Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/derrabus/silex-psr11-provider
Registers a PSR-11 compatible container as a service inside a Silex application.
https://github.com/derrabus/silex-psr11-provider
psr-11 silex-provider
Last synced: 2 months ago
JSON representation
Registers a PSR-11 compatible container as a service inside a Silex application.
- Host: GitHub
- URL: https://github.com/derrabus/silex-psr11-provider
- Owner: derrabus
- License: mit
- Created: 2018-02-04T17:43:40.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2020-07-17T10:51:00.000Z (over 4 years ago)
- Last Synced: 2024-09-13T12:39:58.799Z (3 months ago)
- Topics: psr-11, silex-provider
- Language: PHP
- Homepage:
- Size: 9.77 KB
- Stars: 4
- Watchers: 4
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
Psr11ServiceProvider
====================This service provider registers a PSR-11 compatible container as a service
inside a [Silex](https://github.com/silexphp/Silex) application.PSR-11 enables developers to write code that is aware of the service container
without coupling it to a specific container implementation, thus allowing to
switch to another service container more easily.[![Build Status](https://travis-ci.org/derrabus/silex-psr11-provider.svg?branch=master)](https://travis-ci.org/derrabus/silex-psr11-provider)
Installation
------------Use [Composer](https://getcomposer.org/) to install the package.
```
composer require derrabus/silex-psr11-provider
```Usage
-----Once you have registered the service provider, you can either access the
container as service `service_container` or as a controller argument by using
`Psr\Container\ContainerInterface` as type hint.Examples
--------```php
use Psr\Container\ContainerInterface;
use Rabus\Psr11ServiceProvider\Psr11ServiceProvider;
use Silex\Application;
use Silex\Provider\ServiceControllerServiceProvider;
use Symfony\Component\HttpFoundation\RedirectResponse;class SomeController
{
private $container;public function __construct(ContainerInterface $container)
{
$this->container = $container;
}public function someAction()
{
return new RedirectResponse(
$this->container->get('url_generator')->generate('home')
);
}
}$app = new Application();
$app->register(new ServiceControllerServiceProvider());
$app->register(new Psr11ServiceProvider());$app['some_controller'] = function ($app) {
// Inject a PSR-11 container instead of the $app
return new SomeController($app['service_container']);
};$app->get('/', function() {
return 'Home.';
})->bind('home');$app->get('/test1', 'some_controller:someAction');
// Type-hint the PSR-11 container instead of the $app
$app->get('/test2', function (ContainerInterface $container) {
new RedirectResponse($container->get('url_generator')->generate('home'));
});```
Blog
----This service provider can be used as a stepping stone on the migration path
from Silex to Symfony. It has been created to illustrate how to
[decouple Silex applications from the service container implementation](https://medium.com/@derrabus/decoupling-silex-applications-from-the-service-container-implementation-635263f05e52).