Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/coinranking/exchanges
An open source JavaScript library for fetching tickers from cryptocurrency exchanges
https://github.com/coinranking/exchanges
altcoin binance bitcoin coin coinbase coinranking crypto cryptocurrencies cryptocurrency decentralized dex ethereum exchanges library markets ohlc prices tickers trading volume
Last synced: 2 months ago
JSON representation
An open source JavaScript library for fetching tickers from cryptocurrency exchanges
- Host: GitHub
- URL: https://github.com/coinranking/exchanges
- Owner: coinranking
- License: mit
- Created: 2019-08-01T08:46:13.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2024-04-22T10:32:21.000Z (9 months ago)
- Last Synced: 2024-04-22T11:42:04.147Z (9 months ago)
- Topics: altcoin, binance, bitcoin, coin, coinbase, coinranking, crypto, cryptocurrencies, cryptocurrency, decentralized, dex, ethereum, exchanges, library, markets, ohlc, prices, tickers, trading, volume
- Language: JavaScript
- Homepage: https://coinranking.com
- Size: 20.8 MB
- Stars: 118
- Watchers: 7
- Forks: 51
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- stars - coinranking/exchanges - An open source JavaScript library for fetching tickers from cryptocurrency exchanges (JavaScript)
README
[![code-style](https://img.shields.io/badge/code%20style-airbnb-brightgreen.svg?style=shield)](https://github.com/airbnb/javascript)
[![Commitizen friendly](https://img.shields.io/badge/commitizen-friendly-brightgreen.svg?style=shield)](http://commitizen.github.io/cz-cli/)
[![npm (scoped)](https://img.shields.io/npm/v/@coinranking/exchanges)](https://www.npmjs.com/package/@coinranking/exchanges)
[![codecov](https://img.shields.io/codecov/c/github/coinranking/exchanges/master.svg?style=shield)](https://codecov.io/gh/coinranking/exchanges)# Exchanges 📉📈
A JavaScript library for getting up to date cryptocurrency exchange tickers.
![](exchange.webp)
## Getting started
1. Node.js 14.0 or higher is required
2. Install using [NPM](https://www.npmjs.com/package/@coinranking/exchanges)## Installation
Coinranking Exchanges is a [Node.js](https://nodejs.org/) module available through the [npm registry](https://www.npmjs.com/package/@coinranking/exchanges).
Before installing, [download and install Node.js](https://nodejs.org/en/download/).
Node.js 14.0 or higher is required.Installation is done using the npm install command:
```shell
npm i @coinranking/exchanges
```## Usage
List all supported drivers
```JavaScript
const exchanges = require('@coinranking/exchanges');console.log(exchanges.list());
```Get the tickers of a specific exchange
```JavaScript
const { Binance } = require('@coinranking/exchanges');const driver = new Binance();
driver
.fetchTickers()
.then((tickers) => {
console.log(tickers);
});
```## Development
### Getting started
Install dependencies
```shell
npm install
```### Usage
#### List all supported drivers
```shell
node lib/cli.js list
```#### Get the tickers of a specific exchange
```shell
node lib/cli.js tickers [name of the exchange]
```##### Flags
| Name | Flag | Description
| ----------| ------------------------| ---
| Record | `-R`, `--record` | Record the requests, and save them as fixtures.
| API Key | `-k`, `--key` | For passing down an API key when the driver requires one. When used in combination with the `-R` flag the key will be masked in the fixtures.### Documentation
See the [documentation](DOCUMENTATION.md) for more information.
## Contributing
Bug reports and pull requests are welcome. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the Contributor Covenant code of conduct.
### Adding an exchange
1. Add a new driver (see the [examples](#examples))
2. Add the driver alphabetically to drivers/index.js
3. Add a new fixture (use the record option of the CLI 'tickers' command)Single API calls are highly preferred.
When adding an exchange be aware of the base and quote.
A driver should at least support `base`, `quote`, `close` and `baseVolume` or `quoteVolume`. And optionally `open`, `high`, `low`, `ask`, `bid`, `baseName`, `baseReference`, `quoteName` and `quoteReference`.### Listing requirements
Before we approve your pull request, we’d like to review the exchange and check if it meets our [listing requirements](https://support.coinranking.com/article/71-what-are-the-requirements-for-listing-an-exchange).
Ticking off all the boxes? Cool! Send us your listing request at [[email protected]](mailto:[email protected]) and include your daily trading volume + a link to your platform. We will then review your exchange ASAP.
### Examples
- [Driver basis:](examples/basicdriver.js) Shows the basic setup of a driver, which can be used as the starting point
for new ones.
- [Driver with API key:](examples/apikeydriver.js) Shows how to set up a driver that uses an API which requires a key.### Conventions
1. [Airbnb JavaScript Style Guide](https://github.com/airbnb/javascript)
2. [Conventional commits](https://www.conventionalcommits.org/en/v1.0.0-beta.4/)## Links
### Reach out to us
- [Telegram](https://t.me/CoinrankingOfficial)
- [Forum](https://community.coinranking.com/c/developers/20)
- [Twitter](https://twitter.com/coinranking)
- [[email protected]](mailto:[email protected])### Other
- [Coinranking API](https://coinranking.com/page/cryptocurrency-api)
- [API docs](https://docs.coinranking.com/)
- [Supplies library](https://github.com/coinranking/supplies)## License
[MIT](LICENSE)