Список монет
Ранжированные монеты с ценами, фильтрами и селекторами, с пагинацией через оболочку Laravel
links + meta. Цены, капитализация и circulating_supply — десятичные
строки; изменения и ранги — числа.
Ключи работают только как Bearer и несут право data-api — держите их на стороне сервера.
Параметры запроса
page
Номер страницы (с 1). Не менее 1.
per_page
Строк на страницу. Лимит зависит от тарифа (Free 100, Starter/Pro 250); превышение возвращает 422, а не обрезает значение. Не менее 1. Не более 100.
type
Ограничить одним типом актива: coin или token.
Одно из:
coin
token
status
Статус листинга: active, delisted, untracked, progressing, awaiting или preparing. По умолчанию все публичные статусы.
Одно из:
active
delisted
untracked
progressing
awaiting
preparing
search
Полнотекстовое совпадение по названию или символу. Не более 100 символов.
min_price
Только монеты с ценой не ниже этого значения в USD. Не менее 0.
max_price
Только монеты с ценой не выше этого значения в USD. Не менее 0.
min_marketcap
Только монеты с капитализацией в USD не ниже этого значения. Не менее 0.
max_marketcap
Только монеты с капитализацией в USD не выше этого значения. Не менее 0.
min_volume
Только монеты с объёмом за 24 часа в USD не ниже этого значения. Не менее 0.
max_volume
Только монеты с объёмом за 24 часа в USD не выше этого значения. Не менее 0.
ids
Фильтр по конкретным идентификаторам монет (CSV, до 100 селекторов вместе со slugs/symbols). Не более 1000 символов.
slugs
Фильтр по конкретным слагам монет (CSV, до 100 селекторов в сумме). Не более 2000 символов.
symbols
Фильтр по конкретным символам монет (CSV, без учёта регистра, до 100 селекторов в сумме). Не более 1000 символов.
sort
Поля сортировки через запятую; префикс - для убывания. Доступны: marketcap, rank, price, volume_24h, change_24h, change_7d. Не более 100 символов.
interval
Окно движений только для /coins/gainers и /coins/losers: 24h или 7d.
Одно из:
24h
7d
Запрос
curl --request GET \ --get "http://localhost/api/v1/coins?page=1&per_page=50&type=coin&status=active&search=bitcoin&min_price=0.5&max_price=100000&min_marketcap=1000000&max_marketcap=5000000000000&min_volume=1000000&max_volume=100000000000&ids=38%2C39&slugs=bitcoin%2Cethereum&symbols=BTC%2CETH&sort=-marketcap&interval=24h" \ --header "Authorization: Bearer {YOUR_API_KEY}" \ --header "Content-Type: application/json" \ --header "Accept: application/json"
const url = new URL( "http://localhost/api/v1/coins" ); const params = { "page": "1", "per_page": "50", "type": "coin", "status": "active", "search": "bitcoin", "min_price": "0.5", "max_price": "100000", "min_marketcap": "1000000", "max_marketcap": "5000000000000", "min_volume": "1000000", "max_volume": "100000000000", "ids": "38,39", "slugs": "bitcoin,ethereum", "symbols": "BTC,ETH", "sort": "-marketcap", "interval": "24h", }; Object.keys(params) .forEach(key => url.searchParams.append(key, params[key])); const headers = { "Authorization": "Bearer {YOUR_API_KEY}", "Content-Type": "application/json", "Accept": "application/json", }; fetch(url, { method: "GET", headers, }).then(response => response.json());
$client = new \GuzzleHttp\Client(); $url = 'http://localhost/api/v1/coins'; $response = $client->get( $url, [ 'headers' => [ 'Authorization' => 'Bearer {YOUR_API_KEY}', 'Content-Type' => 'application/json', 'Accept' => 'application/json', ], 'query' => [ 'page' => '1', 'per_page' => '50', 'type' => 'coin', 'status' => 'active', 'search' => 'bitcoin', 'min_price' => '0.5', 'max_price' => '100000', 'min_marketcap' => '1000000', 'max_marketcap' => '5000000000000', 'min_volume' => '1000000', 'max_volume' => '100000000000', 'ids' => '38,39', 'slugs' => 'bitcoin,ethereum', 'symbols' => 'BTC,ETH', 'sort' => '-marketcap', 'interval' => '24h', ], ] ); $body = $response->getBody(); print_r(json_decode((string) $body));
import requests import json url = 'http://localhost/api/v1/coins' params = { 'page': '1', 'per_page': '50', 'type': 'coin', 'status': 'active', 'search': 'bitcoin', 'min_price': '0.5', 'max_price': '100000', 'min_marketcap': '1000000', 'max_marketcap': '5000000000000', 'min_volume': '1000000', 'max_volume': '100000000000', 'ids': '38,39', 'slugs': 'bitcoin,ethereum', 'symbols': 'BTC,ETH', 'sort': '-marketcap', 'interval': '24h', } headers = { 'Authorization': 'Bearer {YOUR_API_KEY}', 'Content-Type': 'application/json', 'Accept': 'application/json' } response = requests.request('GET', url, headers=headers, params=params) response.json()