Autentifikacija
Kiekviena užklausa į partnerių API (Partner API) turi būti autentifikuota naudojant HMAC-SHA256 užklausų pasirašymą. Tai užtikrina, kad užklausos yra autentiškos ir nebuvo pakeistos perdavimo metu.
Reikalingos antraštės
| Antraštė | Aprašymas |
|---|---|
X-API-Key | Jūsų organizacijos API raktas |
X-Timestamp | Dabartinė Unix laiko žyma sekundėmis (pvz., 1711000000) |
X-Nonce | Unikalus eilutės identifikatorius kiekvienai užklausai (rekomenduojama UUID v4) |
X-Signature | HMAC-SHA256 šešioliktainis parašas užklausai |
Parašo sudarymas
Parašas apskaičiuojamas sudarant tašku atskirtą pranešimo eilutę ir pasirašant ją jūsų API rakto slaptuoju raktu:
message = "{timestamp}.{nonce}.{method}.{path}.{body}"
signature = HMAC-SHA256(apiKeySecret, message).hexDigest()
Pranešimo komponentai, sujungti taškais (.):
- timestamp — Unix laiko žyma sekundėmis (ta pati reikšmė kaip
X-Timestampantraštėje) - nonce — Ta pati reikšmė, siųsta
X-Nonceantraštėje - method — HTTP metodas didžiosiomis raidėmis (pvz.,
GET,POST) - path — Pilnas užklausos kelias (pvz.,
/v2/partners/products/tickets) - body — Neapdorota JSON užklausos turinio eilutė. GET užklausoms be turinio naudokite tuščią eilutę
""
Gautas HMAC santraukos rezultatas turi būti užkoduotas mažosiomis šešioliktainėmis raidėmis.
Pavyzdžiai
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}"Svarbios pastabos
X-Timestampturi būti ne senesnė nei 5 minutės (300 sekundžių) nuo serverio laiko. Užklausos su pasenusiomis laiko žymomis bus atmestos su401klaida.- Kiekviena
X-Noncereikšmė turi būti unikali ir gali būti panaudota tik vieną kartą. Pakartotinis nonce naudojimas sukels401klaidą. - Visada naudokite neapdorotą, neformatuotą JSON turinio eilutę parašo skaičiavimui. Neformatuokite ir neperserializuokite turinio prieš pasirašymą.
- Parašas turi būti šešioliktainiu formatu mažosiomis raidėmis. Nenaudokite base64.