Skip to main content

No project description provided

Project description

sqladmin-litestar-plugin

Overview

The SQLAdminPlugin integrates SQLAdmin with a Litestar application.

Acknowledgements

Thanks to aminalaee and all contributors for the excellent SQLAdmin project.

Installation

To install the dependencies, run:

pip install sqladmin-litestar-plugin

Usage

To use the plugin, import the SQLAdminPlugin class and pass it to the Litestar application.

By default, the plugin will create a new admin interface at /admin.

Example

from litestar import Litestar
from sqladmin import ModelView
from sqladmin_litestar_plugin import SQLAdminPlugin
from sqlalchemy import Column, Integer, String
from sqlalchemy.ext.asyncio import create_async_engine
from sqlalchemy.orm import declarative_base


engine = create_async_engine("sqlite+aiosqlite:///example.db")
Base = declarative_base()


class User(Base):
    __tablename__ = "users"

    id = Column(Integer, primary_key=True)
    name = Column(String)


class UserAdmin(ModelView, model=User):
    column_list = [User.id, User.name]


async def on_startup() -> None:
    async with engine.begin() as conn:
        await conn.run_sync(Base.metadata.create_all)  # Create tables


admin = SQLAdminPlugin(views=[UserAdmin], engine=engine)
app = Litestar(plugins=[admin], on_startup=[on_startup])

Configuration

The SQLAdminPlugin accepts the following arguments:

  • views: A sequence of ModelView classes to add to the admin app. Each ModelView class configures the interface for a SQL model.
  • engine: An SQLAlchemy engine to connect to your database.
  • sessionmaker: An SQLAlchemy sessionmaker instance used to manage sessions.
  • base_url: The base URL where the admin app will be hosted.
  • title: The title of the admin app, which appears in the browser's title bar and the header of the admin interface.
  • logo_url: The URL of the logo to display in the admin app, enhancing brand visibility.
  • templates_dir: The directory containing the Jinja2 templates for the admin interface, allowing for customization of the UI.
  • middlewares: A sequence of Starlette middlewares to add to the admin app, useful for handling requests or adding additional functionality.
  • authentication_backend: An authentication backend to secure the admin app, managing user authentication and authorization.

Views are not added to the admin app until the Litestar application is instantiated, so you can append views to the views list until this point.

Use with Advanced-Alchemy Audit Base Variants

Advanced-Alchemy (AA) provides variants of base models that include created_at and updated_at fields which enforce that tzinfo is set on the datetime instance passed through to SQLAlchemy.

When a model is created via the SQLAdmin UI, the created_at and updated_at fields default to the current time in UTC, however, the tzinfo property of the datetime is not set.

sqladmin-litestar-plugin provides a custom ModelView class that ensures the tzinfo property is set on datetime instances when the form field represents an AA DateTimeUTC field.

Example:

from __future__ import annotations

from advanced_alchemy.base import UUIDAuditBase
from sqlalchemy import Column, String

from sqladmin_litestar_plugin.ext.advanced_alchemy import AuditModelView


class Entity(UUIDAuditBase):
    my_column = Column(String(10))


class EntityAdmin(AuditModelView, model=Entity): ...

For a full working example, see the examples/aa_audit_base directory in this repo.

The AuditModelView class should also be useful for models that don't depend on one of the AA audit model bases, but still use DateTimeUTC fields.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

sqladmin_litestar_plugin-0.2.0.tar.gz (6.9 kB view details)

Uploaded Source

Built Distribution

sqladmin_litestar_plugin-0.2.0-py3-none-any.whl (6.9 kB view details)

Uploaded Python 3

File details

Details for the file sqladmin_litestar_plugin-0.2.0.tar.gz.

File metadata

File hashes

Hashes for sqladmin_litestar_plugin-0.2.0.tar.gz
Algorithm Hash digest
SHA256 fb0bbc64812528324cd753738788a95ee298cc33066e9382646ecd1995a61fff
MD5 00a1e4df3b63e831be891c0e04fa94bb
BLAKE2b-256 a98990fdb698565857b79c3cc84058c705acab75cfe19ec8cfd6c82ffb15fb3d

See more details on using hashes here.

File details

Details for the file sqladmin_litestar_plugin-0.2.0-py3-none-any.whl.

File metadata

File hashes

Hashes for sqladmin_litestar_plugin-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 07e6d5a3f996e8618c305f5401d2040375617453bd08314132bb028295341ecf
MD5 f70c6d34bfa49f2e539ae42a8d9159b2
BLAKE2b-256 8ce79398b0a4b162b69a311241acb2370c705c5d067cd1af72375efc617d1770

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page