composer update (Symfony 3.2, Doctrine 2.5, etc)

This commit is contained in:
Alexey Skobkin 2016-12-19 03:23:45 +03:00
parent ee887d8528
commit fb6344d407
14 changed files with 909 additions and 866 deletions

View file

@ -13,7 +13,6 @@ class AppKernel extends Kernel
new Symfony\Bundle\TwigBundle\TwigBundle(), new Symfony\Bundle\TwigBundle\TwigBundle(),
new Symfony\Bundle\MonologBundle\MonologBundle(), new Symfony\Bundle\MonologBundle\MonologBundle(),
new Symfony\Bundle\SwiftmailerBundle\SwiftmailerBundle(), new Symfony\Bundle\SwiftmailerBundle\SwiftmailerBundle(),
new Symfony\Bundle\AsseticBundle\AsseticBundle(),
new Doctrine\Bundle\DoctrineBundle\DoctrineBundle(), new Doctrine\Bundle\DoctrineBundle\DoctrineBundle(),
new Doctrine\Bundle\MigrationsBundle\DoctrineMigrationsBundle(), new Doctrine\Bundle\MigrationsBundle\DoctrineMigrationsBundle(),
new Doctrine\Bundle\FixturesBundle\DoctrineFixturesBundle(), new Doctrine\Bundle\FixturesBundle\DoctrineFixturesBundle(),

View file

@ -168,6 +168,9 @@ class PhpIniRequirement extends Requirement
*/ */
class RequirementCollection implements IteratorAggregate class RequirementCollection implements IteratorAggregate
{ {
/**
* @var Requirement[]
*/
private $requirements = array(); private $requirements = array();
/** /**
@ -265,7 +268,7 @@ class RequirementCollection implements IteratorAggregate
/** /**
* Returns both requirements and recommendations. * Returns both requirements and recommendations.
* *
* @return array Array of Requirement instances * @return Requirement[]
*/ */
public function all() public function all()
{ {
@ -275,7 +278,7 @@ class RequirementCollection implements IteratorAggregate
/** /**
* Returns all mandatory requirements. * Returns all mandatory requirements.
* *
* @return array Array of Requirement instances * @return Requirement[]
*/ */
public function getRequirements() public function getRequirements()
{ {
@ -292,7 +295,7 @@ class RequirementCollection implements IteratorAggregate
/** /**
* Returns the mandatory requirements that were not met. * Returns the mandatory requirements that were not met.
* *
* @return array Array of Requirement instances * @return Requirement[]
*/ */
public function getFailedRequirements() public function getFailedRequirements()
{ {
@ -309,7 +312,7 @@ class RequirementCollection implements IteratorAggregate
/** /**
* Returns all optional recommendations. * Returns all optional recommendations.
* *
* @return array Array of Requirement instances * @return Requirement[]
*/ */
public function getRecommendations() public function getRecommendations()
{ {
@ -326,7 +329,7 @@ class RequirementCollection implements IteratorAggregate
/** /**
* Returns the recommendations that were not met. * Returns the recommendations that were not met.
* *
* @return array Array of Requirement instances * @return Requirement[]
*/ */
public function getFailedRecommendations() public function getFailedRecommendations()
{ {
@ -376,7 +379,8 @@ class RequirementCollection implements IteratorAggregate
*/ */
class SymfonyRequirements extends RequirementCollection class SymfonyRequirements extends RequirementCollection
{ {
const REQUIRED_PHP_VERSION = '5.3.3'; const LEGACY_REQUIRED_PHP_VERSION = '5.3.3';
const REQUIRED_PHP_VERSION = '5.5.9';
/** /**
* Constructor that initializes the requirements. * Constructor that initializes the requirements.
@ -386,15 +390,25 @@ class SymfonyRequirements extends RequirementCollection
/* mandatory requirements follow */ /* mandatory requirements follow */
$installedPhpVersion = phpversion(); $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( $this->addRequirement(
version_compare($installedPhpVersion, self::REQUIRED_PHP_VERSION, '>='), version_compare($installedPhpVersion, $requiredPhpVersion, '>='),
sprintf('PHP version must be at least %s (%s installed)', self::REQUIRED_PHP_VERSION, $installedPhpVersion), 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. 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.', Before using Symfony, upgrade your PHP installation, preferably to the latest version.',
$installedPhpVersion, self::REQUIRED_PHP_VERSION), $installedPhpVersion, $requiredPhpVersion),
sprintf('Install PHP %s or newer (installed version is %s)', self::REQUIRED_PHP_VERSION, $installedPhpVersion) sprintf('Install PHP %s or newer (installed version is %s)', $requiredPhpVersion, $installedPhpVersion)
); );
}
$this->addRequirement( $this->addRequirement(
version_compare($installedPhpVersion, '5.3.16', '!='), version_compare($installedPhpVersion, '5.3.16', '!='),
@ -425,13 +439,15 @@ class SymfonyRequirements extends RequirementCollection
'Change the permissions of either "<strong>app/logs/</strong>" or "<strong>var/logs/</strong>" directory so that the web server can write into it.' '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( $this->addPhpIniRequirement(
'date.timezone', true, false, 'date.timezone', true, false,
'date.timezone setting must be set', 'date.timezone setting must be set',
'Set the "<strong>date.timezone</strong>" setting in php.ini<a href="#phpini">*</a> (like Europe/Paris).' 'Set the "<strong>date.timezone</strong>" setting in php.ini<a href="#phpini">*</a> (like Europe/Paris).'
); );
}
if (version_compare($installedPhpVersion, self::REQUIRED_PHP_VERSION, '>=')) { if (false !== $requiredPhpVersion && version_compare($installedPhpVersion, $requiredPhpVersion, '>=')) {
$timezones = array(); $timezones = array();
foreach (DateTimeZone::listAbbreviations() as $abbreviations) { foreach (DateTimeZone::listAbbreviations() as $abbreviations) {
foreach ($abbreviations as $abbreviation) { foreach ($abbreviations as $abbreviation) {
@ -677,6 +693,21 @@ class SymfonyRequirements extends RequirementCollection
'Upgrade your <strong>intl</strong> extension with a newer ICU version (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( $this->addPhpIniRecommendation(
'intl.error_level', 'intl.error_level',
create_function('$cfgValue', 'return (int) $cfgValue === 0;'), create_function('$cfgValue', 'return (int) $cfgValue === 0;'),
@ -708,9 +739,9 @@ class SymfonyRequirements extends RequirementCollection
if (strtoupper(substr(PHP_OS, 0, 3)) === 'WIN') { if (strtoupper(substr(PHP_OS, 0, 3)) === 'WIN') {
$this->addRecommendation( $this->addRecommendation(
$this->getRealpathCacheSize() > 1000, $this->getRealpathCacheSize() >= 5 * 1024 * 1024,
'realpath_cache_size should be above 1024 in php.ini', 'realpath_cache_size should be at least 5M in php.ini',
'Set "<strong>realpath_cache_size</strong>" to e.g. "<strong>1024</strong>" in php.ini<a href="#phpini">*</a> to improve performance on windows.' '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.'
); );
} }
@ -761,4 +792,28 @@ class SymfonyRequirements extends RequirementCollection
return (int) $size; 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;
}
} }

View file

@ -12,7 +12,7 @@ echo '> PHP is using the following php.ini file:'.PHP_EOL;
if ($iniPath) { if ($iniPath) {
echo_style('green', ' '.$iniPath); echo_style('green', ' '.$iniPath);
} else { } else {
echo_style('warning', ' WARNING: No configuration file (php.ini) used by PHP!'); echo_style('yellow', ' WARNING: No configuration file (php.ini) used by PHP!');
} }
echo PHP_EOL.PHP_EOL; echo PHP_EOL.PHP_EOL;
@ -21,7 +21,6 @@ echo '> Checking Symfony requirements:'.PHP_EOL.' ';
$messages = array(); $messages = array();
foreach ($symfonyRequirements->getRequirements() as $req) { foreach ($symfonyRequirements->getRequirements() as $req) {
/** @var $req Requirement */
if ($helpText = get_error_message($req, $lineSize)) { if ($helpText = get_error_message($req, $lineSize)) {
echo_style('red', 'E'); echo_style('red', 'E');
$messages['error'][] = $helpText; $messages['error'][] = $helpText;
@ -120,10 +119,14 @@ function echo_block($style, $title, $message)
echo PHP_EOL.PHP_EOL; echo PHP_EOL.PHP_EOL;
echo_style($style, str_repeat(' ', $width).PHP_EOL); echo_style($style, str_repeat(' ', $width));
echo_style($style, str_pad(' ['.$title.']', $width, ' ', STR_PAD_RIGHT).PHP_EOL); echo PHP_EOL;
echo_style($style, str_pad($message, $width, ' ', STR_PAD_RIGHT).PHP_EOL); echo_style($style, str_pad(' ['.$title.']', $width, ' ', STR_PAD_RIGHT));
echo_style($style, str_repeat(' ', $width).PHP_EOL); echo PHP_EOL;
echo_style($style, $message);
echo PHP_EOL;
echo_style($style, str_repeat(' ', $width));
echo PHP_EOL;
} }
function has_color_support() function has_color_support()

View file

@ -33,19 +33,6 @@ twig:
- 'bootstrap_3_layout.html.twig' - 'bootstrap_3_layout.html.twig'
- 'SkobkinCopyPasteBundle:Form:fields.html.twig' - 'SkobkinCopyPasteBundle:Form:fields.html.twig'
# Assetic Configuration
assetic:
debug: "%kernel.debug%"
use_controller: false
bundles: [ ]
#java: /usr/bin/java
filters:
cssrewrite: ~
#closure:
# jar: "%kernel.root_dir%/Resources/java/compiler.jar"
#yui_css:
# jar: "%kernel.root_dir%/Resources/java/yuicompressor-2.4.7.jar"
# Doctrine Configuration # Doctrine Configuration
doctrine: doctrine:
dbal: dbal:
@ -68,7 +55,7 @@ doctrine:
auto_mapping: true auto_mapping: true
doctrine_migrations: doctrine_migrations:
dir_name: %kernel.root_dir%/DoctrineMigrations dir_name: "%kernel.root_dir%/DoctrineMigrations"
namespace: Application\Migrations namespace: Application\Migrations
table_name: migration_versions table_name: migration_versions
name: Application Migrations name: Application Migrations

View file

@ -41,8 +41,5 @@ monolog:
# type: chromephp # type: chromephp
# level: info # level: info
assetic:
use_controller: true
#swiftmailer: #swiftmailer:
# delivery_address: me@example.com # delivery_address: me@example.com

View file

@ -6,10 +6,6 @@ _profiler:
resource: "@WebProfilerBundle/Resources/config/routing/profiler.xml" resource: "@WebProfilerBundle/Resources/config/routing/profiler.xml"
prefix: /_profiler prefix: /_profiler
_configurator:
resource: "@SensioDistributionBundle/Resources/config/routing/webconfigurator.xml"
prefix: /_configurator
_errors: _errors:
resource: "@TwigBundle/Resources/config/routing/errors.xml" resource: "@TwigBundle/Resources/config/routing/errors.xml"
prefix: /_error prefix: /_error

View file

@ -7,7 +7,9 @@ umask(0002);
set_time_limit(0); set_time_limit(0);
require_once __DIR__.'/bootstrap.php.cache'; //require_once __DIR__.'/bootstrap.php.cache';
$loader = require_once __DIR__.'/../app/autoload.php';
require_once __DIR__.'/AppKernel.php'; require_once __DIR__.'/AppKernel.php';
use Symfony\Bundle\FrameworkBundle\Console\Application; use Symfony\Bundle\FrameworkBundle\Console\Application;

View file

@ -1,54 +1,49 @@
{ {
"name": "symfony/framework-standard-edition", "name": "skobkin/copypaste",
"license": "MIT", "license": "MIT",
"type": "project", "type": "project",
"description": "The \"Symfony Standard Edition\" distribution", "description": "Online code sharing app",
"autoload": { "autoload": {
"psr-0": { "": "src/", "SymfonyStandard": "app/" } "psr-4": { "": "src/" },
"classmap": [ "app/AppKernel.php", "app/AppCache.php" ]
}, },
"minimum-stability": "dev",
"require": { "require": {
"php": ">=5.3.3", "php": ">=5.5.9",
"symfony/symfony": "2.8.*", "symfony/symfony": "3.2.*",
"doctrine/orm": "~2.2,>=2.2.3,<2.5", "doctrine/orm": "^2.5",
"doctrine/dbal": "<2.5", "doctrine/doctrine-bundle": "^1.4",
"doctrine/doctrine-bundle": "~1.4", "symfony/swiftmailer-bundle": "^2.3",
"twig/extensions": "~1.0", "symfony/monolog-bundle": "~2.11.3",
"symfony/assetic-bundle": "~2.3", "symfony/polyfill-apcu": "^1.0",
"symfony/swiftmailer-bundle": "~2.3", "sensio/distribution-bundle": "^5.0",
"symfony/monolog-bundle": "~2.4", "sensio/framework-extra-bundle": "^3.0.2",
"sensio/distribution-bundle": "~3.0,>=3.0.12",
"sensio/framework-extra-bundle": "~3.0,>=3.0.2",
"incenteev/composer-parameter-handler": "~2.0", "incenteev/composer-parameter-handler": "~2.0",
"doctrine/doctrine-fixtures-bundle": "2.2.*", "doctrine/doctrine-fixtures-bundle": "^2.2",
"theodordiaconu/geshi": "dev-master", "theodordiaconu/geshi": "dev-master",
"theodordiaconu/geshi-bundle" : "dev-master", "theodordiaconu/geshi-bundle" : "dev-master",
"doctrine/doctrine-migrations-bundle": "^1.0" "doctrine/doctrine-migrations-bundle": "^1.0",
"doctrine/annotations": "^1.3"
}, },
"require-dev": { "require-dev": {
"sensio/generator-bundle": "~2.3", "sensio/generator-bundle": "^3.0",
"symfony/phpunit-bridge": "^3.0",
"phpunit/phpunit": "^5.7" "phpunit/phpunit": "^5.7"
}, },
"scripts": { "scripts": {
"post-root-package-install": [ "symfony-scripts": [
"SymfonyStandard\\Composer::hookRootPackageInstall" "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-install-cmd": [ "post-install-cmd": [
"Incenteev\\ParameterHandler\\ScriptHandler::buildParameters", "@symfony-scripts"
"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::removeSymfonyStandardFiles",
"Sensio\\Bundle\\DistributionBundle\\Composer\\ScriptHandler::prepareDeploymentTarget"
], ],
"post-update-cmd": [ "post-update-cmd": [
"Incenteev\\ParameterHandler\\ScriptHandler::buildParameters", "@symfony-scripts"
"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::removeSymfonyStandardFiles",
"Sensio\\Bundle\\DistributionBundle\\Composer\\ScriptHandler::prepareDeploymentTarget"
] ]
}, },
"config": { "config": {
@ -62,7 +57,7 @@
"file": "app/config/parameters.yml" "file": "app/config/parameters.yml"
}, },
"branch-alias": { "branch-alias": {
"dev-master": "2.7-dev" "dev-master": "3.1-dev"
} }
} }
} }

1199
composer.lock generated

File diff suppressed because it is too large Load diff

View file

@ -30,6 +30,8 @@ class DropExpiredCopypastesCommand extends ContainerAwareCommand
/* @var $em EntityManager */ /* @var $em EntityManager */
$em = $this->getContainer()->get('doctrine')->getManager(); $em = $this->getContainer()->get('doctrine')->getManager();
// @todo move to repository
$queryBuilder = $em->createQueryBuilder() $queryBuilder = $em->createQueryBuilder()
->delete('SkobkinCopyPasteBundle:Copypaste c') ->delete('SkobkinCopyPasteBundle:Copypaste c')
->where('c.dateExpire < :now') ->where('c.dateExpire < :now')

View file

@ -30,7 +30,7 @@ class CopypasteController extends Controller
$form = $this->createCreateForm($paste); $form = $this->createCreateForm($paste);
$form->handleRequest($request); $form->handleRequest($request);
if ($form->isValid()) { if ($form->isSubmitted() && $form->isValid()) {
// Check "captcha" // Check "captcha"
// @todo check internally in transformation or somewhere else // @todo check internally in transformation or somewhere else
if (null === $form->get('captcha')->getData()) { if (null === $form->get('captcha')->getData()) {

View file

@ -39,7 +39,6 @@ class CopypasteType extends AbstractType
->add('expire', ChoiceType::class, [ ->add('expire', ChoiceType::class, [
'label' => 'paste_add_form_expire', 'label' => 'paste_add_form_expire',
'mapped' => false, 'mapped' => false,
'choices_as_values' => true,
// @todo move to config // @todo move to config
'choices' => [ 'choices' => [
'5 minutes'=> 300, '5 minutes'=> 300,

View file

@ -1,29 +1,28 @@
<?php <?php
use Symfony\Component\HttpFoundation\Request; use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\Debug\Debug; use Symfony\Component\Debug\Debug;
// If you don't want to setup permissions the proper way, just uncomment the following PHP line // 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 // read http://symfony.com/doc/current/book/installation.html#checking-symfony-application-configuration-and-setup
// for more information
umask(0002); umask(0002);
// This check prevents access to debug front controllers that are deployed by accident to production servers. // 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. // Feel free to remove this, extend it, or make something more sophisticated.
if (isset($_SERVER['HTTP_CLIENT_IP']) if (isset($_SERVER['HTTP_CLIENT_IP'])
|| isset($_SERVER['HTTP_X_FORWARDED_FOR']) || isset($_SERVER['HTTP_X_FORWARDED_FOR'])
|| !(in_array(@$_SERVER['REMOTE_ADDR'], ['127.0.0.1', 'fe80::1', '::1', '192.168.1.2']) || php_sapi_name() === 'cli-server') || !(in_array(@$_SERVER['REMOTE_ADDR'], ['127.0.0.1', 'fe80::1', '::1']) || php_sapi_name() === 'cli-server')
) { ) {
header('HTTP/1.0 403 Forbidden'); header('HTTP/1.0 403 Forbidden');
exit('You are not allowed to access this file. Check '.basename(__FILE__).' for more information.'); exit('You are not allowed to access this file. Check '.basename(__FILE__).' for more information.');
} }
/**
$loader = require_once __DIR__.'/../app/bootstrap.php.cache'; * @var Composer\Autoload\ClassLoader $loader
Debug::enable(); */
//$loader = require __DIR__.'/../app/autoload.php';
$loader = require_once __DIR__.'/../app/autoload.php';
require_once __DIR__.'/../app/AppKernel.php'; require_once __DIR__.'/../app/AppKernel.php';
Debug::enable();
$kernel = new AppKernel('dev', true); $kernel = new AppKernel('dev', true);
$kernel->loadClassCache(); //$kernel->loadClassCache();
$request = Request::createFromGlobals(); $request = Request::createFromGlobals();
$response = $kernel->handle($request); $response = $kernel->handle($request);
$response->send(); $response->send();

View file

@ -1,5 +1,15 @@
<?php <?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'])) { if (!isset($_SERVER['HTTP_HOST'])) {
exit('This script cannot be run from the CLI. Run it from a browser.'); exit('This script cannot be run from the CLI. Run it from a browser.');
} }
@ -18,6 +28,8 @@ $symfonyRequirements = new SymfonyRequirements();
$majorProblems = $symfonyRequirements->getFailedRequirements(); $majorProblems = $symfonyRequirements->getFailedRequirements();
$minorProblems = $symfonyRequirements->getFailedRecommendations(); $minorProblems = $symfonyRequirements->getFailedRecommendations();
$hasMajorProblems = (bool) count($majorProblems);
$hasMinorProblems = (bool) count($minorProblems);
?> ?>
<!DOCTYPE html> <!DOCTYPE html>
@ -25,16 +37,303 @@ $minorProblems = $symfonyRequirements->getFailedRecommendations();
<head> <head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
<meta name="robots" content="noindex,nofollow" /> <meta name="robots" content="noindex,nofollow" />
<title>Symfony Configuration</title> <title>Symfony Configuration Checker</title>
<link rel="stylesheet" href="bundles/framework/css/structure.css" media="all" /> <style>
<link rel="stylesheet" href="bundles/framework/css/body.css" media="all" /> /* styles copied from symfony framework bundle */
<link rel="stylesheet" href="bundles/sensiodistribution/webconfigurator/css/install.css" media="all" /> 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(../images/blue-arrow.png) no-repeat right 6px;
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> </head>
<body> <body>
<div id="content"> <div id="content">
<div class="header clear-fix"> <div class="header clear-fix">
<div class="header-logo"> <div class="header-logo">
<img src="bundles/framework/images/logo_symfony.png" alt="Symfony" /> <img src="" alt="Symfony" />
</div> </div>
<div class="search"> <div class="search">
@ -42,7 +341,7 @@ $minorProblems = $symfonyRequirements->getFailedRecommendations();
<div class="form-row"> <div class="form-row">
<label for="search-id"> <label for="search-id">
<img src="bundles/framework/images/grey_magnifier.png" alt="Search on Symfony website" /> <img src="" alt="Search on Symfony website" />
</label> </label>
<input name="q" id="search-id" type="search" placeholder="Search on Symfony website" /> <input name="q" id="search-id" type="search" placeholder="Search on Symfony website" />
@ -62,32 +361,35 @@ $minorProblems = $symfonyRequirements->getFailedRecommendations();
<div class="sf-reset"> <div class="sf-reset">
<div class="block"> <div class="block">
<div class="symfony-block-content"> <div class="symfony-block-content">
<h1 class="title">Welcome!</h1> <h1 class="title">Configuration Checker</h1>
<p>Welcome to your new Symfony project.</p>
<p> <p>
This script will guide you through the basic configuration of your project. This script analyzes your system to check whether is
You can also do the same by editing the <strong>app/config/parameters.yml</strong> file directly. ready to run Symfony applications.
</p> </p>
<?php if (count($majorProblems)): ?> <?php if ($hasMajorProblems): ?>
<h2 class="ko">Major problems</h2> <h2 class="ko">Major problems</h2>
<p>Major problems have been detected and <strong>must</strong> be fixed before continuing:</p> <p>Major problems have been detected and <strong>must</strong> be fixed before continuing:</p>
<ol> <ol>
<?php foreach ($majorProblems as $problem): ?> <?php foreach ($majorProblems as $problem): ?>
<li><?php echo $problem->getHelpHtml() ?></li> <li><?php echo $problem->getTestMessage() ?>
<p class="help"><em><?php echo $problem->getHelpHtml() ?></em></p>
</li>
<?php endforeach; ?> <?php endforeach; ?>
</ol> </ol>
<?php endif; ?> <?php endif; ?>
<?php if (count($minorProblems)): ?> <?php if ($hasMinorProblems): ?>
<h2>Recommendations</h2> <h2>Recommendations</h2>
<p> <p>
<?php if (count($majorProblems)): ?>Additionally, to<?php else: ?>To<?php endif; ?> enhance your Symfony experience, <?php if ($hasMajorProblems): ?>Additionally, to<?php else: ?>To<?php endif; ?> enhance your Symfony experience,
its recommended that you fix the following: its recommended that you fix the following:
</p> </p>
<ol> <ol>
<?php foreach ($minorProblems as $problem): ?> <?php foreach ($minorProblems as $problem): ?>
<li><?php echo $problem->getHelpHtml() ?></li> <li><?php echo $problem->getTestMessage() ?>
<p class="help"><em><?php echo $problem->getHelpHtml() ?></em></p>
</li>
<?php endforeach; ?> <?php endforeach; ?>
</ol> </ol>
<?php endif; ?> <?php endif; ?>
@ -102,16 +404,12 @@ $minorProblems = $symfonyRequirements->getFailedRecommendations();
</p> </p>
<?php endif; ?> <?php endif; ?>
<?php if (!count($majorProblems) && !count($minorProblems)): ?> <?php if (!$hasMajorProblems && !$hasMinorProblems): ?>
<p class="ok">Your configuration looks good to run Symfony.</p> <p class="ok">All checks passed successfully. Your system is ready to run Symfony applications.</p>
<?php endif; ?> <?php endif; ?>
<ul class="symfony-install-continue"> <ul class="symfony-install-continue">
<?php if (!count($majorProblems)): ?> <?php if ($hasMajorProblems || $hasMinorProblems): ?>
<li><a href="app_dev.php/_configurator/">Configure your Symfony Application online</a></li>
<li><a href="app_dev.php/">Bypass configuration and go to the Welcome page</a></li>
<?php endif; ?>
<?php if (count($majorProblems) || count($minorProblems)): ?>
<li><a href="config.php">Re-check configuration</a></li> <li><a href="config.php">Re-check configuration</a></li>
<?php endif; ?> <?php endif; ?>
</ul> </ul>