Task #3583
closedNo longer possible to overwrite translated strings using wlc
0%
Description
Reported by Mikhel, I open a ticket to better track the issue:
-------------------------------
Overwriting existing translations still fails for me, both with wlc and
curl. Example commands:
wlc --key "<my API key from Weblate>" --url "
https://translations.documentfoundation.org/api/" upload --input
"master/libo_ui/svl/messages.po" --overwrite --method translate
"libo_ui-master/svlmessages/et"
curl -s -X POST -F method=translate -F overwrite=true -F
conflict=replace-translated -F file=@"master/libo_ui/svl/messages.po" -
H "authorization: Token <my API key>"
https://translations.documentfoundation.org/api/translations/libo_ui-master/svlmessages/et/file/
{"not_found":0,"skipped":19,"accepted":0,"total":19,"result":false,"count":19}
Previously untranslated or fuzzy strings get updated as expected.
--------------------------------
Archive of the mail
https://listarchives.libreoffice.org/global/l10n/2022/msg00146.html
Christian Lohmaier: could you have a look at what could go wrong?
Updated by Christian Lohmaier over 2 years ago
- Target version set to Q2/2022
The old wlc bug was diagnoes to be a change in the API way back https://docs.weblate.org/en/latest/api.html#post--api-translations-(string-project)-(string-component)-(string-language)-file-
→ the "conflict" (resolution strategy) flag needs to be set to "replace-translated"
That has been an API change way back for version 4.2 already.
The curl example uses the new flag, but also uses the no longer used overwrite parameter, not sure whether that causes some trouble. Sample file would have been nice...
response includes "skipped" with all strings - need to do some own testing...
Updated by Mihkel Tõnnov over 2 years ago
Thank you for looking into this, Christian.
For curl, the "overwrite" parameter doesn't seem to make a difference, but inspecting the upload page, I realised the parameter name should've been "conflicts" (plural):curl -s -X POST -F method=translate -F conflicts=replace-translated -F file=
@"master/libo_ui/svl/messages.po" -H "authorization: Token <my API key>" https://translations.documentfoundation.org/api/translations/libo_ui-master/svlmessages/et/file/
did the trick:
{"not_found":0,"skipped":18,"accepted":1,"total":19,"result":true,"count":19}
As for wlc (1.13), it doesn't accept "--conflict" as an argument: wlc --key <my API key> --url "https://translations.documentfoundation.org/api/" upload --input "master/libo_ui/svl/messages.po" --method translate --conflict replace-translated "libo_ui-master/svlmessages/et"
returns:
usage: wlc [-h] [--format {text,csv,json,html}] [--version] [--debug] [--config CONFIG] [--config-section CONFIG_SECTION] [--key KEY] [--url URL] {version,list-projects,list-components,list-languages,list-translations,show,delete,ls,commit,push,pull,reset,cleanup,repo,changes,stats,lock-status,lock,unlock,download,upload} ... wlc: error: unrecognized arguments: --conflict
Similar result with "--conflicts replace-translated" and just "--replace-translated".
Also tried with "--overwrite replace-translated" which returned:
Error: Object not found on the server (maybe operation is not supported on the server)
Anyway, at least curl works now -- and I can live with that :)
Thanks again!
Updated by Christian Lohmaier over 2 years ago
- Status changed from New to Resolved
wfm if it wfy :-)
Updated by Florian Effenberger about 2 years ago
- Status changed from Resolved to Closed