-
-
Notifications
You must be signed in to change notification settings - Fork 769
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add example of split API specifications with relative references
Store the API in one file, the schema definitions in another file
- Loading branch information
1 parent
58c8bb6
commit 2458dbf
Showing
6 changed files
with
222 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,34 @@ | ||
=================== | ||
Split Specs Example | ||
=================== | ||
|
||
This example demonstrates split specifications and relative references. | ||
The OpenAPI specification and the Swagger specification are stored in | ||
multiple files and use references that are resolved by Connexion. | ||
|
||
Preparing | ||
--------- | ||
|
||
Create a new virtual environment and install the required libraries | ||
with these commands: | ||
|
||
.. code-block:: bash | ||
$ python -m venv my-venv | ||
$ source my-venv/bin/activate | ||
$ pip install 'connexion[flask,swagger-ui,uvicorn]>=3.1.0' | ||
Running | ||
------- | ||
|
||
Launch the connexion server with this command: | ||
|
||
Running: | ||
|
||
.. code-block:: bash | ||
$ python app.py | ||
Now open your browser and view the Swagger UI for these specification files: | ||
|
||
* http://localhost:8080/openapi/ui/ for the OpenAPI 3 spec | ||
* http://localhost:8080/swagger/ui/ for the Swagger 2 spec |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,30 @@ | ||
from pathlib import Path | ||
|
||
import connexion | ||
|
||
pets = { | ||
1: {"name": "Aldo", "registered": "2022-11-28T00:00:00Z"}, | ||
2: {"name": "Bailey", "registered": "2023-11-28T11:11:11Z"}, | ||
3: {"name": "Hugo", "registered": "2024-11-28T22:22:22Z"}, | ||
} | ||
|
||
|
||
def get(petId): | ||
id_ = int(petId) | ||
if pets.get(id_) is None: | ||
return connexion.NoContent, 404 | ||
return pets[id_] | ||
|
||
|
||
def show(): | ||
# NOTE: we need to wrap it with list for Python 3 as dict_values is not JSON serializable | ||
return list(pets.values()) | ||
|
||
|
||
app = connexion.FlaskApp(__name__, specification_dir="spec/") | ||
app.add_api("openapi.yaml", arguments={"title": "Pet Store Rel Ref Example"}) | ||
app.add_api("swagger.yaml", arguments={"title": "Pet Store Rel Ref Example"}) | ||
|
||
|
||
if __name__ == "__main__": | ||
app.run(f"{Path(__file__).stem}:app", port=8080) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,37 @@ | ||
components: | ||
schemas: | ||
Pet: | ||
required: | ||
- name | ||
properties: | ||
name: | ||
type: string | ||
example: fluffy | ||
tag: | ||
type: string | ||
example: red | ||
id: | ||
type: integer | ||
format: int64 | ||
readOnly: true | ||
example: 1 | ||
last_updated: | ||
type: string | ||
readOnly: true | ||
example: 2019-01-16T23:52:54.309102Z | ||
|
||
Pets: | ||
type: array | ||
items: | ||
$ref: "#/components/schemas/Pet" | ||
|
||
Error: | ||
properties: | ||
code: | ||
type: integer | ||
format: int32 | ||
message: | ||
type: string | ||
required: | ||
- code | ||
- message |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,29 @@ | ||
definitions: | ||
Pet: | ||
type: object | ||
properties: | ||
id: | ||
type: integer | ||
format: int64 | ||
name: | ||
type: string | ||
registered: | ||
type: string | ||
format: date-time | ||
|
||
Pets: | ||
type: array | ||
items: | ||
$ref: "#/definitions/Pet" | ||
|
||
Error: | ||
type: object | ||
properties: | ||
code: | ||
type: integer | ||
format: int32 | ||
message: | ||
type: string | ||
required: | ||
- code | ||
- message |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,54 @@ | ||
openapi: 3.0.0 | ||
|
||
info: | ||
version: 1.0.0 | ||
title: Swagger Petstore | ||
license: | ||
name: MIT | ||
|
||
servers: | ||
- url: /openapi | ||
|
||
paths: | ||
/pets: | ||
get: | ||
summary: List all pets | ||
operationId: app.show | ||
responses: | ||
'200': | ||
description: A list of pets | ||
content: | ||
application/json: | ||
schema: | ||
$ref: "components.yaml#/components/schemas/Pets" | ||
default: | ||
description: Unexpected error | ||
content: | ||
application/json: | ||
schema: | ||
$ref: "components.yaml#/components/schemas/Error" | ||
|
||
'/pets/{petId}': | ||
get: | ||
summary: Info for a specific pet | ||
operationId: app.get | ||
responses: | ||
'200': | ||
description: Expected response to a valid request | ||
content: | ||
application/json: | ||
schema: | ||
$ref: "components.yaml#/components/schemas/Pet" | ||
default: | ||
description: Unexpected error | ||
content: | ||
application/json: | ||
schema: | ||
$ref: "components.yaml#/components/schemas/Error" | ||
parameters: | ||
- name: petId | ||
in: path | ||
description: Id of the pet to get. | ||
required: true | ||
schema: | ||
type: integer |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,38 @@ | ||
swagger: "2.0" | ||
|
||
info: | ||
title: "{{title}}" | ||
version: "1.0" | ||
|
||
basePath: /swagger | ||
|
||
paths: | ||
/pets: | ||
get: | ||
summary: List all pets | ||
operationId: app.show | ||
responses: | ||
'200': | ||
description: List all pets | ||
schema: | ||
type: array | ||
items: | ||
$ref: 'definitions.yaml#/definitions/Pets' | ||
default: | ||
description: Unexpected Error | ||
schema: | ||
$ref: 'definitions.yaml#/definitions/Error' | ||
|
||
'/pets/{id}': | ||
get: | ||
summary: Info for a specific pet | ||
operationId: app.get | ||
responses: | ||
'200': | ||
description: Expected response to a valid request | ||
schema: | ||
$ref: 'definitions.yaml#/definitions/Pet' | ||
default: | ||
description: Unexpected Error | ||
schema: | ||
$ref: 'definitions.yaml#/definitions/Error' |