Swtich DIC to symfony container.

This commit is contained in:
Marco Vito Moscaritolo 2015-05-31 10:33:27 +02:00
parent a0e72b9bc7
commit 3eb1648e13
6 changed files with 108 additions and 156 deletions

View file

@ -26,10 +26,9 @@ if (empty($timezone)) {
}
use PHPCI\Logging\LoggerConfig;
use Pimple\Container;
use G\Yaml2Pimple\ContainerBuilder;
use G\Yaml2Pimple\YamlFileLoader;
use Symfony\Component\DependencyInjection\ContainerBuilder;
use Symfony\Component\Config\FileLocator;
use Symfony\Component\DependencyInjection\Loader\YamlFileLoader;
$configFile = __DIR__ . '/PHPCI/config.yml';
$configEnv = getenv('phpci_config_file');
@ -52,32 +51,14 @@ if (defined('PHPCI_IS_CONSOLE') && PHPCI_IS_CONSOLE) {
$loggerConfig = LoggerConfig::newFromFile(__DIR__ . "/loggerconfig.php");
}
$container = new Container();
$builder = new ContainerBuilder($container);
$loader = new YamlFileLoader($builder, new FileLocator(__DIR__));
$container = new ContainerBuilder();
$loader = new YamlFileLoader($container, new FileLocator(__DIR__));
$loader->load('services.yml');
if (file_exists($configFile)) {
$container['config_file'] = $configFile;
$container->set('config_file', $configFile);
}
$container['store.user'] = function () {
return b8\Store\Factory::getStore('User');
};
$container['store.project'] = function () {
return b8\Store\Factory::getStore('Project');
};
$container['store.build'] = function () {
return b8\Store\Factory::getStore('Build');
};
$container['store.build_meta'] = function () {
return b8\Store\Factory::getStore('BuildMeta');
};
/**
* Allow to modify PHPCI configuration without modify versioned code.
* Dameons should be killed to apply changes in the file.
@ -91,4 +72,4 @@ if (is_readable($localVarsFile)) {
require_once(__DIR__ . '/vars.php');
\PHPCI\Helper\Lang::init($container['config']);
\PHPCI\Helper\Lang::init($container->get('config'));

View file

@ -1,7 +1,7 @@
{
"name" : "block8/phpci",
"description" : "Simple continuous integration for PHP projects.",
"minimum-stability": "dev",
"minimum-stability": "stable",
"type" : "library",
"keywords" : ["php", "phpci", "ci", "continuous", "integration", "testing", "phpunit", "continuous integration", "jenkins", "travis"],
"homepage" : "http://www.phptesting.org/",
@ -49,7 +49,7 @@
"robmorgan/phinx": "~0.4",
"sensiolabs/ansi-to-html": "~1.1",
"jakub-onderka/php-parallel-lint": "0.8.*",
"gonzalo123/yaml2pimple": "^1.0@dev"
"symfony/dependency-injection": "~2.7"
},
"autoload-dev": {

176
composer.lock generated
View file

@ -4,7 +4,7 @@
"Read more about it at https://getcomposer.org/doc/01-basic-usage.md#composer-lock-the-lock-file",
"This file is @generated automatically"
],
"hash": "bd1ad78288fdaea0e4a92b25d644b204",
"hash": "4c1675c48cc8ac6ab60ff9a6663bcdb8",
"packages": [
{
"name": "block8/b8framework",
@ -53,54 +53,6 @@
],
"time": "2014-12-01 21:02:58"
},
{
"name": "gonzalo123/yaml2pimple",
"version": "dev-master",
"source": {
"type": "git",
"url": "https://github.com/gonzalo123/yml2pimple.git",
"reference": "63145b8c1506cc4a01e4b79b2c5b7222f5ab9d94"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/gonzalo123/yml2pimple/zipball/63145b8c1506cc4a01e4b79b2c5b7222f5ab9d94",
"reference": "63145b8c1506cc4a01e4b79b2c5b7222f5ab9d94",
"shasum": ""
},
"require": {
"pimple/pimple": "3.0.*@dev",
"symfony/config": "2.6.*@dev",
"symfony/yaml": "2.6.*@dev"
},
"type": "library",
"extra": {
"branch-alias": {
"dev-master": "1.0-dev"
}
},
"autoload": {
"psr-4": {
"G\\Yaml2Pimple\\": "src/"
}
},
"notification-url": "https://packagist.org/downloads/",
"license": [
"MIT"
],
"authors": [
{
"name": "Gonzalo Ayuso",
"email": "gonzalo123@gmail.com"
}
],
"description": "Build a Pimple/Container from a config file",
"keywords": [
"container",
"dependency injection",
"pimple"
],
"time": "2014-10-04 14:56:45"
},
{
"name": "ircmaxell/password-compat",
"version": "v1.0.4",
@ -609,6 +561,66 @@
"homepage": "http://symfony.com",
"time": "2015-01-25 04:39:26"
},
{
"name": "symfony/dependency-injection",
"version": "v2.7.0",
"source": {
"type": "git",
"url": "https://github.com/symfony/DependencyInjection.git",
"reference": "137bf489c5151c7eb1e4b7dd34a123f9a74b966d"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/symfony/DependencyInjection/zipball/137bf489c5151c7eb1e4b7dd34a123f9a74b966d",
"reference": "137bf489c5151c7eb1e4b7dd34a123f9a74b966d",
"shasum": ""
},
"require": {
"php": ">=5.3.9"
},
"conflict": {
"symfony/expression-language": "<2.6"
},
"require-dev": {
"symfony/config": "~2.2",
"symfony/expression-language": "~2.6",
"symfony/phpunit-bridge": "~2.7",
"symfony/yaml": "~2.1"
},
"suggest": {
"symfony/config": "",
"symfony/proxy-manager-bridge": "Generate service proxies to lazy load them",
"symfony/yaml": ""
},
"type": "library",
"extra": {
"branch-alias": {
"dev-master": "2.7-dev"
}
},
"autoload": {
"psr-4": {
"Symfony\\Component\\DependencyInjection\\": ""
}
},
"notification-url": "https://packagist.org/downloads/",
"license": [
"MIT"
],
"authors": [
{
"name": "Fabien Potencier",
"email": "fabien@symfony.com"
},
{
"name": "Symfony Community",
"homepage": "https://symfony.com/contributors"
}
],
"description": "Symfony DependencyInjection Component",
"homepage": "https://symfony.com",
"time": "2015-05-29 14:44:44"
},
{
"name": "symfony/filesystem",
"version": "v2.6.4",
@ -1971,66 +1983,6 @@
],
"time": "2015-03-04 02:07:03"
},
{
"name": "symfony/dependency-injection",
"version": "v2.6.4",
"target-dir": "Symfony/Component/DependencyInjection",
"source": {
"type": "git",
"url": "https://github.com/symfony/DependencyInjection.git",
"reference": "42bbb43fab66292a1865dc9616c299904c3d4d14"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/symfony/DependencyInjection/zipball/42bbb43fab66292a1865dc9616c299904c3d4d14",
"reference": "42bbb43fab66292a1865dc9616c299904c3d4d14",
"shasum": ""
},
"require": {
"php": ">=5.3.3"
},
"conflict": {
"symfony/expression-language": "<2.6"
},
"require-dev": {
"symfony/config": "~2.2",
"symfony/expression-language": "~2.6",
"symfony/yaml": "~2.1"
},
"suggest": {
"symfony/config": "",
"symfony/proxy-manager-bridge": "Generate service proxies to lazy load them",
"symfony/yaml": ""
},
"type": "library",
"extra": {
"branch-alias": {
"dev-master": "2.6-dev"
}
},
"autoload": {
"psr-0": {
"Symfony\\Component\\DependencyInjection\\": ""
}
},
"notification-url": "https://packagist.org/downloads/",
"license": [
"MIT"
],
"authors": [
{
"name": "Symfony Community",
"homepage": "http://symfony.com/contributors"
},
{
"name": "Fabien Potencier",
"email": "fabien@symfony.com"
}
],
"description": "Symfony DependencyInjection Component",
"homepage": "http://symfony.com",
"time": "2015-01-25 04:39:26"
},
{
"name": "symfony/finder",
"version": "v2.6.4",
@ -2120,10 +2072,8 @@
}
],
"aliases": [],
"minimum-stability": "dev",
"stability-flags": {
"gonzalo123/yaml2pimple": 20
},
"minimum-stability": "stable",
"stability-flags": [],
"prefer-stable": false,
"prefer-lowest": false,
"platform": {

View file

@ -12,6 +12,6 @@ session_start();
require_once(__DIR__ . '/../bootstrap.php');
$app = $container['application'];
$app = $container->get('application');
print $app->handleRequest();

View file

@ -1,16 +1,37 @@
parameters:
config_file: ./PHPCI/config.yml
config_file: ./../PHPCI/config.yml
storage.factory: b8\Store\Factory
services:
http.request:
class: b8\Http\Request
arguments: []
http.response:
class: b8\Http\Response
arguments: []
config:
class: PHPCI\Config
arguments: [%config_file%]
application:
class: PHPCI\Application
arguments: [@config, @http.request, @http.response, @store.user, @store.project]
storage.user:
class: PHPCI\Store\Base\UserStore
factory: [%storage.factory%, getStore]
arguments:
- User
storage.project:
class: PHPCI\Store\Base\ProjectStore
factory: [%storage.factory%, getStore]
arguments:
- Project
storage.build:
class: PHPCI\Store\Base\BuildStore
factory: [%storage.factory%, getStore]
arguments:
- Build
storage.build_meta:
class: PHPCI\Store\Base\BuildMetaStore
factory: [%storage.factory%, getStore]
arguments:
- BuildMeta
http.request:
class: b8\Http\Request
arguments: []
http.response:
class: b8\Http\Response
arguments: []
config:
class: PHPCI\Config
arguments: [%config_file%]
application:
class: PHPCI\Application
arguments: [@config, @http.request, @http.response, @storage.user, @storage.project]

View file

@ -8,7 +8,7 @@ if (!defined('APPLICATION_PATH')) {
// Define our PHPCI_URL, if not already defined:
if (!defined('PHPCI_URL')) {
define('PHPCI_URL', $container['config']->get('phpci.url'));
define('PHPCI_URL', $container->get('config')->get('phpci.url'));
}
// Define PHPCI_BIN_DIR
@ -38,5 +38,5 @@ if (!defined('IS_WIN')) {
// If an environment variable is set defining our config location, use that
// otherwise fall back to PHPCI/config.yml.
if (!defined('PHPCI_CONFIG_FILE')) {
define('PHPCI_CONFIG_FILE', $container['config_file']);
define('PHPCI_CONFIG_FILE', $container->get('config_file'));
}