TYPO3 v10 has reached end-of-life as of April 30th 2023 and is no longer being maintained. Use the version switcher on the top left of this page to select documentation for a supported version of TYPO3.

Need more time before upgrading? You can purchase Extended Long Term Support (ELTS) for TYPO3 v10 here: TYPO3 ELTS.

Extension Integration

This section describes how an extension author can get his extension setup at Crowdin.


Important to know

  • Your extension must be on GitHub, BitBucket or GitLab

  • Currently TYPO3 can only handle one branch/version for languages, more to that later.


Get in contact with the team in the TYPO3 slack channel cig-crowdin-localization with the following information:

  1. Extension name

  2. Information if your extension is already available on the previous translation server

  3. Your email address for an invitation to Crowdin, so you will get the correct role for your project.


You need to handle the integration yourself as you got the permissions on GitHub.


The User Interface has changed slightly, this used to be under Settings > Integrations > Setup integration.

  1. Go to the url of your project at Crowdin (e.g.

  2. Switch to the tab Integrations

  3. Find the card which corresponds to your extension source, e.g. GitHub / GitLab / Bitbucket

  4. Click Set Up integration and then select "Set Up integration"

Start of Crowdin integration for an extension

Start of Crowdin integration for an extension

A modal will open, allowing you to select the correct repository.

Select Branches

Select the main branch you want to be translated.

Branch configuration

Branch configuration


TYPO3 can currently handle one branch for an extension! Typically you should select the master branch.

Push Translations

Click on the Show advanced settings link below to decide now how you want your translations to behave:

Setting for translation pushes

Setting for translation pushes

Uncheck the checkbox to avoid pushing back the translations to your project directly.

Branch Configuration

Now click on the edit button next to the branch name to setup your branch configuration.

Branch configuration

This will open a new modal and will ask for the Configuration file name. We propose the file name .crowdin.yaml

Setting for translation pushes

Adopt the file name and press Continue.

Now you need to define where the language files are located.

Location of translation files

Typically the following setup will workout fine:

  • Source file path: /Resources/Private/Language/

  • Translated file path: /%original_path%/%two_letters_code%.%original_file_name%

Please check in the right area of the model if all xlf files have been identified.

Now press the green save button in upper left corner and then the save button in lower right corner.

Now press the last save button and you are done!

After a short time you should see something like that


Happy translating!


Checkout the Frequently Asked Questions (FAQ) for solutions to common pitfalls.