ferdiunal / laravel-translator
This package allows you to use freely available online translation tools in your project.
Requires
- php: ^8.2
- deeplcom/deepl-php: ^1.9
- guzzlehttp/guzzle: ^7.8
- illuminate/contracts: ^10.0||^11.0||^12.0||^13.0
- illuminate/support: ^10.0||^11.0||^12.0||^13.0
- nlpcloud/nlpcloud-client: ^1.0
- openai-php/client: ^0.10.3
- spatie/laravel-package-tools: ^1.16
- stichoza/google-translate-php: ^5.2
Requires (Dev)
- larastan/larastan: ^2.9||^3.0
- laravel/pint: ^1.24
- nunomaduro/collision: ^7.10||^8.1||^9.0
- orchestra/testbench: ^8.22||^9.0||^10.0||^11.0
- pestphp/pest: ^2.34||^3.0||^4.4.1
- pestphp/pest-plugin-arch: ^2.7||^3.0||^4.0
- pestphp/pest-plugin-laravel: ^2.3||^3.0||^4.1
- phpstan/extension-installer: ^1.3
- phpstan/phpstan-deprecation-rules: ^1.1||^2.0
- phpstan/phpstan-phpunit: ^1.3||^2.0
- spatie/laravel-ray: ^1.35
- dev-main
- v1.3.0
- v1.2.1
- v1.2.0
- v1.1.3
- v1.1.2
- v1.1.1
- v1.1.0
- v1.0.1
- v1.0.0
- dev-dependabot/composer/openai-php/client-tw-0.19.0
- dev-dependabot/github_actions/dependabot/fetch-metadata-2.5.0
- dev-dependabot/github_actions/actions/checkout-6
- dev-dependabot/github_actions/stefanzweifel/git-auto-commit-action-7
- dev-dependabot/github_actions/aglipanci/laravel-pint-action-2.6
This package is auto-updated.
Last update: 2026-05-23 19:04:12 UTC
README
Laravel Translator
English | Türkçe
A type-safe and extensible translation package for Laravel applications with multiple provider support.
Supported providers:
- Google Translate
- Bing Translator
- DeepL
- MyMemory
- NLP Cloud
- OpenAI / OpenAI-compatible custom base URLs
Requirements
- PHP
^8.2— Laravel 13 combinations require PHP^8.3through Laravel's framework constraints. - Laravel 10, 11, 12, or 13.
Installation
composer require ferdiunal/laravel-translator
Publish the configuration file:
php artisan vendor:publish --provider="Ferdiunal\LaravelTranslator\LaravelTranslatorServiceProvider"
Basic usage
use Ferdiunal\LaravelTranslator\LaravelTranslator; $translated = LaravelTranslator::translate( translator: 'google', source: 'en', target: 'tr', text: 'Hello World', );
Facade:
use Ferdiunal\LaravelTranslator\Facades\LaravelTranslator; $translated = LaravelTranslator::translate('openai', 'en', 'tr', 'Hello World');
Helper:
$translated = translator('deepl', 'en', 'tr', 'Hello World');
Resolving a provider instance:
$provider = LaravelTranslator::translator('mymemory'); $translated = $provider->run('en', 'tr', 'Hello :name');
run() preserves Laravel placeholders. Placeholders such as :name and :count are not translated, and characters such as @ inside email addresses are not corrupted.
Provider keys and aliases
Canonical provider keys:
| Provider | Canonical key | Legacy/compatible alias |
|---|---|---|
google |
- | |
| Bing | bing |
- |
| DeepL | deepl |
- |
| MyMemory | mymemory |
myMemory |
| NLP Cloud | nlpcloud |
nlpCloud |
| OpenAI | openai |
- |
Acronym and case differences are no longer resolved through runtime class-name guessing. Provider resolution uses an explicit registry, so names such as OpenAI, DeepL, NLPCloud, and MyMemory are not fragile on Linux or PSR-4 case-sensitive environments.
Get the list of active providers:
$providers = LaravelTranslator::providers();
Configuration
The published config/translator.php file contains these fields in summary:
return [ 'fallback' => [ 'throw' => env('TRANSLATOR_THROW_ON_FAILURE', false), ], 'http' => [ 'timeout' => (int) env('TRANSLATOR_HTTP_TIMEOUT', 10), 'connect_timeout' => (int) env('TRANSLATOR_HTTP_CONNECT_TIMEOUT', 5), 'retry_times' => (int) env('TRANSLATOR_HTTP_RETRY_TIMES', 1), 'retry_sleep_ms' => (int) env('TRANSLATOR_HTTP_RETRY_SLEEP_MS', 100), ], 'providers' => [ // Example for disabling a built-in provider: // 'openai' => ['enabled' => false], ], 'deepl' => [ 'api_key' => env('DEEPL_API_KEY'), ], 'nlpcloud' => [ 'api_key' => env('NLPCLOUD_API_KEY'), 'model' => env('NLPCLOUD_MODEL', 'nllb-200-3-3b'), ], 'openai' => [ 'api_key' => env('OPENAI_API_KEY'), 'base_url' => env('OPENAI_BASE_URL', 'https://api.openai.com/v1'), 'model' => env('OPENAI_MODEL', 'gpt-4o-mini'), ], ];
The package does not ship a default secret or API key. API keys must be provided through .env.
DEEPL_API_KEY=your-deepl-api-key NLPCLOUD_API_KEY=your-nlpcloud-api-key NLPCLOUD_MODEL=nllb-200-3-3b OPENAI_API_KEY=your-openai-api-key OPENAI_BASE_URL=https://api.openai.com/v1 OPENAI_MODEL=gpt-4o-mini
Adding a custom provider
Custom provider classes must extend Ferdiunal\LaravelTranslator\Translators\Translator.
<?php declare(strict_types=1); namespace App\Translators; use Ferdiunal\LaravelTranslator\Translators\Translator; final class AcmeTranslator extends Translator { public function handle(string $source, string $target, string $text): string { return "[$source>$target] $text"; } public function icon(): string { return 'https://example.com/icon.svg'; } public function key(): string { return 'acme'; } public function title(): string { return 'Acme'; } /** @return array{icon: string, key: string, title: string} */ public function toArray(): array { return [ 'icon' => $this->icon(), 'key' => $this->key(), 'title' => $this->title(), ]; } }
config/translator.php:
'providers' => [ 'acme' => [ 'driver' => App\Translators\AcmeTranslator::class, 'enabled' => true, 'title' => 'Acme', 'icon' => 'https://example.com/icon.svg', 'aliases' => ['legacyAcme'], ], ],
Usage:
$translated = LaravelTranslator::translate('acme', 'en', 'tr', 'Hello');
Disabling or overriding providers
Disable a built-in provider:
'providers' => [ 'openai' => [ 'enabled' => false, ], ],
Override built-in provider metadata or driver:
'providers' => [ 'openai' => [ 'driver' => App\Translators\CustomOpenAITranslator::class, 'title' => 'Company OpenAI Proxy', 'default_base_url' => 'https://ai.example.com/v1', 'enabled' => true, ], ],
Invalid custom provider classes throw InvalidTranslatorProviderException; unknown or disabled providers throw UnsupportedTranslatorException.
Using OpenAI-compatible endpoints
The OpenAI provider supports OpenAI-compatible endpoints through OPENAI_BASE_URL:
OPENAI_API_KEY=your-api-key OPENAI_BASE_URL=https://openrouter.ai/api/v1 OPENAI_MODEL=openai/gpt-4o-mini
Tests and quality gates
composer validate --strict
composer format:check
composer analyse
composer test -- --ci
Single command:
composer ci
The CI matrix is designed to cover PHP 8.2/8.3/8.4/8.5 and Laravel 10/11/12/13 combinations.
License
The MIT License (MIT). Please see License File for more information.
