Authentication
makeRequest
function above makes HTTP requests to a server by usingrequest-promise
module to make the actual HTTP requests, and the crypto
module to create an HMAC (hash-based message authentication code) to sign the request payload.
The HMAC is used to authenticate the request by proving that it was sent by someone in possession of the API secret. The server can verify the authenticity of the request by recomputing the HMAC using the API secret it has on file and comparing it to the one provided in the request headers. If the two HMACs match, the server can trust that the request was sent by someone in possession of the API secret, and therefore authenticated.
The makeRequest
function takes several arguments:
apiKey
: This is the API key that identifies the client making the request.apiSecret
: This is the secret used to create the HMAC. It is base64-encoded in the code, but it needs to be decoded before it can be used to create the HMAC.passphrase
: This is another form of authentication that the server may use to verify the authenticity of the request.host
: The hostname of the server to which the request should be sent.route
: The route on the server to which the request should be sent (e.g., '/orders').method
: The HTTP method of the request (e.g., 'POST', 'GET').body
: The request payload.
The function first computes the HMAC by concatenating the current timestamp, the HTTP method, the route, and the request payload, and then using the crypto.createHmac
method to create an HMAC of that concatenated string using the decoded API secret as the key. It then sets the appropriate headers for the request, including the API key, the signed payload (i.e., the HMAC), the timestamp, and the passphrase. Finally, it makes the request using the request-promise
module and returns the server's response.
Example Headers
NDAX Uses HMAC SHA-256 verification to ensure the authenticity of every API request.
To Authenticate with us, you will need to set the following headers:
X-NDAX-API-KEY
Your public key
X-NDAX-SIGNED
Signature for your request
X-NDAX-TIMESTAMP
Unix timestamp
X-NDAX-PASSPHRASE
Your passphrase
"X-NDAX-TIMESTAMP" must be the number of seconds since the Unix Epoch.
To sign your request:
Concatenate timestamp + method + route + request body
Example:
1549468233POST/orders{"client_order_id":"abcdefg","instrument_code":"COSP:BTC/
e₹","market_code":"DNSE","order_type":"limit","price":"3780","quantity":"10","side":"buy"}
Generate an HMAC digest using your private key (using HMAC SHA-256).
Example: Private Key = 6d58e38275388977aa8ef2091d5d4814be9db7a9b345d8c328ef5a31bfd666a0
Encode the HMAC digest in Base64.
NmQ1OGUzODI3NTM4ODk3N2FhOGVmMjA5MWQ1ZDQ4MTRiZTlkYjdhOWIzNDVkOGMzMjhlZjVhMzFiZmQ2NjZhMA==
Last updated