Skip to content

Commit

Permalink
Merge branch '2.6' into 2.7
Browse files Browse the repository at this point in the history
  • Loading branch information
wouterj committed Apr 2, 2015
2 parents c4a5661 + 644aae8 commit c2b5a6a
Show file tree
Hide file tree
Showing 16 changed files with 78 additions and 56 deletions.
41 changes: 25 additions & 16 deletions book/security.rst
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,8 @@ sections:
#. Fetching the current User object.

These are followed by a number of small (but still captivating) sections,
like :ref:`logging out <book-security-logging-out>` and :ref:`encoding user passwords <security-encoding-password>`.
like :ref:`logging out <book-security-logging-out>` and
:ref:`encoding user passwords <security-encoding-password>`.

.. _book-security-firewalls:

Expand Down Expand Up @@ -362,6 +363,11 @@ probably only need one. If you *do* have multiple, you can configure which
*one* provider to use for your firewall under its ``provider`` key (e.g.
``provider: in_memory``).

.. seealso::

See :doc:`/cookbook/security/multiple_user_providers` for
all the details about multiple providers setup.

Try to login using username ``admin`` and password ``kitten``. You should
see an error!

Expand Down Expand Up @@ -666,11 +672,11 @@ Add Code to Deny Access

There are **two** ways to deny access to something:

1) :ref:`access_control in security.yml <security-authorization-access-control>`
#. :ref:`access_control in security.yml <security-authorization-access-control>`
allows you to protect URL patterns (e.g. ``/admin/*``). This is easy,
but less flexible;

2) :ref:`in your code via the security.authorization_checker service <book-security-securing-controller>`.
#. :ref:`in your code via the security.authorization_checker service <book-security-securing-controller>`.

.. _security-authorization-access-control:

Expand Down Expand Up @@ -838,8 +844,10 @@ In both cases, a special
is thrown, which ultimately triggers a 403 HTTP response inside Symfony.

That's it! If the user isn't logged in yet, they will be asked to login (e.g.
redirected to the login page). If they *are* logged in, they'll be shown
the 403 access denied page (which you can :ref:`customize <cookbook-error-pages-by-status-code>`).
redirected to the login page). If they *are* logged in, but do *not* have the
``ROLE_ADMIN`` role, they'll be shown the 403 access denied page (which you can
:ref:`customize <cookbook-error-pages-by-status-code>`). If they are logged in
and have the correct roles, the code will be executed.

.. _book-security-securing-controller-annotations:

Expand Down Expand Up @@ -881,14 +889,13 @@ the built-in helper function:
<a href="...">Delete</a>
<?php endif ?>

If you use this function and are *not* behind a firewall, an exception
will be thrown. Again, it's almost always a good
idea to have a main firewall that covers all URLs (as has been shown
in this chapter).
If you use this function and you are *not* behind a firewall, an exception will
be thrown. Again, it's almost always a good idea to have a main firewall that
covers all URLs (as shown before in this chapter).

.. caution::

Be careful with this in your layout or on your error pages! Because of
Be careful with this in your base layout or on your error pages! Because of
some internal Symfony details, to avoid broken error pages in the ``prod``
environment, wrap calls in these templates with a check for ``app.user``:

Expand All @@ -899,10 +906,10 @@ in this chapter).
Securing other Services
.......................

In fact, anything in Symfony can be protected by doing something similar
to this. For example, suppose you have a service (i.e. a PHP class) whose
job is to send emails. You can restrict use of this class - no matter where
it's being used from - to only certain users.
Anything in Symfony can be protected by doing something similar to the code
used to secure a controller. For example, suppose you have a service (i.e. a
PHP class) whose job is to send emails. You can restrict use of this class - no
matter where it's being used from - to only certain users.

For more information see :doc:`/cookbook/security/securing_services`.

Expand All @@ -911,7 +918,8 @@ Checking to see if a User is Logged In (IS_AUTHENTICATED_FULLY)

So far, you've checked access based on roles - those strings that start with
``ROLE_`` and are assigned to users. But if you *only* want to check if a
user is logged in (you don't care about roles), then you can see ``IS_AUTHENTICATED_FULLY``::
user is logged in (you don't care about roles), then you can use
``IS_AUTHENTICATED_FULLY``::

// ...

Expand Down Expand Up @@ -1026,6 +1034,7 @@ Now you can call whatever methods are on *your* User object. For example,
if your User object has a ``getFirstName()`` method, you could use that::

use Symfony\Component\HttpFoundation\Response;
// ...

public function indexAction()
{
Expand Down Expand Up @@ -1359,7 +1368,7 @@ configuration tree may be useful.

Good luck!

Learn more from the Cookbook
Learn More from the Cookbook
----------------------------

* :doc:`Forcing HTTP/HTTPS </cookbook/security/force_https>`
Expand Down
8 changes: 4 additions & 4 deletions book/templating.rst
Original file line number Diff line number Diff line change
Expand Up @@ -135,10 +135,10 @@ Throughout this chapter, template examples will be shown in both Twig and PHP.
web designers everywhere.

Twig can also do things that PHP can't, such as whitespace control,
sandboxing, automatic and contextual output escaping, and the inclusion of
custom functions and filters that only affect templates. Twig contains
little features that make writing templates easier and more concise. Take
the following example, which combines a loop with a logical ``if``
sandboxing, automatic HTML escaping, manual contextual output escaping,
and the inclusion of custom functions and filters that only affect templates.
Twig contains little features that make writing templates easier and more concise.
Take the following example, which combines a loop with a logical ``if``
statement:

.. code-block:: html+jinja
Expand Down
2 changes: 1 addition & 1 deletion components/console/helpers/progressbar.rst
Original file line number Diff line number Diff line change
Expand Up @@ -330,4 +330,4 @@ your own::
For the ``filename`` to be part of the progress bar, just add the
``%filename%`` placeholder in your format::

$bar->setFormat(" %message%\n %step%/%max%\n Working on %filename%");
$bar->setFormat(" %message%\n %current%/%max%\n Working on %filename%");
4 changes: 2 additions & 2 deletions components/console/logger.rst
Original file line number Diff line number Diff line change
Expand Up @@ -96,8 +96,8 @@ constructor::

// ...
$formatLevelMap = array(
LogLevel::CRITICAL => self::INFO,
LogLevel::DEBUG => self::ERROR,
LogLevel::CRITICAL => ConsoleLogger::INFO,
LogLevel::DEBUG => ConsoleLogger::ERROR,
);
$logger = new ConsoleLogger($output, array(), $formatLevelMap);

Expand Down
10 changes: 5 additions & 5 deletions components/dependency_injection/factories.rst
Original file line number Diff line number Diff line change
Expand Up @@ -4,11 +4,6 @@
Using a Factory to Create Services
==================================

.. versionadded:: 2.6
The new :method:`Symfony\\Component\\DependencyInjection\\Definition::setFactory`
method was introduced in Symfony 2.6. Refer to older versions for the
syntax for factories prior to 2.6.

Symfony's Service Container provides a powerful way of controlling the
creation of objects, allowing you to specify arguments passed to the constructor
as well as calling methods and setting parameters. Sometimes, however, this
Expand All @@ -17,6 +12,11 @@ For this situation, you can use a factory to create the object and tell the
service container to call a method on the factory rather than directly instantiating
the class.

.. versionadded:: 2.6
The new :method:`Symfony\\Component\\DependencyInjection\\Definition::setFactory`
method was introduced in Symfony 2.6. Refer to older versions for the
syntax for factories prior to 2.6.

Suppose you have a factory that configures and returns a new ``NewsletterManager``
object::

Expand Down
3 changes: 1 addition & 2 deletions components/var_dumper/advanced.rst
Original file line number Diff line number Diff line change
Expand Up @@ -145,8 +145,7 @@ Another option for doing the same could be::
$output = fopen('php://memory', 'r+b');

$dumper->dump($cloner->cloneVar($variable), $output);
rewind($output);
$output = stream_get_contents($output);
$output = stream_get_contents($output, -1, 0);

// $output is now populated with the dump representation of $variable

Expand Down
2 changes: 1 addition & 1 deletion cookbook/security/entity_provider.rst
Original file line number Diff line number Diff line change
Expand Up @@ -321,7 +321,7 @@ If a User's ``isActive`` property is set to ``false`` (i.e. ``is_active``
is 0 in the database), the user will still be able to login to the site
normally. This is easily fixable.

To exclude inactive users, change your ``User`` clas to implement
To exclude inactive users, change your ``User`` class to implement
:class:`Symfony\\Component\\Security\\Core\\User\\AdvancedUserInterface`.
This extends :class:`Symfony\\Component\\Security\\Core\\User\\UserInterface`,
so you only need the new interface::
Expand Down
14 changes: 7 additions & 7 deletions cookbook/templating/render_without_controller.rst
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ a simple template that doesn't need any data passed into it, you can avoid
creating the controller entirely, by using the built-in ``FrameworkBundle:Template:template``
controller.

For example, suppose you want to render a ``AppBundle:Static:privacy.html.twig``
For example, suppose you want to render a ``static/privacy.html.twig``
template, which doesn't require that any variables are passed to it. You
can do this without creating a controller:

Expand All @@ -22,7 +22,7 @@ can do this without creating a controller:
path: /privacy
defaults:
_controller: FrameworkBundle:Template:template
template: 'AppBundle:Static:privacy.html.twig'
template: static/privacy.html.twig
.. code-block:: xml
Expand All @@ -34,7 +34,7 @@ can do this without creating a controller:
<route id="acme_privacy" path="/privacy">
<default key="_controller">FrameworkBundle:Template:template</default>
<default key="template">AppBundle:Static:privacy.html.twig</default>
<default key="template">static/privacy.html.twig</default>
</route>
</routes>
Expand All @@ -46,7 +46,7 @@ can do this without creating a controller:
$collection = new RouteCollection();
$collection->add('acme_privacy', new Route('/privacy', array(
'_controller' => 'FrameworkBundle:Template:template',
'template' => 'AppBundle:Static:privacy.html.twig',
'template' => 'static/privacy.html.twig',
)));
return $collection;
Expand Down Expand Up @@ -89,7 +89,7 @@ other variables in your route, you can control exactly how your page is cached:
path: /privacy
defaults:
_controller: FrameworkBundle:Template:template
template: 'AppBundle:Static:privacy.html.twig'
template: 'static/privacy.html.twig'
maxAge: 86400
sharedAge: 86400
Expand All @@ -103,7 +103,7 @@ other variables in your route, you can control exactly how your page is cached:
<route id="acme_privacy" path="/privacy">
<default key="_controller">FrameworkBundle:Template:template</default>
<default key="template">AppBundle:Static:privacy.html.twig</default>
<default key="template">static/privacy.html.twig</default>
<default key="maxAge">86400</default>
<default key="sharedAge">86400</default>
</route>
Expand All @@ -117,7 +117,7 @@ other variables in your route, you can control exactly how your page is cached:
$collection = new RouteCollection();
$collection->add('acme_privacy', new Route('/privacy', array(
'_controller' => 'FrameworkBundle:Template:template',
'template' => 'AppBundle:Static:privacy.html.twig',
'template' => 'static/privacy.html.twig',
'maxAge' => 86400,
'sharedAge' => 86400,
)));
Expand Down
6 changes: 6 additions & 0 deletions reference/configuration/twig.rst
Original file line number Diff line number Diff line change
Expand Up @@ -10,13 +10,19 @@ TwigBundle Configuration ("twig")
twig:
exception_controller: twig.controller.exception:showAction
form_themes:
# Default:
- form_div_layout.html.twig
# Bootstrap:
- bootstrap_3_layout.html.twig
- bootstrap_3_horizontal_layout.html.twig
# Example:
- MyBundle::form.html.twig
globals:
# Examples:
Expand Down
4 changes: 2 additions & 2 deletions reference/forms/types/checkbox.rst
Original file line number Diff line number Diff line change
Expand Up @@ -37,8 +37,8 @@ Example Usage
.. code-block:: php
$builder->add('public', 'checkbox', array(
'label' => 'Show this entry publicly?',
'required' => false,
'label' => 'Show this entry publicly?',
'required' => false,
));
Field Options
Expand Down
10 changes: 5 additions & 5 deletions reference/forms/types/choice.rst
Original file line number Diff line number Diff line change
Expand Up @@ -51,8 +51,8 @@ user sees on the form (e.g. ``Male``).
.. code-block:: php
$builder->add('gender', 'choice', array(
'choices' => array('m' => 'Male', 'f' => 'Female'),
'required' => false,
'choices' => array('m' => 'Male', 'f' => 'Female'),
'required' => false,
));
By setting ``multiple`` to true, you can allow the user to choose multiple
Expand All @@ -62,12 +62,12 @@ of checkboxes depending on the ``expanded`` option:
.. code-block:: php
$builder->add('availability', 'choice', array(
'choices' => array(
'choices' => array(
'morning' => 'Morning',
'afternoon' => 'Afternoon',
'evening' => 'Evening',
),
'multiple' => true,
'multiple' => true,
));
You can also use the ``choice_list`` option, which takes an object that can
Expand All @@ -90,7 +90,7 @@ by this field. The ``choices`` option is an array, where the array key
is the item value and the array value is the item's label::

$builder->add('gender', 'choice', array(
'choices' => array('m' => 'Male', 'f' => 'Female')
'choices' => array('m' => 'Male', 'f' => 'Female'),
));

.. tip::
Expand Down
2 changes: 1 addition & 1 deletion reference/forms/types/entity.rst
Original file line number Diff line number Diff line change
Expand Up @@ -76,7 +76,7 @@ option. The easiest way to use the option is as follows::

$builder->add('users', 'entity', array(
'class' => 'AcmeHelloBundle:User',
'query_builder' => function(EntityRepository $er) {
'query_builder' => function (EntityRepository $er) {
return $er->createQueryBuilder('u')
->orderBy('u.username', 'ASC');
},
Expand Down
2 changes: 1 addition & 1 deletion reference/forms/types/options/trim.rst.inc
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,6 @@ trim
**type**: ``Boolean`` **default**: ``true``

If true, the whitespace of the submitted string value will be stripped
via the ``trim()`` function when the data is bound. This guarantees that
via the :phpfunction:`trim` function when the data is bound. This guarantees that
if a value is submitted with extra whitespace, it will be removed before
the value is merged back onto the underlying object.
10 changes: 9 additions & 1 deletion reference/forms/types/password.rst
Original file line number Diff line number Diff line change
Expand Up @@ -76,4 +76,12 @@ The default value is ``''`` (the empty string).

.. include:: /reference/forms/types/options/required.rst.inc

.. include:: /reference/forms/types/options/trim.rst.inc
trim
~~~~

**type**: ``Boolean`` **default**: ``false``

If true, the whitespace of the submitted string value will be stripped
via the :phpfunction:`trim` function when the data is bound. This guarantees that
if a value is submitted with extra whitespace, it will be removed before
the value is merged back onto the underlying object.
8 changes: 4 additions & 4 deletions reference/forms/types/timezone.rst
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ you should just use the ``choice`` type directly.
+-------------+------------------------------------------------------------------------+
| Rendered as | can be various tags (see :ref:`forms-reference-choice-tags`) |
+-------------+------------------------------------------------------------------------+
| Overridden | - `choice_list`_ |
| Overridden | - `choices`_ |
| Options | |
+-------------+------------------------------------------------------------------------+
| Inherited | from the :doc:`choice </reference/forms/types/choice>` type |
Expand Down Expand Up @@ -49,12 +49,12 @@ you should just use the ``choice`` type directly.
Overridden Options
------------------

choice_list
~~~~~~~~~~~
choices
~~~~~~~

**default**: :class:`Symfony\\Component\\Form\\Extension\\Core\\ChoiceList\\TimezoneChoiceList`

The Timezone type defaults the choice_list to all timezones returned by
The Timezone type defaults the choices to all timezones returned by
:phpmethod:`DateTimeZone::listIdentifiers`, broken down by continent.

Inherited Options
Expand Down
8 changes: 4 additions & 4 deletions reference/twig_reference.rst
Original file line number Diff line number Diff line change
Expand Up @@ -103,7 +103,7 @@ asset
``path``
**type**: ``string``
``packageName``
**type**: ``string``|``null`` **default**: ``null``
**type**: ``string`` | ``null`` **default**: ``null``
``absolute``
**type**: ``boolean`` **default**: ``false``
``version``
Expand All @@ -113,12 +113,12 @@ Returns a public path to ``path``, which takes into account the base path set
for the package and the URL path. More information in
:ref:`book-templating-assets`. For asset versioning, see :ref:`ref-framework-assets-version`.

asset_version
~~~~~~~~~~~~~
assets_version
~~~~~~~~~~~~~~

.. code-block:: jinja
{{ asset_version(packageName) }}
{{ assets_version(packageName) }}
``packageName``
**type**: ``string`` | ``null`` **default**: ``null``
Expand Down

0 comments on commit c2b5a6a

Please sign in to comment.