Middleware for integrating Falcon applications with SQLAlchemy.
Project description
Falcon Middleware: SQLAlchemy Integration
The falcon-sqla package provides a middleware component for managing SQLAlchemy sessions. The manager component can also serve as a base building block or a recipe for more complex use cases, such as applications leveraging multiple database binds.
Installation
$ pip install falcon-sqla
Usage
The falcon_sqla session Manager can be used in two ways:
As a context manager to explicitly provide a database session.
Configuration
Create a SQLAlchemy engine.
Pass the engine to the Manager() initializer as its first parameter.
If using the manager as a middleware component, pass its middleware property to a falcon.App's middleware list:
engine = create_engine('dialect+driver://my/database')
manager = falcon_sqla.Manager(engine)
app = falcon.App(middleware=[manager.middleware])
# The database session will be available as req.context.session
Context Manager
A falcon_sqla.Manager can also explicitly provide a database session using the session_scope() context manager:
# Somewhere inside a responder
with self.manager.session_scope(req, resp) as session:
# Use the session
# <...>
session_scope() can also be used as a standalone session context outside of the request-response cycle:
with self.manager.session_scope() as session:
# Use the session
# <...>
Custom Vertical Partitioning
Simple random selection of read- and write- database replicas is supported out of the box. Use the add_engine() method to instruct the Manager to include the provided engines in the runtime bind selection logic:
manager = falcon_sqla.Manager(engine)
read_replica = create_engine('dialect+driver://my/database.replica')
manager.add_engine(read_replica, 'r')
The Manager.get_bind() method can be overridden to implement custom engine selection logic for more complex use cases.
See also this SQLAlchemy recipe: Custom Vertical Partitioning.
About Falcon
Falcon is the minimalist REST API and microservices framework for Python developers, with a focus on reliability, correctness, and performance at scale.
About SQLAlchemy
SQLAlchemy is the Python SQL toolkit and Object Relational Mapper that gives application developers the full power and flexibility of SQL.
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 falcon-sqla-0.4.0b1.tar.gz
.
File metadata
- Download URL: falcon-sqla-0.4.0b1.tar.gz
- Upload date:
- Size: 13.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 9c05a7ac5b7e12e9a1ab57c82cc612bd277a8a08c66433e696628f138108666a |
|
MD5 | 176c1fdf540d5a7248a9eb2b938bb18d |
|
BLAKE2b-256 | 32f435d184c2ee82d94884f8b90c822820b731c95ab3808a646b980990ab0ba2 |
File details
Details for the file falcon_sqla-0.4.0b1-py3-none-any.whl
.
File metadata
- Download URL: falcon_sqla-0.4.0b1-py3-none-any.whl
- Upload date:
- Size: 14.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.8.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7c5a59d3972c18ce2700a93642db409b541d62fb8b6a65344533e7e1e324124a |
|
MD5 | b7f8cc560ec603d6b6c38e5e37c10a4c |
|
BLAKE2b-256 | 4a603daa82d7791b263bf65043cf6fd3c0ab63c4edf3ac638055758e528a8686 |