Python SDK for Inngest
Project description
Serverless event-driven queues, background jobs, and scheduled jobs for Python.
Add durable functions and workflows to any framework and platform.
Inngest Python SDK
Inngest's SDK adds durable functions to Python in a few lines of code. Using this SDK, you can write background jobs as step functions without new queueing infrastructure such as celery.
We currently support the following frameworks (but adding a new framework is easy!):
- DigitalOcean Functions
- Django (
>=5.0) - FastAPI (
>=0.110.0) - Flask (
>=3.0.0) - Tornado (
>=6.4)
Python 3.10 is the minimum version we support.
Getting started
Examples
💡 You can mix
asyncand non-asyncfunctions in the same app!
Basic (no steps)
This is a minimal example of an Inngest function:
import flask
import inngest.flask
import requests
inngest_client = inngest.Inngest(
app_id="flask_example",
is_production=False,
)
@inngest_client.create_function(
fn_id="find_person",
trigger=inngest.TriggerEvent(event="app/person.find"),
)
def fetch_person(ctx: inngest.ContextSync) -> dict:
person_id = ctx.event.data["person_id"]
res = requests.get(f"https://swapi.dev/api/people/{person_id}", verify=False)
return res.json()
app = flask.Flask(__name__)
# Register functions with the Inngest server
inngest.flask.serve(
app,
inngest_client,
[fetch_person],
)
app.run(port=8000)
Each function is automatically backed by its own queue. Functions can contain steps, which act as code level transactions. Each step retries on failure, and runs once on success. Function state is automatically managed.
Let's run the function. Send the following event in the local development server (Dev Server UI) and the fetch_person function will run:
{
"name": "app/person.find",
"data": {
"person_id": 1
}
}
Step run
The following example registers a function that will:
- Get the person ID from the event
- Fetch the person with that ID
- Fetch the person's ships
- Return a summary dict
@inngest_client.create_function(
fn_id="find_ships",
trigger=inngest.TriggerEvent(event="app/ships.find"),
)
def fetch_ships(ctx: inngest.ContextSync) -> dict:
"""
Find all the ships a person has.
"""
person_id = ctx.event.data["person_id"]
def _fetch_person() -> dict:
res = requests.get(f"https://swapi.dev/api/people/{person_id}", verify=False)
return res.json()
# Wrap the function with step.run to enable retries
person = step.run("fetch_person", _fetch_person)
def _fetch_ship(url: str) -> dict:
res = requests.get(url)
return res.json()
ship_names = []
for ship_url in person["starships"]:
# step.run works in loops!
ship = step.run("fetch_ship", _fetch_ship, ship_url)
ship_names.append(ship["name"])
return {
"person_name": person["name"],
"ship_names": ship_names,
}
Send the following event in the Dev Server UI and the fetch_person function will run:
{
"name": "app/ships.find",
"data": {
"person_id": 1
}
}
Async function
@inngest_client.create_function(
fn_id="find_person",
trigger=inngest.TriggerEvent(event="app/person.find"),
)
async def fetch_person(ctx: inngest.Context) -> dict:
person_id = ctx.event.data["person_id"]
async with httpx.AsyncClient(verify=False) as client:
res = await client.get(f"https://swapi.dev/api/people/{person_id}")
return res.json()
Sending an event outside a function
Sometimes you want to send an event from a normal, non-Inngest function. You can do that using the client:
inngest_client.send_sync(inngest.Event(name="app/test", data={"person_id": 1}))
If you prefer async then use the send method instead:
await inngest_client.send(inngest.Event(name="app/test", data={"person_id": 1}))
Using in production
The Dev Server is not used in production. Inngest Cloud is used instead.
The INNGEST_EVENT_KEY and INNGEST_SIGNING_KEY environment variables must be set. These secrets establish trust between Inngest Cloud and your app. We also use request signature verification to mitigate man-in-the-middle attacks. You can read more about environment variables in our docs.
Your Inngest client must be in production mode. This is typically done with an environment variable:
inngest_client = inngest.Inngest(
app_id="my_app",
is_production=os.getenv("INNGEST_DEV") is None,
)
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file inngest-0.5.15.tar.gz.
File metadata
- Download URL: inngest-0.5.15.tar.gz
- Upload date:
- Size: 87.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
74651ca943ba9ebbe7ab00a9c53c0f78daf38af720567babad179f32e2ea2923
|
|
| MD5 |
aba1fb79bd658ef0da885087623c87a1
|
|
| BLAKE2b-256 |
ea665cee849b96bae4f59f6f86da63d586613731e27da6f4363846d42a5a238d
|
Provenance
The following attestation bundles were made for inngest-0.5.15.tar.gz:
Publisher:
inngest.yml on inngest/inngest-py
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
inngest-0.5.15.tar.gz -
Subject digest:
74651ca943ba9ebbe7ab00a9c53c0f78daf38af720567babad179f32e2ea2923 - Sigstore transparency entry: 855976238
- Sigstore integration time:
-
Permalink:
inngest/inngest-py@23ab906a2df33195e64c5f59e5ee8292f397b738 -
Branch / Tag:
refs/tags/inngest@0.5.15 - Owner: https://github.com/inngest
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
inngest.yml@23ab906a2df33195e64c5f59e5ee8292f397b738 -
Trigger Event:
push
-
Statement type:
File details
Details for the file inngest-0.5.15-py3-none-any.whl.
File metadata
- Download URL: inngest-0.5.15-py3-none-any.whl
- Upload date:
- Size: 134.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
32716fee8dcb8a207a767d17d9a9032bd087a3e0a7dd511f21886353b8862406
|
|
| MD5 |
434eb51c590412e3af98416b7b93cd98
|
|
| BLAKE2b-256 |
647fcc53a20da377ed1ac269bb67cdd01b39f5d07741db6ae5f33504f00fc248
|
Provenance
The following attestation bundles were made for inngest-0.5.15-py3-none-any.whl:
Publisher:
inngest.yml on inngest/inngest-py
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
inngest-0.5.15-py3-none-any.whl -
Subject digest:
32716fee8dcb8a207a767d17d9a9032bd087a3e0a7dd511f21886353b8862406 - Sigstore transparency entry: 855976271
- Sigstore integration time:
-
Permalink:
inngest/inngest-py@23ab906a2df33195e64c5f59e5ee8292f397b738 -
Branch / Tag:
refs/tags/inngest@0.5.15 - Owner: https://github.com/inngest
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
inngest.yml@23ab906a2df33195e64c5f59e5ee8292f397b738 -
Trigger Event:
push
-
Statement type: