Litestar¶
Full Litestar integration with plugin lifecycle, dependency injection, CLI commands, channels backend, and key-value store.
Plugin¶
- class sqlspec.extensions.litestar.SQLSpecPlugin[source]¶
Bases:
InitPluginProtocol,CLIPluginLitestar plugin for SQLSpec database integration.
Automatically configures NumPy array serialization when NumPy is installed, enabling seamless bidirectional conversion between NumPy arrays and JSON for vector embedding workflows.
- Session Table Migrations:
The Litestar extension includes migrations for creating session storage tables. To include these migrations in your database migration workflow, add ‘litestar’ to the include_extensions list in your migration configuration.
Example
- config = AsyncpgConfig(
connection_config={“dsn”: “postgresql://localhost/db”}, extension_config={
- “litestar”: {
“session_table”: “custom_sessions” # Optional custom table name
}
}, migration_config={
“script_location”: “migrations”, “include_extensions”: [“litestar”], # Simple string list only
}
)
The session table migration will automatically use the appropriate column types for your database dialect (JSONB for PostgreSQL, JSON for MySQL, TEXT for SQLite).
Extension migrations use the ext_litestar_ prefix (e.g., ext_litestar_0001) to prevent version conflicts with application migrations.
- __init__(sqlspec, *, loader=None)[source]¶
Initialize SQLSpec plugin.
- Parameters:
sqlspec¶ (
SQLSpec) – Pre-configured SQLSpec instance with registered database configs.loader¶ (
SQLFileLoader|None) – Optional SQL file loader instance (SQLSpec may already have one).
- property config: list[SyncDatabaseConfig[TypeAliasForwardRef('typing.Any'), TypeAliasForwardRef('typing.Any'), TypeAliasForwardRef('typing.Any')] | NoPoolSyncConfig[TypeAliasForwardRef('typing.Any'), TypeAliasForwardRef('typing.Any')] | AsyncDatabaseConfig[TypeAliasForwardRef('typing.Any'), TypeAliasForwardRef('typing.Any'), TypeAliasForwardRef('typing.Any')] | NoPoolAsyncConfig[TypeAliasForwardRef('typing.Any'), TypeAliasForwardRef('typing.Any')]]¶
Return the plugin configurations.
- Returns:
List of database configurations.
- on_app_init(app_config)[source]¶
Configure Litestar application with SQLSpec database integration.
Automatically registers NumPy array serialization when NumPy is installed.
- get_annotations()[source]¶
Return the list of annotations.
- Return type:
list[type[Union[SyncDatabaseConfig[typing.Any, typing.Any, typing.Any],NoPoolSyncConfig[typing.Any, typing.Any],AsyncDatabaseConfig[typing.Any, typing.Any, typing.Any],NoPoolAsyncConfig[typing.Any, typing.Any]]]]- Returns:
List of annotations.
- get_annotation(key)[source]¶
Return the annotation for the given configuration.
- Parameters:
key¶ (
Union[str,SyncDatabaseConfig[typing.Any, typing.Any, typing.Any],NoPoolSyncConfig[typing.Any, typing.Any],AsyncDatabaseConfig[typing.Any, typing.Any, typing.Any],NoPoolAsyncConfig[typing.Any, typing.Any],type[Union[SyncDatabaseConfig[typing.Any, typing.Any, typing.Any],NoPoolSyncConfig[typing.Any, typing.Any],AsyncDatabaseConfig[typing.Any, typing.Any, typing.Any],NoPoolAsyncConfig[typing.Any, typing.Any]]]]) – The configuration instance or key to lookup.- Raises:
KeyError – If no configuration is found for the given key.
- Return type:
type[Union[SyncDatabaseConfig[typing.Any, typing.Any, typing.Any],NoPoolSyncConfig[typing.Any, typing.Any],AsyncDatabaseConfig[typing.Any, typing.Any, typing.Any],NoPoolAsyncConfig[typing.Any, typing.Any]]]- Returns:
The annotation for the configuration.
- provide_request_session(key, state, scope)[source]¶
Provide a database session for the specified configuration key from request scope.
This method requires the connection to already exist in scope (e.g., from DI injection). For on-demand connection creation, use
provide_request_session_syncorprovide_request_session_asyncinstead.- Parameters:
key¶ (
Union[str,SyncDatabaseConfig[typing.Any, typing.Any, typing.Any],NoPoolSyncConfig[typing.Any, typing.Any],AsyncDatabaseConfig[typing.Any, typing.Any, typing.Any],NoPoolAsyncConfig[typing.Any, typing.Any],type[Union[SyncDatabaseConfig[typing.Any, typing.Any, typing.Any],NoPoolSyncConfig[typing.Any, typing.Any],AsyncDatabaseConfig[typing.Any, typing.Any, typing.Any],NoPoolAsyncConfig[typing.Any, typing.Any]]]]) – The configuration identifier (same as get_config).scope¶ (
Union[HTTPScope,WebSocketScope]) – The ASGI scope containing the request context.
- Return type:
- Returns:
A driver session instance for the specified database configuration.
- provide_request_session_sync(key, state, scope)[source]¶
Provide a sync database session for the specified configuration key from request scope.
If no connection exists in scope, one will be created from the pool and stored in scope for reuse. The connection will be cleaned up by the before_send handler.
For async configurations, use
provide_request_session_asyncinstead.
- async provide_request_session_async(key, state, scope)[source]¶
Provide an async database session for the specified configuration key from request scope.
If no connection exists in scope, one will be created from the pool and stored in scope for reuse. The connection will be cleaned up by the before_send handler.
For sync configurations, use
provide_request_sessioninstead.
- provide_request_connection(key, state, scope)[source]¶
Provide a database connection for the specified configuration key from request scope.
This method requires the connection to already exist in scope (e.g., from DI injection). For on-demand connection creation, use
provide_request_connection_syncorprovide_request_connection_asyncinstead.- Parameters:
key¶ (
Union[str,SyncDatabaseConfig[typing.Any, typing.Any, typing.Any],NoPoolSyncConfig[typing.Any, typing.Any],AsyncDatabaseConfig[typing.Any, typing.Any, typing.Any],NoPoolAsyncConfig[typing.Any, typing.Any],type[Union[SyncDatabaseConfig[typing.Any, typing.Any, typing.Any],NoPoolSyncConfig[typing.Any, typing.Any],AsyncDatabaseConfig[typing.Any, typing.Any, typing.Any],NoPoolAsyncConfig[typing.Any, typing.Any]]]]) – The configuration identifier (same as get_config).scope¶ (
Union[HTTPScope,WebSocketScope]) – The ASGI scope containing the request context.
- Return type:
- Returns:
A database connection instance for the specified database configuration.
- provide_request_connection_sync(key, state, scope)[source]¶
Provide a sync database connection for the specified configuration key from request scope.
If no connection exists in scope, one will be created from the pool and stored in scope for reuse. The connection will be cleaned up by the before_send handler.
For async configurations, use
provide_request_connection_asyncinstead.- Parameters:
key¶ (
Union[str,SyncDatabaseConfig[typing.Any, typing.Any, typing.Any],NoPoolSyncConfig[typing.Any, typing.Any],type[Union[SyncDatabaseConfig[typing.Any, typing.Any, typing.Any],NoPoolSyncConfig[typing.Any, typing.Any]]]]) – The configuration identifier (same as get_config).scope¶ (
Union[HTTPScope,WebSocketScope]) – The ASGI scope containing the request context.
- Return type:
- Returns:
A database connection instance for the specified database configuration.
- async provide_request_connection_async(key, state, scope)[source]¶
Provide an async database connection for the specified configuration key from request scope.
If no connection exists in scope, one will be created from the pool and stored in scope for reuse. The connection will be cleaned up by the before_send handler.
For sync configurations, use
provide_request_connectioninstead.- Parameters:
key¶ (
Union[str,AsyncDatabaseConfig[typing.Any, typing.Any, typing.Any],NoPoolAsyncConfig[typing.Any, typing.Any],type[Union[AsyncDatabaseConfig[typing.Any, typing.Any, typing.Any],NoPoolAsyncConfig[typing.Any, typing.Any]]]]) – The configuration identifier (same as get_config).scope¶ (
Union[HTTPScope,WebSocketScope]) – The ASGI scope containing the request context.
- Return type:
- Returns:
A database connection instance for the specified database configuration.
Configuration¶
- class sqlspec.extensions.litestar.LitestarConfig[source]¶
Bases:
TypedDictConfiguration options for Litestar session store extension.
All fields are optional with sensible defaults. Use in extension_config[“litestar”]:
Example
from sqlspec.adapters.oracledb import OracleAsyncConfig
- config = OracleAsyncConfig(
connection_config={“dsn”: “oracle://localhost/XEPDB1”}, extension_config={
- “litestar”: {
“session_table”: “my_sessions”, “in_memory”: True
}
}
)
Notes
This TypedDict provides type safety for extension config but is not required. You can use plain dicts as well.
-
session_table:
NotRequired[str]¶ ‘litestar_session’
Examples
“app_sessions” “user_sessions” “tenant_acme_sessions”
- Type:
Name of the sessions table. Default
-
in_memory:
NotRequired[bool]¶ False.
When enabled, tables are created with the in-memory attribute for databases that support it.
- This is an Oracle-specific feature that requires:
Oracle Database 12.1.0.2 or higher
Database In-Memory option license (Enterprise Edition)
Sufficient INMEMORY_SIZE configured in the database instance
Other database adapters ignore this setting.
Examples
- Oracle with in-memory enabled:
- config = OracleAsyncConfig(
connection_config={“dsn”: “oracle://…”}, extension_config={
- “litestar”: {
“in_memory”: True
}
}
)
Notes
Tables created with INMEMORY PRIORITY HIGH clause
Ignored by unsupported adapters
- Type:
Enable in-memory table storage (Oracle-specific). Default
-
shard_count:
NotRequired[int]¶ Optional hash shard count for session table primary key.
When set (>1), adapters that support computed shard columns (e.g., Spanner) will create a generated shard_id using MOD(FARM_FINGERPRINT(session_id), shard_count) and include it in the primary key to reduce hotspotting. Ignored by adapters that do not support computed shards.
Channels Backend¶
- class sqlspec.extensions.litestar.SQLSpecChannelsBackend[source]¶
Bases:
ChannelsBackendA Litestar Channels backend implemented on top of SQLSpec’s EventChannel.
This backend allows Litestar’s ChannelsPlugin to use a SQLSpec database as the broker. Under the hood it relies on SQLSpec’s events extension, which can be configured to use a durable table queue or native adapter backends.
Notes
Litestar channels may use arbitrary string names. SQLSpec event channel names must be valid identifiers. This backend maps Litestar channel names to deterministic database channel identifiers via hashing.
Store¶
- class sqlspec.extensions.litestar.BaseSQLSpecStore[source]¶
-
Base class for SQLSpec-backed Litestar session stores.
Implements the litestar.stores.base.Store protocol for server-side session storage using SQLSpec database adapters.
This abstract base class provides common functionality for all database-specific store implementations including: - Connection management via SQLSpec configs - Session expiration calculation - Table creation utilities
Subclasses must implement dialect-specific SQL queries.
- Parameters:
config¶ (
TypeVar(ConfigT)) – SQLSpec database configuration with extension_config[“litestar”] settings.
Example
from sqlspec.adapters.asyncpg import AsyncpgConfig from sqlspec.adapters.asyncpg.litestar.store import AsyncpgStore
- config = AsyncpgConfig(
connection_config={“dsn”: “postgresql://…”}, extension_config={“litestar”: {“session_table”: “my_sessions”}}
) store = AsyncpgStore(config) await store.create_table()
Notes
Configuration is read from config.extension_config[“litestar”]: - session_table: Table name (default: “litestar_session”)
- __init__(config)[source]¶
Initialize the session store.
Notes
Reads table_name from config.extension_config[“litestar”][“session_table”]. Defaults to “litestar_session” if not specified.
- property config: ConfigT¶
Return the database configuration.
- abstractmethod async get(key, renew_for=None)[source]¶
Get a session value by key.
- Parameters:
- Return type:
- Returns:
Session data as bytes if found and not expired, None otherwise.
- abstractmethod async delete_expired()[source]¶
Delete all expired sessions.
- Return type:
- Returns:
Number of sessions deleted.
Providers¶
CLI¶
- sqlspec.extensions.litestar.database_group¶
Click command group for managing SQLSpec database components (migrations, etc.).
- Type: