AssumeRoleWithLDAPIdentity
The AIStor Security Token Service (STS) AssumeRoleWithLDAPIdentity
API endpoint generates temporary access credentials using Active Directory or LDAP user credentials.
This page documents the AIStor Server AssumeRoleWithLDAPIdentity
endpoint.
For instructions on implementing STS using an S3-compatible SDK, defer to the documentation for that SDK.
The AIStor STS AssumeRoleWithLDAPIdentity
API endpoint is modeled after the AWS AssumeRoleWithWebIdentity endpoint and shares certain request/response elements.
This page documents the AIStor-specific syntax and links out to the AWS reference for all shared elements.
Request endpoint
The AssumeRoleWithLDAPIdentity
endpoint has the following form:
POST https://aistor.example.net?Action=AssumeRoleWithLDAPIdentity[&ARGS]
The following example uses all supported arguments.
Replace the aistor.example.net
hostname with the appropriate URL for your AIStor Server:
POST https://aistor.example.net?Action=AssumeRoleWithLDAPIdentity
&LDAPUsername=USERNAME
&LDAPPassword=PASSWORD
&Version=2011-06-15
&Policy={}
Request query parameters
This endpoint supports the following query parameters:
Parameter | Type | Description |
---|---|---|
LDAPUsername |
string | Required Specify the username of the AD/LDAP user as whom you want to authenticate. |
LDAPPassword |
string | Required Specify the password for the LDAPUsername . |
Version |
string | Required Specify 2011-06-15 . |
DurationSeconds |
integer | Optional Specify the number of seconds after which the temporary credentials expire. Defaults to 3600 .- The minimum value is 900 or 15 minutes.- The maximum value is 604800 or 7 days.If DurationSeconds is omitted, AIStor checks the JWT token for an exp claim before using the default duration. See RFC 7519 4.1.4: Expiration Time Claim for more information on JSON web token expiration. |
Policy |
string | Optional Specify the URL-encoded JSON-formatted policy to use as an inline session policy. - The minimum string length is 1 .- The maximum string length is 2048 .The resulting permissions for the temporary credentials are the intersection between the policy matching the Distinguished Name (DN) of the LDAPUsername and the specified inline policy. Applications can only perform those operations for which they are explicitly authorized.The inline policy can specify a subset of permissions allowed by the policy specified in the DN policy. Applications can never assume more privileges than those specified in the DN policy. Omit to use only the DN policy. See Access Management for more information on AIStor authentication and authorization. |
Response elements
The XML response for this API endpoint is similar to the AWS AssumeRoleWithLDAPIdentity response.
Specifically, AIStor returns an AssumeRoleWithLDAPIdentityResult
object, where the AssumedRoleUser.Credentials
object contains the temporary credentials generated by AIStor:
AccessKeyId
- The access key applications use for authentication.SecretKeyId
- The secret key applications use for authentication.Expiration
- The ISO-8601 date-time after which the credentials expire.SessionToken
- The session token applications use for authentication. Some SDKs may require this field when using temporary credentials.
The following example is similar to the response returned by the AIStor Server STS AssumeRoleWithLDAPIdentity
endpoint:
<?xml version="1.0" encoding="UTF-8"?>
<AssumeRoleWithLDAPIdentityResponse xmlns="https://sts.amazonaws.com/doc/2011-06-15/">
<AssumeRoleWithLDAPIdentityResult>
<AssumedRoleUser>
<Arn/>
<AssumeRoleId/>
</AssumedRoleUser>
<Credentials>
<AccessKeyId>Y4RJU1RNFGK48LGO9I2S</AccessKeyId>
<SecretAccessKey>sYLRKS1Z7hSjluf6gEbb9066hnx315wHTiACPAjg</SecretAccessKey>
<Expiration>2019-08-08T20:26:12Z</Expiration>
<SessionToken>eyJhbGciOiJIUzUxMiIsInR5cCI6IkpXVCJ9.eyJhY2Nlc3NLZXkiOiJZNFJKVTFSTkZHSzQ4TEdPOUkyUyIsImF1ZCI6IlBvRWdYUDZ1Vk80NUlzRU5SbmdEWGo1QXU1WWEiLCJhenAiOiJQb0VnWFA2dVZPNDVJc0VOUm5nRFhqNUF1NVlhIiwiZXhwIjoxNTQxODExMDcxLCJpYXQiOjE1NDE4MDc0NzEsImlzcyI6Imh0dHBzOi8vbG9jYWxob3N0Ojk0NDMvb2F1dGgyL3Rva2VuIiwianRpIjoiYTBiMjc2MjktZWUxYS00M2JmLTg3MzktZjMzNzRhNGNkYmMwIn0.ewHqKVFTaP-j_kgZrcOEKroNUjk10GEp8bqQjxBbYVovV0nHO985VnRESFbcT6XMDDKHZiWqN2vi_ETX_u3Q-w</SessionToken>
</Credentials>
</AssumeRoleWithLDAPIdentityResult>
<ResponseMetadata/>
</AssumeRoleWithLDAPIdentityResponse>
Error elements
The XML error response for this API endpoint is similar to the AWS AssumeRoleWithLDAPIdentity response.