PAA Property files
Two different types of properties are contained within a PAA distribution. They can be classified as being either:
- User editable. For example a database URL,
- Developer-provided settings. Required for a component to function.
In general custom Ant tasks provided by the developer handle such properties. Exceptions include files with:
- Properties for connecting to an external database
- Selection property for cases when the user wants to install a template other than the default template in the PAA templates directory
- Properties required by the Solution Installer
Users might need to edit such content before they run the installation. Therefore, it makes sense to consolidate such properties in the one place instead of having the user edit multiple files in different locations. However, there is a trade-off with keeping all the properties required by a component together to allow for component reuse. Therefore, a number of approaches to storing properties in the PAA file are allowed.
User editable properties can be defined in the properties file specific to a component...
component_name.properties
...which can be found in the top-level directory of a component. The naming scheme of this file is important because the Solution Installer loads it automatically. When the PAA file is expanded, users are free to edit them as needed. They can then rerun any ConfigEngine function associated with the component to take account of these new values. The values in this file are the defaults for the properties and can be overwritten by parent properties files.
There are two ways in which the properties in the component level properties files can be overwritten by parent properties. The properties files containing user editable properties for the components of the PAA assembly can be consolidated into one properties file. They are placed in the top-level directory of the PAA file. It is called...
assembly_name.properties
The user can edit this file to set any values required for the installation to ConfigEngine and IBM WebSphere Portal to run smoothly. When the user starts the installation process for the ConfigEngine, these properties are read first. The values in the default properties files are redundant because the Ant properties cannot be overwritten, unless they are out of scope.
Alternatively, user editable properties can be passed in on the command line as parameters to the Solution Installer tasks. Individual property name=value pairs can be typed on the command line with a -D prefix to inform solution installer and the ConfigEngine they are to be treated as Ant properties. Alternatively a properties file containing all of the user editable properties can be passed in on the command line with the Ant -propertyfile parameter.
The Solution Installer checks the command line to establish if properties were passed in when the task was started. If so, the properties are loaded by the installer and the values of the properties set are the ones used during the deployment to WebSphere Portal. Similarly, if a properties file is not received on the command line, then it looks in the highest level directory of the PAA distribution for such files. When found, these values are loaded as the values for the properties. If there are extra properties in the assembly level file, then these properties are also read. If no properties file is found, values from the component level property files are used. Otherwise, it is assumed that no user editable properties are required and the installation continues.
Property files containing developer-provided settings must be at the component level. To aid reuse of components across multiple PAA files, keep required settings local to a component.
When we decide on property names, take great care. A limitation of Ant means that when a property is created in a run of the scripts, it cannot be overwritten. If we install multiple components that have a setting with the same name but different values, the first one to be created is used throughout the installation. It can cause unexpected results. Employ a pattern for naming the properties to ensure that property names across components do not clash. For example, a property name might have the name of the component to which it relates, prefixed to the name to ensure uniqueness.