io.micronaut.security.oauth2.grants.AuthorizationCodeGrant Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of micronaut-security-oauth2 Show documentation
Show all versions of micronaut-security-oauth2 Show documentation
Official Security Solution for Micronaut
/*
* Copyright 2017-2019 original authors
*
* 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 io.micronaut.security.oauth2.grants;
import com.fasterxml.jackson.databind.PropertyNamingStrategy;
import com.fasterxml.jackson.databind.annotation.JsonNaming;
import io.micronaut.core.annotation.Introspected;
import javax.annotation.Nonnull;
import java.util.Map;
/**
* Authorization Code Grant Request.
* @see Access Token Request
*
* @author Sergio del Amo
* @since 1.2.0
*/
@Introspected
@JsonNaming(PropertyNamingStrategy.SnakeCaseStrategy.class)
public class AuthorizationCodeGrant implements SecureGrant, AsMap {
private static final String KEY_GRANT_TYPE = "grant_type";
private static final String KEY_CLIENT_ID = "client_id";
private static final String KEY_CLIENT_SECRET = "client_secret";
private static final String KEY_REDIRECT_URI = "redirect_uri";
private static final String KEY_CODE = "code";
private String grantType = GrantType.AUTHORIZATION_CODE.toString();
private String clientId;
private String clientSecret;
private String redirectUri;
private String code;
/**
* Default Constructor.
*/
public AuthorizationCodeGrant() {
}
/**
*
* @return OAuth 2.0 Grant Type.
*/
@Nonnull
public String getGrantType() {
return grantType;
}
/**
*
* @param grantType OAuth 2.0 Grant Type.
*/
public void setGrantType(@Nonnull String grantType) {
this.grantType = grantType;
}
/**
*
* @return The application's Client identifier.
*/
@Nonnull
public String getClientId() {
return clientId;
}
/**
*
* @param clientId Application's Client identifier.
*/
public void setClientId(@Nonnull String clientId) {
this.clientId = clientId;
}
/**
*
* @param clientSecret Application's Client clientSecret.
*/
public void setClientSecret(String clientSecret) {
this.clientSecret = clientSecret;
}
/**
*
* @return The application's Client clientSecret.
*/
public String getClientSecret() {
return this.clientSecret;
}
/**
*
* @return Redirection URI to which the response will be sent.
*/
@Nonnull
public String getRedirectUri() {
return redirectUri;
}
/**
*
* @param redirectUri Redirection URI to which the response will be sent.
*/
public void setRedirectUri(@Nonnull String redirectUri) {
this.redirectUri = redirectUri;
}
/**
*
* @return An authorization code.
*/
@Nonnull
public String getCode() {
return code;
}
/**
*
* @param code An authorization code.
*/
public void setCode(@Nonnull String code) {
this.code = code;
}
/**
*
* @return this object as a Map
*/
@Override
public Map toMap() {
Map m = new SecureGrantMap(5);
m.put(KEY_GRANT_TYPE, getGrantType());
m.put(KEY_CODE, getCode());
if (clientId != null) {
m.put(KEY_CLIENT_ID, clientId);
}
if (clientSecret != null) {
m.put(KEY_CLIENT_SECRET, clientSecret);
}
if (redirectUri != null) {
m.put(KEY_REDIRECT_URI, getRedirectUri());
}
return m;
}
}