PHPackages                             docteurklein/translator-bundle - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Localization &amp; i18n](/categories/localization)
4. /
5. docteurklein/translator-bundle

ActiveSymfony-bundle[Localization &amp; i18n](/categories/localization)

docteurklein/translator-bundle
==============================

This bundle's purpose is to provide an interface for edition, addition and deletion of translations messages.

3.0.1(10y ago)462.7k14[7 issues](https://github.com/docteurklein/TranslatorBundle/issues)MITPHPPHP &gt;=5.4

Since Jul 23Pushed 9y ago3 watchersCompare

[ Source](https://github.com/docteurklein/TranslatorBundle)[ Packagist](https://packagist.org/packages/docteurklein/translator-bundle)[ RSS](/packages/docteurklein-translator-bundle/feed)WikiDiscussions master Synced 1mo ago

READMEChangelog (3)Dependencies (2)Versions (5)Used By (0)

TranslatorBundle
----------------

[](#translatorbundle)

This bundle's purpose is to provide an interface for edition, addition and deletion of translations messages.

Currently supported formats:

- YAML
- XLIFF
- CSV

Install &amp; setup the bundle
------------------------------

[](#install--setup-the-bundle)

1. Install via composer

```
    composer require docteurklein/translator-bundle=~3.0
```

2. Add the bundle to your `AppKernel` class

```
    // app/AppKernerl.php
    public function registerBundles()
    {
        $bundles = array(
            // ...
            new Knp\Bundle\TranslatorBundle\KnpTranslatorBundle,
            // ...
        );
        // ...
    }
```

3. Add routing

```
    // app/config/routing.yml

    knplabs_translator_admin:
        resource: @KnpTranslatorBundle/Resources/config/routing/edition.yml
            prefix:   /trans/admin

    knplabs_translator:
        resource: @KnpTranslatorBundle/Resources/config/routing/routing.yml
            prefix:   /trans
```

These route files provide the following routes:

```
[router] Current routes
Name                     Method  Pattern
knplabs_translator_list  GET    /trans/admin/list
knplabs_translator_get   GET    /trans/{id}/{domain}/{locale}
knplabs_translator_put   PUT    /trans/

```

Minimal configuration
---------------------

[](#minimal-configuration)

This bundle requires the activation of the core translator:

```
    // app/config/config.yml
    framework:
        # ...
        translator:    { fallback: en }
        # ...
```

Additional configuration
------------------------

[](#additional-configuration)

This bundle relies on the Ext Core library. You can decide wheter or not it will be included automatically.

```
    knplabs_translator:
        include_vendor_assets: false # defaults to true
```

Services
--------

[](#services)

This bundle introduces those services:

```
knp_translator.dumper.csv                    container Knp\Bundle\TranslatorBundle\Dumper\CsvDumper
knp_translator.dumper.xliff                  container Knp\Bundle\TranslatorBundle\Dumper\XliffDumper
knp_translator.dumper.yaml                   container Knp\Bundle\TranslatorBundle\Dumper\YamlDumper
knp_translator.writer                        container Knp\Bundle\TranslatorBundle\Translation\Writer

controllers are services too:

knp_translator.controller.edition    request   Knp\Bundle\TranslatorBundle\Controller\EditionController
knp_translator.controller.translator request   Knp\Bundle\TranslatorBundle\Controller\TranslatorController

```

API
---

[](#api)

Updating a given translation key is really simple:

```
    $this->get('translator.writer')->write('the key to translate', 'the translated string', 'messages', 'en');
```

Rest API
--------

[](#rest-api)

- Update `english` translations files for domain `tests` with `translated value` for key `foo.bar.baz`

```
    curl -X PUT http://project-url/trans/  \
        -F 'id=foo.bar.baz' \
        -F 'domain=messages' \
        -F 'locale=en' \
        -F 'value=translate value'
```

- Get the translated value of key `foo.bar.baz` for `english` locale for `tests` domain

```
    curl http://project-url/trans/foo.bar.baz/tests/en
```

###  Health Score

34

—

LowBetter than 77% of packages

Maintenance17

Infrequent updates — may be unmaintained

Popularity30

Limited adoption so far

Community14

Small or concentrated contributor base

Maturity61

Established project with proven stability

 Bus Factor1

Top contributor holds 98.8% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Every ~402 days

Total

3

Last Release

3870d ago

Major Versions

2.1.0 → 3.0.02015-09-18

PHP version history (2 changes)2.1.0PHP &gt;=5.3.0

3.0.0PHP &gt;=5.4

### Community

Maintainers

![](https://www.gravatar.com/avatar/f1c31c81fac8f125314208689f18ddecd5f31ffb10b5485641158f3d438b6263?d=identicon)[florian.klein@free.fr](/maintainers/florian.klein@free.fr)

---

Top Contributors

[![docteurklein](https://avatars.githubusercontent.com/u/109846?v=4)](https://github.com/docteurklein "docteurklein (82 commits)")[![OskarStark](https://avatars.githubusercontent.com/u/995707?v=4)](https://github.com/OskarStark "OskarStark (1 commits)")

---

Tags

translator

### Embed Badge

![Health badge](/badges/docteurklein-translator-bundle/health.svg)

```
[![Health](https://phpackages.com/badges/docteurklein-translator-bundle/health.svg)](https://phpackages.com/packages/docteurklein-translator-bundle)
```

###  Alternatives

[stichoza/google-translate-php

Free Google Translate API PHP Package

2.0k7.6M124](/packages/stichoza-google-translate-php)[barryvdh/laravel-translation-manager

Manage Laravel Translations

1.7k3.6M17](/packages/barryvdh-laravel-translation-manager)[vsch/laravel-translation-manager

Enhanced Laravel Translation Manager

184190.9k2](/packages/vsch-laravel-translation-manager)[phpmyadmin/motranslator

Translation API for PHP using Gettext MO files

591.8M8](/packages/phpmyadmin-motranslator)[kargnas/laravel-ai-translator

AI-powered translation tool for Laravel language files

24838.8k1](/packages/kargnas-laravel-ai-translator)[gettext/translator

Gettext translator functions

114.6M10](/packages/gettext-translator)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
