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

com.amazonaws.services.ssooidc.model.CreateTokenRequest Maven / Gradle / Ivy

/*
 * Copyright 2019-2024 Amazon.com, Inc. or its affiliates. All Rights Reserved.
 * 
 * Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with
 * the License. A copy of the License is located at
 * 
 * http://aws.amazon.com/apache2.0
 * 
 * or in the "license" file accompanying this file. This file 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.amazonaws.services.ssooidc.model;

import java.io.Serializable;
import javax.annotation.Generated;

import com.amazonaws.AmazonWebServiceRequest;

/**
 * 
 * @see AWS API
 *      Documentation
 */
@Generated("com.amazonaws:aws-java-sdk-code-generator")
public class CreateTokenRequest extends com.amazonaws.AmazonWebServiceRequest implements Serializable, Cloneable {

    /**
     * 

* The unique identifier string for the client or application. This value comes from the result of the * RegisterClient API. *

*/ private String clientId; /** *

* A secret string generated for the client. This value should come from the persisted result of the * RegisterClient API. *

*/ private String clientSecret; /** *

* Supports the following OAuth grant types: Device Code and Refresh Token. Specify either of the following values, * depending on the grant type that you want: *

*

* * Device Code - urn:ietf:params:oauth:grant-type:device_code *

*

* * Refresh Token - refresh_token *

*

* For information about how to obtain the device code, see the StartDeviceAuthorization topic. *

*/ private String grantType; /** *

* Used only when calling this API for the Device Code grant type. This short-term code is used to identify this * authorization request. This comes from the result of the StartDeviceAuthorization API. *

*/ private String deviceCode; /** *

* Used only when calling this API for the Authorization Code grant type. The short-term code is used to identify * this authorization request. This grant type is currently unsupported for the CreateToken API. *

*/ private String code; /** *

* Used only when calling this API for the Refresh Token grant type. This token is used to refresh short-term * tokens, such as the access token, that might expire. *

*

* For more information about the features and limitations of the current IAM Identity Center OIDC implementation, * see Considerations for Using this Guide in the IAM Identity Center OIDC API * Reference. *

*/ private String refreshToken; /** *

* The list of scopes for which authorization is requested. The access token that is issued is limited to the scopes * that are granted. If this value is not specified, IAM Identity Center authorizes all scopes that are configured * for the client during the call to RegisterClient. *

*/ private java.util.List scope; /** *

* Used only when calling this API for the Authorization Code grant type. This value specifies the location of the * client or application that has registered to receive the authorization code. *

*/ private String redirectUri; /** *

* Used only when calling this API for the Authorization Code grant type. This value is generated by the client and * presented to validate the original code challenge value the client passed at authorization time. *

*/ private String codeVerifier; /** *

* The unique identifier string for the client or application. This value comes from the result of the * RegisterClient API. *

* * @param clientId * The unique identifier string for the client or application. This value comes from the result of the * RegisterClient API. */ public void setClientId(String clientId) { this.clientId = clientId; } /** *

* The unique identifier string for the client or application. This value comes from the result of the * RegisterClient API. *

* * @return The unique identifier string for the client or application. This value comes from the result of the * RegisterClient API. */ public String getClientId() { return this.clientId; } /** *

* The unique identifier string for the client or application. This value comes from the result of the * RegisterClient API. *

* * @param clientId * The unique identifier string for the client or application. This value comes from the result of the * RegisterClient API. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateTokenRequest withClientId(String clientId) { setClientId(clientId); return this; } /** *

* A secret string generated for the client. This value should come from the persisted result of the * RegisterClient API. *

* * @param clientSecret * A secret string generated for the client. This value should come from the persisted result of the * RegisterClient API. */ public void setClientSecret(String clientSecret) { this.clientSecret = clientSecret; } /** *

* A secret string generated for the client. This value should come from the persisted result of the * RegisterClient API. *

* * @return A secret string generated for the client. This value should come from the persisted result of the * RegisterClient API. */ public String getClientSecret() { return this.clientSecret; } /** *

* A secret string generated for the client. This value should come from the persisted result of the * RegisterClient API. *

* * @param clientSecret * A secret string generated for the client. This value should come from the persisted result of the * RegisterClient API. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateTokenRequest withClientSecret(String clientSecret) { setClientSecret(clientSecret); return this; } /** *

* Supports the following OAuth grant types: Device Code and Refresh Token. Specify either of the following values, * depending on the grant type that you want: *

*

* * Device Code - urn:ietf:params:oauth:grant-type:device_code *

*

* * Refresh Token - refresh_token *

*

* For information about how to obtain the device code, see the StartDeviceAuthorization topic. *

* * @param grantType * Supports the following OAuth grant types: Device Code and Refresh Token. Specify either of the following * values, depending on the grant type that you want:

*

* Device Code - urn:ietf:params:oauth:grant-type:device_code *

*

* Refresh Token - refresh_token *

*

* For information about how to obtain the device code, see the StartDeviceAuthorization topic. */ public void setGrantType(String grantType) { this.grantType = grantType; } /** *

* Supports the following OAuth grant types: Device Code and Refresh Token. Specify either of the following values, * depending on the grant type that you want: *

*

* * Device Code - urn:ietf:params:oauth:grant-type:device_code *

*

* * Refresh Token - refresh_token *

*

* For information about how to obtain the device code, see the StartDeviceAuthorization topic. *

* * @return Supports the following OAuth grant types: Device Code and Refresh Token. Specify either of the following * values, depending on the grant type that you want:

*

* Device Code - urn:ietf:params:oauth:grant-type:device_code *

*

* Refresh Token - refresh_token *

*

* For information about how to obtain the device code, see the StartDeviceAuthorization topic. */ public String getGrantType() { return this.grantType; } /** *

* Supports the following OAuth grant types: Device Code and Refresh Token. Specify either of the following values, * depending on the grant type that you want: *

*

* * Device Code - urn:ietf:params:oauth:grant-type:device_code *

*

* * Refresh Token - refresh_token *

*

* For information about how to obtain the device code, see the StartDeviceAuthorization topic. *

* * @param grantType * Supports the following OAuth grant types: Device Code and Refresh Token. Specify either of the following * values, depending on the grant type that you want:

*

* Device Code - urn:ietf:params:oauth:grant-type:device_code *

*

* Refresh Token - refresh_token *

*

* For information about how to obtain the device code, see the StartDeviceAuthorization topic. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateTokenRequest withGrantType(String grantType) { setGrantType(grantType); return this; } /** *

* Used only when calling this API for the Device Code grant type. This short-term code is used to identify this * authorization request. This comes from the result of the StartDeviceAuthorization API. *

* * @param deviceCode * Used only when calling this API for the Device Code grant type. This short-term code is used to identify * this authorization request. This comes from the result of the StartDeviceAuthorization API. */ public void setDeviceCode(String deviceCode) { this.deviceCode = deviceCode; } /** *

* Used only when calling this API for the Device Code grant type. This short-term code is used to identify this * authorization request. This comes from the result of the StartDeviceAuthorization API. *

* * @return Used only when calling this API for the Device Code grant type. This short-term code is used to identify * this authorization request. This comes from the result of the StartDeviceAuthorization API. */ public String getDeviceCode() { return this.deviceCode; } /** *

* Used only when calling this API for the Device Code grant type. This short-term code is used to identify this * authorization request. This comes from the result of the StartDeviceAuthorization API. *

* * @param deviceCode * Used only when calling this API for the Device Code grant type. This short-term code is used to identify * this authorization request. This comes from the result of the StartDeviceAuthorization API. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateTokenRequest withDeviceCode(String deviceCode) { setDeviceCode(deviceCode); return this; } /** *

* Used only when calling this API for the Authorization Code grant type. The short-term code is used to identify * this authorization request. This grant type is currently unsupported for the CreateToken API. *

* * @param code * Used only when calling this API for the Authorization Code grant type. The short-term code is used to * identify this authorization request. This grant type is currently unsupported for the CreateToken * API. */ public void setCode(String code) { this.code = code; } /** *

* Used only when calling this API for the Authorization Code grant type. The short-term code is used to identify * this authorization request. This grant type is currently unsupported for the CreateToken API. *

* * @return Used only when calling this API for the Authorization Code grant type. The short-term code is used to * identify this authorization request. This grant type is currently unsupported for the CreateToken * API. */ public String getCode() { return this.code; } /** *

* Used only when calling this API for the Authorization Code grant type. The short-term code is used to identify * this authorization request. This grant type is currently unsupported for the CreateToken API. *

* * @param code * Used only when calling this API for the Authorization Code grant type. The short-term code is used to * identify this authorization request. This grant type is currently unsupported for the CreateToken * API. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateTokenRequest withCode(String code) { setCode(code); return this; } /** *

* Used only when calling this API for the Refresh Token grant type. This token is used to refresh short-term * tokens, such as the access token, that might expire. *

*

* For more information about the features and limitations of the current IAM Identity Center OIDC implementation, * see Considerations for Using this Guide in the IAM Identity Center OIDC API * Reference. *

* * @param refreshToken * Used only when calling this API for the Refresh Token grant type. This token is used to refresh short-term * tokens, such as the access token, that might expire.

*

* For more information about the features and limitations of the current IAM Identity Center OIDC * implementation, see Considerations for Using this Guide in the IAM Identity Center * OIDC API Reference. */ public void setRefreshToken(String refreshToken) { this.refreshToken = refreshToken; } /** *

* Used only when calling this API for the Refresh Token grant type. This token is used to refresh short-term * tokens, such as the access token, that might expire. *

*

* For more information about the features and limitations of the current IAM Identity Center OIDC implementation, * see Considerations for Using this Guide in the IAM Identity Center OIDC API * Reference. *

* * @return Used only when calling this API for the Refresh Token grant type. This token is used to refresh * short-term tokens, such as the access token, that might expire.

*

* For more information about the features and limitations of the current IAM Identity Center OIDC * implementation, see Considerations for Using this Guide in the IAM Identity Center * OIDC API Reference. */ public String getRefreshToken() { return this.refreshToken; } /** *

* Used only when calling this API for the Refresh Token grant type. This token is used to refresh short-term * tokens, such as the access token, that might expire. *

*

* For more information about the features and limitations of the current IAM Identity Center OIDC implementation, * see Considerations for Using this Guide in the IAM Identity Center OIDC API * Reference. *

* * @param refreshToken * Used only when calling this API for the Refresh Token grant type. This token is used to refresh short-term * tokens, such as the access token, that might expire.

*

* For more information about the features and limitations of the current IAM Identity Center OIDC * implementation, see Considerations for Using this Guide in the IAM Identity Center * OIDC API Reference. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateTokenRequest withRefreshToken(String refreshToken) { setRefreshToken(refreshToken); return this; } /** *

* The list of scopes for which authorization is requested. The access token that is issued is limited to the scopes * that are granted. If this value is not specified, IAM Identity Center authorizes all scopes that are configured * for the client during the call to RegisterClient. *

* * @return The list of scopes for which authorization is requested. The access token that is issued is limited to * the scopes that are granted. If this value is not specified, IAM Identity Center authorizes all scopes * that are configured for the client during the call to RegisterClient. */ public java.util.List getScope() { return scope; } /** *

* The list of scopes for which authorization is requested. The access token that is issued is limited to the scopes * that are granted. If this value is not specified, IAM Identity Center authorizes all scopes that are configured * for the client during the call to RegisterClient. *

* * @param scope * The list of scopes for which authorization is requested. The access token that is issued is limited to the * scopes that are granted. If this value is not specified, IAM Identity Center authorizes all scopes that * are configured for the client during the call to RegisterClient. */ public void setScope(java.util.Collection scope) { if (scope == null) { this.scope = null; return; } this.scope = new java.util.ArrayList(scope); } /** *

* The list of scopes for which authorization is requested. The access token that is issued is limited to the scopes * that are granted. If this value is not specified, IAM Identity Center authorizes all scopes that are configured * for the client during the call to RegisterClient. *

*

* NOTE: This method appends the values to the existing list (if any). Use * {@link #setScope(java.util.Collection)} or {@link #withScope(java.util.Collection)} if you want to override the * existing values. *

* * @param scope * The list of scopes for which authorization is requested. The access token that is issued is limited to the * scopes that are granted. If this value is not specified, IAM Identity Center authorizes all scopes that * are configured for the client during the call to RegisterClient. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateTokenRequest withScope(String... scope) { if (this.scope == null) { setScope(new java.util.ArrayList(scope.length)); } for (String ele : scope) { this.scope.add(ele); } return this; } /** *

* The list of scopes for which authorization is requested. The access token that is issued is limited to the scopes * that are granted. If this value is not specified, IAM Identity Center authorizes all scopes that are configured * for the client during the call to RegisterClient. *

* * @param scope * The list of scopes for which authorization is requested. The access token that is issued is limited to the * scopes that are granted. If this value is not specified, IAM Identity Center authorizes all scopes that * are configured for the client during the call to RegisterClient. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateTokenRequest withScope(java.util.Collection scope) { setScope(scope); return this; } /** *

* Used only when calling this API for the Authorization Code grant type. This value specifies the location of the * client or application that has registered to receive the authorization code. *

* * @param redirectUri * Used only when calling this API for the Authorization Code grant type. This value specifies the location * of the client or application that has registered to receive the authorization code. */ public void setRedirectUri(String redirectUri) { this.redirectUri = redirectUri; } /** *

* Used only when calling this API for the Authorization Code grant type. This value specifies the location of the * client or application that has registered to receive the authorization code. *

* * @return Used only when calling this API for the Authorization Code grant type. This value specifies the location * of the client or application that has registered to receive the authorization code. */ public String getRedirectUri() { return this.redirectUri; } /** *

* Used only when calling this API for the Authorization Code grant type. This value specifies the location of the * client or application that has registered to receive the authorization code. *

* * @param redirectUri * Used only when calling this API for the Authorization Code grant type. This value specifies the location * of the client or application that has registered to receive the authorization code. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateTokenRequest withRedirectUri(String redirectUri) { setRedirectUri(redirectUri); return this; } /** *

* Used only when calling this API for the Authorization Code grant type. This value is generated by the client and * presented to validate the original code challenge value the client passed at authorization time. *

* * @param codeVerifier * Used only when calling this API for the Authorization Code grant type. This value is generated by the * client and presented to validate the original code challenge value the client passed at authorization * time. */ public void setCodeVerifier(String codeVerifier) { this.codeVerifier = codeVerifier; } /** *

* Used only when calling this API for the Authorization Code grant type. This value is generated by the client and * presented to validate the original code challenge value the client passed at authorization time. *

* * @return Used only when calling this API for the Authorization Code grant type. This value is generated by the * client and presented to validate the original code challenge value the client passed at authorization * time. */ public String getCodeVerifier() { return this.codeVerifier; } /** *

* Used only when calling this API for the Authorization Code grant type. This value is generated by the client and * presented to validate the original code challenge value the client passed at authorization time. *

* * @param codeVerifier * Used only when calling this API for the Authorization Code grant type. This value is generated by the * client and presented to validate the original code challenge value the client passed at authorization * time. * @return Returns a reference to this object so that method calls can be chained together. */ public CreateTokenRequest withCodeVerifier(String codeVerifier) { setCodeVerifier(codeVerifier); return this; } /** * Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be * redacted from this string using a placeholder value. * * @return A string representation of this object. * * @see java.lang.Object#toString() */ @Override public String toString() { StringBuilder sb = new StringBuilder(); sb.append("{"); if (getClientId() != null) sb.append("ClientId: ").append(getClientId()).append(","); if (getClientSecret() != null) sb.append("ClientSecret: ").append("***Sensitive Data Redacted***").append(","); if (getGrantType() != null) sb.append("GrantType: ").append(getGrantType()).append(","); if (getDeviceCode() != null) sb.append("DeviceCode: ").append(getDeviceCode()).append(","); if (getCode() != null) sb.append("Code: ").append(getCode()).append(","); if (getRefreshToken() != null) sb.append("RefreshToken: ").append("***Sensitive Data Redacted***").append(","); if (getScope() != null) sb.append("Scope: ").append(getScope()).append(","); if (getRedirectUri() != null) sb.append("RedirectUri: ").append(getRedirectUri()).append(","); if (getCodeVerifier() != null) sb.append("CodeVerifier: ").append("***Sensitive Data Redacted***"); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof CreateTokenRequest == false) return false; CreateTokenRequest other = (CreateTokenRequest) obj; if (other.getClientId() == null ^ this.getClientId() == null) return false; if (other.getClientId() != null && other.getClientId().equals(this.getClientId()) == false) return false; if (other.getClientSecret() == null ^ this.getClientSecret() == null) return false; if (other.getClientSecret() != null && other.getClientSecret().equals(this.getClientSecret()) == false) return false; if (other.getGrantType() == null ^ this.getGrantType() == null) return false; if (other.getGrantType() != null && other.getGrantType().equals(this.getGrantType()) == false) return false; if (other.getDeviceCode() == null ^ this.getDeviceCode() == null) return false; if (other.getDeviceCode() != null && other.getDeviceCode().equals(this.getDeviceCode()) == false) return false; if (other.getCode() == null ^ this.getCode() == null) return false; if (other.getCode() != null && other.getCode().equals(this.getCode()) == false) return false; if (other.getRefreshToken() == null ^ this.getRefreshToken() == null) return false; if (other.getRefreshToken() != null && other.getRefreshToken().equals(this.getRefreshToken()) == false) return false; if (other.getScope() == null ^ this.getScope() == null) return false; if (other.getScope() != null && other.getScope().equals(this.getScope()) == false) return false; if (other.getRedirectUri() == null ^ this.getRedirectUri() == null) return false; if (other.getRedirectUri() != null && other.getRedirectUri().equals(this.getRedirectUri()) == false) return false; if (other.getCodeVerifier() == null ^ this.getCodeVerifier() == null) return false; if (other.getCodeVerifier() != null && other.getCodeVerifier().equals(this.getCodeVerifier()) == false) return false; return true; } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getClientId() == null) ? 0 : getClientId().hashCode()); hashCode = prime * hashCode + ((getClientSecret() == null) ? 0 : getClientSecret().hashCode()); hashCode = prime * hashCode + ((getGrantType() == null) ? 0 : getGrantType().hashCode()); hashCode = prime * hashCode + ((getDeviceCode() == null) ? 0 : getDeviceCode().hashCode()); hashCode = prime * hashCode + ((getCode() == null) ? 0 : getCode().hashCode()); hashCode = prime * hashCode + ((getRefreshToken() == null) ? 0 : getRefreshToken().hashCode()); hashCode = prime * hashCode + ((getScope() == null) ? 0 : getScope().hashCode()); hashCode = prime * hashCode + ((getRedirectUri() == null) ? 0 : getRedirectUri().hashCode()); hashCode = prime * hashCode + ((getCodeVerifier() == null) ? 0 : getCodeVerifier().hashCode()); return hashCode; } @Override public CreateTokenRequest clone() { return (CreateTokenRequest) super.clone(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy