Step 2: Postman
1. Fork Banxa Sandbox Collection
Use Banxa API collection in Postman by accessing the read-only Banxa Workspace and forking the Collection to your personal or company Workspace.
Link to Banxa Workspace: https://www.postman.com/crimson-comet-2961/workspace/banxa-api-sandbox/collection/19155430-c6f45571-964c-4ac9-8b01-8b08b1bc3806?action=share&creator=19155430
data:image/s3,"s3://crabby-images/e2cf7/e2cf74961679730410e38a8a506b767e06576311" alt="Postman Fork Collection.png 747"
2. Configure credentials
Configure your authorization credentials and domain. Click Save.
Make sure that "https://" is included in front of the domain that you have been provided. e.g. https://binance.banxa.com
data:image/s3,"s3://crabby-images/90a0d/90a0d3279983b2a86f68b2f68ef87e363f9d53a2" alt="Configure credentials and domain.png 1920"
3. Start invoking the APIs using your credentials
Ensure that the Banxa API Sandbox environment is selected so that environment variables are applied to each request.
data:image/s3,"s3://crabby-images/32769/32769fc4f2bf23f88698332df9af64927048b134" alt="Environment Selection.png 1438"
Troubleshooting
If you are getting an unauthorized error message when running an API call, double the following things:
- The domain configured in your Environments variables include a "https://" in front of the URL e.g. https://binance.banxa.com
- Ensure that the Header variables of your API call includes Authorization and a Value is generated
data:image/s3,"s3://crabby-images/74683/746839a5b8a0e8a2c41339564214711c79d7b200" alt="Postman Authorization.png 1218"
- The Collection level Authorization Type is Bearer Token, and the Token is HMAC. The Folders and API calls should inherit Authorization settings from the parent.
data:image/s3,"s3://crabby-images/a4da9/a4da9592d9f30c8505cb2a781c8c38b1720bb6fc" alt="Postman Authorization.png 1218"
- Double check that the Pre-request Script at the Collection level is as per below
data:image/s3,"s3://crabby-images/3eb7d/3eb7d3df8c522a02127dcc4c3bafe1a73a3ac7f5" alt="Postman Pre-request Script.png 896"
var CLIENT_KEY = pm.environment.get("key");
var SECRET_KEY = pm.environment.get("secret");
var AUTH_TYPE = 'HMAC-SHA512';
var AUTH_VERSION = '5.1.2';
function epochTime() {
var d = new Date();
var t = d.getTime();
var o = t + "";
return o.substring(0, 10);
}
var timestamp = epochTime();
function getAuthHeader(httpMethod, requestUrl, requestBody) {
var requestPath = pm.request.url.getPath();
var requestData;
if (httpMethod=="GET"){
requestPath = pm.request.url.getPathWithQuery();
requestPath = replaceVariablesWithValues(requestPath);
requestData = [httpMethod, requestPath, timestamp].join("\n");
} else {
requestPath = replaceVariablesWithValues(requestPath);
requestBody = replaceVariablesWithValues(requestBody);
body = JSON.stringify(JSON.parse(requestBody));
requestData = [httpMethod, requestPath, timestamp, body].join("\n");
}
console.log(requestData);
return CryptoJS.enc.Hex.stringify(CryptoJS.HmacSHA256(requestData, SECRET_KEY));
}
function replaceVariablesWithValues(str) {
var env = pm.environment.toObject();
for (var p in env) {
if( env.hasOwnProperty(p) ) {
str = str.replace('{{' + p + '}}', env[p])
}
}
return str;
}
console.log(request['headers']);
signature = getAuthHeader(request['method'], request['url'], request['data']);
postman.setEnvironmentVariable('hmac', CLIENT_KEY + ":" + signature + ":" + timestamp );
Updated 6 months ago