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

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

Go to download

Authlete Java library used commonly by service implementations and the Authlete server.

There is a newer version: 4.15
Show newest version
/*
 * Copyright (C) 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.common.dto;


/**
 * Response from Authlete's {@code /vci/jwks} API.
 *
 * 

* The Authlete API is supposed to be used from within the implementation of * the JWK Set document endpoint of the credential issuer. *

* *

* Authlete's {@code /vci/jwks} API returns JSON which can be mapped to this * class. The credential issuer implementation should retrieve the value of * the {@link #getAction() action} response parameter from the * API response and take the following steps according to the value. *

* *

OK

* *

* When the value of the {@link #getAction() action} response * parameter is {@link Action#OK OK}, it means that Authlete * could prepare the JWK Set document successfully. *

* *

* In this case, the implementation of the JWK Set document endpoint of the * credential issuer should return an HTTP response with the HTTP status code * "{@code 200 OK}" and the content type "{@code application/json}". * The message body of the response has been prepared by Authlete's * {@code /vci/jwks} API and it is available as the * {@link #getResponseContent() responseContent} response parameter. *

* *

* The implementation of the JWK Set document endpoint can construct an HTTP * response by doing like below. *

* *
 * 200 OK
 * Content-Type: application/json
 * (Other HTTP headers)
 *
 * (the value of the {@link #getResponseContent() responseContent} response parameter)
* *

NOT_FOUND

* *

* When the value of the {@link #getAction() action} response * parameter is {@link Action#NOT_FOUND NOT_FOUND}, it means that * the service configuration has not enabled the feature of Verifiable * Credentials and so the JWK Set document endpoint should not be accessed. *

* *

* In this case, the implementation of the JWK Set document endpoint of the * credential issuer should return an HTTP response with the HTTP status code * "{@code 404 Not Found}" and the content type "{@code application/json}". * The message body (= error information in the JSON format) of the response * has been prepared by Authlete's {@code /vci/jwks} API and it is available * as the {@link #getResponseContent() responseContent} response * parameter. *

* *

* The implementation of the JWK Set document endpoint can construct an HTTP * response by doing like below. *

* *
 * 404 Not Found
 * Content-Type: application/json
 * (Other HTTP headers)
 *
 * (the value of the {@link #getResponseContent() responseContent} response parameter)
* *

INTERNAL_SERVER_ERROR

* *

* When the value of the {@link #getAction() action} response * parameter is {@link Action#INTERNAL_SERVER_ERROR INTERNAL_SERVER_ERROR}, * it means that an unexpected error has occurred on Authlete side or the * service has not been set up properly yet. *

* *

* In this case, a simple implementation of the JWK Set document endpoint would * return an HTTP response with the HTTP status code * "{@code 500 Internal Server Error}" and the content type * "{@code application/json}". The message body (= error information in the JSON * format) of the response has been prepared by Authlete's {@code /vci/jwks} API * and it is available as the {@link #getResponseContent() responseContent} * response parameter. *

* *

* Such simple implementation of the JWK Set document endpoint can construct an * HTTP response by doing like below. *

* *
 * 500 Internal Server Error
 * Content-Type: application/json
 * (Other HTTP headers)
 *
 * (the value of the {@link #getResponseContent() responseContent} response parameter)
* *

* However, in real commercial deployments, it is rare for a credential issuer * to return "{@code 500 Internal Server Error}" when it encounters an * unexpected internal error. It's up to implementations of credential issuers * what they actually return in the case of internal server error. *

* * @since 3.72 * @since Authlete 3.0 * * @see OpenID for Verifiable Credential Issuance */ public class CredentialIssuerJwksResponse extends ApiResponse { private static final long serialVersionUID = 1L; /** * The next action that the implementation of the JWK Set document * endpoint of the credential issuer should take after getting a * response from Authlete's {@code /vci/jwks} API. * * @since 3.72 * @since Authlete 3.0 */ public enum Action { /** * The JWK Set document of the credential issuer has been prepared * successfully. The implementation of the JWK Set document endpoint * should return an HTTP response with the HTTP status code * "{@code 200 OK}" and the content type "{@code application/json}". */ OK, /** * The feature of Verifiable Credentials is not enabled. The * implementation of the JWK Set document endpoint should return an * HTTP response with the HTTP status code "{@code 404 Not Found}" * and the content type "{@code application/json}" to indicate that * the endpoint should not be accessed. */ NOT_FOUND, /** * An unexpected error occurred on Authlete side or the service has * not been set up properly yet. A simple implementation of the * JWK Set document endpoint would return an HTTP response with the * HTTP status code "{@code 500 Internal Server Error}" and the * content type "{@code application/json}". */ INTERNAL_SERVER_ERROR, } private Action action; private String responseContent; /** * Get the next action that the implementation of the credential issuer's * JWK Set document endpoint should take after getting a response from * Authlete's {@code /vci/jwks} API. * * @return * The next action. */ public Action getAction() { return action; } /** * Set the next action that the implementation of the credential issuer's * JWK Set document endpoint should take after getting a response from * Authlete's {@code /vci/jwks} API. * * @param action * The next action. * * @return * {@code this} object. */ public CredentialIssuerJwksResponse setAction(Action action) { this.action = action; return this; } /** * Get the content of the response that should be returned from the JWK * Set document endpoint. * *

* In the successful case (when the {@code action} parameter in the * response from the {@code /vci/jwks} API is {@link Action#OK OK}), * the content of this parameter is the JWK Set document of the * credential issuer ({@code Service.}{@link Service#getCredentialJwks() * credentialJwks}) that contains public keys only. The JWK Set document * does not contain private parts of the keys. *

* *

* In other error cases, the content of this parameter is a JSON that * contains information about the error. *

* * @return * The content of the response that should be returned from the * JWK Set document endpoint. */ public String getResponseContent() { return responseContent; } /** * Set the content of the response that should be returned from the JWK * Set document endpoint. * *

* In the successful case (when the {@code action} parameter in the * response from the {@code /vci/jwks} API is {@link Action#OK OK}), * the content of this parameter is the JWK Set document of the * credential issuer ({@code Service.}{@link Service#getCredentialJwks() * credentialJwks}) that contains public keys only. The JWK Set document * does not contain private parts of the keys. *

* *

* In other error cases, the content of this parameter is a JSON that * contains information about the error. *

* * @param content * The content of the response that should be returned from the * JWK Set document endpoint. * * @return * {@code this} object. */ public CredentialIssuerJwksResponse setResponseContent(String content) { this.responseContent = content; return this; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy