msaSignal - Signals/Events for Starlette/FastAPI.
Project description
msaSignal - Signals/Events for Starlette/FastAPI.
Signals/Events for Starlette/FastAPI. Run background task without blocking the function that creates the signal.
msaSDK.signals tries to stay as a background task runner.
Documentation: msaSignal Documentation (https://msaSignal.u2d.ai/)
Features
- Middleware: for Signal or Task.
- Decorators: for signal registry
- Helpers: for Handler, initiate a Signalor a Task
Main Dependencies
- Starlette 0.20.x
Usage - MSASignalMiddleware
!!! note Only one signal per function, must take request object as arg
Add middleware
from msaSignal import MSASignalMiddleware, signal
from fastapi import FastAPI
app = FastAPI()
app.add_midleware(MSASignalMiddleware, handler=signal)
# OR enable MSASetting for this feature (settings.signal_middleware)
Add handler
Specify how the fired signal should work.
from msaSignal import signal
import asyncio
@signal.register
async def handler(**kwargs):
await asyncio.sleep(5)
print(kwargs)
print('Works!')
Fire signal in function
!!! note Only one signal call is allowed using background task.
from msaSignal import initiate_signal
@app.get("/")
async def endpoint(request: Request):
await initiate_signal(request, 'handler',some_data="test value")
return {"status":"Success"}
Usage - MSATaskMiddleware
Any number of tasks, no request object needed.
Add middleware
from msaSignal import MSATaskMiddleware
from fastapi import FastAPI
app = FastAPI()
app.add_midleware(MSATaskMiddleware)
# OR enable MSASetting for this feature (settings.task_middleware)
Write handler
Specify how the fired task should work.
async def handler():
await asyncio.sleep(5)
print('Works!')
Fire task in function
from msaSignal import initiate_task
@app.get("/")
async def endpoint():
await initiate_task(handler,some_data="test value")
return {"status":"Success"}
License Agreement
msaSignal
Based onMIT
open source and free to use, it is free for commercial use, but please show/list the copyright information about msaSignal somewhere.
How to create the documentation
We use mkdocs and mkdocsstring. The code reference and nav entry get's created virtually by the triggered python script /docs/gen_ref_pages.py while mkdocs
serve
or build
is executed.
Requirements Install for the PDF creation option:
PDF Export is using mainly weasyprint, if you get some errors here pls. check there documentation. Installation is part of the msaSignal, so this should be fine.
We can now test and view our documentation using:
mkdocs serve
Build static Site:
mkdocs build
Build and Publish
Build:
python setup.py sdist
Publish to pypi:
twine upload dist/*
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
File details
Details for the file msaSignal-0.0.1.tar.gz
.
File metadata
- Download URL: msaSignal-0.0.1.tar.gz
- Upload date:
- Size: 5.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.9.14
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 099779dbe42757c29ca831861393f9f5fad86a0758ab3fcc806302943aaeff1d |
|
MD5 | ed498b8efbcca59fa6226cd094835676 |
|
BLAKE2b-256 | 3b74c3fa87c47cc2a261788558bbe7842a1439a9ab0553b39a1c6b6d979b2017 |