From a4804cb0296376835f1a4f03f072741cbc815654 Mon Sep 17 00:00:00 2001
From: Anton Minin <anton.a.minin@gmail.com>
Date: Thu, 27 Jul 2017 01:19:18 +0300
Subject: [PATCH 1/5] Run benchmarks without Apache

---
 benchmark-no-apache.sh                   |   25 +
 benchmarks/_functions.sh                 |    3 +-
 libs/parse_results.php                   |    8 +-
 nofuss-1.2/.gitignore                    |    4 +
 nofuss-1.2/cache/.gitkeep                |    0
 nofuss-1.2/cache/nf.all.php              | 6565 ----------------------
 nofuss-1.2/cache/routes.all.php          |   16 -
 staticphp-0.9/Application/Cache/.gitkeep |    0
 8 files changed, 35 insertions(+), 6586 deletions(-)
 create mode 100644 benchmark-no-apache.sh
 create mode 100644 nofuss-1.2/.gitignore
 create mode 100644 nofuss-1.2/cache/.gitkeep
 delete mode 100644 nofuss-1.2/cache/nf.all.php
 delete mode 100644 nofuss-1.2/cache/routes.all.php
 mode change 100644 => 100755 staticphp-0.9/Application/Cache/.gitkeep

diff --git a/benchmark-no-apache.sh b/benchmark-no-apache.sh
new file mode 100644
index 000000000..3ba5c5d05
--- /dev/null
+++ b/benchmark-no-apache.sh
@@ -0,0 +1,25 @@
+#!/bin/sh
+
+#base="http://127.0.0.1/php-framework-benchmark"
+base="http://localhost:8888/php-framework-benchmark"
+
+cd `dirname $0`
+
+php -S localhost:8888 -t .. > /dev/null 2>&1 &
+PHP_PID=$!
+sleep 2;
+
+if [ $# -eq 0 ]; then
+    # include framework list
+    . ./list.sh
+    export targets="$list"
+else
+    export targets="${@%/}"
+fi
+
+cd benchmarks
+
+sh hello_world.sh "$base"
+
+php ../bin/show_results_table.php
+kill $PHP_PID
diff --git a/benchmarks/_functions.sh b/benchmarks/_functions.sh
index 32fec509e..030f945a1 100644
--- a/benchmarks/_functions.sh
+++ b/benchmarks/_functions.sh
@@ -13,7 +13,8 @@ benchmark ()
     # get time
     count=10
     total=0
-    for ((i=0; i < $count; i++)); do
+    #for ((i=0; i < $count; i++)); do
+    for i in $(seq 0 $count); do
         curl "$url" > "$output"
         t=`tail -1 "$output" | cut -f 2 -d ':'`
         total=`php ./benchmarks/sum_ms.php $t $total`
diff --git a/libs/parse_results.php b/libs/parse_results.php
index ccf5d4183..c36a0bb98 100644
--- a/libs/parse_results.php
+++ b/libs/parse_results.php
@@ -18,10 +18,10 @@ function parse_results($file)
         $time   = (float) trim($column[3])*1000;
         $file   = (int) trim($column[4]);
         
-        $min_rps    = min($min_rps, $rps);
-        $min_memory = min($min_memory, $memory);
-        $min_time   = min($min_time, $time);
-        $min_file   = min($min_file, $file);
+        $min_rps    = min($min_rps, $rps ?: INF);
+        $min_memory = min($min_memory, $memory ?: INF);
+        $min_time   = min($min_time, $time ?: INF);
+        $min_file   = min($min_file, $file ?: INF);
         
         $results[$fw] = [
             'rps'    => $rps,
diff --git a/nofuss-1.2/.gitignore b/nofuss-1.2/.gitignore
new file mode 100644
index 000000000..f5b481dc8
--- /dev/null
+++ b/nofuss-1.2/.gitignore
@@ -0,0 +1,4 @@
+/cache/
+!/cache/.gitkeep
+!/cache/smarty/.gitignore
+!/cache/templates_c/.gitignore
\ No newline at end of file
diff --git a/nofuss-1.2/cache/.gitkeep b/nofuss-1.2/cache/.gitkeep
new file mode 100644
index 000000000..e69de29bb
diff --git a/nofuss-1.2/cache/nf.all.php b/nofuss-1.2/cache/nf.all.php
deleted file mode 100644
index 70d879b81..000000000
--- a/nofuss-1.2/cache/nf.all.php
+++ /dev/null
@@ -1,6565 +0,0 @@
-<?php
-
-
-namespace Nf;
-
-abstract class Session extends Singleton
-{
-
-    protected static $_instance = null;
-
-    public static function factory($namespace, $class, $params, $lifetime)
-    {
-        $className = '\\' . $namespace . '\\' . ucfirst($class);
-        return new $className($params, $lifetime);
-    }
-
-    public static function start()
-    {
-        $config = Registry::get('config');
-        if (isset($config->session)) {
-            // optional parameters sent to the constructor
-            if (isset($config->session->params)) {
-                $sessionParams = $config->session->params;
-            }
-            if (is_object($config->session->handler)) {
-                $sessionHandler = self::factory($config->session->handler->namespace, $config->session->handler->class, $sessionParams, $config->session->lifetime);
-            } else {
-                $sessionHandler = self::factory('Nf\Session', $config->session->handler, $sessionParams, $config->session->lifetime);
-            }
-            
-            session_name($config->session->cookie->name);
-            session_set_cookie_params(0, $config->session->cookie->path, $config->session->cookie->domain, false, true);
-            
-            session_set_save_handler(array(
-                &$sessionHandler,
-                'open'
-            ), array(
-                &$sessionHandler,
-                'close'
-            ), array(
-                &$sessionHandler,
-                'read'
-            ), array(
-                &$sessionHandler,
-                'write'
-            ), array(
-                &$sessionHandler,
-                'destroy'
-            ), array(
-                &$sessionHandler,
-                'gc'
-            ));
-            register_shutdown_function('session_write_close');
-            session_start();
-            // session_regenerate_id(true);
-            Registry::set('session', $sessionHandler);
-            return $sessionHandler;
-        } else {
-            return false;
-        }
-        
-    }
-
-    public static function getData()
-    {
-        return $_SESSION;
-    }
-
-    public function __get($key)
-    {
-        return self::get($key);
-    }
-
-    public function __set($key, $value)
-    {
-        return self::set($key, $value);
-    }
-
-    public static function get($key)
-    {
-        if (isset($_SESSION[$key])) {
-            return $_SESSION[$key];
-        } else {
-            return null;
-        }
-    }
-
-    public static function set($key, $value)
-    {
-        $_SESSION[$key] = $value;
-    }
-
-    public static function delete($key)
-    {
-        unset($_SESSION[$key]);
-    }
-}
-
-
-
-namespace Nf;
-
-abstract class Singleton
-{
-
-    protected static $_instance=null;
-
-    protected function __construct()
-    {
-    }
-
-    public static function getInstance()
-    {
-        if (static::$_instance===null) {
-            $className = get_called_class();
-            static::$_instance = new $className;
-        }
-
-        return static::$_instance;
-    }
-
-    public function __clone()
-    {
-        throw new Exception('Cloning not allowed on a singleton object', E_USER_ERROR);
-    }
-}
-
-
-namespace Nf;
-
-class Make
-{
-
-    /**
-     *
-     * @param string $action
-     *            Executes a make action, like "compress" for putting every file into a single .php file or "map" all the classes in a classmap
-     *            You can use your method with make if you call something like:
-     *            php index.php -m "\App\Mymake\Compressor::compress?type=js", type=js will be accessible with a
-     *            $front = \Nf\Front::getInstance();
-     *            $params = $front->getRequest()->getParams();
-     *            
-     */
-    
-    // merge all the framework files to a single php file, merge all the routes to /cache/allroutes.php
-    public static function compress($action = '')
-    {
-        // merge framework files
-        $destFile = Registry::get('applicationPath') . '/cache/nf.all.php';
-        if (is_file($destFile)) {
-            unlink($destFile);
-        }
-        // get the actual folder of Nf in the app's settings
-        $includedFiles = get_included_files();
-        $folder = null;
-        
-        foreach ($includedFiles as $includedFile) {
-            if (preg_match('%Nf\/Autoloader\.php$%', $includedFile, $regs)) {
-                $folder = str_replace('/Autoloader.php', '', $includedFile);
-                $allFiles = self::getAllFiles($folder);
-                // sort by depth for include
-                uasort($allFiles, array(
-                    'self',
-                    'orderFilesByDepth'
-                ));
-                $bigInclude = '<?' . 'php' . "\n";
-                foreach ($allFiles as $file) {
-                    if (substr($file, - 4) == '.php') {
-                        $bigInclude .= "\n" . str_replace('<?' . 'php', '', file_get_contents($file));
-                    }
-                }
-                file_put_contents($destFile, $bigInclude);
-                
-                // merge routes files
-                $destRoutesFile = Registry::get('applicationPath') . '/cache/routes.all.php';
-                if (is_file($destRoutesFile)) {
-                    unlink($destRoutesFile);
-                }
-                $router = \Nf\Router::getInstance();
-                $router->setRootRoutes();
-                $router->setRoutesFromFiles();
-                $router->addAllRoutes();
-                $allRoutes = $router->getAllRoutes();
-                $bigInclude = '<?' . 'php' . "\n return ";
-                $bigInclude .= var_export($allRoutes, true);
-                $bigInclude .= ";";
-                file_put_contents($destRoutesFile, $bigInclude);
-                break;
-            }
-        }
-        
-        if ($folder === null) {
-            die('The cache already exists, remove the generated files before in /cache (nf.all.php and routes.all.php)' . PHP_EOL);
-        }
-    }
-
-    private static function getAllFiles($folder)
-    {
-        $folder = rtrim($folder, '/');
-        $root = scandir($folder);
-        foreach ($root as $value) {
-            if ($value === '.' || $value === '..') {
-                continue;
-            }
-            if (is_file($folder . '/' . $value)) {
-                $result[] = $folder . '/' . $value;
-                continue;
-            }
-            foreach (self::getAllFiles($folder . '/' . $value) as $value) {
-                $result[] = $value;
-            }
-        }
-        return $result;
-    }
-
-    private static function orderFilesByDepth($file1, $file2)
-    {
-        $t = (substr_count($file1, '/') > substr_count($file2, '/'));
-        return $t ? 1 : - 1;
-    }
-}
-
-
-namespace Nf;
-
-class Db
-{
-
-    const FETCH_ASSOC = 2;
-
-    const FETCH_NUM = 3;
-
-    const FETCH_OBJ = 5;
-
-    const FETCH_COLUMN = 7;
-
-    private static $_connections = array();
-
-    public static function factory($config)
-    {
-        if (! is_array($config)) {
-            // convert to an array
-            $conf = array();
-            $conf['adapter'] = $config->adapter;
-            $conf['params'] = (array) $config->params;
-            $conf['profiler'] = (array) $config->profiler;
-        } else {
-            $conf = $config;
-        }
-        $adapterName = get_class() . '\\Adapter\\' . $conf['adapter'];
-        $dbAdapter = new $adapterName($conf['params']);
-        $dbAdapter->setProfilerConfig($conf['profiler']);
-        return $dbAdapter;
-    }
-
-    public static function getConnection($configName, $alternateHostname = null, $alternateDatabase = null, $storeInInstance = true)
-    {
-        $config = \Nf\Registry::get('config');
-        
-        if(!isset($config->db->$configName)) {
-            throw new \Exception('The adapter "' . $configName . '" is not defined in the config file');
-        }
-        
-        $defaultHostname = $config->db->$configName->params->hostname;
-        $defaultDatabase = $config->db->$configName->params->database;
-        $hostname = ($alternateHostname !== null) ? $alternateHostname : $defaultHostname;
-        $database = ($alternateDatabase !== null) ? $alternateDatabase : $defaultDatabase;
-        
-        // if the connection has already been created and if we store the connection in memory for future use
-        if (isset(self::$_connections[$configName . '-' . $hostname . '-' . $database]) && $storeInInstance) {
-            return self::$_connections[$configName . '-' . $hostname . '-' . $database];
-        } else {
-            // optional profiler config
-            $profilerConfig = isset($config->db->$configName->profiler) ? (array)$config->db->$configName->profiler : null;
-            if ($profilerConfig != null) {
-                $profilerConfig['name'] = $configName;
-            }
-            
-            // or else we create a new connection
-            $dbConfig = array(
-                'adapter' => $config->db->$configName->adapter,
-                'params' => array(
-                    'hostname' => $hostname,
-                    'username' => $config->db->$configName->params->username,
-                    'password' => $config->db->$configName->params->password,
-                    'database' => $database,
-                    'charset' => $config->db->$configName->params->charset
-                ),
-                'profiler' => $profilerConfig
-            );
-            
-            // connection with the factory method
-            $dbConnection = self::factory($dbConfig);
-            if ($storeInInstance) {
-                self::$_connections[$configName . '-' . $hostname . '-' . $database] = $dbConnection;
-            }
-            return $dbConnection;
-        }
-    }
-}
-
-
-
-namespace Nf;
-
-use \IntlDateFormatter;
-use \NumberFormatter;
-
-class Localization extends Singleton
-{
-
-    protected static $_instance;
-
-    protected $_currentLocale='fr_FR';
-
-    const NONE=IntlDateFormatter::NONE;
-    const SHORT=IntlDateFormatter::SHORT;
-    const MEDIUM=IntlDateFormatter::MEDIUM;
-    const LONG=IntlDateFormatter::LONG;
-    const FULL=IntlDateFormatter::FULL;
-
-    public static function normalizeLocale($str)
-    {
-        $str=str_replace('-', '_', $str);
-        $arr=explode('_', $str);
-        $out=strtolower($arr[0]) . '_' . strtoupper($arr[1]);
-        return $out;
-    }
-
-    public static function setLocale($locale)
-    {
-        $instance=self::$_instance;
-        $instance->_currentLocale=$locale;
-    }
-
-    public static function getLocale()
-    {
-        $instance=self::$_instance;
-        return $instance->_currentLocale;
-    }
-
-    public static function formatDate($timestamp, $formatDate = self::SHORT, $formatTime = self::SHORT)
-    {
-        $instance=self::$_instance;
-        $fmt=new IntlDateFormatter($instance->_currentLocale, $formatDate, $formatTime);
-        return $fmt->format($timestamp);
-    }
-
-    // syntax can be found on : http://userguide.icu-project.org/formatparse/datetime
-    public static function formatOther($timestamp, $format = 'eeee')
-    {
-        $instance=self::$_instance;
-        $fmt=new IntlDateFormatter($instance->_currentLocale, 0, 0);
-        $fmt->setPattern($format);
-        return $fmt->format($timestamp);
-    }
-
-    public static function formatDay($timestamp, $fullName = true)
-    {
-        return self::formatOther($timestamp, ($fullName?'EEEE':'EEE'));
-    }
-
-    public static function formatMonth($timestamp, $fullName = true)
-    {
-        return self::formatOther($timestamp, ($fullName?'LLLL':'LLL'));
-    }
-
-    public static function formatCurrency($amount, $currency)
-    {
-        $instance=self::$_instance;
-        $fmt = new NumberFormatter($instance->_currentLocale, NumberFormatter::CURRENCY);
-        return $fmt->formatCurrency($amount, $currency);
-    }
-
-    public static function formatNumber($value)
-    {
-        $instance=self::$_instance;
-        $fmt = new NumberFormatter($instance->_currentLocale, NumberFormatter::DECIMAL);
-        return $fmt->format($value);
-    }
-
-    public static function dateToTimestamp($date, $formatDate = self::SHORT, $formatTime = self::SHORT, $acceptISOFormat = false)
-    {
-        if (self::isTimestamp($date)) {
-            return $date;
-        } elseif ($acceptISOFormat && self::isISOFormat($date)) {
-            $dt=new \DateTime($date);
-            return $dt->getTimestamp();
-        } else {
-            $instance=self::$_instance;
-            $fmt=new IntlDateFormatter($instance->_currentLocale, $formatDate, $formatTime);
-            $timestamp=$fmt->parse($date);
-            if ($timestamp) {
-                return $timestamp;
-            } else {
-                throw new \Exception('input date is in another format and is not recognized:' . $date);
-            }
-        }
-    }
-
-    public static function isISOFormat($date)
-    {
-        if (preg_match('/\A(?:^([1-3][0-9]{3,3})-(0?[1-9]|1[0-2])-(0?[1-9]|[1-2][1-9]|3[0-1])\s([0-1][0-9]|2[0-4]):([0-5][0-9]):([0-5][0-9])$)\Z/im', $date)) {
-            return true;
-        } elseif (preg_match('/\A(?:^([1-3][0-9]{3,3})-(0?[1-9]|1[0-2])-(0?[1-9]|[1-2][1-9]|3[0-1])$)\Z/im', $date)) {
-            return true;
-        } else {
-            return false;
-        }
-    }
-
-    public static function isTimestamp($timestamp)
-    {
-        return ((string) (int) $timestamp === (string) $timestamp)
-            && ($timestamp <= PHP_INT_MAX)
-            && ($timestamp >= ~PHP_INT_MAX);
-    }
-}
-
-
-namespace Nf;
-
-use Nf\Registry;
-use Nf\Front;
-
-class Router extends Singleton
-{
-    
-    // pour le routeur
-    private $routingPreferences = array();
-
-    private $routesDirectories = array();
-
-    private $rootRoutesDirectories = array();
-
-    private $allRoutesByVersionAndLocale = array();
-
-    private $activeRoute = array();
-
-    private $allVersionsUrls = array();
-
-    const rootRouteFilename = '_root.php';
-
-    const defaultRequestType = 'default';
-
-    const defaultRouteName = 'default';
-    
-    // routes
-    public function addAllRoutes()
-    {
-                
-        if (Registry::get('environment')!='dev' && file_exists(Registry::get('applicationPath') . '/cache/routes.all.php')) {
-            $this->allRoutesByVersionAndLocale = require(Registry::get('applicationPath') . '/cache/routes.all.php');
-        } else {
-            $routesDirectory = realpath(Registry::get('applicationPath') . '/routes');
-            $directory = new \RecursiveDirectoryIterator($routesDirectory);
-            $files = new \RecursiveIteratorIterator($directory);
-            $allRouteFiles = array();
-            foreach ($files as $file) {
-                $pathname = ltrim(str_replace($routesDirectory, '', $file->getPathname()), '/');
-                // if it's not a folder or anything other than a .php
-                if (substr($pathname, - 1, 1) != '.' && substr($pathname, -4)=='.php') {
-                    $allRouteFiles[] = $pathname;
-                }
-            }
-            // sort allRouteFiles by their depth to allow inheriting a route from all versions and or locales
-            usort($allRouteFiles, function ($a, $b) {
-                return substr_count($a, '/') > substr_count($b, '/');
-            });
-            foreach ($allRouteFiles as $file) {
-                $pathname = ltrim(str_replace($routesDirectory, '', $file), '/');
-            
-                $arrPath = explode('/', $pathname);
-            
-                // routes are sorted by version and locale
-                if (count($arrPath) == 3) {
-                    $version = $arrPath[0];
-                    $locale = $arrPath[1];
-                } elseif (count($arrPath) == 2) {
-                    $version = $arrPath[0];
-                    $locale = '*';
-                } elseif (count($arrPath) == 1) {
-                    $version = '*';
-                    $locale = '*';
-                }
-                // add the route to allRoutes, sorted by version and locale
-                // all your routes are belong to us
-                if (! isset($this->allRoutesByVersionAndLocale[$version])) {
-                    $this->allRoutesByVersionAndLocale[$version] = array();
-                }
-                if (! isset($this->allRoutesByVersionAndLocale[$version][$locale])) {
-                    $this->allRoutesByVersionAndLocale[$version][$locale] = array();
-                }
-                if (basename($file) != self::rootRouteFilename) {
-                    $subPath = str_replace('.php', '', basename($file));
-                } else {
-                    $subPath = '';
-                }
-                $newRoutes = require $routesDirectory . '/' . $pathname;
-                // the file doesn't contain an array, or contains nothing => we ignore it
-                if (is_array($newRoutes)) {
-                    foreach ($newRoutes as &$newRoute) {
-                        if (isset($newRoute['type']) && $newRoute['type']=='inherit') {
-                            // go up one level until we find the route to inherit from
-                            if (isset($this->allRoutesByVersionAndLocale[$version]['*'][$newRoute['from']])) {
-                                $routeToAdd = $this->allRoutesByVersionAndLocale[$version]['*'][$newRoute['from']];
-                                $routeToAdd['regexp'] = $routeToAdd['inheritableRegexp'];
-                                $routeToAdd['regexp'] = ltrim($routeToAdd['regexp'], '/');
-                                $routeToAdd['regexp'] = rtrim(ltrim($subPath . '/' . $routeToAdd['regexp'], '/'), '/');
-                            } elseif (isset($this->allRoutesByVersionAndLocale['*']['*'][$newRoute['from']])) {
-                                $routeToAdd = $this->allRoutesByVersionAndLocale['*']['*'][$newRoute['from']];
-                                $routeToAdd['regexp'] = $routeToAdd['inheritableRegexp'];
-                                $routeToAdd['regexp'] = ltrim($routeToAdd['regexp'], '/');
-                                $routeToAdd['regexp'] = rtrim(ltrim($subPath . '/' . $routeToAdd['regexp'], '/'), '/');
-                            }
-                            $this->allRoutesByVersionAndLocale[$version][$locale][$routeToAdd['name']] = $routeToAdd;
-                        } else {
-                            if (isset($newRoute['regexp'])) {
-                                $newRoute['regexp'] = ltrim($newRoute['regexp'], '/');
-                                $newRoute['inheritableRegexp'] = $newRoute['regexp'];
-                                $newRoute['regexp'] = rtrim(ltrim($subPath . '/' . $newRoute['regexp'], '/'), '/');
-                            }
-                            if (isset($newRoute['name'])) {
-                                $this->allRoutesByVersionAndLocale[$version][$locale][$newRoute['name']] = $newRoute;
-                            } else {
-                                $this->allRoutesByVersionAndLocale[$version][$locale][] = $newRoute;
-                            }
-                        }
-                    }
-                }
-            }
-        }
-    }
-
-    public function setRoutesFromFiles()
-    {
-        $this->routingPreferences[] = 'files';
-    }
-
-    public function setStructuredRoutes()
-    {
-        $this->routingPreferences[] = 'structured';
-    }
-
-    public function setRootRoutes()
-    {
-        $this->routingPreferences[] = 'root';
-    }
-
-    public function findRoute($version, $locale)
-    {
-        $foundController = null;
-        $config = Registry::get('config');
-        $front = Front::getInstance();
-        $originalUri = $front->getRequest()->getUri();
-        
-        // remove everything after a '?' which is not used in the routing system
-        $uri = preg_replace('/\?.*$/', '', $originalUri);
-        
-        // strip the trailing slash, also unused
-        $uri = rtrim((string) $uri, '/');
-        
-        foreach ($this->routingPreferences as $routingPref) {
-            if ($routingPref == 'files') {
-                $foundController = $this->findRouteFromFiles($uri, $version, $locale);
-                // search by version only
-                if (!$foundController) {
-                    $foundController = $this->findRouteFromFiles($uri, $version, '*');
-                }
-                // search without version nor locale
-                if (!$foundController) {
-                    $foundController = $this->findRouteFromFiles($uri, '*', '*');
-                }
-            }
-            
-            if (! $foundController && $routingPref == 'structured') {
-                // l'url doit être de la forme /m/c/a/, ou /m/c/ ou /m/
-                if (preg_match('#^(\w+)/?(\w*)/?(\w*)#', $uri, $uriSegments)) {
-                    $uriSegments[2] = ! empty($uriSegments[2]) ? $uriSegments[2] : 'index';
-                    $uriSegments[3] = ! empty($uriSegments[3]) ? $uriSegments[3] : 'index';
-                    
-                    // on regarde si on a un fichier et une action pour le même chemin dans les répertoires des modules
-                    if ($foundController = $front->checkModuleControllerAction($uriSegments[1], $uriSegments[2], $uriSegments[3])) {
-                        $this->activeRoute = array(
-                            'type' => self::defaultRequestType,
-                            'name' => self::defaultRouteName,
-                            'components' => array()
-                        );
-                        
-                        // les éventuels paramètres sont en /variable/value
-                        $paramsFromUri = ltrim(preg_replace('#^(\w+)/(\w+)/(\w+)#', '', $uri), '/');
-                        
-                        // si on envoie des variables avec des /
-                        if ($paramsFromUri != '') {
-                            if (substr_count($paramsFromUri, '/') % 2 == 1) {
-                                preg_match_all('/([\w_]+)\/([^\/]*)/', $paramsFromUri, $arrParams, PREG_SET_ORDER);
-                                for ($matchi = 0; $matchi < count($arrParams); $matchi ++) {
-                                    $front->getRequest()->setParam($arrParams[$matchi][1], $arrParams[$matchi][2]);
-                                }
-                            }
-                            
-                            // si on envoie des variables avec des var1=val1
-                            if (substr_count($paramsFromUri, '=') >= 1) {
-                                preg_match_all('/([\w_]+)=([^\/&]*)/', $paramsFromUri, $arrParams, PREG_SET_ORDER);
-                                for ($matchi = 0; $matchi < count($arrParams); $matchi ++) {
-                                    $front->getRequest()->setParam($arrParams[$matchi][1], $arrParams[$matchi][2]);
-                                }
-                            }
-                        }
-                    }
-                }
-            }
-        }
-        
-        // si c'est la route par défaut
-        if (! $foundController) {
-            if (empty($uri)) {
-                if ($foundController = $front->checkModuleControllerAction($config->front->default->module, $config->front->default->controller, $config->front->default->action)) {
-                    if (isset($route[2]) && isset($result[1])) {
-                        $front->associateParams($route[2], $result[1]);
-                    }
-                }
-            }
-        }
-        
-        // reads which middlewares are required and adds them
-        if ($foundController) {
-            if (isset($this->activeRoute['middlewares'])) {
-                $this->activeRoute['middlewaresPre'] = array();
-                $this->activeRoute['middlewaresPost'] = array();
-                foreach ($this->activeRoute['middlewares'] as $middlewareClass) {
-                    if (! class_exists($middlewareClass)) {
-                        throw new \Exception('The middleware ' . $middlewareClass . ' cannot be found. Matched route: ' . print_r($this->activeRoute, true));
-                    }
-                    if (isset(class_uses($middlewareClass)['Nf\Middleware\Pre'])) {
-                        $this->activeRoute['middlewaresPre'][] = $middlewareClass;
-                    } else {
-                        $this->activeRoute['middlewaresPost'][] = $middlewareClass;
-                    }
-                }
-            }
-        }
-        
-        return $foundController;
-    }
-    
-    private function findRouteFromFiles($uri, $version, $locale)
-    {
-        
-        $foundController = null;
-        $front = Front::getInstance();
-        
-        if (isset($this->allRoutesByVersionAndLocale[$version][$locale])) {
-            $routes = $this->allRoutesByVersionAndLocale[$version][$locale];
-        
-            if (! $foundController) {
-                $routes = array_reverse($routes);
-        
-                foreach ($routes as $route) {
-                    if (! $foundController) {
-                        // default type is "default"
-                        $requestType = 'default';
-        
-                        // if a specific type is requested
-                        if (isset($route['type'])) {
-                            $requestType = $route['type'];
-                        }
-        
-                        $routeRegexpWithoutNamedParams = preg_replace('/\([\w_]+:/', '(', $route['regexp']);
-        
-                        $arrRouteModuleControllerAction = explode('/', $route['controller']);
-        
-                        // make the first slash after our route directory optional
-                        $routeTest = rtrim('/' . ltrim($routeRegexpWithoutNamedParams, '/'), '/');
-  
-                        // check if this is a match, or else continue until we have a match
-                        if (preg_match('#^' . $routeRegexpWithoutNamedParams . '#', $uri, $refs)) {
-                            // if using a rest request, the user can override the method
-                            if ($requestType == 'rest') {
-                                // default action
-                                if (isset($_SERVER['REQUEST_METHOD'])) {
-                                    $action = strtolower($_SERVER['REQUEST_METHOD']);
-                                }
-                                if ($_SERVER['REQUEST_METHOD'] == 'POST') {
-                                    // overloading the method with the "method" parameter if the request is POST
-                                    if (isset($_POST['method'])) {
-                                        $action = strtolower($_POST['method']);
-                                    }
-                                    // overloading the method with http headers
-                                    // X-HTTP-Method (Microsoft) or X-HTTP-Method-Override (Google/GData) or X-METHOD-OVERRIDE (IBM)
-                                    $acceptableOverridingHeaders = array(
-                                        'HTTP_X_HTTP_METHOD',
-                                        'HTTP_X_HTTP_METHOD_OVERRIDE',
-                                        'HTTP_X_METHOD_OVERRIDE'
-                                    );
-                                    foreach ($acceptableOverridingHeaders as $overridingHeader) {
-                                        if (isset($_SERVER[$overridingHeader])) {
-                                            $action = strtolower($_SERVER[$overridingHeader]);
-                                        }
-                                    }
-                                }
-                                                                
-                                // if overriding the action in the route
-                                if (isset($arrRouteModuleControllerAction[2])) {
-                                    $action = $arrRouteModuleControllerAction[2];
-                                }
-                            } else {
-                                $action = $arrRouteModuleControllerAction[2];
-                            }
-                            
-                            // on teste la présence du module controller action indiqué dans la route
-                            if ($foundController = $front->checkModuleControllerAction($arrRouteModuleControllerAction[0], $arrRouteModuleControllerAction[1], $action)) {
-                                $this->activeRoute = $route;
-                                $front->setRequestType($requestType);
-                                $front->associateParams($route['regexp'], $refs);
-                                break;
-                            }
-                        }
-                    }
-                }
-                unset($route);
-            }
-        }
-        return $foundController;
-    }
-
-    public function getAllRoutes()
-    {
-        return $this->allRoutesByVersionAndLocale;
-    }
-    
-    public function getActiveRoute()
-    {
-        return $this->activeRoute;
-    }
-
-    // returns the url from the defined routes by its name
-    public function getNamedUrl($name, $params = array(), $version = null, $locale = null, $getFullUrl = true)
-    {
-        if ($version == null) {
-            $version = Registry::get('version');
-        }
-        if ($locale == null) {
-            $locale = Registry::get('locale');
-        }
-        // get the actual domain name from the url.ini
-        $domainName = '';
-        if ($getFullUrl) {
-            if (! isset($this->allVersionsUrls[$version][$locale])) {
-                $urlIni = Registry::get('urlIni');
-                $localeSuffix = $urlIni->suffixes->$locale;
-                $versionPrefix = $urlIni->versions->$version;
-                if (strpos($versionPrefix, '|') !== false) {
-                    $arrVersionPrefix = explode('|', $versionPrefix);
-                    $versionPrefix = $arrVersionPrefix[0];
-                    if ($versionPrefix == '<>') {
-                        $versionPrefix = '';
-                    }
-                }
-                $domainName = str_replace('[version]', $versionPrefix, $localeSuffix);
-                if (! isset($this->allVersionsUrls[$version])) {
-                    $this->allVersionsUrls[$version] = array();
-                    $this->allVersionsUrls[$version][$locale] = $domainName;
-                }
-            } else {
-                $domainName = $this->allVersionsUrls[$version][$locale];
-            }
-        }
-        $foundRoute = false;
-        if (isset($this->allRoutesByVersionAndLocale[$version][$locale][$name])) {
-            $url = $this->allRoutesByVersionAndLocale[$version][$locale][$name]['regexp'];
-            $foundRoute = true;
-        } elseif (isset($this->allRoutesByVersionAndLocale[$version]['*'][$name])) {
-            $url = $this->allRoutesByVersionAndLocale[$version]['*'][$name]['regexp'];
-            $foundRoute = true;
-        } elseif (isset($this->allRoutesByVersionAndLocale['*']['*'][$name])) {
-            $url = $this->allRoutesByVersionAndLocale['*']['*'][$name]['regexp'];
-            $foundRoute = true;
-        }
-        if ($foundRoute) {
-            preg_match_all('/\(([\w_]+):([^)]+)\)/im', $url, $result, PREG_SET_ORDER);
-            for ($matchi = 0; $matchi < count($result); $matchi ++) {
-                if (isset($params[$result[$matchi][1]])) {
-                    $url = str_replace($result[$matchi][0], $params[$result[$matchi][1]], $url);
-                }
-            }
-            if ($getFullUrl) {
-                return $domainName . '/' . $url;
-            } else {
-                return $url;
-            }
-        } else {
-            throw new \Exception('Cannot find route named "' . $name . '" (version=' . $version . ', locale=' . $locale . ')');
-        }
-    }
-}
-
-
-namespace Nf;
-
-abstract class File
-{
-
-    public static function mkdir($pathname, $mode = 0775, $recursive = false)
-    {
-        if (! is_dir($pathname)) {
-            $oldumask = umask(0);
-            $ret = @mkdir($pathname, $mode, $recursive);
-            umask($oldumask);
-            return $ret;
-        }
-        return true;
-    }
-
-    public static function rename($old, $new, $mode = 0775)
-    {
-        if (is_readable($old)) {
-            $pathname = dirname($new);
-            if (! is_dir($pathname)) {
-                self::mkdir($pathname, $mode, true);
-            }
-            return rename($old, $new);
-        }
-        return false;
-    }
-
-    public static function uncompress($src, $dest, $unlinkSrc = false)
-    {
-        $finfo = finfo_open(FILEINFO_MIME_TYPE);
-        $mimeType = finfo_file($finfo, $src);
-        finfo_close($finfo);
-        
-        switch ($mimeType) {
-            case 'application/x-gzip':
-                exec('gzip -dcf ' . $src . ($dest !== null ? ' > ' . $dest : ''), $out, $ret);
-                break;
-            
-            default:
-                return false;
-        }
-        
-        if (isset($ret) && $ret === 0) {
-            if ($unlinkSrc) {
-                @unlink($src);
-            }
-        }
-        return ($ret === 0);
-    }
-
-    public static function generatePath($input, $hereMark = '@')
-    {
-        $input = '' . $input;
-        // 15567 => /7/15/56/7/@/
-        // 6871985 => /5/68/71/98/5/@/
-        // 687198565 /5/68/71/98/56/5/@/
-        // 68719856 /6/68/71/98/56/@/
-        // 21 /1/21/@/
-        // 2121 /1/21/21/@/
-        // 1 /1/1/@
-        // antix /x/an/ti/x/@/
-        $len = strlen($input);
-        if ($len == 1) {
-            $output = $input . '/' . $input;
-        } else {
-            $output = $input{$len - 1} . '/';
-            for ($i = 0; $i < $len - 1; $i ++) {
-                $output .= substr($input, $i, 1);
-                if ($i % 2) {
-                    $trailing = '/';
-                } else {
-                    $trailing = '';
-                }
-                $output .= $trailing;
-            }
-            $output .= $input{$len - 1};
-        }
-        $output .= '/' . $hereMark . '/';
-        return '/' . $output;
-    }
-}
-
-
-
-/**
- * Autoloader is a class loader.
- *
- *     <code>
- *      require($library_path . '/php/classes/Nf/Autoloader.php');
- *      $autoloader=new \Nf\Autoloader();
- *      $autoloader->addMap($applicationPath . '/configs/map.php');
- *      $autoloader->addNamespaceRoot('Nf', $libraryPath . '/Nf');
- *      $autoloader->register();
- *     </code>
- *
- * @package Nf
- * @author Julien Ricard
- * @version 1.0
- **/
-namespace Nf;
-
-class Autoloader
-{
-
-    protected static $_directories = array();
-
-    protected static $_maps = array();
-
-    protected static $_namespaceSeparator = '\\';
-
-    const defaultSuffix = '.php';
-
-    public function __construct() {
-        
-    }
-    
-    public static function load($className)
-    {
-        if (! class_exists($className)) {
-            $foundInMaps = false;
-            
-            if (count(self::$_maps) != 0) {
-                // reads every map for getting class path
-                foreach (self::$_maps as $map) {
-                    if (isset($map[$className])) {
-                        if (self::includeClass($map[$className], $className)) {
-                            return true;
-                        } else {
-                            return false;
-                        }
-                    }
-                }
-                $foundInMaps = false;
-            }
-            if (! $foundInMaps) {
-                $namespaceRoot = '';
-                $fileNamePrefix = '';
-                
-                // reads each directory until it finds the class file
-                if (false !== ($lastNsPos = strripos($className, self::$_namespaceSeparator))) {
-                    $namespace = substr($className, 0, $lastNsPos);
-                    $namespaceRoot = substr($className, 0, strpos($className, self::$_namespaceSeparator));
-                    $shortClassName = substr($className, $lastNsPos + 1);
-                    $fileNamePrefix = str_replace(self::$_namespaceSeparator, DIRECTORY_SEPARATOR, $namespace) . DIRECTORY_SEPARATOR;
-                } else {
-                    $shortClassName = $className;
-                }
-                
-                $fileNamePrefix .= str_replace('_', DIRECTORY_SEPARATOR, $shortClassName);
-                
-                foreach (self::$_directories as $directory) {
-                    if ($directory['namespaceRoot'] == $namespaceRoot && $directory['namespaceRoot'] != '') {
-                        // use the specified directory with remaining path
-                        $fileNamePrefix = str_replace($namespaceRoot . DIRECTORY_SEPARATOR, '', $fileNamePrefix);
-                        if (self::includeClass($directory['path'] . $fileNamePrefix . $directory['suffix'], $className)) {
-                            return true;
-                        } else {
-                            // file was not found in the specified directory
-                            return false;
-                        }
-                    } elseif ($directory['namespaceRoot'] == '') {
-                        if (self::includeClass($directory['path'] . $fileNamePrefix . $directory['suffix'], $className)) {
-                            return true;
-                        }
-                    }
-                }
-            }
-        } else {
-            return true;
-        }
-        return false;
-    }
-
-    public static function includeClass($file, $class_name)
-    {
-        if (! class_exists($class_name)) {
-            if (file_exists($file)) {
-                require $file;
-                return true;
-            } else {
-                return false;
-            }
-        } else {
-            // class already exists
-        }
-    }
-
-    public static function addNamespaceRoot($namespaceRoot, $path, $suffix = self::defaultSuffix)
-    {
-        if (substr($path, - 1) != DIRECTORY_SEPARATOR) {
-            $path .= DIRECTORY_SEPARATOR;
-        }
-        self::$_directories[] = array(
-            'namespaceRoot' => $namespaceRoot,
-            'path' => $path,
-            'suffix' => $suffix
-        );
-    }
-
-    public function addMap($mapFilePath = null)
-    {
-        global $applicationPath;
-        global $libraryPath;
-        
-        if($mapFilePath === null) {
-            $mapFilePath = $applicationPath . '/cache/autoloader.map.php';    
-        }
-        
-        if (file_exists($mapFilePath)) {
-            if (pathinfo($mapFilePath, PATHINFO_EXTENSION) == 'php') {
-                $newMap = require($mapFilePath);
-                self::$_maps[] = $newMap;
-            }
-        }
-    }
-
-    public function register()
-    {
-        spl_autoload_register(__NAMESPACE__ . '\Autoloader::load');
-    }
-}
-
-
-
-namespace Nf;
-
-class Registry extends \ArrayObject
-{
-
-    private static $_registry = null;
-
-    /**
-     * Retrieves the default registry instance.
-     *
-     * @return Zend_Registry
-     */
-    public static function getInstance()
-    {
-        if (self::$_registry === null) {
-            self::init();
-        }
-
-        return self::$_registry;
-    }
-
-    /**
-     * Set the default registry instance to a specified instance.
-     *
-     * @param Zend_Registry $registry An object instance of type Zend_Registry,
-     *   or a subclass.
-     * @return void
-     * @throws Zend_Exception if registry is already initialized.
-     */
-    public static function setInstance(\Nf\Registry $registry)
-    {
-        if (self::$_registry !== null) {
-            #require_once 'Zend/Exception.php';
-            throw new Exception('Registry is already initialized');
-        }
-
-        self::$_registry = $registry;
-    }
-
-    /**
-     * Initialize the default registry instance.
-     *
-     * @return void
-     */
-    protected static function init()
-    {
-        self::setInstance(new \Nf\Registry());
-    }
-
-    /**
-     * getter method, basically same as offsetGet().
-     *
-     * This method can be called from an object of type Nf\Registry, or it
-     * can be called statically.  In the latter case, it uses the default
-     * static instance stored in the class.
-     *
-     * @param string $index - get the value associated with $index
-     * @return mixed
-     * @throws Zend_Exception if no entry is registerd for $index.
-     */
-    public static function get($index)
-    {
-        $instance = self::getInstance();
-
-        if (!$instance->offsetExists($index)) {
-            throw new \Exception("No entry is registered for key '$index'");
-        }
-
-        return $instance->offsetGet($index);
-    }
-
-    /**
-     * setter method, basically same as offsetSet().
-     *
-     * This method can be called from an object of type Zend_Registry, or it
-     * can be called statically.  In the latter case, it uses the default
-     * static instance stored in the class.
-     *
-     * @param string $index The location in the ArrayObject in which to store
-     *   the value.
-     * @param mixed $value The object to store in the ArrayObject.
-     * @return void
-     */
-    public static function set($index, $value)
-    {
-        $instance = self::getInstance();
-        $instance->offsetSet($index, $value);
-    }
-
-    /**
-     * Returns TRUE if the $index is a named value in the registry,
-     * or FALSE if $index was not found in the registry.
-     *
-     * @param  string $index
-     * @return boolean
-     */
-    public static function isRegistered($index)
-    {
-        if (self::$_registry === null) {
-            return false;
-        }
-        return self::$_registry->offsetExists($index);
-    }
-
-    /**
-     * Constructs a parent ArrayObject with default
-     * ARRAY_AS_PROPS to allow acces as an object
-     *
-     * @param array $array data array
-     * @param integer $flags ArrayObject flags
-     */
-    public function __construct()
-    {
-        parent::__construct();
-    }
-
-    /**
-     * @param string $index
-     * @returns mixed
-     *
-     * Workaround for http://bugs.php.net/bug.php?id=40442 (ZF-960).
-     */
-    public function offsetExists($index)
-    {
-        return array_key_exists($index, $this);
-    }
-}
-
-
-
-namespace Nf;
-
-class UserAgent
-{
-
-    public $httpUserAgent;
-    public $lowerHttpUserAgent;
-
-    public function __construct($httpUserAgent)
-    {
-        $this->httpUserAgent=$httpUserAgent;
-        $this->lowerHttpUserAgent=strtolower($httpUserAgent);
-    }
-
-    public function checkClass($class)
-    {
-        switch ($class) {
-            case 'iphone':
-                return $this->isIphone();
-                break;
-            case 'ipad':
-                return $this->isIpad();
-                break;
-            case 'androidmobile':
-                return $this->isAndroidMobile();
-                break;
-            case 'androidtablet':
-                return $this->isAndroidTablet();
-                break;
-            case 'blackberry':
-                return $this->isBlackberry();
-                break;
-        }
-    }
-
-    public function isIphone()
-    {
-        return strstr($this->lowerHttpUserAgent, 'iphone') || strstr($this->lowerHttpUserAgent, 'ipod');
-    }
-
-    public function isIpad()
-    {
-        return strstr($this->lowerHttpUserAgent, 'ipad');
-    }
-
-    public function isAndroidMobile()
-    {
-        return (strstr($this->lowerHttpUserAgent, 'android')!==false) && (strstr($this->lowerHttpUserAgent, 'mobile')===false);
-    }
-
-    public function isAndroidTablet()
-    {
-        return (strstr($this->lowerHttpUserAgent, 'android')!==false) && (strstr($this->lowerHttpUserAgent, 'mobile')===false);
-    }
-
-    public function isBlackberry()
-    {
-        return strstr($this->lowerHttpUserAgent, 'blackberry');
-    }
-}
-
-
-namespace Nf;
-
-class Task
-{
-
-    protected $pid;
-
-    protected $ppid;
-
-    protected $params = null;
-
-    function __construct($params = null)
-    {
-        $this->params = $params;
-    }
-
-    function fork()
-    {
-        $pid = pcntl_fork();
-        if ($pid == - 1)
-            throw new Exception('fork error on Task object');
-        elseif ($pid) {
-            // we are in the parent class
-            $this->pid = $pid;
-            // echo "< in parent with pid {$this->pid}\n";
-        } else {
-            // we are in the child ᶘ ᵒᴥᵒᶅ
-            $this->ppid = posix_getppid();
-            $this->pid = posix_getpid();
-            $this->run();
-            exit(0);
-        }
-    }
-    
-    // overload this method in your class
-    function run()
-    {
-        // echo "> in child {$this->pid}\n";
-    }
-    
-    // call when a task is finished (in parent)
-    function finish()
-    {
-        // echo "task finished {$this->pid}\n";
-    }
-
-    function pid()
-    {
-        return $this->pid;
-    }
-}
-
-
-
-
-
-namespace Nf;
-
-class Front extends Singleton
-{
-
-    protected static $_instance;
-    
-    // les modules
-    private $_moduleDirectories = array();
-
-    const controllersDirectory = 'controllers';
-    
-    // pour instancier le controller, forwarder...
-    private $_moduleNamespace;
-
-    private $_moduleName;
-
-    private $_controllerName;
-
-    private $_actionName;
-    
-    // pour le controller
-    private $_request;
-
-    private $_requestType;
-
-    private $_response;
-
-    private $_router;
-
-    private $_session;
-
-    public static $obLevel = 0;
-    
-    // the instance of the controller that is being dispatched
-    private $_controllerInstance;
-
-    private $_applicationNamespace = 'App';
-
-    private $registeredMiddlewares = array();
-
-    const MIDDLEWARE_PRE = 0;
-
-    const MIDDLEWARE_POST = 1;
-
-    public function __get($var)
-    {
-        $varName = '_' . $var;
-        return $this->$varName;
-    }
-
-    public function getRequestType()
-    {
-        return $this->_requestType;
-    }
-
-    public function getModuleName()
-    {
-        return $this->_moduleName;
-    }
-
-    public function getControllerName()
-    {
-        return $this->_controllerName;
-    }
-
-    public function getActionName()
-    {
-        return $this->_actionName;
-    }
-
-    public function setRequest($request)
-    {
-        $this->_request = $request;
-    }
-
-    public function setResponse($response)
-    {
-        $this->_response = $response;
-    }
-
-    public function setRequestType($requestType)
-    {
-        $this->_requestType = $requestType;
-    }
-
-    public function getRequest()
-    {
-        return $this->_request;
-    }
-
-    public function getResponse()
-    {
-        return $this->_response;
-    }
-
-    public function setSession($session)
-    {
-        $this->_session = $session;
-    }
-
-    public function getSession()
-    {
-        return $this->_session;
-    }
-
-    public function getRouter()
-    {
-        return $this->_router;
-    }
-
-    public function setRouter($router)
-    {
-        $this->_router = $router;
-    }
-
-    public function setApplicationNamespace($namespace)
-    {
-        $this->_applicationNamespace = $namespace;
-    }
-
-    public function getApplicationNamespace()
-    {
-        return $this->_applicationNamespace;
-    }
-
-    public function getControllerInstance()
-    {
-        return $this->_controllerInstance;
-    }
-    
-    // cache
-    public function getCache($which)
-    {
-        // do we already have the cache object in the Registry ?
-        if (Registry::isRegistered('cache_' . $which)) {
-            return Registry::get('cache_' . $which);
-        } else {
-            // get the config for our cache object
-            $config = Registry::get('config');
-            if (isset($config->cache->$which->handler)) {
-                $cache = Cache::factory($config->cache->$which->handler, (isset($config->cache->$which->params)) ? $config->cache->$which->params : array(), (isset($config->cache->$which->lifetime)) ? $config->cache->$which->lifetime : Cache::DEFAULT_LIFETIME);
-                return $cache;
-            } else {
-                throw new Exception('The cache handler "' . $which . '" is not set in config file');
-            }
-        }
-    }
-    
-    // modules
-    public function addModuleDirectory($namespace, $dir)
-    {
-        $this->_moduleDirectories[] = array(
-            'namespace' => $namespace,
-            'directory' => $dir
-        );
-    }
-
-    private function getControllerFilename($namespace, $directory, $module, $controller)
-    {
-        $controllerFilename = ucfirst($controller . 'Controller.php');
-        return $directory . $module . '/' . self::controllersDirectory . '/' . $controllerFilename;
-    }
-
-    public function checkModuleControllerAction($inModule, $inController, $inAction)
-    {
-        $foundController = null;
-        
-        foreach ($this->_moduleDirectories as $moduleDirectory => $moduleDirectoryInfos) {
-            $controllerFilename = $this->getControllerFilename($moduleDirectoryInfos['namespace'], $moduleDirectoryInfos['directory'], $inModule, $inController);
-            
-            if (file_exists($controllerFilename)) {
-                $this->_moduleNamespace = $moduleDirectoryInfos['namespace'];
-                $this->_moduleName = $inModule;
-                $this->_controllerName = $inController;
-                $this->_actionName = $inAction;
-                $foundController = $controllerFilename;
-                break;
-            }
-        }
-        
-        unset($moduleDirectory);
-        unset($moduleDirectoryInfos);
-        if (! $foundController) {
-            return false;
-        }
-        return $foundController;
-    }
-
-    public function forward($module, $controller, $action)
-    {
-        if ($foundController = $this->checkModuleControllerAction($module, $controller, $action)) {
-            if ($this->checkMethodForAction($foundController)) {
-                $this->launchAction();
-                return true;
-            } else {
-                return false;
-            }
-        } else {
-            return false;
-        }
-    }
-
-    public function associateParams($routeRegexp, $values)
-    {
-        if (! is_array($values)) {
-            $values = array(
-                $values
-            );
-        }
-        
-        preg_match_all('/\((\w+):/', $routeRegexp, $matches);
-        
-        for ($i = 0; $i < count($matches[1]); $i ++) {
-            $this->_request->setParam($matches[1][$i], $values[$i + 1]);
-        }
-    }
-
-    public function parseParameters($uri)
-    {
-        // les éventuels paramètres sont en /variable/value
-        $paramsFromUri = ltrim(preg_replace('#^(\w+)/(\w+)/(\w+)#', '', $uri), '/');
-        
-        // si on envoie des variables avec des /
-        if ($paramsFromUri != '') {
-            if (substr_count($paramsFromUri, '/') % 2 == 1) {
-                preg_match_all('/(\w+)\/([^\/]*)/', $paramsFromUri, $arrParams, PREG_SET_ORDER);
-                for ($matchi = 0; $matchi < count($arrParams); $matchi ++) {
-                    $this->_request->setParam($arrParams[$matchi][1], $arrParams[$matchi][2]);
-                }
-            }
-            
-            // si on envoie des variables avec des var1=val1
-            if (substr_count($paramsFromUri, '=') >= 1) {
-                preg_match_all('/(\w+)=([^\/&]*)/', $paramsFromUri, $arrParams, PREG_SET_ORDER);
-                for ($matchi = 0; $matchi < count($arrParams); $matchi ++) {
-                    $this->_request->setParam($arrParams[$matchi][1], $arrParams[$matchi][2]);
-                }
-            }
-        }
-    }
-
-    public function getView()
-    {
-        if (! is_null($this->_controllerInstance->_view)) {
-            return $this->_controllerInstance->_view;
-        } else {
-            $config = Registry::get('config');
-            $view = View::factory($config->view->engine);
-            $view->setResponse($this->_response);
-            return $view;
-        }
-    }
-
-    public function dispatch()
-    {
-        // on va regarder le m/c/a concerné par l'url ou les paramètres déjà saisis
-        if ($foundController = $this->getRouter()->findRoute(Registry::get('version'), Registry::get('locale'))) {
-            return $this->checkMethodForAction($foundController);
-        } else {
-            return false;
-        }
-    }
-
-    private function checkMethodForAction($foundController)
-    {
-        // on lancera dans l'ordre le init, action, postAction
-        require_once($foundController);
-        $controllerClassName = $this->_moduleNamespace . '\\' . ucfirst($this->_moduleName) . '\\' . ucfirst($this->_controllerName) . 'Controller';
-        $this->_controllerInstance = new $controllerClassName($this);
-        
-        $reflected = new \ReflectionClass($this->_controllerInstance);
-        
-        if ($reflected->hasMethod($this->_actionName . 'Action')) {
-            return true;
-        } else {
-            return false;
-        }
-    }
-    
-    // called after dispatch
-    public function init()
-    {
-        return $this->_controllerInstance->init();
-    }
-    
-    // registers a middleware programmatically and not through a route
-    public function registerMiddleware($middlewareInstance)
-    {
-        if (isset(class_uses($middlewareInstance)['Nf\Middleware\Pre'])) {
-            $key = self::MIDDLEWARE_PRE;
-        } else {
-            $key = self::MIDDLEWARE_POST;
-        }
-        // adds the middleware
-        $this->registeredMiddlewares[$key][] = $middlewareInstance;
-    }
-    
-    // calls the actual action found from the routing system
-    public function launchAction()
-    {
-        self::$obLevel = ob_get_level();
-        
-        if (php_sapi_name() != 'cli') {
-            ob_start();
-        }
-        
-        $router = $this->_router;
-        $activeRoute = $router->getActiveRoute();
-        
-        // optionally sets the content-type
-        if (isset($activeRoute['contentType'])) {
-            $this->_response->setContentType($activeRoute['contentType']);
-        }
-        
-        // optionally sets the client cache duration
-        if (isset($activeRoute['cacheMinutes'])) {
-            $this->_response->setCacheable($activeRoute['cacheMinutes']);
-        }
-        
-        // call pre middlewares defined by the active route
-        if (isset($activeRoute['middlewaresPre'])) {
-            foreach ($activeRoute['middlewaresPre'] as $middleware) {
-                $object = new $middleware();
-                $object->execute();
-            }
-            unset($middleware);
-        }
-        // call pre middlewares defined programatically
-        if (isset($this->registeredMiddlewares[self::MIDDLEWARE_PRE])) {
-            foreach ($this->registeredMiddlewares[self::MIDDLEWARE_PRE] as $middleware) {
-                $middleware->execute();
-            }
-        }
-        
-        // call the action
-        call_user_func(array(
-            $this->_controllerInstance,
-            $this->_actionName . 'Action'
-        ));
-        $content = ob_get_clean();
-        $this->_response->addBodyPart($content);
-        
-        // call post middlewares
-        if (isset($activeRoute['middlewaresPost'])) {
-            foreach ($activeRoute['middlewaresPost'] as $middleware) {
-                $object = new $middleware();
-                $object->execute();
-            }
-            unset($middleware);
-        }
-        // call post middlewares defined programatically, by instance
-        if (isset($this->registeredMiddlewares[self::MIDDLEWARE_POST])) {
-            foreach ($this->registeredMiddlewares[self::MIDDLEWARE_POST] as $middleware) {
-                $middleware->execute();
-            }
-        }
-    }
-    
-    // called after action
-    public function postLaunchAction()
-    {
-        $reflected = new \ReflectionClass($this->_controllerInstance);
-        if ($reflected->hasMethod('postLaunchAction')) {
-            call_user_func(array(
-                $this->_controllerInstance,
-                'postLaunchAction'
-            ), null);
-        }
-    }
-}
-
-
-namespace Nf;
-
-abstract class Cache
-{
-
-    static $instances = array();
-    
-    // default lifetime for any stored value
-    const DEFAULT_LIFETIME = 600;
-
-    public static function getKeyName($keyName, $keyValues = array())
-    {
-        $config = Registry::get('config');
-        if (! isset($config->cachekeys->$keyName)) {
-            throw new \Exception('Key ' . $keyName . ' is not set in the config file.');
-        } else {
-            $configKey = $config->cachekeys->$keyName;
-            if (is_array($keyValues)) {
-                // if we send an associative array
-                if (self::isAssoc($keyValues)) {
-                    $result = $configKey;
-                    foreach ($keyValues as $k => $v) {
-                        $result = str_replace('[' . $k . ']', $v, $result);
-                    }
-                } else {
-                    // if we send an indexed array
-                    preg_match_all('/\[([^\]]*)\]/', $configKey, $vars, PREG_PATTERN_ORDER);
-                    if (count($vars[0]) != count($keyValues)) {
-                        throw new \Exception('Key ' . $keyName . ' contains a different number of values than the keyValues you gave.');
-                    } else {
-                        $result = $configKey;
-                        for ($i = 0; $i < count($vars[0]); $i ++) {
-                            $result = str_replace('[' . $vars[0][$i] . ']', $keyValues[$i]);
-                        }
-                    }
-                }
-            } else {
-                // if we send only one value
-                $result = preg_replace('/\[([^\]]*)\]/', $keyValues, $configKey);
-            }
-        }
-        // if we still have [ in the key name, it means that we did not send the right parameters for keyValues
-        if (strpos($result, '[')) {
-            throw new \Exception('The cache key ' . $keyName . ' cannot be parsed with the given keyValues.');
-        } else {
-            $keyPrefix = ! empty($config->cache->keyPrefix) ? $config->cache->keyPrefix : '';
-            return $keyPrefix . $result;
-        }
-    }
-
-    public static function isCacheEnabled()
-    {
-        $config = Registry::get('config');
-        return isset($config->cache->enabled) ? (bool) $config->cache->enabled : true;
-    }
-
-    private static function isAssoc($array)
-    {
-        return is_array($array) && array_diff_key($array, array_keys(array_keys($array)));
-    }
-    
-    public static function getStorage($type)
-    {
-        if (! in_array($type, self::$instances)) {
-            $config = Registry::get('config');
-            if (isset($config->cache->$type->handler)) {
-                $handler = $config->cache->$type->handler;
-            } else {
-                throw new \Exception('The ' . $type . ' cache storage is not defined in the config file');
-            }
-            if (isset($config->cache->$type->params)) {
-                $params = $config->cache->$type->params;
-            } else {
-                $params = null;
-            }
-            if (isset($config->cache->$type->lifetime)) {
-                $lifetime = $config->cache->$type->lifetime;
-            } else {
-                $lifetime = self::DEFAULT_LIFETIME;
-            }
-            $instance = self::factory($handler, $params, $lifetime);
-            self::$instances[$type]=$instance;
-        }
-        return self::$instances[$type];
-    }
-
-    public static function factory($handler, $params, $lifetime = DEFAULT_LIFETIME)
-    {
-        $className = get_class() . '\\' . ucfirst($handler);
-        return new $className($params, $lifetime);
-    }
-}
-
-
-namespace Nf;
-
-/**
- * Reads an .
- *
- *
- * ini file, handling sections, overwriting...
- *
- * @author Julien Ricard
- * @package Nf
- */
-class Ini
-{
-
-    /**
-     * Internal storage array
-     *
-     * @var array
-     */
-    private static $result = array();
-
-    /**
-     * Loads in the ini file specified in filename, and returns the settings in
-     * it as an associative multi-dimensional array
-     *
-     * @param string $filename
-     *            The filename of the ini file being parsed
-     * @param boolean $process_sections
-     *            By setting the process_sections parameter to TRUE,
-     *            you get a multidimensional array, with the section
-     *            names and settings included. The default for
-     *            process_sections is FALSE
-     * @param string $section_name
-     *            Specific section name to extract upon processing
-     * @throws Exception
-     * @return array|boolean
-     */
-    public static function parse($filename, $process_sections = false, $section_name = null, $fallback_section_name = null)
-    {
-        
-        // load the raw ini file
-        // automatically caches the ini file if an opcache is present
-        ob_start();
-        include($filename);
-        $str = ob_get_contents();
-        ob_end_clean();
-        $ini = parse_ini_string($str, $process_sections);
-        
-        // fail if there was an error while processing the specified ini file
-        if ($ini === false) {
-            return false;
-        }
-        
-        // reset the result array
-        self::$result = array();
-        
-        if ($process_sections === true) {
-            // loop through each section
-            foreach ($ini as $section => $contents) {
-                // process sections contents
-                self::processSection($section, $contents);
-            }
-        } else {
-            // treat the whole ini file as a single section
-            self::$result = self::processSectionContents($ini);
-        }
-        
-        // extract the required section if required
-        if ($process_sections === true) {
-            if ($section_name !== null) {
-                // return the specified section contents if it exists
-                if (isset(self::$result[$section_name])) {
-                    return self::bindArrayToObject(self::$result[$section_name]);
-                } else {
-                    if ($fallback_section_name !== null) {
-                        return self::bindArrayToObject(self::$result[$fallback_section_name]);
-                    } else {
-                        throw new \Exception('Section ' . $section_name . ' not found in the ini file');
-                    }
-                }
-            }
-        }
-        
-        // if no specific section is required, just return the whole result
-        return self::bindArrayToObject(self::$result);
-    }
-
-    /**
-     * Process contents of the specified section
-     *
-     * @param string $section
-     *            Section name
-     * @param array $contents
-     *            Section contents
-     * @throws Exception
-     * @return void
-     */
-    private static function processSection($section, array $contents)
-    {
-        // the section does not extend another section
-        if (stripos($section, ':') === false) {
-            self::$result[$section] = self::processSectionContents($contents);
-            
-            // section extends another section
-        } else {
-            // extract section names
-            list ($ext_target, $ext_source) = explode(':', $section);
-            $ext_target = trim($ext_target);
-            $ext_source = trim($ext_source);
-            
-            // check if the extended section exists
-            if (! isset(self::$result[$ext_source])) {
-                throw new \Exception('Unable to extend section ' . $ext_source . ', section not found');
-            }
-            
-            // process section contents
-            self::$result[$ext_target] = self::processSectionContents($contents);
-            
-            // merge the new section with the existing section values
-            self::$result[$ext_target] = self::arrayMergeRecursive(self::$result[$ext_source], self::$result[$ext_target]);
-        }
-    }
-
-    /**
-     * Process contents of a section
-     *
-     * @param array $contents
-     *            Section contents
-     * @return array
-     */
-    private static function processSectionContents(array $contents)
-    {
-        $result = array();
-        
-        // loop through each line and convert it to an array
-        foreach ($contents as $path => $value) {
-            // convert all a.b.c.d to multi-dimensional arrays
-            $process = self::processContentEntry($path, $value);
-            
-            // merge the current line with all previous ones
-            $result = self::arrayMergeRecursive($result, $process);
-        }
-        
-        return $result;
-    }
-
-    /**
-     * Convert a.b.c.d paths to multi-dimensional arrays
-     *
-     * @param string $path
-     *            Current ini file's line's key
-     * @param mixed $value
-     *            Current ini file's line's value
-     * @return array
-     */
-    private static function processContentEntry($path, $value)
-    {
-        $pos = strpos($path, '.');
-        
-        if ($pos === false) {
-            return array(
-                $path => $value
-            );
-        }
-        
-        $key = substr($path, 0, $pos);
-        $path = substr($path, $pos + 1);
-        
-        $result = array(
-            $key => self::processContentEntry($path, $value)
-        );
-        
-        return $result;
-    }
-
-    private static function bindArrayToObject($array)
-    {
-        $return = new \StdClass();
-        foreach ($array as $k => $v) {
-            if (is_array($v)) {
-                $return->$k = self::bindArrayToObject($v);
-            } else {
-                $return->$k = $v;
-            }
-        }
-        return $return;
-    }
-
-    /**
-     * Merge two arrays recursively overwriting the keys in the first array
-     * if such key already exists
-     *
-     * @param mixed $a
-     *            Left array to merge right array into
-     * @param mixed $b
-     *            Right array to merge over the left array
-     * @return mixed
-     */
-    private static function arrayMergeRecursive($a, $b, $level = 0)
-    {
-        // merge arrays if both variables are arrays
-        if (is_array($a) && is_array($b)) {
-            // loop through each right array's entry and merge it into $a
-            foreach ($b as $key => $value) {
-                if (isset($a[$key])) {
-                    if (is_int($key) && ! is_array($value)) {
-                        $a[] = $value;
-                    } else {
-                        $a[$key] = self::arrayMergeRecursive($a[$key], $value, $level + 1);
-                    }
-                } else {
-                    if ($key === 0) {
-                        $a = array(
-                            0 => self::arrayMergeRecursive($a, $value, $level + 1)
-                        );
-                    } else {
-                        $a[$key] = $value;
-                    }
-                }
-            }
-        } else {
-            // at least one of values is not an array
-            $a = $b;
-        }
-        return $a;
-    }
-
-    /**
-     * Replaces text in every value of the config, recursively
-     *
-     * @param string $search
-     *            The string to search for
-     * @param string $replace
-     *            The string for replace with
-     * @throws Exception
-     * @return Ini
-     */
-    public static function deepReplace($ini, $search, $replace)
-    {
-        if (is_object($ini)) {
-            foreach ($ini as $key => &$value) {
-                $value = self::deepReplace($value, $search, $replace);
-            }
-        } else {
-            $ini = str_replace($search, $replace, $ini);
-            return $ini;
-        }
-        return $ini;
-    }
-}
-
-
-/**
- * Nf Input
- *
- */
-
-namespace Nf;
-
-/**
- * Filtering and validating for forms, input parameters, etc
- *
- * @author Julien Ricard
- * @package Nf
- */
-class Input
-{
-
-    const F_INTEGER = 'Int';
-
-    const F_NATURAL = 'Natural';
-
-    const F_NATURALNONZERO = 'NaturalNonZero';
-
-    const F_ALPHA = 'Alpha';
-
-    const F_ALPHANUM = 'AlphaNum';
-
-    const F_NUMERIC = 'Numeric';
-
-    const F_BASE64 = 'Base64';
-
-    const F_REGEXP = 'Regexp';
-
-    const F_STRING = 'String';
-
-    const F_TRIM = 'Trim';
-
-    const F_URL = 'Url';
-
-    const F_STRIPTAGS = 'StripTags';
-
-    const F_NULL = 'NullIfEmptyString';
-
-    const F_BOOLEAN = 'Boolean';
-
-    const V_INTEGER = 'Int';
-
-    const V_NATURAL = 'Natural';
-
-    const V_NATURALNONZERO = 'NaturalNonZero';
-
-    const V_ALPHA = 'Alpha';
-
-    const V_ALPHANUM = 'AlphaNum';
-
-    const V_NUMERIC = 'Numeric';
-
-    const V_BASE64 = 'Base64';
-
-    const V_EQUALS = 'Equals';
-
-    const V_REGEXP = 'Regexp';
-
-    const V_REQUIRED = 'Required';
-
-    const V_NOTEMPTY = 'NotEmpty';
-
-    const V_GREATERTHAN = 'GreaterThan';
-
-    const V_LESSTHAN = 'LessThan';
-
-    const V_MINLENGTH = 'MinLength';
-
-    const V_MAXLENGTH = 'MaxLength';
-
-    const V_EXACTLENGTH = 'ExactLength';
-
-    const V_EMAIL = 'Email';
-
-    const V_MATCHES = 'Matches';
-
-    const V_URL = 'Url';
-
-    const V_DEFAULT = 'Default';
-
-    const V_BOOLEAN = 'Boolean';
-
-    /**
-     * An array of every input parameter
-     */
-    private $_params = array();
-
-    /**
-     * An array of every filter instantiated for every input parameter
-     */
-    private $_filters = array();
-
-    /**
-     * An array of every validator instantiated for every input parameter
-     */
-    private $_validators = array();
-
-    /**
-     * An array of every parameter after filtering and validating
-     */
-    private $_fields = array();
-
-    const REGEXP_ALPHA = '/[^a-z]*/i';
-
-    const REGEXP_ALPHANUM = '/[^a-z0-9]*/i';
-
-    const REGEXP_BASE64 = '%[^a-zA-Z0-9/+=]*%i';
-
-    const REGEXP_INT = '/^[\-+]?[0-9]+$/';
-
-    /**
-     * The constructor to use while filtering/validating input
-     *
-     * @param array $params the input paramters to filter and validate
-     * @param array $filters the list of filters for each parameter
-     * @param array $validators the list of validators for each parameter
-     *
-     * @return Input
-     */
-    public function __construct(array $params, array $filters, array $validators)
-    {
-        $this->_params = $params;
-        $this->_filters = $filters;
-        $this->_validators = $validators;
-        $this->_classMethods = get_class_methods(__CLASS__);
-        $refl = new \ReflectionClass(__CLASS__);
-        $this->_classConstants = $refl->getConstants();
-    }
-
-    /**
-     * This method has to be called after specifying the parameters, filters and validators
-     *
-     * @param void
-     *
-     * @return bool returns true if every validator is validating, or false if any validator is not
-     * This method always filters before validating
-     */
-    public function isValid()
-    {
-        // 1) filter
-        $this->filter();
-        // 2) validate
-        return $this->validate();
-    }
-
-    /**
-     * Filters every input parameter
-     *
-     * @return void
-     */
-    public function filter()
-    {
-        $this->metaFilterAndValidate('filter');
-    }
-
-    /**
-     * Validates every input parameter
-     *
-     * @return void
-     */
-    public function validate()
-    {
-        return $this->metaFilterAndValidate('validate');
-    }
-
-    /**
-     * Returns every incorrect field and the corresponding validator
-     *
-     * @return array
-     */
-    public function getMessages()
-    {
-        $messages = array();
-        foreach ($this->_fields as $fieldName => $values) {
-            if (! $values['isValid']) {
-                $invalidators = array();
-                foreach ($values['validators'] as $validatorName => $validatorValue) {
-                    if (! $validatorValue) {
-                        $invalidators[] = $validatorName;
-                    }
-                }
-                $messages[$fieldName] = $invalidators;
-                unset($validator);
-            }
-            unset($fieldName);
-            unset($values);
-        }
-        return $messages;
-    }
-
-    /**
-     * Returns the original input parameters
-     *
-     * @return array
-     */
-    public function getFields()
-    {
-        return $this->_fields;
-    }
-    
-    /**
-     * Returns every input parameter after content filtering
-     *
-     * @return array
-     */
-    public function getFilteredFields()
-    {
-        $filteredFields = array();
-        foreach ($this->_fields as $fieldName => $data) {
-            $filteredFields[$fieldName] = $data['value'];
-        }
-        return $filteredFields;
-    }
-    
-    /**
-     * Does all the work needed to filter and validate the input parameters
-     *
-     * @param string $metaAction ("filter" or "validate")
-     * @return mixed
-     */
-    private function metaFilterAndValidate($metaAction)
-    {
-        if ($metaAction == 'filter') {
-            $metaSource = $this->_filters;
-        } elseif ($metaAction == 'validate') {
-            $metaSource = $this->_validators;
-            $isValid = true;
-        }
-        
-        foreach ($metaSource as $paramName => $options) {
-            if ($metaAction == 'filter') {
-                $this->setField($paramName, (isset($this->_params[$paramName]) ? $this->_params[$paramName] : null));
-            }
-            
-            if ($metaAction == 'validate') {
-                if (! isset($this->_fields[$paramName])) {
-                    $this->setField($paramName, (isset($this->_params[$paramName]) ? $this->_params[$paramName] : null));
-                }
-                $validators = array();
-            }
-            
-            $options = (array) $options;
-            
-            foreach ($options as $option) {
-                // optional parameter sent to the filter/validator
-                // by default, it's not set
-                unset($optionParameter);
-                
-                if (is_array($option)) {
-                    $optionKeys = array_keys($option);
-                    $optionValues = array_values($option);
-                    
-                    // call with an alias and a parameter: array('isValidId' => '\App\Toto::validateId', 22)
-                    if (isset($option[0]) && $optionKeys[1] == 0) {
-                        $optionName = $optionKeys[0];
-                        $optionFunction = $optionValues[0];
-                        $optionParameter = $optionValues[1];
-                    } elseif ($this->isAssoc($option)) {
-                        // call with an alias only : array('isValidId' => '\App\Toto::validateId'),
-                        // or (if your name is Olivier D) call with the parameter as assoc : array('default' => 7),
-                        $optionKeys = array_keys($option);
-                        $optionValues = array_values($option);
-                        
-                        // if the value of the array is a function
-                        if (isset($$optionFunction)) {
-                            $optionName = $optionKeys[0];
-                            $optionFunction = $optionValues[0];
-                        } else {
-                            // if the value of the array is a function (à la Olivier D)
-                            $optionName = $optionKeys[0];
-                            $optionFunction = $optionKeys[0];
-                            $optionParameter = $optionValues[0];
-                        }
-                    } else {
-                        // call with a parameter only : array('regexp', '/[a-z]*/i')
-                        $optionName = $option[0];
-                        $optionFunction = $option[0];
-                        $optionParameter = $option[1];
-                    }
-                } else {
-                    $optionName = $option;
-                    $optionFunction = $option;
-                }
-                
-                // if we want to validate against a method of a model
-                $idx = strpos($optionFunction, '::');
-                if ($idx !== false) {
-                    // find (with autoload) the class and call the method
-                    $className = substr($optionFunction, 0, $idx);
-                    $methodName = substr($optionFunction, $idx + 2);
-                    if ($metaAction == 'filter') {
-                        if (isset($optionParameter)) {
-                            $this->setField($paramName, $className::$methodName($this->_fields[$paramName]['value'], $optionParameter));
-                        } else {
-                            $this->setField($paramName, $className::$methodName($this->_fields[$paramName]['value']));
-                        }
-                    } elseif ($metaAction == 'validate') {
-                        if (isset($optionParameter)) {
-                            $ret = $className::$methodName($this->_fields[$paramName]['value'], $optionParameter, $this);
-                        } else {
-                            $ret = $className::$methodName($this->_fields[$paramName]['value'], null, $this);
-                        }
-                        // add the validator to the validators for this field
-                        $isValid = $isValid && $ret;
-                        $validators[$optionName] = $ret;
-                    }
-                } else {
-                    // we will search for the function name in this class
-                    $methodNameForOption = $metaAction . ucfirst($optionFunction);
-                    // if the developer has used a shortname for the filter/validator
-                    $methodNameFromConstants = (($metaAction == 'filter') ? 'F' : 'V') . '_' . strtoupper($optionFunction);
-                    if (isset($this->_classConstants[$methodNameFromConstants])) {
-                        $methodNameForOption = (($metaAction == 'filter') ? 'filter' : 'validate') . $this->_classConstants[$methodNameFromConstants];
-                    }
-                                        
-                    if (in_array($methodNameForOption, $this->_classMethods)) {
-                        if ($methodNameForOption == 'validateRequired') {
-                            $ret = array_key_exists($paramName, $this->_params);
-                        } else {
-                            if (! isset($optionParameter)) {
-                                $optionParameter = null;
-                            }
-                            if (is_array($this->_fields[$paramName]['value'])) {
-                                if ($metaAction == 'filter') {
-                                    foreach ($this->_fields[$paramName]['value'] as $paramKey => $paramValue) {
-                                        $this->_fields[$paramName]['value'][$paramKey] = self::$methodNameForOption($this->_fields[$paramName]['value'][$paramKey], $optionParameter, $this);
-                                    }
-                                    unset($paramKey);
-                                    unset($paramValue);
-                                    $ret = $this->_fields[$paramName]['value'];
-                                } else {
-                                    $ret = true;
-                                    foreach ($this->_fields[$paramName]['value'] as $paramKey => $paramValue) {
-                                        $ret &= self::$methodNameForOption($this->_fields[$paramName]['value'][$paramKey], $optionParameter, $this);
-                                    }
-                                    unset($paramKey);
-                                    unset($paramValue);
-                                }
-                            } else {
-                                $ret = self::$methodNameForOption($this->_fields[$paramName]['value'], $optionParameter, $this);
-                            }
-                        }
-                        if ($metaAction == 'filter') {
-                            $this->setField($paramName, $ret);
-                        }
-                        // add the validator to the validators for this field
-                        if ($metaAction == 'validate') {
-                            // special case of the default value
-                            if ($methodNameForOption == 'validateDefault') {
-                                if (is_array($this->_fields[$paramName]['value'])) {
-                                    foreach ($this->_fields[$paramName]['value'] as $paramKey => $paramValue) {
-                                        if (empty($this->_fields[$paramName]['value'][$paramKey])) {
-                                            $this->_fields[$paramName]['value'][$paramKey] = $optionParameter;
-                                        }
-                                    }
-                                    unset($paramKey);
-                                    unset($paramValue);
-                                    $ret = true;
-                                } else {
-                                    if (empty($this->_fields[$paramName]['value'])) {
-                                        $this->_fields[$paramName]['value'] = $optionParameter;
-                                    }
-                                    $ret = true;
-                                }
-                            }
-                            $isValid = $isValid && $ret;
-                            $validators[$optionName] = $ret;
-                        }
-                    } else {
-                        throw new \Exception(__CLASS__ . ' hasn\'t a method called "' . $methodNameForOption . '"');
-                    }
-                }
-            }
-            unset($option);
-            
-            // we set the field after all the input value went through all validators
-            if ($metaAction == 'validate') {
-                // we test for each params if one of validators is not valid.
-                $paramIsValid = true;
-                foreach ($validators as $v) {
-                    if ($v === false) {
-                        $paramIsValid = false;
-                        break;
-                    }
-                }
-                $this->setField($paramName, false, $paramIsValid, $validators);
-            }
-        }
-        if ($metaAction == 'validate') {
-            return $isValid;
-        }
-    }
-    
-    /**
-     * After filtering or validating, updates the field with additional data
-     *
-     * @param mixed $paramName the name of the input parameter
-     * @param mixed $value the value after filtering
-     * @param boolean $isValid is the field valid
-     * @param array $validators sets the given validators for this parameter
-     *
-     * @return mixed
-     */
-    private function setField($paramName, $value = false, $isValid = null, $validators = null)
-    {
-        if (! isset($this->_fields[$paramName])) {
-            $this->_fields[$paramName] = array(
-                'originalValue' => (isset($this->_params[$paramName])) ? $this->_params[$paramName] : null,
-                'value' => (isset($this->_params[$paramName])) ? $this->_params[$paramName] : null,
-                'isValid' => true,
-                'validators' => array()
-            );
-        }
-        if ($value !== false) {
-            $this->_fields[$paramName]['value'] = $value;
-        }
-        if ($isValid !== null) {
-            $this->_fields[$paramName]['isValid'] = $this->_fields[$paramName]['isValid'] && $isValid;
-        }
-        if ($validators !== null) {
-            $this->_fields[$paramName]['validators'] = $validators;
-        }
-    }
-
-    /**
-     * Returns the filtered value for any field given in the params
-     *
-     * @param mixed $paramName the name of the input parameter
-     *
-     * @return mixed
-     */
-    public function __get($paramName)
-    {
-        return $this->_fields[$paramName]['value'];
-    }
-
-    /**
-     * Returns true or false if the input parameter was specified within the instanciation
-     *
-     * @param mixed $paramName the name of the input parameter
-     *
-     * @return boolean
-     */
-    public function __isset($paramName)
-    {
-        return isset($this->_fields[$paramName]['value']);
-    }
-
-    /**
-     * Indicates if the array is an associative one or not
-     *
-     * @param array $paramName the name of the input parameter
-     *
-     * @return boolean
-     */
-    private function isAssoc($array)
-    {
-        return is_array($array) && array_diff_key($array, array_keys(array_keys($array)));
-    }
-    
-    // ************************************************************************
-    // filter functions
-    // ************************************************************************
-
-    /**
-     * Used for filtering integer as string in json data
-     *
-     * @param mixed $value the value of the input parameter
-     *
-     * @return mixed
-     */
-    public static function filterNullIfEmptyString($value)
-    {
-        if ($value == '') {
-            return null;
-        }
-        return $value;
-    }
-
-    /**
-     * Parses the value as an integer
-     *
-     * @param mixed $value the value of the input parameter
-     * @return mixed
-     */
-    public static function filterInt($value)
-    {
-        return filter_var($value, FILTER_SANITIZE_NUMBER_INT);
-    }
-
-    /**
-     * Parses the value as a natural (positive integer)
-     *
-     * @param mixed $value the value of the input parameter
-     * @return mixed
-     */
-    public static function filterNatural($value)
-    {
-        return abs(self::filterInt($value));
-    }
-
-    /**
-     * Parses the value as a strict natural (strictly positive integer)
-     *
-     * @param mixed $value the value of the input parameter
-     * @return mixed
-     */
-    public static function filterNaturalNonZero($value)
-    {
-        $natural = self::filterNatural($value);
-        if ($natural != 0) {
-            return $natural;
-        } else {
-            return null;
-        }
-    }
-
-    /**
-     * Parses the value as alpha (letters only, no digit)
-     *
-     * @param mixed $value the value of the input parameter
-     * @return mixed
-     */
-    public static function filterAlpha($value)
-    {
-        return preg_replace(self::REGEXP_ALPHA, '', $value);
-    }
-
-    /**
-     * Parses the value as an alphanumeric
-     *
-     * @param mixed $value the value of the input parameter
-     * @return mixed
-     */
-    public static function filterAlphaNum($value)
-    {
-        return preg_replace(self::REGEXP_ALPHANUM, '', $value);
-    }
-
-    /**
-     * Parses the value as a base64 string
-     *
-     * @param mixed $value the value of the input parameter
-     * @return mixed
-     */
-    public static function filterBase64($value)
-    {
-        return preg_replace(self::REGEXP_BASE64, '', $value);
-    }
-
-    /**
-     * Parses the value as a boolean
-     *
-     * @param mixed $value the value of the input parameter
-     * @return mixed
-     */
-    public static function filterBoolean($value)
-    {
-        $out = filter_var($value, FILTER_VALIDATE_BOOLEAN);
-        return $out;
-    }
-
-    /**
-     * Parses the value as a float
-     *
-     * @param mixed $value the value of the input parameter
-     * @return mixed
-     */
-    public static function filterNumeric($value)
-    {
-        return filter_var($value, FILTER_SANITIZE_NUMBER_FLOAT, FILTER_FLAG_ALLOW_FRACTION);
-    }
-
-    /**
-     * Removes the html tags from input
-     *
-     * @param mixed $value the value of the input parameter
-     * @return mixed
-     */
-    public static function filterStripTags($value)
-    {
-        return strip_tags($value);
-    }
-
-    /**
-     * Parses the value along a regexp
-     *
-     * @param mixed $value the value of the input parameter
-     * @param string $regexp the regular expression to filter the input parameter to
-
-     * @return mixed
-     */
-    public static function filterRegexp($value, $regexp)
-    {
-        return preg_replace($regexp, '', $value);
-    }
-
-    /**
-     * Parses the value as a string
-     *
-     * @param mixed $value the value of the input parameter
-     * @return mixed
-     */
-    public static function filterString($value)
-    {
-        return filter_var($value, FILTER_SANITIZE_STRING, FILTER_FLAG_STRIP_LOW);
-    }
-
-    /**
-     * Trims the string (default php behaviour)
-     *
-     * @param mixed $value the value of the input parameter
-     * @return mixed
-     */
-    public static function filterTrim($value)
-    {
-        return trim($value);
-    }
-
-    /**
-     * Filters the input string along the php's internal regexp for a url
-     *
-     * @param mixed $value the value of the input parameter
-     * @return mixed
-     */
-    public static function filterUrl($value)
-    {
-        return filter_var($value, FILTER_SANITIZE_URL);
-    }
-    
-    // ************************************************************************
-    // validator functions
-    // ************************************************************************
-    
-    /**
-     * Validates that the input value is an integer
-     *
-     * @param mixed $value the value of the input parameter
-     * @return mixed
-     */
-    public static function validateInt($value)
-    {
-        return (self::filterInt($value) == $value);
-    }
-
-    /**
-     * Validates that the input value is a natural
-     *
-     * @param mixed $value the value of the input parameter
-     * @return mixed
-     */
-    public static function validateNatural($value)
-    {
-        return (self::filterNatural($value) == $value);
-    }
-
-    /**
-     * Validates that the input value is a positive integer greater than zero
-     *
-     * @param mixed $value the value of the input parameter
-     * @return mixed
-     */
-    public static function validateNaturalNonZero($value)
-    {
-        return (self::filterNaturalNonZero($value) == $value);
-    }
-
-    /**
-     * Validates that the input value is alpha (letters only)
-     *
-     * @param mixed $value the value of the input parameter
-     * @return mixed
-     */
-    public static function validateAlpha($value)
-    {
-        return (bool) preg_match(self::REGEXP_ALPHA, $value);
-    }
-
-    /**
-     * Validates that the input value is an alphanumeric string
-     *
-     * @param mixed $value the value of the input parameter
-     * @return mixed
-     */
-    public static function validateAlphaNum($value)
-    {
-        return (bool) preg_match(self::REGEXP_ALPHANUM, $value);
-    }
-
-    /**
-     * Validates that the input value is a base64 string
-     *
-     * @param mixed $value the value of the input parameter
-     * @return mixed
-     */
-    public static function validateBase64($value)
-    {
-        return (bool) preg_match(self::REGEXP_BASE64, $value);
-    }
-
-    /**
-     * Validates that the input value is a boolean
-     *
-     * @param mixed $value the value of the input parameter
-     * @return mixed
-     */
-    public static function validateBoolean($value)
-    {
-        return (self::filterBoolean($value) == $value);
-    }
-
-    /**
-     * Validates that the input value is a number (float)
-     *
-     * @param mixed $value the value of the input parameter
-     * @return mixed
-     */
-    public static function validateNumeric($value, $compare, $instance)
-    {
-        return (self::filterNumeric($value) == $value);
-    }
-
-    /**
-     * Validates that the input value equals the second parameter (no type checking)
-     *
-     * @param mixed $value the value of the input parameter
-     * @param mixed $check the value of the second parameter
-     *
-     * @return mixed
-     */
-    public static function validateEquals($value, $check)
-    {
-        return (bool) ($value == $check);
-    }
-
-    /**
-     * Validates that the input value along a regular expression given as second parameter
-     *
-     * @param mixed $value the value of the input parameter
-     * @param string $regexp the regular expression to validate to
-     * @return mixed
-     */
-    public static function validateRegexp($value, $regexp)
-    {
-        return (bool) preg_match($regexp, $value);
-    }
-
-    /**
-     * This method actually does not exist :) and should not be called directly
-     *
-     * @param mixed $value the value of the input parameter
-     * @return mixed
-     */
-    public static function validateRequired($value)
-    {
-        throw new \Exception('This method should never be called');
-    }
-
-    /**
-     * Validates that the input value is not an empty string
-     *
-     * @param mixed $value the value of the input parameter
-     * @return mixed
-     */
-    public static function validateNotEmpty($value)
-    {
-        return ! (trim($value) === '');
-    }
-
-    /**
-     * Validates that the input value is greater than the given parameter
-     *
-     * @param mixed $value the value of the input parameter
-     * @param mixed $compare the value to compare to
-     * @return mixed
-     */
-    public static function validateGreaterThan($value, $compare)
-    {
-        return ($value >= $compare);
-    }
-
-    /**
-     * Validates that the input value is lesser than the given parameter
-     *
-     * @param mixed $value the value of the input parameter
-     * @param mixed $compare the value to compare to
-     * @return mixed
-     */
-    public static function validateLessThan($value, $compare)
-    {
-        return ($value <= $compare);
-    }
-    
-    /**
-     * Validates that the input value has a minimum length of the given parameter
-     *
-     * @param mixed $value the value of the input parameter
-     * @param mixed $compare the value to compare to
-     * @return mixed
-     */
-    public static function validateMinLength($value, $compare)
-    {
-        return (mb_strlen($value) >= $compare);
-    }
-
-    /**
-     * Validates that the input value has a maximum length of the given parameter
-     *
-     * @param mixed $value the value of the input parameter
-     * @param mixed $compare the value to compare to
-     * @return mixed
-     */
-    public static function validateMaxLength($value, $compare)
-    {
-        return (mb_strlen($value) <= $compare);
-    }
-
-    /**
-     * Validates that the input value has the exact length of the given parameter
-     *
-     * @param mixed $value the value of the input parameter
-     * @param mixed $compare the value to compare to
-     * @return mixed
-     */
-    public static function validateExactLength($value, $compare)
-    {
-        return (mb_strlen($value) == $compare);
-    }
-
-    /**
-     * Validates that the input value is an e-mail address
-     *
-     * @param mixed $value the value of the input parameter
-     * @return mixed
-     */
-    public static function validateEmail($value)
-    {
-        $regexp = '/^[A-Z0-9._%+-]+@(?:[A-Z0-9-]+\.)+[A-Z]{2,4}$/i';
-        return (bool) preg_match($regexp, $value);
-    }
-
-    /**
-     * Validates that the input value matches another input parameter
-     *
-     * @param mixed $value the value of the input parameter
-     * @param mixed $compareField the name of the input parameter to compare to
-     * @param mixed $instance the instance of the Input object
-     * @return mixed
-     */
-    public static function validateMatches($value, $compareField, $instance)
-    {
-        if (isset($instance->_fields[$compareField])) {
-            return ($value == $instance->_fields[$compareField]['value']);
-        }
-    }
-
-    /**
-     * Validates that the input value is an url
-     *
-     * @param mixed $value the value of the input parameter
-     * @return mixed
-     */
-    public static function validateUrl($value)
-    {
-        if (($url = parse_url($value)) && ! empty($url['scheme']) && ! empty($url['host'])) {
-            return true;
-        }
-        return false;
-    }
-
-    /**
-     * Sets the field to a default value if the input value is empty
-     *
-     * @param mixed $value the value of the input parameter
-     * @param mixed $defaultValue the default value to assign if the input value is empty
-     * @return mixed
-     */
-    public static function validateDefault($value, $defaultValue)
-    {
-        if (empty($value)) {
-            return $defaultValue;
-        }
-        return $value;
-    }
-}
-
-
-
-namespace Nf;
-
-abstract class Date
-{
-
-   
-    public static function dateFromMysql($date_origine, $return_time = false)
-    {
-        $date_output='';
-        if ($return_time) {
-            // sous la forme 2007-12-25 14:55:36 (datetime) => on renvoie tout reformaté
-            if (preg_match('/^(\\d{4})\\-(\\d{2})\\-(\\d{2})\\ (\\d{2}):(\\d{2}):(\\d{2})$/', $date_origine, $matches)) {
-                $date_output = preg_replace('/(\\d{4})\\-(\\d{2})\\-(\\d{2})\\ (\\d{2}):(\\d{2}):(\\d{2})/', '$3/$2/$1 $4:$5:$6', $matches[0]);
-            } // sous la forme 2007-12-25 (date) => on renvoie une heure 00:00:00
-            elseif (preg_match('/^(\\d{4})\\-(\\d{2})\\-(\\d{2})$/', $date_origine, $matches))
-                $date_output = preg_replace('/(\\d{4})\\-(\\d{2})\\-(\\d{2})/', '$3/$2/$1 00:00:00', $matches[0]);
-            // sous la forme 25/12/2007 14:55:36
-            elseif (preg_match('/^(\\d{2})\/(\\d{2})\/(\\d{4}) (\\d{2}):(\\d{2}):(\\d{2})$/', $date_origine, $matches))
-                $date_output = $date_origine;
-            // sous la forme 25/12/2007 14:55 => on ajoute :00
-            elseif (preg_match('/^(\\d{1,2})\/(\\d{1,2})\/(\\d{4}) (\\d{2}):(\\d{2})$/', $date_origine, $matches))
-                $date_output = preg_replace('/^(\\d{1,2})\/(\\d{1,2})\/(\\d{4}) (\\d{2}):(\\d{2})$/', '$1/$2/$3 $4:$5:00', $matches[0]);
-            // sous la forme 25/12/2007 => on ajoute 00:00:00
-            elseif (preg_match('/^(\\d{1,2})\/(\\d{1,2})\/(\\d{4})$/', $date_origine, $matches))
-                $date_output = preg_replace('/^(\\d{1,2})\/(\\d{1,2})\/(\\d{4})$/', '$1/$2/$3 00:00:00', $matches[0]);
-        } else {
-            // sous la forme 2007-12-25 (qqch)?
-            if (preg_match('/(\\d{4})\\-(\\d{2})\\-(\\d{2})/', $date_origine, $matches)) {
-                $date_output = preg_replace('/(\\d{4})\\-(\\d{2})\\-(\\d{2})/', '$3/$2/$1', $matches[0]);
-            } // sous la forme 25/12/2007 => on ajoute 00:00:00
-            elseif (preg_match('/(\\d{1,2})\/(\\d{1,2})\/(\\d{4})/', $date_origine, $matches))
-                $date_output = preg_replace('/^(\\d{1,2})\/(\\d{1,2})\/(\\d{4})$/', '$1/$2/$3', $matches[0]);
-        }
-        if ($date_output!='') {
-            return $date_output;
-        } else {
-            throw new \Exception('Erreur date_from_mysql : date non reconnue ' . $date_origine);
-        }
-    }
-    
-    public static function dateRange($first, $last, $step = '+1 day')
-    {
-
-        $dates = array();
-        $current = strtotime($first);
-        $last = strtotime($last);
-        
-        switch ($step) {
-            case '+1 day':
-                $format = 'Y-m-d';
-                break;
-            case '+1 month':
-                $format = 'Y-m-01';
-                break;
-            case '+1 year':
-                $format = 'Y-01-01';
-                break;
-            default:
-                $format = 'Y-m-d';
-        }
-    
-        while ($current <= $last) {
-            $dates[] = date($format, $current);
-            $current = strtotime($step, $current);
-        }
-    
-        return $dates;
-    }
-
-    public static function dateToMysql($date_origine, $return_time = false)
-    {
-
-        $date_output='';
-        if ($return_time) {
-            // sous la forme 25/12/2007 14:55:36 => on reformate tout
-            if (preg_match('/^(\\d{2})\/(\\d{2})\/(\\d{4}) (\\d{2}):(\\d{2}):(\\d{2})$/', $date_origine, $matches)) {
-                $date_output = preg_replace('/^(\\d{2})\/(\\d{2})\/(\\d{4}) (\\d{2}):(\\d{2}):(\\d{2})$/', '$3-$2-$1 $4:$5:$6', $matches[0]);
-            } // sous la forme 25/12/2007 14:55 => on ajoute :00
-            elseif (preg_match('/^(\\d{1,2})\/(\\d{1,2})\/(\\d{4}) (\\d{2}):(\\d{2})$/', $date_origine, $matches))
-                $date_output = preg_replace('/^(\\d{1,2})\/(\\d{1,2})\/(\\d{4}) (\\d{2}):(\\d{2})$/', '$3-$2-$1 $4:$5:00', $matches[0]);
-            // sous la forme 25/12/2007 => on ajoute 00:00:00
-            elseif (preg_match('/^(\\d{1,2})\/(\\d{1,2})\/(\\d{4})$/', $date_origine, $matches))
-                $date_output = preg_replace('/^(\\d{1,2})\/(\\d{1,2})\/(\\d{4})$/', '$3-$2-$1 00:00:00', $matches[0]);
-            // sous la forme time() numérique
-            elseif (is_numeric($date_origine)) {
-                $date_output = date("Y-m-d H:i:s", $date_origine);
-            } // sous la forme mysql datetime
-            elseif (preg_match('/^(\\d{4})-(\\d{2})-(\\d{2}) (\\d{2}):(\\d{2}):(\\d{2})$/', $date_origine, $matches))
-                $date_output = preg_replace('/(\\d{4})-(\\d{2})-(\\d{2}) (\\d{2}):(\\d{2}):(\\d{2})/', '$1-$2-$3 $4:$5:$6', $matches[0]);
-            // sous la forme mysql date
-            elseif (preg_match('/^(\\d{4})-(\\d{2})-(\\d{2})$/', $date_origine, $matches))
-                $date_output = preg_replace('/(\\d{4})-(\\d{2})-(\\d{2})/', '$1-$2-$3 00:00:00', $matches[0]);
-        } else {
-            if (preg_match('/(\\d{1,2})\/(\\d{1,2})\/(\\d{4})/', $date_origine, $matches)) {
-                $date_output = preg_replace('/(\\d{1,2})\/(\\d{1,2})\/(\\d{4})/', '$3-$2-$1', $matches[0]);
-            } // sous la forme d'une timestamp numérique
-            elseif (is_numeric($date_origine))
-                $date_output = date("Y-m-d", $date_origine);
-            // sous la forme mysql datetime
-            elseif (preg_match('/^(\\d{4})-(\\d{2})-(\\d{2}) (\\d{2}):(\\d{2}):(\\d{2})$/', $date_origine, $matches))
-                $date_output = preg_replace('/(\\d{4})-(\\d{2})-(\\d{2}) (\\d{2}):(\\d{2}):(\\d{2})/', '$1-$2-$3', $matches[0]);
-            // sous la forme mysql date
-            elseif (preg_match('/^(\\d{4})-(\\d{2})-(\\d{2})$/', $date_origine, $matches))
-                $date_output = preg_replace('/(\\d{4})-(\\d{2})-(\\d{2}) (\\d{2}):(\\d{2}):(\\d{2})/', '$1-$2-$3', $matches[0]);
-        }
-        if ($date_output!='') {
-            return $date_output;
-        } elseif ($date_output=='') {
-            return null;
-        } else {
-            throw new \Exception('Erreur date_to_mysql : date non reconnue ' . $date_origine);
-        }
-    }
-}
-
-
-
-namespace Nf;
-
-abstract class View extends Singleton
-{
-
-    protected static $_instance;
-
-    private $_vars=array();
-
-    private $_templateDirectory=null;
-    private $_configDirectory=null;
-
-    protected $_response;
-
-    public function setResponse($response)
-    {
-        $this->_response=$response;
-    }
-
-    public static function factory($name)
-    {
-        $className='\\Nf\\View\\' . ucfirst($name);
-        $view=$className::getInstance();
-        return $view;
-    }
-}
-
-
-namespace Nf;
-
-use Nf\Localization;
-
-/**
- * Bootstrap is responsible for instanciating the application in cli or web environment
- *
- * @package Nf
- *         
- */
-class Bootstrap
-{
-
-    const DEFAULT_LOCALESELECTIONORDER = 'cookie,url,browser';
-
-    private $_localeAndVersionFromUrlCache = null;
-
-    private $_applicationNamespace = 'App';
-
-    public function __construct($libraryPath, $applicationPath)
-    {
-        Registry::set('libraryPath', $libraryPath);
-        Registry::set('applicationPath', $applicationPath);
-    }
-
-    public function initHttpEnvironment($inEnvironment = null, $inLocale = null, $inVersion = null)
-    {
-        $urlIni = Ini::parse(Registry::get('applicationPath') . '/configs/url.ini', true);
-        Registry::set('urlIni', $urlIni);
-        
-        // environment : dev, test, prod
-        // si il est défini en variable d'environnement
-        if (empty($inEnvironment)) {
-            if (getenv('environment') != '') {
-                $environment = getenv('environment');
-            } else {
-                // sinon on lit le fichier url.ini
-                if (! empty($_SERVER['HTTP_HOST'])) {
-                    if (preg_match($urlIni->environments->dev->regexp, $_SERVER['HTTP_HOST'])) {
-                        $environment = 'dev';
-                    } elseif (preg_match($urlIni->environments->test->regexp, $_SERVER['HTTP_HOST'])) {
-                        $environment = 'test';
-                    } else {
-                        $environment = 'prod';
-                    }
-                } else {
-                    trigger_error('Cannot guess the requested environment');
-                }
-            }
-        } else {
-            // aucune vérification pour le moment
-            $environment = $inEnvironment;
-        }
-        
-        // locale
-        if (! empty($urlIni->i18n->$environment->localeSelectionOrder)) {
-            $localeSelectionOrder = $urlIni->i18n->$environment->localeSelectionOrder;
-        } else {
-            $localeSelectionOrder = self::DEFAULT_LOCALESELECTIONORDER;
-        }
-        $localeSelectionOrderArray = (array) explode(',', $localeSelectionOrder);
-        // 3 possibilities : suivant l'url ou suivant un cookie ou suivant la langue du navigateur (fonctionnement indiqué dans i18n de url.ini)
-        if (empty($inLocale)) {
-            $locale = null;
-            foreach ($localeSelectionOrderArray as $localeSelectionMethod) {
-                if ($locale === null) {
-                    switch ($localeSelectionMethod) {
-                        case 'browser':
-                            // on utilise la locale du navigateur et on voit si on a une correspondance
-                            if (! empty($_SERVER['HTTP_ACCEPT_LANGUAGE'])) {
-                                // vérification de la syntaxe par une regexp
-                                if (preg_match('/[a-z]+[_\-]?[a-z]+[_\-]?[a-z]+/i', $_SERVER['HTTP_ACCEPT_LANGUAGE'], $matches)) {
-                                    $locale = Localization::normalizeLocale($matches[0]);
-                                    if (! empty($_SERVER['HTTP_HOST'])) {
-                                        $httpHost = strtolower($_SERVER['HTTP_HOST']);
-                                        list ($localeFromUrl, $versionFromUrl, $redirectToHost) = $this->getLocaleAndVersionFromUrl($httpHost, $urlIni);
-                                    }
-                                }
-                            }
-                            break;
-                        case 'url':
-                            // lire le fichier url.ini pour connaître la locale à utiliser
-                            // en fonction de l'url
-                            if (! empty($_SERVER['HTTP_HOST'])) {
-                                $httpHost = strtolower($_SERVER['HTTP_HOST']);
-                                list ($localeFromUrl, $versionFromUrl, $redirectToHost) = $this->getLocaleAndVersionFromUrl($httpHost, $urlIni);
-                                if (! empty($localeFromUrl)) {
-                                    $locale = $localeFromUrl;
-                                }
-                            }
-                            break;
-                        case 'cookie':
-                            // lire le cookie pour connaître la locale à utiliser
-                            if (! empty($_COOKIE['_nfLc'])) {
-                                // vérification de la syntaxe par une regexp
-                                if (preg_match('/[a-z]+[_\-]?[a-z]+[_\-]?[a-z]+/i', $_COOKIE['_nfLc'], $matches)) {
-                                    $locale = Localization::normalizeLocale($matches[0]);
-                                }
-                            }
-                            break;
-                    }
-                }
-            }
-        } else {
-            $locale = $inLocale;
-        }
-        
-        // if we did not find the locale, we use the default value
-        if ($locale == null) {
-            if (! empty($urlIni->i18n->defaultLocale)) {
-                $locale = $urlIni->i18n->defaultLocale;
-            } else {
-                throw new \Exception('You have to set a default locale in url.ini');
-            }
-        }
-        // we match the locale with the defined locale
-        $localeFound = false;
-        foreach ($urlIni->locales as $definedLocale => $definedLocaleNames) {
-            if (! $localeFound) {
-                if (strpos($definedLocaleNames, '|')) {
-                    $arrDefinedLocaleNames = explode('|', $definedLocaleNames);
-                    foreach ($arrDefinedLocaleNames as $localeNameOfArr) {
-                        if (trim($localeNameOfArr) == trim($locale)) {
-                            $locale = trim($definedLocale);
-                            $localeFound = true;
-                            break;
-                        }
-                    }
-                } else {
-                    if (trim($definedLocaleNames) == trim($locale)) {
-                        $locale = trim($definedLocale);
-                        $localeFound = true;
-                        break;
-                    }
-                }
-            }
-        }
-        
-        // if the detected locale was not found in our defined locales
-        if (! $localeFound) {
-            // reverting to the default locale
-            if (! empty($urlIni->i18n->defaultLocale)) {
-                $locale = $urlIni->i18n->defaultLocale;
-            } else {
-                throw new \Exception('You have to set a default locale in url.ini');
-            }
-        }
-        
-        // version (web, mobile, cli...)
-        if (empty($inVersion)) {
-            if (! empty($versionFromUrl)) {
-                $version = $versionFromUrl;
-            } else {
-                if (in_array('url', $localeSelectionOrderArray)) {
-                    if (! empty($_SERVER['HTTP_HOST'])) {
-                        $httpHost = strtolower($_SERVER['HTTP_HOST']);
-                        list ($localeFromUrl, $versionFromUrl, $redirectToHost) = $this->getLocaleAndVersionFromUrl($httpHost, $urlIni);
-                    }
-                }
-                if (! empty($versionFromUrl)) {
-                    $version = $versionFromUrl;
-                } else {
-                    // on prend la version par défaut si elle est définie
-                    if (isset($urlIni->i18n->defaultVersion)) {
-                        $version = $urlIni->i18n->defaultVersion;
-                    } else {
-                        trigger_error('Cannot guess the requested version');
-                    }
-                }
-            }
-        } else {
-            $version = $inVersion;
-        }
-        
-        // on assigne les variables d'environnement et de language en registry
-        Registry::set('environment', $environment);
-        Registry::set('locale', $locale);
-        Registry::set('version', $version);
-        
-        // on lit le config.ini à la section concernée par notre environnement
-        $config = Ini::parse(Registry::get('applicationPath') . '/configs/config.ini', true, $locale . '_' . $environment . '_' . $version, 'common');
-        Registry::set('config', $config);
-        
-        if (! empty($redirectToHost)) {
-            header("HTTP/1.1 301 Moved Permanently");
-            header("Location: http://" . $redirectToHost . $_SERVER['REQUEST_URI']);
-            return false;
-        }
-        
-        // prevention contre l'utilisation de index.php
-        if (isset($_SERVER['REQUEST_URI']) && in_array($_SERVER['REQUEST_URI'], array(
-            'index.php',
-            '/index.php'
-        ))) {
-            header("HTTP/1.1 301 Moved Permanently");
-            header("Location: /");
-            return false;
-        }
-        
-        return true;
-    }
-
-    private function getLocaleAndVersionFromUrl($httpHost, $urlIni)
-    {
-        $redirectToHost = null;
-        
-        if (! empty($this->_localeAndVersionFromUrlCache)) {
-            return $this->_localeAndVersionFromUrlCache;
-        } else {
-            $localeFromUrl = '';
-            $versionFromUrl = '';
-            
-            $found = false;
-            
-            foreach ($urlIni->versions as $version_name => $prefix) {
-                if (! $found) {
-                    $redirectToHost = null;
-                    foreach ($urlIni->suffixes as $locale => $suffix) {
-                        if (! $found) {
-                            if ($suffix != '') {
-                                // the hosts names to test
-                                $httpHostsToTest = array();
-                                if ($prefix == '') {
-                                    $httpHostsToTest = array(
-                                        ltrim(str_replace('[version]', '', $suffix), '.')
-                                    );
-                                } else {
-                                    if (strpos($prefix, '|') !== false) {
-                                        $prefixes = array_values(explode('|', $prefix));
-                                        $redirectToHost = ltrim(str_replace('..', '.', ($prefixes[0] == '<>' ? str_replace('[version]', '', $suffix) : str_replace('[version]', $prefixes[0] . '.', $suffix))), '.');
-                                        foreach ($prefixes as $thePrefix) {
-                                            // default empty prefix
-                                            if ($thePrefix == '<>') {
-                                                $httpHostsToTest[] = ltrim(str_replace('..', '.', str_replace('[version]', '', $suffix)), '.');
-                                            } else {
-                                                $httpHostsToTest[] = ltrim(rtrim(str_replace('..', '.', str_replace('[version]', $thePrefix . '.', $suffix)), '.'), '.');
-                                            }
-                                        }
-                                    } else {
-                                        $redirectToHost = null;
-                                        $httpHostsToTest[] = ltrim(rtrim(str_replace('..', '.', str_replace('[version]', str_replace('<>', '', $prefix) . '.', $suffix)), '.'), '.');
-                                    }
-                                }
-                            } else {
-                                if (strpos($prefix, '|') !== false) {
-                                    $prefixes = array_values(explode('|', $prefix));
-                                    foreach ($prefixes as $thePrefix) {
-                                        $httpHostsToTest[] = $thePrefix;
-                                    }
-                                } else {
-                                    $httpHostsToTest[] = $prefix;
-                                }
-                            }
-                            
-                            // le test sur la chaîne reconstruite
-                            foreach ($httpHostsToTest as $httpHostToTest) {
-                                if ($httpHost == $httpHostToTest) {
-                                    $localeFromUrl = $locale;
-                                    
-                                    $versionFromUrl = $version_name;
-                                    if ($locale == '_default') {
-                                        $localeFromUrl = $urlIni->i18n->defaultLocale;
-                                    }
-                                    if ($httpHostToTest == $redirectToHost) {
-                                        $redirectToHost = null;
-                                    }
-                                    $found = true;
-                                    break;
-                                }
-                            }
-                        }
-                    }
-                } else {
-                    break;
-                }
-                unset($suffix);
-            }
-            
-            unset($prefix);
-            $this->_localeAndVersionFromUrlCache = array(
-                $localeFromUrl,
-                $versionFromUrl,
-                $redirectToHost
-            );
-        }
-        
-        return array(
-            $localeFromUrl,
-            $versionFromUrl,
-            $redirectToHost
-        );
-    }
-
-    public function setApplicationNamespace($namespace)
-    {
-        $this->_applicationNamespace = $namespace;
-        \Nf\Registry::set('applicationNamespace', $namespace);
-    }
-
-    public function initCliEnvironment()
-    {
-        $showUsage = true;
-        
-        if (isset($_SERVER['argv']) && $_SERVER['argc'] >= 2) {
-            $urlIni = Ini::parse(Registry::get('applicationPath') . '/configs/url.ini', true);
-            Registry::set('urlIni', $urlIni);
-            
-            $inEnvironment = 'dev';
-            $inLocale = $urlIni->i18n->defaultLocale;
-            $inVersion = 'cli';
-            $inAction = array(
-                'type' => 'default',
-                'uri' => null
-            );
-            
-            // default values
-            Registry::set('environment', $inEnvironment);
-            Registry::set('locale', $inLocale);
-            Registry::set('version', $inVersion);
-            
-            $arrParams = array();
-            
-            $ac = 1;
-            while ($ac < (count($_SERVER['argv']))) {
-                switch ($_SERVER['argv'][$ac]) {
-                    case '-e':
-                    case '--environment':
-                        $inEnvironment = $_SERVER['argv'][$ac + 1];
-                        $ac += 2;
-                        break;
-                    case '-l':
-                    case '--locale':
-                        $inLocale = $_SERVER['argv'][$ac + 1];
-                        $ac += 2;
-                        break;
-                    case '-v':
-                    case '--version':
-                        $inVersion = $_SERVER['argv'][$ac + 1];
-                        $ac += 2;
-                        break;
-                    case '-a':
-                    case '--action':
-                        $inAction['uri'] = ltrim($_SERVER['argv'][$ac + 1], '/');
-                        $ac += 2;
-                        $showUsage = false;
-                        break;
-                    case '-m':
-                    case '--make':
-                        $inAction['uri'] = ltrim($_SERVER['argv'][$ac + 1], '/');
-                        $inAction['type'] = 'make';
-                        $showUsage = false;
-                        $ac += 2;
-                        break;
-                    default:
-                        $ac += 2;
-                        break;
-                }
-            }
-        }
-        
-        if (! $showUsage) {
-            // on lit le config.ini à la section concernée par notre environnement
-            $config = Ini::parse(Registry::get('applicationPath') . '/configs/config.ini', true, $inLocale . '_' . $inEnvironment . '_' . $inVersion);
-            Registry::set('config', $config);
-            
-            // on assigne les variables d'environnement et de langue en registry
-            Registry::set('environment', $inEnvironment);
-            Registry::set('locale', $inLocale);
-            Registry::set('version', $inVersion);
-            
-            return $inAction;
-        } else {
-            echo "Usage : module/controller/action";
-            echo "\nOr : module/controller/action -variable1 value1 -variable2 value2 -variable3 value3";
-            echo "\nOr : module/controller/action/variable1/value1/variable2/value2/variable3/value3";
-            exit(04);
-        }
-    }
-
-    function redirectForUserAgent()
-    {
-        if (isset($_SERVER['HTTP_USER_AGENT'])) {
-            $userAgent = new \Nf\UserAgent($_SERVER['HTTP_USER_AGENT']);
-            // check the [redirections] section of the url.ini against the userAgent and redirect if we've been told to
-            $urlIni = Registry::get('urlIni');
-            foreach ($urlIni->redirections as $class => $forcedVersion) {
-                if ($userAgent->checkClass($class)) {
-                    if (! empty($forcedVersion)) {
-                        // get the redirection URL according to the current class
-                        $suffixes = (array) $urlIni->suffixes;
-                        $versions = (array) $urlIni->versions;
-                        if ($forcedVersion != $this->_localeAndVersionFromUrlCache[1]) {
-                            $redirectionUrl = 'http://' . str_replace('[version]', $versions[$forcedVersion], $suffixes[$this->_localeAndVersionFromUrlCache[0]]);
-                            $response = new Front\Response\Http();
-                            $response->redirect($redirectionUrl, 301);
-                            $response->sendHeaders();
-                            return true;
-                        }
-                    }
-                }
-            }
-        }
-        return false;
-    }
-
-    function go()
-    {
-        if (php_sapi_name() == 'cli') {
-            $inAction = $this->initCliEnvironment();
-            
-            $uri = $inAction['uri'];
-            Error\Handler::setErrorDisplaying();
-            $front = Front::getInstance();
-            
-            $request = new Front\Request\Cli($uri);
-            $front->setRequest($request);
-            
-            $request->setAdditionalCliParams();
-            
-            $response = new Front\Response\Cli();
-            
-            $front->setResponse($response);
-            $front->setApplicationNamespace($this->_applicationNamespace);
-
-            $this->setTimezone();
-            
-            // routing
-            $router = Router::getInstance();
-            $front->setRouter($router);
-            $router->addAllRoutes();
-            
-            // order in finding routes
-            $router->setStructuredRoutes();
-            
-            $front->addModuleDirectory($this->_applicationNamespace, Registry::get('applicationPath') . '/application/cli/');
-            $front->addModuleDirectory('library', Registry::get('libraryPath') . '/php/application/cli/');
-            
-            $labelManager = LabelManager::getInstance();
-            $labelManager->loadLabels(Registry::get('locale'));
-            
-            $localization = Localization::getInstance();
-            $localization->setLocale(Registry::get('locale'));
-            
-            if ($inAction['type'] == 'default') {
-                $testDispatch = $front->dispatch();
-                
-                if ($testDispatch) {
-                    if ($front->init() !== false) {
-                        $front->launchAction();
-                        $front->postLaunchAction();
-                    }
-                    $response->sendResponse();
-                } else {
-                    throw new \Exception('Action not found : ' . $uri);
-                }
-            } else {
-                $front->parseParameters($inAction['uri']);
-                $className = array();
-                
-                // $inAction['uri'] might be a class name with a static method like \Nf\Make::compress
-                if ((strpos($inAction['uri'], '\\') !== false)) {
-                    if (strpos($inAction['uri'], '::') === false) {
-                        throw new \Exception('You have to specify the model and method to call, or just choose a method from the "Nf\Make" class.');
-                    } else {
-                        $uriSplit = explode('::', $inAction['uri']);
-                        $className = $uriSplit[0];
-                        $methodName = $uriSplit[1];
-                        $obj = new $className();
-                        $className::$methodName();
-                    }
-                } else {
-                    // or an already integrated method in Nf\Make
-                    $methodName = $inAction['uri'];
-                    \Nf\Make::$methodName();
-                }
-            }
-        } else {
-            $this->initHttpEnvironment();
-            
-            Error\Handler::setErrorDisplaying();
-            
-            if (! $this->redirectForUserAgent()) {
-                $front = Front::getInstance();
-                $request = new Front\Request\Http();
-                
-                $front->setRequest($request);
-                $response = new Front\Response\Http();
-                $front->setResponse($response);
-                $front->setApplicationNamespace($this->_applicationNamespace);
-                
-                $this->setTimezone();
-                
-                // routing
-                $router = Router::getInstance();
-                $front->setRouter($router);
-                $router->addAllRoutes();
-                
-                // order in finding routes
-                $router->setRoutesFromFiles();
-                $router->setRootRoutes();
-                $router->setStructuredRoutes();
-                
-                // modules directory for this version
-                $front->addModuleDirectory($this->_applicationNamespace, Registry::get('applicationPath') . '/application/' . Registry::get('version') . '/');
-                $front->addModuleDirectory('library', Registry::get('libraryPath') . '/php/application/' . Registry::get('version') . '/');
-                
-                $config = Registry::get('config');
-                if (isset($config->session->handler)) {
-                    $front->setSession(Session::start());
-                }
-                
-                $labelManager = LabelManager::getInstance();
-                $labelManager->loadLabels(Registry::get('locale'));
-                
-                $localization = Localization::getInstance();
-                Localization::setLocale(Registry::get('locale'));
-                
-                $testDispatch = $front->dispatch();
-                
-                $requestIsClean = $request->sanitizeUri();
-                
-                if ($requestIsClean) {
-                    if ($testDispatch === true) {
-                        $request->setPutFromRequest();
-                        
-                        if (! $request->redirectForTrailingSlash()) {
-                            if ($front->init() !== false) {
-                                if (! $front->response->isRedirect()) {
-                                    $front->launchAction();
-                                }
-                                if (! $front->response->isRedirect()) {
-                                    $front->postLaunchAction();
-                                }
-                            }
-                        }
-                    } else {
-                        Error\Handler::handleNotFound(404);
-                    }
-                } else {
-                    Error\Handler::handleForbidden(403);
-                }
-                $response->sendResponse();
-            }
-        }
-    }
-    
-    private function setTimezone() {
-        $config = Registry::get('config');
-        if(isset($config->date->timezone)) {
-            try {
-                date_default_timezone_set($config->date->timezone);
-            }
-            catch(\Exception $e) {
-                echo 'timezone set failed (' . $config->date->timezone . ') is not a valid timezone';
-            }
-        }
-    }
-    
-}
-
-
-
-namespace Nf;
-
-abstract class Image
-{
-
-    public static function generateThumbnail($imagePath, $thumbnailPath, $thumbnailWidth = 100, $thumbnailHeight = 100, $cut = false)
-    {
-
-        // load the original image
-        $image = new \Imagick($imagePath);
-
-        // undocumented method to limit imagick to one cpu thread
-        $image->setResourceLimit(6, 1);
-
-        // get the original dimensions
-        $width = $image->getImageWidth();
-        $height = $image->getImageHeight();
-
-        // the image will not be cut and the final dimensions will be within the requested dimensions
-        if (!$cut) {
-            // width & height : maximums and aspect ratio is maintained
-            if ($thumbnailHeight==0) {
-                $r=$width/$height;
-                $thumbnailHeight=ceil($thumbnailWidth/$r);
-                // create the thumbnail
-                $image->thumbnailImage($thumbnailWidth, $thumbnailHeight);
-            } elseif ($thumbnailWidth==0) {
-                $r=$width/$height;
-                $thumbnailWidth=ceil($thumbnailHeight*$r);
-                // create thumbnail
-                $image->thumbnailImage($thumbnailWidth, $thumbnailHeight);
-            } else {
-                // determine which dimension to fit to
-                $fitWidth = ($thumbnailWidth / $width) < ($thumbnailHeight / $height);
-                // create thumbnail
-                $image->thumbnailImage(
-                    $fitWidth ? $thumbnailWidth : 0,
-                    $fitWidth ? 0 : $thumbnailHeight
-                );
-            }
-        } else {
-            if ($thumbnailWidth==0 || $thumbnailHeight==0) {
-                throw new \Exception('Cannot generate thumbnail in "cut" mode when a dimension equals zero. Specify the dimensions.');
-            }
-
-            // scale along the smallest side
-            $r=$width/$height;
-            if ($r<1) {
-                $newWidth=$thumbnailWidth;
-                $newHeight=ceil($thumbnailWidth/$r);
-            } else {
-                $newWidth=ceil($thumbnailHeight*$r);
-                $newHeight=$thumbnailHeight;
-            }
-
-            $image->thumbnailImage($newWidth, $newHeight);
-            $width=$newWidth;
-            $height=$newHeight;
-
-            $workingImage=$image->getImage();
-            $workingImage->contrastImage(50);
-            $workingImage->setImageBias(10000);
-            $kernel = array( 0,-1,0,
-                             -1,4,-1,
-                             0,-1,0);
-
-            $workingImage->convolveImage($kernel);
-
-            $x=0;
-            $y=0;
-            $sliceLength=16;
-
-            while ($width-$x>$thumbnailWidth) {
-                $sliceWidth=min($sliceLength, $width - $x - $thumbnailWidth);
-                $imageCopy1=$workingImage->getImage();
-                $imageCopy2=$workingImage->getImage();
-                $imageCopy1->cropImage($sliceWidth, $height, $x, 0);
-                $imageCopy2->cropImage($sliceWidth, $height, $width - $sliceWidth, 0);
-
-                if (self::entropy($imageCopy1) < self::entropy($imageCopy2)) {
-                    $x+=$sliceWidth;
-                } else {
-                    $width-=$sliceWidth;
-                }
-            }
-
-            while ($height-$y>$thumbnailHeight) {
-                $sliceHeight=min($sliceLength, $height - $y - $thumbnailHeight);
-                $imageCopy1=$workingImage->getImage();
-                $imageCopy2=$workingImage->getImage();
-                $imageCopy1->cropImage($width, $sliceHeight, 0, $y);
-                $imageCopy2->cropImage($width, $sliceHeight, 0, $height - $sliceHeight);
-
-                if (self::entropy($imageCopy1) < self::entropy($imageCopy2)) {
-                    $y+=$sliceHeight;
-                } else {
-                    $height-=$sliceHeight;
-                }
-            }
-
-            $image->cropImage($thumbnailWidth, $thumbnailHeight, $x, $y);
-        }
-
-        if ($thumbnailPath!=null) {
-            $image->writeImage($thumbnailPath);
-            $image->clear();
-            $image->destroy();
-            return $thumbnailPath;
-        } else {
-            return $image;
-        }
-
-    }
-
-    private static function entropy($image)
-    {
-        $image->setImageType(\Imagick::IMGTYPE_GRAYSCALE);
-        $pixels=$image->getImageHistogram();
-        $hist=array();
-        foreach ($pixels as $p) {
-            $color = $p->getColor();
-            $theColor=$color['r'];
-            if (!isset($hist[$theColor])) {
-                $hist[$theColor]=0;
-            }
-            $hist[$theColor]+=$p->getColorCount();
-        }
-        // calculate the entropy from the histogram
-        // cf http://www.mathworks.com/help/toolbox/images/ref/entropy.html
-        $entropy=0;
-        foreach ($hist as $c => $v) {
-            $entropy-=$v*log($v, 2);
-        }
-        return $entropy;
-    }
-    
-    public static function identifyImage($sourceFile)
-    {
-        return \Imagick::identifyImage($sourceFile);
-    }
-}
-
-
-
-namespace Nf;
-
-class LabelManager extends Singleton
-{
-
-    protected static $_instance;
-
-    private $_labelsLoaded=false;
-    private $_labels=array();
-
-    // load the labels
-    public function loadLabels($locale, $force = false)
-    {
-        if (!$this->_labelsLoaded || $force) {
-            if (file_exists(\Nf\Registry::get('applicationPath') . '/labels/' . $locale . '.ini')) {
-                $this->_labels=parse_ini_file(\Nf\Registry::get('applicationPath') . '/labels/' . $locale . '.ini', true);
-                $this->_labelsLoaded=true;
-            } else {
-                throw new \Exception('Cannot load labels for this locale (' . $locale . ')');
-            }
-        }
-    }
-
-    public static function get($lbl)
-    {
-        $instance=self::$_instance;
-        return $instance->_labels[$lbl];
-    }
-
-    public static function getAll($section = null)
-    {
-        $instance=self::$_instance;
-        if ($section!=null) {
-            return $instance->_labels[$section];
-        } else {
-            return $instance->_labels;
-        }
-    }
-
-    public function __get($lbl)
-    {
-        return $this->_labels[$lbl];
-    }
-}
-
-
-
-namespace Nf\Middleware;
-
-trait Pre
-{
-    
-}
-
-
-namespace Nf\Middleware;
-
-interface MiddlewareInterface
-{
-
-    public function execute();
-}
-
-
-namespace Nf\Profiler;
-
-class File extends ProfilerAbstract
-{
-
-    protected $handle = null;
-    
-    protected $filepath = '/tmp/profiler.log';
-
-    public function __construct($config)
-    {
-        if (isset($config['file'])) {
-            $this->filepath = $config['file'];
-        }
-        $this->handle = fopen($this->filepath, 'a');
-    }
-}
-
-
-
-namespace Nf\Middleware;
-
-trait Post
-{
-    
-}
-
-
-
-namespace Nf\Session;
-
-use Nf\Session;
-use Nf\Cache;
-
-class Memcached extends Session
-{
-    protected static $_instance=null;
-
-    private $_lifeTime;
-    private $_memcache;
-
-    function __construct($params, $lifetime)
-    {
-        register_shutdown_function('session_write_close');
-        $this->_memcache = new \Memcache;
-        $this->_lifeTime = $lifetime;
-        if (strpos($params->hosts, ',')>0) {
-            $hosts=explode(',', $params->hosts);
-            foreach ($hosts as $host) {
-                $this->_memcache->addServer($host, $params->port);
-            }
-            unset($host);
-        } else {
-            $this->_memcache->addServer($params->hosts, $params->port);
-        }
-    }
-
-    function open($savePath, $sessionName)
-    {
-        
-    }
-
-    function close()
-    {
-        $this->_memcache = null;
-        return true;
-    }
-
-    function read($sessionId)
-    {
-        $sessionId = session_id();
-        $cacheKey = Cache::getKeyName('session', $sessionId);
-        if ($sessionId !== "") {
-            return $this->_memcache->get($cacheKey);
-        }
-    }
-
-    function write($sessionId, $data)
-    {
-        // This is called upon script termination or when session_write_close() is called, which ever is first.
-        $cacheKey = Cache::getKeyName('session', $sessionId);
-        $result = $this->_memcache->set($cacheKey, $data, false, $this->_lifeTime);
-        return $result;
-    }
-
-    function destroy($sessionId)
-    {
-        $cacheKey=Cache::getKeyName('session', $sessionId);
-        $this->_memcache->delete($cacheKey, 0);
-        return true;
-    }
-
-    function gc($notUsedInMemcached)
-    {
-        return true;
-    }
-}
-
-
-namespace Nf\View;
-
-use Nf\View;
-
-class Smarty extends View
-{
-
-    protected static $_instance;
-
-    private $_smarty = null;
-
-    const FILE_EXTENSION = '.tpl';
-
-    private $_vars = array();
-
-    protected function __construct()
-    {
-        require_once \Nf\Registry::get('libraryPath') . '/php/classes/Smarty/Smarty.class.php';
-        $this->_smarty = new \Smarty();
-        $front = \Nf\Front::getInstance();
-        $this->setBasePath($front->getModuleName());
-    }
-
-    /**
-     * Return the template engine object, if any
-     * 
-     * @return mixed
-     */
-    public function getEngine()
-    {
-        return $this->_smarty;
-    }
-
-    public function configLoad($filepath, $section = null)
-    {
-        $lang = \Nf\Registry::getInstance()->get('lang');
-        $config_path = realpath(Registry::get('applicationPath') . '/configs/' . $lang . '/' . $front->getModuleName() . '/' . $filepath);
-        $this->_smarty->config_load($config_path, $section);
-    }
-
-    /**
-     * Assign a variable to the view
-     *
-     * @param string $key
-     *            The variable name.
-     * @param mixed $val
-     *            The variable value.
-     * @return void
-     */
-    public function __set($key, $val)
-    {
-        if ('_' == substr($key, 0, 1)) {
-            throw new Exception('Setting private var is not allowed', $this);
-        }
-        if ($this->_smarty == null) {
-            throw new Exception('Smarty is not defined', $this);
-        }
-        $this->_smarty->assignByRef($key, $val);
-        return;
-    }
-
-    public function __get($key)
-    {
-        if ('_' == substr($key, 0, 1)) {
-            throw new Exception('Setting private var is not allowed', $this);
-        }
-        if ($this->_smarty == null) {
-            throw new Exception('Smarty is not defined', $this);
-        }
-        return $this->_smarty->getTemplateVars($key);
-    }
-
-    /**
-     * Allows testing with empty() and
-     * isset() to work
-     *
-     * @param string $key            
-     * @return boolean
-     */
-    public function __isset($key)
-    {
-        $vars = $this->_smarty->getTemplateVars();
-        return isset($vars[$key]);
-    }
-
-    /**
-     * Allows unset() on object properties to work
-     *
-     * @param string $key            
-     * @return void
-     */
-    public function __unset($key)
-    {
-        $this->_smarty->clearAssign($key);
-    }
-
-    /**
-     * Clear all assigned variables
-     *
-     * Clears all variables assigned to
-     * Zend_View either via {@link assign()} or
-     * property overloading ({@link __get()}/{@link __set()}).
-     *
-     * @return void
-     */
-    public function clearVars()
-    {
-        $this->_smarty->clearAllAssign();
-    }
-
-    /**
-     * Processes a view script and returns the output.
-     *
-     * @param string $name
-     *            The script script name to process.
-     * @return string The script output.
-     */
-    public function render($name)
-    {
-        $this->_response->addBodyPart($this->fetch($name));
-    }
-
-    public function fetch($name)
-    {
-        return $this->_smarty->fetch($name . self::FILE_EXTENSION);
-    }
-
-    public function setBasePath($path)
-    {
-        $config = \Nf\Registry::get('config');
-        
-        // configuration de Smarty
-        $this->_smarty->setTemplateDir(array(
-            \Nf\Registry::get('applicationPath') . '/application/' . \Nf\Registry::get('version') . '/' . $path . '/views/',
-            \Nf\Registry::get('libraryPath') . '/php/application/' . \Nf\Registry::get('version') . '/' . $path . '/views/'
-        ));
-        
-        // répertoire du cache Smarty
-        $cacheDirectory = realpath(\Nf\Registry::get('applicationPath')) . '/cache/smarty/' . \Nf\Registry::get('version') . '/' . \Nf\Registry::get('locale') . '/' . $path . '/';
-        // répertoire des templates compilés
-        $compileDirectory = realpath(\Nf\Registry::get('applicationPath')) . '/cache/templates_c/' . \Nf\Registry::get('version') . '/' . \Nf\Registry::get('locale') . '/' . $path . '/';
-        
-        $configDirectory = realpath(\Nf\Registry::get('applicationPath')) . '/configs/' . \Nf\Registry::get('version') . '/' . \Nf\Registry::get('locale') . '/' . $path . '/';
-        
-        $pluginsDirectories = array(
-            realpath(\Nf\Registry::get('applicationPath') . '/plugins/'),
-            realpath(\Nf\Registry::get('libraryPath') . '/php/plugins/'),
-            realpath(\Nf\Registry::get('libraryPath') . '/php/classes/Smarty/plugins/')
-        );
-        
-        \Nf\File::mkdir($cacheDirectory, 0755, true);
-        \Nf\File::mkdir($compileDirectory, 0755, true);
-        
-        $this->_smarty->setUseSubDirs(true);
-        
-        // répertoire de cache de smarty
-        $this->_smarty->setCacheDir($cacheDirectory);
-        // répertoire de compilation
-        $this->_smarty->setCompileDir($compileDirectory);
-        // répertoire des configs smarty des applis
-        $this->_smarty->setConfigDir($configDirectory);
-        // répertoire des plugins
-        foreach ($pluginsDirectories as $pluginsDirectory) {
-            $this->_smarty->addPluginsDir($pluginsDirectory);
-        }
-        
-        $this->_smarty->left_delimiter = $config->view->smarty->leftDelimiter;
-        $this->_smarty->right_delimiter = $config->view->smarty->rightDelimiter;
-        
-        // dev : we disable Smarty's caching
-        if (\Nf\Registry::get('environment') == 'dev') {
-            $this->_smarty->caching = false;
-            $this->_smarty->force_compile = true;
-            $this->_smarty->setCompileCheck(true);
-        }
-        
-        // only one file generated for each rendering
-        $this->_smarty->merge_compiled_includes = true;
-        
-        // send the registry to the view
-        $this->_smarty->assign('_registry', \Nf\Registry::getInstance());
-        
-        // send the label Manager to the view
-        $this->_smarty->assign('_labels', \Nf\LabelManager::getInstance());
-        
-        // $this->_smarty->testInstall();
-    }
-}
-
-
-namespace Nf\Db;
-
-class Expression
-{
-
-    protected $_expression;
-
-    public function __construct($expression)
-    {
-        $this->_expression = (string) $expression;
-    }
-
-    public function __toString()
-    {
-        return $this->_expression;
-    }
-}
-
-
-
-namespace Nf\Cache;
-
-use \Nf\Cache;
-
-class Memcached implements CacheInterface
-{
-
-    private $_memcache;
-
-    function __construct($params)
-    {
-        $this->_memcache = new \Memcache;
-        if (strpos($params->hosts, ',')>0) {
-            $hosts=explode(',', $params->hosts);
-            foreach ($hosts as $host) {
-                $this->_memcache->addServer($host, $params->port);
-            }
-            unset($host);
-        } else {
-            $this->_memcache->addServer($params->hosts, $params->port);
-        }
-    }
-
-    public function load($keyName, $keyValues = array())
-    {
-        if (Cache::isCacheEnabled()) {
-            return $this->_memcache->get(Cache::getKeyName($keyName, $keyValues));
-        } else {
-            return false;
-        }
-    }
-
-    public function save($keyName, $keyValues, $data, $lifetime = Cache::DEFAULT_LIFETIME)
-    {
-        if (Cache::isCacheEnabled()) {
-            $result = $this->_memcache->set(Cache::getKeyName($keyName, $keyValues), $data, false, $lifetime);
-            return $result;
-        } else {
-            return true;
-        }
-    }
-
-    public function delete($keyName, $keyValues)
-    {
-        if (Cache::isCacheEnabled()) {
-            $this->_memcache->delete(Cache::getKeyName($keyName, $keyValues), 0);
-            return true;
-        } else {
-            return true;
-        }
-    }
-}
-
-
-namespace Nf\Cache;
-
-interface CacheInterface
-{
-
-    public function load($keyName, $keyValues = array());
-
-    public function save($keyName, $keyValues, $data, $lifetime = Cache::DEFAULT_LIFETIME);
-
-    public function delete($keyName, $keyValues);
-}
-
-
-
-namespace Nf\Cache;
-
-use \Nf\Cache;
-
-class Apc implements CacheInterface
-{
-
-    function __construct($params)
-    {
-
-    }
-
-    public function load($keyName, $keyValues = array())
-    {
-        if (Cache::isCacheEnabled()) {
-            return apc_fetch(Cache::getKeyName($keyName, $keyValues));
-        } else {
-            return false;
-        }
-    }
-
-    public function save($keyName, $keyValues, $data, $lifetime = Cache::DEFAULT_LIFETIME)
-    {
-        if (Cache::isCacheEnabled()) {
-            return apc_store(Cache::getKeyName($keyName, $keyValues), $data, $lifetime);
-        } else {
-            return true;
-        }
-    }
-
-    public function delete($keyName, $keyValues)
-    {
-        if (Cache::isCacheEnabled()) {
-            return apc_delete(Cache::getKeyName($keyName, $keyValues));
-        } else {
-            return true;
-        }
-    }
-}
-
-
-
-namespace Nf\View;
-
-use Nf\View;
-use Nf\Front;
-use Nf\Registry;
-use Nf\Ini;
-
-class Php extends View
-{
-
-    protected static $_instance;
-
-    const FILE_EXTENSION='.php';
-
-    private $_vars=array();
-
-    private $_templateDirectory=null;
-    private $_configDirectory=null;
-
-    protected $_response;
-
-    protected function __construct()
-    {
-        parent::__construct();
-        $front=Front::getInstance();
-        $this->setBasePath($front->getModuleName());
-        // send the label Manager to the view
-        $this->_vars['labels'] = \Nf\LabelManager::getInstance();
-    }
-
-    /**
-     * Assign a variable to the view
-     *
-     * @param string $key The variable name.
-     * @param mixed $val The variable value.
-     * @return void
-     */
-    public function __set($key, $val)
-    {
-        $this->_vars[$key]=$val;
-        return;
-    }
-
-    public function __get($key)
-    {
-        return $this->_vars[$key];
-    }
-
-    /**
-     * Allows testing with empty() and
-     * isset() to work
-     *
-     * @param string $key
-     * @return boolean
-     */
-    public function __isset($key)
-    {
-        return isset($this->_vars[$key]);
-    }
-
-    /**
-     * Allows unset() on object properties to work
-     *
-     * @param string $key
-     * @return void
-     */
-    public function __unset($key)
-    {
-        unset($this->_vars[$key]);
-    }
-
-    /**
-     * Clear all assigned variables
-     *
-     * Clears all variables assigned to
-     * Zend_View either via {@link assign()} or
-     * property overloading ({@link __get()}/{@link __set()}).
-     *
-     * @return void
-     */
-    public function clearVars()
-    {
-        $this->_vars=array();
-    }
-
-    /**
-     * Processes a view script and returns the output.
-     *
-     * @param string $name The script script name to process.
-     * @return string The script output.
-     */
-    public function render($name)
-    {
-        $this->_response->addBodyPart($this->fetch($name));
-    }
-
-     public function fetch($name)
-     {
-        // ob_start, require du tpl, ob_get_contents et return
-        extract($this->_vars);
-        ob_start();
-        include($this->_templateDirectory . $name . self::FILE_EXTENSION);
-        $content=ob_get_contents();
-        ob_end_clean();
-        return $content;
-        }
-
-
-        public function setBasePath($path)
-        {
-            $this->_templateDirectory = Registry::get('applicationPath') . '/application/' . Registry::get('version') . '/' . $path . '/views/';
-            $this->_configDirectory = Registry::get('applicationPath') . '/configs/' . Registry::get('version') . '/' . Registry::get('locale') . '/' . $path . '/';
-        }
-
-        public function configLoad($filepath, $section = null)
-        {
-            // lire le fichier ini, ajouter aux variables
-            $ini = Ini::parse($filepath);
-            foreach ($ini as $key => $value) {
-                $this->_vars[$key]=$value;
-            }
-
-        }
-}
-
-
-namespace Nf\Task;
-
-class Manager
-{
-
-    protected $pool;
-
-    function __construct()
-    {
-        $this->pool = array();
-    }
-
-    function addTask($task, $callbackFunction = null)
-    {
-        $this->pool[] = array(
-            'task' => $task,
-            'callback' => $callbackFunction
-        );
-    }
-
-    function run()
-    {
-        foreach ($this->pool as $taskInfos) {
-            $taskInfos['task']->fork();
-        }
-        
-        while (1) {
-            // echo "waiting\n";
-            $pid = pcntl_wait($extra);
-            if ($pid == - 1) {
-                break;
-            }
-            // echo ": task done : $pid\n";
-            $this->finishTask($pid);
-        }
-        // echo "processes done ; exiting\n";
-        return;
-    }
-
-    function finishTask($pid)
-    {
-        $taskInfos = $this->pidToTaskInfos($pid);
-        if ($taskInfos) {
-            $taskInfos['task']->finish();
-            $taskInfos['callback']();
-        }
-    }
-
-    function pidToTaskInfos($pid)
-    {
-        foreach ($this->pool as $taskInfos) {
-            if ($taskInfos['task']->pid() == $pid)
-                return $taskInfos;
-        }
-        return false;
-    }
-}
-
-namespace Nf\Profiler;
-
-use \Nf\Registry;
-use \Nf\Middleware\Post;
-
-class Firephp extends ProfilerAbstract
-{
-    
-    use Post;
-
-    protected $totalDuration = 0;
-
-    protected $firephp = false;
-    
-    protected $dbName = '';
-
-    public function output()
-    {
-    }
-
-    public function __construct($config)
-    {
-        
-        require_once(realpath(Registry::get('libraryPath') . '/php/classes/FirePHPCore/FirePHP.class.php'));
-        $this->firephp = \FirePHP::getInstance(true);
-        
-        $this->label = static::LABEL_TEMPLATE;
-        
-        $front = \Nf\Front::getInstance();
-        
-        $this->dbName = $config['name'];
-        
-        $front->registerMiddleware($this);
-        
-        $this->payload = array(
-            array(
-                'Duration',
-                'Query',
-                'Time'
-            )
-        );
-    }
-}
-
-
-namespace Nf\Profiler;
-
-use \Nf\Registry;
-
-class ProfilerAbstract
-{
-
-    protected $label = array();
-    protected $payload = array();
-}
-
-
-namespace Nf\Error;
-
-class Handler extends \Exception
-{
-
-    static $lastError = array(
-        'type' => 'error',
-        'httpCode' => 0,
-        'message' => '',
-        'number' => 0,
-        'file' => '',
-        'line' => 0,
-        'trace' => ''
-    );
-
-    public static function getLastError()
-    {
-        return self::$lastError;
-    }
-
-    public static function disableErrorHandler()
-    {
-        while (set_error_handler(create_function('$errno,$errstr', 'return false;'))) {
-            // Unset the error handler we just set.
-            restore_error_handler();
-            // Unset the previous error handler.
-            restore_error_handler();
-        }
-        // Restore the built-in error handler.
-        restore_error_handler();
-        
-        while (set_exception_handler(create_function('$e', 'return false;'))) {
-            // Unset the error handler we just set.
-            restore_exception_handler();
-            // Unset the previous error handler.
-            restore_exception_handler();
-        }
-        // Restore the built-in error handler.
-        restore_exception_handler();
-    }
-
-    public static function handleError($errno = null, $errstr = 0, $errfile = null, $errline = null)
-    {
-        $error_reporting = error_reporting();
-        if ($error_reporting == 0) {
-            return true; // developer used @ to ignore all errors
-        }
-        if (! ($error_reporting & $errno)) {
-            return true; // developer asked to ignore this error
-        }
-        throw new \ErrorException($errstr, 0, $errno, $errfile, $errline);
-        return false;
-    }
-
-    public static function handleException($exception)
-    {
-        self::$lastError['httpCode'] = 500;
-        self::$lastError['message'] = $exception->getMessage();
-        
-        if (method_exists($exception, 'getHttpStatus')) {
-            self::$lastError['httpCode'] = $exception->getHttpStatus();
-        }
-        
-        if (method_exists($exception, 'getErrors')) {
-            self::$lastError['message'] = $exception->getErrors();
-        }
-        
-        self::disableErrorHandler();
-        self::$lastError['type'] = 'exception';
-        self::$lastError['fullException'] = $exception;
-        self::$lastError['number'] = 0;
-        self::$lastError['file'] = $exception->getFile();
-        self::$lastError['line'] = $exception->getLine();
-        self::$lastError['trace'] = $exception->getTraceAsString();
-        
-        return self::displayAndLogError($exception);
-    }
-
-    public static function handleFatal()
-    {
-        self::disableErrorHandler();
-        $last = error_get_last();
-        if ($last != null) {
-            self::$lastError['type'] = 'fatal';
-            self::$lastError['httpCode'] = 500;
-            self::$lastError['message'] = $last['message'];
-            self::$lastError['number'] = $last['type'];
-            self::$lastError['file'] = $last['file'];
-            self::$lastError['line'] = $last['line'];
-            self::$lastError['trace'] = '';
-            return self::displayAndLogError();
-        }
-    }
-
-    public static function handleForbidden($httpCode = 403, $friendlyMessage = '')
-    {
-        return self::handleHttpError('forbidden', $httpCode, $friendlyMessage);
-    }
-
-    public static function handleNotFound($httpCode = 404, $friendlyMessage = '')
-    {
-        return self::handleHttpError('notFound', $httpCode, $friendlyMessage);
-    }
-
-    private static function handleHttpError($type = 'notFound', $httpCode, $friendlyMessage = '')
-    {
-        self::$lastError['type'] = $type;
-        self::$lastError['httpCode'] = $httpCode;
-        self::$lastError['message'] = $friendlyMessage;
-        self::$lastError['number'] = 0;
-        self::$lastError['file'] = '';
-        self::$lastError['line'] = 0;
-        self::$lastError['trace'] = '';
-        
-        if (\Nf\Registry::isRegistered('config')) {
-            $config = \Nf\Registry::get('config');
-            $front = \Nf\Front::getInstance();
-            $response = $front->getResponse();
-            if ((isset($config->error->clearResponse) && $config->error->clearResponse) || (! isset($config->error->clearResponse))) {
-                $response->clearBody();
-                $response->clearBuffer();
-            }
-            try {
-                $response->setHttpResponseCode($httpCode);
-                $response->sendHeaders();
-            } catch (Exception $e) {}
-            
-            $configName = strtolower($type);
-            
-            if (isset($config->error->displayMethod)) {
-                if ($config->error->displayMethod == 'forward') {
-                    // forward
-                    if (! $front->forward($config->$configName->forward->module, $config->$configName->forward->controller, $config->$configName->forward->action)) {
-                        ini_set('display_errors', 'On');
-                        trigger_error('Error Handler failed to forward to the error controller.', E_USER_ERROR);
-                    }
-                    return true;
-                } else {
-                    $response->addBodyPart('http error: ' . $httpCode);
-                }
-            }
-        }
-    }
-
-    public static function displayAndLogError($exception = null)
-    {
-        $err = self::getLastError();
-        
-        if (\Nf\Registry::isRegistered('config')) {
-            $config = \Nf\Registry::get('config');
-            $front = \Nf\Front::getInstance();
-            $response = $front->getResponse();
-            
-            // optional error logging
-            if ((isset($exception->doLog) && $exception->doLog || ! isset($exception->doLog))) {
-                if (isset($config->error->logger->class) && strtolower($config->error->logger->class) != 'syslog') {
-                    $className = $config->error->logger->class;
-                    $logger = new $className();
-                    if (! $logger->log($err)) {}
-                } else {
-                    $logger = new \Nf\Error\Logger\Syslog();
-                    if (! $logger->log($err)) {}
-                }
-            }
-            
-            if ($response->isBinary()) {
-                $response->setContentType('html');
-            }
-            if ((isset($config->error->clearResponse) && $config->error->clearResponse) || (! isset($config->error->clearResponse))) {
-                $response->clearBody();
-                $response->clearBuffer();
-            }
-            try {
-                $response->setHttpResponseCode($err['httpCode']);
-                $response->sendHeaders();
-            } catch (Exception $e) {}
-            
-            if (isset($config->error->displayMethod)) {
-                if ($config->error->displayMethod == 'forward') {
-                    // forward
-                    if (! $front->forward($config->error->forward->module, $config->error->forward->controller, $config->error->forward->action)) {
-                        echo '** Nf: Cannot instantiate error module, printing error message **' . PHP_EOL . PHP_EOL;
-                        $response->displayError($err);
-                        echo PHP_EOL;
-                    } else {
-                        $response->sendResponse();
-                    }
-                    return true;
-                } else {
-                    if (method_exists($exception, 'display')) {
-                        $response->setHttpResponseCode($err['httpCode']);
-                        $exception->display();
-                    } else {
-                        // default : display (if xhr, use alternative display)
-                        $response->displayError($err, $front->getRequest()
-                            ->isXhr());
-                    }
-                }
-            }
-            
-            return true;
-        } else {
-            @header('HTTP/1.1 500 Internal Server Error');
-            print_r($err);
-            error_log(print_r($err, true));
-            return true;
-        }
-    }
-
-    public static function setErrorHandler()
-    {
-        set_error_handler(array(
-            'Nf\Error\Handler',
-            'handleError'
-        ));
-        set_exception_handler(array(
-            'Nf\Error\Handler',
-            'handleException'
-        ));
-        register_shutdown_function(array(
-            'Nf\Error\Handler',
-            'handleFatal'
-        ));
-    }
-
-    public static function setErrorDisplaying()
-    {
-        if (\Nf\Registry::isRegistered('config')) {
-            $config = \Nf\Registry::get('config');
-            if (isset($config->error->displayPHPErrors) && (strtolower($config->error->displayPHPErrors) == 'off' || $config->error->displayPHPErrors == 0)) {
-                ini_set('display_errors', 0); // don't display the errors
-            } else {
-                ini_set('display_errors', 1); // display the errors
-            }
-        } else {
-            ini_set('display_errors', 1);
-        }
-    }
-
-    public static function recursiveArrayToString($arr)
-    {
-        if (! is_string($arr)) {
-            return json_encode($arr);
-        } else {
-            return $arr;
-        }
-    }
-}
-
-
-
-namespace Nf\Session;
-
-use Nf\Session;
-use Nf\Db;
-use Nf\Date;
-
-class Mysqli extends Session
-{
-    protected static $_instance=null;
-
-    private $_lifeTime;
-    private $_connection;
-    private $_params;
-
-    function __construct($params, $lifetime)
-    {
-        register_shutdown_function('session_write_close');
-        $db = Db::getConnection($params->db_adapter);
-        $this->_params=$params;
-        $this->_connection=$db;
-        $this->_lifeTime = $lifetime;
-    }
-
-    function open($savePath, $sessionName)
-    {
-        
-    }
-
-    function close()
-    {
-        $this->_connection->closeConnection();
-        return true;
-    }
-
-    function read($sessionId)
-    {
-        if ($sessionId !== '') {
-            $sql="SELECT data FROM " . $this->_params->db_table . " WHERE id=" . $this->_connection->quote($sessionId) . " LIMIT 1";
-            $res=$this->_connection->query($sql);
-            if ($res->rowCount()>0) {
-                $row=$res->fetch();
-                return $row['data'];
-            }
-        }
-    }
-
-    function write($sessionId, $data)
-    {
-        // This is called upon script termination or when session_write_close() is called, which ever is first.
-        $values=array(
-            'data' => $data,
-            'id' => $sessionId,
-            'modified' => date('Y-m-d H:i:s'),
-            'lifetime' => $this->_lifeTime
-        );
-        $sql="INSERT INTO " . $this->_params->db_table . " (id, data, modified, lifetime) VALUES(" . $this->_connection->quote($values['id']) . ", " . $this->_connection->quote($values['data']) . ", " . $this->_connection->quote($values['modified']) . ", " . $this->_connection->quote($values['lifetime']) . ")
-				ON DUPLICATE KEY UPDATE data=" . $this->_connection->quote($values['data']) . ", modified=" . $this->_connection->quote($values['modified']);
-        $this->_connection->query($sql);
-        return true;
-    }
-
-    function destroy($sessionId)
-    {
-        $sql="DELETE FROM " . $this->_params->db_table . " WHERE id=" . $sessionId;
-        $this->_connection->query($sql);
-        return true;
-    }
-
-    function gc()
-    {
-        $sql="DELETE FROM " . $this->_params->db_table . " WHERE modified < DATE_SUB('" . date('Y-m-d H:i:s') . "',INTERVAL lifetime SECOND)";
-        $this->_connection->query($sql);
-        return true;
-    }
-}
-
-
-
-namespace Nf\Front;
-
-class Controller
-{
-
-    protected $_front;
-    protected $_view;
-
-    public function __construct($front)
-    {
-        $this->_front=$front;
-    }
-
-    public function getParams()
-    {
-        return $this->_front->getParams();
-    }
-
-    public function __get($var)
-    {
-        if ($var=='view') {
-            if (is_null($this->_view)) {
-                $this->_view=$this->_front->getView();
-            }
-            return $this->_view;
-        } elseif ($var=='front') {
-            return $this->_front;
-        } elseif ($var=='session') {
-            return $this->_front->getSession();
-        } elseif ($var=='request') {
-            return $this->_front->getRequest();
-        } elseif ($var=='response') {
-            return $this->_front->getResponse();
-        } else {
-            return $this->$var;
-        }
-    }
-    
-    public function getRequest()
-    {
-        return $this->_front->getRequest();
-    }
-    
-    public function getResponse()
-    {
-        return $this->_front->getResponse();
-    }
-
-    // called after dispatch
-    public function init()
-    {
-        return true;
-    }
-
-    // called after action
-    public function postAction()
-    {
-
-    }
-
-    public function getLabel($lbl)
-    {
-        return \Nf\LabelManager::get($lbl);
-    }
-}
-
-
-namespace Nf\Front\Request;
-
-class Http extends AbstractRequest
-{
-
-    protected $_params = array();
-
-    private $_put = null;
-
-    public function __construct()
-    {
-        if (! empty($_SERVER['REDIRECT_URL'])) {
-            $uri = ltrim($_SERVER['REDIRECT_URL'], '/');
-            if (! empty($_SERVER['REDIRECT_QUERY_STRING'])) {
-                $uri .= '?' . $_SERVER['REDIRECT_QUERY_STRING'];
-            }
-        } else {
-            $uri = ltrim($_SERVER['REQUEST_URI'], '/');
-        }
-        $this->_uri = $uri;
-    }
-
-    public function sanitizeUri()
-    {
-        // filter the uri according to the config of security.restrictCharactersInUrl
-        // this option only allows us to use Alpha-numeric text, Tilde: ~, Period: ., Colon: :, Underscore: _, Dash: -
-        $config = \Nf\Registry::get('config');
-        if (isset($config->security->restrictCharactersInUrl) && $config->security->restrictCharactersInUrl) {
-            if (preg_match('%[\w0-9~.,/@\-=:[\]{}|&?!\%]*%i', $this->_uri, $regs)) {
-                if ($this->_uri == $regs[0]) {
-                    return true;
-                }
-            }
-            return false;
-        } else {
-            return true;
-        }
-    }
-
-    public function getMethod()
-    {
-        return $_SERVER['REQUEST_METHOD'];
-    }
-
-    public function isPost()
-    {
-        if ('POST' == $this->getMethod()) {
-            return true;
-        }
-        return false;
-    }
-
-    public function isGet()
-    {
-        if ('GET' == $this->getMethod()) {
-            return true;
-        }
-        return false;
-    }
-
-    public function isXhr()
-    {
-        return (isset($_SERVER['HTTP_X_REQUESTED_WITH']) && $_SERVER['HTTP_X_REQUESTED_WITH'] == 'XMLHttpRequest');
-    }
-
-    public function getUri()
-    {
-        return $this->_uri;
-    }
-
-    public function getParams()
-    {
-        $return = $this->_params;
-        $paramSources = $this->getParamSources();
-        if (in_array('_GET', $paramSources) && isset($_GET) && is_array($_GET)) {
-            $return += $_GET;
-        }
-        if (in_array('_POST', $paramSources) && isset($_POST) && is_array($_POST)) {
-            $return += $_POST;
-        }
-        return $return;
-    }
-    
-    // get the string sent as put
-    public function setPutFromRequest()
-    {
-        if ($this->_put === null) {
-            if ($_SERVER['REQUEST_METHOD'] == 'PUT') {
-                $this->_put = file_get_contents("php://input");
-            }
-        } else {
-            $this->_put = '';
-        }
-    }
-
-    public function getPost($jsonDecode = 'assoc')
-    {
-        $post = '';
-        if ($_SERVER['REQUEST_METHOD'] == 'POST') {
-            $post = file_get_contents("php://input");
-        }
-        
-        if ($jsonDecode == 'assoc') {
-            return json_decode($post, true);
-        } else {
-            return $post;
-        }
-    }
-
-    public function getPut($jsonDecode = 'assoc')
-    {
-        if ($jsonDecode == 'assoc') {
-            return json_decode($this->_put, true);
-        } else {
-            return $this->_put;
-        }
-    }
-    
-    // handle the redirection according to the trailing slash configuration
-    public function redirectForTrailingSlash()
-    {
-        $config = \Nf\Registry::get('config');
-        $redirectionUrl = false;
-        $requestParams = '';
-        $requestPage = '/' . $this->_uri;
-        
-        // we don't redirect for the home page...
-        if ($requestPage != '/' && mb_strpos($requestPage, '/?') !== 0) {
-            // the url without the params is :
-            if (mb_strpos($requestPage, '?') !== false) {
-                $requestParams = mb_substr($requestPage, mb_strpos($requestPage, '?'), mb_strlen($requestPage) - mb_strpos($requestPage, '?'));
-                $requestPage = mb_substr($requestPage, 0, mb_strpos($requestPage, '?'));
-            }
-            
-            if (isset($config->trailingSlash->needed) && $config->trailingSlash->needed==true) {
-                if (mb_substr($requestPage, - 1, 1) != '/') {
-                    $redirectionUrl = 'http://' . $_SERVER['HTTP_HOST'] . $requestPage . '/' . $requestParams;
-                }
-            } else {
-                if (mb_substr($requestPage, - 1, 1) == '/') {
-                    $redirectionUrl = 'http://' . $_SERVER['HTTP_HOST'] . rtrim($requestPage, '/') . $requestParams;
-                }
-            }
-            
-            if ($redirectionUrl !== false) {
-                $response = new \Nf\Front\Response\Http();
-                $response->redirect($redirectionUrl, 301);
-                $response->sendHeaders();
-                return true;
-            }
-        }
-        
-        return false;
-    }
-}
-
-
-namespace Nf\Front\Response;
-
-class Http extends AbstractResponse
-{
-
-    const SEPARATOR = 'separator';
-
-    const SEPARATOR_ALT = "\n";
-
-    const NEWLINE = '<br>';
-
-    const NEWLINE_ALT = "\n";
-
-    const TAB = " ";
-
-    const TAB_ALT = " ";
-
-    private $contentType = 'html';
-
-    private $isBinaryContent = false;
-    
-    private $encoding = 'utf-8';
-
-    protected $_headers = array();
-
-    protected $_headersRaw = array();
-
-    protected $_httpResponseCode = 200;
-
-    protected $_isRedirect = false;
-
-    protected function _normalizeHeader($name)
-    {
-        $filtered = str_replace(array(
-            '-',
-            '_'
-        ), ' ', (string) $name);
-        $filtered = ucwords(strtolower($filtered));
-        $filtered = str_replace(' ', '-', $filtered);
-        return $filtered;
-    }
-
-    public function setHeader($name, $value, $replace = false)
-    {
-        $this->canSendHeaders(true);
-        $name = $this->_normalizeHeader($name);
-        $value = (string) $value;
-        
-        if ($replace) {
-            foreach ($this->_headers as $key => $header) {
-                if ($name == $header['name']) {
-                    unset($this->_headers[$key]);
-                }
-            }
-        }
-        $this->_headers[] = array(
-            'name' => $name,
-            'value' => $value,
-            'replace' => $replace
-        );
-        return $this;
-    }
-
-    public function redirect($url, $code = 302, $exit = true)
-    {
-        $this->canSendHeaders();
-        $this->setHeader('Location', $url, true)->setHttpResponseCode($code);
-        if ($exit) {
-            $front = \Nf\Front::getInstance();
-            $front->postLaunchAction();
-            $this->clearBuffer();
-            $this->clearBody();
-            $this->sendHeaders();
-            exit();
-        }
-        return $this;
-    }
-
-    public function isRedirect()
-    {
-        return $this->_isRedirect;
-    }
-
-    public function getHeaders()
-    {
-        return $this->_headers;
-    }
-
-    public function clearHeaders()
-    {
-        $this->_headers = array();
-        
-        return $this;
-    }
-
-    public function clearHeader($name)
-    {
-        if (! count($this->_headers)) {
-            return $this;
-        }
-        foreach ($this->_headers as $index => $header) {
-            if ($name == $header['name']) {
-                unset($this->_headers[$index]);
-            }
-        }
-        return $this;
-    }
-
-    public function setRawHeader($value)
-    {
-        $this->canSendHeaders();
-        if ('Location' == substr($value, 0, 8)) {
-            $this->_isRedirect = true;
-        }
-        $this->_headersRaw[] = (string) $value;
-        return $this;
-    }
-
-    public function clearRawHeaders()
-    {
-        $this->_headersRaw = array();
-        return $this;
-    }
-
-    public function clearRawHeader($headerRaw)
-    {
-        if (! count($this->_headersRaw)) {
-            return $this;
-        }
-        $key = array_search($headerRaw, $this->_headersRaw);
-        unset($this->_headersRaw[$key]);
-        return $this;
-    }
-
-    public function clearAllHeaders()
-    {
-        return $this->clearHeaders()->clearRawHeaders();
-    }
-
-    public function setHttpResponseCode($code)
-    {
-        if (! is_int($code) || (100 > $code) || (599 < $code)) {
-            throw new \Exception('Invalid HTTP response code');
-        }
-        if ((300 <= $code) && (307 >= $code)) {
-            $this->_isRedirect = true;
-        } else {
-            $this->_isRedirect = false;
-        }
-        $this->_httpResponseCode = $code;
-        return $this;
-    }
-
-    public function canSendHeaders()
-    {
-        $headersSent = headers_sent($file, $line);
-        if ($headersSent) {
-            trigger_error('Cannot send headers; headers already sent in ' . $file . ', line ' . $line);
-        }
-        return ! $headersSent;
-    }
-
-    public function sendHeaders()
-    {
-        // Only check if we can send headers if we have headers to send
-        if (count($this->_headersRaw) || count($this->_headers) || (200 != $this->_httpResponseCode)) {
-            $this->canSendHeaders();
-        } elseif (200 == $this->_httpResponseCode) {
-            // Haven't changed the response code, and we have no headers
-            return $this;
-        }
-        
-        $httpCodeSent = false;
-        
-        foreach ($this->_headersRaw as $header) {
-            if (! $httpCodeSent && $this->_httpResponseCode) {
-                header($header, true, $this->_httpResponseCode);
-                $httpCodeSent = true;
-            } else {
-                header($header);
-            }
-        }
-        
-        foreach ($this->_headers as $header) {
-            if (! $httpCodeSent && $this->_httpResponseCode) {
-                header($header['name'] . ': ' . $header['value'], $header['replace'], $this->_httpResponseCode);
-                $httpCodeSent = true;
-            } else {
-                header($header['name'] . ': ' . $header['value'], $header['replace']);
-            }
-        }
-        
-        if (! $httpCodeSent) {
-            header('HTTP/1.1 ' . $this->_httpResponseCode);
-            $httpCodeSent = true;
-        }
-        
-        return $this;
-    }
-
-    public function displayError($err, $isXhr = false)
-    {
-        // removes the cache headers if there is an error
-        $this->setCacheable(0);
-        if ($isXhr || $this->contentType!='html') {
-            $this->setContentType('text');
-            echo 'Error' . self::NEWLINE_ALT;
-            echo strip_tags(self::displayErrorHelper($err, true));
-            echo 'Error' . self::NEWLINE_ALT;
-        } else {
-            echo '<pre style="color:#555; line-height:16px;"><span style="color:red;">Error</span><br />';
-            echo self::displayErrorHelper($err, false);
-            echo '</pre>';
-        }
-    }
-
-    protected static function boldText($text, $alternativeSeparator = false)
-    {
-        if ($alternativeSeparator) {
-            return '* ' . $text . ' *';
-        } else {
-            return '<b>' . $text . '</b>';
-        }
-    }
-
-    protected static function preFormatErrorText($beginOrEnd, $alternativeSeparator)
-    {
-        if ($alternativeSeparator) {
-            return ($beginOrEnd == 0) ? '' : '';
-        } else {
-            return ($beginOrEnd == 0) ? '<pre>' : '</pre>';
-        }
-    }
-    
-    // sends header to allow the browser to cache the response a given time
-    public function setCacheable($minutes)
-    {
-        $this->setHeader('Expires', gmdate('D, d M Y H:i:s', time() + $minutes * 60) . ' GMT', true);
-        $this->setHeader('Cache-Control', 'max-age=' . $minutes * 60, true);
-        $this->setHeader('Pragma', 'public', true);
-    }
-
-    public function getContentType()
-    {
-        return $this->contentType;
-    }
-    
-    public function isBinary()
-    {
-        return $this->isBinaryContent;
-    }
-
-    public function setContentType($type = 'html')
-    {
-        $this->contentType = $type;
-        $this->isBinaryContent = false;
-        $type = strtolower($type);
-        switch ($type) {
-            case 'atom':
-                $this->setHeader('content-type', 'application/atom+xml');
-                break;
-            case 'css':
-                $this->setHeader('content-type', 'text/css');
-                break;
-            case 'gif':
-                $this->setHeader('content-type', 'image/gif');
-                $this->isBinaryContent = true;
-                break;
-            case 'jpeg':
-            case 'jpg':
-                $this->setHeader('content-type', 'image/jpeg');
-                $this->isBinaryContent = true;
-                break;
-            case 'png':
-                $this->setHeader('content-type', 'image/png');
-                $this->isBinaryContent = true;
-                break;
-            case 'js':
-            case 'javascript':
-                $this->setHeader('content-type', 'text/javascript');
-                break;
-            case 'json':
-                $this->setHeader('content-type', 'application/json');
-                break;
-            case 'pdf':
-                $this->setHeader('content-type', 'application/pdf');
-                $this->isBinaryContent = true;
-                break;
-            case 'rss':
-                $this->setHeader('content-type', 'application/rss+xml');
-                break;
-            case 'text':
-                $this->setHeader('content-type', 'text/plain');
-                break;
-            case 'xml':
-                $this->setHeader('content-type', 'text/xml');
-                break;
-            case 'html':
-                $this->setHeader('content-type', 'text/html');
-                break;
-            default:
-                throw new \Exception('This content type was not found: "' . $type . '"');
-        }
-    }
-    
-    public function getEncoding()
-    {
-        return $this->encoding;
-    }
-    
-    public function setEncoding($encoding)
-    {
-        $this->encoding = $encoding;
-    }
-
-    public static function colorText($text, $color, $alternativeSeparator = false)
-    {
-        if(!$alternativeSeparator) {
-            return '<span style="color:' . $color . '">' . $text . '</span>';
-        }
-        else {
-            return $text;
-        }
-    }
-
-    protected static function escape($str)
-    {
-        return strip_tags($str);
-    }
-}
-
-
-namespace Nf\Db\Adapter;
-
-abstract class AbstractAdapter
-{
-
-    const PROFILER_NAMESPACE_ROOT = '\Nf\Db\Profiler';
-    
-    protected $_config = array();
-
-    protected $_connection = null;
-
-    protected $_autoQuoteIdentifiers = true;
-
-    protected $_cache = false;
-    
-    protected $profiler = false;
-
-    public function __construct($config)
-    {
-        if (! is_array($config)) {
-            throw new \Exception('Adapter parameters must be in an array');
-        }
-        if (! isset($config['charset'])) {
-            $config['charset'] = null;
-        }
-        $this->_config = $config;
-    }
-
-    public function getConnection()
-    {
-        $this->_connect();
-        return $this->_connection;
-    }
-
-    public function query($sql)
-    {
-        $this->_connect();
-        $res = new $this->_resourceClass($sql, $this);
-        
-        $beginTime = microtime(true);
-        
-        $res->execute();
-        
-        $endTime = microtime(true);
-        
-        if ($this->profiler) {
-            $this->profiler->afterQuery($res, $sql, $endTime-$beginTime);
-        }
-        
-        return $res;
-    }
-
-    public function fetchAll($sql)
-    {
-        $cacheKey = md5($sql) . 'All';
-        
-        if (($result = $this->_getCachedResult($cacheKey)) === false) {
-            $stmt = $this->query($sql);
-            $result = $stmt->fetchAll(\Nf\Db::FETCH_ASSOC);
-            $this->_setCachedResult($cacheKey, $result);
-        }
-        $this->disableCache();
-        return $result;
-    }
-
-    public function fetchAssoc($sql)
-    {
-        $cacheKey = md5($sql) . 'Assoc';
-        
-        if (($result = $this->_getCachedResult($cacheKey)) === false) {
-            $stmt = $this->query($sql);
-            $result = array();
-            while ($row = $stmt->fetch(\Nf\Db::FETCH_ASSOC)) {
-                $tmp = array_values(array_slice($row, 0, 1));
-                $result[$tmp[0]] = $row;
-            }
-            $this->_setCachedResult($cacheKey, $result);
-        }
-        $this->disableCache();
-        return $result;
-    }
-
-    public function fetchRow($sql)
-    {
-        $cacheKey = md5($sql) . 'Row';
-        
-        if (($result = $this->_getCachedResult($cacheKey)) === false) {
-            $stmt = $this->query($sql);
-            $result = $stmt->fetch();
-            $this->_setCachedResult($cacheKey, $result);
-        }
-        $this->disableCache();
-        return $result;
-    }
-
-    public function fetchCol($sql)
-    {
-        $cacheKey = md5($sql) . 'Col';
-        
-        if (($result = $this->_getCachedResult($cacheKey)) === false) {
-            $stmt = $this->query($sql);
-            $result = $stmt->fetchAll(\Nf\Db::FETCH_COLUMN, 0);
-            $this->_setCachedResult($cacheKey, $result);
-        }
-        $this->disableCache();
-        return $result;
-    }
-
-    public function fetchOne($sql)
-    {
-        $cacheKey = md5($sql) . 'One';
-        
-        if (($result = $this->_getCachedResult($cacheKey)) === false) {
-            $stmt = $this->query($sql);
-            $result = $stmt->fetchColumn(0);
-            $this->_setCachedResult($cacheKey, $result);
-        }
-        $this->disableCache();
-        return $result;
-    }
-
-    public function fetchPairs($sql)
-    {
-        $cacheKey = md5($sql) . 'Pairs';
-        
-        if (($result = $this->_getCachedResult($cacheKey)) === false) {
-            $stmt = $this->query($sql);
-            $result = array();
-            while ($row = $stmt->fetch(\Nf\Db::FETCH_NUM)) {
-                $result[$row[0]] = $row[1];
-            }
-            $this->_setCachedResult($cacheKey, $result);
-        }
-        $this->disableCache();
-        return $result;
-    }
-
-    public function beginTransaction()
-    {
-        $this->_beginTransaction();
-        return $this;
-    }
-
-    public function commit()
-    {
-        $this->_commit();
-        return $this;
-    }
-
-    public function rollback()
-    {
-        $this->_rollback();
-        return $this;
-    }
-
-    public function enableCache($lifetime = \Nf\Cache::DEFAULT_LIFETIME, $cacheKey = null)
-    {
-        $this->_cache = array(
-            'lifetime' => $lifetime
-        );
-        if ($cacheKey !== null) {
-            $this->_cache['key'] = $cacheKey;
-        }
-        return $this;
-    }
-
-    public function disableCache()
-    {
-        $this->_cache = false;
-        return $this;
-    }
-
-    protected function _getCachedResult($cacheKey)
-    {
-        if ($this->_cache !== false) {
-            $cache = \Nf\Front::getInstance()->getCache('global');
-            $cacheKey = isset($this->_cache['key']) ? $this->_cache['key'] : $cacheKey;
-            return $cache->load('sql', $cacheKey);
-        }
-        return false;
-    }
-
-    protected function _setCachedResult($cacheKey, $result)
-    {
-        if ($this->_cache !== false) {
-            $cache = \Nf\Front::getInstance()->getCache('global');
-            $cacheKey = isset($this->_cache['key']) ? $this->_cache['key'] : $cacheKey;
-            return $cache->save('sql', $cacheKey, $result, $this->_cache['lifetime']);
-        }
-        return false;
-    }
-
-    protected function _quote($value)
-    {
-        if (null === $value) {
-            return 'NULL';
-        } elseif (is_int($value) || $value instanceof \Nf\Db\Expression) {
-            return $value;
-        } elseif (is_float($value)) {
-            return sprintf('%F', $value);
-        } else {
-            return "'" . addcslashes($value, "\000\n\r\\'\"\032") . "'";
-        }
-    }
-
-    public function quote($value, $type = null)
-    {
-        $this->_connect();
-        return $this->_quote($value);
-    }
-
-    public function quoteIdentifier($ident, $auto = false)
-    {
-        return $this->_quoteIdentifierAs($ident, null, $auto);
-    }
-
-    public function quoteColumnAs($ident, $alias, $auto = false)
-    {
-        return $this->_quoteIdentifierAs($ident, $alias, $auto);
-    }
-
-    protected function _quoteIdentifierAs($ident, $alias = null, $auto = false, $as = ' AS ')
-    {
-        if (is_string($ident)) {
-            $ident = explode('.', $ident);
-        }
-        if (is_array($ident)) {
-            $segments = array();
-            foreach ($ident as $segment) {
-                $segments[] = $this->_quoteIdentifier($segment, $auto);
-            }
-            if ($alias !== null && end($ident) == $alias) {
-                $alias = null;
-            }
-            $quoted = implode('.', $segments);
-        } else {
-            $quoted = $this->_quoteIdentifier($ident, $auto);
-        }
-        
-        if ($alias !== null) {
-            $quoted .= $as . $this->_quoteIdentifier($alias, $auto);
-        }
-        return $quoted;
-    }
-
-    protected function _quoteIdentifier($value, $auto = false)
-    {
-        if ($auto === false || $this->_autoQuoteIdentifiers === true) {
-            $q = $this->getQuoteIdentifierSymbol();
-            return ($q . str_replace("$q", "$q$q", $value) . $q);
-        }
-        return $value;
-    }
-
-    public function getQuoteIdentifierSymbol()
-    {
-        return '"';
-    }
-
-    public function setProfilerConfig($profilerConfig)
-    {
-        if ($profilerConfig!=null) {
-            if (isset($profilerConfig['class'])) {
-                if (!empty($profilerConfig['class'])) {
-                    $profilerClass = $profilerConfig['class'];
-                    unset($profilerConfig['class']);
-                    $optionalConfig = $profilerConfig;
-                    $profilerFullClassName = self::PROFILER_NAMESPACE_ROOT . '\\' . $profilerClass;
-                    $profilerInstance = new $profilerFullClassName($optionalConfig);
-                    $this->profiler = $profilerInstance;
-                }
-            } else {
-                throw new \Exception('You must set the profiler class name in the config.ini file');
-            }
-        }
-    }
-    
-    abstract protected function _connect();
-
-    abstract public function isConnected();
-
-    abstract public function closeConnection();
-
-    abstract public function lastInsertId($tableName = null, $primaryKey = null);
-}
-
-
-namespace Nf\Db\Adapter;
-
-use Nf\Localization;
-
-class Mysqli extends AbstractAdapter
-{
-
-    protected $_resourceClass = '\\Nf\\Db\\Resource\\Mysqli';
-
-    protected function _connect()
-    {
-        if ($this->_connection) {
-            return;
-        }
-        
-        if (! extension_loaded('mysqli')) {
-            throw new \Exception('The Mysqli extension is required for this adapter but the extension is not loaded');
-        }
-        
-        if (isset($this->_config['port'])) {
-            $port = (integer) $this->_config['port'];
-        } else {
-            $port = null;
-        }
-        
-        $this->_connection = mysqli_init();
-        
-        if (! empty($this->_config['driver_options'])) {
-            foreach ($this->_config['driver_options'] as $option => $value) {
-                if (is_string($option)) {
-                    // Suppress warnings here
-                    // Ignore it if it's not a valid constant
-                    $option = @constant(strtoupper($option));
-                    if ($option === null) {
-                        continue;
-                    }
-                }
-                @mysqli_options($this->_connection, $option, $value);
-            }
-        }
-        
-        // Suppress connection warnings here.
-        // Throw an exception instead.
-        try {
-            $_isConnected = mysqli_real_connect($this->_connection, $this->_config['hostname'], $this->_config['username'], $this->_config['password'], $this->_config['database'], $port);
-        } catch (Exception $e) {
-            $_isConnected = false;
-        }
-        
-        if ($_isConnected === false || mysqli_connect_errno()) {
-            $this->closeConnection();
-            throw new \Exception(mysqli_connect_error());
-        }
-        
-        if ($_isConnected && ! empty($this->_config['charset'])) {
-            mysqli_set_charset($this->_connection, $this->_config['charset']);
-        }
-    }
-
-    public function isConnected()
-    {
-        return ((bool) ($this->_connection instanceof mysqli));
-    }
-
-    public function closeConnection()
-    {
-        if ($this->isConnected()) {
-            $this->_connection->close();
-        }
-        $this->_connection = null;
-    }
-
-    public function getQuoteIdentifierSymbol()
-    {
-        return "`";
-    }
-
-    protected function _quote($value)
-    {
-        if (null === $value) {
-            return 'NULL';
-        } elseif (is_int($value) || is_float($value) || $value instanceof \Nf\Db\Expression) {
-            return $value;
-        }
-        $this->_connect();
-        return "'" . $this->_connection->real_escape_string($value) . "'";
-    }
-
-    public function lastInsertId($tableName = null, $primaryKey = null)
-    {
-        $mysqli = $this->_connection;
-        return (string) $mysqli->insert_id;
-    }
-
-    public function insert($tableName, array $bind)
-    {
-        $sql = "INSERT INTO " . $this->quoteIdentifier($tableName, true);
-        if (! count($bind)) {
-            // allows for inserting a row without values to get an auto increment id
-            $sql .= " VALUES()";
-        } else {
-            $sql .= " SET ";
-            $insertFields = array();
-            foreach ($bind as $key => $value) {
-                $insertFields[] = $this->quoteIdentifier($key) . "=" . $this->quote($value);
-            }
-            $sql .= " " . implode(', ', $insertFields);
-        }
-        
-        $res = new $this->_resourceClass($sql, $this);
-        $res->execute();
-        
-        return $this->getConnection()->affected_rows;
-    }
-
-    public function insertIgnore($tableName, array $bind)
-    {
-        $sql = "INSERT IGNORE INTO " . $this->quoteIdentifier($tableName, true) . " SET ";
-        $updateFields = array();
-        foreach ($bind as $key => $value) {
-            $updateFields[] = $this->quoteIdentifier($key) . "=" . $this->quote($value);
-        }
-        $sql .= " " . implode(', ', $updateFields);
-        
-        $res = new $this->_resourceClass($sql, $this);
-        $res->execute();
-        
-        return $this->getConnection()->affected_rows;
-    }
-
-    public function upsert($tableName, array $bind, array $where)
-    {
-        $sql = "INSERT INTO " . $this->quoteIdentifier($tableName, true) . " SET ";
-        $updateFields = array();
-        foreach ($bind as $key => $value) {
-            $updateFields[] = $this->quoteIdentifier($key) . "=" . $this->quote($value);
-        }
-        foreach ($where as $key => $value) {
-            $updateFields[] = $this->quoteIdentifier($key) . "=" . $this->quote($value);
-        }
-        $sql .= " " . implode(', ', $updateFields);
-        
-        $sqlOnDuplicate = " ON DUPLICATE KEY UPDATE ";
-        $onDuplicateFields = array();
-        foreach ($bind as $key => $value) {
-            $onDuplicateFields[] = $this->quoteIdentifier($key) . "=" . $this->quote($value);
-        }
-        $sqlOnDuplicate .= " " . implode(', ', $onDuplicateFields);
-        
-        $sql .= $sqlOnDuplicate;
-        
-        $res = new $this->_resourceClass($sql, $this);
-        $res->execute();
-        
-        return $this->getConnection()->affected_rows;
-    }
-
-    public function update($tableName, array $bind, $where = '')
-    {
-        $sql = "UPDATE " . $this->quoteIdentifier($tableName, true) . " SET ";
-        $updateFields = array();
-        foreach ($bind as $key => $value) {
-            $updateFields[] = $this->quoteIdentifier($key) . "=" . $this->quote($value);
-        }
-        $sql .= " " . implode(', ', $updateFields);
-        if ($where != '') {
-            $sql .= " WHERE " . $where;
-        }
-        
-        $res = new $this->_resourceClass($sql, $this);
-        $res->execute();
-        
-        return $this->getConnection()->affected_rows;
-    }
-
-    public function delete($tableName, $where = '')
-    {
-        if ($where != '') {
-            $sql = "DELETE FROM " . $this->quoteIdentifier($tableName, true) . " WHERE " . $where;
-        } else {
-            $sql = "TRUNCATE TABLE" . $this->quoteIdentifier($tableName, true);
-        }
-        
-        $res = new $this->_resourceClass($sql, $this);
-        $res->execute();
-        
-        return $this->getConnection()->affected_rows;
-    }
-
-    function cleanConnection()
-    {
-        $mysqli = $this->_connect();
-        $mysqli = $this->_connection;
-        
-        while ($mysqli->more_results()) {
-            if ($mysqli->next_result()) {
-                $res = $mysqli->use_result();
-                if (is_object($res)) {
-                    $res->free_result();
-                }
-            }
-        }
-    }
-
-    public function multiQuery($queries)
-    {
-        $mysqli = $this->_connect();
-        $mysqli = $this->_connection;
-        
-        if (is_array($queries)) {
-            $queries = implode(';', $queries);
-        }
-        
-        $ret = $mysqli->multi_query($queries);
-        
-        if ($ret === false) {
-            throw new \Exception($mysqli->error);
-        }
-    }
-
-    public static function formatDate($inShortFormatDateOrTimestamp, $hasMinutes = false)
-    {
-        $tstp = Localization::dateToTimestamp($inShortFormatDateOrTimestamp, Localization::SHORT, ($hasMinutes ? Localization::SHORT : Localization::NONE), true);
-        if ($hasMinutes) {
-            return date('Y-m-d', $tstp);
-        } else {
-            return date('Y-m-d H:i:s', $tstp);
-        }
-    }
-
-    /**
-     * Begin a transaction.
-     *
-     * @return void
-     */
-    protected function _beginTransaction()
-    {
-        $this->_connect();
-        $this->_connection->autocommit(false);
-    }
-
-    /**
-     * Commit a transaction.
-     *
-     * @return void
-     */
-    protected function _commit()
-    {
-        $this->_connect();
-        $this->_connection->commit();
-        $this->_connection->autocommit(true);
-    }
-
-    /**
-     * Roll-back a transaction.
-     *
-     * @return void
-     */
-    protected function _rollBack()
-    {
-        $this->_connect();
-        $this->_connection->rollback();
-        $this->_connection->autocommit(true);
-    }
-}
-
-
-namespace Nf\Db\Profiler;
-
-class File extends \Nf\Profiler\File
-{
-    
-    public function afterQuery($resource, $sql, $duration)
-    {
-        fputs($this->handle, date('Y-m-d H:i:s') . PHP_EOL . str_replace(array(
-            "\n",
-            "\t"
-        ), ' ', $sql) . PHP_EOL . round($duration * 10000, 2) . ' ms' . PHP_EOL . '--' . PHP_EOL);
-    }
-}
-
-
-namespace Nf\Error\Exception;
-
-class ClientException extends \Exception
-{
-}
-
-
-namespace Nf\Db\Profiler;
-
-class Firephp extends \Nf\Profiler\Firephp
-{
-
-    const LABEL_TEMPLATE = '#dbName# (#nbQueries# @ #totalDuration# ms)';
-
-    public function afterQuery($resource, $sql, $duration)
-    {
-        $this->payload[] = array(
-            '' . round($duration * 10000, 2),
-            str_replace(array(
-                "\n",
-                "\t"
-            ), ' ', $sql),
-            date('Y-m-d H:i:s')
-        );
-        
-        $this->totalDuration += $duration * 10000;
-    }
-    
-    // outputs the payload
-    public function execute()
-    {
-        $this->label = str_replace(array(
-            '#dbName#',
-            '#nbQueries#',
-            '#totalDuration#'
-        ), array(
-            $this->dbName,
-            count($this->payload) - 1,
-            round($this->totalDuration, 2)
-        ), $this->label);
-        
-        $this->firephp->fb(array(
-            $this->label,
-            $this->payload
-        ), \FirePHP::TABLE);
-    }
-}
-
-
-namespace Nf\Error\Exception;
-
-class Http extends \Exception
-{
-
-    protected $_httpStatus = 500;
-    
-    public $doLog = true;
-
-    public function getHttpStatus()
-    {
-        return $this->_httpStatus;
-    }
-    
-    public function display()
-    {
-        $front = \Nf\Front::getInstance();
-        $response = $front->getResponse();
-        $response->sendResponse();
-    }
-}
-
-
-namespace Nf\Error\Logger;
-
-use \Nf\Registry;
-use \Nf\Error\Handler;
-
-class Gelf
-{
-
-    public function log($err)
-    {
-        $config = Registry::get('config');
-        
-        // We need a transport - UDP via port 12201 is standard.
-        $transport = new \Gelf\Transport\UdpTransport($config->error->logger->gelf->ip, $config->error->logger->gelf->port, \Gelf\Transport\UdpTransport::CHUNK_SIZE_LAN);
-        
-        // While the UDP transport is itself a publisher, we wrap it in a real Publisher for convenience
-        // A publisher allows for message validation before transmission, and it calso supports to send messages
-        // to multiple backends at once
-        $publisher = new \Gelf\Publisher();
-        $publisher->addTransport($transport);
-        
-        $fullMessage = \Nf\Front\Response\Cli::displayErrorHelper($err);
-        
-        // Now we can create custom messages and publish them
-        $message = new \Gelf\Message();
-        $message->setShortMessage(Handler::recursiveArrayToString($err['message']))
-            ->setLevel(\Psr\Log\LogLevel::ERROR)
-            ->setFile($err['file'])
-            ->setLine($err['line'])
-            ->setFullMessage($fullMessage);
-        
-        if (php_sapi_name() == 'cli') {
-            global $argv;
-            $message->setAdditional('url', 'su ' . $_SERVER['LOGNAME'] . ' -c "php ' . Registry::get('applicationPath') . '/html/' . implode(' ', $argv) . '"');
-        } else {
-            $message->setAdditional('url', 'http://' . $_SERVER['HTTP_HOST'] . $_SERVER['REQUEST_URI']);
-        }
-        
-        if (isset($config->error->logger->additionals)) {
-            foreach ($config->error->logger->additionals as $additionalName => $additionalValue) {
-                $message->setAdditional($additionalName, $additionalValue);
-            }
-        }
-        
-        if ($publisher->publish($message)) {
-            return true;
-        } else {
-            return false;
-        }
-    }
-}
-
-
-namespace Nf\Front\Response;
-
-abstract class AbstractResponse
-{
-
-    protected $_bodyParts = array();
-
-    public function addBodyPart($bodyPart)
-    {
-        $this->_bodyParts[] = $bodyPart;
-    }
-
-    public function clearBody()
-    {
-        $this->_bodyParts = array();
-    }
-
-    public function clearBuffer()
-    {
-        $maxObLevel = \Nf\Front::$obLevel;
-        $curObLevel = ob_get_level();
-        if ($curObLevel > $maxObLevel) {
-            do {
-                ob_end_clean();
-                $curObLevel = ob_get_level();
-            } while ($curObLevel > $maxObLevel);
-        }
-    }
-
-    public function output()
-    {
-        echo implode('', $this->_bodyParts);
-    }
-
-    public function sendResponse()
-    {
-        $this->sendHeaders();
-        $this->output();
-    }
-
-    public function setHttpResponseCode($code)
-    {}
-
-    public function isBinary()
-    {
-        return false;
-    }
-
-    public function getContentType()
-    {
-        return false;
-    }
-
-    public function setContentType($type = 'html')
-    {}
-
-    public static function displayErrorHelper($err, $alternativeSeparator = false)
-    {
-        $output = '';
-        
-        $separator = $alternativeSeparator ? static::NEWLINE_ALT : static::NEWLINE;
-        
-        if ($err['type'] != 'fatal') {
-            $output .= static::colorText($err['type'] . ': ' . \Nf\Error\Handler::recursiveArrayToString(static::escape($err['message'])), 'red');
-            $output .= $separator;
-            $output .= static::colorText($err['file'] . ' (line ' . $err['line'] . ')', 'green', $alternativeSeparator);
-            $output .= $separator . '-----' . $separator;
-            $output .= implode($separator, self::getFileSample($err['file'], $err['line']));
-            $output .= $separator . '-----' . $separator;
-            $trace = $err['fullException']->getTrace();
-            foreach ($trace as $entry) {
-                $output .= self::stackTracePrintEntry($entry);
-                if(isset($entry['file']) && isset($entry['line'])) {
-                    $output .= '-----' . $separator;
-                    $output .= implode($separator, self::getFileSample($entry['file'], $entry['line'], 2));
-                    $output .= $separator . '-----' . $separator;
-                }
-            }
-        } else {
-            $output .= $err['message'] . $separator;
-            $output .= static::preFormatErrorText(0, $alternativeSeparator);
-            $output .= self::stackTracePrintEntry($err, 2, $alternativeSeparator);
-            $output .= static::preFormatErrorText(1, $alternativeSeparator);
-        }
-        return $output;
-    }
-
-    protected static function stackTracePrintEntry($entry, $displayArgsType = 1, $alternativeSeparator = false)
-    {
-        $output = '';
-        
-        if (isset($entry['file'])) {
-            $output .= static::colorText($entry['file'] . ' (line ' . $entry['line'] . ')', 'green', $alternativeSeparator);
-            $output .= ($alternativeSeparator ? static::NEWLINE_ALT : static::NEWLINE);
-        }
-        if (isset($entry['class'])) {
-            if ($entry['class'] != 'Nf\Error\Handler') {
-                $output .= 'call: ' . $entry['class'] . '::';
-                if (isset($entry['function'])) {
-                    $output .= $entry['function'];
-                    $output .= ($alternativeSeparator ? static::NEWLINE_ALT : static::NEWLINE);
-                }
-            }
-        }
-        
-        if ($displayArgsType > 0 && isset($entry['args']) && count($entry['args'])) {
-            $output .= static::stackTracePrintArgs($entry['args'], $alternativeSeparator);
-            $output .= ($alternativeSeparator ? static::NEWLINE_ALT : static::NEWLINE);
-        }
-        return $output;
-    }
-
-    protected static function stackTracePrintArgs($args, $alternativeSeparator)
-    {
-        $output = '';
-        $output .= 'arguments: ';
-        $out = array();
-        
-        if (is_array($args)) {
-            foreach ($args as $k => $v) {
-                $forOut = '';
-                $forOut = $k . ' = ';
-                if (is_array($v) || is_object($v)) {
-                    $strV = print_r($v, true);
-                    if (strlen($strV) > 50) {
-                        $strV = substr($strV, 0, 50) . '...';
-                    }
-                    $forReplace = [
-                        "\n",
-                        "\r"
-                    ];
-                    $forOut .= str_replace($forReplace, '', $strV);
-                } else {
-                    $forOut .= $v;
-                }
-                $out[] = $forOut;
-            }
-        }
-        
-        $output .= static::escape($alternativeSeparator ? static::TAB_ALT : static::TAB . '[ ' . implode(', ', $out) . ' ]');
-        return $output;
-    }
-
-    protected static function getFileSample($filename, $line, $linesAround = 3)
-    {
-        $file = new \SplFileObject($filename);
-        $currentLine = $line - $linesAround - 1;
-        $sample = [];
-        while ($currentLine >= 0 && ! $file->eof() && $currentLine < $line + $linesAround) {
-            $file->seek($currentLine);
-            $currentText = trim($file->current(), "\n\r");
-            if ($currentLine == $line - 1) {
-                $sample[] = $currentText;
-            } else {
-                $sample[] = static::colorText($currentText, 'bold_gray');
-            }
-            
-            $currentLine ++;
-        }
-        return $sample;
-    }
-}
-
-
-namespace Nf\Front\Response;
-
-class Cli extends AbstractResponse
-{
-
-    const SEPARATOR = "\r\n";
-
-    const NEWLINE = "\r\n";
-
-    const TAB = "\t";
-
-    public function setHeader($name, $value, $replace = false)
-    {
-        return true;
-    }
-
-    public function redirect($url, $code = 302)
-    {
-        throw new Exception('cannot redirect in cli version');
-    }
-
-    public function clearHeaders()
-    {
-        return false;
-    }
-
-    public function canSendHeaders()
-    {
-        return true;
-    }
-
-    public function sendHeaders()
-    {
-        return false;
-    }
-
-    public function displayError($err, $isXhr = false)
-    {
-        echo static::colorText('Error', 'red') . static::NEWLINE;
-        echo self::displayErrorHelper($err);
-    }
-
-    protected static function boldText($text)
-    {
-        return self::colorText($text, 'green');
-    }
-
-    protected static function preFormatErrorText($beginOrEnd)
-    {
-        return '';
-    }
-
-    public static function colorText($text, $color = 'black')
-    {
-        $colors = array(
-            'black' => '0;30',
-            'dark_gray' => '1;30',
-            'red' => '0;31',
-            'bold_red' => '1;31',
-            'green' => '0;32',
-            'bold_green' => '1;32',
-            'brown' => '0;33',
-            'yellow' => '1;33',
-            'blue' => '0;34',
-            'bold_blue' => '1;34',
-            'purple' => '0;35',
-            'bold_purple' => '1;35',
-            'cyan' => '0;36',
-            'bold_cyan' => '1;36',
-            'white' => '1;37',
-            'bold_gray' => '0;37'
-        );
-        if (isset($colors[$color])) {
-            return "\033[" . $colors[$color] . 'm' . $text . "\033[0m";
-        }
-    }
-
-    protected static function escape($str)
-    {
-        return $str;
-    }
-}
-
-
-namespace Nf\Front\Request;
-
-class Cli extends AbstractRequest
-{
-    
-    // cli parameters that are already used by the framework
-    const RESERVED_CLI_PARAMS = 'e,environment,l,locale,a,action,m,make';
-
-    protected $_params = array();
-
-    public function __construct($uri)
-    {
-        $this->_uri = $uri;
-    }
-
-    public function getUri()
-    {
-        return $this->_uri;
-    }
-
-    public function isXhr()
-    {
-        return false;
-    }
-    
-    // sets additional parameters from the command line from the arguments
-    public function setAdditionalCliParams()
-    {
-        $reservedParams = explode(',', self::RESERVED_CLI_PARAMS);
-        
-        $params = [];
-        
-        $ac = 1;
-        while ($ac < (count($_SERVER['argv']))) {
-            $paramName = substr($_SERVER['argv'][$ac], 1);
-            if (! in_array($paramName, $reservedParams)) {
-                $params[$paramName] = $_SERVER['argv'][$ac + 1];
-            }
-            $ac += 2;
-        }
-        
-        foreach ($params as $param => $value) {
-            $this->setParam($param, $value);
-        }
-    }
-
-    public function getParams()
-    {
-        $return = $this->_params;
-        return $return;
-    }
-}
-
-
-
-namespace Nf\Front\Request;
-
-class AbstractRequest
-{
-
-    private $_paramSources=array('_GET', '_POST');
-
-    public function setParam($name, $value)
-    {
-        $this->_params[$name]=$value;
-    }
-
-    public function getParams()
-    {
-        return $this->_params;
-    }
-
-    protected function getParamSources()
-    {
-        return $this->_paramSources;
-    }
-}
-
-
-namespace Nf\Error\Logger;
-
-use \Nf\Registry;
-
-class Syslog
-{
-
-    public function log($err)
-    {
-        if(!is_string($err['message'])) {
-            $err['message'] = print_r($err['message'], true);
-        }
-        syslog(LOG_WARNING, 'error in file: ' . $err['file'] . ' (line ' . $err['line'] . '). ' . $err['message']);
-    }
-}
-
-
-namespace Nf\Db\Resource;
-
-class Mysqli
-{
-
-    private $_sql;
-
-    private $_res;
-
-    private $_adapter;
-
-    public function __construct($sql, $adapter)
-    {
-        $this->_sql = $sql;
-        $this->_adapter = $adapter;
-    }
-
-    public function execute()
-    {
-        $this->_res = $this->_adapter->getConnection()->query($this->_sql);
-        if ($this->_res === false) {
-            throw new \Exception('The query you tried to execute raised an exception: ' . $this->_sql . ' - ' . $this->_adapter->getConnection()->error);
-        }
-    }
-
-    public function fetch($mode = null)
-    {
-        if (! $this->_res) {
-            return false;
-        }
-        
-        switch ($mode) {
-            case \Nf\Db::FETCH_NUM:
-                return $this->_res->fetch_row();
-                break;
-            case \Nf\Db::FETCH_OBJ:
-                return $this->_res->fetch_object();
-                break;
-            default:
-                return $this->_res->fetch_assoc();
-        }
-    }
-
-    public function fetchAll()
-    {
-        $data = array();
-        while ($row = $this->fetch()) {
-            $data[] = $row;
-        }
-        return $data;
-    }
-
-    public function fetchColumn($col = 0)
-    {
-        $data = array();
-        $col = (int) $col;
-        $row = $this->fetch(\Nf\Db::FETCH_NUM);
-        if (! is_array($row)) {
-            return false;
-        }
-        return $row[$col];
-    }
-
-    public function rowCount()
-    {
-        if (! $this->_adapter) {
-            return false;
-        }
-        $mysqli = $this->_adapter->getConnection();
-        return $mysqli->affected_rows;
-    }
-}
-
-
-namespace Nf\Error\Exception\Http;
-
-use Nf\Error\Exception\Http;
-
-class NotFound extends Http
-{
-    
-    public $doLog = false;
-    
-    protected $_httpStatus = 404;
-    
-    public function getErrors()
-    {
-        return '';
-    }
-}
-
-
-namespace Nf\Error\Exception\Http;
-
-use Nf\Error\Exception\Http;
-
-class Unauthorized extends Http
-{
-    
-    public $doLog = false;
-    
-    protected $_httpStatus = 401;
-    
-    public function getErrors()
-    {
-        return '';
-    }
-}
-
-
-namespace Nf\Error\Exception\Http;
-
-use Nf\Error\Exception\Http;
-
-class NoContent extends Http
-{
-    public $doLog = false;
-
-    protected $_httpStatus = 204;
-
-    public function getErrors()
-    {
-        return '';
-    }
-}
-
-
-namespace Nf\Error\Exception\Http;
-
-use Nf\Error\Exception\Http;
-
-class Forbidden extends Http
-{
-    
-    public $doLog = false;
-    
-    protected $_httpStatus = 403;
-}
-
-
-namespace Nf\Error\Exception\Http;
-
-use Nf\Error\Exception\Http;
-
-/**
- * Gestion des exceptions pour le client avec passage d'array
- */
-class BadRequest extends Http
-{
-
-    public $doLog = false;
-    
-    protected $_httpStatus = 400;
-
-    private $_errors = null;
-
-    /**
-     *
-     * @param array $errors
-     */
-    public function __construct($errors)
-    {
-        if (is_string($errors)) {
-            $errors = array(
-                $errors
-            );
-        }
-        
-        $this->_errors = $errors;
-        parent::__construct();
-    }
-
-    public function getErrors()
-    {
-        return $this->_errors;
-    }
-
-    public function display()
-    {
-        $front = \Nf\Front::getInstance();
-        $response = $front->getResponse();
-        $response->addBodyPart(json_encode($this->_errors));
-        $response->sendResponse();
-    }
-}
diff --git a/nofuss-1.2/cache/routes.all.php b/nofuss-1.2/cache/routes.all.php
deleted file mode 100644
index d300f6c79..000000000
--- a/nofuss-1.2/cache/routes.all.php
+++ /dev/null
@@ -1,16 +0,0 @@
-<?php
- return array (
-  'web' => 
-  array (
-    '*' => 
-    array (
-      'home' => 
-      array (
-        'name' => 'home',
-        'regexp' => 'php-framework-benchmark/nofuss-1.2/html/index.php/hello/index',
-        'controller' => 'home/index/index',
-        'inheritableRegexp' => 'nofuss-1.2/html/index.php/hello/index',
-      ),
-    ),
-  ),
-);
\ No newline at end of file
diff --git a/staticphp-0.9/Application/Cache/.gitkeep b/staticphp-0.9/Application/Cache/.gitkeep
old mode 100644
new mode 100755

From ef9a4c849c1a191191e71d2bca46be03fffaf9f6 Mon Sep 17 00:00:00 2001
From: Anton Minin <anton.a.minin@gmail.com>
Date: Thu, 27 Jul 2017 03:38:41 +0300
Subject: [PATCH 2/5] Add symfony-3.3 and symfony-3.3 with micro kernel

---
 list.sh                                       |    2 +
 symfony-3.3-micro/.gitignore                  |   16 +
 symfony-3.3-micro/README.md                   |    4 +
 symfony-3.3-micro/_benchmark/hello_world.sh   |    3 +
 symfony-3.3-micro/_benchmark/setup.sh         |    8 +
 symfony-3.3-micro/app/AppCache.php            |    7 +
 symfony-3.3-micro/app/AppKernel.php           |   47 +
 symfony-3.3-micro/app/autoload.php            |   13 +
 symfony-3.3-micro/app/config/config.yml       |   24 +
 symfony-3.3-micro/app/config/config_dev.yml   |   27 +
 symfony-3.3-micro/app/config/config_prod.yml  |   27 +
 symfony-3.3-micro/app/config/config_test.yml  |    9 +
 .../app/config/parameters.yml.dist            |   19 +
 symfony-3.3-micro/app/config/services.yml     |    9 +
 symfony-3.3-micro/bin/console                 |   29 +
 symfony-3.3-micro/bin/symfony_requirements    |  146 ++
 symfony-3.3-micro/composer.json               |   48 +
 symfony-3.3-micro/composer.lock               | 1729 ++++++++++++
 symfony-3.3-micro/phpunit.xml.dist            |   31 +
 .../src/App/Controller/HelloController.php    |   17 +
 symfony-3.3-micro/var/SymfonyRequirements.php |  817 ++++++
 symfony-3.3-micro/var/cache/.gitkeep          |    0
 symfony-3.3-micro/var/logs/.gitkeep           |    0
 symfony-3.3-micro/var/sessions/.gitkeep       |    0
 symfony-3.3-micro/web/micro.php               |   19 +
 symfony-3.3/.gitignore                        |   16 +
 symfony-3.3/README.md                         |    4 +
 symfony-3.3/_benchmark/hello_world.sh         |    3 +
 symfony-3.3/_benchmark/setup.sh               |    8 +
 symfony-3.3/app/AppCache.php                  |    7 +
 symfony-3.3/app/AppKernel.php                 |   50 +
 .../app/Resources/views/base.html.twig        |   13 +
 .../Resources/views/default/index.html.twig   |   76 +
 symfony-3.3/app/autoload.php                  |   13 +
 symfony-3.3/app/config/config.yml             |   68 +
 symfony-3.3/app/config/config_dev.yml         |   34 +
 symfony-3.3/app/config/config_prod.yml        |   27 +
 symfony-3.3/app/config/config_test.yml        |   16 +
 symfony-3.3/app/config/parameters.yml.dist    |   19 +
 symfony-3.3/app/config/routing.yml            |    3 +
 symfony-3.3/app/config/routing_dev.yml        |   14 +
 symfony-3.3/app/config/security.yml           |   24 +
 symfony-3.3/app/config/services.yml           |    9 +
 symfony-3.3/bin/console                       |   29 +
 symfony-3.3/bin/symfony_requirements          |  146 ++
 symfony-3.3/composer.json                     |   69 +
 symfony-3.3/composer.lock                     | 2329 +++++++++++++++++
 symfony-3.3/phpunit.xml.dist                  |   31 +
 symfony-3.3/src/AppBundle/AppBundle.php       |    9 +
 .../Controller/DefaultController.php          |   21 +
 .../AppBundle/Controller/HelloController.php  |   18 +
 .../Controller/DefaultControllerTest.php      |   18 +
 symfony-3.3/var/SymfonyRequirements.php       |  817 ++++++
 symfony-3.3/var/cache/.gitkeep                |    0
 symfony-3.3/var/logs/.gitkeep                 |    0
 symfony-3.3/var/sessions/.gitkeep             |    0
 symfony-3.3/web/app.php                       |   32 +
 symfony-3.3/web/app_dev.php                   |   32 +
 symfony-3.3/web/apple-touch-icon.png          |  Bin 0 -> 10784 bytes
 symfony-3.3/web/config.php                    |  422 +++
 symfony-3.3/web/favicon.ico                   |  Bin 0 -> 6518 bytes
 symfony-3.3/web/robots.txt                    |    5 +
 62 files changed, 7433 insertions(+)
 create mode 100644 symfony-3.3-micro/.gitignore
 create mode 100644 symfony-3.3-micro/README.md
 create mode 100644 symfony-3.3-micro/_benchmark/hello_world.sh
 create mode 100644 symfony-3.3-micro/_benchmark/setup.sh
 create mode 100644 symfony-3.3-micro/app/AppCache.php
 create mode 100644 symfony-3.3-micro/app/AppKernel.php
 create mode 100644 symfony-3.3-micro/app/autoload.php
 create mode 100644 symfony-3.3-micro/app/config/config.yml
 create mode 100644 symfony-3.3-micro/app/config/config_dev.yml
 create mode 100644 symfony-3.3-micro/app/config/config_prod.yml
 create mode 100644 symfony-3.3-micro/app/config/config_test.yml
 create mode 100644 symfony-3.3-micro/app/config/parameters.yml.dist
 create mode 100644 symfony-3.3-micro/app/config/services.yml
 create mode 100755 symfony-3.3-micro/bin/console
 create mode 100755 symfony-3.3-micro/bin/symfony_requirements
 create mode 100644 symfony-3.3-micro/composer.json
 create mode 100644 symfony-3.3-micro/composer.lock
 create mode 100644 symfony-3.3-micro/phpunit.xml.dist
 create mode 100644 symfony-3.3-micro/src/App/Controller/HelloController.php
 create mode 100755 symfony-3.3-micro/var/SymfonyRequirements.php
 create mode 100644 symfony-3.3-micro/var/cache/.gitkeep
 create mode 100644 symfony-3.3-micro/var/logs/.gitkeep
 create mode 100644 symfony-3.3-micro/var/sessions/.gitkeep
 create mode 100644 symfony-3.3-micro/web/micro.php
 create mode 100644 symfony-3.3/.gitignore
 create mode 100644 symfony-3.3/README.md
 create mode 100644 symfony-3.3/_benchmark/hello_world.sh
 create mode 100644 symfony-3.3/_benchmark/setup.sh
 create mode 100644 symfony-3.3/app/AppCache.php
 create mode 100644 symfony-3.3/app/AppKernel.php
 create mode 100644 symfony-3.3/app/Resources/views/base.html.twig
 create mode 100644 symfony-3.3/app/Resources/views/default/index.html.twig
 create mode 100644 symfony-3.3/app/autoload.php
 create mode 100644 symfony-3.3/app/config/config.yml
 create mode 100644 symfony-3.3/app/config/config_dev.yml
 create mode 100644 symfony-3.3/app/config/config_prod.yml
 create mode 100644 symfony-3.3/app/config/config_test.yml
 create mode 100644 symfony-3.3/app/config/parameters.yml.dist
 create mode 100644 symfony-3.3/app/config/routing.yml
 create mode 100644 symfony-3.3/app/config/routing_dev.yml
 create mode 100644 symfony-3.3/app/config/security.yml
 create mode 100644 symfony-3.3/app/config/services.yml
 create mode 100755 symfony-3.3/bin/console
 create mode 100755 symfony-3.3/bin/symfony_requirements
 create mode 100644 symfony-3.3/composer.json
 create mode 100644 symfony-3.3/composer.lock
 create mode 100644 symfony-3.3/phpunit.xml.dist
 create mode 100644 symfony-3.3/src/AppBundle/AppBundle.php
 create mode 100644 symfony-3.3/src/AppBundle/Controller/DefaultController.php
 create mode 100644 symfony-3.3/src/AppBundle/Controller/HelloController.php
 create mode 100644 symfony-3.3/tests/AppBundle/Controller/DefaultControllerTest.php
 create mode 100755 symfony-3.3/var/SymfonyRequirements.php
 create mode 100644 symfony-3.3/var/cache/.gitkeep
 create mode 100644 symfony-3.3/var/logs/.gitkeep
 create mode 100644 symfony-3.3/var/sessions/.gitkeep
 create mode 100644 symfony-3.3/web/app.php
 create mode 100644 symfony-3.3/web/app_dev.php
 create mode 100644 symfony-3.3/web/apple-touch-icon.png
 create mode 100644 symfony-3.3/web/config.php
 create mode 100644 symfony-3.3/web/favicon.ico
 create mode 100644 symfony-3.3/web/robots.txt

diff --git a/list.sh b/list.sh
index f2bf65c73..18c1054db 100755
--- a/list.sh
+++ b/list.sh
@@ -40,6 +40,8 @@ staticphp-0.9
 #symfony-2.6
 #symfony-2.7
 symfony-3.0
+symfony-3.3
+symfony-3.3-micro
 tipsy-0.10
 #typo3f-2.3 # does not work
 #typo3f-3.0 # Catchable Fatal Error: Argument 1 passed to TYPO3\Flow\Object\ObjectManager::setObjects() must be of the type array, null given
diff --git a/symfony-3.3-micro/.gitignore b/symfony-3.3-micro/.gitignore
new file mode 100644
index 000000000..93821ad1c
--- /dev/null
+++ b/symfony-3.3-micro/.gitignore
@@ -0,0 +1,16 @@
+/app/config/parameters.yml
+/build/
+/phpunit.xml
+/var/*
+!/var/cache
+/var/cache/*
+!var/cache/.gitkeep
+!/var/logs
+/var/logs/*
+!var/logs/.gitkeep
+!/var/sessions
+/var/sessions/*
+!var/sessions/.gitkeep
+!var/SymfonyRequirements.php
+/vendor/
+/web/bundles/
diff --git a/symfony-3.3-micro/README.md b/symfony-3.3-micro/README.md
new file mode 100644
index 000000000..5d656566e
--- /dev/null
+++ b/symfony-3.3-micro/README.md
@@ -0,0 +1,4 @@
+symfony-3.3
+===========
+
+A Symfony project with [micro kernel](https://symfony.com/doc/current/configuration/micro_kernel_trait.html)
diff --git a/symfony-3.3-micro/_benchmark/hello_world.sh b/symfony-3.3-micro/_benchmark/hello_world.sh
new file mode 100644
index 000000000..bfcc348cc
--- /dev/null
+++ b/symfony-3.3-micro/_benchmark/hello_world.sh
@@ -0,0 +1,3 @@
+#!/bin/sh
+
+url="$base/$fw/web/micro.php/hello/index"
diff --git a/symfony-3.3-micro/_benchmark/setup.sh b/symfony-3.3-micro/_benchmark/setup.sh
new file mode 100644
index 000000000..0244cd4d5
--- /dev/null
+++ b/symfony-3.3-micro/_benchmark/setup.sh
@@ -0,0 +1,8 @@
+#!/bin/sh
+
+export SYMFONY_ENV=prod
+composer install --no-dev --optimize-autoloader
+php bin/console cache:clear --env=prod --no-debug --no-warmup
+php bin/console cache:warmup --env=prod --no-debug
+chmod o+w var/cache/ var/logs/
+chmod -R o+w var/cache/*
diff --git a/symfony-3.3-micro/app/AppCache.php b/symfony-3.3-micro/app/AppCache.php
new file mode 100644
index 000000000..639ec2cd7
--- /dev/null
+++ b/symfony-3.3-micro/app/AppCache.php
@@ -0,0 +1,7 @@
+<?php
+
+use Symfony\Bundle\FrameworkBundle\HttpCache\HttpCache;
+
+class AppCache extends HttpCache
+{
+}
diff --git a/symfony-3.3-micro/app/AppKernel.php b/symfony-3.3-micro/app/AppKernel.php
new file mode 100644
index 000000000..04f982269
--- /dev/null
+++ b/symfony-3.3-micro/app/AppKernel.php
@@ -0,0 +1,47 @@
+<?php
+
+use Symfony\Bundle\FrameworkBundle\Kernel\MicroKernelTrait;
+use Symfony\Component\DependencyInjection\ContainerBuilder;
+use Symfony\Component\HttpKernel\Kernel;
+use Symfony\Component\Config\Loader\LoaderInterface;
+use Symfony\Component\Routing\RouteCollectionBuilder;
+
+class AppKernel extends Kernel
+{
+    use MicroKernelTrait;
+
+    public function registerBundles()
+    {
+        $bundles = [
+            new Symfony\Bundle\FrameworkBundle\FrameworkBundle(),
+            new Symfony\Bundle\MonologBundle\MonologBundle(),
+        ];
+
+        return $bundles;
+    }
+
+    protected function configureRoutes(RouteCollectionBuilder $routes)
+    {
+        $routes->add('/hello/index', \App\Controller\HelloController::class . '::indexAction');
+    }
+
+    public function getRootDir()
+    {
+        return __DIR__;
+    }
+
+    public function getCacheDir()
+    {
+        return dirname(__DIR__).'/var/cache/'.$this->getEnvironment();
+    }
+
+    public function getLogDir()
+    {
+        return dirname(__DIR__).'/var/logs';
+    }
+
+    protected function configureContainer(ContainerBuilder $c, LoaderInterface $loader)
+    {
+        $loader->load($this->getRootDir() . '/config/config_'.$this->getEnvironment().'.yml');
+    }
+}
diff --git a/symfony-3.3-micro/app/autoload.php b/symfony-3.3-micro/app/autoload.php
new file mode 100644
index 000000000..545c536b9
--- /dev/null
+++ b/symfony-3.3-micro/app/autoload.php
@@ -0,0 +1,13 @@
+<?php
+
+//use Doctrine\Common\Annotations\AnnotationRegistry;
+use Composer\Autoload\ClassLoader;
+
+/**
+ * @var ClassLoader $loader
+ */
+$loader = require __DIR__.'/../vendor/autoload.php';
+
+//AnnotationRegistry::registerLoader([$loader, 'loadClass']);
+
+return $loader;
diff --git a/symfony-3.3-micro/app/config/config.yml b/symfony-3.3-micro/app/config/config.yml
new file mode 100644
index 000000000..5e5fd8c63
--- /dev/null
+++ b/symfony-3.3-micro/app/config/config.yml
@@ -0,0 +1,24 @@
+imports:
+    - { resource: parameters.yml }
+#    - { resource: security.yml }
+    - { resource: services.yml }
+
+# Put parameters here that don't need to change on each machine where the app is deployed
+# http://symfony.com/doc/current/best_practices/configuration.html#application-related-configuration
+parameters:
+    locale: en
+
+framework:
+    #esi:             ~
+    #translator:      { fallbacks: ["%locale%"] }
+    secret:          "%secret%"
+    #serializer:      { enable_annotations: true }
+    default_locale:  "%locale%"
+    trusted_hosts:   ~
+    trusted_proxies: ~
+    session:
+        # http://symfony.com/doc/current/reference/configuration/framework.html#handler-id
+        handler_id:  session.handler.native_file
+        save_path:   "%kernel.root_dir%/../var/sessions/%kernel.environment%"
+    fragments:       ~
+    http_method_override: true
diff --git a/symfony-3.3-micro/app/config/config_dev.yml b/symfony-3.3-micro/app/config/config_dev.yml
new file mode 100644
index 000000000..071e9def6
--- /dev/null
+++ b/symfony-3.3-micro/app/config/config_dev.yml
@@ -0,0 +1,27 @@
+imports:
+    - { resource: config.yml }
+
+framework:
+    profiler: { only_exceptions: false }
+
+monolog:
+    handlers:
+        main:
+            type: stream
+            path: "%kernel.logs_dir%/%kernel.environment%.log"
+            level: debug
+            channels: [!event]
+        console:
+            type:   console
+            channels: [!event, !doctrine]
+        # uncomment to get logging in your browser
+        # you may have to allow bigger header sizes in your Web server configuration
+        #firephp:
+        #    type:   firephp
+        #    level:  info
+        #chromephp:
+        #    type:   chromephp
+        #    level:  info
+
+#swiftmailer:
+#    delivery_address: me@example.com
diff --git a/symfony-3.3-micro/app/config/config_prod.yml b/symfony-3.3-micro/app/config/config_prod.yml
new file mode 100644
index 000000000..83ef6d6e5
--- /dev/null
+++ b/symfony-3.3-micro/app/config/config_prod.yml
@@ -0,0 +1,27 @@
+imports:
+    - { resource: config.yml }
+
+#framework:
+#    validation:
+#        cache: validator.mapping.cache.doctrine.apc
+#    serializer:
+#        cache: serializer.mapping.cache.doctrine.apc
+
+#doctrine:
+#    orm:
+#        metadata_cache_driver: apc
+#        result_cache_driver: apc
+#        query_cache_driver: apc
+
+monolog:
+    handlers:
+        main:
+            type:         fingers_crossed
+            action_level: error
+            handler:      nested
+        nested:
+            type:  stream
+            path:  "%kernel.logs_dir%/%kernel.environment%.log"
+            level: debug
+        console:
+            type:  console
diff --git a/symfony-3.3-micro/app/config/config_test.yml b/symfony-3.3-micro/app/config/config_test.yml
new file mode 100644
index 000000000..ec3dfbe5b
--- /dev/null
+++ b/symfony-3.3-micro/app/config/config_test.yml
@@ -0,0 +1,9 @@
+imports:
+    - { resource: config_dev.yml }
+
+framework:
+    test: ~
+    session:
+        storage_id: session.storage.mock_file
+    profiler:
+        collect: false
diff --git a/symfony-3.3-micro/app/config/parameters.yml.dist b/symfony-3.3-micro/app/config/parameters.yml.dist
new file mode 100644
index 000000000..886c92bb8
--- /dev/null
+++ b/symfony-3.3-micro/app/config/parameters.yml.dist
@@ -0,0 +1,19 @@
+# This file is a "template" of what your parameters.yml file should look like
+# Set parameters here that may be different on each deployment target of the app, e.g. development, staging, production.
+# http://symfony.com/doc/current/best_practices/configuration.html#infrastructure-related-configuration
+parameters:
+    database_host:     127.0.0.1
+    database_port:     ~
+    database_name:     symfony
+    database_user:     root
+    database_password: ~
+    # You should uncomment this if you want use pdo_sqlite
+    # database_path: "%kernel.root_dir%/data.db3"
+
+    mailer_transport:  smtp
+    mailer_host:       127.0.0.1
+    mailer_user:       ~
+    mailer_password:   ~
+
+    # A secret key that's used to generate certain security-related tokens
+    secret:            ThisTokenIsNotSoSecretChangeIt
diff --git a/symfony-3.3-micro/app/config/services.yml b/symfony-3.3-micro/app/config/services.yml
new file mode 100644
index 000000000..5c76fc598
--- /dev/null
+++ b/symfony-3.3-micro/app/config/services.yml
@@ -0,0 +1,9 @@
+# Learn more about services, parameters and containers at
+# http://symfony.com/doc/current/book/service_container.html
+parameters:
+#    parameter_name: value
+
+services:
+#    service_name:
+#        class: AppBundle\Directory\ClassName
+#        arguments: ["@another_service_name", "plain_value", "%parameter_name%"]
diff --git a/symfony-3.3-micro/bin/console b/symfony-3.3-micro/bin/console
new file mode 100755
index 000000000..49247c94d
--- /dev/null
+++ b/symfony-3.3-micro/bin/console
@@ -0,0 +1,29 @@
+#!/usr/bin/env php
+<?php
+
+use Symfony\Bundle\FrameworkBundle\Console\Application;
+use Symfony\Component\Console\Input\ArgvInput;
+use Symfony\Component\Debug\Debug;
+
+// if you don't want to setup permissions the proper way, just uncomment the following PHP line
+// read http://symfony.com/doc/current/book/installation.html#configuration-and-setup for more information
+//umask(0000);
+
+set_time_limit(0);
+
+/**
+ * @var Composer\Autoload\ClassLoader $loader
+ */
+$loader = require __DIR__.'/../app/autoload.php';
+
+$input = new ArgvInput();
+$env = $input->getParameterOption(['--env', '-e'], getenv('SYMFONY_ENV') ?: 'dev');
+$debug = getenv('SYMFONY_DEBUG') !== '0' && !$input->hasParameterOption(['--no-debug', '']) && $env !== 'prod';
+
+if ($debug) {
+    Debug::enable();
+}
+
+$kernel = new AppKernel($env, $debug);
+$application = new Application($kernel);
+$application->run($input);
diff --git a/symfony-3.3-micro/bin/symfony_requirements b/symfony-3.3-micro/bin/symfony_requirements
new file mode 100755
index 000000000..a7bf65a1b
--- /dev/null
+++ b/symfony-3.3-micro/bin/symfony_requirements
@@ -0,0 +1,146 @@
+#!/usr/bin/env php
+<?php
+
+require_once dirname(__FILE__).'/../var/SymfonyRequirements.php';
+
+$lineSize = 70;
+$symfonyRequirements = new SymfonyRequirements();
+$iniPath = $symfonyRequirements->getPhpIniConfigPath();
+
+echo_title('Symfony Requirements Checker');
+
+echo '> PHP is using the following php.ini file:'.PHP_EOL;
+if ($iniPath) {
+    echo_style('green', '  '.$iniPath);
+} else {
+    echo_style('yellow', '  WARNING: No configuration file (php.ini) used by PHP!');
+}
+
+echo PHP_EOL.PHP_EOL;
+
+echo '> Checking Symfony requirements:'.PHP_EOL.'  ';
+
+$messages = array();
+foreach ($symfonyRequirements->getRequirements() as $req) {
+    if ($helpText = get_error_message($req, $lineSize)) {
+        echo_style('red', 'E');
+        $messages['error'][] = $helpText;
+    } else {
+        echo_style('green', '.');
+    }
+}
+
+$checkPassed = empty($messages['error']);
+
+foreach ($symfonyRequirements->getRecommendations() as $req) {
+    if ($helpText = get_error_message($req, $lineSize)) {
+        echo_style('yellow', 'W');
+        $messages['warning'][] = $helpText;
+    } else {
+        echo_style('green', '.');
+    }
+}
+
+if ($checkPassed) {
+    echo_block('success', 'OK', 'Your system is ready to run Symfony projects');
+} else {
+    echo_block('error', 'ERROR', 'Your system is not ready to run Symfony projects');
+
+    echo_title('Fix the following mandatory requirements', 'red');
+
+    foreach ($messages['error'] as $helpText) {
+        echo ' * '.$helpText.PHP_EOL;
+    }
+}
+
+if (!empty($messages['warning'])) {
+    echo_title('Optional recommendations to improve your setup', 'yellow');
+
+    foreach ($messages['warning'] as $helpText) {
+        echo ' * '.$helpText.PHP_EOL;
+    }
+}
+
+echo PHP_EOL;
+echo_style('title', 'Note');
+echo '  The command console could use a different php.ini file'.PHP_EOL;
+echo_style('title', '~~~~');
+echo '  than the one used with your web server. To be on the'.PHP_EOL;
+echo '      safe side, please check the requirements from your web'.PHP_EOL;
+echo '      server using the ';
+echo_style('yellow', 'web/config.php');
+echo ' script.'.PHP_EOL;
+echo PHP_EOL;
+
+exit($checkPassed ? 0 : 1);
+
+function get_error_message(Requirement $requirement, $lineSize)
+{
+    if ($requirement->isFulfilled()) {
+        return;
+    }
+
+    $errorMessage = wordwrap($requirement->getTestMessage(), $lineSize - 3, PHP_EOL.'   ').PHP_EOL;
+    $errorMessage .= '   > '.wordwrap($requirement->getHelpText(), $lineSize - 5, PHP_EOL.'   > ').PHP_EOL;
+
+    return $errorMessage;
+}
+
+function echo_title($title, $style = null)
+{
+    $style = $style ?: 'title';
+
+    echo PHP_EOL;
+    echo_style($style, $title.PHP_EOL);
+    echo_style($style, str_repeat('~', strlen($title)).PHP_EOL);
+    echo PHP_EOL;
+}
+
+function echo_style($style, $message)
+{
+    // ANSI color codes
+    $styles = array(
+        'reset' => "\033[0m",
+        'red' => "\033[31m",
+        'green' => "\033[32m",
+        'yellow' => "\033[33m",
+        'error' => "\033[37;41m",
+        'success' => "\033[37;42m",
+        'title' => "\033[34m",
+    );
+    $supports = has_color_support();
+
+    echo($supports ? $styles[$style] : '').$message.($supports ? $styles['reset'] : '');
+}
+
+function echo_block($style, $title, $message)
+{
+    $message = ' '.trim($message).' ';
+    $width = strlen($message);
+
+    echo PHP_EOL.PHP_EOL;
+
+    echo_style($style, str_repeat(' ', $width));
+    echo PHP_EOL;
+    echo_style($style, str_pad(' ['.$title.']', $width, ' ', STR_PAD_RIGHT));
+    echo PHP_EOL;
+    echo_style($style, $message);
+    echo PHP_EOL;
+    echo_style($style, str_repeat(' ', $width));
+    echo PHP_EOL;
+}
+
+function has_color_support()
+{
+    static $support;
+
+    if (null === $support) {
+        if (DIRECTORY_SEPARATOR == '\\') {
+            $support = false !== getenv('ANSICON') || 'ON' === getenv('ConEmuANSI');
+        } else {
+            $support = function_exists('posix_isatty') && @posix_isatty(STDOUT);
+        }
+    }
+
+    return $support;
+}
diff --git a/symfony-3.3-micro/composer.json b/symfony-3.3-micro/composer.json
new file mode 100644
index 000000000..1e6cb190d
--- /dev/null
+++ b/symfony-3.3-micro/composer.json
@@ -0,0 +1,48 @@
+{
+    "name": "kenji/symfony-3.3-micro",
+    "license": "proprietary",
+    "type": "project",
+    "autoload": {
+        "psr-4": {
+            "": "src/"
+        },
+        "classmap": [
+            "app/AppKernel.php",
+            "app/AppCache.php"
+        ]
+    },
+    "require": {
+        "php": ">=5.5.9",
+        "sensio/distribution-bundle": "^5.0",
+        "symfony/framework-bundle": "3.3.*",
+        "symfony/monolog-bundle": "^2.8",
+        "symfony/yaml": "^3.3"
+    },
+    "scripts": {
+        "post-install-cmd": [
+            "Sensio\\Bundle\\DistributionBundle\\Composer\\ScriptHandler::buildBootstrap",
+            "Sensio\\Bundle\\DistributionBundle\\Composer\\ScriptHandler::clearCache"
+        ],
+        "post-update-cmd": [
+            "Sensio\\Bundle\\DistributionBundle\\Composer\\ScriptHandler::buildBootstrap",
+            "Sensio\\Bundle\\DistributionBundle\\Composer\\ScriptHandler::clearCache"
+        ]
+    },
+    "config": {
+        "platform": {
+            "php": "5.5.9"
+        },
+        "sort-packages": true
+    },
+    "extra": {
+        "symfony-app-dir": "app",
+        "symfony-bin-dir": "bin",
+        "symfony-var-dir": "var",
+        "symfony-web-dir": "web",
+        "symfony-tests-dir": "tests",
+        "symfony-assets-install": "relative",
+        "incenteev-parameters": {
+            "file": "app/config/parameters.yml"
+        }
+    }
+}
diff --git a/symfony-3.3-micro/composer.lock b/symfony-3.3-micro/composer.lock
new file mode 100644
index 000000000..0b3e91058
--- /dev/null
+++ b/symfony-3.3-micro/composer.lock
@@ -0,0 +1,1729 @@
+{
+    "_readme": [
+        "This file locks the dependencies of your project to a known state",
+        "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#composer-lock-the-lock-file",
+        "This file is @generated automatically"
+    ],
+    "content-hash": "33c03bcc493aefd4dc6f10c978c0f7d9",
+    "packages": [
+        {
+            "name": "composer/ca-bundle",
+            "version": "1.0.7",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/composer/ca-bundle.git",
+                "reference": "b17e6153cb7f33c7e44eb59578dc12eee5dc8e12"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/composer/ca-bundle/zipball/b17e6153cb7f33c7e44eb59578dc12eee5dc8e12",
+                "reference": "b17e6153cb7f33c7e44eb59578dc12eee5dc8e12",
+                "shasum": ""
+            },
+            "require": {
+                "ext-openssl": "*",
+                "ext-pcre": "*",
+                "php": "^5.3.2 || ^7.0"
+            },
+            "require-dev": {
+                "phpunit/phpunit": "^4.5",
+                "psr/log": "^1.0",
+                "symfony/process": "^2.5 || ^3.0"
+            },
+            "suggest": {
+                "symfony/process": "This is necessary to reliably check whether openssl_x509_parse is vulnerable on older php versions, but can be ignored on PHP 5.5.6+"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "1.x-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Composer\\CaBundle\\": "src"
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Jordi Boggiano",
+                    "email": "j.boggiano@seld.be",
+                    "homepage": "http://seld.be"
+                }
+            ],
+            "description": "Lets you find a path to the system CA bundle, and includes a fallback to the Mozilla CA bundle.",
+            "keywords": [
+                "cabundle",
+                "cacert",
+                "certificate",
+                "ssl",
+                "tls"
+            ],
+            "time": "2017-03-06T11:59:08+00:00"
+        },
+        {
+            "name": "doctrine/cache",
+            "version": "v1.6.2",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/doctrine/cache.git",
+                "reference": "eb152c5100571c7a45470ff2a35095ab3f3b900b"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/doctrine/cache/zipball/eb152c5100571c7a45470ff2a35095ab3f3b900b",
+                "reference": "eb152c5100571c7a45470ff2a35095ab3f3b900b",
+                "shasum": ""
+            },
+            "require": {
+                "php": "~5.5|~7.0"
+            },
+            "conflict": {
+                "doctrine/common": ">2.2,<2.4"
+            },
+            "require-dev": {
+                "phpunit/phpunit": "~4.8|~5.0",
+                "predis/predis": "~1.0",
+                "satooshi/php-coveralls": "~0.6"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "1.6.x-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Doctrine\\Common\\Cache\\": "lib/Doctrine/Common/Cache"
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Roman Borschel",
+                    "email": "roman@code-factory.org"
+                },
+                {
+                    "name": "Benjamin Eberlei",
+                    "email": "kontakt@beberlei.de"
+                },
+                {
+                    "name": "Guilherme Blanco",
+                    "email": "guilhermeblanco@gmail.com"
+                },
+                {
+                    "name": "Jonathan Wage",
+                    "email": "jonwage@gmail.com"
+                },
+                {
+                    "name": "Johannes Schmitt",
+                    "email": "schmittjoh@gmail.com"
+                }
+            ],
+            "description": "Caching library offering an object-oriented API for many cache backends",
+            "homepage": "http://www.doctrine-project.org",
+            "keywords": [
+                "cache",
+                "caching"
+            ],
+            "time": "2017-07-22T12:49:21+00:00"
+        },
+        {
+            "name": "monolog/monolog",
+            "version": "1.23.0",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/Seldaek/monolog.git",
+                "reference": "fd8c787753b3a2ad11bc60c063cff1358a32a3b4"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/Seldaek/monolog/zipball/fd8c787753b3a2ad11bc60c063cff1358a32a3b4",
+                "reference": "fd8c787753b3a2ad11bc60c063cff1358a32a3b4",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.3.0",
+                "psr/log": "~1.0"
+            },
+            "provide": {
+                "psr/log-implementation": "1.0.0"
+            },
+            "require-dev": {
+                "aws/aws-sdk-php": "^2.4.9 || ^3.0",
+                "doctrine/couchdb": "~1.0@dev",
+                "graylog2/gelf-php": "~1.0",
+                "jakub-onderka/php-parallel-lint": "0.9",
+                "php-amqplib/php-amqplib": "~2.4",
+                "php-console/php-console": "^3.1.3",
+                "phpunit/phpunit": "~4.5",
+                "phpunit/phpunit-mock-objects": "2.3.0",
+                "ruflin/elastica": ">=0.90 <3.0",
+                "sentry/sentry": "^0.13",
+                "swiftmailer/swiftmailer": "^5.3|^6.0"
+            },
+            "suggest": {
+                "aws/aws-sdk-php": "Allow sending log messages to AWS services like DynamoDB",
+                "doctrine/couchdb": "Allow sending log messages to a CouchDB server",
+                "ext-amqp": "Allow sending log messages to an AMQP server (1.0+ required)",
+                "ext-mongo": "Allow sending log messages to a MongoDB server",
+                "graylog2/gelf-php": "Allow sending log messages to a GrayLog2 server",
+                "mongodb/mongodb": "Allow sending log messages to a MongoDB server via PHP Driver",
+                "php-amqplib/php-amqplib": "Allow sending log messages to an AMQP server using php-amqplib",
+                "php-console/php-console": "Allow sending log messages to Google Chrome",
+                "rollbar/rollbar": "Allow sending log messages to Rollbar",
+                "ruflin/elastica": "Allow sending log messages to an Elastic Search server",
+                "sentry/sentry": "Allow sending log messages to a Sentry server"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "2.0.x-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Monolog\\": "src/Monolog"
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Jordi Boggiano",
+                    "email": "j.boggiano@seld.be",
+                    "homepage": "http://seld.be"
+                }
+            ],
+            "description": "Sends your logs to files, sockets, inboxes, databases and various web services",
+            "homepage": "http://github.com/Seldaek/monolog",
+            "keywords": [
+                "log",
+                "logging",
+                "psr-3"
+            ],
+            "time": "2017-06-19T01:22:40+00:00"
+        },
+        {
+            "name": "psr/cache",
+            "version": "1.0.1",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/php-fig/cache.git",
+                "reference": "d11b50ad223250cf17b86e38383413f5a6764bf8"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/php-fig/cache/zipball/d11b50ad223250cf17b86e38383413f5a6764bf8",
+                "reference": "d11b50ad223250cf17b86e38383413f5a6764bf8",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.3.0"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "1.0.x-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Psr\\Cache\\": "src/"
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "PHP-FIG",
+                    "homepage": "http://www.php-fig.org/"
+                }
+            ],
+            "description": "Common interface for caching libraries",
+            "keywords": [
+                "cache",
+                "psr",
+                "psr-6"
+            ],
+            "time": "2016-08-06T20:24:11+00:00"
+        },
+        {
+            "name": "psr/container",
+            "version": "1.0.0",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/php-fig/container.git",
+                "reference": "b7ce3b176482dbbc1245ebf52b181af44c2cf55f"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/php-fig/container/zipball/b7ce3b176482dbbc1245ebf52b181af44c2cf55f",
+                "reference": "b7ce3b176482dbbc1245ebf52b181af44c2cf55f",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.3.0"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "1.0.x-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Psr\\Container\\": "src/"
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "PHP-FIG",
+                    "homepage": "http://www.php-fig.org/"
+                }
+            ],
+            "description": "Common Container Interface (PHP FIG PSR-11)",
+            "homepage": "https://github.com/php-fig/container",
+            "keywords": [
+                "PSR-11",
+                "container",
+                "container-interface",
+                "container-interop",
+                "psr"
+            ],
+            "time": "2017-02-14T16:28:37+00:00"
+        },
+        {
+            "name": "psr/log",
+            "version": "1.0.2",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/php-fig/log.git",
+                "reference": "4ebe3a8bf773a19edfe0a84b6585ba3d401b724d"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/php-fig/log/zipball/4ebe3a8bf773a19edfe0a84b6585ba3d401b724d",
+                "reference": "4ebe3a8bf773a19edfe0a84b6585ba3d401b724d",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.3.0"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "1.0.x-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Psr\\Log\\": "Psr/Log/"
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "PHP-FIG",
+                    "homepage": "http://www.php-fig.org/"
+                }
+            ],
+            "description": "Common interface for logging libraries",
+            "homepage": "https://github.com/php-fig/log",
+            "keywords": [
+                "log",
+                "psr",
+                "psr-3"
+            ],
+            "time": "2016-10-10T12:19:37+00:00"
+        },
+        {
+            "name": "psr/simple-cache",
+            "version": "1.0.0",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/php-fig/simple-cache.git",
+                "reference": "753fa598e8f3b9966c886fe13f370baa45ef0e24"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/php-fig/simple-cache/zipball/753fa598e8f3b9966c886fe13f370baa45ef0e24",
+                "reference": "753fa598e8f3b9966c886fe13f370baa45ef0e24",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.3.0"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "1.0.x-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Psr\\SimpleCache\\": "src/"
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "PHP-FIG",
+                    "homepage": "http://www.php-fig.org/"
+                }
+            ],
+            "description": "Common interfaces for simple caching",
+            "keywords": [
+                "cache",
+                "caching",
+                "psr",
+                "psr-16",
+                "simple-cache"
+            ],
+            "time": "2017-01-02T13:31:39+00:00"
+        },
+        {
+            "name": "sensio/distribution-bundle",
+            "version": "v5.0.20",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/sensiolabs/SensioDistributionBundle.git",
+                "reference": "4b019d4c0bd64438c42e4b6b0726085b409be8d9"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/sensiolabs/SensioDistributionBundle/zipball/4b019d4c0bd64438c42e4b6b0726085b409be8d9",
+                "reference": "4b019d4c0bd64438c42e4b6b0726085b409be8d9",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.3.9",
+                "sensiolabs/security-checker": "~3.0|~4.0",
+                "symfony/class-loader": "~2.3|~3.0",
+                "symfony/config": "~2.3|~3.0",
+                "symfony/dependency-injection": "~2.3|~3.0",
+                "symfony/filesystem": "~2.3|~3.0",
+                "symfony/http-kernel": "~2.3|~3.0",
+                "symfony/process": "~2.3|~3.0"
+            },
+            "type": "symfony-bundle",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "5.0.x-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Sensio\\Bundle\\DistributionBundle\\": ""
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Fabien Potencier",
+                    "email": "fabien@symfony.com"
+                }
+            ],
+            "description": "Base bundle for Symfony Distributions",
+            "keywords": [
+                "configuration",
+                "distribution"
+            ],
+            "time": "2017-05-11T16:21:03+00:00"
+        },
+        {
+            "name": "sensiolabs/security-checker",
+            "version": "v4.0.5",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/sensiolabs/security-checker.git",
+                "reference": "6a3b0c3b42e41c777b1ad75032d8177863fdc5e1"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/sensiolabs/security-checker/zipball/6a3b0c3b42e41c777b1ad75032d8177863fdc5e1",
+                "reference": "6a3b0c3b42e41c777b1ad75032d8177863fdc5e1",
+                "shasum": ""
+            },
+            "require": {
+                "composer/ca-bundle": "^1.0",
+                "symfony/console": "~2.7|~3.0"
+            },
+            "bin": [
+                "security-checker"
+            ],
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "4.0-dev"
+                }
+            },
+            "autoload": {
+                "psr-0": {
+                    "SensioLabs\\Security": ""
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Fabien Potencier",
+                    "email": "fabien.potencier@gmail.com"
+                }
+            ],
+            "description": "A security checker for your composer.lock",
+            "time": "2017-07-24T11:42:56+00:00"
+        },
+        {
+            "name": "symfony/cache",
+            "version": "v3.3.5",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/cache.git",
+                "reference": "265987c7f524b9ad17d0a0b8819ac53ce1bb8054"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/cache/zipball/265987c7f524b9ad17d0a0b8819ac53ce1bb8054",
+                "reference": "265987c7f524b9ad17d0a0b8819ac53ce1bb8054",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.5.9",
+                "psr/cache": "~1.0",
+                "psr/log": "~1.0",
+                "psr/simple-cache": "^1.0"
+            },
+            "conflict": {
+                "symfony/var-dumper": "<3.3"
+            },
+            "provide": {
+                "psr/cache-implementation": "1.0",
+                "psr/simple-cache-implementation": "1.0"
+            },
+            "require-dev": {
+                "cache/integration-tests": "dev-master",
+                "doctrine/cache": "~1.6",
+                "doctrine/dbal": "~2.4",
+                "predis/predis": "~1.0"
+            },
+            "suggest": {
+                "symfony/polyfill-apcu": "For using ApcuAdapter on HHVM"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "3.3-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Component\\Cache\\": ""
+                },
+                "exclude-from-classmap": [
+                    "/Tests/"
+                ]
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Nicolas Grekas",
+                    "email": "p@tchwork.com"
+                },
+                {
+                    "name": "Symfony Community",
+                    "homepage": "https://symfony.com/contributors"
+                }
+            ],
+            "description": "Symfony Cache component with PSR-6, PSR-16, and tags",
+            "homepage": "https://symfony.com",
+            "keywords": [
+                "caching",
+                "psr6"
+            ],
+            "time": "2017-07-17T17:27:31+00:00"
+        },
+        {
+            "name": "symfony/class-loader",
+            "version": "v3.3.5",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/class-loader.git",
+                "reference": "386a294d621576302e7cc36965d6ed53b8c73c4f"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/class-loader/zipball/386a294d621576302e7cc36965d6ed53b8c73c4f",
+                "reference": "386a294d621576302e7cc36965d6ed53b8c73c4f",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.5.9"
+            },
+            "require-dev": {
+                "symfony/finder": "~2.8|~3.0",
+                "symfony/polyfill-apcu": "~1.1"
+            },
+            "suggest": {
+                "symfony/polyfill-apcu": "For using ApcClassLoader on HHVM"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "3.3-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Component\\ClassLoader\\": ""
+                },
+                "exclude-from-classmap": [
+                    "/Tests/"
+                ]
+            },
+            "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 ClassLoader Component",
+            "homepage": "https://symfony.com",
+            "time": "2017-06-02T09:51:43+00:00"
+        },
+        {
+            "name": "symfony/config",
+            "version": "v3.3.5",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/config.git",
+                "reference": "a094618deb9a3fe1c3cf500a796e167d0495a274"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/config/zipball/a094618deb9a3fe1c3cf500a796e167d0495a274",
+                "reference": "a094618deb9a3fe1c3cf500a796e167d0495a274",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.5.9",
+                "symfony/filesystem": "~2.8|~3.0"
+            },
+            "conflict": {
+                "symfony/dependency-injection": "<3.3",
+                "symfony/finder": "<3.3"
+            },
+            "require-dev": {
+                "symfony/dependency-injection": "~3.3",
+                "symfony/finder": "~3.3",
+                "symfony/yaml": "~3.0"
+            },
+            "suggest": {
+                "symfony/yaml": "To use the yaml reference dumper"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "3.3-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Component\\Config\\": ""
+                },
+                "exclude-from-classmap": [
+                    "/Tests/"
+                ]
+            },
+            "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 Config Component",
+            "homepage": "https://symfony.com",
+            "time": "2017-06-16T12:40:34+00:00"
+        },
+        {
+            "name": "symfony/console",
+            "version": "v3.3.5",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/console.git",
+                "reference": "a97e45d98c59510f085fa05225a1acb74dfe0546"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/console/zipball/a97e45d98c59510f085fa05225a1acb74dfe0546",
+                "reference": "a97e45d98c59510f085fa05225a1acb74dfe0546",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.5.9",
+                "symfony/debug": "~2.8|~3.0",
+                "symfony/polyfill-mbstring": "~1.0"
+            },
+            "conflict": {
+                "symfony/dependency-injection": "<3.3"
+            },
+            "require-dev": {
+                "psr/log": "~1.0",
+                "symfony/config": "~3.3",
+                "symfony/dependency-injection": "~3.3",
+                "symfony/event-dispatcher": "~2.8|~3.0",
+                "symfony/filesystem": "~2.8|~3.0",
+                "symfony/http-kernel": "~2.8|~3.0",
+                "symfony/process": "~2.8|~3.0"
+            },
+            "suggest": {
+                "psr/log": "For using the console logger",
+                "symfony/event-dispatcher": "",
+                "symfony/filesystem": "",
+                "symfony/process": ""
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "3.3-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Component\\Console\\": ""
+                },
+                "exclude-from-classmap": [
+                    "/Tests/"
+                ]
+            },
+            "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 Console Component",
+            "homepage": "https://symfony.com",
+            "time": "2017-07-03T13:19:36+00:00"
+        },
+        {
+            "name": "symfony/debug",
+            "version": "v3.3.5",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/debug.git",
+                "reference": "63b85a968486d95ff9542228dc2e4247f16f9743"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/debug/zipball/63b85a968486d95ff9542228dc2e4247f16f9743",
+                "reference": "63b85a968486d95ff9542228dc2e4247f16f9743",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.5.9",
+                "psr/log": "~1.0"
+            },
+            "conflict": {
+                "symfony/http-kernel": ">=2.3,<2.3.24|~2.4.0|>=2.5,<2.5.9|>=2.6,<2.6.2"
+            },
+            "require-dev": {
+                "symfony/http-kernel": "~2.8|~3.0"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "3.3-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Component\\Debug\\": ""
+                },
+                "exclude-from-classmap": [
+                    "/Tests/"
+                ]
+            },
+            "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 Debug Component",
+            "homepage": "https://symfony.com",
+            "time": "2017-07-05T13:02:37+00:00"
+        },
+        {
+            "name": "symfony/dependency-injection",
+            "version": "v3.3.5",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/dependency-injection.git",
+                "reference": "761e51a86f35f5b3e213e9b7f554fd91f9bffae4"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/dependency-injection/zipball/761e51a86f35f5b3e213e9b7f554fd91f9bffae4",
+                "reference": "761e51a86f35f5b3e213e9b7f554fd91f9bffae4",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.5.9",
+                "psr/container": "^1.0"
+            },
+            "conflict": {
+                "symfony/config": "<3.3.1",
+                "symfony/finder": "<3.3",
+                "symfony/yaml": "<3.3"
+            },
+            "provide": {
+                "psr/container-implementation": "1.0"
+            },
+            "require-dev": {
+                "symfony/config": "~3.3",
+                "symfony/expression-language": "~2.8|~3.0",
+                "symfony/yaml": "~3.3"
+            },
+            "suggest": {
+                "symfony/config": "",
+                "symfony/expression-language": "For using expressions in service container configuration",
+                "symfony/finder": "For using double-star glob patterns or when GLOB_BRACE portability is required",
+                "symfony/proxy-manager-bridge": "Generate service proxies to lazy load them",
+                "symfony/yaml": ""
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "3.3-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Component\\DependencyInjection\\": ""
+                },
+                "exclude-from-classmap": [
+                    "/Tests/"
+                ]
+            },
+            "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": "2017-07-17T14:07:10+00:00"
+        },
+        {
+            "name": "symfony/event-dispatcher",
+            "version": "v3.3.5",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/event-dispatcher.git",
+                "reference": "67535f1e3fd662bdc68d7ba317c93eecd973617e"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/event-dispatcher/zipball/67535f1e3fd662bdc68d7ba317c93eecd973617e",
+                "reference": "67535f1e3fd662bdc68d7ba317c93eecd973617e",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.5.9"
+            },
+            "conflict": {
+                "symfony/dependency-injection": "<3.3"
+            },
+            "require-dev": {
+                "psr/log": "~1.0",
+                "symfony/config": "~2.8|~3.0",
+                "symfony/dependency-injection": "~3.3",
+                "symfony/expression-language": "~2.8|~3.0",
+                "symfony/stopwatch": "~2.8|~3.0"
+            },
+            "suggest": {
+                "symfony/dependency-injection": "",
+                "symfony/http-kernel": ""
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "3.3-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Component\\EventDispatcher\\": ""
+                },
+                "exclude-from-classmap": [
+                    "/Tests/"
+                ]
+            },
+            "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 EventDispatcher Component",
+            "homepage": "https://symfony.com",
+            "time": "2017-06-09T14:53:08+00:00"
+        },
+        {
+            "name": "symfony/filesystem",
+            "version": "v3.3.5",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/filesystem.git",
+                "reference": "427987eb4eed764c3b6e38d52a0f87989e010676"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/filesystem/zipball/427987eb4eed764c3b6e38d52a0f87989e010676",
+                "reference": "427987eb4eed764c3b6e38d52a0f87989e010676",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.5.9"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "3.3-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Component\\Filesystem\\": ""
+                },
+                "exclude-from-classmap": [
+                    "/Tests/"
+                ]
+            },
+            "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 Filesystem Component",
+            "homepage": "https://symfony.com",
+            "time": "2017-07-11T07:17:58+00:00"
+        },
+        {
+            "name": "symfony/finder",
+            "version": "v3.3.5",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/finder.git",
+                "reference": "baea7f66d30854ad32988c11a09d7ffd485810c4"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/finder/zipball/baea7f66d30854ad32988c11a09d7ffd485810c4",
+                "reference": "baea7f66d30854ad32988c11a09d7ffd485810c4",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.5.9"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "3.3-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Component\\Finder\\": ""
+                },
+                "exclude-from-classmap": [
+                    "/Tests/"
+                ]
+            },
+            "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 Finder Component",
+            "homepage": "https://symfony.com",
+            "time": "2017-06-01T21:01:25+00:00"
+        },
+        {
+            "name": "symfony/framework-bundle",
+            "version": "v3.3.5",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/framework-bundle.git",
+                "reference": "678bc1b17ae351ba98a492f31d57c0011281334a"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/framework-bundle/zipball/678bc1b17ae351ba98a492f31d57c0011281334a",
+                "reference": "678bc1b17ae351ba98a492f31d57c0011281334a",
+                "shasum": ""
+            },
+            "require": {
+                "doctrine/cache": "~1.0",
+                "ext-xml": "*",
+                "php": ">=5.5.9",
+                "symfony/cache": "~3.3",
+                "symfony/class-loader": "~3.2",
+                "symfony/config": "~3.3",
+                "symfony/dependency-injection": "~3.3",
+                "symfony/event-dispatcher": "^3.3.1",
+                "symfony/filesystem": "~2.8|~3.0",
+                "symfony/finder": "~2.8|~3.0",
+                "symfony/http-foundation": "~3.3",
+                "symfony/http-kernel": "~3.3",
+                "symfony/polyfill-mbstring": "~1.0",
+                "symfony/routing": "~3.3",
+                "symfony/stopwatch": "~2.8|~3.0"
+            },
+            "conflict": {
+                "phpdocumentor/reflection-docblock": "<3.0",
+                "phpdocumentor/type-resolver": "<0.2.0",
+                "phpunit/phpunit": "<4.8.35|<5.4.3,>=5.0",
+                "symfony/asset": "<3.3",
+                "symfony/console": "<3.3",
+                "symfony/form": "<3.3",
+                "symfony/property-info": "<3.3",
+                "symfony/serializer": "<3.3",
+                "symfony/translation": "<3.2",
+                "symfony/validator": "<3.3",
+                "symfony/workflow": "<3.3"
+            },
+            "require-dev": {
+                "doctrine/annotations": "~1.0",
+                "fig/link-util": "^1.0",
+                "phpdocumentor/reflection-docblock": "^3.0",
+                "sensio/framework-extra-bundle": "^3.0.2",
+                "symfony/asset": "~3.3",
+                "symfony/browser-kit": "~2.8|~3.0",
+                "symfony/console": "~3.3",
+                "symfony/css-selector": "~2.8|~3.0",
+                "symfony/dom-crawler": "~2.8|~3.0",
+                "symfony/expression-language": "~2.8|~3.0",
+                "symfony/form": "~3.3",
+                "symfony/polyfill-intl-icu": "~1.0",
+                "symfony/process": "~2.8|~3.0",
+                "symfony/property-info": "~3.3",
+                "symfony/security": "~2.8|~3.0",
+                "symfony/security-core": "~3.2",
+                "symfony/security-csrf": "~2.8|~3.0",
+                "symfony/serializer": "~3.3",
+                "symfony/templating": "~2.8|~3.0",
+                "symfony/translation": "~3.2",
+                "symfony/validator": "~3.3",
+                "symfony/web-link": "~3.3",
+                "symfony/workflow": "~3.3",
+                "symfony/yaml": "~3.2",
+                "twig/twig": "~1.34|~2.4"
+            },
+            "suggest": {
+                "ext-apcu": "For best performance of the system caches",
+                "symfony/console": "For using the console commands",
+                "symfony/form": "For using forms",
+                "symfony/property-info": "For using the property_info service",
+                "symfony/serializer": "For using the serializer service",
+                "symfony/validator": "For using validation",
+                "symfony/web-link": "For using web links, features such as preloading, prefetching or prerendering",
+                "symfony/yaml": "For using the debug:config and lint:yaml commands"
+            },
+            "type": "symfony-bundle",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "3.3-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Bundle\\FrameworkBundle\\": ""
+                },
+                "exclude-from-classmap": [
+                    "/Tests/"
+                ]
+            },
+            "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 FrameworkBundle",
+            "homepage": "https://symfony.com",
+            "time": "2017-07-17T11:48:40+00:00"
+        },
+        {
+            "name": "symfony/http-foundation",
+            "version": "v3.3.5",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/http-foundation.git",
+                "reference": "e307abe4b79ccbbfdced9b91c132fd128f456bc5"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/http-foundation/zipball/e307abe4b79ccbbfdced9b91c132fd128f456bc5",
+                "reference": "e307abe4b79ccbbfdced9b91c132fd128f456bc5",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.5.9",
+                "symfony/polyfill-mbstring": "~1.1"
+            },
+            "require-dev": {
+                "symfony/expression-language": "~2.8|~3.0"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "3.3-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Component\\HttpFoundation\\": ""
+                },
+                "exclude-from-classmap": [
+                    "/Tests/"
+                ]
+            },
+            "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 HttpFoundation Component",
+            "homepage": "https://symfony.com",
+            "time": "2017-07-17T14:07:10+00:00"
+        },
+        {
+            "name": "symfony/http-kernel",
+            "version": "v3.3.5",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/http-kernel.git",
+                "reference": "16ceea64d23abddf58797a782ae96a5242282cd8"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/http-kernel/zipball/16ceea64d23abddf58797a782ae96a5242282cd8",
+                "reference": "16ceea64d23abddf58797a782ae96a5242282cd8",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.5.9",
+                "psr/log": "~1.0",
+                "symfony/debug": "~2.8|~3.0",
+                "symfony/event-dispatcher": "~2.8|~3.0",
+                "symfony/http-foundation": "~3.3"
+            },
+            "conflict": {
+                "symfony/config": "<2.8",
+                "symfony/dependency-injection": "<3.3",
+                "symfony/var-dumper": "<3.3",
+                "twig/twig": "<1.34|<2.4,>=2"
+            },
+            "require-dev": {
+                "psr/cache": "~1.0",
+                "symfony/browser-kit": "~2.8|~3.0",
+                "symfony/class-loader": "~2.8|~3.0",
+                "symfony/config": "~2.8|~3.0",
+                "symfony/console": "~2.8|~3.0",
+                "symfony/css-selector": "~2.8|~3.0",
+                "symfony/dependency-injection": "~3.3",
+                "symfony/dom-crawler": "~2.8|~3.0",
+                "symfony/expression-language": "~2.8|~3.0",
+                "symfony/finder": "~2.8|~3.0",
+                "symfony/process": "~2.8|~3.0",
+                "symfony/routing": "~2.8|~3.0",
+                "symfony/stopwatch": "~2.8|~3.0",
+                "symfony/templating": "~2.8|~3.0",
+                "symfony/translation": "~2.8|~3.0",
+                "symfony/var-dumper": "~3.3"
+            },
+            "suggest": {
+                "symfony/browser-kit": "",
+                "symfony/class-loader": "",
+                "symfony/config": "",
+                "symfony/console": "",
+                "symfony/dependency-injection": "",
+                "symfony/finder": "",
+                "symfony/var-dumper": ""
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "3.3-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Component\\HttpKernel\\": ""
+                },
+                "exclude-from-classmap": [
+                    "/Tests/"
+                ]
+            },
+            "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 HttpKernel Component",
+            "homepage": "https://symfony.com",
+            "time": "2017-07-17T19:08:23+00:00"
+        },
+        {
+            "name": "symfony/monolog-bridge",
+            "version": "v3.3.5",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/monolog-bridge.git",
+                "reference": "b2e5cf7959432161c2816a20508f384200c995a3"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/monolog-bridge/zipball/b2e5cf7959432161c2816a20508f384200c995a3",
+                "reference": "b2e5cf7959432161c2816a20508f384200c995a3",
+                "shasum": ""
+            },
+            "require": {
+                "monolog/monolog": "~1.19",
+                "php": ">=5.5.9",
+                "symfony/http-kernel": "~2.8|~3.0"
+            },
+            "conflict": {
+                "symfony/http-foundation": "<3.3"
+            },
+            "require-dev": {
+                "symfony/console": "~2.8|~3.0",
+                "symfony/event-dispatcher": "~2.8|~3.0",
+                "symfony/var-dumper": "~3.3"
+            },
+            "suggest": {
+                "symfony/console": "For the possibility to show log messages in console commands depending on verbosity settings. You need version ~2.3 of the console for it.",
+                "symfony/event-dispatcher": "Needed when using log messages in console commands.",
+                "symfony/http-kernel": "For using the debugging handlers together with the response life cycle of the HTTP kernel."
+            },
+            "type": "symfony-bridge",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "3.3-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Bridge\\Monolog\\": ""
+                },
+                "exclude-from-classmap": [
+                    "/Tests/"
+                ]
+            },
+            "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 Monolog Bridge",
+            "homepage": "https://symfony.com",
+            "time": "2017-06-06T15:10:52+00:00"
+        },
+        {
+            "name": "symfony/monolog-bundle",
+            "version": "v2.12.1",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/monolog-bundle.git",
+                "reference": "b0146bdca7ba2a65f3bbe7010423c7393b29ec3f"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/monolog-bundle/zipball/b0146bdca7ba2a65f3bbe7010423c7393b29ec3f",
+                "reference": "b0146bdca7ba2a65f3bbe7010423c7393b29ec3f",
+                "shasum": ""
+            },
+            "require": {
+                "monolog/monolog": "~1.18",
+                "php": ">=5.3.2",
+                "symfony/config": "~2.3|~3.0",
+                "symfony/dependency-injection": "~2.3|~3.0",
+                "symfony/http-kernel": "~2.3|~3.0",
+                "symfony/monolog-bridge": "~2.3|~3.0"
+            },
+            "require-dev": {
+                "phpunit/phpunit": "^4.8",
+                "symfony/console": "~2.3|~3.0",
+                "symfony/yaml": "~2.3|~3.0"
+            },
+            "type": "symfony-bundle",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "2.x-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Bundle\\MonologBundle\\": ""
+                }
+            },
+            "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 MonologBundle",
+            "homepage": "http://symfony.com",
+            "keywords": [
+                "log",
+                "logging"
+            ],
+            "time": "2017-01-02T19:04:26+00:00"
+        },
+        {
+            "name": "symfony/polyfill-mbstring",
+            "version": "v1.4.0",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/polyfill-mbstring.git",
+                "reference": "f29dca382a6485c3cbe6379f0c61230167681937"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/polyfill-mbstring/zipball/f29dca382a6485c3cbe6379f0c61230167681937",
+                "reference": "f29dca382a6485c3cbe6379f0c61230167681937",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.3.3"
+            },
+            "suggest": {
+                "ext-mbstring": "For best performance"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "1.4-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Polyfill\\Mbstring\\": ""
+                },
+                "files": [
+                    "bootstrap.php"
+                ]
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Nicolas Grekas",
+                    "email": "p@tchwork.com"
+                },
+                {
+                    "name": "Symfony Community",
+                    "homepage": "https://symfony.com/contributors"
+                }
+            ],
+            "description": "Symfony polyfill for the Mbstring extension",
+            "homepage": "https://symfony.com",
+            "keywords": [
+                "compatibility",
+                "mbstring",
+                "polyfill",
+                "portable",
+                "shim"
+            ],
+            "time": "2017-06-09T14:24:12+00:00"
+        },
+        {
+            "name": "symfony/process",
+            "version": "v3.3.5",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/process.git",
+                "reference": "07432804942b9f6dd7b7377faf9920af5f95d70a"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/process/zipball/07432804942b9f6dd7b7377faf9920af5f95d70a",
+                "reference": "07432804942b9f6dd7b7377faf9920af5f95d70a",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.5.9"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "3.3-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Component\\Process\\": ""
+                },
+                "exclude-from-classmap": [
+                    "/Tests/"
+                ]
+            },
+            "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 Process Component",
+            "homepage": "https://symfony.com",
+            "time": "2017-07-13T13:05:09+00:00"
+        },
+        {
+            "name": "symfony/routing",
+            "version": "v3.3.5",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/routing.git",
+                "reference": "dc70bbd0ca7b19259f63cdacc8af370bc32a4728"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/routing/zipball/dc70bbd0ca7b19259f63cdacc8af370bc32a4728",
+                "reference": "dc70bbd0ca7b19259f63cdacc8af370bc32a4728",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.5.9"
+            },
+            "conflict": {
+                "symfony/config": "<2.8",
+                "symfony/dependency-injection": "<3.3",
+                "symfony/yaml": "<3.3"
+            },
+            "require-dev": {
+                "doctrine/annotations": "~1.0",
+                "doctrine/common": "~2.2",
+                "psr/log": "~1.0",
+                "symfony/config": "~2.8|~3.0",
+                "symfony/dependency-injection": "~3.3",
+                "symfony/expression-language": "~2.8|~3.0",
+                "symfony/http-foundation": "~2.8|~3.0",
+                "symfony/yaml": "~3.3"
+            },
+            "suggest": {
+                "doctrine/annotations": "For using the annotation loader",
+                "symfony/config": "For using the all-in-one router or any loader",
+                "symfony/dependency-injection": "For loading routes from a service",
+                "symfony/expression-language": "For using expression matching",
+                "symfony/http-foundation": "For using a Symfony Request object",
+                "symfony/yaml": "For using the YAML loader"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "3.3-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Component\\Routing\\": ""
+                },
+                "exclude-from-classmap": [
+                    "/Tests/"
+                ]
+            },
+            "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 Routing Component",
+            "homepage": "https://symfony.com",
+            "keywords": [
+                "router",
+                "routing",
+                "uri",
+                "url"
+            ],
+            "time": "2017-06-24T09:29:48+00:00"
+        },
+        {
+            "name": "symfony/stopwatch",
+            "version": "v3.3.5",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/stopwatch.git",
+                "reference": "602a15299dc01556013b07167d4f5d3a60e90d15"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/stopwatch/zipball/602a15299dc01556013b07167d4f5d3a60e90d15",
+                "reference": "602a15299dc01556013b07167d4f5d3a60e90d15",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.5.9"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "3.3-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Component\\Stopwatch\\": ""
+                },
+                "exclude-from-classmap": [
+                    "/Tests/"
+                ]
+            },
+            "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 Stopwatch Component",
+            "homepage": "https://symfony.com",
+            "time": "2017-04-12T14:14:56+00:00"
+        },
+        {
+            "name": "symfony/yaml",
+            "version": "v3.3.5",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/yaml.git",
+                "reference": "1f93a8d19b8241617f5074a123e282575b821df8"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/yaml/zipball/1f93a8d19b8241617f5074a123e282575b821df8",
+                "reference": "1f93a8d19b8241617f5074a123e282575b821df8",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.5.9"
+            },
+            "require-dev": {
+                "symfony/console": "~2.8|~3.0"
+            },
+            "suggest": {
+                "symfony/console": "For validating YAML files using the lint command"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "3.3-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Component\\Yaml\\": ""
+                },
+                "exclude-from-classmap": [
+                    "/Tests/"
+                ]
+            },
+            "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 Yaml Component",
+            "homepage": "https://symfony.com",
+            "time": "2017-06-15T12:58:50+00:00"
+        }
+    ],
+    "packages-dev": [],
+    "aliases": [],
+    "minimum-stability": "stable",
+    "stability-flags": [],
+    "prefer-stable": false,
+    "prefer-lowest": false,
+    "platform": {
+        "php": ">=5.5.9"
+    },
+    "platform-dev": [],
+    "platform-overrides": {
+        "php": "5.5.9"
+    }
+}
diff --git a/symfony-3.3-micro/phpunit.xml.dist b/symfony-3.3-micro/phpunit.xml.dist
new file mode 100644
index 000000000..b115bb395
--- /dev/null
+++ b/symfony-3.3-micro/phpunit.xml.dist
@@ -0,0 +1,31 @@
+<?xml version="1.0" encoding="UTF-8"?>
+
+<!-- http://phpunit.de/manual/4.1/en/appendixes.configuration.html -->
+<phpunit xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
+         xsi:noNamespaceSchemaLocation="http://schema.phpunit.de/4.1/phpunit.xsd"
+         backupGlobals="false"
+         colors="true"
+         bootstrap="app/autoload.php"
+>
+    <php>
+        <ini name="error_reporting" value="-1" />
+        <server name="KERNEL_DIR" value="app/" />
+    </php>
+
+    <testsuites>
+        <testsuite name="Project Test Suite">
+            <directory>tests</directory>
+        </testsuite>
+    </testsuites>
+
+    <filter>
+        <whitelist>
+            <directory>src</directory>
+            <exclude>
+                <directory>src/*Bundle/Resources</directory>
+                <directory>src/*/*Bundle/Resources</directory>
+                <directory>src/*/Bundle/*Bundle/Resources</directory>
+            </exclude>
+        </whitelist>
+    </filter>
+</phpunit>
diff --git a/symfony-3.3-micro/src/App/Controller/HelloController.php b/symfony-3.3-micro/src/App/Controller/HelloController.php
new file mode 100644
index 000000000..e127625af
--- /dev/null
+++ b/symfony-3.3-micro/src/App/Controller/HelloController.php
@@ -0,0 +1,17 @@
+<?php
+
+namespace App\Controller;
+
+use Symfony\Bundle\FrameworkBundle\Controller\Controller;
+use Symfony\Component\HttpFoundation\Response;
+
+class HelloController extends Controller
+{
+    /**
+     * @return Response
+     */
+    public function indexAction()
+    {
+        return new Response('Hello World!');
+    }
+}
diff --git a/symfony-3.3-micro/var/SymfonyRequirements.php b/symfony-3.3-micro/var/SymfonyRequirements.php
new file mode 100755
index 000000000..3b14a4022
--- /dev/null
+++ b/symfony-3.3-micro/var/SymfonyRequirements.php
@@ -0,0 +1,817 @@
+<?php
+
+/*
+ * This file is part of the Symfony package.
+ *
+ * (c) Fabien Potencier <fabien@symfony.com>
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+/*
+ * Users of PHP 5.2 should be able to run the requirements checks.
+ * This is why the file and all classes must be compatible with PHP 5.2+
+ * (e.g. not using namespaces and closures).
+ *
+ * ************** CAUTION **************
+ *
+ * DO NOT EDIT THIS FILE as it will be overridden by Composer as part of
+ * the installation/update process. The original file resides in the
+ * SensioDistributionBundle.
+ *
+ * ************** CAUTION **************
+ */
+
+/**
+ * Represents a single PHP requirement, e.g. an installed extension.
+ * It can be a mandatory requirement or an optional recommendation.
+ * There is a special subclass, named PhpIniRequirement, to check a php.ini configuration.
+ *
+ * @author Tobias Schultze <http://tobion.de>
+ */
+class Requirement
+{
+    private $fulfilled;
+    private $testMessage;
+    private $helpText;
+    private $helpHtml;
+    private $optional;
+
+    /**
+     * Constructor that initializes the requirement.
+     *
+     * @param bool        $fulfilled   Whether the requirement is fulfilled
+     * @param string      $testMessage The message for testing the requirement
+     * @param string      $helpHtml    The help text formatted in HTML for resolving the problem
+     * @param string|null $helpText    The help text (when null, it will be inferred from $helpHtml, i.e. stripped from HTML tags)
+     * @param bool        $optional    Whether this is only an optional recommendation not a mandatory requirement
+     */
+    public function __construct($fulfilled, $testMessage, $helpHtml, $helpText = null, $optional = false)
+    {
+        $this->fulfilled = (bool) $fulfilled;
+        $this->testMessage = (string) $testMessage;
+        $this->helpHtml = (string) $helpHtml;
+        $this->helpText = null === $helpText ? strip_tags($this->helpHtml) : (string) $helpText;
+        $this->optional = (bool) $optional;
+    }
+
+    /**
+     * Returns whether the requirement is fulfilled.
+     *
+     * @return bool true if fulfilled, otherwise false
+     */
+    public function isFulfilled()
+    {
+        return $this->fulfilled;
+    }
+
+    /**
+     * Returns the message for testing the requirement.
+     *
+     * @return string The test message
+     */
+    public function getTestMessage()
+    {
+        return $this->testMessage;
+    }
+
+    /**
+     * Returns the help text for resolving the problem.
+     *
+     * @return string The help text
+     */
+    public function getHelpText()
+    {
+        return $this->helpText;
+    }
+
+    /**
+     * Returns the help text formatted in HTML.
+     *
+     * @return string The HTML help
+     */
+    public function getHelpHtml()
+    {
+        return $this->helpHtml;
+    }
+
+    /**
+     * Returns whether this is only an optional recommendation and not a mandatory requirement.
+     *
+     * @return bool true if optional, false if mandatory
+     */
+    public function isOptional()
+    {
+        return $this->optional;
+    }
+}
+
+/**
+ * Represents a PHP requirement in form of a php.ini configuration.
+ *
+ * @author Tobias Schultze <http://tobion.de>
+ */
+class PhpIniRequirement extends Requirement
+{
+    /**
+     * Constructor that initializes the requirement.
+     *
+     * @param string        $cfgName           The configuration name used for ini_get()
+     * @param bool|callback $evaluation        Either a boolean indicating whether the configuration should evaluate to true or false,
+     *                                         or a callback function receiving the configuration value as parameter to determine the fulfillment of the requirement
+     * @param bool          $approveCfgAbsence If true the Requirement will be fulfilled even if the configuration option does not exist, i.e. ini_get() returns false.
+     *                                         This is helpful for abandoned configs in later PHP versions or configs of an optional extension, like Suhosin.
+     *                                         Example: You require a config to be true but PHP later removes this config and defaults it to true internally.
+     * @param string|null   $testMessage       The message for testing the requirement (when null and $evaluation is a boolean a default message is derived)
+     * @param string|null   $helpHtml          The help text formatted in HTML for resolving the problem (when null and $evaluation is a boolean a default help is derived)
+     * @param string|null   $helpText          The help text (when null, it will be inferred from $helpHtml, i.e. stripped from HTML tags)
+     * @param bool          $optional          Whether this is only an optional recommendation not a mandatory requirement
+     */
+    public function __construct($cfgName, $evaluation, $approveCfgAbsence = false, $testMessage = null, $helpHtml = null, $helpText = null, $optional = false)
+    {
+        $cfgValue = ini_get($cfgName);
+
+        if (is_callable($evaluation)) {
+            if (null === $testMessage || null === $helpHtml) {
+                throw new InvalidArgumentException('You must provide the parameters testMessage and helpHtml for a callback evaluation.');
+            }
+
+            $fulfilled = call_user_func($evaluation, $cfgValue);
+        } else {
+            if (null === $testMessage) {
+                $testMessage = sprintf('%s %s be %s in php.ini',
+                    $cfgName,
+                    $optional ? 'should' : 'must',
+                    $evaluation ? 'enabled' : 'disabled'
+                );
+            }
+
+            if (null === $helpHtml) {
+                $helpHtml = sprintf('Set <strong>%s</strong> to <strong>%s</strong> in php.ini<a href="#phpini">*</a>.',
+                    $cfgName,
+                    $evaluation ? 'on' : 'off'
+                );
+            }
+
+            $fulfilled = $evaluation == $cfgValue;
+        }
+
+        parent::__construct($fulfilled || ($approveCfgAbsence && false === $cfgValue), $testMessage, $helpHtml, $helpText, $optional);
+    }
+}
+
+/**
+ * A RequirementCollection represents a set of Requirement instances.
+ *
+ * @author Tobias Schultze <http://tobion.de>
+ */
+class RequirementCollection implements IteratorAggregate
+{
+    /**
+     * @var Requirement[]
+     */
+    private $requirements = array();
+
+    /**
+     * Gets the current RequirementCollection as an Iterator.
+     *
+     * @return Traversable A Traversable interface
+     */
+    public function getIterator()
+    {
+        return new ArrayIterator($this->requirements);
+    }
+
+    /**
+     * Adds a Requirement.
+     *
+     * @param Requirement $requirement A Requirement instance
+     */
+    public function add(Requirement $requirement)
+    {
+        $this->requirements[] = $requirement;
+    }
+
+    /**
+     * Adds a mandatory requirement.
+     *
+     * @param bool        $fulfilled   Whether the requirement is fulfilled
+     * @param string      $testMessage The message for testing the requirement
+     * @param string      $helpHtml    The help text formatted in HTML for resolving the problem
+     * @param string|null $helpText    The help text (when null, it will be inferred from $helpHtml, i.e. stripped from HTML tags)
+     */
+    public function addRequirement($fulfilled, $testMessage, $helpHtml, $helpText = null)
+    {
+        $this->add(new Requirement($fulfilled, $testMessage, $helpHtml, $helpText, false));
+    }
+
+    /**
+     * Adds an optional recommendation.
+     *
+     * @param bool        $fulfilled   Whether the recommendation is fulfilled
+     * @param string      $testMessage The message for testing the recommendation
+     * @param string      $helpHtml    The help text formatted in HTML for resolving the problem
+     * @param string|null $helpText    The help text (when null, it will be inferred from $helpHtml, i.e. stripped from HTML tags)
+     */
+    public function addRecommendation($fulfilled, $testMessage, $helpHtml, $helpText = null)
+    {
+        $this->add(new Requirement($fulfilled, $testMessage, $helpHtml, $helpText, true));
+    }
+
+    /**
+     * Adds a mandatory requirement in form of a php.ini configuration.
+     *
+     * @param string        $cfgName           The configuration name used for ini_get()
+     * @param bool|callback $evaluation        Either a boolean indicating whether the configuration should evaluate to true or false,
+     *                                         or a callback function receiving the configuration value as parameter to determine the fulfillment of the requirement
+     * @param bool          $approveCfgAbsence If true the Requirement will be fulfilled even if the configuration option does not exist, i.e. ini_get() returns false.
+     *                                         This is helpful for abandoned configs in later PHP versions or configs of an optional extension, like Suhosin.
+     *                                         Example: You require a config to be true but PHP later removes this config and defaults it to true internally.
+     * @param string        $testMessage       The message for testing the requirement (when null and $evaluation is a boolean a default message is derived)
+     * @param string        $helpHtml          The help text formatted in HTML for resolving the problem (when null and $evaluation is a boolean a default help is derived)
+     * @param string|null   $helpText          The help text (when null, it will be inferred from $helpHtml, i.e. stripped from HTML tags)
+     */
+    public function addPhpIniRequirement($cfgName, $evaluation, $approveCfgAbsence = false, $testMessage = null, $helpHtml = null, $helpText = null)
+    {
+        $this->add(new PhpIniRequirement($cfgName, $evaluation, $approveCfgAbsence, $testMessage, $helpHtml, $helpText, false));
+    }
+
+    /**
+     * Adds an optional recommendation in form of a php.ini configuration.
+     *
+     * @param string        $cfgName           The configuration name used for ini_get()
+     * @param bool|callback $evaluation        Either a boolean indicating whether the configuration should evaluate to true or false,
+     *                                         or a callback function receiving the configuration value as parameter to determine the fulfillment of the requirement
+     * @param bool          $approveCfgAbsence If true the Requirement will be fulfilled even if the configuration option does not exist, i.e. ini_get() returns false.
+     *                                         This is helpful for abandoned configs in later PHP versions or configs of an optional extension, like Suhosin.
+     *                                         Example: You require a config to be true but PHP later removes this config and defaults it to true internally.
+     * @param string        $testMessage       The message for testing the requirement (when null and $evaluation is a boolean a default message is derived)
+     * @param string        $helpHtml          The help text formatted in HTML for resolving the problem (when null and $evaluation is a boolean a default help is derived)
+     * @param string|null   $helpText          The help text (when null, it will be inferred from $helpHtml, i.e. stripped from HTML tags)
+     */
+    public function addPhpIniRecommendation($cfgName, $evaluation, $approveCfgAbsence = false, $testMessage = null, $helpHtml = null, $helpText = null)
+    {
+        $this->add(new PhpIniRequirement($cfgName, $evaluation, $approveCfgAbsence, $testMessage, $helpHtml, $helpText, true));
+    }
+
+    /**
+     * Adds a requirement collection to the current set of requirements.
+     *
+     * @param RequirementCollection $collection A RequirementCollection instance
+     */
+    public function addCollection(RequirementCollection $collection)
+    {
+        $this->requirements = array_merge($this->requirements, $collection->all());
+    }
+
+    /**
+     * Returns both requirements and recommendations.
+     *
+     * @return Requirement[]
+     */
+    public function all()
+    {
+        return $this->requirements;
+    }
+
+    /**
+     * Returns all mandatory requirements.
+     *
+     * @return Requirement[]
+     */
+    public function getRequirements()
+    {
+        $array = array();
+        foreach ($this->requirements as $req) {
+            if (!$req->isOptional()) {
+                $array[] = $req;
+            }
+        }
+
+        return $array;
+    }
+
+    /**
+     * Returns the mandatory requirements that were not met.
+     *
+     * @return Requirement[]
+     */
+    public function getFailedRequirements()
+    {
+        $array = array();
+        foreach ($this->requirements as $req) {
+            if (!$req->isFulfilled() && !$req->isOptional()) {
+                $array[] = $req;
+            }
+        }
+
+        return $array;
+    }
+
+    /**
+     * Returns all optional recommendations.
+     *
+     * @return Requirement[]
+     */
+    public function getRecommendations()
+    {
+        $array = array();
+        foreach ($this->requirements as $req) {
+            if ($req->isOptional()) {
+                $array[] = $req;
+            }
+        }
+
+        return $array;
+    }
+
+    /**
+     * Returns the recommendations that were not met.
+     *
+     * @return Requirement[]
+     */
+    public function getFailedRecommendations()
+    {
+        $array = array();
+        foreach ($this->requirements as $req) {
+            if (!$req->isFulfilled() && $req->isOptional()) {
+                $array[] = $req;
+            }
+        }
+
+        return $array;
+    }
+
+    /**
+     * Returns whether a php.ini configuration is not correct.
+     *
+     * @return bool php.ini configuration problem?
+     */
+    public function hasPhpIniConfigIssue()
+    {
+        foreach ($this->requirements as $req) {
+            if (!$req->isFulfilled() && $req instanceof PhpIniRequirement) {
+                return true;
+            }
+        }
+
+        return false;
+    }
+
+    /**
+     * Returns the PHP configuration file (php.ini) path.
+     *
+     * @return string|false php.ini file path
+     */
+    public function getPhpIniConfigPath()
+    {
+        return get_cfg_var('cfg_file_path');
+    }
+}
+
+/**
+ * This class specifies all requirements and optional recommendations that
+ * are necessary to run the Symfony Standard Edition.
+ *
+ * @author Tobias Schultze <http://tobion.de>
+ * @author Fabien Potencier <fabien@symfony.com>
+ */
+class SymfonyRequirements extends RequirementCollection
+{
+    const LEGACY_REQUIRED_PHP_VERSION = '5.3.3';
+    const REQUIRED_PHP_VERSION = '5.5.9';
+
+    /**
+     * Constructor that initializes the requirements.
+     */
+    public function __construct()
+    {
+        /* mandatory requirements follow */
+
+        $installedPhpVersion = phpversion();
+        $requiredPhpVersion = $this->getPhpRequiredVersion();
+
+        $this->addRecommendation(
+            $requiredPhpVersion,
+            'Vendors should be installed in order to check all requirements.',
+            'Run the <code>composer install</code> command.',
+            'Run the "composer install" command.'
+        );
+
+        if (false !== $requiredPhpVersion) {
+            $this->addRequirement(
+                version_compare($installedPhpVersion, $requiredPhpVersion, '>='),
+                sprintf('PHP version must be at least %s (%s installed)', $requiredPhpVersion, $installedPhpVersion),
+                sprintf('You are running PHP version "<strong>%s</strong>", but Symfony needs at least PHP "<strong>%s</strong>" to run.
+                Before using Symfony, upgrade your PHP installation, preferably to the latest version.',
+                    $installedPhpVersion, $requiredPhpVersion),
+                sprintf('Install PHP %s or newer (installed version is %s)', $requiredPhpVersion, $installedPhpVersion)
+            );
+        }
+
+        $this->addRequirement(
+            version_compare($installedPhpVersion, '5.3.16', '!='),
+            'PHP version must not be 5.3.16 as Symfony won\'t work properly with it',
+            'Install PHP 5.3.17 or newer (or downgrade to an earlier PHP version)'
+        );
+
+        $this->addRequirement(
+            is_dir(__DIR__.'/../vendor/composer'),
+            'Vendor libraries must be installed',
+            'Vendor libraries are missing. Install composer following instructions from <a href="http://getcomposer.org/">http://getcomposer.org/</a>. '.
+                'Then run "<strong>php composer.phar install</strong>" to install them.'
+        );
+
+        $cacheDir = is_dir(__DIR__.'/../var/cache') ? __DIR__.'/../var/cache' : __DIR__.'/cache';
+
+        $this->addRequirement(
+            is_writable($cacheDir),
+            'app/cache/ or var/cache/ directory must be writable',
+            'Change the permissions of either "<strong>app/cache/</strong>" or  "<strong>var/cache/</strong>" directory so that the web server can write into it.'
+        );
+
+        $logsDir = is_dir(__DIR__.'/../var/logs') ? __DIR__.'/../var/logs' : __DIR__.'/logs';
+
+        $this->addRequirement(
+            is_writable($logsDir),
+            'app/logs/ or var/logs/ directory must be writable',
+            'Change the permissions of either "<strong>app/logs/</strong>" or  "<strong>var/logs/</strong>" directory so that the web server can write into it.'
+        );
+
+        if (version_compare($installedPhpVersion, '7.0.0', '<')) {
+            $this->addPhpIniRequirement(
+                'date.timezone', true, false,
+                'date.timezone setting must be set',
+                'Set the "<strong>date.timezone</strong>" setting in php.ini<a href="#phpini">*</a> (like Europe/Paris).'
+            );
+        }
+
+        if (false !== $requiredPhpVersion && version_compare($installedPhpVersion, $requiredPhpVersion, '>=')) {
+            $timezones = array();
+            foreach (DateTimeZone::listAbbreviations() as $abbreviations) {
+                foreach ($abbreviations as $abbreviation) {
+                    $timezones[$abbreviation['timezone_id']] = true;
+                }
+            }
+
+            $this->addRequirement(
+                isset($timezones[@date_default_timezone_get()]),
+                sprintf('Configured default timezone "%s" must be supported by your installation of PHP', @date_default_timezone_get()),
+                'Your default timezone is not supported by PHP. Check for typos in your <strong>php.ini</strong> file and have a look at the list of deprecated timezones at <a href="http://php.net/manual/en/timezones.others.php">http://php.net/manual/en/timezones.others.php</a>.'
+            );
+        }
+
+        $this->addRequirement(
+            function_exists('iconv'),
+            'iconv() must be available',
+            'Install and enable the <strong>iconv</strong> extension.'
+        );
+
+        $this->addRequirement(
+            function_exists('json_encode'),
+            'json_encode() must be available',
+            'Install and enable the <strong>JSON</strong> extension.'
+        );
+
+        $this->addRequirement(
+            function_exists('session_start'),
+            'session_start() must be available',
+            'Install and enable the <strong>session</strong> extension.'
+        );
+
+        $this->addRequirement(
+            function_exists('ctype_alpha'),
+            'ctype_alpha() must be available',
+            'Install and enable the <strong>ctype</strong> extension.'
+        );
+
+        $this->addRequirement(
+            function_exists('token_get_all'),
+            'token_get_all() must be available',
+            'Install and enable the <strong>Tokenizer</strong> extension.'
+        );
+
+        $this->addRequirement(
+            function_exists('simplexml_import_dom'),
+            'simplexml_import_dom() must be available',
+            'Install and enable the <strong>SimpleXML</strong> extension.'
+        );
+
+        if (function_exists('apc_store') && ini_get('apc.enabled')) {
+            if (version_compare($installedPhpVersion, '5.4.0', '>=')) {
+                $this->addRequirement(
+                    version_compare(phpversion('apc'), '3.1.13', '>='),
+                    'APC version must be at least 3.1.13 when using PHP 5.4',
+                    'Upgrade your <strong>APC</strong> extension (3.1.13+).'
+                );
+            } else {
+                $this->addRequirement(
+                    version_compare(phpversion('apc'), '3.0.17', '>='),
+                    'APC version must be at least 3.0.17',
+                    'Upgrade your <strong>APC</strong> extension (3.0.17+).'
+                );
+            }
+        }
+
+        $this->addPhpIniRequirement('detect_unicode', false);
+
+        if (extension_loaded('suhosin')) {
+            $this->addPhpIniRequirement(
+                'suhosin.executor.include.whitelist',
+                create_function('$cfgValue', 'return false !== stripos($cfgValue, "phar");'),
+                false,
+                'suhosin.executor.include.whitelist must be configured correctly in php.ini',
+                'Add "<strong>phar</strong>" to <strong>suhosin.executor.include.whitelist</strong> in php.ini<a href="#phpini">*</a>.'
+            );
+        }
+
+        if (extension_loaded('xdebug')) {
+            $this->addPhpIniRequirement(
+                'xdebug.show_exception_trace', false, true
+            );
+
+            $this->addPhpIniRequirement(
+                'xdebug.scream', false, true
+            );
+
+            $this->addPhpIniRecommendation(
+                'xdebug.max_nesting_level',
+                create_function('$cfgValue', 'return $cfgValue > 100;'),
+                true,
+                'xdebug.max_nesting_level should be above 100 in php.ini',
+                'Set "<strong>xdebug.max_nesting_level</strong>" to e.g. "<strong>250</strong>" in php.ini<a href="#phpini">*</a> to stop Xdebug\'s infinite recursion protection erroneously throwing a fatal error in your project.'
+            );
+        }
+
+        $pcreVersion = defined('PCRE_VERSION') ? (float) PCRE_VERSION : null;
+
+        $this->addRequirement(
+            null !== $pcreVersion,
+            'PCRE extension must be available',
+            'Install the <strong>PCRE</strong> extension (version 8.0+).'
+        );
+
+        if (extension_loaded('mbstring')) {
+            $this->addPhpIniRequirement(
+                'mbstring.func_overload',
+                create_function('$cfgValue', 'return (int) $cfgValue === 0;'),
+                true,
+                'string functions should not be overloaded',
+                'Set "<strong>mbstring.func_overload</strong>" to <strong>0</strong> in php.ini<a href="#phpini">*</a> to disable function overloading by the mbstring extension.'
+            );
+        }
+
+        /* optional recommendations follow */
+
+        if (file_exists(__DIR__.'/../vendor/composer')) {
+            require_once __DIR__.'/../vendor/autoload.php';
+
+            try {
+                $r = new ReflectionClass('Sensio\Bundle\DistributionBundle\SensioDistributionBundle');
+
+                $contents = file_get_contents(dirname($r->getFileName()).'/Resources/skeleton/app/SymfonyRequirements.php');
+            } catch (ReflectionException $e) {
+                $contents = '';
+            }
+            $this->addRecommendation(
+                file_get_contents(__FILE__) === $contents,
+                'Requirements file should be up-to-date',
+                'Your requirements file is outdated. Run composer install and re-check your configuration.'
+            );
+        }
+
+        $this->addRecommendation(
+            version_compare($installedPhpVersion, '5.3.4', '>='),
+            'You should use at least PHP 5.3.4 due to PHP bug #52083 in earlier versions',
+            'Your project might malfunction randomly due to PHP bug #52083 ("Notice: Trying to get property of non-object"). Install PHP 5.3.4 or newer.'
+        );
+
+        $this->addRecommendation(
+            version_compare($installedPhpVersion, '5.3.8', '>='),
+            'When using annotations you should have at least PHP 5.3.8 due to PHP bug #55156',
+            'Install PHP 5.3.8 or newer if your project uses annotations.'
+        );
+
+        $this->addRecommendation(
+            version_compare($installedPhpVersion, '5.4.0', '!='),
+            'You should not use PHP 5.4.0 due to the PHP bug #61453',
+            'Your project might not work properly due to the PHP bug #61453 ("Cannot dump definitions which have method calls"). Install PHP 5.4.1 or newer.'
+        );
+
+        $this->addRecommendation(
+            version_compare($installedPhpVersion, '5.4.11', '>='),
+            'When using the logout handler from the Symfony Security Component, you should have at least PHP 5.4.11 due to PHP bug #63379 (as a workaround, you can also set invalidate_session to false in the security logout handler configuration)',
+            'Install PHP 5.4.11 or newer if your project uses the logout handler from the Symfony Security Component.'
+        );
+
+        $this->addRecommendation(
+            (version_compare($installedPhpVersion, '5.3.18', '>=') && version_compare($installedPhpVersion, '5.4.0', '<'))
+            ||
+            version_compare($installedPhpVersion, '5.4.8', '>='),
+            'You should use PHP 5.3.18+ or PHP 5.4.8+ to always get nice error messages for fatal errors in the development environment due to PHP bug #61767/#60909',
+            'Install PHP 5.3.18+ or PHP 5.4.8+ if you want nice error messages for all fatal errors in the development environment.'
+        );
+
+        if (null !== $pcreVersion) {
+            $this->addRecommendation(
+                $pcreVersion >= 8.0,
+                sprintf('PCRE extension should be at least version 8.0 (%s installed)', $pcreVersion),
+                '<strong>PCRE 8.0+</strong> is preconfigured in PHP since 5.3.2 but you are using an outdated version of it. Symfony probably works anyway but it is recommended to upgrade your PCRE extension.'
+            );
+        }
+
+        $this->addRecommendation(
+            class_exists('DomDocument'),
+            'PHP-DOM and PHP-XML modules should be installed',
+            'Install and enable the <strong>PHP-DOM</strong> and the <strong>PHP-XML</strong> modules.'
+        );
+
+        $this->addRecommendation(
+            function_exists('mb_strlen'),
+            'mb_strlen() should be available',
+            'Install and enable the <strong>mbstring</strong> extension.'
+        );
+
+        $this->addRecommendation(
+            function_exists('utf8_decode'),
+            'utf8_decode() should be available',
+            'Install and enable the <strong>XML</strong> extension.'
+        );
+
+        $this->addRecommendation(
+            function_exists('filter_var'),
+            'filter_var() should be available',
+            'Install and enable the <strong>filter</strong> extension.'
+        );
+
+        if (!defined('PHP_WINDOWS_VERSION_BUILD')) {
+            $this->addRecommendation(
+                function_exists('posix_isatty'),
+                'posix_isatty() should be available',
+                'Install and enable the <strong>php_posix</strong> extension (used to colorize the CLI output).'
+            );
+        }
+
+        $this->addRecommendation(
+            extension_loaded('intl'),
+            'intl extension should be available',
+            'Install and enable the <strong>intl</strong> extension (used for validators).'
+        );
+
+        if (extension_loaded('intl')) {
+            // in some WAMP server installations, new Collator() returns null
+            $this->addRecommendation(
+                null !== new Collator('fr_FR'),
+                'intl extension should be correctly configured',
+                'The intl extension does not behave properly. This problem is typical on PHP 5.3.X x64 WIN builds.'
+            );
+
+            // check for compatible ICU versions (only done when you have the intl extension)
+            if (defined('INTL_ICU_VERSION')) {
+                $version = INTL_ICU_VERSION;
+            } else {
+                $reflector = new ReflectionExtension('intl');
+
+                ob_start();
+                $reflector->info();
+                $output = strip_tags(ob_get_clean());
+
+                preg_match('/^ICU version +(?:=> )?(.*)$/m', $output, $matches);
+                $version = $matches[1];
+            }
+
+            $this->addRecommendation(
+                version_compare($version, '4.0', '>='),
+                'intl ICU version should be at least 4+',
+                'Upgrade your <strong>intl</strong> extension with a newer ICU version (4+).'
+            );
+
+            if (class_exists('Symfony\Component\Intl\Intl')) {
+                $this->addRecommendation(
+                    \Symfony\Component\Intl\Intl::getIcuDataVersion() <= \Symfony\Component\Intl\Intl::getIcuVersion(),
+                    sprintf('intl ICU version installed on your system is outdated (%s) and does not match the ICU data bundled with Symfony (%s)', \Symfony\Component\Intl\Intl::getIcuVersion(), \Symfony\Component\Intl\Intl::getIcuDataVersion()),
+                    'To get the latest internationalization data upgrade the ICU system package and the intl PHP extension.'
+                );
+                if (\Symfony\Component\Intl\Intl::getIcuDataVersion() <= \Symfony\Component\Intl\Intl::getIcuVersion()) {
+                    $this->addRecommendation(
+                        \Symfony\Component\Intl\Intl::getIcuDataVersion() === \Symfony\Component\Intl\Intl::getIcuVersion(),
+                        sprintf('intl ICU version installed on your system (%s) does not match the ICU data bundled with Symfony (%s)', \Symfony\Component\Intl\Intl::getIcuVersion(), \Symfony\Component\Intl\Intl::getIcuDataVersion()),
+                        'To avoid internationalization data inconsistencies upgrade the symfony/intl component.'
+                    );
+                }
+            }
+
+            $this->addPhpIniRecommendation(
+                'intl.error_level',
+                create_function('$cfgValue', 'return (int) $cfgValue === 0;'),
+                true,
+                'intl.error_level should be 0 in php.ini',
+                'Set "<strong>intl.error_level</strong>" to "<strong>0</strong>" in php.ini<a href="#phpini">*</a> to inhibit the messages when an error occurs in ICU functions.'
+            );
+        }
+
+        $accelerator =
+            (extension_loaded('eaccelerator') && ini_get('eaccelerator.enable'))
+            ||
+            (extension_loaded('apc') && ini_get('apc.enabled'))
+            ||
+            (extension_loaded('Zend Optimizer+') && ini_get('zend_optimizerplus.enable'))
+            ||
+            (extension_loaded('Zend OPcache') && ini_get('opcache.enable'))
+            ||
+            (extension_loaded('xcache') && ini_get('xcache.cacher'))
+            ||
+            (extension_loaded('wincache') && ini_get('wincache.ocenabled'))
+        ;
+
+        $this->addRecommendation(
+            $accelerator,
+            'a PHP accelerator should be installed',
+            'Install and/or enable a <strong>PHP accelerator</strong> (highly recommended).'
+        );
+
+        if (strtoupper(substr(PHP_OS, 0, 3)) === 'WIN') {
+            $this->addRecommendation(
+                $this->getRealpathCacheSize() >= 5 * 1024 * 1024,
+                'realpath_cache_size should be at least 5M in php.ini',
+                'Setting "<strong>realpath_cache_size</strong>" to e.g. "<strong>5242880</strong>" or "<strong>5M</strong>" in php.ini<a href="#phpini">*</a> may improve performance on Windows significantly in some cases.'
+            );
+        }
+
+        $this->addPhpIniRecommendation('short_open_tag', false);
+
+        $this->addPhpIniRecommendation('magic_quotes_gpc', false, true);
+
+        $this->addPhpIniRecommendation('register_globals', false, true);
+
+        $this->addPhpIniRecommendation('session.auto_start', false);
+
+        $this->addRecommendation(
+            class_exists('PDO'),
+            'PDO should be installed',
+            'Install <strong>PDO</strong> (mandatory for Doctrine).'
+        );
+
+        if (class_exists('PDO')) {
+            $drivers = PDO::getAvailableDrivers();
+            $this->addRecommendation(
+                count($drivers) > 0,
+                sprintf('PDO should have some drivers installed (currently available: %s)', count($drivers) ? implode(', ', $drivers) : 'none'),
+                'Install <strong>PDO drivers</strong> (mandatory for Doctrine).'
+            );
+        }
+    }
+
+    /**
+     * Loads realpath_cache_size from php.ini and converts it to int.
+     *
+     * (e.g. 16k is converted to 16384 int)
+     *
+     * @return int
+     */
+    protected function getRealpathCacheSize()
+    {
+        $size = ini_get('realpath_cache_size');
+        $size = trim($size);
+        $unit = '';
+        if (!ctype_digit($size)) {
+            $unit = strtolower(substr($size, -1, 1));
+            $size = (int) substr($size, 0, -1);
+        }
+        switch ($unit) {
+            case 'g':
+                return $size * 1024 * 1024 * 1024;
+            case 'm':
+                return $size * 1024 * 1024;
+            case 'k':
+                return $size * 1024;
+            default:
+                return (int) $size;
+        }
+    }
+
+    /**
+     * Defines PHP required version from Symfony version.
+     *
+     * @return string|false The PHP required version or false if it could not be guessed
+     */
+    protected function getPhpRequiredVersion()
+    {
+        if (!file_exists($path = __DIR__.'/../composer.lock')) {
+            return false;
+        }
+
+        $composerLock = json_decode(file_get_contents($path), true);
+        foreach ($composerLock['packages'] as $package) {
+            $name = $package['name'];
+            if ('symfony/symfony' !== $name && 'symfony/http-kernel' !== $name) {
+                continue;
+            }
+
+            return (int) $package['version'][1] > 2 ? self::REQUIRED_PHP_VERSION : self::LEGACY_REQUIRED_PHP_VERSION;
+        }
+
+        return false;
+    }
+}
diff --git a/symfony-3.3-micro/var/cache/.gitkeep b/symfony-3.3-micro/var/cache/.gitkeep
new file mode 100644
index 000000000..e69de29bb
diff --git a/symfony-3.3-micro/var/logs/.gitkeep b/symfony-3.3-micro/var/logs/.gitkeep
new file mode 100644
index 000000000..e69de29bb
diff --git a/symfony-3.3-micro/var/sessions/.gitkeep b/symfony-3.3-micro/var/sessions/.gitkeep
new file mode 100644
index 000000000..e69de29bb
diff --git a/symfony-3.3-micro/web/micro.php b/symfony-3.3-micro/web/micro.php
new file mode 100644
index 000000000..37af6654d
--- /dev/null
+++ b/symfony-3.3-micro/web/micro.php
@@ -0,0 +1,19 @@
+<?php
+
+use Symfony\Component\HttpFoundation\Request;
+
+/**
+ * @var Composer\Autoload\ClassLoader
+ */
+$loader = require __DIR__ . '/../app/autoload.php';
+include_once __DIR__ . '/../var/bootstrap.php.cache';
+
+$kernel = new AppKernel('prod', false);
+$kernel->loadClassCache();
+
+$request = Request::createFromGlobals();
+$response = $kernel->handle($request);
+$response->send();
+$kernel->terminate($request, $response);
+
+require __DIR__ . '/../../libs/output_data.php';
diff --git a/symfony-3.3/.gitignore b/symfony-3.3/.gitignore
new file mode 100644
index 000000000..93821ad1c
--- /dev/null
+++ b/symfony-3.3/.gitignore
@@ -0,0 +1,16 @@
+/app/config/parameters.yml
+/build/
+/phpunit.xml
+/var/*
+!/var/cache
+/var/cache/*
+!var/cache/.gitkeep
+!/var/logs
+/var/logs/*
+!var/logs/.gitkeep
+!/var/sessions
+/var/sessions/*
+!var/sessions/.gitkeep
+!var/SymfonyRequirements.php
+/vendor/
+/web/bundles/
diff --git a/symfony-3.3/README.md b/symfony-3.3/README.md
new file mode 100644
index 000000000..839b7e5f8
--- /dev/null
+++ b/symfony-3.3/README.md
@@ -0,0 +1,4 @@
+symfony-3.3
+===========
+
+A Symfony project
diff --git a/symfony-3.3/_benchmark/hello_world.sh b/symfony-3.3/_benchmark/hello_world.sh
new file mode 100644
index 000000000..9e6369133
--- /dev/null
+++ b/symfony-3.3/_benchmark/hello_world.sh
@@ -0,0 +1,3 @@
+#!/bin/sh
+
+url="$base/$fw/web/app.php/hello/index"
diff --git a/symfony-3.3/_benchmark/setup.sh b/symfony-3.3/_benchmark/setup.sh
new file mode 100644
index 000000000..0244cd4d5
--- /dev/null
+++ b/symfony-3.3/_benchmark/setup.sh
@@ -0,0 +1,8 @@
+#!/bin/sh
+
+export SYMFONY_ENV=prod
+composer install --no-dev --optimize-autoloader
+php bin/console cache:clear --env=prod --no-debug --no-warmup
+php bin/console cache:warmup --env=prod --no-debug
+chmod o+w var/cache/ var/logs/
+chmod -R o+w var/cache/*
diff --git a/symfony-3.3/app/AppCache.php b/symfony-3.3/app/AppCache.php
new file mode 100644
index 000000000..639ec2cd7
--- /dev/null
+++ b/symfony-3.3/app/AppCache.php
@@ -0,0 +1,7 @@
+<?php
+
+use Symfony\Bundle\FrameworkBundle\HttpCache\HttpCache;
+
+class AppCache extends HttpCache
+{
+}
diff --git a/symfony-3.3/app/AppKernel.php b/symfony-3.3/app/AppKernel.php
new file mode 100644
index 000000000..3789b326e
--- /dev/null
+++ b/symfony-3.3/app/AppKernel.php
@@ -0,0 +1,50 @@
+<?php
+
+use Symfony\Component\HttpKernel\Kernel;
+use Symfony\Component\Config\Loader\LoaderInterface;
+
+class AppKernel extends Kernel
+{
+    public function registerBundles()
+    {
+        $bundles = [
+            new Symfony\Bundle\FrameworkBundle\FrameworkBundle(),
+            new Symfony\Bundle\SecurityBundle\SecurityBundle(),
+            new Symfony\Bundle\TwigBundle\TwigBundle(),
+            new Symfony\Bundle\MonologBundle\MonologBundle(),
+            new Symfony\Bundle\SwiftmailerBundle\SwiftmailerBundle(),
+            new Doctrine\Bundle\DoctrineBundle\DoctrineBundle(),
+            new Sensio\Bundle\FrameworkExtraBundle\SensioFrameworkExtraBundle(),
+            new AppBundle\AppBundle(),
+        ];
+
+        if (in_array($this->getEnvironment(), ['dev', 'test'], true)) {
+            $bundles[] = new Symfony\Bundle\DebugBundle\DebugBundle();
+            $bundles[] = new Symfony\Bundle\WebProfilerBundle\WebProfilerBundle();
+            $bundles[] = new Sensio\Bundle\DistributionBundle\SensioDistributionBundle();
+            $bundles[] = new Sensio\Bundle\GeneratorBundle\SensioGeneratorBundle();
+        }
+
+        return $bundles;
+    }
+
+    public function getRootDir()
+    {
+        return __DIR__;
+    }
+
+    public function getCacheDir()
+    {
+        return dirname(__DIR__).'/var/cache/'.$this->getEnvironment();
+    }
+
+    public function getLogDir()
+    {
+        return dirname(__DIR__).'/var/logs';
+    }
+
+    public function registerContainerConfiguration(LoaderInterface $loader)
+    {
+        $loader->load($this->getRootDir().'/config/config_'.$this->getEnvironment().'.yml');
+    }
+}
diff --git a/symfony-3.3/app/Resources/views/base.html.twig b/symfony-3.3/app/Resources/views/base.html.twig
new file mode 100644
index 000000000..bafd28d3b
--- /dev/null
+++ b/symfony-3.3/app/Resources/views/base.html.twig
@@ -0,0 +1,13 @@
+<!DOCTYPE html>
+<html>
+    <head>
+        <meta charset="UTF-8" />
+        <title>{% block title %}Welcome!{% endblock %}</title>
+        {% block stylesheets %}{% endblock %}
+        <link rel="icon" type="image/x-icon" href="{{ asset('favicon.ico') }}" />
+    </head>
+    <body>
+        {% block body %}{% endblock %}
+        {% block javascripts %}{% endblock %}
+    </body>
+</html>
diff --git a/symfony-3.3/app/Resources/views/default/index.html.twig b/symfony-3.3/app/Resources/views/default/index.html.twig
new file mode 100644
index 000000000..7319df7f8
--- /dev/null
+++ b/symfony-3.3/app/Resources/views/default/index.html.twig
@@ -0,0 +1,76 @@
+{% extends 'base.html.twig' %}
+
+{% block body %}
+    <div id="wrapper">
+        <div id="container">
+            <div id="welcome">
+                <h1><span>Welcome to</span> Symfony {{ constant('Symfony\\Component\\HttpKernel\\Kernel::VERSION') }}</h1>
+            </div>
+
+            <div id="status">
+                <p>
+                    <svg id="icon-status" width="1792" height="1792" viewBox="0 0 1792 1792" xmlns="http://www.w3.org/2000/svg"><path d="M1671 566q0 40-28 68l-724 724-136 136q-28 28-68 28t-68-28l-136-136-362-362q-28-28-28-68t28-68l136-136q28-28 68-28t68 28l294 295 656-657q28-28 68-28t68 28l136 136q28 28 28 68z" fill="#759E1A"/></svg>
+
+                    Your application is now ready. You can start working on it at:
+                    <code>{{ base_dir }}/</code>
+                </p>
+            </div>
+
+            <div id="next">
+                <h2>What's next?</h2>
+                <p>
+                    <svg id="icon-book" version="1.1" xmlns="http://www.w3.org/2000/svg" x="0px" y="0px" viewBox="-12.5 9 64 64" enable-background="new -12.5 9 64 64" xml:space="preserve">
+                        <path fill="#AAA" d="M6.8,40.8c2.4,0.8,4.5-0.7,4.9-2.5c0.2-1.2-0.3-2.1-1.3-3.2l-0.8-0.8c-0.4-0.5-0.6-1.3-0.2-1.9
+                            c0.4-0.5,0.9-0.8,1.8-0.5c1.3,0.4,1.9,1.3,2.9,2.2c-0.4,1.4-0.7,2.9-0.9,4.2l-0.2,1c-0.7,4-1.3,6.2-2.7,7.5
+                            c-0.3,0.3-0.7,0.5-1.3,0.6c-0.3,0-0.4-0.3-0.4-0.3c0-0.3,0.2-0.3,0.3-0.4c0.2-0.1,0.5-0.3,0.4-0.8c0-0.7-0.6-1.3-1.3-1.3
+                            c-0.6,0-1.4,0.6-1.4,1.7s1,1.9,2.4,1.8c0.8,0,2.5-0.3,4.2-2.5c2-2.5,2.5-5.4,2.9-7.4l0.5-2.8c0.3,0,0.5,0.1,0.8,0.1
+                            c2.4,0.1,3.7-1.3,3.7-2.3c0-0.6-0.3-1.2-0.9-1.2c-0.4,0-0.8,0.3-1,0.8c-0.1,0.6,0.8,1.1,0.1,1.5c-0.5,0.3-1.4,0.6-2.7,0.4l0.3-1.3
+                            c0.5-2.6,1-5.7,3.2-5.8c0.2,0,0.8,0,0.8,0.4c0,0.2,0,0.2-0.2,0.5c-0.2,0.3-0.3,0.4-0.2,0.7c0,0.7,0.5,1.1,1.2,1.1
+                            c0.9,0,1.2-1,1.2-1.4c0-1.2-1.2-1.8-2.6-1.8c-1.5,0.1-2.8,0.9-3.7,2.1c-1.1,1.3-1.8,2.9-2.3,4.5c-0.9-0.8-1.6-1.8-3.1-2.3
+                            c-1.1-0.7-2.3-0.5-3.4,0.3c-0.5,0.4-0.8,1-1,1.6c-0.4,1.5,0.4,2.9,0.8,3.4l0.9,1c0.2,0.2,0.6,0.8,0.4,1.5c-0.3,0.8-1.2,1.3-2.1,1
+                            c-0.4-0.2-1-0.5-0.9-0.9c0.1-0.2,0.2-0.3,0.3-0.5s0.1-0.3,0.1-0.3c0.2-0.6-0.1-1.4-0.7-1.6c-0.6-0.2-1.2,0-1.3,0.8
+                            C4.3,38.4,4.7,40,6.8,40.8z M46.1,20.9c0-4.2-3.2-7.5-7.1-7.5h-3.8C34.8,10.8,32.7,9,30.2,9L-2.3,9.1c-2.8,0.1-4.9,2.4-4.9,5.4
+                            L-7,58.6c0,4.8,8.1,13.9,11.6,14.1l34.7-0.1c3.9,0,7-3.4,7-7.6L46.1,20.9z M-0.3,36.4c0-8.6,6.5-15.6,14.5-15.6
+                            c8,0,14.5,7,14.5,15.6S22.1,52,14.2,52C6.1,52-0.3,45-0.3,36.4z M42.1,65.1c0,1.8-1.5,3.1-3.1,3.1H4.6c-0.7,0-3-1.8-4.5-4.4h30.4
+                            c2.8,0,5-2.4,5-5.4V17.9h3.7c1.6,0,2.9,1.4,2.9,3.1V65.1L42.1,65.1z"/>
+                    </svg>
+
+                    Read the documentation to learn
+                    <a href="http://symfony.com/doc/{{ constant('Symfony\\Component\\HttpKernel\\Kernel::VERSION')[:3] }}/book/page_creation.html">
+                        How to create your first page in Symfony
+                    </a>
+                </p>
+            </div>
+
+        </div>
+    </div>
+{% endblock %}
+
+{% block stylesheets %}
+<style>
+    body { background: #F5F5F5; font: 18px/1.5 sans-serif; }
+    h1, h2 { line-height: 1.2; margin: 0 0 .5em; }
+    h1 { font-size: 36px; }
+    h2 { font-size: 21px; margin-bottom: 1em; }
+    p { margin: 0 0 1em 0; }
+    a { color: #0000F0; }
+    a:hover { text-decoration: none; }
+    code { background: #F5F5F5; max-width: 100px; padding: 2px 6px; word-wrap: break-word; }
+    #wrapper { background: #FFF; margin: 1em auto; max-width: 800px; width: 95%; }
+    #container { padding: 2em; }
+    #welcome, #status { margin-bottom: 2em; }
+    #welcome h1 span { display: block; font-size: 75%; }
+    #icon-status, #icon-book { float: left; height: 64px; margin-right: 1em; margin-top: -4px; width: 64px; }
+    #icon-book { display: none; }
+
+    @media (min-width: 768px) {
+        #wrapper { width: 80%; margin: 2em auto; }
+        #icon-book { display: inline-block; }
+        #status a, #next a { display: block; }
+
+        @-webkit-keyframes fade-in { 0% { opacity: 0; } 100% { opacity: 1; } }
+        @keyframes fade-in { 0% { opacity: 0; } 100% { opacity: 1; } }
+        .sf-toolbar { opacity: 0; -webkit-animation: fade-in 1s .2s forwards; animation: fade-in 1s .2s forwards;}
+    }
+</style>
+{% endblock %}
diff --git a/symfony-3.3/app/autoload.php b/symfony-3.3/app/autoload.php
new file mode 100644
index 000000000..fa582ecd0
--- /dev/null
+++ b/symfony-3.3/app/autoload.php
@@ -0,0 +1,13 @@
+<?php
+
+use Doctrine\Common\Annotations\AnnotationRegistry;
+use Composer\Autoload\ClassLoader;
+
+/**
+ * @var ClassLoader $loader
+ */
+$loader = require __DIR__.'/../vendor/autoload.php';
+
+AnnotationRegistry::registerLoader([$loader, 'loadClass']);
+
+return $loader;
diff --git a/symfony-3.3/app/config/config.yml b/symfony-3.3/app/config/config.yml
new file mode 100644
index 000000000..3292445f9
--- /dev/null
+++ b/symfony-3.3/app/config/config.yml
@@ -0,0 +1,68 @@
+imports:
+    - { resource: parameters.yml }
+    - { resource: security.yml }
+    - { resource: services.yml }
+
+# Put parameters here that don't need to change on each machine where the app is deployed
+# http://symfony.com/doc/current/best_practices/configuration.html#application-related-configuration
+parameters:
+    locale: en
+
+framework:
+    #esi:             ~
+    #translator:      { fallbacks: ["%locale%"] }
+    secret:          "%secret%"
+    router:
+        resource: "%kernel.root_dir%/config/routing.yml"
+        strict_requirements: ~
+    form:            ~
+    csrf_protection: ~
+    validation:      { enable_annotations: true }
+    #serializer:      { enable_annotations: true }
+    templating:
+        engines: ['twig']
+    default_locale:  "%locale%"
+    trusted_hosts:   ~
+    trusted_proxies: ~
+    session:
+        # http://symfony.com/doc/current/reference/configuration/framework.html#handler-id
+        handler_id:  session.handler.native_file
+        save_path:   "%kernel.root_dir%/../var/sessions/%kernel.environment%"
+    fragments:       ~
+    http_method_override: true
+    assets: ~
+
+# Twig Configuration
+twig:
+    debug:            "%kernel.debug%"
+    strict_variables: "%kernel.debug%"
+
+# Doctrine Configuration
+doctrine:
+    dbal:
+        driver:   pdo_mysql
+        host:     "%database_host%"
+        port:     "%database_port%"
+        dbname:   "%database_name%"
+        user:     "%database_user%"
+        password: "%database_password%"
+        charset:  UTF8
+        # if using pdo_sqlite as your database driver:
+        #   1. add the path in parameters.yml
+        #     e.g. database_path: "%kernel.root_dir%/data/data.db3"
+        #   2. Uncomment database_path in parameters.yml.dist
+        #   3. Uncomment next line:
+        #     path:     "%database_path%"
+
+    orm:
+        auto_generate_proxy_classes: "%kernel.debug%"
+        naming_strategy: doctrine.orm.naming_strategy.underscore
+        auto_mapping: true
+
+# Swiftmailer Configuration
+swiftmailer:
+    transport: "%mailer_transport%"
+    host:      "%mailer_host%"
+    username:  "%mailer_user%"
+    password:  "%mailer_password%"
+    spool:     { type: memory }
diff --git a/symfony-3.3/app/config/config_dev.yml b/symfony-3.3/app/config/config_dev.yml
new file mode 100644
index 000000000..7eb4739c0
--- /dev/null
+++ b/symfony-3.3/app/config/config_dev.yml
@@ -0,0 +1,34 @@
+imports:
+    - { resource: config.yml }
+
+framework:
+    router:
+        resource: "%kernel.root_dir%/config/routing_dev.yml"
+        strict_requirements: true
+    profiler: { only_exceptions: false }
+
+web_profiler:
+    toolbar: true
+    intercept_redirects: false
+
+monolog:
+    handlers:
+        main:
+            type: stream
+            path: "%kernel.logs_dir%/%kernel.environment%.log"
+            level: debug
+            channels: [!event]
+        console:
+            type:   console
+            channels: [!event, !doctrine]
+        # uncomment to get logging in your browser
+        # you may have to allow bigger header sizes in your Web server configuration
+        #firephp:
+        #    type:   firephp
+        #    level:  info
+        #chromephp:
+        #    type:   chromephp
+        #    level:  info
+
+#swiftmailer:
+#    delivery_address: me@example.com
diff --git a/symfony-3.3/app/config/config_prod.yml b/symfony-3.3/app/config/config_prod.yml
new file mode 100644
index 000000000..83ef6d6e5
--- /dev/null
+++ b/symfony-3.3/app/config/config_prod.yml
@@ -0,0 +1,27 @@
+imports:
+    - { resource: config.yml }
+
+#framework:
+#    validation:
+#        cache: validator.mapping.cache.doctrine.apc
+#    serializer:
+#        cache: serializer.mapping.cache.doctrine.apc
+
+#doctrine:
+#    orm:
+#        metadata_cache_driver: apc
+#        result_cache_driver: apc
+#        query_cache_driver: apc
+
+monolog:
+    handlers:
+        main:
+            type:         fingers_crossed
+            action_level: error
+            handler:      nested
+        nested:
+            type:  stream
+            path:  "%kernel.logs_dir%/%kernel.environment%.log"
+            level: debug
+        console:
+            type:  console
diff --git a/symfony-3.3/app/config/config_test.yml b/symfony-3.3/app/config/config_test.yml
new file mode 100644
index 000000000..2f6d92503
--- /dev/null
+++ b/symfony-3.3/app/config/config_test.yml
@@ -0,0 +1,16 @@
+imports:
+    - { resource: config_dev.yml }
+
+framework:
+    test: ~
+    session:
+        storage_id: session.storage.mock_file
+    profiler:
+        collect: false
+
+web_profiler:
+    toolbar: false
+    intercept_redirects: false
+
+swiftmailer:
+    disable_delivery: true
diff --git a/symfony-3.3/app/config/parameters.yml.dist b/symfony-3.3/app/config/parameters.yml.dist
new file mode 100644
index 000000000..886c92bb8
--- /dev/null
+++ b/symfony-3.3/app/config/parameters.yml.dist
@@ -0,0 +1,19 @@
+# This file is a "template" of what your parameters.yml file should look like
+# Set parameters here that may be different on each deployment target of the app, e.g. development, staging, production.
+# http://symfony.com/doc/current/best_practices/configuration.html#infrastructure-related-configuration
+parameters:
+    database_host:     127.0.0.1
+    database_port:     ~
+    database_name:     symfony
+    database_user:     root
+    database_password: ~
+    # You should uncomment this if you want use pdo_sqlite
+    # database_path: "%kernel.root_dir%/data.db3"
+
+    mailer_transport:  smtp
+    mailer_host:       127.0.0.1
+    mailer_user:       ~
+    mailer_password:   ~
+
+    # A secret key that's used to generate certain security-related tokens
+    secret:            ThisTokenIsNotSoSecretChangeIt
diff --git a/symfony-3.3/app/config/routing.yml b/symfony-3.3/app/config/routing.yml
new file mode 100644
index 000000000..8eadc31ae
--- /dev/null
+++ b/symfony-3.3/app/config/routing.yml
@@ -0,0 +1,3 @@
+app:
+    resource: "@AppBundle/Controller/"
+    type:     annotation
diff --git a/symfony-3.3/app/config/routing_dev.yml b/symfony-3.3/app/config/routing_dev.yml
new file mode 100644
index 000000000..404f6a3bc
--- /dev/null
+++ b/symfony-3.3/app/config/routing_dev.yml
@@ -0,0 +1,14 @@
+_wdt:
+    resource: "@WebProfilerBundle/Resources/config/routing/wdt.xml"
+    prefix:   /_wdt
+
+_profiler:
+    resource: "@WebProfilerBundle/Resources/config/routing/profiler.xml"
+    prefix:   /_profiler
+
+_errors:
+    resource: "@TwigBundle/Resources/config/routing/errors.xml"
+    prefix:   /_error
+
+_main:
+    resource: routing.yml
diff --git a/symfony-3.3/app/config/security.yml b/symfony-3.3/app/config/security.yml
new file mode 100644
index 000000000..8072372c4
--- /dev/null
+++ b/symfony-3.3/app/config/security.yml
@@ -0,0 +1,24 @@
+# To get started with security, check out the documentation:
+# http://symfony.com/doc/current/book/security.html
+security:
+
+    # http://symfony.com/doc/current/book/security.html#where-do-users-come-from-user-providers
+    providers:
+        in_memory:
+            memory: ~
+
+    firewalls:
+        # disables authentication for assets and the profiler, adapt it according to your needs
+        dev:
+            pattern: ^/(_(profiler|wdt)|css|images|js)/
+            security: false
+
+        main:
+            anonymous: ~
+            # activate different ways to authenticate
+
+            # http_basic: ~
+            # http://symfony.com/doc/current/book/security.html#a-configuring-how-your-users-will-authenticate
+
+            # form_login: ~
+            # http://symfony.com/doc/current/cookbook/security/form_login_setup.html
diff --git a/symfony-3.3/app/config/services.yml b/symfony-3.3/app/config/services.yml
new file mode 100644
index 000000000..5c76fc598
--- /dev/null
+++ b/symfony-3.3/app/config/services.yml
@@ -0,0 +1,9 @@
+# Learn more about services, parameters and containers at
+# http://symfony.com/doc/current/book/service_container.html
+parameters:
+#    parameter_name: value
+
+services:
+#    service_name:
+#        class: AppBundle\Directory\ClassName
+#        arguments: ["@another_service_name", "plain_value", "%parameter_name%"]
diff --git a/symfony-3.3/bin/console b/symfony-3.3/bin/console
new file mode 100755
index 000000000..49247c94d
--- /dev/null
+++ b/symfony-3.3/bin/console
@@ -0,0 +1,29 @@
+#!/usr/bin/env php
+<?php
+
+use Symfony\Bundle\FrameworkBundle\Console\Application;
+use Symfony\Component\Console\Input\ArgvInput;
+use Symfony\Component\Debug\Debug;
+
+// if you don't want to setup permissions the proper way, just uncomment the following PHP line
+// read http://symfony.com/doc/current/book/installation.html#configuration-and-setup for more information
+//umask(0000);
+
+set_time_limit(0);
+
+/**
+ * @var Composer\Autoload\ClassLoader $loader
+ */
+$loader = require __DIR__.'/../app/autoload.php';
+
+$input = new ArgvInput();
+$env = $input->getParameterOption(['--env', '-e'], getenv('SYMFONY_ENV') ?: 'dev');
+$debug = getenv('SYMFONY_DEBUG') !== '0' && !$input->hasParameterOption(['--no-debug', '']) && $env !== 'prod';
+
+if ($debug) {
+    Debug::enable();
+}
+
+$kernel = new AppKernel($env, $debug);
+$application = new Application($kernel);
+$application->run($input);
diff --git a/symfony-3.3/bin/symfony_requirements b/symfony-3.3/bin/symfony_requirements
new file mode 100755
index 000000000..a7bf65a1b
--- /dev/null
+++ b/symfony-3.3/bin/symfony_requirements
@@ -0,0 +1,146 @@
+#!/usr/bin/env php
+<?php
+
+require_once dirname(__FILE__).'/../var/SymfonyRequirements.php';
+
+$lineSize = 70;
+$symfonyRequirements = new SymfonyRequirements();
+$iniPath = $symfonyRequirements->getPhpIniConfigPath();
+
+echo_title('Symfony Requirements Checker');
+
+echo '> PHP is using the following php.ini file:'.PHP_EOL;
+if ($iniPath) {
+    echo_style('green', '  '.$iniPath);
+} else {
+    echo_style('yellow', '  WARNING: No configuration file (php.ini) used by PHP!');
+}
+
+echo PHP_EOL.PHP_EOL;
+
+echo '> Checking Symfony requirements:'.PHP_EOL.'  ';
+
+$messages = array();
+foreach ($symfonyRequirements->getRequirements() as $req) {
+    if ($helpText = get_error_message($req, $lineSize)) {
+        echo_style('red', 'E');
+        $messages['error'][] = $helpText;
+    } else {
+        echo_style('green', '.');
+    }
+}
+
+$checkPassed = empty($messages['error']);
+
+foreach ($symfonyRequirements->getRecommendations() as $req) {
+    if ($helpText = get_error_message($req, $lineSize)) {
+        echo_style('yellow', 'W');
+        $messages['warning'][] = $helpText;
+    } else {
+        echo_style('green', '.');
+    }
+}
+
+if ($checkPassed) {
+    echo_block('success', 'OK', 'Your system is ready to run Symfony projects');
+} else {
+    echo_block('error', 'ERROR', 'Your system is not ready to run Symfony projects');
+
+    echo_title('Fix the following mandatory requirements', 'red');
+
+    foreach ($messages['error'] as $helpText) {
+        echo ' * '.$helpText.PHP_EOL;
+    }
+}
+
+if (!empty($messages['warning'])) {
+    echo_title('Optional recommendations to improve your setup', 'yellow');
+
+    foreach ($messages['warning'] as $helpText) {
+        echo ' * '.$helpText.PHP_EOL;
+    }
+}
+
+echo PHP_EOL;
+echo_style('title', 'Note');
+echo '  The command console could use a different php.ini file'.PHP_EOL;
+echo_style('title', '~~~~');
+echo '  than the one used with your web server. To be on the'.PHP_EOL;
+echo '      safe side, please check the requirements from your web'.PHP_EOL;
+echo '      server using the ';
+echo_style('yellow', 'web/config.php');
+echo ' script.'.PHP_EOL;
+echo PHP_EOL;
+
+exit($checkPassed ? 0 : 1);
+
+function get_error_message(Requirement $requirement, $lineSize)
+{
+    if ($requirement->isFulfilled()) {
+        return;
+    }
+
+    $errorMessage = wordwrap($requirement->getTestMessage(), $lineSize - 3, PHP_EOL.'   ').PHP_EOL;
+    $errorMessage .= '   > '.wordwrap($requirement->getHelpText(), $lineSize - 5, PHP_EOL.'   > ').PHP_EOL;
+
+    return $errorMessage;
+}
+
+function echo_title($title, $style = null)
+{
+    $style = $style ?: 'title';
+
+    echo PHP_EOL;
+    echo_style($style, $title.PHP_EOL);
+    echo_style($style, str_repeat('~', strlen($title)).PHP_EOL);
+    echo PHP_EOL;
+}
+
+function echo_style($style, $message)
+{
+    // ANSI color codes
+    $styles = array(
+        'reset' => "\033[0m",
+        'red' => "\033[31m",
+        'green' => "\033[32m",
+        'yellow' => "\033[33m",
+        'error' => "\033[37;41m",
+        'success' => "\033[37;42m",
+        'title' => "\033[34m",
+    );
+    $supports = has_color_support();
+
+    echo($supports ? $styles[$style] : '').$message.($supports ? $styles['reset'] : '');
+}
+
+function echo_block($style, $title, $message)
+{
+    $message = ' '.trim($message).' ';
+    $width = strlen($message);
+
+    echo PHP_EOL.PHP_EOL;
+
+    echo_style($style, str_repeat(' ', $width));
+    echo PHP_EOL;
+    echo_style($style, str_pad(' ['.$title.']', $width, ' ', STR_PAD_RIGHT));
+    echo PHP_EOL;
+    echo_style($style, $message);
+    echo PHP_EOL;
+    echo_style($style, str_repeat(' ', $width));
+    echo PHP_EOL;
+}
+
+function has_color_support()
+{
+    static $support;
+
+    if (null === $support) {
+        if (DIRECTORY_SEPARATOR == '\\') {
+            $support = false !== getenv('ANSICON') || 'ON' === getenv('ConEmuANSI');
+        } else {
+            $support = function_exists('posix_isatty') && @posix_isatty(STDOUT);
+        }
+    }
+
+    return $support;
+}
diff --git a/symfony-3.3/composer.json b/symfony-3.3/composer.json
new file mode 100644
index 000000000..e6fc6a14a
--- /dev/null
+++ b/symfony-3.3/composer.json
@@ -0,0 +1,69 @@
+{
+    "name": "kenji/symfony.3.3",
+    "license": "proprietary",
+    "type": "project",
+    "autoload": {
+        "psr-4": {
+            "": "src/"
+        },
+        "classmap": [
+            "app/AppKernel.php",
+            "app/AppCache.php"
+        ]
+    },
+    "autoload-dev": {
+        "psr-4": {
+            "Tests\\": "tests/"
+        }
+    },
+    "require": {
+        "php": ">=5.5.9",
+        "symfony/symfony": "3.3.*",
+        "doctrine/orm": "^2.5",
+        "doctrine/doctrine-bundle": "^1.6",
+        "doctrine/doctrine-cache-bundle": "^1.2",
+        "symfony/swiftmailer-bundle": "^2.3",
+        "symfony/monolog-bundle": "^2.8",
+        "sensio/distribution-bundle": "^5.0",
+        "sensio/framework-extra-bundle": "^3.0.2",
+        "incenteev/composer-parameter-handler": "^2.0"
+    },
+    "require-dev": {
+        "sensio/generator-bundle": "^3.0",
+        "symfony/phpunit-bridge": "^3.0"
+    },
+    "scripts": {
+        "post-install-cmd": [
+            "Incenteev\\ParameterHandler\\ScriptHandler::buildParameters",
+            "Sensio\\Bundle\\DistributionBundle\\Composer\\ScriptHandler::buildBootstrap",
+            "Sensio\\Bundle\\DistributionBundle\\Composer\\ScriptHandler::clearCache",
+            "Sensio\\Bundle\\DistributionBundle\\Composer\\ScriptHandler::installAssets",
+            "Sensio\\Bundle\\DistributionBundle\\Composer\\ScriptHandler::installRequirementsFile",
+            "Sensio\\Bundle\\DistributionBundle\\Composer\\ScriptHandler::prepareDeploymentTarget"
+        ],
+        "post-update-cmd": [
+            "Incenteev\\ParameterHandler\\ScriptHandler::buildParameters",
+            "Sensio\\Bundle\\DistributionBundle\\Composer\\ScriptHandler::buildBootstrap",
+            "Sensio\\Bundle\\DistributionBundle\\Composer\\ScriptHandler::clearCache",
+            "Sensio\\Bundle\\DistributionBundle\\Composer\\ScriptHandler::installAssets",
+            "Sensio\\Bundle\\DistributionBundle\\Composer\\ScriptHandler::installRequirementsFile",
+            "Sensio\\Bundle\\DistributionBundle\\Composer\\ScriptHandler::prepareDeploymentTarget"
+        ]
+    },
+    "config": {
+        "platform": {
+            "php": "5.5.9"
+        }
+    },
+    "extra": {
+        "symfony-app-dir": "app",
+        "symfony-bin-dir": "bin",
+        "symfony-var-dir": "var",
+        "symfony-web-dir": "web",
+        "symfony-tests-dir": "tests",
+        "symfony-assets-install": "relative",
+        "incenteev-parameters": {
+            "file": "app/config/parameters.yml"
+        }
+    }
+}
diff --git a/symfony-3.3/composer.lock b/symfony-3.3/composer.lock
new file mode 100644
index 000000000..1b35b6c45
--- /dev/null
+++ b/symfony-3.3/composer.lock
@@ -0,0 +1,2329 @@
+{
+    "_readme": [
+        "This file locks the dependencies of your project to a known state",
+        "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#composer-lock-the-lock-file",
+        "This file is @generated automatically"
+    ],
+    "content-hash": "a723c0e8603b9ee3cc29461e54e74279",
+    "packages": [
+        {
+            "name": "composer/ca-bundle",
+            "version": "1.0.7",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/composer/ca-bundle.git",
+                "reference": "b17e6153cb7f33c7e44eb59578dc12eee5dc8e12"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/composer/ca-bundle/zipball/b17e6153cb7f33c7e44eb59578dc12eee5dc8e12",
+                "reference": "b17e6153cb7f33c7e44eb59578dc12eee5dc8e12",
+                "shasum": ""
+            },
+            "require": {
+                "ext-openssl": "*",
+                "ext-pcre": "*",
+                "php": "^5.3.2 || ^7.0"
+            },
+            "require-dev": {
+                "phpunit/phpunit": "^4.5",
+                "psr/log": "^1.0",
+                "symfony/process": "^2.5 || ^3.0"
+            },
+            "suggest": {
+                "symfony/process": "This is necessary to reliably check whether openssl_x509_parse is vulnerable on older php versions, but can be ignored on PHP 5.5.6+"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "1.x-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Composer\\CaBundle\\": "src"
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Jordi Boggiano",
+                    "email": "j.boggiano@seld.be",
+                    "homepage": "http://seld.be"
+                }
+            ],
+            "description": "Lets you find a path to the system CA bundle, and includes a fallback to the Mozilla CA bundle.",
+            "keywords": [
+                "cabundle",
+                "cacert",
+                "certificate",
+                "ssl",
+                "tls"
+            ],
+            "time": "2017-03-06T11:59:08+00:00"
+        },
+        {
+            "name": "doctrine/annotations",
+            "version": "v1.2.7",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/doctrine/annotations.git",
+                "reference": "f25c8aab83e0c3e976fd7d19875f198ccf2f7535"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/doctrine/annotations/zipball/f25c8aab83e0c3e976fd7d19875f198ccf2f7535",
+                "reference": "f25c8aab83e0c3e976fd7d19875f198ccf2f7535",
+                "shasum": ""
+            },
+            "require": {
+                "doctrine/lexer": "1.*",
+                "php": ">=5.3.2"
+            },
+            "require-dev": {
+                "doctrine/cache": "1.*",
+                "phpunit/phpunit": "4.*"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "1.3.x-dev"
+                }
+            },
+            "autoload": {
+                "psr-0": {
+                    "Doctrine\\Common\\Annotations\\": "lib/"
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Roman Borschel",
+                    "email": "roman@code-factory.org"
+                },
+                {
+                    "name": "Benjamin Eberlei",
+                    "email": "kontakt@beberlei.de"
+                },
+                {
+                    "name": "Guilherme Blanco",
+                    "email": "guilhermeblanco@gmail.com"
+                },
+                {
+                    "name": "Jonathan Wage",
+                    "email": "jonwage@gmail.com"
+                },
+                {
+                    "name": "Johannes Schmitt",
+                    "email": "schmittjoh@gmail.com"
+                }
+            ],
+            "description": "Docblock Annotations Parser",
+            "homepage": "http://www.doctrine-project.org",
+            "keywords": [
+                "annotations",
+                "docblock",
+                "parser"
+            ],
+            "time": "2015-08-31T12:32:49+00:00"
+        },
+        {
+            "name": "doctrine/cache",
+            "version": "v1.6.2",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/doctrine/cache.git",
+                "reference": "eb152c5100571c7a45470ff2a35095ab3f3b900b"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/doctrine/cache/zipball/eb152c5100571c7a45470ff2a35095ab3f3b900b",
+                "reference": "eb152c5100571c7a45470ff2a35095ab3f3b900b",
+                "shasum": ""
+            },
+            "require": {
+                "php": "~5.5|~7.0"
+            },
+            "conflict": {
+                "doctrine/common": ">2.2,<2.4"
+            },
+            "require-dev": {
+                "phpunit/phpunit": "~4.8|~5.0",
+                "predis/predis": "~1.0",
+                "satooshi/php-coveralls": "~0.6"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "1.6.x-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Doctrine\\Common\\Cache\\": "lib/Doctrine/Common/Cache"
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Roman Borschel",
+                    "email": "roman@code-factory.org"
+                },
+                {
+                    "name": "Benjamin Eberlei",
+                    "email": "kontakt@beberlei.de"
+                },
+                {
+                    "name": "Guilherme Blanco",
+                    "email": "guilhermeblanco@gmail.com"
+                },
+                {
+                    "name": "Jonathan Wage",
+                    "email": "jonwage@gmail.com"
+                },
+                {
+                    "name": "Johannes Schmitt",
+                    "email": "schmittjoh@gmail.com"
+                }
+            ],
+            "description": "Caching library offering an object-oriented API for many cache backends",
+            "homepage": "http://www.doctrine-project.org",
+            "keywords": [
+                "cache",
+                "caching"
+            ],
+            "time": "2017-07-22T12:49:21+00:00"
+        },
+        {
+            "name": "doctrine/collections",
+            "version": "v1.3.0",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/doctrine/collections.git",
+                "reference": "6c1e4eef75f310ea1b3e30945e9f06e652128b8a"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/doctrine/collections/zipball/6c1e4eef75f310ea1b3e30945e9f06e652128b8a",
+                "reference": "6c1e4eef75f310ea1b3e30945e9f06e652128b8a",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.3.2"
+            },
+            "require-dev": {
+                "phpunit/phpunit": "~4.0"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "1.2.x-dev"
+                }
+            },
+            "autoload": {
+                "psr-0": {
+                    "Doctrine\\Common\\Collections\\": "lib/"
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Roman Borschel",
+                    "email": "roman@code-factory.org"
+                },
+                {
+                    "name": "Benjamin Eberlei",
+                    "email": "kontakt@beberlei.de"
+                },
+                {
+                    "name": "Guilherme Blanco",
+                    "email": "guilhermeblanco@gmail.com"
+                },
+                {
+                    "name": "Jonathan Wage",
+                    "email": "jonwage@gmail.com"
+                },
+                {
+                    "name": "Johannes Schmitt",
+                    "email": "schmittjoh@gmail.com"
+                }
+            ],
+            "description": "Collections Abstraction library",
+            "homepage": "http://www.doctrine-project.org",
+            "keywords": [
+                "array",
+                "collections",
+                "iterator"
+            ],
+            "time": "2015-04-14T22:21:58+00:00"
+        },
+        {
+            "name": "doctrine/common",
+            "version": "v2.6.2",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/doctrine/common.git",
+                "reference": "7bce00698899aa2c06fe7365c76e4d78ddb15fa3"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/doctrine/common/zipball/7bce00698899aa2c06fe7365c76e4d78ddb15fa3",
+                "reference": "7bce00698899aa2c06fe7365c76e4d78ddb15fa3",
+                "shasum": ""
+            },
+            "require": {
+                "doctrine/annotations": "1.*",
+                "doctrine/cache": "1.*",
+                "doctrine/collections": "1.*",
+                "doctrine/inflector": "1.*",
+                "doctrine/lexer": "1.*",
+                "php": "~5.5|~7.0"
+            },
+            "require-dev": {
+                "phpunit/phpunit": "~4.8|~5.0"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "2.7.x-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Doctrine\\Common\\": "lib/Doctrine/Common"
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Roman Borschel",
+                    "email": "roman@code-factory.org"
+                },
+                {
+                    "name": "Benjamin Eberlei",
+                    "email": "kontakt@beberlei.de"
+                },
+                {
+                    "name": "Guilherme Blanco",
+                    "email": "guilhermeblanco@gmail.com"
+                },
+                {
+                    "name": "Jonathan Wage",
+                    "email": "jonwage@gmail.com"
+                },
+                {
+                    "name": "Johannes Schmitt",
+                    "email": "schmittjoh@gmail.com"
+                }
+            ],
+            "description": "Common Library for Doctrine projects",
+            "homepage": "http://www.doctrine-project.org",
+            "keywords": [
+                "annotations",
+                "collections",
+                "eventmanager",
+                "persistence",
+                "spl"
+            ],
+            "time": "2016-11-30T16:50:46+00:00"
+        },
+        {
+            "name": "doctrine/dbal",
+            "version": "v2.5.13",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/doctrine/dbal.git",
+                "reference": "729340d8d1eec8f01bff708e12e449a3415af873"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/doctrine/dbal/zipball/729340d8d1eec8f01bff708e12e449a3415af873",
+                "reference": "729340d8d1eec8f01bff708e12e449a3415af873",
+                "shasum": ""
+            },
+            "require": {
+                "doctrine/common": ">=2.4,<2.8-dev",
+                "php": ">=5.3.2"
+            },
+            "require-dev": {
+                "phpunit/phpunit": "4.*",
+                "symfony/console": "2.*||^3.0"
+            },
+            "suggest": {
+                "symfony/console": "For helpful console commands such as SQL execution and import of files."
+            },
+            "bin": [
+                "bin/doctrine-dbal"
+            ],
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "2.5.x-dev"
+                }
+            },
+            "autoload": {
+                "psr-0": {
+                    "Doctrine\\DBAL\\": "lib/"
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Roman Borschel",
+                    "email": "roman@code-factory.org"
+                },
+                {
+                    "name": "Benjamin Eberlei",
+                    "email": "kontakt@beberlei.de"
+                },
+                {
+                    "name": "Guilherme Blanco",
+                    "email": "guilhermeblanco@gmail.com"
+                },
+                {
+                    "name": "Jonathan Wage",
+                    "email": "jonwage@gmail.com"
+                }
+            ],
+            "description": "Database Abstraction Layer",
+            "homepage": "http://www.doctrine-project.org",
+            "keywords": [
+                "database",
+                "dbal",
+                "persistence",
+                "queryobject"
+            ],
+            "time": "2017-07-22T20:44:48+00:00"
+        },
+        {
+            "name": "doctrine/doctrine-bundle",
+            "version": "1.6.8",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/doctrine/DoctrineBundle.git",
+                "reference": "6e96577cbbdbb5b6dcca2ff203d665976b51beb0"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/doctrine/DoctrineBundle/zipball/6e96577cbbdbb5b6dcca2ff203d665976b51beb0",
+                "reference": "6e96577cbbdbb5b6dcca2ff203d665976b51beb0",
+                "shasum": ""
+            },
+            "require": {
+                "doctrine/dbal": "~2.3",
+                "doctrine/doctrine-cache-bundle": "~1.2",
+                "jdorn/sql-formatter": "~1.1",
+                "php": ">=5.5.9",
+                "symfony/console": "~2.7|~3.0|~4.0",
+                "symfony/dependency-injection": "~2.7|~3.0|~4.0",
+                "symfony/doctrine-bridge": "~2.7|~3.0|~4.0",
+                "symfony/framework-bundle": "~2.7|~3.0|~4.0"
+            },
+            "require-dev": {
+                "doctrine/orm": "~2.3",
+                "phpunit/phpunit": "~4",
+                "satooshi/php-coveralls": "^1.0",
+                "symfony/phpunit-bridge": "~2.7|~3.0|~4.0",
+                "symfony/property-info": "~2.8|~3.0|~4.0",
+                "symfony/validator": "~2.7|~3.0|~4.0",
+                "symfony/yaml": "~2.7|~3.0|~4.0",
+                "twig/twig": "~1.12|~2.0"
+            },
+            "suggest": {
+                "doctrine/orm": "The Doctrine ORM integration is optional in the bundle.",
+                "symfony/web-profiler-bundle": "To use the data collector."
+            },
+            "type": "symfony-bundle",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "1.6.x-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Doctrine\\Bundle\\DoctrineBundle\\": ""
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Symfony Community",
+                    "homepage": "http://symfony.com/contributors"
+                },
+                {
+                    "name": "Benjamin Eberlei",
+                    "email": "kontakt@beberlei.de"
+                },
+                {
+                    "name": "Doctrine Project",
+                    "homepage": "http://www.doctrine-project.org/"
+                },
+                {
+                    "name": "Fabien Potencier",
+                    "email": "fabien@symfony.com"
+                }
+            ],
+            "description": "Symfony DoctrineBundle",
+            "homepage": "http://www.doctrine-project.org",
+            "keywords": [
+                "database",
+                "dbal",
+                "orm",
+                "persistence"
+            ],
+            "time": "2017-05-18T08:15:18+00:00"
+        },
+        {
+            "name": "doctrine/doctrine-cache-bundle",
+            "version": "1.3.0",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/doctrine/DoctrineCacheBundle.git",
+                "reference": "18c600a9b82f6454d2e81ca4957cdd56a1cf3504"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/doctrine/DoctrineCacheBundle/zipball/18c600a9b82f6454d2e81ca4957cdd56a1cf3504",
+                "reference": "18c600a9b82f6454d2e81ca4957cdd56a1cf3504",
+                "shasum": ""
+            },
+            "require": {
+                "doctrine/cache": "^1.4.2",
+                "doctrine/inflector": "~1.0",
+                "php": ">=5.3.2",
+                "symfony/doctrine-bridge": "~2.2|~3.0"
+            },
+            "require-dev": {
+                "instaclick/coding-standard": "~1.1",
+                "instaclick/object-calisthenics-sniffs": "dev-master",
+                "instaclick/symfony2-coding-standard": "dev-remaster",
+                "phpunit/phpunit": "~4",
+                "predis/predis": "~0.8",
+                "satooshi/php-coveralls": "~0.6.1",
+                "squizlabs/php_codesniffer": "~1.5",
+                "symfony/console": "~2.2|~3.0",
+                "symfony/finder": "~2.2|~3.0",
+                "symfony/framework-bundle": "~2.2|~3.0",
+                "symfony/phpunit-bridge": "~2.7|~3.0",
+                "symfony/security-acl": "~2.3|~3.0",
+                "symfony/validator": "~2.2|~3.0",
+                "symfony/yaml": "~2.2|~3.0"
+            },
+            "suggest": {
+                "symfony/security-acl": "For using this bundle to cache ACLs"
+            },
+            "type": "symfony-bundle",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "1.2.x-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Doctrine\\Bundle\\DoctrineCacheBundle\\": ""
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Symfony Community",
+                    "homepage": "http://symfony.com/contributors"
+                },
+                {
+                    "name": "Benjamin Eberlei",
+                    "email": "kontakt@beberlei.de"
+                },
+                {
+                    "name": "Fabio B. Silva",
+                    "email": "fabio.bat.silva@gmail.com"
+                },
+                {
+                    "name": "Guilherme Blanco",
+                    "email": "guilhermeblanco@hotmail.com"
+                },
+                {
+                    "name": "Doctrine Project",
+                    "homepage": "http://www.doctrine-project.org/"
+                },
+                {
+                    "name": "Fabien Potencier",
+                    "email": "fabien@symfony.com"
+                }
+            ],
+            "description": "Symfony Bundle for Doctrine Cache",
+            "homepage": "http://www.doctrine-project.org",
+            "keywords": [
+                "cache",
+                "caching"
+            ],
+            "time": "2016-01-26T17:28:51+00:00"
+        },
+        {
+            "name": "doctrine/inflector",
+            "version": "v1.1.0",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/doctrine/inflector.git",
+                "reference": "90b2128806bfde671b6952ab8bea493942c1fdae"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/doctrine/inflector/zipball/90b2128806bfde671b6952ab8bea493942c1fdae",
+                "reference": "90b2128806bfde671b6952ab8bea493942c1fdae",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.3.2"
+            },
+            "require-dev": {
+                "phpunit/phpunit": "4.*"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "1.1.x-dev"
+                }
+            },
+            "autoload": {
+                "psr-0": {
+                    "Doctrine\\Common\\Inflector\\": "lib/"
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Roman Borschel",
+                    "email": "roman@code-factory.org"
+                },
+                {
+                    "name": "Benjamin Eberlei",
+                    "email": "kontakt@beberlei.de"
+                },
+                {
+                    "name": "Guilherme Blanco",
+                    "email": "guilhermeblanco@gmail.com"
+                },
+                {
+                    "name": "Jonathan Wage",
+                    "email": "jonwage@gmail.com"
+                },
+                {
+                    "name": "Johannes Schmitt",
+                    "email": "schmittjoh@gmail.com"
+                }
+            ],
+            "description": "Common String Manipulations with regard to casing and singular/plural rules.",
+            "homepage": "http://www.doctrine-project.org",
+            "keywords": [
+                "inflection",
+                "pluralize",
+                "singularize",
+                "string"
+            ],
+            "time": "2015-11-06T14:35:42+00:00"
+        },
+        {
+            "name": "doctrine/instantiator",
+            "version": "1.0.5",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/doctrine/instantiator.git",
+                "reference": "8e884e78f9f0eb1329e445619e04456e64d8051d"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/doctrine/instantiator/zipball/8e884e78f9f0eb1329e445619e04456e64d8051d",
+                "reference": "8e884e78f9f0eb1329e445619e04456e64d8051d",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.3,<8.0-DEV"
+            },
+            "require-dev": {
+                "athletic/athletic": "~0.1.8",
+                "ext-pdo": "*",
+                "ext-phar": "*",
+                "phpunit/phpunit": "~4.0",
+                "squizlabs/php_codesniffer": "~2.0"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "1.0.x-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Doctrine\\Instantiator\\": "src/Doctrine/Instantiator/"
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Marco Pivetta",
+                    "email": "ocramius@gmail.com",
+                    "homepage": "http://ocramius.github.com/"
+                }
+            ],
+            "description": "A small, lightweight utility to instantiate objects in PHP without invoking their constructors",
+            "homepage": "https://github.com/doctrine/instantiator",
+            "keywords": [
+                "constructor",
+                "instantiate"
+            ],
+            "time": "2015-06-14T21:17:01+00:00"
+        },
+        {
+            "name": "doctrine/lexer",
+            "version": "v1.0.1",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/doctrine/lexer.git",
+                "reference": "83893c552fd2045dd78aef794c31e694c37c0b8c"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/doctrine/lexer/zipball/83893c552fd2045dd78aef794c31e694c37c0b8c",
+                "reference": "83893c552fd2045dd78aef794c31e694c37c0b8c",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.3.2"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "1.0.x-dev"
+                }
+            },
+            "autoload": {
+                "psr-0": {
+                    "Doctrine\\Common\\Lexer\\": "lib/"
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Roman Borschel",
+                    "email": "roman@code-factory.org"
+                },
+                {
+                    "name": "Guilherme Blanco",
+                    "email": "guilhermeblanco@gmail.com"
+                },
+                {
+                    "name": "Johannes Schmitt",
+                    "email": "schmittjoh@gmail.com"
+                }
+            ],
+            "description": "Base library for a lexer that can be used in Top-Down, Recursive Descent Parsers.",
+            "homepage": "http://www.doctrine-project.org",
+            "keywords": [
+                "lexer",
+                "parser"
+            ],
+            "time": "2014-09-09T13:34:57+00:00"
+        },
+        {
+            "name": "doctrine/orm",
+            "version": "v2.5.6",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/doctrine/doctrine2.git",
+                "reference": "e6c434196c8ef058239aaa0724b4aadb0107940b"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/doctrine/doctrine2/zipball/e6c434196c8ef058239aaa0724b4aadb0107940b",
+                "reference": "e6c434196c8ef058239aaa0724b4aadb0107940b",
+                "shasum": ""
+            },
+            "require": {
+                "doctrine/cache": "~1.4",
+                "doctrine/collections": "~1.2",
+                "doctrine/common": ">=2.5-dev,<2.8-dev",
+                "doctrine/dbal": ">=2.5-dev,<2.6-dev",
+                "doctrine/instantiator": "~1.0.1",
+                "ext-pdo": "*",
+                "php": ">=5.4",
+                "symfony/console": "~2.5|~3.0"
+            },
+            "require-dev": {
+                "phpunit/phpunit": "~4.0",
+                "symfony/yaml": "~2.3|~3.0"
+            },
+            "suggest": {
+                "symfony/yaml": "If you want to use YAML Metadata Mapping Driver"
+            },
+            "bin": [
+                "bin/doctrine",
+                "bin/doctrine.php"
+            ],
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "2.6.x-dev"
+                }
+            },
+            "autoload": {
+                "psr-0": {
+                    "Doctrine\\ORM\\": "lib/"
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Roman Borschel",
+                    "email": "roman@code-factory.org"
+                },
+                {
+                    "name": "Benjamin Eberlei",
+                    "email": "kontakt@beberlei.de"
+                },
+                {
+                    "name": "Guilherme Blanco",
+                    "email": "guilhermeblanco@gmail.com"
+                },
+                {
+                    "name": "Jonathan Wage",
+                    "email": "jonwage@gmail.com"
+                }
+            ],
+            "description": "Object-Relational-Mapper for PHP",
+            "homepage": "http://www.doctrine-project.org",
+            "keywords": [
+                "database",
+                "orm"
+            ],
+            "time": "2016-12-18T15:42:34+00:00"
+        },
+        {
+            "name": "fig/link-util",
+            "version": "1.0.0",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/php-fig/link-util.git",
+                "reference": "1a07821801a148be4add11ab0603e4af55a72fac"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/php-fig/link-util/zipball/1a07821801a148be4add11ab0603e4af55a72fac",
+                "reference": "1a07821801a148be4add11ab0603e4af55a72fac",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.5.0",
+                "psr/link": "~1.0@dev"
+            },
+            "require-dev": {
+                "phpunit/phpunit": "^5.1",
+                "squizlabs/php_codesniffer": "^2.3.1"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "1.0.x-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Fig\\Link\\": "src/"
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "PHP-FIG",
+                    "homepage": "http://www.php-fig.org/"
+                }
+            ],
+            "description": "Common utility implementations for HTTP links",
+            "keywords": [
+                "http",
+                "http-link",
+                "link",
+                "psr",
+                "psr-13",
+                "rest"
+            ],
+            "time": "2016-10-17T18:31:11+00:00"
+        },
+        {
+            "name": "incenteev/composer-parameter-handler",
+            "version": "v2.1.2",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/Incenteev/ParameterHandler.git",
+                "reference": "d7ce7f06136109e81d1cb9d57066c4d4a99cf1cc"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/Incenteev/ParameterHandler/zipball/d7ce7f06136109e81d1cb9d57066c4d4a99cf1cc",
+                "reference": "d7ce7f06136109e81d1cb9d57066c4d4a99cf1cc",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.3.3",
+                "symfony/yaml": "~2.3|~3.0"
+            },
+            "require-dev": {
+                "composer/composer": "1.0.*@dev",
+                "phpspec/prophecy-phpunit": "~1.0",
+                "symfony/filesystem": "~2.2"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "2.1.x-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Incenteev\\ParameterHandler\\": ""
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Christophe Coevoet",
+                    "email": "stof@notk.org"
+                }
+            ],
+            "description": "Composer script handling your ignored parameter file",
+            "homepage": "https://github.com/Incenteev/ParameterHandler",
+            "keywords": [
+                "parameters management"
+            ],
+            "time": "2015-11-10T17:04:01+00:00"
+        },
+        {
+            "name": "jdorn/sql-formatter",
+            "version": "v1.2.17",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/jdorn/sql-formatter.git",
+                "reference": "64990d96e0959dff8e059dfcdc1af130728d92bc"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/jdorn/sql-formatter/zipball/64990d96e0959dff8e059dfcdc1af130728d92bc",
+                "reference": "64990d96e0959dff8e059dfcdc1af130728d92bc",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.2.4"
+            },
+            "require-dev": {
+                "phpunit/phpunit": "3.7.*"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "1.3.x-dev"
+                }
+            },
+            "autoload": {
+                "classmap": [
+                    "lib"
+                ]
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Jeremy Dorn",
+                    "email": "jeremy@jeremydorn.com",
+                    "homepage": "http://jeremydorn.com/"
+                }
+            ],
+            "description": "a PHP SQL highlighting library",
+            "homepage": "https://github.com/jdorn/sql-formatter/",
+            "keywords": [
+                "highlight",
+                "sql"
+            ],
+            "time": "2014-01-12T16:20:24+00:00"
+        },
+        {
+            "name": "monolog/monolog",
+            "version": "1.23.0",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/Seldaek/monolog.git",
+                "reference": "fd8c787753b3a2ad11bc60c063cff1358a32a3b4"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/Seldaek/monolog/zipball/fd8c787753b3a2ad11bc60c063cff1358a32a3b4",
+                "reference": "fd8c787753b3a2ad11bc60c063cff1358a32a3b4",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.3.0",
+                "psr/log": "~1.0"
+            },
+            "provide": {
+                "psr/log-implementation": "1.0.0"
+            },
+            "require-dev": {
+                "aws/aws-sdk-php": "^2.4.9 || ^3.0",
+                "doctrine/couchdb": "~1.0@dev",
+                "graylog2/gelf-php": "~1.0",
+                "jakub-onderka/php-parallel-lint": "0.9",
+                "php-amqplib/php-amqplib": "~2.4",
+                "php-console/php-console": "^3.1.3",
+                "phpunit/phpunit": "~4.5",
+                "phpunit/phpunit-mock-objects": "2.3.0",
+                "ruflin/elastica": ">=0.90 <3.0",
+                "sentry/sentry": "^0.13",
+                "swiftmailer/swiftmailer": "^5.3|^6.0"
+            },
+            "suggest": {
+                "aws/aws-sdk-php": "Allow sending log messages to AWS services like DynamoDB",
+                "doctrine/couchdb": "Allow sending log messages to a CouchDB server",
+                "ext-amqp": "Allow sending log messages to an AMQP server (1.0+ required)",
+                "ext-mongo": "Allow sending log messages to a MongoDB server",
+                "graylog2/gelf-php": "Allow sending log messages to a GrayLog2 server",
+                "mongodb/mongodb": "Allow sending log messages to a MongoDB server via PHP Driver",
+                "php-amqplib/php-amqplib": "Allow sending log messages to an AMQP server using php-amqplib",
+                "php-console/php-console": "Allow sending log messages to Google Chrome",
+                "rollbar/rollbar": "Allow sending log messages to Rollbar",
+                "ruflin/elastica": "Allow sending log messages to an Elastic Search server",
+                "sentry/sentry": "Allow sending log messages to a Sentry server"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "2.0.x-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Monolog\\": "src/Monolog"
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Jordi Boggiano",
+                    "email": "j.boggiano@seld.be",
+                    "homepage": "http://seld.be"
+                }
+            ],
+            "description": "Sends your logs to files, sockets, inboxes, databases and various web services",
+            "homepage": "http://github.com/Seldaek/monolog",
+            "keywords": [
+                "log",
+                "logging",
+                "psr-3"
+            ],
+            "time": "2017-06-19T01:22:40+00:00"
+        },
+        {
+            "name": "paragonie/random_compat",
+            "version": "v2.0.10",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/paragonie/random_compat.git",
+                "reference": "634bae8e911eefa89c1abfbf1b66da679ac8f54d"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/paragonie/random_compat/zipball/634bae8e911eefa89c1abfbf1b66da679ac8f54d",
+                "reference": "634bae8e911eefa89c1abfbf1b66da679ac8f54d",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.2.0"
+            },
+            "require-dev": {
+                "phpunit/phpunit": "4.*|5.*"
+            },
+            "suggest": {
+                "ext-libsodium": "Provides a modern crypto API that can be used to generate random bytes."
+            },
+            "type": "library",
+            "autoload": {
+                "files": [
+                    "lib/random.php"
+                ]
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Paragon Initiative Enterprises",
+                    "email": "security@paragonie.com",
+                    "homepage": "https://paragonie.com"
+                }
+            ],
+            "description": "PHP 5.x polyfill for random_bytes() and random_int() from PHP 7",
+            "keywords": [
+                "csprng",
+                "pseudorandom",
+                "random"
+            ],
+            "time": "2017-03-13T16:27:32+00:00"
+        },
+        {
+            "name": "psr/cache",
+            "version": "1.0.1",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/php-fig/cache.git",
+                "reference": "d11b50ad223250cf17b86e38383413f5a6764bf8"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/php-fig/cache/zipball/d11b50ad223250cf17b86e38383413f5a6764bf8",
+                "reference": "d11b50ad223250cf17b86e38383413f5a6764bf8",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.3.0"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "1.0.x-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Psr\\Cache\\": "src/"
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "PHP-FIG",
+                    "homepage": "http://www.php-fig.org/"
+                }
+            ],
+            "description": "Common interface for caching libraries",
+            "keywords": [
+                "cache",
+                "psr",
+                "psr-6"
+            ],
+            "time": "2016-08-06T20:24:11+00:00"
+        },
+        {
+            "name": "psr/container",
+            "version": "1.0.0",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/php-fig/container.git",
+                "reference": "b7ce3b176482dbbc1245ebf52b181af44c2cf55f"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/php-fig/container/zipball/b7ce3b176482dbbc1245ebf52b181af44c2cf55f",
+                "reference": "b7ce3b176482dbbc1245ebf52b181af44c2cf55f",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.3.0"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "1.0.x-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Psr\\Container\\": "src/"
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "PHP-FIG",
+                    "homepage": "http://www.php-fig.org/"
+                }
+            ],
+            "description": "Common Container Interface (PHP FIG PSR-11)",
+            "homepage": "https://github.com/php-fig/container",
+            "keywords": [
+                "PSR-11",
+                "container",
+                "container-interface",
+                "container-interop",
+                "psr"
+            ],
+            "time": "2017-02-14T16:28:37+00:00"
+        },
+        {
+            "name": "psr/link",
+            "version": "1.0.0",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/php-fig/link.git",
+                "reference": "eea8e8662d5cd3ae4517c9b864493f59fca95562"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/php-fig/link/zipball/eea8e8662d5cd3ae4517c9b864493f59fca95562",
+                "reference": "eea8e8662d5cd3ae4517c9b864493f59fca95562",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.3.0"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "1.0.x-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Psr\\Link\\": "src/"
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "PHP-FIG",
+                    "homepage": "http://www.php-fig.org/"
+                }
+            ],
+            "description": "Common interfaces for HTTP links",
+            "keywords": [
+                "http",
+                "http-link",
+                "link",
+                "psr",
+                "psr-13",
+                "rest"
+            ],
+            "time": "2016-10-28T16:06:13+00:00"
+        },
+        {
+            "name": "psr/log",
+            "version": "1.0.2",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/php-fig/log.git",
+                "reference": "4ebe3a8bf773a19edfe0a84b6585ba3d401b724d"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/php-fig/log/zipball/4ebe3a8bf773a19edfe0a84b6585ba3d401b724d",
+                "reference": "4ebe3a8bf773a19edfe0a84b6585ba3d401b724d",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.3.0"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "1.0.x-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Psr\\Log\\": "Psr/Log/"
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "PHP-FIG",
+                    "homepage": "http://www.php-fig.org/"
+                }
+            ],
+            "description": "Common interface for logging libraries",
+            "homepage": "https://github.com/php-fig/log",
+            "keywords": [
+                "log",
+                "psr",
+                "psr-3"
+            ],
+            "time": "2016-10-10T12:19:37+00:00"
+        },
+        {
+            "name": "psr/simple-cache",
+            "version": "1.0.0",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/php-fig/simple-cache.git",
+                "reference": "753fa598e8f3b9966c886fe13f370baa45ef0e24"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/php-fig/simple-cache/zipball/753fa598e8f3b9966c886fe13f370baa45ef0e24",
+                "reference": "753fa598e8f3b9966c886fe13f370baa45ef0e24",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.3.0"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "1.0.x-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Psr\\SimpleCache\\": "src/"
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "PHP-FIG",
+                    "homepage": "http://www.php-fig.org/"
+                }
+            ],
+            "description": "Common interfaces for simple caching",
+            "keywords": [
+                "cache",
+                "caching",
+                "psr",
+                "psr-16",
+                "simple-cache"
+            ],
+            "time": "2017-01-02T13:31:39+00:00"
+        },
+        {
+            "name": "sensio/distribution-bundle",
+            "version": "v5.0.20",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/sensiolabs/SensioDistributionBundle.git",
+                "reference": "4b019d4c0bd64438c42e4b6b0726085b409be8d9"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/sensiolabs/SensioDistributionBundle/zipball/4b019d4c0bd64438c42e4b6b0726085b409be8d9",
+                "reference": "4b019d4c0bd64438c42e4b6b0726085b409be8d9",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.3.9",
+                "sensiolabs/security-checker": "~3.0|~4.0",
+                "symfony/class-loader": "~2.3|~3.0",
+                "symfony/config": "~2.3|~3.0",
+                "symfony/dependency-injection": "~2.3|~3.0",
+                "symfony/filesystem": "~2.3|~3.0",
+                "symfony/http-kernel": "~2.3|~3.0",
+                "symfony/process": "~2.3|~3.0"
+            },
+            "type": "symfony-bundle",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "5.0.x-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Sensio\\Bundle\\DistributionBundle\\": ""
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Fabien Potencier",
+                    "email": "fabien@symfony.com"
+                }
+            ],
+            "description": "Base bundle for Symfony Distributions",
+            "keywords": [
+                "configuration",
+                "distribution"
+            ],
+            "time": "2017-05-11T16:21:03+00:00"
+        },
+        {
+            "name": "sensio/framework-extra-bundle",
+            "version": "v3.0.26",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/sensiolabs/SensioFrameworkExtraBundle.git",
+                "reference": "6d6cbe971554f0a2cc84965850481eb04a2a0059"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/sensiolabs/SensioFrameworkExtraBundle/zipball/6d6cbe971554f0a2cc84965850481eb04a2a0059",
+                "reference": "6d6cbe971554f0a2cc84965850481eb04a2a0059",
+                "shasum": ""
+            },
+            "require": {
+                "doctrine/common": "~2.2",
+                "symfony/dependency-injection": "~2.3|~3.0",
+                "symfony/framework-bundle": "~2.3|~3.0"
+            },
+            "require-dev": {
+                "doctrine/doctrine-bundle": "~1.5",
+                "doctrine/orm": "~2.4,>=2.4.5",
+                "symfony/asset": "~2.7|~3.0",
+                "symfony/browser-kit": "~2.3|~3.0",
+                "symfony/dom-crawler": "~2.3|~3.0",
+                "symfony/expression-language": "~2.4|~3.0",
+                "symfony/finder": "~2.3|~3.0",
+                "symfony/phpunit-bridge": "~3.2",
+                "symfony/psr-http-message-bridge": "^0.3",
+                "symfony/security-bundle": "~2.4|~3.0",
+                "symfony/templating": "~2.3|~3.0",
+                "symfony/translation": "~2.3|~3.0",
+                "symfony/twig-bundle": "~2.3|~3.0",
+                "symfony/yaml": "~2.3|~3.0",
+                "twig/twig": "~1.12|~2.0",
+                "zendframework/zend-diactoros": "^1.3"
+            },
+            "suggest": {
+                "symfony/expression-language": "",
+                "symfony/psr-http-message-bridge": "To use the PSR-7 converters",
+                "symfony/security-bundle": ""
+            },
+            "type": "symfony-bundle",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "3.0.x-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Sensio\\Bundle\\FrameworkExtraBundle\\": ""
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Fabien Potencier",
+                    "email": "fabien@symfony.com"
+                }
+            ],
+            "description": "This bundle provides a way to configure your controllers with annotations",
+            "keywords": [
+                "annotations",
+                "controllers"
+            ],
+            "time": "2017-05-11T17:01:57+00:00"
+        },
+        {
+            "name": "sensiolabs/security-checker",
+            "version": "v4.0.5",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/sensiolabs/security-checker.git",
+                "reference": "6a3b0c3b42e41c777b1ad75032d8177863fdc5e1"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/sensiolabs/security-checker/zipball/6a3b0c3b42e41c777b1ad75032d8177863fdc5e1",
+                "reference": "6a3b0c3b42e41c777b1ad75032d8177863fdc5e1",
+                "shasum": ""
+            },
+            "require": {
+                "composer/ca-bundle": "^1.0",
+                "symfony/console": "~2.7|~3.0"
+            },
+            "bin": [
+                "security-checker"
+            ],
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "4.0-dev"
+                }
+            },
+            "autoload": {
+                "psr-0": {
+                    "SensioLabs\\Security": ""
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Fabien Potencier",
+                    "email": "fabien.potencier@gmail.com"
+                }
+            ],
+            "description": "A security checker for your composer.lock",
+            "time": "2017-07-24T11:42:56+00:00"
+        },
+        {
+            "name": "swiftmailer/swiftmailer",
+            "version": "v5.4.8",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/swiftmailer/swiftmailer.git",
+                "reference": "9a06dc570a0367850280eefd3f1dc2da45aef517"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/swiftmailer/swiftmailer/zipball/9a06dc570a0367850280eefd3f1dc2da45aef517",
+                "reference": "9a06dc570a0367850280eefd3f1dc2da45aef517",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.3.3"
+            },
+            "require-dev": {
+                "mockery/mockery": "~0.9.1",
+                "symfony/phpunit-bridge": "~3.2"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "5.4-dev"
+                }
+            },
+            "autoload": {
+                "files": [
+                    "lib/swift_required.php"
+                ]
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Chris Corbyn"
+                },
+                {
+                    "name": "Fabien Potencier",
+                    "email": "fabien@symfony.com"
+                }
+            ],
+            "description": "Swiftmailer, free feature-rich PHP mailer",
+            "homepage": "http://swiftmailer.org",
+            "keywords": [
+                "email",
+                "mail",
+                "mailer"
+            ],
+            "time": "2017-05-01T15:54:03+00:00"
+        },
+        {
+            "name": "symfony/monolog-bundle",
+            "version": "v2.12.1",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/monolog-bundle.git",
+                "reference": "b0146bdca7ba2a65f3bbe7010423c7393b29ec3f"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/monolog-bundle/zipball/b0146bdca7ba2a65f3bbe7010423c7393b29ec3f",
+                "reference": "b0146bdca7ba2a65f3bbe7010423c7393b29ec3f",
+                "shasum": ""
+            },
+            "require": {
+                "monolog/monolog": "~1.18",
+                "php": ">=5.3.2",
+                "symfony/config": "~2.3|~3.0",
+                "symfony/dependency-injection": "~2.3|~3.0",
+                "symfony/http-kernel": "~2.3|~3.0",
+                "symfony/monolog-bridge": "~2.3|~3.0"
+            },
+            "require-dev": {
+                "phpunit/phpunit": "^4.8",
+                "symfony/console": "~2.3|~3.0",
+                "symfony/yaml": "~2.3|~3.0"
+            },
+            "type": "symfony-bundle",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "2.x-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Bundle\\MonologBundle\\": ""
+                }
+            },
+            "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 MonologBundle",
+            "homepage": "http://symfony.com",
+            "keywords": [
+                "log",
+                "logging"
+            ],
+            "time": "2017-01-02T19:04:26+00:00"
+        },
+        {
+            "name": "symfony/polyfill-intl-icu",
+            "version": "v1.4.0",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/polyfill-intl-icu.git",
+                "reference": "3191cbe0ce64987bd382daf6724af31c53daae01"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/polyfill-intl-icu/zipball/3191cbe0ce64987bd382daf6724af31c53daae01",
+                "reference": "3191cbe0ce64987bd382daf6724af31c53daae01",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.3.3",
+                "symfony/intl": "~2.3|~3.0|~4.0"
+            },
+            "suggest": {
+                "ext-intl": "For best performance"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "1.4-dev"
+                }
+            },
+            "autoload": {
+                "files": [
+                    "bootstrap.php"
+                ]
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Nicolas Grekas",
+                    "email": "p@tchwork.com"
+                },
+                {
+                    "name": "Symfony Community",
+                    "homepage": "https://symfony.com/contributors"
+                }
+            ],
+            "description": "Symfony polyfill for intl's ICU-related data and classes",
+            "homepage": "https://symfony.com",
+            "keywords": [
+                "compatibility",
+                "icu",
+                "intl",
+                "polyfill",
+                "portable",
+                "shim"
+            ],
+            "time": "2017-06-09T08:25:21+00:00"
+        },
+        {
+            "name": "symfony/polyfill-mbstring",
+            "version": "v1.4.0",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/polyfill-mbstring.git",
+                "reference": "f29dca382a6485c3cbe6379f0c61230167681937"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/polyfill-mbstring/zipball/f29dca382a6485c3cbe6379f0c61230167681937",
+                "reference": "f29dca382a6485c3cbe6379f0c61230167681937",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.3.3"
+            },
+            "suggest": {
+                "ext-mbstring": "For best performance"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "1.4-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Polyfill\\Mbstring\\": ""
+                },
+                "files": [
+                    "bootstrap.php"
+                ]
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Nicolas Grekas",
+                    "email": "p@tchwork.com"
+                },
+                {
+                    "name": "Symfony Community",
+                    "homepage": "https://symfony.com/contributors"
+                }
+            ],
+            "description": "Symfony polyfill for the Mbstring extension",
+            "homepage": "https://symfony.com",
+            "keywords": [
+                "compatibility",
+                "mbstring",
+                "polyfill",
+                "portable",
+                "shim"
+            ],
+            "time": "2017-06-09T14:24:12+00:00"
+        },
+        {
+            "name": "symfony/polyfill-php56",
+            "version": "v1.4.0",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/polyfill-php56.git",
+                "reference": "bc0b7d6cb36b10cfabb170a3e359944a95174929"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/polyfill-php56/zipball/bc0b7d6cb36b10cfabb170a3e359944a95174929",
+                "reference": "bc0b7d6cb36b10cfabb170a3e359944a95174929",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.3.3",
+                "symfony/polyfill-util": "~1.0"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "1.4-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Polyfill\\Php56\\": ""
+                },
+                "files": [
+                    "bootstrap.php"
+                ]
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Nicolas Grekas",
+                    "email": "p@tchwork.com"
+                },
+                {
+                    "name": "Symfony Community",
+                    "homepage": "https://symfony.com/contributors"
+                }
+            ],
+            "description": "Symfony polyfill backporting some PHP 5.6+ features to lower PHP versions",
+            "homepage": "https://symfony.com",
+            "keywords": [
+                "compatibility",
+                "polyfill",
+                "portable",
+                "shim"
+            ],
+            "time": "2017-06-09T08:25:21+00:00"
+        },
+        {
+            "name": "symfony/polyfill-php70",
+            "version": "v1.4.0",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/polyfill-php70.git",
+                "reference": "032fd647d5c11a9ceab8ee8747e13b5448e93874"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/polyfill-php70/zipball/032fd647d5c11a9ceab8ee8747e13b5448e93874",
+                "reference": "032fd647d5c11a9ceab8ee8747e13b5448e93874",
+                "shasum": ""
+            },
+            "require": {
+                "paragonie/random_compat": "~1.0|~2.0",
+                "php": ">=5.3.3"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "1.4-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Polyfill\\Php70\\": ""
+                },
+                "files": [
+                    "bootstrap.php"
+                ],
+                "classmap": [
+                    "Resources/stubs"
+                ]
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Nicolas Grekas",
+                    "email": "p@tchwork.com"
+                },
+                {
+                    "name": "Symfony Community",
+                    "homepage": "https://symfony.com/contributors"
+                }
+            ],
+            "description": "Symfony polyfill backporting some PHP 7.0+ features to lower PHP versions",
+            "homepage": "https://symfony.com",
+            "keywords": [
+                "compatibility",
+                "polyfill",
+                "portable",
+                "shim"
+            ],
+            "time": "2017-06-09T14:24:12+00:00"
+        },
+        {
+            "name": "symfony/polyfill-util",
+            "version": "v1.4.0",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/polyfill-util.git",
+                "reference": "ebccbde4aad410f6438d86d7d261c6b4d2b9a51d"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/polyfill-util/zipball/ebccbde4aad410f6438d86d7d261c6b4d2b9a51d",
+                "reference": "ebccbde4aad410f6438d86d7d261c6b4d2b9a51d",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.3.3"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "1.4-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Polyfill\\Util\\": ""
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Nicolas Grekas",
+                    "email": "p@tchwork.com"
+                },
+                {
+                    "name": "Symfony Community",
+                    "homepage": "https://symfony.com/contributors"
+                }
+            ],
+            "description": "Symfony utilities for portability of PHP codes",
+            "homepage": "https://symfony.com",
+            "keywords": [
+                "compat",
+                "compatibility",
+                "polyfill",
+                "shim"
+            ],
+            "time": "2017-06-09T08:25:21+00:00"
+        },
+        {
+            "name": "symfony/swiftmailer-bundle",
+            "version": "v2.6.3",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/swiftmailer-bundle.git",
+                "reference": "11555c338f3c367b0a1bd2f024a53aa813f4ce00"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/swiftmailer-bundle/zipball/11555c338f3c367b0a1bd2f024a53aa813f4ce00",
+                "reference": "11555c338f3c367b0a1bd2f024a53aa813f4ce00",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.3.2",
+                "swiftmailer/swiftmailer": "~4.2|~5.0",
+                "symfony/config": "~2.7|~3.0",
+                "symfony/dependency-injection": "~2.7|~3.0",
+                "symfony/http-kernel": "~2.7|~3.0"
+            },
+            "require-dev": {
+                "symfony/console": "~2.7|~3.0",
+                "symfony/framework-bundle": "~2.7|~3.0",
+                "symfony/phpunit-bridge": "~3.3@dev",
+                "symfony/yaml": "~2.7|~3.0"
+            },
+            "suggest": {
+                "psr/log": "Allows logging"
+            },
+            "type": "symfony-bundle",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "2.6-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Bundle\\SwiftmailerBundle\\": ""
+                }
+            },
+            "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 SwiftmailerBundle",
+            "homepage": "http://symfony.com",
+            "time": "2017-07-22T07:18:13+00:00"
+        },
+        {
+            "name": "symfony/symfony",
+            "version": "v3.3.5",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/symfony.git",
+                "reference": "b9a0d3d2393f683b28043e9dbf83b8bf6b347faa"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/symfony/zipball/b9a0d3d2393f683b28043e9dbf83b8bf6b347faa",
+                "reference": "b9a0d3d2393f683b28043e9dbf83b8bf6b347faa",
+                "shasum": ""
+            },
+            "require": {
+                "doctrine/common": "~2.4",
+                "ext-xml": "*",
+                "fig/link-util": "^1.0",
+                "php": ">=5.5.9",
+                "psr/cache": "~1.0",
+                "psr/container": "^1.0",
+                "psr/link": "^1.0",
+                "psr/log": "~1.0",
+                "psr/simple-cache": "^1.0",
+                "symfony/polyfill-intl-icu": "~1.0",
+                "symfony/polyfill-mbstring": "~1.0",
+                "symfony/polyfill-php56": "~1.0",
+                "symfony/polyfill-php70": "~1.0",
+                "symfony/polyfill-util": "~1.0",
+                "twig/twig": "~1.34|~2.4"
+            },
+            "conflict": {
+                "phpdocumentor/reflection-docblock": "<3.0||>=3.2.0",
+                "phpdocumentor/type-resolver": "<0.2.0",
+                "phpunit/phpunit": "<4.8.35|<5.4.3,>=5.0"
+            },
+            "provide": {
+                "psr/cache-implementation": "1.0",
+                "psr/container-implementation": "1.0",
+                "psr/simple-cache-implementation": "1.0"
+            },
+            "replace": {
+                "symfony/asset": "self.version",
+                "symfony/browser-kit": "self.version",
+                "symfony/cache": "self.version",
+                "symfony/class-loader": "self.version",
+                "symfony/config": "self.version",
+                "symfony/console": "self.version",
+                "symfony/css-selector": "self.version",
+                "symfony/debug": "self.version",
+                "symfony/debug-bundle": "self.version",
+                "symfony/dependency-injection": "self.version",
+                "symfony/doctrine-bridge": "self.version",
+                "symfony/dom-crawler": "self.version",
+                "symfony/dotenv": "self.version",
+                "symfony/event-dispatcher": "self.version",
+                "symfony/expression-language": "self.version",
+                "symfony/filesystem": "self.version",
+                "symfony/finder": "self.version",
+                "symfony/form": "self.version",
+                "symfony/framework-bundle": "self.version",
+                "symfony/http-foundation": "self.version",
+                "symfony/http-kernel": "self.version",
+                "symfony/inflector": "self.version",
+                "symfony/intl": "self.version",
+                "symfony/ldap": "self.version",
+                "symfony/monolog-bridge": "self.version",
+                "symfony/options-resolver": "self.version",
+                "symfony/process": "self.version",
+                "symfony/property-access": "self.version",
+                "symfony/property-info": "self.version",
+                "symfony/proxy-manager-bridge": "self.version",
+                "symfony/routing": "self.version",
+                "symfony/security": "self.version",
+                "symfony/security-bundle": "self.version",
+                "symfony/security-core": "self.version",
+                "symfony/security-csrf": "self.version",
+                "symfony/security-guard": "self.version",
+                "symfony/security-http": "self.version",
+                "symfony/serializer": "self.version",
+                "symfony/stopwatch": "self.version",
+                "symfony/templating": "self.version",
+                "symfony/translation": "self.version",
+                "symfony/twig-bridge": "self.version",
+                "symfony/twig-bundle": "self.version",
+                "symfony/validator": "self.version",
+                "symfony/var-dumper": "self.version",
+                "symfony/web-link": "self.version",
+                "symfony/web-profiler-bundle": "self.version",
+                "symfony/web-server-bundle": "self.version",
+                "symfony/workflow": "self.version",
+                "symfony/yaml": "self.version"
+            },
+            "require-dev": {
+                "cache/integration-tests": "dev-master",
+                "doctrine/cache": "~1.6",
+                "doctrine/data-fixtures": "1.0.*",
+                "doctrine/dbal": "~2.4",
+                "doctrine/doctrine-bundle": "~1.4",
+                "doctrine/orm": "~2.4,>=2.4.5",
+                "egulias/email-validator": "~1.2,>=1.2.8|~2.0",
+                "monolog/monolog": "~1.11",
+                "ocramius/proxy-manager": "~0.4|~1.0|~2.0",
+                "phpdocumentor/reflection-docblock": "^3.0",
+                "predis/predis": "~1.0",
+                "sensio/framework-extra-bundle": "^3.0.2",
+                "symfony/phpunit-bridge": "~3.2",
+                "symfony/polyfill-apcu": "~1.1",
+                "symfony/security-acl": "~2.8|~3.0"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "3.3-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Bridge\\Doctrine\\": "src/Symfony/Bridge/Doctrine/",
+                    "Symfony\\Bridge\\Monolog\\": "src/Symfony/Bridge/Monolog/",
+                    "Symfony\\Bridge\\ProxyManager\\": "src/Symfony/Bridge/ProxyManager/",
+                    "Symfony\\Bridge\\Twig\\": "src/Symfony/Bridge/Twig/",
+                    "Symfony\\Bundle\\": "src/Symfony/Bundle/",
+                    "Symfony\\Component\\": "src/Symfony/Component/"
+                },
+                "classmap": [
+                    "src/Symfony/Component/Intl/Resources/stubs"
+                ],
+                "exclude-from-classmap": [
+                    "**/Tests/"
+                ]
+            },
+            "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": "The Symfony PHP framework",
+            "homepage": "https://symfony.com",
+            "keywords": [
+                "framework"
+            ],
+            "time": "2017-07-17T19:08:46+00:00"
+        },
+        {
+            "name": "twig/twig",
+            "version": "v1.34.4",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/twigphp/Twig.git",
+                "reference": "f878bab48edb66ad9c6ed626bf817f60c6c096ee"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/twigphp/Twig/zipball/f878bab48edb66ad9c6ed626bf817f60c6c096ee",
+                "reference": "f878bab48edb66ad9c6ed626bf817f60c6c096ee",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.3.3"
+            },
+            "require-dev": {
+                "psr/container": "^1.0",
+                "symfony/debug": "~2.7",
+                "symfony/phpunit-bridge": "~3.3@dev"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "1.34-dev"
+                }
+            },
+            "autoload": {
+                "psr-0": {
+                    "Twig_": "lib/"
+                },
+                "psr-4": {
+                    "Twig\\": "src/"
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "BSD-3-Clause"
+            ],
+            "authors": [
+                {
+                    "name": "Fabien Potencier",
+                    "email": "fabien@symfony.com",
+                    "homepage": "http://fabien.potencier.org",
+                    "role": "Lead Developer"
+                },
+                {
+                    "name": "Armin Ronacher",
+                    "email": "armin.ronacher@active-4.com",
+                    "role": "Project Founder"
+                },
+                {
+                    "name": "Twig Team",
+                    "homepage": "http://twig.sensiolabs.org/contributors",
+                    "role": "Contributors"
+                }
+            ],
+            "description": "Twig, the flexible, fast, and secure template language for PHP",
+            "homepage": "http://twig.sensiolabs.org",
+            "keywords": [
+                "templating"
+            ],
+            "time": "2017-07-04T13:19:31+00:00"
+        }
+    ],
+    "packages-dev": [
+        {
+            "name": "sensio/generator-bundle",
+            "version": "v3.1.6",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/sensiolabs/SensioGeneratorBundle.git",
+                "reference": "128bc5dabc91ca40b7445f094968dd70ccd58305"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/sensiolabs/SensioGeneratorBundle/zipball/128bc5dabc91ca40b7445f094968dd70ccd58305",
+                "reference": "128bc5dabc91ca40b7445f094968dd70ccd58305",
+                "shasum": ""
+            },
+            "require": {
+                "symfony/console": "~2.7|~3.0",
+                "symfony/framework-bundle": "~2.7|~3.0",
+                "symfony/process": "~2.7|~3.0",
+                "symfony/yaml": "~2.7|~3.0",
+                "twig/twig": "^1.28.2|^2.0"
+            },
+            "require-dev": {
+                "doctrine/orm": "~2.4",
+                "symfony/doctrine-bridge": "~2.7|~3.0",
+                "symfony/filesystem": "~2.7|~3.0",
+                "symfony/phpunit-bridge": "^3.3"
+            },
+            "type": "symfony-bundle",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "3.1.x-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Sensio\\Bundle\\GeneratorBundle\\": ""
+                },
+                "exclude-from-classmap": [
+                    "/Tests/"
+                ]
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Fabien Potencier",
+                    "email": "fabien@symfony.com"
+                }
+            ],
+            "description": "This bundle generates code for you",
+            "time": "2017-07-18T07:57:44+00:00"
+        },
+        {
+            "name": "symfony/phpunit-bridge",
+            "version": "v3.3.5",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/phpunit-bridge.git",
+                "reference": "c2c124b7f9de79f4a64dc011f041a3a2c768b913"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/phpunit-bridge/zipball/c2c124b7f9de79f4a64dc011f041a3a2c768b913",
+                "reference": "c2c124b7f9de79f4a64dc011f041a3a2c768b913",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.3.3"
+            },
+            "conflict": {
+                "phpunit/phpunit": "<4.8.35|<5.4.3,>=5.0"
+            },
+            "suggest": {
+                "ext-zip": "Zip support is required when using bin/simple-phpunit",
+                "symfony/debug": "For tracking deprecated interfaces usages at runtime with DebugClassLoader"
+            },
+            "bin": [
+                "bin/simple-phpunit"
+            ],
+            "type": "symfony-bridge",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "3.3-dev"
+                }
+            },
+            "autoload": {
+                "files": [
+                    "bootstrap.php"
+                ],
+                "psr-4": {
+                    "Symfony\\Bridge\\PhpUnit\\": ""
+                },
+                "exclude-from-classmap": [
+                    "/Tests/"
+                ]
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Nicolas Grekas",
+                    "email": "p@tchwork.com"
+                },
+                {
+                    "name": "Symfony Community",
+                    "homepage": "https://symfony.com/contributors"
+                }
+            ],
+            "description": "Symfony PHPUnit Bridge",
+            "homepage": "https://symfony.com",
+            "time": "2017-06-12T13:35:45+00:00"
+        }
+    ],
+    "aliases": [],
+    "minimum-stability": "stable",
+    "stability-flags": [],
+    "prefer-stable": false,
+    "prefer-lowest": false,
+    "platform": {
+        "php": ">=5.5.9"
+    },
+    "platform-dev": [],
+    "platform-overrides": {
+        "php": "5.5.9"
+    }
+}
diff --git a/symfony-3.3/phpunit.xml.dist b/symfony-3.3/phpunit.xml.dist
new file mode 100644
index 000000000..b115bb395
--- /dev/null
+++ b/symfony-3.3/phpunit.xml.dist
@@ -0,0 +1,31 @@
+<?xml version="1.0" encoding="UTF-8"?>
+
+<!-- http://phpunit.de/manual/4.1/en/appendixes.configuration.html -->
+<phpunit xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
+         xsi:noNamespaceSchemaLocation="http://schema.phpunit.de/4.1/phpunit.xsd"
+         backupGlobals="false"
+         colors="true"
+         bootstrap="app/autoload.php"
+>
+    <php>
+        <ini name="error_reporting" value="-1" />
+        <server name="KERNEL_DIR" value="app/" />
+    </php>
+
+    <testsuites>
+        <testsuite name="Project Test Suite">
+            <directory>tests</directory>
+        </testsuite>
+    </testsuites>
+
+    <filter>
+        <whitelist>
+            <directory>src</directory>
+            <exclude>
+                <directory>src/*Bundle/Resources</directory>
+                <directory>src/*/*Bundle/Resources</directory>
+                <directory>src/*/Bundle/*Bundle/Resources</directory>
+            </exclude>
+        </whitelist>
+    </filter>
+</phpunit>
diff --git a/symfony-3.3/src/AppBundle/AppBundle.php b/symfony-3.3/src/AppBundle/AppBundle.php
new file mode 100644
index 000000000..05123b678
--- /dev/null
+++ b/symfony-3.3/src/AppBundle/AppBundle.php
@@ -0,0 +1,9 @@
+<?php
+
+namespace AppBundle;
+
+use Symfony\Component\HttpKernel\Bundle\Bundle;
+
+class AppBundle extends Bundle
+{
+}
diff --git a/symfony-3.3/src/AppBundle/Controller/DefaultController.php b/symfony-3.3/src/AppBundle/Controller/DefaultController.php
new file mode 100644
index 000000000..5d4bb7e85
--- /dev/null
+++ b/symfony-3.3/src/AppBundle/Controller/DefaultController.php
@@ -0,0 +1,21 @@
+<?php
+
+namespace AppBundle\Controller;
+
+use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;
+use Symfony\Bundle\FrameworkBundle\Controller\Controller;
+use Symfony\Component\HttpFoundation\Request;
+
+class DefaultController extends Controller
+{
+    /**
+     * @Route("/", name="homepage")
+     */
+    public function indexAction(Request $request)
+    {
+        // replace this example code with whatever you need
+        return $this->render('default/index.html.twig', [
+            'base_dir' => realpath($this->getParameter('kernel.root_dir').'/..'),
+        ]);
+    }
+}
diff --git a/symfony-3.3/src/AppBundle/Controller/HelloController.php b/symfony-3.3/src/AppBundle/Controller/HelloController.php
new file mode 100644
index 000000000..b8b7e924d
--- /dev/null
+++ b/symfony-3.3/src/AppBundle/Controller/HelloController.php
@@ -0,0 +1,18 @@
+<?php
+
+namespace AppBundle\Controller;
+
+use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;
+use Symfony\Bundle\FrameworkBundle\Controller\Controller;
+use Symfony\Component\HttpFoundation\Response;
+
+class HelloController extends Controller
+{
+    /**
+     * @Route("/hello/index", name="hello_world")
+     */
+    public function indexAction()
+    {
+        return new Response('Hello World!');
+    }
+}
diff --git a/symfony-3.3/tests/AppBundle/Controller/DefaultControllerTest.php b/symfony-3.3/tests/AppBundle/Controller/DefaultControllerTest.php
new file mode 100644
index 000000000..594803cce
--- /dev/null
+++ b/symfony-3.3/tests/AppBundle/Controller/DefaultControllerTest.php
@@ -0,0 +1,18 @@
+<?php
+
+namespace Tests\AppBundle\Controller;
+
+use Symfony\Bundle\FrameworkBundle\Test\WebTestCase;
+
+class DefaultControllerTest extends WebTestCase
+{
+    public function testIndex()
+    {
+        $client = static::createClient();
+
+        $crawler = $client->request('GET', '/');
+
+        $this->assertEquals(200, $client->getResponse()->getStatusCode());
+        $this->assertContains('Welcome to Symfony', $crawler->filter('#container h1')->text());
+    }
+}
diff --git a/symfony-3.3/var/SymfonyRequirements.php b/symfony-3.3/var/SymfonyRequirements.php
new file mode 100755
index 000000000..3b14a4022
--- /dev/null
+++ b/symfony-3.3/var/SymfonyRequirements.php
@@ -0,0 +1,817 @@
+<?php
+
+/*
+ * This file is part of the Symfony package.
+ *
+ * (c) Fabien Potencier <fabien@symfony.com>
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+/*
+ * Users of PHP 5.2 should be able to run the requirements checks.
+ * This is why the file and all classes must be compatible with PHP 5.2+
+ * (e.g. not using namespaces and closures).
+ *
+ * ************** CAUTION **************
+ *
+ * DO NOT EDIT THIS FILE as it will be overridden by Composer as part of
+ * the installation/update process. The original file resides in the
+ * SensioDistributionBundle.
+ *
+ * ************** CAUTION **************
+ */
+
+/**
+ * Represents a single PHP requirement, e.g. an installed extension.
+ * It can be a mandatory requirement or an optional recommendation.
+ * There is a special subclass, named PhpIniRequirement, to check a php.ini configuration.
+ *
+ * @author Tobias Schultze <http://tobion.de>
+ */
+class Requirement
+{
+    private $fulfilled;
+    private $testMessage;
+    private $helpText;
+    private $helpHtml;
+    private $optional;
+
+    /**
+     * Constructor that initializes the requirement.
+     *
+     * @param bool        $fulfilled   Whether the requirement is fulfilled
+     * @param string      $testMessage The message for testing the requirement
+     * @param string      $helpHtml    The help text formatted in HTML for resolving the problem
+     * @param string|null $helpText    The help text (when null, it will be inferred from $helpHtml, i.e. stripped from HTML tags)
+     * @param bool        $optional    Whether this is only an optional recommendation not a mandatory requirement
+     */
+    public function __construct($fulfilled, $testMessage, $helpHtml, $helpText = null, $optional = false)
+    {
+        $this->fulfilled = (bool) $fulfilled;
+        $this->testMessage = (string) $testMessage;
+        $this->helpHtml = (string) $helpHtml;
+        $this->helpText = null === $helpText ? strip_tags($this->helpHtml) : (string) $helpText;
+        $this->optional = (bool) $optional;
+    }
+
+    /**
+     * Returns whether the requirement is fulfilled.
+     *
+     * @return bool true if fulfilled, otherwise false
+     */
+    public function isFulfilled()
+    {
+        return $this->fulfilled;
+    }
+
+    /**
+     * Returns the message for testing the requirement.
+     *
+     * @return string The test message
+     */
+    public function getTestMessage()
+    {
+        return $this->testMessage;
+    }
+
+    /**
+     * Returns the help text for resolving the problem.
+     *
+     * @return string The help text
+     */
+    public function getHelpText()
+    {
+        return $this->helpText;
+    }
+
+    /**
+     * Returns the help text formatted in HTML.
+     *
+     * @return string The HTML help
+     */
+    public function getHelpHtml()
+    {
+        return $this->helpHtml;
+    }
+
+    /**
+     * Returns whether this is only an optional recommendation and not a mandatory requirement.
+     *
+     * @return bool true if optional, false if mandatory
+     */
+    public function isOptional()
+    {
+        return $this->optional;
+    }
+}
+
+/**
+ * Represents a PHP requirement in form of a php.ini configuration.
+ *
+ * @author Tobias Schultze <http://tobion.de>
+ */
+class PhpIniRequirement extends Requirement
+{
+    /**
+     * Constructor that initializes the requirement.
+     *
+     * @param string        $cfgName           The configuration name used for ini_get()
+     * @param bool|callback $evaluation        Either a boolean indicating whether the configuration should evaluate to true or false,
+     *                                         or a callback function receiving the configuration value as parameter to determine the fulfillment of the requirement
+     * @param bool          $approveCfgAbsence If true the Requirement will be fulfilled even if the configuration option does not exist, i.e. ini_get() returns false.
+     *                                         This is helpful for abandoned configs in later PHP versions or configs of an optional extension, like Suhosin.
+     *                                         Example: You require a config to be true but PHP later removes this config and defaults it to true internally.
+     * @param string|null   $testMessage       The message for testing the requirement (when null and $evaluation is a boolean a default message is derived)
+     * @param string|null   $helpHtml          The help text formatted in HTML for resolving the problem (when null and $evaluation is a boolean a default help is derived)
+     * @param string|null   $helpText          The help text (when null, it will be inferred from $helpHtml, i.e. stripped from HTML tags)
+     * @param bool          $optional          Whether this is only an optional recommendation not a mandatory requirement
+     */
+    public function __construct($cfgName, $evaluation, $approveCfgAbsence = false, $testMessage = null, $helpHtml = null, $helpText = null, $optional = false)
+    {
+        $cfgValue = ini_get($cfgName);
+
+        if (is_callable($evaluation)) {
+            if (null === $testMessage || null === $helpHtml) {
+                throw new InvalidArgumentException('You must provide the parameters testMessage and helpHtml for a callback evaluation.');
+            }
+
+            $fulfilled = call_user_func($evaluation, $cfgValue);
+        } else {
+            if (null === $testMessage) {
+                $testMessage = sprintf('%s %s be %s in php.ini',
+                    $cfgName,
+                    $optional ? 'should' : 'must',
+                    $evaluation ? 'enabled' : 'disabled'
+                );
+            }
+
+            if (null === $helpHtml) {
+                $helpHtml = sprintf('Set <strong>%s</strong> to <strong>%s</strong> in php.ini<a href="#phpini">*</a>.',
+                    $cfgName,
+                    $evaluation ? 'on' : 'off'
+                );
+            }
+
+            $fulfilled = $evaluation == $cfgValue;
+        }
+
+        parent::__construct($fulfilled || ($approveCfgAbsence && false === $cfgValue), $testMessage, $helpHtml, $helpText, $optional);
+    }
+}
+
+/**
+ * A RequirementCollection represents a set of Requirement instances.
+ *
+ * @author Tobias Schultze <http://tobion.de>
+ */
+class RequirementCollection implements IteratorAggregate
+{
+    /**
+     * @var Requirement[]
+     */
+    private $requirements = array();
+
+    /**
+     * Gets the current RequirementCollection as an Iterator.
+     *
+     * @return Traversable A Traversable interface
+     */
+    public function getIterator()
+    {
+        return new ArrayIterator($this->requirements);
+    }
+
+    /**
+     * Adds a Requirement.
+     *
+     * @param Requirement $requirement A Requirement instance
+     */
+    public function add(Requirement $requirement)
+    {
+        $this->requirements[] = $requirement;
+    }
+
+    /**
+     * Adds a mandatory requirement.
+     *
+     * @param bool        $fulfilled   Whether the requirement is fulfilled
+     * @param string      $testMessage The message for testing the requirement
+     * @param string      $helpHtml    The help text formatted in HTML for resolving the problem
+     * @param string|null $helpText    The help text (when null, it will be inferred from $helpHtml, i.e. stripped from HTML tags)
+     */
+    public function addRequirement($fulfilled, $testMessage, $helpHtml, $helpText = null)
+    {
+        $this->add(new Requirement($fulfilled, $testMessage, $helpHtml, $helpText, false));
+    }
+
+    /**
+     * Adds an optional recommendation.
+     *
+     * @param bool        $fulfilled   Whether the recommendation is fulfilled
+     * @param string      $testMessage The message for testing the recommendation
+     * @param string      $helpHtml    The help text formatted in HTML for resolving the problem
+     * @param string|null $helpText    The help text (when null, it will be inferred from $helpHtml, i.e. stripped from HTML tags)
+     */
+    public function addRecommendation($fulfilled, $testMessage, $helpHtml, $helpText = null)
+    {
+        $this->add(new Requirement($fulfilled, $testMessage, $helpHtml, $helpText, true));
+    }
+
+    /**
+     * Adds a mandatory requirement in form of a php.ini configuration.
+     *
+     * @param string        $cfgName           The configuration name used for ini_get()
+     * @param bool|callback $evaluation        Either a boolean indicating whether the configuration should evaluate to true or false,
+     *                                         or a callback function receiving the configuration value as parameter to determine the fulfillment of the requirement
+     * @param bool          $approveCfgAbsence If true the Requirement will be fulfilled even if the configuration option does not exist, i.e. ini_get() returns false.
+     *                                         This is helpful for abandoned configs in later PHP versions or configs of an optional extension, like Suhosin.
+     *                                         Example: You require a config to be true but PHP later removes this config and defaults it to true internally.
+     * @param string        $testMessage       The message for testing the requirement (when null and $evaluation is a boolean a default message is derived)
+     * @param string        $helpHtml          The help text formatted in HTML for resolving the problem (when null and $evaluation is a boolean a default help is derived)
+     * @param string|null   $helpText          The help text (when null, it will be inferred from $helpHtml, i.e. stripped from HTML tags)
+     */
+    public function addPhpIniRequirement($cfgName, $evaluation, $approveCfgAbsence = false, $testMessage = null, $helpHtml = null, $helpText = null)
+    {
+        $this->add(new PhpIniRequirement($cfgName, $evaluation, $approveCfgAbsence, $testMessage, $helpHtml, $helpText, false));
+    }
+
+    /**
+     * Adds an optional recommendation in form of a php.ini configuration.
+     *
+     * @param string        $cfgName           The configuration name used for ini_get()
+     * @param bool|callback $evaluation        Either a boolean indicating whether the configuration should evaluate to true or false,
+     *                                         or a callback function receiving the configuration value as parameter to determine the fulfillment of the requirement
+     * @param bool          $approveCfgAbsence If true the Requirement will be fulfilled even if the configuration option does not exist, i.e. ini_get() returns false.
+     *                                         This is helpful for abandoned configs in later PHP versions or configs of an optional extension, like Suhosin.
+     *                                         Example: You require a config to be true but PHP later removes this config and defaults it to true internally.
+     * @param string        $testMessage       The message for testing the requirement (when null and $evaluation is a boolean a default message is derived)
+     * @param string        $helpHtml          The help text formatted in HTML for resolving the problem (when null and $evaluation is a boolean a default help is derived)
+     * @param string|null   $helpText          The help text (when null, it will be inferred from $helpHtml, i.e. stripped from HTML tags)
+     */
+    public function addPhpIniRecommendation($cfgName, $evaluation, $approveCfgAbsence = false, $testMessage = null, $helpHtml = null, $helpText = null)
+    {
+        $this->add(new PhpIniRequirement($cfgName, $evaluation, $approveCfgAbsence, $testMessage, $helpHtml, $helpText, true));
+    }
+
+    /**
+     * Adds a requirement collection to the current set of requirements.
+     *
+     * @param RequirementCollection $collection A RequirementCollection instance
+     */
+    public function addCollection(RequirementCollection $collection)
+    {
+        $this->requirements = array_merge($this->requirements, $collection->all());
+    }
+
+    /**
+     * Returns both requirements and recommendations.
+     *
+     * @return Requirement[]
+     */
+    public function all()
+    {
+        return $this->requirements;
+    }
+
+    /**
+     * Returns all mandatory requirements.
+     *
+     * @return Requirement[]
+     */
+    public function getRequirements()
+    {
+        $array = array();
+        foreach ($this->requirements as $req) {
+            if (!$req->isOptional()) {
+                $array[] = $req;
+            }
+        }
+
+        return $array;
+    }
+
+    /**
+     * Returns the mandatory requirements that were not met.
+     *
+     * @return Requirement[]
+     */
+    public function getFailedRequirements()
+    {
+        $array = array();
+        foreach ($this->requirements as $req) {
+            if (!$req->isFulfilled() && !$req->isOptional()) {
+                $array[] = $req;
+            }
+        }
+
+        return $array;
+    }
+
+    /**
+     * Returns all optional recommendations.
+     *
+     * @return Requirement[]
+     */
+    public function getRecommendations()
+    {
+        $array = array();
+        foreach ($this->requirements as $req) {
+            if ($req->isOptional()) {
+                $array[] = $req;
+            }
+        }
+
+        return $array;
+    }
+
+    /**
+     * Returns the recommendations that were not met.
+     *
+     * @return Requirement[]
+     */
+    public function getFailedRecommendations()
+    {
+        $array = array();
+        foreach ($this->requirements as $req) {
+            if (!$req->isFulfilled() && $req->isOptional()) {
+                $array[] = $req;
+            }
+        }
+
+        return $array;
+    }
+
+    /**
+     * Returns whether a php.ini configuration is not correct.
+     *
+     * @return bool php.ini configuration problem?
+     */
+    public function hasPhpIniConfigIssue()
+    {
+        foreach ($this->requirements as $req) {
+            if (!$req->isFulfilled() && $req instanceof PhpIniRequirement) {
+                return true;
+            }
+        }
+
+        return false;
+    }
+
+    /**
+     * Returns the PHP configuration file (php.ini) path.
+     *
+     * @return string|false php.ini file path
+     */
+    public function getPhpIniConfigPath()
+    {
+        return get_cfg_var('cfg_file_path');
+    }
+}
+
+/**
+ * This class specifies all requirements and optional recommendations that
+ * are necessary to run the Symfony Standard Edition.
+ *
+ * @author Tobias Schultze <http://tobion.de>
+ * @author Fabien Potencier <fabien@symfony.com>
+ */
+class SymfonyRequirements extends RequirementCollection
+{
+    const LEGACY_REQUIRED_PHP_VERSION = '5.3.3';
+    const REQUIRED_PHP_VERSION = '5.5.9';
+
+    /**
+     * Constructor that initializes the requirements.
+     */
+    public function __construct()
+    {
+        /* mandatory requirements follow */
+
+        $installedPhpVersion = phpversion();
+        $requiredPhpVersion = $this->getPhpRequiredVersion();
+
+        $this->addRecommendation(
+            $requiredPhpVersion,
+            'Vendors should be installed in order to check all requirements.',
+            'Run the <code>composer install</code> command.',
+            'Run the "composer install" command.'
+        );
+
+        if (false !== $requiredPhpVersion) {
+            $this->addRequirement(
+                version_compare($installedPhpVersion, $requiredPhpVersion, '>='),
+                sprintf('PHP version must be at least %s (%s installed)', $requiredPhpVersion, $installedPhpVersion),
+                sprintf('You are running PHP version "<strong>%s</strong>", but Symfony needs at least PHP "<strong>%s</strong>" to run.
+                Before using Symfony, upgrade your PHP installation, preferably to the latest version.',
+                    $installedPhpVersion, $requiredPhpVersion),
+                sprintf('Install PHP %s or newer (installed version is %s)', $requiredPhpVersion, $installedPhpVersion)
+            );
+        }
+
+        $this->addRequirement(
+            version_compare($installedPhpVersion, '5.3.16', '!='),
+            'PHP version must not be 5.3.16 as Symfony won\'t work properly with it',
+            'Install PHP 5.3.17 or newer (or downgrade to an earlier PHP version)'
+        );
+
+        $this->addRequirement(
+            is_dir(__DIR__.'/../vendor/composer'),
+            'Vendor libraries must be installed',
+            'Vendor libraries are missing. Install composer following instructions from <a href="http://getcomposer.org/">http://getcomposer.org/</a>. '.
+                'Then run "<strong>php composer.phar install</strong>" to install them.'
+        );
+
+        $cacheDir = is_dir(__DIR__.'/../var/cache') ? __DIR__.'/../var/cache' : __DIR__.'/cache';
+
+        $this->addRequirement(
+            is_writable($cacheDir),
+            'app/cache/ or var/cache/ directory must be writable',
+            'Change the permissions of either "<strong>app/cache/</strong>" or  "<strong>var/cache/</strong>" directory so that the web server can write into it.'
+        );
+
+        $logsDir = is_dir(__DIR__.'/../var/logs') ? __DIR__.'/../var/logs' : __DIR__.'/logs';
+
+        $this->addRequirement(
+            is_writable($logsDir),
+            'app/logs/ or var/logs/ directory must be writable',
+            'Change the permissions of either "<strong>app/logs/</strong>" or  "<strong>var/logs/</strong>" directory so that the web server can write into it.'
+        );
+
+        if (version_compare($installedPhpVersion, '7.0.0', '<')) {
+            $this->addPhpIniRequirement(
+                'date.timezone', true, false,
+                'date.timezone setting must be set',
+                'Set the "<strong>date.timezone</strong>" setting in php.ini<a href="#phpini">*</a> (like Europe/Paris).'
+            );
+        }
+
+        if (false !== $requiredPhpVersion && version_compare($installedPhpVersion, $requiredPhpVersion, '>=')) {
+            $timezones = array();
+            foreach (DateTimeZone::listAbbreviations() as $abbreviations) {
+                foreach ($abbreviations as $abbreviation) {
+                    $timezones[$abbreviation['timezone_id']] = true;
+                }
+            }
+
+            $this->addRequirement(
+                isset($timezones[@date_default_timezone_get()]),
+                sprintf('Configured default timezone "%s" must be supported by your installation of PHP', @date_default_timezone_get()),
+                'Your default timezone is not supported by PHP. Check for typos in your <strong>php.ini</strong> file and have a look at the list of deprecated timezones at <a href="http://php.net/manual/en/timezones.others.php">http://php.net/manual/en/timezones.others.php</a>.'
+            );
+        }
+
+        $this->addRequirement(
+            function_exists('iconv'),
+            'iconv() must be available',
+            'Install and enable the <strong>iconv</strong> extension.'
+        );
+
+        $this->addRequirement(
+            function_exists('json_encode'),
+            'json_encode() must be available',
+            'Install and enable the <strong>JSON</strong> extension.'
+        );
+
+        $this->addRequirement(
+            function_exists('session_start'),
+            'session_start() must be available',
+            'Install and enable the <strong>session</strong> extension.'
+        );
+
+        $this->addRequirement(
+            function_exists('ctype_alpha'),
+            'ctype_alpha() must be available',
+            'Install and enable the <strong>ctype</strong> extension.'
+        );
+
+        $this->addRequirement(
+            function_exists('token_get_all'),
+            'token_get_all() must be available',
+            'Install and enable the <strong>Tokenizer</strong> extension.'
+        );
+
+        $this->addRequirement(
+            function_exists('simplexml_import_dom'),
+            'simplexml_import_dom() must be available',
+            'Install and enable the <strong>SimpleXML</strong> extension.'
+        );
+
+        if (function_exists('apc_store') && ini_get('apc.enabled')) {
+            if (version_compare($installedPhpVersion, '5.4.0', '>=')) {
+                $this->addRequirement(
+                    version_compare(phpversion('apc'), '3.1.13', '>='),
+                    'APC version must be at least 3.1.13 when using PHP 5.4',
+                    'Upgrade your <strong>APC</strong> extension (3.1.13+).'
+                );
+            } else {
+                $this->addRequirement(
+                    version_compare(phpversion('apc'), '3.0.17', '>='),
+                    'APC version must be at least 3.0.17',
+                    'Upgrade your <strong>APC</strong> extension (3.0.17+).'
+                );
+            }
+        }
+
+        $this->addPhpIniRequirement('detect_unicode', false);
+
+        if (extension_loaded('suhosin')) {
+            $this->addPhpIniRequirement(
+                'suhosin.executor.include.whitelist',
+                create_function('$cfgValue', 'return false !== stripos($cfgValue, "phar");'),
+                false,
+                'suhosin.executor.include.whitelist must be configured correctly in php.ini',
+                'Add "<strong>phar</strong>" to <strong>suhosin.executor.include.whitelist</strong> in php.ini<a href="#phpini">*</a>.'
+            );
+        }
+
+        if (extension_loaded('xdebug')) {
+            $this->addPhpIniRequirement(
+                'xdebug.show_exception_trace', false, true
+            );
+
+            $this->addPhpIniRequirement(
+                'xdebug.scream', false, true
+            );
+
+            $this->addPhpIniRecommendation(
+                'xdebug.max_nesting_level',
+                create_function('$cfgValue', 'return $cfgValue > 100;'),
+                true,
+                'xdebug.max_nesting_level should be above 100 in php.ini',
+                'Set "<strong>xdebug.max_nesting_level</strong>" to e.g. "<strong>250</strong>" in php.ini<a href="#phpini">*</a> to stop Xdebug\'s infinite recursion protection erroneously throwing a fatal error in your project.'
+            );
+        }
+
+        $pcreVersion = defined('PCRE_VERSION') ? (float) PCRE_VERSION : null;
+
+        $this->addRequirement(
+            null !== $pcreVersion,
+            'PCRE extension must be available',
+            'Install the <strong>PCRE</strong> extension (version 8.0+).'
+        );
+
+        if (extension_loaded('mbstring')) {
+            $this->addPhpIniRequirement(
+                'mbstring.func_overload',
+                create_function('$cfgValue', 'return (int) $cfgValue === 0;'),
+                true,
+                'string functions should not be overloaded',
+                'Set "<strong>mbstring.func_overload</strong>" to <strong>0</strong> in php.ini<a href="#phpini">*</a> to disable function overloading by the mbstring extension.'
+            );
+        }
+
+        /* optional recommendations follow */
+
+        if (file_exists(__DIR__.'/../vendor/composer')) {
+            require_once __DIR__.'/../vendor/autoload.php';
+
+            try {
+                $r = new ReflectionClass('Sensio\Bundle\DistributionBundle\SensioDistributionBundle');
+
+                $contents = file_get_contents(dirname($r->getFileName()).'/Resources/skeleton/app/SymfonyRequirements.php');
+            } catch (ReflectionException $e) {
+                $contents = '';
+            }
+            $this->addRecommendation(
+                file_get_contents(__FILE__) === $contents,
+                'Requirements file should be up-to-date',
+                'Your requirements file is outdated. Run composer install and re-check your configuration.'
+            );
+        }
+
+        $this->addRecommendation(
+            version_compare($installedPhpVersion, '5.3.4', '>='),
+            'You should use at least PHP 5.3.4 due to PHP bug #52083 in earlier versions',
+            'Your project might malfunction randomly due to PHP bug #52083 ("Notice: Trying to get property of non-object"). Install PHP 5.3.4 or newer.'
+        );
+
+        $this->addRecommendation(
+            version_compare($installedPhpVersion, '5.3.8', '>='),
+            'When using annotations you should have at least PHP 5.3.8 due to PHP bug #55156',
+            'Install PHP 5.3.8 or newer if your project uses annotations.'
+        );
+
+        $this->addRecommendation(
+            version_compare($installedPhpVersion, '5.4.0', '!='),
+            'You should not use PHP 5.4.0 due to the PHP bug #61453',
+            'Your project might not work properly due to the PHP bug #61453 ("Cannot dump definitions which have method calls"). Install PHP 5.4.1 or newer.'
+        );
+
+        $this->addRecommendation(
+            version_compare($installedPhpVersion, '5.4.11', '>='),
+            'When using the logout handler from the Symfony Security Component, you should have at least PHP 5.4.11 due to PHP bug #63379 (as a workaround, you can also set invalidate_session to false in the security logout handler configuration)',
+            'Install PHP 5.4.11 or newer if your project uses the logout handler from the Symfony Security Component.'
+        );
+
+        $this->addRecommendation(
+            (version_compare($installedPhpVersion, '5.3.18', '>=') && version_compare($installedPhpVersion, '5.4.0', '<'))
+            ||
+            version_compare($installedPhpVersion, '5.4.8', '>='),
+            'You should use PHP 5.3.18+ or PHP 5.4.8+ to always get nice error messages for fatal errors in the development environment due to PHP bug #61767/#60909',
+            'Install PHP 5.3.18+ or PHP 5.4.8+ if you want nice error messages for all fatal errors in the development environment.'
+        );
+
+        if (null !== $pcreVersion) {
+            $this->addRecommendation(
+                $pcreVersion >= 8.0,
+                sprintf('PCRE extension should be at least version 8.0 (%s installed)', $pcreVersion),
+                '<strong>PCRE 8.0+</strong> is preconfigured in PHP since 5.3.2 but you are using an outdated version of it. Symfony probably works anyway but it is recommended to upgrade your PCRE extension.'
+            );
+        }
+
+        $this->addRecommendation(
+            class_exists('DomDocument'),
+            'PHP-DOM and PHP-XML modules should be installed',
+            'Install and enable the <strong>PHP-DOM</strong> and the <strong>PHP-XML</strong> modules.'
+        );
+
+        $this->addRecommendation(
+            function_exists('mb_strlen'),
+            'mb_strlen() should be available',
+            'Install and enable the <strong>mbstring</strong> extension.'
+        );
+
+        $this->addRecommendation(
+            function_exists('utf8_decode'),
+            'utf8_decode() should be available',
+            'Install and enable the <strong>XML</strong> extension.'
+        );
+
+        $this->addRecommendation(
+            function_exists('filter_var'),
+            'filter_var() should be available',
+            'Install and enable the <strong>filter</strong> extension.'
+        );
+
+        if (!defined('PHP_WINDOWS_VERSION_BUILD')) {
+            $this->addRecommendation(
+                function_exists('posix_isatty'),
+                'posix_isatty() should be available',
+                'Install and enable the <strong>php_posix</strong> extension (used to colorize the CLI output).'
+            );
+        }
+
+        $this->addRecommendation(
+            extension_loaded('intl'),
+            'intl extension should be available',
+            'Install and enable the <strong>intl</strong> extension (used for validators).'
+        );
+
+        if (extension_loaded('intl')) {
+            // in some WAMP server installations, new Collator() returns null
+            $this->addRecommendation(
+                null !== new Collator('fr_FR'),
+                'intl extension should be correctly configured',
+                'The intl extension does not behave properly. This problem is typical on PHP 5.3.X x64 WIN builds.'
+            );
+
+            // check for compatible ICU versions (only done when you have the intl extension)
+            if (defined('INTL_ICU_VERSION')) {
+                $version = INTL_ICU_VERSION;
+            } else {
+                $reflector = new ReflectionExtension('intl');
+
+                ob_start();
+                $reflector->info();
+                $output = strip_tags(ob_get_clean());
+
+                preg_match('/^ICU version +(?:=> )?(.*)$/m', $output, $matches);
+                $version = $matches[1];
+            }
+
+            $this->addRecommendation(
+                version_compare($version, '4.0', '>='),
+                'intl ICU version should be at least 4+',
+                'Upgrade your <strong>intl</strong> extension with a newer ICU version (4+).'
+            );
+
+            if (class_exists('Symfony\Component\Intl\Intl')) {
+                $this->addRecommendation(
+                    \Symfony\Component\Intl\Intl::getIcuDataVersion() <= \Symfony\Component\Intl\Intl::getIcuVersion(),
+                    sprintf('intl ICU version installed on your system is outdated (%s) and does not match the ICU data bundled with Symfony (%s)', \Symfony\Component\Intl\Intl::getIcuVersion(), \Symfony\Component\Intl\Intl::getIcuDataVersion()),
+                    'To get the latest internationalization data upgrade the ICU system package and the intl PHP extension.'
+                );
+                if (\Symfony\Component\Intl\Intl::getIcuDataVersion() <= \Symfony\Component\Intl\Intl::getIcuVersion()) {
+                    $this->addRecommendation(
+                        \Symfony\Component\Intl\Intl::getIcuDataVersion() === \Symfony\Component\Intl\Intl::getIcuVersion(),
+                        sprintf('intl ICU version installed on your system (%s) does not match the ICU data bundled with Symfony (%s)', \Symfony\Component\Intl\Intl::getIcuVersion(), \Symfony\Component\Intl\Intl::getIcuDataVersion()),
+                        'To avoid internationalization data inconsistencies upgrade the symfony/intl component.'
+                    );
+                }
+            }
+
+            $this->addPhpIniRecommendation(
+                'intl.error_level',
+                create_function('$cfgValue', 'return (int) $cfgValue === 0;'),
+                true,
+                'intl.error_level should be 0 in php.ini',
+                'Set "<strong>intl.error_level</strong>" to "<strong>0</strong>" in php.ini<a href="#phpini">*</a> to inhibit the messages when an error occurs in ICU functions.'
+            );
+        }
+
+        $accelerator =
+            (extension_loaded('eaccelerator') && ini_get('eaccelerator.enable'))
+            ||
+            (extension_loaded('apc') && ini_get('apc.enabled'))
+            ||
+            (extension_loaded('Zend Optimizer+') && ini_get('zend_optimizerplus.enable'))
+            ||
+            (extension_loaded('Zend OPcache') && ini_get('opcache.enable'))
+            ||
+            (extension_loaded('xcache') && ini_get('xcache.cacher'))
+            ||
+            (extension_loaded('wincache') && ini_get('wincache.ocenabled'))
+        ;
+
+        $this->addRecommendation(
+            $accelerator,
+            'a PHP accelerator should be installed',
+            'Install and/or enable a <strong>PHP accelerator</strong> (highly recommended).'
+        );
+
+        if (strtoupper(substr(PHP_OS, 0, 3)) === 'WIN') {
+            $this->addRecommendation(
+                $this->getRealpathCacheSize() >= 5 * 1024 * 1024,
+                'realpath_cache_size should be at least 5M in php.ini',
+                'Setting "<strong>realpath_cache_size</strong>" to e.g. "<strong>5242880</strong>" or "<strong>5M</strong>" in php.ini<a href="#phpini">*</a> may improve performance on Windows significantly in some cases.'
+            );
+        }
+
+        $this->addPhpIniRecommendation('short_open_tag', false);
+
+        $this->addPhpIniRecommendation('magic_quotes_gpc', false, true);
+
+        $this->addPhpIniRecommendation('register_globals', false, true);
+
+        $this->addPhpIniRecommendation('session.auto_start', false);
+
+        $this->addRecommendation(
+            class_exists('PDO'),
+            'PDO should be installed',
+            'Install <strong>PDO</strong> (mandatory for Doctrine).'
+        );
+
+        if (class_exists('PDO')) {
+            $drivers = PDO::getAvailableDrivers();
+            $this->addRecommendation(
+                count($drivers) > 0,
+                sprintf('PDO should have some drivers installed (currently available: %s)', count($drivers) ? implode(', ', $drivers) : 'none'),
+                'Install <strong>PDO drivers</strong> (mandatory for Doctrine).'
+            );
+        }
+    }
+
+    /**
+     * Loads realpath_cache_size from php.ini and converts it to int.
+     *
+     * (e.g. 16k is converted to 16384 int)
+     *
+     * @return int
+     */
+    protected function getRealpathCacheSize()
+    {
+        $size = ini_get('realpath_cache_size');
+        $size = trim($size);
+        $unit = '';
+        if (!ctype_digit($size)) {
+            $unit = strtolower(substr($size, -1, 1));
+            $size = (int) substr($size, 0, -1);
+        }
+        switch ($unit) {
+            case 'g':
+                return $size * 1024 * 1024 * 1024;
+            case 'm':
+                return $size * 1024 * 1024;
+            case 'k':
+                return $size * 1024;
+            default:
+                return (int) $size;
+        }
+    }
+
+    /**
+     * Defines PHP required version from Symfony version.
+     *
+     * @return string|false The PHP required version or false if it could not be guessed
+     */
+    protected function getPhpRequiredVersion()
+    {
+        if (!file_exists($path = __DIR__.'/../composer.lock')) {
+            return false;
+        }
+
+        $composerLock = json_decode(file_get_contents($path), true);
+        foreach ($composerLock['packages'] as $package) {
+            $name = $package['name'];
+            if ('symfony/symfony' !== $name && 'symfony/http-kernel' !== $name) {
+                continue;
+            }
+
+            return (int) $package['version'][1] > 2 ? self::REQUIRED_PHP_VERSION : self::LEGACY_REQUIRED_PHP_VERSION;
+        }
+
+        return false;
+    }
+}
diff --git a/symfony-3.3/var/cache/.gitkeep b/symfony-3.3/var/cache/.gitkeep
new file mode 100644
index 000000000..e69de29bb
diff --git a/symfony-3.3/var/logs/.gitkeep b/symfony-3.3/var/logs/.gitkeep
new file mode 100644
index 000000000..e69de29bb
diff --git a/symfony-3.3/var/sessions/.gitkeep b/symfony-3.3/var/sessions/.gitkeep
new file mode 100644
index 000000000..e69de29bb
diff --git a/symfony-3.3/web/app.php b/symfony-3.3/web/app.php
new file mode 100644
index 000000000..2244ea5c5
--- /dev/null
+++ b/symfony-3.3/web/app.php
@@ -0,0 +1,32 @@
+<?php
+
+use Symfony\Component\HttpFoundation\Request;
+
+/**
+ * @var Composer\Autoload\ClassLoader
+ */
+$loader = require __DIR__.'/../app/autoload.php';
+include_once __DIR__.'/../var/bootstrap.php.cache';
+
+// Enable APC for autoloading to improve performance.
+// You should change the ApcClassLoader first argument to a unique prefix
+// in order to prevent cache key conflicts with other applications
+// also using APC.
+/*
+$apcLoader = new Symfony\Component\ClassLoader\ApcClassLoader(sha1(__FILE__), $loader);
+$loader->unregister();
+$apcLoader->register(true);
+*/
+
+$kernel = new AppKernel('prod', false);
+$kernel->loadClassCache();
+//$kernel = new AppCache($kernel);
+
+// When using the HttpCache, you need to call the method in your front controller instead of relying on the configuration parameter
+//Request::enableHttpMethodParameterOverride();
+$request = Request::createFromGlobals();
+$response = $kernel->handle($request);
+$response->send();
+$kernel->terminate($request, $response);
+
+require $_SERVER['DOCUMENT_ROOT'].'/php-framework-benchmark/libs/output_data.php';
diff --git a/symfony-3.3/web/app_dev.php b/symfony-3.3/web/app_dev.php
new file mode 100644
index 000000000..8456754d5
--- /dev/null
+++ b/symfony-3.3/web/app_dev.php
@@ -0,0 +1,32 @@
+<?php
+
+use Symfony\Component\HttpFoundation\Request;
+use Symfony\Component\Debug\Debug;
+
+// If you don't want to setup permissions the proper way, just uncomment the following PHP line
+// read http://symfony.com/doc/current/book/installation.html#checking-symfony-application-configuration-and-setup
+// for more information
+//umask(0000);
+
+// This check prevents access to debug front controllers that are deployed by accident to production servers.
+// Feel free to remove this, extend it, or make something more sophisticated.
+if (isset($_SERVER['HTTP_CLIENT_IP'])
+    || isset($_SERVER['HTTP_X_FORWARDED_FOR'])
+    || !(in_array(@$_SERVER['REMOTE_ADDR'], ['127.0.0.1', 'fe80::1', '::1']) || php_sapi_name() === 'cli-server')
+) {
+    header('HTTP/1.0 403 Forbidden');
+    exit('You are not allowed to access this file. Check '.basename(__FILE__).' for more information.');
+}
+
+/**
+ * @var Composer\Autoload\ClassLoader $loader
+ */
+$loader = require __DIR__.'/../app/autoload.php';
+Debug::enable();
+
+$kernel = new AppKernel('dev', true);
+$kernel->loadClassCache();
+$request = Request::createFromGlobals();
+$response = $kernel->handle($request);
+$response->send();
+$kernel->terminate($request, $response);
diff --git a/symfony-3.3/web/apple-touch-icon.png b/symfony-3.3/web/apple-touch-icon.png
new file mode 100644
index 0000000000000000000000000000000000000000..11f17e6d89ee3b416218ede42b66ec1dd81507f2
GIT binary patch
literal 10784
zcmWkz1yB@S9ACP-8;%mCRJxlZq&uWLq>(-vq`SL2rBgtpyFoxeqy*{a+i!06c5ZIw
z?c4YM|6jdG6(w0LbaHe60I=ksQflBm@c#=H8T{VQUr_-7bV(aYNfkLsNm?hDPnI_J
z769;hHAmf3C+UV*Wb?)XM@wS)tRc-l5P;BEqyE6vEyPU(OhRz+#fCy7(6tDO@Uo$r
zgFy@E(42^0`LEin#J@!7MQIxF{iRti`|9U?dUEox^w71Rz5h7rHH8Di!)HqPU1$sN
ztAz>)EYrj(LkCB?VemxIEks(}-(%mbkcI%@48iNOzgxZNBV64l03L8!U}wM|-hK)0
zP+`&rXcK@f2>w0>T)Z0agI(hXA@G9~s8???M+cGtz~0MO0s>TG0mqkeB1ph;MbbJ6
zuv|!4feOUH0U57k8Q{e_0b|WTHCFh(Z$N&v7=#_MuNDrb+wx8p9@dQnc*N?&<A@mp
zunY;-ae$T&9+0Fam_VRaM9Aly?cJ&{atdvO!U26_DHCZ5v+oJpQl`m0&(F4g(f#^n
z-ymT^!h&mwwhPHl%c3WM?jtBpVgdm9-Aw;8pJ@F4@7?X+mizXnmqUfmc4wa;B6R;Y
zpSz;r5dmDKsnb=Xy}d;Qr(w8y_g=dSePC4!u-?2ge7}a4uZKSEeHZ1$_b5i4TcGko
zh>8*&1LK6zw4j@FCraey{r0D=DF18l-{&>&Gr&1hETg8cDEP_Q#L=TxEp~qlQR1!R
z%|89}aA?3&EX&L<t_A~EqA&k+BHL6TABMf!)e@xWMpAy^9|XMnN0a)5mgI>AREH_|
zDYc+{9kcKA{|g5ng{?E|0f_luutk$&BmlTpT<^SY03fONE>7$X959hqyaNDTe@G3=
zlSvf6qXK|be&FkRaTLsc!s<Tk?0%}QJ`#8nWGOLBhCU%&3FKWEC3*pAsyLZOpTIKW
z*Lno<e7wwU+~)qbd|3Ni_y&PTP9(_2q`BWnyTZ^A#ebj@n9vDC;F-oQLncv4GGY-S
zCQz<KSTXHE1feQq=!Z)&e1(K<f+3XtoXv%hKgK}pK7Q>7?Yl3JU%F)9CI>dEBFw|P
zi?x^2kbn7}?>ghgg<}XyEwq~<Z>AQ8wG@`kDEx7E1N^?kn!#q?Vp~S9m>5KdOB+Y(
zkTVSvo9*dvYsGP!QR(n{5K;8ynw+9Cz(>Idj!{2`;C{0YijSAoQPhzvXFR5F#_vGY
zMhgyk`;8frRIc32=#76j_}NsTAznwOn&~ecHC-;_M`mmSqa-K;_DJHc5;`4Y{5v@e
zIXmbYl&x63SY#I0CR>r|DBfY@=Pqg^teQ40p*0>SUODk$WMH?IP+%zHmm*prgIaMi
zzC5>u=pJH8-aCnm{7Th{irjhB$_RlxJvoPb4;2pe@CpJh_e{o#EMm#AVz#1%=}a3d
zn;UD61Gf&ejbLi&wCS{2yFVxg`v<|7o|sr+Si!?k(^q76WIkkNq^)Ee8H%Myb7>hr
zG&q;uQDj)9<D`Gm)OmgV+LtI{6hB2EMJvTWWxrBG(^XS+!K)HOqe>H}>Z6ulsf=cm
z%1#B^JaN@R1(jxJ1yAjynx|Tv%9N^6QIFA6(7hQ}V_2w6ei*b!!>si?SqvTV_jeZm
zbR-sCv=EM1?b1J(>NnmUD|#S3P<U|oD5^`kR$5kDCRpbDcAkL4{@$>4#=nv+KS?)<
zHR;2Kz$VJpuxMLjS>s>ByXw8#vub+cazcD^w0i39lp~hInsX)KAaLW3*1^-E+7a5Z
z=00^OGG}(=b%1s?dWC(kF(Z5Ba9MOka(KFUIzz+D$%V=jPiFs?&+KeG-t3QEx=q{6
zS;%%d-k5bq!k~50j9d|O8`Ix#s~zsoBqEm8pD0bMxqe!#+X<PN+PqsU9xNW(?O~Zn
zw#&5am}#DK8z29{x?a6pJ#rk&zmRR0YtpmQwe}bjS|Xi2Bp<~SHJrMd>N|#%`XTkE
zI$cXd%S-D@YpGgp(cp;n$YD|2UWGzC3o}a~YpkWbCaY%9Bg<iv@E2hm%Ph;4y5s8G
z<Huw4<IH2^6aH(HYsPDb>nW;nN_?tCK{r8P7dQ8D4|}JsqvCC@fr`P3fdg$T3abLw
zoC|J}Qib?2{4|d=5_N~NFJ+E--eW0y<bOM6zs_A1Wp!q)*Q_|qZ;T5M`Bgo9V9%l$
zF&q#+6~8>Y(fQ>(zLQgyRrc*7exKu`$4A|d58c$tP1#Jji<}NW)&}*ry2pHs1w@1`
z?k5irM81o_=XvLa_muWPHidiW{TKZ+{81ir9|Z5mp5ktMx4q7Z|0y9E!}Y`M!F30c
z2R0$tA<!UZAeNwTBgG(fB6DDh5J_O7Vd>JiBz@{5Ij6WYd%teQnmI!>ikd^DM{&<N
z&ZJ1ah!-0+g}RCB|Ecs&@nF0KHDXKFKBA4rhAe~R&X17g^}9;;L)B(=H)ppS*2U^w
z-3P1g*ne>q(d~k3wk<9mR@JulYW8NwS#7Yk%C^AI;kVNN((v5~7|>24cL$dTg(G)d
z;rHz`-)HY;YNWcE)$Xkqwv+rmm>kRX6w>9^jrZjXO~+4b6x|D^l~CazRo*Le{6Ix;
z9+DNREZtKWQ>fa|+9ofQ_&Y}{<(h9p&`<K-I!sx{{rh_~Wwke631o@w^cNqrq!xcx
zPpvqwu<<8nCubL_VcDcMzggmJebuUL`Q}X$)~?rYhf#{8@X?!H`a9Q)H6r^^#hIdJ
zwOSQyVnvSfH=p%M^*^^kyP<mX?>8-<5AWzPf{1;)<Lg!0>YJ9^KI{J5g7ivv64OVi
zlX$YfHB{>`|7>$M>o;aS)|mRF@=Hfe^W4^J{XAAJc($ZO@=cI7S4u_l$e3g8rCz%k
zkx7cV=BaJkg1%P3YmyYBYNzV*+S_`Ww%@<Bm5dgAue=;qSAWX4j-DJrkBW~Rt8a9B
z>*Tv_#TTZ-&ai4I{>AK37&*xQbSv<-y^5V^o*11#;5Okt(I0QAUOO+~DZ2K~2{0Vf
zda9{v?O9=3UF_ZP^tr$erXmvjd76CO_4UnXZM$x1zbnVtzd;*u<farIy}$i8+GIVI
zhjQb5N_<eRrB9D+-9Fi`*Y)-`qB*GX#85*8oc6L{pH{O@GCjXK>AlAOCcf9tyjkk&
zv!n8-U~*u6U}7^Pp!Ev%2<r7_R-o6tnyttoU$~(A^iOnA4%J60*`C%H|I@cSX70n>
zaoV~0Ij@BO-R%Y??Ub39<>n}f3eRV(d)+8LX4o038g^SrPUVV{xcyaZHM$wO__-fv
zc-G}~3Ar&{V{BEZ5v~=M^>=#OhSuqSI<mMKJJA-Zb-Vm<Bsg<A7jSRex8S;TyTopo
z=hc1s{g|TFk!gdnjj`kE*5mqw#1s9m;<}-C+~>N-p4F#AlzW`Rfad20i#~^~TjM_C
zsR3P_Q*5;G+~?$%x$x~-*>TwgdKvndxEvZ93M}&ObMwih?Xt!)f~iq|trxE&*Q))^
zr(X{WQ#y~!XBc-;Q@yob6&Eh2RTXst!}P;6U6WqI|4JWgCfEE<+fF++hr4MqUOkFE
zt6a?7n+=yuE8mFh`#wK%+=N^_!1x*QKvjussvs)`y!`*k?=DLM0Gcp4DRGU@t0#sw
zZW@{`&q`PssJPPrTuMK#B^mh;B6<DW+S0EJ*O9R42?Azv>+ruzQzbkiI_!DN6SNUx
z^!U182>!SjN1A=4Wx^}U;p7v;&xDe~n~VbH<xQJ$9c4l{i&RywC6Olecs1MIr-bK3
z9*&<*{H{$RCU=py;HS$k^ksoapacF7T7Ij`mC9dtq-i8ERv0Nj4N&$W0a$=7kd5es
z-scR21C)p=aQWzBY%p8KxNIQ++O9k^pTRnMIO-<QTjp{F=Y$0l2asQBD~24YAaBV6
z55O_93j9`t1cQqUONdxnME>2Z7$6BmBXTO;9nYg*S!+bl;q>tWJqRk*lI3X;v=S9G
zFf?E`#jZR?sMzL>oCD8&?M>E3j{vGMGYlRO1PHg)zCbfkjceZRKwX_}u$U%1?*eKs
zI&*w2UtEI)B8~tUFR+eA`*)U8K=~hF2`nRTg_OEdz}>PUYY2+TkYos1Nh^Avp0Qjd
zT`a==Kshr4I*iEmj^>g2gn*Y>H_IYO`vWHOq&;nnKQn<u{rfX5M7l#(0x1@l6%k#F
z@DEEo)eEUZOyeGimwtn9qwxY^ffc>`L5i0IUDz9L@*!zSOvQ^QPr&7aK%Bl?IavZ%
znWFKK+<0yZ|A0Y^rK_rQXac~)Pk3FJfjWMeiLmuM%I3_Bi0+`g-?-&cn(mpnqH#zQ
z#~2Cr@gxTbL%986x@d$cmA{AE*w;zXS96jAJm-s57dCw0L29{frc7TjWD3Cmh+ls*
z?ZkaHg=0-Z-YB!FCphTn#tXcj{e^jIGe1&}M{aRQg}8-5VVy;!ViwNbO02W%#?pY{
z6uEhgkZwQS>yV4^i0*Hfr7Fqc3~#preKbPY>bKrOo#S@mz%fa6$-1kyeBW9wS&S>`
z0<#ntVSafQooS?8uPYbSYP!K^c3MPsW{X6Iw?;28NsH+7ZL|(BTGg_EJrFL0*`sQw
zAxd5dP~e46!Ekl-X<;km3t{1$K5a2%;yihKJjn5^i)Nh$ER=Ii>g*%jA@zfOv?Ps;
z9P@6>urxv;m_2Fqu}a<InCv=zme;Wm$37i}yD|1p3Jsd?q@-p}?FNdzH=CBLJmd=s
z`XUJN1?y|E#;4`P3cZL<nAgWwY34!G=J1Y1&#sW6*__fUxGtRDfifZe!qJV@!bv<k
z<v42L=^A}r1_p+{qpQa6-(>_`e`Cf{@_(zWsv0p7{`#Ew6)1h}kwHukPXfbXxUi~f
zfP`DL>IfUMlQ1c!!y*ZoXSe!;S5mY;M(*yK|3A*ozx<vaYE4Z|KL1BPY-*v1y547U
z{Z_}J2D9PpdEMt4LNTVGjm<1JVFVu~f||YdIon+690B*jyNms~{k#CBl#~=Hsciew
zZl9Z30%albfB*g|9gcIiAbTp{_MHOR;q4@UrI`sncYhSInxy<_U{Fov*5h;IsMlbM
zBz(IS%w;i3*zxeU(`Iip#qIvm1_H6Qx8Hr&;Cnv8JYS_<r}E&c>PjF+{@Cese2dU*
z2LYEc@PUksEIB8K4f!2sy6E#Q{f9h}oZ+FNgBFLyYF#)9RW+E4$MLdwnvs8d((`U2
z*?r4zhM?AOT*zOe_QdD_c(Ep{snWy4L)yjX?Qoh|O>IL9z28?$M#}g^i0lceZ2G^8
zCk?*YUIT4~{IKGO0uNLhIo@iX9o<3F9dzccC=!lTtAH)<{T$EF5)wfc8M?Z<1_Nkq
zgZQ`4PY+&sB7WJI4VVly(S(JsLZUTpd5sdK9F$m{PfYo7DQVf+W9#%=*=aAGCo3u{
zA_?%Orl$7O3_Zx;XuqeM=nuzIDeO<>;c&u-;%cntmzIVpXS^G-2|$-9M{!bM@Wa*0
zWJMrJQQUHAx8CS*4<tLjxGQgHNQj64pPQ+i&KanHXuP~wUCml(%#*K&O-?~^hkzr5
zD-VwFqkrn}v59jqn!qa1s}s4^zMqTX1msOIW4J!jyxfL64A$4ztCWbND$(*OkY<ZL
zj6XW@i$xdu2qa{$)fn?xO=kC%-}#Cxz^M3~VE5N2cAewv>jo(*uQ0-YZ7?!2&es`<
zQd<Tj!?nFO*uj-{(voGvGq<!<lavfDV0gKlQx<%EQBjtgxFQ0Ml9);ifp|aP?GIEm
zWq)!mN5sXrx~`8(MfJWumh-tjMpN6D67ar!RZ>#I|N1>Yf5w+DUod9|y1Inq<>Vp>
z@igH6P@v<jQx`s{chU!eo4ulux7lc+0JXrT;ECq>^ivTm&cGY6TEG1N0|6N`Lh2=K
z0!yTYGf9Bkk0;F-ij64g@|tuq{jFpP`s-lE5I!X-F84!?P9+v`60>OkyD_8ljQ3XO
zx=ofdgOLOloL|<Or<U7|kZFg|;1okdCDJlbK6EZ%6N*K6UmZ#h4Gl?2brlqdOCtuo
z)zH*boyrx~AIR&A<W0PN-jrc7>2||;EZEXp2&mD_#vnyV*tCC{mc%i+J=@;O9@zPZ
z*cCi@3dCn+MU9S*)=x~br(rm@Qm|_e-lTHI{NwnkRQilB@Mq9uF7~~Z6y*mqQ`67k
z*i@gvit#cvg~UZgMWq*24DW0Mx9&@ZvcqvS%n*EQTDkI%03=s5z+Ztcb9JT4cqj+0
zk00=~L0K=7M4Tf`UmmZLo=S=k7u8Eoh|6Y4bMD+YyYmHLZEbw1si|SAMKUIre`cx!
zUY?;!N;1B_LYbMF<&~A_qED9u9;ZKJKJ`AOrlh7878XKOYS&Jf@}|m2x>>Eib8&O`
zpLonk;s}R;VB<8o?eQ?<3c-&J1p4^)n_c&nI-g-4RNm>q84mM#-cww!4Ysg>Pgz8`
zD75<Da`hKf!4;XV3wW~gzL?;3XLHA2CEm?$Fz$yZ=XWuOy614&;B#|xAHefBYN=>w
zFdRR(+{*?fYHsS62ZT=SZvrw0cu_hLjzOZuRk<bg(rLlqo6Jyr>Y{7<INP*r<8XWa
z0^*+UNFw9oVO5<+Go}4%b0h_BW+gQRk3Ft}s=g6+^9}V(5*m^;Ya%9Y7bA;iE}858
zBvGyIVM4s6iJ>8t-{p*Kv*{3ekK2Ko_d!Y8pE+ewtm++?)!qQniCp0|EyLkxG6FH=
ziF!Clp)9r6pvMaXBjZdqzpM2`CU>*#!t0K!MScANMkS}<Rz_9W2;wx^b6emlfbYTU
zE+ti>+x58tJ&y#vJ*doeyWV*Ki&tf-)=;kTLcP^-!y4QbE}v`r`{SmmAj`8%ZoAKF
zYKawJ+FbVJB@M)?AkV*fdmHv#M9hESj!sT$;i*VUA_za84Y1Wf(2q>{VKa@Lu>6RI
zGuf*a0-jpkS680`9<tDtmv#UU&ywTgjdlIi)bKa_A5Jd!(u^vZu1Ji0P1<71ii;7Q
zX=^N$eZlgW<z6x{TPZCrX6W&I@L1T2YRLgn=zAQ^rrJ{#)tu;$(Lg6kFWkkoADJ-(
z>n>w#a7P)e$<CAQf0|F$S}!JZ1Tlt{T-pubm$#$eg7@7k?~xM^lu<c(`9dTN;xn+;
z`Y_p9S&Qi;!w|n({Os~7Rz>={r2?aOSZj$%OiE(o@1L(wZ%^1ui1-7}(vd|e|H+_Y
z0lf=oq%=jqBfu2&{5yVgyfT0#WY359@BZF9lgB~t2Zh@E_wVn1cKaY$B&Vb}+Yr0d
zEsgcwAHEq7h)@<s982S9U0{wAI*)i%^2*qjl0rg4f|GEh>sRshui}1v6)LLXQ%<+{
z4HDGux?d?EABXC3vMLR7Ahw;hi=H0&)W`^0vis#9)sDO0S!e)_pa*MRMa2vSYvLi{
ztsG1W-r(I~(p$6dXJ9>5G?Qkadi-6Nn-$cP7sQqLrIUd=i$|$bD4mM%opf(+@1XXj
zQ6()aOMyzj4Ry_9y4%NdwZ(x#&X!>V>~mkRl3sgqd@wZMP6jFM7TiRA_`bc8;quLo
zpSO`D-#42E+Q;m{fX6aL#P`S0_6c#srH?*rVC^Hh$9o9>zqr)G-cp0G`4R;Z@0}Q4
zczWmSV_mxU<)icLC=yyLt)FOUxNVcWUiz9hWnwAi%9L`@A#Qn7vhOX&tv^6?n9Pur
z!{rc#=H;jIL`9(-OFM|*;K>;oBkt2J@zoIx4Gq2vm710BE~`V%UnImPCMSQ7jEpcK
zs#W<P&6Z&JJzXt{OI`mPrb${l+T)3&CCtOFYPdyx{&5aX=1JjdRhOOq3U-*J7?j~H
z!cw(v5ehp$kAebgHZ|CQeXI-er+V>F+@q?xp2PBh(hpfOS65e+JenFB)Ac3;dOk0^
zaIX>;edumA5{UJ&7we2ZMNCHO(nsVM6a-FXaw{mH(mBI#zsDsZkzH&3q&?v#yshB@
zJdGJWo341Ijs3r^rTe))v3Y`??5O?YKYm!-1i%+r$#@fvB_7Avn%m3?5=3C0XFSz;
z2l)AQ=YB9Eni)LtAlT3L>i*c`d*@PFT|GEV6TrH56$8oQq_Sg<d>4UAFB>ZbGIqKI
zY31vP8-j!gc8P4)#dcS##VT!%FEKF|F)=ZS0CikA$SQO!ENGxs;Bx*Y#p88u4$`0M
z)y~6d?-aGq@!R9I);P>+e{<7N^LmjwIgYrQTk+_pKb*SCI>)x#-$GNz0<ZnOy!Z`0
zH{4CUSkMChP6a$S)vDN<zu(H91M9cEurTQV@-_0iA|fIrRB?8G3sxGm^$?svGuYJ~
zH$QzeA4v6Q<j1}~;5%aAQAD6Bar)i6ebm-wHbeB5$c$cgvgqWc;WQS5&WxEmS?+v~
zG0hJWqtY$YPDK!0RAfi)X=_WbGwe)N29=uU@p40r4&K+(&x;5z{fSyi=+^9IiI0!I
zATA=Kp`n$=66!4q*)MZe>$hUJZg^1S@VkDGos-_0+jHsPznFo+A#nQMI&J?dv8_6m
zU`j<!8ymVlSquM=#Zw>~M_sL6rbI|VF&2S}g@vV|t{zOlthDtbf&O^9K=Ks}iwP)G
z9QrE;SpztL&k)RFPDsSI&uMp=Aja2cxJ)Y$BeaeD7Tz-B+OF)5Bq6i_UcB}8Z>B4w
zK{1Nm#VaC`3(h~`|7&=7*fnjeWQ|$iW(}Wt`4HYI1G|K;z54vX8Ghjg6kwXvUc`sO
zQ>13uuE?;7Y<_|$Vm4Fqf<&@;G$8$#?f2Q)*$}g`7T?l(gcN-;yaogmY($W#pM|O_
zDoj9bJAS;oh<2SMH5=dg#~C+Fu*F_j%Zal;jQN-1Do6Jt^XVUS;K-rSX~I@I`Q(J$
zB)V!(vUa0sI5Oh@WyXXtY;=4d9=`a$+fi9(Q(0VtDl1=S3VFHcqk$(JME?YV<>l2e
zIKY4I1Fv(#u#pweCIiJ}#egW=*sx$x@~LdyrKV2L&ujE}o_?GqxNPPNeAQK59es1O
zRLA{om1o~Y1^zb9#lc+(fTeO6)t2GA(Bsg=Jn%kU<h?Xw5yw#QDy0pO21-jwZTen(
z&_}l<V^KOw!nmiKs$Qf{hjxvJC0F_c%oIxh7#W#ygn!GX?iCByCw#LWESJR8Z!U~k
z3_hHx0)9LUF*X<l=bPz?1)bxf2{Ab$hGbFw=#dMHhlRC<ICGj!kN?yC_D%1L@Zav6
zkC~h%@C@}*DZ_g%GoXC?^ZamH1~&01LbZ49+tQBYeN>?9BS)!X1_U4@oljYJ<i(;9
zG0^lp@C&@LUD%=VzYV0k#JgOrC~_H~#Zml;5Y?sha|RKplfv~=L$kd2JyF!y_zpB(
zMHnRPDi#)ue)k7udh0@e$lsbGrX(jLrXme(Yb;T7$llUIz~*mWXZl&9kVZSKEd0L3
zSNYvT3)iou_0FCfguV{wD53;&&rYl$W|5ct^=C;^Zed}=zWT=9NvsGlY1Gzrm#7NG
z=`v-S%F0R?27>v8g^?`X)g;Aw6d*T>tHk4IG3NZ@0!!E<GJ?l(-MXE^>hboUhN`NG
zh4yr%=j9-Qa{8kCY_VMF>3pZQs;W5H+17E{#^DMp&V;HNv}|lKvvYHDeRYshQ8P@D
zJmqmWOe%r-2nqlI9aNy`^S?L^ZEX^rhtO!+#J<mr82QU_#;*vVwZA$Xv_=zZk~Q@7
z&{g9+m<Y06;P@;|pSdNGua3cUqaokQM43=Tc9mwwjgA7Jo4;^~)6kCRvjLp{B^(i?
zyz9+bwPh!towYTm^mrH+1u+8)f$CQGyX`NVo~J*tC{W9Z<cC?uuPoJsGHlq1EzRD4
z*iFWG4z3!|#M6vPiGKU~R`Y%mbT>20%cv)(-tM}+{=(p#;k>3N1pfY+DGEDG7~bgz
zo4!Uvxl~nIS5-A3Wpz(Vx;ZOu#h16Kz?)pybsTA{9swh@#_iW2S_(A>PA2IYSZ9S@
zUF+C*p!Guj)LYY=r8m$52W$qsbZ>X!6A;XlDd**T{@KPkKLwH5T2{`{sU73Fo{Jg6
zLO?0voBsOsYmMG0cP-RFet!N}930HRAV06S)mHbHZ6;bAs1Dp9GmxB`s%B$TQJ^^8
z>G?@sQITQApt_$5dM*MFfNCV+o8fAdBEW{19em#$tzr&>$?U9}{aOoK#L&I3NSgt>
zmYP}+*j(SlsHZKWASxmD2Xo^0XMa0S8_&;O2Hf9)yE-&DSe{B0n)RbG?28~FF>zr>
zhd|;x@!}`6<HF$8dmgxQCpbQgt#D}ncaUR1H`e03BQw9a_znn+pr?)tI6VUQBwY-t
zCKX<F5)^qwiD<hPGH<bp3JWE0(@e@RsfBc;s7;VXzKFl<@9i~!LPlDR$@)$GKYu#X
z-0&A;yYzZ?o%*Ie;R5*Idwb%MOE|4-Sd;ufen$s+r{^gX0-Unv)8R@JbE#5JrG6>C
zQW#(iYH>X;+6W}jzbS@&L3*1YLmjWFbiC3Oj=8AOIP=M4$@-mc=ScCCiE63tProyo
zLL}fej&ow9QV5<~5enV<)O|%fg4Z7z(R=m{BNkqp&8TPn(g1+`s_Q!cvaC!yisRk8
zcJjN^<79S&#Cliva>H{|b+gA${~=`l_j0`aS)K(Ev=?w<N{mRwZS3$kkq7gT4s^e&
zy1Fv3gV9xn&%Q)P7Fgx^ExtBI4FCfGC}JLG6cU&9G%dSO(3Of}_vNetN5ayP!-qkR
z*@%Ki5lx1skAO#r*hx#ays4R)O@9!QDS@1EDG?FTKj|pqf6>v=V#hQfg{iBnAM`x@
zC6J-6B@s|EsM4zW6&V?Me$6!?u;I0z^9U}30dsTL7lI#Q5h&E3#eRNXrREE4tAsPC
zGNjScHAf$*kO~W7R!kQI^BcyR_Xl9yQx4KDIy!oJeSN&Vy!<Yd(O~N2s4oz~g%aY}
z2dClgdstD{7C1ro1I7S}jHcj?-P#QLxu^ui@{~OEusDAR_1JT@boC;(k!-avH$UUH
zTbu?Hj^OJ*8KLD>H8p!+2V5@oKBshep8owTc?c#a(X8RGA-Mf-HvMi416iCfHixVk
zf?iV4#Go;o12j9e9OH3a+^gP}4B{Bv@q}NaLGVh*%ZmdIguJry@N$FMTbEsEad9!N
zhzK=Um~X#>{1XDg?AF=#fQEs=cw<vjLRy+E3A@2`rI>k80|5X!D%I1U-DF%o=;kqE
z^O_;46JukN4h}VxI_h=ZGJb=Y_X%XnHsi;<T5C_yquf3>y~)aT1}q$~2~?5e%AsGR
z-a^zro2-;YjQap`J||j3_XSN*K-lpr)*SQ%JMVn|CmD`ian1JU*ae-hmYUy1iWRAN
zhNn=IDZVJp55>6t-CxIkw2-V7rCVh|=kW5=uoTd?IPLyOu=KhC^R`fT0%RFBGS5EV
zP2b?4prF2PkHofji$*NjG=MKVmcj^<6LcH9N5#Y}>LtfsCoo1x>kkD2ED!<ZUF%v*
zX(>}_F`&a}N`zqiu`UfxOi4)zIA}KGkAYuKS2#E7IX^&uOo#x3XH%9Wvt?3~&lGE1
zodVn?-**1hgY=oQpxQuG?n@>08q_|gy)XWJh#SNvX5urOESciQ>sLWX0foNb({(z=
z5h3UVznk%;9D0>MQ{hkvB;Vhha{R486u;}-!UVxgLrcr@`q?@-#v+iDMyx`!#~kRS
zM3-Rm{uyZ4ud)(3Xf=^Jbj8zTt0AQ%)z#RTXykM9RjaI6Hp}?cvnZOe+O+x11sdF0
zyNqz8e1@3rT*ev0`JL}7R#hOQ#QN0aq-AJms8VWa3p>G&J%5ZX3_&RXpa4QVOBLQQ
z_g{1LKAyw&RIX{_Kg>e7xwy85NQ|Te6&OYk>-Z-g$@L~r+I6wVVJ<>XBT3BeG1Ay^
zEm7YUs9PaGM}pY6lA&JB3@(Ijmz%jna_kpe?|XUBN^63LD3L(~^Gi!+D~%RxTD`>M
z9BRamAI)Ruh$+_dC#Yk|NJz@K&0M<yO)052+O_r=;hr+@db2-?CL0qL6r&Mq4e|J~
z|H>B+Zgas$Uy9Ua%{C|pB~n>wsQ^Er5IH9FygPirg1*W@ujE^0Go{7+o{MT4yCIZ+
zO$=LbKLYjlR9+oLt`?;aM-SLC8+vwDTm*sF8NPs=CBkuoIAYZnj_VS^?|%G~^2o3o
zKM@)bLlQDFBFD!Si%UvCISdAv{>C)EXK*gAt_6dLK}w26`SYNSP|V`_K;oRFAz{B<
z5BEQcc`&P&A3B!*Dc|Vw$eoLwQoHT`{!J+^3nqdG7ggJHZ(A!xy)V#Dd-p9A<7<EZ
zhyFq^EJ@(nwt|-%WL^JiM`GwaL{zykPu$dA6D+;z+3QI6xTfBkGQ}{|X6~l(QAcVT
zbS?`O^fGkExxVLeYf|+VW5kjWTF6Iz{jpCS2TYwagGG_3gLIa|TQ^ilmqjytJdQx0
zx%3e3GcsNhTJbAW?|ulp6>Umd+65lHjJ4-G6!-D;w`NeZ*Ariv(;{4wlN7Q?0S8^C
zt=knN7$CH0AaI9|DEKO*1U`mFG<Pyrn4-9mj1ndeO0+rjMDe{h24Yi^83cGN4|IBl
zp)pSW8K@%tQz&M#k9`-DKu<{fW&yp@8JJ71oxdf_9R+cQYY%a*Oc^Izp^v*v2M-U-
z6EQ$4)sdT@sivYFni}2`(7QM(ZTd3l#j2*^v6rHaOy_rAB7HmP!AW*O;t>RgfV`Dq
zl^eKpL_`h{7U2O~-8Vl6K<u8Go`!j3@;#b-d0D^@-N1P0Oi@G{xH?+O%JETD>ysDo
zI8NuhKrZ$&VOLUAELIk|lOh^`qQ{Q#e)>6{l$gjmB_FE><_|_Qvl^|Vh2kv{TcBfJ
zYPv!R?Wij+&u39DB}J}Im7E790(*FuVYfH8G88%;*8T}ciZ<XyR1Vv^Avq#%N{i=+
zRvkhLDpgUh^Wwi=D5feG=jUxMA5~P!JPzmO+(+9Lq3-VP2K<%ZuPY8zr4Y|uOMtNE
zMRGTy`Ec7X2DGt#TALdR9&YX#EZ+6}EDn15;PdlyH(ml_Vq#EfCS6V{*uF=u<vh3R
z4t=K|1%#OMpo?Y5xVs?|mlPMDfq5a1b!&Zol<3oea^Su&HIA~f^1j_t?H-s|;v~}B
z+S%Q0zC7RbCAbSHi1}<GilEhH9N-o@ws2AVYrA)nN=!fX2cw`!lMzX&sH;n^tgJM<
zA8GyXQ7UU|u_XwVa|EQp1dAca96dNG48bW&Ce2y}j~~WwV(mSV$OOC!Z+ddB^!wuM
z?0osBC{7I&hC<T@pNt9%*;E`I*#p3nhp(l^oy1etbntAX^MJ8qF&|)uEU_Gt=h;bq
z5<}nANI*c~3??NIVPPu2hwGAB!_LO^bkbX25pV{UAhX|sTcfI?0x&*ysp?-|Ba#o{
zH@jxjD6UE)KgsjluaskX?<+b37eKYc7;NZsOf>G{v5GJS4Gj(7^lYuDxZoDz>LUpt
zgv<70;nnR%)(KZ5W67!Y9QJP4a6u$1K2`-UEY1N{V4~%2kS=p2wHe{0N%WP1L)J8W
z_9!_OTvz#licyG_xz8^|Z^T<X*z=4GAkz|7q&7hAp!1!b7&0vo;$-t=M2Qw2-;(SP
zM?00@PdTyWK#3Go@R-YV@Z7r{M=-;#j{g|TvM-s<a-u3Y{d)!8n3g@r?fv{Di-%x?
zFmB)sSQymNzqv(|=aKw5e$!(ke-%E)nr}G?GEF^=i((y_7m*V0t)^9PR2e!hkC;b)
zT}VdqfZJE+gvVUdZw7&RnsA^>HnXD0xR0T55{YHc`}4Awh>@eblt#*b7+yHCCUn4J
zO=NuXp75~+e37@XC$@~_nQTa5`*6pLWbxl|#mjz&)DCU&+W5Z-7F`^OnW^V#U6?mC
z$;kj@B)$y4(OunbN!LAj1@F+J{*&x>M`RE9OwboM1Id?`992n;dW(KLzqZ{+hLx*Z
zuG9IXfz(^&Sy1@=S1dxDjvX(sn-IhJ)nkEf9SWyGJHCEBwg}*pLS~fj`-0tfV6C-K
zSkm*YK|)CzfWl47im%NQ!XE^4LfoJg#C^(V`WM#&0rrX+LC%y~A!1bmA0a`O<*f>L
z_Oo}waL;V6zb@oMp&jsTnEtl{#LxLZKU(yWC-)0syi_!lZMAN{6#I&nJ!%!H=TeA<
f!<SkgjlZDu#P5sF0LHT589g8;tt3?|VI1@y22Fs4

literal 0
HcmV?d00001

diff --git a/symfony-3.3/web/config.php b/symfony-3.3/web/config.php
new file mode 100644
index 000000000..fd7e17e6b
--- /dev/null
+++ b/symfony-3.3/web/config.php
@@ -0,0 +1,422 @@
+<?php
+
+/*
+ * ************** CAUTION **************
+ *
+ * DO NOT EDIT THIS FILE as it will be overridden by Composer as part of
+ * the installation/update process. The original file resides in the
+ * SensioDistributionBundle.
+ *
+ * ************** CAUTION **************
+ */
+
+if (!isset($_SERVER['HTTP_HOST'])) {
+    exit("This script cannot be run from the CLI. Run it from a browser.\n");
+}
+
+if (!in_array(@$_SERVER['REMOTE_ADDR'], array(
+    '127.0.0.1',
+    '::1',
+))) {
+    header('HTTP/1.0 403 Forbidden');
+    exit('This script is only accessible from localhost.');
+}
+
+require_once dirname(__FILE__).'/../var/SymfonyRequirements.php';
+
+$symfonyRequirements = new SymfonyRequirements();
+
+$majorProblems = $symfonyRequirements->getFailedRequirements();
+$minorProblems = $symfonyRequirements->getFailedRecommendations();
+$hasMajorProblems = (bool) count($majorProblems);
+$hasMinorProblems = (bool) count($minorProblems);
+
+?>
+<!DOCTYPE html>
+<html>
+    <head>
+        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
+        <meta name="robots" content="noindex,nofollow" />
+        <title>Symfony Configuration Checker</title>
+        <style>
+            /* styles copied from symfony framework bundle */
+            html {
+                background: #eee;
+            }
+            body {
+                font: 11px Verdana, Arial, sans-serif;
+                color: #333;
+            }
+            .sf-reset, .sf-reset .block, .sf-reset #message {
+                margin: auto;
+            }
+            img {
+                border: 0;
+            }
+            .clear {
+                clear: both;
+                height: 0;
+                font-size: 0;
+                line-height: 0;
+            }
+            .clear-fix:after {
+                content: "\0020";
+                display: block;
+                height: 0;
+                clear: both;
+                visibility: hidden;
+            }
+            .clear-fix {
+                display: inline-block;
+            }
+            * html .clear-fix {
+                height: 1%;
+            }
+            .clear-fix {
+                display: block;
+            }
+            .header {
+                padding: 30px 30px 20px 30px;
+            }
+            .header-logo {
+                float: left;
+            }
+            .search {
+                float: right;
+                padding-top: 20px;
+            }
+            .search label {
+                line-height: 28px;
+                vertical-align: middle;
+            }
+            .search input {
+                width: 195px;
+                font-size: 12px;
+                border: 1px solid #dadada;
+                background: #fff url() repeat-x left top;
+                padding: 5px 6px;
+                color: #565656;
+            }
+            .search input[type="search"] {
+                -webkit-appearance: textfield;
+            }
+            #content {
+                width: 970px;
+                margin: 0 auto;
+            }
+            #content pre {
+                white-space: normal;
+                font-family: Arial, Helvetica, sans-serif;
+            }
+
+            /*
+            Copyright (c) 2010, Yahoo! Inc. All rights reserved.
+            Code licensed under the BSD License:
+            http://developer.yahoo.com/yui/license.html
+            version: 3.1.2
+            build: 56
+            */
+            .sf-reset div,.sf-reset dl,.sf-reset dt,.sf-reset dd,.sf-reset ul,.sf-reset ol,.sf-reset li,.sf-reset h1,.sf-reset h2,.sf-reset h3,.sf-reset h4,.sf-reset h5,.sf-reset h6,.sf-reset pre,.sf-reset code,.sf-reset form,.sf-reset fieldset,.sf-reset legend,.sf-reset input,.sf-reset textarea,.sf-reset p,.sf-reset blockquote,.sf-reset th,.sf-reset td{margin:0;padding:0;}.sf-reset table{border-collapse:collapse;border-spacing:0;}.sf-reset fieldset,.sf-reset img{border:0;}.sf-reset address,.sf-reset caption,.sf-reset cite,.sf-reset code,.sf-reset dfn,.sf-reset em,.sf-reset strong,.sf-reset th,.sf-reset var{font-style:normal;font-weight:normal;}.sf-reset li{list-style:none;}.sf-reset caption,.sf-reset th{text-align:left;}.sf-reset h1,.sf-reset h2,.sf-reset h3,.sf-reset h4,.sf-reset h5,.sf-reset h6{font-size:100%;font-weight:normal;}.sf-reset q:before,.sf-reset q:after{content:'';}.sf-reset abbr,.sf-reset acronym{border:0;font-variant:normal;}.sf-reset sup{vertical-align:text-top;}.sf-reset sub{vertical-align:text-bottom;}.sf-reset input,.sf-reset textarea,.sf-reset select{font-family:inherit;font-size:inherit;font-weight:inherit;}.sf-reset input,.sf-reset textarea,.sf-reset select{font-size:100%;}.sf-reset legend{color:#000;}
+            .sf-reset abbr {
+                border-bottom: 1px dotted #000;
+                cursor: help;
+            }
+            .sf-reset p {
+                font-size: 14px;
+                line-height: 20px;
+                padding-bottom: 20px;
+            }
+            .sf-reset strong {
+                color: #313131;
+                font-weight: bold;
+            }
+            .sf-reset a {
+                color: #6c6159;
+            }
+            .sf-reset a img {
+                border: none;
+            }
+            .sf-reset a:hover {
+                text-decoration: underline;
+            }
+            .sf-reset em {
+                font-style: italic;
+            }
+            .sf-reset h2,
+            .sf-reset h3 {
+                font-weight: bold;
+            }
+            .sf-reset h1 {
+                font-family: Georgia, "Times New Roman", Times, serif;
+                font-size: 20px;
+                color: #313131;
+                word-wrap: break-word;
+            }
+            .sf-reset li {
+                padding-bottom: 10px;
+            }
+            .sf-reset .block {
+                -moz-border-radius: 16px;
+                -webkit-border-radius: 16px;
+                border-radius: 16px;
+                margin-bottom: 20px;
+                background-color: #FFFFFF;
+                border: 1px solid #dfdfdf;
+                padding: 40px 50px;
+                word-break: break-all;
+            }
+            .sf-reset h2 {
+                font-size: 16px;
+                font-family: Arial, Helvetica, sans-serif;
+            }
+            .sf-reset li a {
+                background: none;
+                color: #868686;
+                text-decoration: none;
+            }
+            .sf-reset li a:hover {
+                background: none;
+                color: #313131;
+                text-decoration: underline;
+            }
+            .sf-reset ol {
+                padding: 10px 0;
+            }
+            .sf-reset ol li {
+                list-style: decimal;
+                margin-left: 20px;
+                padding: 2px;
+                padding-bottom: 20px;
+            }
+            .sf-reset ol ol li {
+                list-style-position: inside;
+                margin-left: 0;
+                white-space: nowrap;
+                font-size: 12px;
+                padding-bottom: 0;
+            }
+            .sf-reset li .selected {
+                background-color: #ffd;
+            }
+            .sf-button {
+                display: -moz-inline-box;
+                display: inline-block;
+                text-align: center;
+                vertical-align: middle;
+                border: 0;
+                background: transparent none;
+                text-transform: uppercase;
+                cursor: pointer;
+                font: bold 11px Arial, Helvetica, sans-serif;
+            }
+            .sf-button span {
+                text-decoration: none;
+                display: block;
+                height: 28px;
+                float: left;
+            }
+            .sf-button .border-l {
+                text-decoration: none;
+                display: block;
+                height: 28px;
+                float: left;
+                padding: 0 0 0 7px;
+                background: transparent url() no-repeat top left;
+            }
+            .sf-button .border-r {
+                padding: 0 7px 0 0;
+                background: transparent url() right top no-repeat;
+            }
+            .sf-button .btn-bg {
+                padding: 0 14px;
+                color: #636363;
+                line-height: 28px;
+                background: transparent url() repeat-x top left;
+            }
+            .sf-button:hover .border-l,
+            .sf-button-selected .border-l {
+                background: transparent url() no-repeat top left;
+            }
+            .sf-button:hover .border-r,
+            .sf-button-selected .border-r {
+                background: transparent url() right top no-repeat;
+            }
+            .sf-button:hover .btn-bg,
+            .sf-button-selected .btn-bg {
+                color: #FFFFFF;
+                text-shadow:0 1px 1px #6b9311;
+                background: transparent url() repeat-x top left;
+            }
+
+            /* styles copied from bundles/sensiodistribution/webconfigurator/css/install.css */
+            body {
+                font-size: 14px;
+                font-family: "Lucida Sans Unicode", "Lucida Grande", Verdana, Arial, Helvetica, sans-serif;
+            }
+            .sf-reset h1.title {
+                font-size: 45px;
+                padding-bottom: 30px;
+            }
+            .sf-reset h2 {
+                font-weight: bold;
+                color: #FFFFFF;
+                /* Font is reset to sans-serif (like body) */
+                font-family: "Lucida Sans Unicode", "Lucida Grande", Verdana, Arial, Helvetica, sans-serif;
+                margin-bottom: 10px;
+                background-color: #aacd4e;
+                padding: 2px 4px;
+                display: inline-block;
+                text-transform: uppercase;
+            }
+            .sf-reset ul a,
+            .sf-reset ul a:hover {
+                background: url() no-repeat right 7px;
+                padding-right: 10px;
+            }
+            .sf-reset ul, ol {
+                padding-left: 20px;
+            }
+            .sf-reset li {
+                padding-bottom: 18px;
+            }
+            .sf-reset ol li {
+                list-style-type: decimal;
+            }
+            .sf-reset ul li {
+                list-style-type: none;
+            }
+            .sf-reset .symfony-blocks-install {
+                overflow: hidden;
+            }
+            .sf-reset .symfony-install-continue {
+                font-size: 0.95em;
+                padding-left: 0;
+            }
+            .sf-reset .symfony-install-continue li {
+                padding-bottom: 10px;
+            }
+            .sf-reset .ok {
+                color: #fff;
+                font-family: "Lucida Sans Unicode", "Lucida Grande", Verdana, Arial, Helvetica, sans-serif;
+                background-color: #6d6;
+                padding: 10px;
+                margin-bottom: 20px;
+            }
+            .sf-reset .ko {
+                background-color: #d66;
+            }
+            .sf-reset p.help {
+                padding: 12px 16px;
+                word-break: break-word;
+            }
+            .version {
+                text-align: right;
+                font-size: 10px;
+                margin-right: 20px;
+            }
+            .sf-reset a,
+            .sf-reset li a {
+                color: #08C;
+                text-decoration: none;
+            }
+            .sf-reset a:hover,
+            .sf-reset li a:hover {
+                color: #08C;
+                text-decoration: underline;
+            }
+            .sf-reset textarea {
+                padding: 7px;
+            }
+        </style>
+    </head>
+    <body>
+        <div id="content">
+            <div class="header clear-fix">
+                <div class="header-logo">
+                    <img src="" alt="Symfony" />
+                </div>
+
+                <div class="search">
+                  <form method="get" action="http://symfony.com/search">
+                    <div class="form-row">
+
+                      <label for="search-id">
+                                <img src="" alt="Search on Symfony website" />
+                      </label>
+
+                      <input name="q" id="search-id" type="search" placeholder="Search on Symfony website" />
+
+                      <button type="submit" class="sf-button">
+                          <span class="border-l">
+                            <span class="border-r">
+                                <span class="btn-bg">OK</span>
+                            </span>
+                        </span>
+                      </button>
+                    </div>
+                   </form>
+                </div>
+            </div>
+
+            <div class="sf-reset">
+                <div class="block">
+                    <div class="symfony-block-content">
+                        <h1 class="title">Configuration Checker</h1>
+                        <p>
+                            This script analyzes your system to check whether is
+                            ready to run Symfony applications.
+                        </p>
+
+                        <?php if ($hasMajorProblems): ?>
+                            <h2 class="ko">Major problems</h2>
+                            <p>Major problems have been detected and <strong>must</strong> be fixed before continuing:</p>
+                            <ol>
+                                <?php foreach ($majorProblems as $problem): ?>
+                                    <li><?php echo $problem->getTestMessage() ?>
+                                        <p class="help"><em><?php echo $problem->getHelpHtml() ?></em></p>
+                                    </li>
+                                <?php endforeach; ?>
+                            </ol>
+                        <?php endif; ?>
+
+                        <?php if ($hasMinorProblems): ?>
+                            <h2>Recommendations</h2>
+                            <p>
+                                <?php if ($hasMajorProblems): ?>Additionally, to<?php else: ?>To<?php endif; ?> enhance your Symfony experience,
+                                it’s recommended that you fix the following:
+                            </p>
+                            <ol>
+                                <?php foreach ($minorProblems as $problem): ?>
+                                    <li><?php echo $problem->getTestMessage() ?>
+                                        <p class="help"><em><?php echo $problem->getHelpHtml() ?></em></p>
+                                    </li>
+                                <?php endforeach; ?>
+                            </ol>
+                        <?php endif; ?>
+
+                        <?php if ($symfonyRequirements->hasPhpIniConfigIssue()): ?>
+                            <p id="phpini">*
+                                <?php if ($symfonyRequirements->getPhpIniConfigPath()): ?>
+                                    Changes to the <strong>php.ini</strong> file must be done in "<strong><?php echo $symfonyRequirements->getPhpIniConfigPath() ?></strong>".
+                                <?php else: ?>
+                                    To change settings, create a "<strong>php.ini</strong>".
+                                <?php endif; ?>
+                            </p>
+                        <?php endif; ?>
+
+                        <?php if (!$hasMajorProblems && !$hasMinorProblems): ?>
+                            <p class="ok">All checks passed successfully. Your system is ready to run Symfony applications.</p>
+                        <?php endif; ?>
+
+                        <ul class="symfony-install-continue">
+                            <?php if ($hasMajorProblems || $hasMinorProblems): ?>
+                                <li><a href="config.php">Re-check configuration</a></li>
+                            <?php endif; ?>
+                        </ul>
+                    </div>
+                </div>
+            </div>
+            <div class="version">Symfony Standard Edition</div>
+        </div>
+    </body>
+</html>
diff --git a/symfony-3.3/web/favicon.ico b/symfony-3.3/web/favicon.ico
new file mode 100644
index 0000000000000000000000000000000000000000..479f7f50f404ada1e42c536097521d19f2c22f35
GIT binary patch
literal 6518
zcmeHLTWD5E5<a=8s8QqnG7;l#42*(42>Kuy5M>-BgCK}6B8uRHx|%3>L5P|~O|ntQ
zD!!<o56(m%1Z6Z{(dY*8iiwwrn`8$CZ%kH5WO9-})$@IouJ$-%c9`e2q5kTwuCA)C
z?yjoyM^Rdo9%W}oz`0RguPFL5ilW?HKOPoE1)$}D1{QF1(}AK0^d4He(ev~3r=nk$
zlaq5ZD=VuJ{l>Jkw41=CfUf}7Y>i>k%K=@zd-rz03PXkrQJkKhPTU1316WJ0t;)^K
zbyu!jaThLJh>sjO(gCIvVc@`l?8mUf<o;j+h)0heO}%c;oH=n@TU+Y*@#B=?Zr{GG
z{KJL~bG>@?VxRKb$qO($xL+ALa-_~@WM&XcK|z6}QYkrb;DB&Ee*AdFuz@nj!@bZS
z<->;$=Qy4}f4<wdZ=Vzu6)Eq_moMe{i|5+!-@m_uU)Wb(k4v%VTK0GD+}TlIU+>ng
zT`R9&zg9W$g*fMA(V|7V4!nwC1N}icH$iJ+|IndBsoL6Fw{YP?U32~VbvbzOp!Rp|
z+QoH3{j>x9l=r2cuRkN**Q-~rq^qk-7B5~b%a<?L^))p$vSGspH)F;Om4ovzA8>sw
z{R`YNd-iNcpPfE^TKOs}D%6J$A3l`g;$nI7<cW}nyaNUdaIoPf;2#(}_&+8-di1Dp
zA16+nkix=3xpwWE(2txueE6_p^kc3E<{3@{2=5p6r*`Fkoi7U(EKnO}&YVeq>X{UL
zSHSyawhQh!&z`LUKzZ$;*}Tik%OlNg-n`jWRaLp_>grTuW24<4-nr1Qk5d>Z|IndB
zV}Rb@F=NJ1UdNOvQ{rXImgzjkRbgR-$NZsHK#uLv`8VUnjvZ_3IG5CGYYkHp{Xw7d
zUNu1;&*)z`<8uGDG1Qh^W3>M}%s80~_!^L=J#-L5|3XUxZ>I4h7WG4aK41rYe;RNb
z{dzzh`=oIWFb~idV2v^;>#wwo1oIc@?}q#)V7o6pV(@W}vHkDBqXE{EGL7~r9QKUK
z!oh<F|1x311UG8bC^v50IKjQ={U>xnM<=ldqlbHr`L~$+8^Bspw$YMU=aHXyQq|en
z*|tyB2O48DW47~gBD^Kg$xGb?+Qc=CMT8&G9|B<O$p)j--wi%?#*-&cP8~aT%$+}f
z-ZB2IT)EP82;!smAwSTt*7~$3X~z?c?L15uNZRadxbKF3{rYh&<B`-qsz<7Da^}n#
zck<*(dH?>sT)cQO>~+M55vtF}6w__k_%yb`&ZqF(P}LYkrZe14%vWR1L8kIAS+Ydq
zJoUeL@j_))R#q~1xcm3-Q-{(94H^{swD}W2KC|H*`qsi5gZ)L&PrevAT?puFo}m7^
zx;pWC<nG<On!lJw$%DJeJRv=tL((3tHNd;x8(`;<gS9Q7QNQL1oIzN(YSk*suSzQ^
zDWMD04`pR#O5+=$Eq`Kz$_5YLh24b+<Go&YZ0DGnnJJSdO=2!n`NSMk$MosbHTThm
z=g+(A5Ymyqb)NkmK>dq3z6r($w*G)-0BO9hyw_IKB<1M-knc#-^QRNgg!KSvzK%(*
zN%nO;_$&|q8-2#fZ@3n^^=%`+hBd6wE?v4LckbK~)_qHtF10y#>eMOqKlR_ce~)z5
z8j_Kb@n>hCdZ3T?FjklNeusbaS`$8c^hot?*|J4gyToy<P+nfHHtgQBTkjzCx3shf
zYE-2oUYd>n3u|nG?j6v5mbL>r;6L>d>JgQV+Aqk!e%06S-n|p#BF8%R*Y;nP*5$gS
zct^3WWsHWbPx(OSO&2kAGmqV6AMdTx*UIwr=~LDJ;K2ix#WQ*K>{;0Fwr$&#{`T$L
zKtmm+G`pic*gziI!FxvinnQt=#(i<!o;`b{p`k&xZ{Mym8Ed#vG(CeAD^@5U>uS;n
zw{G218frV4IB_EDeqBp>9(1010jeLk4!|59XvudEx^Q2V-`UxzxaLNU$&<5Z&nk`c
zO-)UK&UFOTcYmPyIn!Tn{s*1;RBc3#)p*9Y_U6qS)8TjqT<^cbWb4+gT9;El@`Ag1
z^{QOHd|B;+kCZp@p8l|Z`X3PPpXs-p!tayTwpP_oJLb-vt1@TJnx%O4>eaz7{I=jb
zS+{PTFi){I-@kvq@^L?Y-^8@Tax-hDk|Yg%>C>l=*{Xi!{t)W}jr^$Hh3AjD9n;;h
zxU{r1=;8NDYiny5`+DIc{gA_YZGqpn#s%spSloq=H3w2&<v%O++vVK3bJE=0EZqN^
zHEZmAgzuJXnK!wAdq1dWG@tp{o{T@NC$pgcXJGD6<1b|p><%;kFa|Q#KYsjJ^~{?$
zPkG2k8hyZ+Wo!8ctWTV{*LL@sKxa+M{8I)*{jtYk?eESm(7`9urcKlF#*G_Qf7|;u
zN!o?)64|?VuS}gfRr&lGs1E4d4H?$PV*FnWXan=ZM|x<3|5j2u<D{>>Le9aR(|hp!
z58sEiK5od38#hSfniT&pfUaLK{sO?JH2}_LBk1OXAOrK-$Gr6I+gHD}jYiCGZ_B&<
zrfqL;=eyK39P?b7d~CoO#Jt;(Rfx50)SaxqE@4a?v{nKRcJS`NK8@?%PWH*G`cW@v
zpE-lI5@Qp;&-snLY11Z^$r>K~tnsXwZmR`HKqm9D@&i-9%1z)TE#w*Aan@mejjUh4
zUf+fvxBFWDCyZI+vYF2A(TBR6cfoAnUEzJ84Q5Bs0h;!~ub8<%QG<}5Yh#~RsCx{6
z&Fa4H(T887(+?K`rk8dk-=@(6PVn-cbRvev^tb<CrrLkgP?PESp!MTkn8%rKf?RtS
z)Wz7r*h!#0Nicd>!j=}uC<33gAlnE%;N;oxJW2uoNyrWR#`=%?o~Id@HEm8peo|(F
z++&w_Gih%Y#@_;1x1NFgd%%wY{QkZJU>++0u%2X1YmGAOo*V5m{_KIz9{B8m=r_v|
BFLeL_

literal 0
HcmV?d00001

diff --git a/symfony-3.3/web/robots.txt b/symfony-3.3/web/robots.txt
new file mode 100644
index 000000000..4665fcae3
--- /dev/null
+++ b/symfony-3.3/web/robots.txt
@@ -0,0 +1,5 @@
+# www.robotstxt.org/
+# www.google.com/support/webmasters/bin/answer.py?hl=en&answer=156449
+
+User-agent: *
+Disallow:

From cb8d2ea96939c436b46966c9dff6f85e360b3f58 Mon Sep 17 00:00:00 2001
From: Anton Minin <anton.a.minin@gmail.com>
Date: Tue, 23 Jan 2018 11:44:53 +0300
Subject: [PATCH 3/5] Update sf 3.3 to 3.4 LTS

---
 list.sh                                       |   4 +-
 .../.gitignore                                |   0
 .../README.md                                 |   2 +-
 .../_benchmark/hello_world.sh                 |   0
 .../_benchmark/setup.sh                       |   0
 .../app/AppCache.php                          |   0
 .../app/AppKernel.php                         |   0
 .../app/autoload.php                          |   0
 .../app/config/config.yml                     |   0
 .../app/config/config_dev.yml                 |   0
 .../app/config/config_prod.yml                |   0
 .../app/config/config_test.yml                |   0
 .../app/config/parameters.yml.dist            |   0
 .../app/config/services.yml                   |   0
 .../bin/console                               |   0
 .../bin/symfony_requirements                  |   0
 .../composer.json                             |   9 +-
 .../composer.lock                             | 749 ++++++++++--------
 .../phpunit.xml.dist                          |   0
 .../src/App/Controller/HelloController.php    |   0
 .../var/SymfonyRequirements.php               |   0
 .../var/cache/.gitkeep                        |   0
 .../var/logs/.gitkeep                         |   0
 .../var/sessions/.gitkeep                     |   0
 .../web/micro.php                             |   0
 {symfony-3.3 => symfony-3.4}/.gitignore       |   0
 {symfony-3.3 => symfony-3.4}/README.md        |   2 +-
 .../_benchmark/hello_world.sh                 |   0
 .../_benchmark/setup.sh                       |   0
 {symfony-3.3 => symfony-3.4}/app/AppCache.php |   0
 .../app/AppKernel.php                         |   0
 .../app/Resources/views/base.html.twig        |   0
 .../Resources/views/default/index.html.twig   |   0
 {symfony-3.3 => symfony-3.4}/app/autoload.php |   0
 .../app/config/config.yml                     |   0
 .../app/config/config_dev.yml                 |   0
 .../app/config/config_prod.yml                |   0
 .../app/config/config_test.yml                |   0
 .../app/config/parameters.yml.dist            |   0
 .../app/config/routing.yml                    |   0
 .../app/config/routing_dev.yml                |   0
 .../app/config/security.yml                   |   0
 .../app/config/services.yml                   |   0
 {symfony-3.3 => symfony-3.4}/bin/console      |   0
 .../bin/symfony_requirements                  |   0
 {symfony-3.3 => symfony-3.4}/composer.json    |   6 +-
 {symfony-3.3 => symfony-3.4}/composer.lock    | 373 +++++----
 {symfony-3.3 => symfony-3.4}/phpunit.xml.dist |   0
 .../src/AppBundle/AppBundle.php               |   0
 .../Controller/DefaultController.php          |   0
 .../AppBundle/Controller/HelloController.php  |   0
 .../Controller/DefaultControllerTest.php      |   0
 .../var/SymfonyRequirements.php               |   0
 .../var/cache/.gitkeep                        |   0
 .../var/logs/.gitkeep                         |   0
 .../var/sessions/.gitkeep                     |   0
 {symfony-3.3 => symfony-3.4}/web/app.php      |   0
 {symfony-3.3 => symfony-3.4}/web/app_dev.php  |   0
 .../web/apple-touch-icon.png                  | Bin
 {symfony-3.3 => symfony-3.4}/web/config.php   |   0
 {symfony-3.3 => symfony-3.4}/web/favicon.ico  | Bin
 {symfony-3.3 => symfony-3.4}/web/robots.txt   |   0
 62 files changed, 656 insertions(+), 489 deletions(-)
 rename {symfony-3.3-micro => symfony-3.4-micro}/.gitignore (100%)
 rename {symfony-3.3-micro => symfony-3.4-micro}/README.md (91%)
 rename {symfony-3.3-micro => symfony-3.4-micro}/_benchmark/hello_world.sh (100%)
 rename {symfony-3.3-micro => symfony-3.4-micro}/_benchmark/setup.sh (100%)
 rename {symfony-3.3-micro => symfony-3.4-micro}/app/AppCache.php (100%)
 rename {symfony-3.3-micro => symfony-3.4-micro}/app/AppKernel.php (100%)
 rename {symfony-3.3-micro => symfony-3.4-micro}/app/autoload.php (100%)
 rename {symfony-3.3-micro => symfony-3.4-micro}/app/config/config.yml (100%)
 rename {symfony-3.3-micro => symfony-3.4-micro}/app/config/config_dev.yml (100%)
 rename {symfony-3.3-micro => symfony-3.4-micro}/app/config/config_prod.yml (100%)
 rename {symfony-3.3-micro => symfony-3.4-micro}/app/config/config_test.yml (100%)
 rename {symfony-3.3-micro => symfony-3.4-micro}/app/config/parameters.yml.dist (100%)
 rename {symfony-3.3-micro => symfony-3.4-micro}/app/config/services.yml (100%)
 rename {symfony-3.3-micro => symfony-3.4-micro}/bin/console (100%)
 rename {symfony-3.3-micro => symfony-3.4-micro}/bin/symfony_requirements (100%)
 rename {symfony-3.3-micro => symfony-3.4-micro}/composer.json (80%)
 rename {symfony-3.3-micro => symfony-3.4-micro}/composer.lock (71%)
 rename {symfony-3.3-micro => symfony-3.4-micro}/phpunit.xml.dist (100%)
 rename {symfony-3.3-micro => symfony-3.4-micro}/src/App/Controller/HelloController.php (100%)
 rename {symfony-3.3-micro => symfony-3.4-micro}/var/SymfonyRequirements.php (100%)
 rename {symfony-3.3-micro => symfony-3.4-micro}/var/cache/.gitkeep (100%)
 rename {symfony-3.3-micro => symfony-3.4-micro}/var/logs/.gitkeep (100%)
 rename {symfony-3.3-micro => symfony-3.4-micro}/var/sessions/.gitkeep (100%)
 rename {symfony-3.3-micro => symfony-3.4-micro}/web/micro.php (100%)
 rename {symfony-3.3 => symfony-3.4}/.gitignore (100%)
 rename {symfony-3.3 => symfony-3.4}/README.md (72%)
 rename {symfony-3.3 => symfony-3.4}/_benchmark/hello_world.sh (100%)
 rename {symfony-3.3 => symfony-3.4}/_benchmark/setup.sh (100%)
 rename {symfony-3.3 => symfony-3.4}/app/AppCache.php (100%)
 rename {symfony-3.3 => symfony-3.4}/app/AppKernel.php (100%)
 rename {symfony-3.3 => symfony-3.4}/app/Resources/views/base.html.twig (100%)
 rename {symfony-3.3 => symfony-3.4}/app/Resources/views/default/index.html.twig (100%)
 rename {symfony-3.3 => symfony-3.4}/app/autoload.php (100%)
 rename {symfony-3.3 => symfony-3.4}/app/config/config.yml (100%)
 rename {symfony-3.3 => symfony-3.4}/app/config/config_dev.yml (100%)
 rename {symfony-3.3 => symfony-3.4}/app/config/config_prod.yml (100%)
 rename {symfony-3.3 => symfony-3.4}/app/config/config_test.yml (100%)
 rename {symfony-3.3 => symfony-3.4}/app/config/parameters.yml.dist (100%)
 rename {symfony-3.3 => symfony-3.4}/app/config/routing.yml (100%)
 rename {symfony-3.3 => symfony-3.4}/app/config/routing_dev.yml (100%)
 rename {symfony-3.3 => symfony-3.4}/app/config/security.yml (100%)
 rename {symfony-3.3 => symfony-3.4}/app/config/services.yml (100%)
 rename {symfony-3.3 => symfony-3.4}/bin/console (100%)
 rename {symfony-3.3 => symfony-3.4}/bin/symfony_requirements (100%)
 rename {symfony-3.3 => symfony-3.4}/composer.json (95%)
 rename {symfony-3.3 => symfony-3.4}/composer.lock (87%)
 rename {symfony-3.3 => symfony-3.4}/phpunit.xml.dist (100%)
 rename {symfony-3.3 => symfony-3.4}/src/AppBundle/AppBundle.php (100%)
 rename {symfony-3.3 => symfony-3.4}/src/AppBundle/Controller/DefaultController.php (100%)
 rename {symfony-3.3 => symfony-3.4}/src/AppBundle/Controller/HelloController.php (100%)
 rename {symfony-3.3 => symfony-3.4}/tests/AppBundle/Controller/DefaultControllerTest.php (100%)
 rename {symfony-3.3 => symfony-3.4}/var/SymfonyRequirements.php (100%)
 rename {symfony-3.3 => symfony-3.4}/var/cache/.gitkeep (100%)
 rename {symfony-3.3 => symfony-3.4}/var/logs/.gitkeep (100%)
 rename {symfony-3.3 => symfony-3.4}/var/sessions/.gitkeep (100%)
 rename {symfony-3.3 => symfony-3.4}/web/app.php (100%)
 rename {symfony-3.3 => symfony-3.4}/web/app_dev.php (100%)
 rename {symfony-3.3 => symfony-3.4}/web/apple-touch-icon.png (100%)
 rename {symfony-3.3 => symfony-3.4}/web/config.php (100%)
 rename {symfony-3.3 => symfony-3.4}/web/favicon.ico (100%)
 rename {symfony-3.3 => symfony-3.4}/web/robots.txt (100%)

diff --git a/list.sh b/list.sh
index 18c1054db..8881690d0 100755
--- a/list.sh
+++ b/list.sh
@@ -40,8 +40,8 @@ staticphp-0.9
 #symfony-2.6
 #symfony-2.7
 symfony-3.0
-symfony-3.3
-symfony-3.3-micro
+symfony-3.4
+symfony-3.4-micro
 tipsy-0.10
 #typo3f-2.3 # does not work
 #typo3f-3.0 # Catchable Fatal Error: Argument 1 passed to TYPO3\Flow\Object\ObjectManager::setObjects() must be of the type array, null given
diff --git a/symfony-3.3-micro/.gitignore b/symfony-3.4-micro/.gitignore
similarity index 100%
rename from symfony-3.3-micro/.gitignore
rename to symfony-3.4-micro/.gitignore
diff --git a/symfony-3.3-micro/README.md b/symfony-3.4-micro/README.md
similarity index 91%
rename from symfony-3.3-micro/README.md
rename to symfony-3.4-micro/README.md
index 5d656566e..c4b1d8308 100644
--- a/symfony-3.3-micro/README.md
+++ b/symfony-3.4-micro/README.md
@@ -1,4 +1,4 @@
-symfony-3.3
+symfony-3.4
 ===========
 
 A Symfony project with [micro kernel](https://symfony.com/doc/current/configuration/micro_kernel_trait.html)
diff --git a/symfony-3.3-micro/_benchmark/hello_world.sh b/symfony-3.4-micro/_benchmark/hello_world.sh
similarity index 100%
rename from symfony-3.3-micro/_benchmark/hello_world.sh
rename to symfony-3.4-micro/_benchmark/hello_world.sh
diff --git a/symfony-3.3-micro/_benchmark/setup.sh b/symfony-3.4-micro/_benchmark/setup.sh
similarity index 100%
rename from symfony-3.3-micro/_benchmark/setup.sh
rename to symfony-3.4-micro/_benchmark/setup.sh
diff --git a/symfony-3.3-micro/app/AppCache.php b/symfony-3.4-micro/app/AppCache.php
similarity index 100%
rename from symfony-3.3-micro/app/AppCache.php
rename to symfony-3.4-micro/app/AppCache.php
diff --git a/symfony-3.3-micro/app/AppKernel.php b/symfony-3.4-micro/app/AppKernel.php
similarity index 100%
rename from symfony-3.3-micro/app/AppKernel.php
rename to symfony-3.4-micro/app/AppKernel.php
diff --git a/symfony-3.3-micro/app/autoload.php b/symfony-3.4-micro/app/autoload.php
similarity index 100%
rename from symfony-3.3-micro/app/autoload.php
rename to symfony-3.4-micro/app/autoload.php
diff --git a/symfony-3.3-micro/app/config/config.yml b/symfony-3.4-micro/app/config/config.yml
similarity index 100%
rename from symfony-3.3-micro/app/config/config.yml
rename to symfony-3.4-micro/app/config/config.yml
diff --git a/symfony-3.3-micro/app/config/config_dev.yml b/symfony-3.4-micro/app/config/config_dev.yml
similarity index 100%
rename from symfony-3.3-micro/app/config/config_dev.yml
rename to symfony-3.4-micro/app/config/config_dev.yml
diff --git a/symfony-3.3-micro/app/config/config_prod.yml b/symfony-3.4-micro/app/config/config_prod.yml
similarity index 100%
rename from symfony-3.3-micro/app/config/config_prod.yml
rename to symfony-3.4-micro/app/config/config_prod.yml
diff --git a/symfony-3.3-micro/app/config/config_test.yml b/symfony-3.4-micro/app/config/config_test.yml
similarity index 100%
rename from symfony-3.3-micro/app/config/config_test.yml
rename to symfony-3.4-micro/app/config/config_test.yml
diff --git a/symfony-3.3-micro/app/config/parameters.yml.dist b/symfony-3.4-micro/app/config/parameters.yml.dist
similarity index 100%
rename from symfony-3.3-micro/app/config/parameters.yml.dist
rename to symfony-3.4-micro/app/config/parameters.yml.dist
diff --git a/symfony-3.3-micro/app/config/services.yml b/symfony-3.4-micro/app/config/services.yml
similarity index 100%
rename from symfony-3.3-micro/app/config/services.yml
rename to symfony-3.4-micro/app/config/services.yml
diff --git a/symfony-3.3-micro/bin/console b/symfony-3.4-micro/bin/console
similarity index 100%
rename from symfony-3.3-micro/bin/console
rename to symfony-3.4-micro/bin/console
diff --git a/symfony-3.3-micro/bin/symfony_requirements b/symfony-3.4-micro/bin/symfony_requirements
similarity index 100%
rename from symfony-3.3-micro/bin/symfony_requirements
rename to symfony-3.4-micro/bin/symfony_requirements
diff --git a/symfony-3.3-micro/composer.json b/symfony-3.4-micro/composer.json
similarity index 80%
rename from symfony-3.3-micro/composer.json
rename to symfony-3.4-micro/composer.json
index 1e6cb190d..27e546ac0 100644
--- a/symfony-3.3-micro/composer.json
+++ b/symfony-3.4-micro/composer.json
@@ -12,18 +12,21 @@
         ]
     },
     "require": {
-        "php": ">=5.5.9",
+        "incenteev/composer-parameter-handler": "^2.0",
+        "php": "^5.5.9|>=7.0.8",
         "sensio/distribution-bundle": "^5.0",
-        "symfony/framework-bundle": "3.3.*",
+        "symfony/framework-bundle": "3.4.*",
         "symfony/monolog-bundle": "^2.8",
-        "symfony/yaml": "^3.3"
+        "symfony/yaml": "^3.4"
     },
     "scripts": {
         "post-install-cmd": [
+            "Incenteev\\ParameterHandler\\ScriptHandler::buildParameters",
             "Sensio\\Bundle\\DistributionBundle\\Composer\\ScriptHandler::buildBootstrap",
             "Sensio\\Bundle\\DistributionBundle\\Composer\\ScriptHandler::clearCache"
         ],
         "post-update-cmd": [
+            "Incenteev\\ParameterHandler\\ScriptHandler::buildParameters",
             "Sensio\\Bundle\\DistributionBundle\\Composer\\ScriptHandler::buildBootstrap",
             "Sensio\\Bundle\\DistributionBundle\\Composer\\ScriptHandler::clearCache"
         ]
diff --git a/symfony-3.3-micro/composer.lock b/symfony-3.4-micro/composer.lock
similarity index 71%
rename from symfony-3.3-micro/composer.lock
rename to symfony-3.4-micro/composer.lock
index 0b3e91058..91c9e55e5 100644
--- a/symfony-3.3-micro/composer.lock
+++ b/symfony-3.4-micro/composer.lock
@@ -4,20 +4,20 @@
         "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#composer-lock-the-lock-file",
         "This file is @generated automatically"
     ],
-    "content-hash": "33c03bcc493aefd4dc6f10c978c0f7d9",
+    "content-hash": "928dce99b2637a951b7498e031c2027e",
     "packages": [
         {
             "name": "composer/ca-bundle",
-            "version": "1.0.7",
+            "version": "1.1.0",
             "source": {
                 "type": "git",
                 "url": "https://github.com/composer/ca-bundle.git",
-                "reference": "b17e6153cb7f33c7e44eb59578dc12eee5dc8e12"
+                "reference": "943b2c4fcad1ef178d16a713c2468bf7e579c288"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/composer/ca-bundle/zipball/b17e6153cb7f33c7e44eb59578dc12eee5dc8e12",
-                "reference": "b17e6153cb7f33c7e44eb59578dc12eee5dc8e12",
+                "url": "https://api.github.com/repos/composer/ca-bundle/zipball/943b2c4fcad1ef178d16a713c2468bf7e579c288",
+                "reference": "943b2c4fcad1ef178d16a713c2468bf7e579c288",
                 "shasum": ""
             },
             "require": {
@@ -26,12 +26,9 @@
                 "php": "^5.3.2 || ^7.0"
             },
             "require-dev": {
-                "phpunit/phpunit": "^4.5",
+                "phpunit/phpunit": "^4.8.35",
                 "psr/log": "^1.0",
-                "symfony/process": "^2.5 || ^3.0"
-            },
-            "suggest": {
-                "symfony/process": "This is necessary to reliably check whether openssl_x509_parse is vulnerable on older php versions, but can be ignored on PHP 5.5.6+"
+                "symfony/process": "^2.5 || ^3.0 || ^4.0"
             },
             "type": "library",
             "extra": {
@@ -63,42 +60,40 @@
                 "ssl",
                 "tls"
             ],
-            "time": "2017-03-06T11:59:08+00:00"
+            "time": "2017-11-29T09:37:33+00:00"
         },
         {
-            "name": "doctrine/cache",
-            "version": "v1.6.2",
+            "name": "incenteev/composer-parameter-handler",
+            "version": "v2.1.2",
             "source": {
                 "type": "git",
-                "url": "https://github.com/doctrine/cache.git",
-                "reference": "eb152c5100571c7a45470ff2a35095ab3f3b900b"
+                "url": "https://github.com/Incenteev/ParameterHandler.git",
+                "reference": "d7ce7f06136109e81d1cb9d57066c4d4a99cf1cc"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/doctrine/cache/zipball/eb152c5100571c7a45470ff2a35095ab3f3b900b",
-                "reference": "eb152c5100571c7a45470ff2a35095ab3f3b900b",
+                "url": "https://api.github.com/repos/Incenteev/ParameterHandler/zipball/d7ce7f06136109e81d1cb9d57066c4d4a99cf1cc",
+                "reference": "d7ce7f06136109e81d1cb9d57066c4d4a99cf1cc",
                 "shasum": ""
             },
             "require": {
-                "php": "~5.5|~7.0"
-            },
-            "conflict": {
-                "doctrine/common": ">2.2,<2.4"
+                "php": ">=5.3.3",
+                "symfony/yaml": "~2.3|~3.0"
             },
             "require-dev": {
-                "phpunit/phpunit": "~4.8|~5.0",
-                "predis/predis": "~1.0",
-                "satooshi/php-coveralls": "~0.6"
+                "composer/composer": "1.0.*@dev",
+                "phpspec/prophecy-phpunit": "~1.0",
+                "symfony/filesystem": "~2.2"
             },
             "type": "library",
             "extra": {
                 "branch-alias": {
-                    "dev-master": "1.6.x-dev"
+                    "dev-master": "2.1.x-dev"
                 }
             },
             "autoload": {
                 "psr-4": {
-                    "Doctrine\\Common\\Cache\\": "lib/Doctrine/Common/Cache"
+                    "Incenteev\\ParameterHandler\\": ""
                 }
             },
             "notification-url": "https://packagist.org/downloads/",
@@ -107,33 +102,16 @@
             ],
             "authors": [
                 {
-                    "name": "Roman Borschel",
-                    "email": "roman@code-factory.org"
-                },
-                {
-                    "name": "Benjamin Eberlei",
-                    "email": "kontakt@beberlei.de"
-                },
-                {
-                    "name": "Guilherme Blanco",
-                    "email": "guilhermeblanco@gmail.com"
-                },
-                {
-                    "name": "Jonathan Wage",
-                    "email": "jonwage@gmail.com"
-                },
-                {
-                    "name": "Johannes Schmitt",
-                    "email": "schmittjoh@gmail.com"
+                    "name": "Christophe Coevoet",
+                    "email": "stof@notk.org"
                 }
             ],
-            "description": "Caching library offering an object-oriented API for many cache backends",
-            "homepage": "http://www.doctrine-project.org",
+            "description": "Composer script handling your ignored parameter file",
+            "homepage": "https://github.com/Incenteev/ParameterHandler",
             "keywords": [
-                "cache",
-                "caching"
+                "parameters management"
             ],
-            "time": "2017-07-22T12:49:21+00:00"
+            "time": "2015-11-10T17:04:01+00:00"
         },
         {
             "name": "monolog/monolog",
@@ -213,6 +191,54 @@
             ],
             "time": "2017-06-19T01:22:40+00:00"
         },
+        {
+            "name": "paragonie/random_compat",
+            "version": "v2.0.11",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/paragonie/random_compat.git",
+                "reference": "5da4d3c796c275c55f057af5a643ae297d96b4d8"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/paragonie/random_compat/zipball/5da4d3c796c275c55f057af5a643ae297d96b4d8",
+                "reference": "5da4d3c796c275c55f057af5a643ae297d96b4d8",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.2.0"
+            },
+            "require-dev": {
+                "phpunit/phpunit": "4.*|5.*"
+            },
+            "suggest": {
+                "ext-libsodium": "Provides a modern crypto API that can be used to generate random bytes."
+            },
+            "type": "library",
+            "autoload": {
+                "files": [
+                    "lib/random.php"
+                ]
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Paragon Initiative Enterprises",
+                    "email": "security@paragonie.com",
+                    "homepage": "https://paragonie.com"
+                }
+            ],
+            "description": "PHP 5.x polyfill for random_bytes() and random_int() from PHP 7",
+            "keywords": [
+                "csprng",
+                "pseudorandom",
+                "random"
+            ],
+            "time": "2017-09-27T21:40:39+00:00"
+        },
         {
             "name": "psr/cache",
             "version": "1.0.1",
@@ -405,16 +431,16 @@
         },
         {
             "name": "sensio/distribution-bundle",
-            "version": "v5.0.20",
+            "version": "v5.0.21",
             "source": {
                 "type": "git",
                 "url": "https://github.com/sensiolabs/SensioDistributionBundle.git",
-                "reference": "4b019d4c0bd64438c42e4b6b0726085b409be8d9"
+                "reference": "eb6266b3b472e4002538610b28a0a04bcf94891a"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/sensiolabs/SensioDistributionBundle/zipball/4b019d4c0bd64438c42e4b6b0726085b409be8d9",
-                "reference": "4b019d4c0bd64438c42e4b6b0726085b409be8d9",
+                "url": "https://api.github.com/repos/sensiolabs/SensioDistributionBundle/zipball/eb6266b3b472e4002538610b28a0a04bcf94891a",
+                "reference": "eb6266b3b472e4002538610b28a0a04bcf94891a",
                 "shasum": ""
             },
             "require": {
@@ -453,25 +479,25 @@
                 "configuration",
                 "distribution"
             ],
-            "time": "2017-05-11T16:21:03+00:00"
+            "time": "2017-08-25T16:55:44+00:00"
         },
         {
             "name": "sensiolabs/security-checker",
-            "version": "v4.0.5",
+            "version": "v4.1.7",
             "source": {
                 "type": "git",
                 "url": "https://github.com/sensiolabs/security-checker.git",
-                "reference": "6a3b0c3b42e41c777b1ad75032d8177863fdc5e1"
+                "reference": "d539ccba2b4dce515de04f16b7ed7ae5b9eeb434"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/sensiolabs/security-checker/zipball/6a3b0c3b42e41c777b1ad75032d8177863fdc5e1",
-                "reference": "6a3b0c3b42e41c777b1ad75032d8177863fdc5e1",
+                "url": "https://api.github.com/repos/sensiolabs/security-checker/zipball/d539ccba2b4dce515de04f16b7ed7ae5b9eeb434",
+                "reference": "d539ccba2b4dce515de04f16b7ed7ae5b9eeb434",
                 "shasum": ""
             },
             "require": {
                 "composer/ca-bundle": "^1.0",
-                "symfony/console": "~2.7|~3.0"
+                "symfony/console": "~2.7|~3.0|~4.0"
             },
             "bin": [
                 "security-checker"
@@ -479,7 +505,7 @@
             "type": "library",
             "extra": {
                 "branch-alias": {
-                    "dev-master": "4.0-dev"
+                    "dev-master": "4.1-dev"
                 }
             },
             "autoload": {
@@ -498,27 +524,28 @@
                 }
             ],
             "description": "A security checker for your composer.lock",
-            "time": "2017-07-24T11:42:56+00:00"
+            "time": "2018-01-11T05:54:03+00:00"
         },
         {
             "name": "symfony/cache",
-            "version": "v3.3.5",
+            "version": "v3.4.3",
             "source": {
                 "type": "git",
                 "url": "https://github.com/symfony/cache.git",
-                "reference": "265987c7f524b9ad17d0a0b8819ac53ce1bb8054"
+                "reference": "5725378078bc4e1fe3c3414e9cc0e63d7de47fff"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/symfony/cache/zipball/265987c7f524b9ad17d0a0b8819ac53ce1bb8054",
-                "reference": "265987c7f524b9ad17d0a0b8819ac53ce1bb8054",
+                "url": "https://api.github.com/repos/symfony/cache/zipball/5725378078bc4e1fe3c3414e9cc0e63d7de47fff",
+                "reference": "5725378078bc4e1fe3c3414e9cc0e63d7de47fff",
                 "shasum": ""
             },
             "require": {
-                "php": ">=5.5.9",
+                "php": "^5.5.9|>=7.0.8",
                 "psr/cache": "~1.0",
                 "psr/log": "~1.0",
-                "psr/simple-cache": "^1.0"
+                "psr/simple-cache": "^1.0",
+                "symfony/polyfill-apcu": "~1.1"
             },
             "conflict": {
                 "symfony/var-dumper": "<3.3"
@@ -533,13 +560,10 @@
                 "doctrine/dbal": "~2.4",
                 "predis/predis": "~1.0"
             },
-            "suggest": {
-                "symfony/polyfill-apcu": "For using ApcuAdapter on HHVM"
-            },
             "type": "library",
             "extra": {
                 "branch-alias": {
-                    "dev-master": "3.3-dev"
+                    "dev-master": "3.4-dev"
                 }
             },
             "autoload": {
@@ -570,27 +594,27 @@
                 "caching",
                 "psr6"
             ],
-            "time": "2017-07-17T17:27:31+00:00"
+            "time": "2018-01-03T17:14:19+00:00"
         },
         {
             "name": "symfony/class-loader",
-            "version": "v3.3.5",
+            "version": "v3.4.3",
             "source": {
                 "type": "git",
                 "url": "https://github.com/symfony/class-loader.git",
-                "reference": "386a294d621576302e7cc36965d6ed53b8c73c4f"
+                "reference": "e63c12699822bb3b667e7216ba07fbcc3a3e203e"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/symfony/class-loader/zipball/386a294d621576302e7cc36965d6ed53b8c73c4f",
-                "reference": "386a294d621576302e7cc36965d6ed53b8c73c4f",
+                "url": "https://api.github.com/repos/symfony/class-loader/zipball/e63c12699822bb3b667e7216ba07fbcc3a3e203e",
+                "reference": "e63c12699822bb3b667e7216ba07fbcc3a3e203e",
                 "shasum": ""
             },
             "require": {
-                "php": ">=5.5.9"
+                "php": "^5.5.9|>=7.0.8"
             },
             "require-dev": {
-                "symfony/finder": "~2.8|~3.0",
+                "symfony/finder": "~2.8|~3.0|~4.0",
                 "symfony/polyfill-apcu": "~1.1"
             },
             "suggest": {
@@ -599,7 +623,7 @@
             "type": "library",
             "extra": {
                 "branch-alias": {
-                    "dev-master": "3.3-dev"
+                    "dev-master": "3.4-dev"
                 }
             },
             "autoload": {
@@ -626,34 +650,34 @@
             ],
             "description": "Symfony ClassLoader Component",
             "homepage": "https://symfony.com",
-            "time": "2017-06-02T09:51:43+00:00"
+            "time": "2018-01-03T07:37:34+00:00"
         },
         {
             "name": "symfony/config",
-            "version": "v3.3.5",
+            "version": "v3.4.3",
             "source": {
                 "type": "git",
                 "url": "https://github.com/symfony/config.git",
-                "reference": "a094618deb9a3fe1c3cf500a796e167d0495a274"
+                "reference": "cfd5c972f7b4992a5df41673d25d980ab077aa5b"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/symfony/config/zipball/a094618deb9a3fe1c3cf500a796e167d0495a274",
-                "reference": "a094618deb9a3fe1c3cf500a796e167d0495a274",
+                "url": "https://api.github.com/repos/symfony/config/zipball/cfd5c972f7b4992a5df41673d25d980ab077aa5b",
+                "reference": "cfd5c972f7b4992a5df41673d25d980ab077aa5b",
                 "shasum": ""
             },
             "require": {
-                "php": ">=5.5.9",
-                "symfony/filesystem": "~2.8|~3.0"
+                "php": "^5.5.9|>=7.0.8",
+                "symfony/filesystem": "~2.8|~3.0|~4.0"
             },
             "conflict": {
                 "symfony/dependency-injection": "<3.3",
                 "symfony/finder": "<3.3"
             },
             "require-dev": {
-                "symfony/dependency-injection": "~3.3",
-                "symfony/finder": "~3.3",
-                "symfony/yaml": "~3.0"
+                "symfony/dependency-injection": "~3.3|~4.0",
+                "symfony/finder": "~3.3|~4.0",
+                "symfony/yaml": "~3.0|~4.0"
             },
             "suggest": {
                 "symfony/yaml": "To use the yaml reference dumper"
@@ -661,7 +685,7 @@
             "type": "library",
             "extra": {
                 "branch-alias": {
-                    "dev-master": "3.3-dev"
+                    "dev-master": "3.4-dev"
                 }
             },
             "autoload": {
@@ -688,49 +712,49 @@
             ],
             "description": "Symfony Config Component",
             "homepage": "https://symfony.com",
-            "time": "2017-06-16T12:40:34+00:00"
+            "time": "2018-01-03T07:37:34+00:00"
         },
         {
             "name": "symfony/console",
-            "version": "v3.3.5",
+            "version": "v3.4.3",
             "source": {
                 "type": "git",
                 "url": "https://github.com/symfony/console.git",
-                "reference": "a97e45d98c59510f085fa05225a1acb74dfe0546"
+                "reference": "8394c8ef121949e8f858f13bc1e34f05169e4e7d"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/symfony/console/zipball/a97e45d98c59510f085fa05225a1acb74dfe0546",
-                "reference": "a97e45d98c59510f085fa05225a1acb74dfe0546",
+                "url": "https://api.github.com/repos/symfony/console/zipball/8394c8ef121949e8f858f13bc1e34f05169e4e7d",
+                "reference": "8394c8ef121949e8f858f13bc1e34f05169e4e7d",
                 "shasum": ""
             },
             "require": {
-                "php": ">=5.5.9",
-                "symfony/debug": "~2.8|~3.0",
+                "php": "^5.5.9|>=7.0.8",
+                "symfony/debug": "~2.8|~3.0|~4.0",
                 "symfony/polyfill-mbstring": "~1.0"
             },
             "conflict": {
-                "symfony/dependency-injection": "<3.3"
+                "symfony/dependency-injection": "<3.4",
+                "symfony/process": "<3.3"
             },
             "require-dev": {
                 "psr/log": "~1.0",
-                "symfony/config": "~3.3",
-                "symfony/dependency-injection": "~3.3",
-                "symfony/event-dispatcher": "~2.8|~3.0",
-                "symfony/filesystem": "~2.8|~3.0",
-                "symfony/http-kernel": "~2.8|~3.0",
-                "symfony/process": "~2.8|~3.0"
+                "symfony/config": "~3.3|~4.0",
+                "symfony/dependency-injection": "~3.4|~4.0",
+                "symfony/event-dispatcher": "~2.8|~3.0|~4.0",
+                "symfony/lock": "~3.4|~4.0",
+                "symfony/process": "~3.3|~4.0"
             },
             "suggest": {
                 "psr/log": "For using the console logger",
                 "symfony/event-dispatcher": "",
-                "symfony/filesystem": "",
+                "symfony/lock": "",
                 "symfony/process": ""
             },
             "type": "library",
             "extra": {
                 "branch-alias": {
-                    "dev-master": "3.3-dev"
+                    "dev-master": "3.4-dev"
                 }
             },
             "autoload": {
@@ -757,36 +781,36 @@
             ],
             "description": "Symfony Console Component",
             "homepage": "https://symfony.com",
-            "time": "2017-07-03T13:19:36+00:00"
+            "time": "2018-01-03T07:37:34+00:00"
         },
         {
             "name": "symfony/debug",
-            "version": "v3.3.5",
+            "version": "v3.4.3",
             "source": {
                 "type": "git",
                 "url": "https://github.com/symfony/debug.git",
-                "reference": "63b85a968486d95ff9542228dc2e4247f16f9743"
+                "reference": "603b95dda8b00020e4e6e60dc906e7b715b1c245"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/symfony/debug/zipball/63b85a968486d95ff9542228dc2e4247f16f9743",
-                "reference": "63b85a968486d95ff9542228dc2e4247f16f9743",
+                "url": "https://api.github.com/repos/symfony/debug/zipball/603b95dda8b00020e4e6e60dc906e7b715b1c245",
+                "reference": "603b95dda8b00020e4e6e60dc906e7b715b1c245",
                 "shasum": ""
             },
             "require": {
-                "php": ">=5.5.9",
+                "php": "^5.5.9|>=7.0.8",
                 "psr/log": "~1.0"
             },
             "conflict": {
                 "symfony/http-kernel": ">=2.3,<2.3.24|~2.4.0|>=2.5,<2.5.9|>=2.6,<2.6.2"
             },
             "require-dev": {
-                "symfony/http-kernel": "~2.8|~3.0"
+                "symfony/http-kernel": "~2.8|~3.0|~4.0"
             },
             "type": "library",
             "extra": {
                 "branch-alias": {
-                    "dev-master": "3.3-dev"
+                    "dev-master": "3.4-dev"
                 }
             },
             "autoload": {
@@ -813,38 +837,39 @@
             ],
             "description": "Symfony Debug Component",
             "homepage": "https://symfony.com",
-            "time": "2017-07-05T13:02:37+00:00"
+            "time": "2018-01-03T17:14:19+00:00"
         },
         {
             "name": "symfony/dependency-injection",
-            "version": "v3.3.5",
+            "version": "v3.4.3",
             "source": {
                 "type": "git",
                 "url": "https://github.com/symfony/dependency-injection.git",
-                "reference": "761e51a86f35f5b3e213e9b7f554fd91f9bffae4"
+                "reference": "35f957ca171a431710966bec6e2f8636d3b019c4"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/symfony/dependency-injection/zipball/761e51a86f35f5b3e213e9b7f554fd91f9bffae4",
-                "reference": "761e51a86f35f5b3e213e9b7f554fd91f9bffae4",
+                "url": "https://api.github.com/repos/symfony/dependency-injection/zipball/35f957ca171a431710966bec6e2f8636d3b019c4",
+                "reference": "35f957ca171a431710966bec6e2f8636d3b019c4",
                 "shasum": ""
             },
             "require": {
-                "php": ">=5.5.9",
+                "php": "^5.5.9|>=7.0.8",
                 "psr/container": "^1.0"
             },
             "conflict": {
-                "symfony/config": "<3.3.1",
+                "symfony/config": "<3.3.7",
                 "symfony/finder": "<3.3",
-                "symfony/yaml": "<3.3"
+                "symfony/proxy-manager-bridge": "<3.4",
+                "symfony/yaml": "<3.4"
             },
             "provide": {
                 "psr/container-implementation": "1.0"
             },
             "require-dev": {
-                "symfony/config": "~3.3",
-                "symfony/expression-language": "~2.8|~3.0",
-                "symfony/yaml": "~3.3"
+                "symfony/config": "~3.3|~4.0",
+                "symfony/expression-language": "~2.8|~3.0|~4.0",
+                "symfony/yaml": "~3.4|~4.0"
             },
             "suggest": {
                 "symfony/config": "",
@@ -856,7 +881,7 @@
             "type": "library",
             "extra": {
                 "branch-alias": {
-                    "dev-master": "3.3-dev"
+                    "dev-master": "3.4-dev"
                 }
             },
             "autoload": {
@@ -883,34 +908,34 @@
             ],
             "description": "Symfony DependencyInjection Component",
             "homepage": "https://symfony.com",
-            "time": "2017-07-17T14:07:10+00:00"
+            "time": "2018-01-04T15:56:45+00:00"
         },
         {
             "name": "symfony/event-dispatcher",
-            "version": "v3.3.5",
+            "version": "v3.4.3",
             "source": {
                 "type": "git",
                 "url": "https://github.com/symfony/event-dispatcher.git",
-                "reference": "67535f1e3fd662bdc68d7ba317c93eecd973617e"
+                "reference": "26b87b6bca8f8f797331a30b76fdae5342dc26ca"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/symfony/event-dispatcher/zipball/67535f1e3fd662bdc68d7ba317c93eecd973617e",
-                "reference": "67535f1e3fd662bdc68d7ba317c93eecd973617e",
+                "url": "https://api.github.com/repos/symfony/event-dispatcher/zipball/26b87b6bca8f8f797331a30b76fdae5342dc26ca",
+                "reference": "26b87b6bca8f8f797331a30b76fdae5342dc26ca",
                 "shasum": ""
             },
             "require": {
-                "php": ">=5.5.9"
+                "php": "^5.5.9|>=7.0.8"
             },
             "conflict": {
                 "symfony/dependency-injection": "<3.3"
             },
             "require-dev": {
                 "psr/log": "~1.0",
-                "symfony/config": "~2.8|~3.0",
-                "symfony/dependency-injection": "~3.3",
-                "symfony/expression-language": "~2.8|~3.0",
-                "symfony/stopwatch": "~2.8|~3.0"
+                "symfony/config": "~2.8|~3.0|~4.0",
+                "symfony/dependency-injection": "~3.3|~4.0",
+                "symfony/expression-language": "~2.8|~3.0|~4.0",
+                "symfony/stopwatch": "~2.8|~3.0|~4.0"
             },
             "suggest": {
                 "symfony/dependency-injection": "",
@@ -919,7 +944,7 @@
             "type": "library",
             "extra": {
                 "branch-alias": {
-                    "dev-master": "3.3-dev"
+                    "dev-master": "3.4-dev"
                 }
             },
             "autoload": {
@@ -946,29 +971,29 @@
             ],
             "description": "Symfony EventDispatcher Component",
             "homepage": "https://symfony.com",
-            "time": "2017-06-09T14:53:08+00:00"
+            "time": "2018-01-03T07:37:34+00:00"
         },
         {
             "name": "symfony/filesystem",
-            "version": "v3.3.5",
+            "version": "v3.4.3",
             "source": {
                 "type": "git",
                 "url": "https://github.com/symfony/filesystem.git",
-                "reference": "427987eb4eed764c3b6e38d52a0f87989e010676"
+                "reference": "e078773ad6354af38169faf31c21df0f18ace03d"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/symfony/filesystem/zipball/427987eb4eed764c3b6e38d52a0f87989e010676",
-                "reference": "427987eb4eed764c3b6e38d52a0f87989e010676",
+                "url": "https://api.github.com/repos/symfony/filesystem/zipball/e078773ad6354af38169faf31c21df0f18ace03d",
+                "reference": "e078773ad6354af38169faf31c21df0f18ace03d",
                 "shasum": ""
             },
             "require": {
-                "php": ">=5.5.9"
+                "php": "^5.5.9|>=7.0.8"
             },
             "type": "library",
             "extra": {
                 "branch-alias": {
-                    "dev-master": "3.3-dev"
+                    "dev-master": "3.4-dev"
                 }
             },
             "autoload": {
@@ -995,29 +1020,29 @@
             ],
             "description": "Symfony Filesystem Component",
             "homepage": "https://symfony.com",
-            "time": "2017-07-11T07:17:58+00:00"
+            "time": "2018-01-03T07:37:34+00:00"
         },
         {
             "name": "symfony/finder",
-            "version": "v3.3.5",
+            "version": "v3.4.3",
             "source": {
                 "type": "git",
                 "url": "https://github.com/symfony/finder.git",
-                "reference": "baea7f66d30854ad32988c11a09d7ffd485810c4"
+                "reference": "613e26310776f49a1773b6737c6bd554b8bc8c6f"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/symfony/finder/zipball/baea7f66d30854ad32988c11a09d7ffd485810c4",
-                "reference": "baea7f66d30854ad32988c11a09d7ffd485810c4",
+                "url": "https://api.github.com/repos/symfony/finder/zipball/613e26310776f49a1773b6737c6bd554b8bc8c6f",
+                "reference": "613e26310776f49a1773b6737c6bd554b8bc8c6f",
                 "shasum": ""
             },
             "require": {
-                "php": ">=5.5.9"
+                "php": "^5.5.9|>=7.0.8"
             },
             "type": "library",
             "extra": {
                 "branch-alias": {
-                    "dev-master": "3.3-dev"
+                    "dev-master": "3.4-dev"
                 }
             },
             "autoload": {
@@ -1044,77 +1069,79 @@
             ],
             "description": "Symfony Finder Component",
             "homepage": "https://symfony.com",
-            "time": "2017-06-01T21:01:25+00:00"
+            "time": "2018-01-03T07:37:34+00:00"
         },
         {
             "name": "symfony/framework-bundle",
-            "version": "v3.3.5",
+            "version": "v3.4.3",
             "source": {
                 "type": "git",
                 "url": "https://github.com/symfony/framework-bundle.git",
-                "reference": "678bc1b17ae351ba98a492f31d57c0011281334a"
+                "reference": "41882368efe6c740f7aab9dd6da250c44eb550cf"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/symfony/framework-bundle/zipball/678bc1b17ae351ba98a492f31d57c0011281334a",
-                "reference": "678bc1b17ae351ba98a492f31d57c0011281334a",
+                "url": "https://api.github.com/repos/symfony/framework-bundle/zipball/41882368efe6c740f7aab9dd6da250c44eb550cf",
+                "reference": "41882368efe6c740f7aab9dd6da250c44eb550cf",
                 "shasum": ""
             },
             "require": {
-                "doctrine/cache": "~1.0",
                 "ext-xml": "*",
-                "php": ">=5.5.9",
-                "symfony/cache": "~3.3",
+                "php": "^5.5.9|>=7.0.8",
+                "symfony/cache": "~3.4|~4.0",
                 "symfony/class-loader": "~3.2",
-                "symfony/config": "~3.3",
-                "symfony/dependency-injection": "~3.3",
-                "symfony/event-dispatcher": "^3.3.1",
-                "symfony/filesystem": "~2.8|~3.0",
-                "symfony/finder": "~2.8|~3.0",
-                "symfony/http-foundation": "~3.3",
-                "symfony/http-kernel": "~3.3",
+                "symfony/config": "~3.4|~4.0",
+                "symfony/dependency-injection": "^3.4.3|^4.0.3",
+                "symfony/event-dispatcher": "~3.4|~4.0",
+                "symfony/filesystem": "~2.8|~3.0|~4.0",
+                "symfony/finder": "~2.8|~3.0|~4.0",
+                "symfony/http-foundation": "^3.3.11|~4.0",
+                "symfony/http-kernel": "~3.4|~4.0",
                 "symfony/polyfill-mbstring": "~1.0",
-                "symfony/routing": "~3.3",
-                "symfony/stopwatch": "~2.8|~3.0"
+                "symfony/routing": "~3.4|~4.0"
             },
             "conflict": {
                 "phpdocumentor/reflection-docblock": "<3.0",
-                "phpdocumentor/type-resolver": "<0.2.0",
+                "phpdocumentor/type-resolver": "<0.2.1",
                 "phpunit/phpunit": "<4.8.35|<5.4.3,>=5.0",
                 "symfony/asset": "<3.3",
-                "symfony/console": "<3.3",
-                "symfony/form": "<3.3",
+                "symfony/console": "<3.4",
+                "symfony/form": "<3.4",
                 "symfony/property-info": "<3.3",
                 "symfony/serializer": "<3.3",
-                "symfony/translation": "<3.2",
-                "symfony/validator": "<3.3",
+                "symfony/stopwatch": "<3.4",
+                "symfony/translation": "<3.4",
+                "symfony/validator": "<3.4",
                 "symfony/workflow": "<3.3"
             },
             "require-dev": {
                 "doctrine/annotations": "~1.0",
+                "doctrine/cache": "~1.0",
                 "fig/link-util": "^1.0",
-                "phpdocumentor/reflection-docblock": "^3.0",
-                "sensio/framework-extra-bundle": "^3.0.2",
-                "symfony/asset": "~3.3",
-                "symfony/browser-kit": "~2.8|~3.0",
-                "symfony/console": "~3.3",
-                "symfony/css-selector": "~2.8|~3.0",
-                "symfony/dom-crawler": "~2.8|~3.0",
-                "symfony/expression-language": "~2.8|~3.0",
-                "symfony/form": "~3.3",
+                "phpdocumentor/reflection-docblock": "^3.0|^4.0",
+                "symfony/asset": "~3.3|~4.0",
+                "symfony/browser-kit": "~2.8|~3.0|~4.0",
+                "symfony/console": "~3.4|~4.0",
+                "symfony/css-selector": "~2.8|~3.0|~4.0",
+                "symfony/dom-crawler": "~2.8|~3.0|~4.0",
+                "symfony/expression-language": "~2.8|~3.0|~4.0",
+                "symfony/form": "~3.4|~4.0",
+                "symfony/lock": "~3.4|~4.0",
                 "symfony/polyfill-intl-icu": "~1.0",
-                "symfony/process": "~2.8|~3.0",
-                "symfony/property-info": "~3.3",
-                "symfony/security": "~2.8|~3.0",
-                "symfony/security-core": "~3.2",
-                "symfony/security-csrf": "~2.8|~3.0",
-                "symfony/serializer": "~3.3",
-                "symfony/templating": "~2.8|~3.0",
-                "symfony/translation": "~3.2",
-                "symfony/validator": "~3.3",
-                "symfony/web-link": "~3.3",
-                "symfony/workflow": "~3.3",
-                "symfony/yaml": "~3.2",
+                "symfony/process": "~2.8|~3.0|~4.0",
+                "symfony/property-info": "~3.3|~4.0",
+                "symfony/security": "~2.8|~3.0|~4.0",
+                "symfony/security-core": "~3.2|~4.0",
+                "symfony/security-csrf": "~2.8|~3.0|~4.0",
+                "symfony/serializer": "~3.3|~4.0",
+                "symfony/stopwatch": "~3.4|~4.0",
+                "symfony/templating": "~2.8|~3.0|~4.0",
+                "symfony/translation": "~3.4|~4.0",
+                "symfony/validator": "~3.4|~4.0",
+                "symfony/var-dumper": "~3.3|~4.0",
+                "symfony/web-link": "~3.3|~4.0",
+                "symfony/workflow": "~3.3|~4.0",
+                "symfony/yaml": "~3.2|~4.0",
                 "twig/twig": "~1.34|~2.4"
             },
             "suggest": {
@@ -1130,7 +1157,7 @@
             "type": "symfony-bundle",
             "extra": {
                 "branch-alias": {
-                    "dev-master": "3.3-dev"
+                    "dev-master": "3.4-dev"
                 }
             },
             "autoload": {
@@ -1157,33 +1184,34 @@
             ],
             "description": "Symfony FrameworkBundle",
             "homepage": "https://symfony.com",
-            "time": "2017-07-17T11:48:40+00:00"
+            "time": "2018-01-04T15:42:01+00:00"
         },
         {
             "name": "symfony/http-foundation",
-            "version": "v3.3.5",
+            "version": "v3.4.3",
             "source": {
                 "type": "git",
                 "url": "https://github.com/symfony/http-foundation.git",
-                "reference": "e307abe4b79ccbbfdced9b91c132fd128f456bc5"
+                "reference": "4a213be1cc8598089b8c7451529a2927b49b5d26"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/symfony/http-foundation/zipball/e307abe4b79ccbbfdced9b91c132fd128f456bc5",
-                "reference": "e307abe4b79ccbbfdced9b91c132fd128f456bc5",
+                "url": "https://api.github.com/repos/symfony/http-foundation/zipball/4a213be1cc8598089b8c7451529a2927b49b5d26",
+                "reference": "4a213be1cc8598089b8c7451529a2927b49b5d26",
                 "shasum": ""
             },
             "require": {
-                "php": ">=5.5.9",
-                "symfony/polyfill-mbstring": "~1.1"
+                "php": "^5.5.9|>=7.0.8",
+                "symfony/polyfill-mbstring": "~1.1",
+                "symfony/polyfill-php70": "~1.6"
             },
             "require-dev": {
-                "symfony/expression-language": "~2.8|~3.0"
+                "symfony/expression-language": "~2.8|~3.0|~4.0"
             },
             "type": "library",
             "extra": {
                 "branch-alias": {
-                    "dev-master": "3.3-dev"
+                    "dev-master": "3.4-dev"
                 }
             },
             "autoload": {
@@ -1210,56 +1238,58 @@
             ],
             "description": "Symfony HttpFoundation Component",
             "homepage": "https://symfony.com",
-            "time": "2017-07-17T14:07:10+00:00"
+            "time": "2018-01-03T17:14:19+00:00"
         },
         {
             "name": "symfony/http-kernel",
-            "version": "v3.3.5",
+            "version": "v3.4.3",
             "source": {
                 "type": "git",
                 "url": "https://github.com/symfony/http-kernel.git",
-                "reference": "16ceea64d23abddf58797a782ae96a5242282cd8"
+                "reference": "1c2a82d6a8ec9b354fe4ef48ad1ad3f1a4f7db0e"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/symfony/http-kernel/zipball/16ceea64d23abddf58797a782ae96a5242282cd8",
-                "reference": "16ceea64d23abddf58797a782ae96a5242282cd8",
+                "url": "https://api.github.com/repos/symfony/http-kernel/zipball/1c2a82d6a8ec9b354fe4ef48ad1ad3f1a4f7db0e",
+                "reference": "1c2a82d6a8ec9b354fe4ef48ad1ad3f1a4f7db0e",
                 "shasum": ""
             },
             "require": {
-                "php": ">=5.5.9",
+                "php": "^5.5.9|>=7.0.8",
                 "psr/log": "~1.0",
-                "symfony/debug": "~2.8|~3.0",
-                "symfony/event-dispatcher": "~2.8|~3.0",
-                "symfony/http-foundation": "~3.3"
+                "symfony/debug": "~2.8|~3.0|~4.0",
+                "symfony/event-dispatcher": "~2.8|~3.0|~4.0",
+                "symfony/http-foundation": "^3.3.11|~4.0"
             },
             "conflict": {
                 "symfony/config": "<2.8",
-                "symfony/dependency-injection": "<3.3",
+                "symfony/dependency-injection": "<3.4",
                 "symfony/var-dumper": "<3.3",
                 "twig/twig": "<1.34|<2.4,>=2"
             },
+            "provide": {
+                "psr/log-implementation": "1.0"
+            },
             "require-dev": {
                 "psr/cache": "~1.0",
-                "symfony/browser-kit": "~2.8|~3.0",
+                "symfony/browser-kit": "~2.8|~3.0|~4.0",
                 "symfony/class-loader": "~2.8|~3.0",
-                "symfony/config": "~2.8|~3.0",
-                "symfony/console": "~2.8|~3.0",
-                "symfony/css-selector": "~2.8|~3.0",
-                "symfony/dependency-injection": "~3.3",
-                "symfony/dom-crawler": "~2.8|~3.0",
-                "symfony/expression-language": "~2.8|~3.0",
-                "symfony/finder": "~2.8|~3.0",
-                "symfony/process": "~2.8|~3.0",
-                "symfony/routing": "~2.8|~3.0",
-                "symfony/stopwatch": "~2.8|~3.0",
-                "symfony/templating": "~2.8|~3.0",
-                "symfony/translation": "~2.8|~3.0",
-                "symfony/var-dumper": "~3.3"
+                "symfony/config": "~2.8|~3.0|~4.0",
+                "symfony/console": "~2.8|~3.0|~4.0",
+                "symfony/css-selector": "~2.8|~3.0|~4.0",
+                "symfony/dependency-injection": "~3.4|~4.0",
+                "symfony/dom-crawler": "~2.8|~3.0|~4.0",
+                "symfony/expression-language": "~2.8|~3.0|~4.0",
+                "symfony/finder": "~2.8|~3.0|~4.0",
+                "symfony/process": "~2.8|~3.0|~4.0",
+                "symfony/routing": "~3.4|~4.0",
+                "symfony/stopwatch": "~2.8|~3.0|~4.0",
+                "symfony/templating": "~2.8|~3.0|~4.0",
+                "symfony/translation": "~2.8|~3.0|~4.0",
+                "symfony/var-dumper": "~3.3|~4.0"
             },
             "suggest": {
                 "symfony/browser-kit": "",
-                "symfony/class-loader": "",
                 "symfony/config": "",
                 "symfony/console": "",
                 "symfony/dependency-injection": "",
@@ -1269,7 +1299,7 @@
             "type": "library",
             "extra": {
                 "branch-alias": {
-                    "dev-master": "3.3-dev"
+                    "dev-master": "3.4-dev"
                 }
             },
             "autoload": {
@@ -1296,44 +1326,46 @@
             ],
             "description": "Symfony HttpKernel Component",
             "homepage": "https://symfony.com",
-            "time": "2017-07-17T19:08:23+00:00"
+            "time": "2018-01-05T08:33:00+00:00"
         },
         {
             "name": "symfony/monolog-bridge",
-            "version": "v3.3.5",
+            "version": "v3.4.3",
             "source": {
                 "type": "git",
                 "url": "https://github.com/symfony/monolog-bridge.git",
-                "reference": "b2e5cf7959432161c2816a20508f384200c995a3"
+                "reference": "d00a3eae96da210e44ce0b6a8fa72ee737703861"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/symfony/monolog-bridge/zipball/b2e5cf7959432161c2816a20508f384200c995a3",
-                "reference": "b2e5cf7959432161c2816a20508f384200c995a3",
+                "url": "https://api.github.com/repos/symfony/monolog-bridge/zipball/d00a3eae96da210e44ce0b6a8fa72ee737703861",
+                "reference": "d00a3eae96da210e44ce0b6a8fa72ee737703861",
                 "shasum": ""
             },
             "require": {
                 "monolog/monolog": "~1.19",
-                "php": ">=5.5.9",
-                "symfony/http-kernel": "~2.8|~3.0"
+                "php": "^5.5.9|>=7.0.8",
+                "symfony/http-kernel": "~2.8|~3.0|~4.0"
             },
             "conflict": {
                 "symfony/http-foundation": "<3.3"
             },
             "require-dev": {
-                "symfony/console": "~2.8|~3.0",
-                "symfony/event-dispatcher": "~2.8|~3.0",
-                "symfony/var-dumper": "~3.3"
+                "symfony/console": "~2.8|~3.0|~4.0",
+                "symfony/event-dispatcher": "~2.8|~3.0|~4.0",
+                "symfony/security-core": "~2.8|~3.0|~4.0",
+                "symfony/var-dumper": "~3.3|~4.0"
             },
             "suggest": {
                 "symfony/console": "For the possibility to show log messages in console commands depending on verbosity settings. You need version ~2.3 of the console for it.",
                 "symfony/event-dispatcher": "Needed when using log messages in console commands.",
-                "symfony/http-kernel": "For using the debugging handlers together with the response life cycle of the HTTP kernel."
+                "symfony/http-kernel": "For using the debugging handlers together with the response life cycle of the HTTP kernel.",
+                "symfony/var-dumper": "For using the debugging handlers like the console handler or the log server handler."
             },
             "type": "symfony-bridge",
             "extra": {
                 "branch-alias": {
-                    "dev-master": "3.3-dev"
+                    "dev-master": "3.4-dev"
                 }
             },
             "autoload": {
@@ -1360,7 +1392,7 @@
             ],
             "description": "Symfony Monolog Bridge",
             "homepage": "https://symfony.com",
-            "time": "2017-06-06T15:10:52+00:00"
+            "time": "2018-01-03T07:37:34+00:00"
         },
         {
             "name": "symfony/monolog-bundle",
@@ -1422,18 +1454,74 @@
             ],
             "time": "2017-01-02T19:04:26+00:00"
         },
+        {
+            "name": "symfony/polyfill-apcu",
+            "version": "v1.6.0",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/polyfill-apcu.git",
+                "reference": "04f62674339602def515bff4bc6901fc1d4951e8"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/polyfill-apcu/zipball/04f62674339602def515bff4bc6901fc1d4951e8",
+                "reference": "04f62674339602def515bff4bc6901fc1d4951e8",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.3.3"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "1.6-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Polyfill\\Apcu\\": ""
+                },
+                "files": [
+                    "bootstrap.php"
+                ]
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Nicolas Grekas",
+                    "email": "p@tchwork.com"
+                },
+                {
+                    "name": "Symfony Community",
+                    "homepage": "https://symfony.com/contributors"
+                }
+            ],
+            "description": "Symfony polyfill backporting apcu_* functions to lower PHP versions",
+            "homepage": "https://symfony.com",
+            "keywords": [
+                "apcu",
+                "compatibility",
+                "polyfill",
+                "portable",
+                "shim"
+            ],
+            "time": "2017-10-11T12:05:26+00:00"
+        },
         {
             "name": "symfony/polyfill-mbstring",
-            "version": "v1.4.0",
+            "version": "v1.6.0",
             "source": {
                 "type": "git",
                 "url": "https://github.com/symfony/polyfill-mbstring.git",
-                "reference": "f29dca382a6485c3cbe6379f0c61230167681937"
+                "reference": "2ec8b39c38cb16674bbf3fea2b6ce5bf117e1296"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/symfony/polyfill-mbstring/zipball/f29dca382a6485c3cbe6379f0c61230167681937",
-                "reference": "f29dca382a6485c3cbe6379f0c61230167681937",
+                "url": "https://api.github.com/repos/symfony/polyfill-mbstring/zipball/2ec8b39c38cb16674bbf3fea2b6ce5bf117e1296",
+                "reference": "2ec8b39c38cb16674bbf3fea2b6ce5bf117e1296",
                 "shasum": ""
             },
             "require": {
@@ -1445,7 +1533,7 @@
             "type": "library",
             "extra": {
                 "branch-alias": {
-                    "dev-master": "1.4-dev"
+                    "dev-master": "1.6-dev"
                 }
             },
             "autoload": {
@@ -1479,37 +1567,41 @@
                 "portable",
                 "shim"
             ],
-            "time": "2017-06-09T14:24:12+00:00"
+            "time": "2017-10-11T12:05:26+00:00"
         },
         {
-            "name": "symfony/process",
-            "version": "v3.3.5",
+            "name": "symfony/polyfill-php70",
+            "version": "v1.6.0",
             "source": {
                 "type": "git",
-                "url": "https://github.com/symfony/process.git",
-                "reference": "07432804942b9f6dd7b7377faf9920af5f95d70a"
+                "url": "https://github.com/symfony/polyfill-php70.git",
+                "reference": "0442b9c0596610bd24ae7b5f0a6cdbbc16d9fcff"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/symfony/process/zipball/07432804942b9f6dd7b7377faf9920af5f95d70a",
-                "reference": "07432804942b9f6dd7b7377faf9920af5f95d70a",
+                "url": "https://api.github.com/repos/symfony/polyfill-php70/zipball/0442b9c0596610bd24ae7b5f0a6cdbbc16d9fcff",
+                "reference": "0442b9c0596610bd24ae7b5f0a6cdbbc16d9fcff",
                 "shasum": ""
             },
             "require": {
-                "php": ">=5.5.9"
+                "paragonie/random_compat": "~1.0|~2.0",
+                "php": ">=5.3.3"
             },
             "type": "library",
             "extra": {
                 "branch-alias": {
-                    "dev-master": "3.3-dev"
+                    "dev-master": "1.6-dev"
                 }
             },
             "autoload": {
                 "psr-4": {
-                    "Symfony\\Component\\Process\\": ""
+                    "Symfony\\Polyfill\\Php70\\": ""
                 },
-                "exclude-from-classmap": [
-                    "/Tests/"
+                "files": [
+                    "bootstrap.php"
+                ],
+                "classmap": [
+                    "Resources/stubs"
                 ]
             },
             "notification-url": "https://packagist.org/downloads/",
@@ -1518,67 +1610,50 @@
             ],
             "authors": [
                 {
-                    "name": "Fabien Potencier",
-                    "email": "fabien@symfony.com"
+                    "name": "Nicolas Grekas",
+                    "email": "p@tchwork.com"
                 },
                 {
                     "name": "Symfony Community",
                     "homepage": "https://symfony.com/contributors"
                 }
             ],
-            "description": "Symfony Process Component",
+            "description": "Symfony polyfill backporting some PHP 7.0+ features to lower PHP versions",
             "homepage": "https://symfony.com",
-            "time": "2017-07-13T13:05:09+00:00"
+            "keywords": [
+                "compatibility",
+                "polyfill",
+                "portable",
+                "shim"
+            ],
+            "time": "2017-10-11T12:05:26+00:00"
         },
         {
-            "name": "symfony/routing",
-            "version": "v3.3.5",
+            "name": "symfony/process",
+            "version": "v3.4.3",
             "source": {
                 "type": "git",
-                "url": "https://github.com/symfony/routing.git",
-                "reference": "dc70bbd0ca7b19259f63cdacc8af370bc32a4728"
+                "url": "https://github.com/symfony/process.git",
+                "reference": "ff69f110c6b33fd33cd2089ba97d6112f44ef0ba"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/symfony/routing/zipball/dc70bbd0ca7b19259f63cdacc8af370bc32a4728",
-                "reference": "dc70bbd0ca7b19259f63cdacc8af370bc32a4728",
+                "url": "https://api.github.com/repos/symfony/process/zipball/ff69f110c6b33fd33cd2089ba97d6112f44ef0ba",
+                "reference": "ff69f110c6b33fd33cd2089ba97d6112f44ef0ba",
                 "shasum": ""
             },
             "require": {
-                "php": ">=5.5.9"
-            },
-            "conflict": {
-                "symfony/config": "<2.8",
-                "symfony/dependency-injection": "<3.3",
-                "symfony/yaml": "<3.3"
-            },
-            "require-dev": {
-                "doctrine/annotations": "~1.0",
-                "doctrine/common": "~2.2",
-                "psr/log": "~1.0",
-                "symfony/config": "~2.8|~3.0",
-                "symfony/dependency-injection": "~3.3",
-                "symfony/expression-language": "~2.8|~3.0",
-                "symfony/http-foundation": "~2.8|~3.0",
-                "symfony/yaml": "~3.3"
-            },
-            "suggest": {
-                "doctrine/annotations": "For using the annotation loader",
-                "symfony/config": "For using the all-in-one router or any loader",
-                "symfony/dependency-injection": "For loading routes from a service",
-                "symfony/expression-language": "For using expression matching",
-                "symfony/http-foundation": "For using a Symfony Request object",
-                "symfony/yaml": "For using the YAML loader"
+                "php": "^5.5.9|>=7.0.8"
             },
             "type": "library",
             "extra": {
                 "branch-alias": {
-                    "dev-master": "3.3-dev"
+                    "dev-master": "3.4-dev"
                 }
             },
             "autoload": {
                 "psr-4": {
-                    "Symfony\\Component\\Routing\\": ""
+                    "Symfony\\Component\\Process\\": ""
                 },
                 "exclude-from-classmap": [
                     "/Tests/"
@@ -1598,42 +1673,59 @@
                     "homepage": "https://symfony.com/contributors"
                 }
             ],
-            "description": "Symfony Routing Component",
+            "description": "Symfony Process Component",
             "homepage": "https://symfony.com",
-            "keywords": [
-                "router",
-                "routing",
-                "uri",
-                "url"
-            ],
-            "time": "2017-06-24T09:29:48+00:00"
+            "time": "2018-01-03T07:37:34+00:00"
         },
         {
-            "name": "symfony/stopwatch",
-            "version": "v3.3.5",
+            "name": "symfony/routing",
+            "version": "v3.4.3",
             "source": {
                 "type": "git",
-                "url": "https://github.com/symfony/stopwatch.git",
-                "reference": "602a15299dc01556013b07167d4f5d3a60e90d15"
+                "url": "https://github.com/symfony/routing.git",
+                "reference": "e2b6d6fe7b090c7af720b75c7722c6dfa7a52658"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/symfony/stopwatch/zipball/602a15299dc01556013b07167d4f5d3a60e90d15",
-                "reference": "602a15299dc01556013b07167d4f5d3a60e90d15",
+                "url": "https://api.github.com/repos/symfony/routing/zipball/e2b6d6fe7b090c7af720b75c7722c6dfa7a52658",
+                "reference": "e2b6d6fe7b090c7af720b75c7722c6dfa7a52658",
                 "shasum": ""
             },
             "require": {
-                "php": ">=5.5.9"
+                "php": "^5.5.9|>=7.0.8"
+            },
+            "conflict": {
+                "symfony/config": "<2.8",
+                "symfony/dependency-injection": "<3.3",
+                "symfony/yaml": "<3.4"
+            },
+            "require-dev": {
+                "doctrine/annotations": "~1.0",
+                "doctrine/common": "~2.2",
+                "psr/log": "~1.0",
+                "symfony/config": "~2.8|~3.0|~4.0",
+                "symfony/dependency-injection": "~3.3|~4.0",
+                "symfony/expression-language": "~2.8|~3.0|~4.0",
+                "symfony/http-foundation": "~2.8|~3.0|~4.0",
+                "symfony/yaml": "~3.4|~4.0"
+            },
+            "suggest": {
+                "doctrine/annotations": "For using the annotation loader",
+                "symfony/config": "For using the all-in-one router or any loader",
+                "symfony/dependency-injection": "For loading routes from a service",
+                "symfony/expression-language": "For using expression matching",
+                "symfony/http-foundation": "For using a Symfony Request object",
+                "symfony/yaml": "For using the YAML loader"
             },
             "type": "library",
             "extra": {
                 "branch-alias": {
-                    "dev-master": "3.3-dev"
+                    "dev-master": "3.4-dev"
                 }
             },
             "autoload": {
                 "psr-4": {
-                    "Symfony\\Component\\Stopwatch\\": ""
+                    "Symfony\\Component\\Routing\\": ""
                 },
                 "exclude-from-classmap": [
                     "/Tests/"
@@ -1653,29 +1745,38 @@
                     "homepage": "https://symfony.com/contributors"
                 }
             ],
-            "description": "Symfony Stopwatch Component",
+            "description": "Symfony Routing Component",
             "homepage": "https://symfony.com",
-            "time": "2017-04-12T14:14:56+00:00"
+            "keywords": [
+                "router",
+                "routing",
+                "uri",
+                "url"
+            ],
+            "time": "2018-01-04T15:09:34+00:00"
         },
         {
             "name": "symfony/yaml",
-            "version": "v3.3.5",
+            "version": "v3.4.3",
             "source": {
                 "type": "git",
                 "url": "https://github.com/symfony/yaml.git",
-                "reference": "1f93a8d19b8241617f5074a123e282575b821df8"
+                "reference": "25c192f25721a74084272671f658797d9e0e0146"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/symfony/yaml/zipball/1f93a8d19b8241617f5074a123e282575b821df8",
-                "reference": "1f93a8d19b8241617f5074a123e282575b821df8",
+                "url": "https://api.github.com/repos/symfony/yaml/zipball/25c192f25721a74084272671f658797d9e0e0146",
+                "reference": "25c192f25721a74084272671f658797d9e0e0146",
                 "shasum": ""
             },
             "require": {
-                "php": ">=5.5.9"
+                "php": "^5.5.9|>=7.0.8"
+            },
+            "conflict": {
+                "symfony/console": "<3.4"
             },
             "require-dev": {
-                "symfony/console": "~2.8|~3.0"
+                "symfony/console": "~3.4|~4.0"
             },
             "suggest": {
                 "symfony/console": "For validating YAML files using the lint command"
@@ -1683,7 +1784,7 @@
             "type": "library",
             "extra": {
                 "branch-alias": {
-                    "dev-master": "3.3-dev"
+                    "dev-master": "3.4-dev"
                 }
             },
             "autoload": {
@@ -1710,7 +1811,7 @@
             ],
             "description": "Symfony Yaml Component",
             "homepage": "https://symfony.com",
-            "time": "2017-06-15T12:58:50+00:00"
+            "time": "2018-01-03T07:37:34+00:00"
         }
     ],
     "packages-dev": [],
@@ -1720,7 +1821,7 @@
     "prefer-stable": false,
     "prefer-lowest": false,
     "platform": {
-        "php": ">=5.5.9"
+        "php": "^5.5.9|>=7.0.8"
     },
     "platform-dev": [],
     "platform-overrides": {
diff --git a/symfony-3.3-micro/phpunit.xml.dist b/symfony-3.4-micro/phpunit.xml.dist
similarity index 100%
rename from symfony-3.3-micro/phpunit.xml.dist
rename to symfony-3.4-micro/phpunit.xml.dist
diff --git a/symfony-3.3-micro/src/App/Controller/HelloController.php b/symfony-3.4-micro/src/App/Controller/HelloController.php
similarity index 100%
rename from symfony-3.3-micro/src/App/Controller/HelloController.php
rename to symfony-3.4-micro/src/App/Controller/HelloController.php
diff --git a/symfony-3.3-micro/var/SymfonyRequirements.php b/symfony-3.4-micro/var/SymfonyRequirements.php
similarity index 100%
rename from symfony-3.3-micro/var/SymfonyRequirements.php
rename to symfony-3.4-micro/var/SymfonyRequirements.php
diff --git a/symfony-3.3-micro/var/cache/.gitkeep b/symfony-3.4-micro/var/cache/.gitkeep
similarity index 100%
rename from symfony-3.3-micro/var/cache/.gitkeep
rename to symfony-3.4-micro/var/cache/.gitkeep
diff --git a/symfony-3.3-micro/var/logs/.gitkeep b/symfony-3.4-micro/var/logs/.gitkeep
similarity index 100%
rename from symfony-3.3-micro/var/logs/.gitkeep
rename to symfony-3.4-micro/var/logs/.gitkeep
diff --git a/symfony-3.3-micro/var/sessions/.gitkeep b/symfony-3.4-micro/var/sessions/.gitkeep
similarity index 100%
rename from symfony-3.3-micro/var/sessions/.gitkeep
rename to symfony-3.4-micro/var/sessions/.gitkeep
diff --git a/symfony-3.3-micro/web/micro.php b/symfony-3.4-micro/web/micro.php
similarity index 100%
rename from symfony-3.3-micro/web/micro.php
rename to symfony-3.4-micro/web/micro.php
diff --git a/symfony-3.3/.gitignore b/symfony-3.4/.gitignore
similarity index 100%
rename from symfony-3.3/.gitignore
rename to symfony-3.4/.gitignore
diff --git a/symfony-3.3/README.md b/symfony-3.4/README.md
similarity index 72%
rename from symfony-3.3/README.md
rename to symfony-3.4/README.md
index 839b7e5f8..44895903c 100644
--- a/symfony-3.3/README.md
+++ b/symfony-3.4/README.md
@@ -1,4 +1,4 @@
-symfony-3.3
+symfony-3.4
 ===========
 
 A Symfony project
diff --git a/symfony-3.3/_benchmark/hello_world.sh b/symfony-3.4/_benchmark/hello_world.sh
similarity index 100%
rename from symfony-3.3/_benchmark/hello_world.sh
rename to symfony-3.4/_benchmark/hello_world.sh
diff --git a/symfony-3.3/_benchmark/setup.sh b/symfony-3.4/_benchmark/setup.sh
similarity index 100%
rename from symfony-3.3/_benchmark/setup.sh
rename to symfony-3.4/_benchmark/setup.sh
diff --git a/symfony-3.3/app/AppCache.php b/symfony-3.4/app/AppCache.php
similarity index 100%
rename from symfony-3.3/app/AppCache.php
rename to symfony-3.4/app/AppCache.php
diff --git a/symfony-3.3/app/AppKernel.php b/symfony-3.4/app/AppKernel.php
similarity index 100%
rename from symfony-3.3/app/AppKernel.php
rename to symfony-3.4/app/AppKernel.php
diff --git a/symfony-3.3/app/Resources/views/base.html.twig b/symfony-3.4/app/Resources/views/base.html.twig
similarity index 100%
rename from symfony-3.3/app/Resources/views/base.html.twig
rename to symfony-3.4/app/Resources/views/base.html.twig
diff --git a/symfony-3.3/app/Resources/views/default/index.html.twig b/symfony-3.4/app/Resources/views/default/index.html.twig
similarity index 100%
rename from symfony-3.3/app/Resources/views/default/index.html.twig
rename to symfony-3.4/app/Resources/views/default/index.html.twig
diff --git a/symfony-3.3/app/autoload.php b/symfony-3.4/app/autoload.php
similarity index 100%
rename from symfony-3.3/app/autoload.php
rename to symfony-3.4/app/autoload.php
diff --git a/symfony-3.3/app/config/config.yml b/symfony-3.4/app/config/config.yml
similarity index 100%
rename from symfony-3.3/app/config/config.yml
rename to symfony-3.4/app/config/config.yml
diff --git a/symfony-3.3/app/config/config_dev.yml b/symfony-3.4/app/config/config_dev.yml
similarity index 100%
rename from symfony-3.3/app/config/config_dev.yml
rename to symfony-3.4/app/config/config_dev.yml
diff --git a/symfony-3.3/app/config/config_prod.yml b/symfony-3.4/app/config/config_prod.yml
similarity index 100%
rename from symfony-3.3/app/config/config_prod.yml
rename to symfony-3.4/app/config/config_prod.yml
diff --git a/symfony-3.3/app/config/config_test.yml b/symfony-3.4/app/config/config_test.yml
similarity index 100%
rename from symfony-3.3/app/config/config_test.yml
rename to symfony-3.4/app/config/config_test.yml
diff --git a/symfony-3.3/app/config/parameters.yml.dist b/symfony-3.4/app/config/parameters.yml.dist
similarity index 100%
rename from symfony-3.3/app/config/parameters.yml.dist
rename to symfony-3.4/app/config/parameters.yml.dist
diff --git a/symfony-3.3/app/config/routing.yml b/symfony-3.4/app/config/routing.yml
similarity index 100%
rename from symfony-3.3/app/config/routing.yml
rename to symfony-3.4/app/config/routing.yml
diff --git a/symfony-3.3/app/config/routing_dev.yml b/symfony-3.4/app/config/routing_dev.yml
similarity index 100%
rename from symfony-3.3/app/config/routing_dev.yml
rename to symfony-3.4/app/config/routing_dev.yml
diff --git a/symfony-3.3/app/config/security.yml b/symfony-3.4/app/config/security.yml
similarity index 100%
rename from symfony-3.3/app/config/security.yml
rename to symfony-3.4/app/config/security.yml
diff --git a/symfony-3.3/app/config/services.yml b/symfony-3.4/app/config/services.yml
similarity index 100%
rename from symfony-3.3/app/config/services.yml
rename to symfony-3.4/app/config/services.yml
diff --git a/symfony-3.3/bin/console b/symfony-3.4/bin/console
similarity index 100%
rename from symfony-3.3/bin/console
rename to symfony-3.4/bin/console
diff --git a/symfony-3.3/bin/symfony_requirements b/symfony-3.4/bin/symfony_requirements
similarity index 100%
rename from symfony-3.3/bin/symfony_requirements
rename to symfony-3.4/bin/symfony_requirements
diff --git a/symfony-3.3/composer.json b/symfony-3.4/composer.json
similarity index 95%
rename from symfony-3.3/composer.json
rename to symfony-3.4/composer.json
index e6fc6a14a..a6f63491f 100644
--- a/symfony-3.3/composer.json
+++ b/symfony-3.4/composer.json
@@ -1,5 +1,5 @@
 {
-    "name": "kenji/symfony.3.3",
+    "name": "kenji/symfony.3.4",
     "license": "proprietary",
     "type": "project",
     "autoload": {
@@ -17,8 +17,8 @@
         }
     },
     "require": {
-        "php": ">=5.5.9",
-        "symfony/symfony": "3.3.*",
+        "php": "^5.5.9|>=7.0.8",
+        "symfony/symfony": "3.4.*",
         "doctrine/orm": "^2.5",
         "doctrine/doctrine-bundle": "^1.6",
         "doctrine/doctrine-cache-bundle": "^1.2",
diff --git a/symfony-3.3/composer.lock b/symfony-3.4/composer.lock
similarity index 87%
rename from symfony-3.3/composer.lock
rename to symfony-3.4/composer.lock
index 1b35b6c45..0a97ee23b 100644
--- a/symfony-3.3/composer.lock
+++ b/symfony-3.4/composer.lock
@@ -4,20 +4,20 @@
         "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#composer-lock-the-lock-file",
         "This file is @generated automatically"
     ],
-    "content-hash": "a723c0e8603b9ee3cc29461e54e74279",
+    "content-hash": "cab3e704043ea1ba4c17dd1c93524f32",
     "packages": [
         {
             "name": "composer/ca-bundle",
-            "version": "1.0.7",
+            "version": "1.1.0",
             "source": {
                 "type": "git",
                 "url": "https://github.com/composer/ca-bundle.git",
-                "reference": "b17e6153cb7f33c7e44eb59578dc12eee5dc8e12"
+                "reference": "943b2c4fcad1ef178d16a713c2468bf7e579c288"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/composer/ca-bundle/zipball/b17e6153cb7f33c7e44eb59578dc12eee5dc8e12",
-                "reference": "b17e6153cb7f33c7e44eb59578dc12eee5dc8e12",
+                "url": "https://api.github.com/repos/composer/ca-bundle/zipball/943b2c4fcad1ef178d16a713c2468bf7e579c288",
+                "reference": "943b2c4fcad1ef178d16a713c2468bf7e579c288",
                 "shasum": ""
             },
             "require": {
@@ -26,12 +26,9 @@
                 "php": "^5.3.2 || ^7.0"
             },
             "require-dev": {
-                "phpunit/phpunit": "^4.5",
+                "phpunit/phpunit": "^4.8.35",
                 "psr/log": "^1.0",
-                "symfony/process": "^2.5 || ^3.0"
-            },
-            "suggest": {
-                "symfony/process": "This is necessary to reliably check whether openssl_x509_parse is vulnerable on older php versions, but can be ignored on PHP 5.5.6+"
+                "symfony/process": "^2.5 || ^3.0 || ^4.0"
             },
             "type": "library",
             "extra": {
@@ -63,7 +60,7 @@
                 "ssl",
                 "tls"
             ],
-            "time": "2017-03-06T11:59:08+00:00"
+            "time": "2017-11-29T09:37:33+00:00"
         },
         {
             "name": "doctrine/annotations",
@@ -415,37 +412,41 @@
         },
         {
             "name": "doctrine/doctrine-bundle",
-            "version": "1.6.8",
+            "version": "1.8.1",
             "source": {
                 "type": "git",
                 "url": "https://github.com/doctrine/DoctrineBundle.git",
-                "reference": "6e96577cbbdbb5b6dcca2ff203d665976b51beb0"
+                "reference": "eb6e4fb904a459be28872765ab6e2d246aac7c87"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/doctrine/DoctrineBundle/zipball/6e96577cbbdbb5b6dcca2ff203d665976b51beb0",
-                "reference": "6e96577cbbdbb5b6dcca2ff203d665976b51beb0",
+                "url": "https://api.github.com/repos/doctrine/DoctrineBundle/zipball/eb6e4fb904a459be28872765ab6e2d246aac7c87",
+                "reference": "eb6e4fb904a459be28872765ab6e2d246aac7c87",
                 "shasum": ""
             },
             "require": {
-                "doctrine/dbal": "~2.3",
+                "doctrine/dbal": "^2.5.12",
                 "doctrine/doctrine-cache-bundle": "~1.2",
-                "jdorn/sql-formatter": "~1.1",
-                "php": ">=5.5.9",
+                "jdorn/sql-formatter": "^1.2.16",
+                "php": "^5.5.9|^7.0",
                 "symfony/console": "~2.7|~3.0|~4.0",
                 "symfony/dependency-injection": "~2.7|~3.0|~4.0",
                 "symfony/doctrine-bridge": "~2.7|~3.0|~4.0",
                 "symfony/framework-bundle": "~2.7|~3.0|~4.0"
             },
+            "conflict": {
+                "symfony/http-foundation": "<2.6"
+            },
             "require-dev": {
                 "doctrine/orm": "~2.3",
-                "phpunit/phpunit": "~4",
+                "phpunit/phpunit": "^4.8.36|^5.7|^6.4",
                 "satooshi/php-coveralls": "^1.0",
                 "symfony/phpunit-bridge": "~2.7|~3.0|~4.0",
                 "symfony/property-info": "~2.8|~3.0|~4.0",
                 "symfony/validator": "~2.7|~3.0|~4.0",
+                "symfony/web-profiler-bundle": "~2.7|~3.0|~4.0",
                 "symfony/yaml": "~2.7|~3.0|~4.0",
-                "twig/twig": "~1.12|~2.0"
+                "twig/twig": "~1.26|~2.0"
             },
             "suggest": {
                 "doctrine/orm": "The Doctrine ORM integration is optional in the bundle.",
@@ -454,7 +455,7 @@
             "type": "symfony-bundle",
             "extra": {
                 "branch-alias": {
-                    "dev-master": "1.6.x-dev"
+                    "dev-master": "1.8.x-dev"
                 }
             },
             "autoload": {
@@ -492,27 +493,27 @@
                 "orm",
                 "persistence"
             ],
-            "time": "2017-05-18T08:15:18+00:00"
+            "time": "2017-11-24T13:09:19+00:00"
         },
         {
             "name": "doctrine/doctrine-cache-bundle",
-            "version": "1.3.0",
+            "version": "1.3.2",
             "source": {
                 "type": "git",
                 "url": "https://github.com/doctrine/DoctrineCacheBundle.git",
-                "reference": "18c600a9b82f6454d2e81ca4957cdd56a1cf3504"
+                "reference": "9baecbd6bfdd1123b0cf8c1b88fee0170a84ddd1"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/doctrine/DoctrineCacheBundle/zipball/18c600a9b82f6454d2e81ca4957cdd56a1cf3504",
-                "reference": "18c600a9b82f6454d2e81ca4957cdd56a1cf3504",
+                "url": "https://api.github.com/repos/doctrine/DoctrineCacheBundle/zipball/9baecbd6bfdd1123b0cf8c1b88fee0170a84ddd1",
+                "reference": "9baecbd6bfdd1123b0cf8c1b88fee0170a84ddd1",
                 "shasum": ""
             },
             "require": {
                 "doctrine/cache": "^1.4.2",
                 "doctrine/inflector": "~1.0",
                 "php": ">=5.3.2",
-                "symfony/doctrine-bridge": "~2.2|~3.0"
+                "symfony/doctrine-bridge": "~2.2|~3.0|~4.0"
             },
             "require-dev": {
                 "instaclick/coding-standard": "~1.1",
@@ -520,15 +521,15 @@
                 "instaclick/symfony2-coding-standard": "dev-remaster",
                 "phpunit/phpunit": "~4",
                 "predis/predis": "~0.8",
-                "satooshi/php-coveralls": "~0.6.1",
+                "satooshi/php-coveralls": "^1.0",
                 "squizlabs/php_codesniffer": "~1.5",
-                "symfony/console": "~2.2|~3.0",
-                "symfony/finder": "~2.2|~3.0",
-                "symfony/framework-bundle": "~2.2|~3.0",
-                "symfony/phpunit-bridge": "~2.7|~3.0",
+                "symfony/console": "~2.2|~3.0|~4.0",
+                "symfony/finder": "~2.2|~3.0|~4.0",
+                "symfony/framework-bundle": "~2.2|~3.0|~4.0",
+                "symfony/phpunit-bridge": "~2.7|~3.0|~4.0",
                 "symfony/security-acl": "~2.3|~3.0",
-                "symfony/validator": "~2.2|~3.0",
-                "symfony/yaml": "~2.2|~3.0"
+                "symfony/validator": "~2.2|~3.0|~4.0",
+                "symfony/yaml": "~2.2|~3.0|~4.0"
             },
             "suggest": {
                 "symfony/security-acl": "For using this bundle to cache ACLs"
@@ -536,7 +537,7 @@
             "type": "symfony-bundle",
             "extra": {
                 "branch-alias": {
-                    "dev-master": "1.2.x-dev"
+                    "dev-master": "1.3.x-dev"
                 }
             },
             "autoload": {
@@ -580,7 +581,7 @@
                 "cache",
                 "caching"
             ],
-            "time": "2016-01-26T17:28:51+00:00"
+            "time": "2017-10-12T17:23:29+00:00"
         },
         {
             "name": "doctrine/inflector",
@@ -759,31 +760,31 @@
         },
         {
             "name": "doctrine/orm",
-            "version": "v2.5.6",
+            "version": "v2.5.14",
             "source": {
                 "type": "git",
                 "url": "https://github.com/doctrine/doctrine2.git",
-                "reference": "e6c434196c8ef058239aaa0724b4aadb0107940b"
+                "reference": "810a7baf81462a5ddf10e8baa8cb94b6eec02754"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/doctrine/doctrine2/zipball/e6c434196c8ef058239aaa0724b4aadb0107940b",
-                "reference": "e6c434196c8ef058239aaa0724b4aadb0107940b",
+                "url": "https://api.github.com/repos/doctrine/doctrine2/zipball/810a7baf81462a5ddf10e8baa8cb94b6eec02754",
+                "reference": "810a7baf81462a5ddf10e8baa8cb94b6eec02754",
                 "shasum": ""
             },
             "require": {
                 "doctrine/cache": "~1.4",
                 "doctrine/collections": "~1.2",
-                "doctrine/common": ">=2.5-dev,<2.8-dev",
-                "doctrine/dbal": ">=2.5-dev,<2.6-dev",
-                "doctrine/instantiator": "~1.0.1",
+                "doctrine/common": ">=2.5-dev,<2.9-dev",
+                "doctrine/dbal": ">=2.5-dev,<2.7-dev",
+                "doctrine/instantiator": "^1.0.1",
                 "ext-pdo": "*",
                 "php": ">=5.4",
-                "symfony/console": "~2.5|~3.0"
+                "symfony/console": "~2.5|~3.0|~4.0"
             },
             "require-dev": {
                 "phpunit/phpunit": "~4.0",
-                "symfony/yaml": "~2.3|~3.0"
+                "symfony/yaml": "~2.3|~3.0|~4.0"
             },
             "suggest": {
                 "symfony/yaml": "If you want to use YAML Metadata Mapping Driver"
@@ -831,7 +832,7 @@
                 "database",
                 "orm"
             ],
-            "time": "2016-12-18T15:42:34+00:00"
+            "time": "2017-12-17T02:57:51+00:00"
         },
         {
             "name": "fig/link-util",
@@ -1068,16 +1069,16 @@
         },
         {
             "name": "paragonie/random_compat",
-            "version": "v2.0.10",
+            "version": "v2.0.11",
             "source": {
                 "type": "git",
                 "url": "https://github.com/paragonie/random_compat.git",
-                "reference": "634bae8e911eefa89c1abfbf1b66da679ac8f54d"
+                "reference": "5da4d3c796c275c55f057af5a643ae297d96b4d8"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/paragonie/random_compat/zipball/634bae8e911eefa89c1abfbf1b66da679ac8f54d",
-                "reference": "634bae8e911eefa89c1abfbf1b66da679ac8f54d",
+                "url": "https://api.github.com/repos/paragonie/random_compat/zipball/5da4d3c796c275c55f057af5a643ae297d96b4d8",
+                "reference": "5da4d3c796c275c55f057af5a643ae297d96b4d8",
                 "shasum": ""
             },
             "require": {
@@ -1112,7 +1113,7 @@
                 "pseudorandom",
                 "random"
             ],
-            "time": "2017-03-13T16:27:32+00:00"
+            "time": "2017-09-27T21:40:39+00:00"
         },
         {
             "name": "psr/cache",
@@ -1355,16 +1356,16 @@
         },
         {
             "name": "sensio/distribution-bundle",
-            "version": "v5.0.20",
+            "version": "v5.0.21",
             "source": {
                 "type": "git",
                 "url": "https://github.com/sensiolabs/SensioDistributionBundle.git",
-                "reference": "4b019d4c0bd64438c42e4b6b0726085b409be8d9"
+                "reference": "eb6266b3b472e4002538610b28a0a04bcf94891a"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/sensiolabs/SensioDistributionBundle/zipball/4b019d4c0bd64438c42e4b6b0726085b409be8d9",
-                "reference": "4b019d4c0bd64438c42e4b6b0726085b409be8d9",
+                "url": "https://api.github.com/repos/sensiolabs/SensioDistributionBundle/zipball/eb6266b3b472e4002538610b28a0a04bcf94891a",
+                "reference": "eb6266b3b472e4002538610b28a0a04bcf94891a",
                 "shasum": ""
             },
             "require": {
@@ -1403,42 +1404,42 @@
                 "configuration",
                 "distribution"
             ],
-            "time": "2017-05-11T16:21:03+00:00"
+            "time": "2017-08-25T16:55:44+00:00"
         },
         {
             "name": "sensio/framework-extra-bundle",
-            "version": "v3.0.26",
+            "version": "v3.0.29",
             "source": {
                 "type": "git",
                 "url": "https://github.com/sensiolabs/SensioFrameworkExtraBundle.git",
-                "reference": "6d6cbe971554f0a2cc84965850481eb04a2a0059"
+                "reference": "bb907234df776b68922eb4b25bfa061683597b6a"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/sensiolabs/SensioFrameworkExtraBundle/zipball/6d6cbe971554f0a2cc84965850481eb04a2a0059",
-                "reference": "6d6cbe971554f0a2cc84965850481eb04a2a0059",
+                "url": "https://api.github.com/repos/sensiolabs/SensioFrameworkExtraBundle/zipball/bb907234df776b68922eb4b25bfa061683597b6a",
+                "reference": "bb907234df776b68922eb4b25bfa061683597b6a",
                 "shasum": ""
             },
             "require": {
                 "doctrine/common": "~2.2",
                 "symfony/dependency-injection": "~2.3|~3.0",
-                "symfony/framework-bundle": "~2.3|~3.0"
+                "symfony/framework-bundle": "~2.3|~3.0|~4.0"
             },
             "require-dev": {
                 "doctrine/doctrine-bundle": "~1.5",
                 "doctrine/orm": "~2.4,>=2.4.5",
-                "symfony/asset": "~2.7|~3.0",
-                "symfony/browser-kit": "~2.3|~3.0",
-                "symfony/dom-crawler": "~2.3|~3.0",
-                "symfony/expression-language": "~2.4|~3.0",
-                "symfony/finder": "~2.3|~3.0",
-                "symfony/phpunit-bridge": "~3.2",
-                "symfony/psr-http-message-bridge": "^0.3",
-                "symfony/security-bundle": "~2.4|~3.0",
-                "symfony/templating": "~2.3|~3.0",
-                "symfony/translation": "~2.3|~3.0",
-                "symfony/twig-bundle": "~2.3|~3.0",
-                "symfony/yaml": "~2.3|~3.0",
+                "symfony/asset": "~2.7|~3.0|~4.0",
+                "symfony/browser-kit": "~2.3|~3.0|~4.0",
+                "symfony/dom-crawler": "~2.3|~3.0|~4.0",
+                "symfony/expression-language": "~2.4|~3.0|~4.0",
+                "symfony/finder": "~2.3|~3.0|~4.0",
+                "symfony/phpunit-bridge": "~3.2|~4.0",
+                "symfony/psr-http-message-bridge": "^0.3|^1.0",
+                "symfony/security-bundle": "~2.4|~3.0|~4.0",
+                "symfony/templating": "~2.3|~3.0|~4.0",
+                "symfony/translation": "~2.3|~3.0|~4.0",
+                "symfony/twig-bundle": "~2.3|~3.0|~4.0",
+                "symfony/yaml": "~2.3|~3.0|~4.0",
                 "twig/twig": "~1.12|~2.0",
                 "zendframework/zend-diactoros": "^1.3"
             },
@@ -1473,25 +1474,25 @@
                 "annotations",
                 "controllers"
             ],
-            "time": "2017-05-11T17:01:57+00:00"
+            "time": "2017-12-14T19:03:23+00:00"
         },
         {
             "name": "sensiolabs/security-checker",
-            "version": "v4.0.5",
+            "version": "v4.1.7",
             "source": {
                 "type": "git",
                 "url": "https://github.com/sensiolabs/security-checker.git",
-                "reference": "6a3b0c3b42e41c777b1ad75032d8177863fdc5e1"
+                "reference": "d539ccba2b4dce515de04f16b7ed7ae5b9eeb434"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/sensiolabs/security-checker/zipball/6a3b0c3b42e41c777b1ad75032d8177863fdc5e1",
-                "reference": "6a3b0c3b42e41c777b1ad75032d8177863fdc5e1",
+                "url": "https://api.github.com/repos/sensiolabs/security-checker/zipball/d539ccba2b4dce515de04f16b7ed7ae5b9eeb434",
+                "reference": "d539ccba2b4dce515de04f16b7ed7ae5b9eeb434",
                 "shasum": ""
             },
             "require": {
                 "composer/ca-bundle": "^1.0",
-                "symfony/console": "~2.7|~3.0"
+                "symfony/console": "~2.7|~3.0|~4.0"
             },
             "bin": [
                 "security-checker"
@@ -1499,7 +1500,7 @@
             "type": "library",
             "extra": {
                 "branch-alias": {
-                    "dev-master": "4.0-dev"
+                    "dev-master": "4.1-dev"
                 }
             },
             "autoload": {
@@ -1518,20 +1519,20 @@
                 }
             ],
             "description": "A security checker for your composer.lock",
-            "time": "2017-07-24T11:42:56+00:00"
+            "time": "2018-01-11T05:54:03+00:00"
         },
         {
             "name": "swiftmailer/swiftmailer",
-            "version": "v5.4.8",
+            "version": "v5.4.9",
             "source": {
                 "type": "git",
                 "url": "https://github.com/swiftmailer/swiftmailer.git",
-                "reference": "9a06dc570a0367850280eefd3f1dc2da45aef517"
+                "reference": "7ffc1ea296ed14bf8260b6ef11b80208dbadba91"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/swiftmailer/swiftmailer/zipball/9a06dc570a0367850280eefd3f1dc2da45aef517",
-                "reference": "9a06dc570a0367850280eefd3f1dc2da45aef517",
+                "url": "https://api.github.com/repos/swiftmailer/swiftmailer/zipball/7ffc1ea296ed14bf8260b6ef11b80208dbadba91",
+                "reference": "7ffc1ea296ed14bf8260b6ef11b80208dbadba91",
                 "shasum": ""
             },
             "require": {
@@ -1566,13 +1567,13 @@
                 }
             ],
             "description": "Swiftmailer, free feature-rich PHP mailer",
-            "homepage": "http://swiftmailer.org",
+            "homepage": "https://swiftmailer.symfony.com",
             "keywords": [
                 "email",
                 "mail",
                 "mailer"
             ],
-            "time": "2017-05-01T15:54:03+00:00"
+            "time": "2018-01-23T07:37:21+00:00"
         },
         {
             "name": "symfony/monolog-bundle",
@@ -1634,18 +1635,74 @@
             ],
             "time": "2017-01-02T19:04:26+00:00"
         },
+        {
+            "name": "symfony/polyfill-apcu",
+            "version": "v1.6.0",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/polyfill-apcu.git",
+                "reference": "04f62674339602def515bff4bc6901fc1d4951e8"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/polyfill-apcu/zipball/04f62674339602def515bff4bc6901fc1d4951e8",
+                "reference": "04f62674339602def515bff4bc6901fc1d4951e8",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.3.3"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "1.6-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Polyfill\\Apcu\\": ""
+                },
+                "files": [
+                    "bootstrap.php"
+                ]
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Nicolas Grekas",
+                    "email": "p@tchwork.com"
+                },
+                {
+                    "name": "Symfony Community",
+                    "homepage": "https://symfony.com/contributors"
+                }
+            ],
+            "description": "Symfony polyfill backporting apcu_* functions to lower PHP versions",
+            "homepage": "https://symfony.com",
+            "keywords": [
+                "apcu",
+                "compatibility",
+                "polyfill",
+                "portable",
+                "shim"
+            ],
+            "time": "2017-10-11T12:05:26+00:00"
+        },
         {
             "name": "symfony/polyfill-intl-icu",
-            "version": "v1.4.0",
+            "version": "v1.6.0",
             "source": {
                 "type": "git",
                 "url": "https://github.com/symfony/polyfill-intl-icu.git",
-                "reference": "3191cbe0ce64987bd382daf6724af31c53daae01"
+                "reference": "d2bb2ef00dd8605d6fbd4db53ed4af1395953497"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/symfony/polyfill-intl-icu/zipball/3191cbe0ce64987bd382daf6724af31c53daae01",
-                "reference": "3191cbe0ce64987bd382daf6724af31c53daae01",
+                "url": "https://api.github.com/repos/symfony/polyfill-intl-icu/zipball/d2bb2ef00dd8605d6fbd4db53ed4af1395953497",
+                "reference": "d2bb2ef00dd8605d6fbd4db53ed4af1395953497",
                 "shasum": ""
             },
             "require": {
@@ -1658,7 +1715,7 @@
             "type": "library",
             "extra": {
                 "branch-alias": {
-                    "dev-master": "1.4-dev"
+                    "dev-master": "1.6-dev"
                 }
             },
             "autoload": {
@@ -1690,20 +1747,20 @@
                 "portable",
                 "shim"
             ],
-            "time": "2017-06-09T08:25:21+00:00"
+            "time": "2017-10-11T12:05:26+00:00"
         },
         {
             "name": "symfony/polyfill-mbstring",
-            "version": "v1.4.0",
+            "version": "v1.6.0",
             "source": {
                 "type": "git",
                 "url": "https://github.com/symfony/polyfill-mbstring.git",
-                "reference": "f29dca382a6485c3cbe6379f0c61230167681937"
+                "reference": "2ec8b39c38cb16674bbf3fea2b6ce5bf117e1296"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/symfony/polyfill-mbstring/zipball/f29dca382a6485c3cbe6379f0c61230167681937",
-                "reference": "f29dca382a6485c3cbe6379f0c61230167681937",
+                "url": "https://api.github.com/repos/symfony/polyfill-mbstring/zipball/2ec8b39c38cb16674bbf3fea2b6ce5bf117e1296",
+                "reference": "2ec8b39c38cb16674bbf3fea2b6ce5bf117e1296",
                 "shasum": ""
             },
             "require": {
@@ -1715,7 +1772,7 @@
             "type": "library",
             "extra": {
                 "branch-alias": {
-                    "dev-master": "1.4-dev"
+                    "dev-master": "1.6-dev"
                 }
             },
             "autoload": {
@@ -1749,20 +1806,20 @@
                 "portable",
                 "shim"
             ],
-            "time": "2017-06-09T14:24:12+00:00"
+            "time": "2017-10-11T12:05:26+00:00"
         },
         {
             "name": "symfony/polyfill-php56",
-            "version": "v1.4.0",
+            "version": "v1.6.0",
             "source": {
                 "type": "git",
                 "url": "https://github.com/symfony/polyfill-php56.git",
-                "reference": "bc0b7d6cb36b10cfabb170a3e359944a95174929"
+                "reference": "265fc96795492430762c29be291a371494ba3a5b"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/symfony/polyfill-php56/zipball/bc0b7d6cb36b10cfabb170a3e359944a95174929",
-                "reference": "bc0b7d6cb36b10cfabb170a3e359944a95174929",
+                "url": "https://api.github.com/repos/symfony/polyfill-php56/zipball/265fc96795492430762c29be291a371494ba3a5b",
+                "reference": "265fc96795492430762c29be291a371494ba3a5b",
                 "shasum": ""
             },
             "require": {
@@ -1772,7 +1829,7 @@
             "type": "library",
             "extra": {
                 "branch-alias": {
-                    "dev-master": "1.4-dev"
+                    "dev-master": "1.6-dev"
                 }
             },
             "autoload": {
@@ -1805,20 +1862,20 @@
                 "portable",
                 "shim"
             ],
-            "time": "2017-06-09T08:25:21+00:00"
+            "time": "2017-10-11T12:05:26+00:00"
         },
         {
             "name": "symfony/polyfill-php70",
-            "version": "v1.4.0",
+            "version": "v1.6.0",
             "source": {
                 "type": "git",
                 "url": "https://github.com/symfony/polyfill-php70.git",
-                "reference": "032fd647d5c11a9ceab8ee8747e13b5448e93874"
+                "reference": "0442b9c0596610bd24ae7b5f0a6cdbbc16d9fcff"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/symfony/polyfill-php70/zipball/032fd647d5c11a9ceab8ee8747e13b5448e93874",
-                "reference": "032fd647d5c11a9ceab8ee8747e13b5448e93874",
+                "url": "https://api.github.com/repos/symfony/polyfill-php70/zipball/0442b9c0596610bd24ae7b5f0a6cdbbc16d9fcff",
+                "reference": "0442b9c0596610bd24ae7b5f0a6cdbbc16d9fcff",
                 "shasum": ""
             },
             "require": {
@@ -1828,7 +1885,7 @@
             "type": "library",
             "extra": {
                 "branch-alias": {
-                    "dev-master": "1.4-dev"
+                    "dev-master": "1.6-dev"
                 }
             },
             "autoload": {
@@ -1864,20 +1921,20 @@
                 "portable",
                 "shim"
             ],
-            "time": "2017-06-09T14:24:12+00:00"
+            "time": "2017-10-11T12:05:26+00:00"
         },
         {
             "name": "symfony/polyfill-util",
-            "version": "v1.4.0",
+            "version": "v1.6.0",
             "source": {
                 "type": "git",
                 "url": "https://github.com/symfony/polyfill-util.git",
-                "reference": "ebccbde4aad410f6438d86d7d261c6b4d2b9a51d"
+                "reference": "6e719200c8e540e0c0effeb31f96bdb344b94176"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/symfony/polyfill-util/zipball/ebccbde4aad410f6438d86d7d261c6b4d2b9a51d",
-                "reference": "ebccbde4aad410f6438d86d7d261c6b4d2b9a51d",
+                "url": "https://api.github.com/repos/symfony/polyfill-util/zipball/6e719200c8e540e0c0effeb31f96bdb344b94176",
+                "reference": "6e719200c8e540e0c0effeb31f96bdb344b94176",
                 "shasum": ""
             },
             "require": {
@@ -1886,7 +1943,7 @@
             "type": "library",
             "extra": {
                 "branch-alias": {
-                    "dev-master": "1.4-dev"
+                    "dev-master": "1.6-dev"
                 }
             },
             "autoload": {
@@ -1916,20 +1973,20 @@
                 "polyfill",
                 "shim"
             ],
-            "time": "2017-06-09T08:25:21+00:00"
+            "time": "2017-10-11T12:05:26+00:00"
         },
         {
             "name": "symfony/swiftmailer-bundle",
-            "version": "v2.6.3",
+            "version": "v2.6.7",
             "source": {
                 "type": "git",
                 "url": "https://github.com/symfony/swiftmailer-bundle.git",
-                "reference": "11555c338f3c367b0a1bd2f024a53aa813f4ce00"
+                "reference": "c4808f5169efc05567be983909d00f00521c53ec"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/symfony/swiftmailer-bundle/zipball/11555c338f3c367b0a1bd2f024a53aa813f4ce00",
-                "reference": "11555c338f3c367b0a1bd2f024a53aa813f4ce00",
+                "url": "https://api.github.com/repos/symfony/swiftmailer-bundle/zipball/c4808f5169efc05567be983909d00f00521c53ec",
+                "reference": "c4808f5169efc05567be983909d00f00521c53ec",
                 "shasum": ""
             },
             "require": {
@@ -1975,47 +2032,49 @@
             ],
             "description": "Symfony SwiftmailerBundle",
             "homepage": "http://symfony.com",
-            "time": "2017-07-22T07:18:13+00:00"
+            "time": "2017-10-19T01:06:41+00:00"
         },
         {
             "name": "symfony/symfony",
-            "version": "v3.3.5",
+            "version": "v3.4.3",
             "source": {
                 "type": "git",
                 "url": "https://github.com/symfony/symfony.git",
-                "reference": "b9a0d3d2393f683b28043e9dbf83b8bf6b347faa"
+                "reference": "21abeae69baf64d689b04ca33663b4354be1a226"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/symfony/symfony/zipball/b9a0d3d2393f683b28043e9dbf83b8bf6b347faa",
-                "reference": "b9a0d3d2393f683b28043e9dbf83b8bf6b347faa",
+                "url": "https://api.github.com/repos/symfony/symfony/zipball/21abeae69baf64d689b04ca33663b4354be1a226",
+                "reference": "21abeae69baf64d689b04ca33663b4354be1a226",
                 "shasum": ""
             },
             "require": {
                 "doctrine/common": "~2.4",
                 "ext-xml": "*",
                 "fig/link-util": "^1.0",
-                "php": ">=5.5.9",
+                "php": "^5.5.9|>=7.0.8",
                 "psr/cache": "~1.0",
                 "psr/container": "^1.0",
                 "psr/link": "^1.0",
                 "psr/log": "~1.0",
                 "psr/simple-cache": "^1.0",
+                "symfony/polyfill-apcu": "~1.1",
                 "symfony/polyfill-intl-icu": "~1.0",
                 "symfony/polyfill-mbstring": "~1.0",
                 "symfony/polyfill-php56": "~1.0",
-                "symfony/polyfill-php70": "~1.0",
+                "symfony/polyfill-php70": "~1.6",
                 "symfony/polyfill-util": "~1.0",
-                "twig/twig": "~1.34|~2.4"
+                "twig/twig": "^1.35|^2.4.4"
             },
             "conflict": {
-                "phpdocumentor/reflection-docblock": "<3.0||>=3.2.0",
-                "phpdocumentor/type-resolver": "<0.2.0",
+                "phpdocumentor/reflection-docblock": "<3.0||>=3.2.0,<3.2.2",
+                "phpdocumentor/type-resolver": "<0.2.1",
                 "phpunit/phpunit": "<4.8.35|<5.4.3,>=5.0"
             },
             "provide": {
                 "psr/cache-implementation": "1.0",
                 "psr/container-implementation": "1.0",
+                "psr/log-implementation": "1.0",
                 "psr/simple-cache-implementation": "1.0"
             },
             "replace": {
@@ -2043,6 +2102,7 @@
                 "symfony/inflector": "self.version",
                 "symfony/intl": "self.version",
                 "symfony/ldap": "self.version",
+                "symfony/lock": "self.version",
                 "symfony/monolog-bridge": "self.version",
                 "symfony/options-resolver": "self.version",
                 "symfony/process": "self.version",
@@ -2072,6 +2132,7 @@
             },
             "require-dev": {
                 "cache/integration-tests": "dev-master",
+                "doctrine/annotations": "~1.0",
                 "doctrine/cache": "~1.6",
                 "doctrine/data-fixtures": "1.0.*",
                 "doctrine/dbal": "~2.4",
@@ -2080,17 +2141,15 @@
                 "egulias/email-validator": "~1.2,>=1.2.8|~2.0",
                 "monolog/monolog": "~1.11",
                 "ocramius/proxy-manager": "~0.4|~1.0|~2.0",
-                "phpdocumentor/reflection-docblock": "^3.0",
+                "phpdocumentor/reflection-docblock": "^3.0|^4.0",
                 "predis/predis": "~1.0",
-                "sensio/framework-extra-bundle": "^3.0.2",
-                "symfony/phpunit-bridge": "~3.2",
-                "symfony/polyfill-apcu": "~1.1",
+                "symfony/phpunit-bridge": "~3.4|~4.0",
                 "symfony/security-acl": "~2.8|~3.0"
             },
             "type": "library",
             "extra": {
                 "branch-alias": {
-                    "dev-master": "3.3-dev"
+                    "dev-master": "3.4-dev"
                 }
             },
             "autoload": {
@@ -2128,20 +2187,20 @@
             "keywords": [
                 "framework"
             ],
-            "time": "2017-07-17T19:08:46+00:00"
+            "time": "2018-01-05T08:33:31+00:00"
         },
         {
             "name": "twig/twig",
-            "version": "v1.34.4",
+            "version": "v1.35.0",
             "source": {
                 "type": "git",
                 "url": "https://github.com/twigphp/Twig.git",
-                "reference": "f878bab48edb66ad9c6ed626bf817f60c6c096ee"
+                "reference": "daa657073e55b0a78cce8fdd22682fddecc6385f"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/twigphp/Twig/zipball/f878bab48edb66ad9c6ed626bf817f60c6c096ee",
-                "reference": "f878bab48edb66ad9c6ed626bf817f60c6c096ee",
+                "url": "https://api.github.com/repos/twigphp/Twig/zipball/daa657073e55b0a78cce8fdd22682fddecc6385f",
+                "reference": "daa657073e55b0a78cce8fdd22682fddecc6385f",
                 "shasum": ""
             },
             "require": {
@@ -2155,7 +2214,7 @@
             "type": "library",
             "extra": {
                 "branch-alias": {
-                    "dev-master": "1.34-dev"
+                    "dev-master": "1.35-dev"
                 }
             },
             "autoload": {
@@ -2193,22 +2252,22 @@
             "keywords": [
                 "templating"
             ],
-            "time": "2017-07-04T13:19:31+00:00"
+            "time": "2017-09-27T18:06:46+00:00"
         }
     ],
     "packages-dev": [
         {
             "name": "sensio/generator-bundle",
-            "version": "v3.1.6",
+            "version": "v3.1.7",
             "source": {
                 "type": "git",
                 "url": "https://github.com/sensiolabs/SensioGeneratorBundle.git",
-                "reference": "128bc5dabc91ca40b7445f094968dd70ccd58305"
+                "reference": "28cbaa244bd0816fd8908b93f90380bcd7b67a65"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/sensiolabs/SensioGeneratorBundle/zipball/128bc5dabc91ca40b7445f094968dd70ccd58305",
-                "reference": "128bc5dabc91ca40b7445f094968dd70ccd58305",
+                "url": "https://api.github.com/repos/sensiolabs/SensioGeneratorBundle/zipball/28cbaa244bd0816fd8908b93f90380bcd7b67a65",
+                "reference": "28cbaa244bd0816fd8908b93f90380bcd7b67a65",
                 "shasum": ""
             },
             "require": {
@@ -2249,20 +2308,20 @@
                 }
             ],
             "description": "This bundle generates code for you",
-            "time": "2017-07-18T07:57:44+00:00"
+            "time": "2017-12-07T15:36:41+00:00"
         },
         {
             "name": "symfony/phpunit-bridge",
-            "version": "v3.3.5",
+            "version": "v3.4.3",
             "source": {
                 "type": "git",
                 "url": "https://github.com/symfony/phpunit-bridge.git",
-                "reference": "c2c124b7f9de79f4a64dc011f041a3a2c768b913"
+                "reference": "24ffb71a115c25f5ee56cbfd38e56ed2cdbeb0a9"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/symfony/phpunit-bridge/zipball/c2c124b7f9de79f4a64dc011f041a3a2c768b913",
-                "reference": "c2c124b7f9de79f4a64dc011f041a3a2c768b913",
+                "url": "https://api.github.com/repos/symfony/phpunit-bridge/zipball/24ffb71a115c25f5ee56cbfd38e56ed2cdbeb0a9",
+                "reference": "24ffb71a115c25f5ee56cbfd38e56ed2cdbeb0a9",
                 "shasum": ""
             },
             "require": {
@@ -2281,7 +2340,11 @@
             "type": "symfony-bridge",
             "extra": {
                 "branch-alias": {
-                    "dev-master": "3.3-dev"
+                    "dev-master": "3.4-dev"
+                },
+                "thanks": {
+                    "name": "phpunit/phpunit",
+                    "url": "https://github.com/sebastianbergmann/phpunit"
                 }
             },
             "autoload": {
@@ -2311,7 +2374,7 @@
             ],
             "description": "Symfony PHPUnit Bridge",
             "homepage": "https://symfony.com",
-            "time": "2017-06-12T13:35:45+00:00"
+            "time": "2018-01-04T17:19:23+00:00"
         }
     ],
     "aliases": [],
@@ -2320,7 +2383,7 @@
     "prefer-stable": false,
     "prefer-lowest": false,
     "platform": {
-        "php": ">=5.5.9"
+        "php": "^5.5.9|>=7.0.8"
     },
     "platform-dev": [],
     "platform-overrides": {
diff --git a/symfony-3.3/phpunit.xml.dist b/symfony-3.4/phpunit.xml.dist
similarity index 100%
rename from symfony-3.3/phpunit.xml.dist
rename to symfony-3.4/phpunit.xml.dist
diff --git a/symfony-3.3/src/AppBundle/AppBundle.php b/symfony-3.4/src/AppBundle/AppBundle.php
similarity index 100%
rename from symfony-3.3/src/AppBundle/AppBundle.php
rename to symfony-3.4/src/AppBundle/AppBundle.php
diff --git a/symfony-3.3/src/AppBundle/Controller/DefaultController.php b/symfony-3.4/src/AppBundle/Controller/DefaultController.php
similarity index 100%
rename from symfony-3.3/src/AppBundle/Controller/DefaultController.php
rename to symfony-3.4/src/AppBundle/Controller/DefaultController.php
diff --git a/symfony-3.3/src/AppBundle/Controller/HelloController.php b/symfony-3.4/src/AppBundle/Controller/HelloController.php
similarity index 100%
rename from symfony-3.3/src/AppBundle/Controller/HelloController.php
rename to symfony-3.4/src/AppBundle/Controller/HelloController.php
diff --git a/symfony-3.3/tests/AppBundle/Controller/DefaultControllerTest.php b/symfony-3.4/tests/AppBundle/Controller/DefaultControllerTest.php
similarity index 100%
rename from symfony-3.3/tests/AppBundle/Controller/DefaultControllerTest.php
rename to symfony-3.4/tests/AppBundle/Controller/DefaultControllerTest.php
diff --git a/symfony-3.3/var/SymfonyRequirements.php b/symfony-3.4/var/SymfonyRequirements.php
similarity index 100%
rename from symfony-3.3/var/SymfonyRequirements.php
rename to symfony-3.4/var/SymfonyRequirements.php
diff --git a/symfony-3.3/var/cache/.gitkeep b/symfony-3.4/var/cache/.gitkeep
similarity index 100%
rename from symfony-3.3/var/cache/.gitkeep
rename to symfony-3.4/var/cache/.gitkeep
diff --git a/symfony-3.3/var/logs/.gitkeep b/symfony-3.4/var/logs/.gitkeep
similarity index 100%
rename from symfony-3.3/var/logs/.gitkeep
rename to symfony-3.4/var/logs/.gitkeep
diff --git a/symfony-3.3/var/sessions/.gitkeep b/symfony-3.4/var/sessions/.gitkeep
similarity index 100%
rename from symfony-3.3/var/sessions/.gitkeep
rename to symfony-3.4/var/sessions/.gitkeep
diff --git a/symfony-3.3/web/app.php b/symfony-3.4/web/app.php
similarity index 100%
rename from symfony-3.3/web/app.php
rename to symfony-3.4/web/app.php
diff --git a/symfony-3.3/web/app_dev.php b/symfony-3.4/web/app_dev.php
similarity index 100%
rename from symfony-3.3/web/app_dev.php
rename to symfony-3.4/web/app_dev.php
diff --git a/symfony-3.3/web/apple-touch-icon.png b/symfony-3.4/web/apple-touch-icon.png
similarity index 100%
rename from symfony-3.3/web/apple-touch-icon.png
rename to symfony-3.4/web/apple-touch-icon.png
diff --git a/symfony-3.3/web/config.php b/symfony-3.4/web/config.php
similarity index 100%
rename from symfony-3.3/web/config.php
rename to symfony-3.4/web/config.php
diff --git a/symfony-3.3/web/favicon.ico b/symfony-3.4/web/favicon.ico
similarity index 100%
rename from symfony-3.3/web/favicon.ico
rename to symfony-3.4/web/favicon.ico
diff --git a/symfony-3.3/web/robots.txt b/symfony-3.4/web/robots.txt
similarity index 100%
rename from symfony-3.3/web/robots.txt
rename to symfony-3.4/web/robots.txt

From 1c82de0ace2fd4e36eff25e1a0095e218d18f43a Mon Sep 17 00:00:00 2001
From: Anton Minin <anton.a.minin@gmail.com>
Date: Tue, 23 Jan 2018 16:21:29 +0300
Subject: [PATCH 4/5] Add symfony 3.4 with micro-framework-bundle

---
 list.sh                                       |    1 +
 symfony-3.4-empty/.gitignore                  |   17 +
 symfony-3.4-empty/LICENSE                     |   19 +
 symfony-3.4-empty/README.md                   |   34 +
 symfony-3.4-empty/_benchmark/hello_world.sh   |    3 +
 symfony-3.4-empty/_benchmark/setup.sh         |    8 +
 symfony-3.4-empty/app/AppKernel.php           |   48 +
 symfony-3.4-empty/app/autoload.php            |    3 +
 symfony-3.4-empty/app/config/config.yml       |   23 +
 symfony-3.4-empty/app/config/config_dev.yml   |    2 +
 symfony-3.4-empty/app/config/config_prod.yml  |    2 +
 symfony-3.4-empty/app/config/config_test.yml  |    2 +
 .../app/config/parameters.yml.dist            |    2 +
 symfony-3.4-empty/app/config/routings.yml     |   12 +
 .../app/config/routings/.gitkeep              |    0
 .../app/config/routings/routings.yml          |   12 +
 symfony-3.4-empty/bin/console                 |   18 +
 symfony-3.4-empty/composer.json               |   35 +
 symfony-3.4-empty/composer.lock               | 1038 +++++++++++++++++
 symfony-3.4-empty/src/AppBundle/AppBundle.php |    9 +
 .../AppBundle/Controller/HelloController.php  |   15 +
 .../src/AppBundle/Kernel/MicroKernelTrait.php |   96 ++
 symfony-3.4-empty/var/cache/.gitkeep          |    0
 symfony-3.4-empty/var/logs/.gitkeep           |    0
 symfony-3.4-empty/web/app.php                 |   17 +
 symfony-3.4-empty/web/favicon.ico             |  Bin 0 -> 1406 bytes
 symfony-3.4-empty/web/robots.txt              |    4 +
 27 files changed, 1420 insertions(+)
 create mode 100644 symfony-3.4-empty/.gitignore
 create mode 100644 symfony-3.4-empty/LICENSE
 create mode 100644 symfony-3.4-empty/README.md
 create mode 100644 symfony-3.4-empty/_benchmark/hello_world.sh
 create mode 100644 symfony-3.4-empty/_benchmark/setup.sh
 create mode 100644 symfony-3.4-empty/app/AppKernel.php
 create mode 100644 symfony-3.4-empty/app/autoload.php
 create mode 100644 symfony-3.4-empty/app/config/config.yml
 create mode 100644 symfony-3.4-empty/app/config/config_dev.yml
 create mode 100644 symfony-3.4-empty/app/config/config_prod.yml
 create mode 100644 symfony-3.4-empty/app/config/config_test.yml
 create mode 100644 symfony-3.4-empty/app/config/parameters.yml.dist
 create mode 100644 symfony-3.4-empty/app/config/routings.yml
 create mode 100644 symfony-3.4-empty/app/config/routings/.gitkeep
 create mode 100644 symfony-3.4-empty/app/config/routings/routings.yml
 create mode 100755 symfony-3.4-empty/bin/console
 create mode 100644 symfony-3.4-empty/composer.json
 create mode 100644 symfony-3.4-empty/composer.lock
 create mode 100644 symfony-3.4-empty/src/AppBundle/AppBundle.php
 create mode 100644 symfony-3.4-empty/src/AppBundle/Controller/HelloController.php
 create mode 100644 symfony-3.4-empty/src/AppBundle/Kernel/MicroKernelTrait.php
 create mode 100644 symfony-3.4-empty/var/cache/.gitkeep
 create mode 100644 symfony-3.4-empty/var/logs/.gitkeep
 create mode 100644 symfony-3.4-empty/web/app.php
 create mode 100644 symfony-3.4-empty/web/favicon.ico
 create mode 100644 symfony-3.4-empty/web/robots.txt

diff --git a/list.sh b/list.sh
index 8881690d0..639691a78 100755
--- a/list.sh
+++ b/list.sh
@@ -42,6 +42,7 @@ staticphp-0.9
 symfony-3.0
 symfony-3.4
 symfony-3.4-micro
+symfony-3.4-empty
 tipsy-0.10
 #typo3f-2.3 # does not work
 #typo3f-3.0 # Catchable Fatal Error: Argument 1 passed to TYPO3\Flow\Object\ObjectManager::setObjects() must be of the type array, null given
diff --git a/symfony-3.4-empty/.gitignore b/symfony-3.4-empty/.gitignore
new file mode 100644
index 000000000..40e9c1007
--- /dev/null
+++ b/symfony-3.4-empty/.gitignore
@@ -0,0 +1,17 @@
+# Temporary Files
+/var/*
+
+!/var/cache
+/var/cache/*
+!var/cache/.gitkeep
+
+!/var/logs
+/var/logs/*
+!var/logs/.gitkeep
+
+# Configuration
+/app/config/parameters.yml
+
+# Third Party libraries
+/vendor/
+/composer.phar
diff --git a/symfony-3.4-empty/LICENSE b/symfony-3.4-empty/LICENSE
new file mode 100644
index 000000000..5241ee57e
--- /dev/null
+++ b/symfony-3.4-empty/LICENSE
@@ -0,0 +1,19 @@
+Copyright (c) 2014-2015 Loïc Faugeron
+
+Permission is hereby granted, free of charge, to any person obtaining a copy
+of this software and associated documentation files (the "Software"), to deal
+in the Software without restriction, including without limitation the rights
+to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+copies of the Software, and to permit persons to whom the Software is furnished
+to do so, subject to the following conditions:
+
+The above copyright notice and this permission notice shall be included in all
+copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
+THE SOFTWARE.
diff --git a/symfony-3.4-empty/README.md b/symfony-3.4-empty/README.md
new file mode 100644
index 000000000..3713fe968
--- /dev/null
+++ b/symfony-3.4-empty/README.md
@@ -0,0 +1,34 @@
+# Symfony Empty Edition
+
+A skeleton allowing you to create an empty Symfony application: it is provided without
+any libraries or bundles (except for Symfony's FrameworkBundle).
+
+You can then start building on it, and install the dependencies you need.
+
+> **Note**: The [Symfony Standard Edition](https://github.com/symfony/symfony-standard)
+> provides a big set of libraries and bundles (database, email, templating, etc).
+> If you don't feel comfortable with picking your own yet, you should probably use it.
+
+## Installation
+
+Use [Composer](https://getcomposer.org/) to create a new application:
+
+```
+composer create-project gnugat/symfony-empty-edition my-project
+```
+
+## Differences with the Standard Edition
+
+* Only 2 bundles: `src/AppBundle` and `symfony/framework-bundle`, add the ones you really need
+* Only 1 front controller (`web/app.php`), change the environment using the `SYMFONY_ENV` environment variable
+* No annotations (can be brought back by installing `sensio/framework-extra-bundle`)
+
+## Use cases
+
+There are many real world use cases for this distribution. Here's a small selection:
+
+* tailored made applications: for applications that require "non standard" dependencies (e.g. Propel or Pomm for the database, etc)
+* micro applications: for applications that don't need database, templating or mailing systems (Symfony can be a Micro Framework)
+* legacy migrations: for applications that need to depend on legacy database, templating, etc while migrating to symfony
+* teaching material: [better explained here](http://www.whitewashing.de/2014/04/24/symfony_hello_world.html)
+
diff --git a/symfony-3.4-empty/_benchmark/hello_world.sh b/symfony-3.4-empty/_benchmark/hello_world.sh
new file mode 100644
index 000000000..9e6369133
--- /dev/null
+++ b/symfony-3.4-empty/_benchmark/hello_world.sh
@@ -0,0 +1,3 @@
+#!/bin/sh
+
+url="$base/$fw/web/app.php/hello/index"
diff --git a/symfony-3.4-empty/_benchmark/setup.sh b/symfony-3.4-empty/_benchmark/setup.sh
new file mode 100644
index 000000000..0244cd4d5
--- /dev/null
+++ b/symfony-3.4-empty/_benchmark/setup.sh
@@ -0,0 +1,8 @@
+#!/bin/sh
+
+export SYMFONY_ENV=prod
+composer install --no-dev --optimize-autoloader
+php bin/console cache:clear --env=prod --no-debug --no-warmup
+php bin/console cache:warmup --env=prod --no-debug
+chmod o+w var/cache/ var/logs/
+chmod -R o+w var/cache/*
diff --git a/symfony-3.4-empty/app/AppKernel.php b/symfony-3.4-empty/app/AppKernel.php
new file mode 100644
index 000000000..e45ccd8f1
--- /dev/null
+++ b/symfony-3.4-empty/app/AppKernel.php
@@ -0,0 +1,48 @@
+<?php
+// app/AppKernel.php
+
+use AppBundle\Kernel\MicroKernelTrait;
+use Symfony\Component\DependencyInjection\ContainerBuilder;
+use Symfony\Component\HttpKernel\Kernel;
+use Symfony\Component\Config\Loader\LoaderInterface;
+use Symfony\Component\Routing\RouteCollectionBuilder;
+
+class AppKernel extends Kernel
+{
+    use MicroKernelTrait;
+
+    public function registerBundles()
+    {
+        $bundles = [
+            new Gnugat\MicroFrameworkBundle\GnugatMicroFrameworkBundle(),
+//            new Symfony\Bundle\MonologBundle\MonologBundle(),
+        ];
+
+        return $bundles;
+    }
+
+    protected function configureRoutes(RouteCollectionBuilder $routes)
+    {
+        $routes->add('/hello/index', \AppBundle\Controller\HelloController::class . '::indexAction');
+    }
+
+    public function getRootDir()
+    {
+        return __DIR__;
+    }
+
+    public function getCacheDir()
+    {
+        return dirname(__DIR__) . '/var/cache/' . $this->getEnvironment();
+    }
+
+    public function getLogDir()
+    {
+        return dirname(__DIR__) . '/var/logs';
+    }
+
+    protected function configureContainer(ContainerBuilder $c, LoaderInterface $loader)
+    {
+        $loader->load($this->getRootDir() . '/config/config_' . $this->getEnvironment() . '.yml');
+    }
+}
diff --git a/symfony-3.4-empty/app/autoload.php b/symfony-3.4-empty/app/autoload.php
new file mode 100644
index 000000000..991ea4397
--- /dev/null
+++ b/symfony-3.4-empty/app/autoload.php
@@ -0,0 +1,3 @@
+<?php
+
+require __DIR__.'/../vendor/autoload.php';
diff --git a/symfony-3.4-empty/app/config/config.yml b/symfony-3.4-empty/app/config/config.yml
new file mode 100644
index 000000000..2b0a05a9d
--- /dev/null
+++ b/symfony-3.4-empty/app/config/config.yml
@@ -0,0 +1,23 @@
+#imports:
+#    - { resource: parameters.yml }
+#    - { resource: services/ }
+#
+#framework:
+#    secret: '%secret%'
+#    router:
+#        resource: '%kernel.root_dir%/config/routings/'
+#        type: directory
+
+# app/config/config.yml
+imports:
+  - { resource: parameters.yml }
+
+#framework:
+#  secret: "%secret%"
+#  router:
+#    resource: "%kernel.root_dir%/config/routings.yml"
+
+services:
+  app.hello_controller:
+    class: AppBundle\Controller\HelloController
+    tags: ['controller.service_arguments']
diff --git a/symfony-3.4-empty/app/config/config_dev.yml b/symfony-3.4-empty/app/config/config_dev.yml
new file mode 100644
index 000000000..8e0b6ff02
--- /dev/null
+++ b/symfony-3.4-empty/app/config/config_dev.yml
@@ -0,0 +1,2 @@
+imports:
+    - { resource: config.yml }
diff --git a/symfony-3.4-empty/app/config/config_prod.yml b/symfony-3.4-empty/app/config/config_prod.yml
new file mode 100644
index 000000000..8e0b6ff02
--- /dev/null
+++ b/symfony-3.4-empty/app/config/config_prod.yml
@@ -0,0 +1,2 @@
+imports:
+    - { resource: config.yml }
diff --git a/symfony-3.4-empty/app/config/config_test.yml b/symfony-3.4-empty/app/config/config_test.yml
new file mode 100644
index 000000000..a3b2db43c
--- /dev/null
+++ b/symfony-3.4-empty/app/config/config_test.yml
@@ -0,0 +1,2 @@
+imports:
+    - { resource: config_dev.yml }
diff --git a/symfony-3.4-empty/app/config/parameters.yml.dist b/symfony-3.4-empty/app/config/parameters.yml.dist
new file mode 100644
index 000000000..a447c8b81
--- /dev/null
+++ b/symfony-3.4-empty/app/config/parameters.yml.dist
@@ -0,0 +1,2 @@
+parameters:
+    secret: ThouShallChangeMe
diff --git a/symfony-3.4-empty/app/config/routings.yml b/symfony-3.4-empty/app/config/routings.yml
new file mode 100644
index 000000000..0625d76f4
--- /dev/null
+++ b/symfony-3.4-empty/app/config/routings.yml
@@ -0,0 +1,12 @@
+main_page:
+    path: /
+    defaults:
+        _controller: app.hello_controller:worldAction
+    methods:
+        - GET
+hello_world:
+    path: /hello/index
+    defaults:
+        _controller: app.hello_controller:worldAction
+    methods:
+        - GET
\ No newline at end of file
diff --git a/symfony-3.4-empty/app/config/routings/.gitkeep b/symfony-3.4-empty/app/config/routings/.gitkeep
new file mode 100644
index 000000000..e69de29bb
diff --git a/symfony-3.4-empty/app/config/routings/routings.yml b/symfony-3.4-empty/app/config/routings/routings.yml
new file mode 100644
index 000000000..0625d76f4
--- /dev/null
+++ b/symfony-3.4-empty/app/config/routings/routings.yml
@@ -0,0 +1,12 @@
+main_page:
+    path: /
+    defaults:
+        _controller: app.hello_controller:worldAction
+    methods:
+        - GET
+hello_world:
+    path: /hello/index
+    defaults:
+        _controller: app.hello_controller:worldAction
+    methods:
+        - GET
\ No newline at end of file
diff --git a/symfony-3.4-empty/bin/console b/symfony-3.4-empty/bin/console
new file mode 100755
index 000000000..9d1acfea3
--- /dev/null
+++ b/symfony-3.4-empty/bin/console
@@ -0,0 +1,18 @@
+#!/usr/bin/env php
+<?php
+// bin/console
+
+set_time_limit(0);
+
+require_once __DIR__.'/../app/autoload.php';
+
+use Gnugat\MicroFrameworkBundle\Service\KernelApplication;
+use Symfony\Component\Console\Input\ArgvInput;
+
+$input = new ArgvInput();
+$env = $input->getParameterOption(array('--env', '-e'), 'dev');
+$debug = !$input->hasParameterOption(array('--no-debug', '')) && $env !== 'prod';
+
+$kernel = new AppKernel($env, $debug);
+$application = new KernelApplication($kernel);
+$application->run($input);
diff --git a/symfony-3.4-empty/composer.json b/symfony-3.4-empty/composer.json
new file mode 100644
index 000000000..37b55ed5a
--- /dev/null
+++ b/symfony-3.4-empty/composer.json
@@ -0,0 +1,35 @@
+{
+    "name": "gnugat/symfony-empty-edition",
+    "license": "MIT",
+    "type": "project",
+    "description": "The \"Symfony Empty Edition\" distribution",
+    "autoload": {
+        "psr-4": { "": "src" },
+        "files": [ "app/AppKernel.php" ]
+    },
+    "autoload-dev": {
+        "psr-4": { "Tests\\": "tests" }
+    },
+    "require": {
+        "php": "^5.5.9|^7.0",
+        "symfony/console": "^3.0",
+        "symfony/event-dispatcher": "^3.0",
+        "symfony/finder": "^3.0",
+        "symfony/yaml": "^3.0",
+        "incenteev/composer-parameter-handler": "^2.1",
+        "gnugat/micro-framework-bundle": "0.5.0"
+    },
+    "scripts": {
+        "post-install-cmd": [
+            "Incenteev\\ParameterHandler\\ScriptHandler::buildParameters"
+        ],
+        "post-update-cmd": [
+            "Incenteev\\ParameterHandler\\ScriptHandler::buildParameters"
+        ]
+    },
+    "extra": {
+        "incenteev-parameters": [
+            { "file": "app/config/parameters.yml" }
+        ]
+    }
+}
diff --git a/symfony-3.4-empty/composer.lock b/symfony-3.4-empty/composer.lock
new file mode 100644
index 000000000..30a7ea8cf
--- /dev/null
+++ b/symfony-3.4-empty/composer.lock
@@ -0,0 +1,1038 @@
+{
+    "_readme": [
+        "This file locks the dependencies of your project to a known state",
+        "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#composer-lock-the-lock-file",
+        "This file is @generated automatically"
+    ],
+    "content-hash": "8a0245f7f986cb0548da5da6fc82fc81",
+    "packages": [
+        {
+            "name": "gnugat/micro-framework-bundle",
+            "version": "v0.5.0",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/gnugat/micro-framework-bundle.git",
+                "reference": "fc426e68e891b456b9bff214f3d08d5509d5c8d0"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/gnugat/micro-framework-bundle/zipball/fc426e68e891b456b9bff214f3d08d5509d5c8d0",
+                "reference": "fc426e68e891b456b9bff214f3d08d5509d5c8d0",
+                "shasum": ""
+            },
+            "require": {
+                "php": "^5.5.9|^7.0",
+                "symfony/class-loader": "^3.0",
+                "symfony/config": "^3.0",
+                "symfony/console": "^3.0",
+                "symfony/dependency-injection": "^3.0",
+                "symfony/finder": "^3.0",
+                "symfony/http-kernel": "^3.0",
+                "symfony/routing": "^3.0"
+            },
+            "require-dev": {
+                "league/tactician-bundle": "^0.4",
+                "phpunit/phpunit": "^5.0",
+                "symfony/monolog-bundle": "^2.0"
+            },
+            "type": "symfony-bundle",
+            "autoload": {
+                "psr-4": {
+                    "Gnugat\\MicroFrameworkBundle\\": ""
+                },
+                "exclude-from-classmap": [
+                    "/Tests/"
+                ]
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Loïc Faugeron",
+                    "email": "faugeron.loic@gmail.com",
+                    "homepage": "http://gnugat.github.io",
+                    "role": "Developer"
+                }
+            ],
+            "description": "Symfony Micro Framework Bundle",
+            "homepage": "http://gnugat.github.io/micro-framework-bundle",
+            "keywords": [
+                "bundle",
+                "framework",
+                "micro",
+                "symfony"
+            ],
+            "time": "2016-03-09T19:36:33+00:00"
+        },
+        {
+            "name": "incenteev/composer-parameter-handler",
+            "version": "v2.1.2",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/Incenteev/ParameterHandler.git",
+                "reference": "d7ce7f06136109e81d1cb9d57066c4d4a99cf1cc"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/Incenteev/ParameterHandler/zipball/d7ce7f06136109e81d1cb9d57066c4d4a99cf1cc",
+                "reference": "d7ce7f06136109e81d1cb9d57066c4d4a99cf1cc",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.3.3",
+                "symfony/yaml": "~2.3|~3.0"
+            },
+            "require-dev": {
+                "composer/composer": "1.0.*@dev",
+                "phpspec/prophecy-phpunit": "~1.0",
+                "symfony/filesystem": "~2.2"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "2.1.x-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Incenteev\\ParameterHandler\\": ""
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Christophe Coevoet",
+                    "email": "stof@notk.org"
+                }
+            ],
+            "description": "Composer script handling your ignored parameter file",
+            "homepage": "https://github.com/Incenteev/ParameterHandler",
+            "keywords": [
+                "parameters management"
+            ],
+            "time": "2015-11-10T17:04:01+00:00"
+        },
+        {
+            "name": "psr/container",
+            "version": "1.0.0",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/php-fig/container.git",
+                "reference": "b7ce3b176482dbbc1245ebf52b181af44c2cf55f"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/php-fig/container/zipball/b7ce3b176482dbbc1245ebf52b181af44c2cf55f",
+                "reference": "b7ce3b176482dbbc1245ebf52b181af44c2cf55f",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.3.0"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "1.0.x-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Psr\\Container\\": "src/"
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "PHP-FIG",
+                    "homepage": "http://www.php-fig.org/"
+                }
+            ],
+            "description": "Common Container Interface (PHP FIG PSR-11)",
+            "homepage": "https://github.com/php-fig/container",
+            "keywords": [
+                "PSR-11",
+                "container",
+                "container-interface",
+                "container-interop",
+                "psr"
+            ],
+            "time": "2017-02-14T16:28:37+00:00"
+        },
+        {
+            "name": "psr/log",
+            "version": "1.0.2",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/php-fig/log.git",
+                "reference": "4ebe3a8bf773a19edfe0a84b6585ba3d401b724d"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/php-fig/log/zipball/4ebe3a8bf773a19edfe0a84b6585ba3d401b724d",
+                "reference": "4ebe3a8bf773a19edfe0a84b6585ba3d401b724d",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.3.0"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "1.0.x-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Psr\\Log\\": "Psr/Log/"
+                }
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "PHP-FIG",
+                    "homepage": "http://www.php-fig.org/"
+                }
+            ],
+            "description": "Common interface for logging libraries",
+            "homepage": "https://github.com/php-fig/log",
+            "keywords": [
+                "log",
+                "psr",
+                "psr-3"
+            ],
+            "time": "2016-10-10T12:19:37+00:00"
+        },
+        {
+            "name": "symfony/class-loader",
+            "version": "v3.4.3",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/class-loader.git",
+                "reference": "e63c12699822bb3b667e7216ba07fbcc3a3e203e"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/class-loader/zipball/e63c12699822bb3b667e7216ba07fbcc3a3e203e",
+                "reference": "e63c12699822bb3b667e7216ba07fbcc3a3e203e",
+                "shasum": ""
+            },
+            "require": {
+                "php": "^5.5.9|>=7.0.8"
+            },
+            "require-dev": {
+                "symfony/finder": "~2.8|~3.0|~4.0",
+                "symfony/polyfill-apcu": "~1.1"
+            },
+            "suggest": {
+                "symfony/polyfill-apcu": "For using ApcClassLoader on HHVM"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "3.4-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Component\\ClassLoader\\": ""
+                },
+                "exclude-from-classmap": [
+                    "/Tests/"
+                ]
+            },
+            "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 ClassLoader Component",
+            "homepage": "https://symfony.com",
+            "time": "2018-01-03T07:37:34+00:00"
+        },
+        {
+            "name": "symfony/config",
+            "version": "v3.4.3",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/config.git",
+                "reference": "cfd5c972f7b4992a5df41673d25d980ab077aa5b"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/config/zipball/cfd5c972f7b4992a5df41673d25d980ab077aa5b",
+                "reference": "cfd5c972f7b4992a5df41673d25d980ab077aa5b",
+                "shasum": ""
+            },
+            "require": {
+                "php": "^5.5.9|>=7.0.8",
+                "symfony/filesystem": "~2.8|~3.0|~4.0"
+            },
+            "conflict": {
+                "symfony/dependency-injection": "<3.3",
+                "symfony/finder": "<3.3"
+            },
+            "require-dev": {
+                "symfony/dependency-injection": "~3.3|~4.0",
+                "symfony/finder": "~3.3|~4.0",
+                "symfony/yaml": "~3.0|~4.0"
+            },
+            "suggest": {
+                "symfony/yaml": "To use the yaml reference dumper"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "3.4-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Component\\Config\\": ""
+                },
+                "exclude-from-classmap": [
+                    "/Tests/"
+                ]
+            },
+            "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 Config Component",
+            "homepage": "https://symfony.com",
+            "time": "2018-01-03T07:37:34+00:00"
+        },
+        {
+            "name": "symfony/console",
+            "version": "v3.4.3",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/console.git",
+                "reference": "8394c8ef121949e8f858f13bc1e34f05169e4e7d"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/console/zipball/8394c8ef121949e8f858f13bc1e34f05169e4e7d",
+                "reference": "8394c8ef121949e8f858f13bc1e34f05169e4e7d",
+                "shasum": ""
+            },
+            "require": {
+                "php": "^5.5.9|>=7.0.8",
+                "symfony/debug": "~2.8|~3.0|~4.0",
+                "symfony/polyfill-mbstring": "~1.0"
+            },
+            "conflict": {
+                "symfony/dependency-injection": "<3.4",
+                "symfony/process": "<3.3"
+            },
+            "require-dev": {
+                "psr/log": "~1.0",
+                "symfony/config": "~3.3|~4.0",
+                "symfony/dependency-injection": "~3.4|~4.0",
+                "symfony/event-dispatcher": "~2.8|~3.0|~4.0",
+                "symfony/lock": "~3.4|~4.0",
+                "symfony/process": "~3.3|~4.0"
+            },
+            "suggest": {
+                "psr/log": "For using the console logger",
+                "symfony/event-dispatcher": "",
+                "symfony/lock": "",
+                "symfony/process": ""
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "3.4-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Component\\Console\\": ""
+                },
+                "exclude-from-classmap": [
+                    "/Tests/"
+                ]
+            },
+            "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 Console Component",
+            "homepage": "https://symfony.com",
+            "time": "2018-01-03T07:37:34+00:00"
+        },
+        {
+            "name": "symfony/debug",
+            "version": "v4.0.3",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/debug.git",
+                "reference": "9ae4223a661b56a9abdce144de4886cca37f198f"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/debug/zipball/9ae4223a661b56a9abdce144de4886cca37f198f",
+                "reference": "9ae4223a661b56a9abdce144de4886cca37f198f",
+                "shasum": ""
+            },
+            "require": {
+                "php": "^7.1.3",
+                "psr/log": "~1.0"
+            },
+            "conflict": {
+                "symfony/http-kernel": "<3.4"
+            },
+            "require-dev": {
+                "symfony/http-kernel": "~3.4|~4.0"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "4.0-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Component\\Debug\\": ""
+                },
+                "exclude-from-classmap": [
+                    "/Tests/"
+                ]
+            },
+            "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 Debug Component",
+            "homepage": "https://symfony.com",
+            "time": "2018-01-03T17:15:19+00:00"
+        },
+        {
+            "name": "symfony/dependency-injection",
+            "version": "v3.4.3",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/dependency-injection.git",
+                "reference": "35f957ca171a431710966bec6e2f8636d3b019c4"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/dependency-injection/zipball/35f957ca171a431710966bec6e2f8636d3b019c4",
+                "reference": "35f957ca171a431710966bec6e2f8636d3b019c4",
+                "shasum": ""
+            },
+            "require": {
+                "php": "^5.5.9|>=7.0.8",
+                "psr/container": "^1.0"
+            },
+            "conflict": {
+                "symfony/config": "<3.3.7",
+                "symfony/finder": "<3.3",
+                "symfony/proxy-manager-bridge": "<3.4",
+                "symfony/yaml": "<3.4"
+            },
+            "provide": {
+                "psr/container-implementation": "1.0"
+            },
+            "require-dev": {
+                "symfony/config": "~3.3|~4.0",
+                "symfony/expression-language": "~2.8|~3.0|~4.0",
+                "symfony/yaml": "~3.4|~4.0"
+            },
+            "suggest": {
+                "symfony/config": "",
+                "symfony/expression-language": "For using expressions in service container configuration",
+                "symfony/finder": "For using double-star glob patterns or when GLOB_BRACE portability is required",
+                "symfony/proxy-manager-bridge": "Generate service proxies to lazy load them",
+                "symfony/yaml": ""
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "3.4-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Component\\DependencyInjection\\": ""
+                },
+                "exclude-from-classmap": [
+                    "/Tests/"
+                ]
+            },
+            "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": "2018-01-04T15:56:45+00:00"
+        },
+        {
+            "name": "symfony/event-dispatcher",
+            "version": "v3.4.3",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/event-dispatcher.git",
+                "reference": "26b87b6bca8f8f797331a30b76fdae5342dc26ca"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/event-dispatcher/zipball/26b87b6bca8f8f797331a30b76fdae5342dc26ca",
+                "reference": "26b87b6bca8f8f797331a30b76fdae5342dc26ca",
+                "shasum": ""
+            },
+            "require": {
+                "php": "^5.5.9|>=7.0.8"
+            },
+            "conflict": {
+                "symfony/dependency-injection": "<3.3"
+            },
+            "require-dev": {
+                "psr/log": "~1.0",
+                "symfony/config": "~2.8|~3.0|~4.0",
+                "symfony/dependency-injection": "~3.3|~4.0",
+                "symfony/expression-language": "~2.8|~3.0|~4.0",
+                "symfony/stopwatch": "~2.8|~3.0|~4.0"
+            },
+            "suggest": {
+                "symfony/dependency-injection": "",
+                "symfony/http-kernel": ""
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "3.4-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Component\\EventDispatcher\\": ""
+                },
+                "exclude-from-classmap": [
+                    "/Tests/"
+                ]
+            },
+            "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 EventDispatcher Component",
+            "homepage": "https://symfony.com",
+            "time": "2018-01-03T07:37:34+00:00"
+        },
+        {
+            "name": "symfony/filesystem",
+            "version": "v4.0.3",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/filesystem.git",
+                "reference": "760e47a4ee64b4c48f4b30017011e09d4c0f05ed"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/filesystem/zipball/760e47a4ee64b4c48f4b30017011e09d4c0f05ed",
+                "reference": "760e47a4ee64b4c48f4b30017011e09d4c0f05ed",
+                "shasum": ""
+            },
+            "require": {
+                "php": "^7.1.3"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "4.0-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Component\\Filesystem\\": ""
+                },
+                "exclude-from-classmap": [
+                    "/Tests/"
+                ]
+            },
+            "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 Filesystem Component",
+            "homepage": "https://symfony.com",
+            "time": "2018-01-03T07:38:00+00:00"
+        },
+        {
+            "name": "symfony/finder",
+            "version": "v3.4.3",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/finder.git",
+                "reference": "613e26310776f49a1773b6737c6bd554b8bc8c6f"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/finder/zipball/613e26310776f49a1773b6737c6bd554b8bc8c6f",
+                "reference": "613e26310776f49a1773b6737c6bd554b8bc8c6f",
+                "shasum": ""
+            },
+            "require": {
+                "php": "^5.5.9|>=7.0.8"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "3.4-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Component\\Finder\\": ""
+                },
+                "exclude-from-classmap": [
+                    "/Tests/"
+                ]
+            },
+            "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 Finder Component",
+            "homepage": "https://symfony.com",
+            "time": "2018-01-03T07:37:34+00:00"
+        },
+        {
+            "name": "symfony/http-foundation",
+            "version": "v4.0.3",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/http-foundation.git",
+                "reference": "03fe5171e35966f43453e2e5c15d7fe65f7fb23b"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/http-foundation/zipball/03fe5171e35966f43453e2e5c15d7fe65f7fb23b",
+                "reference": "03fe5171e35966f43453e2e5c15d7fe65f7fb23b",
+                "shasum": ""
+            },
+            "require": {
+                "php": "^7.1.3",
+                "symfony/polyfill-mbstring": "~1.1"
+            },
+            "require-dev": {
+                "symfony/expression-language": "~3.4|~4.0"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "4.0-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Component\\HttpFoundation\\": ""
+                },
+                "exclude-from-classmap": [
+                    "/Tests/"
+                ]
+            },
+            "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 HttpFoundation Component",
+            "homepage": "https://symfony.com",
+            "time": "2018-01-03T17:15:19+00:00"
+        },
+        {
+            "name": "symfony/http-kernel",
+            "version": "v3.4.3",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/http-kernel.git",
+                "reference": "1c2a82d6a8ec9b354fe4ef48ad1ad3f1a4f7db0e"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/http-kernel/zipball/1c2a82d6a8ec9b354fe4ef48ad1ad3f1a4f7db0e",
+                "reference": "1c2a82d6a8ec9b354fe4ef48ad1ad3f1a4f7db0e",
+                "shasum": ""
+            },
+            "require": {
+                "php": "^5.5.9|>=7.0.8",
+                "psr/log": "~1.0",
+                "symfony/debug": "~2.8|~3.0|~4.0",
+                "symfony/event-dispatcher": "~2.8|~3.0|~4.0",
+                "symfony/http-foundation": "^3.3.11|~4.0"
+            },
+            "conflict": {
+                "symfony/config": "<2.8",
+                "symfony/dependency-injection": "<3.4",
+                "symfony/var-dumper": "<3.3",
+                "twig/twig": "<1.34|<2.4,>=2"
+            },
+            "provide": {
+                "psr/log-implementation": "1.0"
+            },
+            "require-dev": {
+                "psr/cache": "~1.0",
+                "symfony/browser-kit": "~2.8|~3.0|~4.0",
+                "symfony/class-loader": "~2.8|~3.0",
+                "symfony/config": "~2.8|~3.0|~4.0",
+                "symfony/console": "~2.8|~3.0|~4.0",
+                "symfony/css-selector": "~2.8|~3.0|~4.0",
+                "symfony/dependency-injection": "~3.4|~4.0",
+                "symfony/dom-crawler": "~2.8|~3.0|~4.0",
+                "symfony/expression-language": "~2.8|~3.0|~4.0",
+                "symfony/finder": "~2.8|~3.0|~4.0",
+                "symfony/process": "~2.8|~3.0|~4.0",
+                "symfony/routing": "~3.4|~4.0",
+                "symfony/stopwatch": "~2.8|~3.0|~4.0",
+                "symfony/templating": "~2.8|~3.0|~4.0",
+                "symfony/translation": "~2.8|~3.0|~4.0",
+                "symfony/var-dumper": "~3.3|~4.0"
+            },
+            "suggest": {
+                "symfony/browser-kit": "",
+                "symfony/config": "",
+                "symfony/console": "",
+                "symfony/dependency-injection": "",
+                "symfony/finder": "",
+                "symfony/var-dumper": ""
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "3.4-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Component\\HttpKernel\\": ""
+                },
+                "exclude-from-classmap": [
+                    "/Tests/"
+                ]
+            },
+            "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 HttpKernel Component",
+            "homepage": "https://symfony.com",
+            "time": "2018-01-05T08:33:00+00:00"
+        },
+        {
+            "name": "symfony/polyfill-mbstring",
+            "version": "v1.6.0",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/polyfill-mbstring.git",
+                "reference": "2ec8b39c38cb16674bbf3fea2b6ce5bf117e1296"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/polyfill-mbstring/zipball/2ec8b39c38cb16674bbf3fea2b6ce5bf117e1296",
+                "reference": "2ec8b39c38cb16674bbf3fea2b6ce5bf117e1296",
+                "shasum": ""
+            },
+            "require": {
+                "php": ">=5.3.3"
+            },
+            "suggest": {
+                "ext-mbstring": "For best performance"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "1.6-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Polyfill\\Mbstring\\": ""
+                },
+                "files": [
+                    "bootstrap.php"
+                ]
+            },
+            "notification-url": "https://packagist.org/downloads/",
+            "license": [
+                "MIT"
+            ],
+            "authors": [
+                {
+                    "name": "Nicolas Grekas",
+                    "email": "p@tchwork.com"
+                },
+                {
+                    "name": "Symfony Community",
+                    "homepage": "https://symfony.com/contributors"
+                }
+            ],
+            "description": "Symfony polyfill for the Mbstring extension",
+            "homepage": "https://symfony.com",
+            "keywords": [
+                "compatibility",
+                "mbstring",
+                "polyfill",
+                "portable",
+                "shim"
+            ],
+            "time": "2017-10-11T12:05:26+00:00"
+        },
+        {
+            "name": "symfony/routing",
+            "version": "v3.4.3",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/routing.git",
+                "reference": "e2b6d6fe7b090c7af720b75c7722c6dfa7a52658"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/routing/zipball/e2b6d6fe7b090c7af720b75c7722c6dfa7a52658",
+                "reference": "e2b6d6fe7b090c7af720b75c7722c6dfa7a52658",
+                "shasum": ""
+            },
+            "require": {
+                "php": "^5.5.9|>=7.0.8"
+            },
+            "conflict": {
+                "symfony/config": "<2.8",
+                "symfony/dependency-injection": "<3.3",
+                "symfony/yaml": "<3.4"
+            },
+            "require-dev": {
+                "doctrine/annotations": "~1.0",
+                "doctrine/common": "~2.2",
+                "psr/log": "~1.0",
+                "symfony/config": "~2.8|~3.0|~4.0",
+                "symfony/dependency-injection": "~3.3|~4.0",
+                "symfony/expression-language": "~2.8|~3.0|~4.0",
+                "symfony/http-foundation": "~2.8|~3.0|~4.0",
+                "symfony/yaml": "~3.4|~4.0"
+            },
+            "suggest": {
+                "doctrine/annotations": "For using the annotation loader",
+                "symfony/config": "For using the all-in-one router or any loader",
+                "symfony/dependency-injection": "For loading routes from a service",
+                "symfony/expression-language": "For using expression matching",
+                "symfony/http-foundation": "For using a Symfony Request object",
+                "symfony/yaml": "For using the YAML loader"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "3.4-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Component\\Routing\\": ""
+                },
+                "exclude-from-classmap": [
+                    "/Tests/"
+                ]
+            },
+            "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 Routing Component",
+            "homepage": "https://symfony.com",
+            "keywords": [
+                "router",
+                "routing",
+                "uri",
+                "url"
+            ],
+            "time": "2018-01-04T15:09:34+00:00"
+        },
+        {
+            "name": "symfony/yaml",
+            "version": "v3.4.3",
+            "source": {
+                "type": "git",
+                "url": "https://github.com/symfony/yaml.git",
+                "reference": "25c192f25721a74084272671f658797d9e0e0146"
+            },
+            "dist": {
+                "type": "zip",
+                "url": "https://api.github.com/repos/symfony/yaml/zipball/25c192f25721a74084272671f658797d9e0e0146",
+                "reference": "25c192f25721a74084272671f658797d9e0e0146",
+                "shasum": ""
+            },
+            "require": {
+                "php": "^5.5.9|>=7.0.8"
+            },
+            "conflict": {
+                "symfony/console": "<3.4"
+            },
+            "require-dev": {
+                "symfony/console": "~3.4|~4.0"
+            },
+            "suggest": {
+                "symfony/console": "For validating YAML files using the lint command"
+            },
+            "type": "library",
+            "extra": {
+                "branch-alias": {
+                    "dev-master": "3.4-dev"
+                }
+            },
+            "autoload": {
+                "psr-4": {
+                    "Symfony\\Component\\Yaml\\": ""
+                },
+                "exclude-from-classmap": [
+                    "/Tests/"
+                ]
+            },
+            "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 Yaml Component",
+            "homepage": "https://symfony.com",
+            "time": "2018-01-03T07:37:34+00:00"
+        }
+    ],
+    "packages-dev": [],
+    "aliases": [],
+    "minimum-stability": "stable",
+    "stability-flags": [],
+    "prefer-stable": false,
+    "prefer-lowest": false,
+    "platform": {
+        "php": "^5.5.9|^7.0"
+    },
+    "platform-dev": []
+}
diff --git a/symfony-3.4-empty/src/AppBundle/AppBundle.php b/symfony-3.4-empty/src/AppBundle/AppBundle.php
new file mode 100644
index 000000000..05123b678
--- /dev/null
+++ b/symfony-3.4-empty/src/AppBundle/AppBundle.php
@@ -0,0 +1,9 @@
+<?php
+
+namespace AppBundle;
+
+use Symfony\Component\HttpKernel\Bundle\Bundle;
+
+class AppBundle extends Bundle
+{
+}
diff --git a/symfony-3.4-empty/src/AppBundle/Controller/HelloController.php b/symfony-3.4-empty/src/AppBundle/Controller/HelloController.php
new file mode 100644
index 000000000..13ddeefc2
--- /dev/null
+++ b/symfony-3.4-empty/src/AppBundle/Controller/HelloController.php
@@ -0,0 +1,15 @@
+<?php
+// src/AppBundle/Controller/HelloController.php
+
+namespace AppBundle\Controller;
+
+use Symfony\Component\HttpFoundation\Request;
+use Symfony\Component\HttpFoundation\Response;
+
+class HelloController
+{
+    public function worldAction(Request $request)
+    {
+        return new Response('Hello World!');
+    }
+}
diff --git a/symfony-3.4-empty/src/AppBundle/Kernel/MicroKernelTrait.php b/symfony-3.4-empty/src/AppBundle/Kernel/MicroKernelTrait.php
new file mode 100644
index 000000000..326e031c8
--- /dev/null
+++ b/symfony-3.4-empty/src/AppBundle/Kernel/MicroKernelTrait.php
@@ -0,0 +1,96 @@
+<?php
+
+/*
+ * This file is part of the Symfony package.
+ *
+ * (c) Fabien Potencier <fabien@symfony.com>
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace AppBundle\Kernel;
+
+use Symfony\Component\Config\Loader\LoaderInterface;
+use Symfony\Component\DependencyInjection\ContainerBuilder;
+use Symfony\Component\EventDispatcher\EventSubscriberInterface;
+use Symfony\Component\Routing\RouteCollectionBuilder;
+
+/**
+ * A Kernel that provides configuration hooks.
+ *
+ * @author Ryan Weaver <ryan@knpuniversity.com>
+ * @author Fabien Potencier <fabien@symfony.com>
+ */
+trait MicroKernelTrait
+{
+    /**
+     * Add or import routes into your application.
+     *
+     *     $routes->import('config/routing.yml');
+     *     $routes->add('/admin', 'AppBundle:Admin:dashboard', 'admin_dashboard');
+     *
+     * @param RouteCollectionBuilder $routes
+     */
+    abstract protected function configureRoutes(RouteCollectionBuilder $routes);
+
+    /**
+     * Configures the container.
+     *
+     * You can register extensions:
+     *
+     * $c->loadFromExtension('framework', array(
+     *     'secret' => '%secret%'
+     * ));
+     *
+     * Or services:
+     *
+     * $c->register('halloween', 'FooBundle\HalloweenProvider');
+     *
+     * Or parameters:
+     *
+     * $c->setParameter('halloween', 'lot of fun');
+     *
+     * @param ContainerBuilder $c
+     * @param LoaderInterface  $loader
+     */
+    abstract protected function configureContainer(ContainerBuilder $c, LoaderInterface $loader);
+
+    /**
+     * {@inheritdoc}
+     */
+    public function registerContainerConfiguration(LoaderInterface $loader)
+    {
+        $loader->load(function (ContainerBuilder $container) use ($loader) {
+            $container->loadFromExtension('gnugat_micro_framework', array(
+                'router' => array(
+                    'resource' => 'kernel:loadRoutes',
+                    'type' => 'service',
+                ),
+            ));
+
+            if ($this instanceof EventSubscriberInterface) {
+                $container->register('kernel', static::class)
+                    ->setSynthetic(true)
+                    ->setPublic(true)
+                    ->addTag('kernel.event_subscriber')
+                ;
+            }
+
+            $this->configureContainer($container, $loader);
+
+            $container->addObjectResource($this);
+        });
+    }
+
+    /**
+     * @internal
+     */
+    public function loadRoutes(LoaderInterface $loader)
+    {
+        $routes = new RouteCollectionBuilder($loader);
+        $this->configureRoutes($routes);
+
+        return $routes->build();
+    }
+}
diff --git a/symfony-3.4-empty/var/cache/.gitkeep b/symfony-3.4-empty/var/cache/.gitkeep
new file mode 100644
index 000000000..e69de29bb
diff --git a/symfony-3.4-empty/var/logs/.gitkeep b/symfony-3.4-empty/var/logs/.gitkeep
new file mode 100644
index 000000000..e69de29bb
diff --git a/symfony-3.4-empty/web/app.php b/symfony-3.4-empty/web/app.php
new file mode 100644
index 000000000..33eb67506
--- /dev/null
+++ b/symfony-3.4-empty/web/app.php
@@ -0,0 +1,17 @@
+<?php
+
+use Symfony\Component\HttpFoundation\Request;
+
+require_once __DIR__.'/../app/autoload.php';
+
+$env = getenv('SYMFONY_ENV') ?: 'prod';
+$debug = ('prod' !== $env);
+
+$kernel = new AppKernel($env, $debug);
+// $kernel->loadClassCache();
+Request::enableHttpMethodParameterOverride();
+$request = Request::createFromGlobals();
+$response = $kernel->handle($request);
+$response->send();
+
+require __DIR__ . '/../../libs/output_data.php';
diff --git a/symfony-3.4-empty/web/favicon.ico b/symfony-3.4-empty/web/favicon.ico
new file mode 100644
index 0000000000000000000000000000000000000000..526c2581c9502539ae8a0e0d9daa9781749539e2
GIT binary patch
literal 1406
zcmZQzU<5(|0R|w+!H~hqz#zuJz@P!dKp_SNAO?w#g3%Bd4S~@R7!3i`5cvO}fq@bX
E0PkKP@Bjb+

literal 0
HcmV?d00001

diff --git a/symfony-3.4-empty/web/robots.txt b/symfony-3.4-empty/web/robots.txt
new file mode 100644
index 000000000..214e41196
--- /dev/null
+++ b/symfony-3.4-empty/web/robots.txt
@@ -0,0 +1,4 @@
+# www.robotstxt.org/
+# www.google.com/support/webmasters/bin/answer.py?hl=en&answer=156449
+
+User-agent: *

From 96d0fa679436c52c027e6ee35f39beb1bdcaa2ef Mon Sep 17 00:00:00 2001
From: Anton Minin <anton.a.minin@gmail.com>
Date: Tue, 23 Jan 2018 16:34:55 +0300
Subject: [PATCH 5/5] Fix some warnings

---
 phalcon-1.3/public/index.php |  2 +-
 phalcon-2.0/public/index.php |  2 +-
 slim-3.0/index.php           | 11 +++++++++--
 symfony-3.4/web/app.php      |  2 +-
 4 files changed, 12 insertions(+), 5 deletions(-)

diff --git a/phalcon-1.3/public/index.php b/phalcon-1.3/public/index.php
index 0692a1a0e..9e562dcda 100644
--- a/phalcon-1.3/public/index.php
+++ b/phalcon-1.3/public/index.php
@@ -30,4 +30,4 @@
     echo $e->getMessage();
 }
 
-require $_SERVER['DOCUMENT_ROOT'].'/php-framework-benchmark/libs/output_data.php';
+require __DIR__ . '/../../libs/output_data.php';
diff --git a/phalcon-2.0/public/index.php b/phalcon-2.0/public/index.php
index 0692a1a0e..9e562dcda 100644
--- a/phalcon-2.0/public/index.php
+++ b/phalcon-2.0/public/index.php
@@ -30,4 +30,4 @@
     echo $e->getMessage();
 }
 
-require $_SERVER['DOCUMENT_ROOT'].'/php-framework-benchmark/libs/output_data.php';
+require __DIR__ . '/../../libs/output_data.php';
diff --git a/slim-3.0/index.php b/slim-3.0/index.php
index d07cb7226..f62cc1838 100644
--- a/slim-3.0/index.php
+++ b/slim-3.0/index.php
@@ -5,9 +5,16 @@
 $app = new \Slim\App();
 
 $app->get('/hello/index', function ($request, $response, $args) {
-    return $response->write('Hello World!');
+    return $response->write('Hello World!' . str_repeat('+', 22));
 });
 
+ob_start();
 $app->run();
+$output = ob_get_clean();
 
-require $_SERVER['DOCUMENT_ROOT'].'/php-framework-benchmark/libs/output_data.php';
+ob_start();
+// Doesn't work due to Content-Length header
+require __DIR__ . '/../libs/output_data.php';
+$benchmarkData = ob_get_clean();
+
+echo str_replace('+', ' ', str_replace(str_repeat('+', min(22, strlen($benchmarkData))), $benchmarkData, $output));
diff --git a/symfony-3.4/web/app.php b/symfony-3.4/web/app.php
index 2244ea5c5..ff372e2ca 100644
--- a/symfony-3.4/web/app.php
+++ b/symfony-3.4/web/app.php
@@ -29,4 +29,4 @@
 $response->send();
 $kernel->terminate($request, $response);
 
-require $_SERVER['DOCUMENT_ROOT'].'/php-framework-benchmark/libs/output_data.php';
+require __DIR__ . '/../../libs/output_data.php';