Verify (OTP)
API для створення та перевірки одноразових кодів верифікації (OTP) через SMS, Email та інші канали.
Запити POST відправляються із заголовком Content-Type: application/json. Перевірка коду (verify) підтримує також GET.
Створення коду — синхронний
Створює код верифікації та надсилає його через SMS або Email. Шлюз обробляє запит одразу та повертає verify_id.
URI: /api/verify.php
Метод: POST
Параметри запиту
Приклад запиту
{
"auth": "API_KEY",
"command": "verify/create",
"phone": "441501234567",
"type": "sms",
"sender_name": "MyBrand",
"lang": "en",
"code_length": 6,
"code_type": "numeric",
"service_id": 1,
"custom_id": "abcdef1234567",
"hook": "https://example.com/webhook"
}
Приклад відповіді:
{
"success": true,
"verify_id": "14fb5f3d-20be-41ef-b31a-b9f5e499bc7a"
}
Помилки HTTP: 400 (невірний формат/JSON), 401 (невірний auth), 413 (занадто велике тіло запиту).
Створення коду — асинхронний
Постановка створення коду в чергу для фонової обробки. Тіло запиту таке саме, як при синхронному створенні, але поле command необов'язкове (воркер автоматично встановлює verify/create).
URI: /v1/verify/create
Метод: POST
Content-Type: application/json
Приклад відповіді:
{
"request_id": "cf-ray-1234567890-ABC",
"success": true
}
verify_id у цій відповіді не повертається. Для оновлення статусу після обробки використовуйте URL з поля hook у запиті.
Коди помилок HTTP:
| Code | Опис |
|---|---|
400 | Невірний JSON |
401 | Відсутній або невірний auth |
405 | Метод, відмінний від POST |
413 | Занадто велике тіло запиту |
415 | Відсутній або невірний Content-Type (має бути application/json) |
503 | Черга недоступна |
Перевірка коду
URI: /api/verify.php
Перевіряє код, введений користувачем, і повертає статус верифікації (тільки синхронний API).
Параметри запиту
Приклад запиту (GET)
/api/verify.php?auth=API_KEY&command=verify&phone=380501234567&code=123456&verify_id=14fb5f3d-20be-41ef-b31a-b9f5e499bc7a
Приклад запиту (POST, JSON)
{
"auth": "API_KEY",
"command": "verify",
"phone": "380501234567",
"code": "123456",
"verify_id": "14fb5f3d-20be-41ef-b31a-b9f5e499bc7a"
}
Приклад успішної відповіді:
{
"success": true,
"verify_id": "14fb5f3d-20be-41ef-b31a-b9f5e499bc7a",
"phone": "441501234567",
"type": "sms",
"status": "approved",
"service_id": 1
}
Можливі значення status:
| status | Опис |
|---|---|
approved | Код вірний, верифікація успішна |
pending | Код невірний, спроби ще залишились |
expired | Код прострочений |
blocked | Перевищено ліміт спроб |
Коди помилок HTTP:
400— невірний формат запиту або JSON401— відсутній або невірний auth413— занадто велике тіло запиту
Обмеження
- Час життя коду: за замовчуванням 300 секунд (5 хвилин), діапазон 60–3600 секунд.
- Максимальна кількість спроб: за замовчуванням 5.