forked from loafle/openapi-generator-original
clean up kotlin spring samples (#20445)
* clean up samples * use 3.0 petstore test spec * update samples * better code format
This commit is contained in:
parent
358e8af2bf
commit
a6cfef53fe
1
.github/workflows/samples-kotlin-server.yaml
vendored
1
.github/workflows/samples-kotlin-server.yaml
vendored
@ -34,7 +34,6 @@ jobs:
|
|||||||
- samples/server/petstore/kotlin-springboot-delegate
|
- samples/server/petstore/kotlin-springboot-delegate
|
||||||
- samples/server/petstore/kotlin-springboot-modelMutable
|
- samples/server/petstore/kotlin-springboot-modelMutable
|
||||||
- samples/server/petstore/kotlin-springboot-reactive
|
- samples/server/petstore/kotlin-springboot-reactive
|
||||||
- samples/server/petstore/kotlin-springboot-reactive-with-flow
|
|
||||||
- samples/server/petstore/kotlin-springboot-reactive-without-flow
|
- samples/server/petstore/kotlin-springboot-reactive-without-flow
|
||||||
- samples/server/petstore/kotlin-springboot-source-swagger1
|
- samples/server/petstore/kotlin-springboot-source-swagger1
|
||||||
- samples/server/petstore/kotlin-springboot-source-swagger2
|
- samples/server/petstore/kotlin-springboot-source-swagger2
|
||||||
|
@ -1,13 +0,0 @@
|
|||||||
generatorName: kotlin-spring
|
|
||||||
outputDir: samples/server/petstore/kotlin-springboot-reactive-with-flow
|
|
||||||
library: spring-boot
|
|
||||||
inputSpec: modules/openapi-generator/src/test/resources/3_0/petstore.yaml
|
|
||||||
templateDir: modules/openapi-generator/src/main/resources/kotlin-spring
|
|
||||||
additionalProperties:
|
|
||||||
documentationProvider: springdoc
|
|
||||||
annotationLibrary: swagger2
|
|
||||||
useSwaggerUI: "true"
|
|
||||||
serviceImplementation: "true"
|
|
||||||
reactive: "true"
|
|
||||||
beanValidations: "true"
|
|
||||||
useFlowForArrayReturnType: "true"
|
|
@ -1,7 +1,7 @@
|
|||||||
generatorName: kotlin-spring
|
generatorName: kotlin-spring
|
||||||
outputDir: samples/server/petstore/kotlin-springboot-reactive
|
outputDir: samples/server/petstore/kotlin-springboot-reactive
|
||||||
library: spring-boot
|
library: spring-boot
|
||||||
inputSpec: modules/openapi-generator/src/test/resources/2_0/petstore.yaml
|
inputSpec: modules/openapi-generator/src/test/resources/3_0/petstore.yaml
|
||||||
templateDir: modules/openapi-generator/src/main/resources/kotlin-spring
|
templateDir: modules/openapi-generator/src/main/resources/kotlin-spring
|
||||||
additionalProperties:
|
additionalProperties:
|
||||||
documentationProvider: springdoc
|
documentationProvider: springdoc
|
||||||
@ -10,3 +10,5 @@ additionalProperties:
|
|||||||
serviceImplementation: "true"
|
serviceImplementation: "true"
|
||||||
reactive: "true"
|
reactive: "true"
|
||||||
beanValidations: "true"
|
beanValidations: "true"
|
||||||
|
# the following option is set to true by default
|
||||||
|
#useFlowForArrayReturnType: "true"
|
||||||
|
@ -40,26 +40,34 @@ public class KotlinServerCodegen extends AbstractKotlinCodegen implements BeanVa
|
|||||||
public static final String DEFAULT_LIBRARY = Constants.KTOR;
|
public static final String DEFAULT_LIBRARY = Constants.KTOR;
|
||||||
private final Logger LOGGER = LoggerFactory.getLogger(KotlinServerCodegen.class);
|
private final Logger LOGGER = LoggerFactory.getLogger(KotlinServerCodegen.class);
|
||||||
|
|
||||||
@Getter @Setter
|
@Getter
|
||||||
|
@Setter
|
||||||
private Boolean autoHeadFeatureEnabled = true;
|
private Boolean autoHeadFeatureEnabled = true;
|
||||||
@Getter @Setter
|
@Getter
|
||||||
|
@Setter
|
||||||
private Boolean conditionalHeadersFeatureEnabled = false;
|
private Boolean conditionalHeadersFeatureEnabled = false;
|
||||||
@Getter @Setter
|
@Getter
|
||||||
|
@Setter
|
||||||
private Boolean hstsFeatureEnabled = true;
|
private Boolean hstsFeatureEnabled = true;
|
||||||
@Getter @Setter
|
@Getter
|
||||||
|
@Setter
|
||||||
private Boolean corsFeatureEnabled = false;
|
private Boolean corsFeatureEnabled = false;
|
||||||
@Getter @Setter
|
@Getter
|
||||||
|
@Setter
|
||||||
private Boolean compressionFeatureEnabled = true;
|
private Boolean compressionFeatureEnabled = true;
|
||||||
@Getter @Setter
|
@Getter
|
||||||
|
@Setter
|
||||||
private Boolean resourcesFeatureEnabled = true;
|
private Boolean resourcesFeatureEnabled = true;
|
||||||
@Getter @Setter
|
@Getter
|
||||||
|
@Setter
|
||||||
private Boolean metricsFeatureEnabled = true;
|
private Boolean metricsFeatureEnabled = true;
|
||||||
private boolean interfaceOnly = false;
|
private boolean interfaceOnly = false;
|
||||||
private boolean useBeanValidation = false;
|
private boolean useBeanValidation = false;
|
||||||
private boolean useCoroutines = false;
|
private boolean useCoroutines = false;
|
||||||
private boolean useMutiny = false;
|
private boolean useMutiny = false;
|
||||||
private boolean returnResponse = false;
|
private boolean returnResponse = false;
|
||||||
@Setter private boolean omitGradleWrapper = false;
|
@Setter
|
||||||
|
private boolean omitGradleWrapper = false;
|
||||||
|
|
||||||
// This is here to potentially warn the user when an option is not supported by the target framework.
|
// This is here to potentially warn the user when an option is not supported by the target framework.
|
||||||
private Map<String, List<String>> optionsSupportedPerFramework = new ImmutableMap.Builder<String, List<String>>()
|
private Map<String, List<String>> optionsSupportedPerFramework = new ImmutableMap.Builder<String, List<String>>()
|
||||||
|
@ -924,12 +924,12 @@ public class KotlinSpringServerCodegenTest {
|
|||||||
codegen.additionalProperties().put(KotlinSpringServerCodegen.DELEGATE_PATTERN, true);
|
codegen.additionalProperties().put(KotlinSpringServerCodegen.DELEGATE_PATTERN, true);
|
||||||
|
|
||||||
List<File> files = new DefaultGenerator()
|
List<File> files = new DefaultGenerator()
|
||||||
.opts(
|
.opts(
|
||||||
new ClientOptInput()
|
new ClientOptInput()
|
||||||
.openAPI(TestUtils.parseSpec("src/test/resources/3_0/kotlin/issue16130-add-useFlowForArrayReturnType-param.yaml"))
|
.openAPI(TestUtils.parseSpec("src/test/resources/3_0/kotlin/issue16130-add-useFlowForArrayReturnType-param.yaml"))
|
||||||
.config(codegen)
|
.config(codegen)
|
||||||
)
|
)
|
||||||
.generate();
|
.generate();
|
||||||
|
|
||||||
Assertions.assertThat(files).contains(
|
Assertions.assertThat(files).contains(
|
||||||
new File(output, "src/main/kotlin/org/openapitools/api/TestV1Api.kt"),
|
new File(output, "src/main/kotlin/org/openapitools/api/TestV1Api.kt"),
|
||||||
@ -969,12 +969,12 @@ public class KotlinSpringServerCodegenTest {
|
|||||||
codegen.additionalProperties().put(KotlinSpringServerCodegen.DELEGATE_PATTERN, true);
|
codegen.additionalProperties().put(KotlinSpringServerCodegen.DELEGATE_PATTERN, true);
|
||||||
|
|
||||||
List<File> files = new DefaultGenerator()
|
List<File> files = new DefaultGenerator()
|
||||||
.opts(
|
.opts(
|
||||||
new ClientOptInput()
|
new ClientOptInput()
|
||||||
.openAPI(TestUtils.parseSpec("src/test/resources/3_0/kotlin/issue16130-add-useFlowForArrayReturnType-param.yaml"))
|
.openAPI(TestUtils.parseSpec("src/test/resources/3_0/kotlin/issue16130-add-useFlowForArrayReturnType-param.yaml"))
|
||||||
.config(codegen)
|
.config(codegen)
|
||||||
)
|
)
|
||||||
.generate();
|
.generate();
|
||||||
|
|
||||||
Assertions.assertThat(files).contains(
|
Assertions.assertThat(files).contains(
|
||||||
new File(output, "src/main/kotlin/org/openapitools/api/TestV1Api.kt"),
|
new File(output, "src/main/kotlin/org/openapitools/api/TestV1Api.kt"),
|
||||||
@ -1015,12 +1015,12 @@ public class KotlinSpringServerCodegenTest {
|
|||||||
codegen.additionalProperties().put(KotlinSpringServerCodegen.DELEGATE_PATTERN, true);
|
codegen.additionalProperties().put(KotlinSpringServerCodegen.DELEGATE_PATTERN, true);
|
||||||
|
|
||||||
List<File> files = new DefaultGenerator()
|
List<File> files = new DefaultGenerator()
|
||||||
.opts(
|
.opts(
|
||||||
new ClientOptInput()
|
new ClientOptInput()
|
||||||
.openAPI(TestUtils.parseSpec("src/test/resources/3_0/kotlin/issue16130-add-useFlowForArrayReturnType-param.yaml"))
|
.openAPI(TestUtils.parseSpec("src/test/resources/3_0/kotlin/issue16130-add-useFlowForArrayReturnType-param.yaml"))
|
||||||
.config(codegen)
|
.config(codegen)
|
||||||
)
|
)
|
||||||
.generate();
|
.generate();
|
||||||
|
|
||||||
Assertions.assertThat(files).contains(
|
Assertions.assertThat(files).contains(
|
||||||
new File(output, "src/main/kotlin/org/openapitools/api/TestV1Api.kt"),
|
new File(output, "src/main/kotlin/org/openapitools/api/TestV1Api.kt"),
|
||||||
@ -1060,12 +1060,12 @@ public class KotlinSpringServerCodegenTest {
|
|||||||
codegen.additionalProperties().put(KotlinSpringServerCodegen.DELEGATE_PATTERN, true);
|
codegen.additionalProperties().put(KotlinSpringServerCodegen.DELEGATE_PATTERN, true);
|
||||||
|
|
||||||
List<File> files = new DefaultGenerator()
|
List<File> files = new DefaultGenerator()
|
||||||
.opts(
|
.opts(
|
||||||
new ClientOptInput()
|
new ClientOptInput()
|
||||||
.openAPI(TestUtils.parseSpec("src/test/resources/3_0/kotlin/issue16130-add-useFlowForArrayReturnType-param.yaml"))
|
.openAPI(TestUtils.parseSpec("src/test/resources/3_0/kotlin/issue16130-add-useFlowForArrayReturnType-param.yaml"))
|
||||||
.config(codegen)
|
.config(codegen)
|
||||||
)
|
)
|
||||||
.generate();
|
.generate();
|
||||||
|
|
||||||
Assertions.assertThat(files).contains(
|
Assertions.assertThat(files).contains(
|
||||||
new File(output, "src/main/kotlin/org/openapitools/api/TestV1Api.kt"),
|
new File(output, "src/main/kotlin/org/openapitools/api/TestV1Api.kt"),
|
||||||
@ -1105,12 +1105,12 @@ public class KotlinSpringServerCodegenTest {
|
|||||||
codegen.additionalProperties().put(KotlinSpringServerCodegen.DELEGATE_PATTERN, true);
|
codegen.additionalProperties().put(KotlinSpringServerCodegen.DELEGATE_PATTERN, true);
|
||||||
|
|
||||||
List<File> files = new DefaultGenerator()
|
List<File> files = new DefaultGenerator()
|
||||||
.opts(
|
.opts(
|
||||||
new ClientOptInput()
|
new ClientOptInput()
|
||||||
.openAPI(TestUtils.parseSpec("src/test/resources/3_0/kotlin/issue16130-add-useFlowForArrayReturnType-param.yaml"))
|
.openAPI(TestUtils.parseSpec("src/test/resources/3_0/kotlin/issue16130-add-useFlowForArrayReturnType-param.yaml"))
|
||||||
.config(codegen)
|
.config(codegen)
|
||||||
)
|
)
|
||||||
.generate();
|
.generate();
|
||||||
|
|
||||||
Assertions.assertThat(files).contains(
|
Assertions.assertThat(files).contains(
|
||||||
new File(output, "src/main/kotlin/org/openapitools/api/TestV1Api.kt"),
|
new File(output, "src/main/kotlin/org/openapitools/api/TestV1Api.kt"),
|
||||||
|
@ -1,23 +0,0 @@
|
|||||||
# OpenAPI Generator Ignore
|
|
||||||
# Generated by openapi-generator https://github.com/openapitools/openapi-generator
|
|
||||||
|
|
||||||
# Use this file to prevent files from being overwritten by the generator.
|
|
||||||
# The patterns follow closely to .gitignore or .dockerignore.
|
|
||||||
|
|
||||||
# As an example, the C# client generator defines ApiClient.cs.
|
|
||||||
# You can make changes and tell OpenAPI Generator to ignore just this file by uncommenting the following line:
|
|
||||||
#ApiClient.cs
|
|
||||||
|
|
||||||
# You can match any string of characters against a directory, file or extension with a single asterisk (*):
|
|
||||||
#foo/*/qux
|
|
||||||
# The above matches foo/bar/qux and foo/baz/qux, but not foo/bar/baz/qux
|
|
||||||
|
|
||||||
# You can recursively match patterns against a directory, file or extension with a double asterisk (**):
|
|
||||||
#foo/**/qux
|
|
||||||
# This matches foo/bar/qux, foo/baz/qux, and foo/bar/baz/qux
|
|
||||||
|
|
||||||
# You can also negate patterns with an exclamation (!).
|
|
||||||
# For example, you can ignore all files in a docs folder with the file extension .md:
|
|
||||||
#docs/*.md
|
|
||||||
# Then explicitly reverse the ignore rule for a single file:
|
|
||||||
#!docs/README.md
|
|
@ -1,28 +0,0 @@
|
|||||||
README.md
|
|
||||||
build.gradle.kts
|
|
||||||
gradle/wrapper/gradle-wrapper.jar
|
|
||||||
gradle/wrapper/gradle-wrapper.properties
|
|
||||||
gradlew
|
|
||||||
gradlew.bat
|
|
||||||
pom.xml
|
|
||||||
settings.gradle
|
|
||||||
src/main/kotlin/org/openapitools/Application.kt
|
|
||||||
src/main/kotlin/org/openapitools/HomeController.kt
|
|
||||||
src/main/kotlin/org/openapitools/api/ApiUtil.kt
|
|
||||||
src/main/kotlin/org/openapitools/api/PetApiController.kt
|
|
||||||
src/main/kotlin/org/openapitools/api/PetApiService.kt
|
|
||||||
src/main/kotlin/org/openapitools/api/PetApiServiceImpl.kt
|
|
||||||
src/main/kotlin/org/openapitools/api/StoreApiController.kt
|
|
||||||
src/main/kotlin/org/openapitools/api/StoreApiService.kt
|
|
||||||
src/main/kotlin/org/openapitools/api/StoreApiServiceImpl.kt
|
|
||||||
src/main/kotlin/org/openapitools/api/UserApiController.kt
|
|
||||||
src/main/kotlin/org/openapitools/api/UserApiService.kt
|
|
||||||
src/main/kotlin/org/openapitools/api/UserApiServiceImpl.kt
|
|
||||||
src/main/kotlin/org/openapitools/model/Category.kt
|
|
||||||
src/main/kotlin/org/openapitools/model/ModelApiResponse.kt
|
|
||||||
src/main/kotlin/org/openapitools/model/Order.kt
|
|
||||||
src/main/kotlin/org/openapitools/model/Pet.kt
|
|
||||||
src/main/kotlin/org/openapitools/model/Tag.kt
|
|
||||||
src/main/kotlin/org/openapitools/model/User.kt
|
|
||||||
src/main/resources/application.yaml
|
|
||||||
src/main/resources/openapi.yaml
|
|
@ -1 +0,0 @@
|
|||||||
7.11.0-SNAPSHOT
|
|
@ -1,21 +0,0 @@
|
|||||||
# openAPIPetstore
|
|
||||||
|
|
||||||
This Kotlin based [Spring Boot](https://spring.io/projects/spring-boot) application has been generated using the [OpenAPI Generator](https://github.com/OpenAPITools/openapi-generator).
|
|
||||||
|
|
||||||
## Getting Started
|
|
||||||
|
|
||||||
This document assumes you have either maven or gradle available, either via the wrapper or otherwise. This does not come with a gradle / maven wrapper checked in.
|
|
||||||
|
|
||||||
By default a [`pom.xml`](pom.xml) file will be generated. If you specified `gradleBuildFile=true` when generating this project, a `build.gradle.kts` will also be generated. Note this uses [Gradle Kotlin DSL](https://github.com/gradle/kotlin-dsl).
|
|
||||||
|
|
||||||
To build the project using maven, run:
|
|
||||||
```bash
|
|
||||||
mvn package && java -jar target/openapi-spring-1.0.0.jar
|
|
||||||
```
|
|
||||||
|
|
||||||
To build the project using gradle, run:
|
|
||||||
```bash
|
|
||||||
gradle build && java -jar build/libs/openapi-spring-1.0.0.jar
|
|
||||||
```
|
|
||||||
|
|
||||||
If all builds successfully, the server should run on [http://localhost:8080/](http://localhost:8080/)
|
|
@ -1,53 +0,0 @@
|
|||||||
import org.jetbrains.kotlin.gradle.tasks.KotlinCompile
|
|
||||||
|
|
||||||
buildscript {
|
|
||||||
repositories {
|
|
||||||
mavenCentral()
|
|
||||||
}
|
|
||||||
dependencies {
|
|
||||||
classpath("org.springframework.boot:spring-boot-gradle-plugin:2.6.7")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
group = "org.openapitools"
|
|
||||||
version = "1.0.0"
|
|
||||||
|
|
||||||
repositories {
|
|
||||||
mavenCentral()
|
|
||||||
}
|
|
||||||
|
|
||||||
tasks.withType<KotlinCompile> {
|
|
||||||
kotlinOptions.jvmTarget = "1.8"
|
|
||||||
}
|
|
||||||
|
|
||||||
plugins {
|
|
||||||
val kotlinVersion = "1.9.25"
|
|
||||||
id("org.jetbrains.kotlin.jvm") version kotlinVersion
|
|
||||||
id("org.jetbrains.kotlin.plugin.jpa") version kotlinVersion
|
|
||||||
id("org.jetbrains.kotlin.plugin.spring") version kotlinVersion
|
|
||||||
id("org.springframework.boot") version "2.6.7"
|
|
||||||
id("io.spring.dependency-management") version "1.0.11.RELEASE"
|
|
||||||
}
|
|
||||||
|
|
||||||
dependencies {
|
|
||||||
val kotlinxCoroutinesVersion = "1.6.1"
|
|
||||||
implementation("org.jetbrains.kotlin:kotlin-stdlib-jdk8")
|
|
||||||
implementation("org.jetbrains.kotlin:kotlin-reflect")
|
|
||||||
implementation("org.springframework.boot:spring-boot-starter-webflux")
|
|
||||||
implementation("org.jetbrains.kotlinx:kotlinx-coroutines-core:$kotlinxCoroutinesVersion")
|
|
||||||
implementation("org.jetbrains.kotlinx:kotlinx-coroutines-reactor:$kotlinxCoroutinesVersion")
|
|
||||||
implementation("org.springdoc:springdoc-openapi-webflux-ui:1.6.8")
|
|
||||||
|
|
||||||
implementation("com.google.code.findbugs:jsr305:3.0.2")
|
|
||||||
implementation("com.fasterxml.jackson.dataformat:jackson-dataformat-yaml")
|
|
||||||
implementation("com.fasterxml.jackson.dataformat:jackson-dataformat-xml")
|
|
||||||
implementation("com.fasterxml.jackson.datatype:jackson-datatype-jsr310")
|
|
||||||
implementation("com.fasterxml.jackson.module:jackson-module-kotlin")
|
|
||||||
implementation("javax.validation:validation-api")
|
|
||||||
implementation("javax.annotation:javax.annotation-api:1.3.2")
|
|
||||||
testImplementation("org.jetbrains.kotlin:kotlin-test-junit5")
|
|
||||||
testImplementation("org.springframework.boot:spring-boot-starter-test") {
|
|
||||||
exclude(module = "junit")
|
|
||||||
}
|
|
||||||
testImplementation("org.jetbrains.kotlinx:kotlinx-coroutines-test:$kotlinxCoroutinesVersion")
|
|
||||||
}
|
|
Binary file not shown.
@ -1,7 +0,0 @@
|
|||||||
distributionBase=GRADLE_USER_HOME
|
|
||||||
distributionPath=wrapper/dists
|
|
||||||
distributionUrl=https\://services.gradle.org/distributions/gradle-8.1.1-bin.zip
|
|
||||||
networkTimeout=10000
|
|
||||||
validateDistributionUrl=true
|
|
||||||
zipStoreBase=GRADLE_USER_HOME
|
|
||||||
zipStorePath=wrapper/dists
|
|
@ -1,249 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
|
|
||||||
#
|
|
||||||
# Copyright © 2015-2021 the original authors.
|
|
||||||
#
|
|
||||||
# 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
|
|
||||||
#
|
|
||||||
# https://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.
|
|
||||||
#
|
|
||||||
|
|
||||||
##############################################################################
|
|
||||||
#
|
|
||||||
# Gradle start up script for POSIX generated by Gradle.
|
|
||||||
#
|
|
||||||
# Important for running:
|
|
||||||
#
|
|
||||||
# (1) You need a POSIX-compliant shell to run this script. If your /bin/sh is
|
|
||||||
# noncompliant, but you have some other compliant shell such as ksh or
|
|
||||||
# bash, then to run this script, type that shell name before the whole
|
|
||||||
# command line, like:
|
|
||||||
#
|
|
||||||
# ksh Gradle
|
|
||||||
#
|
|
||||||
# Busybox and similar reduced shells will NOT work, because this script
|
|
||||||
# requires all of these POSIX shell features:
|
|
||||||
# * functions;
|
|
||||||
# * expansions «$var», «${var}», «${var:-default}», «${var+SET}»,
|
|
||||||
# «${var#prefix}», «${var%suffix}», and «$( cmd )»;
|
|
||||||
# * compound commands having a testable exit status, especially «case»;
|
|
||||||
# * various built-in commands including «command», «set», and «ulimit».
|
|
||||||
#
|
|
||||||
# Important for patching:
|
|
||||||
#
|
|
||||||
# (2) This script targets any POSIX shell, so it avoids extensions provided
|
|
||||||
# by Bash, Ksh, etc; in particular arrays are avoided.
|
|
||||||
#
|
|
||||||
# The "traditional" practice of packing multiple parameters into a
|
|
||||||
# space-separated string is a well documented source of bugs and security
|
|
||||||
# problems, so this is (mostly) avoided, by progressively accumulating
|
|
||||||
# options in "$@", and eventually passing that to Java.
|
|
||||||
#
|
|
||||||
# Where the inherited environment variables (DEFAULT_JVM_OPTS, JAVA_OPTS,
|
|
||||||
# and GRADLE_OPTS) rely on word-splitting, this is performed explicitly;
|
|
||||||
# see the in-line comments for details.
|
|
||||||
#
|
|
||||||
# There are tweaks for specific operating systems such as AIX, CygWin,
|
|
||||||
# Darwin, MinGW, and NonStop.
|
|
||||||
#
|
|
||||||
# (3) This script is generated from the Groovy template
|
|
||||||
# https://github.com/gradle/gradle/blob/HEAD/subprojects/plugins/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt
|
|
||||||
# within the Gradle project.
|
|
||||||
#
|
|
||||||
# You can find Gradle at https://github.com/gradle/gradle/.
|
|
||||||
#
|
|
||||||
##############################################################################
|
|
||||||
|
|
||||||
# Attempt to set APP_HOME
|
|
||||||
|
|
||||||
# Resolve links: $0 may be a link
|
|
||||||
app_path=$0
|
|
||||||
|
|
||||||
# Need this for daisy-chained symlinks.
|
|
||||||
while
|
|
||||||
APP_HOME=${app_path%"${app_path##*/}"} # leaves a trailing /; empty if no leading path
|
|
||||||
[ -h "$app_path" ]
|
|
||||||
do
|
|
||||||
ls=$( ls -ld "$app_path" )
|
|
||||||
link=${ls#*' -> '}
|
|
||||||
case $link in #(
|
|
||||||
/*) app_path=$link ;; #(
|
|
||||||
*) app_path=$APP_HOME$link ;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
|
|
||||||
# This is normally unused
|
|
||||||
# shellcheck disable=SC2034
|
|
||||||
APP_BASE_NAME=${0##*/}
|
|
||||||
# Discard cd standard output in case $CDPATH is set (https://github.com/gradle/gradle/issues/25036)
|
|
||||||
APP_HOME=$( cd "${APP_HOME:-./}" > /dev/null && pwd -P ) || exit
|
|
||||||
|
|
||||||
# Use the maximum available, or set MAX_FD != -1 to use that value.
|
|
||||||
MAX_FD=maximum
|
|
||||||
|
|
||||||
warn () {
|
|
||||||
echo "$*"
|
|
||||||
} >&2
|
|
||||||
|
|
||||||
die () {
|
|
||||||
echo
|
|
||||||
echo "$*"
|
|
||||||
echo
|
|
||||||
exit 1
|
|
||||||
} >&2
|
|
||||||
|
|
||||||
# OS specific support (must be 'true' or 'false').
|
|
||||||
cygwin=false
|
|
||||||
msys=false
|
|
||||||
darwin=false
|
|
||||||
nonstop=false
|
|
||||||
case "$( uname )" in #(
|
|
||||||
CYGWIN* ) cygwin=true ;; #(
|
|
||||||
Darwin* ) darwin=true ;; #(
|
|
||||||
MSYS* | MINGW* ) msys=true ;; #(
|
|
||||||
NONSTOP* ) nonstop=true ;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar
|
|
||||||
|
|
||||||
|
|
||||||
# Determine the Java command to use to start the JVM.
|
|
||||||
if [ -n "$JAVA_HOME" ] ; then
|
|
||||||
if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
|
|
||||||
# IBM's JDK on AIX uses strange locations for the executables
|
|
||||||
JAVACMD=$JAVA_HOME/jre/sh/java
|
|
||||||
else
|
|
||||||
JAVACMD=$JAVA_HOME/bin/java
|
|
||||||
fi
|
|
||||||
if [ ! -x "$JAVACMD" ] ; then
|
|
||||||
die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME
|
|
||||||
|
|
||||||
Please set the JAVA_HOME variable in your environment to match the
|
|
||||||
location of your Java installation."
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
JAVACMD=java
|
|
||||||
if ! command -v java >/dev/null 2>&1
|
|
||||||
then
|
|
||||||
die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
|
|
||||||
|
|
||||||
Please set the JAVA_HOME variable in your environment to match the
|
|
||||||
location of your Java installation."
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Increase the maximum file descriptors if we can.
|
|
||||||
if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then
|
|
||||||
case $MAX_FD in #(
|
|
||||||
max*)
|
|
||||||
# In POSIX sh, ulimit -H is undefined. That's why the result is checked to see if it worked.
|
|
||||||
# shellcheck disable=SC2039,SC3045
|
|
||||||
MAX_FD=$( ulimit -H -n ) ||
|
|
||||||
warn "Could not query maximum file descriptor limit"
|
|
||||||
esac
|
|
||||||
case $MAX_FD in #(
|
|
||||||
'' | soft) :;; #(
|
|
||||||
*)
|
|
||||||
# In POSIX sh, ulimit -n is undefined. That's why the result is checked to see if it worked.
|
|
||||||
# shellcheck disable=SC2039,SC3045
|
|
||||||
ulimit -n "$MAX_FD" ||
|
|
||||||
warn "Could not set maximum file descriptor limit to $MAX_FD"
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Collect all arguments for the java command, stacking in reverse order:
|
|
||||||
# * args from the command line
|
|
||||||
# * the main class name
|
|
||||||
# * -classpath
|
|
||||||
# * -D...appname settings
|
|
||||||
# * --module-path (only if needed)
|
|
||||||
# * DEFAULT_JVM_OPTS, JAVA_OPTS, and GRADLE_OPTS environment variables.
|
|
||||||
|
|
||||||
# For Cygwin or MSYS, switch paths to Windows format before running java
|
|
||||||
if "$cygwin" || "$msys" ; then
|
|
||||||
APP_HOME=$( cygpath --path --mixed "$APP_HOME" )
|
|
||||||
CLASSPATH=$( cygpath --path --mixed "$CLASSPATH" )
|
|
||||||
|
|
||||||
JAVACMD=$( cygpath --unix "$JAVACMD" )
|
|
||||||
|
|
||||||
# Now convert the arguments - kludge to limit ourselves to /bin/sh
|
|
||||||
for arg do
|
|
||||||
if
|
|
||||||
case $arg in #(
|
|
||||||
-*) false ;; # don't mess with options #(
|
|
||||||
/?*) t=${arg#/} t=/${t%%/*} # looks like a POSIX filepath
|
|
||||||
[ -e "$t" ] ;; #(
|
|
||||||
*) false ;;
|
|
||||||
esac
|
|
||||||
then
|
|
||||||
arg=$( cygpath --path --ignore --mixed "$arg" )
|
|
||||||
fi
|
|
||||||
# Roll the args list around exactly as many times as the number of
|
|
||||||
# args, so each arg winds up back in the position where it started, but
|
|
||||||
# possibly modified.
|
|
||||||
#
|
|
||||||
# NB: a `for` loop captures its iteration list before it begins, so
|
|
||||||
# changing the positional parameters here affects neither the number of
|
|
||||||
# iterations, nor the values presented in `arg`.
|
|
||||||
shift # remove old arg
|
|
||||||
set -- "$@" "$arg" # push replacement arg
|
|
||||||
done
|
|
||||||
fi
|
|
||||||
|
|
||||||
|
|
||||||
# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
|
|
||||||
DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
|
|
||||||
|
|
||||||
# Collect all arguments for the java command:
|
|
||||||
# * DEFAULT_JVM_OPTS, JAVA_OPTS, JAVA_OPTS, and optsEnvironmentVar are not allowed to contain shell fragments,
|
|
||||||
# and any embedded shellness will be escaped.
|
|
||||||
# * For example: A user cannot expect ${Hostname} to be expanded, as it is an environment variable and will be
|
|
||||||
# treated as '${Hostname}' itself on the command line.
|
|
||||||
|
|
||||||
set -- \
|
|
||||||
"-Dorg.gradle.appname=$APP_BASE_NAME" \
|
|
||||||
-classpath "$CLASSPATH" \
|
|
||||||
org.gradle.wrapper.GradleWrapperMain \
|
|
||||||
"$@"
|
|
||||||
|
|
||||||
# Stop when "xargs" is not available.
|
|
||||||
if ! command -v xargs >/dev/null 2>&1
|
|
||||||
then
|
|
||||||
die "xargs is not available"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Use "xargs" to parse quoted args.
|
|
||||||
#
|
|
||||||
# With -n1 it outputs one arg per line, with the quotes and backslashes removed.
|
|
||||||
#
|
|
||||||
# In Bash we could simply go:
|
|
||||||
#
|
|
||||||
# readarray ARGS < <( xargs -n1 <<<"$var" ) &&
|
|
||||||
# set -- "${ARGS[@]}" "$@"
|
|
||||||
#
|
|
||||||
# but POSIX shell has neither arrays nor command substitution, so instead we
|
|
||||||
# post-process each arg (as a line of input to sed) to backslash-escape any
|
|
||||||
# character that might be a shell metacharacter, then use eval to reverse
|
|
||||||
# that process (while maintaining the separation between arguments), and wrap
|
|
||||||
# the whole thing up as a single "set" statement.
|
|
||||||
#
|
|
||||||
# This will of course break if any of these variables contains a newline or
|
|
||||||
# an unmatched quote.
|
|
||||||
#
|
|
||||||
|
|
||||||
eval "set -- $(
|
|
||||||
printf '%s\n' "$DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS" |
|
|
||||||
xargs -n1 |
|
|
||||||
sed ' s~[^-[:alnum:]+,./:=@_]~\\&~g; ' |
|
|
||||||
tr '\n' ' '
|
|
||||||
)" '"$@"'
|
|
||||||
|
|
||||||
exec "$JAVACMD" "$@"
|
|
@ -1,92 +0,0 @@
|
|||||||
@rem
|
|
||||||
@rem Copyright 2015 the original author or authors.
|
|
||||||
@rem
|
|
||||||
@rem Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
@rem you may not use this file except in compliance with the License.
|
|
||||||
@rem You may obtain a copy of the License at
|
|
||||||
@rem
|
|
||||||
@rem https://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
@rem
|
|
||||||
@rem Unless required by applicable law or agreed to in writing, software
|
|
||||||
@rem distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
@rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
@rem See the License for the specific language governing permissions and
|
|
||||||
@rem limitations under the License.
|
|
||||||
@rem
|
|
||||||
|
|
||||||
@if "%DEBUG%"=="" @echo off
|
|
||||||
@rem ##########################################################################
|
|
||||||
@rem
|
|
||||||
@rem Gradle startup script for Windows
|
|
||||||
@rem
|
|
||||||
@rem ##########################################################################
|
|
||||||
|
|
||||||
@rem Set local scope for the variables with windows NT shell
|
|
||||||
if "%OS%"=="Windows_NT" setlocal
|
|
||||||
|
|
||||||
set DIRNAME=%~dp0
|
|
||||||
if "%DIRNAME%"=="" set DIRNAME=.
|
|
||||||
@rem This is normally unused
|
|
||||||
set APP_BASE_NAME=%~n0
|
|
||||||
set APP_HOME=%DIRNAME%
|
|
||||||
|
|
||||||
@rem Resolve any "." and ".." in APP_HOME to make it shorter.
|
|
||||||
for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi
|
|
||||||
|
|
||||||
@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
|
|
||||||
set DEFAULT_JVM_OPTS="-Xmx64m" "-Xms64m"
|
|
||||||
|
|
||||||
@rem Find java.exe
|
|
||||||
if defined JAVA_HOME goto findJavaFromJavaHome
|
|
||||||
|
|
||||||
set JAVA_EXE=java.exe
|
|
||||||
%JAVA_EXE% -version >NUL 2>&1
|
|
||||||
if %ERRORLEVEL% equ 0 goto execute
|
|
||||||
|
|
||||||
echo. 1>&2
|
|
||||||
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. 1>&2
|
|
||||||
echo. 1>&2
|
|
||||||
echo Please set the JAVA_HOME variable in your environment to match the 1>&2
|
|
||||||
echo location of your Java installation. 1>&2
|
|
||||||
|
|
||||||
goto fail
|
|
||||||
|
|
||||||
:findJavaFromJavaHome
|
|
||||||
set JAVA_HOME=%JAVA_HOME:"=%
|
|
||||||
set JAVA_EXE=%JAVA_HOME%/bin/java.exe
|
|
||||||
|
|
||||||
if exist "%JAVA_EXE%" goto execute
|
|
||||||
|
|
||||||
echo. 1>&2
|
|
||||||
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% 1>&2
|
|
||||||
echo. 1>&2
|
|
||||||
echo Please set the JAVA_HOME variable in your environment to match the 1>&2
|
|
||||||
echo location of your Java installation. 1>&2
|
|
||||||
|
|
||||||
goto fail
|
|
||||||
|
|
||||||
:execute
|
|
||||||
@rem Setup the command line
|
|
||||||
|
|
||||||
set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar
|
|
||||||
|
|
||||||
|
|
||||||
@rem Execute Gradle
|
|
||||||
"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %*
|
|
||||||
|
|
||||||
:end
|
|
||||||
@rem End local scope for the variables with windows NT shell
|
|
||||||
if %ERRORLEVEL% equ 0 goto mainEnd
|
|
||||||
|
|
||||||
:fail
|
|
||||||
rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
|
|
||||||
rem the _cmd.exe /c_ return code!
|
|
||||||
set EXIT_CODE=%ERRORLEVEL%
|
|
||||||
if %EXIT_CODE% equ 0 set EXIT_CODE=1
|
|
||||||
if not ""=="%GRADLE_EXIT_CONSOLE%" exit %EXIT_CODE%
|
|
||||||
exit /b %EXIT_CODE%
|
|
||||||
|
|
||||||
:mainEnd
|
|
||||||
if "%OS%"=="Windows_NT" endlocal
|
|
||||||
|
|
||||||
:omega
|
|
@ -1,147 +0,0 @@
|
|||||||
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
|
|
||||||
<modelVersion>4.0.0</modelVersion>
|
|
||||||
<groupId>org.openapitools</groupId>
|
|
||||||
<artifactId>openapi-spring</artifactId>
|
|
||||||
<packaging>jar</packaging>
|
|
||||||
<name>openapi-spring</name>
|
|
||||||
<version>1.0.0</version>
|
|
||||||
<properties>
|
|
||||||
<kotlinx-coroutines.version>1.6.1</kotlinx-coroutines.version>
|
|
||||||
<springdoc-openapi.version>1.6.8</springdoc-openapi.version>
|
|
||||||
<findbugs-jsr305.version>3.0.2</findbugs-jsr305.version>
|
|
||||||
<javax-annotation.version>1.3.2</javax-annotation.version>
|
|
||||||
<kotlin-test-junit5.version>1.6.21</kotlin-test-junit5.version>
|
|
||||||
|
|
||||||
<kotlin.version>1.6.21</kotlin.version>
|
|
||||||
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
|
||||||
</properties>
|
|
||||||
<parent>
|
|
||||||
<groupId>org.springframework.boot</groupId>
|
|
||||||
<artifactId>spring-boot-starter-parent</artifactId>
|
|
||||||
<version>2.7.15</version>
|
|
||||||
</parent>
|
|
||||||
<build>
|
|
||||||
<sourceDirectory>${project.basedir}/src/main/kotlin</sourceDirectory>
|
|
||||||
<testSourceDirectory>${project.basedir}/src/test/kotlin</testSourceDirectory>
|
|
||||||
<plugins>
|
|
||||||
<plugin>
|
|
||||||
<groupId>org.springframework.boot</groupId>
|
|
||||||
<artifactId>spring-boot-maven-plugin</artifactId>
|
|
||||||
<executions>
|
|
||||||
<execution>
|
|
||||||
<goals>
|
|
||||||
<goal>repackage</goal>
|
|
||||||
</goals>
|
|
||||||
</execution>
|
|
||||||
</executions>
|
|
||||||
</plugin>
|
|
||||||
<plugin>
|
|
||||||
<artifactId>kotlin-maven-plugin</artifactId>
|
|
||||||
<groupId>org.jetbrains.kotlin</groupId>
|
|
||||||
<version>${kotlin.version}</version>
|
|
||||||
<configuration>
|
|
||||||
<compilerPlugins>
|
|
||||||
<plugin>spring</plugin>
|
|
||||||
</compilerPlugins>
|
|
||||||
<jvmTarget>1.8</jvmTarget>
|
|
||||||
</configuration>
|
|
||||||
<executions>
|
|
||||||
<execution>
|
|
||||||
<id>compile</id>
|
|
||||||
<phase>compile</phase>
|
|
||||||
<goals>
|
|
||||||
<goal>compile</goal>
|
|
||||||
</goals>
|
|
||||||
</execution>
|
|
||||||
<execution>
|
|
||||||
<id>test-compile</id>
|
|
||||||
<phase>test-compile</phase>
|
|
||||||
<goals>
|
|
||||||
<goal>test-compile</goal>
|
|
||||||
</goals>
|
|
||||||
</execution>
|
|
||||||
</executions>
|
|
||||||
<dependencies>
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.jetbrains.kotlin</groupId>
|
|
||||||
<artifactId>kotlin-maven-allopen</artifactId>
|
|
||||||
<version>${kotlin.version}</version>
|
|
||||||
</dependency>
|
|
||||||
</dependencies>
|
|
||||||
</plugin>
|
|
||||||
</plugins>
|
|
||||||
</build>
|
|
||||||
<dependencies>
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.jetbrains.kotlin</groupId>
|
|
||||||
<artifactId>kotlin-stdlib-jdk8</artifactId>
|
|
||||||
<version>${kotlin.version}</version>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.jetbrains.kotlin</groupId>
|
|
||||||
<artifactId>kotlin-reflect</artifactId>
|
|
||||||
<version>${kotlin.version}</version>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.springframework.boot</groupId>
|
|
||||||
<artifactId>spring-boot-starter-webflux</artifactId>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.jetbrains.kotlinx</groupId>
|
|
||||||
<artifactId>kotlinx-coroutines-core</artifactId>
|
|
||||||
<version>${kotlinx-coroutines.version}</version>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.jetbrains.kotlinx</groupId>
|
|
||||||
<artifactId>kotlinx-coroutines-reactor</artifactId>
|
|
||||||
<version>${kotlinx-coroutines.version}</version>
|
|
||||||
</dependency>
|
|
||||||
|
|
||||||
<!--SpringDoc dependencies -->
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.springdoc</groupId>
|
|
||||||
<artifactId>springdoc-openapi-webflux-ui</artifactId>
|
|
||||||
<version>${springdoc-openapi.version}</version>
|
|
||||||
</dependency>
|
|
||||||
|
|
||||||
<!-- @Nullable annotation -->
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.google.code.findbugs</groupId>
|
|
||||||
<artifactId>jsr305</artifactId>
|
|
||||||
<version>${findbugs-jsr305.version}</version>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.fasterxml.jackson.dataformat</groupId>
|
|
||||||
<artifactId>jackson-dataformat-yaml</artifactId>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.fasterxml.jackson.dataformat</groupId>
|
|
||||||
<artifactId>jackson-dataformat-xml</artifactId>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.fasterxml.jackson.datatype</groupId>
|
|
||||||
<artifactId>jackson-datatype-jsr310</artifactId>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.fasterxml.jackson.module</groupId>
|
|
||||||
<artifactId>jackson-module-kotlin</artifactId>
|
|
||||||
</dependency>
|
|
||||||
<!-- Bean Validation API support -->
|
|
||||||
<dependency>
|
|
||||||
<groupId>javax.validation</groupId>
|
|
||||||
<artifactId>validation-api</artifactId>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>javax.annotation</groupId>
|
|
||||||
<artifactId>javax.annotation-api</artifactId>
|
|
||||||
<version>${javax-annotation.version}</version>
|
|
||||||
<scope>provided</scope>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.jetbrains.kotlin</groupId>
|
|
||||||
<artifactId>kotlin-test-junit5</artifactId>
|
|
||||||
<version>${kotlin-test-junit5.version}</version>
|
|
||||||
<scope>test</scope>
|
|
||||||
</dependency>
|
|
||||||
</dependencies>
|
|
||||||
</project>
|
|
@ -1,15 +0,0 @@
|
|||||||
pluginManagement {
|
|
||||||
repositories {
|
|
||||||
maven { url = uri("https://repo.spring.io/snapshot") }
|
|
||||||
maven { url = uri("https://repo.spring.io/milestone") }
|
|
||||||
gradlePluginPortal()
|
|
||||||
}
|
|
||||||
resolutionStrategy {
|
|
||||||
eachPlugin {
|
|
||||||
if (requested.id.id == "org.springframework.boot") {
|
|
||||||
useModule("org.springframework.boot:spring-boot-gradle-plugin:${requested.version}")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
rootProject.name = "openapi-spring"
|
|
@ -1,13 +0,0 @@
|
|||||||
package org.openapitools
|
|
||||||
|
|
||||||
import org.springframework.boot.runApplication
|
|
||||||
import org.springframework.boot.autoconfigure.SpringBootApplication
|
|
||||||
import org.springframework.context.annotation.ComponentScan
|
|
||||||
|
|
||||||
@SpringBootApplication
|
|
||||||
@ComponentScan(basePackages = ["org.openapitools", "org.openapitools.api", "org.openapitools.model"])
|
|
||||||
class Application
|
|
||||||
|
|
||||||
fun main(args: Array<String>) {
|
|
||||||
runApplication<Application>(*args)
|
|
||||||
}
|
|
@ -1,26 +0,0 @@
|
|||||||
package org.openapitools
|
|
||||||
|
|
||||||
import org.springframework.context.annotation.Bean
|
|
||||||
import org.springframework.stereotype.Controller
|
|
||||||
import org.springframework.web.bind.annotation.RequestMapping
|
|
||||||
import org.springframework.web.bind.annotation.ResponseBody
|
|
||||||
import org.springframework.web.bind.annotation.GetMapping
|
|
||||||
import org.springframework.web.reactive.function.server.HandlerFunction
|
|
||||||
import org.springframework.web.reactive.function.server.RequestPredicates.GET
|
|
||||||
import org.springframework.web.reactive.function.server.RouterFunction
|
|
||||||
import org.springframework.web.reactive.function.server.RouterFunctions.route
|
|
||||||
import org.springframework.web.reactive.function.server.ServerResponse
|
|
||||||
import java.net.URI
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Home redirection to OpenAPI api documentation
|
|
||||||
*/
|
|
||||||
@Controller
|
|
||||||
class HomeController {
|
|
||||||
|
|
||||||
@Bean
|
|
||||||
fun index(): RouterFunction<ServerResponse> = route(
|
|
||||||
GET("/"), HandlerFunction<ServerResponse> {
|
|
||||||
ServerResponse.temporaryRedirect(URI.create("swagger-ui.html")).build()
|
|
||||||
})
|
|
||||||
}
|
|
@ -1,5 +0,0 @@
|
|||||||
package org.openapitools.api
|
|
||||||
|
|
||||||
|
|
||||||
object ApiUtil {
|
|
||||||
}
|
|
@ -1,183 +0,0 @@
|
|||||||
package org.openapitools.api
|
|
||||||
|
|
||||||
import org.openapitools.model.ModelApiResponse
|
|
||||||
import org.openapitools.model.Pet
|
|
||||||
import io.swagger.v3.oas.annotations.*
|
|
||||||
import io.swagger.v3.oas.annotations.enums.*
|
|
||||||
import io.swagger.v3.oas.annotations.media.*
|
|
||||||
import io.swagger.v3.oas.annotations.responses.*
|
|
||||||
import io.swagger.v3.oas.annotations.security.*
|
|
||||||
import org.springframework.http.HttpStatus
|
|
||||||
import org.springframework.http.MediaType
|
|
||||||
import org.springframework.http.ResponseEntity
|
|
||||||
|
|
||||||
import org.springframework.web.bind.annotation.*
|
|
||||||
import org.springframework.validation.annotation.Validated
|
|
||||||
import org.springframework.web.context.request.NativeWebRequest
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired
|
|
||||||
|
|
||||||
import javax.validation.Valid
|
|
||||||
import javax.validation.constraints.DecimalMax
|
|
||||||
import javax.validation.constraints.DecimalMin
|
|
||||||
import javax.validation.constraints.Email
|
|
||||||
import javax.validation.constraints.Max
|
|
||||||
import javax.validation.constraints.Min
|
|
||||||
import javax.validation.constraints.NotNull
|
|
||||||
import javax.validation.constraints.Pattern
|
|
||||||
import javax.validation.constraints.Size
|
|
||||||
|
|
||||||
import kotlinx.coroutines.flow.Flow
|
|
||||||
import kotlin.collections.List
|
|
||||||
import kotlin.collections.Map
|
|
||||||
|
|
||||||
@RestController
|
|
||||||
@Validated
|
|
||||||
@RequestMapping("\${api.base-path:/v2}")
|
|
||||||
class PetApiController(@Autowired(required = true) val service: PetApiService) {
|
|
||||||
|
|
||||||
@Operation(
|
|
||||||
summary = "Add a new pet to the store",
|
|
||||||
operationId = "addPet",
|
|
||||||
description = """""",
|
|
||||||
responses = [
|
|
||||||
ApiResponse(responseCode = "200", description = "successful operation", content = [Content(schema = Schema(implementation = Pet::class))]),
|
|
||||||
ApiResponse(responseCode = "405", description = "Invalid input") ],
|
|
||||||
security = [ SecurityRequirement(name = "petstore_auth", scopes = [ "write:pets", "read:pets" ]) ]
|
|
||||||
)
|
|
||||||
@RequestMapping(
|
|
||||||
method = [RequestMethod.POST],
|
|
||||||
value = ["/pet"],
|
|
||||||
produces = ["application/xml", "application/json"],
|
|
||||||
consumes = ["application/json", "application/xml"]
|
|
||||||
)
|
|
||||||
suspend fun addPet(@Parameter(description = "Pet object that needs to be added to the store", required = true) @Valid @RequestBody pet: Pet): ResponseEntity<Pet> {
|
|
||||||
return ResponseEntity(service.addPet(pet), HttpStatus.valueOf(200))
|
|
||||||
}
|
|
||||||
|
|
||||||
@Operation(
|
|
||||||
summary = "Deletes a pet",
|
|
||||||
operationId = "deletePet",
|
|
||||||
description = """""",
|
|
||||||
responses = [
|
|
||||||
ApiResponse(responseCode = "400", description = "Invalid pet value") ],
|
|
||||||
security = [ SecurityRequirement(name = "petstore_auth", scopes = [ "write:pets", "read:pets" ]) ]
|
|
||||||
)
|
|
||||||
@RequestMapping(
|
|
||||||
method = [RequestMethod.DELETE],
|
|
||||||
value = ["/pet/{petId}"]
|
|
||||||
)
|
|
||||||
suspend fun deletePet(@Parameter(description = "Pet id to delete", required = true) @PathVariable("petId") petId: kotlin.Long,@Parameter(description = "", `in` = ParameterIn.HEADER) @RequestHeader(value = "api_key", required = false) apiKey: kotlin.String?): ResponseEntity<Unit> {
|
|
||||||
return ResponseEntity(service.deletePet(petId, apiKey), HttpStatus.valueOf(400))
|
|
||||||
}
|
|
||||||
|
|
||||||
@Operation(
|
|
||||||
summary = "Finds Pets by status",
|
|
||||||
operationId = "findPetsByStatus",
|
|
||||||
description = """Multiple status values can be provided with comma separated strings""",
|
|
||||||
responses = [
|
|
||||||
ApiResponse(responseCode = "200", description = "successful operation", content = [Content(array = ArraySchema(schema = Schema(implementation = Pet::class)))]),
|
|
||||||
ApiResponse(responseCode = "400", description = "Invalid status value") ],
|
|
||||||
security = [ SecurityRequirement(name = "petstore_auth", scopes = [ "read:pets" ]) ]
|
|
||||||
)
|
|
||||||
@RequestMapping(
|
|
||||||
method = [RequestMethod.GET],
|
|
||||||
value = ["/pet/findByStatus"],
|
|
||||||
produces = ["application/xml", "application/json"]
|
|
||||||
)
|
|
||||||
fun findPetsByStatus(@NotNull @Parameter(description = "Status values that need to be considered for filter", required = true, schema = Schema(allowableValues = ["available", "pending", "sold"])) @Valid @RequestParam(value = "status", required = true) status: kotlin.collections.List<kotlin.String>): ResponseEntity<Flow<Pet>> {
|
|
||||||
return ResponseEntity(service.findPetsByStatus(status), HttpStatus.valueOf(200))
|
|
||||||
}
|
|
||||||
|
|
||||||
@Operation(
|
|
||||||
summary = "Finds Pets by tags",
|
|
||||||
operationId = "findPetsByTags",
|
|
||||||
description = """Multiple tags can be provided with comma separated strings. Use tag1, tag2, tag3 for testing.""",
|
|
||||||
responses = [
|
|
||||||
ApiResponse(responseCode = "200", description = "successful operation", content = [Content(array = ArraySchema(schema = Schema(implementation = Pet::class)))]),
|
|
||||||
ApiResponse(responseCode = "400", description = "Invalid tag value") ],
|
|
||||||
security = [ SecurityRequirement(name = "petstore_auth", scopes = [ "read:pets" ]) ]
|
|
||||||
)
|
|
||||||
@RequestMapping(
|
|
||||||
method = [RequestMethod.GET],
|
|
||||||
value = ["/pet/findByTags"],
|
|
||||||
produces = ["application/xml", "application/json"]
|
|
||||||
)
|
|
||||||
fun findPetsByTags(@NotNull @Parameter(description = "Tags to filter by", required = true) @Valid @RequestParam(value = "tags", required = true) tags: kotlin.collections.List<kotlin.String>): ResponseEntity<Flow<Pet>> {
|
|
||||||
return ResponseEntity(service.findPetsByTags(tags), HttpStatus.valueOf(200))
|
|
||||||
}
|
|
||||||
|
|
||||||
@Operation(
|
|
||||||
summary = "Find pet by ID",
|
|
||||||
operationId = "getPetById",
|
|
||||||
description = """Returns a single pet""",
|
|
||||||
responses = [
|
|
||||||
ApiResponse(responseCode = "200", description = "successful operation", content = [Content(schema = Schema(implementation = Pet::class))]),
|
|
||||||
ApiResponse(responseCode = "400", description = "Invalid ID supplied"),
|
|
||||||
ApiResponse(responseCode = "404", description = "Pet not found") ],
|
|
||||||
security = [ SecurityRequirement(name = "api_key") ]
|
|
||||||
)
|
|
||||||
@RequestMapping(
|
|
||||||
method = [RequestMethod.GET],
|
|
||||||
value = ["/pet/{petId}"],
|
|
||||||
produces = ["application/xml", "application/json"]
|
|
||||||
)
|
|
||||||
suspend fun getPetById(@Parameter(description = "ID of pet to return", required = true) @PathVariable("petId") petId: kotlin.Long): ResponseEntity<Pet> {
|
|
||||||
return ResponseEntity(service.getPetById(petId), HttpStatus.valueOf(200))
|
|
||||||
}
|
|
||||||
|
|
||||||
@Operation(
|
|
||||||
summary = "Update an existing pet",
|
|
||||||
operationId = "updatePet",
|
|
||||||
description = """""",
|
|
||||||
responses = [
|
|
||||||
ApiResponse(responseCode = "200", description = "successful operation", content = [Content(schema = Schema(implementation = Pet::class))]),
|
|
||||||
ApiResponse(responseCode = "400", description = "Invalid ID supplied"),
|
|
||||||
ApiResponse(responseCode = "404", description = "Pet not found"),
|
|
||||||
ApiResponse(responseCode = "405", description = "Validation exception") ],
|
|
||||||
security = [ SecurityRequirement(name = "petstore_auth", scopes = [ "write:pets", "read:pets" ]) ]
|
|
||||||
)
|
|
||||||
@RequestMapping(
|
|
||||||
method = [RequestMethod.PUT],
|
|
||||||
value = ["/pet"],
|
|
||||||
produces = ["application/xml", "application/json"],
|
|
||||||
consumes = ["application/json", "application/xml"]
|
|
||||||
)
|
|
||||||
suspend fun updatePet(@Parameter(description = "Pet object that needs to be added to the store", required = true) @Valid @RequestBody pet: Pet): ResponseEntity<Pet> {
|
|
||||||
return ResponseEntity(service.updatePet(pet), HttpStatus.valueOf(200))
|
|
||||||
}
|
|
||||||
|
|
||||||
@Operation(
|
|
||||||
summary = "Updates a pet in the store with form data",
|
|
||||||
operationId = "updatePetWithForm",
|
|
||||||
description = """""",
|
|
||||||
responses = [
|
|
||||||
ApiResponse(responseCode = "405", description = "Invalid input") ],
|
|
||||||
security = [ SecurityRequirement(name = "petstore_auth", scopes = [ "write:pets", "read:pets" ]) ]
|
|
||||||
)
|
|
||||||
@RequestMapping(
|
|
||||||
method = [RequestMethod.POST],
|
|
||||||
value = ["/pet/{petId}"],
|
|
||||||
consumes = ["application/x-www-form-urlencoded"]
|
|
||||||
)
|
|
||||||
suspend fun updatePetWithForm(@Parameter(description = "ID of pet that needs to be updated", required = true) @PathVariable("petId") petId: kotlin.Long,@Parameter(description = "Updated name of the pet") @RequestParam(value = "name", required = false) name: kotlin.String? ,@Parameter(description = "Updated status of the pet") @RequestParam(value = "status", required = false) status: kotlin.String? ): ResponseEntity<Unit> {
|
|
||||||
return ResponseEntity(service.updatePetWithForm(petId, name, status), HttpStatus.valueOf(405))
|
|
||||||
}
|
|
||||||
|
|
||||||
@Operation(
|
|
||||||
summary = "uploads an image",
|
|
||||||
operationId = "uploadFile",
|
|
||||||
description = """""",
|
|
||||||
responses = [
|
|
||||||
ApiResponse(responseCode = "200", description = "successful operation", content = [Content(schema = Schema(implementation = ModelApiResponse::class))]) ],
|
|
||||||
security = [ SecurityRequirement(name = "petstore_auth", scopes = [ "write:pets", "read:pets" ]) ]
|
|
||||||
)
|
|
||||||
@RequestMapping(
|
|
||||||
method = [RequestMethod.POST],
|
|
||||||
value = ["/pet/{petId}/uploadImage"],
|
|
||||||
produces = ["application/json"],
|
|
||||||
consumes = ["multipart/form-data"]
|
|
||||||
)
|
|
||||||
suspend fun uploadFile(@Parameter(description = "ID of pet to update", required = true) @PathVariable("petId") petId: kotlin.Long,@Parameter(description = "Additional data to pass to server") @RequestParam(value = "additionalMetadata", required = false) additionalMetadata: kotlin.String? ,@Parameter(description = "file to upload") @Valid @RequestPart("file", required = false) file: org.springframework.web.multipart.MultipartFile?): ResponseEntity<ModelApiResponse> {
|
|
||||||
return ResponseEntity(service.uploadFile(petId, additionalMetadata, file), HttpStatus.valueOf(200))
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,104 +0,0 @@
|
|||||||
package org.openapitools.api
|
|
||||||
|
|
||||||
import org.openapitools.model.ModelApiResponse
|
|
||||||
import org.openapitools.model.Pet
|
|
||||||
import kotlinx.coroutines.flow.Flow
|
|
||||||
|
|
||||||
interface PetApiService {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* POST /pet : Add a new pet to the store
|
|
||||||
*
|
|
||||||
*
|
|
||||||
* @param pet Pet object that needs to be added to the store (required)
|
|
||||||
* @return successful operation (status code 200)
|
|
||||||
* or Invalid input (status code 405)
|
|
||||||
* @see PetApi#addPet
|
|
||||||
*/
|
|
||||||
suspend fun addPet(pet: Pet): Pet
|
|
||||||
|
|
||||||
/**
|
|
||||||
* DELETE /pet/{petId} : Deletes a pet
|
|
||||||
*
|
|
||||||
*
|
|
||||||
* @param petId Pet id to delete (required)
|
|
||||||
* @param apiKey (optional)
|
|
||||||
* @return Invalid pet value (status code 400)
|
|
||||||
* @see PetApi#deletePet
|
|
||||||
*/
|
|
||||||
suspend fun deletePet(petId: kotlin.Long, apiKey: kotlin.String?): Unit
|
|
||||||
|
|
||||||
/**
|
|
||||||
* GET /pet/findByStatus : Finds Pets by status
|
|
||||||
* Multiple status values can be provided with comma separated strings
|
|
||||||
*
|
|
||||||
* @param status Status values that need to be considered for filter (required)
|
|
||||||
* @return successful operation (status code 200)
|
|
||||||
* or Invalid status value (status code 400)
|
|
||||||
* @see PetApi#findPetsByStatus
|
|
||||||
*/
|
|
||||||
fun findPetsByStatus(status: kotlin.collections.List<kotlin.String>): Flow<Pet>
|
|
||||||
|
|
||||||
/**
|
|
||||||
* GET /pet/findByTags : Finds Pets by tags
|
|
||||||
* Multiple tags can be provided with comma separated strings. Use tag1, tag2, tag3 for testing.
|
|
||||||
*
|
|
||||||
* @param tags Tags to filter by (required)
|
|
||||||
* @return successful operation (status code 200)
|
|
||||||
* or Invalid tag value (status code 400)
|
|
||||||
* @deprecated
|
|
||||||
* @see PetApi#findPetsByTags
|
|
||||||
*/
|
|
||||||
fun findPetsByTags(tags: kotlin.collections.List<kotlin.String>): Flow<Pet>
|
|
||||||
|
|
||||||
/**
|
|
||||||
* GET /pet/{petId} : Find pet by ID
|
|
||||||
* Returns a single pet
|
|
||||||
*
|
|
||||||
* @param petId ID of pet to return (required)
|
|
||||||
* @return successful operation (status code 200)
|
|
||||||
* or Invalid ID supplied (status code 400)
|
|
||||||
* or Pet not found (status code 404)
|
|
||||||
* @see PetApi#getPetById
|
|
||||||
*/
|
|
||||||
suspend fun getPetById(petId: kotlin.Long): Pet
|
|
||||||
|
|
||||||
/**
|
|
||||||
* PUT /pet : Update an existing pet
|
|
||||||
*
|
|
||||||
*
|
|
||||||
* @param pet Pet object that needs to be added to the store (required)
|
|
||||||
* @return successful operation (status code 200)
|
|
||||||
* or Invalid ID supplied (status code 400)
|
|
||||||
* or Pet not found (status code 404)
|
|
||||||
* or Validation exception (status code 405)
|
|
||||||
* API documentation for the updatePet operation
|
|
||||||
* @see <a href="http://petstore.swagger.io/v2/doc/updatePet">Update an existing pet Documentation</a>
|
|
||||||
* @see PetApi#updatePet
|
|
||||||
*/
|
|
||||||
suspend fun updatePet(pet: Pet): Pet
|
|
||||||
|
|
||||||
/**
|
|
||||||
* POST /pet/{petId} : Updates a pet in the store with form data
|
|
||||||
*
|
|
||||||
*
|
|
||||||
* @param petId ID of pet that needs to be updated (required)
|
|
||||||
* @param name Updated name of the pet (optional)
|
|
||||||
* @param status Updated status of the pet (optional)
|
|
||||||
* @return Invalid input (status code 405)
|
|
||||||
* @see PetApi#updatePetWithForm
|
|
||||||
*/
|
|
||||||
suspend fun updatePetWithForm(petId: kotlin.Long, name: kotlin.String?, status: kotlin.String?): Unit
|
|
||||||
|
|
||||||
/**
|
|
||||||
* POST /pet/{petId}/uploadImage : uploads an image
|
|
||||||
*
|
|
||||||
*
|
|
||||||
* @param petId ID of pet to update (required)
|
|
||||||
* @param additionalMetadata Additional data to pass to server (optional)
|
|
||||||
* @param file file to upload (optional)
|
|
||||||
* @return successful operation (status code 200)
|
|
||||||
* @see PetApi#uploadFile
|
|
||||||
*/
|
|
||||||
suspend fun uploadFile(petId: kotlin.Long, additionalMetadata: kotlin.String?, file: org.springframework.web.multipart.MultipartFile?): ModelApiResponse
|
|
||||||
}
|
|
@ -1,41 +0,0 @@
|
|||||||
package org.openapitools.api
|
|
||||||
|
|
||||||
import org.openapitools.model.ModelApiResponse
|
|
||||||
import org.openapitools.model.Pet
|
|
||||||
import kotlinx.coroutines.flow.Flow
|
|
||||||
import org.springframework.stereotype.Service
|
|
||||||
@Service
|
|
||||||
class PetApiServiceImpl : PetApiService {
|
|
||||||
|
|
||||||
override suspend fun addPet(pet: Pet): Pet {
|
|
||||||
TODO("Implement me")
|
|
||||||
}
|
|
||||||
|
|
||||||
override suspend fun deletePet(petId: kotlin.Long, apiKey: kotlin.String?): Unit {
|
|
||||||
TODO("Implement me")
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun findPetsByStatus(status: kotlin.collections.List<kotlin.String>): Flow<Pet> {
|
|
||||||
TODO("Implement me")
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun findPetsByTags(tags: kotlin.collections.List<kotlin.String>): Flow<Pet> {
|
|
||||||
TODO("Implement me")
|
|
||||||
}
|
|
||||||
|
|
||||||
override suspend fun getPetById(petId: kotlin.Long): Pet {
|
|
||||||
TODO("Implement me")
|
|
||||||
}
|
|
||||||
|
|
||||||
override suspend fun updatePet(pet: Pet): Pet {
|
|
||||||
TODO("Implement me")
|
|
||||||
}
|
|
||||||
|
|
||||||
override suspend fun updatePetWithForm(petId: kotlin.Long, name: kotlin.String?, status: kotlin.String?): Unit {
|
|
||||||
TODO("Implement me")
|
|
||||||
}
|
|
||||||
|
|
||||||
override suspend fun uploadFile(petId: kotlin.Long, additionalMetadata: kotlin.String?, file: org.springframework.web.multipart.MultipartFile?): ModelApiResponse {
|
|
||||||
TODO("Implement me")
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,105 +0,0 @@
|
|||||||
package org.openapitools.api
|
|
||||||
|
|
||||||
import org.openapitools.model.Order
|
|
||||||
import io.swagger.v3.oas.annotations.*
|
|
||||||
import io.swagger.v3.oas.annotations.enums.*
|
|
||||||
import io.swagger.v3.oas.annotations.media.*
|
|
||||||
import io.swagger.v3.oas.annotations.responses.*
|
|
||||||
import io.swagger.v3.oas.annotations.security.*
|
|
||||||
import org.springframework.http.HttpStatus
|
|
||||||
import org.springframework.http.MediaType
|
|
||||||
import org.springframework.http.ResponseEntity
|
|
||||||
|
|
||||||
import org.springframework.web.bind.annotation.*
|
|
||||||
import org.springframework.validation.annotation.Validated
|
|
||||||
import org.springframework.web.context.request.NativeWebRequest
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired
|
|
||||||
|
|
||||||
import javax.validation.Valid
|
|
||||||
import javax.validation.constraints.DecimalMax
|
|
||||||
import javax.validation.constraints.DecimalMin
|
|
||||||
import javax.validation.constraints.Email
|
|
||||||
import javax.validation.constraints.Max
|
|
||||||
import javax.validation.constraints.Min
|
|
||||||
import javax.validation.constraints.NotNull
|
|
||||||
import javax.validation.constraints.Pattern
|
|
||||||
import javax.validation.constraints.Size
|
|
||||||
|
|
||||||
import kotlinx.coroutines.flow.Flow
|
|
||||||
import kotlin.collections.List
|
|
||||||
import kotlin.collections.Map
|
|
||||||
|
|
||||||
@RestController
|
|
||||||
@Validated
|
|
||||||
@RequestMapping("\${api.base-path:/v2}")
|
|
||||||
class StoreApiController(@Autowired(required = true) val service: StoreApiService) {
|
|
||||||
|
|
||||||
@Operation(
|
|
||||||
summary = "Delete purchase order by ID",
|
|
||||||
operationId = "deleteOrder",
|
|
||||||
description = """For valid response try integer IDs with value < 1000. Anything above 1000 or nonintegers will generate API errors""",
|
|
||||||
responses = [
|
|
||||||
ApiResponse(responseCode = "400", description = "Invalid ID supplied"),
|
|
||||||
ApiResponse(responseCode = "404", description = "Order not found") ]
|
|
||||||
)
|
|
||||||
@RequestMapping(
|
|
||||||
method = [RequestMethod.DELETE],
|
|
||||||
value = ["/store/order/{orderId}"]
|
|
||||||
)
|
|
||||||
suspend fun deleteOrder(@Parameter(description = "ID of the order that needs to be deleted", required = true) @PathVariable("orderId") orderId: kotlin.String): ResponseEntity<Unit> {
|
|
||||||
return ResponseEntity(service.deleteOrder(orderId), HttpStatus.valueOf(400))
|
|
||||||
}
|
|
||||||
|
|
||||||
@Operation(
|
|
||||||
summary = "Returns pet inventories by status",
|
|
||||||
operationId = "getInventory",
|
|
||||||
description = """Returns a map of status codes to quantities""",
|
|
||||||
responses = [
|
|
||||||
ApiResponse(responseCode = "200", description = "successful operation", content = [Content(schema = Schema(implementation = kotlin.collections.Map::class))]) ],
|
|
||||||
security = [ SecurityRequirement(name = "api_key") ]
|
|
||||||
)
|
|
||||||
@RequestMapping(
|
|
||||||
method = [RequestMethod.GET],
|
|
||||||
value = ["/store/inventory"],
|
|
||||||
produces = ["application/json"]
|
|
||||||
)
|
|
||||||
suspend fun getInventory(): ResponseEntity<Map<String, kotlin.Int>> {
|
|
||||||
return ResponseEntity(service.getInventory(), HttpStatus.valueOf(200))
|
|
||||||
}
|
|
||||||
|
|
||||||
@Operation(
|
|
||||||
summary = "Find purchase order by ID",
|
|
||||||
operationId = "getOrderById",
|
|
||||||
description = """For valid response try integer IDs with value <= 5 or > 10. Other values will generate exceptions""",
|
|
||||||
responses = [
|
|
||||||
ApiResponse(responseCode = "200", description = "successful operation", content = [Content(schema = Schema(implementation = Order::class))]),
|
|
||||||
ApiResponse(responseCode = "400", description = "Invalid ID supplied"),
|
|
||||||
ApiResponse(responseCode = "404", description = "Order not found") ]
|
|
||||||
)
|
|
||||||
@RequestMapping(
|
|
||||||
method = [RequestMethod.GET],
|
|
||||||
value = ["/store/order/{orderId}"],
|
|
||||||
produces = ["application/xml", "application/json"]
|
|
||||||
)
|
|
||||||
suspend fun getOrderById(@Min(1L) @Max(5L) @Parameter(description = "ID of pet that needs to be fetched", required = true) @PathVariable("orderId") orderId: kotlin.Long): ResponseEntity<Order> {
|
|
||||||
return ResponseEntity(service.getOrderById(orderId), HttpStatus.valueOf(200))
|
|
||||||
}
|
|
||||||
|
|
||||||
@Operation(
|
|
||||||
summary = "Place an order for a pet",
|
|
||||||
operationId = "placeOrder",
|
|
||||||
description = """""",
|
|
||||||
responses = [
|
|
||||||
ApiResponse(responseCode = "200", description = "successful operation", content = [Content(schema = Schema(implementation = Order::class))]),
|
|
||||||
ApiResponse(responseCode = "400", description = "Invalid Order") ]
|
|
||||||
)
|
|
||||||
@RequestMapping(
|
|
||||||
method = [RequestMethod.POST],
|
|
||||||
value = ["/store/order"],
|
|
||||||
produces = ["application/xml", "application/json"],
|
|
||||||
consumes = ["application/json"]
|
|
||||||
)
|
|
||||||
suspend fun placeOrder(@Parameter(description = "order placed for purchasing the pet", required = true) @Valid @RequestBody order: Order): ResponseEntity<Order> {
|
|
||||||
return ResponseEntity(service.placeOrder(order), HttpStatus.valueOf(200))
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,50 +0,0 @@
|
|||||||
package org.openapitools.api
|
|
||||||
|
|
||||||
import org.openapitools.model.Order
|
|
||||||
import kotlinx.coroutines.flow.Flow
|
|
||||||
|
|
||||||
interface StoreApiService {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* DELETE /store/order/{orderId} : Delete purchase order by ID
|
|
||||||
* For valid response try integer IDs with value < 1000. Anything above 1000 or nonintegers will generate API errors
|
|
||||||
*
|
|
||||||
* @param orderId ID of the order that needs to be deleted (required)
|
|
||||||
* @return Invalid ID supplied (status code 400)
|
|
||||||
* or Order not found (status code 404)
|
|
||||||
* @see StoreApi#deleteOrder
|
|
||||||
*/
|
|
||||||
suspend fun deleteOrder(orderId: kotlin.String): Unit
|
|
||||||
|
|
||||||
/**
|
|
||||||
* GET /store/inventory : Returns pet inventories by status
|
|
||||||
* Returns a map of status codes to quantities
|
|
||||||
*
|
|
||||||
* @return successful operation (status code 200)
|
|
||||||
* @see StoreApi#getInventory
|
|
||||||
*/
|
|
||||||
suspend fun getInventory(): Map<String, kotlin.Int>
|
|
||||||
|
|
||||||
/**
|
|
||||||
* GET /store/order/{orderId} : Find purchase order by ID
|
|
||||||
* For valid response try integer IDs with value <= 5 or > 10. Other values will generate exceptions
|
|
||||||
*
|
|
||||||
* @param orderId ID of pet that needs to be fetched (required)
|
|
||||||
* @return successful operation (status code 200)
|
|
||||||
* or Invalid ID supplied (status code 400)
|
|
||||||
* or Order not found (status code 404)
|
|
||||||
* @see StoreApi#getOrderById
|
|
||||||
*/
|
|
||||||
suspend fun getOrderById(orderId: kotlin.Long): Order
|
|
||||||
|
|
||||||
/**
|
|
||||||
* POST /store/order : Place an order for a pet
|
|
||||||
*
|
|
||||||
*
|
|
||||||
* @param order order placed for purchasing the pet (required)
|
|
||||||
* @return successful operation (status code 200)
|
|
||||||
* or Invalid Order (status code 400)
|
|
||||||
* @see StoreApi#placeOrder
|
|
||||||
*/
|
|
||||||
suspend fun placeOrder(order: Order): Order
|
|
||||||
}
|
|
@ -1,24 +0,0 @@
|
|||||||
package org.openapitools.api
|
|
||||||
|
|
||||||
import org.openapitools.model.Order
|
|
||||||
import kotlinx.coroutines.flow.Flow
|
|
||||||
import org.springframework.stereotype.Service
|
|
||||||
@Service
|
|
||||||
class StoreApiServiceImpl : StoreApiService {
|
|
||||||
|
|
||||||
override suspend fun deleteOrder(orderId: kotlin.String): Unit {
|
|
||||||
TODO("Implement me")
|
|
||||||
}
|
|
||||||
|
|
||||||
override suspend fun getInventory(): Map<String, kotlin.Int> {
|
|
||||||
TODO("Implement me")
|
|
||||||
}
|
|
||||||
|
|
||||||
override suspend fun getOrderById(orderId: kotlin.Long): Order {
|
|
||||||
TODO("Implement me")
|
|
||||||
}
|
|
||||||
|
|
||||||
override suspend fun placeOrder(order: Order): Order {
|
|
||||||
TODO("Implement me")
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,173 +0,0 @@
|
|||||||
package org.openapitools.api
|
|
||||||
|
|
||||||
import org.openapitools.model.User
|
|
||||||
import io.swagger.v3.oas.annotations.*
|
|
||||||
import io.swagger.v3.oas.annotations.enums.*
|
|
||||||
import io.swagger.v3.oas.annotations.media.*
|
|
||||||
import io.swagger.v3.oas.annotations.responses.*
|
|
||||||
import io.swagger.v3.oas.annotations.security.*
|
|
||||||
import org.springframework.http.HttpStatus
|
|
||||||
import org.springframework.http.MediaType
|
|
||||||
import org.springframework.http.ResponseEntity
|
|
||||||
|
|
||||||
import org.springframework.web.bind.annotation.*
|
|
||||||
import org.springframework.validation.annotation.Validated
|
|
||||||
import org.springframework.web.context.request.NativeWebRequest
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired
|
|
||||||
|
|
||||||
import javax.validation.Valid
|
|
||||||
import javax.validation.constraints.DecimalMax
|
|
||||||
import javax.validation.constraints.DecimalMin
|
|
||||||
import javax.validation.constraints.Email
|
|
||||||
import javax.validation.constraints.Max
|
|
||||||
import javax.validation.constraints.Min
|
|
||||||
import javax.validation.constraints.NotNull
|
|
||||||
import javax.validation.constraints.Pattern
|
|
||||||
import javax.validation.constraints.Size
|
|
||||||
|
|
||||||
import kotlinx.coroutines.flow.Flow
|
|
||||||
import kotlin.collections.List
|
|
||||||
import kotlin.collections.Map
|
|
||||||
|
|
||||||
@RestController
|
|
||||||
@Validated
|
|
||||||
@RequestMapping("\${api.base-path:/v2}")
|
|
||||||
class UserApiController(@Autowired(required = true) val service: UserApiService) {
|
|
||||||
|
|
||||||
@Operation(
|
|
||||||
summary = "Create user",
|
|
||||||
operationId = "createUser",
|
|
||||||
description = """This can only be done by the logged in user.""",
|
|
||||||
responses = [
|
|
||||||
ApiResponse(responseCode = "200", description = "successful operation") ],
|
|
||||||
security = [ SecurityRequirement(name = "api_key") ]
|
|
||||||
)
|
|
||||||
@RequestMapping(
|
|
||||||
method = [RequestMethod.POST],
|
|
||||||
value = ["/user"],
|
|
||||||
consumes = ["application/json"]
|
|
||||||
)
|
|
||||||
suspend fun createUser(@Parameter(description = "Created user object", required = true) @Valid @RequestBody user: User): ResponseEntity<Unit> {
|
|
||||||
return ResponseEntity(service.createUser(user), HttpStatus.valueOf(200))
|
|
||||||
}
|
|
||||||
|
|
||||||
@Operation(
|
|
||||||
summary = "Creates list of users with given input array",
|
|
||||||
operationId = "createUsersWithArrayInput",
|
|
||||||
description = """""",
|
|
||||||
responses = [
|
|
||||||
ApiResponse(responseCode = "200", description = "successful operation") ],
|
|
||||||
security = [ SecurityRequirement(name = "api_key") ]
|
|
||||||
)
|
|
||||||
@RequestMapping(
|
|
||||||
method = [RequestMethod.POST],
|
|
||||||
value = ["/user/createWithArray"],
|
|
||||||
consumes = ["application/json"]
|
|
||||||
)
|
|
||||||
suspend fun createUsersWithArrayInput(@Parameter(description = "List of user object", required = true) @Valid @RequestBody user: Flow<User>): ResponseEntity<Unit> {
|
|
||||||
return ResponseEntity(service.createUsersWithArrayInput(user), HttpStatus.valueOf(200))
|
|
||||||
}
|
|
||||||
|
|
||||||
@Operation(
|
|
||||||
summary = "Creates list of users with given input array",
|
|
||||||
operationId = "createUsersWithListInput",
|
|
||||||
description = """""",
|
|
||||||
responses = [
|
|
||||||
ApiResponse(responseCode = "200", description = "successful operation") ],
|
|
||||||
security = [ SecurityRequirement(name = "api_key") ]
|
|
||||||
)
|
|
||||||
@RequestMapping(
|
|
||||||
method = [RequestMethod.POST],
|
|
||||||
value = ["/user/createWithList"],
|
|
||||||
consumes = ["application/json"]
|
|
||||||
)
|
|
||||||
suspend fun createUsersWithListInput(@Parameter(description = "List of user object", required = true) @Valid @RequestBody user: Flow<User>): ResponseEntity<Unit> {
|
|
||||||
return ResponseEntity(service.createUsersWithListInput(user), HttpStatus.valueOf(200))
|
|
||||||
}
|
|
||||||
|
|
||||||
@Operation(
|
|
||||||
summary = "Delete user",
|
|
||||||
operationId = "deleteUser",
|
|
||||||
description = """This can only be done by the logged in user.""",
|
|
||||||
responses = [
|
|
||||||
ApiResponse(responseCode = "400", description = "Invalid username supplied"),
|
|
||||||
ApiResponse(responseCode = "404", description = "User not found") ],
|
|
||||||
security = [ SecurityRequirement(name = "api_key") ]
|
|
||||||
)
|
|
||||||
@RequestMapping(
|
|
||||||
method = [RequestMethod.DELETE],
|
|
||||||
value = ["/user/{username}"]
|
|
||||||
)
|
|
||||||
suspend fun deleteUser(@Parameter(description = "The name that needs to be deleted", required = true) @PathVariable("username") username: kotlin.String): ResponseEntity<Unit> {
|
|
||||||
return ResponseEntity(service.deleteUser(username), HttpStatus.valueOf(400))
|
|
||||||
}
|
|
||||||
|
|
||||||
@Operation(
|
|
||||||
summary = "Get user by user name",
|
|
||||||
operationId = "getUserByName",
|
|
||||||
description = """""",
|
|
||||||
responses = [
|
|
||||||
ApiResponse(responseCode = "200", description = "successful operation", content = [Content(schema = Schema(implementation = User::class))]),
|
|
||||||
ApiResponse(responseCode = "400", description = "Invalid username supplied"),
|
|
||||||
ApiResponse(responseCode = "404", description = "User not found") ]
|
|
||||||
)
|
|
||||||
@RequestMapping(
|
|
||||||
method = [RequestMethod.GET],
|
|
||||||
value = ["/user/{username}"],
|
|
||||||
produces = ["application/xml", "application/json"]
|
|
||||||
)
|
|
||||||
suspend fun getUserByName(@Parameter(description = "The name that needs to be fetched. Use user1 for testing.", required = true) @PathVariable("username") username: kotlin.String): ResponseEntity<User> {
|
|
||||||
return ResponseEntity(service.getUserByName(username), HttpStatus.valueOf(200))
|
|
||||||
}
|
|
||||||
|
|
||||||
@Operation(
|
|
||||||
summary = "Logs user into the system",
|
|
||||||
operationId = "loginUser",
|
|
||||||
description = """""",
|
|
||||||
responses = [
|
|
||||||
ApiResponse(responseCode = "200", description = "successful operation", content = [Content(schema = Schema(implementation = kotlin.String::class))]),
|
|
||||||
ApiResponse(responseCode = "400", description = "Invalid username/password supplied") ]
|
|
||||||
)
|
|
||||||
@RequestMapping(
|
|
||||||
method = [RequestMethod.GET],
|
|
||||||
value = ["/user/login"],
|
|
||||||
produces = ["application/xml", "application/json"]
|
|
||||||
)
|
|
||||||
suspend fun loginUser(@NotNull @Pattern(regexp="^[a-zA-Z0-9]+[a-zA-Z0-9\\.\\-_]*[a-zA-Z0-9]+$") @Parameter(description = "The user name for login", required = true) @Valid @RequestParam(value = "username", required = true) username: kotlin.String,@NotNull @Parameter(description = "The password for login in clear text", required = true) @Valid @RequestParam(value = "password", required = true) password: kotlin.String): ResponseEntity<kotlin.String> {
|
|
||||||
return ResponseEntity(service.loginUser(username, password), HttpStatus.valueOf(200))
|
|
||||||
}
|
|
||||||
|
|
||||||
@Operation(
|
|
||||||
summary = "Logs out current logged in user session",
|
|
||||||
operationId = "logoutUser",
|
|
||||||
description = """""",
|
|
||||||
responses = [
|
|
||||||
ApiResponse(responseCode = "200", description = "successful operation") ],
|
|
||||||
security = [ SecurityRequirement(name = "api_key") ]
|
|
||||||
)
|
|
||||||
@RequestMapping(
|
|
||||||
method = [RequestMethod.GET],
|
|
||||||
value = ["/user/logout"]
|
|
||||||
)
|
|
||||||
suspend fun logoutUser(): ResponseEntity<Unit> {
|
|
||||||
return ResponseEntity(service.logoutUser(), HttpStatus.valueOf(200))
|
|
||||||
}
|
|
||||||
|
|
||||||
@Operation(
|
|
||||||
summary = "Updated user",
|
|
||||||
operationId = "updateUser",
|
|
||||||
description = """This can only be done by the logged in user.""",
|
|
||||||
responses = [
|
|
||||||
ApiResponse(responseCode = "400", description = "Invalid user supplied"),
|
|
||||||
ApiResponse(responseCode = "404", description = "User not found") ],
|
|
||||||
security = [ SecurityRequirement(name = "api_key") ]
|
|
||||||
)
|
|
||||||
@RequestMapping(
|
|
||||||
method = [RequestMethod.PUT],
|
|
||||||
value = ["/user/{username}"],
|
|
||||||
consumes = ["application/json"]
|
|
||||||
)
|
|
||||||
suspend fun updateUser(@Parameter(description = "name that need to be deleted", required = true) @PathVariable("username") username: kotlin.String,@Parameter(description = "Updated user object", required = true) @Valid @RequestBody user: User): ResponseEntity<Unit> {
|
|
||||||
return ResponseEntity(service.updateUser(username, user), HttpStatus.valueOf(400))
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,93 +0,0 @@
|
|||||||
package org.openapitools.api
|
|
||||||
|
|
||||||
import org.openapitools.model.User
|
|
||||||
import kotlinx.coroutines.flow.Flow
|
|
||||||
|
|
||||||
interface UserApiService {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* POST /user : Create user
|
|
||||||
* This can only be done by the logged in user.
|
|
||||||
*
|
|
||||||
* @param user Created user object (required)
|
|
||||||
* @return successful operation (status code 200)
|
|
||||||
* @see UserApi#createUser
|
|
||||||
*/
|
|
||||||
suspend fun createUser(user: User): Unit
|
|
||||||
|
|
||||||
/**
|
|
||||||
* POST /user/createWithArray : Creates list of users with given input array
|
|
||||||
*
|
|
||||||
*
|
|
||||||
* @param user List of user object (required)
|
|
||||||
* @return successful operation (status code 200)
|
|
||||||
* @see UserApi#createUsersWithArrayInput
|
|
||||||
*/
|
|
||||||
suspend fun createUsersWithArrayInput(user: Flow<User>): Unit
|
|
||||||
|
|
||||||
/**
|
|
||||||
* POST /user/createWithList : Creates list of users with given input array
|
|
||||||
*
|
|
||||||
*
|
|
||||||
* @param user List of user object (required)
|
|
||||||
* @return successful operation (status code 200)
|
|
||||||
* @see UserApi#createUsersWithListInput
|
|
||||||
*/
|
|
||||||
suspend fun createUsersWithListInput(user: Flow<User>): Unit
|
|
||||||
|
|
||||||
/**
|
|
||||||
* DELETE /user/{username} : Delete user
|
|
||||||
* This can only be done by the logged in user.
|
|
||||||
*
|
|
||||||
* @param username The name that needs to be deleted (required)
|
|
||||||
* @return Invalid username supplied (status code 400)
|
|
||||||
* or User not found (status code 404)
|
|
||||||
* @see UserApi#deleteUser
|
|
||||||
*/
|
|
||||||
suspend fun deleteUser(username: kotlin.String): Unit
|
|
||||||
|
|
||||||
/**
|
|
||||||
* GET /user/{username} : Get user by user name
|
|
||||||
*
|
|
||||||
*
|
|
||||||
* @param username The name that needs to be fetched. Use user1 for testing. (required)
|
|
||||||
* @return successful operation (status code 200)
|
|
||||||
* or Invalid username supplied (status code 400)
|
|
||||||
* or User not found (status code 404)
|
|
||||||
* @see UserApi#getUserByName
|
|
||||||
*/
|
|
||||||
suspend fun getUserByName(username: kotlin.String): User
|
|
||||||
|
|
||||||
/**
|
|
||||||
* GET /user/login : Logs user into the system
|
|
||||||
*
|
|
||||||
*
|
|
||||||
* @param username The user name for login (required)
|
|
||||||
* @param password The password for login in clear text (required)
|
|
||||||
* @return successful operation (status code 200)
|
|
||||||
* or Invalid username/password supplied (status code 400)
|
|
||||||
* @see UserApi#loginUser
|
|
||||||
*/
|
|
||||||
suspend fun loginUser(username: kotlin.String, password: kotlin.String): kotlin.String
|
|
||||||
|
|
||||||
/**
|
|
||||||
* GET /user/logout : Logs out current logged in user session
|
|
||||||
*
|
|
||||||
*
|
|
||||||
* @return successful operation (status code 200)
|
|
||||||
* @see UserApi#logoutUser
|
|
||||||
*/
|
|
||||||
suspend fun logoutUser(): Unit
|
|
||||||
|
|
||||||
/**
|
|
||||||
* PUT /user/{username} : Updated user
|
|
||||||
* This can only be done by the logged in user.
|
|
||||||
*
|
|
||||||
* @param username name that need to be deleted (required)
|
|
||||||
* @param user Updated user object (required)
|
|
||||||
* @return Invalid user supplied (status code 400)
|
|
||||||
* or User not found (status code 404)
|
|
||||||
* @see UserApi#updateUser
|
|
||||||
*/
|
|
||||||
suspend fun updateUser(username: kotlin.String, user: User): Unit
|
|
||||||
}
|
|
@ -1,40 +0,0 @@
|
|||||||
package org.openapitools.api
|
|
||||||
|
|
||||||
import org.openapitools.model.User
|
|
||||||
import kotlinx.coroutines.flow.Flow
|
|
||||||
import org.springframework.stereotype.Service
|
|
||||||
@Service
|
|
||||||
class UserApiServiceImpl : UserApiService {
|
|
||||||
|
|
||||||
override suspend fun createUser(user: User): Unit {
|
|
||||||
TODO("Implement me")
|
|
||||||
}
|
|
||||||
|
|
||||||
override suspend fun createUsersWithArrayInput(user: Flow<User>): Unit {
|
|
||||||
TODO("Implement me")
|
|
||||||
}
|
|
||||||
|
|
||||||
override suspend fun createUsersWithListInput(user: Flow<User>): Unit {
|
|
||||||
TODO("Implement me")
|
|
||||||
}
|
|
||||||
|
|
||||||
override suspend fun deleteUser(username: kotlin.String): Unit {
|
|
||||||
TODO("Implement me")
|
|
||||||
}
|
|
||||||
|
|
||||||
override suspend fun getUserByName(username: kotlin.String): User {
|
|
||||||
TODO("Implement me")
|
|
||||||
}
|
|
||||||
|
|
||||||
override suspend fun loginUser(username: kotlin.String, password: kotlin.String): kotlin.String {
|
|
||||||
TODO("Implement me")
|
|
||||||
}
|
|
||||||
|
|
||||||
override suspend fun logoutUser(): Unit {
|
|
||||||
TODO("Implement me")
|
|
||||||
}
|
|
||||||
|
|
||||||
override suspend fun updateUser(username: kotlin.String, user: User): Unit {
|
|
||||||
TODO("Implement me")
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,32 +0,0 @@
|
|||||||
package org.openapitools.model
|
|
||||||
|
|
||||||
import java.util.Objects
|
|
||||||
import com.fasterxml.jackson.annotation.JsonProperty
|
|
||||||
import javax.validation.constraints.DecimalMax
|
|
||||||
import javax.validation.constraints.DecimalMin
|
|
||||||
import javax.validation.constraints.Email
|
|
||||||
import javax.validation.constraints.Max
|
|
||||||
import javax.validation.constraints.Min
|
|
||||||
import javax.validation.constraints.NotNull
|
|
||||||
import javax.validation.constraints.Pattern
|
|
||||||
import javax.validation.constraints.Size
|
|
||||||
import javax.validation.Valid
|
|
||||||
import io.swagger.v3.oas.annotations.media.Schema
|
|
||||||
|
|
||||||
/**
|
|
||||||
* A category for a pet
|
|
||||||
* @param id
|
|
||||||
* @param name
|
|
||||||
*/
|
|
||||||
data class Category(
|
|
||||||
|
|
||||||
@Schema(example = "null", description = "")
|
|
||||||
@get:JsonProperty("id") val id: kotlin.Long? = null,
|
|
||||||
|
|
||||||
@get:Pattern(regexp="^[a-zA-Z0-9]+[a-zA-Z0-9\\.\\-_]*[a-zA-Z0-9]+$")
|
|
||||||
@Schema(example = "null", description = "")
|
|
||||||
@get:JsonProperty("name") val name: kotlin.String? = null
|
|
||||||
) {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
@ -1,35 +0,0 @@
|
|||||||
package org.openapitools.model
|
|
||||||
|
|
||||||
import java.util.Objects
|
|
||||||
import com.fasterxml.jackson.annotation.JsonProperty
|
|
||||||
import javax.validation.constraints.DecimalMax
|
|
||||||
import javax.validation.constraints.DecimalMin
|
|
||||||
import javax.validation.constraints.Email
|
|
||||||
import javax.validation.constraints.Max
|
|
||||||
import javax.validation.constraints.Min
|
|
||||||
import javax.validation.constraints.NotNull
|
|
||||||
import javax.validation.constraints.Pattern
|
|
||||||
import javax.validation.constraints.Size
|
|
||||||
import javax.validation.Valid
|
|
||||||
import io.swagger.v3.oas.annotations.media.Schema
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Describes the result of uploading an image resource
|
|
||||||
* @param code
|
|
||||||
* @param type
|
|
||||||
* @param message
|
|
||||||
*/
|
|
||||||
data class ModelApiResponse(
|
|
||||||
|
|
||||||
@Schema(example = "null", description = "")
|
|
||||||
@get:JsonProperty("code") val code: kotlin.Int? = null,
|
|
||||||
|
|
||||||
@Schema(example = "null", description = "")
|
|
||||||
@get:JsonProperty("type") val type: kotlin.String? = null,
|
|
||||||
|
|
||||||
@Schema(example = "null", description = "")
|
|
||||||
@get:JsonProperty("message") val message: kotlin.String? = null
|
|
||||||
) {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
@ -1,68 +0,0 @@
|
|||||||
package org.openapitools.model
|
|
||||||
|
|
||||||
import java.util.Objects
|
|
||||||
import com.fasterxml.jackson.annotation.JsonCreator
|
|
||||||
import com.fasterxml.jackson.annotation.JsonProperty
|
|
||||||
import com.fasterxml.jackson.annotation.JsonValue
|
|
||||||
import javax.validation.constraints.DecimalMax
|
|
||||||
import javax.validation.constraints.DecimalMin
|
|
||||||
import javax.validation.constraints.Email
|
|
||||||
import javax.validation.constraints.Max
|
|
||||||
import javax.validation.constraints.Min
|
|
||||||
import javax.validation.constraints.NotNull
|
|
||||||
import javax.validation.constraints.Pattern
|
|
||||||
import javax.validation.constraints.Size
|
|
||||||
import javax.validation.Valid
|
|
||||||
import io.swagger.v3.oas.annotations.media.Schema
|
|
||||||
|
|
||||||
/**
|
|
||||||
* An order for a pets from the pet store
|
|
||||||
* @param id
|
|
||||||
* @param petId
|
|
||||||
* @param quantity
|
|
||||||
* @param shipDate
|
|
||||||
* @param status Order Status
|
|
||||||
* @param complete
|
|
||||||
*/
|
|
||||||
data class Order(
|
|
||||||
|
|
||||||
@Schema(example = "null", description = "")
|
|
||||||
@get:JsonProperty("id") val id: kotlin.Long? = null,
|
|
||||||
|
|
||||||
@Schema(example = "null", description = "")
|
|
||||||
@get:JsonProperty("petId") val petId: kotlin.Long? = null,
|
|
||||||
|
|
||||||
@Schema(example = "null", description = "")
|
|
||||||
@get:JsonProperty("quantity") val quantity: kotlin.Int? = null,
|
|
||||||
|
|
||||||
@Schema(example = "null", description = "")
|
|
||||||
@get:JsonProperty("shipDate") val shipDate: java.time.OffsetDateTime? = null,
|
|
||||||
|
|
||||||
@Schema(example = "null", description = "Order Status")
|
|
||||||
@get:JsonProperty("status") val status: Order.Status? = null,
|
|
||||||
|
|
||||||
@Schema(example = "null", description = "")
|
|
||||||
@get:JsonProperty("complete") val complete: kotlin.Boolean? = false
|
|
||||||
) {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Order Status
|
|
||||||
* Values: placed,approved,delivered
|
|
||||||
*/
|
|
||||||
enum class Status(@get:JsonValue val value: kotlin.String) {
|
|
||||||
|
|
||||||
placed("placed"),
|
|
||||||
approved("approved"),
|
|
||||||
delivered("delivered");
|
|
||||||
|
|
||||||
companion object {
|
|
||||||
@JvmStatic
|
|
||||||
@JsonCreator
|
|
||||||
fun forValue(value: kotlin.String): Status {
|
|
||||||
return values().first{it -> it.value == value}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
@ -1,73 +0,0 @@
|
|||||||
package org.openapitools.model
|
|
||||||
|
|
||||||
import java.util.Objects
|
|
||||||
import com.fasterxml.jackson.annotation.JsonCreator
|
|
||||||
import com.fasterxml.jackson.annotation.JsonProperty
|
|
||||||
import com.fasterxml.jackson.annotation.JsonValue
|
|
||||||
import org.openapitools.model.Category
|
|
||||||
import org.openapitools.model.Tag
|
|
||||||
import javax.validation.constraints.DecimalMax
|
|
||||||
import javax.validation.constraints.DecimalMin
|
|
||||||
import javax.validation.constraints.Email
|
|
||||||
import javax.validation.constraints.Max
|
|
||||||
import javax.validation.constraints.Min
|
|
||||||
import javax.validation.constraints.NotNull
|
|
||||||
import javax.validation.constraints.Pattern
|
|
||||||
import javax.validation.constraints.Size
|
|
||||||
import javax.validation.Valid
|
|
||||||
import io.swagger.v3.oas.annotations.media.Schema
|
|
||||||
|
|
||||||
/**
|
|
||||||
* A pet for sale in the pet store
|
|
||||||
* @param name
|
|
||||||
* @param photoUrls
|
|
||||||
* @param id
|
|
||||||
* @param category
|
|
||||||
* @param tags
|
|
||||||
* @param status pet status in the store
|
|
||||||
*/
|
|
||||||
data class Pet(
|
|
||||||
|
|
||||||
@Schema(example = "doggie", required = true, description = "")
|
|
||||||
@get:JsonProperty("name", required = true) val name: kotlin.String,
|
|
||||||
|
|
||||||
@Schema(example = "null", required = true, description = "")
|
|
||||||
@get:JsonProperty("photoUrls", required = true) val photoUrls: kotlin.collections.List<kotlin.String>,
|
|
||||||
|
|
||||||
@Schema(example = "null", description = "")
|
|
||||||
@get:JsonProperty("id") val id: kotlin.Long? = null,
|
|
||||||
|
|
||||||
@field:Valid
|
|
||||||
@Schema(example = "null", description = "")
|
|
||||||
@get:JsonProperty("category") val category: Category? = null,
|
|
||||||
|
|
||||||
@field:Valid
|
|
||||||
@Schema(example = "null", description = "")
|
|
||||||
@get:JsonProperty("tags") val tags: kotlin.collections.List<Tag>? = null,
|
|
||||||
|
|
||||||
@Schema(example = "null", description = "pet status in the store")
|
|
||||||
@Deprecated(message = "")
|
|
||||||
@get:JsonProperty("status") val status: Pet.Status? = null
|
|
||||||
) {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* pet status in the store
|
|
||||||
* Values: available,pending,sold
|
|
||||||
*/
|
|
||||||
enum class Status(@get:JsonValue val value: kotlin.String) {
|
|
||||||
|
|
||||||
available("available"),
|
|
||||||
pending("pending"),
|
|
||||||
sold("sold");
|
|
||||||
|
|
||||||
companion object {
|
|
||||||
@JvmStatic
|
|
||||||
@JsonCreator
|
|
||||||
fun forValue(value: kotlin.String): Status {
|
|
||||||
return values().first{it -> it.value == value}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
@ -1,31 +0,0 @@
|
|||||||
package org.openapitools.model
|
|
||||||
|
|
||||||
import java.util.Objects
|
|
||||||
import com.fasterxml.jackson.annotation.JsonProperty
|
|
||||||
import javax.validation.constraints.DecimalMax
|
|
||||||
import javax.validation.constraints.DecimalMin
|
|
||||||
import javax.validation.constraints.Email
|
|
||||||
import javax.validation.constraints.Max
|
|
||||||
import javax.validation.constraints.Min
|
|
||||||
import javax.validation.constraints.NotNull
|
|
||||||
import javax.validation.constraints.Pattern
|
|
||||||
import javax.validation.constraints.Size
|
|
||||||
import javax.validation.Valid
|
|
||||||
import io.swagger.v3.oas.annotations.media.Schema
|
|
||||||
|
|
||||||
/**
|
|
||||||
* A tag for a pet
|
|
||||||
* @param id
|
|
||||||
* @param name
|
|
||||||
*/
|
|
||||||
data class Tag(
|
|
||||||
|
|
||||||
@Schema(example = "null", description = "")
|
|
||||||
@get:JsonProperty("id") val id: kotlin.Long? = null,
|
|
||||||
|
|
||||||
@Schema(example = "null", description = "")
|
|
||||||
@get:JsonProperty("name") val name: kotlin.String? = null
|
|
||||||
) {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
@ -1,55 +0,0 @@
|
|||||||
package org.openapitools.model
|
|
||||||
|
|
||||||
import java.util.Objects
|
|
||||||
import com.fasterxml.jackson.annotation.JsonProperty
|
|
||||||
import javax.validation.constraints.DecimalMax
|
|
||||||
import javax.validation.constraints.DecimalMin
|
|
||||||
import javax.validation.constraints.Email
|
|
||||||
import javax.validation.constraints.Max
|
|
||||||
import javax.validation.constraints.Min
|
|
||||||
import javax.validation.constraints.NotNull
|
|
||||||
import javax.validation.constraints.Pattern
|
|
||||||
import javax.validation.constraints.Size
|
|
||||||
import javax.validation.Valid
|
|
||||||
import io.swagger.v3.oas.annotations.media.Schema
|
|
||||||
|
|
||||||
/**
|
|
||||||
* A User who is purchasing from the pet store
|
|
||||||
* @param id
|
|
||||||
* @param username
|
|
||||||
* @param firstName
|
|
||||||
* @param lastName
|
|
||||||
* @param email
|
|
||||||
* @param password
|
|
||||||
* @param phone
|
|
||||||
* @param userStatus User Status
|
|
||||||
*/
|
|
||||||
data class User(
|
|
||||||
|
|
||||||
@Schema(example = "null", description = "")
|
|
||||||
@get:JsonProperty("id") val id: kotlin.Long? = null,
|
|
||||||
|
|
||||||
@Schema(example = "null", description = "")
|
|
||||||
@get:JsonProperty("username") val username: kotlin.String? = null,
|
|
||||||
|
|
||||||
@Schema(example = "null", description = "")
|
|
||||||
@get:JsonProperty("firstName") val firstName: kotlin.String? = null,
|
|
||||||
|
|
||||||
@Schema(example = "null", description = "")
|
|
||||||
@get:JsonProperty("lastName") val lastName: kotlin.String? = null,
|
|
||||||
|
|
||||||
@Schema(example = "null", description = "")
|
|
||||||
@get:JsonProperty("email") val email: kotlin.String? = null,
|
|
||||||
|
|
||||||
@Schema(example = "null", description = "")
|
|
||||||
@get:JsonProperty("password") val password: kotlin.String? = null,
|
|
||||||
|
|
||||||
@Schema(example = "null", description = "")
|
|
||||||
@get:JsonProperty("phone") val phone: kotlin.String? = null,
|
|
||||||
|
|
||||||
@Schema(example = "null", description = "User Status")
|
|
||||||
@get:JsonProperty("userStatus") val userStatus: kotlin.Int? = null
|
|
||||||
) {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
@ -1,10 +0,0 @@
|
|||||||
spring:
|
|
||||||
application:
|
|
||||||
name: openAPIPetstore
|
|
||||||
|
|
||||||
jackson:
|
|
||||||
serialization:
|
|
||||||
WRITE_DATES_AS_TIMESTAMPS: false
|
|
||||||
|
|
||||||
server:
|
|
||||||
port: 8080
|
|
@ -1,811 +0,0 @@
|
|||||||
openapi: 3.0.0
|
|
||||||
info:
|
|
||||||
description: "This is a sample server Petstore server. For this sample, you can\
|
|
||||||
\ use the api key `special-key` to test the authorization filters."
|
|
||||||
license:
|
|
||||||
name: Apache-2.0
|
|
||||||
url: https://www.apache.org/licenses/LICENSE-2.0.html
|
|
||||||
title: OpenAPI Petstore
|
|
||||||
version: 1.0.0
|
|
||||||
externalDocs:
|
|
||||||
description: Find out more about Swagger
|
|
||||||
url: http://swagger.io
|
|
||||||
servers:
|
|
||||||
- url: http://petstore.swagger.io/v2
|
|
||||||
tags:
|
|
||||||
- description: Everything about your Pets
|
|
||||||
name: pet
|
|
||||||
- description: Access to Petstore orders
|
|
||||||
name: store
|
|
||||||
- description: Operations about user
|
|
||||||
name: user
|
|
||||||
paths:
|
|
||||||
/pet:
|
|
||||||
post:
|
|
||||||
description: ""
|
|
||||||
operationId: addPet
|
|
||||||
requestBody:
|
|
||||||
$ref: '#/components/requestBodies/Pet'
|
|
||||||
responses:
|
|
||||||
"200":
|
|
||||||
content:
|
|
||||||
application/xml:
|
|
||||||
schema:
|
|
||||||
$ref: '#/components/schemas/Pet'
|
|
||||||
application/json:
|
|
||||||
schema:
|
|
||||||
$ref: '#/components/schemas/Pet'
|
|
||||||
description: successful operation
|
|
||||||
"405":
|
|
||||||
description: Invalid input
|
|
||||||
security:
|
|
||||||
- petstore_auth:
|
|
||||||
- write:pets
|
|
||||||
- read:pets
|
|
||||||
summary: Add a new pet to the store
|
|
||||||
tags:
|
|
||||||
- pet
|
|
||||||
put:
|
|
||||||
description: ""
|
|
||||||
externalDocs:
|
|
||||||
description: API documentation for the updatePet operation
|
|
||||||
url: http://petstore.swagger.io/v2/doc/updatePet
|
|
||||||
operationId: updatePet
|
|
||||||
requestBody:
|
|
||||||
$ref: '#/components/requestBodies/Pet'
|
|
||||||
responses:
|
|
||||||
"200":
|
|
||||||
content:
|
|
||||||
application/xml:
|
|
||||||
schema:
|
|
||||||
$ref: '#/components/schemas/Pet'
|
|
||||||
application/json:
|
|
||||||
schema:
|
|
||||||
$ref: '#/components/schemas/Pet'
|
|
||||||
description: successful operation
|
|
||||||
"400":
|
|
||||||
description: Invalid ID supplied
|
|
||||||
"404":
|
|
||||||
description: Pet not found
|
|
||||||
"405":
|
|
||||||
description: Validation exception
|
|
||||||
security:
|
|
||||||
- petstore_auth:
|
|
||||||
- write:pets
|
|
||||||
- read:pets
|
|
||||||
summary: Update an existing pet
|
|
||||||
tags:
|
|
||||||
- pet
|
|
||||||
/pet/findByStatus:
|
|
||||||
get:
|
|
||||||
description: Multiple status values can be provided with comma separated strings
|
|
||||||
operationId: findPetsByStatus
|
|
||||||
parameters:
|
|
||||||
- deprecated: true
|
|
||||||
description: Status values that need to be considered for filter
|
|
||||||
explode: false
|
|
||||||
in: query
|
|
||||||
name: status
|
|
||||||
required: true
|
|
||||||
schema:
|
|
||||||
items:
|
|
||||||
default: available
|
|
||||||
enum:
|
|
||||||
- available
|
|
||||||
- pending
|
|
||||||
- sold
|
|
||||||
type: string
|
|
||||||
type: array
|
|
||||||
style: form
|
|
||||||
responses:
|
|
||||||
"200":
|
|
||||||
content:
|
|
||||||
application/xml:
|
|
||||||
schema:
|
|
||||||
items:
|
|
||||||
$ref: '#/components/schemas/Pet'
|
|
||||||
type: array
|
|
||||||
application/json:
|
|
||||||
schema:
|
|
||||||
items:
|
|
||||||
$ref: '#/components/schemas/Pet'
|
|
||||||
type: array
|
|
||||||
description: successful operation
|
|
||||||
"400":
|
|
||||||
description: Invalid status value
|
|
||||||
security:
|
|
||||||
- petstore_auth:
|
|
||||||
- read:pets
|
|
||||||
summary: Finds Pets by status
|
|
||||||
tags:
|
|
||||||
- pet
|
|
||||||
/pet/findByTags:
|
|
||||||
get:
|
|
||||||
deprecated: true
|
|
||||||
description: "Multiple tags can be provided with comma separated strings. Use\
|
|
||||||
\ tag1, tag2, tag3 for testing."
|
|
||||||
operationId: findPetsByTags
|
|
||||||
parameters:
|
|
||||||
- description: Tags to filter by
|
|
||||||
explode: false
|
|
||||||
in: query
|
|
||||||
name: tags
|
|
||||||
required: true
|
|
||||||
schema:
|
|
||||||
items:
|
|
||||||
type: string
|
|
||||||
type: array
|
|
||||||
style: form
|
|
||||||
responses:
|
|
||||||
"200":
|
|
||||||
content:
|
|
||||||
application/xml:
|
|
||||||
schema:
|
|
||||||
items:
|
|
||||||
$ref: '#/components/schemas/Pet'
|
|
||||||
type: array
|
|
||||||
application/json:
|
|
||||||
schema:
|
|
||||||
items:
|
|
||||||
$ref: '#/components/schemas/Pet'
|
|
||||||
type: array
|
|
||||||
description: successful operation
|
|
||||||
"400":
|
|
||||||
description: Invalid tag value
|
|
||||||
security:
|
|
||||||
- petstore_auth:
|
|
||||||
- read:pets
|
|
||||||
summary: Finds Pets by tags
|
|
||||||
tags:
|
|
||||||
- pet
|
|
||||||
/pet/{petId}:
|
|
||||||
delete:
|
|
||||||
description: ""
|
|
||||||
operationId: deletePet
|
|
||||||
parameters:
|
|
||||||
- explode: false
|
|
||||||
in: header
|
|
||||||
name: api_key
|
|
||||||
required: false
|
|
||||||
schema:
|
|
||||||
type: string
|
|
||||||
style: simple
|
|
||||||
- description: Pet id to delete
|
|
||||||
explode: false
|
|
||||||
in: path
|
|
||||||
name: petId
|
|
||||||
required: true
|
|
||||||
schema:
|
|
||||||
format: int64
|
|
||||||
type: integer
|
|
||||||
style: simple
|
|
||||||
responses:
|
|
||||||
"400":
|
|
||||||
description: Invalid pet value
|
|
||||||
security:
|
|
||||||
- petstore_auth:
|
|
||||||
- write:pets
|
|
||||||
- read:pets
|
|
||||||
summary: Deletes a pet
|
|
||||||
tags:
|
|
||||||
- pet
|
|
||||||
get:
|
|
||||||
description: Returns a single pet
|
|
||||||
operationId: getPetById
|
|
||||||
parameters:
|
|
||||||
- description: ID of pet to return
|
|
||||||
explode: false
|
|
||||||
in: path
|
|
||||||
name: petId
|
|
||||||
required: true
|
|
||||||
schema:
|
|
||||||
format: int64
|
|
||||||
type: integer
|
|
||||||
style: simple
|
|
||||||
responses:
|
|
||||||
"200":
|
|
||||||
content:
|
|
||||||
application/xml:
|
|
||||||
schema:
|
|
||||||
$ref: '#/components/schemas/Pet'
|
|
||||||
application/json:
|
|
||||||
schema:
|
|
||||||
$ref: '#/components/schemas/Pet'
|
|
||||||
description: successful operation
|
|
||||||
"400":
|
|
||||||
description: Invalid ID supplied
|
|
||||||
"404":
|
|
||||||
description: Pet not found
|
|
||||||
security:
|
|
||||||
- api_key: []
|
|
||||||
summary: Find pet by ID
|
|
||||||
tags:
|
|
||||||
- pet
|
|
||||||
post:
|
|
||||||
description: ""
|
|
||||||
operationId: updatePetWithForm
|
|
||||||
parameters:
|
|
||||||
- description: ID of pet that needs to be updated
|
|
||||||
explode: false
|
|
||||||
in: path
|
|
||||||
name: petId
|
|
||||||
required: true
|
|
||||||
schema:
|
|
||||||
format: int64
|
|
||||||
type: integer
|
|
||||||
style: simple
|
|
||||||
requestBody:
|
|
||||||
content:
|
|
||||||
application/x-www-form-urlencoded:
|
|
||||||
schema:
|
|
||||||
$ref: '#/components/schemas/updatePetWithForm_request'
|
|
||||||
responses:
|
|
||||||
"405":
|
|
||||||
description: Invalid input
|
|
||||||
security:
|
|
||||||
- petstore_auth:
|
|
||||||
- write:pets
|
|
||||||
- read:pets
|
|
||||||
summary: Updates a pet in the store with form data
|
|
||||||
tags:
|
|
||||||
- pet
|
|
||||||
/pet/{petId}/uploadImage:
|
|
||||||
post:
|
|
||||||
description: ""
|
|
||||||
operationId: uploadFile
|
|
||||||
parameters:
|
|
||||||
- description: ID of pet to update
|
|
||||||
explode: false
|
|
||||||
in: path
|
|
||||||
name: petId
|
|
||||||
required: true
|
|
||||||
schema:
|
|
||||||
format: int64
|
|
||||||
type: integer
|
|
||||||
style: simple
|
|
||||||
requestBody:
|
|
||||||
content:
|
|
||||||
multipart/form-data:
|
|
||||||
schema:
|
|
||||||
$ref: '#/components/schemas/uploadFile_request'
|
|
||||||
responses:
|
|
||||||
"200":
|
|
||||||
content:
|
|
||||||
application/json:
|
|
||||||
schema:
|
|
||||||
$ref: '#/components/schemas/ApiResponse'
|
|
||||||
description: successful operation
|
|
||||||
security:
|
|
||||||
- petstore_auth:
|
|
||||||
- write:pets
|
|
||||||
- read:pets
|
|
||||||
summary: uploads an image
|
|
||||||
tags:
|
|
||||||
- pet
|
|
||||||
/store/inventory:
|
|
||||||
get:
|
|
||||||
description: Returns a map of status codes to quantities
|
|
||||||
operationId: getInventory
|
|
||||||
responses:
|
|
||||||
"200":
|
|
||||||
content:
|
|
||||||
application/json:
|
|
||||||
schema:
|
|
||||||
additionalProperties:
|
|
||||||
format: int32
|
|
||||||
type: integer
|
|
||||||
type: object
|
|
||||||
description: successful operation
|
|
||||||
security:
|
|
||||||
- api_key: []
|
|
||||||
summary: Returns pet inventories by status
|
|
||||||
tags:
|
|
||||||
- store
|
|
||||||
/store/order:
|
|
||||||
post:
|
|
||||||
description: ""
|
|
||||||
operationId: placeOrder
|
|
||||||
requestBody:
|
|
||||||
content:
|
|
||||||
application/json:
|
|
||||||
schema:
|
|
||||||
$ref: '#/components/schemas/Order'
|
|
||||||
description: order placed for purchasing the pet
|
|
||||||
required: true
|
|
||||||
responses:
|
|
||||||
"200":
|
|
||||||
content:
|
|
||||||
application/xml:
|
|
||||||
schema:
|
|
||||||
$ref: '#/components/schemas/Order'
|
|
||||||
application/json:
|
|
||||||
schema:
|
|
||||||
$ref: '#/components/schemas/Order'
|
|
||||||
description: successful operation
|
|
||||||
"400":
|
|
||||||
description: Invalid Order
|
|
||||||
summary: Place an order for a pet
|
|
||||||
tags:
|
|
||||||
- store
|
|
||||||
/store/order/{orderId}:
|
|
||||||
delete:
|
|
||||||
description: For valid response try integer IDs with value < 1000. Anything
|
|
||||||
above 1000 or nonintegers will generate API errors
|
|
||||||
operationId: deleteOrder
|
|
||||||
parameters:
|
|
||||||
- description: ID of the order that needs to be deleted
|
|
||||||
explode: false
|
|
||||||
in: path
|
|
||||||
name: orderId
|
|
||||||
required: true
|
|
||||||
schema:
|
|
||||||
type: string
|
|
||||||
style: simple
|
|
||||||
responses:
|
|
||||||
"400":
|
|
||||||
description: Invalid ID supplied
|
|
||||||
"404":
|
|
||||||
description: Order not found
|
|
||||||
summary: Delete purchase order by ID
|
|
||||||
tags:
|
|
||||||
- store
|
|
||||||
get:
|
|
||||||
description: For valid response try integer IDs with value <= 5 or > 10. Other
|
|
||||||
values will generate exceptions
|
|
||||||
operationId: getOrderById
|
|
||||||
parameters:
|
|
||||||
- description: ID of pet that needs to be fetched
|
|
||||||
explode: false
|
|
||||||
in: path
|
|
||||||
name: orderId
|
|
||||||
required: true
|
|
||||||
schema:
|
|
||||||
format: int64
|
|
||||||
maximum: 5
|
|
||||||
minimum: 1
|
|
||||||
type: integer
|
|
||||||
style: simple
|
|
||||||
responses:
|
|
||||||
"200":
|
|
||||||
content:
|
|
||||||
application/xml:
|
|
||||||
schema:
|
|
||||||
$ref: '#/components/schemas/Order'
|
|
||||||
application/json:
|
|
||||||
schema:
|
|
||||||
$ref: '#/components/schemas/Order'
|
|
||||||
description: successful operation
|
|
||||||
"400":
|
|
||||||
description: Invalid ID supplied
|
|
||||||
"404":
|
|
||||||
description: Order not found
|
|
||||||
summary: Find purchase order by ID
|
|
||||||
tags:
|
|
||||||
- store
|
|
||||||
/user:
|
|
||||||
post:
|
|
||||||
description: This can only be done by the logged in user.
|
|
||||||
operationId: createUser
|
|
||||||
requestBody:
|
|
||||||
content:
|
|
||||||
application/json:
|
|
||||||
schema:
|
|
||||||
$ref: '#/components/schemas/User'
|
|
||||||
description: Created user object
|
|
||||||
required: true
|
|
||||||
responses:
|
|
||||||
default:
|
|
||||||
description: successful operation
|
|
||||||
security:
|
|
||||||
- api_key: []
|
|
||||||
summary: Create user
|
|
||||||
tags:
|
|
||||||
- user
|
|
||||||
/user/createWithArray:
|
|
||||||
post:
|
|
||||||
description: ""
|
|
||||||
operationId: createUsersWithArrayInput
|
|
||||||
requestBody:
|
|
||||||
$ref: '#/components/requestBodies/UserArray'
|
|
||||||
responses:
|
|
||||||
default:
|
|
||||||
description: successful operation
|
|
||||||
security:
|
|
||||||
- api_key: []
|
|
||||||
summary: Creates list of users with given input array
|
|
||||||
tags:
|
|
||||||
- user
|
|
||||||
/user/createWithList:
|
|
||||||
post:
|
|
||||||
description: ""
|
|
||||||
operationId: createUsersWithListInput
|
|
||||||
requestBody:
|
|
||||||
$ref: '#/components/requestBodies/UserArray'
|
|
||||||
responses:
|
|
||||||
default:
|
|
||||||
description: successful operation
|
|
||||||
security:
|
|
||||||
- api_key: []
|
|
||||||
summary: Creates list of users with given input array
|
|
||||||
tags:
|
|
||||||
- user
|
|
||||||
/user/login:
|
|
||||||
get:
|
|
||||||
description: ""
|
|
||||||
operationId: loginUser
|
|
||||||
parameters:
|
|
||||||
- description: The user name for login
|
|
||||||
explode: true
|
|
||||||
in: query
|
|
||||||
name: username
|
|
||||||
required: true
|
|
||||||
schema:
|
|
||||||
pattern: "^[a-zA-Z0-9]+[a-zA-Z0-9\\.\\-_]*[a-zA-Z0-9]+$"
|
|
||||||
type: string
|
|
||||||
style: form
|
|
||||||
- description: The password for login in clear text
|
|
||||||
explode: true
|
|
||||||
in: query
|
|
||||||
name: password
|
|
||||||
required: true
|
|
||||||
schema:
|
|
||||||
type: string
|
|
||||||
style: form
|
|
||||||
responses:
|
|
||||||
"200":
|
|
||||||
content:
|
|
||||||
application/xml:
|
|
||||||
schema:
|
|
||||||
type: string
|
|
||||||
application/json:
|
|
||||||
schema:
|
|
||||||
type: string
|
|
||||||
description: successful operation
|
|
||||||
headers:
|
|
||||||
Set-Cookie:
|
|
||||||
description: Cookie authentication key for use with the `api_key` apiKey
|
|
||||||
authentication.
|
|
||||||
explode: false
|
|
||||||
schema:
|
|
||||||
example: AUTH_KEY=abcde12345; Path=/; HttpOnly
|
|
||||||
type: string
|
|
||||||
style: simple
|
|
||||||
X-Rate-Limit:
|
|
||||||
description: calls per hour allowed by the user
|
|
||||||
explode: false
|
|
||||||
schema:
|
|
||||||
format: int32
|
|
||||||
type: integer
|
|
||||||
style: simple
|
|
||||||
X-Expires-After:
|
|
||||||
description: date in UTC when token expires
|
|
||||||
explode: false
|
|
||||||
schema:
|
|
||||||
format: date-time
|
|
||||||
type: string
|
|
||||||
style: simple
|
|
||||||
"400":
|
|
||||||
description: Invalid username/password supplied
|
|
||||||
summary: Logs user into the system
|
|
||||||
tags:
|
|
||||||
- user
|
|
||||||
/user/logout:
|
|
||||||
get:
|
|
||||||
description: ""
|
|
||||||
operationId: logoutUser
|
|
||||||
responses:
|
|
||||||
default:
|
|
||||||
description: successful operation
|
|
||||||
security:
|
|
||||||
- api_key: []
|
|
||||||
summary: Logs out current logged in user session
|
|
||||||
tags:
|
|
||||||
- user
|
|
||||||
/user/{username}:
|
|
||||||
delete:
|
|
||||||
description: This can only be done by the logged in user.
|
|
||||||
operationId: deleteUser
|
|
||||||
parameters:
|
|
||||||
- description: The name that needs to be deleted
|
|
||||||
explode: false
|
|
||||||
in: path
|
|
||||||
name: username
|
|
||||||
required: true
|
|
||||||
schema:
|
|
||||||
type: string
|
|
||||||
style: simple
|
|
||||||
responses:
|
|
||||||
"400":
|
|
||||||
description: Invalid username supplied
|
|
||||||
"404":
|
|
||||||
description: User not found
|
|
||||||
security:
|
|
||||||
- api_key: []
|
|
||||||
summary: Delete user
|
|
||||||
tags:
|
|
||||||
- user
|
|
||||||
get:
|
|
||||||
description: ""
|
|
||||||
operationId: getUserByName
|
|
||||||
parameters:
|
|
||||||
- description: The name that needs to be fetched. Use user1 for testing.
|
|
||||||
explode: false
|
|
||||||
in: path
|
|
||||||
name: username
|
|
||||||
required: true
|
|
||||||
schema:
|
|
||||||
type: string
|
|
||||||
style: simple
|
|
||||||
responses:
|
|
||||||
"200":
|
|
||||||
content:
|
|
||||||
application/xml:
|
|
||||||
schema:
|
|
||||||
$ref: '#/components/schemas/User'
|
|
||||||
application/json:
|
|
||||||
schema:
|
|
||||||
$ref: '#/components/schemas/User'
|
|
||||||
description: successful operation
|
|
||||||
"400":
|
|
||||||
description: Invalid username supplied
|
|
||||||
"404":
|
|
||||||
description: User not found
|
|
||||||
summary: Get user by user name
|
|
||||||
tags:
|
|
||||||
- user
|
|
||||||
put:
|
|
||||||
description: This can only be done by the logged in user.
|
|
||||||
operationId: updateUser
|
|
||||||
parameters:
|
|
||||||
- description: name that need to be deleted
|
|
||||||
explode: false
|
|
||||||
in: path
|
|
||||||
name: username
|
|
||||||
required: true
|
|
||||||
schema:
|
|
||||||
type: string
|
|
||||||
style: simple
|
|
||||||
requestBody:
|
|
||||||
content:
|
|
||||||
application/json:
|
|
||||||
schema:
|
|
||||||
$ref: '#/components/schemas/User'
|
|
||||||
description: Updated user object
|
|
||||||
required: true
|
|
||||||
responses:
|
|
||||||
"400":
|
|
||||||
description: Invalid user supplied
|
|
||||||
"404":
|
|
||||||
description: User not found
|
|
||||||
security:
|
|
||||||
- api_key: []
|
|
||||||
summary: Updated user
|
|
||||||
tags:
|
|
||||||
- user
|
|
||||||
components:
|
|
||||||
requestBodies:
|
|
||||||
UserArray:
|
|
||||||
content:
|
|
||||||
application/json:
|
|
||||||
schema:
|
|
||||||
items:
|
|
||||||
$ref: '#/components/schemas/User'
|
|
||||||
type: array
|
|
||||||
description: List of user object
|
|
||||||
required: true
|
|
||||||
Pet:
|
|
||||||
content:
|
|
||||||
application/json:
|
|
||||||
schema:
|
|
||||||
$ref: '#/components/schemas/Pet'
|
|
||||||
application/xml:
|
|
||||||
schema:
|
|
||||||
$ref: '#/components/schemas/Pet'
|
|
||||||
description: Pet object that needs to be added to the store
|
|
||||||
required: true
|
|
||||||
schemas:
|
|
||||||
Order:
|
|
||||||
description: An order for a pets from the pet store
|
|
||||||
example:
|
|
||||||
petId: 6
|
|
||||||
quantity: 1
|
|
||||||
id: 0
|
|
||||||
shipDate: 2000-01-23T04:56:07.000+00:00
|
|
||||||
complete: false
|
|
||||||
status: placed
|
|
||||||
properties:
|
|
||||||
id:
|
|
||||||
format: int64
|
|
||||||
type: integer
|
|
||||||
petId:
|
|
||||||
format: int64
|
|
||||||
type: integer
|
|
||||||
quantity:
|
|
||||||
format: int32
|
|
||||||
type: integer
|
|
||||||
shipDate:
|
|
||||||
format: date-time
|
|
||||||
type: string
|
|
||||||
status:
|
|
||||||
description: Order Status
|
|
||||||
enum:
|
|
||||||
- placed
|
|
||||||
- approved
|
|
||||||
- delivered
|
|
||||||
type: string
|
|
||||||
complete:
|
|
||||||
default: false
|
|
||||||
type: boolean
|
|
||||||
title: Pet Order
|
|
||||||
type: object
|
|
||||||
xml:
|
|
||||||
name: Order
|
|
||||||
Category:
|
|
||||||
description: A category for a pet
|
|
||||||
example:
|
|
||||||
name: name
|
|
||||||
id: 6
|
|
||||||
properties:
|
|
||||||
id:
|
|
||||||
format: int64
|
|
||||||
type: integer
|
|
||||||
name:
|
|
||||||
pattern: "^[a-zA-Z0-9]+[a-zA-Z0-9\\.\\-_]*[a-zA-Z0-9]+$"
|
|
||||||
type: string
|
|
||||||
title: Pet category
|
|
||||||
type: object
|
|
||||||
xml:
|
|
||||||
name: Category
|
|
||||||
User:
|
|
||||||
description: A User who is purchasing from the pet store
|
|
||||||
example:
|
|
||||||
firstName: firstName
|
|
||||||
lastName: lastName
|
|
||||||
password: password
|
|
||||||
userStatus: 6
|
|
||||||
phone: phone
|
|
||||||
id: 0
|
|
||||||
email: email
|
|
||||||
username: username
|
|
||||||
properties:
|
|
||||||
id:
|
|
||||||
format: int64
|
|
||||||
type: integer
|
|
||||||
username:
|
|
||||||
type: string
|
|
||||||
firstName:
|
|
||||||
type: string
|
|
||||||
lastName:
|
|
||||||
type: string
|
|
||||||
email:
|
|
||||||
type: string
|
|
||||||
password:
|
|
||||||
type: string
|
|
||||||
phone:
|
|
||||||
type: string
|
|
||||||
userStatus:
|
|
||||||
description: User Status
|
|
||||||
format: int32
|
|
||||||
type: integer
|
|
||||||
title: a User
|
|
||||||
type: object
|
|
||||||
xml:
|
|
||||||
name: User
|
|
||||||
Tag:
|
|
||||||
description: A tag for a pet
|
|
||||||
example:
|
|
||||||
name: name
|
|
||||||
id: 1
|
|
||||||
properties:
|
|
||||||
id:
|
|
||||||
format: int64
|
|
||||||
type: integer
|
|
||||||
name:
|
|
||||||
type: string
|
|
||||||
title: Pet Tag
|
|
||||||
type: object
|
|
||||||
xml:
|
|
||||||
name: Tag
|
|
||||||
Pet:
|
|
||||||
description: A pet for sale in the pet store
|
|
||||||
example:
|
|
||||||
photoUrls:
|
|
||||||
- photoUrls
|
|
||||||
- photoUrls
|
|
||||||
name: doggie
|
|
||||||
id: 0
|
|
||||||
category:
|
|
||||||
name: name
|
|
||||||
id: 6
|
|
||||||
tags:
|
|
||||||
- name: name
|
|
||||||
id: 1
|
|
||||||
- name: name
|
|
||||||
id: 1
|
|
||||||
status: available
|
|
||||||
properties:
|
|
||||||
id:
|
|
||||||
format: int64
|
|
||||||
type: integer
|
|
||||||
category:
|
|
||||||
$ref: '#/components/schemas/Category'
|
|
||||||
name:
|
|
||||||
example: doggie
|
|
||||||
type: string
|
|
||||||
photoUrls:
|
|
||||||
items:
|
|
||||||
type: string
|
|
||||||
type: array
|
|
||||||
xml:
|
|
||||||
name: photoUrl
|
|
||||||
wrapped: true
|
|
||||||
tags:
|
|
||||||
items:
|
|
||||||
$ref: '#/components/schemas/Tag'
|
|
||||||
type: array
|
|
||||||
xml:
|
|
||||||
name: tag
|
|
||||||
wrapped: true
|
|
||||||
status:
|
|
||||||
deprecated: true
|
|
||||||
description: pet status in the store
|
|
||||||
enum:
|
|
||||||
- available
|
|
||||||
- pending
|
|
||||||
- sold
|
|
||||||
type: string
|
|
||||||
required:
|
|
||||||
- name
|
|
||||||
- photoUrls
|
|
||||||
title: a Pet
|
|
||||||
type: object
|
|
||||||
xml:
|
|
||||||
name: Pet
|
|
||||||
ApiResponse:
|
|
||||||
description: Describes the result of uploading an image resource
|
|
||||||
example:
|
|
||||||
code: 0
|
|
||||||
type: type
|
|
||||||
message: message
|
|
||||||
properties:
|
|
||||||
code:
|
|
||||||
format: int32
|
|
||||||
type: integer
|
|
||||||
type:
|
|
||||||
type: string
|
|
||||||
message:
|
|
||||||
type: string
|
|
||||||
title: An uploaded response
|
|
||||||
type: object
|
|
||||||
updatePetWithForm_request:
|
|
||||||
properties:
|
|
||||||
name:
|
|
||||||
description: Updated name of the pet
|
|
||||||
type: string
|
|
||||||
status:
|
|
||||||
description: Updated status of the pet
|
|
||||||
type: string
|
|
||||||
type: object
|
|
||||||
uploadFile_request:
|
|
||||||
properties:
|
|
||||||
additionalMetadata:
|
|
||||||
description: Additional data to pass to server
|
|
||||||
type: string
|
|
||||||
file:
|
|
||||||
description: file to upload
|
|
||||||
format: binary
|
|
||||||
type: string
|
|
||||||
type: object
|
|
||||||
securitySchemes:
|
|
||||||
petstore_auth:
|
|
||||||
flows:
|
|
||||||
implicit:
|
|
||||||
authorizationUrl: http://petstore.swagger.io/api/oauth/dialog
|
|
||||||
scopes:
|
|
||||||
write:pets: modify pets in your account
|
|
||||||
read:pets: read your pets
|
|
||||||
type: oauth2
|
|
||||||
api_key:
|
|
||||||
in: header
|
|
||||||
name: api_key
|
|
||||||
type: apiKey
|
|
@ -1,131 +0,0 @@
|
|||||||
package org.openapitools.api
|
|
||||||
|
|
||||||
import org.openapitools.model.ModelApiResponse
|
|
||||||
import org.openapitools.model.Pet
|
|
||||||
import org.junit.jupiter.api.Test
|
|
||||||
import kotlinx.coroutines.flow.Flow
|
|
||||||
import kotlinx.coroutines.test.runBlockingTest
|
|
||||||
import org.springframework.http.ResponseEntity
|
|
||||||
|
|
||||||
class PetApiTest {
|
|
||||||
|
|
||||||
private val service: PetApiService = PetApiServiceImpl()
|
|
||||||
private val api: PetApiController = PetApiController(service)
|
|
||||||
|
|
||||||
/**
|
|
||||||
* To test PetApiController.addPet
|
|
||||||
*
|
|
||||||
* @throws ApiException
|
|
||||||
* if the Api call fails
|
|
||||||
*/
|
|
||||||
@Test
|
|
||||||
fun addPetTest() = runBlockingTest {
|
|
||||||
val pet: Pet = TODO()
|
|
||||||
val response: ResponseEntity<Pet> = api.addPet(pet)
|
|
||||||
|
|
||||||
// TODO: test validations
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* To test PetApiController.deletePet
|
|
||||||
*
|
|
||||||
* @throws ApiException
|
|
||||||
* if the Api call fails
|
|
||||||
*/
|
|
||||||
@Test
|
|
||||||
fun deletePetTest() = runBlockingTest {
|
|
||||||
val petId: kotlin.Long = TODO()
|
|
||||||
val apiKey: kotlin.String? = TODO()
|
|
||||||
val response: ResponseEntity<Unit> = api.deletePet(petId, apiKey)
|
|
||||||
|
|
||||||
// TODO: test validations
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* To test PetApiController.findPetsByStatus
|
|
||||||
*
|
|
||||||
* @throws ApiException
|
|
||||||
* if the Api call fails
|
|
||||||
*/
|
|
||||||
@Test
|
|
||||||
fun findPetsByStatusTest() = runBlockingTest {
|
|
||||||
val status: kotlin.collections.List<kotlin.String> = TODO()
|
|
||||||
val response: ResponseEntity<Flow<Pet>> = api.findPetsByStatus(status)
|
|
||||||
|
|
||||||
// TODO: test validations
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* To test PetApiController.findPetsByTags
|
|
||||||
*
|
|
||||||
* @throws ApiException
|
|
||||||
* if the Api call fails
|
|
||||||
*/
|
|
||||||
@Test
|
|
||||||
fun findPetsByTagsTest() = runBlockingTest {
|
|
||||||
val tags: kotlin.collections.List<kotlin.String> = TODO()
|
|
||||||
val response: ResponseEntity<Flow<Pet>> = api.findPetsByTags(tags)
|
|
||||||
|
|
||||||
// TODO: test validations
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* To test PetApiController.getPetById
|
|
||||||
*
|
|
||||||
* @throws ApiException
|
|
||||||
* if the Api call fails
|
|
||||||
*/
|
|
||||||
@Test
|
|
||||||
fun getPetByIdTest() = runBlockingTest {
|
|
||||||
val petId: kotlin.Long = TODO()
|
|
||||||
val response: ResponseEntity<Pet> = api.getPetById(petId)
|
|
||||||
|
|
||||||
// TODO: test validations
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* To test PetApiController.updatePet
|
|
||||||
*
|
|
||||||
* @throws ApiException
|
|
||||||
* if the Api call fails
|
|
||||||
*/
|
|
||||||
@Test
|
|
||||||
fun updatePetTest() = runBlockingTest {
|
|
||||||
val pet: Pet = TODO()
|
|
||||||
val response: ResponseEntity<Pet> = api.updatePet(pet)
|
|
||||||
|
|
||||||
// TODO: test validations
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* To test PetApiController.updatePetWithForm
|
|
||||||
*
|
|
||||||
* @throws ApiException
|
|
||||||
* if the Api call fails
|
|
||||||
*/
|
|
||||||
@Test
|
|
||||||
fun updatePetWithFormTest() = runBlockingTest {
|
|
||||||
val petId: kotlin.Long = TODO()
|
|
||||||
val name: kotlin.String? = TODO()
|
|
||||||
val status: kotlin.String? = TODO()
|
|
||||||
val response: ResponseEntity<Unit> = api.updatePetWithForm(petId, name, status)
|
|
||||||
|
|
||||||
// TODO: test validations
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* To test PetApiController.uploadFile
|
|
||||||
*
|
|
||||||
* @throws ApiException
|
|
||||||
* if the Api call fails
|
|
||||||
*/
|
|
||||||
@Test
|
|
||||||
fun uploadFileTest() = runBlockingTest {
|
|
||||||
val petId: kotlin.Long = TODO()
|
|
||||||
val additionalMetadata: kotlin.String? = TODO()
|
|
||||||
val file: org.springframework.web.multipart.MultipartFile? = TODO()
|
|
||||||
val response: ResponseEntity<ModelApiResponse> = api.uploadFile(petId, additionalMetadata, file)
|
|
||||||
|
|
||||||
// TODO: test validations
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,68 +0,0 @@
|
|||||||
package org.openapitools.api
|
|
||||||
|
|
||||||
import org.openapitools.model.Order
|
|
||||||
import org.junit.jupiter.api.Test
|
|
||||||
import kotlinx.coroutines.flow.Flow
|
|
||||||
import kotlinx.coroutines.test.runBlockingTest
|
|
||||||
import org.springframework.http.ResponseEntity
|
|
||||||
|
|
||||||
class StoreApiTest {
|
|
||||||
|
|
||||||
private val service: StoreApiService = StoreApiServiceImpl()
|
|
||||||
private val api: StoreApiController = StoreApiController(service)
|
|
||||||
|
|
||||||
/**
|
|
||||||
* To test StoreApiController.deleteOrder
|
|
||||||
*
|
|
||||||
* @throws ApiException
|
|
||||||
* if the Api call fails
|
|
||||||
*/
|
|
||||||
@Test
|
|
||||||
fun deleteOrderTest() = runBlockingTest {
|
|
||||||
val orderId: kotlin.String = TODO()
|
|
||||||
val response: ResponseEntity<Unit> = api.deleteOrder(orderId)
|
|
||||||
|
|
||||||
// TODO: test validations
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* To test StoreApiController.getInventory
|
|
||||||
*
|
|
||||||
* @throws ApiException
|
|
||||||
* if the Api call fails
|
|
||||||
*/
|
|
||||||
@Test
|
|
||||||
fun getInventoryTest() = runBlockingTest {
|
|
||||||
val response: ResponseEntity<Map<String, kotlin.Int>> = api.getInventory()
|
|
||||||
|
|
||||||
// TODO: test validations
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* To test StoreApiController.getOrderById
|
|
||||||
*
|
|
||||||
* @throws ApiException
|
|
||||||
* if the Api call fails
|
|
||||||
*/
|
|
||||||
@Test
|
|
||||||
fun getOrderByIdTest() = runBlockingTest {
|
|
||||||
val orderId: kotlin.Long = TODO()
|
|
||||||
val response: ResponseEntity<Order> = api.getOrderById(orderId)
|
|
||||||
|
|
||||||
// TODO: test validations
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* To test StoreApiController.placeOrder
|
|
||||||
*
|
|
||||||
* @throws ApiException
|
|
||||||
* if the Api call fails
|
|
||||||
*/
|
|
||||||
@Test
|
|
||||||
fun placeOrderTest() = runBlockingTest {
|
|
||||||
val order: Order = TODO()
|
|
||||||
val response: ResponseEntity<Order> = api.placeOrder(order)
|
|
||||||
|
|
||||||
// TODO: test validations
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,126 +0,0 @@
|
|||||||
package org.openapitools.api
|
|
||||||
|
|
||||||
import org.openapitools.model.User
|
|
||||||
import org.junit.jupiter.api.Test
|
|
||||||
import kotlinx.coroutines.flow.Flow
|
|
||||||
import kotlinx.coroutines.test.runBlockingTest
|
|
||||||
import org.springframework.http.ResponseEntity
|
|
||||||
|
|
||||||
class UserApiTest {
|
|
||||||
|
|
||||||
private val service: UserApiService = UserApiServiceImpl()
|
|
||||||
private val api: UserApiController = UserApiController(service)
|
|
||||||
|
|
||||||
/**
|
|
||||||
* To test UserApiController.createUser
|
|
||||||
*
|
|
||||||
* @throws ApiException
|
|
||||||
* if the Api call fails
|
|
||||||
*/
|
|
||||||
@Test
|
|
||||||
fun createUserTest() = runBlockingTest {
|
|
||||||
val user: User = TODO()
|
|
||||||
val response: ResponseEntity<Unit> = api.createUser(user)
|
|
||||||
|
|
||||||
// TODO: test validations
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* To test UserApiController.createUsersWithArrayInput
|
|
||||||
*
|
|
||||||
* @throws ApiException
|
|
||||||
* if the Api call fails
|
|
||||||
*/
|
|
||||||
@Test
|
|
||||||
fun createUsersWithArrayInputTest() = runBlockingTest {
|
|
||||||
val user: kotlin.collections.List<User> = TODO()
|
|
||||||
val response: ResponseEntity<Unit> = api.createUsersWithArrayInput(user)
|
|
||||||
|
|
||||||
// TODO: test validations
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* To test UserApiController.createUsersWithListInput
|
|
||||||
*
|
|
||||||
* @throws ApiException
|
|
||||||
* if the Api call fails
|
|
||||||
*/
|
|
||||||
@Test
|
|
||||||
fun createUsersWithListInputTest() = runBlockingTest {
|
|
||||||
val user: kotlin.collections.List<User> = TODO()
|
|
||||||
val response: ResponseEntity<Unit> = api.createUsersWithListInput(user)
|
|
||||||
|
|
||||||
// TODO: test validations
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* To test UserApiController.deleteUser
|
|
||||||
*
|
|
||||||
* @throws ApiException
|
|
||||||
* if the Api call fails
|
|
||||||
*/
|
|
||||||
@Test
|
|
||||||
fun deleteUserTest() = runBlockingTest {
|
|
||||||
val username: kotlin.String = TODO()
|
|
||||||
val response: ResponseEntity<Unit> = api.deleteUser(username)
|
|
||||||
|
|
||||||
// TODO: test validations
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* To test UserApiController.getUserByName
|
|
||||||
*
|
|
||||||
* @throws ApiException
|
|
||||||
* if the Api call fails
|
|
||||||
*/
|
|
||||||
@Test
|
|
||||||
fun getUserByNameTest() = runBlockingTest {
|
|
||||||
val username: kotlin.String = TODO()
|
|
||||||
val response: ResponseEntity<User> = api.getUserByName(username)
|
|
||||||
|
|
||||||
// TODO: test validations
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* To test UserApiController.loginUser
|
|
||||||
*
|
|
||||||
* @throws ApiException
|
|
||||||
* if the Api call fails
|
|
||||||
*/
|
|
||||||
@Test
|
|
||||||
fun loginUserTest() = runBlockingTest {
|
|
||||||
val username: kotlin.String = TODO()
|
|
||||||
val password: kotlin.String = TODO()
|
|
||||||
val response: ResponseEntity<kotlin.String> = api.loginUser(username, password)
|
|
||||||
|
|
||||||
// TODO: test validations
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* To test UserApiController.logoutUser
|
|
||||||
*
|
|
||||||
* @throws ApiException
|
|
||||||
* if the Api call fails
|
|
||||||
*/
|
|
||||||
@Test
|
|
||||||
fun logoutUserTest() = runBlockingTest {
|
|
||||||
val response: ResponseEntity<Unit> = api.logoutUser()
|
|
||||||
|
|
||||||
// TODO: test validations
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* To test UserApiController.updateUser
|
|
||||||
*
|
|
||||||
* @throws ApiException
|
|
||||||
* if the Api call fails
|
|
||||||
*/
|
|
||||||
@Test
|
|
||||||
fun updateUserTest() = runBlockingTest {
|
|
||||||
val username: kotlin.String = TODO()
|
|
||||||
val user: User = TODO()
|
|
||||||
val response: ResponseEntity<Unit> = api.updateUser(username, user)
|
|
||||||
|
|
||||||
// TODO: test validations
|
|
||||||
}
|
|
||||||
}
|
|
@ -40,16 +40,18 @@ class PetApiController(@Autowired(required = true) val service: PetApiService) {
|
|||||||
operationId = "addPet",
|
operationId = "addPet",
|
||||||
description = """""",
|
description = """""",
|
||||||
responses = [
|
responses = [
|
||||||
|
ApiResponse(responseCode = "200", description = "successful operation", content = [Content(schema = Schema(implementation = Pet::class))]),
|
||||||
ApiResponse(responseCode = "405", description = "Invalid input") ],
|
ApiResponse(responseCode = "405", description = "Invalid input") ],
|
||||||
security = [ SecurityRequirement(name = "petstore_auth", scopes = [ "write:pets", "read:pets" ]) ]
|
security = [ SecurityRequirement(name = "petstore_auth", scopes = [ "write:pets", "read:pets" ]) ]
|
||||||
)
|
)
|
||||||
@RequestMapping(
|
@RequestMapping(
|
||||||
method = [RequestMethod.POST],
|
method = [RequestMethod.POST],
|
||||||
value = ["/pet"],
|
value = ["/pet"],
|
||||||
|
produces = ["application/xml", "application/json"],
|
||||||
consumes = ["application/json", "application/xml"]
|
consumes = ["application/json", "application/xml"]
|
||||||
)
|
)
|
||||||
suspend fun addPet(@Parameter(description = "Pet object that needs to be added to the store", required = true) @Valid @RequestBody body: Pet): ResponseEntity<Unit> {
|
suspend fun addPet(@Parameter(description = "Pet object that needs to be added to the store", required = true) @Valid @RequestBody pet: Pet): ResponseEntity<Pet> {
|
||||||
return ResponseEntity(service.addPet(body), HttpStatus.valueOf(405))
|
return ResponseEntity(service.addPet(pet), HttpStatus.valueOf(200))
|
||||||
}
|
}
|
||||||
|
|
||||||
@Operation(
|
@Operation(
|
||||||
@ -75,7 +77,7 @@ class PetApiController(@Autowired(required = true) val service: PetApiService) {
|
|||||||
responses = [
|
responses = [
|
||||||
ApiResponse(responseCode = "200", description = "successful operation", content = [Content(array = ArraySchema(schema = Schema(implementation = Pet::class)))]),
|
ApiResponse(responseCode = "200", description = "successful operation", content = [Content(array = ArraySchema(schema = Schema(implementation = Pet::class)))]),
|
||||||
ApiResponse(responseCode = "400", description = "Invalid status value") ],
|
ApiResponse(responseCode = "400", description = "Invalid status value") ],
|
||||||
security = [ SecurityRequirement(name = "petstore_auth", scopes = [ "write:pets", "read:pets" ]) ]
|
security = [ SecurityRequirement(name = "petstore_auth", scopes = [ "read:pets" ]) ]
|
||||||
)
|
)
|
||||||
@RequestMapping(
|
@RequestMapping(
|
||||||
method = [RequestMethod.GET],
|
method = [RequestMethod.GET],
|
||||||
@ -93,7 +95,7 @@ class PetApiController(@Autowired(required = true) val service: PetApiService) {
|
|||||||
responses = [
|
responses = [
|
||||||
ApiResponse(responseCode = "200", description = "successful operation", content = [Content(array = ArraySchema(schema = Schema(implementation = Pet::class)))]),
|
ApiResponse(responseCode = "200", description = "successful operation", content = [Content(array = ArraySchema(schema = Schema(implementation = Pet::class)))]),
|
||||||
ApiResponse(responseCode = "400", description = "Invalid tag value") ],
|
ApiResponse(responseCode = "400", description = "Invalid tag value") ],
|
||||||
security = [ SecurityRequirement(name = "petstore_auth", scopes = [ "write:pets", "read:pets" ]) ]
|
security = [ SecurityRequirement(name = "petstore_auth", scopes = [ "read:pets" ]) ]
|
||||||
)
|
)
|
||||||
@RequestMapping(
|
@RequestMapping(
|
||||||
method = [RequestMethod.GET],
|
method = [RequestMethod.GET],
|
||||||
@ -128,6 +130,7 @@ class PetApiController(@Autowired(required = true) val service: PetApiService) {
|
|||||||
operationId = "updatePet",
|
operationId = "updatePet",
|
||||||
description = """""",
|
description = """""",
|
||||||
responses = [
|
responses = [
|
||||||
|
ApiResponse(responseCode = "200", description = "successful operation", content = [Content(schema = Schema(implementation = Pet::class))]),
|
||||||
ApiResponse(responseCode = "400", description = "Invalid ID supplied"),
|
ApiResponse(responseCode = "400", description = "Invalid ID supplied"),
|
||||||
ApiResponse(responseCode = "404", description = "Pet not found"),
|
ApiResponse(responseCode = "404", description = "Pet not found"),
|
||||||
ApiResponse(responseCode = "405", description = "Validation exception") ],
|
ApiResponse(responseCode = "405", description = "Validation exception") ],
|
||||||
@ -136,10 +139,11 @@ class PetApiController(@Autowired(required = true) val service: PetApiService) {
|
|||||||
@RequestMapping(
|
@RequestMapping(
|
||||||
method = [RequestMethod.PUT],
|
method = [RequestMethod.PUT],
|
||||||
value = ["/pet"],
|
value = ["/pet"],
|
||||||
|
produces = ["application/xml", "application/json"],
|
||||||
consumes = ["application/json", "application/xml"]
|
consumes = ["application/json", "application/xml"]
|
||||||
)
|
)
|
||||||
suspend fun updatePet(@Parameter(description = "Pet object that needs to be added to the store", required = true) @Valid @RequestBody body: Pet): ResponseEntity<Unit> {
|
suspend fun updatePet(@Parameter(description = "Pet object that needs to be added to the store", required = true) @Valid @RequestBody pet: Pet): ResponseEntity<Pet> {
|
||||||
return ResponseEntity(service.updatePet(body), HttpStatus.valueOf(400))
|
return ResponseEntity(service.updatePet(pet), HttpStatus.valueOf(200))
|
||||||
}
|
}
|
||||||
|
|
||||||
@Operation(
|
@Operation(
|
||||||
|
@ -8,15 +8,18 @@ interface PetApiService {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* POST /pet : Add a new pet to the store
|
* POST /pet : Add a new pet to the store
|
||||||
|
*
|
||||||
*
|
*
|
||||||
* @param body Pet object that needs to be added to the store (required)
|
* @param pet Pet object that needs to be added to the store (required)
|
||||||
* @return Invalid input (status code 405)
|
* @return successful operation (status code 200)
|
||||||
|
* or Invalid input (status code 405)
|
||||||
* @see PetApi#addPet
|
* @see PetApi#addPet
|
||||||
*/
|
*/
|
||||||
suspend fun addPet(body: Pet): Unit
|
suspend fun addPet(pet: Pet): Pet
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* DELETE /pet/{petId} : Deletes a pet
|
* DELETE /pet/{petId} : Deletes a pet
|
||||||
|
*
|
||||||
*
|
*
|
||||||
* @param petId Pet id to delete (required)
|
* @param petId Pet id to delete (required)
|
||||||
* @param apiKey (optional)
|
* @param apiKey (optional)
|
||||||
@ -62,17 +65,22 @@ interface PetApiService {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* PUT /pet : Update an existing pet
|
* PUT /pet : Update an existing pet
|
||||||
|
*
|
||||||
*
|
*
|
||||||
* @param body Pet object that needs to be added to the store (required)
|
* @param pet Pet object that needs to be added to the store (required)
|
||||||
* @return Invalid ID supplied (status code 400)
|
* @return successful operation (status code 200)
|
||||||
|
* or Invalid ID supplied (status code 400)
|
||||||
* or Pet not found (status code 404)
|
* or Pet not found (status code 404)
|
||||||
* or Validation exception (status code 405)
|
* or Validation exception (status code 405)
|
||||||
|
* API documentation for the updatePet operation
|
||||||
|
* @see <a href="http://petstore.swagger.io/v2/doc/updatePet">Update an existing pet Documentation</a>
|
||||||
* @see PetApi#updatePet
|
* @see PetApi#updatePet
|
||||||
*/
|
*/
|
||||||
suspend fun updatePet(body: Pet): Unit
|
suspend fun updatePet(pet: Pet): Pet
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* POST /pet/{petId} : Updates a pet in the store with form data
|
* POST /pet/{petId} : Updates a pet in the store with form data
|
||||||
|
*
|
||||||
*
|
*
|
||||||
* @param petId ID of pet that needs to be updated (required)
|
* @param petId ID of pet that needs to be updated (required)
|
||||||
* @param name Updated name of the pet (optional)
|
* @param name Updated name of the pet (optional)
|
||||||
@ -84,6 +92,7 @@ interface PetApiService {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* POST /pet/{petId}/uploadImage : uploads an image
|
* POST /pet/{petId}/uploadImage : uploads an image
|
||||||
|
*
|
||||||
*
|
*
|
||||||
* @param petId ID of pet to update (required)
|
* @param petId ID of pet to update (required)
|
||||||
* @param additionalMetadata Additional data to pass to server (optional)
|
* @param additionalMetadata Additional data to pass to server (optional)
|
||||||
|
@ -7,7 +7,7 @@ import org.springframework.stereotype.Service
|
|||||||
@Service
|
@Service
|
||||||
class PetApiServiceImpl : PetApiService {
|
class PetApiServiceImpl : PetApiService {
|
||||||
|
|
||||||
override suspend fun addPet(body: Pet): Unit {
|
override suspend fun addPet(pet: Pet): Pet {
|
||||||
TODO("Implement me")
|
TODO("Implement me")
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -27,7 +27,7 @@ class PetApiServiceImpl : PetApiService {
|
|||||||
TODO("Implement me")
|
TODO("Implement me")
|
||||||
}
|
}
|
||||||
|
|
||||||
override suspend fun updatePet(body: Pet): Unit {
|
override suspend fun updatePet(pet: Pet): Pet {
|
||||||
TODO("Implement me")
|
TODO("Implement me")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -96,9 +96,10 @@ class StoreApiController(@Autowired(required = true) val service: StoreApiServic
|
|||||||
@RequestMapping(
|
@RequestMapping(
|
||||||
method = [RequestMethod.POST],
|
method = [RequestMethod.POST],
|
||||||
value = ["/store/order"],
|
value = ["/store/order"],
|
||||||
produces = ["application/xml", "application/json"]
|
produces = ["application/xml", "application/json"],
|
||||||
|
consumes = ["application/json"]
|
||||||
)
|
)
|
||||||
suspend fun placeOrder(@Parameter(description = "order placed for purchasing the pet", required = true) @Valid @RequestBody body: Order): ResponseEntity<Order> {
|
suspend fun placeOrder(@Parameter(description = "order placed for purchasing the pet", required = true) @Valid @RequestBody order: Order): ResponseEntity<Order> {
|
||||||
return ResponseEntity(service.placeOrder(body), HttpStatus.valueOf(200))
|
return ResponseEntity(service.placeOrder(order), HttpStatus.valueOf(200))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -39,11 +39,12 @@ interface StoreApiService {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* POST /store/order : Place an order for a pet
|
* POST /store/order : Place an order for a pet
|
||||||
|
*
|
||||||
*
|
*
|
||||||
* @param body order placed for purchasing the pet (required)
|
* @param order order placed for purchasing the pet (required)
|
||||||
* @return successful operation (status code 200)
|
* @return successful operation (status code 200)
|
||||||
* or Invalid Order (status code 400)
|
* or Invalid Order (status code 400)
|
||||||
* @see StoreApi#placeOrder
|
* @see StoreApi#placeOrder
|
||||||
*/
|
*/
|
||||||
suspend fun placeOrder(body: Order): Order
|
suspend fun placeOrder(order: Order): Order
|
||||||
}
|
}
|
||||||
|
@ -18,7 +18,7 @@ class StoreApiServiceImpl : StoreApiService {
|
|||||||
TODO("Implement me")
|
TODO("Implement me")
|
||||||
}
|
}
|
||||||
|
|
||||||
override suspend fun placeOrder(body: Order): Order {
|
override suspend fun placeOrder(order: Order): Order {
|
||||||
TODO("Implement me")
|
TODO("Implement me")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -39,14 +39,16 @@ class UserApiController(@Autowired(required = true) val service: UserApiService)
|
|||||||
operationId = "createUser",
|
operationId = "createUser",
|
||||||
description = """This can only be done by the logged in user.""",
|
description = """This can only be done by the logged in user.""",
|
||||||
responses = [
|
responses = [
|
||||||
ApiResponse(responseCode = "200", description = "successful operation") ]
|
ApiResponse(responseCode = "200", description = "successful operation") ],
|
||||||
|
security = [ SecurityRequirement(name = "api_key") ]
|
||||||
)
|
)
|
||||||
@RequestMapping(
|
@RequestMapping(
|
||||||
method = [RequestMethod.POST],
|
method = [RequestMethod.POST],
|
||||||
value = ["/user"]
|
value = ["/user"],
|
||||||
|
consumes = ["application/json"]
|
||||||
)
|
)
|
||||||
suspend fun createUser(@Parameter(description = "Created user object", required = true) @Valid @RequestBody body: User): ResponseEntity<Unit> {
|
suspend fun createUser(@Parameter(description = "Created user object", required = true) @Valid @RequestBody user: User): ResponseEntity<Unit> {
|
||||||
return ResponseEntity(service.createUser(body), HttpStatus.valueOf(200))
|
return ResponseEntity(service.createUser(user), HttpStatus.valueOf(200))
|
||||||
}
|
}
|
||||||
|
|
||||||
@Operation(
|
@Operation(
|
||||||
@ -54,14 +56,16 @@ class UserApiController(@Autowired(required = true) val service: UserApiService)
|
|||||||
operationId = "createUsersWithArrayInput",
|
operationId = "createUsersWithArrayInput",
|
||||||
description = """""",
|
description = """""",
|
||||||
responses = [
|
responses = [
|
||||||
ApiResponse(responseCode = "200", description = "successful operation") ]
|
ApiResponse(responseCode = "200", description = "successful operation") ],
|
||||||
|
security = [ SecurityRequirement(name = "api_key") ]
|
||||||
)
|
)
|
||||||
@RequestMapping(
|
@RequestMapping(
|
||||||
method = [RequestMethod.POST],
|
method = [RequestMethod.POST],
|
||||||
value = ["/user/createWithArray"]
|
value = ["/user/createWithArray"],
|
||||||
|
consumes = ["application/json"]
|
||||||
)
|
)
|
||||||
suspend fun createUsersWithArrayInput(@Parameter(description = "List of user object", required = true) @Valid @RequestBody body: Flow<User>): ResponseEntity<Unit> {
|
suspend fun createUsersWithArrayInput(@Parameter(description = "List of user object", required = true) @Valid @RequestBody user: Flow<User>): ResponseEntity<Unit> {
|
||||||
return ResponseEntity(service.createUsersWithArrayInput(body), HttpStatus.valueOf(200))
|
return ResponseEntity(service.createUsersWithArrayInput(user), HttpStatus.valueOf(200))
|
||||||
}
|
}
|
||||||
|
|
||||||
@Operation(
|
@Operation(
|
||||||
@ -69,14 +73,16 @@ class UserApiController(@Autowired(required = true) val service: UserApiService)
|
|||||||
operationId = "createUsersWithListInput",
|
operationId = "createUsersWithListInput",
|
||||||
description = """""",
|
description = """""",
|
||||||
responses = [
|
responses = [
|
||||||
ApiResponse(responseCode = "200", description = "successful operation") ]
|
ApiResponse(responseCode = "200", description = "successful operation") ],
|
||||||
|
security = [ SecurityRequirement(name = "api_key") ]
|
||||||
)
|
)
|
||||||
@RequestMapping(
|
@RequestMapping(
|
||||||
method = [RequestMethod.POST],
|
method = [RequestMethod.POST],
|
||||||
value = ["/user/createWithList"]
|
value = ["/user/createWithList"],
|
||||||
|
consumes = ["application/json"]
|
||||||
)
|
)
|
||||||
suspend fun createUsersWithListInput(@Parameter(description = "List of user object", required = true) @Valid @RequestBody body: Flow<User>): ResponseEntity<Unit> {
|
suspend fun createUsersWithListInput(@Parameter(description = "List of user object", required = true) @Valid @RequestBody user: Flow<User>): ResponseEntity<Unit> {
|
||||||
return ResponseEntity(service.createUsersWithListInput(body), HttpStatus.valueOf(200))
|
return ResponseEntity(service.createUsersWithListInput(user), HttpStatus.valueOf(200))
|
||||||
}
|
}
|
||||||
|
|
||||||
@Operation(
|
@Operation(
|
||||||
@ -85,7 +91,8 @@ class UserApiController(@Autowired(required = true) val service: UserApiService)
|
|||||||
description = """This can only be done by the logged in user.""",
|
description = """This can only be done by the logged in user.""",
|
||||||
responses = [
|
responses = [
|
||||||
ApiResponse(responseCode = "400", description = "Invalid username supplied"),
|
ApiResponse(responseCode = "400", description = "Invalid username supplied"),
|
||||||
ApiResponse(responseCode = "404", description = "User not found") ]
|
ApiResponse(responseCode = "404", description = "User not found") ],
|
||||||
|
security = [ SecurityRequirement(name = "api_key") ]
|
||||||
)
|
)
|
||||||
@RequestMapping(
|
@RequestMapping(
|
||||||
method = [RequestMethod.DELETE],
|
method = [RequestMethod.DELETE],
|
||||||
@ -126,7 +133,7 @@ class UserApiController(@Autowired(required = true) val service: UserApiService)
|
|||||||
value = ["/user/login"],
|
value = ["/user/login"],
|
||||||
produces = ["application/xml", "application/json"]
|
produces = ["application/xml", "application/json"]
|
||||||
)
|
)
|
||||||
suspend fun loginUser(@NotNull @Parameter(description = "The user name for login", required = true) @Valid @RequestParam(value = "username", required = true) username: kotlin.String,@NotNull @Parameter(description = "The password for login in clear text", required = true) @Valid @RequestParam(value = "password", required = true) password: kotlin.String): ResponseEntity<kotlin.String> {
|
suspend fun loginUser(@NotNull @Pattern(regexp="^[a-zA-Z0-9]+[a-zA-Z0-9\\.\\-_]*[a-zA-Z0-9]+$") @Parameter(description = "The user name for login", required = true) @Valid @RequestParam(value = "username", required = true) username: kotlin.String,@NotNull @Parameter(description = "The password for login in clear text", required = true) @Valid @RequestParam(value = "password", required = true) password: kotlin.String): ResponseEntity<kotlin.String> {
|
||||||
return ResponseEntity(service.loginUser(username, password), HttpStatus.valueOf(200))
|
return ResponseEntity(service.loginUser(username, password), HttpStatus.valueOf(200))
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -135,7 +142,8 @@ class UserApiController(@Autowired(required = true) val service: UserApiService)
|
|||||||
operationId = "logoutUser",
|
operationId = "logoutUser",
|
||||||
description = """""",
|
description = """""",
|
||||||
responses = [
|
responses = [
|
||||||
ApiResponse(responseCode = "200", description = "successful operation") ]
|
ApiResponse(responseCode = "200", description = "successful operation") ],
|
||||||
|
security = [ SecurityRequirement(name = "api_key") ]
|
||||||
)
|
)
|
||||||
@RequestMapping(
|
@RequestMapping(
|
||||||
method = [RequestMethod.GET],
|
method = [RequestMethod.GET],
|
||||||
@ -151,13 +159,15 @@ class UserApiController(@Autowired(required = true) val service: UserApiService)
|
|||||||
description = """This can only be done by the logged in user.""",
|
description = """This can only be done by the logged in user.""",
|
||||||
responses = [
|
responses = [
|
||||||
ApiResponse(responseCode = "400", description = "Invalid user supplied"),
|
ApiResponse(responseCode = "400", description = "Invalid user supplied"),
|
||||||
ApiResponse(responseCode = "404", description = "User not found") ]
|
ApiResponse(responseCode = "404", description = "User not found") ],
|
||||||
|
security = [ SecurityRequirement(name = "api_key") ]
|
||||||
)
|
)
|
||||||
@RequestMapping(
|
@RequestMapping(
|
||||||
method = [RequestMethod.PUT],
|
method = [RequestMethod.PUT],
|
||||||
value = ["/user/{username}"]
|
value = ["/user/{username}"],
|
||||||
|
consumes = ["application/json"]
|
||||||
)
|
)
|
||||||
suspend fun updateUser(@Parameter(description = "name that need to be deleted", required = true) @PathVariable("username") username: kotlin.String,@Parameter(description = "Updated user object", required = true) @Valid @RequestBody body: User): ResponseEntity<Unit> {
|
suspend fun updateUser(@Parameter(description = "name that need to be deleted", required = true) @PathVariable("username") username: kotlin.String,@Parameter(description = "Updated user object", required = true) @Valid @RequestBody user: User): ResponseEntity<Unit> {
|
||||||
return ResponseEntity(service.updateUser(username, body), HttpStatus.valueOf(400))
|
return ResponseEntity(service.updateUser(username, user), HttpStatus.valueOf(400))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -9,29 +9,31 @@ interface UserApiService {
|
|||||||
* POST /user : Create user
|
* POST /user : Create user
|
||||||
* This can only be done by the logged in user.
|
* This can only be done by the logged in user.
|
||||||
*
|
*
|
||||||
* @param body Created user object (required)
|
* @param user Created user object (required)
|
||||||
* @return successful operation (status code 200)
|
* @return successful operation (status code 200)
|
||||||
* @see UserApi#createUser
|
* @see UserApi#createUser
|
||||||
*/
|
*/
|
||||||
suspend fun createUser(body: User): Unit
|
suspend fun createUser(user: User): Unit
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* POST /user/createWithArray : Creates list of users with given input array
|
* POST /user/createWithArray : Creates list of users with given input array
|
||||||
|
*
|
||||||
*
|
*
|
||||||
* @param body List of user object (required)
|
* @param user List of user object (required)
|
||||||
* @return successful operation (status code 200)
|
* @return successful operation (status code 200)
|
||||||
* @see UserApi#createUsersWithArrayInput
|
* @see UserApi#createUsersWithArrayInput
|
||||||
*/
|
*/
|
||||||
suspend fun createUsersWithArrayInput(body: Flow<User>): Unit
|
suspend fun createUsersWithArrayInput(user: Flow<User>): Unit
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* POST /user/createWithList : Creates list of users with given input array
|
* POST /user/createWithList : Creates list of users with given input array
|
||||||
|
*
|
||||||
*
|
*
|
||||||
* @param body List of user object (required)
|
* @param user List of user object (required)
|
||||||
* @return successful operation (status code 200)
|
* @return successful operation (status code 200)
|
||||||
* @see UserApi#createUsersWithListInput
|
* @see UserApi#createUsersWithListInput
|
||||||
*/
|
*/
|
||||||
suspend fun createUsersWithListInput(body: Flow<User>): Unit
|
suspend fun createUsersWithListInput(user: Flow<User>): Unit
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* DELETE /user/{username} : Delete user
|
* DELETE /user/{username} : Delete user
|
||||||
@ -46,6 +48,7 @@ interface UserApiService {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* GET /user/{username} : Get user by user name
|
* GET /user/{username} : Get user by user name
|
||||||
|
*
|
||||||
*
|
*
|
||||||
* @param username The name that needs to be fetched. Use user1 for testing. (required)
|
* @param username The name that needs to be fetched. Use user1 for testing. (required)
|
||||||
* @return successful operation (status code 200)
|
* @return successful operation (status code 200)
|
||||||
@ -57,6 +60,7 @@ interface UserApiService {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* GET /user/login : Logs user into the system
|
* GET /user/login : Logs user into the system
|
||||||
|
*
|
||||||
*
|
*
|
||||||
* @param username The user name for login (required)
|
* @param username The user name for login (required)
|
||||||
* @param password The password for login in clear text (required)
|
* @param password The password for login in clear text (required)
|
||||||
@ -68,6 +72,7 @@ interface UserApiService {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* GET /user/logout : Logs out current logged in user session
|
* GET /user/logout : Logs out current logged in user session
|
||||||
|
*
|
||||||
*
|
*
|
||||||
* @return successful operation (status code 200)
|
* @return successful operation (status code 200)
|
||||||
* @see UserApi#logoutUser
|
* @see UserApi#logoutUser
|
||||||
@ -79,10 +84,10 @@ interface UserApiService {
|
|||||||
* This can only be done by the logged in user.
|
* This can only be done by the logged in user.
|
||||||
*
|
*
|
||||||
* @param username name that need to be deleted (required)
|
* @param username name that need to be deleted (required)
|
||||||
* @param body Updated user object (required)
|
* @param user Updated user object (required)
|
||||||
* @return Invalid user supplied (status code 400)
|
* @return Invalid user supplied (status code 400)
|
||||||
* or User not found (status code 404)
|
* or User not found (status code 404)
|
||||||
* @see UserApi#updateUser
|
* @see UserApi#updateUser
|
||||||
*/
|
*/
|
||||||
suspend fun updateUser(username: kotlin.String, body: User): Unit
|
suspend fun updateUser(username: kotlin.String, user: User): Unit
|
||||||
}
|
}
|
||||||
|
@ -6,15 +6,15 @@ import org.springframework.stereotype.Service
|
|||||||
@Service
|
@Service
|
||||||
class UserApiServiceImpl : UserApiService {
|
class UserApiServiceImpl : UserApiService {
|
||||||
|
|
||||||
override suspend fun createUser(body: User): Unit {
|
override suspend fun createUser(user: User): Unit {
|
||||||
TODO("Implement me")
|
TODO("Implement me")
|
||||||
}
|
}
|
||||||
|
|
||||||
override suspend fun createUsersWithArrayInput(body: Flow<User>): Unit {
|
override suspend fun createUsersWithArrayInput(user: Flow<User>): Unit {
|
||||||
TODO("Implement me")
|
TODO("Implement me")
|
||||||
}
|
}
|
||||||
|
|
||||||
override suspend fun createUsersWithListInput(body: Flow<User>): Unit {
|
override suspend fun createUsersWithListInput(user: Flow<User>): Unit {
|
||||||
TODO("Implement me")
|
TODO("Implement me")
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -34,7 +34,7 @@ class UserApiServiceImpl : UserApiService {
|
|||||||
TODO("Implement me")
|
TODO("Implement me")
|
||||||
}
|
}
|
||||||
|
|
||||||
override suspend fun updateUser(username: kotlin.String, body: User): Unit {
|
override suspend fun updateUser(username: kotlin.String, user: User): Unit {
|
||||||
TODO("Implement me")
|
TODO("Implement me")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -23,6 +23,7 @@ data class Category(
|
|||||||
@Schema(example = "null", description = "")
|
@Schema(example = "null", description = "")
|
||||||
@get:JsonProperty("id") val id: kotlin.Long? = null,
|
@get:JsonProperty("id") val id: kotlin.Long? = null,
|
||||||
|
|
||||||
|
@get:Pattern(regexp="^[a-zA-Z0-9]+[a-zA-Z0-9\\.\\-_]*[a-zA-Z0-9]+$")
|
||||||
@Schema(example = "null", description = "")
|
@Schema(example = "null", description = "")
|
||||||
@get:JsonProperty("name") val name: kotlin.String? = null
|
@get:JsonProperty("name") val name: kotlin.String? = null
|
||||||
) {
|
) {
|
||||||
|
@ -46,6 +46,7 @@ data class Pet(
|
|||||||
@get:JsonProperty("tags") val tags: kotlin.collections.List<Tag>? = null,
|
@get:JsonProperty("tags") val tags: kotlin.collections.List<Tag>? = null,
|
||||||
|
|
||||||
@Schema(example = "null", description = "pet status in the store")
|
@Schema(example = "null", description = "pet status in the store")
|
||||||
|
@Deprecated(message = "")
|
||||||
@get:JsonProperty("status") val status: Pet.Status? = null
|
@get:JsonProperty("status") val status: Pet.Status? = null
|
||||||
) {
|
) {
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
openapi: 3.0.1
|
openapi: 3.0.0
|
||||||
info:
|
info:
|
||||||
description: "This is a sample server Petstore server. For this sample, you can\
|
description: "This is a sample server Petstore server. For this sample, you can\
|
||||||
\ use the api key `special-key` to test the authorization filters."
|
\ use the api key `special-key` to test the authorization filters."
|
||||||
@ -7,6 +7,9 @@ info:
|
|||||||
url: https://www.apache.org/licenses/LICENSE-2.0.html
|
url: https://www.apache.org/licenses/LICENSE-2.0.html
|
||||||
title: OpenAPI Petstore
|
title: OpenAPI Petstore
|
||||||
version: 1.0.0
|
version: 1.0.0
|
||||||
|
externalDocs:
|
||||||
|
description: Find out more about Swagger
|
||||||
|
url: http://swagger.io
|
||||||
servers:
|
servers:
|
||||||
- url: http://petstore.swagger.io/v2
|
- url: http://petstore.swagger.io/v2
|
||||||
tags:
|
tags:
|
||||||
@ -19,20 +22,21 @@ tags:
|
|||||||
paths:
|
paths:
|
||||||
/pet:
|
/pet:
|
||||||
post:
|
post:
|
||||||
|
description: ""
|
||||||
operationId: addPet
|
operationId: addPet
|
||||||
requestBody:
|
requestBody:
|
||||||
content:
|
$ref: '#/components/requestBodies/Pet'
|
||||||
application/json:
|
|
||||||
schema:
|
|
||||||
$ref: '#/components/schemas/Pet'
|
|
||||||
application/xml:
|
|
||||||
schema:
|
|
||||||
$ref: '#/components/schemas/Pet'
|
|
||||||
description: Pet object that needs to be added to the store
|
|
||||||
required: true
|
|
||||||
responses:
|
responses:
|
||||||
|
"200":
|
||||||
|
content:
|
||||||
|
application/xml:
|
||||||
|
schema:
|
||||||
|
$ref: '#/components/schemas/Pet'
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
$ref: '#/components/schemas/Pet'
|
||||||
|
description: successful operation
|
||||||
"405":
|
"405":
|
||||||
content: {}
|
|
||||||
description: Invalid input
|
description: Invalid input
|
||||||
security:
|
security:
|
||||||
- petstore_auth:
|
- petstore_auth:
|
||||||
@ -41,28 +45,29 @@ paths:
|
|||||||
summary: Add a new pet to the store
|
summary: Add a new pet to the store
|
||||||
tags:
|
tags:
|
||||||
- pet
|
- pet
|
||||||
x-codegen-request-body-name: body
|
|
||||||
put:
|
put:
|
||||||
|
description: ""
|
||||||
|
externalDocs:
|
||||||
|
description: API documentation for the updatePet operation
|
||||||
|
url: http://petstore.swagger.io/v2/doc/updatePet
|
||||||
operationId: updatePet
|
operationId: updatePet
|
||||||
requestBody:
|
requestBody:
|
||||||
content:
|
$ref: '#/components/requestBodies/Pet'
|
||||||
application/json:
|
|
||||||
schema:
|
|
||||||
$ref: '#/components/schemas/Pet'
|
|
||||||
application/xml:
|
|
||||||
schema:
|
|
||||||
$ref: '#/components/schemas/Pet'
|
|
||||||
description: Pet object that needs to be added to the store
|
|
||||||
required: true
|
|
||||||
responses:
|
responses:
|
||||||
|
"200":
|
||||||
|
content:
|
||||||
|
application/xml:
|
||||||
|
schema:
|
||||||
|
$ref: '#/components/schemas/Pet'
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
$ref: '#/components/schemas/Pet'
|
||||||
|
description: successful operation
|
||||||
"400":
|
"400":
|
||||||
content: {}
|
|
||||||
description: Invalid ID supplied
|
description: Invalid ID supplied
|
||||||
"404":
|
"404":
|
||||||
content: {}
|
|
||||||
description: Pet not found
|
description: Pet not found
|
||||||
"405":
|
"405":
|
||||||
content: {}
|
|
||||||
description: Validation exception
|
description: Validation exception
|
||||||
security:
|
security:
|
||||||
- petstore_auth:
|
- petstore_auth:
|
||||||
@ -71,13 +76,13 @@ paths:
|
|||||||
summary: Update an existing pet
|
summary: Update an existing pet
|
||||||
tags:
|
tags:
|
||||||
- pet
|
- pet
|
||||||
x-codegen-request-body-name: body
|
|
||||||
/pet/findByStatus:
|
/pet/findByStatus:
|
||||||
get:
|
get:
|
||||||
description: Multiple status values can be provided with comma separated strings
|
description: Multiple status values can be provided with comma separated strings
|
||||||
operationId: findPetsByStatus
|
operationId: findPetsByStatus
|
||||||
parameters:
|
parameters:
|
||||||
- description: Status values that need to be considered for filter
|
- deprecated: true
|
||||||
|
description: Status values that need to be considered for filter
|
||||||
explode: false
|
explode: false
|
||||||
in: query
|
in: query
|
||||||
name: status
|
name: status
|
||||||
@ -107,11 +112,9 @@ paths:
|
|||||||
type: array
|
type: array
|
||||||
description: successful operation
|
description: successful operation
|
||||||
"400":
|
"400":
|
||||||
content: {}
|
|
||||||
description: Invalid status value
|
description: Invalid status value
|
||||||
security:
|
security:
|
||||||
- petstore_auth:
|
- petstore_auth:
|
||||||
- write:pets
|
|
||||||
- read:pets
|
- read:pets
|
||||||
summary: Finds Pets by status
|
summary: Finds Pets by status
|
||||||
tags:
|
tags:
|
||||||
@ -148,33 +151,36 @@ paths:
|
|||||||
type: array
|
type: array
|
||||||
description: successful operation
|
description: successful operation
|
||||||
"400":
|
"400":
|
||||||
content: {}
|
|
||||||
description: Invalid tag value
|
description: Invalid tag value
|
||||||
security:
|
security:
|
||||||
- petstore_auth:
|
- petstore_auth:
|
||||||
- write:pets
|
|
||||||
- read:pets
|
- read:pets
|
||||||
summary: Finds Pets by tags
|
summary: Finds Pets by tags
|
||||||
tags:
|
tags:
|
||||||
- pet
|
- pet
|
||||||
/pet/{petId}:
|
/pet/{petId}:
|
||||||
delete:
|
delete:
|
||||||
|
description: ""
|
||||||
operationId: deletePet
|
operationId: deletePet
|
||||||
parameters:
|
parameters:
|
||||||
- in: header
|
- explode: false
|
||||||
|
in: header
|
||||||
name: api_key
|
name: api_key
|
||||||
|
required: false
|
||||||
schema:
|
schema:
|
||||||
type: string
|
type: string
|
||||||
|
style: simple
|
||||||
- description: Pet id to delete
|
- description: Pet id to delete
|
||||||
|
explode: false
|
||||||
in: path
|
in: path
|
||||||
name: petId
|
name: petId
|
||||||
required: true
|
required: true
|
||||||
schema:
|
schema:
|
||||||
format: int64
|
format: int64
|
||||||
type: integer
|
type: integer
|
||||||
|
style: simple
|
||||||
responses:
|
responses:
|
||||||
"400":
|
"400":
|
||||||
content: {}
|
|
||||||
description: Invalid pet value
|
description: Invalid pet value
|
||||||
security:
|
security:
|
||||||
- petstore_auth:
|
- petstore_auth:
|
||||||
@ -188,12 +194,14 @@ paths:
|
|||||||
operationId: getPetById
|
operationId: getPetById
|
||||||
parameters:
|
parameters:
|
||||||
- description: ID of pet to return
|
- description: ID of pet to return
|
||||||
|
explode: false
|
||||||
in: path
|
in: path
|
||||||
name: petId
|
name: petId
|
||||||
required: true
|
required: true
|
||||||
schema:
|
schema:
|
||||||
format: int64
|
format: int64
|
||||||
type: integer
|
type: integer
|
||||||
|
style: simple
|
||||||
responses:
|
responses:
|
||||||
"200":
|
"200":
|
||||||
content:
|
content:
|
||||||
@ -205,10 +213,8 @@ paths:
|
|||||||
$ref: '#/components/schemas/Pet'
|
$ref: '#/components/schemas/Pet'
|
||||||
description: successful operation
|
description: successful operation
|
||||||
"400":
|
"400":
|
||||||
content: {}
|
|
||||||
description: Invalid ID supplied
|
description: Invalid ID supplied
|
||||||
"404":
|
"404":
|
||||||
content: {}
|
|
||||||
description: Pet not found
|
description: Pet not found
|
||||||
security:
|
security:
|
||||||
- api_key: []
|
- api_key: []
|
||||||
@ -216,15 +222,18 @@ paths:
|
|||||||
tags:
|
tags:
|
||||||
- pet
|
- pet
|
||||||
post:
|
post:
|
||||||
|
description: ""
|
||||||
operationId: updatePetWithForm
|
operationId: updatePetWithForm
|
||||||
parameters:
|
parameters:
|
||||||
- description: ID of pet that needs to be updated
|
- description: ID of pet that needs to be updated
|
||||||
|
explode: false
|
||||||
in: path
|
in: path
|
||||||
name: petId
|
name: petId
|
||||||
required: true
|
required: true
|
||||||
schema:
|
schema:
|
||||||
format: int64
|
format: int64
|
||||||
type: integer
|
type: integer
|
||||||
|
style: simple
|
||||||
requestBody:
|
requestBody:
|
||||||
content:
|
content:
|
||||||
application/x-www-form-urlencoded:
|
application/x-www-form-urlencoded:
|
||||||
@ -232,7 +241,6 @@ paths:
|
|||||||
$ref: '#/components/schemas/updatePetWithForm_request'
|
$ref: '#/components/schemas/updatePetWithForm_request'
|
||||||
responses:
|
responses:
|
||||||
"405":
|
"405":
|
||||||
content: {}
|
|
||||||
description: Invalid input
|
description: Invalid input
|
||||||
security:
|
security:
|
||||||
- petstore_auth:
|
- petstore_auth:
|
||||||
@ -243,15 +251,18 @@ paths:
|
|||||||
- pet
|
- pet
|
||||||
/pet/{petId}/uploadImage:
|
/pet/{petId}/uploadImage:
|
||||||
post:
|
post:
|
||||||
|
description: ""
|
||||||
operationId: uploadFile
|
operationId: uploadFile
|
||||||
parameters:
|
parameters:
|
||||||
- description: ID of pet to update
|
- description: ID of pet to update
|
||||||
|
explode: false
|
||||||
in: path
|
in: path
|
||||||
name: petId
|
name: petId
|
||||||
required: true
|
required: true
|
||||||
schema:
|
schema:
|
||||||
format: int64
|
format: int64
|
||||||
type: integer
|
type: integer
|
||||||
|
style: simple
|
||||||
requestBody:
|
requestBody:
|
||||||
content:
|
content:
|
||||||
multipart/form-data:
|
multipart/form-data:
|
||||||
@ -292,10 +303,11 @@ paths:
|
|||||||
- store
|
- store
|
||||||
/store/order:
|
/store/order:
|
||||||
post:
|
post:
|
||||||
|
description: ""
|
||||||
operationId: placeOrder
|
operationId: placeOrder
|
||||||
requestBody:
|
requestBody:
|
||||||
content:
|
content:
|
||||||
'*/*':
|
application/json:
|
||||||
schema:
|
schema:
|
||||||
$ref: '#/components/schemas/Order'
|
$ref: '#/components/schemas/Order'
|
||||||
description: order placed for purchasing the pet
|
description: order placed for purchasing the pet
|
||||||
@ -311,12 +323,10 @@ paths:
|
|||||||
$ref: '#/components/schemas/Order'
|
$ref: '#/components/schemas/Order'
|
||||||
description: successful operation
|
description: successful operation
|
||||||
"400":
|
"400":
|
||||||
content: {}
|
|
||||||
description: Invalid Order
|
description: Invalid Order
|
||||||
summary: Place an order for a pet
|
summary: Place an order for a pet
|
||||||
tags:
|
tags:
|
||||||
- store
|
- store
|
||||||
x-codegen-request-body-name: body
|
|
||||||
/store/order/{orderId}:
|
/store/order/{orderId}:
|
||||||
delete:
|
delete:
|
||||||
description: For valid response try integer IDs with value < 1000. Anything
|
description: For valid response try integer IDs with value < 1000. Anything
|
||||||
@ -324,17 +334,17 @@ paths:
|
|||||||
operationId: deleteOrder
|
operationId: deleteOrder
|
||||||
parameters:
|
parameters:
|
||||||
- description: ID of the order that needs to be deleted
|
- description: ID of the order that needs to be deleted
|
||||||
|
explode: false
|
||||||
in: path
|
in: path
|
||||||
name: orderId
|
name: orderId
|
||||||
required: true
|
required: true
|
||||||
schema:
|
schema:
|
||||||
type: string
|
type: string
|
||||||
|
style: simple
|
||||||
responses:
|
responses:
|
||||||
"400":
|
"400":
|
||||||
content: {}
|
|
||||||
description: Invalid ID supplied
|
description: Invalid ID supplied
|
||||||
"404":
|
"404":
|
||||||
content: {}
|
|
||||||
description: Order not found
|
description: Order not found
|
||||||
summary: Delete purchase order by ID
|
summary: Delete purchase order by ID
|
||||||
tags:
|
tags:
|
||||||
@ -345,6 +355,7 @@ paths:
|
|||||||
operationId: getOrderById
|
operationId: getOrderById
|
||||||
parameters:
|
parameters:
|
||||||
- description: ID of pet that needs to be fetched
|
- description: ID of pet that needs to be fetched
|
||||||
|
explode: false
|
||||||
in: path
|
in: path
|
||||||
name: orderId
|
name: orderId
|
||||||
required: true
|
required: true
|
||||||
@ -353,6 +364,7 @@ paths:
|
|||||||
maximum: 5
|
maximum: 5
|
||||||
minimum: 1
|
minimum: 1
|
||||||
type: integer
|
type: integer
|
||||||
|
style: simple
|
||||||
responses:
|
responses:
|
||||||
"200":
|
"200":
|
||||||
content:
|
content:
|
||||||
@ -364,10 +376,8 @@ paths:
|
|||||||
$ref: '#/components/schemas/Order'
|
$ref: '#/components/schemas/Order'
|
||||||
description: successful operation
|
description: successful operation
|
||||||
"400":
|
"400":
|
||||||
content: {}
|
|
||||||
description: Invalid ID supplied
|
description: Invalid ID supplied
|
||||||
"404":
|
"404":
|
||||||
content: {}
|
|
||||||
description: Order not found
|
description: Order not found
|
||||||
summary: Find purchase order by ID
|
summary: Find purchase order by ID
|
||||||
tags:
|
tags:
|
||||||
@ -378,75 +388,69 @@ paths:
|
|||||||
operationId: createUser
|
operationId: createUser
|
||||||
requestBody:
|
requestBody:
|
||||||
content:
|
content:
|
||||||
'*/*':
|
application/json:
|
||||||
schema:
|
schema:
|
||||||
$ref: '#/components/schemas/User'
|
$ref: '#/components/schemas/User'
|
||||||
description: Created user object
|
description: Created user object
|
||||||
required: true
|
required: true
|
||||||
responses:
|
responses:
|
||||||
default:
|
default:
|
||||||
content: {}
|
|
||||||
description: successful operation
|
description: successful operation
|
||||||
|
security:
|
||||||
|
- api_key: []
|
||||||
summary: Create user
|
summary: Create user
|
||||||
tags:
|
tags:
|
||||||
- user
|
- user
|
||||||
x-codegen-request-body-name: body
|
|
||||||
/user/createWithArray:
|
/user/createWithArray:
|
||||||
post:
|
post:
|
||||||
|
description: ""
|
||||||
operationId: createUsersWithArrayInput
|
operationId: createUsersWithArrayInput
|
||||||
requestBody:
|
requestBody:
|
||||||
content:
|
$ref: '#/components/requestBodies/UserArray'
|
||||||
'*/*':
|
|
||||||
schema:
|
|
||||||
items:
|
|
||||||
$ref: '#/components/schemas/User'
|
|
||||||
type: array
|
|
||||||
description: List of user object
|
|
||||||
required: true
|
|
||||||
responses:
|
responses:
|
||||||
default:
|
default:
|
||||||
content: {}
|
|
||||||
description: successful operation
|
description: successful operation
|
||||||
|
security:
|
||||||
|
- api_key: []
|
||||||
summary: Creates list of users with given input array
|
summary: Creates list of users with given input array
|
||||||
tags:
|
tags:
|
||||||
- user
|
- user
|
||||||
x-codegen-request-body-name: body
|
|
||||||
/user/createWithList:
|
/user/createWithList:
|
||||||
post:
|
post:
|
||||||
|
description: ""
|
||||||
operationId: createUsersWithListInput
|
operationId: createUsersWithListInput
|
||||||
requestBody:
|
requestBody:
|
||||||
content:
|
$ref: '#/components/requestBodies/UserArray'
|
||||||
'*/*':
|
|
||||||
schema:
|
|
||||||
items:
|
|
||||||
$ref: '#/components/schemas/User'
|
|
||||||
type: array
|
|
||||||
description: List of user object
|
|
||||||
required: true
|
|
||||||
responses:
|
responses:
|
||||||
default:
|
default:
|
||||||
content: {}
|
|
||||||
description: successful operation
|
description: successful operation
|
||||||
|
security:
|
||||||
|
- api_key: []
|
||||||
summary: Creates list of users with given input array
|
summary: Creates list of users with given input array
|
||||||
tags:
|
tags:
|
||||||
- user
|
- user
|
||||||
x-codegen-request-body-name: body
|
|
||||||
/user/login:
|
/user/login:
|
||||||
get:
|
get:
|
||||||
|
description: ""
|
||||||
operationId: loginUser
|
operationId: loginUser
|
||||||
parameters:
|
parameters:
|
||||||
- description: The user name for login
|
- description: The user name for login
|
||||||
|
explode: true
|
||||||
in: query
|
in: query
|
||||||
name: username
|
name: username
|
||||||
required: true
|
required: true
|
||||||
schema:
|
schema:
|
||||||
|
pattern: "^[a-zA-Z0-9]+[a-zA-Z0-9\\.\\-_]*[a-zA-Z0-9]+$"
|
||||||
type: string
|
type: string
|
||||||
|
style: form
|
||||||
- description: The password for login in clear text
|
- description: The password for login in clear text
|
||||||
|
explode: true
|
||||||
in: query
|
in: query
|
||||||
name: password
|
name: password
|
||||||
required: true
|
required: true
|
||||||
schema:
|
schema:
|
||||||
type: string
|
type: string
|
||||||
|
style: form
|
||||||
responses:
|
responses:
|
||||||
"200":
|
"200":
|
||||||
content:
|
content:
|
||||||
@ -458,29 +462,42 @@ paths:
|
|||||||
type: string
|
type: string
|
||||||
description: successful operation
|
description: successful operation
|
||||||
headers:
|
headers:
|
||||||
|
Set-Cookie:
|
||||||
|
description: Cookie authentication key for use with the `api_key` apiKey
|
||||||
|
authentication.
|
||||||
|
explode: false
|
||||||
|
schema:
|
||||||
|
example: AUTH_KEY=abcde12345; Path=/; HttpOnly
|
||||||
|
type: string
|
||||||
|
style: simple
|
||||||
X-Rate-Limit:
|
X-Rate-Limit:
|
||||||
description: calls per hour allowed by the user
|
description: calls per hour allowed by the user
|
||||||
|
explode: false
|
||||||
schema:
|
schema:
|
||||||
format: int32
|
format: int32
|
||||||
type: integer
|
type: integer
|
||||||
|
style: simple
|
||||||
X-Expires-After:
|
X-Expires-After:
|
||||||
description: date in UTC when token expires
|
description: date in UTC when token expires
|
||||||
|
explode: false
|
||||||
schema:
|
schema:
|
||||||
format: date-time
|
format: date-time
|
||||||
type: string
|
type: string
|
||||||
|
style: simple
|
||||||
"400":
|
"400":
|
||||||
content: {}
|
|
||||||
description: Invalid username/password supplied
|
description: Invalid username/password supplied
|
||||||
summary: Logs user into the system
|
summary: Logs user into the system
|
||||||
tags:
|
tags:
|
||||||
- user
|
- user
|
||||||
/user/logout:
|
/user/logout:
|
||||||
get:
|
get:
|
||||||
|
description: ""
|
||||||
operationId: logoutUser
|
operationId: logoutUser
|
||||||
responses:
|
responses:
|
||||||
default:
|
default:
|
||||||
content: {}
|
|
||||||
description: successful operation
|
description: successful operation
|
||||||
|
security:
|
||||||
|
- api_key: []
|
||||||
summary: Logs out current logged in user session
|
summary: Logs out current logged in user session
|
||||||
tags:
|
tags:
|
||||||
- user
|
- user
|
||||||
@ -490,30 +507,35 @@ paths:
|
|||||||
operationId: deleteUser
|
operationId: deleteUser
|
||||||
parameters:
|
parameters:
|
||||||
- description: The name that needs to be deleted
|
- description: The name that needs to be deleted
|
||||||
|
explode: false
|
||||||
in: path
|
in: path
|
||||||
name: username
|
name: username
|
||||||
required: true
|
required: true
|
||||||
schema:
|
schema:
|
||||||
type: string
|
type: string
|
||||||
|
style: simple
|
||||||
responses:
|
responses:
|
||||||
"400":
|
"400":
|
||||||
content: {}
|
|
||||||
description: Invalid username supplied
|
description: Invalid username supplied
|
||||||
"404":
|
"404":
|
||||||
content: {}
|
|
||||||
description: User not found
|
description: User not found
|
||||||
|
security:
|
||||||
|
- api_key: []
|
||||||
summary: Delete user
|
summary: Delete user
|
||||||
tags:
|
tags:
|
||||||
- user
|
- user
|
||||||
get:
|
get:
|
||||||
|
description: ""
|
||||||
operationId: getUserByName
|
operationId: getUserByName
|
||||||
parameters:
|
parameters:
|
||||||
- description: The name that needs to be fetched. Use user1 for testing.
|
- description: The name that needs to be fetched. Use user1 for testing.
|
||||||
|
explode: false
|
||||||
in: path
|
in: path
|
||||||
name: username
|
name: username
|
||||||
required: true
|
required: true
|
||||||
schema:
|
schema:
|
||||||
type: string
|
type: string
|
||||||
|
style: simple
|
||||||
responses:
|
responses:
|
||||||
"200":
|
"200":
|
||||||
content:
|
content:
|
||||||
@ -525,10 +547,8 @@ paths:
|
|||||||
$ref: '#/components/schemas/User'
|
$ref: '#/components/schemas/User'
|
||||||
description: successful operation
|
description: successful operation
|
||||||
"400":
|
"400":
|
||||||
content: {}
|
|
||||||
description: Invalid username supplied
|
description: Invalid username supplied
|
||||||
"404":
|
"404":
|
||||||
content: {}
|
|
||||||
description: User not found
|
description: User not found
|
||||||
summary: Get user by user name
|
summary: Get user by user name
|
||||||
tags:
|
tags:
|
||||||
@ -538,30 +558,51 @@ paths:
|
|||||||
operationId: updateUser
|
operationId: updateUser
|
||||||
parameters:
|
parameters:
|
||||||
- description: name that need to be deleted
|
- description: name that need to be deleted
|
||||||
|
explode: false
|
||||||
in: path
|
in: path
|
||||||
name: username
|
name: username
|
||||||
required: true
|
required: true
|
||||||
schema:
|
schema:
|
||||||
type: string
|
type: string
|
||||||
|
style: simple
|
||||||
requestBody:
|
requestBody:
|
||||||
content:
|
content:
|
||||||
'*/*':
|
application/json:
|
||||||
schema:
|
schema:
|
||||||
$ref: '#/components/schemas/User'
|
$ref: '#/components/schemas/User'
|
||||||
description: Updated user object
|
description: Updated user object
|
||||||
required: true
|
required: true
|
||||||
responses:
|
responses:
|
||||||
"400":
|
"400":
|
||||||
content: {}
|
|
||||||
description: Invalid user supplied
|
description: Invalid user supplied
|
||||||
"404":
|
"404":
|
||||||
content: {}
|
|
||||||
description: User not found
|
description: User not found
|
||||||
|
security:
|
||||||
|
- api_key: []
|
||||||
summary: Updated user
|
summary: Updated user
|
||||||
tags:
|
tags:
|
||||||
- user
|
- user
|
||||||
x-codegen-request-body-name: body
|
|
||||||
components:
|
components:
|
||||||
|
requestBodies:
|
||||||
|
UserArray:
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
items:
|
||||||
|
$ref: '#/components/schemas/User'
|
||||||
|
type: array
|
||||||
|
description: List of user object
|
||||||
|
required: true
|
||||||
|
Pet:
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
$ref: '#/components/schemas/Pet'
|
||||||
|
application/xml:
|
||||||
|
schema:
|
||||||
|
$ref: '#/components/schemas/Pet'
|
||||||
|
description: Pet object that needs to be added to the store
|
||||||
|
required: true
|
||||||
schemas:
|
schemas:
|
||||||
Order:
|
Order:
|
||||||
description: An order for a pets from the pet store
|
description: An order for a pets from the pet store
|
||||||
@ -609,6 +650,7 @@ components:
|
|||||||
format: int64
|
format: int64
|
||||||
type: integer
|
type: integer
|
||||||
name:
|
name:
|
||||||
|
pattern: "^[a-zA-Z0-9]+[a-zA-Z0-9\\.\\-_]*[a-zA-Z0-9]+$"
|
||||||
type: string
|
type: string
|
||||||
title: Pet category
|
title: Pet category
|
||||||
type: object
|
type: object
|
||||||
@ -705,6 +747,7 @@ components:
|
|||||||
name: tag
|
name: tag
|
||||||
wrapped: true
|
wrapped: true
|
||||||
status:
|
status:
|
||||||
|
deprecated: true
|
||||||
description: pet status in the store
|
description: pet status in the store
|
||||||
enum:
|
enum:
|
||||||
- available
|
- available
|
||||||
@ -766,4 +809,3 @@ components:
|
|||||||
in: header
|
in: header
|
||||||
name: api_key
|
name: api_key
|
||||||
type: apiKey
|
type: apiKey
|
||||||
x-original-swagger-version: "2.0"
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user