Authentication Service
The Authentication service enables you to manage authentication tokens with the following API commands:
authentication token::create
The authentication token::create command enables you to create an authentication token for the logged-in user.
A successful response returns a token value and several additional token properties.
You need to provide this token in subsequent API requests.
You must define a token even in the first API request to create a new token. You can create the initial API token in
CLI Syntax
The following shows the CLI syntax for the authentication token::create command:
ctm authentication token::create -f <tokenDefinition.json>
where <tokenDefinition.json> is the full path and name of a .json payload file with token details.
The following example shows the content of a .json payload file with token details:
{
"tokenName": "emuser1-token",
"expirationDate":"2020-12-02",
"roles": ["Admin","User"]
}
The following table describes the authentication token::create command parameters.
Parameter |
Description |
---|---|
tokenName |
Defines a unique name for the token. |
expirationDate |
Defines a future token expiration date in the following format: YYYY-MM-DD The expiration is based on the UTC time zone. Default: No expiration (if an expiration date is not defined) |
roles |
Defines a list of roles that are granted access with the token. The logged-in user must be a member of all specified roles. This parameter is mandatory, and you must specify at least one role. |
If annotation is enabled for the Scheduling definitions, Configuration management, or Control-M security category in the
REST API Syntax
The following example shows the REST API syntax for the authentication token::create command in cURL:
AuthHeader="x-api-key: $token"
# AuthHeader="Authentication: Bearer $token" #for a session token
curl -H "$AuthHeader" -H "Content-Type: application/json" -X POST "$endpoint/authentication/token" -d @tokenDefinition.json
To select the AuthHeader value ("Authentication: Bearer $token" or "x-api-key: $token"), see Authentication Tokens.
authentication token::update
The authentication token::update command enables you to update an authentication token of the logged-in user.
A successful response returns an updated list of token properties.
CLI Syntax
The following shows the CLI syntax for the authentication token::update command:
ctm authentication token::update -f <tokenDefinition.json>
where <tokenDefinition.json> is the full path and name of a .json payload file with token details.
The contents of this file for an update request are the same as a creation request (authentication token::create). The following guidelines are for an update action:
-
You can update the token expiration date and the roles associated with the token. You cannot modify the token name.
-
You must ensure that the .json file has all parameters, including those that are not updated.
Run one of the get commands before you run an update action to obtain the current values of all parameters.
If annotation is enabled for the Scheduling definitions, Configuration management, or Control-M security category in the
REST API Syntax
The following example shows the REST API syntax for the authentication token::update command in cURL:
AuthHeader="x-api-key: $token"
# AuthHeader="Authentication: Bearer $token" #for a session token
curl -H "$AuthHeader" -H "Content-Type: application/json" -X PUT "$endpoint/authentication/token" -d @tokenDefinition.json
To select the AuthHeader value ("Authentication: Bearer $token" or "x-api-key: $token"), see Authentication Tokens.
authentication token::delete
The authentication token::delete command enables you to delete an authentication token of the logged-in user.
CLI Syntax
The following shows the CLI syntax for the authentication token::delete command:
ctm authentication token::delete <tokenName>
If annotation is enabled for the Scheduling definitions, Configuration management, or Control-M security category in the
REST API Syntax
The following example shows the REST API syntax for the authentication token::delete command in cURL:
tokenName=myToken
AuthHeader="x-api-key: $token"
# AuthHeader="Authentication: Bearer $token" #for a session token
curl -H "$AuthHeader" -H "Content-Type: application/json" -X DELETE "$endpoint/authentication/token/$tokenName"
To select the AuthHeader value ("Authentication: Bearer $token" or "x-api-key: $token"), see Authentication Tokens.
authentication token::get
The authentication token::get command enables you to retrieve details of an authentication token of the logged-in user.
CLI Syntax
The following shows the CLI syntax for the authentication token::get command:
ctm authentication token::get <tokenName>
REST API Syntax
The following example shows the REST API syntax for theauthentication token::get command in cURL:
tokenName=myToken
AuthHeader="x-api-key: $token"
# AuthHeader="Authentication: Bearer $token" #for a session token
curl -H "$AuthHeader" -H "Content-Type: application/json" "$endpoint/authentication/token/$tokenName"
To select the AuthHeader value ("Authentication: Bearer $token" or "x-api-key: $token"), see Authentication Tokens.
authentication tokens::get
The authentication tokens::get command enables you to retrieve a list of authentication tokens for the logged-in user, including the details of each token.
CLI Syntax
The following shows the CLI syntax for the authentication tokens::get command:
ctm authentication tokens::get
REST API Syntax
The following example shows the REST API syntax for the authentication tokens::get command in cURL:
AuthHeader="x-api-key: $token"
# AuthHeader="Authentication: Bearer $token" #for a session token
curl -H "$AuthHeader" -H "Content-Type: application/json" "$endpoint/authentication/tokens"
To select the AuthHeader value ("Authentication: Bearer $token" or "x-api-key: $token"), see Authentication Tokens.