Auto choose the fastest cdn host for fastapi project docs.
Project description
FastAPI CDN host Selector for docs ui
Auto find swagger-ui in local files, if exist use them. Otherwise make concurrent http requests by httpx to find out which third part cdn host(cdn.jsdelivr.net/unpkg.com/cdnjs.cloudflare.com/cdn.bootcdn.net/cdn.staticfile.org) is the fastest one.
English | 中文
Install
pip install fastapi-cdn-host
Usage
import fastapi_cdn_host
from fastapi import FastAPI
app = FastAPI()
# include_routes ...
fastapi_cdn_host.patch_docs(app)
See more at:
- examples/
- tests/
Detail
- Let's say that the default docs CDN host https://cdn.jsdelivr.net is too slow in your network, while unpkg.com is much faster.
import fastapi_cdn_host
from fastapi import FastAPI
app = FastAPI()
fastapi_cdn_host.patch_docs(app) # Will use `unpkg.com`(or other faster host) to replace the `cdn.jsdelivr.net/npm`
- To support offline docs/, put swagger-ui asset files into local directory named
static
from pathlib import Path
fastapi_cdn_host.patch_docs(app, Path(__file__).parent.joinpath('static'))
This get the same result of the example in official document: https://fastapi.tiangolo.com/how-to/custom-docs-ui-assets/?h=static#self-hosting-javascript-and-css-for-docs
- If asset files are ready in private cdn
from fastapi_cdn_host import AssetUrl
fastapi_cdn_host.patch_docs(app, AssetUrl(
js='http://my-cdn.com/swagger-ui.js',
css='http://my-cdn.com/swagger-ui.css',
redoc='http://my-cdn.com/redoc.standalone.js',
favicon='http://my-cdn.com/favicon.ico')
)
License
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
fastapi_cdn_host-0.8.0.tar.gz
(13.1 kB
view details)
Built Distribution
File details
Details for the file fastapi_cdn_host-0.8.0.tar.gz
.
File metadata
- Download URL: fastapi_cdn_host-0.8.0.tar.gz
- Upload date:
- Size: 13.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.3 CPython/3.11.9 Darwin/20.6.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7c9f8efc8568c067165346bb7561520e775f172a07431fa34aff7af4406f4d9c |
|
MD5 | cc6688ea42db95cd06a0615eb355f368 |
|
BLAKE2b-256 | 60a8ba1ba53e2dbfd399e8c847e76621a2a5099e83d13d605066339632a9a652 |
File details
Details for the file fastapi_cdn_host-0.8.0-py3-none-any.whl
.
File metadata
- Download URL: fastapi_cdn_host-0.8.0-py3-none-any.whl
- Upload date:
- Size: 13.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.3 CPython/3.11.9 Darwin/20.6.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 30eacb5d9fac4d710e72df469ea9139544d3a42f62da6041b6065170f6fd7136 |
|
MD5 | 09ae5d4a35b92b72caf08876f349d87b |
|
BLAKE2b-256 | 2303a354317f6b9196ebfa6e58132ed79e9e7542e829df621ecb724e10504b7f |