Skip to main content

API client for ServiceDesk Plus

Project description

REST API client for ServiceDesk Plus

1) Методы

1.1) get_request - получение заявки по id
1.2) get_requests - получение заявок по условиям
1.3) create_request - создание заявки
1.4) update_request - обновление заявки
1.5) cancel_request - отмена заявки
1.6) attach_file_to_request - прикрепление файлов к заявке
1.7) get_categories - получение категорий
1.8) get_service_categories - получение категорий услуг
1.9) get_subcategories - получение подкатегорий
1.10) get_templates - получение шаблонов для заявок
1.11) get_template - получение шаблона по id
1.12) get_urgencies - получение возможных значений срочности заявок
1.13) add_note - добавление заметок к заявке
1.14) attach_file_to_note - прикрепление файлов к заметке
1.15) get_resolution - получение решения заявки
1.16) download - скачивает ресурс по указанному URL
1.17) stream - стримит ресурс по указанному URL

Все методы могут вызывать исключения HelpdeskClientError и httpx.HTTPError (stream только httpx.HTTPError)

2) Установка

pip

pip install servicedesk-client

pdm

pdm add servicedesk-client

3) Пример внедрения

3.1) Настройки

class HelpdeskSettings(BaseSettings):
    model_config = SettingsConfigDict(str_strip_whitespace=True, env_prefix="helpdesk_")

    authtoken: SecretStr
    base_url: str
    timeout: int

3.2) Http Client

HelpdeskHttpClient = NewType("HelpdeskHttpClient", httpx.AsyncClient)

@asynccontextmanager
async def get_helpdesk_http_client(
    settings: HelpdeskSettings,
) -> AsyncIterator[HelpdeskHttpClient]:

    async with httpx.AsyncClient(
        headers={"authtoken": settings.authtoken.get_secret_value()},
        base_url=settings.base_url,
        timeout=settings.timeout,
    ) as client:
        yield HelpdeskHttpClient(client)

3.3) DI (используется библиотека https://pypi.org/project/aioinject/)

from helpdesk_client.v3 import HelpdeskClient


@asynccontextmanager
async def _get_helpdesk_client(
    http_client: HelpdeskHttpClient,
) -> AsyncIterator[HelpdeskClient]:
    yield HelpdeskClient(http_client=http_client)


PROVIDERS: Providers = [
    aioinject.Singleton(get_helpdesk_http_client, HelpdeskHttpClient),
    aioinject.Singleton(_get_helpdesk_client),
]

3.4) Helpdesk Service

from helpdesk_client.v3 import HelpdeskClient


class HelpdeskService:
    def __init__(self, helpdesk_client: HelpdeskClient) -> None:
        self._helpdesk_client = helpdesk_client

    ...

4) Пример получения 5 последних заявок

import httpx
from helpdesk_client.enums import SortEnum
from helpdesk_client.exceptions import HelpdeskClientError
from helpdesk_client.v3 import HelpdeskClient
from helpdesk_client.v3.schemas import (
    RequestFilterParams,
    RequestListSchema,
    RequestSearchFields,
)
from result import as_async_result


class HelpdeskService:
    def __init__(self, helpdesk_client: HelpdeskClient) -> None:
        self._helpdesk_client = helpdesk_client

    @as_async_result(HelpdeskClientError, httpx.HTTPError)
    async def get_requests(
        self,
        full_name: str,
        requester_id: int | None,
    ) -> RequestListSchema:

        search_fields = RequestSearchFields(requester_id=requester_id)
        if requester_id is None:
            search_fields = RequestSearchFields(requester_name=full_name)
        return await self._helpdesk_client.get_requests(
            filter_=RequestFilterParams(
                limit=5,
                offset=0,
                sort_field="created_time",
                sort_order=SortEnum.desc,
                search_fields=search_fields,
            ),
        )

Не удалось составить запрос для получения списка заявок по почте заявителя. Поэтому для запроса используются ФИО или helpdesk_id.

ФИО в редких случаях могут повторяться у разных людей (возможны коллизии), но helpdesk_id доступен не всегда, поэтому является опциональным. В примере helpdesk_id используется в запросе только тогда, когда передается в метод.

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

servicedesk_client-0.4.3.tar.gz (11.9 kB view details)

Uploaded Source

Built Distribution

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

servicedesk_client-0.4.3-py3-none-any.whl (13.6 kB view details)

Uploaded Python 3

File details

Details for the file servicedesk_client-0.4.3.tar.gz.

File metadata

  • Download URL: servicedesk_client-0.4.3.tar.gz
  • Upload date:
  • Size: 11.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: pdm/2.25.2 CPython/3.13.9 Darwin/24.6.0

File hashes

Hashes for servicedesk_client-0.4.3.tar.gz
Algorithm Hash digest
SHA256 5d3036273e4eac7bbbbb9fa79ba5846e077af3581dc27c12e8c19e827170054c
MD5 43881b03d6fb90bea6b592c9e56f75ed
BLAKE2b-256 62852f8fca5fdf02c24e2428b83ccf85a3a64097f2e91c5c9418df5c60c582ed

See more details on using hashes here.

File details

Details for the file servicedesk_client-0.4.3-py3-none-any.whl.

File metadata

File hashes

Hashes for servicedesk_client-0.4.3-py3-none-any.whl
Algorithm Hash digest
SHA256 5581d8f2e077540bce364aa8709776c2464c52991b41208168d52be17078fe18
MD5 b1166de2e29e117f9e87d3b9ce42e200
BLAKE2b-256 dd2e69aee38155be26475a8cce49aa0bed9341242746d516e15370d77f6d1f4b

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