Symfony2 Dynamic subdomain handler Bundle

dev-master 2018-04-04 12:03 UTC

This package is not auto-updated.

Last update: 2024-07-11 13:50:23 UTC



In composer.json:

"require": {
    "netgusto/dynamic-subdomain-bundle": "dev-master"

In app/AppKernel.php:

$bundles = array(
    # [...]
    new Netgusto\DynamicSubdomainBundle\NetgustoDynamicSubdomainBundle(),
    # [...]


In app/config.yaml

    parameter_name: ~
    entity: Acme\DemoBundle\Entity\MySite
    property: ~
  • base_host:

    • The domain base host, where all subdomains are attached
    • required
    • example:
  • parameter_name:

    • The name of the parameter that will be set on the current Request
    • optional
    • default value: subdomain
  • entity:

    • The class or Doctrine alias of the entity mapped to subdomains
    • required
    • example: Acme\DemoBundle\Entity\MySite
  • property:

    • The name of the property storing the subdomain name in your entity
    • optional
    • default value: subdomain
  • method:

    • The name of method that will be called to get object with the property defined
    • optional
    • default value: findOneBy


  1. Create the entities mapped to your subdomains
  2. Get the current subdomain object through the Symfony Request object

In php, assuming that equals subdomain (the default value):

use Symfony\Component\HttpFoundation\Request;

class DefaultController extends Controller {

    public function indexAction(Request $request) {
        $subdomainobject = $request->attributes->get('subdomain');

In twig, assuming that equals subdomain (the default value), and that the entity mapped to subdomains has a title property:

{{ app.request.attributes.get('subdomain').title }}


If the subdomain is not found in the database, an exception will be thrown by the Bundle (Symfony\Component\HttpKernel\Exception\NotFoundHttpException).