From dd47e1d761357bb945ca03bac11840ea2b5e2e8e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jes=C3=BAs=20Miguel=20Benito=20Calzada?= Date: Mon, 16 Feb 2015 10:14:17 +0100 Subject: [PATCH 1/7] Fixed semantic error --- cookbook/bundles/extension.rst | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/cookbook/bundles/extension.rst b/cookbook/bundles/extension.rst index aa2c5be8a35..78092a3f3fd 100644 --- a/cookbook/bundles/extension.rst +++ b/cookbook/bundles/extension.rst @@ -70,7 +70,7 @@ should also override :method:`Extension::getAlias() ` to return the correct DI alias. The DI alias is the name used to refer to the bundle in the container (e.g. in the ``app/config/config.yml`` file). By -default, this is done by removing the ``Extension`` prefix and converting the +default, this is done by removing the ``Extension`` suffix and converting the class name to underscores (e.g. ``AcmeHelloExtension``'s DI alias is ``acme_hello``). From 9488a85a2599fdfe99b3c88cd272e9cf84006868 Mon Sep 17 00:00:00 2001 From: Javier Eguiluz Date: Tue, 17 Feb 2015 12:13:45 +0100 Subject: [PATCH 2/7] Updated the contents of the generic Deployment article --- cookbook/deployment/tools.rst | 118 +++++++++++++++------------------- 1 file changed, 53 insertions(+), 65 deletions(-) diff --git a/cookbook/deployment/tools.rst b/cookbook/deployment/tools.rst index 4004c06aeb8..180d74efe8a 100644 --- a/cookbook/deployment/tools.rst +++ b/cookbook/deployment/tools.rst @@ -8,9 +8,9 @@ How to Deploy a Symfony Application .. note:: - Deploying can be a complex and varied task depending on your setup and needs. - This entry doesn't try to explain everything, but rather offers the most - common requirements and ideas for deployment. + Deploying can be a complex and varied task depending on the setup and + requirements of your application. This article is not a step-by-step guide, + but a general list of the most common requirements and ideas for deployment. .. _symfony2-deployment-basics: @@ -19,26 +19,27 @@ Symfony Deployment Basics The typical steps taken while deploying a Symfony application include: -#. Upload your modified code to the live server; -#. Update your vendor dependencies (typically done via Composer, and may +#. Upload your code to the production server; +#. Install/update your vendor dependencies (typically done via Composer, and may be done before uploading); #. Running database migrations or similar tasks to update any changed data structures; -#. Clearing (and perhaps more importantly, warming up) your cache. +#. Clearing (and optionally, warming up) your cache. -A deployment may also include other things, such as: +A deployment may also include other tasks, such as: -* Tagging a particular version of your code as a release in your source control repository; +* Tagging a particular version of your code as a release in your source control + repository; * Creating a temporary staging area to build your updated setup "offline"; * Running any tests available to ensure code and/or server stability; -* Removal of any unnecessary files from ``web`` to keep your production environment clean; +* Removal of any unnecessary files from ``web/`` directory to keep your production + environment clean; * Clearing of external cache systems (like `Memcached`_ or `Redis`_). How to Deploy a Symfony Application ----------------------------------- -There are several ways you can deploy a Symfony application. - -Start with a few basic deployment strategies and build up from there. +There are several ways you can deploy a Symfony application. Start with a few +basic deployment strategies and build up from there. Basic File Transfer ~~~~~~~~~~~~~~~~~~~ @@ -62,12 +63,35 @@ manually taking other steps (see `Common Post-Deployment Tasks`_). Using Build Scripts and other Tools ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ -There are also high-quality tools to help ease the pain of deployment. There -are even a few tools which have been specifically tailored to the requirements of -Symfony, and which take special care to ensure that everything before, during, -and after a deployment has gone correctly. +There are also tools to help ease the pain of deployment. Some of them have been +specifically tailored to the requirements of Symfony. + +`Capifony`_ + Provides a specialized set of tools on top of `Capistrano`_, tailored + specifically to Symfony projects. + +`sf2debpkg`_ + Helps you build a native Debian package for your Symfony project. + +`Magallanes`_ + This Capistrano-like deployment tool is built in PHP, and may be easier + for PHP developers to extend for their needs. -See `The Tools`_ for a list of tools that can help with deployment. +Bundles + There are some `bundles that add deployment features`_ directly into your + Symfony console. + +Basic scripting + You can of course use shell, `Ant`_, or any other build tool to script + the deploying of your project. + +Platform as a Service Providers + The Symfony Cookbook includes detailed articles for some of the most well-known + Platform as a Service (PaaS) providers: + + * :doc:`` + * :doc:`` + * :doc:`` Common Post-Deployment Tasks ---------------------------- @@ -87,12 +111,11 @@ Check if your server meets the requirements by running: B) Configure your ``app/config/parameters.yml`` File ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ -This file should be customized on each system. The method you use to -deploy your source code should *not* deploy this file. Instead, you should -set it up manually (or via some build process) on your server(s). +This file should *not* be deployed, but managed through the automatic utilities +provided by Symfony. -C) Update your Vendors -~~~~~~~~~~~~~~~~~~~~~~ +C) Install/Update your Vendors +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ Your vendors can be updated before transferring your source code (i.e. update the ``vendor/`` directory, then transfer that with your source @@ -105,10 +128,9 @@ as you normally do: .. tip:: - The ``--optimize-autoloader`` flag makes Composer's autoloader more - performant by building a "class map". The ``--no-dev`` flag - ensures that development packages are not installed in the production - environment. + The ``--optimize-autoloader`` flag improves Composer's autoloader performance + significantly by building a "class map". The ``--no-dev`` flag ensures that + development packages are not installed in the production environment. .. caution:: @@ -152,7 +174,7 @@ Application Lifecycle: Continuous Integration, QA, etc While this entry covers the technical details of deploying, the full lifecycle of taking code from development up to production may have a lot more steps -(think deploying to staging, QA, running tests, etc). +(think deploying to staging, QA (Quality Assurance), running tests, etc). The use of staging, testing, QA, continuous integration, database migrations and the capability to roll back in case of failure are all strongly advised. There @@ -163,51 +185,17 @@ Don't forget that deploying your application also involves updating any dependen (typically via Composer), migrating your database, clearing your cache and other potential things like pushing assets to a CDN (see `Common Post-Deployment Tasks`_). -The Tools ---------- - -`Capifony`_: - - This tool provides a specialized set of tools on top of Capistrano, tailored - specifically to symfony and Symfony projects. - -`sf2debpkg`_: - - This tool helps you build a native Debian package for your Symfony project. - -`Magallanes`_: - - This Capistrano-like deployment tool is built in PHP, and may be easier - for PHP developers to extend for their needs. - -Bundles: - - There are many `bundles that add deployment features`_ directly into your - Symfony console. - -Basic scripting: - - You can of course use shell, `Ant`_, or any other build tool to script - the deploying of your project. - -Platform as a Service Providers: - - PaaS is a relatively new way to deploy your application. Typically a PaaS - will use a single configuration file in your project's root directory to - determine how to build an environment on the fly that supports your software. - One provider with confirmed Symfony support is `PagodaBox`_. - .. tip:: - Looking for more? Talk to the community on the `Symfony IRC channel`_ #symfony - (on freenode) for more information. + Looking for more? Talk to the community on the `Symfony IRC channel`_ for + more information. .. _`Capifony`: http://capifony.org/ +.. _`Capistrano`: http://capistranorb.com/ .. _`sf2debpkg`: https://github.com/liip/sf2debpkg .. _`Ant`: http://blog.sznapka.pl/deploying-symfony2-applications-with-ant -.. _`PagodaBox`: https://github.com/jmather/pagoda-symfony-sonata-distribution/blob/master/Boxfile .. _`Magallanes`: https://github.com/andres-montanez/Magallanes .. _`bundles that add deployment features`: http://knpbundles.com/search?q=deploy -.. _`Symfony IRC channel`: http://webchat.freenode.net/?channels=symfony +.. _`Symfony IRC channel`: http://symfony.com/irc .. _`Memcached`: http://memcached.org/ .. _`Redis`: http://redis.io/ From 576d5054f300fe993ac77430a3c16a9da5919552 Mon Sep 17 00:00:00 2001 From: Javier Eguiluz Date: Tue, 17 Feb 2015 12:40:36 +0100 Subject: [PATCH 3/7] Improved the text of the links --- cookbook/deployment/tools.rst | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/cookbook/deployment/tools.rst b/cookbook/deployment/tools.rst index 180d74efe8a..eda79163ad6 100644 --- a/cookbook/deployment/tools.rst +++ b/cookbook/deployment/tools.rst @@ -89,9 +89,9 @@ Platform as a Service Providers The Symfony Cookbook includes detailed articles for some of the most well-known Platform as a Service (PaaS) providers: - * :doc:`` - * :doc:`` - * :doc:`` + * :doc:`Microsoft Azure ` + * :doc:`Heroku ` + * :doc:`Platform.sh ` Common Post-Deployment Tasks ---------------------------- From 58526f7ce23cd1240450018471f95bc391756104 Mon Sep 17 00:00:00 2001 From: Javier Eguiluz Date: Tue, 17 Feb 2015 17:27:36 +0100 Subject: [PATCH 4/7] Fixed grammar issues --- cookbook/deployment/tools.rst | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/cookbook/deployment/tools.rst b/cookbook/deployment/tools.rst index eda79163ad6..2c04be68476 100644 --- a/cookbook/deployment/tools.rst +++ b/cookbook/deployment/tools.rst @@ -8,9 +8,9 @@ How to Deploy a Symfony Application .. note:: - Deploying can be a complex and varied task depending on the setup and + Deploying can be a complex and varied task depending on the setup and the requirements of your application. This article is not a step-by-step guide, - but a general list of the most common requirements and ideas for deployment. + but is a general list of the most common requirements and ideas for deployment. .. _symfony2-deployment-basics: @@ -31,8 +31,8 @@ A deployment may also include other tasks, such as: repository; * Creating a temporary staging area to build your updated setup "offline"; * Running any tests available to ensure code and/or server stability; -* Removal of any unnecessary files from ``web/`` directory to keep your production - environment clean; +* Removal of any unnecessary files from the ``web/`` directory to keep your + production environment clean; * Clearing of external cache systems (like `Memcached`_ or `Redis`_). How to Deploy a Symfony Application From c9caef60518d6ec104c37186464d2fbc9ec19696 Mon Sep 17 00:00:00 2001 From: Xavier Coureau Date: Mon, 16 Feb 2015 11:39:39 +0100 Subject: [PATCH 5/7] Fixed case where definition service is an alias Added exception catch Changed methods used Revert --- components/dependency_injection/tags.rst | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/components/dependency_injection/tags.rst b/components/dependency_injection/tags.rst index b8442c3b933..3bb349517f2 100644 --- a/components/dependency_injection/tags.rst +++ b/components/dependency_injection/tags.rst @@ -133,11 +133,11 @@ custom tag:: { public function process(ContainerBuilder $container) { - if (!$container->hasDefinition('acme_mailer.transport_chain')) { + if (!$container->has('acme_mailer.transport_chain')) { return; } - $definition = $container->getDefinition( + $definition = $container->findDefinition( 'acme_mailer.transport_chain' ); From 9e0194164b14ae22146d312183989f17d1a0df44 Mon Sep 17 00:00:00 2001 From: Javier Eguiluz Date: Wed, 18 Feb 2015 22:25:31 +0100 Subject: [PATCH 6/7] Minor fixes and added Fabric tool --- cookbook/deployment/tools.rst | 23 +++++++++++------------ 1 file changed, 11 insertions(+), 12 deletions(-) diff --git a/cookbook/deployment/tools.rst b/cookbook/deployment/tools.rst index 2c04be68476..322154ba9f2 100644 --- a/cookbook/deployment/tools.rst +++ b/cookbook/deployment/tools.rst @@ -20,8 +20,8 @@ Symfony Deployment Basics The typical steps taken while deploying a Symfony application include: #. Upload your code to the production server; -#. Install/update your vendor dependencies (typically done via Composer, and may - be done before uploading); +#. Install your vendor dependencies (typically done via Composer and may be done + before uploading); #. Running database migrations or similar tasks to update any changed data structures; #. Clearing (and optionally, warming up) your cache. @@ -67,8 +67,8 @@ There are also tools to help ease the pain of deployment. Some of them have been specifically tailored to the requirements of Symfony. `Capifony`_ - Provides a specialized set of tools on top of `Capistrano`_, tailored - specifically to Symfony projects. + This Ruby-based tool provides a specialized set of tools on top of + `Capistrano`_, tailored specifically to Symfony projects. `sf2debpkg`_ Helps you build a native Debian package for your Symfony project. @@ -77,12 +77,16 @@ specifically tailored to the requirements of Symfony. This Capistrano-like deployment tool is built in PHP, and may be easier for PHP developers to extend for their needs. +`Fabric`_ + This Python-based library provides a basic suite of operations for executing + local or remote shell commands and uploading/downloading files. + Bundles There are some `bundles that add deployment features`_ directly into your Symfony console. Basic scripting - You can of course use shell, `Ant`_, or any other build tool to script + You can of course use shell, `Ant`_ or any other build tool to script the deploying of your project. Platform as a Service Providers @@ -185,17 +189,12 @@ Don't forget that deploying your application also involves updating any dependen (typically via Composer), migrating your database, clearing your cache and other potential things like pushing assets to a CDN (see `Common Post-Deployment Tasks`_). -.. tip:: - - Looking for more? Talk to the community on the `Symfony IRC channel`_ for - more information. - .. _`Capifony`: http://capifony.org/ .. _`Capistrano`: http://capistranorb.com/ .. _`sf2debpkg`: https://github.com/liip/sf2debpkg -.. _`Ant`: http://blog.sznapka.pl/deploying-symfony2-applications-with-ant +.. _`Fabric`: http://www.fabfile.org/ .. _`Magallanes`: https://github.com/andres-montanez/Magallanes +.. _`Ant`: http://blog.sznapka.pl/deploying-symfony2-applications-with-ant .. _`bundles that add deployment features`: http://knpbundles.com/search?q=deploy -.. _`Symfony IRC channel`: http://symfony.com/irc .. _`Memcached`: http://memcached.org/ .. _`Redis`: http://redis.io/ From f3cff0bcc35a7709542ea046b9fceeedb5d31e63 Mon Sep 17 00:00:00 2001 From: WouterJ Date: Sun, 1 Mar 2015 16:14:03 +0100 Subject: [PATCH 7/7] Added February changelog --- changelog.rst | 43 +++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 43 insertions(+) diff --git a/changelog.rst b/changelog.rst index 51d1ba644ba..664073e5008 100644 --- a/changelog.rst +++ b/changelog.rst @@ -13,6 +13,49 @@ documentation. Do you also want to participate in the Symfony Documentation? Take a look at the ":doc:`/contributing/documentation/overview`" article. +February, 2015 +-------------- + +New Documentation +~~~~~~~~~~~~~~~~~ + +- `a25da10 `_ #4966 [#4231] Clarify that only the main command triggers events (riperez) +- `9cce63c `_ #4924 [swiftmailer] Document whitelist option to email redirect (TerjeBr) +- `f5ff45e `_ #4712 Provide full test example (ifdattic) +- `5e83045 `_ #4657 Update assetic watch command (xtreamwayz) +- `d447b12 `_ #4556 Updated twig reference with optimizations and paths (jzawadzki) +- `018cf3f `_ #4661 Added a short cookbook about avoiding the automatic start of the sessions (javiereguiluz) +- `2305066 `_ #4902 Removed the Stable API chapter from the Symfony book (javiereguiluz) + +Fixed Documentation +~~~~~~~~~~~~~~~~~~~ + +- `b0d9c5c `_ #4978 fix wrong header-line syntax (sstok) +- `6d65564 `_ #4954 Fixed some syntax issues in Twig Reference (javiereguiluz) + +Minor Documentation Changes +~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +- `f75bc2b `_ #4972 Fix typos (ifdattic) +- `9fab10b `_ #4854 Removed no longer needed information about PHP 5.3 (WouterJ) +- `1726054 `_ #4500 Link to standard edition (harikt) +- `91ff6f8 `_ #4329 ensure consistency with the note (greg0ire) +- `e5dbd49 `_ #4977 Unnecessary comma (edsonmedina) +- `5d44987 `_ #4991 Fixed typo and tweaked syntax. (cdvrooman) +- `3845c9c `_ #4979 require_once path fixed (mvanmeerbeck) +- `96770aa `_ #4969 Add typehint (piotrantosik) +- `f97d01f `_ #4995 [#4965] file extension fix (hansstevens) +- `c5647dd `_ #4968 Fix typo (ifdattic) +- `c3218fc `_ #4962 cookbok/security/acl.rst (DaliusK) +- `72489a4 `_ #4963 Normalize excluded_404s in monolog cookbook (jbafford) +- `0adb6f6 `_ #4964 link to the cookbook article on avoiding to start a session (dbu) +- `5d8456f `_ #4955 Fixed wrong API link (dosten) +- `0a85053 `_ #4950 Fixes for 2.3 branch (ifdattic) +- `d3d96e1 `_ #4951 fix characters in backported patch (xabbuh) +- `208904a `_ #4949 Fixes for 2.3 branch (ifdattic) +- `42b44c4 `_ #4929 Remove block which doesn't make sense after best practices (ifdattic) +- `6f8b145 `_ #4904 Added a reference about including JS and CSS files in PHP templates (javiereguiluz) + January, 2015 -------------