Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

Table of Contents
maxLevel2
minLevel2

 

 


...


Terminology

This topic uses the following acronyms. The meaning of each one is described below. 


TermDescription
POJO

A Plain Old Java Object. This refers to a basic Java class not implementing or extending any special class(es).

MVC

Model-View-Controller. A design pattern used to separate the business model, business logic and UI logic.

Spring MVC

The web application framework used by XperienCentral to render the Editor.

DAOData Access Object. An object that encapsulates all access to a particular data source. It is used to prevent a business object from having dependencies with a particular persistence implementation.
DTAP

Development Test Acceptance and Production.

JCR

Java Content Repository.

RBAC

Role Based Access Control.

FBOA FormBackingObject, which is an object that represents the data contained by an HTML form.
Plugin audit

The process of verifying a plugin against the plugin development guidelines and granting a particular certification level.

Plugin certification level

A level that indicates the extent to which the plugin conforms to the plugin development guidelines. The higher the certification level, the more the plugin conforms to the defined guidelines.

Plugin certification range

The range from the first certified plugin version to the first major version of the plugin for which the current plugin certification level will not be valid anymore and a new plugin audit will be required.

Guideline scope

The software component(s) or component type(s) to which the guideline applies.

Pre-audit

The act of running the plugin guideline audit tool to verify your plugin against a basic subset of guidelines.

...


Back to top 


...

The Certification Process

...

  • Version of the audited plugin : 1.1.4
  • Assigned plugin certification level: 2
  • Certified on XperienCentral version: 10.8
  • Plugin certification range: 1.1.4 to 2.0 (but not including 2.0)

...


Back to top 


...

Guidelines Overview

This document describes the guidelines and conventions for plugin development. These are divided into the following themes:

...

The following abbreviations are used in the table summary: 


ScopeDescription
A

The guideline applies to all component types or to the plugin or WCA as a whole.

P

The guideline applies to panel components.

E

The guideline applies to element components.

M

The guideline applies to media item components.

C

The guideline applies to service components.

D

The guideline applies to page metadata components.

L

The guideline applies to servlet components.

R

The guideline applies to presentation components.

F

The guideline applies to form components.

V

The guideline applies to profile provider components.

 


Back to top 


...

Anchor
guidelines_summary
guidelines_summary

...

The table below summarizes all the guidelines. Because the guidelines have evolved over time, some IDs have been removed, therefore the sequential order skips numbers in some places. If the column "Certification Level" is blank, this means that the guideline is not required for any certification level and is only a recommendation. Most of the guidelines are discussed in greater length following the table below. 


             
Guideline IDDescriptionCertification LevelScope
G001
Anchor
g001
g001

The HTML rendering the UI conforms to the basic layout using a table of class widget grid.

1PEMDV
G002
Anchor
g002
g002

The HTML rendering the UI uses only the defined CSS classes.

3PEMDV
G003
Anchor
g003
g003

The UI conforms to the basic guidelines.

2PEMDV
G004
Anchor
g004
g004

The UI uses the widgets supported by the XperienCentral platform.

2PEMDV
G005
Anchor
g005
g005

The JSPs that render the HTML use the JSTL tags and JSP tags offered by the XperienCentral platform as often as possible.

2PEMDV
G006
Anchor
g006
g006

The UI conforms to the defined UI interaction patterns.

2PEMDV
G007
Anchor
g007
g007

The business object is implemented as a POJO and does not contain any reference to a controller, form backing object or DAO.

1PEMDV
G008
Anchor
g008
g008

The business object does not contain properties or logic whose sole purpose is the view.

1PDV
G009
Anchor
g009
g009

The FormBackingObject is implemented as a POJO and does not have any reference to a controller, DAO or business object unless the business object is a POJO itself.

1PEMDV
G010
Anchor
g010
g010

The FormBackingObject reflects the properties and logic to be rendered by the view and not the properties and logic of the business object from which it retrieves values.

1PEMDV
G011
Anchor
g011
g011

The FormBackingObject and Business Object is not one and the same object.

1PEMDV
G012
Anchor
g012
g012

The copyProperties() method of org.springframework.beans.BeanUtils is used to transfer values from the FormBackingObject to the business object (or vice versa).

3PMDV
G013
Anchor
g013
g013

The controller is a separate class and implements all controller logic.

1PEMD
G014
Anchor
g014
g014

Persistence logic is not contained by the business object but implemented in a separate DAO.

1PEMDV
G015
Anchor
g015
g015

JSPs do not contain SQL statements or other persistence implementation-specific logic unless they are contained by a separate JSP tag.

1PEMDRV
G016
Anchor
g016
g016

The plugin contains all resources not provided by dependencies or other presentation plugins and is capable of being deployed and functioning properly on any XperienCentral installation, as long as all its defined dependencies are available.

1A
G017
Anchor
g017
g017

The version number of a plugin conforms to the syntax "major.minor.micro".

1A
G019
Anchor
g019
g019

The version numbers of the plugin are independent of the XperienCentral release they were developed for.

1A
G020
Anchor
g020
g020

If the data model of the plugin has been changed in a newer version of the plugin , the plugin must properly handle data model updates.

2PEMDV
G021
Anchor
g021
g021

The API that XperienCentral provides is used to access the data model XperienCentral exposes.

1A
G022
Anchor
g022
g022

XperienCentral features and API functions are used where possible instead of implementing custom functions.

1A
G023
Anchor
g023
g023

When the plugin uses a service, a dependency with that service is defined in the component definition in order to retrieve a reference to the service.

1A
G024
Anchor
g024
g024

Text, images and other GUI components are suitable for translation.

3PEMCDV
G025
Anchor
g025
g025

Multilingual content that can be created using the plugin is translatable.


PEMCDLFV
G026
Anchor
g026
g026

Language labels are defined in language resource files conforming to JavaI18N and the filename meets the syntax messages_<language>_<country>_<variant>.properties.

1PEMCDLFV
G027
Anchor
g027
g027

Label IDs in the language resource files use only lower case letters.

1PEMCDLFV
G028
Anchor
g028
g028

Language labels in language resource files are grouped per component and prefixed with at least the ID of the component.

 
PEMCDLFV
G034
Anchor
g034
g034

Documentation is available in at least the US English language.

3PEMDFV
G035
Anchor
g035
g035

A plugin is distributed as a single ZIP file known as a WCA (WebManager Component Archive) which can also contain other related plugins.

1A
G036
Anchor
g036
g036

The contents of the WCA conforms to the defined directory structure.

2A
G037
Anchor
g037
g037

The WCA contains a readme.txt and a changelog.txt.

1A
G038
Anchor
g038
g038

The layout of the readme.txt and changelog.txt follow the defined templates. Click the links to the left to download the templates.

1A
G039
Anchor
g039
g039

The plugin JAR file containing the software follows the defined directory structure.

1A
G042
Anchor
g042
g042

The HTML generated by the JSPs for rendering the Editor is XHTML 1.0 transitional compliant.

3PEMDV
G045
Anchor
g045
g045

All content generated by the plugin is stored in the JCR or in an external database if there is an obvious need for it.

1PEMCDLFV
G046
Anchor
g046
g046

The configuration management service is used to store configuration options. No hard-coded web IDs, paths or URLs are used in the software.

1PEMCDLFV
G047
Anchor
g047
g047

The preferences service is used to store all preferences.

1PEMCDLFV
G048
Anchor
g048
g048

The output-html-encoded-quotes XSLT template is used to properly escape HTML strings in the output when using XSLT.

1PEMDRV
G049
Anchor
g049
g049

SQL-prepared statements are used for all SQL queries.

1A
G050
Anchor
g050
g050

At least one RBAC category is defined for each component which has a GUI representation which contains one or more RBAC permissions for the component.

2PEDV
G051
Anchor
g051
g051

A permission category defines and implements at least the RBAC permissions as defined.

2PEV
G052
Anchor
g052
g052

The implementation of RBAC permission handling is mainly programmed in a controller or service, not in the business object itself. The check is only performed in the business object itself if the permission defines authorization to retrieve or update that particular property only.

2PEMDV
G053
Anchor
g053
g053

The definition of all RBAC permissions is positive. Permissions are defined in a way that assigning the permission to a role grants the role particular rights and it never denies rights.

1PEMDV
G055
Anchor
g055
g055

Coding conventions: the coding conventions that Sun publishes as the standard for the Java programming language are followed.


A
G056
Anchor
g056
g056

Coding conventions: Java language features are used where applicable (Java version 5 and higher).

3A
G057
Anchor
g057
g057

Coding conventions: Java Util Logging is used where applicable and proper log levels are used (Java version 5 and higher).

1A
G058
Anchor
g058
g058

Coding conventions: Java concurrency utilities are used where applicable (Java version 5 and higher).

3A
G059
Anchor
g059
g059

Coding conventions: old collections like Hashtable, Vector or Dictionary are not used if it can be avoided.

1A
G060
Anchor
g060
g060

Coding conventions: the @override annotation is used if a method is overridden from a super class.

 
A
G061
Anchor
g061
g061

Coding conventions: The basic variant of the Hungarian notation is used.


A
G063
Anchor
g063
g063

Coding conventions: The source code does not contain blank spaces before and after method arguments, however, spaces are used after Java keywords and commas.


A
G064
Anchor
g064
g064

Coding conventions: Declare variables and methods in the following order: Class (static) variables, instance variables, constructors, methods.


A
G067
Anchor
g067
g067

The FIXME comment is used to indicate that code snippets are incorrect during development and do not appear in a released plugin.


A
G068
Anchor
g068
g068

The TODO comment is used to indicate that code snippets are incomplete during development and do not appear in a released plugin.


A
G069
Anchor
g069
g069

Coding conventions: Spaces are used instead of tabs for trailing white space in the source code.


A
G070
Anchor
g070
g070

Coding conventions: The size of one line in the software code is limited to 120 characters.


A
G071
Anchor
g071
g071

Coding conventions: Start brackets are added on the same line as the statement to which they apply but ending brackets appear on a new line.


A
G072
Anchor
g072
g072

Coding conventions: Brackets are used in all cases, even for single line statements.

 
A
G073
Anchor
g073
g073

Coding conventions: The source code conforms to Javadoc conventions defined by Sun.

2A
G074
Anchor
g074
g074

Coding conventions: Public and protected classes, interfaces, variables and methods are tagged with Javadoc.

2A
G075
Anchor
g075
g075

The Javadoc does not contain references to documents that might not be accessible by external developers.

3A
G076
Anchor
g076
g076

General plugin classes conform to the defined naming conventions.

1A
G077
Anchor
g077
g077

Element component classes conform to the defined naming conventions.

1E
G078
Anchor
g078
g078

Element component classes conform to the defined hierarchy.

1E
G079
Anchor
g079
g079

Media Item component classes conform to the defined naming conventions.

1M
G080
Anchor
g080
g080

Media Item component classes conform to the defined hierarchy.

1M
G081
Anchor
g081
g081

Panel component classes conform to the defined naming conventions.

1P
G082
Anchor
g082
g082

Panel component classes conform to the defined hierarchy.

1P
G083
Anchor
g083
g083

The domain used for naming is returned by ComponentBundleDefinition.getDomain().

1A
G084
Anchor
g084
g084

The plugin ID is returned by ComponentBundleDefinition.getWCBId().

1A
G087
Anchor
g087
g087

The prefix equals the plugin ID.

1A
G089
Anchor
g089
g089

Package names used in the source code of the plugin conform to the package naming guidelines as defined by the Sun coding conventions.

1A
G090
Anchor
g090
g090

Top level Java package names follow the syntax <domain>.<plugin ID>.

1A
G095
Anchor
g095
g095

The artifact ID in the pom.xml equals the plugin ID.

1A
G096
Anchor
g096
g096

The group ID in the pom.xml equals the domain.

1A
G097
Anchor
g097
g097

The ID of the component bundle definition defined in the activator of the plugin conforms to the defined syntax.

1A
G098
Anchor
g098
g098

The ID of each component definition contained by the plugin must be prefixed with the component bundle definition ID followed by an ID that is unique within the plugin, matches the component name and consists of lower case alphanumeric characters in the range [a-z]. This does not include the media item component definition.

1A
G099
Anchor
g099
g099

All IDs and properties defined use only lower case letters.

1A
G101
Anchor
g101
g101

The name of the RBAC category conforms to the syntax  <top level domain>.<plugin ID>.<Component ID>.

1PEMCDLFV
G102
Anchor
g102
g102

The technical name of each RBAC permission is prefixed with the technical name of the RBAC category, followed by a dot.

1PEMCDLFV
G103
Anchor
g103
g103

Technical names of categories and permissions are in lower case, do not contain spaces and separate words are separated by a dot.

1PEMCDLFV
G104
Anchor
g104
g104

For CRUD actions, the defined naming conventions are used. 


2PEMCDLFV
G105
Anchor
g105
g105

In user documentation, the defined naming conventions are used for XperienCentral assets.

3A
G106
Anchor
g106
g106

All names of labels, Java classes, methods, properties, etc. are in US English unless they represent translatable labels presented to the end user.

1A
G107
Anchor
g107
g107

The CMU-SEI (https://en.wikipedia.org/wiki/Cyclomatic_complexity) does not exceed 15.

3PEMCDLFV
G108
Anchor
g108
g108

Online help covering the visible components contained by the plugin is available.

2PEMDV
G109
Anchor
g109
g109

An API is exposed by a domain object interface when it consists of getters and setters for properties of that domain object.

1PEMCDLFV
G110
Anchor
g110
g110

Implementations of a domain object interface is postfixed with "Impl".

2PEMCDLFV
G111
Anchor
g111
g111

An API is exposed as a service when the API creates or deletes domain objects or operates on multiple domain objects.

2PEMCDLFV
G112
Anchor
g112
g112

An API service managing entities is preferably postfixed with "ManagementService".

3CV
G113
Anchor
g113
g113

A method handles an exception internally if it is recoverable.

2A
G114
Anchor
g114
g114

A method throws a checked exception if it is unrecoverable and occurs in an area outside the immediate control of the program.


A
G116
Anchor
g116
g116

Identifiers used by a plugin are defined in one class as public static final fields of that class.

3A
G117
Anchor
g117
g117

A plugin exposes its identifiers by exposing the class as defined by guideline G116.

3A
G118
Anchor
g118
g118

Any class or interface that is exposed by a plugin as API should be contained by a package called "api" directly under the plugin's root package, or by a sub package of this package.

2A
G119
Anchor
g119
g119

If content is stored in an internal relational database, the SQL scripts to create those database tables should be contained by the plugin in a /sqlscripts directory.

2A
G120
Anchor
g120
g120

Each plugin should come with a unit test or test bundle that has a code coverage of at least 10%.

3PEMCDLFV
G121
Anchor
g121
g121

The plugin ID only contains alphanumeric characters in the range [a-z].

1A
G122
Anchor
g122
g122

The domain only contains alphanumeric characters in the range [a-z] separated by dots.

1A
G123
Anchor
g123
g123

In the JSPs, properly escaped strings in the HTML are output using standard JSTL functions.

1PEMDRV
G124
Anchor
g124
g124

The contenttype of a media item component which is defined by the @ContentType annotation must equal the plugin ID or be prefixed by the plugin ID and may only contain alphanumeric characters in the range [a-z].

1M
G125
Anchor
g125
g125

Use the Entity Manager as the DAO implementation to store entities in the JCR when possible.


PEMCDLF
G126
Anchor
g126
g126

Creating and removing resources on which a plugin depends should be done automatically upon installation and purging the plugin if possible.

1A
G127
Anchor
g127
g127

Framework labels are grouped separately in the language resource files.                           

 
PEMCDLFV
G128
Anchor
g128
g128

Language files are at least available in US English.

2PEMCDLFV
G129
Anchor
g129
g129

A method should not catch an unchecked exception if it is unrecoverable and occurs in an area inside the immediate control of the program.

1A
G131
Anchor
g131
g131

A new checked exception type is used as the wrapper for multiple checked exceptions if the amount of thrown checked exception exceeds five.

2A
G132
Anchor
g132
g132

The Javadoc clearly explains how the class or interface should be used, preferably by providing code examples.

2A
G133
Anchor
g133
g133

For each package contained by the plugin, a package.html is provided that clarifies the purpose and contents of the package.


A
G134
Anchor
g134
g134

HTML generated by the JSPs for rendering the website environment should be XHTML 1.0 transitional compliant.

3R
G135
Anchor
g135
g135

If a method of a class implements a method of an interface, refer to the Javadoc of the interface using the {@inheritDoc} annotation.

2A
G136
Anchor
g136
g136

The bundleSymbolicName in the pom.xml matches the syntax <domain>.<plugin ID>.

1A
G137
Anchor
g137
g137

The presentation plugin is self-sufficient and does not depend on any resource provided by another plugin unless it is another presentation plugin .

1R
G138
Anchor
g138
g138

JSPs copied from the original XperienCentral platform presentation are copied to the specified directory.

1R
G139
Anchor
g139
g139

The value of the name attribute in the descriptor of a JSP is prefixed by the plugin ID.

1R
G140
Anchor
g140
g140

Static files used by the presentation plugin are located in a subdirectory that equals the plugin ID.

1R
G141
Anchor
g141
g141

The software does not contain code snippets that are commented out, not used or that duplicates of other code snippets in the same plugin .

2A
G142
Anchor
g142
g142

Media item JSPs that display the content of a media item contain a check to see whether the media item has not already been rendered before within the same request.

1MR
G143
Anchor
g143
g143

Use the Link.linkAttributes() method to build links in a JSP.

1PEMDRV
G144
Anchor
g144
g144

Implement caching properly by providing SSIs.

1PEMDRV
G145
Anchor
g145
g145

A plugin contains only those components that logically belong to each other.

1R
G147
Anchor
g147
g147

The plugin does not contain the empty online help that was generated by the archetype.

1A
G148
Anchor
g148
g148

Do not use public or protected instance variables. Use private instance variables with getters and setters instead.

1A
G149
Anchor
g149
g149

The plugin ID and domain are approved by GX and the plugin (of this version) is registered.

1A
G151
Anchor
g151
g151

The name of a scheduled job is prefixed by the plugin ID.

1C
G152
Anchor
g152
g152

The ID of each configuration set defined by the plugin is prefixed by or equals the plugin ID.

1A
G153
Anchor
g153
g153

The plugin contains an example frontend presentation if it requires such a presentation to work properly.

2EMDFV
G154
Anchor
g154
g154

The plugin supports the software and hardware as described in Hardware and Software Requirements.

2A

 


Back to top 


...

GUI Guidelines for the Editor

...

Developed plugins should apply this design pattern to be flexible, pluggable and extendable themselves. The figure below shows the abstraction layers in XperienCentral: 


 

 



In the approach depicted above, there is a very clean separation of responsibilities by the several application layers as also depicted below: 


 


The layers also conform to the MVC pattern in which a controller determines the model and returns the view to render the model.

...

  • The business object is implemented as a POJO and does not contain any reference to a controller, form backing object or DAO. However, It may contain service references or references to other business objects [G007].
  • The business object does not contain properties or logic whose only purpose is the view [G008]. An example violating this guideline would be defining a property like "selectedBook" that is not persisted but only temporarily stores the user selection in the view.
  • The FormBackingObject is implemented as a POJO and does not have any reference to a controller, DAO or business object, unless the business object is a POJO itself. It may contain references to other FormBackingObjects. [G009].
  • The FormBackingObject reflects the properties and logic to be rendered by the view and not the properties and logic of the business object from which it retrieves values. [G010].
  • The FormBackingObject and the business object are not one and the same object [G011].
  • Use the copyProperties() method of org.springframework.beans.BeanUtils to transfer values from the FormBackingObject to the business object and vice versa [G012].
  • The controller is a separate class (not mixed with business object and/or FormBackingObject) and it implements all controller logic such as creating, updating and deleting FormBackingObjects, business objects and the views [G013].
  • Persistence logic is not contained by the business object but is instead implemented in a separate DAO [G014]. It is recommended that you use the Entity Manager (a DAO implementation that currently supports only the JCR) available from XperienCentral.10.3 and later [G125]. Note that the current XperienCentral API does not yet support this for element business objects. For all other cases, this is the preferred way.
  • JSPs do not contain SQL statements or other persistence implementation specific logic, except for those with scope Query or DatabaseEntity. If you have to use SQL in a JSP, separate it by including the SQL statement in a separate JSP tag [G015].

...


Plugin Completeness

A plugin is intended to be an individual component that contains all resources (like images, Java code and XML files) that contribute to the functionality of that plugin. If the proper working of a plugin requires, for example, a change to the web.xml of the web application, this breaks the one-click deployment concept of a plugin. A plugin must be capable of being deployed on any XperienCentral installation and work properly as long as all its dependencies are available [G016]. Note that the plugin may depend on presentation files contained by another plugin for level 1 certification, but for level 2 certification, it is required you add to add at least a working example presentation to the plugin [G153].

...

Writing readable code contributes to the maintainability of the software code and makes the software less error-prone since it easy to understand what the code does and/or is supposed to do. For determining an objective measurement of software complexity the so called Cyclomatic Complexity Number can be determined. A definition of the CMU-SEI interpretation of this number can be found at https://en.wikipedia.org/wiki/Cyclomatic_complexity. It is recommended that the CMU-SEI of the software does not exceed 15 [G107]. 


Back to top 


...

Migration Guidelines

Versioning

...

Plugins that use a service must define a service dependency with this service in the component definition in order to retrieve a reference to the service [G023]. For example:

 


Code Block
themeEclipse
ComponentDependencyImpl serviceDependency = new ComponentDependencyImpl();
serviceDependency.setServiceName(BookService.class.getName());
serviceDependency.setRequired(true);
elementDefinition.setDependencies(
  new ComponentDependency[]{serviceDependency});  


Back to top 


...

Internationalization Guidelines

...

Language labels should be defined in language resource files conforming to JavaI18N. The name of these language files conforms to the syntax [G026]: 


Code Block
themeEclipse
messages_<language>_<country>_<variant>.properties

 


The language file contains the language labels used throughout the entire plugin but its scope is limited to that plugin. Using the same language labels in different plugins will not cause conflicts. It is recommended that you use only lower case letters for the label ID [G027] and that you group the language labels per component and prefix them with at least the ID of the component [G028]. All labels with an ID prefixed by panel.button are reserved by the framework for retrieving language labels for panel buttons - it is recommended that you group these labels separately [G127].

For example, if a plugin has three components with IDs reviewelement, reviewmediaitem and maintenancepanel, the US English resource file might look like this: 


Code Block
themeEclipse
// Framework labels
panel.button.apply=Apply
panel.button.close=Close
panel.button.ok=OK

// Labels for review element
reviewelement.menuitem=Books review element
reviewelement.headertitle=Books review element
reviewelement.title=Title
reviewelement.frontcover=Front cover

// Labels for review media item
reviewmediaitem.bookreview=Book review
reviewmediaitem.metadata=Metadata
reviewmediaitem.quote=Review quote
reviewmediaitem.select=Select

// Labels for maintenance panel
maintenancepanel.books=Books
maintenancepanel.reviewers=Reviewers
maintenancepanel.genres=Genres

 


Back to top 


...

Documentation Guidelines

This part provides guidelines for documentation to be distributed among with the plugin.

...

Documentation should be available in at least US English [G034]. 


Back to top 


...

Distribution Guidelines

A plugin is distributed as a single ZIP file, called a WCA (WebManager Component Archive) which can also contains other related plugins [G035]. The WCA contains the compiled plugins as JAR files, corresponding documentation and (optionally) the source code. The WCA contains the following directory structure [G036]:

...

/configuration - Contains configuration files like metatype files for Configuration Management. 


Note

A plugin should contain only components that logically belong to each other [G145].

...


Back to top 


...

Quality Guidelines

In order for GX Software to be able to effectively monitor adherence to the quality guidelines, a quality assurance report must accompany a plugin that is submitted to GX Software for certification. This report must detail various subjects in order for certification to be able to take place. Please note that the discussion of the plugin quality guidelines will be kept in relatively general terms because an exhaustive treatment thereof would not be practical given the goal of this part. Similarly, the methods for validating adherence to the quality guidelines will also only be discussed in general terms.

...

Each plugin should come with a unit test or test bundle that has a code coverage of at least 10% [G120]. 


Back to top 


...

DTAP Guidelines

DTAP is an abbreviation of Development, Test, Acceptance and Production. These terms refer to the environments on which the software will be installed, starting on a development environment it will be installed next onto the test environment. When development and bug fixing is finished it is installed onto an acceptance environment to be tested by the customer. Finally if the software component is accepted, it will be installed onto the production environment.

...

For persisting preferences for a plugin, use the Preferences Service offered by the XperienCentral platform [G047]. This ensures a proper distribution and maintenance of preferences in multiple environments as applicable for the DTAP model. Note that preferences are properties that are maintained by the software and are read-only for the end-user.

 


Back to top 


...

Security Guidelines

Web applications such as XperienCentral operate in a hostile environment. Over the last few years many powerful and extremely common types of security flaws have been found in web applications. It is an unfortunate truth that security flaws are very easy to introduce into an application. This part provides some basic guidelines for avoiding some common security errors when developing plugins. It is advised that every web developer at least be aware of the Open Web Application Security Project (OWASP) and its top ten list of security vulnerabilities for web applications. The list is updated each year and is located here: https://www.owasp.org/index.php/OWASP_Top_10. 


Note

More complete security guidelines are explained in /wiki/spaces/PD/pages/24707143. The topics in this section are only visible to certified GX Software partners and customers who are logged in to the GX Software domain.

...


Escape Input from the User

Outputting user supplied data without correctly escaping it for HTML or XML can be exploited for Cross Site Scripting (XSS) attacks. Use the output-html-encoded-quotes XSLT template to properly HTML escape strings in the output when using XSLT [G048].

 


Code Block
themeEclipse
<xsl:call-template name="output-html-encoded-quotes">
<xsl:with-param name="text" select="$mystring"/>
</xsl:call-template>

...


In JSP, use standard JSTL functions (like escapeXML()) to properly escape strings in the HTML output [G123]:

 


Code Block
themeEclipse
<%@ taglib uri="http://java.sun.com/jsp/jstl/functions" prefix="fn" %>
${fn:escapeXml(user.name)}

...


Use SQL Prepared Statements

SQL injection is a way to abuse poorly programmed SQL statements in order to execute statements that the developer did not foresee. Consider the following example of a badly programmed SQL query: 


Code Block
themeEclipse
// Bad SQL query vulnerable to SQL injection
String query = "select count(*) from users where name=' + name + "' and password='" + password + "'";

...


If the name and password are directly passed from the posted form onto this query, the query will be vulnerable to SQL injection. If the user would enter username and password: 


Code Block
themeEclipse
username=’ or 1=1 or name='
password=’ or 1=1 or password='

...


The query would always return 1. SQL injection can be easily prevented by using prepared statements instead. Prepared statements prevent SQL injection by automatically escaping the input. For this reason it is recommended that you use prepared statements in all cases. See java.sql.PreparedStatement [G049].

...

All content must be stored in the JCR [G045]. This of course also applies to files. Files can be stored in the JCR in two ways; public and non-public. Public files are copied to all web servers in the production environment and are thus accessible by anyone who visits the website. Non-public files are handled by the application server only and support custom authorization on file downloads. 


Back to top 


...

API

A plugin may expose an API containing interfaces, implementation classes, constants, etc. To ensure consistency over all APIs exposed by all plugins, this part describes which guidelines to which such an API should conform.

...

Any class or interface that is exposed by a plugin as API should be contained by a package called "api” directly under the plugins root package or by a sub package of this package [G118]. Because of guideline [G090], the full package name of this API package will be: 


Code Block
themeEclipse
<domain>.<plugin ID>.api

...


Back to top

 


...

Presentation Plugins

Presentation plugins differ in in many ways from other plugins. They contain the actual representation of the website as a whole and thus presentations (in JSP) of several components deployed from several plugins. They overrule presentations defined by the plugins themselves, which should be considered example presentations. A presentation plugin usually is customer-specific - it contains the presentation of that customer’s website. For that reason, separate guidelines are applicable for presentation plugins. A presentation plugin must be self-sufficient - it should not depend on any resource (JSP, CSS, etc.) provided by another plugin unless this presentation is a plugin itself [G137]. If a presentation plugin depends on presentation JSPs that are part of the original XperienCentral platform, these JSPs should be copied to the presentation plugin in the directory /src/main/resources/presentationtype/jsp/wm [G138]. Note that the guidelines mentioned in the remainder of this part do not apply to these JSPs.

...

Finally, implement caching properly by providing SSIs [G144]. 


Back to top 


...

Coding Conventions

This part describes the recommended coding conventions for XperienCentral development. These conventions are based on Sun’s coding conventions but additional XperienCentral specific conventions apply. G055 covers Sun’s coding conventions, all other conventions in this chapter are XperienCentral specific.

...

The use of a basic variant of the Hungarian notation is encouraged. It is recommended that you prefix instance variables with “my”. For example: 


Code Block
themeEclipse
// Correct
private String myTitle;

// Incorrect
private String title;

...

Use of blank space is discouraged before and after a method argument but it is mandatory after Java keywords and commas. For example:

 


Code Block
themeEclipse
// Correct
public void makeItSo(String action, String expression){
    if (check(expression)) {
        makeItSo(action);
    }
}

// Incorrect
public void makeItSo( String action , String expression ) {
    if(check(expression)) {
        makeItSo(action);
    }
}

...

It is recommended that you use the comment “FIXME” in the source code to indicate that the implementation is incorrect. It may be used, for example, to indicate that the code snippet fails in some cases or that it is a workaround for another issue. It is also recommended that you add the name of the developer that added the FIXME to the code.  For example: 


Code Block
themeEclipse
// FIXME (ivol): this won't work if myNumber equals 0
public String getProperty();
    return 1/myNumber;
}

...

It is recommended that you use a TODO in the code if the code snippet works but is not yet finalized. It is also recommended that you add the name of the developer that added the TODO to the code. For example:

 


Code Block
themeEclipse
public int doComplexCalculation();
    // TODO (ivol): must be implemented, return 0 for now
    return 0;
}

...

It is recommended that you add start brackets on the same line as the statement to which they apply and to add ending bracket on a new line. For example:

...


Code Block
themeEclipse
// Correct
public void makeItSo() {
    if (isTrue) {
        doSomething();
    }
}

// Incorrect
Public void makeItSo() 
{
    if (isTrue) 
    {
        doSomething();
    }
}

...

It is recommended that you use brackets in all cases, even for single line statements. For example:

...


Code Block
themeEclipse
// Correct
if (expression) {
    doSomething();
}

// Incorrect
if (expression) doSomething();
if (expression) 
    doSomething();

...


Instance Variable Access [G148]

Instance variables should always be private and provided by accessor methods (getter and setter). Using private instead of public and protected instance variables prevents tight code coupling between the class and classes from other plugins that use this class. 


Back to top 


...

Javadoc Conventions

This part describes the recommended Javadoc conventions for XperienCentral development. These conventions are based on Sun’s Javadoc conventions. Additional XperienCentral specific conventions are also explained below.

...

The Javadoc should clearly explain how the class or interface should be used, preferably by using code examples [G132]. For each package contained by the plugin, a package.html should be provided that clarifies the purpose and contents of the package [G133]. 


Back to top 


...

Class Name Conventions

For consistency of the source code of all plugins, it is important to define naming conventions. This makes the plugin easy to read and maintain for developers since the same classes will be named the same way in each plugin. This part defines naming conventions for Java classes.

...

For general classes (classes that are not directly related to a particular component implementation) used in plugins, the following naming convention for the Java classes are recommended [G076]. Note that <name> indicates a custom name defined by the developer. 


Java class nameDescription
Activator.java

The activator class of the plugin.

<name>ComponentDefinitionImpl.java

The implementation of the specific component definition.

<name>Editor.java

The property editor(s) used to convert String to a complex object type and vice versa. The class must implement the PropertyEditor interface.

<name>Validator.java

The validator used to validate user input. The class must implement the Validator interface.

 


Element Components

For element components, the following naming convention for the Java classes are recommended [G077]. Note that <name> indicates a custom name defined by the developer like ‘review’ or ‘webshop’. 


Java class nameDescription
<name>Element.java

The interface of the element’s business logic.

<name>ElementImpl.java

The implementation class of the element containing the actual business logic.

<name>ElementFBO.java

The form backing object for the element. For element components usually there is only one form backing object.

<name>ElementController.java

The controller for the element component. An element component can have only one controller.

<name>ElementComponent.java

The custom implementation of the element component. Usually the SimpleElementComponent can be used instead.

...


To properly use the API for element components offered by the XperienCentral platform, it is recommended that you use the following hierarchy for the classes contained by an element component [G078]: 


Java classExtendsImplements
<name>Element

Element

 

<name>ElementImpl

ElementBase

<name>Element
<name>ElementFBO

ElementFBO

<name>Element
<name>ElementController

ElementComponentController

 


<name>ElementComponent

SimpleElementComponent

 

...



Media Item Components

For media item components, the following naming convention for the Java classes are recommended [G079]. Note that the difference between a media item and a media item version is that a media item has one or more versions. The implementation of the media item itself is not contained by a media item component but by the implementation of the media item version. Again, <name> indicates a custom name defined by the developer like "article" or "movie". 


Java class nameDescription
<name>MediaItemVersion.java

The interface of the media item’s business logic.

<name>MediaItemVersionImpl.java

The implementation class of the media item version containing the actual business logic.

<name>MediaItemVersionFBO.java

The form backing object for the media item version. For media item components there is usually only one form backing object.

<name>MediaItemController.java

The controller for the media item component. A media item component can have only one controller.

<name>MediaItemComponent.java

The custom implementation of the media item component. Usually the SimpleMediaItemComponent can be used instead.

...


To properly use the API for element components offered by the XperienCentral platform, it is recommended that you use the following hierarchy for the classes contained by a media item component [G080]: 


 
Java class nameExtendsImplements
<name>MediaItemVersion

MediaItemVersion or MediaItemArticleVersion


<name>MediaItemVersionImpl

MediaItemVersionImpl or

MediaItemArticleVersionImpl

 <name>MediaItemVersion
<name>MediaItemVersionFBO

MediaItemVersionFBO

 <name>MediaItemVersion
<name>MediaItemController

MediaItemComponentController

 


<name>MediaItemComponent

SimpleMediaItemComponent

 

...



Panel Components

For panel components, the following naming convention for the Java classes are recommended [G081]. In the table below, <name> indicates the name of the panel as a whole while <tab> indicates the name of one particular (horizontal, vertical or sub) tab within that panel. 


Java class nameDescription
<name>Panel.java

The implementation of the controller logic for the panel. This is in fact a helper class for the panel component controller.

<name>PanelComponent.java

The custom implementation of the panel component - usually the SimplePanelComponent can be used instead.

<name>PanelController.java

The controller for the panel component. Each panel component has exactly one controller, even if it has several horizontal and vertical tabs.

<tab>TabFBO.java

The form backing object for this particular tab of the panel. Usually there is one form backing object for each horizontal, vertical or sub tab.

<tab>TabController.java

The controller for this particular tab of the panel. Usually there is one controller for each horizontal, vertical or sub tab.

 


To properly use the API for element components offered by the XperienCentral platform, it is recommended that you use the following hierarchy for the classes contained by a panel component [G082]: 


  
Java class nameExtendsImplements
<name>Panel

PanelBase


<name>PanelComponent

SimplePanelComponent 
<name>PanelController

PanelComponentController

 



Back to top 


...

ID Naming Conventions

Because the ecosystem of plugins will cause a rapidly increasing number of available plugins developed by many different companies, unique identifiers are necessary to prevent conflicts between plugins. This part describes the guidelines for which identifiers defined by a plugin should conform to in order to prevent such conflicts.

...

A plugin consists of one or more components. The activator of a plugin defines what component a plugin contains by defining one component bundle definition which registers one or more component definitions. The ID of the component bundle definition defined in the activator of the plugin must follow the following syntax [G097]:

 


Code Block
themeEclipse
<domain>.<plugin ID>

...


The ID of each component definition contained by the plugin must be prefixed with the component bundle definition ID followed by an ID that is unique within the plugin and must match the component name and consist of lowercase alphanumeric characters in the range [a-z] [G098]. We refer to this unique ID within the plugin as the component ID and the component definition ID conforms to the syntax: 


Code Block
themeEclipse
<domain>.<plugin ID>.<Component ID>

...


For media Item components, the content type (defined by the @ContentType annotation in the media Item version implementation class) must equal the plugin ID or be prefixed by the plugin ID and may only contain alphanumeric characters in the range [a-z] [G124].

...

The package names used by the plugin must conform to the Java standard as also stated in the Java coding conventions by SUN [G089]. The top level package name must meet the following syntax [G090]: 


Code Block
themeEclipse
<domain>.<plugin ID>

...

This part provides an overview of the recommended naming conventions as described above. An additional guideline is that all these properties may use only lowercase letters [G099]: 


PropertyExample

Domain name

<domain name>

Plugin ID

<plugin ID>

Namespace prefix

<plugin ID>

Component bundle definition ID

<domain name>.<plugin ID>

Component definition ID

<domain name>.<plugin ID>.<Component ID>

Package of the plugin

<domain name>.<plugin ID>

Package of component

<domain name>.<plugin ID>.<Component ID>

Artifact ID

<plugin ID>

Group ID

<domain name>

bundleSymbolicName

<domain name>.<plugin ID>

Content Type

<plugin ID>

...


RBAC Naming

Each plugin defines at least one RBAC category which may contain one or more RBAC permissions. The technical naming of all RBAC categories and permissions must be unique in order to avoid collisions across multiple plugins. For this reason, the technical name of each RBAC category must conform to the syntax <domain>.<plugin ID>.<Component ID> [G101]. Furthermore, the technical name of each RBAC permission must be prefixed with the technical name of the RBAC category, followed by a dot [G102]. All technical names of categories and permissions must be lowercase, may not contain spaces and separate words must be separated by a dot [G103].

...

This part provides an example for using proper naming conventions: 


PropertyExample

Domain name

com.libris4you

Plugin ID

books

Namespace prefix

books

Component bundle definition ID

com.libris4you.books

Component IDmaintenancepanel

Component definition ID

com.libris4you.books.maintenancepanel

Plugin package

com.libris4you.books

Component package

com.libris4you.books.maintenancepanel

Artifact ID

books

Group ID

com.libris4you

Content Type

Books

RBAC category maintenance panel componentcom.libris4you.books.maintenancepanel
RBAC permission add bookcom.libris4you.books.maintenancepanel.add_book

...

When writing documentation or online help for plugins, it is recommended that you use the following guidelines regarding naming of XperienCentral assets [G105]: 


PropertyExample

Editor

The XperienCentral application in which editors maintain the content to be published on the website or another medium.

Website environment

A presentation of (a part of) the content maintained by XperienCentral, usually a website.

Standalone

The mode in which XperienCentral content is served from only one application server.

Clustered

The mode in which XperienCentral content is served from at least two application servers.

Master

The application server on which the Editor can be used to maintain the content. In standalone mode, there is only one master. In clustered mode, there is one master and one or more slaves.

Slave

The application server which only serves content (the website environment) but cannot be used to maintain the content because it is read-only. In standalone mode, there is no slave. In clustered mode, there are one or more slaves.

External server name

The public hostname of the application server accessible from the internet. The website environment is accessible from this hostname.

Internal server name

The hostname of the application server that exists only in the local network. The Editor is accessible only from this host name.

...

The language to be used for all names, codes, Java classes, methods, properties, etc. is US English [G106]. A different language may only be used if, and only if, it represents a piece of text that is displayed to the end user and may require translation.

 


Back to top