.. index:: single: Bundle; Installation
Most bundles provide their own installation instructions. However, the basic steps for installing a bundle are the same:
Dependencies are managed with Composer, so if Composer is new to you, learn some basics in their documentation. This involves two steps:
The README for a bundle (e.g. FOSUserBundle) usually tells you its name
(e.g. friendsofsymfony/user-bundle
). If it doesn't, you can search for
the bundle on the Packagist.org site.
Tip
Looking for bundles? Try searching for symfony-bundle topic on GitHub.
Now that you know the package name, you can install it via Composer:
$ composer require friendsofsymfony/user-bundle
This will choose the best version for your project, add it to composer.json
and download its code into the vendor/
directory. If you need a specific
version, include it as the second argument of the composer require command:
$ composer require friendsofsymfony/user-bundle "~2.0"
At this point, the bundle is installed in your Symfony project (e.g.
vendor/friendsofsymfony/
) and the autoloader recognizes its classes.
The only thing you need to do now is register the bundle in AppKernel
:
// app/AppKernel.php // ... class AppKernel extends Kernel { // ... public function registerBundles() { $bundles = array( // ... new FOS\UserBundle\FOSUserBundle(), ); // ... } }
In a few rare cases, you may want a bundle to be only enabled in the development
:doc:`environment </configuration/environments>`. For example,
the DoctrineFixturesBundle helps to load dummy data - something you probably
only want to do while developing. To only load this bundle in the dev
and test
environments, register the bundle in this way:
// app/AppKernel.php // ... class AppKernel extends Kernel { // ... public function registerBundles() { $bundles = array( // ... ); if (in_array($this->getEnvironment(), array('dev', 'test'))) { $bundles[] = new Doctrine\Bundle\FixturesBundle\DoctrineFixturesBundle(); } // ... } }
It's pretty common for a bundle to need some additional setup or configuration
in app/config/config.yml
. The bundle's documentation will tell you about
the configuration, but you can also get a reference of the bundle's configuration
via the config:dump-reference
command:
$ bin/console config:dump-reference AsseticBundle
Instead of the full bundle name, you can also pass the short name used as the root of the bundle's configuration:
$ bin/console config:dump-reference assetic
The output will look like this:
assetic:
debug: '%kernel.debug%'
use_controller:
enabled: '%kernel.debug%'
profiler: false
read_from: '%kernel.project_dir%/web'
write_to: '%assetic.read_from%'
java: /usr/bin/java
node: /usr/local/bin/node
node_paths: []
# ...
Tip
For complex bundles that define lots of configuration options, you can pass
a second optional argument to the config:dump-reference
command to only
display a section of the entire configuration:
$ bin/console config:dump-reference AsseticBundle use_controller
# Default configuration for "AsseticBundle" at path "use_controller"
use_controller:
enabled: '%kernel.debug%'
profiler: false
At this point, check the README
file of your brand new bundle to see
what to do next. Have fun!