Я использую ключ JSON API, созданный на платформе разработчика Coinbase (CDP), и подтвердил, что:
- Ключ имеет правильные разрешения
- Ребенок в Заголовок JWT соответствует идентификатору ключа API.
- Утверждение sub соответствует имени ключа (organizations/.../apiKeys/...)
- Токен подписан с помощью ES256.
- Для aud установлено значение https://api.coinbase.com
- Утверждения nbf и exp находятся в пределах правильных значений. окно
- HTTP-запрос включает JWT в заголовок Authorization: Bearer
Код: Выделить всё
401 Unauthorized
{"error":"invalid_token"}
Код: Выделить всё
import jwt
import json
import time
from pathlib import Path
from cryptography.hazmat.primitives import serialization
# Load JSON API key (Coinbase CDP key)
with open("cdp_api_key.json", "r") as f:
key_data = json.load(f)
# Load EC private key
with open("private_key.pem", "r") as f:
private_key = serialization.load_pem_private_key(
f.read().encode(),
password=None,
)
now = int(time.time())
# JWT payload
payload = {
"sub": key_data["name"],
"iss": key_data["name"],
"nbf": now,
"exp": now + 120,
"aud": "https://api.coinbase.com",
}
# Generate ES256-signed JWT
token = jwt.encode(
payload,
private_key,
algorithm="ES256",
headers={"kid": key_data["id"]},
)
print(token)
Вопрос:
Существует ли дополнительное требование для потока JWT ES256 Coinbase (ключи CDP JSON), которое не задокументировано, или что-то тонкое, что мне не хватает?
Подробнее здесь: https://stackoverflow.com/questions/798 ... n-with-a-v
Мобильная версия