CQ5 WCM How To - A Collection

CQ5 WCM How To - A Collection
CQ5 WCM How To - A Collection
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Contents
1. Introduction ........................................................................................................................ 1
1.1. Introduction ............................................................................................................. 1
1.2. Purpose of this Document ........................................................................................ 1
1.3. Target Audience ...................................................................................................... 1
2. How to Quickly Create a Website ....................................................................................... 2
2.1. Introduction ............................................................................................................. 2
2.2. Creating the application, the Content Page Template, the Content Page Component
and a Web Page ........................................................................................................... 2
2.3. Setting up the Designer ........................................................................................... 3
2.4. Importing the original Web Page (CSS, HTML and images) into your project ................ 3
2.5. Replacing static content by dynamic content using CQ Foundation Components .......... 4
2.6. Creating a Media Library ......................................................................................... 5
3. How to Develop Components ............................................................................................. 6
3.1. Developing Components .......................................................................................... 6
3.1.1. Developing a new component by adapting an existing component .................... 6
3.1.2. Adding a new component to the paragraph system (design mode) ................... 7
3.1.3. Extending the Text and Image Component - An Example ................................ 7
4. How to Set Up a Cluster .................................................................................................. 14
4.1. How to Set Up a Cluster in CQ .............................................................................. 14
5. How to Monitor Performance ............................................................................................ 15
5.1. Introduction ........................................................................................................... 15
5.2. Performance - some theory .................................................................................... 15
5.3. Performance - basic rules ...................................................................................... 16
5.4. Recognizing some common performance problems ................................................. 17
5.5. Monitoring, and optimizing, the performance ........................................................... 17
5.5.1. Tools and mechanisms ............................................................................... 18
5.5.2. Interpreting the request.log .......................................................................... 19
5.5.3. Caching ...................................................................................................... 21
5.5.4. Analyzing Search ........................................................................................ 23
5.5.5. Monitoring Performance using JVisualVM ..................................................... 23
5.5.6. Performance when loading and editing Digital Assets .................................... 23
6. How to Create and Use a Workflow .................................................................................. 25
6.1. Creating a Workflow .............................................................................................. 25
6.1.1. Creating a new Workflow Model .................................................................. 25
6.1.2. Editing the Workflow ................................................................................... 25
6.2. Using the Workflow ............................................................................................... 28
6.2.1. Starting the Workflow for an individual page ................................................. 28
6.2.2. Taking actions on a Participant Step ............................................................ 30
6.2.3. Suspending, Resuming and Terminating a Workflow instance ........................ 33
6.2.4. Monitoring the Status of Workflow Instances ................................................. 33
6.3. Using the Workflow Launcher for Node Modifications ............................................... 34
6.3.1. Adding a Launcher relationship .................................................................... 35
6.3.2. Removing a Launcher relationship ............................................................... 36
7. Multi Site Manager ........................................................................................................... 37
7.1. Typical Use Cases for the Multi Site Manager ......................................................... 37
7.1.1. Multinational Site ........................................................................................ 37
7.1.2. Multilingual Site .......................................................................................... 37
7.1.3. Multinational Multilingual Site ....................................................................... 38
7.2. Managing Different Language Versions of a Website ............................................... 38
7.3. Managing the Translation of your Language Branches ............................................. 40
7.4. Managing Blueprints and Live Copies ..................................................................... 42
7.4.1. Creating a Live Copy .................................................................................. 42
7.4.2. Configuring Synchronization Actions between a Blueprint and its Live Copy
..... 51
7.4.3. Rolling out Changes on the Blueprint to the Live Copy .................................. 55
7.4.4. Live Copy status at Page and at Paragraph level .......................................... 57
Page iii of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
CQ5 WCM How To - A Collection
7.4.5. Managing Blueprints and Live Copies .......................................................... 62
7.4.6. Moving Blueprint and/or Live Copy pages ..................................................... 64
8. Upgrading to CQ5 ............................................................................................................ 65
8.1. How to Upgrade Your Communiqué Instance (3 or 4) to CQ5 ................................... 65
8.2. Upgrading from CQ 5.1 to CQ 5.2 .......................................................................... 67
8.2.1. Important information to read before starting the upgrade .............................. 67
8.2.2. Preparing for the upgrade from CQ 5.1 to CQ 5.2 ......................................... 68
8.2.3. Upgrading your CQ 5.1 instance to CQ 5.2 .................................................. 69
8.2.4. Upgrading your CQ 5.1 Digital Assets .......................................................... 70
8.2.5. Tasks to perform after the upgrade .............................................................. 71
8.2.6. The final status of your upgraded instance ................................................... 72
9. Installing CQ5 .................................................................................................................. 73
9.1. How to Install CQ WCM Author and Publish Instances using Quickstart ..................... 73
9.1.1. Installing an Author Instance ....................................................................... 73
9.1.2. Installing a Publish Instance ........................................................................ 74
9.1.3. Installing a CQ WCM Instance - Generic Procedure ...................................... 74
9.2. How to install CQ5 with an Application Server ......................................................... 75
9.2.1. WebSphere v6.1 ......................................................................................... 76
9.2.2. WebLogic v10.3 .......................................................................................... 78
9.2.3. Tomcat v6 .................................................................................................. 80
9.2.4. JBoss v4 .................................................................................................... 82
9.2.5. Generic Procedures .................................................................................... 85
10. How to Use, Create, and Edit a Page .............................................................................. 88
10.1. Managing Pages within CQ WCM ......................................................................... 88
10.1.1. Creating a New Page ................................................................................ 88
10.1.2. Editing a Page .......................................................................................... 90
10.1.3. Find & Replace ......................................................................................... 93
10.1.4. Moving or Renaming Page ........................................................................ 94
10.1.5. Deleting a Page ........................................................................................ 95
10.1.6. Setting the Page Properties ....................................................................... 96
11. How to Publish a Page ................................................................................................. 102
11.1. How To Publish Pages ....................................................................................... 102
11.1.1. Activating Content ................................................................................... 102
11.1.2. Deactivating Content ............................................................................... 103
11.1.3. Determining Page Publication Status ........................................................ 104
11.1.4. Locking Pages ........................................................................................ 104
11.1.5. Unlocking Pages ..................................................................................... 105
11.1.6. Using Preview Mode ............................................................................... 106
12. How to Restore a Page ................................................................................................ 107
12.1. How To Restore Pages ...................................................................................... 107
13. How to Create Templates ............................................................................................. 109
13.1. Developing Page Templates ............................................................................... 109
13.1.1. Creating a new Template (based on an existing template) .......................... 109
14. How to activate a section of your website ...................................................................... 110
14.1. How to activate a complete section (tree) of your website ..................................... 110
15. How to Use Tags ......................................................................................................... 111
15.1. How to Manage Tags in CQ WCM ...................................................................... 111
15.1.1. Using Sidekick to access and assign Tags ................................................ 111
15.1.2. The Tag Administration Console .............................................................. 112
15.1.3. Searching for Tags .................................................................................. 114
16. How to use Social Collaboration .................................................................................... 116
16.1. How to Blog with CQ ......................................................................................... 116
16.1.1. Creating a new blog ................................................................................ 116
16.1.2. Posting a new blog entry ......................................................................... 116
16.1.3. Adding quick reference links to your blog .................................................. 118
16.1.4. Importing RSS Feeds .............................................................................. 119
16.2. Managing the Social Collaboration Profiles .......................................................... 121
16.2.1. Registering and editing a user profile ....................................................... 121
Page iv of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
CQ5 WCM How To - A Collection
16.2.2. Finding the profiles in CRX ......................................................................
17. How to import offline documents ...................................................................................
17.1. How to import documents generated offline .........................................................
18. Validating External Links ...............................................................................................
18.1. How to validate external links .............................................................................
19. How to Find Logs and Audit Entries ..............................................................................
19.1. Working with Audit Records and Log Files ..........................................................
19.1.1. Finding the Audit Records .......................................................................
19.1.2. Finding the Log Files ...............................................................................
19.1.3. Activating the DEBUG Log Level ..............................................................
19.1.4. Create a Custom Log File ........................................................................
20. How to monitor, and configure, your Replication Agents ..................................................
20.1. How to monitor your Replication Agents ..............................................................
20.2. How to configure your Replication Agents ...........................................................
20.2.1. Configuring your Replication Agents from wcm/siteadmin ...........................
20.2.2. Configuring your Replication Agents from the CRX Explorer .......................
20.2.3. Configuring Reverse Replication ..............................................................
20.2.4. Configuring Replication for Multiple Publish Instances ................................
20.2.5. Configuring a Dispatcher Flush agent .......................................................
21. Troubleshooting CQ WCM ............................................................................................
21.1. Troubleshooting scenarios by Role(s) ..................................................................
21.2. Troubleshooting Scenarios .................................................................................
21.2.1. Common Installation Issues .....................................................................
21.2.2. Possible Issues with the GUI ...................................................................
21.2.3. Methods for Troubleshooting Analysis ......................................................
22. How to Backup your CQ WCM instance ........................................................................
22.1. Backing up your software installation ..................................................................
22.2. Backing up your repository .................................................................................
23. Security Checklists .......................................................................................................
23.1. Security Checklist for System Administrators .......................................................
23.2. Security Checklist for Power Users .....................................................................
23.3. Security Checklist for Developers ........................................................................
23.4. Disable WebDAV ...............................................................................................
23.5. Restrict Access via the Dispatcher ......................................................................
23.6. Check for Cross-Site Scripting (XSS) ..................................................................
23.7. Change Default Passwords ................................................................................
23.7.1. Changing the CQ admin password ...........................................................
23.7.2. Changing the admin password for CQSE ..................................................
23.7.3. Changing the admin password for the Apache Felix Web Management
Console .............................................................................................................
23.8. Use the user session, not the administrative session ............................................
24. Defining Performance Tests on Your Publish Environment ..............................................
24.1. Introduction ........................................................................................................
24.2. Phases to be used .............................................................................................
24.3. Verification of Knowledge ...................................................................................
24.3.1. Test Architecture .....................................................................................
24.3.2. Application Map ......................................................................................
24.4. Scope Definition .................................................................................................
24.5. Test Methodologies ............................................................................................
24.6. Defining the Performance Goals .........................................................................
24.6.1. Single Component Tests ..........................................................................
24.6.2. Combined Component Tests ....................................................................
24.6.3. Going Live Tests .....................................................................................
24.6.4. Error Tests .............................................................................................
24.6.5. Endurance Tests .....................................................................................
24.7. Optimization .......................................................................................................
24.8. Reporting ...........................................................................................................
25. Extending CQ documentation and Online Help ...............................................................
Page v of 214
122
123
123
124
124
125
125
125
126
127
128
130
130
131
131
132
133
135
135
137
137
137
137
138
139
144
144
144
145
145
145
145
145
146
147
147
148
150
151
151
152
152
152
152
153
153
153
154
154
155
155
156
156
156
157
157
158
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
CQ5 WCM How To - A Collection
25.1. How to extend the documentation and online help ...............................................
25.1.1. To extend the online help delivered with CQ .............................................
26. How to Create a Fully Featured Internet Website ............................................................
27. How to Set Up the Development Environment with Eclipse ..............................................
27.1. How to Set Up the Development Environment with Eclipse ...................................
27.1.1. Creating the Project Structure in CQ5 .......................................................
27.1.2. Installing FileVault (VLT) ..........................................................................
27.1.3. Installing Eclipse .....................................................................................
27.1.4. Creating the Project Structure in Eclipse ...................................................
27.1.5. Scripting with Eclipse and CQ5 ................................................................
27.1.6. Java Developing with Eclipse and CQ5 ....................................................
27.1.7. Building collaborative and automated projects ...........................................
28. Multi Site Manager for Developers .................................................................................
28.1. MSM in the Repository .......................................................................................
28.1.1. MSM-specific Nodes, Node Types, and Properties ....................................
28.1.2. MSM mechanisms in the repository ..........................................................
28.2. Extending MSM Functionalities ...........................................................................
28.2.1. How to extend synchronization actions .....................................................
28.2.2. How to define the properties and the nodes that are copied to the Live
Copy ..................................................................................................................
28.2.3. How to remove the "Chapters" step in the "Create Site" wizard ...................
29. JSP Tag Libraries .........................................................................................................
29.1. JSP Tag Libraries ..............................................................................................
29.1.1. CQ Tag Library .......................................................................................
29.1.2. Sling Tag Library .....................................................................................
30. DAM Media Handlers ....................................................................................................
30.1. Default Media Handlers ......................................................................................
30.2. Using Media Handlers in Workflows to perform tasks on Assets ............................
30.3. Disabling/Enabling a Media Handler ....................................................................
30.4. Creating a new Media Handler ...........................................................................
30.4.1. Important Classes and Interfaces .............................................................
30.4.2. Example: create a specific Text Handler ...................................................
31. How to Model Data .......................................................................................................
31.1. Data Modeling - David Nuescheler's Model ..........................................................
31.1.1. Source ....................................................................................................
31.1.2. Introduction from David ............................................................................
31.1.3. Seven Simple Rules ................................................................................
A. Copyright, Licenses and Formatting Conventions .............................................................
A.1. Formatting Conventions .......................................................................................
Page vi of 214
158
158
161
162
162
162
162
163
164
168
170
172
173
173
173
176
177
177
186
187
188
188
188
193
196
196
197
200
201
201
201
208
208
208
208
208
214
214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
1 Introduction
1.1 Introduction
To help you perform certain tasks within CQ5 this collection of How To articles has been compiled.
1.2 Purpose of this Document
To collect all the How To articles into one document.
1.3 Target Audience
• see individual How To sections
Page 1 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
2 How to Quickly Create a Website
2.1 Introduction
This tutorial enables you to quickly create a website with CQ5, based on an existing website. It is
mainly targeted at Day Pre-Sales staff and Day Partners preparing Proof Of Concept for a project.
You only need CQ5 WCM, CQDE and a Web browser.
2.2 Creating the application, the Content Page Template, the
Content Page Component and a Web Page
1.
In CRX Explorer, copy the node apps/geometrixx, name the target node
<customername> and paste it under apps.
2.
Set the title (jcr:title property) of the Template apps/<customername>/templates/
contentpage to <Customername> Content Page Template.
3.
Replace the thumbnail /apps/<customername>/templates/contentpage/
thumbnail.png with one representing your Template.
• Create a PNG image, 128 x 98 px big.
• In your file system, copy the image and paste it into /apps/<customername>/
templates/contentpage/ .
4.
Delete the property allowedPaths of the Template /apps/<customername>/
templates/contentpage.
5.
Set the property sling:resourceType of the node /apps/<customername>/
templates/contentpage/jcr:content to <customername>/components/
contentpage.
6.
In CQDE, under the Component /apps/<customername>/components/contentpage,
create the file contentpage.jsp.
7.
Copy/paste following code into the script contentpage.jsp:
<%@page session="false" contentType="text/html; charset=utf-8" %><%
%><%@taglib prefix="cq" uri="http://www.day.com/taglibs/cq/1.0" %><%
%><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/
strict.dtd">
<html>
<%@include file="/libs/wcm/global.jsp" %><%
%><head>
<cq:include script="/libs/wcm/init/init.jsp"/>
<% currentDesign.writeCssIncludes(out); %>
MyCustomerHead
</head>
<body>
MyCustomerBody
</body>
</html>
8.
In your browser, open the CQ site administration.
9.
Under Websites, create a new page with the Title www.<customername>.com, the label
<customername> and the <Customername> Content Page Template.
10. Under the Page www.<customername>.com, create a new page with the Title English,
the label en and the <Customername> Content Page Template. If needed, create one Page
with the Title French, the label fr and one Page the Title German, the label de.
Page 2 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Quickly Create a Website
11. Under the Page English, create as many pages as needed in order to reproduce the site
map of your customer site.
12. Open the English Page. It should look as follows:
2.3 Setting up the Designer
1.
In CRX Explorer, copy the node /etc/designs/geometrixx, name the target node
<customername> and paste it under /etc/designs.
2.
In contentpage.jsp, insert <% currentDesign.writeCssIncludes(out); %> at the
appropriate location.
3.
In CQDE, open the file /etc/designs/<customername>/static.css and adapt the
styles to your needs.
4.
Link your pages to the <customername> designer: in CRX Explorer, select the node /
content/<customername>/jcr:content. Double-click Property cq:designPath and
set /etc/designs/<customername> as Value.
2.4 Importing the original Web Page (CSS, HTML and images) into
your project
1.
In Firefox, browse to the page that you want to import, select Save Page As …, enter
<customername> as Filename and save it on your desktop.
2.
Test the downloaded website on your desktop: open the downloaded
<customername>.htm file in your browser and compare the result with the original website.
If it is different, open the file in a text editor and fix the problems. Problems are often caused
by paths for css files and images that need to be correctly reset.
3.
In your filesystem, zip all the resources of your webpage (html, css, images, ...).
4.
In CRX Explorer, under the node /apps/<customername>/components/contentpage,
create a New Node: set the Name to resources and the Type to sling:Folder.
Page 3 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Quickly Create a Website
5.
In CRX Content Loader, import the zip file and expand it into the node /apps/
<customername>/components/contentpage/resources:
• Browse to http://localhost:4502/crx/loader/index.jsp.
• Click Browse beside Root path for import:, browse to the node /apps/
<customername>/components/contentpage/resources and click Open.
• Click Browse beside File to upload:, browse to your zip file and click Open.
• Check Auto-Expand and Expand file content directly below selected
root checkboxes.
• Click Import.
Note
In a normal project setup, the resources wouldn't be placed under the Component. It
is only done here to maximize your efficiency.
6.
In CQDE, open the file <customername>.html and copy the content between the <head>
and </head> tags. In the script contentpage.jsp, select
MyCustomerHead
and paste the previously copied content.
7.
In the file <customername>.html, copy the content between the <body> and </body> tags.
In the script contentpage.jsp, select
MyCustomerBody
and paste the previously copied content.
8.
In the script contentpage.jsp, reset the paths of the css files and the images by replacing:
<customername>_files
with:
/apps/<customername>/components/contentpage/resources
Note
Make sure that the names of your resources don't start with _ (underscore).
.
9.
In the script contentpage.jsp, replace all external links with internal links. This way the
external links don't appear broken when your machine is not online.
10. In your browser, in the CQ Site Administration, open the page www.<customername>.com. It
should display your <customername> web page.
2.5 Replacing static content by dynamic content using CQ
Foundation Components
1.
In CQDE, in the file contentpage.jsp, select the content of the middle part of the page and
replace it with:
<cq:include path="par" resourceType="foundation/components/parsys" />
Page 4 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Quickly Create a Website
. The content has been replaced by the parsys Foundation Component.
2.
In your browser, refresh your page. The features of the Paragraph System are now available
to you: you can include other Components, for example, Flash, Text or Text Image.
3.
By following the previous steps, you can add other CQ Foundation Components as for
example topnav or toolnav.
4.
In your browser, in the CQ Site Administration, open a page of your choice from your
application. Copy content from the original web page and paste it into your page.
5.
Adapt the design to look like the design of the original website.
2.6 Creating a Media Library
1.
In your browser, download about 20 resources (pictures, banners, pdf, …) from the original
website: open a Google page, type site:<customer-url>, click search and click the
Images tab. Save the desired resources on your computer.
2.
In your filesystem, zip all the resources.
3.
In CRX Content Loader, import the zip file and expand it into the node content/dam/
<customername>. The resources are now available in the contentfinder, when browsing
through the Pages.
Page 5 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
3 How to Develop Components
3.1 Developing Components
This section describes how to create your own components and add them to the paragraph
system.
A quick way to get started is to copy an existing component and then make the changes you want.
You can also use this method to edit existing components (although Day recommends that you
back up the original component).
An example of how to develop a component is described in detail in Extending the Text and Image
Component - An Example.
3.1.1 Developing a new component by adapting an existing component
To develop new components for CQ WCM based on existing component, you copy the component
and create a javascript file for the new component and store it in a location accessible to CQ5:
1.
Create a new component folder in /apps/<website-name>/
components/<MyComponent> by copying an existing component, such as the Text
component, and renaming it.
2.
In the CRX Explorer, modify the jcr:description and jcr:title to reflect its new name.
3.
Open the new component folder and make the changes you require; also, delete any
extraneous information in the folder.
You can make changes such as:
• adding a new field in the dialog box
• replacing the .jsp file (name it after your new component)
• or completely reworking the entire component if you want
For example, if you take a copy of the standard Text component, you can add an additional
field to the dialog box, then update the .jsp to process the input made there.
Page 6 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Develop Components
4.
In the Content Explorer, navigate to the component and change the allowedParents
property to */parsys, which makes it available to the paragraph system.
Note
Either cq:editConfig node, dialog, or design_dialog node should be present and
properly initialized for the new component to appear.
5.
Activate the new component in your paragraph system either by adding /apps/<websitename>/components/<MyComponent> to the /etc/designs/default/<websitename>/jcr:content/contentpage/parsys/components property in CRX or by
following the instructions in Adding new components to paragraph systems.
6.
In CQ WCM, open a page in your web site and insert a new paragraph of the type you just
created to make sure the component is working properly.
Note
To see timing statistics for page loading, you can use Ctrl-Shift-U - with ?
debugClientLibs=true set in the URL.
3.1.2 Adding a new component to the paragraph system (design mode)
After the component has been developed, you add it to the paragraph system, which enables
authors to select and use the component when editing a page.
1.
Access a page within your authoring environment that uses the paragraph system; for
example <contentPath>/Test.html.
2.
Switch to Design mode by either:
• adding ?cmsmode=design to the end of the URL and accessing again; for example
<contextPath>/ Test.html?cmsmode=design.
• clicking Design in Sidekick
You are now in designmode and can edit the paragraph system:
3.
Click Edit.
A list of components belonging to the paragraph system are shown (all those defined with the
property allowedParents=*/parsys). Your new component is also listed.
The components can be activated (or deactivated) to determine which are offered to the
author when editing a page.
4.
Activate your component, then return to normal edit mode to confirm that it is available for
use.
3.1.3 Extending the Text and Image Component - An Example
This section provides an example on how to extend the widely used text and image standard
component with a configurable image placement feature.
The extension to the text and image component allows editors to use all the existing functionality of
the component plus have an extra option to specify the placement of the image either:
• on the left-hand side of the text (current behavior and the new default)
• as well as on the right-hand side
Page 7 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Develop Components
After extending this component, you can configure the image placement through the component's
dialog box.
The following techniques are described in this exercise:
• Copying existing component node and modifying its metadata
• Modifying the component's dialog, including inheritance of widgets from parent dialog boxes
• Modifying the component's script to implement the new functionality
3.1.3.1 Extending the existing textimage component
To create the new component, we use the standard textimage component as a basis and modify
it. We store the new component in the Geometrixx CQ WCM example application. To extend the
textimage component, go to the CRX Explorer (server name:port number/crx) and log in as
admin and then navigate to the Content Explorer.
1.
Copy the standard textimage component from /libs/foundation/components/
textimage into the Geometrixx component folder, /apps/geometrixx/components,
using textimage as the target node name. (Copy the component by navigating to the
component, right-clicking and selecting Copy and browsing to the target directory.)
2.
To keep this example simple, navigate to the component you copied and delete all the
subnodes of the new textimage node except for the following ones:
• dialog definition: textimage/dialog
• component script: textimage/textimage.jsp
Page 8 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Develop Components
3.
Edit the component metadata:
• Component name
• Set jcr:description to Text Image Component (Extended)
• Set jcr:title to Text Image (Extended)
• Component listing in the paragraph (parsys component) system (leave as is)
• Leave allowedParents defined as */parsys
• Group, where the component is listed in the sidekick (leave as is)
• Leave componentGroup set to General
• Parent component for the new component (the standard textimage component)
• Set sling:resourceSuperType to foundation/components/textimage
After these steps the component node looks like the following:
4.
Modify the component's dialog box to include the new option. The new component inherits
the parts of the dialog box that are the same as in the original. The only addition we make is
to extend the Advanced tab, adding an Image Position dropdown list, with options Left
and Right:
• Leave the textimage/dialog properties unchanged.
• Note how textimage/dialog/items has three subnodes, tab1 to tab3, representing
the three tabs of the textimage dialog box.
• For the first two tabs (tab1 and tab2):
• Change xtype to cqinclude (to inherit from the standard component).
• Add a pathParameter property with values /libs/foundation/components/
textimage/dialog/items/tab1.infinity.json and /libs/foundation/
components/textimage/dialog/items/tab2.infinity.json, respectively.
• Remove all other properties or subnodes.
• For tab3:
• Leave the properties and subnodes without changes
• Add a new field definition to tab3/items, node position of type cq:Widget
• Set the following properties (of type String) for the new tab3/items/position node
Page 9 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Develop Components
• name: ./imagePosition
• xtype: selection
• fieldLabel: Image Position
• type: select
• Add subnode position/options of type cq:WidgetCollection to represent the
two choices for image placement, and under it create two nodes, o1 and o2 of type
nt:unstructured
• For node position/options/o1 set the properties: text to Left and value to left
• For node position/options/o2 set the properties: text to Right and value to
right
Image position is persisted in content as the imagePosition property of the node
representing textimage paragraph.
After these steps, the component dialog box looks like this:
5.
Extend the component script, textimage.jsp, with extra handling of the new parameter.
• Open the /apps/geometrixx/components/textimage/textimage.jsp script for
editing.
• We are going to manipulate the style of the <div class="image"> tag, generated by the
component, to float the image to the right. It is located in the following area of the code:
Image img = new Image(resource, "image");
if (img.hasContent() || WCMMode.fromRequest(request) == WCMMode.EDIT) {
%><div class="image"><%
img.loadStyleData(currentStyle);
We are going to replace the emphasized code fragment %><div class="image"><%
with new code generating a custom style for this tag.
Page 10 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Develop Components
• Copy the following code fragment, and replace the %><div class="image"><% line with
it:
// todo: add new CSS class for the 'right image' instead of using
//
the style attribute
String style="";
if (properties.get("imagePosition", "left").equals("right")) {
style = "style=\"float:right\"";
}
%><div <%= style %> class="image"><%
Note that for simplicity we are hard-coding the style to the HTML tag. The proper way to do
it would be to add a new CSS class to the application styles and just add the class to the
tag in the code in the case of a right-aligned image.
• The code fragment, after the change, should look like this (new code emphasized):
Image img = new Image(resource, "image");
if (img.hasContent() || WCMMode.fromRequest(request) == WCMMode.EDIT) {
// todo: add new CSS class for the 'right image' instead of using
//
the style attribute
String style="";
if (properties.get("imagePosition", "left").equals("right")) {
style = "style=\"float:right\"";
}
%><div <%= style %> class="image"><%
img.loadStyleData(currentStyle);
• Save the script to the repository.
6.
The component is ready to test.
3.1.3.2 Checking the new component
After the component has been developed, you can add it to the paragraph system, which enables
authors to select and use the component when editing a page. These steps allow you to test the
component.
1.
Open a page in Geometrixx; for example, English/Company
2.
Switch to design mode by clicking Design in Sidekick
3.
Edit the paragraph system design by clicking Edit on the paragraph system in the middle of
the page. A list of components, which can be placed in the paragraph system are shown, and
it should include your newly developed component, Text Image (Extended). Activate it
for the paragraph system by selecting it and clicking OK.
4.
Switch back to the editing mode.
5.
Add the Text Image (Extended) paragraph to the paragraph system, initialize text and image
with sample content. Save and you should see the default rendering of Text and Image
component:
Page 11 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Develop Components
6.
Open the dialog of the text and image paragraph, and change the Image Position on the
Advanced tab to Right, and click OK to save the changes.
7.
You see the paragraph rendered with the image on the right:
Page 12 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Develop Components
8.
The component is now ready to use.
The component stores its content in a paragraph on the Company page. The following screenshot
shows how our new configuration parameter is persisted in the repository, with the node
representing the paragraph we have just created.
The textimage/imagePosition parameter represents the position of the image for this
paragraph on /content/geometrixx/en/company page.
Page 13 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
4 How to Set Up a Cluster
4.1 How to Set Up a Cluster in CQ
A cluster is formed of two, or more, live servers linked together. Therefore, if one node fails, the
other nodes are active and accessible for your applications and there is no system interruption.
This allows you to recover and re-start failed nodes easily. New nodes can also be added to an
existing cluster, allowing for simple extensibility.
Clustering is beneficial for:
Increased availability
When a server breaks down, or becomes unavailable, the cluster agent relays requests to the
servers that are still running. Service continues without interruption.
Increased performance
Clustering increases system performance and availability even when nodes fail.
While all servers in the cluster are active, you can use their combined computational power.
Therefore, this solution improves performance during normal use. However, if one server
breaks down you lose its performance, so the overall application performance may suffer.
The following section describes how to set up a cluster in CQ with two cluster nodes on two
separately networked servers.
The master node is called node 1, the slave node is called node 2.
On the node 1 (master):
1.
In the file system, create a folder /node1.
2.
Install CQ under /node1. For a complete description of the installation, please refer to the
section called “Installing an Author Instance”.
3.
In the file system, share the folder node1/crx-quickstart/repository/shared so that
it can be accessed from node 2.
On the node 2 (slave):
1.
In the file system, create a folder /node2.
2.
Install CQ under /node2. For a complete description of the installation, please refer to the
section called “Installing an Author Instance”.
3.
In the file system, map the folder on node 1 node1/crx-quickstart/repository/
shared to a drive; Z: in our case.
4.
In your browser, navigate to http://localhost:4502/crx to open the CRX Main
Console.
5.
Log in as administrator (admin).
6.
Click Repository Configuration.
7.
Under Tools, click Cluster.
8.
Under Join Cluster, as Shared path, enter Z:\ and click Join.
Note
In order to add more nodes to the cluster, repeat the steps on the slave node as many
times as needed.
Page 14 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
5 How to Monitor Performance
5.1 Introduction
CQ5 encompasses several applications, and interacts with several more.
Performance (or the lack of it) is one of the first things that your users notice, so as with any
application with a user interface, performance is of key importance. To optimize the performance of
your CQ5 WCM installation you need to monitor various attributes of the instance and its behavior.
This is primarily of interest to power user, system administrators and project managers.
5.2 Performance - some theory
The problems that cause performance issues are often difficult to track down, even when their
effects are easy to see.
A basic starting point is a good knowledge of your system when it is operating as normal. If you
don't know how your environment "looks" and "behaves" when it is performing properly, it can
be difficult to locate the problem when performance deteriorates. This means that you should
spend some time investigating your system when it is running smoothly and ensure that collecting
performance information is an ongoing task. This will provide you with a basis for comparison
should the performance suffer.
The following diagram illustrates the path that a request for CQ5 content can take - and therefore
the number of different elements which can impact the performance.
Figure 5.1. CQ5 request - the web-chain
Performance is also a balance between Volume and Capacity:
Volume
the amount of output that is processed and delivered by the system.
Page 15 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Monitor Performance
Capacity
the system’s ability to deliver the volume.
This can be illustrated in various locations throughout the web-chain.
Figure 5.2. Capacity vs. Volume
There are several functional areas which are often responsible for impacting the performance:
• Caching
• Application (your project) code
• Search functionality
5.3 Performance - basic rules
Certain rules should be kept in mind when optimizing performance:
1. Performance tuning must be part of every project.
2. Do not optimize early in the development cycle.
3. Performance is only as good as the weakest link.
4. Always think about capacity vs. volume.
5. Optimize important things first.
6. Never optimize without realistic goals.
Note
Bear in mind that the mechanism you use to measure performance will often affect
exactly what you are trying to measure. You should always try to account for these
Page 16 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Monitor Performance
discrepancies, and eliminate as much of their effect as possible; in particular browser
plug-ins should be de-activated wherever possible.
5.4 Recognizing some common performance problems
The following lists common performance issues which occur, together with proposals on how to
spot and counteract them.
Table 5.1. Recognizing common performance problems
Area
Symptom(s)
To increase capacity...
To reduce volume...
Client
High client CPU usage.
Install a client CPU with
higher performance.
Simplify (HTML) layout.
Low server CPU usage.
Upgrade to a faster browser. Improve client-side cache.
Some clients fast, some
slow.
Server
Network
CPU usage low on both
servers and clients.
Remove any network
bottlenecks.
Improve/optimize the
configuration of the client
cache.
Browsing locally on the
server is (comparatively)
fast.
Increase network
bandwidth.
Reduce the "weight" of
your web pages (e.g. less
images, optimized HTML).
Cluster your web-servers.
Reduce the hits per page
(visit).
Web-server CPU usage on the webserver is high.
Use a hardware loadbalancer.
Application Server CPU usage is high.
Cluster your CQ5 instances. Search for, and eliminate,
CPU and memory hogs (use
code review, timing output,
etc).
High memory consumption.
Improve caching on all
levels.
Low response times.
Optimize templates and
components (e.g. structure,
logic).
Repository
Cache
5.5 Monitoring, and optimizing, the performance
Performance issues may stem from a number of causes that have nothing to do with your website,
including temporary slowdowns in connection speed, CPU load, and many more.
It may also impact either all your visitors, or only a subset of them.
All this information needs to be obtained, sorted and analyzed before you can optimize the
performance.
If you experience a performance issue:
• try to replicate it: with one (or preferably more) standard web-browsers, on a different client that
you know has good general performance and/or on the server itself (if possible)
Page 17 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Monitor Performance
• check whether anything (related to the system) has changed within an appropriate time-space,
and if any of these changes could have impacted the performance
• collect as much information as possible to compare with your knowledge of the system under
normal circumstances
5.5.1 Tools and mechanisms
The following gives a short overview of some of the tools available for monitoring performance.
Note
Some of these will be dependent on your operating system.
Table 5.2. Tools and mechanisms for monitoring performance
Tool
Used to analyze...
Usage / More information...
request.log
Response times and
concurrency.
Interpreting the request.log.
truss/strace
Page Loads
Unix command. Include the misc.truss log level to
INFO.
Thread dumps
Observe JVM threads. Dependent on the operating system, e.g. kill -QUIT
Identify contentions,
<pid> on Unix/Linux whereas Ctrl-Break on Windows.
locks and long-runners.
System calls
Identify timing issues.
Apache Bench Identify memory leaks,
selectively analyze
response time.
Calls to System.currentTimeMillis() or
com.day.util.Timing are used to generate
timestamps from your code, or via HTML-comments.
Note: These should be implemented so that they can
be activated / deactivated as required; when a system is
running smoothly the overhead of collecting statistics will
not be needed.
For full details: http://httpd.apache.org/docs/2.0/programs/
ab.html; basic usage is: ab -k -n <requests> -c
<concurrency> <url>
Search
Analysis
Execute search queries Analyzing Search.
offline, identify response
time of query, test and
confirm result set.
JMeter
Load and functional
tests.
http://jakarta.apache.org/jmeter/
JProfiler
In-depth CPU and
memory profiling.
http://www.ej-technologies.com/
JConsole
Observe JVM metrics
and threads.
Usage: jconsole
Note: With JDK 1.6 JConsole is extensible with plug-ins;
for example, Top or TDA (Thread Dump Analyzer).
JVisualVM
Observe JVM metrics,
threads, memory and
profiling.
Monitoring Performance using JVisualVM.
Usage: jconsole
Note: With JDK 1.6 JConsole is extensible with plug-ins;
for example, Top or TDA (Thread Dump Analyzer).
Unix/Linux commands.
Page 18 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Monitor Performance
Tool
Used to analyze...
Usage / More information...
truss/strace,
lsof
In depth kernel call and
process analysis (Unix).
Timing
Statistics
See timing statistics for To see timing statistics for page rendering
page rendering.
you can use Ctrl-Shift-U together with ?
debugClientLibs=true set in the URL.
5.5.2 Interpreting the request.log
This file registers basic information about every request made to CQ5. From this valuable
conclusions can be extracted.
5.5.2.1 Monitoring traffic on your website
The request log registers each request made, together with the response made:
09:43:41 [66] -> GET /author/y.html HTTP/1.1
09:43:41 [66] <- 200 text/html 797ms
By totaling all the GET entries within a specific periods (e.g. over various 24 hour periods) you can
make statements about the average traffic on your website.
5.5.2.2 Monitoring response times with the CQ5 request.log
A good starting point for performance analysis is the request log.
You can find the request log at <cq-installation-dir>/crx-quickstart/logs.
The log looks as follows (the lines are shortened for simplicity):
31/Mar/2009:11:32:57
31/Mar/2009:11:32:57
31/Mar/2009:11:33:17
31/Mar/2009:11:33:17
+0200
+0200
+0200
+0200
[379]
[379]
[380]
[380]
->
<->
<-
GET
200
GET
200
/path/x HTTP/1.1
text/html 33ms
/path/y HTTP/1.1
application/json 39ms
This log has one line per request or response:
• The date at which each request or response was made.
• The number of the request, in square brackets. This number matches for the request and the
response.
• An arrow indicating whether this is a request (arrow pointing to the right) or a response (arrow to
the left).
• For requests, the line contains:
• the method (typically, GET, HEAD or POST)
• the requested page
• the protocol
• For responses, the line contains:
• the status code (200 means “success”, 404 means “page not found”)
• the MIME type
• the response time
Page 19 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Monitor Performance
Using small scripts, you can extract the required information from the log file and assemble the
statistics you want. From these, you can see which pages or types of pages are slow, and if the
overall performance is satisfactory.
5.5.2.3 Monitoring search response times with the CQ5 request.log
Search requests are also registered in the log file:
31/Mar/2009:11:35:34 +0200 [338] -> GET /author/playground/en/tools/search.html?
query=dilbert&size=5&dispenc=utf-8 HTTP/1.1
31/Mar/2009:11:35:34 +0200 [338] <- 200 text/html 1562ms
So, as above, you can use scripts to extract the relevant information and build up statistics.
5.5.2.4 Monitoring the numbers and impacts of concurrent users
Again the request.log can be used to monitor concurrency and the system's reaction to it.
Tests must be made to determine how many concurrent users the system can handle before a
negative impact is seen. Again scripts can be used to extract results from the log file:
• monitor how many requests are made within a specific time span e.g. one minute
• test the effects of a specific number of users all making the same requests at (as close as
possible) the same time; e.g. 30 users clicking Save at the same time
31/Mar/2009:11:45:29 +0200 [333] -> GET /author/libs/Personalize/content/statics.close.gif
HTTP/1.1
31/Mar/2009:11:45:29 +0200 [334] -> GET /author/libs/Personalize/content/statics.detach.gif
HTTP/1.1
31/Mar/2009:11:45:30 +0200 [335] -> GET /author/libs/CFC/content/imgs/
logo.rZMNURccynWcTpCxyuBNiTCoiBMmw000.default.gif HTTP/1.1
31/Mar/2009:11:45:32 +0200 [335] <- 304 text/html 0ms
31/Mar/2009:11:45:33 +0200 [334] <- 200 image/gif 31ms
31/Mar/2009:11:45:38 +0200 [333] <- 200 image/gif 31ms
31/Mar/2009:11:45:42 +0200 [336] -> GET /author/libs/CFC/content/imgs/
logo.rZMNURccynWcTZRXunQbbQtvuuCMbRRBuWXz0000.default.gif HTTP/1.1
31/Mar/2009:11:45:43 +0200 [337] -> GET /author/titlebar_bg.gif HTTP/1.1
31/Mar/2009:11:45:43 +0200 [336] <- 304 text/html 0ms
31/Mar/2009:11:45:44 +0200 [337] <- 304 text/html 0ms
5.5.2.5 Using rlog.jar to find requests with long duration times
CQ includes various helper tools located in <cq-installation-dir>/crx-quickstart/opt/
helpers. One of these, rlog.jar, can be used to quickly sort request.log so that requests
are displayed by duration, from longest to shortest time.
The following command shows the possible arguments:
$java -jar rlog.jar
Request Log Analyzer Version 21584 Copyright 2005 Day Management AG
Usage:
java -jar rlog.jar [options] <filename>
Options:
-h
Prints this usage.
-n <maxResults> Limits output to <maxResults> lines.
-m <maxRequests> Limits input to <maxRequest> requests.
-xdev
Exclude POST request to CQDE.
For example, you can run it specifying request.log file as a parameter and show the 10 first
requests that have the longest duration:
Page 20 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Monitor Performance
$ java -jar ../opt/helpers/rlog.jar -n 10 request.log
*Info * Parsed 464 requests.
*Info * Time for parsing: 22ms
*Info * Time for sorting: 2ms
*Info * Total Memory: 1mb
*Info * Free Memory: 1mb
*Info * Used Memory: 0mb
-----------------------------------------------------18051ms 31/Mar/2009:11:15:34 +0200 200 GET /content/geometrixx/en/company.html text/
html
2198ms 31/Mar/2009:11:15:20 +0200 200 GET /libs/cq/widgets.js application/xjavascript
1981ms 31/Mar/2009:11:15:11 +0200 200 GET /libs/wcm/content/welcome.html text/html
1973ms 31/Mar/2009:11:15:52 +0200 200 GET /content/campaigns/geometrixx.teasers..html
text/html
1883ms 31/Mar/2009:11:15:20 +0200 200 GET /libs/security/cq-security.js application/
x-javascript
1876ms 31/Mar/2009:11:15:20 +0200 200 GET /libs/tagging/widgets.js application/xjavascript
1869ms 31/Mar/2009:11:15:20 +0200 200 GET /libs/tagging/widgets/themes/default.js
application/x-javascript
1729ms 30/Mar/2009:16:45:56 +0200 200 GET /libs/wcm/content/welcome.html text/html;
charset=utf-8
1510ms 31/Mar/2009:11:15:34 +0200 200 GET /bin/wcm/contentfinder/asset/view.json/
content/dam?_dc=1238490934657&query=&mimeType=image&_charset_=utf-8 application/json
1462ms 30/Mar/2009:17:23:08 +0200 200 GET /libs/wcm/content/welcome.html text/html;
charset=utf-8
Note
You may need to concatenate the individual request.log files if you need to do this
operation on a large data sample.
5.5.3 Caching
The following diagram shows the different cache locations that can be used for the various content
types.
Figure 5.3. What can be cached where?
The following can act as a rough guide for target values:
Page 21 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Monitor Performance
Figure 5.4. Cache vs. Uncached - maximum hits / second
Although there are many algorithms to ensure that data is retrieved from the source system when
appropriate, circumstances can arise where the data residing in a cache is out of date. Retrieving
every page individually is the only guaranteed method of ensuring your content is up-to-date, but it
is very costly in terms of response, and can indeed cause knock-on effects.
This is particularly relevant when using personalized pages, where at least some content of a
page is dependent on the user, and the account they used to login.
Figure 5.5. Cache speed vs. Data Integrity
Page 22 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Monitor Performance
5.5.3.1 Optimizing your content for cache performance
Make sure you use realistic cache settings for the browser cache. If you have disabled the browser
cache for development, this may increase traffic and decrease responsiveness.
5.5.4 Analyzing Search
First steps to analyzing the search function can be made with Monitoring search response times
with the CQ5 request.log.
However, once you have determined the response time, you may need to analyze why the request
is taking the time it does, and what can be done to improve the response. Further information about
the underlying search functionality of CRX can be found at Searching in CRX.
5.5.5 Monitoring Performance using JVisualVM
Since JDK 1.6 the tool command jvisualvm is available. After you have installed JDK 1.6 you
can:
1.
Either:
a.
Start your CQ5 instance using the -jconsole option.
b.
Add the -Dcom.sun.management.jmxremote argument to the java command line
that starts your JVM.
2.
Run jvisualvm (normally found in the JDK 1.6 bin folder).
3.
From within the Local application, double-click com.day.crx.quickstart.Main:
Note
You can use this tool to generate thread dumps and memory head dumps. This
information is often requested by the technical support team.
5.5.6 Performance when loading and editing Digital Assets
Due to the large volume of data involved when loading and editing digital assets, performance can
become an issue.
Page 23 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Monitor Performance
Two things affect performance here:
• CPU - multipe cores allow for smoother work when transcoding
• Hard disk - parallel RAID disks achieve the same
To improve performance you can consider the following:
• How many assets are going to be uploaded per day? A good estimate can be based on:
• The timeframe in which edits will be made (typically the length of the working day, more for
international operations).
• The average size of images uploaded (and the size of renditions generated per image) in
megabytes.
• Determine the average data rate:
80% of all edits will be made in 20% of the time, so in peak time you will have 4 times the
average data rate. This is your performance goal.
Page 24 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
6 How to Create and Use a Workflow
6.1 Creating a Workflow
First, you must create your workflow. You can then apply an instance of this (version dependent)
when managing your website.
Important
Actions on workflows can only be undertaken if:
• you are working with the admin account
• the account has been assigned to the default group workflow-users, which holds all
the privileges necessary for your users to perform workflow actions.
Note
For simplicity, the following examples have all been made using the admin account.
6.1.1 Creating a new Workflow Model
The actual creation is a small step - a skeleton workflow (with 3 default steps) will be created.
1.
Open the Workflow console.
2.
From the Models tab, select New from the top navigation bar. The New Workflow dialog
opens.
3.
Specify the Title for your workflow.
4.
Click OK to save and close the dialog. You return to the Models tab, where you see your new
workflow in the list.
6.1.2 Editing the Workflow
When you create a new workflow, a skeleton workflow is created with a minimum of steps. For the
workflow to become meaningful, you must edit it.
1.
Open the Workflow console.
2.
From the Models tab, select your workflow.
3.
Either click Edit or double-click the name of the workflow. A new tab (named after the
workflow) opens for editing and configuring the workflow. This shows 3 panes:
Page 25 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Create and Use a Workflow
• Toolbox
Lists the Step and Split types. Click to display the appropriate list, then use drag the
element you want into the appropriate position to build your workflow.
Note
A complete explanation of all types of workflow steps and splits, together with
their related properties, can be found in the section called “The types of Workflow
Steps available”.
• Workflow Model
Contains the graphical representation of your workflow. Here you can position the steps
and splits, edit the workflow name or description and save changes.
The Save button is also located here, as is the Model Version. The Model Version is
incremented every time the workflow model is updated. This is reflected in the monitoring
displays. As multiple versions of a workflow can be in use at any one time, this helps you
track the version being used in each instance.
• Properties
Allows you to edit properties of the individual steps and splits.
Note
A complete explanation of all types of workflow steps and splits, together with
their related properties, can be found in the section called “The types of Workflow
Steps available”.
Three steps have already been created:
Start
A mandatory step to start the workflow. This cannot be edited, nor deleted.
Step 1
A Participant step which is an example. This must be edited, or replaced if required.
Further steps can be added.
End
A mandatory step for every workflow. The End step is used to cleanly terminate the
workflow, or to pass control back to the parent workflow in the case of a child (sub-)
workflow.
Page 26 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Create and Use a Workflow
You can either define a full workflow, or a sub-section of a workflow. Sub-workflows can then
be referenced by other workflows to form part of a complete workflow. This simplifies the
construction of complex workflows, and also allows you to reuse sub-workflows which occur
repeatedly.
4.
Enter a Model Description for the workflow (you can also edit the Model Title) from
the center pane. Click on the field to enter edit mode.
5.
You can now design your workflow by dragging steps onto the Workflow Model, then
configuring the properties.
6.
When finished, Save your model, then close the tab.
6.1.2.1 Example
To illustrate some of the possibilities for creating a workflow, the following example emulates a
variation of the Publish Example workflow.
1.
Edit Step 1 using
on the step itself.
a.
Enter Validate Content for the Title and Description.
b.
Set the User/Group to admin.
c.
Set the Timeout to Off and Timeout Handler empty.
2.
Click Splits to display the list of split types.
3.
Drag an Or Split onto the workflow and position it between Validate Content and End.
An Or Split is added to your workflow.
4.
Edit the left-hand branch:
a.
Click the
icon on the actual branch.
b.
Set Default Route to true.
c.
Click the
icon on New Step in the left-hand branch. This will be a Participant step.
5.
d.
Enter Cancel Publish for the Title and Description.
e.
Set the User/Group to admin.
Edit the right-hand branch:
Page 27 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Create and Use a Workflow
a.
Click the
icon on the actual branch.
b.
Set Default Route to false.
c.
Leave the Rule empty. This is for demonstration purposes.
d.
Click the
icon on New Step in the right-hand branch. Change this from a Participant to a
Process step; the properties available will be updated.
e.
Enter Publish Page for the Title and Description.
f.
Set the Handler Advance to false.
g.
Select com.day.cq.wcm.workflow.process.ActivatePageProcess as the
Implementation script. This implementation will publish the selected page to the publisher
instances.
6.
Now you have specified all steps in your workflow, click Save.
7.
Finally close the tab and return to the main console.
6.2 Using the Workflow
After you have defined your workflow you will want it to be used when managing your website. The
following sections detail the different tasks when using workflows.
6.2.1 Starting the Workflow for an individual page
There are two methods of starting a workflow; from the Workflow Console or the siteadmin:
Page 28 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Create and Use a Workflow
In either case you need to link a workflow to its payload. The payload (including pages, nodes,
resources) will then be subject to this instance of the workflow.
Important
The current version of the workflow model is assigned; if the main copy of the workflow is
updated later then the changes will have no impact on the instance assigned.
Procedure 6.1. Starting a workflow from the workflow console
1.
Open the Workflow console.
2.
From the Models tab select the required workflow.
3.
Click Start from the top navigation.
4.
The Start Workflow dialog opens allowing you to enter the payload and a comment.
Specify the payload (includes pages, nodes, resources, and so on) to which the workflow is
to be applied. You can use the drop down menu to browse the repository when selecting:
5.
Click OK to save your selection and start the workflow. Now the workflow is running.
Procedure 6.2. Starting a workflow from the sidekick
1.
Open the siteadmin.
2.
Open the required page.
3.
Select the Workflow tab from the sidekick.
4.
Expand the Workflow dialog, allowing you to select the Workflow and a enter a Comment.
Page 29 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Create and Use a Workflow
5.
Click Start Workflow to save your selection and start the workflow. Now the workflow is
running.
Once a page has been linked to a workflow it will be indicated in the siteadmin:
6.2.2 Taking actions on a Participant Step
Any participant steps that you have created will be assigned to the specific user or group, who will
need to take action:
• When the task is completed they then acknowledge this fact by completing the workflow step
(see Completing a Participant step).
• If the specific user(s) are unable to take action they can delegate responsibility to another user or
group (see Delegating a Participant step).
• If necessary they can step back to repeat a section of the workflow (see Performing Step Back
on a Participant step).
6.2.2.1 Selecting a Participant Step to take action
Before you can take any action on a Participant step, you need to select it:
Page 30 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Create and Use a Workflow
1.
Open the Workflow console.
2.
Select the Inbox tab to see when an action is assigned to you. This occurs when a workflow
reaches a Participant step with your account, or group, specified:
3.
Select the entry.
6.2.2.2 Completing a Participant step
After you have taken the action indicated you can complete the workflow step, thus allowing the
workflow to continue.
1.
Click the Complete button in the top navigation bar.
2.
In the resulting dialog, select the Next Step; that is, the step to execute next. A drop down
list shows all appropriate destinations. A Comment can also be entered.
Note
The number of steps listed depends on the design of the workflow.
3.
Click OK to confirm the action.
6.2.2.3 Delegating a Participant Step
If a step has been assigned to you, but for any reason you are unable to take action, you can
delegate the step to another user or group.
1.
Click the Delegate button in the top navigation bar.
2.
In the resulting dialog, select the User you want to pass the action to.
A drop down list shows all appropriate users.
Page 31 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Create and Use a Workflow
If the step has been defined with one user, then only this user will be available - the step
cannot be delegated to anyone else.
If a group has been defined, then the list shows the group itself and all individual users within
the group. You can delegate to either the entire group, or an individual user within that group.
A Comment can also be entered.
3.
Click OK to confirm the action.
6.2.2.4 Performing Step Back on a Participant step
If you discover that a step, or series of steps, needs to be repeated you can step back. This allows
you to select a step that occurred earlier in the workflow for reprocessing. The workflow returns to
the step you specify, then proceed from there.
1.
Click the Step Back button in the top navigation bar.
2.
In the resulting dialog, select the Previous Step; that is, the step to execute next - even
though it is a step that occurs earlier in the workflow. A drop down list shows all appropriate
destinations.
Note
The number of previous steps available in the list depends on the design of the
workflow.
Page 32 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Create and Use a Workflow
3.
Click OK to confirm the action.
6.2.3 Suspending, Resuming and Terminating a Workflow instance
Aside from workflow instances that require your immediate action and show up in your Workflow
Inbox, you can perform certain other actions on running workflow instances.
1.
Open the Workflow console.
2.
Select the Instances tab. You will see a list of active (neither finished, nor terminated)
workflow instances.
3.
Select an entry.
4.
To suspend the workflow, click the Suspend button in the navigation bar. The State changes
to Suspended. This can be helpful in exceptional cases when you do not want the workflow
to proceed; for instance for maintenance.
5.
While a workflow is suspended, you can then click Resume. This restarts the workflow from
where it was suspended, with the same configuration. Again the State is updated.
6.
To finally terminate the workflow, click Terminate. This immediately ends the workflow
execution - the state changes to ABORTED. A terminated workflow instance cannot be
restarted.
The Instances tab is not only useful for taking action on running workflows, you can also use it to
monitor workflow instances, without necessarily modifying them.
6.2.4 Monitoring the Status of Workflow Instances
To monitor the status of workflow instances, you can use the Instances or Archive tabs.
Instances tab
Shows all running instances.
Archive tab
Shows terminated workflow instances.
6.2.4.1 Monitoring Workflows in progress
From the Instances tab you can see the status of a Workflow in progress. A list of the active
Models is shown; in this case RUNNING:
Page 33 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Create and Use a Workflow
With the Instances tab you can take various actions (see Suspending, Resuming and
Terminating a Workflow instance) and also Open History to show the actions executed to date
on the workflow instance:
6.2.4.2 Archived Workflows
After a Workflow instance has finished, for whatever reason (terminated, as below, or after
successful completion), it can (only) be seen in the Archive tab:
As the workflow has already completed, no further action can be taken on these instances.
However, if you need further details of a completed workflow you can use Open History.
6.3 Using the Workflow Launcher for Node Modifications
The Workflow Launcher, provides one component to monitor all changes in the content repository
and launch workflows dependent on the location and resource type of the changed node.
Using the Launcher tab you can:
• see the workflows already launched for specific nodes.
• select a workflow to be launched when a certain node/node-type has been modified.
• remove an existing workflow-to-node relationship.
Various definitions are included with the standard installation. These are used for digital asset
management and social collaboration tasks:
Page 34 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Create and Use a Workflow
6.3.1 Adding a Launcher relationship
1.
Open the Workflow tab.
2.
Select the Launcher tab.
3.
Click Add... and configure the new workflow-to-node relationship as required:
Event Type
Define the event type that will launch the workflow:
• Created
• Modified
• Removed
Nodetype
Select the nodetype from the drop down list.
Path
Define the path for which the launch entry is to be applied.
Condition
Define any conditions which may apply on node property values.
Page 35 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Create and Use a Workflow
For example, to check whether a node has a property “name” holding the value “User”
specify name==User.
Workflow
The workflow to be launched when the Event Type occurs on the Nodetype and/or
Path under the defined Condition.
Description
A description for the relationship.
6.3.2 Removing a Launcher relationship
1.
Open the Workflow tab.
2.
Select the Launcher tab.
3.
Click on the entry you want to remove.
4.
Click Remove.
Page 36 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
7 Multi Site Manager
This section describes the functionalities of the CQ5 Multi Site Manager (MSM).
With CQ5, you can manually manage multiple sites. When the number of sites in the same
language is low (three to five), a manual process is most efficient. However, as soon as the number
of sites grows or when multiple languages are involved, it becomes more efficient to use an
automated functionality: the MSM. The MSM lets you define relations between the sites and also
lets you define to what degree re-use or control is exerted on the different sites. The MSM, once
set up, does this automatically.
MSM reduces the time it takes to manage your websites and increases re-use for:
• Different language editions of a website
• Automatic updates of one or more sites based on a source site. It allows you to:
• Enforce a common base structure and common content across all versions of the website.
• Provide structure and content that the sites can freely use, thus avoiding duplicated work and
improving the unified look and feel.
• Focus on the differences between the sites.
• Manage the content based on a fine level of granularity as the inheritance of the content and
structure can be managed at a page and/or paragraph level.
7.1 Typical Use Cases for the Multi Site Manager
This section describes several scenarios where using the MSM is easier than maintaining sites
manually.
7.1.1 Multinational Site
ENT Corporation, a large distributed enterprise, has a large number of subsidiaries in various
countries. All of them share a similar look-and-feel. These sites share various components with one
another and most are centrally hosted.
Corporate Communications at ENT can use MSM features to propagate press release content
to all the various press release pages of each of the countries' websites. This is done simply by
making the press releases section of the source website mandatory.
Additionally, the Knowledge Management department at ENT has gathered a large collection of
FAQs that apply to most countries. To allow the surfer to stay in his or her respective country's
website yet have access to the FAQ appropriate to that country, this content can be offered as
optional on the MSM source site. As a result, the owner of a particular country's web site can
subscribe to the content that is appropriate for that site. The content is not "forced" on the owner of
a site.
Some time later, because of the reorganization of the site, the press releases section is moved to
another location in the navigation on the source site. Because of MSM, this change is reflected
automatically in all subsidiary sites.
7.1.2 Multilingual Site
UNORG, a multinational organization, hosts a website in 15 languages.
Experience has shown that multilingual websites often share a number of characteristics:
Page 37 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager
• Content trees are not identical in different languages.
• There is almost never a "lead" language in which all the content is available.
• It is not just about text (images mean different things in different cultures).
• Internal document structures (content objects) in different languages, or even different
geographies with the same language, are often different, for example, because of differing legal
requirements.
• The "if-language-is-not-there-then-switch-to-default-language" scenario almost never works (a
French surfer does not appreciate suddenly being thrown into a section of English content).
But, despite all of these differences between different language sections, there is also a certain
coherence between the languages that needs to be maintained.
The Language Manager monitors the differences between language sections and allows for the
clean up of any differences between the various language trees, thus helping to keep the sections
synchronized.
7.1.3 Multinational Multilingual Site
ENT Corporation, a large distributed enterprise, with a large number of subsidiaries also has a
number of subsidiaries in countries like Switzerland, Belgium, and Canada that have to support a
number of different languages per national site. But the set of supported languages per site must
be decided on a per-country basis.
The combination of the Language Manager and the Multi-Site Manager lets you precisely control
which content is visible in which country and how the various languages are managed and kept
synchronized on a per-country level.
7.2 Managing Different Language Versions of a Website
This section describes how to add a new language version of a web site using the Language Copy
tool:
1.
In the Websites tab, in the left pane, select the site.
2.
In the right pane, make sure that the Names of the language pages are ISO language
abbreviations (for example: en , fr, de). Check the ISO specifications for more information.
3.
Add a new language branch to the site:
1.
Click New... .
2.
In the dialog, specify the Title and the Name (the name must be an ISO language
abbreviation). Select the Template and click Create.
Page 38 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager
4.
In the Websites tab, in the left pane, select the site.
5.
In the Tools menu, select Language Copy.
6.
The Language Copy dialog opens. It displays a matrix of the language versions available
for individual pages. An x in a language column means that the page is available within the
language tree.
7.
To copy an existing page or page tree to a specific language first select the appropriate empty
cell. Then click the arrow and select the type of copy in the drop-down menu.
Page 39 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager
Table 7.1. Type of Language Copy
auto
Uses the behavior from parent pages
ignore
Cancels the copy for this page and its
children
<language>+ (e.g. French+)
Copies the page and all its children from that
language
<language> (e.g. French)
Copies only the page from that language
8.
Click OK to close the dialog.
9.
In the next dialog, click Yes to confirm the copy.
7.3 Managing the Translation of your Language Branches
When your website consists of several language branches and when you create a new page in
your reference language branch, you can start a translation workflow that automatically creates
new pages in the language branches of your choice and helps you translate the pages by
displaying side-by-side the page to be translated and the reference page.
This procedure describes how to start the translation workflow and how to display the reference
page beside the page that needs to be translated.
Important
The website must have at least two language branches.
1.
In the Siteadmin tab create a new page in your reference language branch, for example,
English.
2.
Open the new page and add the desired text.
3.
In the Sidekick, in the Workflow tab, select Translation:
Page 40 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager
1.
Check the language branch(es) into which you would like to have a new page created.
2.
In the Workflow drop-down menu, select Translation.
3.
Click Translate.
The reference page is being copied into the selected language branch(es).
4.
Activate the reference page. A new version of the page is created.
5.
Open the page that needs to be translated. Edit the text that has been copied from the
reference page and translate it. Save your changes.
6.
Open the reference page and add new content to it.
7.
Activate the reference page. A new version of the page is created.
8.
Open the page that needs to be translated.
9.
In the Sidekick, in the Workflow tab, select Translation to see the changes that have
been made in the reference page since a specified version. Check this version and click Show
Side-By-Side.
10. The reference page is displayed beside the page that needs to be translated. The text that
has been added since the selected version is red and underlined.
Page 41 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager
Note
The reference page is only displayed and cannot be edited.
11. Edit the text that needs to be translated and translate it. Save your changes.
12. To close the view of the reference page, click Hide in the Sidekick.
Repeat previous steps every time new content is added to the reference page and needs to be
translated in one or more language branches.
7.4 Managing Blueprints and Live Copies
MSM lets you create a site (called a Live Copy) based on another site (called a Blueprint) and to
actively manage the relationships between the Blueprint and the Live Copy. The Blueprint defines
structure and content centrally. The structure and content can then be used on the Live Copy.
7.4.1 Creating a Live Copy
This section explains how to create a Live Copy, which is a copy of another site called a Blueprint
and is actively linked to the Blueprint.
With CQ5 it is possible to:
• Create a Live Copy based on a predefined Blueprint
• Create a Live Copy based on an existing site or on any page and its sub pages
Note
A Live Copy can only be linked to one Blueprint.
A Blueprint can be linked to several Live Copies.
7.4.1.1 Creating a Live Copy based on a Blueprint
This section describes:
• how to create a Blueprint by defining an existing site as a Blueprint.
Page 42 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager
• how to create a Live Copy based on an existing Blueprint.
Note
If the Blueprint already exists, the first section can be skipped.
7.4.1.1.1 Creating a Blueprint
This section explains how to create a Blueprint by defining an existing site as Blueprint. A single
Blueprint can be used to create as many Live Copies as needed.
To create a Blueprint:
1.
Select the Tools tab.
2.
In the left pane, under the Tools folder, select the Blueprints folder. In the right pane,
click New... .
3.
In the dialog, specify a title and a name. Click Create to close the dialog.
4.
Refresh the Page List. Right-click the newly created page and select Open in the drop-down
menu.
5.
The page opens. Click Edit.
6.
In the dialog, in the Settings tab:
• Name: name the Blueprint
• Description: describe the Blueprint (this is not mandatory)
• Source Path: set the site path of the Blueprint:
1.
Click the arrow to open a dialog.
2.
In the dialog, navigate to the desired site. Click OK to close the dialog.
Page 43 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager
Note
You can also type the absolute path of the site.
Note
The Source site must have the same site structure as Geometrixx for its
languages and chapters (children pages of the language pages).
7.
In the Thumbnail Image tab: specify a thumbnail (this is not mandatory). It will appear in
the dialog when creating a Live Copy.
8.
Click OK to close the dialog.
9.
The Blueprint definition page looks as follows:
Page 44 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager
7.4.1.1.2 Creating a Live Copy based on a Blueprint
This section describes how to create a Live Copy based on an existing Blueprint.
1.
In the Websites tab, in the left pane, select the Websites folder.
2.
Click the arrow beside the New... button and select New Site... .
3.
In the dialog, specify a title and a name for your site and select the desired Blueprint. A
sequence is displayed at the bottom of the dialog (the sequence might take a few seconds to
be collated and displayed). Click Next.
4.
Select the languages of the Blueprint to be copied to the new site. Click Next.
Page 45 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager
5.
Select the main chapters of the Blueprint to be copied to the new site. Click Next.
6.
Select the Site Owner account to be responsible for this site (e.g.: admin). Click Next.
Note
The Site Owner entry is saved but currently not used within CQ5.
Page 46 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager
7.
Specify following parameters:
• Sync Trigger defines when the modifications on the Blueprint are propagated to the Live
Copy. Choose one of the following values:
• Never: the modifications will never be propagated. The Live Copy is then a plain copy of
the Blueprint at the time of creation.
• On Rollout: the modifications are propagated when rollout is activated. For more
information on rollout, refer to the section called “Rolling out Changes on the Blueprint to
the Live Copy”.
• On Modification: the modifications are propagated for each modification to the
Blueprint.
Note
Be careful when choosing this option as it might cause a lot of network traffic.
• On Activation: the modifications are propagated when the Blueprint is activated.
• Update Content:
• If checked, modifications to the Blueprint will be propagated.
• If unchecked, modifications to the Blueprint will not be propagated. This option should
only be used in combination with a workflow.
• Enable Notification: if checked, you will be notified when the modifications are
propagated.
Note
In order to be notified, you first need to subscribe to rollout.
• Start Workflow: select the workflow to be started when the synchronization actions are
triggered. Refer to Chapter 1, to define your own workflow.
Page 47 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager
• Read only for: select the group that will have read-only access to the Live Copy. This
option prevents a group from modifying the Live Copy.
Click Next.
8.
Click Create Site to create the Live Copy.
9.
When the Live Copy is created, it is displayed in the Websites tab:
Page 48 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager
7.4.1.2 Creating a Live Copy based on an existing Site
To create a Live Copy based on an existing site or on any page and its sub pages:
1.
In the Websites tab, in the left pane, select the location where the Live Copy will be created.
2.
In the right pane, click the arrow beside New..., then select New Live Copy... .
3.
In the dialog, specify following parameters:
• Title: choose a title for the Live Copy.
• Name: choose a name for the Live Copy.
• Live Copy From: define the Source path:
1.
Click the arrow to open a dialog.
2.
Navigate to the desired site or sub-site and click OK to close the dialog.
Note
You can also type the absolute path of the site.
• Sync Trigger defines when the modifications on the Blueprint are propagated to the Live
Copy. Choose one of the following values:
• Never: the modifications will never be propagated. The Live Copy is then a plain copy of
the Blueprint at the time of creation.
• On Rollout: the modifications are propagated when rollout is activated. For more
information on rollout, refer to the section called “Rolling out Changes on the Blueprint to
the Live Copy”.
• On Modification: the modifications are propagated for each modification to the
Blueprint.
Note
Be careful when choosing this option as it might cause a lot of network traffic.
• On Activation: the modifications are propagated when the Blueprint is activated.
• Update Content:
• If checked, modifications to the Blueprint will be propagated.
• If unchecked, modifications to the Blueprint will not be propagated.. This option should
only be used in combination with a workflow.
Page 49 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager
• Enable Notification: if checked, you will be notified when the modifications are
propagated.
Note
In order to be notified, you first need to subscribe to rollout.
• Start Workflow: select the workflow to be started when the synchronization actions are
triggered. Refer to Chapter 1, to define your own workflow.
• Read only for: select the group that will have read-only access to the Live Copy. This
option prevents a group from modifying the Live Copy.
4.
Click Create to close the dialog and create the Live Copy.
5.
When the Live Copy is created, it is displayed in the Websites tab.
Page 50 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager
7.4.2 Configuring Synchronization Actions between a Blueprint and its Live
Copy
CQ5 lets you configure synchronization actions between a Blueprint and its Live Copy. These
actions can be configured on both a Blueprint and/or on a Live Copy page. When configuring the
synchronization actions you should be aware of the following:
• When a Blueprint is created, no synchronization actions are saved to the Blueprint pages.
• When configuring a synchronization action on a Blueprint page, the action is only saved to the
selected Blueprint page. Blueprint children pages do not inherit actions.
• When a Live Copy is created, the synchronization actions are only saved to the Live Copy root
page.
• When configuring a synchronization action on a Live Copy page, the action is only saved to the
selected Live Copy page.
• When you select a Live Copy page (called page A here) that does not have any actions explicitly
saved to it, the tree is scanned upwards until the first parent page with actions is found:
• those actions are then used for the selected page (but not saved to the selected page) if no
actions are saved to the corresponding Blueprint page of the Live Copy page A.
• if actions are saved to the corresponding Blueprint page of the Live Copy page A, those
actions are then used for the selected page A (but not saved to the selected page A).
Following graphic explains the inheritance process:
Page 51 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager
7.4.2.1 Configuring Synchronization Actions on a Blueprint page
To configure synchronization actions on a Blueprint page:
1.
In the Websites tab, in the right panel, right-click the Blueprint page and select Properties
in the drop-down menu.
Note
You can also open the page and click Page Properties... in the Sidekick.
2.
In the dialog, select the Blueprint tab:
• Current Live Copies: lists all the Live Copies currently linked to this Blueprint. It is not
possible to modify this list.
Page 52 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager
• Update Content:
• If checked, modifications to the Blueprint will be propagated.
• If unchecked, modifications to the Blueprint will not be propagated.. This option should
only be used in combination with a workflow.
• Enable Notification: if checked, you will be notified when the modifications are
propagated.
Note
In order to be notified, you first need to subscribe to rollout.
• Start Workflow: select the workflow to be started when the synchronization actions are
triggered. Refer to Chapter 1, to define your own workflow.
• Read only for: select the group that will have read-only access to the Live Copy. This
option prevents a group from modifying the Live Copy.
Note
If the selected page is also a Live Copy, the Live Copy tab is activated. Otherwise,
it is deactivated.
3.
Click OK to close the dialog.
Page 53 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager
7.4.2.2 Configuring Synchronization Actions on a Live Copy page
To configure synchronization actions for a Live Copy page:
1.
In the Websites tab, in the right panel, right-click the Live Copy page and select
Properties.
Note
You can also open the page and click Page Properties... in the Sidekick.
2.
In the dialog, select the Live Copy tab:
• Live Copy from: displays the Blueprint path.
• Live Copy cancelled: if checked, the Live Copy page is not linked to the Blueprint
anymore.
• Informative text:
• Displays as follows when the current page is the Live Copy root page:
• Displays as follows when the actions are inherited from a parent page:
• Displays as follows when the actions are saved to the current page:
It is possible to restore parent configurations by clicking reset the configuration.
• Sync Trigger defines when the modifications on the Blueprint are propagated to the Live
Copy. Choose one of the following values:
• Never: the modifications will never be propagated. The Live Copy is then a plain copy of
the Blueprint at the time of creation.
• On Rollout: the modifications are propagated when rollout is activated. For more
information on rollout, refer to the section called “Rolling out Changes on the Blueprint to
the Live Copy”.
• On Modification: the modifications are propagated for each modification to the
Blueprint.
Note
Be careful when choosing this option as it might cause a lot of network traffic.
• On Activation: the modifications are propagated when the Blueprint is activated.
• Update Content:
• If checked, modifications to the Blueprint will be propagated.
Page 54 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager
• If unchecked, modifications to the Blueprint will not be propagated.. This option should
only be used in combination with a workflow.
• Enable Notification: if checked, you will be notified when the modifications are
propagated.
Note
In order to be notified, you first need to subscribe to rollout.
• Start Workflow: select the workflow to be started when the synchronization actions are
triggered. Refer to Chapter 1, to define your own workflow.
• Read only for: select the group that will have read-only access to the Live Copy. This
option prevents a group from modifying the Live Copy.
Note
If the selected page is also a Blueprint, the Blueprint tab is activated. Otherwise,
it is deactivated.
3.
Click OK to close the dialog.
7.4.3 Rolling out Changes on the Blueprint to the Live Copy
Rolling out consist of propagating the changes made on the Blueprint to the Live Copy.
This section describes how to roll out the changes from the Blueprint to the Live Copy.
Page 55 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager
The following rules apply for a rollout:
• A rollout can only be triggered on the Blueprint. There is one exception to this rule: when a
paragraph is re-locked on a Live Copy page, a rollout is automatically triggered on a Live Copy.
• A rollout can be triggered for one page or for a page and all its sub-pages.
• A rollout can be triggered for a paragraph.
To roll out the changes from the Blueprint to the Live Copy:
1.
Open the Blueprint page.
2.
In the Sidekick, in the Page tab, select Rollout Page.
3.
In the dialog, select the Rollout Scope:
• Rollout entire page to only roll out the page.
• Rollout page and all sub pages to roll out the page and all its sub pages.
• Rollout selected components to roll out the paragraphs selected in the page.
• Delete + rollout selected components: when this option is checked, the selected
components are deleted on the Blueprint and the deletion of the selected components is
propagated to the Live Copies.
Click Next to reach the next step.
4.
In the next dialog, select the Live Copy(ies) to be updated and click Rollout.
Page 56 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager
Note
In a Live Copy page, the Rollout Page button is deactivated.
Note
Media assets originating from CQ DAM (Digital Asset Management) are referenced in
Blueprints and Live Copies. When an asset is modified in the DAM, the modified asset
is rendered in the Blueprint and the Live Copy. A rollout is not needed to propagate the
change. This asset has its own life cycle and is independent from the Blueprint and the
Live Copy.
7.4.4 Live Copy status at Page and at Paragraph level
Live Copy status are displayed as follows:
• the Websites tab displays colored indicators for the Live Copy pages.
• the Live Copy page displays visual indicators for all its paragraphs.
7.4.4.1 Live Copy Page Status
The Websites tab displays colored indicators for the Live Copy pages. Moving the mouse cursor
over the icon displays the detailed status.
Page 57 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager
A Live Copy page has one of the following icons:
Table 7.2.
Icon
Description
Live Copy from the Blueprint page <path of the page>.
(green)
The page contains paragraphs for which Live Copy has been cancelled (lock open
on the Live Copy).
(grey)
The page has been created on the Live Copy.
(blue)
The Blueprint page <path of the page> has been deleted.
(red)
Either the Live Copy or the Blueprint page <path of the page> has been locally
modified.
(yellow)
7.4.4.2 Live Copy Paragraph status
7.4.4.2.1 Viewing the paragraph status of a Live Copy page
To view the status of a Live Copy paragraph:
1.
Open the Live Copy page.
2.
In the Sidekick, click the Live Copy Status button to view the status of all the paragraphs
of the page:
Page 58 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager
3.
The status of the paragraphs are displayed on the page as follows:
Page 59 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager
Each paragraph within a Live Copy page has one of the following statuses:
Table 7.3.
Frame
color / Icon
Description
The Live Copy paragraph is in lockstep with the Blueprint paragraph: modifications
to the Blueprint paragraph will be propagated to the Live Copy paragraph.
(green frame)
This is the default status after creating a Live Copy page.
The Live Copy paragraph is not in lockstep with the Blueprint paragraph. Deletion,
update or reordering of the Blueprint paragraph does not affect the Live Copy
paragraph anymore.
(red frame)
The paragraph has this status when:
Page 60 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager
Frame
color / Icon
Description
• the Live Copy paragraph has been modified (e.g. when modifying some text or
styles)
• the inheritance has been cancelled by clicking the lock icon of the Live Copy
paragraph
When a Live Copy paragraph container (e.g. a paragraph system) has this status,
the order of the paragraphs inside the container is not inherited from the Blueprint
anymore.
no frame / no
icon
The paragraph has been created in the Live Copy page. It does not appear in the
Blueprint page.
7.4.4.2.2 Cancelling the inheritance of a paragraph
To cancel the inheritance of a paragraph:
1.
Follow the steps according to the procedure in the section called “Viewing the paragraph
status of a Live Copy page”.
2.
On the page displaying the status of the appropriate paragraph, click the closed lock icon of
that paragraph.
3.
In the dialog, click Yes to cancel the inheritance .
4.
After the page has been refreshed, the open lock icon will be displayed.
7.4.4.2.3 Reverting the inheritance of a paragraph
To revert the inheritance of a paragraph:
1.
Follow the steps according to the procedure in the section called “Viewing the paragraph
status of a Live Copy page”.
2.
On the page displaying the status of the appropriate paragraph, click the open lock icon of
that paragraph.
3.
In the dialog, click Yes to revert the inheritance .
4.
After the page has been refreshed, the closed lock icon will be displayed.
Page 61 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager
7.4.5 Managing Blueprints and Live Copies
This section describes:
• how to display the list of existing Blueprints
• how to manage a Blueprint and its Live Copies
7.4.5.1 Displaying the list of Blueprints
To display the list of existing Blueprints:
1.
Select the Tools tab.
2.
In the left pane, double-click the Blueprints folder.
3.
A list of all Blueprints is displayed, with the following parameters:
• Thumbnail
• Title
• Description
• Site Path
• View / Edit: click the link to edit the Blueprint.
• Rollout: click the link to roll out the changes to the Live Copies.
7.4.5.2 Editing a Blueprint
To edit a Blueprint:
1.
Open the Blueprint definition page:
• Either: in the Tools tab, in the left pane, select Blueprints and open the desired
Blueprint definition page.
Page 62 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager
• Or: from the Blueprints list, click the desired link in the Status column.
2.
The Blueprint definition page is displayed as follows:
• The first part displays the Blueprint settings:
• The second part displays a button to edit the Blueprint settings:
• The last part displays following matrix:
• The first column displays the Blueprint site which can be expanded by clicking the +
beside the page.
• The following columns display the status of the Live Copy pages linked to the Blueprint.
Hovering the mouse cursor over the status icon displays a precise description of the
status.
Page 63 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager
3.
Select a Blueprint page from the matrix to edit its properties:
4.
Modify the properties. Click Save to save the modifications.
5.
Select a Live Copy page from the matrix to edit its properties:
6.
Modify the properties. Click Save to save the modifications.
7.4.6 Moving Blueprint and/or Live Copy pages
Following behaviors apply when moving Blueprint and/or Live Copy pages:
• When you move a Blueprint root page, you have to reference all the pages of all the Live Copies
in the appropriate dialog. The Blueprint root page is moved and all the Live Copy pages remain
linked to this Blueprint.
• When you move any other Blueprint page, the page is moved but it is considered deleted on the
Blueprint by the Live Copy. The Live Copy page will be deleted on the next rollout.
• When you move a Live Copy root page, the page and all its sub-pages are moved and remain
linked to the Blueprint.
• When you move any other Live Copy page, the page is moved. If a version of the page has not
been created, the original page will be re-created on the next rollout. Otherwise, the page is
considered as deleted.
Page 64 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
8 Upgrading to CQ5
8.1 How to Upgrade Your Communiqué Instance (3 or 4) to CQ5
The upgrade tool allows you to launch a standardized upgrade process. It is delivered with a
configuration to be used “out of the box,” though several settings can be updated when necessary.
You:
• provide the URL of the Communiqué instance to be upgraded, together with the superuser
access credentials
• can configure a list of page handles to be included in the upgrade
• can set debug parameters if required.
Note
The following procedure uses a standard Communiqué 4 installation, complete with
Playground and DesignGround, to illustrate the upgrade process.
Important
If the remote Communiqué 4 instance is accessed through the dispatcher, the dispatcher
configuration must not exclude /system from being served. Many dispatcher
configurations exclude /system. You can also list the URLs that need to be accessible
through the dispatcher for the upgrade script.
1.
Navigate to the Upgrade window, by one of the following methods:
a.
Select the Tools tab in CQ WCM, click on Importers to open the folder, then
Double-click on the Upgrade from CQ3/CQ4 Page to open.
b.
Navigate directly to http://<cq-context-path>/etc/importers/upgrade.html
for example, http://localhost:4502/etc//importers/upgrade.html (if not
already logged in you will be required to).
In either case the following form displays:
Page 65 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Upgrading to CQ5
2.
Update any of the default settings if required.
Important
The upgrade tool uses the password superuser as default. Please ensure that the
password is correct for the instance you are upgrading.
3.
Click Migrate to start the process. A status message will shown and information about the
individual pages being processed will be added while the upgrade is running:
Page 66 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Upgrading to CQ5
4.
When complete you can access the upgraded items in your CQ5 instance:
Important
You must test the operation of the upgraded website; highly customized items may
need to be upgraded separately.
Note
This mechanism can also be used as the basis for a customized upgrade routine,
developed as part of your project.
8.2 Upgrading from CQ 5.1 to CQ 5.2
8.2.1 Important information to read before starting the upgrade
Please read the following points and take action where necessary:
• This upgrade procedure only works if the CQ 5.1 installation was performed with Quickstart. As
opposed to installation with a third party application server.
• You must test the operation of the upgraded website; highly customized items may need to be
upgraded separately.
Page 67 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Upgrading to CQ5
• Beginning with CQ 5.2 the Text Components add a HTML paragraph tag around the text.
Prior versions did not always do that. Adding the paragraph tag might cause visual differences.
Make advance tests (edit a test object) to confirm whether this occurs with your installation. If
necessary adapt the CSS selector, and note the changes necessary after the upgrade.
• Check whether you have any extremely large character strings in your repository.
See Step 6 for further information.
• If OSGi bundles and configurations have been setup directly from the OSGi console (as opposed
to storing them in the JCR repository) the configuration should be saved before the upgrade.
This is done by:
• saving the output of /system/console/config
and
• saving a copy of the crx-quickstart/launchpad folder
As the crx-quickstart/launchpad folder is deleted before the upgrade, then the bundles
and configurations must be restored manually after the upgrade,
• Be aware that certain default content is impacted by the upgrade:
• Default content under /etc is replaced by the upgrade.
If you need this content then please save the original content tree (for example, as etc_51)
before the upgrade. After the upgrade is complete you can re-insert any differences manually.
• Any changes that you have made to the repository folders containing CQ 5.1 software (/libs
and others) might be lost after this upgrade.
• Content packages delete everything under the path(s) that they impact. Therefore, content
created under /content/geometrixx will be deleted by the upgrade to CQ 5.2.
• The upgrade procedure deletes everything under:
• /content/geometrixx
• /apps/geometrixx
• /etc/designs/geometrixx
• /libs/
• The cq-security-content package is not reinstalled when upgrading, the old version is kept.
You must manually update the permissions after the upgrade. You must make the group
contributor a member of the group uploader.
• Replication configuration settings are reset during the update. You need to reconfigure these
after the upgrade, using the new Replication configuration under Tools.
• The default workflows are overwritten during the upgrade, so any customizations are lost. Please
take a copy of these if required.
8.2.2 Preparing for the upgrade from CQ 5.1 to CQ 5.2
All preparation steps must be checked to ensure a smooth upgrade:
Page 68 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Upgrading to CQ5
1.
Ensure you have a full backup of your CQ 5.1 instance.
2.
Ensure that the CQ 5.1 installation was made using Quickstart.
3.
Ensure that you have at least 2GB of free diskspace.
4.
Ensure that the system account you are using has sufficient privileges to replace the jar file.
5.
Ensure that the crx-quickstart/repository folder that contains your repository data is
binary compatible between the CQ 5.1 and 5.2 versions.
Note
Ensure that no changes (hotfixes or customizations) have been applied to the
repository folder that make it incompatible with the 5.2 version that is about to be
installed.
If you are in doubt please check with Day.
6.
Request the cleanupMessage.jsp script from Day.
8.2.3 Upgrading your CQ 5.1 instance to CQ 5.2
Updating your CQ 5.1 instance to a CQ 5.2 instance requires the following steps:
Important
Please read the section called “Important information to read before starting the upgrade”
before starting the upgrade.
Important
Please complete all preparation steps as in the section called “Preparing for the upgrade
from CQ 5.1 to CQ 5.2”.
1.
Delete the crx-quickstart/launchpad folder.
2.
Run the cleanupMessage script:
1.
Copy the cleanupMessage.jsp file to your author environment:
<cq-installation-dir>/crx-quickstart/server/runtime/0/_crx/
config/cleanupMessage.jsp
Adapt the path as necessary.
2.
Start your CQ 5.1 instance, then navigate to your CRX console, for example:
http://localhost:4502/crx (adapt as necessary).
3.
Log in as admin to the workspace where CQ is installed; for example crx.default.
4.
Open the script at:
http://localhost:4502/crx/config/cleanupMessage.jsp (adapt as
necessary).
5.
Only the following properties are changed:
• with the name “message” under the specified node
• those that are longer than the specified size
Page 69 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Upgrading to CQ5
The default settings should be correct in all cases.
6.
Start the script using 'clean'.
7.
The output is formed of the nodes that contain a message property.
The prefix “cleaned:” means the text was truncated, while “ignored:” means the text was
short and therefore unchanged.
Tip
After the script is run, you may reduce the repository size using Tar PM
Optimization.
3.
Stop your CQ 5.1 instance.
4.
Copy the new jar file to the location of the currently installed jar file:
<cq-installation-dir>/
Caution
If you had changed the name of your CQ 5.1 jar file, then rename the CQ 5.2 jar file
to that of the existing file.
For example, if it had been renamed for an author environment:
<cq-installation-dir>/cq-author-4502.jar
Or a corresponding publish environment:
<cq-installation-dir>/cq-publish-4503.jar
5.
Start CQ 5.2; in the same manner as with your CQ 5.1 instance, by a double-click on the
jar file, or from the command line.
Note
This step will take longer than a normal startup as the new 5.2 content packages
have to be installed.
6.
Restart CQ 5.2. The upgrade will now be complete.
8.2.4 Upgrading your CQ 5.1 Digital Assets
The structure of digital assets has changed between CQ 5.1 and CQ 5.2. For this reason a wizard
is included to automate the process of moving the assets to the new structure:
1.
Ensure that you have a backup of your newly upgraded repository.
2.
Start your newly upgraded CQ 5.2 instance.
3.
Navigate to:
http://localhost:4502/libs/dam/migrate.html
Page 70 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Upgrading to CQ5
4.
Click Start migration. A status message will be shown upon completion:
Note
After the upgrade script has finished it might take some time until all assets
reappear for use, as they are being processed in the background. You can monitor
stdout.log to see when everything has been finished.
Note
The upgrade removes the replication state on the assets.
8.2.5 Tasks to perform after the upgrade
The following tasks should be performed after the upgrade:
1.
The CQ 5.1 jar file is not needed after the upgrade and if still present, should be removed
from the installation folder to avoid confusion.
2.
Reinstall any customized OSGi bundles (if you had manually installed them before).
3.
Restore any customized configurations you had made on the file system:
• /server/runtime/0/_crx/WEB-INF/repository.xml; for example, search engine
settings.
• /server/etc/; for example, LDAP configurations.
4.
Restore any customized configurations from the Apache Felix Console:
• Mail Service
• Day Commons GFX Font Helper
Page 71 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Upgrading to CQ5
• SSO Authentication Handler
• Apache Sling Resource Resolver
Note
CQ 5.2 adds a new default rule /content/-/ that you might want to remove.
5.
Restore any customized configurations in CRX:
• URL to tracker.js: /libs/wcm/config.publish/
com.day.cq.wcm.core.stats.PageViewStatistics
6.
Reconfigure the replication configuration settings, using the new Replication configuration
under Tools.
7.
The cq-security-content package is not reinstalled when upgrading, the old version is
kept.
You must manually update the permissions after the upgrade, by making the group
contributor a member of the group uploader.
8.
Check all forms on the site. If you had used the custom form action you need to change the
dialog to fit the new structure.
9.
Beginning with CQ 5.2 the Text Components add a HTML paragraph tag around the text.
Prior versions did not do always do that. Adding the paragraph tag might cause visual
differences. If necessary adapt the CSS selector - as according to your tests in Important
information to read before starting the upgrade.
8.2.6 The final status of your upgraded instance
The resulting system is identical to a fresh CQ 5.2 installation, with the user's content preserved
(assuming it was not stored in any repository folders that contained the CQ 5.1 software).
Page 72 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
9 Installing CQ5
9.1 How to Install CQ WCM Author and Publish Instances using
Quickstart
This section describes how to install CQ WCM.
Generally, when you set up CQ WCM, you need to set up an Author and a Publish instance see the section called “Author and Publish Environments” for further details on the two types of
environment.
Installation procedures for these are described in Installing an Author instance and Installing a
Publish instance. If, for testing or other purposes, you need to install CQ WCM out of the box (an
author instance with default settings and file names), you can use the generic procedure.
9.1.1 Installing an Author Instance
This procedure describes how to set up a default Author instance on port 4502 of the desired host.
To install an author instance:
1.
On the host file system, create a directory and name it author.
2.
Copy the CQ5 cq-wcm-quickstart-<version>.jar file into author/.
3.
Rename cq-wcm-quickstart-<version>.jar to cq5-author-4502.jar. If you need
a different port this can be set in the filename.
4.
Copy a valid license.properties file into author/ as well (the same directory as the
cq5-author-4502.jar file).
Note
If when starting the application, you do not provide the license.properties file,
CQ WCM redirects you to the Welcome screen where you enter a valid license key.
You can also request a valid license key from Day at this time.
5.
Start CQ WCM Quickstart:
• If using a GUI file-system explorer, double-click the cq5-author-4502.jar file.
• If using the command line, type:
java -jar cq5-author-4502.jar
• Use a custom script located in the crx quickstartfolder, such as server.bat to start
CQ. The Start and Stop scripts are for UNIX, Linux, and Macintosh. The server.bat
script is for Windows.
Important
You cannot use a custom script when you install the quickstart.jar file
unless you expand the file first. Use the -unpack option on the command line
to unpack the contents before running the script as in java -jar cq-wcmquickstart-<version>.jar -unpack.
6.
When the installation is completed, you are automatically redirected to http://
localhost:4502/bin/login.html.
Page 73 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Installing CQ5
Note
With the default settings, the syndication agent points toward the publish instance at
http://localhost:4503/.
9.1.2 Installing a Publish Instance
To set up a publish instance on port 4503 of the desired host, you perform the same steps as
in installing an author instance except that you create a directory named publish (instead of
author) and you rename the quickstart.jar file as cq5-publish-4503.jar. You can select any
port number.
To install a publish instance:
1.
On the host file system, create a directory and name it publish.
2.
Copy the CQ WCM cq-wcm-quickstart-<version>.jar file into publish/.
3.
Rename cq-wcm-quickstart-<version>.jar to cq5-publish-4503.jar. If you
need a different port this can be set in the filename.
4.
Copy a valid license.properties file into publish/ as well (the same directory as the
cq5-publish-4503.jar file).
Note
If when starting the application, you do not provide the license.properties file,
CQ WCM redirects you to the Welcome screen where you enter a valid license key.
You can also request a valid license key from Day at this time.
5.
Start CQ WCM Quickstart:
• If using a GUI file-system explorer, double-click the cq5-publish-4503.jar file.
• If using the command line, type:
java -jar cq5-publish-4503.jar
• Use a custom script located in the crx quickstartfolder, such as server.bat to start
CQ. The Start and Stop scripts are for UNIX, Linux, and Macintosh. The server.bat
script is for Windows.
Important
You cannot use a custom script when you install the quickstart.jar file unless
you expand the file first. Use the -unpack option on the command line to unpack
the contents before running the script as in java -jar cq-wcm-quickstart<version>.jar -unpack.
6.
When the installation is completed, you can browse your site (for example, http://
localhost:4503/content/geometrixx/en/company.html)
9.1.3 Installing a CQ WCM Instance - Generic Procedure
This procedure is a generic, quickstart procedure for installing CQ WCM; it installs an author
instance using default settings and file names. It is often used when testing, or other scenarios
when you need a quickly available instance.
Page 74 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Installing CQ5
Note
You do not need to perform this procedure before installing author or publish instances.
To install an author or publish instance, see Installing an Author instance and Installing
the Publish instance.
To install a generic CQ WCM instance (author):
1.
Copy the CQ WCM cq-wcm-quickstart-<version>.jar file (for example, cq-wcmquickstart-5.2.0.20090319.jar) to the desired directory on the host file system.
2.
Copy a valid license.properties file into the same directory as the cq-wcmquickstart-<version>.jar file.
Note
If when starting the application, you do not provide the license.properties file,
CQ WCM redirects you to the Welcome screen where you enter a valid license key.
You can also request a valid license key from Day at this time.
3.
Start CQ WCM Quickstart by doing one of the following:
• If using a GUI file-system explorer, double-click the cq-wcm-quickstart<version>.jar file. This installs and automatically starts the server.
Note
The repository data is stored in the subdirectory crx-quickstart/
repository.
• If using the command line, type the following:
java -jar cq-wcm-quickstart-<version>.jar
• Use a custom script located in the crx quickstart folder, such as server.bat to
start CQ. The Start and Stop scripts are for UNIX, Linux, and Macintosh. The server.bat
script is for Windows.
Note
You cannot use a custom script when you install the quickstart.jar file
unless you expand the file first. Use the -unpack option on the command line
to unpack the contents before running the script as in java -jar cq-wcmquickstart-<version>.jar -unpack.
4.
When the installation is complete, you are automatically redirected to http://
localhost:4502/bin/login.html.
Note
CQ WCM quickstart selects the first available port from the following list:
4502,8080,8081,8082,8083,8084,8085,8888,9362,<random>. You can
also set the port number. See installing an author instance for an example on how to
set a port number.
9.2 How to install CQ5 with an Application Server
The following sections detail how to install CQ5 in conjunction with various application servers:
• WebSphere v6.1
Page 75 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Installing CQ5
• WebLogic v10.1
• Tomcat v6
• JBoss v4
A generic overview is also given for general usage and information:
• Generic Procedures
9.2.1 WebSphere v6.1
After installing WebSphere v6.1 you:
9.2.1.1 Install CQ5
1.
Unpack the installation files of the CQ5 Quickstart into a directory (without starting the server);
the installation directory will be referred to as <cq-installation-dir>:
•
Start the CQ5 Quickstart jar with the option -unpack; for example:
java -jar cq-wcm-quickstart-5.2.0.jar -unpack
This will create a folder <cq-installation-dir>crx-quickstart containing the
files and folders used for installation, without actually starting the installation.
Important
This must be done from the command line. If you open the jar file directly you will
activate the Quickstart installation and start the server.
2.
Copy the following jar files to the application server folder holding shared libraries:
a.
CRX\server\lib\container\jcr-1.0.jar
b.
CRX\server\lib\container\crx-shared.jar
3.
Restart WebSphere.
4.
Deploy the following web applications; they can be found in <cq-installationdir>\crx-quickstart\server\webapps:
a.
CRX webapp; crx-explorer_crx.war.
For example, deploy with the context path /crx.
b.
Launchpad webapp; crx-launchpad.war.
For example, deploy with the context path /launchpad.
5.
Start the two applications.
6.
Register your CRX license:
a.
Access your CRX installation:
http://<server>:<port>/<context-path>/index.jsp
for example: http://<server>:<port>/crx/index.jsp
b.
Click the red warning message - “Click here...” (the message is a link).
c.
Enter your license key.
Page 76 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Installing CQ5
9.2.1.2 Configure the default JDK
WebSphere v6.1 uses JDK 1.5. By default the SAMLv2 JSP JDK source level uses JDK 1.3. As the
SAMLv2 sample configuration uses the JDK 1.5 syntax, running it with the default source level will
not work. The following steps should be used to configure the source level as 1.5:
1.
Within the deployed crx-explorer_crx.war, edit ibm-web-ext.xmi and add the
following configuration parameter to specify the JSP engine:
<jspAttributes xmi:id="JSPAttribute_1225281520121"
name="jdkSourceLevel" value="15"/>
Note
The integer (n) referenced in JSPAttribute_<n> must be unique within the file.
2.
Repeat for crx-launchpad.war.
Note
The default configuration directory for the web module is:
<WAS_ROOT>\profiles\profilename\config\cells\cellname
\applications\enterpriseappname\ deployments\deployedname
\webmodulename\WEB-INF\
If you have already checked the option Use Binary Configuration the files are
extracted to the following directory, where they can be edited:
<WAS_ROOT>\profiles\profilename\installedApps\nodename
\enterpriseappname\webmodulename\
Where <WAS_ROOT> is the root directory of the web application server installation.
3.
Restart Websphere.
9.2.1.3 Install your Content Packages
1.
Stop CQ5.
2.
Edit the workspace configuration file:
a.
Open the following file for edit:
<cq-installation-dir>\crx-quickstart\repository\workspaces
\workspace.xml
b.
Scroll down to the <SearchIndex> parameter section.
c.
Add <param name="indexingConfiguration" value=""/> to the
<SearchIndex> parameter section.
3.
Start CQ5.
4.
Access the CRX main console.
5.
Log in to the crx.system workspace as admin.
6.
Navigate to the Package Manager in CRX.
7.
Upload and install the following CQ5 package from <cq-installation-dir>\crxquickstart\repository\install\system:
Page 77 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Installing CQ5
•
WCM Security Content Package; cq-security-content-<cq-version>.jar.
8.
Switch to the crx.default workspace, again as admin
9.
Upload and install the following CQ5 packages from <cq-installation-dir>\crxquickstart\repository\install in the following order:
a.
Sling Content Package; 0001-cq-wcm-sling-content-<cq-version>.jar.
b.
WCM Content Package; 0002-cq-wcm-content-<cq-version>.jar.
9.2.1.4 Enable Replication for Author instances of CQ5
For an author instance of CQ5 you must configure it to start in “author run mode” so that you can
perform replications.
1.
Open the file: <cq-installation-dir>\crx-quickstart\launchpad
\sling.properties for edit.
2.
Add the following two properties to the file:
sling.jcrinstall.folder.name.regexp = .*/(install|config)(.author)?$
sling.run.modes = author
3.
Restart the crx-launchpad web application.
9.2.2 WebLogic v10.3
After installing WebLogic v10.3 and creating your domain you:
9.2.2.1 Configure the Server Locale
When you deploy CQ5 with WebLogic 10.3 you must have the server locale set to en_US to avoid
errors such as:
java.lang.IllegalArgumentException: Bad date header: 'Wed, 12 Nov 2008
16:34:28 GMT'
These can occur when, for example, requesting a resource such as /libs/widgets/0.gif.
To configure the server locale on Microsoft Windows:
1.
Open the Control Panel.
2.
Open Regional and Languages Options.
3.
In the Regional Options tab, for Standards and formats select English(United
States).
To configure the server locale on Linux or Unix:
•
set the environment variable LANG to en_US.
9.2.2.2 Enable Basic Authentication Headers
To enable out-of-the-box authentication of users in CQ5, authentication by the application server
must be switched off:
1.
Open <WebLogic-installation-dir>/user_projects/domains/<your-domain>/
config/config.xml.
2.
Locate the element <security-configuration>.
Page 78 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Installing CQ5
3.
Add the following child element to it:
<enforce-valid-basic-auth-credentials>
false
</enforce-valid-basic-auth-credentials>
4.
If you had already started WebLogic then you will need to restart it.
9.2.2.3 Install CQ5
1.
Unpack the installation files of the CQ5 Quickstart into a directory (without starting the server);
the installation directory will be referred to as <cq-installation-dir>:
•
Start the CQ5 Quickstart jar with the option -unpack; for example:
java -jar cq-wcm-quickstart-5.2.0.jar -unpack
This will create a folder <cq-installation-dir>crx-quickstart containing the
files and folders used for installation, without actually starting the installation.
Important
This must be done from the command line. If you open the jar file directly you will
activate the Quickstart installation and start the server.
2.
Copy the following jar files to the application server folder holding shared libraries:
a.
CRX\server\lib\container\jcr-1.0.jar
b.
CRX\server\lib\container\crx-shared.jar
3.
Restart WebLogic.
4.
Deploy the following web applications; they can be found in <cq-installationdir>\crx-quickstart\server\webapps:
a.
CRX webapp; crx-explorer_crx.war.
For example, deploy with the context path /crx.
b.
Launchpad webapp; crx-launchpad.war.
For example, deploy with the context path /launchpad.
5.
Start the two applications.
6.
Register your CRX license:
a.
Access your CRX installation:
http://<server>:<port>/<context-path>/index.jsp
for example: http://<server>:<port>/crx/index.jsp
b.
Click the red warning message - “Click here...” (the message is a link).
c.
Enter your license key.
9.2.2.4 Install your Content Packages
1.
Stop CQ5.
2.
Edit the workspace configuration file:
Page 79 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Installing CQ5
a.
Open the following file for edit:
<cq-installation-dir>\crx-quickstart\repository\workspaces
\workspace.xml
b.
Scroll down to the <SearchIndex> parameter section.
c.
Add <param name="indexingConfiguration" value=""/> to the
<SearchIndex> parameter section.
3.
Start CQ5.
4.
Access the CRX main console.
5.
Log in to the crx.system workspace as admin.
6.
Navigate to the Package Manager in CRX.
7.
Upload and install the following CQ5 package from <cq-installation-dir>\crxquickstart\repository\install\system:
•
WCM Security Content Package; cq-security-content-<cq-version>.jar.
8.
Switch to the crx.default workspace, again as admin
9.
Upload and install the following CQ5 packages from <cq-installation-dir>\crxquickstart\repository\install in the following order:
a.
Sling Content Package; 0001-cq-wcm-sling-content-<cq-version>.jar.
b.
WCM Content Package; 0002-cq-wcm-content-<cq-version>.jar.
9.2.2.5 Enable Replication for Author instances of CQ5
For an author instance of CQ5 you must configure it to start in “author run mode” so that you can
perform replications.
1.
Open the file: <cq-installation-dir>\crx-quickstart\launchpad
\sling.properties for edit.
2.
Add the following two properties to the file:
sling.jcrinstall.folder.name.regexp = .*/(install|config)(.author)?$
sling.run.modes = author
3.
Restart the crx-launchpad web application.
9.2.3 Tomcat v6
After installing Tomcat v6 you:
9.2.3.1 Configure Tomcat access accounts
Tomcat enables neither admin nor manager access at installation.
Therefore you have to manually edit tomcat-users.xml to allow access for these accounts:
1.
Navigate to the Tomcat configuration folder.
2.
Edit tomcat-users.xml to include access for admin and manager. The configuration
should look similar to the following example:
Page 80 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Installing CQ5
<?xml version='1.0' encoding='utf-8'?>
<tomcat-users>
<role rolename="manager"/>
<role rolename="tomcat"/>
<role rolename="admin"/>
<role rolename="role1"/>
<user username="both" password="tomcat" roles="tomcat,role1"/>
<user username="tomcat" password="tomcat" roles="tomcat"/>
<user username="admin" password="admin" roles="admin,manager"/>
<user username="role1" password="tomcat" roles="role1"/>
</tomcat-users>
9.2.3.2 Install CQ5
1.
Unpack the installation files of the CQ5 Quickstart into a directory (without starting the server);
the installation directory will be referred to as <cq-installation-dir>:
•
Start the CQ5 Quickstart jar with the option -unpack; for example:
java -jar cq-wcm-quickstart-5.2.0.jar -unpack
This will create a folder <cq-installation-dir>crx-quickstart containing the
files and folders used for installation, without actually starting the installation.
Important
This must be done from the command line. If you open the jar file directly you will
activate the Quickstart installation and start the server.
2.
Copy the following jar files to the application server folder holding shared libraries:
a.
CRX\server\lib\container\jcr-1.0.jar
b.
CRX\server\lib\container\crx-shared.jar
3.
Restart Tomcat.
4.
Deploy the following web applications; they can be found in <cq-installationdir>\crx-quickstart\server\webapps:
a.
CRX webapp; crx-explorer_crx.war.
For example, deploy with the context path /crx.
b.
Launchpad webapp; crx-launchpad.war.
For example, deploy with the context path /launchpad.
5.
Start the two applications.
6.
Register your CRX license:
a.
Access your CRX installation:
http://<server>:<port>/<context-path>/index.jsp
for example: http://<server>:<port>/crx/index.jsp
b.
Click the red warning message - “Click here...” (the message is a link).
c.
Enter your license key.
Page 81 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Installing CQ5
9.2.3.3 Install your Content Packages
1.
Stop CQ5.
2.
Edit the workspace configuration file:
a.
Open the following file for edit:
<cq-installation-dir>\crx-quickstart\repository\workspaces
\workspace.xml
b.
Scroll down to the <SearchIndex> parameter section.
c.
Add <param name="indexingConfiguration" value=""/> to the
<SearchIndex> parameter section.
3.
Start CQ5.
4.
Access the CRX main console.
5.
Log in to the crx.system workspace as admin.
6.
Navigate to the Package Manager in CRX.
7.
Upload and install the following CQ5 package from <cq-installation-dir>\crxquickstart\repository\install\system:
•
WCM Security Content Package; cq-security-content-<cq-version>.jar.
8.
Switch to the crx.default workspace, again as admin
9.
Upload and install the following CQ5 packages from <cq-installation-dir>\crxquickstart\repository\install in the following order:
a.
Sling Content Package; 0001-cq-wcm-sling-content-<cq-version>.jar.
b.
WCM Content Package; 0002-cq-wcm-content-<cq-version>.jar.
9.2.3.4 Enable Replication for Author instances of CQ5
For an author instance of CQ5 you must configure it to start in “author run mode” so that you can
perform replications.
1.
Open the file: <cq-installation-dir>\crx-quickstart\launchpad
\sling.properties for edit.
2.
Add the following two properties to the file:
sling.jcrinstall.folder.name.regexp = .*/(install|config)(.author)?$
sling.run.modes = author
3.
Restart the crx-launchpad web application.
9.2.4 JBoss v4
After installing JBoss v4 you:
9.2.4.1 Install CQ5
1.
Unpack the installation files of the CQ5 Quickstart into a directory (without starting the server);
the installation directory is referred to as <cq-installation-dir>:
Page 82 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Installing CQ5
•
Start the CQ5 Quickstart jar with the option -unpack; for example:
java -jar cq-wcm-quickstart-5.2.0.jar -unpack
This creates a folder <cq-installation-dir>crx-quickstart containing the files
and folders used for installation, without actually starting the installation.
Important
This must be done from the command line. If you open the jar file directly you will
activate the Quickstart installation and start the server.
2.
Copy the following jar files to the application server folder holding shared libraries
(<JBOSS_HOME]\server\default\lib>):
a.
CRX\server\lib\container\jcr-1.0.jar
b.
CRX\server\lib\container\crx-shared.jar
3.
Restart JBoss.
4.
Unpack the crx-explorer_crx.war file located in the <cq-installation-dir>\crxquickstart\server\webapps folder.
Note
In Windows, change the .war extension to .zip and unpack like any zip file. In
Linux, type jar xvf crx-explorer_crx.war to unpack.
5.
In the WEB-INF folder, open log4j.xml.
6.
Remove or comment the line <appender-ref ref="console"/> which is in the Loggers
section of the file and save your changes and exit the file. This disables console logging in the
CRX web application.
7.
In the WEB-INF folder, navigate to the lib folder and delete the following files:
• jcr-1.0.jar
• jackrabbit-api-1.4.jar
• day-commons-naming-1.1.1.jar
• crx-api-1.4.1.jar
8.
Pack the crx-explorer_crx.war file.
Note
In Windows, run the zip utility to compress it and rename the crxexplorer_crx.zip file to crx-explorer_crx.war. In Linux, type jar cvf
crx-explorer_crx.war.
9.
Deploy the following web applications; they can be found in <cq-installationdir>\crx-quickstart\server\webapps:
a.
CRX webapp; crx-explorer_crx.war.
For example, deploy with the context path /crx.
b.
Launchpad webapp; crx-launchpad.war.
Page 83 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Installing CQ5
For example, deploy with the context path /launchpad.
JBoss supports Hot Deployment, so you can simply drag the two files to <JBOSS_HOME>
\server\default\deploy.
10. Start the two applications.
11. Register your CRX license:
a.
Access your CRX installation:
http://<server>:<port>/<context-path>/index.jsp
for example: http://<server>:<port>/crx/index.jsp
b.
Click the red warning message - “Click here...” (the message is a link).
c.
Enter your license key.
9.2.4.2 Configure the JBoss Server Login Module
By default JBoss' default login configuration attempts to authenticate users against a list of users
in the users.properties file. You must configure JBoss as follows to let login attempts by
unknown users to pass to the web application (CRX Explorer). The web application will then
process authentication by itself.
1.
Open the file for editing:
<JBOSS_HOME>\server\default\conf\login-config.xml
2.
In the section application-policy name="other" (at the bottom of the file) add the
attribute:
unauthenticatedIdentity="nobody"
to the login-module entry.
9.2.4.3 Install your Content Packages
Once you have installed CQ5 you will want to install content packages.
1.
Stop CQ5.
2.
Edit the workspace configuration file:
a.
Open the following file for edit:
<cq-installation-dir>\crx-quickstart\repository\workspaces
\workspace.xml
b.
Scroll down to the <SearchIndex> parameter section.
c.
Add <param name="indexingConfiguration" value=""/> to the
<SearchIndex> parameter section.
3.
Start CQ5.
4.
Access the CRX main console:
http://<server>:<port>/crx-explorer_crx/index.jsp
5.
Log in to the crx.system workspace as admin.
Page 84 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Installing CQ5
6.
Navigate to the Package Manager in CRX.
7.
Upload and install the following CQ5 package from <cq-installation-dir>\crxquickstart\repository\install\system:
•
WCM Security Content Package; cq-security-content-<cq-version>.jar.
8.
Switch to the crx.default workspace, again as admin
9.
Upload and install the following CQ5 packages from <cq-installation-dir>\crxquickstart\repository\install in the following order:
a.
Sling Content Package; 0001-cq-wcm-sling-content-<cq-version>.jar.
b.
WCM Content Package; 0002-cq-wcm-content-<cq-version>.jar.
10. Restart JBoss.
9.2.4.4 Enable Replication for Author instances of CQ5
For an author instance of CQ5 you must configure it to start in “author run mode” so that you can
perform replications.
1.
Open the file: <cq-installation-dir>\crx-quickstart\launchpad
\sling.properties for edit.
2.
Add the following two properties to the file:
sling.jcrinstall.folder.name.regexp = .*/(install|config)(.author)?$
sling.run.modes = author
3.
Restart the crx-launchpad web application.
9.2.5 Generic Procedures
After installing the appropriate web application server you:
9.2.5.1 Generic Installation Procedure
This section provides generic information about installing CQ5 with an application server.
1.
Unpack the installation files of the CQ5 Quickstart into a directory (without starting the server);
the installation directory will be referred to as <cq-installation-dir>:
•
Start the CQ5 Quickstart jar with the option -unpack; for example:
java -jar cq-wcm-quickstart-5.2.0.jar -unpack
This will create a folder <cq-installation-dir>crx-quickstart containing the
files and folders used for installation, without actually starting the installation.
Important
This must be done from the command line. If you open the jar file directly you will
activate the Quickstart installation and start the server.
2.
Copy the following jar files to the application server folder holding shared libraries:
a.
CRX\server\lib\container\jcr-1.0.jar
b.
CRX\server\lib\container\crx-shared.jar
Page 85 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Installing CQ5
3.
Restart your web application server.
4.
Deploy the following web applications; they can be found in <cq-installationdir>\crx-quickstart\server\webapps:
a.
CRX webapp; crx-explorer_crx.war.
For example, deploy with the context path /crx.
b.
Launchpad webapp; crx-launchpad.war.
For example, deploy with the context path /launchpad.
5.
Start the two applications.
6.
Register your CRX license:
a.
Access your CRX installation:
http://<server>:<port>/<context-path>/index.jsp
for example: http://<server>:<port>/crx/index.jsp
b.
Click the red warning message - “Click here...” (the message is a link).
c.
Enter your license key.
9.2.5.2 Install Content Packages
Once you have installed CQ5 you will want to install content packages.
1.
Stop CQ5.
2.
Edit the workspace configuration file:
a.
Open the following file for edit:
<cq-installation-dir>\crx-quickstart\repository\workspaces
\workspace.xml
b.
Scroll down to the <SearchIndex> parameter section.
c.
Add <param name="indexingConfiguration" value=""/> to the
<SearchIndex> parameter section.
3.
Start CQ5.
4.
Access the CRX main console.
5.
Log in to the crx.system workspace as admin.
6.
Navigate to the Package Manager in CRX.
7.
Upload and install the following CQ5 package from <cq-installation-dir>\crxquickstart\repository\install\system:
•
WCM Security Content Package; cq-security-content-<cq-version>.jar.
8.
Switch to the crx.default workspace, again as admin
9.
Upload and install the following CQ5 packages from <cq-installation-dir>\crxquickstart\repository\install in the following order:
Page 86 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Installing CQ5
a.
Sling Content Package; 0001-cq-wcm-sling-content-<cq-version>.jar.
b.
WCM Content Package; 0002-cq-wcm-content-<cq-version>.jar.
9.2.5.3 Enable Replication for Author instances of CQ5
For an author instance of CQ5 you must configure it to start in “author run mode” so that you can
perform replications.
1.
Open the file: <cq-installation-dir>\crx-quickstart\launchpad
\sling.properties for edit.
2.
Add the following two properties to the file:
sling.jcrinstall.folder.name.regexp = .*/(install|config)(.author)?$
sling.run.modes = author
3.
Restart the crx-launchpad web application.
Page 87 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
10 How to Use, Create, and Edit a
Page
10.1 Managing Pages within CQ WCM
This section describes how to create a page within CQ WCM and then create content on that page.
Important
Your account needs the appropriate access rights to create or edit pages.
10.1.1 Creating a New Page
Unless all pages have been created for you in advance, before you can start creating content, you
must create a page:
1.
From the wcm/siteadmin window, select the level at which you want to create a new page.
In the following example, you are creating a page under the level English - shown in the left
pane; the right pane shows the existing pages at this level.
2.
In the New... menu (click the arrow next to New...), select New Page.... The Create
Page window opens.
Note
Clicking New... itself also acts as a shortcut to the New Page... option.
3.
In the Title field, select a title that is displayed to the user.
4.
In the Name field, select a name that is used to create the URI.
5.
Click the template you want to use to create the new page; for example, to determine the
basic layout of a content page.
Page 88 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Use, Create, and Edit a Page
6.
Click Create to create the page. You return to the wcm/siteadmin window where you can
see an entry for the new page.
This provides information about the page (for example when it was last edited and by whom)
which is updated as necessary.
Page 89 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Use, Create, and Edit a Page
10.1.2 Editing a Page
After the page has been created, you can edit its content. When you first create a page, the page
includes only the text and elements from the template. You add content by double-clicking or
dragging and dropping components onto the page.
10.1.2.1 Opening a page
You can open the page to be edited by one of several methods:
• From wcm/siteadmin, you can double-click the page title to open it for editing.
• From wcm/siteadmin, you can right-click the page item, then select Open from the menu:
• After you have opened a page, you can navigate to other pages within the site to edit them by
clicking hyperlinks.
10.1.2.2 Inserting a new paragraph
After you open the page, you can start to add content. You do this by adding paragraphs (also
called components).
To insert a new paragraph:
1.
Double-click the area labeled Drag components or assets here... or drag a
component from the floating toolbar (called sidekick) to insert a new paragraph. This
area appears wherever new content can be added, such as at the end of the list if other
paragraphs exist or at the end of a column.
Note
If a paragraph already exists, you can right-click the paragraph and select
Insert. This inserts the new paragraph before the existing one.
Page 90 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Use, Create, and Edit a Page
2.
After you select to insert a paragraph, you see a list of the available paragraph types.
Note
Depending on your production environment, these choices may differ. For complete
details on components, see Default Components.
3.
Click the component that you want. A window opens that allows you to configure your
paragraph and add content.
10.1.2.3 Editing a paragraph
To edit an existing paragraph, do one of the following:
Page 91 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Use, Create, and Edit a Page
• Double-click the paragraph to open it. You see the same window as when you created the
paragraph with the existing content. Make your changes and click OK.
• Right-click the paragraph and click Edit.
10.1.2.4 Moving a paragraph
To move a paragraph:
1.
Click the paragraph you want to move. CQ WCM highlights the paragraph.
2.
Drag the paragraph to the new location - CQ WCM indicates where paragraphs can be
moved to with a green checkmark. Drop it in your desired location:
3.
Your paragraph is moved.
10.1.2.5 Deleting a paragraph
To delete a paragraph:
Page 92 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Use, Create, and Edit a Page
1.
Select the paragraph and right-click.
2.
Select Delete from the menu. CQ WCM requests confirmation that you want to delete the
paragraph as this action cannot be undone.
3.
Click OK.
10.1.3 Find & Replace
A Find & Replace menu option allows you to search for, and replace multiple instances of a
string, within a section of the website.
1.
Select the root page, or folder, where you want the “Find and Replace” action to take place.
2.
Select Tools then Find & Replace:
3.
The Find & Replace dialog will:
• confirm the root path where the find action should start
• define the term to be found
• define the term that should replace it
• indicate whether the search should be case-sensitive
• whether only whole words should be found (otherwise substrings will also be found)
Clicking Preview will list where the term has been found. You can select / deselect specific
instances to be replaced:
Page 93 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Use, Create, and Edit a Page
4.
Click Replace to actually replace all instances. You will be asked to confirm the action.
Note
The default scope for the find and replace servlet covers the following properties:
• jcr:title
• jcr:description
• jcr:text
• text
This can be changed using the Apache Felix Web Management Console (for
example, at http://localhost:4502/system/console/configMgr) for
com.day.cq.wcm.core.impl.servlets.FindReplaceServlet.
10.1.4 Moving or Renaming Page
The procedure to move or rename a page is the same. You do not need to do both: you can
rename a page without moving it or vice versa.
To move or rename a page:
1.
From the wcm/siteadmin window, click to select the page, then select Move.... (You can
also select the page item, then right-click and select Move....) The Move window
opens where you can either specify a new location, a new name for the page, or both.
Page 94 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Use, Create, and Edit a Page
2.
Fill in the following fields, as appropriate:
Move
Specify the page to be moved - this is usually filled in by default, depending on how and
where you started the move action.
to
Use the sitemap (available via the drop-down menu
) to select the location where the page should be moved to. If you are only renaming the
page, ignore this field.
Rename to
The current page label displays by default. Specify the new page label, if required.
3.
Click Move. CQ WCM confirms that you want to move or rename the current page. Click OK to
confirm.
10.1.5 Deleting a Page
1.
You can delete a page from various locations:
• Within the wcm/siteadmin window, click to select the page, then right-click and
select Delete from the resulting menu.
• Within sidekick use the Page actions tab to select Delete - this deletes the page that is
currently open
2.
After you have selected to delete a page you must confirm the request - as the action cannot
be undone.
Note
If the page has been published you can restore the latest (or a specific) version,
but this may not have exactly the same content as your last version if further
modifications had been made. See the section called “How To Restore Pages” for
further details.
Page 95 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Use, Create, and Edit a Page
10.1.6 Setting the Page Properties
Page Properties define the various properties of the page, such as titles, when they appear on the
website and others.
1.
Open the page you want to edit.
2.
In the sidekick, click the Page icon. Select Page Properties... from the list.
3.
In the window that opens, you can modify the global, advanced, tags, impressions, and page
analytics of a page:
a.
Global
Page 96 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Use, Create, and Edit a Page
Title Text
The page title - as appears in the siteadmin list.
Page Title
A title to be used on the page.
Navigation Title
A title for the page for use within the navigation map. Often shorter than the full title.
Subtitle
A subtitle for use on the page.
Hide Page in Navigation
A toggle switch to indicate whether the page is shown or hidden in the page
navigation.
b.
Advanced
Page 97 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Use, Create, and Edit a Page
On Time
The date and time at which the published page will be activated. When published this
page will be kept dormant until the specified time. Leave these fields empty for pages
you want to publish immediately (the normal scenario).
Off Time
The time at which the published page will be deactivated. Again leave these fields
empty for pages you want to publish immediately.
Vanity URL
Allows you to enter a vanity URL for this page.
Redirect Vanity URL
Indicates whether you want the page to use the vanity URL.
Page Language
Defined language of the page.
Redirect Target
Target to which the page should be redirected.
Design Path
Path of the page design.
c.
Tags/Keywords
Here you can add, or remove tags from the page by updating the list in the selection box:
• A completely new tag can be entered by typing the name in an empty space in the
selection box.
• With the drop-down functionality you can select from existing tags.
• An x appears when you mouse-over a tag entry in the selection box; this can be used
to remove that tag for this page.
Page 98 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Use, Create, and Edit a Page
d.
Impressions
This shows the activity on the page as in the impressions generated.
e.
Page Analytics
External Provider
The provider who is generating the analytical statistics.
ID / Snippet
The ID or code snippet to be included on the page.
f.
Live Copy:
Page 99 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Use, Create, and Edit a Page
Live Copy From
Define the source path.
Live Copy suspended
Suspend the Live Copy.
Sync Trigger
Defines when the modifications on the Blueprint are propagated to the Live Copy.
Sync Actions
Update Content
Controls whether, or not, modifications to the Blueprint will be propagated.
Enable Notification
Activate to be notified when the modifications are propagated.
Start Workflow
Select the workflow to be started when the synchronisation actions are triggered.
Read only for
Select the group that will have read-only access to the Live Copy.
Important
See Chapter 1, for full details.
g.
Blueprint:
Page 100 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Use, Create, and Edit a Page
Current Live Copies
Show the current live copies.
Sync Actions
Actions defined for the blueprint:
Update Content
Enables content update.
Enable Notification
Enables notifications.
Start Workflow
Select a workflow to be started upon synchronization.
Read only for
Select the groups that will have read-only access to the copies.
Important
See Chapter 1, for full details.
4.
Click OK to save the new properties.
Page 101 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
11 How to Publish a Page
11.1 How To Publish Pages
This section describes how to publish pages in CQ WCM. To publish a page, you activate its
contents. Conversely, to remove a page from publication, you deactivate its contents.
When you are working on pages that you are modifying, you can lock the pages so other users
cannot make changes or accidentally activate the content. In addition, you preview a page before
publishing by selecting Preview Mode in the sidekick.
If you are a system administrator and need to test the publish environment, see How to install CQ5
author and publish instances.
11.1.1 Activating Content
You activate pages in the wcm/siteadmin window. After you have opened a page and modified
its contents, you return to the wcm/siteadmin window to activate the content of that page or of an
entire tree of pages.
To activate page content:
1.
In the siteadmin/wcm window, select the page that you want to activate.
2.
Select Activate, either from the top menu, or the drop-down menu on the selected page
item.
Note
To activate the content of the page and all its sub-pages use the Tools tab.
3.
CQ WCM activates the selected content. To see that the page and its sub-pages (if selected)
have been published, refresh the page. The published page or pages appears in the
siteadmin/wcm window with information about who activated the content as well as date and
time of activation.
Page 102 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Publish a Page
11.1.2 Deactivating Content
To remove a page from the publish environment, you deactivate the content.
To deactivate a page:
1.
In the siteadmin/wcm window, select the page that you want to deactivate.
2.
Select Deactivate, either from the top menu, or the drop-down menu on the selected page
item. You are asked to confirm the deletion.
3.
Refresh the siteadmin/wcm window and the content is no longer published:
Page 103 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Publish a Page
11.1.3 Determining Page Publication Status
The colors next to pages in the siteadmin/wcm window indicate publication status.
Table 11.1.
Color
Description
Green
Publication was successful. Content is published.
Yellow
Publication is pending. Confirmation of publication has not yet
been received by the system.
Red
Publication failed. There is no connection with the publish
instance. This can also mean that the content was deactivated.
blank
This page has never been published.
11.1.4 Locking Pages
To lock a page that you are working on so no one can modify the contents or activate it:
1.
In the siteadmin/wcm window, select the page that you want to lock.
2.
Double-click the page to open it for edit.
Page 104 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Publish a Page
3.
In the Page tab of sidekick, select Lock Page:
4.
A message shows that your page is locked to other users:
5.
CQ WCM displays the page as locked and indicates which user has locked the page.
11.1.5 Unlocking Pages
You can only unlock locked pages if you locked the page or if you have administrator privileges.
To unlock a page:
1.
In the siteadmin/wcm window, select the page you want to unlock.
Page 105 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Publish a Page
2.
Double-click the page to open it for edit.
3.
In the Page tab of sidekick, select Unlock Page:
11.1.6 Using Preview Mode
This mode allows you to preview the page as if it were appearing on your website in its final form.
To access Preview mode:
1.
In the siteadmin/wcm window, open the page you want to view in Edit mode.
2.
In the sidekick, click the magnifying glass (preview mode). CQ WCM displays the page as it
appears on your web site in its final form.
Page 106 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
12 How to Restore a Page
12.1 How To Restore Pages
This section describes how to restore pages that have been previously deleted.
Note
Only pages that have been previously activated can be restored. Each time you activate a
page or tree, CQ WCM creates a new version of that page or tree.
To restore a page to a previous version:
1.
In the wcm/siteadmin window, navigate to the page you want to restore and select it.
2.
From the top menu select Tools, then Restore:
3.
Selecting Restore Version... lists previous versions of the document. Selecting
Restore Tree... lists previous versions of the content tree.
Page 107 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Restore a Page
4.
Click Restore. CQ WCM restores the version(s) (or trees) that you select.
Page 108 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
13 How to Create Templates
13.1 Developing Page Templates
CQ5 page templates are simply models used to create new pages. They can contain as little, or as
much, initial content as needed, their role being to create the correct initial node structures, with the
required properties (primarily sling:resourceType) set to allow editing and rendering.
13.1.1 Creating a new Template (based on an existing template)
Needless to say a new template can be created completely from scratch, but often an existing
template will be copied and updated to save you time and effort. For example, the templates within
Geometrixx can be used to get you started.
1.
Copy an existing template (preferably with a definition as close as possible to what you want
to achieve) to a new node.
Note
Templates are usually stored in /apps/<website-name>/templates/
<template-name>.
2.
Change the jcr:title of the new template node to reflect its new role. You can also update the
jcr:description if appropriate.
3.
Copy the component on which the template is based (this is indicated by the
sling:resourceType property of the jcr:content node within the template) to create a new
instance.
Note
Components are usually stored in /apps/<website-name>/components/
<component-name>.
4.
Update the jcr:title and jcr:description of the new component.
5.
Replace the thumbnail.png if you want a new thumbnail picture to be shown in the
template selection list.
6.
Update the sling:resourceType of the template's jcr:content node to reference the new
component.
7.
Make any further changes to the functionality or design of the template and/or its underlying
component.
Changes made to the /apps/<website>/templates/<template-name> node will affect
the template instance (as in the selection list).
Changes made to the /apps/<website>/components/<component-name> node will
affect the content page created when the template is used.
You can now create a page within your website using the new template.
Page 109 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
14 How to activate a section of your
website
14.1 How to activate a complete section (tree) of your website
From wcm/siteadmin you can activate the individual pages. When you have entered, or updated, a
considerable number of content pages - all of which are resident under the same root page - it can
be easier to activate the entire tree in one action. You can also perform a Dry Run to emulate an
activation and highlight which pages would be activated.
To activate a complete tree of your website:
1.
Access the Tools tab in CQ.
2.
Click on Replication - the folder will expand.
3.
Then double-click on Activate Tree.
4.
The following dialog screen will be shown:
5.
Enter the Start Path. This specifies the path to the root of the section you want to activate
(publish). This page, and all pages underneath, will be considered for activation (or used in
the emulation if a Dry Run is selected).
6.
Activate the selection criteria as required:
• Only Modified: only activate pages that have been modified.
• Only Activated: only activate pages that have (already) been activated. Acts as a form
of reactivation.
• Ignore Deactivated: ignore any pages which have been deactivated.
7.
Select the action you want to perform:
a.
Select Dry Run if you want to check which pages would be activated. This is only an
emulation, no pages will be activated.
b.
Select Activate if you want to activate the pages.
Page 110 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
15 How to Use Tags
15.1 How to Manage Tags in CQ WCM
15.1.1 Using Sidekick to access and assign Tags
Many users will assign tags directly to the page they are editing. This can be done using the
sidekick:
1.
Within sidekick select the Page tab.
2.
Click Page Properties....
3.
Select the Tags/Keywords tab.
Here you can either enter a tag by typing a new name or by selecting an existing tag from the
list of matching tags:
Or selecting a tag according to namespace by using the drop-down option:
Page 111 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Use Tags
15.1.2 The Tag Administration Console
The Tag Administration console can be used to manage your tags and taxonomies.
It shows information about the tags already created for your website, and a count of how often they
are referenced in the website:
From here you can perform various actions on tags and/or namespaces.
Page 112 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Use Tags
15.1.2.1 Creating or Editing Tags and Namespaces
1.
2.
Depending on the level you are starting from you can create either a tag or a namespace
using Create:
a.
If you select Tags you can create a namespace:
b.
If you select a namespace (for example Demo) you can create a tag within that
namespace:
In both cases enter a name, title, and description then click Create.
15.1.2.2 Deleting Tags
1.
In the right-hand pane, select the namespace or tag that you want to delete.
2.
Click Delete.
3.
You are asked to confirm the delete action. Click Yes to delete the item.
15.1.2.3 Activating and Deactivating Tags
1.
In the right-hand pane, select the namespace or tag that you want to activate or deactivate.
2.
Click Activate, Activate Tree, or Deactivate as required.
15.1.2.4 List - showing where tags are referenced
List opens a new window showing the paths of all pages using the highlighted tag:
Page 113 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Use Tags
15.1.3 Searching for Tags
You can search for tags in both the author and publish environments.
15.1.3.1 Searching for tags with the Search component
The search component covers tags and can be used in both the author and publish environments.
15.1.3.2 Searching for tags with the Content Finder
In the author environment you can use the content finder to search for tags:
1.
Select the Pages tab in the content finder.
2.
Enter the tag you want to search for.
Using the prefix “tags:” limits the search to tags only.
Page 114 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Use Tags
Page 115 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
16 How to use Social Collaboration
16.1 How to Blog with CQ
16.1.1 Creating a new blog
To create a new blog:
1.
Open the CQ WCM siteadmin.
2.
Select the location where you want to create your blog.
3.
Select the New... menu (click the arrow next to New...).
4.
Select New Page....
5.
Enter a Title for your new page and the Name if you do not want the default.
6.
Select the Blog Template.
7.
Click Create to create the new blog page. A new page looks as follows:
16.1.2 Posting a new blog entry
To post a new entry to your blog:
1.
Open your blog page:
Page 116 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to use Social Collaboration
2.
Click the link here to open the dialog:
Here you can enter a heading and body text. Assigning a category (tag) to this entry lists this
entry under the appropriate category.
Page 117 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to use Social Collaboration
3.
Click Submit Entry to save the blog entry. It appears as follows:
16.1.3 Adding quick reference links to your blog
To add quick reference links to your blog overview page:
1.
Open the blog overview page.
2.
From the sidekick you can add various quick reference components to the right column:
Blog Archive
Allows quick reference to blog entries according to their dates of entry.
Blog Categories
Allows quick reference to blog entries according to their categories (tags).
Page 118 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to use Social Collaboration
Blog Search
A search box that allows the user to search all blog entries.
Tag Cloud
Displays tags; either from the entire website or the current page.
16.1.4 Importing RSS Feeds
You can import RSS feeds into your blog in CQ WCM by using the polling importer.
To import blogs from other websites into your blog:
1.
Navigate to the Tools window.
2.
In the Tools window, expand the Importers folder and double-click the Feed Importer.
Page 119 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to use Social Collaboration
3.
Click Add to open the New Importer Configuration window.
4.
In the Feed URL, enter the source url for the blog data. The format is rss:<URL_OF_BLOG>,
for example, rss:http://blog.nameofblog.com/feed.xml.
5.
In the Import to Path field, add the path where the imported blog should be stored, such
as /content/blogs/myblogs.
6.
In the Update Interval in Seconds field, enter a time in seconds. The minimum is 300
seconds. The first import of blog information happens after the time you specify (you do not
see content import until after the specified time).
Note
The minimum can be reconfigured in the OSGi interface to less than 300 seconds,
but reconfiguring the minimum is only recommended for testing purposes.
Page 120 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to use Social Collaboration
7.
Click OK. Your import configuration is stored.
8.
Navigate to your blog. After the specified interval, imported data appears on the blog.
16.2 Managing the Social Collaboration Profiles
To use the social collaboration features, users need to register for an account, then log in so that
they:
• have an identity to be used for communication with other website users
• can configure specific pages to their own requirements
16.2.1 Registering and editing a user profile
When users want to use the social collaboration functionality with CQ, they must register:
1.
Users log in using the Login option on the toolbar:
2.
This provides them with the following fields for registering the basic details required:
3.
Once registered, users can edit their profiles:
Page 121 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to use Social Collaboration
16.2.2 Finding the profiles in CRX
When a visitor registers for a new social collaboration profile, it is saved in CRX:
•
The profile can be found in CRX under /home/users:
Page 122 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
17 How to import offline documents
17.1 How to import documents generated offline
The offline importer allows you to import documents generated offline. Currently documents
generated with the following tools are supported:
• Microsoft Word
To import a document use the following steps:
1.
Click the Tools tab in CQ.
2.
Click Importers in the left pane to open the folder.
3.
Double-click Offline Importer in either the left or right pane.The following dialog opens:
4.
Use the Browse... button to select the Word Document you want to import into CQ.
5.
Select the site navigator
to select the Path to the node at which point this document should be imported.
6.
If necessary, you can change the components to be used for the various paragraph
definitions. Choose from a list of available components from the drop down lists.
7.
Click Import to start the import.
8.
Return to the wcm/site admin and navigate to the location you specified. Under the specified
page you can see the new pages generated from the imported document. You can now edit
the content directly within CQ.
Page 123 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
18 Validating External Links
18.1 How to validate external links
An external link checker is provided within CQ. The link checker:
• scans all content pages
• generates a list of all valid and invalid links
• marks invalid links as broken in situ on the individual content pages
To use the external link checker:
1.
Access the Tools tab within CQ.
2.
Double-click on External Link Checker (either the right or left pane). A list of all
links is generated.
3.
You can highlight a specific link then select Check for the link to be validated:
Information such as:
• status of the link
• URL
• time since the link was last validated
• time since the link was last available
• time since the link was last accessed
is displayed.
4.
On the individual content pages any invalid links will now be shown as broken:
Page 124 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
19 How to Find Logs and Audit
Entries
19.1 Working with Audit Records and Log Files
Auditing records and log files relating to CQ5 can be found at various locations. The following is
provided to give you a overview of what you can find where.
Note
As CQ WCM is based on CRX, some of the log files listed below are actually generated
by CRX. Please see the CRX documentation for full details of these.
19.1.1 Finding the Audit Records
Audit records are held to provide a record of who did what when. Different audit records are
generated for both CQ WCM and OSGi events.
19.1.1.1 CQ WCM Audit records from within the siteadmin
1.
Open a page.
2.
From the sidekick you can select the
tab, then double-click on Audit Log...
3.
A new window will open showing the list of audit records for the current page.
4.
Click OK when you want to close the window.
19.1.1.2 CQ WCM Auditing records within the repository
Within the /var/audit folder, audit records are held according to the resource. You can drill
down until you can see the individual records and the information they contain.
Note
These entries hold the same information as displayed above in the siteadmin.
Page 125 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Find Logs and Audit Entries
19.1.1.3 OSGi Audit records from within the Felix console
OSGi events also generate audit records which can be seen from the Audit Log tab in the Felix
Web Management Console:
19.1.2 Finding the Log Files
Various log files are held on the file server where you installed CQ5:
• <cq-installation-dir>\crx-quickstart\launchpad\logs
• error.log
Error messages, of varying levels of severity, related to the CRX Quick launchpad are
registered here.
• <cq-installation-dir>\crx-quickstart\logs
• access.log
All access requests to CQ WCM and the repository are registered here.
• error.log
Error messages (of varying levels of severity) are registered here.
• request.log
Each access request is registered here together with the response.
• server.log
All actions made by the server are registered here.
• stderr.log
Holds error messages, again of varying levels of severity, generated during startup.
• stdout.log
Holds logging messages indicating events during startup.
Page 126 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Find Logs and Audit Entries
• <cq-installation-dir>\crx-quickstart\logs\crx
• error.log
Error messages (of varying levels of severity) related to the repository are registered here.
• translation.log
Translation journaling.
• <cq-installation-dir>\crx-quickstart\repository\
• revision.log
Revision journaling information.
• <cq-installation-dir>\crx-quickstart\repository\repository\index
• redo.log
Redo event journaling.
• <cq-installation-dir>\crx-quickstart\repository\shared\journal
• journal.log<.x>
Event journaling on the repository; multiple versions.
• <cq-installation-dir>\crx-quickstart\repository\workspaces\<workspace>
\index
• indexing_queue.log
Index journaling.
• redo.log
Redo event journaling.
• <cq-installation-dir>\crx-quickstart\server\logs
• access.log
All access requests to CQ WCM and the repository are registered here.
• startup.log
Server startup.
19.1.3 Activating the DEBUG Log Level
The default log level is INFO, that is, DEBUG messages are not logged.
To activate DEBUG log level, use the CRX explorer to set the /libs/
sling/config/org.apache.sling.commons.log.LogManager/
org.apache.sling.commons.log.level property to debug.
Caution
Do not leave the log at the DEBUG log level longer than necessary, as it generates a lot
of log entries, thus consuming resources.
A line in the debug file usually starts with DEBUG, and then provides the log level, the installer
action and the log message. For example:
Page 127 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Find Logs and Audit Entries
DEBUG 3 WebApp Panel: WebApp successfully deployed
The log levels are as follows:
Table 19.1. Log Levels
0
Fatal error
The action has failed, and the installer cannot proceed.
1
Error
The action has failed. The installation proceeds, but a part of CQ
WCM was not installed correctly and will not work.
2
Warning
The action has succeeded but encountered problems. CQ WCM
may or may not work correctly.
3
Information
The action has succeeded.
19.1.4 Create a Custom Log File
In certain circumstance you may want to create a custom log file. You can do this by:
1.
Open the Apache Felix Web Management Console; for example at http://
localhost:4502/system/console/.
2.
Go to the Configuration page.
3.
Select Sling Logging Writer Configuration from the Factory Configurations
drop down list.
4.
Enter the name of your custom log file; for example, logs/custom.log:
5.
Click Save.
A new entry is now listed in the Configurations drop down list.
Page 128 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Find Logs and Audit Entries
6.
Select Sling Logging Logger Configuration from the Factory Configurations
drop down list.
7.
Configure the following:
a.
Set the Log Level; for example Debug.
b.
Enter the name of your Log File - the same as earlier; in this example logs/
custom.log.
c.
Set the Categories to com.day.cq.wcm.foundation.
8.
Click Save.
9.
Restart CQ.
Note
This is necessary to ensure that any static loggers used access the new
configuration.
10. Read your new log file with your chosen tool.
Page 129 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
20 How to monitor, and configure,
your Replication Agents
Replication agents are central to CQ as they are used to publish (activate) content from one
environment to another, often from an author to a publish environment. They are also used to
explicitly flush content from the Dispatcher cache.
20.1 How to monitor your Replication Agents
To monitor a replication agent:
1.
Access the Tools tab in CQ.
2.
Click Replication.
3.
Double-click the link to agents for the appropriate environment (either the left or the right
pane); for example Agents on author.The resulting window shows an overview of all your
replication agents for the author environment, including their target and status:
4.
Click the appropriate agent name (which is a link) to show detailed information on that agent:
Page 130 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to monitor, and configure, your Replication Agents
Here you can:
• See whether the agent is enabled.
• See the target of any replications.
• See whether the replication queue is currently active, and if so any items in the queue.
• View Log to access the log of any actions by the replication agent.
• Test Connection to the target instance.
• Refresh or Clear the display of queue entries.
• Force Retry on any queue items if required.
20.2 How to configure your Replication Agents
20.2.1 Configuring your Replication Agents from wcm/siteadmin
From siteadmin in the author environment you can configure replication agents that reside in
either the author environment (Agents on author) or the publish environment (Agents
on publish). The following procedures illustrate the configuration of an agent in the author
environment, but can be used for both.
To configure a replication agent from siteadmin:
1.
Access the Tools tab in CQ.
2.
Click Replication (left pane to open the folder).
3.
Double-click Agents on author (either the left or the right pane).
Page 131 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to monitor, and configure, your Replication Agents
4.
Click the appropriate agent name (which is a link) to show detailed information on that agent.
5.
Click Edit to open the configuration dialog:
6.
The values provided should be sufficient for a default installation. If you make changes then
click OK to save them (see the section called “Replication Agents - Configuration Parameters”
for more details of the individual parameters).
20.2.2 Configuring your Replication Agents from the CRX Explorer
Various parameters of your replication agents can be configured using the CRX Explorer.
If you navigate to /etc/replication you can see the following three nodes:
• agents.author
• agents.publish
• treeactivation
The two agents hold configuration information about the appropriate environment, and are only
active when that environment is running. For example, agents.publish will only be used in the
publish environment. The following screenshot shows the publish agent in the author environment,
as included with CQ WCM:
Page 132 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to monitor, and configure, your Replication Agents
20.2.3 Configuring Reverse Replication
Reverse replication is used to get user content generated on a publish instance back to an author
instance. This is commonly used for moderated forums, blogs, surveys and registration forms,
amongst others.
For security reasons, most network topologies do not allow connections from the “Demilitarized
Zone” (a subnetwork that exposes the external services to an untrusted network such as the
Internet).
As the publish environment is usually in the DMZ, to get content back to the author environment
the connection must be initiated from the author instance. This is done with:
• an outbox in the publish environment where the content is placed.
• an agent (publish) in the author environment which periodically polls the outbox for new content.
To do this you need:
A reverse replication agent in the author environment
This acts as the active component to collect information from the outbox in the publish
environment:
Page 133 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to monitor, and configure, your Replication Agents
If you want to use reverse replication then ensure that this agent is activated.
A reverse replication agent in the publish environment (an outbox)
This is the passive element as it acts as an “outbox.” User input is placed here, from where it is
collected by the agent in the author environment.
Page 134 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to monitor, and configure, your Replication Agents
20.2.4 Configuring Replication for Multiple Publish Instances
Upon installation a default agent is already configured for replication to a publish instance running
on port 4503 of the localhost.
To configure replication for an additional publish instance you need to create, and configure, a new
replication agent:
1.
Log in to the site administration of CQ5 on the author instance.
2.
Open the Tools tab; for example, at http://localhost:4502/libs/wcm/content/
misc.html.
3.
Select Replication, then Agents on author in the left panel.
4.
Select New....
5.
Set the Title and Name, then select Replication Agent.
6.
Click Create to create the new agent.
7.
Double-click the new agent item to open the configuration panel.
8.
Click Edit - the Agent Settings dialog will open - the Serialization Type is already
defined as Default, this must remain so.
a.
b.
In the Settings tab:
i.
Activate Enabled.
ii.
Enter a Description.
iii.
Set the Retry Delay to 60000.
iv.
Leave the Serialization Type as Default.
In the Transport tab:
•
Enter the required URI for the new publish instance; for example, http://
localhost:4504/bin/receive.
You can configure other parameters as required.
9.
Click OK to save the settings.
Tip
You can then test operation by updating, then publishing, a page in the author
environment.
The updates will appear on all publish instances that have been configured as above.
If you encounter any problems, you can check the logs on the author instance.
Depending on the level of detail required you can also set the Log Level to Debug.
using the Agent Settings dialog as above.
20.2.5 Configuring a Dispatcher Flush agent
Default agents are included with the installation. However, certain configuration is still needed and
the same applies if you are defining a new agent:
1.
Log in to the site administration of CQ5 on the author instance.
Page 135 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to monitor, and configure, your Replication Agents
2.
Open the Tools tab; for example, at http://localhost:4502/libs/wcm/content/
misc.html.
3.
Select Replication, then Agents on publish in the left panel.
4.
Double-click on the Dispatcher Flush item to open the overview.
5.
Click Edit - the Agent Settings dialog will open:
a.
b.
In the Settings tab:
i.
Activate Enabled.
ii.
Enter a Description.
iii.
Leave the Serialization Type as Dispatcher Flush, or set it as such if
creating a new agent.
In the Transport tab:
•
Enter the required URI for the new publish instance; for example, http://
localhost:80/dispatcher/invalidate.cache.
You can configure other parameters as required.
6.
Click OK to save the changes.
7.
Return to the Tools tab, from here you can Activate the Dispatcher Flush agent
(Agents on publish).
Note
The Dispatcher Flush replication agent is not active on author. You can access
the same page in the publish environment by using the equivalent URI; for example,
http://localhost:4503/etc/replication/agents.publish/flush.html.
Page 136 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
21 Troubleshooting CQ WCM
The following section covers some issues that you might encounter when using CQ, together with
suggestions on how to troubleshoot them.
As this section covers many aspects of CQ WCM it is targeted as various roles.
21.1 Troubleshooting scenarios by Role(s)
The following table gives an overview of problems you may need to troubleshoot according to the
role (most probably) impacted:
Table 21.1. Troubleshooting scenarios by Role(s)
Role(s)
Problem
System Administrator
Double-clicking the Quickstart jar does not have any effect or
opens the jar file with another program (for example, archive
manager)
System Administrator
My application running on CRX throws out-of-memory errors
System Administrator
The CQ WCM Welcome screen does not display in the browser
after double-clicking CQ WCM Quickstart
System Administrator
Making a Thread Dump
admin user
System Administrator
Checking for unclosed JCR sessions
admin user
User
Old page version still showing
User
Sidekick not visible
User
Find & Replace - not all instances of the find term on a page
are replaced
21.2 Troubleshooting Scenarios
The following sections lists some common troubleshooting scenarios.
21.2.1 Common Installation Issues
The following section describes some installation issues and their solutions.
21.2.1.1 Double-clicking the Quickstart jar does not have any effect or opens
the jar file with another program (for example, archive manager)
This usually indicates a problem with the way your operating system's desktop environment is
configured to open files with extension .jar. It may also indicate that you do not have Java
installed, or that you are using an unsupported version of Java.
As jar files use the ubiquitous ZIP format, some of the archiving programs may automatically
configure the desktop to open jar files as archive files.
To troubleshoot, do the following:
Page 137 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Troubleshooting CQ WCM
• Double check that you have at least Java version 1.5 installed.
• Try a context menu (usually right-mouse click) on the CQ WCM Quickstart, and select "Open
With...."
• Check if Java or Sun Java is listed, and try to run CQ WCM with it. If you have multiple Java
versions installed, select the supported one.
Note
If you succeed with this step, and your operating systems offers an option to always
use the selected program to run the .jar files, select it. Double-clicking should work from
now on.
• Sometimes reinstalling the supported Java version helps restore the correct association.
• You can always run CRX using the command line or start/stop scripts as described earlier in this
document.
21.2.1.2 My application running on CRX throws out-of-memory errors
CRX itself has a very low memory footprint. If the application running within CRX has bigger
memory requirements or requests memory-heavy operations (for example, large transactions), the
JVM instance where CRX runs needs to be started with appropriate memory settings. Use Java
command options to define memory settings of the JVM (for example, java -Xmx512m -jar crx*.jar
to set heapsize to 512MB).
Note
Specify the memory setting option while starting CQ WCM from the command line. The
CQ WCM start/stop scripts or custom scripts for managing CQ WCM startup can also be
modified to define the required memory settings.
21.2.1.3 The CQ WCM Welcome screen does not display in the browser after
double-clicking CQ WCM Quickstart
In certain situations, the CQ WCM Welcome screens does not automatically display even though
the repository itself is successfully running. This may depend on operating system setup, browser
configuration, or similar factors.
The usual symptom is that the CQ WCM Quickstart window displays "CQ WCM starting up, waiting
for server startup...." If that message displays for a relatively long time, enter the CQ WCM URL
into the browser window manually, using the default 4502 port, or the port on which the instance is
running: http://localhost:4502/.
Also, logs may reveal the reason for the browser not starting.
Sometimes, the CQ WCM Quickstart window has the message "CQ WCM running on http://
localhost:port/" and the browser does not start automatically. In this case, click on the URL in the
CQ WCM Quickstart window (it is a hyperlink) or manually enter the URL in the browser.
If everything else fails, check the logs to find out what has happened.
21.2.2 Possible Issues with the GUI
21.2.2.1 Old page version still showing
You have made changes to the publish site, but the old version of the page is still being shown.
There are various possibilities here:
Page 138 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Troubleshooting CQ WCM
• Clear the cache in your local browser and try to reaccess your page.
• Add “?” to the end of the page URL. For example, instead of
• http://home.html
enter:
• http://home.html?
This will request the page directly from CQ5 and bypass the Dispatcher. If you receive the
updated page, it is an indication that you should clear the Dispatcher cache.
21.2.2.2 Sidekick not visible
In rare cases you might have managed to position the header of your sidekick outside the scope of
your current window. This means you cannot reposition it again.
Log out from your current session and log back in again.
Sidekick will return to the default position.
21.2.2.3 Find & Replace - not all instances of the find term on a page are
replaced
Find & Replace - not all instances of the find term on a page are replaced.
The capability of Find & Replace depends on how the content is saved, and whether it can be
searched upon.
For example, a blog text is stored in jcr:text property which is not configured to be searched upon.
The default scope for the find and replace servlet covers the following properties:
• jcr:title
• jcr:description
• jcr:text
• text
This can be changed using the Apache Felix Web Management Console (for
example, at http://localhost:4502/system/console/configMgr) for
com.day.cq.wcm.core.impl.servlets.FindReplaceServlet.
21.2.3 Methods for Troubleshooting Analysis
21.2.3.1 Making a Thread Dump
The thread dump is a list of all the Java threads that are currently active. If CQ5 does not respond
properly, the thread dump can help you identify deadlocks or other problems.
21.2.3.1.1 Using Sling Thread Dumper
1.
Open the Apache Felix Web Management Console; for example at http://
localhost:4502/system/console/.
2.
Go to the Threads page:
Page 139 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Troubleshooting CQ WCM
21.2.3.1.2 Using javadump
1.
Find the PID (process id) of your Java instance.
2.
Run:
javadump.exe <pid>
3.
Open <cq-installation-dir>/crx-quickstart/server/log/startup.log. This
will show the thread dump.
21.2.3.1.3 Using jstack (command line)
1.
Find the PID (process id) of the CQ Java instance.
For example, you can use ps -ef or jps.
2.
Run:
jstack <pid>
3.
This will show the thread dump.
21.2.3.2 Checking for unclosed JCR sessions
When functionality is developed for CQ WCM, JCR Sessions may be opened (comparable to
opening a database connection). If the opened sessions are never closed, your system may
experience following symptoms: • The system gets slower and slower Miscellaneous • You have
a lot of "CacheManager: resizeAll" entries in the log file (the number behind size=... is the number
of caches; each sessions opens a few caches) • From time to time the system runs out of memory
(after a few hours, days, or weeks - depending on the severity)
• The system becomes slower.
• You can see a lot of CacheManager: resizeAll entries in the log file; the following number
(size=<x>) shows the number of caches, each sessions opens several caches.
Page 140 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Troubleshooting CQ WCM
• From time to time the system runs out of memory (after a few hours, days, or weeks - depending
on the severity).
Unfortunately, unclosed sessions are not covered by garbage collection. To find out if there are any
unclosed sessions, first run:
jps -l
This will show you the process id of all Java processes.
Then run:
jmap -histo <pid> | grep "CRXSessionImpl"
For the appropriate process (<pid>).
The second column is the instance count, showing the number of sessions currently open (not
closed) and currently are in memory. If the number is higher than 100 then you should investigate
further.
21.2.3.2.1 Locating the code that didn't close JCR sessions
To analyze where the sessions were started (for CRX 1.4.x) start CQ / CRX with the following JVM
Option:
java -Dcrx.debug.sessions=true ...
Then analyze the startup.log file with OpenSessions.java:
javac OpenSessions.java
java OpenSessions <installation_path>/crx-quickstart/server/logs/startup.log | sort >
test.txt
This will generate a new file test.txt that contains the stack trace of unclosed sessions, sorted
by stack trace content. Each stack trace is one line, and 'compressed' (repeated prefixes are
removed). The session id is at the end of the line. For example:
com.day.crx.j2ee.JCRExplorerServlet.login(JCRExplorerServlet.java:521)
ResourceServlet.spoolResource(ResourceServlet.java:148)
java.lang.Thread.run(Thread.java:595): session# 10023
The above example shows that session #10023 was not closed. With this information you can find
the corresponding stacktrace in the startup.log.
21.2.3.3 Using the Apache Felix Web Management Console
The status of the OSGi bundles can also give an early indication of possible issues.
1.
Open the Apache Felix Web Management Console; for example at http://
localhost:4502/system/console/.
2.
Go to the Bundles page:
Page 141 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Troubleshooting CQ WCM
3.
Check:
• the Status of the bundles. If any are Inactive or Unsatisfied, then try to stop
and restart
the bundle. If the issue persists then you may need to investigate further using other
methods.
• whether any of the bundles have missing dependencies. Such details can be seen by
clicking on the individual bundle Name, which is a link (the following example does not have
any issues):
Page 142 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Troubleshooting CQ WCM
Page 143 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
22 How to Backup your CQ WCM
instance
It is good practice to take backups of:
• your software installation - before/after significant changes in configuration
• the content held within the repository - regular
22.1 Backing up your software installation
After installation, or significant changes in the configuration, it is advisable to take a backup of your
software installation.
To do this you need to take a backup of your repository then:
• stop CQ WCM
• backup the entire <cq-installation-dir> from your file system
Caution
If you are operating a cluster then the “shared” folder might be in a different location and
will also need to be backed-up. See the section called “How to Set Up a Cluster in CQ”
for information about configuring a cluster.
Caution
If you are operating a third party application server, then additional folders may be in a
different location and also need to be backed-up. See the section called “How to install
CQ5 with an Application Server” for information about installing application servers.
Caution
Incremental backups should not be used with TarPM as file names can change.
Note
Disk mirroring can also be used as a backup mechanism.
22.2 Backing up your repository
The Backup and Restore section of the CRX documentation covers all issues related to backups of
the CRX repository. Both on- and/or offline.
For full details of making an online “Hot” backup see Creating an Online Backup.
Page 144 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
23 Security Checklists
This section deals with various steps you should take to ensure that your CQ5 installation is
secure.
23.1 Security Checklist for System Administrators
The following actions should be taken, or at least reviewed:
• Change Default Passwords
• Disable WebDAV
• Restrict Access via the Dispatcher
• Check for Cross-Site Scripting (XSS)
23.2 Security Checklist for Power Users
The following actions should be taken, or at least reviewed:
• Change Default Passwords
23.3 Security Checklist for Developers
The following actions should be taken, or at least reviewed:
• Use the user session, not the administrative session
• Check for Cross-Site Scripting (XSS)
23.4 Disable WebDAV
WebDAV should be disabled on the publish environment.
This needs action at two levels:
1.
Reconfigure the CRX webapp:
a.
Open the web.xml of the CRX webapp; this is usually found in <cq-installationdir>/crx-quickstart/server/runtime/0/_crx/WEB-INF.
b.
Comment out the following servlets in the S E R V L E T M A P P I N G section to
effectively disable WebDAV access to the repository:
• Webdav
• JCRWebdavServer
• CqResource
c.
The resulting configuration should look like:
<!-- ====================================================================== -->
<!-- S E R V L E T
M A P P I N G
-->
<!-- ====================================================================== -->
<servlet-mapping>
<servlet-name>NodeTree</servlet-name>
<url-pattern>/ui/nodetree/*</url-pattern>
Page 145 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Security Checklists
</servlet-mapping>
<!--servlet-mapping>
<servlet-name>Webdav</servlet-name>
<url-pattern>/repository/*</url-pattern>
</servlet-mapping-->
<servlet-mapping>
<servlet-name>Export</servlet-name>
<url-pattern>/export/*</url-pattern>
</servlet-mapping>
<!--servlet-mapping>
<servlet-name>JCRWebdavServer</servlet-name>
<url-pattern>/server/*</url-pattern>
</servlet-mapping-->
<!--servlet-mapping>
<servlet-name>CqResource</servlet-name>
<url-pattern>/cqresource/*</url-pattern>
</servlet-mapping-->
<servlet-mapping>
<servlet-name>JCRExplorer</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
d.
2.
Restart your CQ/CRX instance to make the changes take effect.
Configure CQ by stopping the appropriate bundle:
a.
Connect to the Felix Management Console running on http://<host>:<port>/
system/console; for example http://localhost:4503/system/console/
bundles.
b.
In the list of bundles, find the bundle named Sling - Simple WebDAV Access to
repositories.
c.
Click the stop button
to stop this bundle. A restart is not required.
23.5 Restrict Access via the Dispatcher
By configuring the Dispatcher you should restrict access so that only the following are available to
external visitors:
• /content - Site content
• /etc - Miscellaneous content such as designs
The following should be entered in the configuration file dispatcher.any:
# only handle the requests in the following acl. default is 'none'
# the glob pattern is matched against the first request line
/filter
{
/0001
{
/glob "*"
/type "deny"
}
/0002
{
/glob "* /content[./]"
/type "allow"
}
/0003
{
/glob "* /etc[./]"
Page 146 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Security Checklists
/type "allow"
}
Note
This configuration includes the following restrictions:
1. Restricts access to the Servlet Engine Administration /admin
2. Restricts access to the Sling Console /system
3. Restricts access to CRX /crx
4. Restricts access to the following application specific folders:
• /apps – Application data
• /libs – CQ5 Library
• /var – var folder
• /etc – Miscellaneous folder
• /home – User’s home folder
5. Restricts access to /tmp
6. Denies POST requests in case forms are not used.
23.6 Check for Cross-Site Scripting (XSS)
Cross-site scripting (XSS) allows attackers to inject code into web pages viewed by other users.
This security vulnerability can be exploited by malicious web users to bypass access controls.
Warning
CQ5 example code is not protected against such attacks.
23.7 Change Default Passwords
Day strongly recommends that you change the passwords for the following (privileged) admin
accounts (on all instances) after installation:
1.
The CQ admin account.
Important
The CQ admin account and the CRX admin accounts are actually one and the
same. So once you have changed the password for the “CQ admin” account, you
will need to use the new password when accessing CRX.
Important
To change the password for the CQ / CRX admin account, you need to make
changes in both CRX and the OSGi Console. See the section called “Changing the
CQ admin password in the CRX console” and the section called “Changing the CQ
admin password in the OSGi Apache Felix console”.
2.
The CQSE (Communiqué Servlet Engine) admin account.
3.
The Apache Felix Web Management Console admin password.
Page 147 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Security Checklists
Note
Further actions are described in the table the section called “Default Users and Groups”,
which gives an overview of the default users and groups included in the standard
installation.
23.7.1 Changing the CQ admin password
To change the password for the CQ admin account, you need to make changes in both CRX and
the OSGi Console.
23.7.1.1 Changing the CQ admin password in the CRX console
To change the admin account in the CRX console:
1.
Navigate to http://<server>:<port_number>/crx to open the CRX console.
2.
Log in as admin to the crx.system workspace.
3.
Open the Content Explorer and navigate to the admin user and select it.
4.
In the Security menu, select Set User Password. A Set User Password window
opens.
Page 148 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Security Checklists
5.
Enter the new password and re-enter to confirm and click OK to save your changes.
Note
The new password is instantly persisted in the repository, a dedicated click on Save
All is not required.
23.7.1.2 Changing the CQ admin password in the OSGi Apache Felix console
To change the admin account in the OSGi Apache Felix console:
1.
Navigate to http://<server>:<port_number>/system/console/configMgr, and
login as admin, to open Configurations in the Apache Felix console.
2.
In the Configurations menu, select CRX Sling Client Repository.
Page 149 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Security Checklists
3.
In the Admin password field, change the password to match the one you entered in the CRX
console.
4.
Click Save to save your changes.
23.7.2 Changing the admin password for CQSE
To change the admin account in the CQSE console:
1.
Navigate to http://<server>:<port_number>/admin to open the CRX console.
2.
Log in as admin (the default password is admin).
3.
Select the Change Password tab:
Page 150 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Security Checklists
4.
Enter the Old Password, your New Password, then Confirm the new password.
5.
Click Change to save the new password.
23.7.3 Changing the admin password for the Apache Felix Web Management
Console
To change the admin account in the OSGi Apache Felix console:
1.
Navigate to http://<server>:<port_number>/system/console/configMgr, and
login as admin, to open Configurations in the Apache Felix console.
2.
In the Configurations menu, select Apache Felix OSGi Management Console.
3.
In the Password field, change the password.
4.
Click Save to save your changes.
23.8 Use the user session, not the administrative session
This means you should use:
slingRequest.getResourceResolver().adaptTo(Session.class);
Page 151 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
24 Defining Performance Tests on
Your Publish Environment
24.1 Introduction
Performance is of prime importance to your publish environment. Therefore, you need to
carefully plan and analyze the performance tests you will make for the publish environment while
implementing your project.
This section aims to give a standardized overview of the issues involved with defining a Test
Concept specifically for performance tests on your publish environment. This is primarily of interest
to QA engineers, project managers and system administrators.
24.2 Phases to be used
This document covers a standardized approach to performance tests for a CQ5 application on the
Publish environment. This involves the following 5 phases (which will be covered in more detail in
the next 5 sections):
1. Verification of Knowledge
2. Definition of Scope
3. Definition of Performance Goals
4. Test Methodologies
5. Optimization
Controlling is an additional, all-encompassing process - necessary but not limited to testing.
Figure 24.1. The 5 Phases of Performance Testing on your Publish
Environment
24.3 Verification of Knowledge
A first step is to document the basis information which you need to know before you can start
testing:
Page 152 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Defining Performance Tests on Your Publish Environment
• the architecture of your test environment
• an application map detailing the internal elements which will need testing (both in isolation and
combination)
24.3.1 Test Architecture
You should clearly document the architecture of the test environment being used for your
performance testing.
You will need a reproduction of your planned production Publish environment, together with
Dispatcher and Load Balancer.
24.3.2 Application Map
To get a clear overview you can create a map of the entire application (you may well have this from
tests on the Author environment).
A diagram representation of the internal elements of the application, can give an overview of the
testing requirements; with color-coding it can also act as a basis for reporting.
The example below illustrates the level of detail appropriate:
Figure 24.2. Verification Map
24.4 Scope Definition
An application will usually have a selection of use cases. Some will be very important, others less
so.
To focus the scope of the performance testing on publish, we recommend that you define the:
• most important business use cases
• most critical technical use cases
The number of use cases is up to you, but it should be limited to an easily manageable number
(e.g. between 5 to 10).
Once the key use cases have been selected, then the key performance indicators (KPI) and the
tools used to measure them can be defined for each case. Examples of common KPIs include:
Page 153 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Defining Performance Tests on Your Publish Environment
• End to end response time
• Servlet response time
• Response time for a single component
• Response time for the services
• Number of idle threads in the thread pool
• Number of free connections
• System resources such as CPU and I/O access
24.5 Test Methodologies
This concept has 4 scenarios used for defining and testing the performance goals:
1. Single component tests
2. Combined component tests
3. Going Live scenario
4. Error scenarios
Based on the following principles.
Component Breakpoints
Each component has a specific breaking point when related to performance. This means
that a component can show good performance until a specific point is reached, after which
performance will degrade rapidly.
To get a full overview of the application, you must first verify your components to determine
when the breakpoint of each is reached.
To find the breakpoint you can perform a load test where, over a period of time, you increase
the number of users to create an increasing load. By monitoring this load, and the response of
the components, you will encounter specific performance behavior when the breaking point of
the component is reached. The point can be qualified by the number of concurrent transactions
per second, together with the number of concurrent users (if the component is sensitive to this
KPI).
This information can then act as a benchmark for improvements, indicate the efficiency of the
measures being used, and help define test scenarios.
Transactions
The term transaction is used to represent the request of a complete web page, including the
page itself and all subsequent calls; i.e. the page request, any AJAX calls, images and other
objects.
Request Drill Down
To fully analyze each request you can represent each element of the call stack, then total the
average processing time for each.
24.6 Defining the Performance Goals
Once the scope, and related KPIs have been defined, the specific performance goals can be set.
This involves devising test scenarios, together with target values.
Page 154 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Defining Performance Tests on Your Publish Environment
You will need to test performance under both average and peak conditions. In addition, you will
need Going Live scenario tests to ensure that you can cater for increased interest in your website
when it is first made available.
Any experience, or statistics which you may have collected from an existing website can also be
useful in determining future goals; for example top traffic from your live website.
Note
As already mentioned, performance is of prime importance to a CQ5 project. Therefore
the goals (for both individual components and scenarios) should be defined at the
beginning of the project and verified during the implementation phase.
See also the Target Metrics section in the Project Manager Guide.
24.6.1 Single Component Tests
Critical components will need to be tested - under both average and peak conditions.
In both cases, you can define the expected number of transactions per second when a predefined
number of users are using the system.
Table 24.1. Example - Single Component Test
Component
Homepage Single User
Homepage 100 Users
Test Type
#Users
Tx/sec
(Expected)
Average
1
1
Peak
1
3
Average
100
3
Peak
100
3
Tx/sec
(Tested)
Description
24.6.2 Combined Component Tests
Testing the components in combination gives a closer reflection of the applications behavior. Again
average and peak conditions must be tested.
Table 24.2. Example - Combined Component Tests
Scenario
Component
Mixed average Homepage
Mixed peak
#Users
Tx/sec
(Expected)
10
1
Search
10
1
News
10
2
Events
10
1
Activations
10
3
Homepage
100
5
Search
50
5
News
100
10
Events
100
10
Activations
20
20
Page 155 of 214
Tx/sec
(Tested)
Description
Simulation of author
behavior.
Simulation of author
behavior.
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Defining Performance Tests on Your Publish Environment
24.6.3 Going Live Tests
During the first few days after your website is made available, you can expect an increased level
of interest. This will probably be even greater than the peak values you have been testing for. It
is strongly recommended to test Going Live scenarios to ensure that the system can cater for this
situation.
Table 24.3. Example - Going Live Tests
Scenario
Going Live peak
Test Type
#Users
Tx/sec
(Expected)
Homepage
200
20
Search
100
10
News
200
20
Events
200
20
Activations
20
20
Tx/sec
(Tested)
Description
Simulation
of author
behavior.
24.6.4 Error Tests
Error scenarios must also be tested to ensure that the system reacts correctly and appropriately.
Not only in how the error itself is handled, but the impact it may have on performance. For
example:
• what happens when the user tries to input an invalid search term in the search box
• what happens when the search term is so general that it returns an excessive number of results
When devising these tests it should be remembered that not all scenarios will occur regularly.
However, their impact on the entire system is important.
Table 24.4. Example - Error Scenario Tests
Error
Scenario
Search
component
overload
Error Type
#Users
Tx/sec
(Expected)
Tx/sec
(Tested)
Description
Search on global
wildcard (asterisk)
10
1
Only *** are
searched.
Stop word
20
2
Searching for a
stop word.
Empty string
10
1
Searching
for an empty
string.
Special characters
10
1
Searching
for special
characters.
24.6.5 Endurance Tests
Certain issues will only be encountered after the system has been running for a continued period of
time; be that either hours or even days. An endurance test is used to test an constant average load
over a required period of time. Any performance degradation can then be analyzed.
Page 156 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Defining Performance Tests on Your Publish Environment
Table 24.5. Example - Endurance Tests
Scenario
Test Type
Endurance test Homepage
(72 hours)
#Users
Tx/sec
(Expected)
10
1
Search
10
1
News
20
2
Events
10
1
Activations
1
3
Tx/sec
(Tested)
Description
Simulation of author
behavior.
24.7 Optimization
In the later stages of implementation you will need to optimize the application to fulfill / maximize
the performance goals.
Any optimizations made must be tested to ensure they have not affected the functionality and
verified with the load tests before being released.
A selection of tools is available to help you with load-generation, performance monitoring and/or
results analysis:
• JMeter
• Load Runner (HP)
• CA Wily Introscope
• Determyne InsideApps
• InfraRED
• Java Interactive Profile
• many more...
After optimization, you will need to test again to confirm the impact.
24.8 Reporting
On-going reporting will be needed to keep everyone informed of the status; as mentioned
previously with color-coding the Architecture Map can be used for this.
After all tests have been completed you will want to report on:
• any critical errors encountered
• non-critical issues which will still need further investigation
• any assumptions made during testing
• any recommendations to arise from the testing
Page 157 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
25 Extending CQ documentation and
Online Help
25.1 How to extend the documentation and online help
Although closely related, there are different methods involved, depending on what your endproduct is to be:
25.1.1 To extend the online help delivered with CQ
1.
Click the Tools tab.
2.
In the left pane, select Custom Documentation.
3.
From the top menu, click the arrow next to New... then select New Page:
4.
Enter a Title for the new DocBook element and a Name if you do not want the default.
5.
Select a template corresponding to the DocBook element you want to create.
6.
Click Create to create the page.
7.
Double-click the page to open it for editing using the available components:
Page 158 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Extending CQ documentation and Online Help
Note
Ensure that the page is in Edit mode. This is shown by the Edit/View toggle link
at the top right. You are in Edit mode when the link reads View (as it switches to
View mode).
Or from within the Online Help browser:
To generate new content:
Page 159 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Extending CQ documentation and Online Help
Important
The pages containing the online help must not be published (activated) as they contain
proprietary information that is the property of Day.
Page 160 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
26 How to Create a Fully Featured
Internet Website
How to Create a Fully Featured Internet Website
Page 161 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
27 How to Set Up the Development
Environment with Eclipse
27.1 How to Set Up the Development Environment with Eclipse
This document describes the process of setting up a local development environment for a simple
CQ5 project with Eclipse. It then describes how to integrate logic into the project through Java
coding and JSP scripting. Lastly, it points to open source software to enable collaborative and
automated developing.
The setup described here is an alternative among others and may vary from project to project.
The local development environment involves:
• A CQ5 installation that will act as your local environment.
• CRX Explorer within the CQ5 instance to create and edit nodes and properties within the CRX
repository.
• FileVault (VLT), a Day developed utility that maps the CRX repository to your file system.
• Eclipse to edit the project source on your local file system.
• Apache Maven to run local snapshot builds.
27.1.1 Creating the Project Structure in CQ5
This section describes the creation of a simple project structure in CQ5:
1.
Install CQ5 on your machine. Please refer to the section called “Installing a CQ WCM
Instance - Generic Procedure” for the detailed procedure. In the current context, CQ5 runs
locally on port 4502.
If already installed then ensure it is running and connect.
2.
3.
In the CRX Explorer, create the project structure:
1.
Under the /apps folder, create the nt:folder myApp.
2.
Under the myApp folder, create the nt:folder components.
3.
Under the myApp folder, create the nt:folder templates.
4.
Under the myApp folder, create the nt:folder install.
In your browser, navigate to the Tools tab. Under designs, create the design page of your
application:
• Title: My Application Design Page.
• Name: myApp.
• Template: Design Page Template.
27.1.2 Installing FileVault (VLT)
FileVault (VLT) is a tool developed by Day that maps the content of a CRX instance to your
file system. The VLT tool has similar functionalities to those of an SVN client, providing normal
check in, check out and management operations, as well as configuration options for flexible
representation of the project content.
Page 162 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Set Up the Development Environment with Eclipse
To install VLT, follow the steps:
1.
In your file system, go to <cq-installation-dir>/crx-quickstart/opt/filevault.
The build is available in both tgz and zip formats.
2.
Extract the archive.
3.
Add <cq-installation-dir>/crx-quickstart/opt/filevault/vault-cli<version>/bin to your environment PATH so that the command files vlt or vlt.bat are
accessed as appropriate. For example, <cq-installation-dir>/crx-quickstart/
opt/filevault/vault-cli-1.1.2/bin
4.
Open a command line shell and execute vlt --help. Make sure it displays the following help
screen:
27.1.3 Installing Eclipse
Eclipse is open source software used to edit the project source locally on your file system. Apache
Maven is also open source software, used to run local snapshot builds: it compiles Java code and
stores the compiled code in a jar file.
In this section, you will install Eclipse and a Maven plugin which embeds the Maven functionality
within Eclipse:
1.
Download Eclipse - select the Eclipse IDE for Java EE Developers option.
2.
Install Eclipse: extract from the downloaded zip file to your destination directory.
3.
Start Eclipse:
4.
a.
Navigate to the directory into which you extracted the contents of the Eclipse installation
zip file. For example C:\Program Files\Eclipse\.
b.
Double-click on eclipse.exe (or eclipse.app) to start Eclipse.
Create a new workspace for your project and name it myApp.
Page 163 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Set Up the Development Environment with Eclipse
5.
Install the Maven plugin (m2) from Sonatype. Disable Maven SCM handler for Subclipse
(Optional) and Maven Integration for AJDT (Optional).
6.
After installation it is recommended to restart Eclipse.
27.1.4 Creating the Project Structure in Eclipse
In this section, you will create two Maven projects:
• one called UI (after User Interface) which contains the CQ5 project structure with the JSP scripts.
• the other called Core which contains the Java code (source and compiled). The compiled code is
stored in a jar file.
The advantage of such a structure is that it adds modularity and autonomy to the logic of your
application because each jar file (bundle) can be managed separately.
27.1.4.1 Create the UI Maven Project
To create the UI Maven project, follow the steps:
1.
In Eclipse open the Workbench.
2.
Create the UI Maven project:
1.
In the Menu bar, click File, select New, then Other... .
2.
In the dialog, expand the Maven folder, select Maven Project and click Next.
3.
Check the Create a simple project box and the Use default Workspace
locations box, then click Next.
4.
Define the Maven project:
• Group Id: com.day.cq5.myapp
• Artifact Id: ui
• Name: CQ5 MyApp UI
• Description: This is the UI module
5.
3.
Click Finish.
Set the Java Compiler to version 1.5:
1.
Right-click the ui project, select Properties.
2.
Select Java Compiler and set following properties to 1.5:
• Compiler compliance level
• Generated .class files compatibility
• Source compatibility
4.
3.
Click OK.
4.
In the dialog window, click Yes.
Create the filter.xml file which defines the content that will be exported by VLT:
1.
In Eclipse, navigate to ui/scr/main and create the content folder.
Page 164 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Set Up the Development Environment with Eclipse
2.
Under content, create the META-INF folder.
3.
Under META-INF, create the vault folder.
4.
Under vault, create the filter.xml file.
5.
In filter.xml, copy the following code to filter.xml:
<?xml version="1.0" encoding="UTF-8"?>
<!-Defines which repository items are generally included
-->
<workspaceFilter vesion="1.0">
<filter root="/apps/myApp" />
<filter root="/etc/designs/myApp" />
</workspaceFilter>
6.
5.
Save the changes.
Check out the CQ5 content into your ui project with VLT:
1.
From the system command line, navigate to the directory holding your Eclipse
workspace <eclipse>/<workspace>/myApp/ui/src/main/content.
2.
Execute the command: vlt --credentials admin:admin co http://localhost:4502/crx
This command creates the folder jcr_root under <eclipse>/<workspace>/
myApp/ui/src/main/content. This maps to the CRX root (/). Under jcr_root the
following files and folders are created, as defined in filter.xml:
• apps/myApp
• etc/designs/myApp
It also creates two files, config.xml and settings.xml in <eclipse>/
<workspace>/myApp/ui/src/main/content/META-INF/vault. These are used
by VLT.
6.
7.
To enable Eclipse to map the file paths used in the JSP scripts, create a link to the apps
folder under ui:
1.
Right-click ui, select New, then Folder.
2.
In the dialog window, click Advanced and check the Link to folder in the file
system box.
3.
Click Browse, then specify <eclipse>/<workspace>/myApp/ui/src/main/
content/jcr_root/apps.
4.
Click OK.
5.
Click Finish.
To enable Eclipse to identify the Java classes, methods and objects used in the JSP scripts,
export the needed Java libraries from the CQ5 server to your file system and reference them
in the ui project.
In this example, you will reference the following libraries:
• libs/cq/install stored in the CQ5 server
• libs/sling/install stored in the CQ5 server
Page 165 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Set Up the Development Environment with Eclipse
• libs/wcm/install stored in the CQ5 server
• <cq-installation-dir>/crx-quickstart/server/lib/container stored in
your file system
Proceed as follows:
1.
In your file system, create a CQ5 libraries folder called cq5libs. This folder can be
created anywhere.
2.
Under cq5libs, create the folders: cq, sling and wcm.
3.
From the system command line go to .../cq5libs/cq and execute vlt co http://
localhost:4502/crx /libs/cq/install . to export the libraries stored under /libs/cq/
install from the CQ5 server.
4.
From the system command line go to .../cq5libs/sling and execute vlt co http://
localhost:4502/crx /libs/sling/install . to export the libraries stored under /libs/
sling/install from the CQ5 server.
5.
From the system command line go to .../cq5libs/wcm and execute vlt co http://
localhost:4502/crx /libs/wcm/install . to export the libraries stored under /libs/wcm/
install from the CQ5 server.
6.
In Eclipse, right-click the ui project, select Build Path, then Configure Build
Path. In the dialog select the Libraries tab.
7.
Click Add External JARS..., navigate to .../cq5libs/cq/jcr_root, select all
the jar files and click Open.
8.
Click Add External JARS..., navigate to .../cq5libs/sling/jcr_root, select
all the jar files and click Open.
9.
Click Add External JARS..., navigate to .../cq5libs/wcm/jcr_root, select all
the jar files and click Open.
10. Click Add External JARS..., navigate to <cq-installation-dir>/crxquickstart/server/lib/container, select all the jar files and click Open.
11. Click OK.
27.1.4.2 Create the Core Maven Project
To create the Core Maven project, follow the steps:
1.
In Eclipse, create the Core Maven project:
1.
In the Menu bar, click File, select New, then Other... .
2.
In the dialog, expand the Maven folder, select Maven Project and click Next.
3.
Check the Create a simple project box and the Use default Workspace
locations box, then click Next.
4.
Define the Maven project:
• Group Id: com.day.cq5.myapp
• Artifact Id: core
• Name: CQ5 MyApp Core
Page 166 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Set Up the Development Environment with Eclipse
• Description: This is the Core module
5.
2.
Click Finish.
Add the necessary plugins and dependencies to the core project:
1.
Open the pom.xml file under core.
2.
Copy-paste following code before the </project> tag:
<packaging>bundle</packaging>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>1.5</source>
<target>1.5</target>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.felix</groupId>
<artifactId>maven-bundle-plugin</artifactId>
<version>1.4.3</version>
<extensions>true</extensions>
<configuration>
<instructions>
<Export-Package> com.day.cq5.myapp.*;version=
${pom.version}
</Export-Package>
</instructions>
</configuration>
</plugin>
</plugins>
</build>
<dependencies>
<dependency>
<groupId>com.day.cq.wcm</groupId>
<artifactId>cq-wcm-api</artifactId>
<version>5.1.20</version>
</dependency>
<dependency>
<groupId>com.day.cq</groupId>
<artifactId>cq-commons</artifactId>
<version>5.1.18</version>
</dependency>
<dependency>
<groupId>org.apache.sling</groupId>
<artifactId>org.apache.sling.api</artifactId>
<version>2.0.3-incubator-R708951</version>
</dependency>
</dependencies>
3.
3.
Save the changes.
Deploy the CQ5 specific artifacts as defined in the pom.xml (cq-wcm-api, cq-commons and
org.apache.sling.api) to the local Maven repository:
Page 167 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Set Up the Development Environment with Eclipse
1.
From the system command line go to <your-user-dir>/.m2/repository/com/
day/cq/wcm/cq-wcm-api/5.1.20 (create the folders if they don't exist) and execute
vlt co http://localhost:4502/crx /libs/wcm/install/cq-wcm-api-5.1.20.jar . to export the
library from the CQ5 server.
2.
From the system command line go to <your-user-dir>/.m2/repository/com/
day/cq/cq-commons/5.1.18 (create the folders if they don't exist) and execute vlt
co http://localhost:4502/crx /libs/cq/install/cq-commons-5.1.18.jar . to export the
library from the CQ5 server.
3.
From the system command line go to <your-user-dir>/.m2/repository/org/
apache/sling/org.apache.sling.api/2.0.3-incubator-R708951 (create
the folders if they don't exist) and execute vlt co http://localhost:4502/crx /libs/sling/
install/org.apache.sling.api-2.0.3-incubator-R708951.jar . to export the library from
the CQ5 server.
Note
You don't need to perform this step if the three CQ5 artifacts are globally deployed
for the project on a Maven repository (e.g. using Apache Archiva).
4.
Set the Java Compiler to version 1.5:
1.
Right-click the core project, select Properties.
2.
Select Java Compiler and set following properties to 1.5:
• Compiler compliance level
• Generated .class files compatibility
• Source compatibility
5.
3.
Click OK.
4.
In the dialog window, click Yes.
Create the package com.day.cq5.myapp that will contain the Java classes under core/
src/main/java:
1.
Under core, right-click src/main/java, select New, then Package.
2.
Name it com.day.cq5.myapp and click Finish.
27.1.5 Scripting with Eclipse and CQ5
When editing UI code use the following sequence:
• Create a template and a component with the CRX Explorer.
• Update the changes with VLT (export from the repository to your file system) .
• Create a component script (JSP) with Eclipse.
• Check in the changes from the file system into the repository with VLT.
The following example illustrates this process:
1.
Create a new template with the CRX Explorer:
1.
In the CRX Explorer, under /apps/myApp/templates, create a new template: Name:
contentpage Type: cq:Template
Page 168 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Set Up the Development Environment with Eclipse
2.
2.
Under the contentpage Node, edit the Property jcr:title and add as Value:
MyApp Content Page Template
3.
Under the contentpage Node, add a new Node: Name: jcr:content Type:
cq:PageContent
4.
Under the jcr:content Node, edit the Property sling:resourceType and add as
Value: myApp/components/contentpage
5.
Under the jcr:content Node, add a new Property: Name: personName Value:
myName
Create a new component with the CRX Explorer:
•
3.
4.
In the CRX Explorer, under /apps/myApp/components, create a new component:
Name: contentpage Type: cq:Component
Use VLT to update the changes made from your repository to your file system, and therefore
Eclipse:
1.
From the system command line navigate to <eclipse>/<workspace>/myApp/ui/
src/main/content/jcr_root.
2.
Execute: vlt st --show-update to see the changes made on the repository.
3.
Execute: vlt up to update the changes from the repository to your file system.
Create the component script (JSP) with Eclipse:
1.
In Eclipse, navigate to ui/src/main/content/jcr_root/apps/myApp/
components/contentpage.
2.
Right-click contentpage, select New, then File.
3.
In the dialog, name the file contentpage.jsp and click Finish.
4.
Copy the following code into contentpage.jsp:
This is the contentpage component.
5.
5.
6.
Save the changes.
With VLT check in the changes from the file system into the repository:
1.
From the system command line navigate to <eclipse>/<workspace>/myApp/ui/
src/main/content/jcr_root.
2.
Execute: vlt st to see the changes made on the file system.
3.
Execute: vlt add apps/myApp/components/contentpage/contentpage.jsp to add the
contentpage.jsp file to VLT control.
4.
Execute: vlt ci to commit the contentpage.jsp file to the repository.
From CQ5 create a page based on this template. Open the page to make sure it displays the
following message:
This is the contentpage component.
Page 169 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Set Up the Development Environment with Eclipse
Tip
It is possible to define the VLT commands as External Tools in Eclipse. This enables you
to run the VLT commands from within Eclipse.
27.1.6 Java Developing with Eclipse and CQ5
When editing Core code use the following sequence:
• Create a Java class.
• Compile the Java class.
• Reference the jar file in the ui library.
• Embed the Java Class logic into the JSP script.
• Use VLT to check these changes to the JSP script (in the file system) into the repository.
• Use VLT to deploy the jar file (with the compiled class) from the file system into the repository.
The following example illustrates this process:
1.
Create the Java class:
1.
In Eclipse, under core/src/main/java, right-click the com.day.cq5.myapp
package, select New, then Class.
2.
In the dialog window, name the Java Class HelloPerson and click Finish. Eclipse
creates and opens the file HelloPerson.java.
3.
In HelloPerson.java replace the existing code with the following:
package com.day.cq5.myapp;
import com.day.cq.wcm.api.Page;
public class HelloPerson {
private Page personPage;
public static final String PN_PERSON_NAME = "personName";
public HelloPerson(Page personPage) {
this.personPage = personPage;
}
public String getHelloMessage() {
String personName = personPage.getProperties().get(PN_PERSON_NAME).toString();
return personName != null ? personName : "--empty--";
}
}
4.
2.
3.
Save the changes.
Compile the Java class:
1.
Right-click the core project, select Run As, then Maven Install.
2.
Make sure that a new file core-0.0.1-SNAPSHOT.jar (containing the compiled
class) is created under core/target.
Reference this jar file in the ui library to enable the code completion when accessing this
class with the JSP script:
Page 170 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Set Up the Development Environment with Eclipse
4.
1.
In Eclipse, right-click the ui project, select Build Path, then Configure Build
Path. In the dialog select the Libraries tab.
2.
Click Add JARS... and navigate to core/target, select the core-0.0.1SNAPSHOT.jar file and click OK.
3.
Click OK to close the dialog.
Embed the Java Class logic into the JSP script:
1.
In Eclipse, open the JSP script contentpage.jsp in ui/src/main/content/
jcr_root/apps/myApp/components/contentpage.
2.
Replace the existing code with the following:
<%@ page import="com.day.cq5.myapp.HelloPerson" %>
<%@include file="/libs/wcm/global.jsp"%>
<%
HelloPerson hello = new HelloPerson(currentPage);
String msg = hello.getHelloMessage();
%>
Hello, <%= msg %>.</br></br>
This is the contenpage component.
3.
5.
6.
7.
Save the changes.
With VTL check in the changes to the JSP script from the file system to the repository:
1.
From the system command line navigate to <eclipse>/<workspace>/myApp/ui/
src/main/content/jcr_root.
2.
Execute: vlt st to see the changes made on the file system.
3.
Execute: vlt ci to commit the modified contentpage.jsp file to the repository.
Deploy the jar file containing the compiled class from the file system into the repository with
VLT:
1.
In Eclipse, under core/target, copy the core-0.0.1-SNAPSHOT.jar file.
2.
In Eclipse navigate to ui/scr/main/content/jcr_root/apps/myapp/install
and paste the copied file.
3.
From the system command line navigate to <eclipse>/<workspace>/myApp/ui/
src/main/content/jcr_root.
4.
Execute: vlt st to see the changes made on the file system.
5.
Execute: vlt add apps/myApp/install/core-0.0.1-SNAPSHOT.jar to add the jar file to
VLT control.
6.
Execute: vlt ci to commit the jar file to the repository.
In your browser, refresh the CQ5 page to make sure it displays following message:
Hello, myName.
This is the contentpage component.
8.
In CRX Explorer, change the value myName and make sure that the new value is displayed
when you refresh the page.
Page 171 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Set Up the Development Environment with Eclipse
27.1.7 Building collaborative and automated projects
This section points to three open source softwares which enhance the development of CQ5
projects by adding collaboration and automation features:
• Subversion (SVN) to manage a central repository where all the developers involved in the project
can commit and retrieve the code and the content they generate on their local instance.
• Apache Archiva to centrally store and retrieve the project libraries.
• Apache Continuum to automate the build process.
27.1.7.1 Collaboration with Subversion (SVN)
As the CQ5 repository can be mapped to your file system with VLT, it is now easy to set up a
central repository with SVN. This is used by all developers in the project as a place they can
commit, and retrieve, the code and content they generate on their local instances.
The setup of an SVN server is not covered in this document as many tutorials are already available
online.
When VLT is in operation it creates .vlt files within the local directory structure. These .vlt files hold
timestamps and other VLT-specific information that should not be checked into the SVN repository.
This can be prevented by adding .vlt to the ignore list of the local SVN setup. To do this you add
the following code to the local SVN setup file - settings.xml in the .subversion directory of your
user's HOME directory:
[miscellany]
### Set global-ignores to a set of whitespace-delimited globs
### which Subversion will ignore in its 'status' output, and
### while importing or adding files and directories.
global-ignores = .vlt
27.1.7.2 Central dependency management with Apache Archiva
Java libraries, called artifacts in Maven language, can be managed centrally through Apache
Archiva, an artifact repository that is used to store and retrieve the project artifacts. The setup of
Archiva is well detailed online and can be referenced during setup. The Archiva server requires
little management outside that of configuring local developer accounts to obtain access to the
snapshots and full releases.
27.1.7.3 Build automation with Apache Continuum
Once the project content and code is centrally available through an SVN server, it is possible to
automate the build process and run the build on a daily basis (for example a nightly build). This is
done with Apache Continuum, a continuous integration server with the sole duty of providing build
management of artifacts and releases.
The setup of Continuum is also well detailed online.
Page 172 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
28 Multi Site Manager for Developers
This document describes:
• What happens in the repository when you set up MSM.
• How MSM can be extended to meet the specific needs of your application.
Please refer to Chapter 1, for instructions on setting up MSM.
28.1 MSM in the Repository
This section describes what happens in the repository when you set up MSM. The first part
describes the Nodes, Node Types, and Properties that are specific to MSM. The second part
describes how MSM works at the repository level.
28.1.1 MSM-specific Nodes, Node Types, and Properties
This section describes the Nodes, Node Types, and Properties that are specific to MSM.
28.1.1.1 cq:LiveRelationship mixin
The cq:LiveRelationship mixin is used as a supertype for the cq:LiveSync mixin.
It adds the following properties to the jcr:content node of the Live Copy page:
cq:lastRolledout
date and time of the last rollout
cq:lastRolledoutBy
indicates who performed the last rollout
cq:msmSyncState
not used anymore
28.1.1.2 cq:LiveSync mixin
The cq:LiveSync mixin adds the following nodes and properties to the jcr:content node of
the Live Copy page:
Page 173 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager for Developers
• the three properties defined by the cqLiveRelationship mixin, which is the supertype of
cq:LiveSync, which has the following three properties: cq:lastRolledout, cq:lastRolledoutBy
and cq:msmSyncState.
• the cq:LiveSyncConfig and the cq:LiveSyncAction nodes (see the following description).
28.1.1.3 cq:LiveSyncConfig node and node type
The cq:LiveSyncConfig node is of type cq:LiveSyncConfig and has the three following
properties storing the configuration of the Live Copy page:
cq:isDeep
Boolean defining whether the Live Copy is only for the page (when false) or for the complete
sub tree (when true). The default value is true. It is not accessible through the Siteadmin of
CQ5.
cq:master
String defining the path of the Blueprint.
cq:trigger
String defining the event triggering the synchronization. The default values are rollout,
modification, or publish.
Page 174 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager for Developers
28.1.1.4 cq:LiveSyncAction node and node type
The cq:LiveSyncAction node is of the type cq:LiveSyncAction and defines the synchronization
actions performed on the Live Copy page and on each node of its jcr:content node
(paragraphs) when the Blueprint is rolled out.
Each of its child node is an action: its name is the action name and its node type is
cq:LiveSyncAction. It must match one action in the client side action set and one server
synchronization action service. The following nodes exist by default:
mandatory
this node has a property called target defining the group that has read-only access to the Live
Copy, for example: surfer.
notify
this node has a property called target defining whether the notification has been enabled (when
true).
updateContent
this node has a property called status defining whether modifications to the Blueprint will be
propagated (when true).
workflow
this node has a property called target defining the path of the workflow that is started when
the synchronization actions are triggered, for example: /etc/workflow/models/dam/
update_asset.
28.1.1.5 cq:LiveSyncCancelled mixin
When a Live Copy is suspended, the cq:LiveSyncCancelled mixin is added to the
jcr:content node of the page or to the paragraph node.
The cq:LiveSyncCancelled mixin adds the boolean property cq:isCancelledForChildren: when
true, the Live Copy is cancelled for the complete sub tree. This property is not accessible through
the Siteadmin of CQ5.
Page 175 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager for Developers
28.1.1.6 cq:BlueprintAction node and node type
The cq:BlueprintAction node is the equivalent of the cq:LiveSyncAction node on the
Blueprint side. It defines the synchronization actions performed on the Live Copy page and on each
node of its jcr:content node (paragraphs) when the Blueprint is rolled out.
Each one of its child node represents an action: its name is the action name and its node type
is cq:LiveSyncAction. It must match one action in the client side action set and one server
synchronization action service. The following nodes exist by default:
mandatory
this node has a property called target defining the group who has a read only access to the
Live Copy, for example: surfer.
notify
this node has a property called target defining whether the notification has been enabled (when
true).
updateContent
this node has a property called status defining whether modifications to the Blueprint will be
propagated (when true).
workflow
this node has a property called target defining the path of the workflow that is started when
the synchronization actions are triggered, for example: /etc/workflow/models/dam/
update_asset.
28.1.2 MSM mechanisms in the repository
When configuring synchronization actions, following mechanisms take place in the repository:
• When a Blueprint is created, a cq:Page node is created under /etc/blueprints.
• When a Live Copy is created, a cq:LiveSyncConfig node and a cq:LiveSyncAction node
are created under the jcr:content node of the Live Copy root page and only there.
• When a synchronization action is configured on a Blueprint page, a cq:BlueprintAction
node is created under the jcr:content node of the page. For each action a
cq:LiveSyncAction node is created under the cq:BlueprintAction node.
• When a synchronization action is configured on a Live Copy page, a cq:LiveSyncConfig
node and a cq:LiveSyncAction node are created under the jcr:content node of the Live
Copy page.
Page 176 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager for Developers
• The configuration of a Live Copy page is defined as follows:
• if a cq:LiveSyncConfig node is stored under its jcr:content node, the configuration is
taken from this cq:LiveSyncConfig node.
• otherwise, the configuration is inherited from the first parent page with a
cq:LiveSyncConfig node stored to it.
• The actions to be performed on a Live Copy page are defined according to the following process:
1. In a first step:
• if a cq:LiveSyncAction node is stored under its jcr:content node, the actions are
taken from the cq:LiveSyncAction node.
• otherwise, the actions are inherited from the first parent page with a cq:LiveSyncAction
node stored to it.
2. If for this given Live Copy page, an action is defined on its Blueprint page (it has a
cq:LiveSyncAction node stored to it):
• if the action does not exist on the Live Copy page, the Blueprint action is added to the
action set and is performed.
• if the action exists on the Live Copy page, the Blueprint action replaces it and is performed.
• When a Live Copy is suspended, the cq:LiveSyncCancelled mixin is added to the
jcr:content node of the page or to the paragraph node.
28.2 Extending MSM Functionalities
28.2.1 How to extend synchronization actions
The set of synchronization actions available in the Create Site and Create Live Copy
dialogs or in the Live Copy and the Blueprint tabs is extensible: custom actions can be added
or complete actions set can be refactored.
CQ.wcm.msm.MSM.ACTIONS is a static JavaScript array that contains client-side configuration
from the synchronization actions. It is rendered into a CQ.Ext.form.FieldSet.
The code for CQ.wcm.msm.MSM.ACTIONS looks as follows:
CQ.wcm.msm.MSM.ACTIONS = [
CQ.wcm.msm.MSM.UpdateContentAction,
CQ.wcm.msm.MSM.NotifyAction,
CQ.wcm.msm.MSM.WorkflowAction,
CQ.wcm.msm.MSM.MandatoryAction
];
CQ.wcm.msm.MSM.UpdateContentAction, CQ.wcm.msm.MSM.NotifyAction,
CQ.wcm.msm.MSM.WorkflowAction and CQ.wcm.msm.MSM.MandatoryAction are objects
representing the default configurations for standard synchronization actions.
28.2.1.1 How to change the order of appearance of an action
You can customize the order of the actions by editing the array CQ.wcm.msm.MSM.ACTIONS and
reordering the actions within it.
28.2.1.2 How to remove an action
You can remove an action by editing the array CQ.wcm.msm.MSM.ACTIONS and removing an
action from it.
Page 177 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager for Developers
28.2.1.3 How to create an action
You can create a new action. To do so, two parts have to be configured:
• the JavaScript client side
• the custom synchronization action must be deployed on the server
The following procedure shows you how to add a new synchronization action called "Mandatory
Structure": the user selects a user-group that will be able to modify the Live Copy page content but
will not be able to delete or move the page.
28.2.1.3.1 Client side
To add a new synchronization action on the client side, proceed as follows:
1.
In CRX Explorer, create a new node under the /apps node. Name = myApp, Type =
nt:folder.
2.
Create a new node under /apps/myApp: Name = widgets, Type =
cq:ClientLibraryFolder. Then:
• edit the property categories and set cq.wcm.edit as Value.
• edit the property dependencies and set cq.widgets as Value.
• add a new property: Name = sling:resourceType, Type = String, Value = widgets/
clientlib.
3.
Create a new node under /apps/myApp/widgets: Name = source, Type =
sling:Folder.
4.
Create the js.txt file with the following code and store it under /apps/myApp/widgets
(for example with WebDAV):
#base=source
myMsmActions.js
Note
To connect to the CRX repository using the WebDAV protocol, check the CRX
documentation on WebDAV access.
5.
Create the myMsmActions.js file with the following code and store it under /apps/myApp/
widgets/source (for example with WebDAV):
CQ.wcm.msm.MSM.MandatoryStructureAction = {
"xtype": "combo",
"fieldLabel": CQ.I18n.getMessage("Mandatory Structure for"),
"name": "actionMandatoryStructure",
"hiddenName": "msm:actionMandatoryStructure/target",
"actionName":"msm:actionMandatoryStructure",
"stateful": false,
"typeAhead":true,
"triggerAction":"all",
"inputType":"text",
"displayField":"name",
"emptyText": "",
"minChars":0,
"editable":true,
"lazyInit": false,
"queryParam": "filter",
Page 178 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager for Developers
"fieldDescription": CQ.I18n.getMessage("Select the groups that will not be able to
modify the Live Copy structure."),
"tpl" :new CQ.Ext.XTemplate(
'<tpl for=".">',
'<div class="cq-msm-list cq-msm-mandatory-list">',
'<div class="cq-msm-list-entry cq-msm-mandatory-listentry">{[values.name==""? values.id: values.name]}</div>',
'</div>',
'</tpl>'),
"itemSelector" :"div.cq-msm-mandatory-list",
"store": new CQ.Ext.data.Store({
"autoLoad":false,
"proxy": new CQ.Ext.data.HttpProxy({
"url": "/bin/security/authorizables.json?limit=25&hideUsers=true",
"method":"GET"
}),
"reader": new CQ.Ext.data.JsonReader({
"root":"authorizables",
"totalProperty":"results",
"id":"id",
"fields":["name","id"]})
}),
"defaultValue": ""
};
// Adds the new action to the CQ.wcm.msm.MSM.ACTIONS array
CQ.wcm.msm.MSM.ACTIONS.push(CQ.wcm.msm.MSM.MandatoryStructureAction);
6.
The project structure looks as follows in CRX Explorer:
7.
In CQ5, open a Live Copy page. In the Page tab of the sidekick, click Page Properties....
Select the Live Copy tab to view the newly created widget:
Page 179 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager for Developers
28.2.1.3.2 Server side
To implement the new action on the Server side, proceed as follows:
Note
Refer to the section called “Installing Eclipse” for installing and setting up Eclipse with a
Maven plugin.
1.
In Eclipse, create the Core Maven project:
1.
In the Menu bar, click File, select New, then Other... .
2.
In the dialog, expand the Maven folder, select Maven Project and click Next.
3.
Check the Create a simple project box and the Use default Workspace
locations box, then click Next.
4.
Define the Maven project:
• Group Id: com.day.cq5.mymsm
• Artifact Id: core
• Name: CQ5 MyMsm Core
• Description: This is the CQ5 MyMsm Core
5.
Click Finish.
Page 180 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager for Developers
2.
Set the Java Compiler to version 1.5:
1.
Right-click the core project, select Properties.
2.
Select Java Compiler and set following properties to 1.5:
• Compiler compliance level
• Generated .class files compatibility
• Source compatibility
3.
3.
Click OK.
4.
In the dialog window, click Yes.
Replace the code in the pom.xml with the following code:
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/
XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/
maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.day.cq5.mymsm</groupId>
<artifactId>core</artifactId>
<name>CQ5 MyMsm Core</name>
<version>0.0.1-SNAPSHOT</version>
<description>This is the CQ5 MyMsm Core</description>
<packaging>bundle</packaging>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>1.5</source>
<target>1.5</target>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.felix</groupId>
<artifactId>maven-bundle-plugin</artifactId>
<version>1.4.3</version>
<extensions>true</extensions>
<configuration>
<instructions>
<Export-Package> com.day.cq5.mymsm.*;version=${pom.version}
</Export-Package>
</instructions>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.felix</groupId>
<artifactId>maven-scr-plugin</artifactId>
<version>1.0.8</version>
<executions>
<execution>
<id>generate-scr-scrdescriptor</id>
<goals>
<goal>scr</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
Page 181 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager for Developers
</build>
<dependencies>
<dependency>
<groupId>com.day.cq.wcm</groupId>
<artifactId>cq-wcm-api</artifactId>
<version>5.2.22</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>com.day.cq</groupId>
<artifactId>cq-security</artifactId>
<version>5.2.22</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>com.day.cq</groupId>
<artifactId>cq-security-api</artifactId>
<version>5.2.6</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>com.day.crx.sling</groupId>
<artifactId>com.day.crx.sling.client</artifactId>
<version>1.4.2</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>org.apache.sling</groupId>
<artifactId>org.apache.sling.jcr.api</artifactId>
<version>2.0.2-incubator</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>com.day.cq</groupId>
<artifactId>cq-commons</artifactId>
<version>5.2.20</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>org.apache.sling</groupId>
<artifactId>org.apache.sling.api</artifactId>
<version>2.0.3-incubator-R746167</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>org.osgi</groupId>
<artifactId>osgi_R4_core</artifactId>
<version>1.0</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>org.osgi</groupId>
<artifactId>osgi_R4_compendium</artifactId>
<version>1.0</version>
<scope>provided</scope>
</dependency>
</dependencies>
<repositories>
<repository>
Page 182 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager for Developers
<id>day-external-central</id>
<name>Day Central Repository</name>
<url>http://repo.day.com/archiva/repository/day-central</url>
<releases>
<enabled>true</enabled>
</releases>
<snapshots>
<enabled>false</enabled>
</snapshots>
</repository>
<repository>
<id>apache-incubating-repository</id>
<name>Apache Incubating Repository</name>
<url>http://people.apache.org/repo/m2-incubating-repository</url>
<releases>
<enabled>true</enabled>
</releases>
<snapshots>
<enabled>false</enabled>
</snapshots>
</repository>
</repositories>
<pluginRepositories>
<pluginRepository>
<id>day-external-central</id>
<name>Day Central Repository</name>
<url>http://repo.day.com/archiva/repository/day-central</url>
<releases>
<enabled>true</enabled>
</releases>
<snapshots>
<enabled>false</enabled>
</snapshots>
</pluginRepository>
<pluginRepository>
<id>apache-incubating-repository</id>
<name>Apache Incubating Repository</name>
<url>http://people.apache.org/repo/m2-incubating-repository</url>
<releases>
<enabled>true</enabled>
</releases>
<snapshots>
<enabled>false</enabled>
</snapshots>
</pluginRepository>
</pluginRepositories>
</project>
4.
Add the credentials into the settings.xml file of your <maven-install-dir>/.m2
directory: copy/paste the following code into the <servers></servers> tags:
<server>
<id>day-external-central</id>
<username>cq5_training</username>
<password>tr41n1ng</password>
</server>
5.
Create the package com.day.cq5.mymsm that will contain the Java classes under core/
src/main/java:
1.
Under core, right-click src/main/java, select New, then Package.
2.
Name it com.day.cq5.mymsm and click Finish.
Page 183 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager for Developers
6.
Create the Java class MandatoryStructureAction:
1.
In Eclipse, under core/src/main/java, right-click the com.day.cq5.mymsm
package, select New, then Class.
2.
In the dialog window, name the Java Class MandatoryStructureAction and click
Finish. Eclipse creates and opens the file MandatoryStructureAction.java.
3.
In MandatoryStructureAction.java replace the existing code with the following:
package com.day.cq5.mymsm;
import javax.jcr.Node;
import org.apache.sling.api.resource.Resource;
import org.apache.sling.api.resource.ResourceResolver;
import org.osgi.service.component.ComponentContext;
import
import
import
import
import
import
import
import
import
import
import
com.day.cq.security.util.ActionSet;
com.day.cq.security.util.CRXPolicyManager;
com.day.cq.wcm.api.NameConstants;
com.day.cq.wcm.api.Page;
com.day.cq.wcm.api.PageManager;
com.day.cq.wcm.api.WCMException;
com.day.cq.wcm.api.msm.ActionConfig;
com.day.cq.wcm.api.msm.ActionManager;
com.day.cq.wcm.api.msm.LiveAction;
com.day.cq.wcm.api.msm.LiveRelationship;
com.day.crx.CRXSession;
/**
* Set read-ony to group defined in the action config of the relationship (for
pages only). Denied ACL are: <ul>
* <li>ActionSet.ACTION_NAME_REMOVE</li>
* <li>ActionSet.ACTION_NAME_SET_PROPERTY</li>
* <li>ActionSet.ACTION_NAME_ACL_MODIFY</li>
* </ul>
* @scr.component metatype="false"
name="com.day.cq5.mymsm.MandatoryStructureAction" immediate="true"
* label="%mandatoryaction.name" description="%mandatoryaction.description"
* @scr.service interface="com.day.cq.wcm.api.msm.LiveAction"
*/
public class MandatoryStructureAction implements LiveAction {
//name of the action in the repository
public static final String ACTION_NAME = "mandatoryStructure";
//name of the request parameter used to get/post action properties
public static final String ACTION_PARAM_NAME =
"msm:actionMandatoryStructure";
public static final int ACTION_RANK = 602;
public static final String ACTION_PARAM_TARGET = "target";
//name of the request parameter used to get/post action properties
private String[] properties = {MandatoryStructureAction.ACTION_PARAM_TARGET};
/**
* @scr.reference
*/
@SuppressWarnings("UnusedDeclaration")
private ActionManager actionManager;
protected void activate(ComponentContext context) {
actionManager.registerAcion(this);
}
protected void deactivate(ComponentContext context) {
actionManager.unregisterAcion(this);
}
Page 184 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager for Developers
public String getName() {
return ACTION_NAME;
}
public int getRank() {
return ACTION_RANK;
}
public String[] getPropertiesNames() {
return properties;
}
public String getParameterName() {
return ACTION_PARAM_NAME;
}
public void execute(ResourceResolver resolver, LiveRelationship relation,
ActionConfig config, boolean autoSave) throws WCMException {
try {
if (!relation.getStatus().isCancelled() && config != null) {
if (config.hasProperty(ACTION_PARAM_TARGET)) {
String target = config.getProperty(ACTION_PARAM_TARGET);
if (target != null && !target.equals("")) {
Resource r = resolver.getResource(relation.getTargetPath());
Node slaveNode = r != null ? r.adaptTo(Node.class):
null;//Utils.getNode(resolver, relation.getTargetPath());
if (slaveNode != null) {
//set mandatory only on pages
if
(NameConstants.NN_CONTENT.equals(slaveNode.getName()) &&
slaveNode.getParent().isNodeType(NameConstants.NT_PAGE)) {
//at this point, action is executed only for a
page.
PageManager pm =
resolver.adaptTo(PageManager.class);
Page p =
pm.getContainingPage(resolver.getResource(slaveNode.getPath()));
if (p != null) {
CRXPolicyManager policyMgr = new
CRXPolicyManager((CRXSession) slaveNode.getSession());
policyMgr.enact(p.getPath(), target, false,
ActionSet.create(new String[]{
ActionSet.ACTION_NAME_REMOVE,
//
ActionSet.ACTION_NAME_SET_PROPERTY,
//
ActionSet.ACTION_NAME_ACL_MODIFY})
);
}
}
}
}
}
}
} catch (Exception re) {
throw new WCMException("Error while executing " + getName() + "
action", re);
}
}
}
4.
Save the changes.
Note
The synchronization action parameter name must match the value returned by
LiveAction#getParameterName.
Page 185 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager for Developers
A synchronization action is an OSGI service that must implement the interface
com.day.cq.wcm.api.msm.LiveAction and must register itself to the RolloutManager.
As you can see in the above code, a rank has been set to the action (the value of
the field ACTION_RANK). The actions are executed by following the order of the
ranks. For the default synchronization actions, the ranks are:
• UpdateContentAction = CUDAction service: 301
• NotifyAction = NotifyAction service: 501
• MandatoryAction = MandatoryAction service: 601
• WorkflowAction = WorkflowAction service: 701
7.
Compile the Java class and create the bundle:
1.
Right-click the core project, select Run As, then Maven Install.
2.
The bundle core-0.0.1-SNAPSHOT.jar (containing the compiled class) is created
under core/target.
8.
In CRX Explorer, create a new node under /apps/myApp. Name = install, Type =
nt:folder.
9.
Copy the bundle core-0.0.1-SNAPSHOT.jar and store it under /apps/myApp/install
(for example with WebDAV).
10. In your browser, in CQ5:
1.
Open a Live Copy page. In the Live Copy tab of the Page Properties, select a group
beside Mandatory Structure for. Click OK.
2.
Rollout the corresponding Blueprint page.
3.
Log out of CQ5 and log in as a member of the selected group.
4.
Refresh the Live Copy page: you can now edit the page but not delete it.
28.2.2 How to define the properties and the nodes that are copied to the Live
Copy
The MSM in CQ5 lets you define:
• which properties are copied by the Update Content synchronization action.
• which node types are part of the rollout process, that is, which synchronization actions are
performed on the node.
To do so:
1.
In your browser, open the Apache Felix Web Management Console Configuration
(for example: http://localhost:4502/system/console/configMgr).
2.
In Configuration, select CQ WCM Rollout Manager.
Page 186 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Multi Site Manager for Developers
3.
Configure these two parameters:
Excluded Properties
java regexes that define the property names to not copy. If the property name matches
one regex, it will not be copied.
Excluded Nodetypes
java regexes that define the node types to exclude from rollout. If the node type matches
one regex, it will not be included by the rollout manager.
28.2.3 How to remove the "Chapters" step in the "Create Site" wizard
In some cases, the Chapters selection is not required in the Create Site wizard but only the
Languages selection. To remove this step in the default Geometrixx blueprint:
1.
In CRX Explorer, remove the node /etc/blueprints/geometrixx/jcr:content/
dialog/items/tabs/items/tab_chap.
2.
Navigate to /libs/wcm/msm/templates/blueprint/defaults/livecopy_tab/
items and create a new node. Name = chapters, Type = cq:Widget.
3.
Add following properties to the new node:
• Name = name, Type = String, Value = msm:chapterPages
• Name = value, Type = String, Value = all
• Name = xtype, Type = String, Value = hidden
Page 187 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
29 JSP Tag Libraries
29.1 JSP Tag Libraries
The CQ and Sling tab libraries give you access to specific functions for use in the JSP script of
your templates and components.
29.1.1 CQ Tag Library
The CQ tag library contains helpful CQ functions.
To use the CQ Tag Library in your script, the script must start with the following code:
<%@taglib prefix="cq" uri="http://www.day.com/taglibs/cq/1.0" %>
Note
When the /libs/wcm/global.jsp file is included in the script, the cq taglib is
automatically declared.
Tip
When you develop the jsp script of a CQ5 component, it is recommended to include
following code at the top of the script:
<%@include file="/libs/wcm/global.jsp"%>
It declares the sling, cq and jstl taglibs and exposes the regularly used scripting objects
defined by the <cq:defineObjects /> tag. This shortens and simplifies the jsp code of your
component.
29.1.1.1 <cq:setContentBundle>
The <cq:setContentBundle> tag creates an i18n localization context and stores it in the
javax.servlet.jsp.jstl.fmt.localizationContext configuration variable.
It has the following attribute:
language
The language of the locale for which to retrieve the resource bundle.
The "content bundle" can be simply used by standard JSTL <fmt:message> tags. The lookup of
messages by keys is two-fold:
1. First, the JCR properties of the underlying resource that is currently rendered are searched for
translations. This allows you to define a simple component dialog to edit those values.
2. If the node does not contain a property named exactly like the key, the fallback is to load a
resource bundle from the sling request (SlingHttpServletRequest.getResourceBundle(Locale)).
The language or locale for this bundle is defined this way:
a. First, if the parameter language of the<cq:setContentBundle> tag is set, this is used.
b. Otherwise, the locale of the page is looked up. This is defined by the LanguageManager of
CQ5 (language copy function), which is typically taken from the page path (eg. the path /
content/site/en/some/page produces the "en" locale).
c. Finally, if there is no page language defined, the default locale of the current request is used,
which is equivalent to calling request.getResourceBundle(null).
Page 188 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
JSP Tag Libraries
Example:
<%@include file="/libs/wcm/global.jsp"%><%
%><%@ page import="com.day.cq.wcm.foundation.forms.ValidationInfo,
com.day.cq.wcm.foundation.forms.FormsConstants,
com.day.cq.wcm.foundation.forms.FormsHelper,
org.apache.sling.api.resource.Resource,
org.apache.sling.api.resource.ResourceUtil,
org.apache.sling.api.resource.ValueMap" %><%
%><cq:setContentBundle/>
29.1.1.2 <cq:include>
The <cq:include> tag includes a resource into the current page.
It has the following attributes:
flush
A boolean defining whether to flush the output before including the target.
path
The path to the resource object to be included in the current request processing. If this path is
relative it is appended to the path of the current resource whose script is including the given
resource. Either path and resourceType, or script must be specified.
resourceType
The resource type of the resource to be included. If the resource type is set, the path must be
the exact path to a resource object: in this case, adding parameters, selectors and extensions
to the path is not supported.
If the resource to be included is specified with the path attribute that cannot be resolved to a
resource, the tag may create a synthetic resource object out of the path and this resource type.
Either path and resourceType, or script must be specified.
script
The jsp script to include. Either path and resourceType, or script must be specified.
ignoreComponentHierarchy
A boolean controlling whether the component hierarchy should be ignored for script resolution.
If true, only the search paths are respected.
Example:
<%@taglib prefix="cq" uri="http://www.day.com/taglibs/cq/1.0" %><%
%><div class="center">
<cq:include path="trail" resourceType="foundation/components/breadcrumb" />
<cq:include path="title" resourceType="foundation/components/title" />
<cq:include script="redirect.jsp"/>
<cq:include path="par" resourceType="foundation/components/parsys" />
</div>
Note
Should you use <%@ include file="myScript.jsp" %> or <cq:include script="myScript.jsp"
%> to include a script?
• The <%@ include file="myScript.jsp" %> directive informs the JSP compiler to include
a complete file into the current file. It is as if the contents of the included file were
pasted directly into the original file.
• With the <cq:include script="myScript.jsp" %> directive, the file is included at runtime.
Page 189 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
JSP Tag Libraries
Note
Should you use <cq:include> or <sling:include>?
• When developing CQ5 components, Day recommends that you use <cq:include>.
• <cq:include> allows you to directly include script files by their name when using the
script attribute. This takes component and resource type inheritance into account, and
is often simpler than strict adherence to Sling's script resolution using selectors and
extensions.
29.1.1.3 <cq:defineObjects>
The <cq:defineObjects> tag exposes the following, regularly used, scripting objects which can be
referenced by the developer. It also exposes the objects defined by the <sling:defineObjects> tag.
componentContext
the current component context object of the request
(com.day.cq.wcm.api.components.ComponentContext interface).
component
the current CQ5 component object of the current resource
(com.day.cq.wcm.api.components.Component interface).
currentDesign
the current design object of the current page (com.day.cq.wcm.api.designer.Design interface).
currentPage
the current CQ WCM page object (com.day.cq.wcm.api.Page interface).
currentStyle
the current style object of the current cell (com.day.cq.wcm.api.designer.Style interface).
designer
the designer object used to access design information (com.day.cq.wcm.api.designer.Designer
interface).
editContext
the edit context object of the CQ5 component (com.day.cq.wcm.api.components.EditContext
interface).
pageManager
the page manager object for page level operations (com.day.cq.wcm.api.PageManager
interface).
pageProperties
the page properties object of the current page (org.apache.sling.api.resource.ValueMap).
properties
the properties object of the current resource (org.apache.sling.api.resource.ValueMap).
resourceDesign
the design object of the resource page (com.day.cq.wcm.api.designer.Design interface).
resourcePage
the resource page object (com.day.cq.wcm.api.Page interface).
It has the following attributes:
requestName
inherited from sling
Page 190 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
JSP Tag Libraries
responseName
inherited from sling
resourceName
inherited from sling
nodeName
inherited from sling
logName
inherited from sling
resourceResolverName
inherited from sling
slingName
inherited from sling
componentContextName
specific to wcm
editContextName
specific to wcm
propertiesName
specific to wcm
pageManagerName
specific to wcm
currentPageName
specific to wcm
resourcePageName
specific to wcm
pagePropertiesName
specific to wcm
componentName
specific to wcm
designerName
specific to wcm
currentDesignName
specific to wcm
resourceDesignName
specific to wcm
currentStyleName
specific to wcm
Example:
<%@page session="false" contentType="text/html; charset=utf-8" %><%
%><%@ page import="com.day.cq.wcm.api.WCMMode" %><%
%><%@taglib prefix="cq" uri="http://www.day.com/taglibs/cq/1.0" %><%
%><cq:defineObjects/>
Page 191 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
JSP Tag Libraries
Note
When the /libs/wcm/global.jsp file is included in the script, the <cq:defineObjects /
> tag is automatically included.
29.1.1.4 <cq:requestURL>
The <cq:requestURL> tag writes the current request URL to the JspWriter. The two tags
<cq:addParam> and <cq:removeParam> may be used inside the body of this tag to modify the
current request URL before it is written.
It allows you to create links to the current page with varying parameters. For example, it enables
you to transform the request:
mypage.html?mode=view&query=something into mypage.html?query=something.
The use of addParam or removeParam only changes the occurence of the given parameter, all
other parameters are unaffected.
<cq:requestURL> does not have any attribute.
Examples:
<a href="<cq:requestURL><cq:removeParam name="language"/></cq:requestURL>">remove filter</
a>
<a title="filter results" href="<cq:requestURL><cq:addParam name="language"
value="${bucket.value}"/></cq:requestURL>">${label} (${bucket.count})</a>
29.1.1.5 <cq:addParam>
The <cq:addParam> tag adds a request parameter with the given name and value to the enclosing
<cq:requestURL> tag.
It has the following attributes:
name
name of the parameter to be added
value
value of the parameter to be added
Example:
<a title="filter results" href="<cq:requestURL><cq:addParam name="language"
value="${bucket.value}"/></cq:requestURL>">${label} (${bucket.count})</a>
29.1.1.6 <cq:removeParam>
The <cq:removeParam> tag removes a request parameter with the given name and value from
the enclosing <cq:requestURL> tag. If no value is provided all parameters with the given name are
removed.
It has the following attributes:
name
name of the parameter to be removed
Example:
<a href="<cq:requestURL><cq:removeParam name="language"/></cq:requestURL>">remove filter</
a>
Page 192 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
JSP Tag Libraries
29.1.2 Sling Tag Library
The Sling tag library contains helpful Sling functions.
When you use the Sling Tag Library in your script, the script must start with the following code:
<%@ taglib prefix="sling" uri="http://sling.apache.org/taglibs/sling/1.0" %>
Note
When the /libs/wcm/global.jsp file is included in the script, the sling taglib is
automatically declared.
29.1.2.1 <sling:include>
The <sling:include> tag includes a resource into the current page.
It has the following attributes:
flush
A boolean defining whether to flush the output before including the target.
resource
The resource object to be included in the current request processing. Either resource or path
must be specified. If both are specified, the resource takes precedence.
path
The path to the resource object to be included in the current request processing. If this path is
relative it is appended to the path of the current resource whose script is including the given
resource. Either resource or path must be specified. If both are specified, the resource takes
precedence.
resourceType
The resource type of the resource to be included. If the resource type is set, the path must be
the exact path to a resource object: in this case, adding parameters, selectors and extensions
to the path is not supported.
If the resource to be included is specified with the path attribute that cannot be resolved to a
resource, the tag may create a synthetic resource object out of the path and this resource type.
replaceSelectors
When dispatching, the selectors are replaced with the value of this attribute.
addSelectors
When dispatching, the value of this attribute is added to the selectors.
replaceSuffix
When dispatching, the suffix is replaced by the value of this attribute.
Note
The resolution of the resource and the script that are included with the <sling:include> tag
is the same as for a normal sling URL resolution. By default, the selectors, extension, etc.
from the current request are used for the included script as well. They can be modified
through the tag attributes: for example replaceSelectors="foo.bar" allows you to overwrite
the selectors.
Examples:
<div class="item"><sling:include path="<%= pathtoinclude %>"/></div>
Page 193 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
JSP Tag Libraries
<sling:include resource="<%= par %>"/>
<sling:include addSelectors="spool"/>
<sling:include resource="<%= par %>" resourceType="<%= newType %>"/>
<sling:include replaceSelectors="content" />
29.1.2.2 <sling:defineObjects>
The <sling:defineObjects> tag exposes the following, regularly used, scripting objects which can be
referenced by the developer:
slingRequest
SlingHttpServletRequest object, providing access to the HTTP request header information extends the standard HttpServletRequest - and provides access to Sling-specific things like
resource, path info, selector, etc.
slingResponse
SlingHttpServletResponse object, providing access for the HTTP response that is created by
the server. This is currently the same as the HttpServletResponse from which it extends.
request
The standard JSP request object which is a pure HttpServletRequest.
response
The standard JSP response object which is a pure HttpServletResponse.
resourceResolver
The current ResourceResolver object. It is the same as slingRequest.getResourceResolver().
sling
A SlingScriptHelper object, containing convenience methods for scripts, mainly sling.include('/
some/other/resource') for including the responses of other resources inside this response (eg.
embedding header html snippets) and sling.getService(foo.bar.Service.class) to retrieve OSGi
services available in Sling (Class notation depending on scripting language).
resource
the current Resource object to handle, depending on the URL of the request. It is the same as
slingRequest.getResource().
currentNode
If the current resource points to a JCR node (which is typically the case in Sling), this gives
direct access to the Node object. Otherwise this object is not defined.
log
Provides an SLF4J Logger for logging to the Sling log system from within scripts, eg.
log.info("Executing my script").
It has the following attributes:
requestName
responseName
resourceName
nodeName
logName
Page 194 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
JSP Tag Libraries
resourceResolverName
slingName
Example:
<%@page session="false" %><%
%><%@page import="com.day.cq.wcm.foundation.forms.ValidationHelper"%><%
%><%@taglib prefix="sling" uri="http://sling.apache.org/taglibs/sling/1.0" %><%
%><sling:defineObjects/>
Page 195 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
30 DAM Media Handlers
CQ5 DAM comes with a set of default workflows and media handlers to process assets. The
workflow defines the general tasks to be executed on the assets, then delegates the specific tasks
to the media handlers, for example thumbnail generation or metadata extraction.
Media handlers are services inside CQ5 DAM that perform specific actions on assets. For example,
when an MP3 audio file is uploaded into CQ5, a workflow triggers an MP3 handler that extracts
the metadata and generates a thumbnail. Media handlers are usually used in combination with
workflows. Most common MIME types are supported within CQ5. Specific tasks can be performed
on assets by either extending/creating workflows, extending/creating media handlers or disabling/
enabling media handlers.
30.1 Default Media Handlers
The following media handlers are available within CQ5 DAM and handle the most common MIME
types (click the handler name to access its Javadocs):
Table 30.1.
Handler name
Service Name (in the
System Console)
Supported MIME types
TextHandler
com.day.cq.dam.core.impl.handler.TextHandler
text/plain
PdfHandler
com.day.cq.dam.handler.standard.pdf.PdfHandler
application/pdf
JpegHandler
com.day.cq.dam.core.impl.handler.JpegHandler
image/jpeg
image/jpg
Mp3Handler
com.day.cq.dam.handler.standard.mp3.Mp3Handler
audio/mpeg
ZipHandler
com.day.cq.dam.handler.standard.zip.ZipHandler
application/java-archive
application/zip
PictHandler
com.day.cq.dam.handler.standard.pict.PictHandler
image/pict
StandardImageHandler
com.day.cq.dam.core.impl.handler.StandardImageHandler
image/gif
image/png
application/photoshop
image/jpeg
image/tiff
image/x-ms-bmp
image/bmp
GenericAssetHandler
com.day.cq.dam.core.impl.handler.GenericAssetHandler
fallback in case no other handler was found to
extract data from an asset
All the handlers perform the following tasks:
• extracting all available metadata from the asset.
• creating a thumbnail image out of the asset.
Page 196 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
DAM Media Handlers
Beside those tasks other MIME type specific tasks are available: refer to the Javadocs for detailed
information.
It is possible to view the active media handlers:
1.
In your browser, navigate to http://<host>:<port>/system/console/components.
2.
Click the link com.day.cq.dam.core.impl.store.AssetStoreImpl.
3.
A list with all the active media handlers is displayed. For example:
30.2 Using Media Handlers in Workflows to perform tasks on
Assets
Media handlers are services that are usually used in combination with workflows.
CQ5 has the following default workflows to process assets:
• DAM Asset Sync and Metadata Extractor
• DAM Delete Asset
• DAM Delete Dam Asset under /content/dam
• DAM Sub Asset Processor
• DAM Update Asset
Existing workflows can be extended and new ones can be created to process assets according to
specific requirements.
By default, when a PDF document is uploaded into the /var/dam/geometrixx/documents
folder, the default DAM Asset Sync and Metadata Extractor process:
• copies the document into the /content/dam/geometrixx/documents folder
• asks the AssetStore for a handler that is able to process pdf
Then, the pdf handler:
• extracts the metadata
Page 197 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
DAM Media Handlers
• generates a thumbnail
• creates sub-assets: each page of the document becomes a sub-asset
The following example shows how to disable the sub-asset creation for PDF documents by
extending the workflow: the Process Subassets step will be replaced by an OR-split that checks
the asset filename:
• if it ends with .pdf, the asset reaches the End step.
• if it does not end with .pdf, the asset goes through a Process Subassets step that
generates sub-assets.
The workflow will look as follows:
Proceed as follows:
1.
Create a service (for example com.day.cq5.myprocess.DoNothingProcess) that does
not affect the asset and install it in CQ5. This service will be used to bypass the sub-asset
creation step.
Tip
You can refer to the section called “Example: create a specific Text Handler” to see
how to create a service and install it in CQ5.
Page 198 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
DAM Media Handlers
2.
In your browser, open the Workflow Console (for example: http://localhost:4502/
libs/workflow/content/console.html).
3.
Select the Models tab and edit the DAM Asset Sync and Metadata Extractor
workflow.
4.
Drag and drop an OR Split between the Thumbnail Creation step and the Process
Subassets step.
5.
Click the configuration button of the left step of the OR Split and set the following properties in
the right panel:
• Type: select Process
• Description: This process creates subassets if handler is able to
extract subassets
• Handler Advance: true
• Implementation: select com.day.cq.dam.core.process.CreateSubAssetsProcess
• Process Arguments: /etc/workflow/models/dam/sub_asset_processor
• Timeout: Off
• Timeout Handler:
• Title: Process Subassets
6.
Click the configuration button of the right step of the OR Split and set the following properties
in the right panel:
• Type: select Process
• Description: This process does not affect the asset and leads to the
next step
• Handler Advance: true
• Implementation: type the name of the service here (the service created in step 1; for
example: com.day.cq5.myprocess.DoNothingProcess)
• Process Arguments:
• Timeout: Off
• Timeout Handler:
• Title: Do Nothing
7.
Delete the Process Subassets step that comes after the end of the OR Split.
8.
Create an ecma-script function that is set to true if the filename ends with .pdf, to false
otherwise:
1.
In CQDE, create a file under /etc/workflow/scripts and call it
myPdfCheck.ecma.
2.
Copy-paste the following code into it:
function check() {
if (workflowData.getPayloadType() == "JCR_PATH") {
var path = workflowData.getPayload().toString();
Page 199 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
DAM Media Handlers
var node = jcrSession.getItem(path);
if (node.getPath().indexOf(".pdf") >= 0) {
return true;
} else {
return false;
}
} else {
return false;
}
}
3.
9.
Save the file.
Create an ecma-script function that is set to true if the filename does not end with .pdf, to
false otherwise:
1.
In CQDE, create a file under /etc/workflow/scripts and call it
myNotPdfCheck.ecma.
2.
Copy-paste the following code into it:
function check() {
if (workflowData.getPayloadType() == "JCR_PATH") {
var path = workflowData.getPayload().toString();
var node = jcrSession.getItem(path);
if (node.getPath().indexOf(".pdf") >= 0) {
return false;
} else {
return true;
}
} else {
return true;
}
}
3.
Save the file.
10. In your browser, set the rule of the Process Subassets step of the OR Split: type /etc/
workflow/scripts/myPdfCheck.ecma as value of the Rule.
11. Set the rule of the Do Nothing step of the OR Split: type /etc/workflow/scripts/
myNotPdfCheck.ecma as value of the Rule.
12. Save the workflow.
From now on, whenever a pdf file is uploaded into the /var/dam/geometrixx/documents
folder, the file is copied into /content/dam/geometrixx/documents, its metadata are
extracted and thumbnails are generated. Subassets are not created anymore.
30.3 Disabling/Enabling a Media Handler
The media handlers can be disabled or enabled through the Apache Felix Web Management
Console. When the media handler is disabled, its tasks are not performed on the assets.
To enable/disable a media handler:
1.
In your browser, navigate to http://<host>:<port>/system/console/components.
2.
Click the Disable button right beside the name of the media handler. For example:
com.day.cq.dam.handler.standard.mp3.Mp3Handler.
3.
Refresh the page: a Disabled icon is displayed beside the media handler.
4.
To enable the media handler, click the Enable button beside the name of the media handler.
Page 200 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
DAM Media Handlers
30.4 Creating a new Media Handler
To support a new media type or to execute specific tasks on an asset, it is necessary to create a
new media handler. This section describes how to proceed.
30.4.1 Important Classes and Interfaces
The best way to start an implementation is to inherit from a provided abstract implementation
that takes care of most things and provides reasonable default behaviour: the
com.day.cq.dam.core.AbstractAssetHandler Class.
Note
This class already provides an abstract service descriptor. So if you inherit from this class
and use the maven-sling-plugin, make sure that you set the inherit flag to true.
The following methods need to be implemented:
• extractMetadata(): this method extracts all available metadata.
• getThumbnailImage(): this method creates a thumbnail image out of the passed asset.
• getMimeTypes(): this method returns the asset mime type(s).
Here is an example template:
package my.own.stuff;
/**
* @scr.component inherit="true"
* @scr.service
*/
public class MyMediaHandler extends com.day.cq.dam.core.AbstractAssetHandler {
// implement the relevant parts
}
The interface and classes include:
com.day.cq.dam.api.handler.AssetHandler Interface
This interface describes the service which adds support for specific mime types. Adding a new
mime type requires to implement this interface. The interface contains methods for importing
and exporting the specific documents, for creating thumbnails and extracting metadata.
For more information refer to the Javadocs.
com.day.cq.dam.core.AbstractAssetHandler Class
This class serves as basis for all other asset handler implementations and provides common
used functionality.
For more information refer to the Javadocs.
com.day.cq.dam.core.AbstractSubAssetHandler Class:
This class serves as basis for all other asset handler implementations and provides common
used functionality plus common used functionality for subasset extraction
For more information refer to the Javadocs.
30.4.2 Example: create a specific Text Handler
In this section, you will create a specific Text Handler that generates thumbnails with a watermark.
Proceed as follows:
Page 201 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
DAM Media Handlers
Note
Refer to the section called “Installing Eclipse” for installing and setting up Eclipse with a
Maven plugin and for setting up the dependencies that are needed for the Maven project.
1.
In Eclipse, create the myBundle Maven project:
1.
In the Menu bar, click File, select New, then Other... .
2.
In the dialog, expand the Maven folder, select Maven Project and click Next.
3.
Check the Create a simple project box and the Use default Workspace
locations box, then click Next.
4.
Define the Maven project:
• Group Id: com.day.cq5.myhandler
• Artifact Id: myBundle
• Name: My CQ5 bundle
• Description: This is my CQ5 bundle
5.
2.
Click Finish.
Set the Java Compiler to version 1.5:
1.
Right-click the myBundle project, select Properties.
2.
Select Java Compiler and set following properties to 1.5:
• Compiler compliance level
• Generated .class files compatibility
• Source compatibility
3.
3.
Click OK.
4.
In the dialog window, click Yes.
Replace the code in the pom.xml file with the following code:
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/
XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://
maven.apache.org/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<!-- ====================================================================== -->
<!-- P A R E N T P R O J E C T D E S C R I P T I O N
-->
<!-- ====================================================================== -->
<parent>
<groupId>com.day.cq.dam</groupId>
<artifactId>dam</artifactId>
<version>5.2.14</version>
<relativePath>../parent</relativePath>
</parent>
<!-- ====================================================================== -->
<!-- P R O J E C T D E S C R I P T I O N
-->
<!-- ====================================================================== -->
<groupId>com.day.cq5.myhandler</groupId>
<artifactId>myBundle</artifactId>
<name>My CQ5 bundle</name>
<version>0.0.1-SNAPSHOT</version>
<description>This is my CQ5 bundle</description>
Page 202 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
DAM Media Handlers
<packaging>bundle</packaging>
<!-- ====================================================================== -->
<!-- B U I L D
D E F I N I T I O N
-->
<!-- ====================================================================== -->
<build>
<plugins>
<plugin>
<groupId>org.apache.felix</groupId>
<artifactId>maven-scr-plugin</artifactId>
</plugin>
<plugin>
<groupId>org.apache.sling</groupId>
<artifactId>maven-sling-plugin</artifactId>
<configuration>
<slingUrlSuffix>/libs/dam/install/</slingUrlSuffix>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.felix</groupId>
<artifactId>maven-bundle-plugin</artifactId>
<extensions>true</extensions>
<configuration>
<instructions>
<Bundle-Category>cq5</Bundle-Category>
<Export-Package>
com.day.cq5.myhandler
</Export-Package>
</instructions>
</configuration>
</plugin>
</plugins>
</build>
<!-- ====================================================================== -->
<!-- D E P E N D E N C I E S
-->
<!-- ====================================================================== -->
<dependencies>
<dependency>
<groupId>com.day.cq.dam</groupId>
<artifactId>cq-dam-api</artifactId>
<version>5.2.10</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>com.day.cq.dam</groupId>
<artifactId>cq-dam-core</artifactId>
<version>5.2.10</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>com.day.cq</groupId>
<artifactId>cq-commons</artifactId>
</dependency>
<dependency>
<groupId>javax.jcr</groupId>
<artifactId>jcr</artifactId>
</dependency>
<dependency>
<groupId>org.apache.felix</groupId>
<artifactId>org.osgi.compendium</artifactId>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
</dependency>
<dependency>
<groupId>commons-lang</groupId>
<artifactId>commons-lang</artifactId>
</dependency>
<dependency>
<groupId>commons-collections</groupId>
Page 203 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
DAM Media Handlers
<artifactId>commons-collections</artifactId>
</dependency>
<dependency>
<groupId>commons-io</groupId>
<artifactId>commons-io</artifactId>
</dependency>
<dependency>
<groupId>com.day.commons</groupId>
<artifactId>day-commons-gfx</artifactId>
</dependency>
<dependency>
<groupId>com.day.commons</groupId>
<artifactId>day-commons-text</artifactId>
</dependency>
<dependency>
<groupId>com.day.cq.workflow</groupId>
<artifactId>cq-workflow-api</artifactId>
</dependency>
<dependency>
<groupId>com.day.cq.wcm</groupId>
<artifactId>cq-wcm-foundation</artifactId>
<version>5.2.22</version>
</dependency>
</dependencies>
</project>
4.
5.
Create the package com.day.cq5.myhandler that will contain the Java classes under
myBundle/src/main/java:
1.
Under myBundle, right-click src/main/java, select New, then Package.
2.
Name it com.day.cq5.myhandler and click Finish.
Create the Java class MyHandler:
1.
In Eclipse, under myBundle/src/main/java, right-click the
com.day.cq5.myhandler package, select New, then Class.
2.
In the dialog window, name the Java Class MyHandler and click Finish. Eclipse
creates and opens the file MyHandler.java.
3.
In MyHandler.java replace the existing code with the following:
package com.day.cq5.myhandler;
import
import
import
import
import
import
java.awt.Color;
java.awt.Rectangle;
java.awt.image.BufferedImage;
java.io.IOException;
java.io.InputStream;
java.io.InputStreamReader;
import javax.jcr.Node;
import javax.jcr.RepositoryException;
import javax.jcr.Session;
import org.apache.commons.io.IOUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import
import
import
import
import
com.day.cq.dam.api.metadata.ExtractedMetadata;
com.day.cq.dam.core.AbstractAssetHandler;
com.day.image.Font;
com.day.image.Layer;
com.day.cq.wcm.foundation.ImageHelper;
/**
Page 204 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
DAM Media Handlers
* The <code>MyHandler</code> can extract text files
*
* @scr.component inherit="true" immediate="true" metatype="false"
* @scr.service
*/
public class MyHandler extends AbstractAssetHandler {
/**
* Logger instance for this class.
*/
private static final Logger log = LoggerFactory.getLogger(MyHandler.class);
/**
* Music icon margin
*/
private static final int MARGIN = 10;
/**
* @see com.day.cq.dam.api.handler.AssetHandler#getMimeTypes()
*/
public String[] getMimeTypes() {
return new String[] {"text/plain"};
}
public ExtractedMetadata extractMetadata(Node asset) {
ExtractedMetadata extractedMetadata = new ExtractedMetadata();
InputStream data = getInputStream(asset);
try {
// read text data
InputStreamReader reader = new InputStreamReader(data);
char[] buffer = new char[4096];
String text = "";
while (reader.read(buffer) != -1) {
text += new String(buffer);
}
reader.close();
long wordCount = this.wordCount(text);
extractedMetadata.setProperty("text", text);
extractedMetadata.setMetaDataProperty("Word Count",wordCount);
setMimetype(extractedMetadata, asset);
} catch (Throwable t) {
log.error("handling error: " + t.toString(), t);
} finally {
IOUtils.closeQuietly(data);
}
return extractedMetadata;
}
// ----------------------< helpers >---------------------------------------protected BufferedImage getThumbnailImage(Node node) {
ExtractedMetadata metadata = extractMetadata(node);
final String text = (String) metadata.getProperty("text");
// create text layer
final Layer layer = new Layer(500, 600, Color.WHITE);
layer.setPaint(Color.black);
Font font = new Font("Arial", 12);
String displayText = this.getDisplayText(text, 600, 12);
if(displayText!=null && displayText.length() > 0) {
// commons-gfx Font class would throw IllegalArgumentException on
empty or null text
layer.drawText(10, 10, 500, 600, displayText, font, Font.ALIGN_LEFT,
0, 0);
}
// create watermark and merge with text layer
Layer watermarkLayer;
try {
final Session session = node.getSession();
Page 205 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
DAM Media Handlers
watermarkLayer = ImageHelper.createLayer(session, "/var/dam/geometrixx/icons/
certificate.png");
watermarkLayer.setX(MARGIN);
watermarkLayer.setY(MARGIN);
layer.merge(watermarkLayer);
} catch (RepositoryException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
layer.crop(new Rectangle(510, 600));
return layer.getImage();
}
// ---------------< private >----------------------------------------------/**
* This method cuts lines if the text file is too long..
*
* @param text
*
text to check
* @param height
*
text box height (px)
* @param fontheight
*
font height (px)
* @return the text which will fit into the box
*/
private String getDisplayText(String text, int height, int fontheight) {
String trimmedText = text.trim();
int numOfLines = height / fontheight;
String lines[] = trimmedText.split("\n");
if (lines.length <= numOfLines) {
return trimmedText;
} else {
String cuttetText = "";
for (int i = 0; i < numOfLines; i++) {
cuttetText += lines[i] + "\n";
}
return cuttetText;
}
}
/**
* This method counts the number of words in a string
*
* @param text the String whose words would like to be counted
* @return the number of words in the string
*/
private long wordCount(String text) {
// We need to keep track of the last character, if we have two white
spaces in a row we dont want to double count
// The starting of the document is always a whitespace
boolean prevWhiteSpace = true;
boolean currentWhiteSpace = true;
char c;
long numwords = 0;
int j = text.length();
int i = 0;
while (i < j) {
c = text.charAt(i++);
if (c == 0) {
break;
}
currentWhiteSpace = Character.isWhitespace(c);
if (currentWhiteSpace && !prevWhiteSpace) {
numwords++;
}
prevWhiteSpace = currentWhiteSpace;
}
Page 206 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
DAM Media Handlers
// If we do not end with a white space then we need to add one extra
word
if (!currentWhiteSpace) {
numwords++;
}
return numwords;
}
}
4.
6.
Save the changes.
Compile the Java class and create the bundle:
1.
Right-click the myBundle project, select Run As, then Maven Install.
2.
The bundle myBundle-0.0.1-SNAPSHOT.jar (containing the compiled class) is
created under myBundle/target.
7.
In CRX Explorer, create a new node under /apps/myApp. Name = install, Type =
nt:folder.
8.
Copy the bundle myBundle-0.0.1-SNAPSHOT.jar and store it under /apps/myApp/
install (for example with WebDAV).
Note
The new text handler is now active in CQ5.
9.
In your browser, open the Apache Felix Web Management Console and disable the default
text handler com.day.cq.dam.core.impl.handler.TextHandler.
From now on, whenever you upload a txt file into CQ5 under the /var/dam/documents folder,
the file is copied into /content/dam/documents, its metadata are extracted and two thumbnails
with a watermark are generated.
Page 207 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
31 How to Model Data
31.1 Data Modeling - David Nuescheler's Model
31.1.1 Source
The following details are ideas and comments expressed by David Nuescheler.
David is co-founder and CTO of Day Software AG, a leading provider of global content
management and content infrastructure software. He also leads the development of JSR-170, the
Java Content Repository (JCR) application programming interface (API), the technology standard
for content management.
Further updates can also be seen on http://wiki.apache.org/jackrabbit/DavidsModel.
31.1.2 Introduction from David
In various discussions I found that developers are somewhat at unease with the features and
functionalities presented by JCR when it comes to content modeling. There is no guide and very
little experience yet on how to model content in a repository and why one content model is better
than the other.
While in the relational world the software industry has a lot of experience on how to model data, we
are still at the early stages for the content repository space.
I would like to start filling this void by expressing my personal opinions on how content should
be modeled, hoping that this could some day graduate into something more meaningful to the
developers community, which is not just "my opinion" but something that is more generally
applicable. So consider this my quickly evolving first stab at it.
Important
Disclaimer: These guidelines express my personal, sometimes controversial views. I am
looking forward to debate these guidelines and refine them.
31.1.3 Seven Simple Rules
31.1.3.1 Rule #1: Data First, Structure Later. Maybe.
31.1.3.1.1 Explanation
I recommend not to worry about a declared data structure in an ERD sense. Initially.
Learn to love nt:unstructured (& friends) in development.
I think Stefano pretty much sums this one up.
My bottom-line: Structure is expensive and in many cases it is entirely unnecessary to explicitly
declare structure to the underlying storage.
There is an implicit contract about structure that your application inherently uses. Let's say I store
the modification date of a blog post in a lastModified property. My App will automatically know
to read the modification date from that same property again, there is really no need to declare that
explicitly.
Further data constraints like mandatory or type and value constraints should only be applied where
required for data integrity reasons.
Page 208 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Model Data
31.1.3.1.2 Example
The above example of using a "lastModified" Date property on for example "blog post" node, really
does not mean that there is a need for a special nodetype. I would definitely use "nt:unstructured"
for my blog post nodes at least initially. Since in my blogging application all I am going to do is to
display the lastModified date anyway (possibly "order by" it) I barely care if it is a Date at all. Since
I implicitly trust my blog-writing application to put a "date" there anyway, there really is no need to
declare the presence of a "lastModified" date in the form a of nodetype.
31.1.3.1.3 Discussion
http://www.nabble.com/DM-Rule-#1:-Data-First,-Structure-Later.-Maybe.-tf4039967.html
31.1.3.2 Rule #2: Drive the content hierarchy, don't let it happen.
31.1.3.2.1 Explanation
The content hierarchy is a very valuable asset. So don't just let it happen, design it. If you don't
have a "good", human-readable name for a node, that's probably that you should reconsider.
Arbitrary numbers are hardly ever a "good name".
While it may be extremely easy to quickly put an existing relational model into a hierarchical model,
one should put some thought in that process.
In my experience if one thinks of access control and containment usually good drivers for the
content hierarchy. Think of it as if it was your file system. Maybe even use files and folders to
model it on your local disk.
Personally I prefer hierarchy conventions over the nodetyping system in a lot of cases initially, and
introduce the typing later.
31.1.3.2.2 Example
I would model a simple blogging system as follows. Please note that initially I don't even care about
the respective nodetypes that I use at this point.
/content/myblog
/content/myblog/posts
/content/myblog/posts/what_i_learned_today
/content/myblog/posts/iphone_shipping
/content/myblog/comments/iphone_shipping/i_like_it_too
/content/myblog/comments/iphone_shipping/i_like_it_too/i_hate_it
I think one of the things that become apparent is that we all understand the structure of the content
based on the example without any further explanations.
What may be unexpected initially is why I wouldn't store the "comments" with the "post", which is
due to access control which I would like to be applied in a reasonably hierarchical way.
Using the above content model I can easily allow the "anonymous" user to "create" comments, but
keep the anonymous user on a read-only basis for the rest of the workspace.
31.1.3.2.3 Discussion
http://www.nabble.com/DM-Rule-#2:-Drive-the-content-hierarchy,-don't-let-it-happen.tf4039994.html
31.1.3.3 Rule #3: Workspaces are for clone(), merge() and update().
31.1.3.3.1 Explanation
If you don't use clone(), merge() or update() methods in your application a single workspace is
probably the way to go.
Page 209 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Model Data
"Corresponding nodes" is a concept defined in the JCR spec. Essentially, it boils down to nodes
that represent the same content, in different so-called workspaces.
JCR introduces the very abstract concept of Workspaces which leaves a lot of developers unclear
on what to do with them. I would like to propose to put your use of workspaces to the following to
test.
If you have a considerable overlap of "corresponding" nodes (essentially the nodes with the same
UUID) in multiple workspaces you probably put workspaces to good use.
If there is no overlap of nodes with the same UUID you are probably abusing workspaces.
Workspaces should not be used for access control. Visibility of content for a particular group of
users is not a good argument to separate things into different workspaces. JCR features "Access
Control" in the content repository to provide for that.
Workspaces are the boundary for references and query.
31.1.3.3.2 Example
Use workspaces for things like:
• v1.2 of your project vs. a v1.3 of your project
• a "development", "QA" and a "published" state of content
Do not use workspaces for things like:
• user home directories
• distinct content for different target audiences like public, private, local, ...
• mail-inboxes for different users
31.1.3.3.3 Discussion
http://www.nabble.com/DM-Rule-#3:-Workspaces-are-for-corresponding-nodes.-tf4040010.html
31.1.3.4 Rule #4: Beware of Same Name Siblings.
31.1.3.4.1 Explanation
While Same Name Siblings (SNS) have been introduced into the spec to allow compatibility with
data structures that are designed for and expressed through XML and therefore are extremely
valuable to JCR, SNS come with a substantial overhead and complexity for the repository.
Any path into the content repository that contains an SNS in one of its path segments becomes
much less stable, if an SNS is removed or reordered, it has an impact on the paths of all the other
SNS and their children.
For import of XML or interaction with existing XML SNS maybe necessary and useful but I have
never used SNS, and never will in my "green field" data models.
31.1.3.4.2 Example
Use
/content/myblog/posts/what_i_learned_today
/content/myblog/posts/iphone_shipping
instead of
Page 210 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Model Data
/content/blog[1]/post[1]
/content/blog[1]/post[2]
31.1.3.4.3 Discussion
http://www.nabble.com/DM-Rule-#4:-Beware-of-Same-Name-Siblings.-tf4040024.html
31.1.3.5 Rule #5: References considered harmful.
31.1.3.5.1 Explanation
References imply referential integrity. I find it important to understand that references do not just
add additional cost for the repository managing the referential integrity, but they also are costly
from a content flexibility perspective.
Personally I make sure I only ever use references when I really cannot deal with a dangling
reference and otherwise use a path, a name or a string UUID to refer to another node.
31.1.3.5.2 Example
Let's assume I allow "references" from a document (a) to another document (b). If I model this
relation using reference properties this means that the two documents are linked on a repository
level. I cannot export/import document (a) individually, since the reference property's target may
not exist. Other operations like merge, update, restore or clone are affected as well.
So I would either model those references as "weak-references" (in JCR v1.0 this essentially boils
down to string properties that contain the uuid of the target node) or simply use a path. Sometimes
the path is more meaningful to begin with.
I think there are use cases where a system really can't work if a reference is dangling, but I just
can't come up with a good "real" yet simple example from my direct experience.
31.1.3.5.3 Discussion
http://www.nabble.com/DM-Rule-#5:-References-considered-harmful.-tf4040042.html
31.1.3.6 Rule #6: Files are Files are Files.
31.1.3.6.1 Explanation
If a content model exposes something that even remotely smells like a file or a folder I try to use (or
extend from) nt:file, nt:folder and nt:resource.
In my experience a lot of generic applications allow interaction with nt:folder and nt:files implicitly
and know how to handle and display those event if they are enriched with additional metainformation. For example a direct interaction with file server implementations like CIFS or WebDAV
sitting on top of JCR become implicit.
I think as good rule of thumb one could use the following: If you need to store the filename and
the mime-type then nt:file/nt:resource is a very good match. If you could have multiple "files" an
nt:folder is a good place to store them.
If you need to add meta information for your resource, let's say an "author" or a "description"
property, extend nt:resource not the nt:file. I rarely extend nt:file and frequently extend nt:resource.
31.1.3.6.2 Example
Let's assume that someone would like to upload an image to a blog entry at:
/content/myblog/posts/iphone_shipping
Page 211 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Model Data
and maybe the initial gut reaction would be to add a binary property containing the picture.
While there certainly are good use cases to use just a binary property (let's say the name is
irrelevant and the mime-type is implicit) in this case I would recommend the following structure for
my blog example.
/content/myblog/posts/iphone_shipping/attachments [nt:folder]
/content/myblog/posts/iphone_shipping/attachments/front.jpg [nt:file]
/content/myblog/posts/iphone_shipping/attachments/front.jpg/jcr:content [nt:resource]
31.1.3.6.3 Discussion
http://www.nabble.com/DM-Rule-#6:-Files-are-Files-are-Files.-tf4040063.html
31.1.3.7 Rule #7: IDs are evil.
31.1.3.7.1 Explanation
In relational databases IDs are a necessary means to express relations, so people tend to use
them in content models as well. Mostly for the wrong reasons through.
If your content model is full of properties that end in "Id" you probably are not leveraging the
hierarchy properly.
It is true that some nodes need a stable identification throughout their live cycle. Much fewer than
you might think though. mix:referenceable provides such a mechanism built into the repository,
so there really is no need to come up with an additional means of identifying a node in a stable
fashion.
Keep also in mind that items can be identified by path, and as much as "symlinks" make way
more sense for most users than hardlinks in a unix filesystem, a path makes a sense for most
applications to refer to a target node.
More importantly, it is **mix**:referenceable which means that it can be applied to a node at the
point in time when you actually need to reference it.
So let's say just because you would like to be able to potentially reference a node of type
"Document" does not mean that your "Document" nodetype has to extend from mix:referenceable
in a static fashion since it can be added to any instance of the "Document" dynamically.
31.1.3.7.2 Example
use:
/content/myblog/posts/iphone_shipping/attachments/front.jpg
instead of:
[Blog]
- blogId
- author
[Post]
- postId
- blogId
- title
- text
- date
[Attachment]
- attachmentId
- postId
- filename
Page 212 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
How to Model Data
+ resource (nt:resource)
31.1.3.7.3 Discussion
http://www.nabble.com/DM-Rule-#7:-IDs-are-evil.-tf4040076.html
Page 213 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG
Appendix A. Copyright, Licenses and
Formatting Conventions
For all copyright statements and license agreements see Copyright, Licenses and Disclaimers.
A.1 Formatting Conventions
The following tables detail formatting conventions used within this guide:
Table A.1. Formatting Conventions - Text
Style
Description
Example
Cross-reference
Cross-reference to external documents.
See the Microsoft Manual of
Style for Technical Publications.
GUI Item
User interface items.
Click Save.
Keyboard shortcut
Keyboard shortcuts.
Press Ctrl+A.
Mouse Button
Mouse buttons.
Secondary-mouse button
(usually the right-mouse
button).
Link
Link to anchor-points within the current
document and/or external sources.
http://www.day.com
Code
Example of programming code.
if (weather == sunny) smile;
User Input
Example of text, or commands, that you
type.
<Variable User
Input>
Example of variable text - you type the
actual value needed.
ls <cq-installation-dir>
[Optional
Parameter]
An optional parameter.
ls [<option>] [<filename>]
Computer Output
Logging and error messages.
ls *.xml
ls: cannot access
error.log:
Table A.2. Formatting Conventions - Actions
When you see this...
It means do this...
Ctrl+A
Hold down the Ctrl key, then press the A key.
Right-click
Press the right-mouse button (or the left-mouse button if your mouse
has been configured for left-handed use).
Drag
Hold down the left mouse button while moving the item, then release the
mouse button at the new location (or the right mouse button if your mouse
has been configured for left-handed use).
Page 214 of 214
CQ 5.2 WCM
Copyright 1993-2009 Day Management AG