An alternative FDK to easily run any ASGI application on OCI Functions behind an API Gateway.
Project description
fdk-asgi
An alternative FDK to easily run any ASGI application on OCI Functions behind an API Gateway.
Basic usage
Use it just like uvicorn. The fdk-asgi-serve command wraps your ASGI app with a middleware that translates from/to the Fn protocol and starts a server that respects runtime Fn configuration, e.g. listens on a unix-socket etc.
pip install fdk-asgi[cli]
fdk-asgi-serve package.module:app
If you install the package without extras, Typer and uvicorn dependencies are skipped. This is particularly useful if you want to use another ASGI server and just need the ASGI middleware this package provides.
Full usage
fdk-asgi-serve --help
Usage: fdk-asgi-serve [OPTIONS] APP
Arguments:
APP [required]
Options:
--uds TEXT Path to the UNIX domain socket, prefixed
with "unix:". This will be managed by the Fn
Server. [env var: FN_LISTENER; default:
unix:./fdk-asgi.socket]
--loop [none|auto|asyncio|uvloop]
[env var: FDK_ASGI_LOOP; default: none]
--http [auto|h11|httptools] [env var: FDK_ASGI_HTTP; default: auto]
--lifespan [auto|on|off] [env var: FDK_ASGI_LIFESPAN; default: auto]
--env-file PATH Read configuration from an env file. Only
affects the ASGI app, not the FDK/Server!
[env var: FDK_ASGI_ENV_FILE]
--log-config PATH [env var: FDK_ASGI_LOG_CONFIG]
--log-level TEXT [env var: FDK_ASGI_LOG_LEVEL]
--proxy-headers / --no-proxy-headers
Enable/Disable X-Forwarded-Proto,
X-Forwarded-For, X-Forwarded-Port to
populate remote address info. [env var:
FDK_ASGI_PROXY_HEADERS; default: proxy-
headers]
--server-header / --no-server-header
[env var: FDK_ASGI_SERVER_HEADER; default:
server-header]
--date-header / --no-date-header
[env var: FDK_ASGI_DATE_HEADER; default:
date-header]
--prefix TEXT Strips the given prefix from URL paths. Also
sets root_path to this value. [env var:
FDK_ASGI_PREFIX]
--timeout-keep-alive INTEGER [env var: FDK_ASGI_TIMEOUT_KEEP_ALIVE;
default: 5]
--factory / --no-factory Treat APP as an application factory, i.e. a
() -> <ASGI app> callable. [env var:
FDK_ASGI_FACTORY; default: no-factory]
--h11-max-incomplete-event-size INTEGER
[env var:
FDK_ASGI_H11_MAX_INCOMPLETE_EVENT_SIZE]
--install-completion [bash|zsh|fish|powershell|pwsh]
Install completion for the specified shell.
--show-completion [bash|zsh|fish|powershell|pwsh]
Show completion for the specified shell, to
copy it or customize the installation.
--help Show this message and exit.
Documentation on the Open Fn Project and OCI Functions
Example request:
POST /call HTTP/1.1
Fn-Call-Id : 12345678910
Fn-Deadline: <date/time>
Fn-Http-Request-Url: https://my.fn.com/t/hello/world
Fn-Http-Method: PUT
Fn-Http-H-Custom-Header: foo
Content-type: text/plain
<Body here>
Example Response:
HTTP/1.1 200 OK
Fn-Http-Status: 204
Fn-Http-H-My-Header: foo
Fn-Fdk-Version: fdk-go/0.0.42
Content-type: text/plain
<Body here>
For more info see Fn container contract.
Notes:
- 0666 contract can be fulfilled by
gunicorn --umask 0666
.
Default Environment Variables
Here is the list of automatically generated environment variables that are available to your functions.
Fn Generated Var | Sample Value | Description |
---|---|---|
FN_APP_ID |
01NNNNNNNNNG8G00GZJ0000001 |
The application ID for the app the current function is contained in. |
FN_FN_ID |
01DYNNNNNNNG8G00GZJ0000002 |
The ID of the current function |
FN_FORMAT |
http-stream |
Communications protocol. (Deprecated) |
FN_LISTENER |
unix:/tmp/iofs/lsnr.sock |
The Unix socket address (prefixed with “unix:”) on the file system that the FDK should create to listen for requests. The platform will guarantee that this directory is writable to the function. FDKs must not write any other data than the unix socket to this directory. |
FN_MEMORY |
128 |
The maximum memory of the function in MB. |
FN_TYPE |
sync |
The type of function. Always sync currently. |
Source: Fn Project: Using Config Variables and Environment Variables
Project details
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 fdk_asgi-0.7.0.tar.gz
.
File metadata
- Download URL: fdk_asgi-0.7.0.tar.gz
- Upload date:
- Size: 11.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.0.0 CPython/3.12.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4e128eebdfd62b3b7f750299bab38e2f430d5385c1c0643cd591f6f306985c5c |
|
MD5 | dc653477c4f41119c779cd9aa9fb78b0 |
|
BLAKE2b-256 | 9973d51abbaf48f956fd8b7d14495a605ab63cbf1eb23292599d9bf4b73bf075 |
File details
Details for the file fdk_asgi-0.7.0-py3-none-any.whl
.
File metadata
- Download URL: fdk_asgi-0.7.0-py3-none-any.whl
- Upload date:
- Size: 11.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.0.0 CPython/3.12.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2fd6294b69bd06a120949eb356d0b921c0b49982f7716bae42141d09414b45e7 |
|
MD5 | 3877734ab7ca8bd8f36cd063e4729f7d |
|
BLAKE2b-256 | 3d9645bab2d3888567156f1b7a612b1ca9ef4cefcdc9bd3d0b6ac14101b97881 |