com.authlete.common.dto.TokenCreateRequest Maven / Gradle / Ivy
Show all versions of authlete-java-common Show documentation
/*
* Copyright (C) 2015-2023 Authlete, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* https://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.authlete.common.dto;
import java.io.Serializable;
import java.net.URI;
import com.authlete.common.types.GrantType;
/**
* Request to Authlete's {@code /auth/token/create} API.
*
*
* The API is used to create an arbitrary access token in a special way
* that is different from standard grant flows.
*
*
*
*
*
* grantType
(REQUIRED)
* -
*
* The grant type for a newly created access token. One of the following.
* {@link com.authlete.common.types.GrantType#REFRESH_TOKEN REFRESH_TOKEN}
* is not allowed.
*
*
* - {@link com.authlete.common.types.GrantType#AUTHORIZATION_CODE AUTHORIZATION_CODE}
*
- {@link com.authlete.common.types.GrantType#IMPLICIT IMPLICIT}
*
- {@link com.authlete.common.types.GrantType#PASSWORD PASSWORD}
*
- {@link com.authlete.common.types.GrantType#CLIENT_CREDENTIALS CLIENT_CREDENTIALS}
*
- {@link com.authlete.common.types.GrantType#CIBA CIBA} (Authlete 2.1 onwards)
*
- {@link com.authlete.common.types.GrantType#DEVICE_CODE DEVICE_CODE} (Authlete 2.1 onwards)
*
- {@link com.authlete.common.types.GrantType#TOKEN_EXCHANGE TOKEN_EXCHANGE} (Authlete 2.3 onwards)
*
- {@link com.authlete.common.types.GrantType#JWT_BEARER JWT_BEARER} (Authlete 2.3 onwards)
*
- {@link com.authlete.common.types.GrantType#PRE_AUTHORIZED_CODE PRE_AUTHORIZED_CODE} (Authlete 3.0 onwards)
*
*
* When {@code grantType} is either {@code IMPLICIT} or {@code CLIENT_CREDENTIALS},
* a refresh token is not issued.
*
*
*
* clientId
(REQUIRED)
* -
*
* The ID of the client application which will be associated with
* a newly created access token.
*
*
*
* subject
(CONDITIONALLY REQUIRED)
* -
*
* The subject (= unique identifier) of the user who will be associated with
* a newly created access token. This parameter is ignored when the grant
* type is {@link com.authlete.common.types.GrantType#CLIENT_CREDENTIALS
* CLIENT_CREDENTIALS}. This parameter is optional when the grant type is
* {@link com.authlete.common.types.GrantType#JWT_BEARER JWT_BEARER}.
* In other cases, this parameter is required. When specified, the value must
* consist of only ASCII characters and its length must not exceed 100.
*
*
*
* scopes
(OPTIONAL)
* -
*
* The scopes which will be associated with a newly created access token.
* Scopes that are not supported by the service cannot be specified and
* requesting them will cause an error.
*
*
*
* accessTokenDuration
(OPTIONAL)
* -
*
* The duration of a newly created access token in seconds. If the value is 0,
* the duration is determined according to the settings of the service.
*
*
*
* refreshTokenDuration
(OPTIONAL)
* -
*
* The duration of a newly created refresh token in seconds. If the value is 0,
* the duration is determined according to the settings of the service.
*
*
* A refresh token is not created (1) if the service does not support
* {@link com.authlete.common.types.GrantType#REFRESH_TOKEN REFRESH_TOKEN},
* or (2) if the specified grant type is either {@link
* com.authlete.common.types.GrantType#IMPLICIT IMPLICIT} or {@link
* com.authlete.common.types.GrantType#CLIENT_CREDENTIALS CLIENT_CREDENTIALS}.
*
*
*
* properties
(OPTIONAL)
* -
*
* Extra properties to associate with a newly created access token. Note that
* {@code properties} parameter is accepted only when Content-Type of the
* request is application/json, so don't use application/x-www-form-urlencoded
* if you want to specify {@code properties}
*
*
*
* clientIdAliasUsed
(OPTIONAL)
* -
*
* A boolean request parameter which indicates whether to emulate that the client
* ID alias is used instead of the original numeric client ID when a new access
* token is created.
*
*
* This has an effect only on the value of the {@code aud} claim in a response from
* UserInfo
* endpoint. When you access the UserInfo endpoint (which is expected to be
* implemented using Authlete's {@code /api/auth/userinfo} API and {@code
* /api/auth/userinfo/issue} API) with an access token which has been created using
* Authlete's {@code /api/auth/token/create} API with this property ({@code
* clientIdAliasUsed}) true, the client ID alias is used as the value of the {@code
* aud} claim in a response from the UserInfo endpoint.
*
*
* Note that if a client ID alias is not assigned to the client when Authlete's
* {@code /api/auth/token/create} API is called, this property ({@code
* clientIdAliasUsed}) has no effect (it is always regarded as {@code false}).
*
*
*
* accessToken
(OPTIONAL)
* -
*
* The value of the new access token.
*
*
* The {@code /api/auth/token/create} API generates an access token.
* Therefore, callers of the API do not have to specify values of
* newly created access tokens. However, in some cases, for example,
* if you want to migrate existing access tokens from an old system
* to Authlete, you may want to specify values of access tokens.
* In such a case, you can specify the value of a newly created
* access token by passing a non-null value as the value of
* {@code accessToken} request parameter. The implementation of the
* {@code /api/auth/token/create} uses the value of the {@code
* accessToken} request parameter instead of generating a new value
* when the request parameter holds a non-null value.
*
*
* Note that if the hash value of the specified access token already
* exists in Authlete's database, the access token cannot be inserted
* and the {@code /api/auth/token/create} API will report an error.
*
*
*
* refreshToken
(OPTIONAL)
* -
*
* The value of the new refresh token.
*
*
* The {@code /api/auth/token/create} API may generate a refresh token.
* Therefore, callers of the API do not have to specify values of
* newly created refresh tokens. However, in some cases, for example,
* if you want to migrate existing refresh tokens from an old system
* to Authlete, you may want to specify values of refresh tokens.
* In such a case, you can specify the value of a newly created
* refresh token by passing a non-null value as the value of
* {@code refreshToken} request parameter. The implementation of the
* {@code /api/auth/token/create} uses the value of the {@code
* refreshToken} request parameter instead of generating a new value
* when the request parameter holds a non-null value.
*
*
*
* Note that if the hash value of the specified refresh token already
* exists in Authlete's database, the refresh token cannot be inserted
* and the {@code /api/auth/token/create} API will report an error.
*
*
*
* accessTokenPersistent
(OPTIONAL)
* -
*
* A boolean request parameter which indicates whether the access token
* expires or not. By default, all access tokens expire after a period of
* time determined by their service. If this request parameter is {@code true}
* then the access token will not automatically expire and must be revoked
* or deleted manually at the service.
*
*
*
* If this request parameter is {@code true}, the {@code accessTokenDuration}
* request parameter is ignored.
*
*
*
* certificateThumbprint
(OPTIONAL)
* -
*
* The thumbprint of the MTLS certificate bound to this token. If this field
* is set, a certificate with the corresponding value MUST be presented with the
* access token when it is used by a client.
*
*
*
* dpopKeyThumbprint
(OPTIONAL)
* -
*
* The thumbprint of the public key used for DPoP presentation of this token.
* If this field is set, a DPoP proof signed with the corresponding private key
* MUST be presented with the access token when it is used by a client. Additionally,
* the token's {@code token_type} will be set to 'DPoP'.
*
*
*
* authorizationDetails
(OPTIONAL)
* -
*
* The value of the {@code authorization_details} to associate with the token.
* Can be {@code null}.
*
*
*
* resources
(OPTIONAL)
* -
*
* The value of the {@code resource}s to associate with the token.
* Can be {@code null}.
*
*
*
* forExternalAttachment
(OPTIONAL)
* -
*
* A boolean flag which indicates whether the access token is for an external
* attachment. See External Attachments of OpenID Connect for Identity Assurance 1.0 for details about external
* attachments.
*
*
*
*
*
*
* @see TokenCreateResponse
*
* @since 1.13
*/
public class TokenCreateRequest implements Serializable
{
private static final long serialVersionUID = 13L;
private GrantType grantType;
private long clientId;
private String subject;
private String[] scopes;
private long accessTokenDuration;
private long refreshTokenDuration;
private Property[] properties;
private boolean clientIdAliasUsed;
private boolean clientEntityIdUsed;
private String accessToken;
private String refreshToken;
private boolean accessTokenPersistent;
private String certificateThumbprint;
private String dpopKeyThumbprint;
private AuthzDetails authorizationDetails;
private URI[] resources;
private boolean forExternalAttachment;
private String jwtAtClaims;
private String acr;
private long authTime;
/**
* Get the grant type for a newly created access token.
*
* @return
* Grant type.
*/
public GrantType getGrantType()
{
return grantType;
}
/**
* Set the grant type for a newly created access token.
*
* @param grantType
* Grant type.
*
* @return
* {@code this} object.
*/
public TokenCreateRequest setGrantType(GrantType grantType)
{
this.grantType = grantType;
return this;
}
/**
* Get the client ID that will be associated with a newly created
* access token.
*
* @return
* Client ID.
*/
public long getClientId()
{
return clientId;
}
/**
* Set the client ID that will be associated with a newly created
* access token.
*
* @param clientId
* Client ID.
*
* @return
* {@code this} object.
*/
public TokenCreateRequest setClientId(long clientId)
{
this.clientId = clientId;
return this;
}
/**
* Get the subject (= unique identifier) of the user who will be
* associated with a newly created access token.
*
* @return
* The subject of the user.
*/
public String getSubject()
{
return subject;
}
/**
* Set the subject (= unique identifier) of the user who will be
* associated with a newly created access token.
*
* @param subject
* The subject of the user.
*
* @return
* {@code this} object.
*/
public TokenCreateRequest setSubject(String subject)
{
this.subject = subject;
return this;
}
/**
* Get the scopes that will be associated with a newly created
* access token.
*
* @return
* Scopes.
*/
public String[] getScopes()
{
return scopes;
}
/**
* Set the scopes that will be associated with a newly created
* access token.
*
* @param scopes
* Scopes.
*
* @return
* {@code this} object.
*/
public TokenCreateRequest setScopes(String[] scopes)
{
this.scopes = scopes;
return this;
}
/**
* Get the duration of a newly created access token in seconds.
* 0 means that the duration will be determined according to the
* settings of the service.
*
* @return
* The duration of a newly created access token.
*/
public long getAccessTokenDuration()
{
return accessTokenDuration;
}
/**
* Set the duration of a newly created access token in seconds.
* 0 means that the duration will be determined according to the
* settings of the service.
*
* @param accessTokenDuration
* The duration of a newly created access token.
*
* @return
* {@code this} object.
*/
public TokenCreateRequest setAccessTokenDuration(long accessTokenDuration)
{
this.accessTokenDuration = accessTokenDuration;
return this;
}
/**
* Get the duration of a newly created refresh token in seconds.
* 0 means that the duration will be determined according to the
* settings of the service.
*
* @return
* The duration of a newly created refresh token.
*/
public long getRefreshTokenDuration()
{
return refreshTokenDuration;
}
/**
* Set the duration of a newly created refresh token in seconds.
* 0 means that the duration will be determined according to the
* settings of the service.
*
* @param refreshTokenDuration
* The duration of a newly created refresh token.
*
* @return
* {@code this} object.
*/
public TokenCreateRequest setRefreshTokenDuration(long refreshTokenDuration)
{
this.refreshTokenDuration = refreshTokenDuration;
return this;
}
/**
* Get the extra properties to associate with an access token which
* will be issued by this request.
*
* @return
* Extra properties.
*
* @since 1.30
*/
public Property[] getProperties()
{
return properties;
}
/**
* Set extra properties to associate with an access token which will
* be issued by this request.
*
*
* Keys of extra properties will be used as labels of top-level
* entries in a JSON response containing an access token which is
* returned from an authorization server. An example is
* {@code example_parameter}, which you can find in 5.1. Successful
* Response in RFC 6749. The following code snippet is an example
* to set one extra property having {@code example_parameter} as its
* key and {@code example_value} as its value.
*
*
*
*
* {@link Property}[] properties = { new {@link Property#Property(String, String)
* Property}("example_parameter", "example_value") };
* request.{@link #setProperties(Property[]) setProperties}(properties);
*
*
*
*
* Keys listed below should not be used and they would be ignored on
* the server side even if they were used. It's because they are reserved
* in RFC 6749 and
* OpenID Connect Core 1.0.
*
*
*
* - {@code access_token}
*
- {@code token_type}
*
- {@code expires_in}
*
- {@code refresh_token}
*
- {@code scope}
*
- {@code error}
*
- {@code error_description}
*
- {@code error_uri}
*
- {@code id_token}
*
*
*
* Note that there is an upper limit on the total size of extra properties.
* On the server side, the properties will be (1) converted to a multidimensional
* string array, (2) converted to JSON, (3) encrypted by AES/CBC/PKCS5Padding, (4)
* encoded by base64url, and then stored into the database. The length of the
* resultant string must not exceed 65,535 in bytes. This is the upper limit, but
* we think it is big enough.
*
*
* @param properties
* Extra properties.
*
* @return
* {@code this} object.
*
* @since 1.30
*/
public TokenCreateRequest setProperties(Property[] properties)
{
this.properties = properties;
return this;
}
/**
* Get the flag which indicates whether to emulate that the client ID alias is used
* instead of the original numeric client ID when a new access token is created.
*
*
* This has an effect only on the value of the {@code aud} claim in a response from
* UserInfo
* endpoint. When you access the UserInfo endpoint (which is expected to be
* implemented using Authlete's {@code /api/auth/userinfo} API and {@code
* /api/auth/userinfo/issue} API) with an access token which has been created using
* Authlete's {@code /api/auth/token/create} API with this property ({@code
* clientIdAliasUsed}) true, the client ID alias is used as the value of the {@code
* aud} claim in a response from the UserInfo endpoint.
*
*
*
* Note that if a client ID alias is not assigned to the client when Authlete's
* {@code /api/auth/token/create} API is called, this property ({@code
* clientIdAliasUsed}) has no effect (it is always regarded as {@code false}).
*
*
*
* Note that {@code clientIdAliasUsed} and {@code clientEntityIdUsed} are
* mutually exclusive.
*
*
* @return
* {@code true} to emulate that the client ID alias is used when a new
* access token is created.
*
* @since 2.3
*/
public boolean isClientIdAliasUsed()
{
return clientIdAliasUsed;
}
/**
* Set the flag which indicates whether to emulate that the client ID alias is used
* instead of the original numeric client ID when a new access token is created.
*
*
* This has an effect only on the value of the {@code aud} claim in a response from
* UserInfo
* endpoint. When you access the UserInfo endpoint (which is expected to be
* implemented using Authlete's {@code /api/auth/userinfo} API and {@code
* /api/auth/userinfo/issue} API) with an access token which has been created using
* Authlete's {@code /api/auth/token/create} API with this property ({@code
* clientIdAliasUsed}) true, the client ID alias is used as the value of the {@code
* aud} claim in a response from the UserInfo endpoint.
*
*
*
* Note that if a client ID alias is not assigned to the client when Authlete's
* {@code /api/auth/token/create} API is called, this property ({@code
* clientIdAliasUsed}) has no effect (it is always regarded as {@code false}).
*
*
*
* Note that {@code clientIdAliasUsed} and {@code clientEntityIdUsed} are
* mutually exclusive.
*
*
* @param used
* {@code true} to emulate that the client ID alias is used when a new
* access token is created.
*
* @return
* {@code this} object.
*
* @since 2.3
*/
public TokenCreateRequest setClientIdAliasUsed(boolean used)
{
this.clientIdAliasUsed = used;
return this;
}
/**
* Get the flag which indicates whether to emulate that the entity ID is
* used as a client ID when a new access token is created.
*
*
* This has an effect only on the value of the {@code aud} claim in a
* response from UserInfo endpoint. When you access the UserInfo endpoint (which is
* expected to be implemented using Authlete's {@code /auth/userinfo} API
* and {@code /auth/userinfo/issue} API) with an access token which has
* been created using Authlete's {@code /auth/token/create} API with this
* property ({@code clientEntityIdUsed}) true, the entity ID of the client
* is used as the value of the {@code aud} claim in a response from the
* UserInfo endpoint.
*
*
*
* Note that if an entity ID is not assigned to the client when Authlete's
* {@code /auth/token/create} API is called, this property
* ({@code clientEntityIdUsed}) has no effect (it is always regarded as
* {@code false}).
*
*
*
* Note that {@code clientIdAliasUsed} and {@code clientEntityIdUsed} are
* mutually exclusive.
*
*
* @return
* {@code true} to emulate that the entity ID is used when a new
* access token is created.
*
* @since 3.37
* @since Authlete 2.3
*/
public boolean isClientEntityIdUsed()
{
return clientEntityIdUsed;
}
/**
* Set the flag which indicates whether to emulate that the entity ID is
* used as a client ID when a new access token is created.
*
*
* This has an effect only on the value of the {@code aud} claim in a
* response from UserInfo endpoint. When you access the UserInfo endpoint (which is
* expected to be implemented using Authlete's {@code /auth/userinfo} API
* and {@code /auth/userinfo/issue} API) with an access token which has
* been created using Authlete's {@code /auth/token/create} API with this
* property ({@code clientEntityIdUsed}) true, the entity ID of the client
* is used as the value of the {@code aud} claim in a response from the
* UserInfo endpoint.
*
*
*
* Note that if an entity ID is not assigned to the client when Authlete's
* {@code /auth/token/create} API is called, this property
* ({@code clientEntityIdUsed}) has no effect (it is always regarded as
* {@code false}).
*
*
*
* Note that {@code clientIdAliasUsed} and {@code clientEntityIdUsed} are
* mutually exclusive.
*
*
* @param used
* {@code true} to emulate that the entity ID is used when a new
* access token is created.
*
* @return
* {@code this} object.
*
* @since 3.37
* @since Authlete 2.3
*/
public TokenCreateRequest setClientEntityIdUsed(boolean used)
{
this.clientEntityIdUsed = used;
return this;
}
/**
* Get the access token.
*
*
* When this method returns a non-null value, the implementation of
* {@code /api/auth/token/create} uses the value instead of generating
* a new one. See the description of {@link #setAccessToken(String)}
* for details.
*
*
* @return
* The value of the access token. In normal cases, {@code null}
* is returned.
*
* @see #setAccessToken(String)
*
* @since 2.6
*/
public String getAccessToken()
{
return accessToken;
}
/**
* Set the access token.
*
*
* The {@code /api/auth/token/create} API generates an access token.
* Therefore, callers of the API do not have to specify values of
* newly created access tokens. However, in some cases, for example,
* if you want to migrate existing access tokens from an old system
* to Authlete, you may want to specify values of access tokens.
* In such a case, you can specify the value of a newly created
* access token by passing a non-null value as the value of
* {@code accessToken} request parameter. The implementation of the
* {@code /api/auth/token/create} uses the value of the {@code
* accessToken} request parameter instead of generating a new value
* when the request parameter holds a non-null value.
*
*
*
* Note that if the hash value of the specified access token already
* exists in Authlete's database, the access token cannot be inserted
* and the {@code /api/auth/token/create} API will report an error.
*
*
* @param accessToken
* The value of the access token. If a non-null value is
* specified, the implementation of {@code /api/auth/token/create}
* API will use the value instead of generating a new one.
*
* Because Authlete does not store the value of the access
* token into its database (Authlete stores the hash value
* of the access token only), any value is accepted as the
* value of this {@code accessToken} request parameter.
*
* @return
* {@code this} object.
*
* @since 2.6
*/
public TokenCreateRequest setAccessToken(String accessToken)
{
this.accessToken = accessToken;
return this;
}
/**
* Get the refresh token.
*
*
* When this method returns a non-null value, the implementation of
* {@code /api/auth/token/create} uses the value instead of generating
* a new one. See the description of {@link #setRefreshToken(String)}
* for details.
*
*
* @return
* The value of the refresh token. In normal cases, {@code null}
* is returned.
*
* @see #setRefreshToken(String)
*
* @since 2.6
*/
public String getRefreshToken()
{
return refreshToken;
}
/**
* Set the refresh token.
*
*
* The {@code /api/auth/token/create} API may generate a refresh token.
* Therefore, callers of the API do not have to specify values of
* newly created refresh tokens. However, in some cases, for example,
* if you want to migrate existing refresh tokens from an old system
* to Authlete, you may want to specify values of refresh tokens.
* In such a case, you can specify the value of a newly created
* refresh token by passing a non-null value as the value of
* {@code refreshToken} request parameter. The implementation of the
* {@code /api/auth/token/create} uses the value of the {@code
* refreshToken} request parameter instead of generating a new value
* when the request parameter holds a non-null value.
*
*
*
* Note that if the hash value of the specified refresh token already
* exists in Authlete's database, the refresh token cannot be inserted
* and the {@code /api/auth/token/create} API will report an error.
*
*
* @param refreshToken
* The value of the refresh token. If a non-null value is
* specified, the implementation of {@code /api/auth/token/create}
* API will use the value instead of generating a new one.
*
* Because Authlete does not store the value of the refresh
* token into its database (Authlete stores the hash value
* of the refresh token only), any value is accepted as the
* value of this {@code refreshToken} request parameter.
*
* @return
* {@code this} object.
*
* @since 2.6
*/
public TokenCreateRequest setRefreshToken(String refreshToken)
{
this.refreshToken = refreshToken;
return this;
}
/**
* Get whether the access token expires or not. By default, all access tokens
* expire after a period of time determined by their service. If this request
* parameter is {@code true} then the access token will not automatically
* expire and must be revoked or deleted manually at the service.
*
*
* If this request parameter is {@code true}, the {@code accessTokenDuration}
* request parameter is ignored.
*
*
* @return
* {@code false} if the access token expires (default).
* {@code true} if the access token does not expire.
*
* @since 2.30
*/
public boolean isAccessTokenPersistent()
{
return accessTokenPersistent;
}
/**
* Set whether the access token expires or not. By default, all access tokens
* expire after a period of time determined by their service. If this request
* parameter is {@code true} then the access token will not automatically
* expire and must be revoked or deleted manually at the service.
*
*
* If this request parameter is {@code true}, the {@code accessTokenDuration}
* request parameter is ignored.
*
*
* @param persistent
* {@code false} to make the access token expire (default).
* {@code true} to make the access token be persistent.
*
* @return
* {@code this} object.
*
* @since 2.30
*/
public TokenCreateRequest setAccessTokenPersistent(boolean persistent)
{
this.accessTokenPersistent = persistent;
return this;
}
/**
* Get the thumbprint of the MTLS certificate bound to this token. If this field
* is set, a certificate with the corresponding value MUST be presented with the
* access token when it is used by a client.
*
* @return
* The SHA256 certificate thumbprint, base64url encoded.
*
* @since 2.72
*/
public String getCertificateThumbprint()
{
return certificateThumbprint;
}
/**
* Set the thumbprint of the MTLS certificate bound to this token. If this field
* is set, a certificate with the corresponding value MUST be presented with the
* access token when it is used by a client.
*
* @param certificateThumbprint
* The SHA256 certificate thumbprint, base64url encoded.
*
* @return
* {@code this} object.
*
* @since 2.72
*/
public TokenCreateRequest setCertificateThumbprint(String certificateThumbprint)
{
this.certificateThumbprint = certificateThumbprint;
return this;
}
/**
* Get the thumbprint of the public key used for DPoP presentation of this token.
* If this field is set, a DPoP proof signed with the corresponding private key
* MUST be presented with the access token when it is used by a client. Additionally,
* the token's {@code token_type} will be set to 'DPoP'.
*
* @return
* The JWK public key thumbprint.
*
* @since 2.72
*/
public String getDpopKeyThumbprint()
{
return dpopKeyThumbprint;
}
/**
* Set the thumbprint of the public key used for DPoP presentation of this token.
* If this field is set, a DPoP proof signed with the corresponding private key
* MUST be presented with the access token when it is used by a client. Additionally,
* the token's {@code token_type} will be set to 'DPoP'.
*
* @param dpopKeyThumbprint
* The JWK public key thumbprint.
*
* @return
* {@code this} object.
*
* @since 2.72
*/
public TokenCreateRequest setDpopKeyThumbprint(String dpopKeyThumbprint)
{
this.dpopKeyThumbprint = dpopKeyThumbprint;
return this;
}
/**
* Get the authorization details. This represents the value of the
* {@code "authorization_details"} request parameter which is defined in
* "OAuth 2.0 Rich Authorization Requests".
*
* @return
* Authorization details.
*
* @since 2.99
*/
public AuthzDetails getAuthorizationDetails()
{
return authorizationDetails;
}
/**
* Set the authorization details. This represents the value of the
* {@code "authorization_details"} request parameter which is defined in
* "OAuth 2.0 Rich Authorization Requests".
*
* @param authorizationDetails
* Authorization details.
*
* @return
* {@code this} object.
*
* @since 2.99
*/
public TokenCreateRequest setAuthorizationDetails(AuthzDetails authorizationDetails)
{
this.authorizationDetails = authorizationDetails;
return this;
}
/**
* Get the resources. This represents the value of one or more
* {@code "resource"} request parameters which is defined in
* "RFC8707 Resource Indicators for OAuth 2.0".
*
* @return
* Array of resource URIs.
*
* @since 2.99
*/
public URI[] getResources()
{
return resources;
}
/**
* Get the resources. This represents the value of one or more
* {@code "resource"} request parameters which is defined in
* "RFC8707 Resource Indicators for OAuth 2.0".
*
* @param resources
* Array of resource URIs.
*
* @return
* {@code this} object.
*
* @since 2.99
*/
public TokenCreateRequest setResources(URI[] resources)
{
this.resources = resources;
return this;
}
/**
* Get the flag which indicates whether the access token is for an external
* attachment.
*
* @return
* {@code true} if the access token is for an external attachment.
*
* @since 3.16
*
* @see OpenID Connect for Identity Assurance 1.0, External Attachments
*/
public boolean isForExternalAttachment()
{
return forExternalAttachment;
}
/**
* Set the flag which indicates whether the access token is for an external
* attachment.
*
* @param forExternalAttachment
* {@code true} to indicate that the access token is for an
* external attachment.
*
* @return
* {@code this} object.
*
* @since 3.16
*
* @see OpenID Connect for Identity Assurance 1.0, External Attachments
*/
public TokenCreateRequest setForExternalAttachment(boolean forExternalAttachment)
{
this.forExternalAttachment = forExternalAttachment;
return this;
}
/**
* Get the additional claims in JSON object format that are added to the
* payload part of the JWT access token.
*
*
* This request parameter has a meaning only when the format of access
* tokens issued by this service is JWT. In other words, it has a meaning
* only when the {@code accessTokenSignAlg} property of the {@link Service}
* holds a non-null value. See the description of the {@link
* Service#getAccessTokenSignAlg() getAccessTokenSignAlg()} method for
* details.
*
*
* @return
* Additional claims that are added to the payload part of the JWT
* access token.
*
* @since 3.23
*/
public String getJwtAtClaims()
{
return jwtAtClaims;
}
/**
* Set the additional claims in JSON object format that are added to the
* payload part of the JWT access token.
*
*
* This request parameter has a meaning only when the format of access
* tokens issued by this service is JWT. In other words, it has a meaning
* only when the {@code accessTokenSignAlg} property of the {@link Service}
* holds a non-null value. See the description of the {@link
* Service#getAccessTokenSignAlg() getAccessTokenSignAlg()} method for
* details.
*
*
* @param claims
* Additional claims that are added to the payload part of the JWT
* access token.
*
* @return
* {@code this} object.
*
* @since 3.23
*/
public TokenCreateRequest setJwtAtClaims(String claims)
{
this.jwtAtClaims = claims;
return this;
}
/**
* Get the Authentication Context Class Reference of the user authentication
* that the authorization server performed during the course of issuing the
* access token.
*
*
* Note that this parameter is ignored in cases where the {@code subject}
* parameter is missing or ignored.
*
*
* @return
* The Authentication Context Class Reference.
*
* @since 3.40
* @since Authlete 2.3
*
* @see RFC 9470 OAuth 2.0 Step Up Authentication Challenge Protocol
*/
public String getAcr()
{
return acr;
}
/**
* Set the Authentication Context Class Reference of the user authentication
* that the authorization server performed during the course of issuing the
* access token.
*
*
* Note that this parameter is ignored in cases where the {@code subject}
* parameter is missing or ignored.
*
*
* @param acr
* The Authentication Context Class Reference.
*
* @return
* {@code this} object.
*
* @since 3.40
* @since Authlete 2.3
*
* @see RFC 9470 OAuth 2.0 Step Up Authentication Challenge Protocol
*/
public TokenCreateRequest setAcr(String acr)
{
this.acr = acr;
return this;
}
/**
* Get the time when the user authentication was performed during the course
* of issuing the access token.
*
*
* Note that this parameter is ignored in cases where the {@code subject}
* parameter is missing or ignored.
*
*
* @return
* The time of the user authentication in seconds since the Unix epoch.
*
* @since 3.40
* @since Authlete 2.3
*
* @see RFC 9470 OAuth 2.0 Step Up Authentication Challenge Protocol
*/
public long getAuthTime()
{
return authTime;
}
/**
* Set the time when the user authentication was performed during the course
* of issuing the access token.
*
*
* Note that this parameter is ignored in cases where the {@code subject}
* parameter is missing or ignored.
*
*
* @param authTime
* The time of the user authentication in seconds since the Unix epoch.
* Must not be negative.
*
* @return
* {@code this} object.
*
* @since 3.40
* @since Authlete 2.3
*
* @see RFC 9470 OAuth 2.0 Step Up Authentication Challenge Protocol
*/
public TokenCreateRequest setAuthTime(long authTime)
{
this.authTime = authTime;
return this;
}
}