Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/coinbase/coinbase-pro-node
DEPRECATED — The official Node.js library for Coinbase Pro
https://github.com/coinbase/coinbase-pro-node
bitcoin coinbase ethereum gdax gdax-api orderbook trade trading trading-api
Last synced: about 1 month ago
JSON representation
DEPRECATED — The official Node.js library for Coinbase Pro
- Host: GitHub
- URL: https://github.com/coinbase/coinbase-pro-node
- Owner: coinbase
- License: apache-2.0
- Archived: true
- Created: 2016-07-18T22:02:53.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2020-01-16T05:40:14.000Z (almost 5 years ago)
- Last Synced: 2024-05-29T03:50:46.416Z (7 months ago)
- Topics: bitcoin, coinbase, ethereum, gdax, gdax-api, orderbook, trade, trading, trading-api
- Language: JavaScript
- Homepage:
- Size: 393 KB
- Stars: 834
- Watchers: 62
- Forks: 308
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
# Coinbase Pro [![CircleCI](https://circleci.com/gh/coinbase/coinbase-pro-node.svg?style=svg)](https://circleci.com/gh/coinbase/coinbase-pro-node) [![npm version](https://badge.fury.io/js/coinbase-pro.svg)](https://badge.fury.io/js/coinbase-pro)
**Note**: The `gdax` package is deprecated and might have to be removed from NPM.
Please migrate to the `coinbase-pro` package to ensure future compatibility.The official Node.js library for Coinbase's [Pro API](https://docs.pro.coinbase.com/).
## Features
- Easy functionality to use in programmatic trading
- A customizable, websocket-synced Order Book implementation
- API clients with convenient methods for every API endpoint
- Abstracted interfaces – don't worry about HMAC signing or JSON formatting; the
library does it for you## Installation
```bash
npm install coinbase-pro
```You can learn about the API responses of each endpoint [by reading our
documentation](https://docs.pro.coinbase.com/#market-data).## Quick Start
The Coinbase Pro API has both public and private endpoints. If you're only interested in
the public endpoints, you should use a `PublicClient`.```js
const CoinbasePro = require('coinbase-pro');
const publicClient = new CoinbasePro.PublicClient();
```All methods, unless otherwise specified, can be used with either a promise or
callback API.### Using Promises
```js
publicClient
.getProducts()
.then(data => {
// work with data
})
.catch(error => {
// handle the error
});
```The promise API can be used as expected in `async` functions in ES2017+
environments:```js
async function yourFunction() {
try {
const products = await publicClient.getProducts();
} catch (error) {
/* ... */
}
}
```### Using Callbacks
Your callback should accept three arguments:
- `error`: contains an error message (`string`), or `null` if no error was
encountered
- `response`: a generic HTTP response abstraction created by the [`request`
library](https://github.com/request/request)
- `data`: contains data returned by the Coinbase Pro API, or `undefined` if an error was
encountered```js
publicClient.getProducts((error, response, data) => {
if (error) {
// handle the error
} else {
// work with data
}
});
```**NOTE:** if you supply a callback, no promise will be returned. This is to
prevent potential `UnhandledPromiseRejectionWarning`s, which will cause future
versions of Node to terminate.```js
const myCallback = (err, response, data) => {
/* ... */
};const result = publicClient.getProducts(myCallback);
result.then(() => {
/* ... */
}); // TypeError: Cannot read property 'then' of undefined
```### Optional Parameters
Some methods accept optional parameters, e.g.
```js
publicClient.getProductOrderBook('BTC-USD', { level: 3 }).then(book => {
/* ... */
});
```To use optional parameters with callbacks, supply the options as the first
parameter(s) and the callback as the last parameter:```js
publicClient.getProductOrderBook(
'ETH-USD',
{ level: 3 },
(error, response, book) => {
/* ... */
}
);
```### The Public API Client
```js
const publicClient = new CoinbasePro.PublicClient(endpoint);
```- `productID` _optional_ - defaults to 'BTC-USD' if not specified.
- `endpoint` _optional_ - defaults to 'https://api.pro.coinbase.com' if not specified.#### Public API Methods
- [`getProducts`](https://docs.pro.coinbase.com/#get-products)
```js
publicClient.getProducts(callback);
```- [`getProductOrderBook`](https://docs.pro.coinbase.com/#get-product-order-book)
```js
// Get the order book at the default level of detail.
publicClient.getProductOrderBook('BTC-USD', callback);// Get the order book at a specific level of detail.
publicClient.getProductOrderBook('LTC-USD', { level: 3 }, callback);
```- [`getProductTicker`](https://docs.pro.coinbase.com/#get-product-ticker)
```js
publicClient.getProductTicker('ETH-USD', callback);
```- [`getProductTrades`](https://docs.pro.coinbase.com/#get-trades)
```js
publicClient.getProductTrades('BTC-USD', callback);// To make paginated requests, include page parameters
publicClient.getProductTrades('BTC-USD', { after: 1000 }, callback);
```- [`getProductTradeStream`](https://docs.pro.coinbase.com/#get-trades)
Wraps around `getProductTrades`, fetches all trades with IDs `>= tradesFrom` and
`<= tradesTo`. Handles pagination and rate limits.```js
const trades = publicClient.getProductTradeStream('BTC-USD', 8408000, 8409000);// tradesTo can also be a function
const trades = publicClient.getProductTradeStream(
'BTC-USD',
8408000,
trade => Date.parse(trade.time) >= 1463068e6
);
```- [`getProductHistoricRates`](https://docs.pro.coinbase.com/#get-historic-rates)
```js
publicClient.getProductHistoricRates('BTC-USD', callback);// To include extra parameters:
publicClient.getProductHistoricRates(
'BTC-USD',
{ granularity: 3600 },
callback
);
```- [`getProduct24HrStats`](https://docs.pro.coinbase.com/#get-24hr-stats)
```js
publicClient.getProduct24HrStats('BTC-USD', callback);
```- [`getCurrencies`](https://docs.pro.coinbase.com/#get-currencies)
```js
publicClient.getCurrencies(callback);
```- [`getTime`](https://docs.pro.coinbase.com/#time)
```js
publicClient.getTime(callback);
```### The Authenticated API Client
The [private exchange API endpoints](https://docs.pro.coinbase.com/#private) require you
to authenticate with a Coinbase Pro API key. You can create a new API key [in your
exchange account's settings](https://pro.coinbase.com/profile/api). You can also specify
the API URI (defaults to `https://api.pro.coinbase.com`).```js
const key = 'your_api_key';
const secret = 'your_b64_secret';
const passphrase = 'your_passphrase';const apiURI = 'https://api.pro.coinbase.com';
const sandboxURI = 'https://api-public.sandbox.pro.coinbase.com';const authedClient = new CoinbasePro.AuthenticatedClient(
key,
secret,
passphrase,
apiURI
);
```Like `PublicClient`, all API methods can be used with either callbacks or will
return promises.`AuthenticatedClient` inherits all of the API methods from
`PublicClient`, so if you're hitting both public and private API endpoints you
only need to create a single client.#### Private API Methods
- [`getCoinbaseAccounts`](https://docs.pro.coinbase.com/#coinbase-accounts)
```javascript
authedClient.getCoinbaseAccounts(callback);
```- [`getPaymentMethods`](https://docs.pro.coinbase.com/#payment-methods)
```javascript
authedClient.getPaymentMethods(callback);
```- [`getAccounts`](https://docs.pro.coinbase.com/#list-accounts)
```js
authedClient.getAccounts(callback);
```- [`getAccount`](https://docs.pro.coinbase.com/#get-an-account)
```js
const accountID = '7d0f7d8e-dd34-4d9c-a846-06f431c381ba';
authedClient.getAccount(accountID, callback);
```- [`getAccountHistory`](https://docs.pro.coinbase.com/#get-account-history)
```js
const accountID = '7d0f7d8e-dd34-4d9c-a846-06f431c381ba';
authedClient.getAccountHistory(accountID, callback);// For pagination, you can include extra page arguments
authedClient.getAccountHistory(accountID, { before: 3000 }, callback);
```- [`getAccountTransfers`](https://docs.pro.coinbase.com/#get-account-transfers)
```js
const accountID = '7d0f7d8e-dd34-4d9c-a846-06f431c381ba';
authedClient.getAccountTransfers(accountID, callback);// For pagination, you can include extra page arguments
authedClient.getAccountTransfers(accountID, { before: 3000 }, callback);
```- [`getAccountHolds`](https://docs.pro.coinbase.com/#get-holds)
```js
const accountID = '7d0f7d8e-dd34-4d9c-a846-06f431c381ba';
authedClient.getAccountHolds(accountID, callback);// For pagination, you can include extra page arguments
authedClient.getAccountHolds(accountID, { before: 3000 }, callback);
```- [`buy`, `sell`](https://docs.pro.coinbase.com/#place-a-new-order)
```js
// Buy 1 BTC @ 100 USD
const buyParams = {
price: '100.00', // USD
size: '1', // BTC
product_id: 'BTC-USD',
};
authedClient.buy(buyParams, callback);// Sell 1 BTC @ 110 USD
const sellParams = {
price: '110.00', // USD
size: '1', // BTC
product_id: 'BTC-USD',
};
authedClient.sell(sellParams, callback);
```- [`placeOrder`](https://docs.pro.coinbase.com/#place-a-new-order)
```js
// Buy 1 LTC @ 75 USD
const params = {
side: 'buy',
price: '75.00', // USD
size: '1', // LTC
product_id: 'LTC-USD',
};
authedClient.placeOrder(params, callback);
```- [`cancelOrder`](https://docs.pro.coinbase.com/#cancel-an-order)
```js
const orderID = 'd50ec984-77a8-460a-b958-66f114b0de9b';
authedClient.cancelOrder(orderID, callback);
```- [`cancelOrders`](https://docs.pro.coinbase.com/#cancel-all)
```js
// Cancels "open" orders
authedClient.cancelOrders(callback);
```- [`cancelAllOrders`](https://docs.pro.coinbase.com/#cancel-all)
```js
// `cancelOrders` may require you to make the request multiple times until
// all of the "open" orders are deleted.// `cancelAllOrders` will handle making these requests for you asynchronously.
// Also, you can add a `product_id` param to only delete orders of that product.// The data will be an array of the order IDs of all orders which were cancelled
authedClient.cancelAllOrders({ product_id: 'BTC-USD' }, callback);
```- [`getOrders`](https://docs.pro.coinbase.com/#list-open-orders)
```js
authedClient.getOrders(callback);
// For pagination, you can include extra page arguments
// Get all orders of 'open' status
authedClient.getOrders({ after: 3000, status: 'open' }, callback);
```- [`getOrder`](https://docs.pro.coinbase.com/#get-an-order)
```js
const orderID = 'd50ec984-77a8-460a-b958-66f114b0de9b';
authedClient.getOrder(orderID, callback);
```- [`getFills`](https://docs.pro.coinbase.com/#list-fills)
```js
const params = {
product_id: 'LTC-USD',
};
authedClient.getFills(params, callback);
// For pagination, you can include extra page arguments
authedClient.getFills({ before: 3000 }, callback);
```- [`getFundings`](https://docs.pro.coinbase.com/#list-fundings)
```js
authedClient.getFundings({}, callback);
```- [`repay`](https://docs.pro.coinbase.com/#repay)
```js
const params = {
amount: '2000.00',
currency: 'USD',
};
authedClient.repay(params, callback);
```- [`marginTransfer`](https://docs.pro.coinbase.com/#margin-transfer)
```js
const params =
'margin_profile_id': '45fa9e3b-00ba-4631-b907-8a98cbdf21be',
'type': 'deposit',
'currency': 'USD',
'amount': 2
};
authedClient.marginTransfer(params, callback);
```- [`closePosition`](https://docs.pro.coinbase.com/#close)
```js
const params = {
repay_only: false,
};
authedClient.closePosition(params, callback);
```- [`convert`](https://docs.pro.coinbase.com/#create-conversion)
```js
const params = {
from: 'USD',
to: 'USDC',
amount: '100',
};
authedClient.convert(params, callback);
```- [`deposit`, `withdraw`](https://docs.pro.coinbase.com/#deposits)
```js
// Deposit to your Exchange USD account from your Coinbase USD account.
const depositParamsUSD = {
amount: '100.00',
currency: 'USD',
coinbase_account_id: '60680c98bfe96c2601f27e9c', // USD Coinbase Account ID
};
authedClient.deposit(depositParamsUSD, callback);// Withdraw from your Exchange USD account to your Coinbase USD account.
const withdrawParamsUSD = {
amount: '100.00',
currency: 'USD',
coinbase_account_id: '60680c98bfe96c2601f27e9c', // USD Coinbase Account ID
};
authedClient.withdraw(withdrawParamsUSD, callback);// Deposit to your Exchange BTC account from your Coinbase BTC account.
const depositParamsBTC = {
amount: '2.0',
currency: 'BTC',
coinbase_account_id: '536a541fa9393bb3c7000023', // BTC Coinbase Account ID
};
authedClient.deposit(depositParamsBTC, callback);// Withdraw from your Exchange BTC account to your Coinbase BTC account.
const withdrawParamsBTC = {
amount: '2.0',
currency: 'BTC',
coinbase_account_id: '536a541fa9393bb3c7000023', // BTC Coinbase Account ID
};
authedClient.withdraw(withdrawParamsBTC, callback);// Fetch a deposit address from your Exchange BTC account.
const depositAddressParams = {
currency: 'BTC',
};
authedClient.depositCrypto(depositAddressParams, callback);// Withdraw from your Exchange BTC account to another BTC address.
const withdrawAddressParams = {
amount: 10.0,
currency: 'BTC',
crypto_address: '15USXR6S4DhSWVHUxXRCuTkD1SA6qAdy',
};
authedClient.withdrawCrypto(withdrawAddressParams, callback);
```- [`depositPayment`](https://docs.pro.coinbase.com/#payment-method)
```js
// Schedule Deposit to your Exchange USD account from a configured payment method.
const depositPaymentParamsUSD = {
amount: '100.00',
currency: 'USD',
payment_method_id: 'bc6d7162-d984-5ffa-963c-a493b1c1370b', // ach_bank_account
};
authedClient.depositPayment(depositPaymentParamsUSD, callback);
```- [`withdrawPayment`](https://docs.pro.coinbase.com/#payment-method47)
```js
// Withdraw from your Exchange USD account to a configured payment method.
const withdrawPaymentParamsUSD = {
amount: '100.00',
currency: 'USD',
payment_method_id: 'bc6d7162-d984-5ffa-963c-a493b1c1370b', // ach_bank_account
};
authedClient.withdrawPayment(withdrawPaymentParamsUSD, callback);
```- [`getTrailingVolume`](https://docs.pro.coinbase.com/#user-account)
```js
// Get your 30 day trailing volumes
authedClient.getTrailingVolume(callback);
```### Websocket Client
The `WebsocketClient` allows you to connect and listen to the [exchange
websocket messages](https://docs.pro.coinbase.com/#messages).```js
const websocket = new CoinbasePro.WebsocketClient(['BTC-USD', 'ETH-USD']);websocket.on('message', data => {
/* work with data */
});
websocket.on('error', err => {
/* handle error */
});
websocket.on('close', () => {
/* ... */
});
```The client will automatically subscribe to the `heartbeat` channel. By
default, the `full` channel will be subscribed to unless other channels are
requested.```javascript
const websocket = new CoinbasePro.WebsocketClient(
['BTC-USD', 'ETH-USD'],
'wss://ws-feed-public.sandbox.pro.coinbase.com',
{
key: 'suchkey',
secret: 'suchsecret',
passphrase: 'muchpassphrase',
},
{ channels: ['full', 'level2'] }
);
```Optionally, [change subscriptions at runtime](https://docs.pro.coinbase.com/#subscribe):
```javascript
websocket.unsubscribe({ channels: ['full'] });websocket.subscribe({ product_ids: ['LTC-USD'], channels: ['ticker', 'user'] });
websocket.subscribe({
channels: [
{
name: 'user',
product_ids: ['ETH-USD'],
},
],
});websocket.unsubscribe({
channels: [
{
name: 'user',
product_ids: ['LTC-USD'],
},
{
name: 'user',
product_ids: ['ETH-USD'],
},
],
});
```The following events can be emitted from the `WebsocketClient`:
- `open`
- `message`
- `close`
- `error`### Orderbook
`Orderbook` is a data structure that can be used to store a local copy of the
orderbook.```js
const orderbook = new CoinbasePro.Orderbook();
```The orderbook has the following methods:
- `state(book)`
- `get(orderId)`
- `add(order)`
- `remove(orderId)`
- `match(match)`
- `change(change)`### Orderbook Sync
`OrderbookSync` creates a local mirror of the orderbook on Coinbase Pro using
`Orderbook` and `WebsocketClient` as described
[here](https://docs.pro.coinbase.com/#real-time-order-book).```js
const orderbookSync = new CoinbasePro.OrderbookSync(['BTC-USD', 'ETH-USD']);
console.log(orderbookSync.books['ETH-USD'].state());
```## Testing
```bash
npm test# test for known vulnerabilities in packages
npm install -g nsp
nsp check --output summary
```