blockfrost-js
Blockfrost.io SDK for JavaScript for Node.js.
Getting started •
Installation •
Usage
Getting started
To use this SDK, you first need to log in to blockfrost.io, create your project and retrieve the API token.
Installation
To run the SDK you need Node.js version 14 and higher. While you may find a way to run it directly in a browser, we don't actively support or provide troubleshooting assistance with this scenario. We recommend setting up your own Node.js backend. Exposing your API keys in a frontend application is almost always a bad idea.
The SDK is hosted on npmjs.com, so you can directly import it using your favorite package manager.
npm i @blockfrost/blockfrost-js
yarn add @blockfrost/blockfrost-js
Usage
Using the SDK is pretty straight-forward as you can see from the following examples.
For more examples take a look in examples directory.
const API = new Blockfrost.BlockFrostAPI({
projectId: 'YOUR API KEY HERE',
});
Options
projectId
- string
, Blockfrost project ID (required)isTestnet
- boolean
, whether the projectId is intended for testnet network (optional, default value is derived from the projectId
itself if possible)rateLimiter
- boolean
or RateLimiterConfig
, whether to enable rate limiter that matches Blockfrost API limits (optional, default true
). If you have your IP addresses white-listed you may want to disable it. You may also customize rate limiter by passing your own config object.requestTimeout
- number
, How long to wait for a request to complete, in milliseconds (optional, default 20000
)retrySettings
- RequiredRetryOptions
, customizations for retrying failed request (optional, for defaults click here)debug
- boolean
, whether to enable debug logging. It is also possible to enable it by setting environment variable DEBUG
to true
(optional, default false
).customBackend
- string
, option to set URL to a non-official backend (optional)version
- number
, version of the Blockfrost API (optional, default 0
)
Error handling
Blockfrost Node.js SDK throws 2 types of errors, BlockfrostServerError
and BlockfrostClientError
. Each of these errors is extended from the built-in Error
class, allowing you to properly catch it and handle it in your code.
BlockfrostServerError
BlockfrostServerError
is an error returned directly by Blockfrost API. The error's properties are matching the same format as defined by Blockfrost API.
Example
Blockfrost API returns 404 Not Found for any resource that does not exist on chain at the moment, even when in theory, it could exist. For more detailed explanation check Blockfrost developer portal.
try {
const address = await API.addresses('totallyValidAddress');
} catch (error) {
if (error instanceof BlockfrostServerError && error.status_code === 404) {
console.log("Address is totally empty! But that's ok!");
} else {
throw error;
}
}
BlockfrostClientError
BlockfrostClientError
is an error that was NOT returned by a Blockfrost API server. In this case the request has never reached our backends. Most common causes are network-related.
Shape of BlockfrostClientError
object is slightly different from BlockfrostServerError
. The error has code
and message
property to help you investigate the issue.
Here is a small example showcasing the error format:
{
"code": "ENOTFOUND",
"message": "getaddrinfo ENOTFOUND api.blockfrost.io"
}
Example
try {
const address = await API.addresses('totallyValidAddress');
} catch (error) {
if (error instanceof BlockfrostClientError) {
console.log('Oops, error during sending the request');
}
throw error;
}
Examples
For more examples take a look in examples directory.
Cardano
const Blockfrost = require('@blockfrost/blockfrost-js');
const API = new Blockfrost.BlockFrostAPI({
projectId: 'YOUR API KEY HERE',
});
async function runExample() {
try {
const latestBlock = await API.blocksLatest();
const networkInfo = await API.network();
const latestEpoch = await API.epochsLatest();
const health = await API.health();
const address = await API.addresses(
'addr1qxqs59lphg8g6qndelq8xwqn60ag3aeyfcp33c2kdp46a09re5df3pzwwmyq946axfcejy5n4x0y99wqpgtp2gd0k09qsgy6pz',
);
const pools = await API.pools({ page: 1, count: 10, order: 'asc' });
console.log('pools', pools);
console.log('address', address);
console.log('networkInfo', networkInfo);
console.log('latestEpoch', latestEpoch);
console.log('latestBlock', latestBlock);
console.log('health', health);
} catch (err) {
console.log('error', err);
}
}
runExample();
IPFS
const Blockfrost = require('@blockfrost/blockfrost-js');
const IPFS = new Blockfrost.BlockFrostIPFS({
projectId: 'YOUR IPFS KEY HERE',
});
async function runExample() {
try {
const added = await IPFS.add(`${__dirname}/img.svg`);
console.log('added', added);
const pinned = await IPFS.pin(added.ipfs_hash);
console.log('pinned', pinned);
} catch (err) {
console.log('error', err);
}
}
runExample();
For a more detailed list of possibilities, check out the wiki.