Using APIs

Check out this demo, which walks you through using a Dhali linked API:

Each API on Dhali has a unique base endpoint. To access the API, send requests to the base endpoint with extra routes, etc, determined by the API's spec. All you need to do in addition is add a payment claim (i.e., a Dhali API key). This is a base64 encoded JSON object embedded in the request header to fund the service, taking the following form:

{
    "version": "<a version number>",
    "account": "<Your account classic address>",
    "destination_account": "<Dhali's classic address>",
    "protocol", "<e.g., XRPL.MAINNET>",
    "currency", {"code": "USD", "issuer": "example acccount", "scale": 6},
    "authorized_to_claim": "<The max amount (measured in <code>*10^<scale>) that this payment claim allows to be extracted from the channel>",
    "signature": "<A cryptographic signature that only 'account' can create>",
    "channel_id": "<The ID of the channel>"
}

Once you have a payment claim, you can use the API:

URL

API request URLs through Dhali take the form:

https://run.api.dhali.io/{uuid}/{other_paths}

Path parameters

Name Type Description
uuid String The UUID of the API
other_paths String The API provider's route

Supported methods:

Dhali supports all REST methods: GET, POST, PUT, DELETE, PATCH

Headers

Name Type Description
Payment-Claim String A receipt against your payment channel
... String Headers required by the API provider

Query paramters

Dhali forwards all query strings to the linked API.

200: OK

The execution was successful. You will receive a response with the following headers:

Name Type Description
dhali-latest-request-charge String The cost of this request.
... String Any other headers returned by the linked API

The body of the response will be:

{
    <The API's output>
}

402: Bad payment claim.

{
    detail: "<Why your payment claim was not valid>"
}