Webhooks are user-defined HTTP callbacks, which can be maintained, modified and managed by any third-party users, in order to cause events on one site to invoke behavior on another.
Webhooks can be called from anywhere. They can be added in a Bitbucket repo's settings, to extend what Bitbucket does when the repository changes (for example, new code is pushed or a pull request is merged).
When the webhook is triggered, the assigned languages/projects on POEditor receive data from the Bitbucket file that is connected to it.
- api_token (required) - you can get this key from your POEditor account. You'll find it in My Account > API Access.
- id_project (required) - the id of project. You'll find it in My Account > API Access.
- language (required) - language code. You'll find it in My Account > API Access.
- operation (required) - can be one of the following:
- get_terms - brings the terms from connected file on Bitbucket to the POEditor project
- import_translations - brings the translations from the file on Bitbucket repo to the linked language in the POEditor project
- import_terms_and_translations - brings new terms from the file on Bitbucket repo to the POEditor project, also adding translations to the linked language
- export_terms_and_translations - sends terms and translations from POEditor to the linked file on Bitbucket
- sync_terms_and_translations - gets the terms and translations from Bitbucket repo and removes obsolete terms from POEditor
- overwrite_translations (optional) - when importing translations to POEditor, set it to 1 in order to overwrite existing translations
In the Bitbucket integration page, you can find a webhook generator.
Linking multiple files to a language
Webhooks work on a project / language basis. So, if you have several files linked to a language, it's enough to run one webhook with an operation and that operation will be executed for all the files linked to that language.
We strongly recommend that you do not use the sync webhook if you have multiple files linked to the source language. The sync webhook deletes the terms which are in the project, but are not in the connected file, so it will delete the terms from the other linked files. The terms from the file last synced is what remains in your POEditor project.
Notes: 1) The export option can be triggered from anywhere, except Bitbucket.
2) How your webhook behaves is determined by how you set it up in the integration page, in the Settings of each linked language.