1. Go to this page and download the library: Download composite-php/container library. Choose the download type require.
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
composite-php / container example snippets
// Your simple logger.
class Logger
{
public function log(string $message): void
{
echo $message;
}
}
// Your users store: responsible for containing usernames.
class UsersStore
{
private array $users = [];
public function add(string $username): void
{
$this->users[$username] = true;
}
}
// Your service that is responsible for registering user: persisting username and writing something to log.
class UserRegistrationService
{
public function __construct(
private Logger $logger,
private UsersStore $store
) {
}
public function registerUser(string $name): void
{
$this->store->add($name);
$this->logger->log('User was registered.');
}
}
$regService = new UserRegistrationService(
new Logger(),
new UsersStore()
);
$regService->register('Foo');
use Composite\Container\Container;
$container = new Container();
// Ask the container to get instance of UserRegistrationService.
// The container will create instances of Logger and UsersStore,
// then it will return the UserRegistrationService with the
// Instance of this class can be instantiated automatically, because there are no constructor arguments.
class A
{
}
// Instance of this class can be instantiated automatically, because the parameter is an instance of a concrete class.
class B
{
public function __construct(
public A $a
) {
}
}
// Instance of this class can be instantiated automatically, because the parameter is an instance of concrete class.
// When B (being an argument) is instantiated, it gets injected with A.
// So, resolution of dependencies is recursive.
class C
{
public function __construct(
public B $b
) {
}
}
// The following will be resolved with default "/tmp/default" value.
class FileLogger
{
public function __construct(
private string $targetFile = '/tmp/default'
) {}
}
// The following cannot be instantiated automatically,
// because the container doesn't know what to pass as constructor argument.
class FileLogger
{
public function __construct(
private string $targetFile
) {
}
}
interface LoggerInterface
{
}
// Instance of this service cannot be instantiated automatically,
// because constructor argument is type hinted against interface, which cannot be instantiated.
class MyService
{
public function __construct(
public LoggerInterface $logger
)
}
use Composite\Container\Container;
$container = new Container();
// Resolve your service from the container.
$regService = $container->get(UserRegistrationService::class);
// Register user.
$regService->register('Foo');
// Resolve your service from the container again - the container will return previously created instance.
$regService = $container->get(UserRegistrationService::class);
$regService->register('Foo'); // Will throw an exception, because of the logic in UserStore::add.
class MyLogger
{
public function __construct() {
echo 'Constructor invoked!';
}
}
$container = new Container();
// The following line outputs 'Constructor invoked!'
$container->get(MyLogger::class);
// The following line outputs nothing, because the container will return instance of `MyLogger` that was created before (and constructor of which had been called).
$container->get(MyLogger::class);
use Composite\Container\Container;
// Define that whenever an instance of LoggerInterface is > static function (Container $container) {
return $container->get(FileLogger::class);
}
];
// Create container instance, passing the definitions.
$container = new Composite\Container\Container($definitions);
// Returns instance of FileLogger.
$hotelsProvider = $container->get(LoggerInterface::class);
use Psr\Container\ContainerInterface;
use Composite\Container\Container;
$definitions = static function (): iterable {
yield ContainerInterface::class
=> static fn (Container $container)
=> $container;
yield UsersRepository::class
=> static fn (Container $container)
=> $container->get(DatabaseUserRepository::class);
yield Config::class
=> static fn ()
=> new Config();
};
$container = new Container($definitions());
use Composite\Container\Container;
$definitions = [
'projectRoot' => static function () {
return '/opt/xres';
}
];
$container = new Container($definitions);
// Returns '/opt/xres' string.
$projectRoot = $container->get('projectRoot');
declare(strict_types=1);
use Composite\Container;
// Create container instance without custom definitions.
$container = new Container();
use Psr\Container\ContainerInterface;
class ContainerDefinitions implements IteratorAggregate
{
public function getIterator() : Traversable
{
// When someone needs instance of `ContainerInterface`, return the container itself.
yield ContainerInterface::class
=> fn (Container $container) => $container;
// When someone gets FactoryInterface, return concrete factory implementation.
yield FactoryInterface::class
=> fn (Container $container)
=> $container->get(MyConcreteFactory::class);
}
}
// Create container with the definitions.
$container = new Container(new ContainerDefitions());
// When requested for FactoryInterface instance, container will return MyConcreteFactory according
// to your definition.
/** @var MyConcreteFactory $myFactory */
$myFactory = $container->get(FactoryInterface::class);
shell
composer
Loading please wait ...
Before you can download the PHP files, the dependencies should be resolved. This can take some minutes. Please be patient.