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

io.swagger.v3.oas.annotations.media.ArraySchema Maven / Gradle / Ivy

package io.swagger.v3.oas.annotations.media;

import io.swagger.v3.oas.annotations.extensions.Extension;

import java.lang.annotation.Inherited;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

import static java.lang.annotation.ElementType.ANNOTATION_TYPE;
import static java.lang.annotation.ElementType.TYPE;
import static java.lang.annotation.ElementType.FIELD;
import static java.lang.annotation.ElementType.METHOD;
import static java.lang.annotation.ElementType.PARAMETER;

/**
 * The annotation may be used to define a schema of type "array" for a set of elements of the OpenAPI spec, and/or to define additional
 * properties for the schema. It is applicable e.g. to parameters, schema classes (aka "models"), properties of such
 * models, request and response content, header.
 *
 * 

swagger-core resolver and swagger-jaxrs2 reader engine consider this annotation along with JAX-RS annotations, * element type and context as input to resolve the annotated element into an OpenAPI schema definition for such element.

* *

The annotation {@link Schema} shall be used for non array elements; {@link ArraySchema} and {@link Schema} cannot * coexist

* * @see Schema (OpenAPI specification) * @see Schema **/ @Target({FIELD, METHOD, PARAMETER, TYPE, ANNOTATION_TYPE}) @Retention(RetentionPolicy.RUNTIME) @Inherited public @interface ArraySchema { /** * The schema of the items in the array * * @return schema */ Schema schema() default @Schema; /** * Allows to define the properties to be resolved into properties of the schema of type `array` (not the ones of the * `items` of such schema which are defined in {@link #schema() schema}. * * @return arraySchema * * @since 2.0.2 */ Schema arraySchema() default @Schema; /** * sets the maximum number of items in an array. Ignored if value is Integer.MIN_VALUE. * * @return integer representing maximum number of items in array **/ int maxItems() default Integer.MIN_VALUE; /** * sets the minimum number of items in an array. Ignored if value is Integer.MAX_VALUE. * * @return integer representing minimum number of items in array **/ int minItems() default Integer.MAX_VALUE; /** * determines whether an array of items will be unique * * @return boolean - whether items in an array are unique or repeating **/ boolean uniqueItems() default false; /** * The list of optional extensions * * @return an optional array of extensions */ Extension[] extensions() default {}; }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy