NAV
bash javascript

Crypto Exchange API

Nrnb API ver.1 allows you to get programming access to the services of Nrnb exchange platform. Some of the requests have such parameters as 'coin_from' or ‘coin_to’, which is coin ticker in uppercase. Examples: ‘BTC’, ‘ETH’, ‘XMR’, ‘IOTA’, ‘CLOAK’. This list is constantly growing as we’re adding new coins. All requests needs to be executed using HTTPS, this is a security measure.

Extra ID is an additional field for wallet addresses of currencies that may use additional ID for transaction processing (XRP, STEEM/SBD, XLM, DCT, XEM, XMR). This parameter should be filled only if the coin has this additional identifier. In any other case this parameter is not filled or not sent at all. All requests needs to be executed using HTTPS, this is a security measure. For every request to https://api.nrnb.io/api/v1/ following parameters should be used in headers:

Content-Type: application/json

Accept: application/json

API URL

Environment REST
PROD https://api.nrnb.io/api/v1/

Authorization

Some requests requires API authorization key. There are also requests where this authorization is not mandatory, but it should be included in order to access such features like assigning transactions to the user's personal account and getting information from the user's account. To set up API authorisation, following parameter should be added in headers:

public-key: {partners_token}

public-key can be obtained in the user's personal account or by sending a request to nrnb support [email protected].

The next parameter should be Included in the API query:

affiliate_id

Your affiliate id can be also obtained in the user's personal affiliate account.

Get a List of Coins

Example request:

curl -X GET "https://api.nrnb.io/api/v1/coins" \
-H "Accept: application/json"
var settings = {
    "async": true,
    "crossDomain": true,
    "url": "https://api.nrnb.io/api/v1/coins",
    "method": "GET",
    "headers": {
        "accept": "application/json"
    }
}


$.ajax(settings).done(function (response) {
    console.log(response);
});

$requestHeaders = ['Content-type: application/json'];
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, 'https://api.nrnb.io/api/v1/coins');
curl_setopt($ch, CURLOPT_HTTPHEADER, $requestHeaders);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_exec($ch);
curl_close($ch);

Example response:

[{
      "code": "BTC",
      "name": "Bitcoin",
      "disabled": 0,
      "icon": "https://nrnb.io/storage/coins/BTC.png",
      "has_extra": 0,
      "extra_name": null,
      "explorer": null,
   },
   {
      "code": "ETH",
      "name": "Ethereum",
      "disabled": 0,
      "icon": "https://nrnb.io/storage/coins/ETH.png",
      "has_extra": 0,
      "extra_name": null,
      "explorer": null,
   }]

HTTP Request

GET /api/v1/coins

This returns the list of coins, available for exchange with selected coin at given time, or gets entire list of coins. Response also contains such parameters as extra id name, if it exists, For example, destination tag for Ripple, message for XEM or payment id for Monero. In addition, it provides icon links.

Response:

Name Type Description
code string Coin short name (code)
name string Currency full name
disabled int The availability of the coins. 0 - available, 1 - unavailable
icon string The link to the coin logo
has_extra int 1 if coin may have an extra ID in addition to the address, 0 if it doesn’t
extra_name string|null Name of the extra ID
explorer string|null Currency blockchain explorer URL. It is used for checking transaction status in block explorer

Coin Info

Example request:


curl -X POST "https://api.nrnb.io/api/v1/info" \
-H "Accept: application/json" \
-H "Content-Type: application/json" \
-d '{ "from": "BTC", "to": "ETH", "amount": 1, "float": true, "network_from": "BTC", "network_to": "XMR" }'
var settings = {
    "async": true,
    "crossDomain": true,
    "url": "https://api.nrnb.io/api/v1/info",
    "method": "POST",
    "data": {
        "from": "BTC",
        "to": "ETH",
        "amount": 1,
        "float": true,
        "network_from": "BTC",
        "network_to": "XMR"
},
    "headers": {
        "accept": "application/json"
    }
}

$.ajax(settings).done(function (response) {
    console.log(response);
});

        $requestHeaders = [
            'Content-type: application/json'
        ];
        $ch = curl_init('https://api.nrnb.io/api/v1/info');
        curl_setopt($ch, CURLOPT_POST, 1);
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
        curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode([
                "from" : "BTC",
                "to":"ETH",
                "amount": 1,
                "float": true,
                "network_from": "BTC",
                "network_to": "XMR"])
                );
        curl_setopt($ch, CURLOPT_HTTPHEADER, $requestHeaders);
        curl_setopt($ch, CURLOPT_TIMEOUT, 10);

The above command returns JSON structured like this:

{
"min_amount": 0.01,
"max_amount": 0,
"amount": 28.94050772,
"fee": 0,
"float": true
"rate_uuid": "574e3a43-6e15-4675-892d-16800d0253e7"
"rate_expired_at": "1716373571661"
"rate": 28.94050772
"networks_from": [{"network":"ZEC","has_tag":0}, {"network":"BNB","has_tag":1}, {"network":"BSC","has_tag":0}]
"networks_to": [{"network":"BTC","has_tag":0}]
"coin_from": {
        "code": "BTC",
        "name": "Bitcoin",
        "icon": null,
        "min_amount": null,
        "max_amount": null,
        "default_amount": "0.008000000000",
        "price_change_24h": 2.99,
        "is_active": 1,
        "disabled": 0}
"coin_to": {
        "code": "XMR",
        "name": "Monero",
        "icon": null,
        "min_amount": null,
        "max_amount": null,
        "default_amount": "3.720000000000",
        "price_change_24h": 0.05,
        "is_active": 1,
        "disabled": 0}
"network_from": {
        "network": "BTC",
        "code": "BTC",
        "name": "Bitcoin",
        "is_active": 1,
        "is_default": 1,
        "has_extra": 0,
        "extra_name": null,
        "explorer": "https:\/\/blockchair.com\/bitcoin\/transaction\/",
        "contract_address": null}
"network_to": {
        "network": "XMR",
        "code": "XMR",
        "name": "Monero",
        "is_active": 1,
        "is_default": 1,
        "has_extra": 0,
        "extra_name": null,
        "explorer": "https:\/\/localmonero.co\/blocks\/search\/",
        "contract_address": null}
}

HTTP Request

POST api/v1/info

Gets current rate, calculates final amount that user will get, and also it sets minimum and maximum amounts for deposit.

Parameters

<>
Parameter Type Status Description
from string required Coin code from
to string required Coin code to
amount numeric required Amount of currency “from”
float boolean optional true - the rate is floating,
false - the rate is fixed
network_from string optional coin from network
network_to string optional coin to network

Response

name Type Description
min_amount float Minimum possible amount to be sent
max_amount float Maximum possible amount to be sent; usually we do not have upper limits
amount float The final amount that user will receive after the exchange
fee float Service fee (in destination currency)
rate float Current exchange rate offered by nrnb
networks_from array Array of networks objects for coin from
network string Name of network
has_tag int 1 if coin may have an extra ID in addition to the address, 0 if it doesn’t
networks_to array Array of networks objects for coin to
float boolean true - the rate is floating,
false - the rate is fixed
coin_from object coin from data
coin_to object coin to data
network_from object network from data
network_to object network to data
rate_expired_at string rate’s expiration date
withdrawal_fee string withdrawal fee
rate_uuid string rate uuid

Coin Info Revert

Example request:


curl -X POST "https://api.nrnb.io/api/v1/info-revert" \
-H "Accept: application/json" \
-H "Content-Type: application/json" \
-d '{ "from": "BTC", "to": "XMR", "amount": 75, "float": true, "network_from": "BTC", "network_to": "XMR" }'
var settings = {
    "async": true,
    "crossDomain": true,
    "url": "https://api.nrnb.io/api/v1/info-revert",
    "method": "POST",
    "data": {
        "from": "BTC",
        "to": "XMR",
        "amount": 75,
        "float": true,
        "network_from": "BTC",
        "network_to": "XMR"
},
    "headers": {
        "accept": "application/json"
    }
}

$.ajax(settings).done(function (response) {
    console.log(response);
});

        $requestHeaders = [
            'Content-type: application/json'
        ];
        $ch = curl_init('https://api.nrnb.io/api/v1/info-revert');
        curl_setopt($ch, CURLOPT_POST, 1);
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
        curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode([
                "from" : "BTC",
                "to":"XMR",
                "amount": 75,
                "float": true,
                "network_from": "BTC",
                "network_to": "XMR"])
                );
        curl_setopt($ch, CURLOPT_HTTPHEADER, $requestHeaders);
        curl_setopt($ch, CURLOPT_TIMEOUT, 10);

The above command returns JSON structured like this:

{
"min_amount": 0.76271832,
"max_amount": 0,
"amount": 1.0569014,
"fee": 0,
"rate": 74.57565357
"float": true
"rate_uuid": "574e3a43-6e15-4675-892d-16800d0253e7"
"rate_expired_at": "1716373571661"
"expired_at": "1718698866018"
"rate": 28.94050772
"networks_from": [{"network":"ZEC","has_tag":0}, {"network":"BNB","has_tag":1}, {"network":"BSC","has_tag":0}]
"networks_to": [{"network":"BTC","has_tag":0}]
"coin_from": {
        "code": "BTC",
        "name": "Bitcoin",
        "icon": null,
        "min_amount": null,
        "max_amount": null,
        "default_amount": "0.008000000000",
        "price_change_24h": 2.99,
        "is_active": 1,
        "disabled": 0}
"coin_to": {
        "code": "XMR",
        "name": "Monero",
        "icon": null,
        "min_amount": null,
        "max_amount": null,
        "default_amount": "3.720000000000",
        "price_change_24h": 0.05,
        "is_active": 1,
        "disabled": 0}
"network_from": {
        "network": "BTC",
        "code": "BTC",
        "name": "Bitcoin",
        "is_active": 1,
        "is_default": 1,
        "has_extra": 0,
        "extra_name": null,
        "explorer": "https:\/\/blockchair.com\/bitcoin\/transaction\/",
        "contract_address": null}
"network_to": {
        "network": "XMR",
        "code": "XMR",
        "name": "Monero",
        "is_active": 1,
        "is_default": 1,
        "has_extra": 0,
        "extra_name": null,
        "explorer": "https:\/\/localmonero.co\/blocks\/search\/",
        "contract_address": null}
}

HTTP Request

POST api/v1/info-revert

This method is used when you want to get the exact amount of specific coins. For example, when a customer needs to pay the bill with 5 XMR (coin ‘to’), and he needs to know how much BTC (coin ‘from’) he should send. The request gets current rate, calculates the amount of coins that user should send to receive the desired amount of ‘target’ currency, and also it sets the minimum and the maximum amounts for the deposit.

Parameters

Parameter Type Status Description
from string required Coin code from
to string required Coin code to
amount numeric required Amount of currency “to”
float boolean optional true - the rate is floating,
false - the rate is fixed
network_from string optional coin from network
network_to string optional coin to network

Response

name Type Description
min_amount float Minimum possible amount to be sent
max_amount float Maximum possible amount to be sent; usually we do not have upper limits
amount float The final amount that the user need send for exchange
fee float Service fee (in destination currency)
rate float Current exchange rate offered by nrnb
float boolean true - the rate is floating,
false - the rate is fixed
coin_from object coin from data
coin_to object coin to data
network_from object network from data
network_to object network to data
rate_expired_at string rate’s expiration date
withdrawal_fee string withdrawal fee
rate_uuid string rate uuid
networks_from array Array of networks objects for coin from
networks_to array Array of networks objects for coin to
expired_at string rate’s expiration date

Transaction statuses

Transaction statuses

wait The exchange has just been created and it’s waiting for coins to reach the deposit wallet
confirmation The transaction appears in mempool and now it is waiting for necessary network confirmations to start.
confirmed User’s payment is confirmed, the exchange process is about to start.
exchanging The exchange process is running.
sending Currency is being sent to the recipient address.
sending_confirmation Outgoing transaction is waiting for network confirmations.
success The exchange is completed and currency is successfully sent to the recipient address.
overdue Deposit receiving time for this transaction has expired.
error Transaction has failed. In most cases, the amount was sent differs from specified one when creating the transaction.
refunded Exchange was failed and coins were refunded to user's wallet.

Create Transaction

Example request:


curl -X POST "https://api.nrnb.io/api/v1/transaction" \
-H "Accept: application/json" \
-H "Content-Type: application/json" \
-d '{ "coin_from": "LTC", "coin_to": "ETH", "deposit_amount": "1", "withdrawal": "0x5aadfa328D778383d1134F7530f9feaC676E74B80efCa", "withdrawal_extra_id": "qbGDbH9gwrAkJTM6gxsfQpWYMfe8zRuZsSpoU77sx73peCPbzdZaUWW9tKWbBDs3hmeV", "return": "LsZK2wfxvXrfsfB6L39qmCcV5DK29ismmAwN41", "return_extra_id": "qbGDbH9gwrAkfJTM6gxsfQpWYMfe8zRuZsSpoU77sx73peCPbzdZaUWW9tKWbBDs3hmeV", "affiliate_id": "yWSiyDh93J7NPDNY", "coin_to_network": null, "coin_from_network": "ZEC", "float":true }'
var settings = {
    "async": true,
    "crossDomain": true,
    "url": "https://api.nrnb.io/api/v1/transaction",
    "method": "POST",
    "data": {
        "coin_from": "LTC",
        "coin_to": "ETH",
        "deposit_amount": 1,
        "withdrawal": "0x5aadfa328D778383d1134F7530f9feaC676E74B80efCa",
        "withdrawal_extra_id": "qbGDbH9gwrAkJTM6gxsfQpWYMfe8zRuZsSpoU77sx73peCPbzdZaUWW9tKWbBDs3hmeV",
        "return": "LsZK2wfxvXrfsfB6L39qmCcV5DK29ismmAwN41",
        "return_extra_id": "qbGDbH9gwrAkfJTM6gxsfQpWYMfe8zRuZsSpoU77sx73peCPbzdZaUWW9tKWbBDs3hmeV",
        "coin_to_network": null,
        "coin_from_network": "ZEC",
        "float":true
},
    "headers": {
        "accept": "application/json"
    }
}

$.ajax(settings).done(function (response) {
    console.log(response);
});

        $requestHeaders = [
            'Content-type: application/json'
        ];
        $ch = curl_init('https://api.nrnb.io/api/v1/transaction');
        curl_setopt($ch, CURLOPT_POST, 1);
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
        curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode([
                "coin_from" : "LTC",
                "coin_to":"ETH",
                "deposit_amount": 1,
                "withdrawal": 0x5aadfa328D778383d1134F7530f9feaC676E74B80efCa,
                "withdrawal_extra_id": qbGDbH9gwrAkJTM6gxsfQpWYMfe8zRuZsSpoU77sx73peCPbzdZaUWW9tKWbBDs3hmeV,
                "return": LsZK2wfxvXrfsfB6L39qmCcV5DK29ismmAwN41,
                "return_extra_id": qbGDbH9gwrAkfJTM6gxsfQpWYMfe8zRuZsSpoU77sx73peCPbzdZaUWW9tKWbBDs3hmeV,
                "affiliate_id": yWSiyDh93J7NPDNY,
                "coin_to_network": null,
                "coin_from_network": "ZEC",
                "float":true])
                );
        curl_setopt($ch, CURLOPT_HTTPHEADER, $requestHeaders);
        curl_setopt($ch, CURLOPT_TIMEOUT, 10);

The above command returns JSON structured like this:

{
      "status": wait,
      "coin_from": "LTC",
      "coin_to": "ETH",
      "deposit_amount": 1,
      "withdrawal": "0x5aadfa328D778383d1134F7530f9feaC676E74B80efCa",
      "withdrawal_extra_id": "qbGDbH9gwrAkJTM6gxsfQpWYMfe8zRuZsSpoU77sx73peCPbzdZaUWW9tKWbBDs3hmeV",
      "return": "LsZK2wfxvXrfsfB6L39qmCcV5DK29ismmAwN41",
      "return_extra_id": "qbGDbH9gwrAkfJTM6gxsfQpWYMfe8zRuZsSpoU77sx73peCPbzdZaUWW9tKWbBDs3hmeV",
      "withdrawal_amount": 0.25281436,
      "deposit": "LsZK2wfxvXrdffsfB6L39qmCcV5DK29ismmAwN41",
      "deposit_extra_id": null,
      "rate": 0.26011493,
      "fee": 0.00730057,
      "transaction_id": "5bb4d99cd44a5",
      "float": true,
   }

HTTP Request

POST api/v1/transaction

This call allows to request creating an exchange transaction. You choose coin pair you’d like to exchange, provide sender’s withdrawal address and specify amount of coins you want to swap. Nrnb returns address and extra id (if needed) to deposit to, final amount, fee and some other parameters.

To receive affiliate bonuses from transaction, the next parameter should be Included in the API query: affiliate_id.

Parameters

Parameter Type Status Description
coin_from string required Coin code from
coin_to string required Coin code to
deposit_amount numeric required Amount to be exchanged
withdrawal string required Destination address, it is used for sending exchanged coins
withdrawal_extra_id string optional Additional ID for destination wallet addresses of currencies that use extra ID for transaction processing
return string optional The address user sends coins from, or another one that may be used as a refund address, if it is necessary
return_extra_id string optional Additional ID for refund wallet addresses of currencies that use extra ID for transaction processing
coin_from_network string optional Network name of coin from
coin_to_network string optional Network name of coin to
float boolean optional true - the rate is floating,
false - the rate is fixed

Response

Name Type Description
transaction_id string Unique identifier for transaction assigned by nrnb
status string Transaction status is used to notify user about progress of the exchange process. See *transaction statuses for detailed description
coin_from string Coin to exchange from
coin_to string Coin to exchange to
deposit_amount float Amount of coins to be exchanged, specified by user
withdrawal_amount float This is expected amount that user will receive when exchange is completed
deposit string Deposit address to which user sends the currency
deposit_extra_id string|null Additional ID for deposit wallet addresses of currencies that use extra ID for transaction processing. Important: sending coins without using extra id (when it is provided) may result in money loss!
withdrawal string Destination address, it is used for sending exchanged coins
withdrawal_extra_id string|null Additional ID for destination wallet addresses of currencies that use extra ID for transaction processing
rate float Current exchange rate offered by nrnb
fee float Service fee (in destination currency)
return string The address user sends coins from, or another one that may be used as a refund address, if it is necessary
return_extra_id string|null Additional ID for refund wallet addresses of currencies that use extra ID for transaction processing
final_amount float It differs from withdrawal_amount if real deposit amount is not equal to amount specified by user. In this case, user receives this amount.
hash_in string Incoming transaction hash
hash_out string Outcoming transaction hash
float boolean true - the rate is floating,
false - the rate is fixed

Create Transaction Revert (by withdrawal amount)

Example request:


curl -X POST "https://api.nrnb.io/api/v1/transaction-revert" \
-H "Accept: application/json" \
-H "Content-Type: application/json" \
-d '{ "coin_from": "LTC", "coin_to": "ETH", "withdrawal_amount": "1", "withdrawal": "0x0", "withdrawal_extra_id": null, "affiliate_id": "yWSiyDh93J7NPDNY" }'
var settings = {
    "async": true,
    "crossDomain": true,
    "url": "https://api.nrnb.io/api/v1/transaction-revert",
    "method": "POST",
    "data": {
        "coin_from": "LTC",
        "coin_to": "ETH",
        "withdrawal_amount": 1,
        "withdrawal": "0x0",
        "withdrawal_extra_id": null,
        "affiliate_id": "yWSiyDh93J7NPDNY"
},
    "headers": {
        "accept": "application/json"
    }
}

$.ajax(settings).done(function (response) {
    console.log(response);
});

        $requestHeaders = [
            'Content-type: application/json'
        ];
        $ch = curl_init('https://api.nrnb.io/api/v1/transaction-revert');
        curl_setopt($ch, CURLOPT_POST, 1);
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
        curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode([
                "coin_from" : "LTC",
                "coin_to":"ETH",
                "withdrawal_amount": 1,
                "withdrawal": "0x0",
                "withdrawal_extra_id": null,
                "affiliate_id": yWSiyDh93J7NPDNY])
                );
        curl_setopt($ch, CURLOPT_HTTPHEADER, $requestHeaders);
        curl_setopt($ch, CURLOPT_TIMEOUT, 10);

The above command returns JSON structured like default request click here

HTTP Request

POST api/v1/transaction-revert

Same us Create Transaction, but without "deposit_amount" and required "withdrawal_amount".

Parameters

Parameter Type Status Description
deposit_amount numeric required Amount to be exchanged
withdrawal_amount numeric required Amount to be received

Response

Same us Create Transaction

Get Transaction

Example request:


curl -X GET "https://api.nrnb.io/api/v1/transaction/{id}" \
-H "Accept: application/json" \
-H "Content-Type: application/json" 
var settings = {
    "async": true,
    "crossDomain": true,
    "url": "https://api.nrnb.io/api/v1/transaction/{id}",
    "method": "GET",
    "headers": {
        "accept": "application/json"
    }
}

$.ajax(settings).done(function (response) {
    console.log(response);
});

$requestHeaders = ['Content-type: application/json'];
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, 'https://api.nrnb.io/api/v1/transaction/{id}');
curl_setopt($ch, CURLOPT_HTTPHEADER, $requestHeaders);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_exec($ch);
curl_close($ch);

Example response:

{
      "created_at": "2024-06-18T11:48:18.000000Z",
      "status": "wait",
      "transaction_id": "fb43d8da477as3e375",
      "coin_from": "ETH",
      "coin_to": "BTC",
      "deposit_amount": 4,
      "withdrawal_amount": 0.35552848,
      "rate": 0.08931962,
      "fee": 0.00175,
      "deposit": "0xbf595543984538e606e94ac1644cb63b69273d506dffb334",
      "deposit_extra_id": null,
      "withdrawal": "LcXGHfldb5szxJtj6d3fvY6btD3FA7V7f4L8GsoG4io",
      "withdrawal_extra_id": null,
      "return": "DJHda6CherXgE4R9xU52pnt36y3M8oYiWRndfsvopqgf",
      "return_extra_id": null,
      "final_amount": 18.55209531,
      "hash_in": null,
      "hash_out": null,
      "real_deposit_amount": 0.021020074485,
      "real_withdrawal_amount": 0.021020074485,
      "is_float": 1,
      "coin_from_network": "BTC",
      "coin_to_network": "ARBITRUM",
      "coin_from_name": "Bitcoin",
      "coin_to_name": "Ethereum",
      "coin_from_explorer_url": "https://blockchair.com/bitcoin/transaction/",
      "coin_to_explorer_url": "https://arbiscan.io/tx/",
      "need_confirmations": 1,
      "return_network_code":: null,
      "return_explorer_url":: null,
      "confirmations": 0,
      "coin_from_icon": "https://gdx-prod.s3.eu-north-1.amazonaws.com/coins/1WAAPTr9nKbBxTy7C8P5fuqm7FvRhDwqOm7qeEFR.png",
      "coin_to_icon": "https://gdx-prod.s3.eu-north-1.amazonaws.com/coins/16m5aOiHxH0HPCUna4B09wjBJmLKTsMNNjZjhmzD.png",
   }

HTTP Request

GET api/v1/transaction/{id}

Gets detailed information about a single transaction. One of returned parameters is ‘rate’, which is current rate offered by nrnb. It may differ from market rate, and also may change rapidly depending on the markets.

Options:

Name Type Description
id required|string Unique identifier for transaction assigned by nrnb

Response:

Name Type Description
transaction_id string Unique identifier for transaction assigned by nrnb
status string Transaction status is used to notify user about progress of the exchange process. See *transaction statuses for detailed description
coin_from string Coin to exchange from
coin_to string Coin to exchange to
deposit_amount float Amount of coins to be exchanged, specified by user
withdrawal_amount float This is expected amount that user will receive when exchange is completed
deposit string Deposit address to which user sends the currency
deposit_extra_id string|null Additional ID for deposit wallet addresses of currencies that use extra ID for transaction processing. Important: sending coins without using extra id (when it is provided) may result in money loss!
withdrawal string Destination address, it is used for sending exchanged coins
withdrawal_extra_id string|null Additional ID for destination wallet addresses of currencies that use extra ID for transaction processing
rate float Current exchange rate offered by nrnb
fee float Service fee (in destination currency)
return string The address user sends coins from, or another one that may be used as a refund address, if it is necessary
return_extra_id string|null Additional ID for refund wallet addresses of currencies that use extra ID for transaction processing
return_extra_id string|null Additional ID for refund wallet addresses of currencies that use extra ID for transaction processing
final_amount string|null It differs from withdrawal_amount if real deposit amount is not equal to amount specified by user. In this case, user receives this amount.
hash_in string|null Incoming transaction hash
hash_out string|null Outcoming transaction hash
real_deposit_amount string|null Displays received deposit amount. It may differ from the amount specified by user.
real_withdrawal_amount string|null If the received deposit is different, the final amount is being recalculated using the same rate.
execution_time string|null The time in seconds spent on the exchange. It is measured from the moment funds are received until the output transaction is sent to the recipient’s wallet.
is_float int 1 - the rate is floating,
0 - the rate is fixed
coin_from_network string coin from network
coin_to_network string Coin to network
coin_from_name string Coin from name
coin_to_name string Coin to name
coin_from_explorer_url string Coin from explorer url
coin_to_explorer_url string Coin to explorer url
need_confirmations int The number of network confirmations needed to initiate the exchange
confirmations array the number of passed confirmations
coin_from_icon string Coin from icon
coin_to_icon string Coin to icon
created_at string Transaction creation date
return_network_code string Network code of refund coin
return_explorer_url string Explorer url of refund coin
final_amount string This is final amount that user will receive when exchange is completed

Get List of Transactions

Example request:


curl -X GET "https://api.nrnb.io/api/v1/transactions/{id},{id}" \
-H "Accept: application/json" \
-H "Content-Type: application/json" 
var settings = {
    "async": true,
    "crossDomain": true,
    "url": "https://api.nrnb.io/api/v1/transactions/{id},{id}",
    "method": "GET",
    "headers": {
        "accept": "application/json"
    }
}

$.ajax(settings).done(function (response) {
    console.log(response);
});

$requestHeaders = ['Content-type: application/json'];
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, 'https://api.nrnb.io/api/v1/transactions/{id},{id}');
curl_setopt($ch, CURLOPT_HTTPHEADER, $requestHeaders);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_exec($ch);
curl_close($ch);

Example response:


[
  {
      "status": "wait",
      "transaction_id": "fb43d8da477as3e375",
      "coin_from": "ETH",
      "coin_to": "BTC",
      "deposit_amount": 4,
      "withdrawal_amount": 0.35552848,
      "rate": 0.08931962,
      "fee": 0.00175,
      "deposit": "0xbf595543984538e606e94ac1644cb63b69273d506dffb334",
      "deposit_extra_id": null,
      "withdrawal": "LcXGHfldb5szxJtj6d3fvY6btD3FA7V7f4L8GsoG4io",
      "withdrawal_extra_id": null,
      "return": "DJHda6CherXgE4R9xU52pnt36y3M8oYiWRndfsvopqgf",
      "return_extra_id": null,
      "hash_in": null,
      "hash_out": null,
      "real_deposit_amount": 0.021020074485,
      "real_withdrawal_amount": 0.021020074485,
  },
  {
      "status": "wait",
      "transaction_id": "ol43d8da477as3n8te",
      "coin_from": "ETH",
      "coin_to": "BTC",
      "deposit_amount": 4,
      "withdrawal_amount": 0.35552848,
      "rate": 0.08931962,
      "fee": 0.00175,
      "deposit": "0xbf595543984538e606e94ac1644cb63b69273d506dffb334",
      "deposit_extra_id": null,
      "withdrawal": "LcXGHfldb5szxJtj6d3fvY6btD3FA7V7f4L8GsoG4io",
      "withdrawal_extra_id": null,
      "return": "DJHda6CherXgE4R9xU52pnt36y3M8oYiWRndfsvopqgf",
      "return_extra_id": null,
      "hash_in": null,
      "hash_out": null,
      "real_deposit_amount": 0.021020074485,
      "real_withdrawal_amount": 0.021020074485,
  }
]
            

HTTP Request

GET api/v1/transactions/{id},{id}

Returns detailed information about multiple transactions. The unique transaction identifiers are separated by commas.

Options:

Name Type Description
id required|string Unique identifier for transaction assigned by nrnb

Response:

Name Type Description
transaction_id string Unique identifier for transaction assigned by nrnb
status string Transaction status is used to notify user about progress of the exchange process. See *transaction statuses for detailed description
coin_from string Coin to exchange from
coin_to string Coin to exchange to
deposit_amount float Amount of coins to be exchanged, specified by user
withdrawal_amount float This is expected amount that user will receive when exchange is completed
deposit string Deposit address to which user sends the currency
deposit_extra_id string|null Additional ID for deposit wallet addresses of currencies that use extra ID for transaction processing. Important: sending coins without using extra id (when it is provided) may result in money loss!
withdrawal string Destination address, it is used for sending exchanged coins
withdrawal_extra_id string|null Additional ID for destination wallet addresses of currencies that use extra ID for transaction processing
rate float Current exchange rate offered by nrnb
fee float Service fee (in destination currency)
return string The address user sends coins from, or another one that may be used as a refund address, if it is necessary
return_extra_id string|null Additional ID for refund wallet addresses of currencies that use extra ID for transaction processing
return_extra_id string|null Additional ID for refund wallet addresses of currencies that use extra ID for transaction processing
final_amount string|null It differs from withdrawal_amount if real deposit amount is not equal to amount specified by user. In this case, user receives this amount.
hash_in string|null Incoming transaction hash
hash_out string|null Outcoming transaction hash
real_deposit_amount string|null Displays received deposit amount. It may differ from the amount specified by user.
real_withdrawal_amount string|null If the received deposit is different, the final amount is being recalculated using the same rate.
execution_time string|null The time in seconds spent on the exchange. It is measured from the moment funds are received until the output transaction is sent to the recipient’s wallet.

Transaction Status

Example request:


curl -X GET "https://api.nrnb.io/api/v1/transaction/5bb38dea41f88/status" \
-H "Accept: application/json" \
-H "Content-Type: application/json"
            
var settings = {
    "async": true,
    "crossDomain": true,
    "url": "https://api.nrnb.io/api/v1/transaction/{id}/status",
    "method": "GET",
    "headers": {
        "accept": "application/json"
    }
}

$.ajax(settings).done(function (response) {
    console.log(response);
});

$requestHeaders = ['Content-type: application/json'];
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, 'https://api.nrnb.io/api/v1/transaction/{id}/status');
curl_setopt($ch, CURLOPT_HTTPHEADER, $requestHeaders);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_exec($ch);
curl_close($ch);
            

Example response:

status

HTTP Request

GET api/v1/transaction/{id}/status

Allows to check the current status of the transaction as a string.

Options:

Name Type Description
id required|string Unique identifier for transaction assigned by nrnb

Response:

Return transaction status

User Info

In order to use these API requests you must have an authorization token. You can receive in your nrnb account settings or contact the support.

Get Balance

Example request:

curl -X GET "https://api.nrnb.io/api/v1/balance" \
-H "Content-Type: application/json" \
-H "public-key: eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiIsImp0aSI6Ij"
var settings = {
    "async": true,
    "crossDomain": true,
    "url": "https://api.nrnb.io/api/v1/balance",
    "method": "GET",
    "headers": {
        "accept": "application/json"
        "public-key": "eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiIsImp0aSI6Ij"
    }
}

$.ajax(settings).done(function (response) {
    console.log(response);
});
$requestHeaders = ['Content-type: application/json', 'Content-type: application/json', 'public-key: eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiIsImp0aSI6Ij'];
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, 'https://api.nrnb.io/api/v1/balance');
curl_setopt($ch, CURLOPT_HTTPHEADER, $requestHeaders);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_exec($ch);
curl_close($ch);

Example response:

100,00

HTTP Request

GET api/v1/balance

Represents the current user’s accumulated balance in BTC.

Options:

Parameters are not needed, but it requires Authorization api key.

Answer:

Will return the current balance in the string

Get a balance story

Example request:

curl -X GET "https://api.nrnb.io/api/v1/history" \
-H "Content-Type: application/json" \
-H "public-key: eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiIsImp0aSI6Ij"
var settings = {
    "async": true,
    "crossDomain": true,
    "url": "https://api.nrnb.io/api/v1/history",
    "method": "GET",
    "headers": {
        "accept": "application/json",
        "public-key": "eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiIsImp0aSI6Ij"
    }
}

$.ajax(settings).done(function (response) {
    console.log(response);
});
$requestHeaders = ['Content-type: application/json', 'public-key: eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiIsImp0aSI6Ij'];
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, 'https://api.nrnb.io/api/v1/history');
curl_setopt($ch, CURLOPT_HTTPHEADER, $requestHeaders);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_exec($ch);
curl_close($ch);

Example response:

    [
      {
        "amount": "0.35552848",
        "type": "transaction",
        "source_id": "72cb3f954cff",
        "created_at": "2018-09-17 04:48:35",
      },
      {
        "amount": "0.2187264",
        "type": "affiliate",
        "source_id": "b0c6cd6ccc90",
        "created_at": "2018-09-15 04:48:35",
      },
        {
        "amount": "0.1034893",
        "type": "withdrawal",
        "source_id": "eedb9a09356e",
        "created_at": "2018-09-13 10:50:34",
      }
    ]

HTTP Request

GET api/v1/history

Gets the history of the user's balance changes. This can be accrual of funds from the affiliate program, from user's transactions, and also withdrawals. In addition it returns the transaction ID and the date of a specific balance change

Options:

Parameters are not needed, but it requires Authorization api key.

Response:

array of objects

Name Type Description
amount float Balance change
type string Type of balance change: Transaction - income from exchange made by user; Affiliate - income from exchange made by affiliate link Withdrawal - funds withdrawal
source_id int Unique identifier for transaction assigned by nrnb
created_at string Date and time when transaction was created

Get All Transaction

Example request:


curl -X GET "https://api.nrnb.io/api/v1/transactions" \
-H "Content-Type: application/json" \
-H "public-key: eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiIsImp0aSI6Ij"
var settings = {
    "async": true,
    "crossDomain": true,
    "url": "https://api.nrnb.io/api/v1/transactions",
    "method": "GET",
    "headers": {
        "accept": "application/json",
        "public-key": "eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiIsImp0aSI6Ij"

    }
}

$.ajax(settings).done(function (response) {
    console.log(response);
});

$requestHeaders = ['Content-type: application/json, 'Content-type: application/json', 'public-key: eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiIsImp0aSI6Ij'];
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, 'https://api.nrnb.io/api/v1/transactions');
curl_setopt($ch, CURLOPT_HTTPHEADER, $requestHeaders);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_exec($ch);
curl_close($ch);

Example response:

    [
      {
        "transaction_id": "5b758efb69fbaYjef",
        "status": "wait",
        "coin_from": "BTC",
        "coin_to": "ETH",
        "deposit_amount": "1",
        "withdrawal_amount": "0.04342730",
        "deposit": "",
        "withdrawal": "37ZdZAQgKiuyKENJjJK1XfJmgJ3HFcEiorScaVx",
        "created_at": "2018-08-17 14:52:32"
      },
      {
        "transaction_id": "5bsp76a6dfw1b54046",
        "status": "wait",
        "coin_from": "XEM",
        "coin_to": "XRP",
        "deposit_amount": "300",
        "withdrawal_amount": "101.46818249",
        "deposit": "",
        "withdrawal": "Udfk883JF38MVlvdfsqp46kvHJMlw",
        "created_at": "2018-08-17 10:40:27"
      }
    ]

HTTP Request

GET api/v1/transactions

Gets an array, containing list of all transactions and their parameters, like transaction id, status, coin pair, date of creation and others.

Options:

Parameters are not needed, but it requires Authorization api key.

Answer:

array of objects

Name Type Description
transaction_id string Unique identifier for transaction assigned by nrnb
status string Transaction status
coin_from string Coin code from
coin_to string Coin code to
deposit_amount float Amount of coins to be exchanged, specified by user
withdrawal_amount float This is expected amount that user will receive when exchange is completed
deposit string Deposit address to which user sends the currency
withdrawal string The address user sends coins from.
created_at Date and time when transaction was created

Get Affiliate Transactions

Example request:


curl -X GET "https://api.nrnb.io/api/v1/affiliate/history" \
-H "Content-Type: application/json" \
-H "public-key: eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiIsImp0aSI6Ij"
var settings = {
    "async": true,
    "crossDomain": true,
    "url": "https://api.nrnb.io/api/v1/affiliate/history",
    "method": "GET",
    "headers": {
        "accept": "application/json",
        "public-key": "eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiIsImp0aSI6Ij"

    }
}

$.ajax(settings).done(function (response) {
    console.log(response);
});

$requestHeaders = ['Content-type: application/json, 'Content-type: application/json', 'public-key: eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiIsImp0aSI6Ij'];
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, 'https://api.nrnb.io/api/v1/affiliate/history');
curl_setopt($ch, CURLOPT_HTTPHEADER, $requestHeaders);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_exec($ch);
curl_close($ch);

Example response:

    [
      {
        "transaction_id": "5b758efb69fbaYjef",
        "status": "wait",
        "coin_from": "BTC",
        "coin_to": "ETH",
        "deposit_amount": "1",
        "withdrawal_amount": "0.04342730",
        "deposit": "",
        "withdrawal": "37ZdZAQgKiuyKENJjJK1XfJmgJ3HFcEiorScaVx",
        "rate": "29.43135400",
        "fee": "0",
        "user_id": "33",
        "affiliate_id": "KUZ6fSFVnmTaVIRW",
        "created_at": "2018-08-17 14:52:32"
      },
      {
        "transaction_id": "5bsp76a6dfw1b54046",
        "status": "wait",
        "coin_from": "XEM",
        "coin_to": "XRP",
        "deposit_amount": "300",
        "withdrawal_amount": "101.46818249",
        "deposit": "",
        "withdrawal": "Udfk883JF38MVlvdfsqp46kvHJMlw",
        "rate": "29.43135400",
        "fee": "0",
        "user_id": "33",
        "affiliate_id": "KUZ6fSFVnmTaVIRW",
        "created_at": "2018-08-17 10:40:27"
      }
    ]

HTTP Request

GET api/v1/affiliate/history

Returns the array of data for transactions made by the user with the specific affiliate id.

Options:

Parameters are not needed, but it requires Authorization api key.

Name Type Description
coin_from (Optional) string Ticker for a currency from
coin_to (Optional) string Ticker for a destination currency
status (Optional) string Transaction status (see the list of available statuses)
limit (Optional) integer Amount of transactions to be displayed (default: 10)
offset (Optional) integer Number of transactions to skip

Answer:

array of objects

Name Type Description
transaction_id string Unique identifier for transaction assigned by nrnb
status string Transaction status
coin_from string Coin code from
coin_to string Coin code to
deposit_amount float Amount of coins to be exchanged, specified by user
withdrawal_amount float This is expected amount that user will receive when exchange is completed
deposit string Deposit address to which user sends the currency
withdrawal string The address user sends coins from.
created_at Date and time when transaction was created