acelot / resolver
Dependency auto resolver for PHP 7 and 8
Installs: 1 960
Dependents: 0
Suggesters: 1
Security: 0
Stars: 12
Watchers: 2
Forks: 1
Open Issues: 0
Requires
- php: ^7.3 || ^8.0
- psr/container: ^1.0
Requires (Dev)
- phpunit/phpunit: ^9.0
- vimeo/psalm: ^4.8
This package is auto-updated.
Last update: 2024-12-20 15:31:52 UTC
README
Resolver is a dependency auto resolver for PHP 7 and 8. Supports PSR-11 ContainerInterface
.
Installation
composer require acelot/resolver
Why?
Imagine that you have a controller:
class UsersController { public function __construct(UsersService $service) { // ... } }
As you can see the controller requires UsersService
in constructor. To resolve this dependency you can just pass
the new instance of UsersService
. Let's do this:
$service = new UsersService(); $controller = new UsersController($service);
It doesn't work, because UsersService
, in turn, requires UsersRepository
to access the data.
class UsersService { public function __construct(UsersRepository $repository) { // ... } }
Okay, let's create the repository instance!
$repository = new UsersRepository(); $service = new UsersService($repository); $controller = new UsersController($service);
Sadly, it still doesn't work, because we encountering the new dependency! The repository, surprisingly, requires a database connection :)
class UsersRepository { public function __construct(Database $db) { // ... } }
You say "Eat this!".
$db = new Database('connection string here'); $repository = new UsersRepository($db); $service = new UsersService($repository); $controller = new UsersController($service);
Success! We have finally created the instance of UsersController
!
Now imagine that you have ten or hundred controllers like this?!
With Resolver you can greatly simplify creation of classes.
In what turns this code using Resolver:
$resolver = new Resolver([ Database::class => ObjectDefinition::define(Database::class)->withArgument('connectionString', 'connection string here') ]); $controller = $resolver->resolve(UsersController::class);
And it's all.
How it works?
Resolver resolves the classes by using Reflection. Through reflection the Resolver finds out all dependencies of the class and all dependencies of dependencies and so on. When Resolver reaches the deepest dependency it starts creating instances of these one by one until the top class. The resolved classes are stored in local array to avoid re-resolving.
Available definitions
- FactoryDefinition (short alias
factory()
) - ObjectDefinition (short alias
object()
) - ValueDefinition (short alias
value()
)
Instance sharing
Resolved definitions can be shared between calls via ->shared()
method. This method available in FactoryDefinition
and ObjectDefinition
. ValueDefinition
is shared always by design.
Resolver (c) by Valeriy Protopopov.
Resolver is licensed under a MIT license.