cryptocompare
CryptoCompare JavaScript API
Install
npm install --save cryptocompare
Usage
Note: cryptocompare depends on fetch()
being defined globally.
-
If you are using this in electron, it should work without any configuration.
-
If you are using this in Node.js, you will need to use node-fetch
.
Example:
global.fetch = require('node-fetch')
const cc = require('cryptocompare')
Methods
price()
Get the current price of any cryptocurrency in any other currency.
price(fsym, tsyms[, options])
fsym
(String) From Symboltsyms
(Array of Strings | String) To Symbol(s)options
(Object)
tryConversion
(Boolean) By default, if the crypto does not trade directly into the toSymbol requested, BTC will be used for conversion. Set tryConversion
to false
to disable using BTC for conversion.exchanges
(Array of Strings | Array) Exchanges to get price data from. By default, average data is used. (You can get a list of top exchanges for a given pair with topExchanges()
.)
const cc = require('cryptocompare')
cc.price('BTC', ['USD', 'EUR'])
.then(prices => {
console.log(prices)
})
.catch(console.error)
cc.price('BTC', 'USD')
.then(prices => {
console.log(prices)
})
.catch(console.error)
priceMulti()
Works like price()
, except it allows you to specify a matrix of From Symbols.
priceMulti(fsyms, tsyms[, options])
fsyms
(Array of Strings | String) From Symbol(s)tsyms
(Array of Strings | String) To Symbol(s)options
(Object)
tryConversion
(Boolean) By default, if the crypto does not trade directly into the toSymbol requested, BTC will be used for conversion. Set tryConversion
to false
to disable using BTC for conversion.exchanges
(Array of Strings | Array) Exchanges to get price data from. By default, average data is used. (You can get a list of top exchanges for a given pair with topExchanges()
.)
const cc = require('cryptocompare')
cc.priceMulti(['BTC', 'ETH'], ['USD', 'EUR'])
.then(prices => {
console.log(prices)
})
.catch(console.error)
cc.priceMulti('BTC', 'USD')
.then(prices => {
console.log(prices)
})
.catch(console.error)
priceFull()
Get all the current trading info (price, vol, open, high, low, etc.) of any list of cryptocurrencies in any other currency.
priceFull(fsyms, tsyms[, options])
fsyms
(Array of Strings | String) From Symbol(s)tsyms
(Array of Strings | String) To Symbol(s)options
(Object)
tryConversion
(Boolean) By default, if the crypto does not trade directly into the toSymbol requested, BTC will be used for conversion. Set tryConversion
to false
to disable using BTC for conversion.exchanges
(Array of Strings | Array) Exchanges to get price data from. By default, average data is used. (You can get a list of top exchanges for a given pair with topExchanges()
.)
const cc = require('cryptocompare')
cc.priceFull(['BTC', 'ETH'], ['USD', 'EUR'])
.then(prices => {
console.log(prices)
})
.catch(console.error)
priceHistorical()
Get the price of any cryptocurrency in any other currency at a given timestamp. The price comes from the daily info - so it would be the price at the end of the day GMT based on the requested timestamp.
priceHistorical(fsym, tsyms, time[, options])
fsym
(String) From Symboltsyms
(Array of Strings | String) To Symbol(s)time
(Date) Date in history that you want price data foroptions
(Object)
tryConversion
(Boolean) By default, if the crypto does not trade directly into the toSymbol requested, BTC will be used for conversion. Set tryConversion
to false
to disable using BTC for conversion.exchanges
(Array of Strings | Array) Exchanges to get price data from. By default, average data is used. (You can get a list of top exchanges for a given pair with topExchanges()
.)
const cc = require('cryptocompare')
cc.priceHistorical('BTC', ['USD', 'EUR'], new Date('2017-01-01'))
.then(prices => {
console.log(prices)
})
.catch(console.error)
generateAvg()
Compute the current trading info (price, vol, open, high, low etc) of the requested pair as a volume weighted average based on the markets requested.
generateAvg(fsym, tsym, markets[, tryConversion])
fsym
(String) From Symboltsym
(String) To Symbolmarkets
(Array) Array of markets to base the average on. (You can get a list of top exchanges for a given pair with topExchanges()
.)tryConversion
(Boolean) By default, if the crypto does not trade directly into the toSymbol requested, BTC will be used for conversion. Set tryConversion
to false
to disable using BTC for conversion.
const cc = require('cryptocompare')
cc.generateAvg('BTC', 'USD', ['Coinbase', 'Kraken', 'Bitstamp', 'Bitfinex'])
.then(data => {
console.log(data)
})
.catch(console.error)
topPairs()
Get top pairs by volume for a currency.
topPairs(fsym[, limit])
fsym
(String) From Symbollimit
(Number) Limit the number of pairs you receive (default 5).
const cc = require('cryptocompare')
cc.topPairs('BTC', 2)
.then(pairs => {
console.log(pairs)
})
.catch(console.error)
topExchanges()
Get top exchanges by volume for a currency pair.
topExchanges(fsym, tsym[, limit])
fsym
(String) From Symboltsym
(String) To Symbollimit
(Number) Limit the number of exchanges you receive (default 5).
const cc = require('cryptocompare')
cc.topExchanges('BTC', 'USD', 2)
.then(exchanges => {
console.log(exchanges)
})
.catch(console.error)
histoDay()
Get open, high, low, close, volumefrom and volumeto from the daily historical data. The values are based on 00:00 GMT time.
histoDay(fsym, tsym[, options])
fsym
(String) From Symboltsym
(String) To Symboloptions
(Object)
aggregate
(Number) Number of data points to aggregate.limit
(Number | 'none'
) Limit the number of days to lookup. Default is 30. If you set it to the string 'none'
, you will get all available data.tryConversion
(Boolean) By default, if the crypto does not trade directly into the toSymbol requested, BTC will be used for conversion. Set tryConversion
to false
to disable using BTC for conversion.timestamp
(Date) By default, histoDay()
gets historical data for the past several days. Use the timestamp
option to set a historical start point.exchange
(String) Exchange to get history data from. By default, average data is used. (You can get a list of top exchanges for a given pair with topExchanges()
.)
cc.histoDay('BTC', 'USD')
.then(data => {
console.log(data)
})
.catch(console.error)
histoHour()
Get open, high, low, close, volumefrom and volumeto from the hourly historical data.
histoHour(fsym, tsym[, options])
fsym
(String) From Symboltsym
(String) To Symboloptions
(Object)
aggregate
(Number) Number of data points to aggregate.limit
(Number) Limit the number of hours to lookup. Default is 168.tryConversion
(Boolean) By default, if the crypto does not trade directly into the toSymbol requested, BTC will be used for conversion. Set tryConversion
to false
to disable using BTC for conversion.timestamp
(Date) By default, histoHour()
gets historical data for the past several hours. Use the timestamp
option to set a historical start point.exchange
(String) Exchange to get history data from. By default, average data is used. (You can get a list of top exchanges for a given pair with topExchanges()
.)
cc.histoHour('BTC', 'USD')
.then(data => {
console.log(data)
})
.catch(console.error)
histoMinute()
Get open, high, low, close, volumefrom and volumeto from the minute-by-minute historical data.
histoMinute(fsym, tsym[, options])
fsym
(String) From Symboltsym
(String) To Symboloptions
(Object)
aggregate
(Number) Number of data points to aggregate.limit
(Number) Limit the number of minutes to lookup. Default is 1440.tryConversion
(Boolean) By default, if the crypto does not trade directly into the toSymbol requested, BTC will be used for conversion. Set tryConversion
to false
to disable using BTC for conversion.timestamp
(Date) By default, histoMinute()
gets historical data for the past several minutes. Use the timestamp
option to set a historical start point.exchange
(String) Exchange to get history data from. By default, average data is used. (You can get a list of top exchanges for a given pair with topExchanges()
.)
cc.histoMinute('BTC', 'USD')
.then(data => {
console.log(data)
})
.catch(console.error)
License
MIT