Skip to main content

Documentation Index

Fetch the complete documentation index at: https://whitebit-mintlify-fix-broken-links-1777248521.mintlify.app/llms.txt

Use this file to discover all available pages before exploring further.

Overview

The Authentication guide explains how to authenticate with WhiteBIT’s private HTTP API endpoints, which require authentication for security purposes.

Getting Started

Setting Up API Keys

2
Select the appropriate configuration tab for API keys
Different API keys provide access to different API endpoints
3
Generate a new API key
4
Recommended Security Measures:
  • Enable IP restrictions (specify up to 50 trusted IPs)
  • Enable Endpoint access restrictions (select only necessary endpoints)
Keys auto-deactivate after 14 days of inactivity. 2FA must be enabled before key creation. Use separate keys per application with minimal permissions.

Authentication Requirements

All authenticated requests must:
  1. Use the POST HTTP method
  2. Include specific body data
  3. Contain required headers

Body Data Format

The request body must be a JSON object containing:
FieldDescriptionExample
requestRequest path without domain name'/api/v4/trade-account/balance'
nonceAn incrementing number larger than previous requests'1594297865000'
nonceWindowOptional boolean to enable time-based nonce validationtrue
Request-specific parametersAdditional parameters required by the endpoint"ticker": "BTC"
Example Request Body:
{
    "request": "/api/v4/trade-account/balance",
    "nonce": 1594297865000,
    "nonceWindow": true,
    "ticker": "BTC"
}

About Nonce Values

  • Use the Unix timestamp in milliseconds for nonce values
  • Ensure each nonce is larger than previous requests
  • When nonceWindow is enabled:
    • Provide Unix timestamp in milliseconds as the nonce
    • Timestamp must be within ±5 seconds of server time
    • Each nonce must be unique to prevent double processing
    • Useful for high-frequency trading systems with concurrent requests

Required Headers

Every authenticated request requires these headers: Create the signature using: hex(HMAC_SHA512(payload, key=api_secret))

Implementation Examples

WhiteBIT provides the API Quick Start Helper library with examples in multiple languages:
  • Python
  • PHP
  • NodeJS
  • Go
  • JavaScript
  • Kotlin
  • DotNet
  • Ruby
  • C++
  • Rust

Common Errors

For rate limits and REST error format, see Rate limits and error codes.

Testing in the API playground