Companies with several business units, websites, brands, and extranets are often looking for ways to centrally manage all their outlets and initiatives from one application or platform. XperienCentral is designed to manage multiple websites and handle multi-channel publishing. It is possible to set up new channels (referred to in XperienCentral as channels) without installing additional hard- and software. In fact, every channel is a website with its own page structure and its own Workspace environment. The added value of multiple channels is the possibility to share and reuse information across those channels. Content Repository items that have been created in one channel can be reused in another channel. It is possible to specify exactly which functionality and content can be shared between which channels.
This topic describes how to set up extra channels and how to share information between these channels as well as some additional functionality.
In This Topic
Creating a New Channel
The steps below describe how to extend a XperienCentral installation with an extra channel. Some of these steps have to be taken by a system administrator and/or application manager due to some core configuration changes. This topic describes both local and development environments. A multiple website setup for production environments can be configured in a similar way, but it does require extra configuration of the web server(s) and possibly other software. Procedures for production environments are described in the Linux and Windows installation topics for production environments.
Before creating a new channel, stop XperienCentral.
Generate Hostnames
To create a second channel, two new hostnames are required: the hostname for the public website and the hostname for the editor environment (the generator). In this document www.mysecondsite.com and cms.mysecondsite.com will be used.
Þ Add these hostnames to your ‘hosts’ file (C:\Windows\system32\drivers\etc\hosts on Windows computers) and point them to 127.0.0.1. For example:
127.0.0.1 www.mysecondsite.com
127.0.0.1 cms.mysecondsite.com
Þ If you use a proxy server, add excludes for these hostnames in the proxy configuration of your browsers.
1.2 Request an updated configuration.xml
The configuration.xml is a file with a license key that also contains the valid hostnames for the installation. To create a new channel a new configuration.xml with the two new hostnames is required:
Þ Send an e‑mail to developersupport@gx.nl to obtain a new configuration.xml. Do not forget to include the two new required hostnames in your e‑mail.
1.3 Update the configuration.xmls
The new configuration.xml file has to be saved in the following locations:
Þ For local installations created with the .ZIP file:
<GX‑installdir>\XperienCentral‑webapps\XperienCentral‑backend‑webapp\target\XperienCentral‑backend‑webapp‑1.0‑SNAPSHOT\WEB‑INF\siteworks\
AND
<GX‑installdir>\XperienCentral‑webapps\XperienCentral‑backend‑webapp\src\main\webapp\WEB-INF\siteworks\
Þ For local installations created with the .EXE file:
<GX‑installdir>\XperienCentral\webapps\backend\WEB‑INF\siteworks\
Þ For production environments (depending on the configuration)
<GX-installdir>/configuration/
Tips:
- Use the search function to locate these folders.
- The right location can always be found in the XperienCentral Setup tool on the tab [General Configuration] search for the setting ‘config_filename’.
1.4 Create a new channel in XperienCentral
The steps to create a new channel:
Þ Start XperienCentral.
Þ Log in to XperienCentral.
Þ Open the menu Configure > channel configuration.
Þ In the pull-down menu ‘Select website’ choose the option ‘<new website>’.
Þ A new window is opened with four steps to create a new channel.
Step 1 of 4: Name the new website
Fields | Description |
Name
| The name of the new channel. |
Identifier
| The identifier of the new channel. |
Based on website
| Choose a website here if all the parameters are similar to those of an existing website. It is recommended to base the new website on an existing website, because all the configuration settings (such as paths) will be duplicated. |
Step 2 of 4: Configuration settings of new website
Fields | Description |
Hostname
| Choose the hostname of the public website. |
Generator
| Choose the hostname of the edit environment. |
Default e-mail address
| Default e-mail address for functionality such as the link checker. |
Folder for uploads
| Folder where uploaded files are stored. |
Upload URL
| Base URL of the uploaded files. Usually set to /upload/. |
Folder for multimedia uploads
| Folder where binary files are stored. |
Multimedia Upload URL
| Base URL of the uploaded binary files. Usually set to /upload_mm/. |
Descriptor folders
| Presentation JSPs are stored in folders. A task scans these folders for descriptor files. Multiple folders can be specified separated by semicolons. Usually set to /WEB‑INF/project/;/WEB‑INF/wm/jsp |
Redirect base directory
| The base folder of the static files. |
Step 3 of 4: Create a new website
In step 3 you have to confirm that you want to create a new channel by clicking on the [Create website] button and confirming this choice for the second time.
Step 4 of 4: Confirmation
After a successful creation of the new channel (step 4) you can exit the wizard by clicking the [Close] button.
After completing the wizard, a new channel with one page, the homepage, has been created. You can now log in to the channel by accessing the URL by its new hostname (+port number) followed by /web/edit. With the example in this document, that would be http://cms.mysecondsite.com:8080/web/edit.
Note: The homepage of the new channel can only be viewed if the status will be set to ‘Published’. Otherwise visitors will see a blank page (in Firefox) or a message that the web page cannot be found (in Internet Explorer).
1.5 Optional: extending the folder structure
The configuration of the new channel can be extended or altered to deal with separate files or presentations.
1.5.1 Separating presentations
On large websites with multiple channels it might be necessary to share common resources and (parts of) the presentation. In order to realize this:
- There must be a central folder for the shared files and presentations, for example with the name common.
- Besides the central folder, each channel also has its own folders for private files and presentations.
Example of a folder structure in a presentation WCB:
To be able to use this subdivision, some configurations have to be made in the Setup tool:
Þ In the /web/setup tool, select the [Website specific setting] tab.
Þ In the first channel, navigate to ‘presentation_jsps_url’. Enter the following folders:
- /WEB-INF/%PACKAGE%.%WCB NAME%/<dir> (e.g., WEB-INF/project/nl.gx.solutions.userprofileextension/jsp)
- /WEB-INF/wm/jsp/ (optional)
Þ Click on the ‘Update’ button for this channel.
Þ For each channel, repeat the above steps by replacing ‘<dir>’ with the name of the folder in which the channel specific JSPs are located.
Explanation: In the /web/setup tool, the descriptor directories are listed in a particular sequence. This sequence also indicates which JSPs are used if there are more JSPs with the same name. For instance, if with above settings, a page.jsp exists in the common folder and a page.jsp exists in the website1 folder, then the page.jsp from the website1 folder will be used.
The static files can be placed in a similar way as the JSPs:
Finally, the uploaded files can be placed in separate folders. With this, the first channel can use the standard upload and upload_mm folders. Uploads for the second and subsequent channels can be placed in a separate folder below the main folder.
In the Setup tool, also these paths can be set for each channel, on the [General Configuration] tab underneath the Configuration Set Definition “website_settings”, in the fields:
- ‘file_upload_directory’ and ‘file_upload_url’ (for normal uploads)
- ‘file_upload_mm_directory’ and ‘file_upload_mm_url’ (for Media Repository uploads)
2 Sharing content
2.1 Introduction
For organizations with several websites and multiple publication channels (multi-channel publishing) it is often essential to be able to manage content from a central location and to re-use it on multiple places. This means not only content but also web users, forms etc.
In a default installation with more than one channel all content is strictly separated. Content sharing is not done automatically. So, if this is wanted then some settings have to be changed. Most of these changes involve assigning different read/write permissions for different channels. Editors of the various channels must explicitly allow one another to read content and to re-use content. With explicitly assigned what to read per channel everything can be set up in a safe and flexible manner.
An important feature of shared content is that shared content can only be read on another channel. When for example an article is created in channel A then it can be displayed on channel B, but it can never be modified on channel B. This is to ensure that the rights of the author remain with the author. When different editors should be allowed to edit content on different channels their user accounts have to be shared as well. Editor X on channel A must be shared and granted permission to work on channel B as well.
Note: In the following sections, ‘content’ is used in a broader context and is used as a synonym for content types, model types, settings, web users etc. Language labels don't belong to this form of content. Language labels are maintained in a single object pool that is valid for all websites.
2.2 Sharing and accepting
In order to share content between channel A and channel B the configuration has to be changed to be able to expose (‘Share’) the content of one channel with another, but also to receive (‘Accept’) the content from another channel.
Sharing content takes place in three steps. For each channel, specify the following:
- Which content types are available for sharing
- Which content should be shared with which other channel(s)
- Which content should be accepted from other channel(s)
Example: articles from the media repository must be shared between channel A and channel B, and editors on both channel A and B should be able to add new articles and to use each other’s articles on their website.
Step 1
Which content types are available for sharing is set up in Configure > channel configuration > [Functionalities] under ‘Shared model types’. In order to share the Media Repository the ‘Mediabank’ option has to be selected in the ‘Shared model types’ in channel A. This step must be repeated for channel B. You can use the ‘Select website’ dropdown list in the panel to switch to channel B.
Step 2 and 3
Sharing and accepting are configured in Configure > channel configuration on the [Sharing / accepting] tab:
Short explanation:
- Select websites (1): The current channel
- Select websites (2): Filter to show only items of a specific channel.
- Select model type: Filter to show only certain model types.
- Share: Selection of items that this channel offers to other channels; in the above screenshot, the content of the Media Repository (‘Mediabank’) is offered to the other channel (which has the name “WI B”).
- Accept: Selection of items that have been accepted from other channels. In the above screenshot the current channel has accepted all content from the Media Repository.
- Share automatically: If this option is checked all sharable items of the selected model type (that are available) are automatically shared
- Accept automatically: If this option is checked all sharable items of the selected model type (that are available) are automatically accepted
Note: ‘Share’ and ‘Accept’ do not always contain more items because this cannot always be configured at this level. In that case everything is shared or nothing is shared. Examples are the Media Repository and web users.
In order to share the media repository according to the example:
- channel A has to share the media repository with B
- channel A has to accept the media repository from B
- channel B has to share the media repository with A
- channel B has to accept the media repository from A
When this is completed the configuration looks like this:
channel A (with the name “MyWeb”):
channel B (with the name “WI B”):
2.3 Model types
Below is a list of all model types that can be shared. When there are no comments for a model type the individual items of a model type can be shared. For example, with the queries you can choose on a query level which queries are shared or not.
Model types | Comment |
Application integration: filter definitions |
|
Applications |
|
Form resources | Form resources and form steps |
Forms |
|
Form models |
|
Form rules (all handlers) |
|
User groups |
|
Page section labels |
|
Media repository | Always the entire media repository, no individual media items |
Personalization | Both personalization expressions as well as personalization models |
Presentations | Note: only presentations and no presentation variants |
Queries |
|
Frameworks |
|
Style cluster |
|
Style properties |
|
Frames |
|
Languages |
|
Frames |
|
Web users | Always all web users, no individual web users |
3 Multiple websites vs language switch
In organizations that publish in several languages the question may arise how to accomplish this. The organization may either use more channels or use the ‘language switch’ functionality. To make this decision for the shorter and longer term, the pros and cons are described below.
Language switch | Extra channels |
The site structure for every website is the same. Not all pages have to be translated or published. | Each channel has its own site structure. |
Authorization per language is not possible. An editor can edit all languages. | Authorization is fully adjustable per channel. Each channel has its own editing environment. |
All languages use the same presentation. | There are many ways to separate the design or sharing parts of the design between several channels. |
License is part of the ‘Versioning’ component. | Additional licenses are required for each extra channel. |
For a straightforward one-to-one translation of a website and when the content is translated by the same group of editors the natural choice would be the language switch. In cases where extra functionality is required or per language authorization is required the natural choice would be to set up a separate channel and to use sharing and accepting to share content.