FF-Factories/readme.md
2019-06-21 10:04:19 +02:00

6.4 KiB

FF\Factories | Fast Forward Family

by Marco Stoll


What is the Fast Forward Family?

Fast Forward, in short FF, is a template for building web applications. The FF Family is a series of basic repositories on which FF depends on but may also be used independently if desired.

FF is not a framework in and of itself and therefore should not be called so. But you may orchestrate multiple FF components to build an web application skeleton that provides the most common tasks.

Introduction - What if FF\Factories?

FF\Factories provides an factory pattern implementation for generic object instantiation.

Installation

via Composer

@todo

manual Installation

@todo

The Factories

The AbstractFactory provides logic to introduce factory-style object instantiation. By configuring it with a designated class locator you may invoke its create() method with a class identifier and the necessary constructor arguments to get a fresh instance of this class.

The factory will instruct the its class locator to detect a suitable class definition and after that will invoke the class's constructor and return the object.

An example:

namespace MyProject\Views\Helpers;

use FF\Factories\AbstractFactory;
use FF\Factories\ClassLocators\NamespaceClassLocator;

/**
 * Definition of Helpers Factory
 */
class MyHelpersFactory extends AbstractFactory
{
    public function __construct()
    {
        // configure the factory with its own namespace
        // to search for Helper class
        parent::__construct(new NamespaceClassLocator(__NAMESPACE__));
    }
}

...

// Will get a MyViewHelper instance assumed the a MyProject\Views\Helpers\MyViewHelper class exists.
// In this example $arg1 and $arg2 will be passed to the MyViewHelper class's constructor in the given order.
$myHelper = $myHelpersFactory->create('MyViewHelper', $arg1, $arg2);

The AbstractSingletonFactory extends this behaviour by adding a singleton pattern to its implementation that will ensure that an instance of a class identified by its identifier will only be instantiated a single time.
So any additional call to its create() method will return the same instance as the first time.

Beware: Only the class identifier will be taken into account for identifying already instantiated objects. Varying any constructor arguments will not lead to generating new object instances.

The Class Locators

Class locators implement various strategies to derive full-qualified class names based on a shorter class identifier. Each class locator defines a different convention for specifying class identifiers and the logic to detect suitable class definitions based on this.

The Namespace Class Locator

This class locator can be configured with a list of base namespaces ro search for class definitions with a class identifier relative to one of its base namespaces. The base namespaces wil be search in the give order. So the locator will return the first match of an existing class.

An example:

use FF\Factories\ClassLocators\NamespaceClassLocator;

$myLocator = new NamespaceClassLocator('MyProject\Sub1', 'MyProject\Sub2');

// This will find MyProject\Sub1\MyClass or MyProject\Sub2\MyClass in this order.
// If none of the above exist, $class will be null.
$class = $myLocator->locateClass('MyClass');

// This will find MyProject\Sub1\Foo\MyClass or MyProject\Sub2\Foo\MyClass in this order.
// If none of the above exist, $class will be null.
$class = $myLocator->locateClass('Foo\MyClass');

The Base Namespace Class Locator

This class locator can be configured with a list of base namespaces and a common suffix ro search for class definitions with a class identifier relative to one of its base namespaces. The base namespaces wil be search in the give order. So the locator will return the first match of an existing class.

An example:

use FF\Factories\ClassLocators\BaseNamespaceClassLocator;

$commonSuffix = 'Some\Suffix';
$myLocator = new NamespaceClassLocator($commonSuffix, MyProject\Sub1', 'MyProject\Sub2');

// This will find MyProject\Sub1\Some\Suffix\MyClass or MyProject\Sub2\Some\Suffix\MyClass in this order.
// If none of the above exist, $class will be null.
$class = $myLocator->locateClass('MyClass');

// This will find MyProject\Sub1\Some\Suffix\Foo\MyClass or MyProject\Sub2\Some\Suffix\Foo\MyClass in this order.
// If none of the above exist, $class will be null.
$class = $myLocator->locateClass('Foo\MyClass');    

The Namespace Prefixed Class Locator

Sometimes you want to distribute class definitions of a certain kind (say Event classes) over various packages. To provide a factory capable of creating this events objects you may use the NamespacePrefixedClassLocator. This locator enforces you to place your various class definitions within a common class namespace prefix.

An example:

    use FF\Factories\ClassLocators\NamespacePrefixedClassLocator;
    
    // The first argumens ('Events') is the common class namespace prefix.
    // The following argumentgs are the base namespaces to inspect.
    $myLocator = new NamespaceClassLocator('Events', MyProject\Sub1', 'MyProject\Sub2');
    
    // This will find MyProject\Sub1\Events\MyEvent or MyProject\Sub2\Events\MyEven in this order.
    // If none of the above exist, $class will be null.
    $class = $myLocator->locateClass('MyEvent');
    
    // This will find MyProject\Sub1\Foo\Events\MyEvent or MyProject\Sub2\Foo\Events\MyEvent in this order.
    // If none of the above exist, $class will be null.
    $class = $myLocator->locateClass('Foo\MyEvent');

Road map

The extend of the Factories component is mainly driven by the needs of other FF components, so not concrete features are planned at this time. The component surely will grow as other FF components require additional logic that is not part of their domain.