Package org.opends.server.plugins
Class EntryUUIDPlugin
java.lang.Object
org.opends.server.api.plugin.DirectoryServerPlugin<EntryUuidPluginCfg>
org.opends.server.plugins.EntryUUIDPlugin
- All Implemented Interfaces:
ConfigurationChangeListener<EntryUuidPluginCfg>
public final class EntryUUIDPlugin
extends DirectoryServerPlugin<EntryUuidPluginCfg>
implements ConfigurationChangeListener<EntryUuidPluginCfg>
This class implements a Directory Server plugin that will add the entryUUID attribute to an entry whenever it is
added or imported as per RFC 4530. For entries added over LDAP, the entryUUID will be based on a semi-random UUID
(which is still guaranteed to be unique). For entries imported from LDIF, the UUID will be constructed from the entry
DN using a repeatable algorithm. This will ensure that LDIF files imported in parallel across multiple systems will
have identical entryUUID values.
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionapplyConfigurationChange(EntryUuidPluginCfg configuration) Applies the configuration changes to this change listener.voiddoLDIFImport(LDIFImportConfig importConfig, Entry entry) Performs any necessary processing that should be done during an LDIF import operation immediately after reading an entry and confirming that it should be imported based on the provided configuration.voiddoPreOperation(PreOperationAddOperation addOperation) Performs any necessary processing that should be done just before the Directory Server performs the core processing for an add operation.voidPerforms any necessary finalization for this plugin.voidinitializePlugin(Set<PluginType> pluginTypes, EntryUuidPluginCfg configuration) Performs any initialization necessary for this plugin.booleanisConfigurationAcceptable(EntryUuidPluginCfg cfg, List<LocalizableMessage> unacceptableReasons) Indicates whether the provided configuration is acceptable for this plugin.booleanisConfigurationChangeAcceptable(EntryUuidPluginCfg configuration, List<LocalizableMessage> unacceptableReasons) Indicates whether the proposed change to the configuration is acceptable to this change listener.Methods inherited from class org.opends.server.api.plugin.DirectoryServerPlugin
doLDIFImportBegin, doLDIFImportEnd, doPostCommit, doPostCommit, doPostCommit, doPostCommit, doPostConnect, doPostDisconnect, doPostOperation, doPostOperation, doPostOperation, doPostOperation, doPostOperation, doPostOperation, doPostOperation, doPostOperation, doPostOperation, doPostOperation, doPostResponse, doPostResponse, doPostResponse, doPostResponse, doPostResponse, doPostResponse, doPostResponse, doPostResponse, doPostSynchronization, doPostSynchronization, doPostSynchronization, doPostSynchronization, doPreOperation, doPreOperation, doPreOperation, doPreOperation, doPreOperation, doPreOperation, doPreOperation, doPreParse, doPreParse, doPreParse, doPreParse, doPreParse, doPreParse, doPreParse, doPreParse, doPreParse, doPreParse, doShutdown, doStartup, getPluginEntryDN, getPluginTypes, getServerContext, initializeInternal, invokeForInternalOperations, processIntermediateResponse, processSearchEntry, processSearchReference, processSubordinateDelete, processSubordinateModifyDN, setInvokeForInternalOperations
-
Constructor Details
-
EntryUUIDPlugin
public EntryUUIDPlugin()
-
-
Method Details
-
initializePlugin
public void initializePlugin(Set<PluginType> pluginTypes, EntryUuidPluginCfg configuration) throws ConfigException Description copied from class:DirectoryServerPluginPerforms any initialization necessary for this plugin. This will be called as soon as the plugin has been loaded and before it is registered with the server.- Specified by:
initializePluginin classDirectoryServerPlugin<EntryUuidPluginCfg>- Parameters:
pluginTypes- The set of plugin types that indicate the ways in which this plugin will be invoked.configuration- The configuration for this plugin.- Throws:
ConfigException- If the provided entry does not contain a valid configuration for this plugin.
-
finalizePlugin
public void finalizePlugin()Description copied from class:DirectoryServerPluginPerforms any necessary finalization for this plugin. This will be called just after the plugin has been deregistered with the server but before it has been unloaded.- Overrides:
finalizePluginin classDirectoryServerPlugin<EntryUuidPluginCfg>
-
doLDIFImport
Description copied from class:DirectoryServerPluginPerforms any necessary processing that should be done during an LDIF import operation immediately after reading an entry and confirming that it should be imported based on the provided configuration.- Overrides:
doLDIFImportin classDirectoryServerPlugin<EntryUuidPluginCfg>- Parameters:
importConfig- The configuration used for the LDIF import.entry- The entry that has been read to the LDIF file.- Throws:
LdapException- if LDIF import failed.
-
doPreOperation
Description copied from class:DirectoryServerPluginPerforms any necessary processing that should be done just before the Directory Server performs the core processing for an add operation. This method is not called when processing synchronization operations.- Overrides:
doPreOperationin classDirectoryServerPlugin<EntryUuidPluginCfg>- Parameters:
addOperation- The add operation to be processed.
-
isConfigurationAcceptable
public boolean isConfigurationAcceptable(EntryUuidPluginCfg cfg, List<LocalizableMessage> unacceptableReasons) Description copied from class:DirectoryServerPluginIndicates whether the provided configuration is acceptable for this plugin. It should be possible to call this method on an uninitialized plugin instance in order to determine whether the plugin would be able to use the provided configuration.- Overrides:
isConfigurationAcceptablein classDirectoryServerPlugin<EntryUuidPluginCfg>- Parameters:
cfg- The plugin configuration for which to make the determination.unacceptableReasons- A list that may be used to hold the reasons that the provided configuration is not acceptable.- Returns:
trueif the provided configuration is acceptable for this plugin, orfalseif not.
-
isConfigurationChangeAcceptable
public boolean isConfigurationChangeAcceptable(EntryUuidPluginCfg configuration, List<LocalizableMessage> unacceptableReasons) Description copied from interface:ConfigurationChangeListenerIndicates whether the proposed change to the configuration is acceptable to this change listener.- Specified by:
isConfigurationChangeAcceptablein interfaceConfigurationChangeListener<EntryUuidPluginCfg>- Parameters:
configuration- The new configuration containing the changes.unacceptableReasons- A list that can be used to hold messages about why the provided configuration is not acceptable.- Returns:
- Returns
trueif the proposed change is acceptable, orfalseif it is not.
-
applyConfigurationChange
Description copied from interface:ConfigurationChangeListenerApplies the configuration changes to this change listener.- Specified by:
applyConfigurationChangein interfaceConfigurationChangeListener<EntryUuidPluginCfg>- Parameters:
configuration- The new configuration containing the changes.- Returns:
- Returns information about the result of changing the configuration.
-