Package io.jans.as.server.model.common
Class AbstractAuthorizationGrant
- java.lang.Object
-
- io.jans.as.server.model.common.AbstractAuthorizationGrant
-
- All Implemented Interfaces:
IAuthorizationGrant
- Direct Known Subclasses:
AuthorizationGrant
public abstract class AbstractAuthorizationGrant extends Object implements IAuthorizationGrant
- Version:
- September 30, 2021
- Author:
- Yuriy Zabrovarnyy, Javier Rojas Blum, Yuriy Movchan
-
-
Field Summary
Fields Modifier and Type Field Description protected ConcurrentMap<String,AccessToken>
accessTokens
protected io.jans.as.model.configuration.AppConfiguration
appConfiguration
protected ConcurrentMap<String,RefreshToken>
refreshTokens
protected ScopeChecker
scopeChecker
-
Constructor Summary
Constructors Modifier Constructor Description protected
AbstractAuthorizationGrant()
protected
AbstractAuthorizationGrant(io.jans.as.common.model.common.User user, AuthorizationGrantType authorizationGrantType, io.jans.as.common.model.registration.Client client, Date authenticationTime)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description String
checkScopesPolicy(String requestedScopes)
Checks the scopes policy configured according to the type of the authorization grant to limit the issued token scopes.AccessToken
createAccessToken(ExecutionContext executionContext)
RefreshToken
createRefreshToken(ExecutionContext context)
RefreshToken
createRefreshToken(ExecutionContext context, int lifetime)
AbstractToken
getAccessToken(String tokenCode)
Gets the access token instance from the id token list or the access token list given its code.int
getAccessTokenLifetimeInSeconds(ExecutionContext executionContext)
List<AccessToken>
getAccessTokens()
Returns a list with all the issued access tokens.Set<String>
getAccessTokensCodes()
Returns a list with all the issued access tokens codes.String
getAcrValues()
Date
getAuthenticationTime()
AuthorizationCode
getAuthorizationCode()
Returns theAuthorizationCode
.AuthorizationGrantType
getAuthorizationGrantType()
Returns theAuthorizationGrantType
.String
getClaims()
io.jans.as.common.model.registration.Client
getClient()
Returns theClient
.String
getClientDn()
String
getClientId()
String
getCodeChallenge()
String
getCodeChallengeMethod()
String
getDpopJkt()
String
getGrantId()
IdToken
getIdToken()
JwtAuthorizationRequest
getJwtAuthorizationRequest()
AccessToken
getLongLivedAccessToken()
String
getNonce()
RefreshToken
getRefreshToken(String refreshTokenCode)
Gets the refresh token instance from the refresh token list given its code.List<RefreshToken>
getRefreshTokens()
Returns a list with all the issued refresh tokens.Set<String>
getRefreshTokensCodes()
Returns a list with all the issued refresh tokens codes.Set<String>
getScopes()
Returns a list of the scopes granted to the client.String
getSessionDn()
String
getTokenBindingHash()
TokenEntity
getTokenEntity()
io.jans.as.common.model.common.User
getUser()
Returns the resource owner's.String
getUserDn()
String
getUserId()
String
getX5cs256()
protected void
init(io.jans.as.common.model.common.User user, AuthorizationGrantType authorizationGrantType, io.jans.as.common.model.registration.Client client, Date authenticationTime)
void
setAccessTokens(List<AccessToken> accessTokens)
void
setAcrValues(String acrValues)
void
setAuthenticationTime(Date authenticationTime)
void
setAuthorizationCode(AuthorizationCode authorizationCode)
Sets theAuthorizationCode
.void
setClaims(String claims)
void
setCodeChallenge(String codeChallenge)
void
setCodeChallengeMethod(String codeChallengeMethod)
void
setDpopJkt(String dpopJkt)
void
setGrantId(String grantId)
void
setIdToken(IdToken idToken)
void
setJwtAuthorizationRequest(JwtAuthorizationRequest jwtAuthorizationRequest)
void
setLongLivedAccessToken(AccessToken longLivedAccessToken)
void
setNonce(String nonce)
void
setRefreshTokens(List<RefreshToken> refreshTokens)
void
setScopes(Collection<String> scopes)
void
setSessionDn(String sessionDn)
void
setTokenBindingHash(String tokenBindingHash)
void
setTokenEntity(TokenEntity tokenEntity)
void
setX5cs256(String x5cs256)
String
toString()
-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface io.jans.as.server.model.common.IAuthorizationGrant
checkExpiredTokens, createIdToken, getGrantType, getSub, revokeAllTokens, save
-
-
-
-
Field Detail
-
appConfiguration
@Inject protected io.jans.as.model.configuration.AppConfiguration appConfiguration
-
scopeChecker
@Inject protected ScopeChecker scopeChecker
-
accessTokens
protected final ConcurrentMap<String,AccessToken> accessTokens
-
refreshTokens
protected final ConcurrentMap<String,RefreshToken> refreshTokens
-
-
Constructor Detail
-
AbstractAuthorizationGrant
protected AbstractAuthorizationGrant()
-
AbstractAuthorizationGrant
protected AbstractAuthorizationGrant(io.jans.as.common.model.common.User user, AuthorizationGrantType authorizationGrantType, io.jans.as.common.model.registration.Client client, Date authenticationTime)
-
-
Method Detail
-
init
protected void init(io.jans.as.common.model.common.User user, AuthorizationGrantType authorizationGrantType, io.jans.as.common.model.registration.Client client, Date authenticationTime)
-
getDpopJkt
public String getDpopJkt()
-
setDpopJkt
public void setDpopJkt(String dpopJkt)
-
getGrantId
public String getGrantId()
- Specified by:
getGrantId
in interfaceIAuthorizationGrant
-
setGrantId
public void setGrantId(String grantId)
- Specified by:
setGrantId
in interfaceIAuthorizationGrant
-
getAuthorizationCode
public AuthorizationCode getAuthorizationCode()
Returns theAuthorizationCode
.- Specified by:
getAuthorizationCode
in interfaceIAuthorizationGrant
- Returns:
- The authorization code.
-
setAuthorizationCode
public void setAuthorizationCode(AuthorizationCode authorizationCode)
Sets theAuthorizationCode
.- Specified by:
setAuthorizationCode
in interfaceIAuthorizationGrant
- Parameters:
authorizationCode
- The authorization code.
-
getTokenBindingHash
public String getTokenBindingHash()
-
setTokenBindingHash
public void setTokenBindingHash(String tokenBindingHash)
-
getX5cs256
public String getX5cs256()
-
setX5cs256
public void setX5cs256(String x5cs256)
-
getNonce
public String getNonce()
- Specified by:
getNonce
in interfaceIAuthorizationGrant
-
setNonce
public void setNonce(String nonce)
- Specified by:
setNonce
in interfaceIAuthorizationGrant
-
getCodeChallenge
public String getCodeChallenge()
-
setCodeChallenge
public void setCodeChallenge(String codeChallenge)
-
getCodeChallengeMethod
public String getCodeChallengeMethod()
-
setCodeChallengeMethod
public void setCodeChallengeMethod(String codeChallengeMethod)
-
getClaims
public String getClaims()
-
setClaims
public void setClaims(String claims)
-
getRefreshTokensCodes
public Set<String> getRefreshTokensCodes()
Returns a list with all the issued refresh tokens codes.- Specified by:
getRefreshTokensCodes
in interfaceIAuthorizationGrant
- Returns:
- List with all the issued refresh tokens codes.
-
getAccessTokensCodes
public Set<String> getAccessTokensCodes()
Returns a list with all the issued access tokens codes.- Specified by:
getAccessTokensCodes
in interfaceIAuthorizationGrant
- Returns:
- List with all the issued access tokens codes.
-
getAccessTokens
public List<AccessToken> getAccessTokens()
Returns a list with all the issued access tokens.- Specified by:
getAccessTokens
in interfaceIAuthorizationGrant
- Returns:
- List with all the issued access tokens.
-
setScopes
public void setScopes(Collection<String> scopes)
- Specified by:
setScopes
in interfaceIAuthorizationGrant
-
getLongLivedAccessToken
public AccessToken getLongLivedAccessToken()
- Specified by:
getLongLivedAccessToken
in interfaceIAuthorizationGrant
-
setLongLivedAccessToken
public void setLongLivedAccessToken(AccessToken longLivedAccessToken)
- Specified by:
setLongLivedAccessToken
in interfaceIAuthorizationGrant
-
getIdToken
public IdToken getIdToken()
- Specified by:
getIdToken
in interfaceIAuthorizationGrant
-
setIdToken
public void setIdToken(IdToken idToken)
- Specified by:
setIdToken
in interfaceIAuthorizationGrant
-
getTokenEntity
public TokenEntity getTokenEntity()
- Specified by:
getTokenEntity
in interfaceIAuthorizationGrant
-
setTokenEntity
public void setTokenEntity(TokenEntity tokenEntity)
- Specified by:
setTokenEntity
in interfaceIAuthorizationGrant
-
getUser
public io.jans.as.common.model.common.User getUser()
Returns the resource owner's.- Specified by:
getUser
in interfaceIAuthorizationGrant
- Returns:
- The resource owner's.
-
getAcrValues
public String getAcrValues()
- Specified by:
getAcrValues
in interfaceIAuthorizationGrant
-
setAcrValues
public void setAcrValues(String acrValues)
- Specified by:
setAcrValues
in interfaceIAuthorizationGrant
-
getSessionDn
public String getSessionDn()
- Specified by:
getSessionDn
in interfaceIAuthorizationGrant
-
setSessionDn
public void setSessionDn(String sessionDn)
- Specified by:
setSessionDn
in interfaceIAuthorizationGrant
-
checkScopesPolicy
public String checkScopesPolicy(String requestedScopes)
Checks the scopes policy configured according to the type of the authorization grant to limit the issued token scopes.- Specified by:
checkScopesPolicy
in interfaceIAuthorizationGrant
- Parameters:
requestedScopes
- A space-delimited list of values in which the order of values does not matter.- Returns:
- A space-delimited list of scopes
-
getAccessTokenLifetimeInSeconds
public int getAccessTokenLifetimeInSeconds(ExecutionContext executionContext)
-
createAccessToken
public AccessToken createAccessToken(ExecutionContext executionContext)
- Specified by:
createAccessToken
in interfaceIAuthorizationGrant
-
createRefreshToken
public RefreshToken createRefreshToken(ExecutionContext context)
- Specified by:
createRefreshToken
in interfaceIAuthorizationGrant
-
createRefreshToken
public RefreshToken createRefreshToken(ExecutionContext context, int lifetime)
- Specified by:
createRefreshToken
in interfaceIAuthorizationGrant
-
getUserId
public String getUserId()
- Specified by:
getUserId
in interfaceIAuthorizationGrant
-
getUserDn
public String getUserDn()
- Specified by:
getUserDn
in interfaceIAuthorizationGrant
-
getAuthorizationGrantType
public AuthorizationGrantType getAuthorizationGrantType()
Returns theAuthorizationGrantType
.- Specified by:
getAuthorizationGrantType
in interfaceIAuthorizationGrant
- Returns:
- The authorization grant type.
-
getClient
public io.jans.as.common.model.registration.Client getClient()
Returns theClient
. An application making protected resource requests on behalf of the resource owner and with its authorization.- Specified by:
getClient
in interfaceIAuthorizationGrant
- Returns:
- The client.
-
getClientId
public String getClientId()
- Specified by:
getClientId
in interfaceIAuthorizationGrant
-
getClientDn
public String getClientDn()
- Specified by:
getClientDn
in interfaceIAuthorizationGrant
-
getAuthenticationTime
public Date getAuthenticationTime()
- Specified by:
getAuthenticationTime
in interfaceIAuthorizationGrant
-
setAuthenticationTime
public void setAuthenticationTime(Date authenticationTime)
-
getScopes
public Set<String> getScopes()
Returns a list of the scopes granted to the client.- Specified by:
getScopes
in interfaceIAuthorizationGrant
- Returns:
- List of the scopes granted to the client.
-
getJwtAuthorizationRequest
public JwtAuthorizationRequest getJwtAuthorizationRequest()
- Specified by:
getJwtAuthorizationRequest
in interfaceIAuthorizationGrant
-
setJwtAuthorizationRequest
public void setJwtAuthorizationRequest(JwtAuthorizationRequest jwtAuthorizationRequest)
- Specified by:
setJwtAuthorizationRequest
in interfaceIAuthorizationGrant
-
setAccessTokens
public void setAccessTokens(List<AccessToken> accessTokens)
- Specified by:
setAccessTokens
in interfaceIAuthorizationGrant
-
getRefreshTokens
public List<RefreshToken> getRefreshTokens()
Returns a list with all the issued refresh tokens.- Specified by:
getRefreshTokens
in interfaceIAuthorizationGrant
- Returns:
- List with all the issued refresh tokens.
-
setRefreshTokens
public void setRefreshTokens(List<RefreshToken> refreshTokens)
- Specified by:
setRefreshTokens
in interfaceIAuthorizationGrant
-
getRefreshToken
public RefreshToken getRefreshToken(String refreshTokenCode)
Gets the refresh token instance from the refresh token list given its code.- Specified by:
getRefreshToken
in interfaceIAuthorizationGrant
- Parameters:
refreshTokenCode
- The code of the refresh token.- Returns:
- The refresh token instance or
null
if not found.
-
getAccessToken
public AbstractToken getAccessToken(String tokenCode)
Gets the access token instance from the id token list or the access token list given its code.- Specified by:
getAccessToken
in interfaceIAuthorizationGrant
- Parameters:
tokenCode
- The code of the access token.- Returns:
- The access token instance or
null
if not found.
-
-