Download the PHP package silverstripe/multi-domain without Composer
On this page you can find all versions of the php package silverstripe/multi-domain. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download silverstripe/multi-domain
More information about silverstripe/multi-domain
Files in silverstripe/multi-domain
Package multi-domain
Short Description Allows multiple domains to access one CMS instance, mapping them to different sections of the hierarchy
License BSD-3-Clause
Homepage https://github.com/silverstripe/silverstripe-multi-domain/
Informations about the package multi-domain
Multi Domains for SilverStripe
Allows multiple domains to access one CMS instance, mapping them to different sections of the hierarchy, which allows for vanity URLs. Examples:
example.com
-> resolves to home pageexample.com/shop/store
-> Resolves to a Store pageexample-store.com
-> Shows content forexample.com/shop/store
.example-store.com/checkout
-> Shows content forexample.com/shop/store/checkout
Requirements
- silverstripe/framework ^4.0
Configuration
Each domain is identified by a key. You must define one domain using the primary
key to mark it as the primary domain.
Options
allow_subdomains
: If true, domain matching is subdomain agnostic, so that anything.example.com still maps to example.com, the primary domain in the above configuration.
Whitelisting
Sometimes you may have routes that should resolve normally, and bypass the multidomain filter. In this case, for any given domain, you can specify an allow
list.
In the above example, any URL beginning with admin/
, Security/
or matching my-custom-webhook/
will resolve on any domain.
Global whitelists
You can put your allow
node directly under MultiDomain
to have a global whitelist.
Forcing URLs to specific domains
Sometimes, you may have a page that sits outside the node representing a domain, but you still want it to be considered part of that domain. For this, you can use the force
option.
In the above configuration, the page buy-now
can live in the site root, but the URL example-store.com/buy-now
will nonetheless resolve the page, even though the page isn't under shop/store
.
Using environment variables
If you have multiple test environments, it may not make sense for you to hard code the host name in the config. Alternatively, you can define an environment variable, i.e. a constant, and refer to it as a string in the config.
This way, every environment can declare its hostname independently.
Why not subsites?
Subsites creates a parallel CMS instance for a given domain name. This module allows you to map domains to a specific section of the hierarchy, in the context of all your other pages.
Why not "homepage for domain"?
That works to create a vanity URL for one page, but as soon as you go deeper into the hierarchy, you return to the native URL. A more robust solution is required for persisting the vanity URLs.
Further, this module is more extensible, allowing for collaboration with other URL-hungry modules, such as Translatable or Fluent.