Skip to main content

Exon API wrapper

Project description

easy-exon

easy-exon — это лёгкая Python-обёртка к REST API платформы Exon (СУИД).
Она упрощает аутентификацию через Keycloak и предоставляет «плоский» Python-клиент с ресурсами (api.objects, api.users, api.itd_acts и т. д.) вместо ручного формирования HTTP-запросов.

Важно: библиотека пока ориентирована на чтение данных.
Из методов PUT/POST/PATCH реализовано только добавление/редактирование пользователей — и то при наличии соответствующих прав у вашего аккаунта.
Для остальных сущностей доступна только выборка (GET и POST для передачи фильтра).

Возможности

  • 🔒 Авторизация по OIDC-токену (Keycloak, realm SpringBoot).
  • 🚀 Удобный высокоуровневый клиент MyApiClient с «живыми» ресурсами
    (создаются один раз при инициализации).
  • 📝 Встроенные модели / валидация на базе Pydantic v2.
  • 🐍 Минимум зависимостей (только requests и pydantic).

Установка

pip install git+https://github.com/fallec/easy-exon.git
# или с  PyPI:
pip install easy-exon

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

from easy_exon import MyApiClient, get_token

# 1. Получаем JWT-токен Keycloak
token = get_token("login@example.com", "S3cret!")

# 2. Создаём клиент (ресурсы становятся атрибутами объекта)
api = MyApiClient(token=token)

# 3. Делаем запросы
objects_page = api.objects.list()   # Список объектов

Где брать названия полей и эндпоинтов?

Exon не публикует открытой спецификации.
Чтобы понять, какие поля доступны в том или ином методе, откройте вкладку DevTools → Network вашего браузера при работе с веб-версией Exon:
там видны реальные HTTP-запросы, их URL, query-параметры и JSON-payload.
Эти сведения легко перенести в вызовы easy-exon.

Архитектура

  • MyApiClient — центральный класс-обёртка.
    При создании инициализирует все ресурсы:
    users, organizations, objects, itd_*, isr_*, act_*, sk_*,
    otitb_*, pir_* и др.
  • BaseClient — низкоуровневый слой (повторно использует requests.Session).
  • resources/* — отдельный модуль на каждый «микросервис» Exon.
  • exceptions.py — типы ошибок (например, TokenError).

Обратная связь

По всем вопросам обращаться в отдел аналитики АНО РСИ.

Грехов Андрей 90788

Измалков Кирилл 90938

Лицензия

Проект распространяется под лицензией MIT.
См. файл LICENSE для подробностей.


easy-exon — неофициальный инструмент. Авторы не связаны с разработчиками Exon Project и не могут гарантировать стабильность внутренних API.

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

easy_exon-0.0.9.tar.gz (17.9 kB view details)

Uploaded Source

Built Distribution

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

easy_exon-0.0.9-py2.py3-none-any.whl (40.7 kB view details)

Uploaded Python 2Python 3

File details

Details for the file easy_exon-0.0.9.tar.gz.

File metadata

  • Download URL: easy_exon-0.0.9.tar.gz
  • Upload date:
  • Size: 17.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.2

File hashes

Hashes for easy_exon-0.0.9.tar.gz
Algorithm Hash digest
SHA256 698753d59b3b3025b67352a2d9fc17ad6fe7f8ddf2096b39d81600edfd07fe8f
MD5 ca1debf8a3f833eb5e8b5d4ceeec507d
BLAKE2b-256 448b285b5bc55e6538f3499142929a531971d69a3f4e52ff09ee8ffbc008c6c3

See more details on using hashes here.

File details

Details for the file easy_exon-0.0.9-py2.py3-none-any.whl.

File metadata

  • Download URL: easy_exon-0.0.9-py2.py3-none-any.whl
  • Upload date:
  • Size: 40.7 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.2

File hashes

Hashes for easy_exon-0.0.9-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 291c190b836bdb12dd00c1ad19c2634fdea69b0316d9a4be45959988d5c4b757
MD5 8c985045f4a2601d292c7dcd4f7f666e
BLAKE2b-256 6c7b45320acaeefc4333e92ea9743191afbfd4c3df5f7609f115d5cf7e511fa1

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