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

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

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

Uploaded Python 3

File details

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

File metadata

  • Download URL: json_admin-1.2.1.tar.gz
  • Upload date:
  • Size: 21.7 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.1.tar.gz
Algorithm Hash digest
SHA256 aaf55062f1a787b2ec72fd7a4f2da0a7c7704509d2c0bb3b925fa029992acca6
MD5 b9707f3791a14c630e5ac7a8be075780
BLAKE2b-256 4048f384d9dd7b5e110e9b7bf02c1a37eea21a77f5df9ec47444bdad3096545e

See more details on using hashes here.

Provenance

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

File metadata

  • Download URL: json_admin-1.2.1-py3-none-any.whl
  • Upload date:
  • Size: 22.5 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.1-py3-none-any.whl
Algorithm Hash digest
SHA256 df141acea87bf498eb1962bc8a63e5bb4d63112afdedbd783027c84f835ae85b
MD5 cc5415267d88e0c71c466c4e9d0acd42
BLAKE2b-256 23cb656208bf2f8be7c6e90aebb5d76587f479161244075e93cd4cac8f267b9f

See more details on using hashes here.

Provenance

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