Spamworldpro Mini Shell
Spamworldpro


Server : Apache
System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64
User : corals ( 1002)
PHP Version : 7.4.33
Disable Function : exec,passthru,shell_exec,system
Directory :  /home/corals/mautic.corals.io/vendor/sensio/framework-extra-bundle/src/Resources/doc/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : /home/corals/mautic.corals.io/vendor/sensio/framework-extra-bundle/src/Resources/doc/index.rst
SensioFrameworkExtraBundle
==========================

The default Symfony ``FrameworkBundle`` implements a basic but robust and
flexible MVC framework. `SensioFrameworkExtraBundle`_ extends it to add sweet
conventions and annotations. It allows for more concise controllers.

Installation
------------

An official Symfony recipe is available for this bundle. To automatically
install and configure it run:

.. code-block:: bash

    $ composer require sensio/framework-extra-bundle

You're done!

Configuration
-------------

All features provided by the bundle are enabled by default when the bundle is
registered in your Kernel class.

The default configuration is as follow:

.. configuration-block::

    .. code-block:: yaml

        sensio_framework_extra:
            router:      { annotations: true } # Deprecated; use routing annotations of Symfony core instead
            request:     { converters: true, auto_convert: true }
            view:        { annotations: true }
            cache:       { annotations: true }
            security:    { annotations: true }


    .. code-block:: xml

        <!-- xmlns:sensio-framework-extra="http://symfony.com/schema/dic/symfony_extra" -->
        <sensio-framework-extra:config>
            <router annotations="true" />
            <request converters="true" auto_convert="true" />
            <view annotations="true" />
            <cache annotations="true" />
            <security annotations="true" />
        </sensio-framework-extra:config>

    .. code-block:: php

        // load the profiler
        $container->loadFromExtension('sensio_framework_extra', array(
            'router'      => array('annotations' => true),
            'request'     => array('converters' => true, 'auto_convert' => true),
            'view'        => array('annotations' => true),
            'cache'       => array('annotations' => true),
            'security'    => array('annotations' => true),
        ));

You can disable some annotations and conventions by defining one or more
settings to ``false``.

Annotations for Controllers
---------------------------

Annotations are a great way to easily configure your controllers, from the
routes to the cache configuration.

Even if annotations are not a native feature of PHP, it still has several
advantages over the classic Symfony configuration methods:

* Code and configuration are in the same place (the controller class);
* Simple to learn and to use;
* Concise to write;
* Makes your Controller thin (as its sole responsibility is to get data from
  the Model).

.. tip::

   If you use view classes, annotations are a great way to avoid creating
   view classes for simple and common use cases.

The following annotations are defined by the bundle:

.. toctree::
   :maxdepth: 1

   annotations/routing
   annotations/converters
   annotations/view
   annotations/cache
   annotations/security

This example shows all the available annotations in action (here and in all
the other examples both plain old annotations and PHP 8 attributes are shown):

.. configuration-block::

    .. code-block:: php-annotations

        use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;
        use Sensio\Bundle\FrameworkExtraBundle\Configuration\Cache;
        use Sensio\Bundle\FrameworkExtraBundle\Configuration\Template;
        use Sensio\Bundle\FrameworkExtraBundle\Configuration\ParamConverter;
        use Sensio\Bundle\FrameworkExtraBundle\Configuration\Method;
        use Sensio\Bundle\FrameworkExtraBundle\Configuration\IsGranted;
        use Sensio\Bundle\FrameworkExtraBundle\Configuration\Security;

        /**
         * @Route("/blog")
         * @Cache(expires="tomorrow")
         */
        class AnnotController
        {
            /**
             * @Route("/")
             * @Template
             */
            public function index()
            {
                $posts = ...;

                return array('posts' => $posts);
            }

            /**
             * @Route("/{id}")
             * @Method("GET")
             * @ParamConverter("post", class="SensioBlogBundle:Post")
             * @Template("@SensioBlog/annot/show.html.twig", vars={"post"})
             * @Cache(smaxage="15", lastmodified="post.getUpdatedAt()", etag="'Post' ~ post.getId() ~ post.getUpdatedAt()")
             * @IsGranted("ROLE_SPECIAL_USER")
             * @Security("is_granted('ROLE_ADMIN') and is_granted('POST_SHOW', post)")
             */
            public function show(Post $post)
            {
            }
        }

    .. code-block:: php-attributes

        use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;
        use Sensio\Bundle\FrameworkExtraBundle\Configuration\Cache;
        use Sensio\Bundle\FrameworkExtraBundle\Configuration\Template;
        use Sensio\Bundle\FrameworkExtraBundle\Configuration\ParamConverter;
        use Sensio\Bundle\FrameworkExtraBundle\Configuration\Method;
        use Sensio\Bundle\FrameworkExtraBundle\Configuration\IsGranted;
        use Sensio\Bundle\FrameworkExtraBundle\Configuration\Security;

        #[Route('/blog')]
        #[Cache(expired: 'tomorrow')]
        class AnnotController
        {
            #[Route('/')]
            #[Template]
            public function index()
            {
                $posts = ...;

                return array('posts' => $posts);
            }

            #[Route('/{id}')]
            #[Method('GET')]
            #[ParamConverter('post', class: 'SensioBlogBundle:Post')]
            #[Template('@SensioBlog/annot/show.html.twig", vars: ['post'])]
            #[Cache(smaxage: 15, lastmodified: 'post.getUpdatedAt()', etag: "'Post' ~ post.getId() ~ post.getUpdatedAt()")]
            #[IsGranted('ROLE_SPECIAL_USER')]
            #[Security("is_granted('ROLE_ADMIN') and is_granted('POST_SHOW', post)")]
            public function show(Post $post)
            {
            }
        }

As the ``showAction`` method follows some conventions, you can omit some
annotations:

.. configuration-block::

    .. code-block:: php-annotations

        /**
         * @Route("/{id}")
         * @Cache(smaxage="15", lastModified="post.getUpdatedAt()", Etag="'Post' ~ post.getId() ~ post.getUpdatedAt()")
         * @IsGranted("ROLE_SPECIAL_USER")
         * @Security("is_granted('ROLE_ADMIN') and is_granted('POST_SHOW', post)")
         */
        public function show(Post $post)
        {
        }

    .. code-block:: php-attributes

        #[Route('/{id}')]
        #[Cache(smaxage: 15, lastmodified: 'post.getUpdatedAt()', etag: "'Post' ~ post.getId() ~ post.getUpdatedAt()")]
        #[IsGranted('ROLE_SPECIAL_USER')]
        #[Security("is_granted('ROLE_ADMIN') and is_granted('POST_SHOW', post)")]
        public function show(Post $post)
        {
        }

The routes need to be imported to be active as any other routing resources, for
example:

.. code-block:: yaml

    # config/routes/annotations.yaml

    # import routes from a controller directory
    annot:
        resource: "@AnnotRoutingBundle/Controller"
        type:     annotation

.. _`SensioFrameworkExtraBundle`: https://github.com/sensiolabs/SensioFrameworkExtraBundle

Spamworldpro Mini