Skip to main content

Жирный КОРЕНЬ китов: единая error-иерархия, config/retry/paths-утили, checkpoint/resume, транспорт/auth/sessions — общий код для clikit, adapterkit и доменных пакетов.

Project description

librarykit

Жирное ядро экосистемы китов — переиспользуемый фундамент, на котором строятся тонкие надстройки (adapterkit, clikit) и любые доменные пакеты. Вся общая логика живёт здесь один раз, вместо копипасты по проектам: единая иерархия ошибок, config/paths-утили, политики повторов, HTTP-транспорт, авторизация, шифрованное хранилище сессий, antibot/браузер, пагинация, RPC/stream и оркестраторы онбординга/health.

librarykit   ← КОРЕНЬ: errors · config · retry · transport · auth · sessions ·
                        errmap · pagination · antibot · browser · rpc · stream ·
                        orchestration.  Зависит НИ ОТ ЧЕГО из китов.
   ▲
clikit       ← CLI-обёртка (поверх librarykit)
   ▲
adapterkit   ← SDK сетевых адаптеров (поверх librarykit + clikit)
   ▲
домен        ← конкретный продукт (поверх всех трёх)

Зависимости направлены только внутрь, к корню. librarykit не импортирует ни один другой кит и ничего не знает о потребителях.

Установка

uv add s-librarykit

Имя дистрибутива — s-librarykit, имя для импорта — librarykit.

Опциональные extra (тяжёлые зависимости ставятся по требованию):

uv add "s-librarykit[browser]"   # Playwright — warm/cold-login, snapshot сессий
uv add "s-librarykit[antibot]"   # curl-cffi — JA3-impersonate транспорт
uv add "s-librarykit[ws]"        # websockets — persistent stream-транспорт

Ядро (errors/config_util/retry/checkpoint/contract) почти-stdlib — единственная не-stdlib зависимость ядра platformdirs (нативные пути ОС для AppPaths). Сетевые модули тянут httpx/stamina, шифрование сессий — cryptography/keyring.

Состав

Слой Модуль Что даёт
Ошибки librarykit.errors единая иерархия CliError/ApiError + сетевые подклассы (AuthRequired/RateLimited/NotFound/ServerError/TransportError/Blocked) + множество RETRYABLE
Конфиг/пути librarykit.config_util deep_merge, interpolate_env, load_dotenv, slugify, normalize_account_id, atomic_write_text, chmod_600, AppPaths
Контракт librarykit.contract граничные Protocol (Transport/Auth/Refreshable/ErrorMapper/Paginator/SessionStoreProtocol/StreamTransport/Codec) + DTO/enum (SessionRef/Creds/PaginationMode/AuthMode/TransportKind)
Протоколы librarykit.protocols опциональные онбординг/health-контракты (LoginMode/OnboardingProtocol/HealthProtocol/HealthState/InteractiveFlow)
Повторы librarykit.retry RetryPolicy (header-driven: Retry-After/rate-limit) поверх stamina + SimpleRetryPolicy
Транспорт librarykit.transport HttpxTransport + HttpClient — единый choke-point HTTP-вызовов
Ошибки→исключения librarykit.errmap декларативная карта {status|code|body-predicate → ErrorSubclass} (build_error_map)
Пагинация librarykit.pagination CursorPaginator (offset/cursor/page) + tweepy-стиль обёртки
Авторизация librarykit.auth TokenAuth/CookieSessionAuth/OAuth2Auth/BrowserLoginAuth + dump/load/encrypt настроек
Сессии librarykit.sessions SessionStore — envelope-шифрованное файловое хранилище сессий (DEK под KEK), resolve_kek
Секреты librarykit.secret_store SecretStore — keyring + file-fallback
Antibot librarykit.antibot выбор транспорта Tier 0-4 (curl-cffi JA3 / реальный браузер по CDP)
Браузер librarykit.browser warm/cold-login, snapshot/restore storage-state
RPC librarykit.rpc RpcClient + codec-слой (JsonCodec/PrefixedJsonCodec) поверх HttpClient
Stream librarykit.stream persistent-транспорты (StubStreamTransport + WebSocketsStreamTransport)
Checkpoint librarykit.checkpoint Checkpoint (атомарный JSON-state), JsonlSink (forensic-лог), RunMetrics
Сущности librarykit.entities нейтральные data-классы (Session/SessionContext/HealthReport)
Оркестрация librarykit.orchestration OnboardingService, HealthMonitor, SessionLoader — переиспользуемые сценарии онбординга/health

Топ-уровневый import librarykit ре-экспортирует публичный API (см. librarykit.__all__).

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

import librarykit as lk

# единая иерархия ошибок
try:
    ...
except lk.RateLimited as e:
    ...

# header-driven повторы + choke-point HTTP-клиент
client = lk.HttpClient(base_url="https://api.example.com", retry=lk.DEFAULT_RETRY)

# декларативная карта ответ → доменная ошибка
err_map = lk.build_error_map()

# envelope-шифрованное хранилище сессий
store = lk.SessionStore(root=..., kek=lk.resolve_kek())

Разработка

uv sync --extra dev
uv run --extra dev pytest -q
uv run --extra dev ruff check librarykit

Лицензия

MIT © 2026 Dmitry.

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

s_librarykit-0.1.8.tar.gz (206.7 kB view details)

Uploaded Source

Built Distribution

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

s_librarykit-0.1.8-py3-none-any.whl (135.6 kB view details)

Uploaded Python 3

File details

Details for the file s_librarykit-0.1.8.tar.gz.

File metadata

  • Download URL: s_librarykit-0.1.8.tar.gz
  • Upload date:
  • Size: 206.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.9.30 {"installer":{"name":"uv","version":"0.9.30","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"12","id":"bookworm","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for s_librarykit-0.1.8.tar.gz
Algorithm Hash digest
SHA256 7de88108379448f6d8cb21506f928ef14a39e60fb7f0696cf8d4c4310ce91e54
MD5 255ccc977a4a0a0e92f02485caa7bd0a
BLAKE2b-256 15fbb10bfe967f9ed912ef5f38fef1be1287ed247cc92057835b94365b6f0921

See more details on using hashes here.

File details

Details for the file s_librarykit-0.1.8-py3-none-any.whl.

File metadata

  • Download URL: s_librarykit-0.1.8-py3-none-any.whl
  • Upload date:
  • Size: 135.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.9.30 {"installer":{"name":"uv","version":"0.9.30","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"12","id":"bookworm","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for s_librarykit-0.1.8-py3-none-any.whl
Algorithm Hash digest
SHA256 0835bdbfa2a1fa787583dd710bcb10b21921af759c04ff819a9e892576a17c46
MD5 ced141be40c9d3e0b2687e8f6754bbdd
BLAKE2b-256 f61ec2412ca1f50b84d91e1f2053f8b3dfbb77f552c120a717e5d9d548b996d7

See more details on using hashes here.

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