Разработка API DEX-агрегатора

Проектируем и разрабатываем блокчейн-решения полного цикла: от архитектуры смарт-контрактов до запуска DeFi-протоколов, NFT-маркетплейсов и криптобирж. Аудит безопасности, токеномика, интеграция с существующей инфраструктурой.
Показано 1 из 1 услугВсе 1306 услуг
Разработка API DEX-агрегатора
Средняя
~3-5 рабочих дней
Часто задаваемые вопросы
Направления блокчейн-разработки
Этапы блокчейн-разработки
Последние работы
  • image_website-b2b-advance_0.png
    Разработка сайта компании B2B ADVANCE
    1221
  • image_web-applications_feedme_466_0.webp
    Разработка веб-приложения для компании FEEDME
    1163
  • image_websites_belfingroup_462_0.webp
    Разработка веб-сайта для компании БЕЛФИНГРУПП
    855
  • image_ecommerce_furnoro_435_0.webp
    Разработка интернет магазина для компании FURNORO
    1060
  • image_logo-advance_0.png
    Разработка логотипа компании B2B Advance
    561
  • image_crm_enviok_479_0.webp
    Разработка веб-приложения для компании Enviok
    828

Разработка API DEX-агрегатора

Проект приходит с простым запросом: «нам нужен свой агрегатор, как 1inch». За этим стоит не просто прокси к нескольким DEX — это полноценный routing engine, который должен за 200–400 мс найти оптимальный маршрут свапа по десяткам пулов, рассчитать slippage, price impact и вернуть котировку, которую можно исполнить без сюрпризов. Большинство команд недооценивают эту задачу и получают API, который даёт хорошие котировки на тестах, но теряет деньги пользователей на mainnet при высокой волатильности.

Где ломается routing-логика на практике

Stale quotes и race condition при исполнении

Самый частый источник проблем — разрыв между моментом получения котировки и моментом отправки транзакции. За 15–30 секунд, пока пользователь подтверждает свап в кошельке, состояние пула меняется. Если API не учитывает это и возвращает amountOutMin без адекватного slippage tolerance, транзакция либо ревертится (пользователь платит газ зря), либо исполняется по худшей цене.

Конкретный паттерн: агрегатор запрашивает резервы через getReserves() у Uniswap v2 пары, считает цену по формуле xy=k. Между запросом и деплоем транзакции в мемпул — 3 блока, в каждом крупный своп. amountOut расходится с реальностью на 1.5%. При slippageTolerance = 0.5% транзакция ревертится. Решение — короткий TTL котировок (5–10 секунд) и динамический slippage на основе исторической волатильности пары.

Неучтённые fee tiers в Uniswap v3

Uniswap v3 имеет пулы с разными fee tier: 0.01%, 0.05%, 0.3%, 1%. Для пары USDC/USDT ликвидность сосредоточена в 0.01% пуле. Если router по умолчанию берёт 0.3% пул — пользователь получает хуже цену и платит в 30 раз больше комиссии. Routing engine обязан проверять ликвидность во всех tier через PoolAddress.computeAddress и выбирать пул с лучшей глубиной относительно размера свапа.

Газ vs. цена: multi-hop не всегда выгоден

Маршрут A→B→C может давать на 0.3% лучшую цену, чем прямой A→C, но стоить на 80k газа дороже. При цене газа 30 gwei и свапе на $500 дополнительные $2.4 газа превращают выгоду в убыток. API должен считать net output с учётом стоимости газа и возвращать маршрут, оптимальный по итоговой сумме, а не только по цене свапа.

Как мы строим DEX-агрегатор API

Архитектура routing engine

Ядро системы — граф ликвидности. Нода — токен, ребро — пул с весом в виде effective exchange rate (с учётом fee). Алгоритм поиска пути: модифицированный Bellman-Ford для нахождения maximum output path (не shortest path). Для multi-hop до 3 хопов это работает за приемлемое время; для 4+ хопов используем эвристику с beam search.

Поддерживаемые источники ликвидности:

Протокол Версии Особенности интеграции
Uniswap v2, v3, v4 v3: все fee tiers; v4: hooks
Curve StableSwap, CryptoSwap Нелинейная AMM-формула
Balancer v2 WeightedPool, StablePool Многотокенные пулы
PancakeSwap v2, v3 BSC + Ethereum
SushiSwap v2 Мультичейн

Данные пулов синхронизируются через комбинацию The Graph subgraph (для исторических данных) и прямых on-chain вызовов через eth_call batch (для актуальных резервов). The Graph даёт latency ~500 мс — слишком медленно для real-time котировок. Поэтому критичные данные (reserves, sqrtPriceX96 для v3) кэшируются локально и обновляются через WebSocket подписку на события Swap, Mint, Burn.

Контрактная часть: smart order router

API возвращает не просто маршрут, а calldata для исполнения. Для мультихоп свапов через разные протоколы — собственный router-контракт, который батчит вызовы и обеспечивает атомарность. Если один шаг в цепочке ревертится — откатывается всё.

Контракт написан на Solidity 0.8.x с использованием delegatecall для вызовов адаптеров под каждый протокол. Адаптеры изолированы — добавление нового DEX не трогает основной router. Тесты через Foundry с fork mainnet: реальные пулы, реальные резервы, edge cases при низкой ликвидности.

Защита от MEV и sandwich атак

Котировка агрегатора — лакомый кусок для MEV-ботов. Если amountOutMin установлен слишком мягко, sandwich атака неизбежна: бот видит транзакцию в мемпуле, толкает цену вперёд, ваш свап проходит по худшей цене, бот откатывает. Контрмеры: amountOutMin по default = 99% от котировки (1% slippage), опциональная интеграция с Flashbots Protect или MEV Blocker для private mempool routing.

Процесс и сроки

Аналитика (1 день): список целевых DEX, чейны (Ethereum, Arbitrum, Base, BSC), требования к latency.

Разработка routing engine (2–3 дня): граф ликвидности, алгоритм поиска пути, кэш резервов.

Разработка router-контракта (1–2 дня): мультихоп адаптеры, тесты на fork.

REST/RPC API (1 день): endpoint /quote, /swap, rate limiting, документация.

Тестирование и оптимизация (1 день): нагрузочные тесты, latency профилирование.

Итого: 3–5 дней для базовой версии с 3–5 DEX на одном чейне. Мультичейн с 10+ источниками ликвидности — 2–3 недели. Стоимость рассчитывается после уточнения списка протоколов и чейнов.