Class OAuthMappingExtUtils


  • public class OAuthMappingExtUtils
    extends java.lang.Object
    Implementation of STS Mapping Extension Functions for OAuth.
    • Method Summary

      All Methods Static Methods Concrete Methods 
      Modifier and Type Method Description
      static boolean associate​(java.lang.String stateID, java.lang.String attrKey, java.lang.String attrValue)
      Associates the attribute key-value pair to authorization grant state ID.
      static boolean associate​(java.lang.String stateID, java.lang.String attrKey, java.lang.String attrValue, boolean sensitive, boolean readonly)
      Associates the attribute key-value pair to authorization grant state ID.
      static java.lang.String batchCreate​(java.lang.String stateID, java.util.Map<java.lang.String,​java.lang.String> attributesToCreate)
      Perform a batch creation of associated attributes.
      static java.lang.String batchDelete​(java.lang.String stateID, java.util.List<java.lang.String> attributesToDelete)
      Perform a batch removal of the associated attributes of a grant This will remove the attributes with the provided names.
      static java.lang.String batchUpdate​(java.lang.String stateID, java.util.Map<java.lang.String,​java.lang.String> attributesToUpdate)
      Perform a batch modification of associated attributes.
      static boolean createClient​(java.lang.String definitionName, java.lang.String clientId, java.lang.String clientName, java.lang.String companyName, java.lang.String clientSecret, java.lang.String[] redirectUris, java.lang.String companyUrl, java.lang.String contactPerson, java.lang.String emailAddress, java.lang.String phoneNumber, java.lang.String contactType, java.lang.String otherInfo, boolean requirePkce, java.lang.String jwksUri, java.lang.String encryptionDb, java.lang.String encryptionCert)
      Creates a client.
      static org.w3c.dom.Element createTokenElement​(java.lang.String token, java.lang.String tokenType)
      Generate the element object based on the token passed in Supported token types are: 1. urn:ietf:params:oauth:token-type:jwt
      static java.lang.String createUUID()
      Create a UUID String
      static int deleteAllTokensForUser​(java.lang.String username)
      Delete all tokens owned by a user from the cache
      static boolean deleteClient​(java.lang.String clientId)
      Remove a client by clientId.
      static boolean deleteGrant​(java.lang.String stateID)
      Delete an OAuth grant from the cache.
      static boolean deleteGrant​(java.lang.String stateID, java.lang.Boolean cleanAttributes)
      Delete an OAuth grant from the cache.
      static boolean deleteHashedToken​(java.lang.String tokenID)
      Delete a Hashed OAuth token from the cache.
      static boolean deleteToken​(java.lang.String tokenID)
      Delete an OAuth token from the cache.
      static int deleteTokens​(java.lang.String username, java.lang.String clientId)
      Delete all tokens owned by a user for a specific client from the cache
      static int deleteTokens​(java.lang.String username, java.lang.String clientId, int batchSize)
      Delete all tokens owned by a user for a specific client from the cache
      static java.lang.String disassociate​(java.lang.String stateID, java.lang.String attrKey)
      Disassociates the attribute key-value pair from the authorization grant state ID.
      static java.lang.String extractIssuer​(java.lang.String token, java.lang.String tokenType)
      Extract issuer from the token based on different token type.
      static java.lang.String generateRandomString​(int length)
      Generate a random string of specified length.
      static Token getActiveToken​(java.lang.String tokenId)
      Retrieve a token based off its tokenId.
      static Token[] getActiveTokens​(java.lang.String stateId)
      Get the tokens associated with the given stateId Expired tokens will not be returned.
      static Token[] getActiveTokens​(java.lang.String clientId, java.lang.String username)
      Get the tokens associated with the given username and client ID Expired tokens will not be returned.
      static Token[] getAllActiveTokensForUser​(java.lang.String username)
      Get all the tokens for a given user Expired tokens will not be returned.
      static Token[] getAllTokensForUser​(java.lang.String username)
      Get all the tokens for a given user Some of the tokens returned may have expired and not been cleaned up.
      static java.lang.String getAssociation​(java.lang.String stateID, java.lang.String attrKey)
      Get an attribute value associated with the given state ID and attibute key.
      static java.lang.String[] getAssociationKeys​(java.lang.String stateID)
      Get all the attribute keys associated with the given authorization grant state ID.
      static java.lang.String[] getCertificateChain​(java.lang.String keystore, java.lang.String alias)
      Retrieving Certificate chain value based on
      static java.lang.String getCertificateThumbprint​(java.lang.String keystore, java.lang.String alias)
      Retrieving Certificate Thumbprint(x5t) value based on
      static java.lang.String getCertificateThumbprint_S256​(java.lang.String keystore, java.lang.String alias)
      Retrieving Certificate Thumbprint(x5tS256) value based on
      static Client getClient​(java.lang.String clientId)
      Retrive a client with the given clientId.
      static Client[] getClientsByCompanyName​(java.lang.String companyName)
      Gets a list of clients which have an company name which matches the provided value
      static Client[] getClientsByContactPerson​(java.lang.String person)
      Gets a list of clients which have an contact person which matches the provided value
      static Client[] getClientsByEmail​(java.lang.String emailAddress)
      Gets a list of clients which have an email address which matches the provided value
      static Definition getDefinition​(java.lang.String definitionName)
      Retrive a definition with the given definitionName.
      static Definition getDefinitionByID​(long definitionID)
      Retrive a definition with the given definitionID.
      static java.util.Map<java.lang.String,​java.lang.String> getEmptyMap()  
      static Grant[] getGrants​(java.lang.String username)
      Get the grants associated with the given username.
      static Token getToken​(java.lang.String tokenId)
      Retrieve a token based off its tokenId.
      static Token[] getTokens​(java.lang.String stateId)
      Get the tokens associated with the given stateId Some of the tokens returned may have expired and not been cleaned up.
      static Token[] getTokens​(java.lang.String clientId, java.lang.String username)
      Get the tokens associated with the given username and client ID Some of the tokens returned may have expired and not been cleaned up.
      static HttpResponse httpGet​(java.lang.String urlstr)
      HTTP client GET method.
      static HttpResponse httpGet​(java.lang.String urlstr, java.util.Map headers, java.lang.String httpsTrustStore, java.lang.String basicAuthUsername, java.lang.String basicAuthPassword, java.lang.String clientKeyStore, java.lang.String clientKeyAlias)
      HTTP client GET method.
      static HttpResponse httpPost​(java.lang.String urlstr, java.util.Map params)
      HTTP client POST method.
      static HttpResponse httpPost​(java.lang.String urlstr, java.util.Map headers, java.util.Map params, java.lang.String httpsTrustStore, java.lang.String basicAuthUsername, java.lang.String basicAuthPassword, java.lang.String clientKeyStore, java.lang.String clientKeyAlias)
      HTTP client POST method.
      static boolean isFapiCompliantByDefinitionID​(long definitionID)
      Retrive fapiCompliant Flag with the given definitionID.
      static boolean isIncludeIssByDefinitionID​(long definitionID)
      Retrieve includeIssuer In Authorization response Flag with the given definitionID.
      static boolean isOidcCompliantByDefinitionID​(long definitionID)
      Retrieve oidcCompliant Flag with the given definitionID.
      static java.lang.String parseSTSUUToJson​(STSUniversalUser sts, java.lang.String tokenType, java.lang.String universalNameMapJson)
      Parse the attribute in STSUU object to a JSON.
      static java.lang.String retrieveActor​(java.lang.String stateId)
      Retrieve the act claims from the OAuth Token extra attributes table.
      static java.util.Map<java.lang.String,​java.lang.String> retrieveAllAssociations​(java.lang.String stateID)
      retrieve all associations for a given grant/state-id this is to be as performant as possible
      static byte[] SHA256Sum​(java.lang.String value)
      Get a SHA-256 hash of the provided value.
      static byte[] SHA384Sum​(java.lang.String value)  
      static byte[] SHA512Sum​(java.lang.String value)
      Get a SHA-512 hash of the provided value.
      static void storeJwtActor​(java.lang.String act, java.lang.String stateId)
      Store the JWT token "act" claims into OAuth Token extra attributes table.
      static void throwSTSAccessDeniedMessageException​(java.lang.String message)
      Used to throw STS Messages from Javascript mapping rules and to return a 401.
      static void throwSTSAccessDeniedMessageException​(java.lang.String message, java.lang.String details)
      Used to throw STS Messages from Javascript mapping rules and to return a 401.
      static void throwSTSCustomUserMessageException​(java.lang.String message, int statusCode)
      Used to throw STS Messages with user-supplied status code from Javascript mapping rules.
      static void throwSTSCustomUserMessageException​(java.lang.String message, int statusCode, java.lang.String errorType)
      Used to throw STS Messages with user-supplied status code and error type from Javascript mapping rules.
      static void throwSTSCustomUserPageException​(java.lang.String message, int statusCode, java.lang.String errorType)
      Used to thrown an error page with user-supplied message, status code and error type from XLST/Javascript mapping rules.
      static void throwSTSException​(java.lang.String message)
      Used to throw STS Messages from Javascript mapping rules.
      static void throwSTSInvalidGrantMessageException​(java.lang.String message)
      Used to throw STS Messages from Javascript mapping rules and to return a 400 with the error "invalid_grant"
      static void throwSTSInvalidGrantMessageException​(java.lang.String message, java.lang.String details)
      Used to throw STS Messages from Javascript mapping rules and to return a 400 with the error "invalid_grant"
      static void throwSTSUserMessageException​(java.lang.String message)
      Used to throw STS Messages from Javascript mapping rules.
      static void throwSTSUserMessageException​(java.lang.String message, java.lang.String details)
      Used to throw STS Messages from Javascript mapping rules.
      static boolean updateClient​(java.lang.String clientId, java.lang.String clientName, java.lang.String clientSecret, java.lang.String[] redirectUris, boolean requirePkce)
      Update a client.
      static boolean updateToken​(java.lang.String tokenId, java.lang.Long newLifetime, java.lang.Long newLastUsed, java.lang.Boolean enabled)
      Update a tokens lifetime lastused or enabled state One of newLifetime, newLastUsed and enabled must not be null.
      • Methods inherited from class java.lang.Object

        equals, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
    • Field Detail

      • OAuthMappingExtUtils_java_copyright

        public static final java.lang.String OAuthMappingExtUtils_java_copyright
    • Constructor Detail

      • OAuthMappingExtUtils

        public OAuthMappingExtUtils()
    • Method Detail

      • throwSTSException

        public static void throwSTSException​(java.lang.String message)
                                      throws STSException
        Used to throw STS Messages from Javascript mapping rules. use IDMappingExtUtils.throwSTSException(String) instead
        Throws:
        STSException
      • generateRandomString

        public static java.lang.String generateRandomString​(int length)
        Generate a random string of specified length. Charset will include:
        • A-Z
        • a-z
        • 0-9
        Parameters:
        length - of the string to create.
        Returns:
        a String of specified length
      • throwSTSUserMessageException

        public static void throwSTSUserMessageException​(java.lang.String message)
                                                 throws STSUserMessageException
        Used to throw STS Messages from Javascript mapping rules. use IDMappingExtUtils.throwSTSException(String) instead
        Throws:
        STSUserMessageException
      • throwSTSCustomUserPageException

        public static void throwSTSCustomUserPageException​(java.lang.String message,
                                                           int statusCode,
                                                           java.lang.String errorType)
                                                    throws STSCustomUserPageException
        Used to thrown an error page with user-supplied message, status code and error type from XLST/Javascript mapping rules.
        Parameters:
        message - to include as error_description in the error page
        statusCode - to return Http status code
        errorType - to include as error
        Throws:
        STSCustomUserPageException
      • throwSTSCustomUserMessageException

        public static void throwSTSCustomUserMessageException​(java.lang.String message,
                                                              int statusCode)
                                                       throws STSCustomUserMessageException
        Used to throw STS Messages with user-supplied status code from Javascript mapping rules.
        Parameters:
        message - to include as error_description
        statusCode - to return Http status code
        Throws:
        STSCustomUserMessageException
      • throwSTSCustomUserMessageException

        public static void throwSTSCustomUserMessageException​(java.lang.String message,
                                                              int statusCode,
                                                              java.lang.String errorType)
                                                       throws STSCustomUserMessageException
        Used to throw STS Messages with user-supplied status code and error type from Javascript mapping rules.
        Parameters:
        message - to include as error_description
        statusCode - to return Http status code
        errorType - to include as error
        Throws:
        STSCustomUserMessageException
      • throwSTSUserMessageException

        public static void throwSTSUserMessageException​(java.lang.String message,
                                                        java.lang.String details)
                                                 throws STSUserMessageException
        Used to throw STS Messages from Javascript mapping rules.
        Parameters:
        details - string of details to include. If valid json will be parsed and included as a json object, otherwise will be presented as a string. use IDMappingExtUtils.throwSTSException(String) instead
        Throws:
        STSUserMessageException
      • throwSTSInvalidGrantMessageException

        public static void throwSTSInvalidGrantMessageException​(java.lang.String message)
                                                         throws STSUserMessageException
        Used to throw STS Messages from Javascript mapping rules and to return a 400 with the error "invalid_grant"
        Parameters:
        message - to include as a error_description use IDMappingExtUtils.throwSTSException(String) instead
        Throws:
        STSUserMessageException
      • throwSTSInvalidGrantMessageException

        public static void throwSTSInvalidGrantMessageException​(java.lang.String message,
                                                                java.lang.String details)
                                                         throws STSUserMessageException
        Used to throw STS Messages from Javascript mapping rules and to return a 400 with the error "invalid_grant"
        Parameters:
        message - to include as a error_description
        details - string or object use IDMappingExtUtils.throwSTSException(String) instead
        Throws:
        STSUserMessageException
      • throwSTSAccessDeniedMessageException

        public static void throwSTSAccessDeniedMessageException​(java.lang.String message)
                                                         throws STSUserMessageException
        Used to throw STS Messages from Javascript mapping rules and to return a 401. use IDMappingExtUtils.throwSTSException(String) instead
        Throws:
        STSUserMessageException
      • throwSTSAccessDeniedMessageException

        public static void throwSTSAccessDeniedMessageException​(java.lang.String message,
                                                                java.lang.String details)
                                                         throws STSUserMessageException
        Used to throw STS Messages from Javascript mapping rules and to return a 401.
        Parameters:
        details - string of details to include. If valid json will be parsed and included as a json object, otherwise will be presented as a string. use IDMappingExtUtils.throwSTSException(String) instead
        Throws:
        STSUserMessageException
      • associate

        public static boolean associate​(java.lang.String stateID,
                                        java.lang.String attrKey,
                                        java.lang.String attrValue)
        Associates the attribute key-value pair to authorization grant state ID. This method will set the sensitive and readonly properties to false.
        Parameters:
        stateID - State ID of the authorization grant
        attrKey - Attribute key
        attrValue - Attribute value
        Returns:
        Whether or not it succeeded.
      • associate

        public static boolean associate​(java.lang.String stateID,
                                        java.lang.String attrKey,
                                        java.lang.String attrValue,
                                        boolean sensitive,
                                        boolean readonly)
        Associates the attribute key-value pair to authorization grant state ID. When updating an existing property, this method does not allow changes to be made to the immutable sensitive and readonly properties. Will not mark a sensitive attributes as non-sensitive, or a non-sensitive attribute as sensitive. The same applies for readonly.
        Parameters:
        stateID - State ID of the authorization grant
        attrKey - Attribute key
        attrValue - Attribute value
        sensitive - If this value should be stored as a sensitive value. If the attribute already exists, its sensitive state will be preserved.
        readonly - If this value should be stored as a readonly value. If this attribute already exists, its readonly state will be preserved.
        Returns:
        Whether or not it succeeded.
      • updateToken

        public static boolean updateToken​(java.lang.String tokenId,
                                          java.lang.Long newLifetime,
                                          java.lang.Long newLastUsed,
                                          java.lang.Boolean enabled)
        Update a tokens lifetime lastused or enabled state One of newLifetime, newLastUsed and enabled must not be null.
        Parameters:
        tokenId - identifier of the token to update. Cannot be null.
        newLifetime - the new lifetime of the token in seconds. If null the lifetime will not be changed.
        newLastUsed - the new date last used of the token in milliseconds since the epoch (i.e. 01 January 1970 00:00:00 UTC). If null the date last used will not be changed.
        enabled - whether or not the token is enabled.
      • disassociate

        public static java.lang.String disassociate​(java.lang.String stateID,
                                                    java.lang.String attrKey)
        Disassociates the attribute key-value pair from the authorization grant state ID.
        Parameters:
        stateID - State ID of the authorization grant
        attrKey - Attribute key
        Returns:
        Attribute value of disassociated attribute. Null if attribute not found.
      • getToken

        public static Token getToken​(java.lang.String tokenId)
        Retrieve a token based off its tokenId. If token hashing is enabled, the is function will handle hashing the token for the lookup. The token returned may have expired and not yet been cleaned up.
        Parameters:
        tokenId - to lookup
      • getActiveToken

        public static Token getActiveToken​(java.lang.String tokenId)
        Retrieve a token based off its tokenId. If token hashing is enabled, the is function will handle hashing the token for the lookup. Expired tokens will not be returned.
        Parameters:
        tokenId - to lookup
      • getAllTokensForUser

        public static Token[] getAllTokensForUser​(java.lang.String username)
        Get all the tokens for a given user Some of the tokens returned may have expired and not been cleaned up. Some of the tokens may not belong to this client.
        Parameters:
        username - which identifies a grant
        Returns:
        An array of tokens issued for the provided user
      • getAllActiveTokensForUser

        public static Token[] getAllActiveTokensForUser​(java.lang.String username)
        Get all the tokens for a given user Expired tokens will not be returned. Some of the tokens may not belong to this client.
        Parameters:
        username - which identifies a grant
        Returns:
        An array of tokens issued for the provided user
      • getTokens

        public static Token[] getTokens​(java.lang.String stateId)
        Get the tokens associated with the given stateId Some of the tokens returned may have expired and not been cleaned up.
        Parameters:
        StateId - which identifies a grant
        Returns:
        An array of tokens associated with the given stateId.
      • getActiveTokens

        public static Token[] getActiveTokens​(java.lang.String stateId)
        Get the tokens associated with the given stateId Expired tokens will not be returned.
        Parameters:
        StateId - which identifies a grant
        Returns:
        An array of tokens associated with the given stateId.
      • getTokens

        public static Token[] getTokens​(java.lang.String clientId,
                                        java.lang.String username)
        Get the tokens associated with the given username and client ID Some of the tokens returned may have expired and not been cleaned up.
        Parameters:
        clientId - The client id of the token. This parameter cannot be null or empty.
        username - The user name of the token. This parameter cannot be null or empty.
        Returns:
        An array of tokens associated with the given username and client ID. Null if no tokens found.
      • getActiveTokens

        public static Token[] getActiveTokens​(java.lang.String clientId,
                                              java.lang.String username)
        Get the tokens associated with the given username and client ID Expired tokens will not be returned.
        Parameters:
        clientId - The client id of the token. This parameter cannot be null or empty.
        username - The user name of the token. This parameter cannot be null or empty.
        Returns:
        An array of tokens associated with the given username and client ID. Null if no tokens found.
      • deleteAllTokensForUser

        public static int deleteAllTokensForUser​(java.lang.String username)
        Delete all tokens owned by a user from the cache
        Parameters:
        username - username of the OAuth tokens to be deleted. This cannot be null or empty.
        Returns:
        false- No tokens deleted true- Tokens deleted
      • deleteTokens

        public static int deleteTokens​(java.lang.String username,
                                       java.lang.String clientId)
        Delete all tokens owned by a user for a specific client from the cache
        Parameters:
        username - username of the OAuth tokens to be deleted. This cannot be null or empty.
        clientId - clientId of the OAuth tokens to be deleted. This cannot be null or empty.
        Returns:
        false- No tokens deleted true- Tokens deleted
      • deleteTokens

        public static int deleteTokens​(java.lang.String username,
                                       java.lang.String clientId,
                                       int batchSize)
        Delete all tokens owned by a user for a specific client from the cache
        Parameters:
        username - username of the OAuth tokens to be deleted. This cannot be null or empty.
        clientId - clientId of the OAuth tokens to be deleted. This cannot be null or empty.
        batchSize - The number of tokens to delete in a single batch.
        Returns:
        false- No tokens deleted true- Tokens deleted
      • deleteToken

        public static boolean deleteToken​(java.lang.String tokenID)
        Delete an OAuth token from the cache.
        Parameters:
        tokenID - ID of the OAuth token to be deleted. This cannot be null or empty.
        Returns:
        false- No token deleted true- Token deleted
      • deleteHashedToken

        public static boolean deleteHashedToken​(java.lang.String tokenID)
        Delete a Hashed OAuth token from the cache.
        Parameters:
        tokenID - ID of the OAuth token to be deleted. This cannot be null or empty.
        Returns:
        false- No token deleted true- Token deleted
      • getGrants

        public static Grant[] getGrants​(java.lang.String username)
        Get the grants associated with the given username.
        Parameters:
        username - The username of the grant. This parameter cannot be null or empty.
        Returns:
        An array of grants associated with the given username. Null if no grants found.
      • deleteGrant

        public static boolean deleteGrant​(java.lang.String stateID)
        Delete an OAuth grant from the cache.
        Parameters:
        stateID - ID of the OAuth grant to be deleted. This cannot be null or empty.
        Returns:
        false- No grant deleted true- Grant deleted
      • deleteGrant

        public static boolean deleteGrant​(java.lang.String stateID,
                                          java.lang.Boolean cleanAttributes)
        Delete an OAuth grant from the cache.
        Parameters:
        stateID - ID of the OAuth grant to be deleted. This cannot be null or empty.
        cleanAttributes - Flag to clean the extra attributes associated.
        Returns:
        false- No grant deleted true- Grant deleted
      • getAssociationKeys

        public static java.lang.String[] getAssociationKeys​(java.lang.String stateID)
        Get all the attribute keys associated with the given authorization grant state ID.
        Parameters:
        stateID - State ID of the authorization grant
        Returns:
        A String array of all attribute keys associated with the authorization grant state ID. Returns null if state ID is invalid, problem retrieving from token cache, or no associated attributes.
      • getAssociation

        public static java.lang.String getAssociation​(java.lang.String stateID,
                                                      java.lang.String attrKey)
        Get an attribute value associated with the given state ID and attibute key.
        Parameters:
        stateID - State ID of the authorization grant
        Returns:
        Attribute value. Null if not found.
      • retrieveAllAssociations

        public static java.util.Map<java.lang.String,​java.lang.String> retrieveAllAssociations​(java.lang.String stateID)
        retrieve all associations for a given grant/state-id this is to be as performant as possible
        Parameters:
        stateID - of the grant/token to retireve
      • batchDelete

        public static java.lang.String batchDelete​(java.lang.String stateID,
                                                   java.util.List<java.lang.String> attributesToDelete)
        Perform a batch removal of the associated attributes of a grant This will remove the attributes with the provided names. If an error occurs, the database connection is rolled back.
        Parameters:
        stateId - the token/grant to update.
        attributesToDelete - list of attribute names to be deleted from the token/grants extra attributes
        Returns:
        null if all processing was successful / A string containing any SQL error output.
      • getEmptyMap

        public static java.util.Map<java.lang.String,​java.lang.String> getEmptyMap()
      • batchCreate

        public static java.lang.String batchCreate​(java.lang.String stateID,
                                                   java.util.Map<java.lang.String,​java.lang.String> attributesToCreate)
        Perform a batch creation of associated attributes. This will create attributes as provided by the input parameters via a single SQL statement to be as performant as possible. If an error occurs, the connection is rolled back.
        Parameters:
        stateId - the token/grant to update.
        attributesToCreate - map of key/value attributes to create. The key will not be checked prior to insertion, thus primary key violations may occur if an attempt to create an attribute which exists are made.
        attributesToUpdate - map of key/value attributes to update. The key will not be checked prior to update, so no update will occur on a key which does not exist
        Returns:
        null if all processing was successful / A string containing any SQL error output.
      • batchUpdate

        public static java.lang.String batchUpdate​(java.lang.String stateID,
                                                   java.util.Map<java.lang.String,​java.lang.String> attributesToUpdate)
        Perform a batch modification of associated attributes. This will create attributes as provided by the input parameters via a single SQL statement to be as performant as possible. If an error occurs, the connection is rolled back.
        Parameters:
        stateId - the token/grant to update.
        attributesToUpdate - map of key/value attributes to update. The key will not be checked prior to update, so no update will occur on a key which does not exist
        Returns:
        null if all processing was successful / A string containing any SQL error output.
      • httpGet

        public static HttpResponse httpGet​(java.lang.String urlstr)
        HTTP client GET method.
        Parameters:
        urlstr - URL
        Returns:
        The HTTP response. Null if invalid URL or no response.
      • httpGet

        public static HttpResponse httpGet​(java.lang.String urlstr,
                                           java.util.Map headers,
                                           java.lang.String httpsTrustStore,
                                           java.lang.String basicAuthUsername,
                                           java.lang.String basicAuthPassword,
                                           java.lang.String clientKeyStore,
                                           java.lang.String clientKeyAlias)
        HTTP client GET method.
        Parameters:
        urlstr - URL
        headers - A Map (String,String) to be added to the request header.
        httpsTrustStore - The name of the trust store to use. If a HTTPS connection is required and this is set to NULL, the default trust store specified in the override configs will be used.
        basicAuthUsername - Basic-auth username. If null, basic-auth will be disabled.
        basicAuthPassword - Basic-auth password. If null, basic-auth will be disabled.
        clientKeyStore - Client key store. If null, client cert auth will be disabled.
        clientKeyAlias - Client key alias. If null, client cert auth will be disabled.
        Returns:
        The HTTP response. Null if invalid URL or no response.
      • httpPost

        public static HttpResponse httpPost​(java.lang.String urlstr,
                                            java.util.Map params)
        HTTP client POST method.
        Parameters:
        urlstr - URL
        params - A Map (String,String) to be added to the request body.
        Returns:
        The HTTP response. Null if invalid URL or no response.
      • httpPost

        public static HttpResponse httpPost​(java.lang.String urlstr,
                                            java.util.Map headers,
                                            java.util.Map params,
                                            java.lang.String httpsTrustStore,
                                            java.lang.String basicAuthUsername,
                                            java.lang.String basicAuthPassword,
                                            java.lang.String clientKeyStore,
                                            java.lang.String clientKeyAlias)
        HTTP client POST method.
        Parameters:
        urlstr - URL
        headers - A Map (String,String) to be added to the request header.
        params - A Map (String,String) to be added to the request body.
        httpsTrustStore - The trust store to use. If a HTTPS connection is required and this is set to NULL, the default trust store specified in the override configs will be used.
        basicAuthUsername - Basic-auth username. If null, basic-auth will be disabled.
        basicAuthPassword - Basic-auth password. If null, basic-auth will be disabled.
        clientKeyStore - Client key store. If null, client cert auth will be disabled.
        clientKeyAlias - Client key alias. If null, client cert auth will be disabled.
        Returns:
        The HTTP response. Null if invalid URL or no response.
      • getClient

        public static Client getClient​(java.lang.String clientId)
        Retrive a client with the given clientId. Client IDs are unique across all definitions, there is a guarantee that only one client is returned.
        Parameters:
        clientId - to lookup
        Returns:
        a Client object on success / null on error or no client found
      • getClientsByEmail

        public static Client[] getClientsByEmail​(java.lang.String emailAddress)
        Gets a list of clients which have an email address which matches the provided value
        Parameters:
        emailAddress - to search for clients with
        Returns:
        Array of clients, may be empty. null on error.
      • getClientsByContactPerson

        public static Client[] getClientsByContactPerson​(java.lang.String person)
        Gets a list of clients which have an contact person which matches the provided value
        Parameters:
        person - to search for clients with
        Returns:
        Array of clients, may be empty. null on error.
      • getClientsByCompanyName

        public static Client[] getClientsByCompanyName​(java.lang.String companyName)
        Gets a list of clients which have an company name which matches the provided value
        Parameters:
        companyName - to search for clients with
        Returns:
        Array of clients, may be empty. null on error.
      • createClient

        public static boolean createClient​(java.lang.String definitionName,
                                           java.lang.String clientId,
                                           java.lang.String clientName,
                                           java.lang.String companyName,
                                           java.lang.String clientSecret,
                                           java.lang.String[] redirectUris,
                                           java.lang.String companyUrl,
                                           java.lang.String contactPerson,
                                           java.lang.String emailAddress,
                                           java.lang.String phoneNumber,
                                           java.lang.String contactType,
                                           java.lang.String otherInfo,
                                           boolean requirePkce,
                                           java.lang.String jwksUri,
                                           java.lang.String encryptionDb,
                                           java.lang.String encryptionCert)
        Creates a client. This client will be available for use as soon as this function is called.
        Null and empty string are OK for some values.
        Required values are:
        • definitionName
        • clientId
        • clientName
        • companyName

        RedirectUri and companyUrl if provided must be valid URIs.
        If client secret is null the client will be considered non-confidential
        Contact type must be one of:
        • ADMINISTRATIVE
        • BILLING
        • OTHER
        • SUPPORT
        • TECHNICAL
        Parameters:
        definitionName - of the definition to add this client to
        clientId - identifier of this client.
        clientName - friendly name of the client.
        companyName - to identify which entity this client belongs to
        clientSecret - OPTIONAL secret for confidential clients
        redirectUri -
        companyUrl -
        contactPerson -
        emailAddress -
        phoneNumber -
        contactType -
        otherInfo -
        Returns:
        true on successful create / false if the client was not created.
      • deleteClient

        public static boolean deleteClient​(java.lang.String clientId)
        Remove a client by clientId.
        Parameters:
        clientId - to identify the client to remove.
        Returns:
        true if a client was removed / false if the client didn't exist or an error occurred.
      • updateClient

        public static boolean updateClient​(java.lang.String clientId,
                                           java.lang.String clientName,
                                           java.lang.String clientSecret,
                                           java.lang.String[] redirectUris,
                                           boolean requirePkce)
        Update a client. No update will be performed if a value is null. This means to update a client to be non-confidential "" should be used.
        Parameters:
        clientId - to identify the client to update.
        clientName - new name of the client. Cannot be empty.
        clientSecret - new client secret.
        redirectUri - new redirectUri
        Returns:
        true if a client was update / false if the client didn't exist or an error occurred.
      • SHA512Sum

        public static byte[] SHA512Sum​(java.lang.String value)
        Get a SHA-512 hash of the provided value. This byte array can be converted to a base64 encoded string using the Base64Utility. Example: Base64Utility.encode(SHA512Sum(myValue));
        Parameters:
        value - to sum.
      • SHA384Sum

        public static byte[] SHA384Sum​(java.lang.String value)
      • SHA256Sum

        public static byte[] SHA256Sum​(java.lang.String value)
        Get a SHA-256 hash of the provided value. This byte array can be converted to a base64 encoded string using the Base64Utility. Example: Base64Utility.encode(SHA256Sum(myValue));
        Parameters:
        value - to sum.
      • getCertificateThumbprint

        public static java.lang.String getCertificateThumbprint​(java.lang.String keystore,
                                                                java.lang.String alias)
                                                         throws java.lang.Exception
        Retrieving Certificate Thumbprint(x5t) value based on
        Parameters:
        value - to certificate thumbprint in sha-1.
        Throws:
        java.lang.Exception
      • getCertificateThumbprint_S256

        public static java.lang.String getCertificateThumbprint_S256​(java.lang.String keystore,
                                                                     java.lang.String alias)
                                                              throws java.lang.Exception
        Retrieving Certificate Thumbprint(x5tS256) value based on
        Parameters:
        value - to certificate thumbprint in sha-256.
        Throws:
        java.lang.Exception
      • getCertificateChain

        public static java.lang.String[] getCertificateChain​(java.lang.String keystore,
                                                             java.lang.String alias)
                                                      throws java.lang.Exception
        Retrieving Certificate chain value based on
        Parameters:
        value - to certificate chain
        Throws:
        java.lang.Exception
      • getDefinition

        public static Definition getDefinition​(java.lang.String definitionName)
        Retrive a definition with the given definitionName. DefinitionNames are unique across all definitions, there is a guarantee that only one definition is returned.
        Parameters:
        definitionName - to lookup
        Returns:
        a Definition object on success / null on error or no client found
      • getDefinitionByID

        public static Definition getDefinitionByID​(long definitionID)
        Retrive a definition with the given definitionID. DefinitionID are unique across all definitions, there is a guarantee that only one definition is returned.
        Parameters:
        definitionID - to lookup
        Returns:
        a Definition object on success / null on error or no client found
      • isIncludeIssByDefinitionID

        public static boolean isIncludeIssByDefinitionID​(long definitionID)
        Retrieve includeIssuer In Authorization response Flag with the given definitionID. DefinitionName are unique across all definitions, there is a guarantee that only one definition is returned.
        Parameters:
        DefinitionName - to lookup
        Returns:
        a boolean result will be returned, True if Definition has been configured to be include Iss and False otherwise.
      • isOidcCompliantByDefinitionID

        public static boolean isOidcCompliantByDefinitionID​(long definitionID)
        Retrieve oidcCompliant Flag with the given definitionID. DefinitionName are unique across all definitions, there is a guarantee that only one definition is returned.
        Parameters:
        DefinitionName - to lookup
        Returns:
        a boolean result will be returned, True if Definition has been configured to be OIDC Compliant and False otherwise.
      • isFapiCompliantByDefinitionID

        public static boolean isFapiCompliantByDefinitionID​(long definitionID)
        Retrive fapiCompliant Flag with the given definitionID. DefinitionName are unique across all definitions, there is a guarantee that only one definition is returned.
        Parameters:
        DefinitionName - to lookup
        Returns:
        a boolean result will be returned, True if Definition has been configured to be OIDC Compliant and False otherwise.
      • extractIssuer

        public static java.lang.String extractIssuer​(java.lang.String token,
                                                     java.lang.String tokenType)
                                              throws java.lang.Exception
        Extract issuer from the token based on different token type. This method is being used prior to STS callouts. Issuer will be extraced and used to verify which chain to call. Supported token types are: 1. urn:ietf:params:oauth:token-type:jwt 2. urn:ietf:params:oauth:token-type:saml1 3. urn:ietf:params:oauth:token-type:saml2
        Parameters:
        token - to be analyzed to get the issuer.
        tokenType - is the type of the token.
        Returns:
        issuer string
        Throws:
        java.lang.Exception
      • createTokenElement

        public static org.w3c.dom.Element createTokenElement​(java.lang.String token,
                                                             java.lang.String tokenType)
                                                      throws java.lang.Exception
        Generate the element object based on the token passed in Supported token types are: 1. urn:ietf:params:oauth:token-type:jwt
        Parameters:
        token - to be used to generate the Element Object.
        tokenType - is the type of the token.
        Returns:
        Element object
        Throws:
        java.lang.Exception
      • parseSTSUUToJson

        public static java.lang.String parseSTSUUToJson​(STSUniversalUser sts,
                                                        java.lang.String tokenType,
                                                        java.lang.String universalNameMapJson)
                                                 throws java.lang.Exception
        Parse the attribute in STSUU object to a JSON.
        Parameters:
        sts - is the STSUU object which contains the attribute.
        tokenType - is the type of the token.
        universalNameMapJson - is the JSON string which contains the universal and original name mapping.
        Returns:
        JSON String
        Throws:
        java.lang.Exception
      • storeJwtActor

        public static void storeJwtActor​(java.lang.String act,
                                         java.lang.String stateId)
                                  throws java.lang.Exception
        Store the JWT token "act" claims into OAuth Token extra attributes table.
        Parameters:
        act - is the "act" claims in the jwt token.
        stateId - is the State ID of the authorization grant.
        Throws:
        java.lang.Exception
      • retrieveActor

        public static java.lang.String retrieveActor​(java.lang.String stateId)
        Retrieve the act claims from the OAuth Token extra attributes table.
        Parameters:
        stateId - is State ID of the authorization grant.
        Returns:
        JSON String
      • createUUID

        public static java.lang.String createUUID()
        Create a UUID String
        Returns:
        UUID string