2017 © Pedro Peláez
 

library simple-container

A simple psr-11 container for PHP >= 7.0

image

fkeloks/simple-container

A simple psr-11 container for PHP >= 7.0

  • Monday, September 4, 2017
  • by fkeloks
  • Repository
  • 1 Watchers
  • 0 Stars
  • 0 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 1 Versions
  • 0 % Grown

The README.md

PSR-11 Simple container

Build Status, (*1)

A simple psr-11 compatible container.
By Florian B. (Alias fkeloks), (*2)

Installation :

With Composer:, (*3)

composer require fkeloks/simple-container

How to use it :

Declare configuration:

Example:, (*4)

$configuration = [
    FakeClassA::class => FakeClassA::class,
    FakeClassB::class => FakeClassA::class,
    'FakeC'           => FakeClassC::class,
    'FakeD'           => [
        'class'  => FakeClassD::class,
        'params' => ['A', 'B']
    ]
]

/*
 * get(FakeClassA::class) will return FakeClassA class
 * |-> But this statement is useless, the container will understand automatically.
 *
 * get(FakeClassB::class) will return FakeClassA class
 * |-> Because the configuration overrides the name of the class.
 *
 * get('FakeC') will return FakeClassC class
 *
 * get('FakeD') will return FakeClassD class withs constructor parameters 'A' and 'B'
 */

Creating the container from the containerBuilder:

We consider that $configuration has been instantiated above., (*5)

use SimpleContainer\ContainerBuilder;

ContainerBuilder::build($configuration);
$container = ContainerBuilder::getContainer();
use SimpleContainer\ContainerBuilder;

// Short syntax
$container = ContainerBuilder::build($configuration)::getContainer();

Once the constructor is built, the container can be retrieved anywhere with:, (*6)

use SimpleContainer\ContainerBuilder;

$container = ContainerBuilder::getContainer();
// The container will be configured with the previous `ContainerBuilder::build()`

If necessary, the container has a destroy () method to destroy the previous build ():, (*7)

ContainerBuilder::destroy();

Get and make methods:

Get:

The get function will return the desired instance.
At the first call, the instance will be cached.
If the instance is present in the cache, the cached instance will be returned., (*8)

Examples:, (*9)

$classA = $container->get('FakeA');
$classA = $container->get(FakeClassB::class);

Make:

The make function returns the desired instance.
This function does not take into account the cache in the return of the instance.
However, the returned instance will still be cached for the next get (), (*10)

Examples:, (*11)

$classB = $container->make('FakeB');
$classC = $container->make(FakeClassC::class);

Examples:

Example 1:, (*12)

class Hello() {

    private $name;
    private $pseudo;

    public function __construct($name, $pseudo) {
        $this->name   = $name;
        $this->pseudo = $pseudo;
    }

    public function sayHello() {
        return "Hello {$this->pseudo} ({$this->name}) !";
    }
}

SimpleContainer\ContainerBuilder::build([
    'helloClass' => [
        'class'  => Hello::class,
        'params' => ['James', 'Jojo']
    ]
])

$container = SimpleContainer\ContainerBuilder::getContainer();

$helloClass = $container->get('helloClass');
echo $helloClass->sayHello();

/*
 * The result will be: "Hello Jojo (James) !"
 */

Example 2:, (*13)

SimpleContainer\ContainerBuilder::build([
    'classA' => ClassA::class
])

$container = SimpleContainer\ContainerBuilder::getContainer();

$classA = $container->get('classA'); // A new instance of ClassA is generated
$classA = $container->get('classA'); // Class A has been cached, so the same instance is returned

$classA = $container->make('classA');
// |-> The make function does not take the cache into account, so a new instance of A is generated

Further information

In the kind of configuration:, (*14)

SimpleContainer\ContainerBuilder::build([
    'helloClass' => [
        'class'  => Hello::class,
        'params' => ['James', 'Jojo']
    ]
])

The constructor will receive 2 distinct variables. ('James', and 'Jojo')
Whatever type of variable to pass to the constructor, params must be an array., (*15)

Examples:, (*16)

'params' => ['yeah']     // string
'params' => [true]       // boolean
'params' => [['A', 'B']] // array
'params' => [123456789]  // integer

The Versions

04/09 2017

dev-master

9999999-dev

A simple psr-11 container for PHP >= 7.0

  Sources   Download

MIT

The Requires

 

The Development Requires

by Avatar fkeloks