The funnest ASGI Web Framework
Project description
ZipLine
ZipLine is a simple asyncronous ASGI web framework for Python. It is designed to be simple and easy to use, while still being powerful and flexible.
Quick Start
from zipline import ZipLine
app = ZipLine()
@app.route("/")
async def home(request):
planet = request.query.get("planet")
return f"Hello, {planet}!"
uvicorn my_awesome_project:app
curl http://localhost:8000/?planet=Earth
Handlers
a ZipLine handler is a simple async
function that takes a request
object and returns a response, or throws an exception.
A response can be bytes
, str
, dict
, or the ZipeLine Response
object.
If a dict
is returned, it will be serialized to JSON.
If an Exception
is thrown, it will be caught and handled by the framework, returning a basic error response.
Middleware
Zipline middleware is inspired by Express.js. Any number of handler functions can be added to the middleware stack.
Each middleware function is just another ZipLine Handler
.
Middleware functions are called in the order they are added to the stack, and pass along their context to the next handler.
The first handler in the stack to return something other than a Request
object (including Exception
) will short-circuit the stack and return the response.
from zipline import ZipLine, middleware
# middleware functions
def auth_middleware(request):
if request.headers.get("Authorization") == "Bearer 1234":
is_authed = True
else:
is_authed = False
return request, { "is_authed": is_authed }
def auth_guard(request, ctx):
if not ctx.get("is_authed"):
raise Exception("Unauthorized")
app = ZipLine()
# apply middleware to all routes
app.middleware(auth_middleware)
@app.get("/profile")
@middleware([auth_guard])
async def user_profile(request):
return "Hello, World!"
Dependency Injection
Like with middeleware, ZipLine supports dependency injection at the route level or application level. Dependencies are passed to the handler function as keyword arguments.
from zipline import ZipLine, inject
class LoggingService:
def log_request(self, request):
print(f"Request to {request.url}")
class UserService:
def __init__(self):
self.connection = "Connected to database"
def get_user():
return "User"
app = ZipLine()
# available to all routes
app.inject(LoggingService)
@app.route("/")
@inject(UserService, name="user_service")
async def home(request, user_service: UserService, logger: LoggingService):
logger.log_request(request)
return user_service.get_user()
Routing
Like Express.js, ZipLine supports multiple, nested routers.
from zipline import ZipLine, Router
app = ZipLine()
user_router = Router("/user")
@user_router.get("/:id")
async def get_user(request):
return f"User {request.path_params.get('id')}"
app.router(user_router)
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 ziplineio-0.1.7.tar.gz
.
File metadata
- Download URL: ziplineio-0.1.7.tar.gz
- Upload date:
- Size: 14.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | cfba58138a4216f4b73a01652d5f97fade5ca41d0c14741ef957c72ff1a34eff |
|
MD5 | c77194f378efffd230e716c5d1f471b6 |
|
BLAKE2b-256 | 4cc46731c16a4e2a875709a568d49e07ea22a9f0341be44d9e19b9a36a8a36b2 |
File details
Details for the file ziplineio-0.1.7-py3-none-any.whl
.
File metadata
- Download URL: ziplineio-0.1.7-py3-none-any.whl
- Upload date:
- Size: 13.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | dbbb497327b498eceb0681b354ddc6e392992736dafe5e9156bdbcb54c5757a4 |
|
MD5 | 5ec1c4b826338f795732ca2844bf4633 |
|
BLAKE2b-256 | 713dc1a1fcf5b42a44994c0bb34f789edb64dd82ca20acb5fa50f02a20ade542 |