This is a wrapper library for Authlete Web APIs.
Authlete is a cloud service that provides an implementation of OAuth 2.0 & OpenID Connect (overview). By using the Web APIs provided by Authlete, you can build a DB-less authorization server. "DB-less" here means that you don't have to prepare a database server that stores authorization data (e.g. access tokens), settings of authorization servers and settings of client applications. These data are stored in the Authlete server on cloud.
java-oauth-server is the reference implementation of an authorization server written using this library and authlete-java-jaxrs library. It is a good starting point for your own authorization server implementation.
Apache License, Version 2.0
JSON files under src/test/resources/ekyc-ida
have been copied from
https://bitbucket.org/openid/ekyc-ida/src/master/examples/response/ .
Regarding their license, ask the eKYC-IDA WG of OpenID Foundation.
<dependency>
<groupId>com.authlete</groupId>
<artifactId>authlete-java-common</artifactId>
<version>${authlete-java-common.version}</version>
</dependency>
Please refer to the CHANGES.md file to know the latest version
to write in place of ${authlete-java-common.version}
.
https://github.com/authlete/authlete-java-common
https://authlete.github.io/authlete-java-common/
https://authlete.github.io/authlete-java-common/index.html?overview-summary.html
[FRAMES]
All the methods to communicate with Authlete Web APIs are gathered in
AuthleteApi
interface. To get an implementation of the interface, you need to
call create()
method of AuthleteApiFactory
class. There are two variants
of the method as shown below.
public static AuthleteApi
create(AuthleteConfiguration configuration);
public static AuthleteApi
create(AuthleteConfiguration configuration, String className);
As you can see, both methods take AuthleteConfiguration
as their first argument.
AuthleteConfiguration
is an interface that holds configuration values to access
Authlete Web APIs such as the URL of Authlete server and API credentials of a
service. To be concrete, the interface has the following methods.
Method | Authlete Version | Description |
---|---|---|
getBaseUrl() |
Common | URL of Authlete server |
getServiceApiKey() |
Common | API key of a service |
getServiceApiSecret() |
Up to version 2.x | API secret of a service |
getServiceOwnerApiKey() |
Up to version 2.x | API key of your account |
getServiceOwnerApiSecret() |
Up to version 2.x | API secret of your account |
getApiVersion() |
Since version 3.0 | API version |
getServiceAccessToken() |
Since version 3.0 | API access token |
authlete-java-common library includes three implementations of
AuthleteConfiguration
interface as listed below.
Class | Description |
---|---|
AuthleteEnvConfiguration |
Configuration via environment variables |
AuthletePropertiesConfiguration |
Configuration via a properties file |
AuthleteSimpleConfiguration |
Configuration via POJO |
You can use one of these or create your own implementation of the interface. In
either case, you can get an implementation of AuthleteApi
interface by passing
an AuthleteConfiguration
instance to create()
method of AuthleteApiFactory
class.
In summary, the flow to get an implementation of AuthleteApi
becomes like below.
// Prepare an instance of AuthleteConfiguration interface.
AuthleteConfiguration configuration = ...;
// Get an instance of AuthleteApi interface.
AuthleteApi api = AuthleteApiFactory.create(configuration);
If you want to do it in an easier way, use AuthleteApiFactory.getDefaultApi()
method. This method searches the file system and the classpath for a properties
file named authlete.properties
and loads the content of the file using
AuthletePropertiesConfiguration
class.
// Search the file system and the classpath for "authlete.properties".
AuthleteApi api = AuthleteApiFactory.getDefaultApi();
AuthleteApiFactory.getDefaultApi()
method caches the search result, so you can
call the method as many times as you like without worrying about the overhead of
file loading.
Among the three implementations of AuthleteConfiguration
interface, this section
explains AuthletePropertiesConfiguration
class.
AuthletePropertiesConfiguration
class provides a mechanism to use a properties
file to set configuration values to access Authlete Web APIs. The class searches
the file system and the classpath for a specified file.
Valid property keys in a properties file and their meanings are as follows.
Property Key | Description |
---|---|
base_url |
URL of Authlete server |
service.api_key |
API key of a service |
service.api_secret |
API secret of a service |
service.api_secret.encrypted |
Encrypted API secret of a service |
service_owner.api_key |
API key of your account |
service_owner.api_secret |
API secret of your account |
service_owner.api_secret.encrypted |
Encrypted API secret of your account |
api_version |
API version. "V3" for Authlete 3.0 |
service.access_token |
API access token |
If you don't want to write API secrets in plain text, use
*.api_secret.encrypted
keys instead of *.api_secret
keys. You can set
encrypted secrets to the *.encrypted
keys. But in this case, you have to pass
the encryption key and the initial vector to a constructor of
AuthletePropertiesConfiguration
so that the loader can decode the encrypted
values. See the JavaDoc for details.
Since version 2.0, authlete-java-common library includes an implementation of
AuthleteApi
interface using HttpURLConnection
. Before version 2.0,
authlete-java-jaxrs which contains an implementation of AuthleteApi
was
additionally needed.
AuthleteApiFactory.create()
method searches known locations for an
AuthleteApi
implementation and loads one using reflection. The reason to use
reflection is to avoid depending on specific implementations (e.g. JAX-RS based
implementation in authlete-java-jaxrs).
As of this writing, known implementations of AuthleteApi
interface are as
follows.
com.authlete.jaxrs.api.AuthleteApiImpl
(in authlete-java-jaxrs)com.authlete.common.api.AuthleteApiImpl
(in authlete-java-common)
AuthleteApiFactory
checks existence of the above classes in this order.
getSettings()
method of AuthleteApi
interface has been available since
the version 2.9. By configuring the instance returned by the method, you can
change behaviours of the implementation of AuthleteApi
interface.
Examples
// An implementation of AuthleteApi interface.
AuthleteApi api = ...;
// Get the instance which holds settings of the AuthleteApi implementation.
Settings settings = api.getSettings();
// Set a connection timeout in milliseconds.
//
// Note:
// There is no standard way to set a connection timeout value
// before JAX-RS API 2.1 (which is a part of Java EE 8).
// Therefore, if authlete-java-jaxrs is used as AuthleteApi
// implementation and if the JAX-RS Client implementation is
// not supported by the implementation of setConnectionTimeout()
// of authlete-java-jaxrs, the value given to setConnectionTimeout()
// won't have any effect. See README in authlete-java-jaxrs
// for details.
//
settings.setConnectionTimeout(5000);
// Set a read timeout in milliseconds.
//
// Note:
// There is no standard way to set a read timeout value before
// JAX-RS API 2.1 (which is a part of Java EE 8). Therefore,
// if authlete-java-jaxrs is used as AuthleteApi implementation
// and if the JAX-RS Client implementation is not supported by
// the implementation of setReadTimeout() of authlete-java-jaxrs,
// the value given to setReadTimeout() won't have any effect.
// See README in authlete-java-jaxrs for details.
//
settings.setReadTimeout(5000);
Methods in AuthleteApi
interface can be divided into some categories.
- Methods for Authorization Endpoint Implementation
authorization(AuthorizationRequest request)
authorizationFail(AuthorizationFailRequest request)
authorizationIssue(AuthorizationIssueRequest request)
- Methods for Token Endpoint Implementation
token(TokenRequest request)
tokenFail(TokenFailRequest request)
tokenIssue(TokenIssueRequest request)
idTokenReissue(IDTokenReissueRequest request)
- Methods for Service Management
createService(Service service)
deleteService(long serviceApiKey)
getService(long serviceApiKey)
getServiceList()
getServiceList(int start, int end)
updateService(Service service)
- Methods for Client Application Management
createClient(Client client)
deleteClient(long clientId)
deleteClient(String clientId)
getClient(long clientId)
getClient(String clientId)
getClientList()
getClientList(int start, int end)
updateClient(Client client)
refreshClientSecret(long clientId)
refreshClientSecret(String clientIdentifier)
updateClientSecret(long clientId, String clientSecret)
updateClientSecret(String clientIdentifier, String clientSecret)
- Methods for Access Token Introspection
introspection(IntrospectionRequest request)
standardIntrospection(StandardIntrospectionRequest request)
getTokenList()
getTokenList(String clientIdentifier, String subject)
getTokenList(int start, int end)
getTokenList(String clientIdentifier, String subject, int start, int end)
getTokenList(TokenStatus)
getTokenList(int start, int end, TokenStatus tokenStatus)
getTokenList(String clientIdentifier, String subject, TokenStatus tokenStatus)
getTokenList(String clientIdentifier, String subject, int start, int end, TokenStatus tokenStatus)
- Methods for Revocation Endpoint Implementation
revocation(RevocationRequest request)
- Methods for User Info Endpoint Implementation
userinfo(UserInfoRequest request)
userinfoIssue(UserInfoIssueRequest request)
- Methods for JWK Set Endpoint Implementation
getServiceJwks()
getServiceJwks(boolean pretty, boolean includePrivateKeys)
- Methods for OpenID Connect Discovery
getServiceConfiguration()
getServiceConfiguration(boolean pretty)
- Methods for Token Operations
tokenCreate(TokenCreateRequest request)
tokenDelete(String token)
tokenRevoke(TokenRevokeRequest request)
tokenUpdate(TokenUpdateRequest request)
tokenCreateBatch(TokenCreateRequest[] request)
getTokenCreateBatchStatus(String requestId)
- Methods for Requestable Scopes per Client (deprecated; Client APIs suffice)
getRequestableScopes(long clientId)
setRequestableScopes(long clientId, String[] scopes)
deleteRequestableScopes(long clientId)
- Methods for Records of Granted Scopes
getGrantedScopes(long clientId, String subject)
deleteGrantedScopes(long clientId, String subject)
- Methods for Authorization Management on a User-Client Combination Basis
deleteClientAuthorization(long clientId, String subject)
getClientAuthorizationList(ClientAuthorizationGetListRequest request)
updateClientAuthorization(long clientId, ClientAuthorizationUpdateRequest request)
- Methods for JOSE
verifyJose(JoseVerifyRequest)
- Methods for CIBA (Client Initiated Backchannel Authentication)
backchannelAuthentication(BackchannelAuthenticationRequest)
backchannelAuthenticationIssue(BackchannelAuthenticationIssueRequest)
backchannelAuthenticationFail(BackchannelAuthenticationFailRequest)
backchannelAuthenticationComplete(BackchannelAuthenticationCompleteRequest)
- Methods for OpenID Connect Dynamic Client Registration
dynamicClientRegister(ClientRegistrationRequest)
dynamicClientGet(ClientRegistrationRequest)
dynamicClientUpdate(ClientRegistrationRequest)
dynamicClientDelete(ClientRegistrationRequest)
- Methods for Device Flow
deviceAuthorization(DeviceAuthorizationRequest)
deviceComplete(DeviceCompleteRequest)
deviceVerification(DeviceVerificationRequest)
- Methods for Pushed Authorization Requests
pushAuthorizationRequest(PushedAuthReqRequest)
- Methods for Grant Management for OAuth 2.0
gm(GMRequest)
- Methods for OpenID Connect Federation 1.0
federationConfiguration(FederationConfigurationRequest)
federationRegistration(FederationRegistrationRequest)
- Methods for Verifiable Credentials
credentialIssuerMetadata(CredentialIssuerMetadataRequest)
credentialIssuerJwks(CredentialIssuerJwksRequest)
credentialJwtIssuerMetadata(CredentialJwtIssuerMetadataRequest)
credentialOfferCreate(CredentialOfferCreateRequest)
credentialOfferInfo(CredentialOfferInfoRequest)
credentialSingleParse(CredentialSingleParseRequest)
credentialSingleIssue(CredentialSingleIssueRequest)
credentialBatchParse(CredentialBatchParseRequest)
credentialBatchIssue(CredentialBatchIssueRequest)
credentialDeferredParse(CredentialDeferredParseRequest)
credentialDeferredIssue(CredentialDeferredIssueRequest)
Examples
The following code snippet is an example to get the list of your existing services. Each service corresponds to an authorization server.
// Get an implementation of AuthleteApi interface.
AuthleteApi api = AuthleteApiFactory.getDefaultApi();
// Get the list of services.
ServiceListResponse response = api.getServiceList();
Some APIs and features don't work (even if they are defined in the AuthleteApi
interface) if Authlete API server you use doesn't support them. For example,
CIBA works only in Authlete 2.1 onwards. Please contact us if you want to use
newer Authlete versions.
Features available in Authlete 2.0 and onwards:
- Financial-grade API (FAPI)
- OAuth 2.0 Mutual TLS Client Authentication and Certificate Bound Access Tokens (MTLS)
- JWT-based Client Authentication (RFC 7523)
- Scope attributes
- UK Open Banking Security Profile
Features available in Authlete 2.1 and onwards:
- Client Initiated Backchannel Authentication (CIBA)
- JWT Secured Authorization Response Mode for OAuth 2.0 (JARM)
- Dynamic Client Registration (RFC 7591 & RFC 7592)
- OAuth 2.0 Device Authorization Grant (Device Flow)
- JWT-based Access Token
See Spec Sheet for further details.
You can write an authorization server using the methods in AuthleteApi
interface only, but the task will become much easier if you use utility classes
in authlete-java-jaxrs library. See java-oauth-server for an example of
an authorization server implementation written using the utility classes.
To address the "multiple ambiguous setter methods" json deserialization issue.
An annotation processor has been added to the maven build step and will run
during the process-classes
maven phase.
The JsonSetterAnnotationProcessor
class is responsible for this process.
The process involves iterating over all classes in the DTO package. Then
finding any ambiguously defined setter methods (setter methods defined with
the same name) which do not have any @JsonSetter
annotation defined. If
there are setters found that match these criteria, the correct setter method
to annotate will be determined by matching the first argument of the setter
method with the return type of the matching getter method.
The new annotation is then added to the identified setter method and written
to the existing class file.
- Authlete - Authlete Home Page
- JavaDoc - JavaDoc of this library
- authlete-java-jaxrs - Authlete Library for JAX-RS (Java)
- java-oauth-server - Authorization Server Implementation
- java-resource-server - Resource Server Implementation
- New Architecture of OAuth 2.0 and OpenID Connect Implementation - Explanation about Authlete Architecture
Purpose | Email Address |
---|---|
General | info@authlete.com |
Sales | sales@authlete.com |
PR | pr@authlete.com |
Technical | support@authlete.com |