Skip to main content

Simple web admin interface to manage .json file

Project description

Json-admin

Библиотека с реализацией простого интерфейса для управления .json-файлом с настройками приложения.

Установка

uv add json-admin
poetry add json-admin
pip install json-admin

Быстрый старт

from litestar import Litestar
from pydantic import BaseModel, Field

from jsonadmin import Admin, HtmlPage, JsonPage


class AppSettings(BaseModel):
    """Настройки приложения."""

    debug: bool = Field(default=False, description="Включает debug-режим")
    retries: int = Field(default=3, ge=0, description="Количество повторных попыток")


class FeatureFlags(BaseModel):
    """Настройки флагов."""

    use_cache: bool = Field(default=True, description="Включает кеширование")
    beta_mode: bool = Field(default=False, description="Включает beta-режим")


app = Litestar(route_handlers=[])
admin = Admin(
    app=app,
    passwd="super-strong-password",
    title="My App Admin",
    index="index.html",
    login="login.html",
    pages=[
        HtmlPage(
            slug="info",
            title="Информация",
            icon="fa-solid fa-circle-info",
            content="""
            <h2>Welcome</h2>
            <p>Эта вкладка только для чтения и показывает HTML-блок.</p>
            """,
        ),
        JsonPage(
            slug="settings",
            title="Настройки",
            file_path="data/app_settings.json",
            model=AppSettings,
            icon="fa-solid fa-gear",
        ),
        JsonPage(
            slug="features",
            title="Флаги",
            file_path="data/feature_flags.json",
            model=FeatureFlags,
            icon="fa-solid fa-flag",
        ),
    ],
    base_url="/",
)

После запуска:

  • GET / покажет форму входа по паролю.
  • после входа доступны вкладки-страницы с JSON-редактором.
  • HtmlPage — read-only вкладка с HTML-блоком. content может быть: встроенной строкой HTML, путём к .html файлу или Callable[[], str].
  • кнопка Сохранить валидирует данные через обязательную Pydantic-модель и сохраняет JSON в файл.
  • можно переопределить интерфейс через Jinja-шаблоны в jsonadmin/html/ (по умолчанию) или через templates_dir=....
  • для вкладок можно передать icon с классом Font Awesome, например fa-solid fa-gear.

Пример интерфейса

Ниже — короткий визуальный пример того, как выглядит админка:

  • Страница входа: Страница входа

  • Read-only HTML-вкладка (HtmlPage): HTML-вкладка

  • Редактирование JSON (вкладка 1): Редактирование JSON 1

  • Редактирование JSON (вкладка 2): Редактирование JSON 2

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

json_admin-1.0.0.tar.gz (10.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

json_admin-1.0.0-py3-none-any.whl (11.7 kB view details)

Uploaded Python 3

File details

Details for the file json_admin-1.0.0.tar.gz.

File metadata

  • Download URL: json_admin-1.0.0.tar.gz
  • Upload date:
  • Size: 10.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for json_admin-1.0.0.tar.gz
Algorithm Hash digest
SHA256 12d28267e97901deb5c1065761f4d307f40e8975dd73b573641baa2e0ab3b7ea
MD5 84becf5fb82c4532128aa916a84ae7ec
BLAKE2b-256 3ff5d0789f1fe8c204a333c10c283a9d0b85e8bffa4b8699ed8eeae962d07a3c

See more details on using hashes here.

Provenance

The following attestation bundles were made for json_admin-1.0.0.tar.gz:

Publisher: pypi.yml on LoveBloodAndDiamonds/json-admin

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file json_admin-1.0.0-py3-none-any.whl.

File metadata

  • Download URL: json_admin-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 11.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for json_admin-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 cfb87263601c762b3cbf0c78ff39244d069fc4483fa9c08d5672e27223314f54
MD5 fb6638231bf363ed62f7ae0c4f4de529
BLAKE2b-256 11c687557e4e02eac8cd8d65a2a55326a30ce1b63fedb4ecc3ced2b758c7d6f3

See more details on using hashes here.

Provenance

The following attestation bundles were made for json_admin-1.0.0-py3-none-any.whl:

Publisher: pypi.yml on LoveBloodAndDiamonds/json-admin

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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