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",
            sync_mode="migrate",
        ),
        JsonPage(
            slug="features",
            title="Флаги",
            file_path="data/feature_flags.json",
            model=FeatureFlags,
            icon="fa-solid fa-flag",
            sync_mode="migrate",
        ),
    ],
    base_url="/",
)

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

  • GET / покажет форму входа по паролю.
  • после входа доступны вкладки-страницы с JSON-редактором.
  • HtmlPage — read-only вкладка с HTML-блоком. content может быть: встроенной строкой HTML, путём к .html файлу или Callable[[], str].
  • кнопка Сохранить валидирует данные через обязательную Pydantic-модель и сохраняет JSON в файл.
  • sync_mode="create" создаст JSON-файл при старте, если файла нет.
  • sync_mode="migrate" создаст файл при отсутствии или прогонит существующий 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.2.3.tar.gz (25.5 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.2.3-py3-none-any.whl (27.3 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: json_admin-1.2.3.tar.gz
  • Upload date:
  • Size: 25.5 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.2.3.tar.gz
Algorithm Hash digest
SHA256 c1bc64928b8f9dc5b1e9d510929aee6c66f54b03985631772dc865838292ffe6
MD5 cc7f3ea5f49a0dc4418356b85485c371
BLAKE2b-256 9a6958c21b76c5dcdcd31f88ecc280a8bcf2a165cf216cd24fae767fd5279b08

See more details on using hashes here.

Provenance

The following attestation bundles were made for json_admin-1.2.3.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.2.3-py3-none-any.whl.

File metadata

  • Download URL: json_admin-1.2.3-py3-none-any.whl
  • Upload date:
  • Size: 27.3 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.2.3-py3-none-any.whl
Algorithm Hash digest
SHA256 76e245266ef4832affc1d95723e5ac7a3821c4656934068717083821db317c48
MD5 f3142842655497227f0907c207208635
BLAKE2b-256 488d5768b7daf3c47bc51d32294d7f87ce47e720c8ed08340bc9ff37d29482fa

See more details on using hashes here.

Provenance

The following attestation bundles were made for json_admin-1.2.3-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