satori/micro

Microframework application

v0.1.2 2019-06-22 07:23 UTC

This package is auto-updated.

Last update: 2024-12-05 22:57:52 UTC


README

Requires PHP 7

Usage

Dependency injection container

Step 1: Declare dependencies.

declare(strict_types=1);

use Satori\Micro\Application;

$app = new Application();

/**
 * Declares an action that has dependencies.
 */
$app->pageIndexAction = function (Application $app) {
    return new \Page\IndexAction(
        $app->pageIndexTemplate,
        $app->pageIndexService
    );
};

/**
 * Declares a template that depends on a configuration parameter.
 */
$app->pageIndexTemplate = function (Application $app) {
    return new \Page\IndexTemplate($app['path.template']);
};

/**
 * Declares an service.
 */
$app->pageIndexService = function (Application $app) {
    return new \Page\IndexService($app['fake.data']);
};

/**
 * Configuration parameters.
 */
$app['path.root'] = __DIR__ . '/../..';
$app['path.template'] = $app['path.root'] . '/template/site';
$app['fake.data'] = ['foo' => 'Foo', 'bar' => 'Bar'];

Step 2: Get action with resolved dependencies.

$action = $app->pageIndexAction;

Event dispatcher

Step 1: Subscribe a listener.

declare(strict_types=1);

use Satori\Micro\Application;
use App\Logger;

$app = new Application();

/**
 * Declares a logger.
 */
$app->logger = function (Application $app) {
    return new \App\Logger();
};

/**
 * Subscribes a listener to an event.
 *
 * @param string   $event    The unique name of the event.
 * @param string   $listener The unique name of the listener.
 * @param callable $callback The closure or invokable object.
 */
$app->subscribe(
    'system_error', // $event
    'logger',       // $listener
    function (Application $app, array $arguments = null) {
        $logger = $app->logger;
        $logger->log('error', 'System error', $arguments);
    }
);

Step 2: Notify all listeners about an event.

$app->notify('system_error', ['file' => '/app/functions.php', 'line' => 20]);

License

MIT License