@ThreadSafety(level=NOT_THREADSAFE) public final class LDAPCompare extends LDAPCommandLineTool implements java.io.Serializable
LDAPCommandLineTool
class. In addition, a set of at
least two unnamed trailing arguments must be given. The first argument
should be a string containing the name of the target attribute followed by a
colon and the assertion value to use for that attribute (e.g.,
"cn:john doe"). Alternately, the attribute name may be followed by two
colons and the base64-encoded representation of the assertion value
(e.g., "cn:: am9obiBkb2U="). Any subsequent trailing arguments will be the
DN(s) of entries in which to perform the compare operation(s).
com.unboundid.util.args
package)com.unboundid.util
package)com.unboundid.ldap.sdk
package)Constructor and Description |
---|
LDAPCompare(java.io.OutputStream outStream,
java.io.OutputStream errStream)
Creates a new instance of this tool.
|
Modifier and Type | Method and Description |
---|---|
void |
addNonLDAPArguments(ArgumentParser parser)
Adds the arguments used by this program that aren't already provided by the
generic
LDAPCommandLineTool framework. |
boolean |
defaultsToInteractiveMode()
Indicates whether this tool defaults to launching in interactive mode if
the tool is invoked without any command-line arguments.
|
protected boolean |
defaultToPromptForBindPassword()
Indicates whether this tool should default to interactively prompting for
the bind password if a password is required but no argument was provided
to indicate how to get the password.
|
void |
doExtendedNonLDAPArgumentValidation()
Performs any necessary processing that should be done to ensure that the
provided set of command-line arguments were valid.
|
ResultCode |
doToolProcessing()
Performs the actual processing for this tool.
|
protected java.util.List<Control> |
getBindControls()
Retrieves a set of controls that should be included in any bind request
generated by this tool.
|
java.util.LinkedHashMap<java.lang.String[],java.lang.String> |
getExampleUsages()
Retrieves a set of information that may be used to generate example usage
information.
|
int |
getMaxTrailingArguments()
Retrieves the maximum number of unnamed trailing arguments that are
allowed.
|
int |
getMinTrailingArguments()
Retrieves the minimum number of unnamed trailing arguments that are
required.
|
java.lang.String |
getToolDescription()
Retrieves the description for this tool.
|
java.lang.String |
getToolName()
Retrieves the name for this tool.
|
java.lang.String |
getToolVersion()
Retrieves the version string for this tool.
|
java.lang.String |
getTrailingArgumentsPlaceholder()
Retrieves a placeholder string that may be used to indicate what kinds of
trailing arguments are allowed.
|
protected boolean |
includeAlternateLongIdentifiers()
Indicates whether the LDAP-specific arguments should include alternate
versions of all long identifiers that consist of multiple words so that
they are available in both camelCase and dash-separated versions.
|
static void |
main(java.lang.String[] args)
Parse the provided command line arguments and make the appropriate set of
changes.
|
static ResultCode |
main(java.lang.String[] args,
java.io.OutputStream outStream,
java.io.OutputStream errStream)
Parse the provided command line arguments and make the appropriate set of
changes.
|
protected boolean |
supportsDebugLogging()
Indicates whether this tool supports the ability to generate a debug log
file.
|
boolean |
supportsInteractiveMode()
Indicates whether this tool should provide support for an interactive mode,
in which the tool offers a mode in which the arguments can be provided in
a text-driven menu rather than requiring them to be given on the command
line.
|
protected boolean |
supportsOutputFile()
Indicates whether this tool should provide arguments for redirecting output
to a file.
|
boolean |
supportsPropertiesFile()
Indicates whether this tool supports the use of a properties file for
specifying default values for arguments that aren't specified on the
command line.
|
protected boolean |
supportsSSLDebugging()
Indicates whether this tool should provide a command-line argument that
allows for low-level SSL debugging.
|
addToolArguments, anyLDAPArgumentsProvided, createBindRequest, createServerSet, createSSLUtil, createSSLUtil, doExtendedArgumentValidation, getConnection, getConnectionOptions, getConnectionOptionsWithRequestedSettings, getConnectionPool, getConnectionPool, getSuppressedShortIdentifiers, getUnauthenticatedConnection, supportsAuthentication, supportsMultipleServers, supportsSASLHelp
addEnableSSLDebuggingArgument, createArgumentParser, doShutdownHookProcessing, err, getAdditionalDescriptionParagraphs, getErr, getOriginalErr, getOriginalOut, getOut, getPasswordFileReader, getToolCompletionMessage, logToolInvocationByDefault, out, registerShutdownHook, requestToolArgumentsInteractively, runTool, wrapErr, wrapOut
public LDAPCompare(@Nullable java.io.OutputStream outStream, @Nullable java.io.OutputStream errStream)
outStream
- The output stream to which standard out should be
written. It may be null
if output should be
suppressed.errStream
- The output stream to which standard error should be
written. It may be null
if error messages
should be suppressed.public static void main(@NotNull java.lang.String[] args)
args
- The command line arguments provided to this program.@NotNull public static ResultCode main(@NotNull java.lang.String[] args, @Nullable java.io.OutputStream outStream, @Nullable java.io.OutputStream errStream)
args
- The command line arguments provided to this program.outStream
- The output stream to which standard out should be
written. It may be null
if output should be
suppressed.errStream
- The output stream to which standard error should be
written. It may be null
if error messages
should be suppressed.@NotNull public java.lang.String getToolName()
getToolName
in class CommandLineTool
@NotNull public java.lang.String getToolDescription()
getToolDescription
in class CommandLineTool
@NotNull public java.lang.String getToolVersion()
getToolVersion
in class CommandLineTool
public int getMinTrailingArguments()
getMinTrailingArguments
in class CommandLineTool
public int getMaxTrailingArguments()
getMaxTrailingArguments
in class CommandLineTool
@NotNull public java.lang.String getTrailingArgumentsPlaceholder()
getTrailingArgumentsPlaceholder
in class CommandLineTool
public boolean supportsInteractiveMode()
defaultsToInteractiveMode()
returns true
, then
interactive mode may be invoked by simply launching the tool without any
arguments.supportsInteractiveMode
in class CommandLineTool
true
if this tool supports interactive mode, or
false
if not.public boolean defaultsToInteractiveMode()
supportsInteractiveMode()
returns true
.defaultsToInteractiveMode
in class CommandLineTool
true
if this tool defaults to using interactive mode if
launched without any command-line arguments, or false
if
not.protected boolean supportsOutputFile()
true
, then the tool will offer
an "--outputFile" argument that will specify the path to a file to which
all standard output and standard error content will be written, and it will
also offer a "--teeToStandardOut" argument that can only be used if the
"--outputFile" argument is present and will cause all output to be written
to both the specified output file and to standard output.supportsOutputFile
in class CommandLineTool
true
if this tool should provide arguments for redirecting
output to a file, or false
if not.protected boolean defaultToPromptForBindPassword()
defaultToPromptForBindPassword
in class LDAPCommandLineTool
true
if this tool should default to interactively
prompting for the bind password, or false
if not.public boolean supportsPropertiesFile()
supportsPropertiesFile
in class CommandLineTool
true
if this tool supports the use of a properties file
for specifying default values for arguments that aren't specified
on the command line, or false
if not.protected boolean supportsDebugLogging()
true
, then the tool will expose
additional arguments that can control debug logging.supportsDebugLogging
in class CommandLineTool
true
if this tool supports the ability to generate a debug
log file, or false
if not.protected boolean includeAlternateLongIdentifiers()
includeAlternateLongIdentifiers
in class LDAPCommandLineTool
true
if this tool should provide multiple versions of
long identifiers for LDAP-specific arguments, or false
if
not.protected boolean supportsSSLDebugging()
true
, then an
"--enableSSLDebugging}" argument will be added that sets the
"javax.net.debug" system property to "all" before attempting any
communication.supportsSSLDebugging
in class LDAPCommandLineTool
true
if this tool should offer an "--enableSSLDebugging"
argument, or false
if not.public void addNonLDAPArguments(@NotNull ArgumentParser parser) throws ArgumentException
LDAPCommandLineTool
framework.addNonLDAPArguments
in class LDAPCommandLineTool
parser
- The argument parser to which the arguments should be added.ArgumentException
- If a problem occurs while adding the arguments.public void doExtendedNonLDAPArgumentValidation() throws ArgumentException
CommandLineTool.doToolProcessing()
method is invoked.doExtendedNonLDAPArgumentValidation
in class LDAPCommandLineTool
ArgumentException
- If there was a problem with the command-line
arguments provided to this program.@NotNull protected java.util.List<Control> getBindControls()
getBindControls
in class LDAPCommandLineTool
null
or empty if no
controls should be included in the bind request.@NotNull public ResultCode doToolProcessing()
doToolProcessing
in class CommandLineTool
@NotNull public java.util.LinkedHashMap<java.lang.String[],java.lang.String> getExampleUsages()
getExampleUsages
in class CommandLineTool
null
or empty if no example usage
information is available.