@ThreadSafety(level=NOT_THREADSAFE) public final class LDAPSearch extends LDAPCommandLineTool implements UnsolicitedNotificationHandler
LDAPSearch tool, and includes a
number of features only intended for use with Ping Identity, UnboundID, and
Nokia/Alcatel-Lucent 8661 server products.
NOTE: This class, and other classes within the
com.unboundid.ldap.sdk.unboundidds package structure, are only
supported for use against Ping Identity, UnboundID, and
Nokia/Alcatel-Lucent 8661 server products. These classes provide support
for proprietary functionality or for external specifications that are not
considered stable or mature enough to be guaranteed to work in an
interoperable way with other types of LDAP servers.
| Constructor and Description |
|---|
LDAPSearch(java.io.OutputStream out,
java.io.OutputStream err)
Creates a new instance of this tool with the provided streams.
|
| Modifier and Type | Method and Description |
|---|---|
void |
addNonLDAPArguments(ArgumentParser parser)
Adds the arguments needed by this command-line tool to the provided
argument parser which are not related to connecting or authenticating to
the directory server.
|
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 core set of processing for this tool.
|
java.util.List<java.lang.String> |
getAdditionalDescriptionParagraphs()
Retrieves additional paragraphs that should be included in the description
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.
|
LDAPConnectionOptions |
getConnectionOptions()
Retrieves the connection options that should be used for connections that
are created with this command line 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 may be
provided for this tool.
|
int |
getMinTrailingArguments()
Retrieves the minimum number of unnamed trailing arguments that must be
provided for this tool.
|
protected java.util.Set<java.lang.Character> |
getSuppressedShortIdentifiers()
Retrieves a set containing any short identifiers that should be suppressed
in the set of generic tool arguments so that they can be used by a
tool-specific argument instead.
|
java.lang.String |
getToolDescription()
Retrieves a human-readable description for this tool.
|
java.lang.String |
getToolName()
Retrieves the name of this tool.
|
java.lang.String |
getToolVersion()
Retrieves a version string for this tool, if available.
|
java.lang.String |
getTrailingArgumentsPlaceholder()
Retrieves a placeholder string that should be used for trailing arguments
in the usage information for this tool.
|
void |
handleUnsolicitedNotification(LDAPConnection connection,
ExtendedResult notification)
Performs any processing that may be necessary in response to the provided
unsolicited notification that has been received from the server.
|
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 ResultCode |
main(java.io.OutputStream out,
java.io.OutputStream err,
java.lang.String... args)
Runs this tool with the provided streams and command-line arguments.
|
static void |
main(java.lang.String... args)
Runs this tool with the provided command-line arguments.
|
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 |
supportsMultipleServers()
Indicates whether this tool supports creating connections to multiple
servers.
|
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, getConnectionOptionsWithRequestedSettings, getConnectionPool, getConnectionPool, getUnauthenticatedConnection, supportsAuthentication, supportsSASLHelpaddEnableSSLDebuggingArgument, createArgumentParser, doShutdownHookProcessing, err, getErr, getOriginalErr, getOriginalOut, getOut, getPasswordFileReader, getToolCompletionMessage, logToolInvocationByDefault, out, registerShutdownHook, requestToolArgumentsInteractively, runTool, supportsOutputFile, wrapErr, wrapOutpublic LDAPSearch(@Nullable java.io.OutputStream out, @Nullable java.io.OutputStream err)
out - The output stream to use for standard output. If this is
null, then standard output will be suppressed.err - The output stream to use for standard error. If this is
null, then standard error will be suppressed.public static void main(@NotNull java.lang.String... args)
args - The command-line arguments to provide to this program.@NotNull public static ResultCode main(@Nullable java.io.OutputStream out, @Nullable java.io.OutputStream err, @NotNull java.lang.String... args)
out - The output stream to use for standard output. If this is
null, then standard output will be suppressed.err - The output stream to use for standard error. If this is
null, then standard error will be suppressed.args - The command-line arguments provided to this program.ResultCode.SUCCESS indicates an error.@NotNull public java.lang.String getToolName()
getToolName in class CommandLineTool@NotNull public java.lang.String getToolDescription()
CommandLineTool.getAdditionalDescriptionParagraphs() method should be used to
return the text for the subsequent paragraphs.getToolDescription in class CommandLineTool@NotNull public java.util.List<java.lang.String> getAdditionalDescriptionParagraphs()
CommandLineTool.getToolDescription() method should return the text of the
first paragraph, and each item in the list returned by this method should
be the text for each subsequent paragraph. If the tool description should
only have a single paragraph, then this method may return null or
an empty list.getAdditionalDescriptionParagraphs in class CommandLineToolnull or an empty list if only a single
description paragraph (whose text is returned by the
getToolDescription method) is needed.@NotNull public java.lang.String getToolVersion()
getToolVersion in class CommandLineToolnull if none is
available.public int getMinTrailingArguments()
CommandLineTool.getMaxTrailingArguments()
arguments to return nonzero values, and it must also override the
CommandLineTool.getTrailingArgumentsPlaceholder() method to return a
non-null value.getMinTrailingArguments in class CommandLineToolpublic int getMaxTrailingArguments()
CommandLineTool.getTrailingArgumentsPlaceholder() method to
return a non-null value.getMaxTrailingArguments in class CommandLineTool@NotNull public java.lang.String getTrailingArgumentsPlaceholder()
getTrailingArgumentsPlaceholder in class CommandLineToolnull if trailing
arguments are not supported.public boolean supportsInteractiveMode()
CommandLineTool.defaultsToInteractiveMode() returns true, then
interactive mode may be invoked by simply launching the tool without any
arguments.supportsInteractiveMode in class CommandLineTooltrue if this tool supports interactive mode, or
false if not.public boolean defaultsToInteractiveMode()
CommandLineTool.supportsInteractiveMode() returns true.defaultsToInteractiveMode in class CommandLineTooltrue if this tool defaults to using interactive mode if
launched without any command-line arguments, or false if
not.public boolean supportsPropertiesFile()
supportsPropertiesFile in class CommandLineTooltrue 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 CommandLineTooltrue if this tool supports the ability to generate a debug
log file, or false if not.protected boolean defaultToPromptForBindPassword()
defaultToPromptForBindPassword in class LDAPCommandLineTooltrue if this tool should default to interactively
prompting for the bind password, or false if not.protected boolean includeAlternateLongIdentifiers()
includeAlternateLongIdentifiers in class LDAPCommandLineTooltrue 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 LDAPCommandLineTooltrue if this tool should offer an "--enableSSLDebugging"
argument, or false if not.@NotNull protected java.util.Set<java.lang.Character> getSuppressedShortIdentifiers()
getSuppressedShortIdentifiers in class LDAPCommandLineToolnull.public void addNonLDAPArguments(@NotNull ArgumentParser parser) throws ArgumentException
addNonLDAPArguments in class LDAPCommandLineToolparser - The argument parser to which the arguments should be added.ArgumentException - If a problem occurs while adding the arguments.@NotNull protected java.util.List<Control> getBindControls()
getBindControls in class LDAPCommandLineToolnull or empty if no
controls should be included in the bind request.protected boolean supportsMultipleServers()
supportsMultipleServers in class LDAPCommandLineTooltrue if this tool supports creating connections to
multiple servers, or false if not.public void doExtendedNonLDAPArgumentValidation() throws ArgumentException
CommandLineTool.doToolProcessing() method is invoked.doExtendedNonLDAPArgumentValidation in class LDAPCommandLineToolArgumentException - If there was a problem with the command-line
arguments provided to this program.@NotNull public LDAPConnectionOptions getConnectionOptions()
getConnectionOptions in class LDAPCommandLineTool@NotNull public ResultCode doToolProcessing()
doToolProcessing in class CommandLineToolpublic void handleUnsolicitedNotification(@NotNull LDAPConnection connection, @NotNull ExtendedResult notification)
handleUnsolicitedNotification in interface UnsolicitedNotificationHandlerconnection - The connection on which the unsolicited notification
was received.notification - The unsolicited notification that has been received
from the server.@NotNull public java.util.LinkedHashMap<java.lang.String[],java.lang.String> getExampleUsages()
getExampleUsages in class CommandLineToolnull or empty if no example usage
information is available.