This plugin updates the FastAPI app to host latest Swagger UI distribution.
Project description
FastAPI Swagger Plugin
This plugin updates the FastAPI app to include a latest Swagger UI distribution. Also, it works locally and does not depend on the @tiangolo domains and cdns.
Why?
The FastAPI already includes a Swagger UI. However, author updates swagger not so often. Moreover he uses his own hosts for the resources, and they are not always available (especially in Russia). This plugin allows to use the latest Swagger UI distribution and host it inside your app.
Usage
Installation
pip install fastapi-swagger
Basic Usage
from fastapi import FastAPI
from fastapi_swagger import patch_fastapi
app = FastAPI(docs_url=None, swagger_ui_oauth2_redirect_url=None) # docs url will be at /docs
patch_fastapi(app)
How it works?
How it was before:
FastAPI uses the get_swagger_ui_html
function to render the Swagger UI under the hood.
def get_swagger_ui_html(
*,
openapi_url: str,
title: str,
swagger_js_url: str = "https://cdn.jsdelivr.net/npm/swagger-ui-dist@5/swagger-ui-bundle.js",
swagger_css_url: str = "https://cdn.jsdelivr.net/npm/swagger-ui-dist@5/swagger-ui.css",
swagger_favicon_url: str = "https://fastapi.tiangolo.com/img/favicon.png",
oauth2_redirect_url: Optional[str] = None,
init_oauth: Optional[Dict[str, Any]] = None,
swagger_ui_parameters: Optional[Dict[str, Any]] = None,
) -> HTMLResponse:
...
How it is now:
Actually, we just copy the Swagger UI distribution from
the GitHub releases to the fastapi_swagger
package, and serve it
from your app.
Patch creates several additional routes with the Swagger UI resources and one route for docs page (btw, using same
get_swagger_ui_html
function).
def patch_fastapi(
app: FastAPI,
docs_url: str = "/docs",
*,
title: Optional[str],
swagger_js_url: str = "/swagger/swagger-ui-bundle.js", # relative path from app root
swagger_css_url: str = "/swagger/swagger-ui.css", # relative path from app root
swagger_favicon_url: str = "/swagger/favicon-32x32.png", # relative path from app root
oauth2_redirect_url: Optional[str] = None,
init_oauth: Optional[Dict[str, Any]] = None,
swagger_ui_parameters: Optional[Dict[str, Any]] = None,
):
...
patch_fastapi(app)
# Now there are additional routes /swagger/swagger-ui-bundle.js, /swagger/swagger-ui.css, /swagger/favicon-32x32.png and /docs
# They all are not dependent on the external resources.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file fastapi_swagger-0.2.2.tar.gz
.
File metadata
- Download URL: fastapi_swagger-0.2.2.tar.gz
- Upload date:
- Size: 430.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.0 CPython/3.12.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8c4cee5292bc246aaa055ecfc622d6a4d28035d06b25f4b64db8da06b04c4449 |
|
MD5 | 5814a36643c8f5e0003177a084b9798e |
|
BLAKE2b-256 | 1af1d9d35302642cc272b9b56e81bcec5e488c3cb107b332dd9b8e7bf2754e9e |
File details
Details for the file fastapi_swagger-0.2.2-py3-none-any.whl
.
File metadata
- Download URL: fastapi_swagger-0.2.2-py3-none-any.whl
- Upload date:
- Size: 432.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.0 CPython/3.12.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | c18952df28fab76fabe4c3371966f303fd616e96df78ac7910d3f92cebc00fec |
|
MD5 | dfef07635be130690b4a7a619f4a72b2 |
|
BLAKE2b-256 | 0828230f50b736cd50995ece1d7c6cdf588b3c2bb3bee326411c88d6b8147622 |