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

com.authlete.common.dto.StandardIntrospectionResponse Maven / Gradle / Ivy

/*
 * Copyright (C) 2017 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.common.dto;


import com.authlete.common.api.AuthleteApi;


/**
 * Response from Authlete's {@code /api/auth/introspection/standard} API.
 * Note that the API and {@code /api/auth/introspection} API are different.
 * {@code /api/auth/introspection/standard} API exists to help your
 * authorization server provide its own introspection API which complies
 * with RFC 7662 (OAuth
 * 2.0 Token Introspection).
 *
 * 

* Authlete's {@code /api/auth/introspection/standard} API returns JSON * which can be mapped to this class. The implementation of the * introspection endpoint of your authorization server should retrieve the * value of {@code "action"} from the response and take the following steps * according to the value. *

* *
*
{@link Action#INTERNAL_SERVER_ERROR INTERNAL_SERVER_ERROR}
*
*

* When the value of {@code "action"} is {@code "INTERNAL_SERVER_ERROR"}, * it means that the request from your system to Authlete * ({@link StandardIntrospectionRequest}) was wrong or that an error * occurred in Authlete. *

* *

* In either case, from the viewpoint of the client application, it is an * error on the server side. Therefore, the introspection endpoint of * your authorization server should generate a response to the client * application with the HTTP status of {@code "500 Internal Server Error"}. *

* *

* {@link #getResponseContent()} returns a JSON string which describes * the error, so it can be used as the entity body of the response if * you want. Note that, however, RFC 7662 does not mention * anything about the response body of error responses. *

* *

* The following illustrates an example response which the introspection * endpoint of your authorization server generates and returns to the * client application. *

* *
 * HTTP/1.1 500 Internal Server Error
 * Content-Type: application/json
 *
 * (The value returned from {@link #getResponseContent()})
*
* *
{@link Action#BAD_REQUEST BAD_REQUEST}
*
*

* When the value of {@code "action"} is {@code "BAD_REQUEST"}, it means * that the request from the client application is invalid. This happens * when the request from the client did not include the {@code token} * request parameter. See "2.1. Introspection * Request" in RFC 7662 for details about requirements for * introspection requests. *

* *

* The HTTP status of the response returned to the client application * should be {@code "400 Bad Request"}. *

* *

* {@link #getResponseContent()} returns a JSON string which describes * the error, so it can be used as the entity body of the response if * you want. Note that, however, RFC 7662 does not mention * anything about the response body of error responses. *

* *

* The following illustrates an example response which the introspection * endpoint of your authorization server generates and returns to the * client application. *

* *
 * HTTP/1.1 400 Bad Request
 * Content-Type: application/json
 *
 * (The value returned from {@link #getResponseContent()})
*
* *
{@link Action#OK OK}
*
*

* When the value of {@code "action"} is {@code "OK"}, it means that * the request from the client application is valid. *

* *

* The HTTP status of the response returned to the client application * must be {@code "200 OK"} and its content type must be {@code * "application/json"}. *

* *

* {@link #getResponseContent()} returns a JSON string which complies * with the introspection response defined in "2.2. Introspection * Response" in RFC7662. *

* *

* The following illustrates the response which the introspection endpoint * of your authorization server should generate and return to the client * application. *

* *
 * HTTP/1.1 200 OK
 * Content-Type: application/json
 *
 * (The value returned from {@link #getResponseContent()})
*
*
* *
*

* Note that RFC 7662 says "To prevent token scanning attacks, * the endpoint MUST also require some form of authorization * to access this endpoint". This means that you have to protect * your introspection endpoint in some way or other. Authlete does * not care about how your introspection endpoint is protected. In * most cases, as mentioned in RFC 7662, {@code "401 Unauthorized"} * is a proper response when an introspection request does not * satisfy authorization requirements imposed by your introspection * endpoint. *

* * @see RFC 7662, OAuth 2.0 Token Introspection * @see StandardIntrospectionRequest * @see AuthleteApi#standardIntrospection(StandardIntrospectionRequest) * * @author Takahiko Kawasaki * * @since 2.7 */ public class StandardIntrospectionResponse extends ApiResponse { private static final long serialVersionUID = 1L; /** * The next action that the implementation of the introspection * endpoint of the authorization server should take. */ public enum Action { /** * The request from your system to Authlete ({@link * StandardIntrospectionRequest}) was wrong or an error occurred * in Authlete. The introspection endpoint of your authorization * server should return {@code "500 Internal Server Error"} to * the client application. */ INTERNAL_SERVER_ERROR, /** * The request from the client was wrong. The introspection endpoint * of your authorization server should return {@code "400 Bad Request"} * to the client application. */ BAD_REQUEST, /** * The request from the client was valid. The introspection endpoint * of your authorization server should return {@code "200 OK"} to * the client application. */ OK } private static final String SUMMARY_FORMAT = "action=%s, responseContent=%s"; private Action action; private String responseContent; /** * Get the next action that the introspection endpoint of your * authorization server should take. */ public Action getAction() { return action; } /** * Set the next action that the introspection endpoint of the * authorization server should take. */ public void setAction(Action action) { this.action = action; } /** * Get the response content which can be used as the entity body * of the response returned to the client application. */ public String getResponseContent() { return responseContent; } /** * Set the response content which can be used as the entity body * of the response returned to the client application. */ public void setResponseContent(String responseContent) { this.responseContent = responseContent; } /** * Get the summary of this instance. */ public String summarize() { return String.format(SUMMARY_FORMAT, action, responseContent); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy