Package org.opends.server.tools.tasks
Class TaskToolHelper
java.lang.Object
org.opends.server.tools.tasks.TaskToolHelper
A helper class for adding online capabilities to an offline tool. It allows for a tool or subcommand to add
 task-related arguments and to run a task according to the argument values.
 The methods must be called in this order:
 
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final StringMagic value used to indicate that the user would like to schedule this operation to run immediately as a task as opposed to running the operation in the local VM.static final booleanThe value to pass tovalidateTaskRelatedArguments(boolean)if the offline mode does not modify server files.static final booleanThe value to pass tovalidateTaskRelatedArguments(boolean)if the offline mode modifies sever files.static final StringThe value for the long option compress.static final StringThe value for the tmp directory long option.static final CharacterThe value for the "backendId" short option.static final charThe value for the short option compress.
- 
Constructor SummaryConstructorsConstructorDescriptionTaskToolHelper(com.forgerock.opendj.cli.Tool printer, com.forgerock.opendj.cli.ArgumentParser argumentParser) Creates a new TaskToolHelper with the provided tool for printing the messages.TaskToolHelper(com.forgerock.opendj.cli.Tool printer, com.forgerock.opendj.cli.ArgumentParser argumentParser, com.forgerock.opendj.cli.SubCommand subCommand) Creates a new TaskToolHelper with the provided tool for printing the messages.
- 
Method SummaryModifier and TypeMethodDescriptionstatic voidaddAttribute(Entry taskEntry, String attrName, com.forgerock.opendj.cli.Argument argument) Adds the provided attribute with the argument value(s) to the provided task entry only if the argument has been provided on the command line.static voidaddAttributeIfArgumentPresent(Entry taskEntry, String attrName, com.forgerock.opendj.cli.Argument argument) Adds the attribute with the argument value to the task entry if the argument corresponding to the attribute has been provided on the command line.addTaskRelatedArgumentsToParser(boolean offlineModifiesServerFiles) Add all the task-related arguments to the constructor-supplied argument parser or sub command.addTaskRelatedArgumentsToParser(com.forgerock.opendj.cli.BooleanArgument offlineArgument) Add all the task-related arguments to the constructor-supplied argument parser or sub command.booleanIndicates whether the offline argument was provided.com.forgerock.opendj.cli.ReturnCodeprocess(TaskCommand taskCommand) Process locally or run a task depending on whether the offline argument was provided.static voidshutdownBackends(ServerContext serverContext) Shutdowns all backends.voidvalidateTaskRelatedArguments(boolean isEmbedded) Validates the task-related arguments and throw an exception if the user-provided values are invalid.
- 
Field Details- 
OPTION_LONG_COMPRESSThe value for the long option compress.- See Also:
 
- 
OPTION_SHORT_COMPRESSpublic static final char OPTION_SHORT_COMPRESSThe value for the short option compress.- See Also:
 
- 
OPTION_SHORT_BACKEND_IDThe value for the "backendId" short option.
- 
OPTION_LONG_TMP_DIRECTORYThe value for the tmp directory long option.- See Also:
 
- 
OFFLINE_DOES_NOT_MODIFY_SERVER_FILESpublic static final boolean OFFLINE_DOES_NOT_MODIFY_SERVER_FILESThe value to pass tovalidateTaskRelatedArguments(boolean)if the offline mode does not modify server files.- See Also:
 
- 
OFFLINE_MODIFIES_SERVER_FILESpublic static final boolean OFFLINE_MODIFIES_SERVER_FILESThe value to pass tovalidateTaskRelatedArguments(boolean)if the offline mode modifies sever files.- See Also:
 
- 
NOWMagic value used to indicate that the user would like to schedule this operation to run immediately as a task as opposed to running the operation in the local VM.- See Also:
 
 
- 
- 
Constructor Details- 
TaskToolHelperpublic TaskToolHelper(com.forgerock.opendj.cli.Tool printer, com.forgerock.opendj.cli.ArgumentParser argumentParser) Creates a new TaskToolHelper with the provided tool for printing the messages. Task options will be added at the global level to the provided argument parser.- Parameters:
- printer- The tool used for printing the messages.
- argumentParser- The argument parser
 
- 
TaskToolHelperpublic TaskToolHelper(com.forgerock.opendj.cli.Tool printer, com.forgerock.opendj.cli.ArgumentParser argumentParser, com.forgerock.opendj.cli.SubCommand subCommand) Creates a new TaskToolHelper with the provided tool for printing the messages. Task options will be added to the provided sub-command.- Parameters:
- printer- The tool used for printing the messages.
- argumentParser- The argument parser
- subCommand- The sub-command
 
 
- 
- 
Method Details- 
shutdownBackendsShutdowns all backends.- Parameters:
- serverContext- the server context
 
- 
addAttributeIfArgumentPresentpublic static void addAttributeIfArgumentPresent(Entry taskEntry, String attrName, com.forgerock.opendj.cli.Argument argument) Adds the attribute with the argument value to the task entry if the argument corresponding to the attribute has been provided on the command line.- Parameters:
- taskEntry- The task- Entryto update
- attrName- The attribute corresponding to the argument
- argument- The argument representing the attribute
 
- 
addAttributepublic static void addAttribute(Entry taskEntry, String attrName, com.forgerock.opendj.cli.Argument argument) Adds the provided attribute with the argument value(s) to the provided task entry only if the argument has been provided on the command line.
- 
addTaskRelatedArgumentsToParserAdd all the task-related arguments to the constructor-supplied argument parser or sub command. This includes ldap client arguments to connect to a directory server, task arguments to customize the task execution and the offline argument to distinguish between the task mode and offline mode.- Parameters:
- offlineModifiesServerFiles- Indicates whether the offline mode will modify server files
- Returns:
- this object to be able to chain method calls
- See Also:
 
- 
addTaskRelatedArgumentsToParserpublic TaskToolHelper addTaskRelatedArgumentsToParser(com.forgerock.opendj.cli.BooleanArgument offlineArgument) Add all the task-related arguments to the constructor-supplied argument parser or sub command. This includes ldap client arguments to connect to a directory server, task arguments to customize the task execution and the provided offline argument to distinguish between the task mode and offline mode.- Parameters:
- offlineArgument- the offline argument
- Returns:
- this object to be able to chain method calls
- See Also:
 
- 
validateTaskRelatedArgumentspublic void validateTaskRelatedArguments(boolean isEmbedded) throws com.forgerock.opendj.cli.ClientException Validates the task-related arguments and throw an exception if the user-provided values are invalid.- Parameters:
- isEmbedded- Whether the tool is embedded.
- Throws:
- com.forgerock.opendj.cli.ClientException- If the user provided values for task-related argument are invalid.
 
- 
isOfflinepublic boolean isOffline()Indicates whether the offline argument was provided.- Returns:
- whether the offline argument was provided.
 
- 
processpublic com.forgerock.opendj.cli.ReturnCode process(TaskCommand taskCommand) throws com.forgerock.opendj.cli.ClientException Process locally or run a task depending on whether the offline argument was provided. The task will be run according to the user provided task-related arguments.- Parameters:
- taskCommand- the command that should be executed.
- Returns:
- the return code.
- Throws:
- com.forgerock.opendj.cli.ClientException- If there is a problem when running the task.
 
 
-