Realized in fewer than 200 lines of source.
Well documented, perfect for building/learning.
100% line and method coverage on PHP 8.2, 8.3, and 8.4.
One of the fastest PHP dynamic autowired containers available.
Cobalt was created to push the performance limits of what a PHP-based dynamic
autowired DI container can achieve. Container::class implements the PSR-11
ContainerInterface and provides many of the features found in more notable
container projects. Resolution closures are cached after the first build, so
subsequent lookups skip all reflection work. Cobalt and its simple, heavily
commented source are perfect for learning, or for embedding inside projects
and frameworks.
The Cobalt service container has the following features:
- Single class container implementing the PSR-11
ContainerInterfacev2. ArrayAccessmethods for container bindings.- Constructor injection of type-hinted dependencies.
- Dependency injection through
bind()method closures. - Autowired dependency resolution using Reflection.
- Top-down inversion of control (IoC).
- Shared mode option (singleton only).
- Bind existing instances into the container.
- A self-binding global container instance.
composer require jshannon63/cobalt
use Jshannon63\Cobalt\Container;
// create a default (prototype) container
$app = new Container();
// or, create a singleton-only services container
$app = new Container('shared');Binding does not instantiate the class. Instantiation is deferred until the
binding is requested from the container. bind() accepts three parameters:
the abstract name, the concrete implementation, and a boolean for whether
the binding is a singleton. The abstract name is free-form and acts as the
key in the binding registry.
bind(string $abstract, mixed $concrete = null, bool $singleton = false): void
// a simple binding using only the class name
$app->bind(Foo::class);
// or, bind an interface with a desired concrete implementation —
// you can swap the concrete out in one place in your code.
$app->bind(FooInterface::class, Foo::class);
// or, bind an interface or other label to a closure to directly
// control dependency injection.
$app->bind(FooInterface::class, fn () => new Foo('123-456-7890'));
// or, use array access to bind a new instance directly.
$app['Foo'] = new Foo();$instance = resolve(string $id): mixed (resolve checks for an existing binding before instantiating)
$foo = $app->resolve(FooInterface::class);
// or
$foo = $app[FooInterface::class];
// or
$foo = $app->get(FooInterface::class);Trying to resolve a missing binding throws NotFoundException per PSR-11.
make() is bind() then resolve() — useful for one-shot instantiation.
$instance = make(string $abstract, mixed ...$args): mixed
$foo = $app->make(FooInterface::class, Foo::class);alias(string $alias, string $binding): void
Allows creating additional string IDs for accessing existing container bindings.
$app->alias('myfoo', FooInterface::class);Pass an object to bind() and Cobalt registers it as a singleton automatically
(a pre-built instance is by definition shared).
$app->bind('Foo', new Foo);$bool = has(string $abstract): bool
$bool = $app->has('Foo');$array = getBinding(string $abstract): array
$array = $app->getBinding($abstract);$array = getBindings(): array
$array = $app->getBindings();Run the full quality bar locally:
composer install
composer check # lint + analyse + testOr individually:
composer test # PHPUnit
composer lint # Laravel Pint (PSR-12 + opinionated)
composer analyse # PHPStan level 9The MIT License (MIT). Please see License File for more information.