DatabaseSessionDependency¶
- class safir.dependencies.db_session.DatabaseSessionDependency¶
- Bases: - object- Manages an async per-request SQLAlchemy session. - Notes - Creation of the database session factory has to be deferred until the configuration has been loaded, which in turn is deferred until app startup. - In the app startup hook, run: - await db_session_dependency.initialize(database_url) - In the app shutdown hook, run: - await db_session_dependency.aclose() - An isolation level may optionally be configured when calling - initialize. By default, a transaction is opened for every request and committed at the end of that request. This can be configured when calling- initialize.- Methods Summary - __call__()- Return the database session manager. - aclose()- Shut down the database engine. - initialize(url, password, *[, connect_args, ...])- Initialize the session dependency. - Methods Documentation - async __call__()¶
- Return the database session manager. - Returns:
- The newly-created session. 
- Return type:
 
 - async initialize(url, password, *, connect_args=None, isolation_level=None, max_overflow=None, pool_size=None, pool_timeout=None)¶
- Initialize the session dependency. - Parameters:
- url ( - str|- Url) – Database connection URL, not including the password.
- password ( - str|- SecretStr|- None) – Database connection password.
- connect_args ( - dict[- str,- Any] |- None, default:- None) – Additional connection arguments to pass directly to the underlying database driver.
- isolation_level ( - str|- None, default:- None) – If specified, sets a non-default isolation level for the database engine.
- max_overflow ( - int|- None, default:- None) – Maximum number of connections over the pool size for surge traffic.
- pool_size ( - int|- None, default:- None) – Connection pool size.
- pool_timeout ( - float|- None, default:- None) – How long to wait for a connection from the connection pool before giving up.
 
- Return type: