Swift
Типизированный клиент для Pachca API на Swift. Построен на URLSession с async throws, Codable-моделями и встроенным retry. Требуется Swift 5.9+, macOS 13+ или iOS 16+.
Быстрый старт
Установка
Добавьте пакет в Package.swift:
Или через Xcode: File > Add Package Dependencies > https://github.com/pachca/openapi.
Создание клиента
Получите API-токен в интерфейсе Пачки: Настройки > Автоматизации > API (подробнее — Авторизация).
Первый запрос
Инициализация
| Параметр | Тип | По умолчанию | Описание |
|---|---|---|---|
token | String | — | Bearer-токен для авторизации |
baseURL | String | https://api.pachca.com/api/shared/v1 | Базовый URL API |
Клиент — value type (struct), использует URLSession.shared. Явного закрытия не требует.
Все методы
| Метод | Метод API |
|---|---|
client.common.requestExport() | POSTЭкспорт сообщений |
client.common.uploadFile() | POSTЗагрузка файла |
client.common.getUploadParams() | POSTПолучение подписи, ключа и других параметров |
client.common.downloadExport() | GETСкачать архив экспорта |
client.common.listProperties() | GETСписок дополнительных полей |
client.profile.getTokenInfo() | GETИнформация о токене |
client.profile.getProfile() | GETСвой профиль |
client.profile.getStatus() | GETСвой статус |
client.profile.updateProfileAvatar() | PUTЗагрузка своего аватара |
client.profile.updateStatus() | PUTНовый свой статус |
client.profile.deleteProfileAvatar() | DELETEУдаление своего аватара |
client.profile.deleteStatus() | DELETEУдаление своего статуса |
client.users.createUser() | POSTНовый сотрудник |
client.users.listUsers() | GETСписок сотрудников |
client.users.getUser() | GETИнформация о сотруднике |
client.users.getUserStatus() | GETСтатус сотрудника |
client.users.updateUser() | PUTРедактирование сотрудника |
client.users.updateUserAvatar() | PUTЗагрузка аватара сотрудника |
client.users.updateUserStatus() | PUTНовый статус сотрудника |
client.users.deleteUser() | DELETEУдаление сотрудника |
client.users.deleteUserAvatar() | DELETEУдаление аватара сотрудника |
client.users.deleteUserStatus() | DELETEУдаление статуса сотрудника |
client.groupTags.createTag() | POSTНовый тег |
client.groupTags.listTags() | GETСписок тегов сотрудников |
client.groupTags.getTag() | GETИнформация о теге |
client.groupTags.getTagUsers() | GETСписок сотрудников тега |
client.groupTags.updateTag() | PUTРедактирование тега |
client.groupTags.deleteTag() | DELETEУдаление тега |
client.chats.createChat() | POSTНовый чат |
client.chats.listChats() | GETСписок чатов |
client.chats.getChat() | GETИнформация о чате |
client.chats.updateChat() | PUTРедактирование чата |
client.chats.archiveChat() | PUTАрхивация чата |
client.chats.unarchiveChat() | PUTРазархивация чата |
client.members.addTags() | POSTДобавление тегов |
client.members.addMembers() | POSTДобавление пользователей |
client.members.listMembers() | GETСписок участников чата |
client.members.updateMemberRole() | PUTРедактирование роли |
client.members.removeTag() | DELETEИсключение тега |
client.members.leaveChat() | DELETEВыход из беседы или канала |
client.members.removeMember() | DELETEИсключение пользователя |
client.threads.createThread() | POSTНовый тред |
client.threads.listThreads() | GETСписок тредов |
client.threads.getThread() | GETИнформация о треде |
client.messages.createMessage() | POSTНовое сообщение |
client.messages.pinMessage() | POSTЗакрепление сообщения |
client.messages.listChatMessages() | GETСписок сообщений чата |
client.messages.getMessage() | GETИнформация о сообщении |
client.messages.updateMessage() | PUTРедактирование сообщения |
client.messages.deleteMessage() | DELETEУдаление сообщения |
client.messages.unpinMessage() | DELETEОткрепление сообщения |
client.readMembers.listReadMembers() | GETСписок прочитавших сообщение |
client.reactions.addReaction() | POSTДобавление реакции |
client.reactions.listReactions() | GETСписок реакций |
client.reactions.removeReaction() | DELETEУдаление реакции |
client.linkPreviews.createLinkPreviews() | POSTUnfurl (разворачивание ссылок) |
client.search.searchChats() | GETПоиск чатов |
client.search.searchMessages() | GETПоиск сообщений |
client.search.searchUsers() | GETПоиск сотрудников |
client.tasks.createTask() | POSTНовое напоминание |
client.tasks.listTasks() | GETСписок напоминаний |
client.tasks.getTask() | GETИнформация о напоминании |
client.tasks.updateTask() | PUTРедактирование напоминания |
client.tasks.deleteTask() | DELETEУдаление напоминания |
client.views.openView() | POSTОткрытие представления |
client.bots.createBot() | POSTНовый бот |
client.bots.getBot() | GETИнформация о боте |
client.bots.getWebhookEvents() | GETИстория событий |
client.bots.selfUpdateBotWebhook() | PUTСаморегистрация вебхука бота |
client.bots.updateBot() | PUTРедактирование бота |
client.bots.deleteWebhookEvent() | DELETEУдаление события |
client.security.getAuditEvents() | GETЖурнал аудита событий |
Запросы
Все методы — async throws.
GET с параметрами:
POST с телом запроса:
Простой вызов по ID:
Пагинация
SDK работает с двумя группами методов, возвращающих списки, у которых разная структура meta — это важно учитывать при ручной пагинации:
- Списочные методы (
client.users.listUsers(),client.chats.listChats(),client.messages.listChatMessages()и т.д.) —meta.paginateс полямиnextPage,prevPage,hasNext,hasPrev. Признак конца —hasNext == false. КурсорprevPageнужен для polling новых записей «сверху» списка. - Методы поиска (
client.search.searchUsers(),client.search.searchChats(),client.search.searchMessages()) —metaс полямиtotalиpaginate.nextPage(безprevPage/hasNext/hasPrev). Признак конца — пустойdataили совпадение числа полученных записей сtotal.
Курсоры — непрозрачные токены, никогда не бывают nil/пустыми. Подробное описание полей и примеры — на странице Пагинация.
Ручная пагинация
Автопагинация
Для каждого метода с пагинацией есть *All() вариант:
Доступные методы автопагинации:
| Метод | Возвращает |
|---|---|
security.getAuditEventsAll() | [AuditEvent] |
bots.getWebhookEventsAll() | [WebhookEvent] |
chats.listChatsAll() | [Chat] |
groupTags.listTagsAll() | [GroupTag] |
groupTags.getTagUsersAll() | [User] |
members.listMembersAll() | [User] |
messages.listChatMessagesAll() | [Message] |
reactions.listReactionsAll() | [Reaction] |
search.searchChatsAll() | [Chat] |
search.searchMessagesAll() | [Message] |
search.searchUsersAll() | [User] |
tasks.listTasksAll() | [Task] |
users.listUsersAll() | [User] |
Обработка ошибок
SDK выбрасывает два типа ошибок (реализуют протокол Error):
ApiError
Возникает при ошибках 400, 403, 404, 409, 410, 422:
Поля ApiErrorItem:
| Поле | Тип | Описание |
|---|---|---|
key | String | Поле, вызвавшее ошибку |
value | String? | Переданное значение |
message | String | Текст ошибки |
code | ValidationErrorCode | Код валидации |
payload | String? | Дополнительные данные |
OAuthError
Возникает при ошибке авторизации (401):
Повторные запросы
SDK автоматически повторяет запрос при получении 429 Too Many Requests и ошибок сервера 5xx (500, 502, 503, 504):
- До 3 повторов на каждый запрос
- 429: если сервер вернул заголовок
Retry-After— ждёт указанное время, иначе — экспоненциальный backoff: 1 сек, 2 сек, 4 сек - 5xx: экспоненциальный backoff с jitter: ~10 сек, ~20 сек, ~40 сек
- Ожидание через
Task.sleep(nanoseconds:)— не блокирует поток - Ошибки клиента (4xx, кроме 429) возвращаются сразу без повторов
Типы
Все типы — Codable struct'ы:
Доступные перечисления: AuditEventKey, ChatAvailability, ChatMemberRole, ChatMemberRoleFilter, ChatSubtype, CustomPropertyDataType, FileType, InviteStatus, MemberEventType, MessageEntityType, OAuthScope, ReactionEventType, SearchEntityType, SearchSortOrder, SortOrder, TaskKind, TaskStatus, UserEventType, UserRole, ValidationErrorCode, WebhookEventType.
Платформы
| Платформа | Минимальная версия |
|---|---|
| macOS | 13.0+ |
| iOS | 16.0+ |
| Swift | 5.9+ |