This is a repository to store the OpenAPI specification of the SwaggerHub API for Spring pagination, which is hosted at https://app.swaggerhub.com/apis/spring/pagination.
While a SwaggerHub Domain would be more appropriate for this use case, it is unfortunately a paid feature.
- Add
x-spring-paginated: true
. - Add
pageParam
,sizeParam
andsortParam
parameters (note that this will addpage
,size
andsort
parameters to the generated controller methods, until OpenAPITools/openapi-generator#8315 is implemented). - Create a schema that inherits from
PaginationResponse
and use it in the response content schema.
Example usage:
# ...
paths:
/pet:
get:
tags:
- pet
operationId: findPets
x-spring-paginated: true
parameters:
- $ref: 'https://api.swaggerhub.com/apis/spring/pagination/1.0.0#/components/parameters/pageParam'
- $ref: 'https://api.swaggerhub.com/apis/spring/pagination/1.0.0#/components/parameters/sizeParam'
- $ref: 'https://api.swaggerhub.com/apis/spring/pagination/1.0.0#/components/parameters/sortParam'
responses:
'200':
description: successful operation
content:
application/json:
schema:
$ref: '#/components/schemas/PetPage'
components:
schemas:
Pet:
# ...
PetPage:
type: object
allOf:
- $ref: 'https://api.swaggerhub.com/apis/spring/pagination/1.0.0#/components/schemas/PaginationResponse'
- type: object
properties:
content:
type: array
items:
$ref: '#/components/schemas/Pet'
default: []
If using with OpenAPI Generator, configure the following mappings:
- object+pageable=Pageable
- object+sort=Sort
- Pageable=org.springframework.data.domain.Pageable
- Sort=org.springframework.data.domain.Sort
e.g.
With openapi-generator-cli:
openapi-generator-cli generate \
-i petstore.yaml \
-g spring \
--schema-mappings=Pageable=org.springframework.data.domain.Pageable,Sort=org.springframework.data.domain.Sort \
--type-mappings=object+pageable=Pageable,object+sort=Sort
With openapi-generator-maven-plugin:
<plugin>
<groupId>org.openapitools</groupId>
<artifactId>openapi-generator-maven-plugin</artifactId>
<!-- ... -->
<executions>
<execution>
<goals>
<goal>generate</goal>
</goals>
<configuration>
<inputSpec>${project.basedir}/src/main/resources/petstore.yaml</inputSpec>
<generatorName>spring</generatorName>
<typeMappings>
<typeMapping>object+pageable=Pageable</typeMapping>
<typeMapping>object+sort=Sort</typeMapping>
</typeMappings>
<schemaMappings>
<schemaMapping>Pageable=org.springframework.data.domain.Pageable</schemaMapping>
<schemaMapping>Sort=org.springframework.data.domain.Sort</schemaMapping>
</schemaMappings>
</configuration>
</execution>
</executions>
</plugin>
With openapi-generator-gradle-plugin:
// build.gradle
openApiGenerate {
inputSpec.set("$rootDir/src/main/resources/petstore.yaml")
generatorName.set("spring")
typeMappings.set([
"object+pageable": "Pageable",
"object+sort": "Sort",
])
schemaMappings.set([
Pageable: "org.springframework.data.domain.Pageable",
Sort: "org.springframework.data.domain.Sort",
])
}
// build.gradle.kts
openApiGenerate {
inputSpec.set("$rootDir/src/main/resources/petstore.yaml")
generatorName.set("spring")
typeMappings.set(mapOf(
"object+pageable" to "Pageable",
"object+sort" to "Sort",
))
schemaMappings.set(mapOf(
"Pageable" to "org.springframework.data.domain.Pageable",
"Sort" to "org.springframework.data.domain.Sort",
))
}