Class PBKDF2PasswordStorageScheme

    • Constructor Detail

      • PBKDF2PasswordStorageScheme

        public PBKDF2PasswordStorageScheme()
    • Method Detail

      • getStorageSchemeName

        public String getStorageSchemeName()
        Description copied from class: PasswordStorageScheme
        Retrieves the name of the password storage scheme provided by this handler.
        Returns:
        The name of the password storage scheme provided by this handler.
      • getAuthPasswordSchemeName

        public String getAuthPasswordSchemeName()
        Description copied from class: PasswordStorageScheme
        Retrieves the scheme name that should be used with this password storage scheme when it is used in the context of the authentication password syntax. This default implementation will return the same value as the getStorageSchemeName method.
        Returns:
        The scheme name that should be used with this password storage scheme when it is used in the context of the authentication password syntax.
      • encodeOffline

        public static String encodeOffline​(byte[] passwordBytes)
                                    throws LdapException
        Generates an encoded password string from the given clear-text password. This method is primarily intended for use when it is necessary to generate a password with the server offline (e.g., when setting the initial root user password).
        Parameters:
        passwordBytes - The bytes that make up the clear-text password.
        Returns:
        The encoded password string, including the scheme name in curly braces.
        Throws:
        LdapException - If a problem occurs during processing.
      • passwordMatches

        public boolean passwordMatches​(ByteSequence plaintextPassword,
                                       ByteSequence storedPassword)
        Description copied from class: PasswordStorageScheme
        Indicates whether the provided plaintext password included in a bind request matches the given stored value. The provided stored value should not include the scheme name in curly braces.
        Specified by:
        passwordMatches in class PasswordStorageScheme<Pbkdf2PasswordStorageSchemeCfg>
        Parameters:
        plaintextPassword - The plaintext password provided by the user as part of a simple bind attempt.
        storedPassword - The stored password to compare against the provided plaintext password.
        Returns:
        true if the provided plaintext password matches the provided stored password, or false if not.
      • supportsAuthPasswordSyntax

        public boolean supportsAuthPasswordSyntax()
        Description copied from class: PasswordStorageScheme
        Indicates whether this password storage scheme supports the ability to interact with values using the authentication password syntax defined in RFC 3112.
        Overrides:
        supportsAuthPasswordSyntax in class PasswordStorageScheme<Pbkdf2PasswordStorageSchemeCfg>
        Returns:
        true if this password storage scheme supports the ability to interact with values using the authentication password syntax, or false if it does not.
      • encodeAuthPassword

        public ByteString encodeAuthPassword​(ByteSequence plaintext)
                                      throws LdapException
        Description copied from class: PasswordStorageScheme
        Encodes the provided plaintext password for this storage scheme using the authentication password syntax defined in RFC 3112. Note that the provided plaintext password should not be altered in any way.
        Overrides:
        encodeAuthPassword in class PasswordStorageScheme<Pbkdf2PasswordStorageSchemeCfg>
        Parameters:
        plaintext - The plaintext version of the password.
        Returns:
        The password that has been encoded in the authentication password syntax.
        Throws:
        LdapException - If a problem occurs while processing of if this storage scheme does not support the authentication password syntax.
      • authPasswordMatches

        public boolean authPasswordMatches​(ByteSequence plaintextPassword,
                                           String authInfo,
                                           String authValue)
        Description copied from class: PasswordStorageScheme
        Indicates whether the provided plaintext password matches the encoded password using the authentication password syntax with the given authInfo and authValue components.

        This is the historical method signature used by clients' custom password storage scheme. Be careful to not modify it.

        Overrides:
        authPasswordMatches in class PasswordStorageScheme<Pbkdf2PasswordStorageSchemeCfg>
        Parameters:
        plaintextPassword - The plaintext password provided by the user.
        authInfo - The authInfo component of the password encoded in the authentication password syntax.
        authValue - The authValue component of the password encoded in the authentication password syntax.
        Returns:
        true if the provided plaintext password matches the encoded password according to the authentication password info syntax, or false if it does not or this storage scheme does not support the authentication password syntax.
      • isStorageSchemeSecure

        public boolean isStorageSchemeSecure()
        Description copied from class: PasswordStorageScheme
        Indicates whether this password storage scheme should be considered "secure". If the encoding used for this scheme does not obscure the value at all, or if it uses a method that is trivial to reverse (e.g., base64), then it should not be considered secure.

        This may be used to determine whether a password may be included in a set of search results, including the possibility of overriding access controls in the case that access controls would allow the password to be returned but the password is considered too insecure to reveal.
        Specified by:
        isStorageSchemeSecure in class PasswordStorageScheme<Pbkdf2PasswordStorageSchemeCfg>
        Returns:
        false if it may be trivial to discover the original plain-text password from the encoded form, or true if the scheme offers sufficient protection that revealing the encoded password will not easily reveal the corresponding plain-text value.
      • isRehashNeeded

        public boolean isRehashNeeded​(ByteSequence storedPassword)
        Description copied from class: PasswordStorageScheme
        Indicates whether the encoded password needs to be rehashed because the password storage scheme configuration changed. Only password storage schemes with specific configuration parameters, such as PBKDF2, need to override this method.
        Overrides:
        isRehashNeeded in class PasswordStorageScheme<Pbkdf2PasswordStorageSchemeCfg>
        Parameters:
        storedPassword - An existing hashed password including the name of the storage scheme.
        Returns:
        whether the stored password should be rehashed.