Site definition
Site definitions enable you to individually control multiple websites, each with distinct domains and languages, within a single Magnolia installation. Each website corresponds to a website’s root page and its subpages in the Pages app.
The definition needs to be mapped to the website content. Specifically, you have to map your site definition to your website’s root page. The site definition and website must have the same name.
Additionally, every site definition can have its own site-wide theme and template prototype configurations. Template prototypes are used to define master page templates. Anything configured in them (for example, navigation, common page areas, or JavaScript) is applied to all page templates. Themes allow you to define different image renditions.
Go to the How to use Multisite page to configure multiple sites from one Magnolia installation.
Do I need a site definition?
No, it’s not necessary to use a site definition. A site based on concrete template definitions works perfectly well. A site definition is an advanced option. It’s useful when you have a large site and want to avoid repeating a similar configuration.
Without a site definition you can still:
- 
Choose which templates are available to editors. 
- 
Add CSS and JavaScript at the page level instead of site level. 
- 
Configure variations for each page template. 
But without a site definition, you cannot use:
- 
sitefntemplating functions
Prerequisites
You need the Site module to create a site definition. The module may not always be included, for example when you create your own webapp based on the empty webapp. Add a dependency to the Site module in your webapp POM file.
| DX Core provides the multisite feature. It allows you to configure a different site definition for each website in a single Magnolia instance. Each site can be mapped to a different domain and you can serve content from different workspaces. These features are in the Multisite module. | 
Site definitions in CE and DX Core
The steps to create a site definition can vary depending on which modules you have installed.
- 
In the Magnolia Community Edition, you are only allowed a single site definition. 
- 
For Magnolia DX Core, multiple site definitions are allowed. 
Community Edition
When using the Community Edition, only the Site module is installed. Because of this, you only have the option for a single site definition in your project. If you need to work with multiple sites, you must upgrade to Magnolia DX Core.
DX Core
When using Magnolie DX Core, only the Multisite module is installed. With this module, you can have as many sites as required. However, there are physical limits as each new site that’s added creates additional complexity.
It can sometimes be helpful to break the installations into multiple author instances. Especially in cases where you have multiple different teams spanning different regions.
| You can have as many author instances as you need as long as the content stays independent. | 
| Site limitation In DX Core, the number of sites that can be used is defined by the number of sites purchased. In the Community Edition, you can only create and use one site. | 
Configuring a site definition
You can configure a site using a YAML definition file in the sites folder of your module.
Configuration properties
| Property | Description | ||||
|---|---|---|---|---|---|
| 
 | optional | ||||
|       | optional The template prototype is a master template definition which applies to the whole site. Anything you configure in the prototype is applied to all page templates. | ||||
|       | optional Template availability defines which page templates are available to the editors using the Pages app. There are more ways to control page template availability. | ||||
| 
 | optional, default is  Enables and disables the site definition. | ||||
| 
 | optional Maps domain names to the site. Requires the Multisite module. | ||||
| 
 | optional Reference to a theme that defines the look and feel of the site. | ||||
| 
 | optional Node containing a locale configuration, with which you can add support for entering and serving content in multiple languages in your project. 
 | ||||
| 
 | optional URI mappings that define which node in a workspace should be served when a particular URI is requested. | ||||
| 
 | optional Configuration of a trusted proxy headers filter for the given site. 
 Filter configuration parameters determine which headers are allowed or checked by this filter. 
 Available header names: 
 
 | ||||
| 
 | optional Custom template properties that you can access from a script without having to write a class. | ||||
| 
 | optional Variations adapt the site for different devices or geographical locations. | ||||
| 
 | optional A CORS configuration for the site definition. For configuration details, see Request processing and filters: Properties. | 
Mapping a site definition to your website
The mappings property defines exactly to which node a site definition applies.
For example, in the mapping definition below, the root page /home-page is the website for which the site definition applies.
...
mappings:
  website:
    URIPrefix: '' (1)
    handlePrefix: /home-page (2)
    repository: website| 1 | The URIPrefixmaps a requested URL to one of the workspaces. For the website repository, it’s always empty.
See URI to repository mapping for more information. | 
| 2 | The handlePrefixspecifies the website to which the site definition is applied.
The site definition and website must have the same name. | 
| The  Some example mappings from the   | 
Example configurations
Travel site definition example
For an example site definition, see the Magnolia travel.yaml definition file.
Site definition decoration example
To customize an existing site definition, such as the travel-demo site, you can use a decoration file.
This lets you override specific configurations without modifying the original site definition.
For example, to decorate the travel-demo site, create a decoration file at: ${magnolia.resources.dir}/my-light-module/decorations/travel-demo/sites/travel.yaml
Below is an example of a travel.yaml decoration file that configures internationalization (i18n), domains, and mappings for the travel-demo site:
i18n: !override
  class: info.magnolia.cms.i18n.IetfI18nContentSupport
  enabled: true
  fallbackLocale: en
  locales:
    en:
      enabled: true
      languageTag: en
    de:
      enabled: true
      languageTag: de
    fr:
      enabled: true
      languageTag: fr
domains: !override
  travel-demo:
    name: travel-demo.magnolia-cms.com
mappings: !override
  website:
    URIPrefix: ''
    handlePrefix: /travel
    repository: website