Before beginning to develop a provider, determine the application specific requirements, content source, and properties of the provider.
Determine the nature of the provider. Will this provider be a building block provider or will this be a content provider? The content providers are special purpose providers and the building block providers are general purpose providers. For example, the bookmark channel is special purpose, where XMLProvider is general purpose. That is, the XMLProvider can be used, in general, to connect to an XML source and translate it via XSLT to some markup language.
Determine if the content made available via this provider will be:
Preset for the user by the administrator thus making it unmodifiable by the end-user. This will determine the logistics of the isEditable() method.
Preconfigured for the user by the administrator, but editable by the end-user (determines the logistics of the getEdit() method). If editable, determine:
What will and what will not be editable. That is, determine the parameters that will be configurable and those that will not be editable.
The type of edit form to present - EDIT_SUBSET or EDIT_COMPLETE. The advantage of using EDIT_SUBSET is that the EditContainer provides a common look and feel for all providers that have EDIT_SUBSET edit type. Using EDIT_COMPLETE edit type provides more control over the overall look and feel for the edit page.
This will determine the logistics of the getEditType() and the processEdit() methods.
Determine the theme requirements for the content made available via this provider. A theme is a collection of visual elements, such as background color, font face, and so on, to be used when displaying the provider’s content. The themes are stored as global properties in the organization level’s display profile. Providers can use these properties in their templates or JSPs to achieve a global look and feel of the presentation. For use with JSP, theme properties can be accessed from a series of tag libraries. Non-JSP channels can access theme properties via the Theme class. See the Javadocs for more detail.
Determine whether the provider will fetch content from template files or JSPs. This will determine the logistics of the getTemplate() method.
Channel template files are stored in a directory based on the name of the channel, or the name of the provider that is used by the channel. The channel directory for the provider is created under the template root directory. By default, this will be:
PortalServer-DataDir/portals/portal-ID/desktop/desktoptype/channeldirectory/templatefiles
The JSPs and templates for desktop type default are stored under PortalServer-DataDir/portals/portal-ID/desktop/default directory. Storing the files in the PortalServer-DataDir/portals/portal-ID/desktop/default directory allows the files to be shared. That is, when the Desktop service uses the comma-separated string (as an ordered Desktop type list) in the Desktop type attribute to lookup, it starts at the first element in the list and each element represents a subdirectory under the Desktop template base directory. If a template is not found in the first directory (or the first string in the desktop type attribute), then it proceeds to the next one in the list. This continues until the item is found (or not), for all Desktop type elements in the list. If the default directory is not included in the list, it will be added at the end of the list implicitly.
The directory search order for the template and JSP files is as follows:
desktoptype_locale/channelname/clientPath desktoptype_locale/provider/clientPath desktoptype_locale/channelname desktoptype_locale/provider desktoptype_locale/clientPath desktoptype_locale desktoptype/channelname/clientPath desktoptype/provider/clientPath desktoptype/channelname desktoptype/provider desktoptype default_locale/channelname/clientPath default_locale/provider/clientPath default_locale/channelname default_locale/provider default_locale default/channelname/clientPath default/provider/clientPath default/channelname default/provider default/clientPath default templateroot
Where
desktoptype is the value of the desktopType property
locale is the user’s locale
channelname is the name of the channel
provider is the provider name
clientPath is an optional file-path containing client-specific templates
templateroot is, by default, PortalServer-DataDir/portals/portal-ID/desktop
If there is no clientPath specified, then the directory search order is as follows:
desktoptype_locale/channelname desktoptype_locale/provider desktoptype_locale desktoptype/channelname desktoptype/provider desktoptype default_locale/channelname default_locale/provider default_locale default/channelname default/provider default templateroot
If the channel display profile is defined inside a container display profile definition, the lookup for the channel will be desktoptype/containername/channelname/clientPath.
In the display profile, properties contain configuration information for the provider and the provider’s channels. A provider can define any number of specific properties. See Properties in Display Profile and the Sun Java System Portal Server 7.1 Technical Reference for more information.
Also, a provider can have more than one properties file, which is actually a Java resource bundle file that enables localization of on-screen images or text. See Properties in Resource bundle for more information.
The display profile document defines a Provider. The definition of a Provider associates the Provider with the class file that implements its behavior. A Provider definition includes a number of properties, mandatory and provider-specific.
Provider specific properties are defined in the display profile. Provider specific properties are defined in the display profile within the <Properties></Properties> tag for the provider. The following is the structure of the properties in the display profile:
| <Properties> <Collection> ...subset of property definitions </Collection> <Integer>...</Integer> <String>...</String> <Boolean>...</Boolean> </Properties> | 
Typically, the custom provider will not modify the required properties. When properties are updated, they are set in the user’s display profile by the administrator via the administration console. However, values can only be set on existing properties.
If the provider class does not extend the ProfileProviderAdapter and implements the Provider interface, then the get*Property() methods cannot be used directly, and the display profile properties are not accessible. If the provider class implements the Provider interface directly, then no properties are required. Properties must be hardcoded return values or can come from another source such as a database. However, some provider properties are required if the provider implementation extends ProviderAdapter or ProfileProviderAdapter.
The following is a list of the mandatory properties for a provider. The mandatory properties described below are for a provider extending the ProviderAdapter or the ProfileProviderAdapter classes. If you are implementing the Provider interface directly, you can avoid the use of the display profile and the required properties outlined below.
Title of the Provider
Description of the Provider
Time interval for cached content
Can the Provider be edited
Type of edit form to use
Width of the Provider
URL of a help page for this Provider
See Technical Reference Guide for detailed information on the Display Profile properties.
Channel definitions that use a provider can overwrite the properties of that provider. At runtime, channel property values can be affected by the display profile merge process. See Technical Reference Guide for detailed information on the display profile merge process.
Strings defined in the provider’s resource bundle properties file are displayed on the user’s Desktop and they are not the channel’s properties (such as the channel title). Strings are defined in the resource bundle to enable localization.
Typically, resource bundle includes properties that do not need to be customized by the administrator or the end-user. For example, properties that need to be localized, are read-only at runtime, and properties that do not change per channel should be included in a resource bundle. Properties that need to be localized, are settable, and properties that change per channel should be in the display profile.
By default, a provider’s resource bundle properties file is stored in PortalServer-base/web-src/WEB-INF/classes directory. Note that you can change the file here, but you must re-deploy the portal web application for the changes to take effect.
Resource bundles that are needed by the custom providers should be copied into the provider class base directory (see Provider Class File for more information.) Resource bundles should be placed as individual files and cannot exist inside the JAR file under the provider class base directory.
Resource bundles are given a base name that equals to the name of the display profile provider definition that they are associated with. Typically, this is the class name of the Java class file that implements the provider.
To get the name of the resource bundle in your custom provider, call ProviderContext.getProviderName(). This value can then be used as the baseName argument to ResourceBundle.getBundle(). If you are extending ProviderAdapter, simply call getResourceBundle().