Os feeds privados da nossa API WebSocket (como o feed openOrders e o feed addOrder) requerem um token de autenticação do endpoint da API REST GetWebSocketsToken.
Segue-se um exemplo de código Python 3 para chamar o endpoint da API REST GetWebSocketsToken, analisar a resposta JSON e gerar o novo token de autenticação WebSocket:
#!/usr/bin/env python3
# Importar bibliotecas Python necessárias
import time
import base64
import hashlib
import hmac
import urllib.request
import json
# Copiar/colar chave pública da API e chave privada da API conforme exibido na gestão da conta
api_key = 'COPY/PASTE API PUBLIC KEY HERE'
api_secret = 'COPY/PASTE API PRIVATE KEY HERE'
# Variáveis (método da API, nonce e dados POST)
api_path = '/0/private/GetWebSocketsToken'
api_nonce = str(int(time.time()*1000))
api_post = 'nonce=' + api_nonce
# Algoritmos de hash criptográficos
api_sha256 = hashlib.sha256(api_nonce.encode('utf-8') + api_post.encode('utf-8'))
api_hmac = hmac.new(base64.b64decode(api_secret), api_path.encode('utf-8') + api_sha256.digest(), hashlib.sha512)
# Codificar assinatura para o formato base64 usado no valor API-Sign
api_signature = base64.b64encode(api_hmac.digest())
# Pedido HTTP (POST)
api_request = urllib.request.Request('https://api.kraken.com/0/private/GetWebSocketsToken', api_post.encode('utf-8'))
api_request.add_header('API-Key', api_key)
api_request.add_header('API-Sign', api_signature)
api_response = urllib.request.urlopen(api_request).read().decode()
# Gerar resposta da API
print(json.loads(api_response)['result']['token'])
As variáveis de chave pública/privada da API (api_key e api_secret) devem ser substituídas por uma nova chave de API da sua conta Kraken, após o que o código pode ser usado para obter um token de autenticação WebSocket para a mesma conta. Tenha em atenção que a chave de API deve ter a permissão Other -> Access WebSockets API ativada.