Simple Yet Powerful PSR-11 Complaint Di Container

v2.4.0 2023-09-19 20:55 UTC

README

Latest Stable Version License ci.yml Coverage Status

A Simple PSR-11 Complaint Di Container

Requirements

  • php: >=7.4
  • psr/container: ~1.0 || ~2.0

Installing

Install the latest version with:

composer require 'corpus/di'

Usage

Getting started with Di the three most important methods follow.

  • The set method is used to set either the item to return or a lambda to lazily construct it, optionally taking constructor arguments.
  • The get method is used to retrieve values with memoization after the initial lazy loading.
  • The getNew is used to invoke the lazy loading creation lambda every call, optionally taking an array of constructor arguments as a second parameter.
<?php

require 'vendor/autoload.php';

$di = new \Corpus\Di\Di;

// Eager Loading
$di->set('foo', new Foo);

$di->get('foo'); // the Foo instance from above

// --- --- --- --- --- ---

// Lazy Loading
$di->set('bar', function () {
	return new Bar;
});

// Value is memoized, new Bar() is only called once at first `get`.
$bar1 = $di->get('bar');
$bar2 = $di->get('bar');

// --- --- --- --- --- ---

// Constructor Parameters
$di->set('baz', function ( $qux ) {
	return new Baz($qux);
});

// Calling getNew explicitly avoids the memoization. Constructor params passed as array.
$baz  = $di->getNew('baz', [ 'corge' ]);
$baz2 = $di->getNew('baz', [ 'grault' ]);

// --- --- --- --- --- ---

// Auto-Constructor Parametrization
$di->set('qux', Qux::class);

$qux1 = $di->get('qux'); // New instance of Qux
$qux2 = $di->get('qux'); // Memoized instance of Qux

// --- --- --- --- --- ---

// Lazy Loading with auto-arguments.
$di->set('quux', function ( Qux $qux ) {
	return new Quux($qux);
});

$quux = $di->get('quux'); // Instance of Quux given the previous instance of Qux automatically

// --- --- --- --- --- ---

// getMany lets you retrieve multiple memoized values at once.
[$foo, $bar] = $di->getMany([ 'foo', 'bar' ]);

// getManyNew lets you retrieve multiple new values at once, providing for arguments.
[$baz, $baz2] = $di->getManyNew([ [ 'baz', [ 'corge' ] ], [ 'baz', [ 'grault' ] ] ]);

$di->callFromReflectiveParams(function (Bar $bar, Baz $baz){
	// Callable called with parameters automatically populated based on their name
	// $bar => 'bar'
});

// Construct a class auto-populating constructor parameters based on their name
$controller1 = $di->constructFromReflectiveParams(MyController::class);
$controller2 = $di->constructFromReflectiveParams('MyController');

Documentation

Class: \Corpus\Di\Di

Method: Di->getMany

function getMany(array $ids) : array

Retrieve multiple item; cached if existing. For use with list()

Parameters:
  • string[] $ids - The names/keys of the items
Returns:
  • array

Method: Di->get

function get($id)

Finds an entry of the container by its identifier and returns it.

Parameters:
  • string $id - Identifier of the entry to look for.

Throws: \Psr\Container\NotFoundExceptionInterface - No entry was found for this identifier.

Throws: \Psr\Container\ContainerExceptionInterface - Error while retrieving the entry.

Returns:
  • mixed - Entry.

Method: Di->getManyNew

function getManyNew(array $data) : array

Retrieve multiple item. For use with list()

Parameters:
  • array[] $data - The array of (names/keys / argument) pair tuple of the items

Throws: \InvalidArgumentException

Returns:
  • array

Method: Di->getNew

function getNew(string $id [, array $args = []])

Retrieve an item

Parameters:
  • string $id - The name/key of the item
  • array $args

Throws: \Corpus\Di\Exceptions\UndefinedIdentifierException

Method: Di->duplicate

function duplicate(string $src, string $dest)

Clone a given value into a second key

Parameters:
  • string $src - The source
  • string $dest - The destination

Method: Di->set

function set(string $id, $value)

Store a value via key to retrieve later

Parameters:
  • string $id - The name/key of the item
  • mixed $value - The value to store

Method: Di->has

function has($id) : bool

Returns true if the container can return an entry for the given identifier.

Returns false otherwise.

has($id) returning true does not mean that get($id) will not throw an exception.
It does however mean that get($id) will not throw a NotFoundExceptionInterface.

Parameters:
  • string $id - Identifier of the entry to look for.
Returns:
  • bool

Method: Di->raw

function raw(string $id)
Parameters:
  • string $id - The name/key to be retrieved

Throws: \Corpus\Di\Exceptions\UndefinedIdentifierException

Method: Di->constructFromReflectiveParams

function constructFromReflectiveParams(string $className [, array $initials = []]) : object

Use reflection to execute a classes constructor with auto-populated parameters

Parameters:
  • string $className - The class to construct
  • array $initials - An ordered list of arguments to populate initial arguments on constructor

Method: Di->callFromReflectiveParams

function callFromReflectiveParams(callable $callable [, array $initials = []])

Use reflection to execute a callable with auto-populated parameters

Parameters:
  • array $initials - An ordered list of arguments to populate initial arguments on callable
Returns:
  • mixed - the return value of the callable.

Class: \Corpus\Di\Exceptions\UndefinedIdentifierException

Thrown when attempting to retrieve a key that does not exist.