Skip to main content

Yougile API models

Project description

Yougile API для Python

Информация о библиотеке

Библиотека является разработкой стороннего разработчика для удобства обращения к Yougile API.

Установка

Если вы устанавливаете вручную, перед использованием библиотеки, необходимо установить следующее:

> pip install pydantic
> pip install requests
> pip install httpx

Если вы устанавливаете из PyPI, то эти библиотеки устанавливаются автоматически:

> pip install yougile-api

Wiki

У моделей есть правила:

  1. Название моделей полностью копируют URL этой модели на официальном API.
  2. У всех моделей есть описания параметров, краткого описания из официального API и ссылка на запрос.
  3. Названия параметров модели и их типизация идентичны параметрам из официального API (За исключением параметра token)

Возможности

Токен можно передавать тремя способами:

  1. в саму модель
  2. в yougile.query(...) / yougile.query_async(...)
  3. в yougile.Client(...) / yougile.AsyncClient(...)

Приоритет такой: явный аргумент функции/метода, затем токен клиента, затем токен модели.

Пример передачи токена в функцию запроса:

import requests
import yougile
import yougile.models as models

def yougile_get(model: yougile.BaseModel) -> requests.Response:
    return yougile.query(model, token="TOKEN")

model = models.ChatMessageController_search(chatId="12324")
response = yougile_get(model)

for msg in response.json()["content"]:
    print(msg["text"])

Примеры

1. Получаем список доступных компаний

import yougile  # Импортируем библиотеку
import yougile.models as models  # Импортируем модели

model = models.AuthKeyController_companiesList(
    login="USERNAME",
    password="PASSWORD",
)  # Указываем модель запроса листа компаний через авторизацию
response = yougile.query(model)  # Делаем запрос на сервер
print(response.text)  # Получаем ответ

2. Создаем токен

import yougile
import yougile.models as models

model = models.AuthKeyController_create(
    login="USERNAME",
    password="PASSWORD",
    companyId="12345",
)
response = yougile.query(model)
print(response.json()["key"])

3. Получаем историю сообщений

import yougile
import yougile.models as models

model = models.ChatMessageController_search(token="TOKEN", chatId="12324")
response = yougile.query(model)
for msg in response.json()["content"]:
    print(msg["text"])

4. Асинхронный запрос: Загружаем файл

import asyncio
import yougile
import yougile.models as models

async def main():
    model = models.FileController_uploadFile(
        token="YOUR_TOKEN",
        file=r"C:\Users\txello\Desktop\test.png",
    )
    response = await yougile.query_async(model)
    print(response.json())

asyncio.run(main())

5. Self-hosted: указываем base_url

import yougile
import yougile.models as models

model = models.ChatMessageController_search(token="TOKEN", chatId="12324")
response = yougile.query(
    model,
    base_url="https://yougile.example.com",
)

for msg in response.json()["content"]:
    print(msg["text"])

6. Клиент с настройками подключения

import yougile
import yougile.models as models

client = yougile.Client(
    base_url="https://yougile.example.com",
    token="TOKEN",
)

model = models.ChatMessageController_search(chatId="12324")
response = client.query(model)

for msg in response.json()["content"]:
    print(msg["text"])

7. Асинхронный клиент с настройками подключения

import asyncio
import yougile
import yougile.models as models

async def main():
    client = yougile.AsyncClient(
        base_url="https://yougile.example.com",
        token="TOKEN",
    )
    model = models.ChatMessageController_search(chatId="12324")
    response = await client.query(model)
    print(response.json())

asyncio.run(main())

Версии

v1.4.1

  • Исправлена поддержка версии Python с 3.8+ на 3.10+ (Спасибо ilsky69)

v1.4.0

  • Добавлена поддержка self-hosted YouGile через параметр base_url в query и query_async
  • Добавлены yougile.Client и yougile.AsyncClient для хранения настроек подключения
  • Параметр token в API-моделях сделан необязательным: токен теперь можно хранить только в клиенте или передавать в функцию запроса
  • Исправлены модели CompanyController_get и CompanyController_update
  • Исправлены модели TaskController_search, TaskController_searchReversed, TaskController_create и TaskController_update
  • Исправлены модели GroupChatController_create, GroupChatController_update, WebhookController_create и WebhookController_put
  • Исправлены модели DepartmentController_search и ChatMessageController_sendMessage
  • Исправлены модели CrmContactPersonsController_create и CrmExternalIdController_findContactByExternalId
  • Обновлена документация и примеры использования

Спасибо ilsky69 за найденные проблемы и вклад в улучшение проекта.

v1.3.0

  • Добавлена асинхронная поддержка через функцию query_async (Через библиотеку httpx).
  • Фильтрация версий изменена с последней на первую.
  • Исправлены docstrings.

v1.2.0

  • Добавлены модели CrmContactPersonsController_create и CrmExternalIdController_findContactByExternalId.
  • Изменена лицензия в файле LICENSE с GNU GPL v3.0 на MIT (Спасибо XTerris).

v1.1.0

  • Добавлены новые модели: CompanyController_get, CompanyController_update, FileController_uploadFile, TaskController_getChatSubscribers, TaskController_updateChatSubscribers
  • Добавлена возможность загрузки файла через FileController_uploadFile
  • Добавлено CI/CD
  • Исправлены модели TaskController_get и TaskController_update (Спасибо XTerris)
  • Исправлены модели в документации
  • Улучшена документация: Заменена на Google Docstring
  • Выполнен рефакторинг кода

v1.0.1

  • Исправлены модели
  • Исправлены комментарии

v1.0.0

  • Созданы первые модели
  • Создано подключение к серверу 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

yougile_api-1.4.1.tar.gz (17.5 kB view details)

Uploaded Source

Built Distribution

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

yougile_api-1.4.1-py3-none-any.whl (28.1 kB view details)

Uploaded Python 3

File details

Details for the file yougile_api-1.4.1.tar.gz.

File metadata

  • Download URL: yougile_api-1.4.1.tar.gz
  • Upload date:
  • Size: 17.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for yougile_api-1.4.1.tar.gz
Algorithm Hash digest
SHA256 c660af2bbc3b943cea4b4f54638937f0fb4d15a2e5740e3566eb42c431be0574
MD5 9860c6ce39b15a3274c04faf2c6cb8ee
BLAKE2b-256 a377cdf9187a7c9f29061cb63b7b86f0ac2e2648c68c65632d2aeafa1dfc82d9

See more details on using hashes here.

File details

Details for the file yougile_api-1.4.1-py3-none-any.whl.

File metadata

  • Download URL: yougile_api-1.4.1-py3-none-any.whl
  • Upload date:
  • Size: 28.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for yougile_api-1.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 81fd4f4b4e09a9403a562cdde6710b1e767c901f1f889346538ecf75863021ac
MD5 9f1dae52f96fb9cb6cb89a46fb1eebaa
BLAKE2b-256 778aac7b653739ebd4ea7cd78a1d8f3608f2bb22d8bdc9d4a379e49e8e8682f7

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