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

com.authlete.jakarta.GMRequestHandler Maven / Gradle / Ivy

/*
 * Copyright (C) 2021-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;


import java.util.LinkedHashMap;
import java.util.Map;
import jakarta.ws.rs.WebApplicationException;
import jakarta.ws.rs.core.Response;
import com.authlete.common.api.AuthleteApi;
import com.authlete.common.dto.GMRequest;
import com.authlete.common.dto.GMResponse;
import com.authlete.common.dto.GMResponse.Action;


/**
 * Handler for grant management requests.
 *
 * 

* This class can be used to implement the grant management endpoint. *

* * @since 2.37 * * @see Grant Management for OAuth 2.0 */ public class GMRequestHandler extends BaseHandler { /** * Constructor with an implementation of {@link AuthleteApi} interface. * * @param api * Implementation of {@link AuthleteApi} interface. */ public GMRequestHandler(AuthleteApi api) { super(api); } /** * Handle a grant management request. * * @param request * A grant management request. * * @return * A response that should be returned from the grant management * endpoint to the client application. * * @throws WebApplicationException */ public Response handle(GMRequest request) throws WebApplicationException { // Call Authlete's /api/gm API. GMResponse response = getApiCaller().callGm(request); // 'action' in the response denotes the next action which // the implementation of grant management endpoint should take. Action action = response.getAction(); // The content of the response to the client application. String content = response.getResponseContent(); // Additional HTTP headers. Map headers = prepareHeaders(response); // Dispatch according to the action. switch (action) { case OK: // 200 OK return ResponseUtil.ok(content, headers); case NO_CONTENT: // 204 No Content return ResponseUtil.noContent(headers); case UNAUTHORIZED: // 401 Unauthorized return ResponseUtil.unauthorized(content, null, headers); case FORBIDDEN: // 403 Forbidden return ResponseUtil.forbidden(content, headers); case NOT_FOUND: // 404 Not Found return ResponseUtil.notFound(content, headers); case CALLER_ERROR: case AUTHLETE_ERROR: // 500 Internal Server Error return ResponseUtil.internalServerError(content, headers); default: // This should not happen. throw getApiCaller().unknownAction("/api/gm", action); } } private static Map prepareHeaders(GMResponse response) { Map headers = new LinkedHashMap<>(); // DPoP-Nonce String dpopNonce = response.getDpopNonce(); if (dpopNonce != null) { headers.put("DPoP-Nonce", dpopNonce); } return headers; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy