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

com.authlete.jakarta.api.AuthleteApiImpl Maven / Gradle / Ivy

There is a newer version: 2.83
Show newest version
/*
 * Copyright (C) 2014-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.jakarta.api;


import static jakarta.ws.rs.core.HttpHeaders.AUTHORIZATION;
import static jakarta.ws.rs.core.MediaType.APPLICATION_JSON_TYPE;
import java.util.LinkedHashMap;
import java.util.Map;
import jakarta.ws.rs.client.WebTarget;
import jakarta.ws.rs.core.GenericType;
import com.authlete.common.api.AuthleteApi;
import com.authlete.common.api.AuthleteApiException;
import com.authlete.common.conf.AuthleteApiVersion;
import com.authlete.common.conf.AuthleteConfiguration;
import com.authlete.common.dto.*;
import com.authlete.common.types.TokenStatus;
import com.authlete.common.web.BasicCredentials;


/**
 * The implementation of {@link AuthleteApi} using JAX-RS 2.0 client API.
 *
 * @author Takahiko Kawasaki
 *
 *         For Authlete 2.x
 */
public class AuthleteApiImpl extends AuthleteApiJaxrsImpl
{
    private static final String AUTH_AUTHORIZATION_API_PATH                   = "/api/auth/authorization";
    private static final String AUTH_AUTHORIZATION_FAIL_API_PATH              = "/api/auth/authorization/fail";
    private static final String AUTH_AUTHORIZATION_ISSUE_API_PATH             = "/api/auth/authorization/issue";
    private static final String AUTH_AUTHORIZATION_TICKET_INFO_API_PATH       = "/api/auth/authorization/ticket/info";
    private static final String AUTH_AUTHORIZATION_TICKET_UPDATE_API_PATH     = "/api/auth/authorization/ticket/update";
    private static final String AUTH_TOKEN_API_PATH                           = "/api/auth/token";
    private static final String AUTH_TOKEN_CREATE_API_PATH                    = "/api/auth/token/create";
    private static final String AUTH_TOKEN_DELETE_API_PATH                    = "/api/auth/token/delete/%s";
    private static final String AUTH_TOKEN_FAIL_API_PATH                      = "/api/auth/token/fail";
    private static final String AUTH_TOKEN_GET_LIST_API_PATH                  = "/api/auth/token/get/list";
    private static final String AUTH_TOKEN_ISSUE_API_PATH                     = "/api/auth/token/issue";
    private static final String AUTH_TOKEN_REVOKE_API_PATH                    = "/api/auth/token/revoke";
    private static final String AUTH_TOKEN_UPDATE_API_PATH                    = "/api/auth/token/update";
    private static final String AUTH_REVOCATION_API_PATH                      = "/api/auth/revocation";
    private static final String AUTH_USERINFO_API_PATH                        = "/api/auth/userinfo";
    private static final String AUTH_USERINFO_ISSUE_API_PATH                  = "/api/auth/userinfo/issue";
    private static final String AUTH_INTROSPECTION_API_PATH                   = "/api/auth/introspection";
    private static final String AUTH_INTROSPECTION_STANDARD_API_PATH          = "/api/auth/introspection/standard";
    private static final String SERVICE_CONFIGURATION_API_PATH                = "/api/service/configuration";
    private static final String SERVICE_CREATE_API_PATH                       = "/api/service/create";
    private static final String SERVICE_DELETE_API_PATH                       = "/api/service/delete/%d";
    private static final String SERVICE_GET_API_PATH                          = "/api/service/get/%d";
    private static final String SERVICE_GET_LIST_API_PATH                     = "/api/service/get/list";
    private static final String SERVICE_JWKS_GET_API_PATH                     = "/api/service/jwks/get";
    private static final String SERVICE_UPDATE_API_PATH                       = "/api/service/update/%d";
    private static final String CLIENT_CREATE_API_PATH                        = "/api/client/create";
    private static final String CLIENT_REGISTRATION_API_PATH                  = "/api/client/registration";
    private static final String CLIENT_REGISTRATION_GET_API_PATH              = "/api/client/registration/get";
    private static final String CLIENT_REGISTRATION_UPDATE_API_PATH           = "/api/client/registration/update";
    private static final String CLIENT_REGISTRATION_DELETE_API_PATH           = "/api/client/registration/delete";
    private static final String CLIENT_DELETE_API_PATH                        = "/api/client/delete/%s";
    private static final String CLIENT_GET_API_PATH                           = "/api/client/get/%s";
    private static final String CLIENT_GET_LIST_API_PATH                      = "/api/client/get/list";
    private static final String CLIENT_SECRET_REFRESH_API_PATH                = "/api/client/secret/refresh/%s";
    private static final String CLIENT_SECRET_UPDATE_API_PATH                 = "/api/client/secret/update/%s";
    private static final String CLIENT_UPDATE_API_PATH                        = "/api/client/update/%d";
    private static final String REQUESTABLE_SCOPES_DELETE_API_PATH            = "/api/client/extension/requestable_scopes/delete/%d";
    private static final String REQUESTABLE_SCOPES_GET_API_PATH               = "/api/client/extension/requestable_scopes/get/%d";
    private static final String REQUESTABLE_SCOPES_UPDATE_API_PATH            = "/api/client/extension/requestable_scopes/update/%d";
    private static final String GRANTED_SCOPES_GET_API_PATH                   = "/api/client/granted_scopes/get/%d";
    private static final String GRANTED_SCOPES_DELETE_API_PATH                = "/api/client/granted_scopes/delete/%d";
    private static final String CLIENT_AUTHORIZATION_DELETE_API_PATH          = "/api/client/authorization/delete/%d";
    private static final String CLIENT_AUTHORIZATION_GET_LIST_API_PATH        = "/api/client/authorization/get/list";
    private static final String CLIENT_AUTHORIZATION_UPDATE_API_PATH          = "/api/client/authorization/update/%d";
    private static final String JOSE_VERIFY_API_PATH                          = "/api/jose/verify";
    private static final String BACKCHANNEL_AUTHENTICATION_API_PATH           = "/api/backchannel/authentication";
    private static final String BACKCHANNEL_AUTHENTICATION_COMPLETE_API_PATH  = "/api/backchannel/authentication/complete";
    private static final String BACKCHANNEL_AUTHENTICATION_FAIL_API_PATH      = "/api/backchannel/authentication/fail";
    private static final String BACKCHANNEL_AUTHENTICATION_ISSUE_API_PATH     = "/api/backchannel/authentication/issue";
    private static final String DEVICE_AUTHORIZATION_API_PATH                 = "/api/device/authorization";
    private static final String DEVICE_COMPLETE_API_PATH                      = "/api/device/complete";
    private static final String DEVICE_VERIFICATION_API_PATH                  = "/api/device/verification";
    private static final String PUSHED_AUTH_REQ_API_PATH                      = "/api/pushed_auth_req";
    private static final String HSK_CREATE_API_PATH                           = "/api/hsk/create";
    private static final String HSK_DELETE_API_PATH                           = "/api/hsk/delete/%s";
    private static final String HSK_GET_API_PATH                              = "/api/hsk/get/%s";
    private static final String HSK_GET_LIST_API_PATH                         = "/api/hsk/get/list";
    private static final String ECHO_API_PATH                                 = "/api/misc/echo";
    private static final String GM_API_PATH                                   = "/api/gm";
    private static final String CLIENT_LOCK_FLAG_UPDATE_API_PATH              = "/api/client/lock_flag/update/%s";
    private static final String FEDERATION_CONFIGURATION_API_PATH             = "/api/federation/configuration";
    private static final String FEDERATION_REGISTRATION_API_PATH              = "/api/federation/registration";
    private static final String VCI_JWKS_API_PATH                             = "/api/vci/jwks";
    private static final String VCI_JWT_ISSUER_API_PATH                       = "/api/vci/jwtissuer";
    private static final String VCI_METADATA_API_PATH                         = "/api/vci/metadata";
    private static final String VCI_OFFER_CREATE_API_PATH                     = "/api/vci/offer/create";
    private static final String VCI_OFFER_INFO_API_PATH                       = "/api/vci/offer/info";
    private static final String VCI_SINGLE_PARSE_API_PATH                     = "/api/vci/single/parse";
    private static final String VCI_SINGLE_ISSUE_API_PATH                     = "/api/vci/single/issue";
    private static final String VCI_BATCH_PARSE_API_PATH                      = "/api/vci/batch/parse";
    private static final String VCI_BATCH_ISSUE_API_PATH                      = "/api/vci/batch/issue";
    private static final String VCI_DEFERRED_PARSE_API_PATH                   = "/api/vci/deferred/parse";
    private static final String VCI_DEFERRED_ISSUE_API_PATH                   = "/api/vci/deferred/issue";
    private static final String ID_TOKEN_REISSUE_API_PATH                     = "/api/idtoken/reissue";


    private final String mServiceOwnerAuth;
    private final String mServiceAuth;

    /**
     * The constructor with an instance of {@link AuthleteConfiguration}.
     *
     * 

* The existence of a constructor of this type is a required by * {@link com.authlete.common.api.AuthleteApiFactory AuthleteApiFactory}. *

* * @param configuration * An instance of {@link AuthleteConfiguration}. */ public AuthleteApiImpl(AuthleteConfiguration configuration) { super(configuration); // Authlete API version specified by the configuration. AuthleteApiVersion version = AuthleteApiVersion.parse(configuration.getApiVersion()); if (version != null && version != AuthleteApiVersion.V2) { throw new IllegalArgumentException("Configuration must be set to V2 for this implementation."); } mServiceOwnerAuth = createServiceOwnerCredentials(configuration); mServiceAuth = createServiceCredentials(configuration); } /** * Create an authorization header for the service owner. */ private String createServiceOwnerCredentials(AuthleteConfiguration configuration) { if (configuration.getServiceOwnerAccessToken() != null) { if (isDpopEnabled()) { return "DPoP " + configuration.getServiceOwnerAccessToken(); } else { return "Bearer " + configuration.getServiceOwnerAccessToken(); } } else { String key = configuration.getServiceOwnerApiKey(); String secret = configuration.getServiceOwnerApiSecret(); return new BasicCredentials(key, secret).format(); } } /** * Create an authorization header for the service. */ private String createServiceCredentials(AuthleteConfiguration configuration) { if (configuration.getServiceAccessToken() != null) { if (isDpopEnabled()) { return "DPoP " + configuration.getServiceAccessToken(); } else { return "Bearer " + configuration.getServiceAccessToken(); } } else { String key = configuration.getServiceApiKey(); String secret = configuration.getServiceApiSecret(); return new BasicCredentials(key, secret).format(); } } private TResponse callServiceOwnerGetApi( String path, Class responseClass, Map params) { return callGetApi(mServiceOwnerAuth, path, responseClass, params); } private TResponse callServiceGetApi( String path, Class responseClass, Map params) { return callGetApi(mServiceAuth, path, responseClass, params); } private Void callServiceOwnerDeleteApi(String path) { return callDeleteApi(mServiceOwnerAuth, path); } private Void callServiceDeleteApi(String path) { return callDeleteApi(mServiceAuth, path); } private TResponse callServiceOwnerPostApi(String path, Object request, Class responseClass) { return callPostApi(mServiceOwnerAuth, path, request, responseClass); } private TResponse callServicePostApi(String path, Object request, Class responseClass) { return callPostApi(mServiceAuth, path, request, responseClass); } private static abstract class ApiCaller implements AuthleteApiCall { protected final String mPath; protected final Object mRequest; protected final Class mResponseClass; protected final Map mParams = new LinkedHashMap<>(); ApiCaller(Class responseClass, Object request, String path) { mPath = path; mRequest = request; mResponseClass = responseClass; } ApiCaller(Class responseClass, Object request, String format, Object... args) { this(responseClass, request, String.format(format, args)); } public ApiCaller addParam(String name, Object... values) { mParams.put(name, values); return this; } } private class ServiceOwnerDeleteApiCaller extends ApiCaller { ServiceOwnerDeleteApiCaller(String path) { super(Void.class, null, path); } ServiceOwnerDeleteApiCaller(String format, Object... args) { super(Void.class, null, format, args); } @Override public Void call() { return callServiceOwnerDeleteApi(mPath); } } private class ServiceOwnerGetApiCaller extends ApiCaller { ServiceOwnerGetApiCaller(Class responseClass, String path) { super(responseClass, null, path); } ServiceOwnerGetApiCaller(Class responseClass, String format, Object... args) { super(responseClass, null, format, args); } @Override public TResponse call() { return callServiceOwnerGetApi(mPath, mResponseClass, mParams); } } private class ServiceOwnerPostApiCaller extends ApiCaller { ServiceOwnerPostApiCaller(Class responseClass, Object request, String path) { super(responseClass, request, path); } ServiceOwnerPostApiCaller(Class responseClass, Object request, String format, Object... args) { super(responseClass, request, format, args); } @Override public TResponse call() { return callServiceOwnerPostApi(mPath, mRequest, mResponseClass); } } private class ServiceDeleteApiCaller extends ApiCaller { ServiceDeleteApiCaller(String path) { super(Void.class, null, path); } ServiceDeleteApiCaller(String format, Object... args) { super(Void.class, null, format, args); } @Override public Void call() { return callServiceDeleteApi(mPath); } } private class ServiceGetApiCaller extends ApiCaller { ServiceGetApiCaller(Class responseClass, String path) { super(responseClass, null, path); } ServiceGetApiCaller(Class responseClass, String format, Object... args) { super(responseClass, null, format, args); } @Override public TResponse call() { return callServiceGetApi(mPath, mResponseClass, mParams); } } private class ServicePostApiCaller extends ApiCaller { ServicePostApiCaller(Class responseClass, Object request, String path) { super(responseClass, request, path); } ServicePostApiCaller(Class responseClass, Object request, String format, Object... args) { super(responseClass, request, format, args); } @Override public TResponse call() { return callServicePostApi(mPath, mRequest, mResponseClass); } } /** * Call {@code /api/auth/authorization} API. */ @Override public AuthorizationResponse authorization(AuthorizationRequest request) throws AuthleteApiException { return executeApiCall( new ServicePostApiCaller( AuthorizationResponse.class, request, AUTH_AUTHORIZATION_API_PATH)); } /** * Call {@code /api/auth/authorization/fail} API. */ @Override public AuthorizationFailResponse authorizationFail(AuthorizationFailRequest request) throws AuthleteApiException { return executeApiCall( new ServicePostApiCaller( AuthorizationFailResponse.class, request, AUTH_AUTHORIZATION_FAIL_API_PATH)); } /** * Call {@code /api/auth/authorization/issue} API. */ @Override public AuthorizationIssueResponse authorizationIssue(AuthorizationIssueRequest request) throws AuthleteApiException { return executeApiCall( new ServicePostApiCaller( AuthorizationIssueResponse.class, request, AUTH_AUTHORIZATION_ISSUE_API_PATH)); } /** * Call {@code /api/auth/token} API. */ @Override public TokenResponse token(TokenRequest request) throws AuthleteApiException { return executeApiCall( new ServicePostApiCaller( TokenResponse.class, request, AUTH_TOKEN_API_PATH)); } /** * Call {@code /api/auth/token/create} API. */ @Override public TokenCreateResponse tokenCreate(TokenCreateRequest request) throws AuthleteApiException { return executeApiCall( new ServicePostApiCaller( TokenCreateResponse.class, request, AUTH_TOKEN_CREATE_API_PATH)); } /** * Call /api/auth/token/delete/{token} API. */ @Override public void tokenDelete(String token) throws AuthleteApiException { executeApiCall( new ServiceDeleteApiCaller( AUTH_TOKEN_DELETE_API_PATH, token)); } /** * Call {@code /api/auth/token/fail} API. */ @Override public TokenFailResponse tokenFail(TokenFailRequest request) throws AuthleteApiException { return executeApiCall( new ServicePostApiCaller( TokenFailResponse.class, request, AUTH_TOKEN_FAIL_API_PATH)); } /** * Call {@code /api/auth/token/issue} API. */ @Override public TokenIssueResponse tokenIssue(TokenIssueRequest request) throws AuthleteApiException { return executeApiCall( new ServicePostApiCaller( TokenIssueResponse.class, request, AUTH_TOKEN_ISSUE_API_PATH)); } /** * Call {@code /api/auth/token/revoke} API. */ @Override public TokenRevokeResponse tokenRevoke(TokenRevokeRequest request) throws AuthleteApiException { return executeApiCall( new ServicePostApiCaller( TokenRevokeResponse.class, request, AUTH_TOKEN_REVOKE_API_PATH)); } /** * Call {@code /api/auth/token/update} API. */ @Override public TokenUpdateResponse tokenUpdate(TokenUpdateRequest request) throws AuthleteApiException { return executeApiCall( new ServicePostApiCaller( TokenUpdateResponse.class, request, AUTH_TOKEN_UPDATE_API_PATH)); } @Override public TokenListResponse getTokenList() throws AuthleteApiException { return getTokenList(null, null, 0, 0, false, TokenStatus.ALL); } @Override public TokenListResponse getTokenList(TokenStatus tokenStatus) throws AuthleteApiException { return getTokenList(null, null, 0, 0, false, tokenStatus); } @Override public TokenListResponse getTokenList(String clientIdentifier, String subject) throws AuthleteApiException { return getTokenList(clientIdentifier, subject, 0, 0, false, TokenStatus.ALL); } @Override public TokenListResponse getTokenList(String clientIdentifier, String subject, TokenStatus tokenStatus) throws AuthleteApiException { return getTokenList(clientIdentifier, subject, 0, 0, false, tokenStatus); } @Override public TokenListResponse getTokenList(int start, int end) throws AuthleteApiException { return getTokenList(null, null, start, end, true, TokenStatus.ALL); } @Override public TokenListResponse getTokenList(int start, int end, TokenStatus tokenStatus) throws AuthleteApiException { return getTokenList(null, null, start, end, true, tokenStatus); } @Override public TokenListResponse getTokenList(String clientIdentifier, String subject, int start, int end) throws AuthleteApiException { return getTokenList(clientIdentifier, subject, start, end, true, TokenStatus.ALL); } @Override public TokenListResponse getTokenList(String clientIdentifier, String subject, int start, int end, TokenStatus tokenStatus) throws AuthleteApiException { return getTokenList(clientIdentifier, subject, start, end, true, tokenStatus); } private TokenListResponse getTokenList( final String clientIdentifier, final String subject, final int start, final int end, final boolean rangeGiven, TokenStatus tokenStatus) throws AuthleteApiException { return executeApiCall(new AuthleteApiCall() { @Override public TokenListResponse call() { return callGetTokenList(clientIdentifier, subject, start, end, rangeGiven, tokenStatus); } }); } private TokenListResponse callGetTokenList( String clientIdentifier, String subject, int start, int end, boolean rangeGiven, TokenStatus tokenStatus) { WebTarget target = getTarget().path(AUTH_TOKEN_GET_LIST_API_PATH); if (clientIdentifier != null) { target = target.queryParam("clientIdentifier", clientIdentifier); } if (subject != null) { target = target.queryParam("subject", subject); } if (rangeGiven) { target = target.queryParam("start", start).queryParam("end", end); } target = target.queryParam("tokenStatus", tokenStatus.toString()); return wrapWithDpop(target .request(APPLICATION_JSON_TYPE), AUTH_TOKEN_GET_LIST_API_PATH, "GET") .header(AUTHORIZATION, mServiceAuth) .get(TokenListResponse.class); } /** * Call {@code /api/auth/revocation} API. */ @Override public RevocationResponse revocation(RevocationRequest request) throws AuthleteApiException { return executeApiCall( new ServicePostApiCaller( RevocationResponse.class, request, AUTH_REVOCATION_API_PATH)); } /** * Call {@code /api/auth/userinfo} API. */ @Override public UserInfoResponse userinfo(UserInfoRequest request) throws AuthleteApiException { return executeApiCall( new ServicePostApiCaller( UserInfoResponse.class, request, AUTH_USERINFO_API_PATH)); } /** * Call {@code /api/auth/userinfo/issue} API. */ @Override public UserInfoIssueResponse userinfoIssue(UserInfoIssueRequest request) throws AuthleteApiException { return executeApiCall( new ServicePostApiCaller( UserInfoIssueResponse.class, request, AUTH_USERINFO_ISSUE_API_PATH)); } /** * Call {@code /api/auth/introspection} API. */ @Override public IntrospectionResponse introspection(IntrospectionRequest request) throws AuthleteApiException { return executeApiCall( new ServicePostApiCaller( IntrospectionResponse.class, request, AUTH_INTROSPECTION_API_PATH)); } /** * Call {@code /api/auth/introspection/standard} API. */ @Override public StandardIntrospectionResponse standardIntrospection( StandardIntrospectionRequest request) throws AuthleteApiException { return executeApiCall( new ServicePostApiCaller( StandardIntrospectionResponse.class, request, AUTH_INTROSPECTION_STANDARD_API_PATH)); } /** * Call {@code /api/service/create} API. */ @Override public Service createService(Service service) throws AuthleteApiException { return executeApiCall( new ServiceOwnerPostApiCaller( Service.class, service, SERVICE_CREATE_API_PATH)); } /** * Call {@code /api/service/create} API. */ @Override @Deprecated public Service createServie(Service service) throws AuthleteApiException { return createService(service); } /** * Call /api/service/delete/{serviceApiKey} API. */ @Override public void deleteService(long apiKey) throws AuthleteApiException { executeApiCall( new ServiceOwnerDeleteApiCaller( SERVICE_DELETE_API_PATH, apiKey)); } /** * Call /api/service/get/{serviceApiKey} API. */ @Override public Service getService(long apiKey) throws AuthleteApiException { return executeApiCall( new ServiceOwnerGetApiCaller( Service.class, SERVICE_GET_API_PATH, apiKey)); } /** * Call {@code /api/service/get/list} API. */ @Override public ServiceListResponse getServiceList() throws AuthleteApiException { return getServiceList(0, 0, false); } @Override public ServiceListResponse getServiceList(int start, int end) throws AuthleteApiException { return getServiceList(start, end, true); } private ServiceListResponse getServiceList( final int start, final int end, final boolean rangeGiven) throws AuthleteApiException { return executeApiCall(new AuthleteApiCall() { @Override public ServiceListResponse call() { return callGetServiceList(start, end, rangeGiven); } }); } /** * Call /service/get/list. */ private ServiceListResponse callGetServiceList(int start, int end, boolean rangeGiven) { WebTarget target = getTarget().path(SERVICE_GET_LIST_API_PATH); if (rangeGiven) { target = target.queryParam("start", start).queryParam("end", end); } return wrapWithDpop(target .request(APPLICATION_JSON_TYPE), SERVICE_GET_LIST_API_PATH, "GET") .header(AUTHORIZATION, mServiceOwnerAuth) .get(ServiceListResponse.class); } /** * Call /api/service/update/{serviceApiKey} API. */ @Override public Service updateService(final Service service) throws AuthleteApiException { return executeApiCall( new ServiceOwnerPostApiCaller( Service.class, service, SERVICE_UPDATE_API_PATH, service.getApiKey())); } /** * Call {@code /api/service/jwks/get} API */ @Override public String getServiceJwks() throws AuthleteApiException { return executeApiCall( new ServiceGetApiCaller( String.class, SERVICE_JWKS_GET_API_PATH)); } /** * Call {@code /api/service/jwks/get} API */ @Override public String getServiceJwks(boolean pretty, boolean includePrivateKeys) throws AuthleteApiException { return executeApiCall( new ServiceGetApiCaller( String.class, SERVICE_JWKS_GET_API_PATH) .addParam("pretty", pretty) .addParam("includePrivateKeys", includePrivateKeys)); } /** * Call {@code /api/service/configuration} API */ @Override public String getServiceConfiguration() throws AuthleteApiException { return executeApiCall( new ServiceGetApiCaller( String.class, SERVICE_CONFIGURATION_API_PATH)); } /** * Call {@code /api/service/configuration} API */ @Override public String getServiceConfiguration(boolean pretty) throws AuthleteApiException { return executeApiCall( new ServiceGetApiCaller( String.class, SERVICE_CONFIGURATION_API_PATH) .addParam("pretty", pretty)); } /** * Call {@code /api/service/configuration} API */ @Override public String getServiceConfiguration(ServiceConfigurationRequest request) throws AuthleteApiException { return executeApiCall( new ServicePostApiCaller( String.class, request, SERVICE_CONFIGURATION_API_PATH)); } /** * Call {@code /api/client/create} API. */ @Override public Client createClient(Client client) throws AuthleteApiException { return executeApiCall( new ServicePostApiCaller( Client.class, client, CLIENT_CREATE_API_PATH)); } /** * Call {@code /api/client/registration} API. */ @Override public ClientRegistrationResponse dynamicClientRegister(ClientRegistrationRequest request) throws AuthleteApiException { return executeApiCall( new ServicePostApiCaller( ClientRegistrationResponse.class, request, CLIENT_REGISTRATION_API_PATH)); } /** * Call {@code /api/client/registration/get} API. */ @Override public ClientRegistrationResponse dynamicClientGet(ClientRegistrationRequest request) throws AuthleteApiException { return executeApiCall( new ServicePostApiCaller( ClientRegistrationResponse.class, request, CLIENT_REGISTRATION_GET_API_PATH)); } /** * Call {@code /api/client/registration/update} API. */ @Override public ClientRegistrationResponse dynamicClientUpdate(ClientRegistrationRequest request) throws AuthleteApiException { return executeApiCall( new ServicePostApiCaller( ClientRegistrationResponse.class, request, CLIENT_REGISTRATION_UPDATE_API_PATH)); } /** * Call {@code /api/client/registration/delete} API. */ @Override public ClientRegistrationResponse dynamicClientDelete(ClientRegistrationRequest request) throws AuthleteApiException { return executeApiCall( new ServicePostApiCaller( ClientRegistrationResponse.class, request, CLIENT_REGISTRATION_DELETE_API_PATH)); } /** * Call /api/client/delete/{clientId} API. */ @Override public void deleteClient(long clientId) throws AuthleteApiException { deleteClient(String.valueOf(clientId)); } /** * Call /api/client/delete/{clientId} API. */ @Override public void deleteClient(String clientId) throws AuthleteApiException { executeApiCall( new ServiceDeleteApiCaller( CLIENT_DELETE_API_PATH, clientId)); } /** * Call /api/client/get/{clientId} API. */ @Override public Client getClient(long clientId) throws AuthleteApiException { return getClient(String.valueOf(clientId)); } /** * Call /api/client/get/{clientId} API. */ @Override public Client getClient(String clientId) throws AuthleteApiException { return executeApiCall( new ServiceGetApiCaller( Client.class, CLIENT_GET_API_PATH, clientId)); } /** * Call {@code /api/client/get/list} API. */ @Override public ClientListResponse getClientList() throws AuthleteApiException { return getClientList(null, 0, 0, false); } @Override public ClientListResponse getClientList(String developer) throws AuthleteApiException { return getClientList(developer, 0, 0, false); } @Override public ClientListResponse getClientList(int start, int end) throws AuthleteApiException { return getClientList(null, start, end, true); } @Override public ClientListResponse getClientList(String developer, int start, int end) throws AuthleteApiException { return getClientList(developer, start, end, true); } private ClientListResponse getClientList( final String developer, final int start, final int end, final boolean rangeGiven) throws AuthleteApiException { return executeApiCall(new AuthleteApiCall() { @Override public ClientListResponse call() { return callGetClientList(developer, start, end, rangeGiven); } }); } private ClientListResponse callGetClientList(String developer, int start, int end, boolean rangeGiven) { WebTarget target = getTarget().path(CLIENT_GET_LIST_API_PATH); if (developer != null) { target = target.queryParam("developer", developer); } if (rangeGiven) { target = target.queryParam("start", start).queryParam("end", end); } return wrapWithDpop(target .request(APPLICATION_JSON_TYPE), CLIENT_GET_LIST_API_PATH, "GET") .header(AUTHORIZATION, mServiceAuth) .get(ClientListResponse.class); } /** * Call /api/client/update/{clientId} API. */ @Override public Client updateClient(Client client) throws AuthleteApiException { return executeApiCall( new ServicePostApiCaller( Client.class, client, CLIENT_UPDATE_API_PATH, client.getClientId())); } /** * Call /api/client/extension/requestable_scopes/get/{clientId} API. */ @Override public String[] getRequestableScopes(long clientId) throws AuthleteApiException { // Call the API. RequestableScopes response = executeApiCall( new ServiceGetApiCaller( RequestableScopes.class, REQUESTABLE_SCOPES_GET_API_PATH, clientId)); if (response != null) { // Extract 'requestableScopes' from the response. return response.getRequestableScopes(); } else { return null; } } @Override public String[] setRequestableScopes(long clientId, String[] scopes) throws AuthleteApiException { // Prepare a request body. RequestableScopes request = new RequestableScopes().setRequestableScopes(scopes); // Call the API. RequestableScopes response = executeApiCall( new ServicePostApiCaller( RequestableScopes.class, request, REQUESTABLE_SCOPES_UPDATE_API_PATH, clientId)); if (response != null) { // Extract 'requestableScopes' from the response. return response.getRequestableScopes(); } else { return null; } } /** * Call /api/client/extension/requestable_scopes/delete/{clientId} API. */ @Override public void deleteRequestableScopes(long clientId) throws AuthleteApiException { executeApiCall( new ServiceDeleteApiCaller( REQUESTABLE_SCOPES_DELETE_API_PATH, clientId)); } @Override public GrantedScopesGetResponse getGrantedScopes(long clientId, String subject) { // Prepare a request body. GrantedScopesRequest request = new GrantedScopesRequest(subject); // Call the API. return executeApiCall( new ServicePostApiCaller( GrantedScopesGetResponse.class, request, GRANTED_SCOPES_GET_API_PATH, clientId)); } @Override public void deleteGrantedScopes(long clientId, String subject) { // Prepare a request body. GrantedScopesRequest request = new GrantedScopesRequest(subject); executeApiCall( new ServicePostApiCaller( ApiResponse.class, request, GRANTED_SCOPES_DELETE_API_PATH, clientId)); } private static final class GrantedScopesRequest { private String subject; public GrantedScopesRequest(String subject) { this.subject = subject; } @SuppressWarnings("unused") public String getSubject() { return subject; } @SuppressWarnings("unused") public void setSubject(String subject) { this.subject = subject; } } @Override public void deleteClientAuthorization(long clientId, String subject) throws AuthleteApiException { // Prepare a request body. ClientAuthorizationDeleteRequest request = new ClientAuthorizationDeleteRequest(subject); executeApiCall( new ServicePostApiCaller( ApiResponse.class, request, CLIENT_AUTHORIZATION_DELETE_API_PATH, clientId)); } @Override public AuthorizedClientListResponse getClientAuthorizationList(ClientAuthorizationGetListRequest request) throws AuthleteApiException { return executeApiCall( new ServicePostApiCaller( AuthorizedClientListResponse.class, request, CLIENT_AUTHORIZATION_GET_LIST_API_PATH)); } @Override public void updateClientAuthorization(long clientId, ClientAuthorizationUpdateRequest request) throws AuthleteApiException { executeApiCall( new ServicePostApiCaller( ApiResponse.class, request, CLIENT_AUTHORIZATION_UPDATE_API_PATH, clientId)); } @Override public ClientSecretRefreshResponse refreshClientSecret(long clientId) throws AuthleteApiException { return refreshClientSecret(String.valueOf(clientId)); } @Override public ClientSecretRefreshResponse refreshClientSecret(String clientIdentifier) throws AuthleteApiException { return executeApiCall( new ServiceGetApiCaller( ClientSecretRefreshResponse.class, CLIENT_SECRET_REFRESH_API_PATH, clientIdentifier)); } @Override public ClientSecretUpdateResponse updateClientSecret(long clientId, String clientSecret) throws AuthleteApiException { return updateClientSecret(String.valueOf(clientId), clientSecret); } @Override public ClientSecretUpdateResponse updateClientSecret(String clientIdentifier, String clientSecret) throws AuthleteApiException { // Prepare a request body. setClientSecret(String) method // throws IllegalArgumentException if the given client secret // does not comply with the format. ClientSecretUpdateRequest request = new ClientSecretUpdateRequest().setClientSecret(clientSecret); return executeApiCall( new ServicePostApiCaller( ClientSecretUpdateResponse.class, request, CLIENT_SECRET_UPDATE_API_PATH, clientIdentifier)); } /** * Call {@code /api/jose/verify} API. */ @Override public JoseVerifyResponse verifyJose(JoseVerifyRequest request) throws AuthleteApiException { return executeApiCall( new ServicePostApiCaller( JoseVerifyResponse.class, request, JOSE_VERIFY_API_PATH)); } /** * Call {@code /api/backchannel/authentication} API. */ @Override public BackchannelAuthenticationResponse backchannelAuthentication(BackchannelAuthenticationRequest request) throws AuthleteApiException { return executeApiCall( new ServicePostApiCaller( BackchannelAuthenticationResponse.class, request, BACKCHANNEL_AUTHENTICATION_API_PATH)); } /** * Call {@code /api/backchannel/authentication/issue} API. */ @Override public BackchannelAuthenticationIssueResponse backchannelAuthenticationIssue(BackchannelAuthenticationIssueRequest request) throws AuthleteApiException { return executeApiCall( new ServicePostApiCaller( BackchannelAuthenticationIssueResponse.class, request, BACKCHANNEL_AUTHENTICATION_ISSUE_API_PATH)); } /** * Call {@code /api/backchannel/authentication/fail} API. */ @Override public BackchannelAuthenticationFailResponse backchannelAuthenticationFail(BackchannelAuthenticationFailRequest request) throws AuthleteApiException { return executeApiCall( new ServicePostApiCaller( BackchannelAuthenticationFailResponse.class, request, BACKCHANNEL_AUTHENTICATION_FAIL_API_PATH)); } /** * Call {@code /api/backchannel/authentication/complete} API. */ @Override public BackchannelAuthenticationCompleteResponse backchannelAuthenticationComplete(BackchannelAuthenticationCompleteRequest request) throws AuthleteApiException { return executeApiCall( new ServicePostApiCaller( BackchannelAuthenticationCompleteResponse.class, request, BACKCHANNEL_AUTHENTICATION_COMPLETE_API_PATH)); } /** * Call {@code /api/device/authorization} API. */ @Override public DeviceAuthorizationResponse deviceAuthorization(DeviceAuthorizationRequest request) throws AuthleteApiException { return executeApiCall( new ServicePostApiCaller( DeviceAuthorizationResponse.class, request, DEVICE_AUTHORIZATION_API_PATH)); } /** * Call {@code /api/device/complete} API. */ @Override public DeviceCompleteResponse deviceComplete(DeviceCompleteRequest request) throws AuthleteApiException { return executeApiCall( new ServicePostApiCaller( DeviceCompleteResponse.class, request, DEVICE_COMPLETE_API_PATH)); } /** * Call {@code /api/device/verification} API. */ @Override public DeviceVerificationResponse deviceVerification(DeviceVerificationRequest request) throws AuthleteApiException { return executeApiCall( new ServicePostApiCaller( DeviceVerificationResponse.class, request, DEVICE_VERIFICATION_API_PATH)); } @Override public PushedAuthReqResponse pushAuthorizationRequest(PushedAuthReqRequest request) throws AuthleteApiException { return executeApiCall( new ServicePostApiCaller( PushedAuthReqResponse.class, request, PUSHED_AUTH_REQ_API_PATH)); } @Override public HskResponse hskCreate(HskCreateRequest request) throws AuthleteApiException { return executeApiCall( new ServicePostApiCaller( HskResponse.class, request, HSK_CREATE_API_PATH)); } @Override public HskResponse hskDelete(String handle) throws AuthleteApiException { return executeApiCall( new ServiceGetApiCaller( HskResponse.class, HSK_DELETE_API_PATH, handle)); } @Override public HskResponse hskGet(String handle) throws AuthleteApiException { return executeApiCall( new ServiceGetApiCaller( HskResponse.class, HSK_GET_API_PATH, handle)); } @Override public HskListResponse hskGetList() throws AuthleteApiException { return executeApiCall( new ServiceGetApiCaller( HskListResponse.class, HSK_GET_LIST_API_PATH)); } @Override public Map echo(Map parameters) throws AuthleteApiException { return executeApiCall(new AuthleteApiCall>() { @Override public Map call() { return callEcho(parameters); } }); } private Map callEcho(Map parameters) { WebTarget target = getTarget().path(ECHO_API_PATH); if (parameters != null) { for (Map.Entry entry : parameters.entrySet()) { target = target.queryParam(entry.getKey(), entry.getValue()); } } // The API does not require any authentication, so the code below // does not include '.header(AUTHORIZATION, ...)'. return target .request(APPLICATION_JSON_TYPE) .get(new GenericType>(){}); } @Override public GMResponse gm(GMRequest request) throws AuthleteApiException { return executeApiCall( new ServicePostApiCaller( GMResponse.class, request, GM_API_PATH)); } @Override public void updateClientLockFlag( String clientIdentifier, boolean clientLocked) throws AuthleteApiException { // Prepare a request body. ClientLockFlagUpdateRequest request = new ClientLockFlagUpdateRequest().setClientLocked(clientLocked); executeApiCall( new ServicePostApiCaller( ApiResponse.class, request, CLIENT_LOCK_FLAG_UPDATE_API_PATH, clientIdentifier)); } @Override public FederationConfigurationResponse federationConfiguration( FederationConfigurationRequest request) throws AuthleteApiException { return executeApiCall( new ServicePostApiCaller( FederationConfigurationResponse.class, request, FEDERATION_CONFIGURATION_API_PATH)); } @Override public FederationRegistrationResponse federationRegistration( FederationRegistrationRequest request) throws AuthleteApiException { return executeApiCall( new ServicePostApiCaller( FederationRegistrationResponse.class, request, FEDERATION_REGISTRATION_API_PATH)); } @Override public CredentialIssuerMetadataResponse credentialIssuerMetadata( CredentialIssuerMetadataRequest request) throws AuthleteApiException { // Note that the /vci/metadata API is not available in Authlete 2.x, // so the executeApiCall below will throw an exception. return executeApiCall( new ServicePostApiCaller( CredentialIssuerMetadataResponse.class, request, VCI_METADATA_API_PATH)); } @Override public CredentialJwtIssuerMetadataResponse credentialJwtIssuerMetadata( CredentialJwtIssuerMetadataRequest request) throws AuthleteApiException { // Note that the /vci/jwtissuer API is not available in Authlete 2.x, // so the executeApiCall below will throw an exception. return executeApiCall( new ServicePostApiCaller( CredentialJwtIssuerMetadataResponse.class, request, VCI_JWT_ISSUER_API_PATH)); } @Override public CredentialIssuerJwksResponse credentialIssuerJwks( CredentialIssuerJwksRequest request) throws AuthleteApiException { // Note that the /vci/jwks API is not available in Authlete 2.x, // so the executeApiCall below will throw an exception. return executeApiCall( new ServicePostApiCaller( CredentialIssuerJwksResponse.class, request, VCI_JWKS_API_PATH)); } @Override public CredentialOfferCreateResponse credentialOfferCreate( CredentialOfferCreateRequest request) throws AuthleteApiException { // Note that the /vci/offer/create API is not available in Authlete 2.x, // so the executeApiCall below will throw an exception. return executeApiCall( new ServicePostApiCaller( CredentialOfferCreateResponse.class, request, VCI_OFFER_CREATE_API_PATH)); } @Override public CredentialOfferInfoResponse credentialOfferInfo( CredentialOfferInfoRequest request) throws AuthleteApiException { // Note that the /vci/offer/info API is not available in Authlete 2.x, // so the executeApiCall below will throw an exception. return executeApiCall( new ServicePostApiCaller( CredentialOfferInfoResponse.class, request, VCI_OFFER_INFO_API_PATH)); } @Override public CredentialSingleParseResponse credentialSingleParse( CredentialSingleParseRequest request) throws AuthleteApiException { // Note that the /vci/single/parse API is not available in Authlete 2.x, // so the executeApiCall below will throw an exception. return executeApiCall( new ServicePostApiCaller( CredentialSingleParseResponse.class, request, VCI_SINGLE_PARSE_API_PATH)); } @Override public CredentialSingleIssueResponse credentialSingleIssue( CredentialSingleIssueRequest request) throws AuthleteApiException { // Note that the /vci/single/issue API is not available in Authlete 2.x, // so the executeApiCall below will throw an exception. return executeApiCall( new ServicePostApiCaller( CredentialSingleIssueResponse.class, request, VCI_SINGLE_ISSUE_API_PATH)); } @Override public CredentialBatchParseResponse credentialBatchParse( CredentialBatchParseRequest request) throws AuthleteApiException { // Note that the /vci/batch/parse API is not available in Authlete 2.x, // so the executeApiCall below will throw an exception. return executeApiCall( new ServicePostApiCaller( CredentialBatchParseResponse.class, request, VCI_BATCH_PARSE_API_PATH)); } @Override public CredentialBatchIssueResponse credentialBatchIssue( CredentialBatchIssueRequest request) throws AuthleteApiException { // Note that the /vci/batch/issue API is not available in Authlete 2.x, // so the executeApiCall below will throw an exception. return executeApiCall( new ServicePostApiCaller( CredentialBatchIssueResponse.class, request, VCI_BATCH_ISSUE_API_PATH)); } @Override public CredentialDeferredParseResponse credentialDeferredParse( CredentialDeferredParseRequest request) throws AuthleteApiException { // Note that the /vci/deferred/parse API is not available in Authlete 2.x, // so the executeApiCall below will throw an exception. return executeApiCall( new ServicePostApiCaller( CredentialDeferredParseResponse.class, request, VCI_DEFERRED_PARSE_API_PATH)); } @Override public CredentialDeferredIssueResponse credentialDeferredIssue( CredentialDeferredIssueRequest request) throws AuthleteApiException { // Note that the /vci/deferred/issue API is not available in Authlete 2.x, // so the executeApiCall below will throw an exception. return executeApiCall( new ServicePostApiCaller( CredentialDeferredIssueResponse.class, request, VCI_DEFERRED_ISSUE_API_PATH)); } @Override public IDTokenReissueResponse idTokenReissue( IDTokenReissueRequest request) throws AuthleteApiException { return executeApiCall( new ServicePostApiCaller( IDTokenReissueResponse.class, request, ID_TOKEN_REISSUE_API_PATH)); } @Override public AuthorizationTicketInfoResponse authorizationTicketInfo( AuthorizationTicketInfoRequest request) throws AuthleteApiException { // Note that the /auth/authorization/ticket/info API is not available // in Authlete 2.x, so the executeApiCall below will throw an exception. return executeApiCall( new ServicePostApiCaller( AuthorizationTicketInfoResponse.class, request, AUTH_AUTHORIZATION_TICKET_INFO_API_PATH)); } @Override public AuthorizationTicketUpdateResponse authorizationTicketUpdate( AuthorizationTicketUpdateRequest request) throws AuthleteApiException { // Note that the /auth/authorization/ticket/update API is not available // in Authlete 2.x, so the executeApiCall below will throw an exception. return executeApiCall( new ServicePostApiCaller( AuthorizationTicketUpdateResponse.class, request, AUTH_AUTHORIZATION_TICKET_UPDATE_API_PATH)); } @Override public TokenCreateBatchResponse tokenCreateBatch( TokenCreateRequest[] tokenCreateRequests, boolean dryRun) throws AuthleteApiException { throw new AuthleteApiException( "This method can't be invoked since the corresponding API is not supported."); } @Override public TokenCreateBatchStatusResponse getTokenCreateBatchStatus( String requestId) throws AuthleteApiException { throw new AuthleteApiException( "This method can't be invoked since the corresponding API is not supported."); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy