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

org.eclipse.microprofile.openapi.annotations.responses.APIResponseSchema Maven / Gradle / Ivy

/**
 * Copyright (c) 2020 Contributors to the Eclipse Foundation
 * 

* 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 org.eclipse.microprofile.openapi.annotations.responses; import java.lang.annotation.ElementType; import java.lang.annotation.Inherited; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target; /** * The APIResponseSchema annotation corresponds to an individual schema in the OpenAPI * Response model object which describes a single response from an API Operation. This * annotation provides a short-hand way to specify a simple response that would otherwise * be specified using {@link APIResponse @APIResponse} and that typically could not be determined by * scanning the resource method alone. * *

* The following annotation usages are equivalent to the OpenAPI annotation scanner runtime. * *

 * @APIResponse(content = { @Content(schema = @Schema(implementation = MyResponseObject.class)) })
 *
 * @APIResponseSchema(MyResponseObject.class)
 * 
* *

* When this annotation is applied to a method the response is added to the responses * defined in the corresponding OpenAPI operation with a default response code and description * that correspond to the method's HTTP method annotation and return type. Any media types that * apply to the resource method from either a method-level or class-level @Produces * annotation will result in those media types applying to the OpenAPI response model. * *

* If not specified, default responseCode and responseDescription values shall be determined * according to the {@link #responseCode() responseCode} and {@link #responseDescription() responseDescription} * documentation. * *

 * @GET
 * @Path("{id}")
 * @APIResponseSchema(value = MyResponseObject.class, responseDescription = "Success", responseCode = "200")
 * public Response getById(@PathParam("{id}") long id) {
 *     MyResponseObject entity = service.load(id);
 *     return Response.status(200).entity(entity).build();
 * }
 * 
* * @since 2.0 * @see APIResponse * @see "https://github.com/OAI/OpenAPI-Specification/blob/master/versions/3.0.0.md#responseObject" * **/ @Target({ ElementType.METHOD }) @Retention(RetentionPolicy.RUNTIME) @Inherited public @interface APIResponseSchema { /** * Provides a Java class as implementation for this schema. The class will * undergo introspection to determine any applicable Schema attributes to be * applied to the OpenAPI response model. * * @return a class that implements this schema **/ Class value(); /** * A short description of the response. It is a REQUIRED property in the OpenAPI document. * *

* If no value is specified, the default value will set to the description given by the * HTTP/1.1 documentation * for the {@link #responseCode() responseCode} in use. * * @return description of the response. **/ String responseDescription() default ""; /** * The HTTP response code, or 'default', for the supplied response. May have only one 'default' entry. * *

* If no value is specified, a default shall be determined using REST conventions as follows: * *

    *
  • If the method's return type is void and the HTTP method is @POST, * the code will be 201. *
  • Otherwise, if the method's return type is void the method does not list a JAX-RS * AsyncResponse parameter, the code will be 204. *
  • Otherwise, the code will be 200. *
* * @return HTTP response code for this response instance or default **/ String responseCode() default ""; }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy