Convert Dependency injection bootstrap file to use factory functions, rather than direct instances
This commit is contained in:
parent
e0e63cf094
commit
88e06a0052
@ -38,58 +38,85 @@ return function(array $config_array = []) {
|
|||||||
// -------------------------------------------------------------------------
|
// -------------------------------------------------------------------------
|
||||||
|
|
||||||
// Create Config Object
|
// Create Config Object
|
||||||
$config = new Config($config_array);
|
$container->set('config', function() {
|
||||||
$container->set('config', $config);
|
return new Config();
|
||||||
|
});
|
||||||
|
$container->setInstance('config', new Config($config_array));
|
||||||
|
|
||||||
// Create Cache Object
|
// Create Cache Object
|
||||||
$container->set('cache', new CacheManager($config));
|
$container->set('cache', function($container) {
|
||||||
|
return new CacheManager($container->get('config'));
|
||||||
|
});
|
||||||
|
|
||||||
// Create Aura Router Object
|
// Create Aura Router Object
|
||||||
$container->set('aura-router', new RouterContainer);
|
$container->set('aura-router', function() {
|
||||||
|
return new RouterContainer;
|
||||||
|
});
|
||||||
|
|
||||||
// Create Html helper Object
|
// Create Html helper Object
|
||||||
$html_helper = (new HelperLocatorFactory)->newInstance();
|
$container->set('html-helper', function($container) {
|
||||||
$html_helper->set('menu', function() use ($container) {
|
$html_helper = (new HelperLocatorFactory)->newInstance();
|
||||||
$menu_helper = new Helper\Menu();
|
$html_helper->set('menu', function() use ($container) {
|
||||||
$menu_helper->setContainer($container);
|
$menu_helper = new Helper\Menu();
|
||||||
return $menu_helper;
|
$menu_helper->setContainer($container);
|
||||||
|
return $menu_helper;
|
||||||
|
});
|
||||||
|
|
||||||
|
return $html_helper;
|
||||||
});
|
});
|
||||||
$container->set('html-helper', $html_helper);
|
|
||||||
|
|
||||||
// Create Request/Response Objects
|
// Create Request/Response Objects
|
||||||
$request = ServerRequestFactory::fromGlobals(
|
$container->set('request', function() {
|
||||||
$_SERVER,
|
return ServerRequestFactory::fromGlobals(
|
||||||
$_GET,
|
$_SERVER,
|
||||||
$_POST,
|
$_GET,
|
||||||
$_COOKIE,
|
$_POST,
|
||||||
$_FILES
|
$_COOKIE,
|
||||||
);
|
$_FILES
|
||||||
$container->set('request', $request);
|
);
|
||||||
$container->set('response', new Response());
|
});
|
||||||
|
$container->set('response', function() {
|
||||||
|
return new Response;
|
||||||
|
});
|
||||||
|
|
||||||
// Create session Object
|
// Create session Object
|
||||||
$session = (new SessionFactory())->newInstance($_COOKIE);
|
$container->set('session', function() {
|
||||||
$container->set('session', $session);
|
return (new SessionFactory())->newInstance($_COOKIE);
|
||||||
|
});
|
||||||
|
|
||||||
// Miscellaneous helper methods
|
// Miscellaneous helper methods
|
||||||
$util = new Util($container);
|
$container->set('util', function($container) {
|
||||||
$container->set('anime-client', $util);
|
return new Util($container);
|
||||||
$container->set('util', $util);
|
});
|
||||||
|
|
||||||
// Models
|
// Models
|
||||||
$container->set('api-model', new Model\API($container));
|
$container->set('api-model', function($container) {
|
||||||
$container->set('anime-model', new Model\Anime($container));
|
return new Model\API($container);
|
||||||
$container->set('manga-model', new Model\Manga($container));
|
});
|
||||||
$container->set('anime-collection-model', new Model\AnimeCollection($container));
|
$container->set('anime-model', function($container) {
|
||||||
|
return new Model\Anime($container);
|
||||||
|
});
|
||||||
|
$container->set('manga-model', function($container) {
|
||||||
|
return new Model\Manga($container);
|
||||||
|
});
|
||||||
|
$container->set('anime-collection-model', function($container) {
|
||||||
|
return new Model\AnimeCollection($container);
|
||||||
|
});
|
||||||
|
|
||||||
// Miscellaneous Classes
|
// Miscellaneous Classes
|
||||||
$container->set('auth', new HummingbirdAuth($container));
|
$container->set('auth', function($container) {
|
||||||
$container->set('url-generator', new UrlGenerator($container));
|
return new HummingbirdAuth($container);
|
||||||
|
});
|
||||||
|
$container->set('url-generator', function($container) {
|
||||||
|
return new UrlGenerator($container);
|
||||||
|
});
|
||||||
|
|
||||||
// -------------------------------------------------------------------------
|
// -------------------------------------------------------------------------
|
||||||
// Dispatcher
|
// Dispatcher
|
||||||
// -------------------------------------------------------------------------
|
// -------------------------------------------------------------------------
|
||||||
$container->set('dispatcher', new Dispatcher($container));
|
$container->set('dispatcher', function($container) {
|
||||||
|
return new Dispatcher($container);
|
||||||
|
});
|
||||||
|
|
||||||
return $container;
|
return $container;
|
||||||
};
|
};
|
||||||
|
@ -26,7 +26,8 @@
|
|||||||
"phpunit/phpunit": "^5.4",
|
"phpunit/phpunit": "^5.4",
|
||||||
"robmorgan/phinx": "^0.6.4",
|
"robmorgan/phinx": "^0.6.4",
|
||||||
"humbug/humbug": "~1.0@dev",
|
"humbug/humbug": "~1.0@dev",
|
||||||
"consolidation/robo": "~1.0@dev",
|
"consolidation/robo": "~1.0@RC",
|
||||||
"henrikbjorn/lurker": "^1.1.0"
|
"henrikbjorn/lurker": "^1.1.0",
|
||||||
|
"symfony/var-dumper": "^3.1"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user