germania-kg / language-negotiation
Middleware to store negotiated client language in a Request attribute.
Installs: 34
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 2
Forks: 0
Open Issues: 0
pkg:composer/germania-kg/language-negotiation
Requires
- php: ^7.4|^8.0
- psr/http-message: ^1.0
- psr/http-server-middleware: ^1.0
- psr/log: ^1.0
- willdurand/negotiation: ^2.3|^3.0
Requires (Dev)
- nyholm/psr7: ^1.3
- php-coveralls/php-coveralls: ^2.0
- phpspec/prophecy-phpunit: ^2.0
- phpstan/phpstan: ^1.9
- phpunit/phpunit: ^8.0|^9.0
This package is auto-updated.
Last update: 2025-10-04 14:15:22 UTC
README
Germania KG ยท Language Negotiation
This middleware stores the result of Will Durand's language Negotiation language in a Request attribute X-language-negotiated.
Works with both PSR-15 SinglePass and traditional Slim-like DoublePass approach.
Usage
Setup
<?php use Germania\LanguageNegotiation\LanguageNegotiationMiddleware; use Negotiation\LanguageNegotiator; $negotiator = new LanguageNegotiator(); $priorities = array('de', 'fu', 'en'); new LanguageNegotiationMiddleware($negotiator, $priorities);
Configuration using constructor :
// Defaults: $accept_header = "Accept-Language"; $attr_name = "X-language-negotiated"; $logger = new Monolog // Any PSR-3 Logger; new LanguageNegotiationMiddleware($negotiator, $priorities, $accept_header, $attr_name, $logger);
Configuration using methods API:
$middleware = new LanguageNegotiationMiddleware($negotiator, $priorities); $middleware->setAcceptLanguageHeader("Accept-Language"); $middleware->setRequestAttributeName("X-language-negotiated"); $middleware->setLogger( $psr3_logger );
Usage in Controller
Slim-like example:
<?php class MyController { public function __invoke(ServerRequestInterface $request, ResponseInterface $response, $args) { // S.th. like 'fu' echo $request->getAttribute("X-language-negotiated"); } }
Development
$ git clone git@github.com:GermaniaKG/language-negotiation.git
$ cd language-negotiation
$ composer install
Unit tests
Either copy phpunit.xml.dist to phpunit.xml and adapt to your needs, or leave as is. Run PhpUnit test or composer scripts like this:
$ composer test # or $ vendor/bin/phpunit