Автентифікація (Authentication)
Кожен запит до Partner API повинен бути автентифікований за допомогою підпису запитів HMAC-SHA256. Це гарантує, що запити є справжніми та не були змінені під час передачі.
Обов'язкові заголовки
| Заголовок | Опис |
|---|---|
X-API-Key | Ваш API-ключ організації |
X-Timestamp | Поточна мітка часу Unix у секундах (наприклад, 1711000000) |
X-Nonce | Унікальний рядок для кожного запиту (рекомендується UUID v4) |
X-Signature | Шістнадцятковий підпис HMAC-SHA256 запиту |
Побудова підпису (Signature Construction)
Підпис обчислюється шляхом побудови рядка повідомлення, розділеного крапками, та його підписання вашим секретним ключем API:
message = "{timestamp}.{nonce}.{method}.{path}.{body}"
signature = HMAC-SHA256(apiKeySecret, message).hexDigest()
Компоненти повідомлення, з'єднані крапками (.):
- timestamp — Мітка часу Unix у секундах (те саме значення, що й у заголовку
X-Timestamp) - nonce — Те саме значення, що надіслане у заголовку
X-Nonce - method — HTTP-метод у верхньому регістрі (наприклад,
GET,POST) - path — Повний шлях запиту (наприклад,
/v2/partners/products/tickets) - body — Необроблений рядок JSON тіла запиту. Для GET-запитів без тіла використовуйте порожній рядок
""
Отриманий HMAC-дайджест повинен бути закодований як шістнадцятковий рядок у нижньому регістрі.
Приклади
API_KEY="your-api-key"
API_SECRET="your-api-secret"
TIMESTAMP=$(date +%s)
NONCE=$(uuidgen | tr '[:upper:]' '[:lower:]')
METHOD="GET"
REQ_PATH="/v2/partners/products/tickets"
BODY=""
MESSAGE="${TIMESTAMP}.${NONCE}.${METHOD}.${REQ_PATH}.${BODY}"
SIGNATURE=$(echo -n "${MESSAGE}" | \
openssl dgst -sha256 -hmac "${API_SECRET}" | \
awk '{print $2}')
curl -X GET "https://api.vignetim.com${REQ_PATH}" \
-H "Content-Type: application/json" \
-H "X-API-Key: ${API_KEY}" \
-H "X-Timestamp: ${TIMESTAMP}" \
-H "X-Nonce: ${NONCE}" \
-H "X-Signature: ${SIGNATURE}"Важливі примітки
X-Timestampповинен бути в межах 5 хвилин (300 секунд) від часу сервера. Запити із застарілими мітками часу будуть відхилені з помилкою401.- Кожне значення
X-Nonceповинно бути унікальним і може бути використане лише один раз. Повторне використання nonce призведе до помилки401. - Завжди використовуйте необроблений, неформатований рядок JSON тіла для обчислення підпису. Не форматуйте та не перетворюйте тіло перед підписанням.
- Підпис повинен бути закодований у шістнадцятковому форматі в нижньому регістрі. Не використовуйте base64.