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.4.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.4-py3-none-any.whl (27.2 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: json_admin-1.2.4.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.4.tar.gz
Algorithm Hash digest
SHA256 fc1856e867094297396132ec46f83bdc3eb4fa13a685c3627c3a0e455674152b
MD5 05a6d51d0295f43bfdde0721bd0da9f1
BLAKE2b-256 3c9acf840f35c2d4e4c1edecb6b69798b42443b455d8c7a258f6adb2fdaba8fc

See more details on using hashes here.

Provenance

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

File metadata

  • Download URL: json_admin-1.2.4-py3-none-any.whl
  • Upload date:
  • Size: 27.2 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.4-py3-none-any.whl
Algorithm Hash digest
SHA256 0c65f2f7f3829ce67bf3bac92195e6d49f56518c978f84d3f8c234243d6a776f
MD5 99830e8bb78acd191c0913a90021a746
BLAKE2b-256 8328c91f4f7c0d199a7fca4bb5ec66a76a2339791087c813f54196e4e99b6edb

See more details on using hashes here.

Provenance

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