All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.authlete.common.dto.DeviceVerificationResponse Maven / Gradle / Ivy

Go to download

Authlete Java library used commonly by service implementations and the Authlete server.

There is a newer version: 4.16
Show newest version
/*
 * Copyright (C) 2019-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
 *
 * http://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.net.URI;
import com.authlete.common.types.GMAction;


/**
 * Response from Authlete's {@code /api/device/verification} API.
 *
 * 

* Authlete's {@code /api/device/verification} API returns JSON which can * be mapped to this class. The authorization server implementation should * retrieve the value of {@code action} from the response and take the * following steps according to the value. *

* *
*
{@link Action#VALID VALID}
*
*

* When the value of {@code action} is {@code VALID}, it means that the user * code exists, has not expired, and belongs to the service. The authorization * server implementation should interact with the end-user to ask whether she * approves or rejects the authorization request from the device. *

*
* *
{@link Action#EXPIRED EXPIRED}
*
*

* When the value of {@code action} is {@code EXPIRED}, it means that the user * code has expired. The authorization server implementation should tell the * end-user that the user code has expired and urge her to re-initiate a device * flow. *

*
* *
{@link Action#NOT_EXIST NOT_EXIST}
*
*

* When the value of {@code action} is {@code NOT_EXIST}, it means that the * user code does not exist. The authorization server implementation should * tell the end-user that the user code is invalid and urge her to retry to * input a valid user code. *

*
* *
{@link Action#SERVER_ERROR SERVER_ERROR}
*
*

* When the value of {@code action} is {@code SERVER_ERROR}, it means that an * error occurred on Authlete side. The authorization server implementation * should tell the end-user that something wrong happened and urge her to * re-initiate a device flow. *

*
*
* * @since 2.42 */ public class DeviceVerificationResponse extends ApiResponse { private static final long serialVersionUID = 9L; /** * The next action that the authorization server implementation should take. */ public enum Action { /** * The user code is valid. This means that the user code exists, has * not expired, and belongs to the service. The authorization server * implementation should interact with the end-user to ask whether she * approves or rejects the authorization request from the device. */ VALID, /** * The user code has expired. The authorization server implementation * should tell the end-user that the user code has expired and urge her * to re-initiate a device flow. */ EXPIRED, /** * The user code does not exist. The authorization server implementation * should tell the end-user that the user code is invalid and urge her * to retry to input a valid user code. */ NOT_EXIST, /** * An error occurred on Authlete side. The authorization server * implementation should tell the end-user that something wrong happened * and urge her to re-initiate a device flow. */ SERVER_ERROR, } /** * @since Authlete 2.0.0 */ private Action action; /** * @since Authlete 2.0.0 */ private long clientId; /** * @since Authlete 2.0.0 */ private String clientIdAlias; /** * @since Authlete 2.0.0 */ private boolean clientIdAliasUsed; /** * @since Authlete 2.3.0 */ private URI clientEntityId; /** * @since Authlete 2.3.0 */ private boolean clientEntityIdUsed; /** * @since Authlete 2.0.0 */ private String clientName; /** * @since Authlete 2.0.0 */ private Scope[] scopes; /** * @since Authlete 2.2.0 */ private DynamicScope[] dynamicScopes; /** * @since Authlete 2.0.0 */ private String[] claimNames; /** * @since Authlete 2.0.0 */ private String[] acrs; /** * @since Authlete 2.0.0 */ private long expiresAt; /** * @since Authlete 2.2.1 */ private URI[] resources; /** * @since Authlete 2.2.0 */ private AuthzDetails authorizationDetails; /** * @since Authlete 2.3.0 */ private GMAction gmAction; /** * @since Authlete 2.3.0 */ private String grantId; /** * @since Authlete 2.3.0 */ private String grantSubject; /** * @since Authlete 2.3.0 */ private Grant grant; /** * @since Authlete 2.2.3 */ private Pair[] serviceAttributes; /** * @since Authlete 2.2.3 */ private Pair[] clientAttributes; /** * Get the next action that the authorization server should take. * * @return * The next action. */ public Action getAction() { return action; } /** * Set the next action that the authorization server should take. * * @param action * The next action. * * @return * {@code this} object. */ public DeviceVerificationResponse setAction(Action action) { this.action = action; return this; } /** * Get the client ID of the client application to which the user code has * been issued. * * @return * The client ID of the client application. */ public long getClientId() { return clientId; } /** * Set the client ID of the client application to which the user code has * been issued. * * @param clientId * The client ID of the client application. * * @return * {@code this} object. */ public DeviceVerificationResponse setClientId(long clientId) { this.clientId = clientId; return this; } /** * Get the client ID alias of the client application to which the user code * has been issued. * * @return * The client ID alias of the client application. */ public String getClientIdAlias() { return clientIdAlias; } /** * Set the client ID alias of the client application to which the user code * has been issued. * * @param alias * The client ID alias of the client application. * * @return * {@code this} object. */ public DeviceVerificationResponse setClientIdAlias(String alias) { this.clientIdAlias = alias; return this; } /** * Get the flag which indicates whether the client ID alias was used in * the device authorization request for the user code. * * @return * {@code true} if the client ID alias was used in the request. */ public boolean isClientIdAliasUsed() { return clientIdAliasUsed; } /** * Set the flag which indicates whether the client ID alias was used in * the device authorization request for the user code. * * @param used * {@code true} to indicate that the client ID alias was used in * the request. * * @return * {@code this} object. */ public DeviceVerificationResponse setClientIdAliasUsed(boolean used) { this.clientIdAliasUsed = used; return this; } /** * Get the entity ID of the client. * *

* "Entity ID" is a technical term defined in OpenID * Federation 1.0. *

* * @return * The entity ID of the client. * * @since 3.37 * @since Authlete 2.3 * * @see OpenID Federation 1.0 */ public URI getClientEntityId() { return clientEntityId; } /** * Set the entity ID of the client. * *

* "Entity ID" is a technical term defined in OpenID * Federation 1.0. *

* * @param entityId * The entity ID of the client. * * @return * {@code this} object. * * @since 3.37 * @since Authlete 2.3 * * @see OpenID Federation 1.0 */ public DeviceVerificationResponse setClientEntityId(URI entityId) { this.clientEntityId = entityId; return this; } /** * Get the flag which indicates whether the entity ID of the client was * used in the device authorization request as a client ID. * *

* "Entity ID" is a technical term defined in OpenID * Federation 1.0. *

* * @return * {@code true} if the entity ID of the client was used in the * request as a client ID. * * @since 3.37 * @since Authlete 2.3 * * @see OpenID Federation 1.0 */ public boolean isClientEntityIdUsed() { return clientEntityIdUsed; } /** * Set the flag which indicates whether the entity ID of the client was * used in the device authorization request as a client ID. * *

* "Entity ID" is a technical term defined in OpenID * Federation 1.0. *

* * @param used * {@code true} to indicate that the entity ID of the client was * used in the request as a client ID. * * @return * {@code this} object. * * @since 3.37 * @since Authlete 2.3 * * @see OpenID Federation 1.0 */ public DeviceVerificationResponse setClientEntityIdUsed(boolean used) { this.clientEntityIdUsed = used; return this; } /** * Get the client identifier used in the device authorization request for * the user code. * *

* When {@link #isClientIdAliasUsed()} returns {@code true}, this method * returns the same value as {@link #getClientIdAlias()} does. Otherwise, * if {@link #isClientEntityIdUsed()} returns {@code true}, this method * returns the same value as {@link #getClientEntityId()}{@code .toString()} * does. In other cases, this method returns the string representation of * the value returned from {@link #getClientId()}. *

* * @return * The client identifier used in the device authorization request * for the user code. */ public String getClientIdentifier() { if (clientIdAliasUsed) { return clientIdAlias; } else if (clientEntityIdUsed) { return clientEntityId.toString(); } else { return String.valueOf(clientId); } } /** * Get the name of the client application to which the user code has been * issued. * * @return * The name of the client application. */ public String getClientName() { return clientName; } /** * Set the name of the client application to which the user code has been * issued. * * @param name * The name of the client application. * * @return * {@code this} object. */ public DeviceVerificationResponse setClientName(String name) { this.clientName = name; return this; } /** * Get the scopes requested by the device authorization request for the * user code. * *

* Note that {@link Scope#getDescription()} method and * {@link Scope#getDescriptions()} method of each element ({@link Scope} * instance) in the array returned from this method always return * {@code null} even if descriptions of the scopes are registered. *

* * @return * The requested scopes. */ public Scope[] getScopes() { return scopes; } /** * Set the scopes requested by the device authorization request for the * user code. * * @param scopes * The requested scopes. * * @return * {@code this} object. */ public DeviceVerificationResponse setScopes(Scope[] scopes) { this.scopes = scopes; return this; } /** * Get the dynamic scopes which the client application requested * by the {@code scope} request parameter. See the description of * {@link DynamicScope} for details. * * @return * The list of dynamic scopes. * * @since 2.92 * * @see DynamicScope */ public DynamicScope[] getDynamicScopes() { return dynamicScopes; } /** * Set the dynamic scopes which the client application requested * by the {@code scope} request parameter. See the description of * {@link DynamicScope} for details. * * @param dynamicScopes * The list of dynamic scopes. * * @return * {@code this} object. * * @since 2.92 * * @see DynamicScope */ public DeviceVerificationResponse setDynamicScopes(DynamicScope[] dynamicScopes) { this.dynamicScopes = dynamicScopes; return this; } /** * Get the names of the claims which were requested indirectly via some * special scopes. See 5.4. Requesting Claims using Scope Values in OpenID Connect * Core 1.0 for details. * *

* This method always returns {@code null} if the {@code scope} request * parameter of the device authorization request does not include the * {@code openid} scope even if special scopes (such as {@code profile}) * are included in the request (unless the {@code openid} scope is included * in the default set of scopes which is used when the {@code scope} * request parameter is omitted). *

* * @return * The names of the requested claims. * * @since 2.44 */ public String[] getClaimNames() { return claimNames; } /** * Set the names of the claims which were requested indirectly via some * special scopes. * * @param names * The names of the requested claims. * * @return * {@code this} object. * * @since 2.44 */ public DeviceVerificationResponse setClaimNames(String[] names) { this.claimNames = names; return this; } /** * Get the list of ACR values requested by the device authorization * request. * * @return * The list of requested ACR values. * * @since 2.44 */ public String[] getAcrs() { return acrs; } /** * Set the list of ACR values requested by the device authorization * request. * * @param acrs * The list of requested ACR values. * * @return * {@code this} object. * * @since 2.44 */ public DeviceVerificationResponse setAcrs(String[] acrs) { this.acrs = acrs; return this; } /** * Get the date in milliseconds since the Unix epoch (1970-01-01) * at which the user code will expire. * * @return * The expiration date in milliseconds since the Unix epoch * (1970-01-01) at which the user code will expire. * * @since 2.44 */ public long getExpiresAt() { return expiresAt; } /** * Set the date in milliseconds since the Unix epoch (1970-01-01) * at which the user code will expire. * * @param expiresAt * The expiration date in milliseconds since the Unix epoch * (1970-01-01) at which the user code will expire. * * @return * {@code this} object. * * @since 2.44 */ public DeviceVerificationResponse setExpiresAt(long expiresAt) { this.expiresAt = expiresAt; return this; } /** * Get the resources specified by the {@code resource} request parameters * in the preceding device authorization request. * See "Resource Indicators for OAuth 2.0" for details. * * @return * Target resources. * * @since 2.62 */ public URI[] getResources() { return resources; } /** * Set the resources specified by the {@code resource} request parameters * in the preceding device authorization request. * See "Resource Indicators for OAuth 2.0" for details. * * @param resources * Target resources. * * @return * {@code this} object. * * @since 2.62 */ public DeviceVerificationResponse setResources(URI[] resources) { this.resources = resources; 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.56 */ 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 details * Authorization details. * * @return * {@code this} object. * * @since 2.56 */ public DeviceVerificationResponse setAuthorizationDetails(AuthzDetails details) { this.authorizationDetails = details; return this; } /** * Get the value of the {@code grant_management_action} request parameter * of the device authorization request. * *

* The {@code grant_management_action} request parameter is defined in * Grant * Management for OAuth 2.0, which is supported by Authlete 2.3 and * newer versions. *

* * @return * A grant management action. {@code null} or one of * {@link GMAction#CREATE CREATE}, {@link GMAction#REPLACE REPLACE} * and {@link GMAction#MERGE MERGE}. * * @see Grant Management for OAuth 2.0 * * @since 3.6 */ public GMAction getGmAction() { return gmAction; } /** * Set the value of the {@code grant_management_action} request parameter * of the device authorization request. * *

* The {@code grant_management_action} request parameter is defined in * Grant * Management for OAuth 2.0, which is supported by Authlete 2.3 and * newer versions. *

* * @param action * A grant management action. {@code null} or one of * {@link GMAction#CREATE CREATE}, {@link GMAction#REPLACE REPLACE} * and {@link GMAction#MERGE MERGE}. * * @return * {@code this} object. * * @see Grant Management for OAuth 2.0 * * @since 3.6 */ public DeviceVerificationResponse setGmAction(GMAction action) { this.gmAction = action; return this; } /** * Get the value of the {@code grant_id} request parameter of the device * authorization request. * *

* The {@code grant_id} request parameter is defined in * Grant * Management for OAuth 2.0, which is supported by Authlete 2.3 and * newer versions. *

* * @return * A grant ID. * * @see Grant Management for OAuth 2.0 * * @since 3.6 */ public String getGrantId() { return grantId; } /** * Set the value of the {@code grant_id} request parameter of the device * authorization request. * *

* The {@code grant_id} request parameter is defined in * Grant * Management for OAuth 2.0, which is supported by Authlete 2.3 and * newer versions. *

* * @param grantId * A grant ID. * * @see Grant Management for OAuth 2.0 * * @return * {@code this} object. * * @since 3.6 */ public DeviceVerificationResponse setGrantId(String grantId) { this.grantId = grantId; return this; } /** * Get the subject of the user who has given the grant which is identified * by the {@code grant_id} request parameter of the device authorization * request. * *

* Authlete 2.3 and newer versions support Grant Management * for OAuth 2.0. An authorization request may contain a {@code grant_id} * request parameter which is defined in the specification. If the value of * the request parameter is valid, {@link #getGrantSubject()} will return * the subject of the user who has given the grant to the client application. * Authorization server implementations may use the value returned from * {@link #getGrantSubject()} in order to determine the user to authenticate. *

* *

* The user your system will authenticate during the authorization process * (or has already authenticated) may be different from the user of the * grant. The first implementer's draft of "Grant Management for OAuth 2.0" * does not mention anything about the case, so the behavior in the case is * left to implementations. Authlete will not perform the grant management * action when the {@code subject} passed to Authlete does not match the * user of the grant. *

* * @return * The subject of the user who has given the grant. * * @see Grant Management for OAuth 2.0 * * @since 3.6 */ public String getGrantSubject() { return grantSubject; } /** * Set the subject of the user who has given the grant which is identified * by the {@code grant_id} request parameter of the device authorization * request. * *

* Authlete 2.3 and newer versions support Grant Management * for OAuth 2.0. An authorization request may contain a {@code grant_id} * request parameter which is defined in the specification. If the value of * the request parameter is valid, {@link #getGrantSubject()} will return * the subject of the user who has given the grant to the client application. * Authorization server implementations may use the value returned from * {@link #getGrantSubject()} in order to determine the user to authenticate. *

* *

* The user your system will authenticate during the authorization process * (or has already authenticated) may be different from the user of the * grant. The first implementer's draft of "Grant Management for OAuth 2.0" * does not mention anything about the case, so the behavior in the case is * left to implementations. Authlete will not perform the grant management * action when the {@code subject} passed to Authlete does not match the * user of the grant. *

* * @param subject * The subject of the user who has given the grant. * * @return * {@code this} object. * * @see Grant Management for OAuth 2.0 * * @since 3.6 */ public DeviceVerificationResponse setGrantSubject(String subject) { this.grantSubject = subject; return this; } /** * Get the content of the grant which is identified by the {@code grant_id} * request parameter of the device authorization request. * *

* The user your system will authenticate during the authorization process * (or has already authenticated) may be different from the user of the grant. * Be careful when your system displays the content of the grant. *

* * @return * The content of the grant. * * @see Grant Management for OAuth 2.0 * * @since 3.6 */ public Grant getGrant() { return grant; } /** * Set the content of the grant which is identified by the {@code grant_id} * request parameter of the device authorization request. * *

* The user your system will authenticate during the authorization process * (or has already authenticated) may be different from the user of the grant. * Be careful when your system displays the content of the grant. *

* * @param grant * The content of the grant. * * @return * {@code this} object. * * @see Grant Management for OAuth 2.0 * * @since 3.6 */ public DeviceVerificationResponse setGrant(Grant grant) { this.grant = grant; return this; } /** * Get the attributes of the service that the client application belongs to. * *

* This property is available since Authlete 2.2. *

* * @return * The attributes of the service. * * @since 2.88 */ public Pair[] getServiceAttributes() { return serviceAttributes; } /** * Set the attributes of the service that the client application belongs to. * *

* This property is available since Authlete 2.2. *

* * @param attributes * The attributes of the service. * * @return * {@code this} object. * * @since 2.88 */ public DeviceVerificationResponse setServiceAttributes(Pair[] attributes) { this.serviceAttributes = attributes; return this; } /** * Get the attributes of the client. * *

* This property is available since Authlete 2.2. *

* * @return * The attributes of the client. * * @since 2.88 */ public Pair[] getClientAttributes() { return clientAttributes; } /** * Set the attributes of the client. * *

* This property is available since Authlete 2.2. *

* * @param attributes * The attributes of the client. * * @return * {@code this} object. * * @since 2.88 */ public DeviceVerificationResponse setClientAttributes(Pair[] attributes) { this.clientAttributes = attributes; return this; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy