Skip to content

Commit

Permalink
Merge branch '2.4' into 2.5
Browse files Browse the repository at this point in the history
* 2.4:
  Clarify that route defaults don't need a placeholder
  • Loading branch information
weaverryan committed Sep 22, 2014
2 parents f42a300 + ba293dd commit 84aaa10
Show file tree
Hide file tree
Showing 4 changed files with 69 additions and 0 deletions.
4 changes: 4 additions & 0 deletions book/routing.rst
Original file line number Diff line number Diff line change
Expand Up @@ -1032,6 +1032,10 @@ see :ref:`route-parameters-controller-arguments`.
You can also use a special ``$_route`` variable, which is set to the
name of the route that was matched.

You can even add extra information to your route definition and access it
within your controller. For more information on this topic,
see :doc:`/cookbook/routing/extra_information`.

.. index::
single: Routing; Importing routing resources

Expand Down
1 change: 1 addition & 0 deletions cookbook/map.rst.inc
Original file line number Diff line number Diff line change
Expand Up @@ -134,6 +134,7 @@
* :doc:`/cookbook/routing/service_container_parameters`
* :doc:`/cookbook/routing/custom_route_loader`
* :doc:`/cookbook/routing/redirect_trailing_slash`
* :doc:`/cookbook/routing/extra_information`

* :doc:`/cookbook/security/index`

Expand Down
63 changes: 63 additions & 0 deletions cookbook/routing/extra_information.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,63 @@
.. index::
single: Routing; Extra Information

How to Pass Extra Information from a Route to a Controller
==========================================================

Parameters inside the ``defaults`` collection don't necessarily have to
match a placeholder in the route ``path``. In fact, you can use the
``defaults`` array to specify extra parameters that will then be accessible as
arguments to your controller:

.. configuration-block::

.. code-block:: yaml
# app/config/routing.yml
blog:
path: /blog/{page}
defaults:
_controller: AcmeBlogBundle:Blog:index
page: 1
title: "Hello world!"
.. code-block:: xml
<!-- app/config/routing.xml -->
<?xml version="1.0" encoding="UTF-8" ?>
<routes xmlns="http://symfony.com/schema/routing"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://symfony.com/schema/routing
http://symfony.com/schema/routing/routing-1.0.xsd">
<route id="blog" path="/blog/{page}">
<default key="_controller">AcmeBlogBundle:Blog:index</default>
<default key="page">1</default>
<default key="title">Hello world!</default>
</route>
</routes>
.. code-block:: php
// app/config/routing.php
use Symfony\Component\Routing\RouteCollection;
use Symfony\Component\Routing\Route;
$collection = new RouteCollection();
$collection->add('blog', new Route('/blog/{page}', array(
'_controller' => 'AcmeBlogBundle:Blog:index',
'page' => 1,
'title' => 'Hello world!',
)));
return $collection;
Now, you can access this extra parameter in your controller::

public function indexAction($page, $title)
{
// ...
}

As you can see, the ``$title`` variable was never defined inside the route path,
but you can still access its value from inside your controller.
1 change: 1 addition & 0 deletions cookbook/routing/index.rst
Original file line number Diff line number Diff line change
Expand Up @@ -11,3 +11,4 @@ Routing
service_container_parameters
custom_route_loader
redirect_trailing_slash
extra_information

0 comments on commit 84aaa10

Please sign in to comment.