Реализация просмотра доходности DeFi-позиций в мобильном кошельке

TRUETECH занимается разработкой, поддержкой и обслуживанием мобильных приложений iOS, Android, PWA. Имеем большой опыт и экспертизу для публикации мобильных приложений в популярные маркеты Google Play, App Store, Amazon, AppGallery и другие.
Разработка и поддержка любых видов мобильных приложений:
Информационные и развлекательные мобильные приложения
Новостные приложения, игры, справочники, онлайн-каталоги, погодные, фитнес и здоровье, туристические, образовательные, социальные сети и мессенджеры, квиз, блоги и подкасты, форумы, агрегаторы
Мобильные приложения электронной коммерции
Интернет-магазины, B2B-приложения, маркетплейсы, онлайн-обменники, кэшбэк-сервисы, биржи, дропшиппинг-платформы, программы лояльности, доставка еды и товаров, платежные системы
Мобильные приложения для управления бизнес-процессами
CRM-системы, ERP-системы, управление проектами, инструменты для команды продаж, учет финансов, управление производством, логистика и доставка, управление персоналом, системы мониторинга данных
Мобильные приложения электронных услуг
Доски объявлений, онлайн-школы, онлайн-кинотеатры, платформы предоставления электронных услуг, платформы кешбека, видеохостинги, тематические порталы, платформы онлайн-бронирования и записи, платформы онлайн-торговли

Это лишь некоторые из типы мобильных приложений, с которыми мы работаем, и каждый из них может иметь свои специфические особенности и функциональность, а также быть адаптированным под конкретные потребности и цели клиента.

Предлагаемые услуги
Показано 1 из 1 услугВсе 1735 услуг
Реализация просмотра доходности DeFi-позиций в мобильном кошельке
Средняя
~3-5 рабочих дней
Часто задаваемые вопросы
Наши компетенции:
Этапы разработки
Последние работы
  • image_mobile-applications_feedme_467_0.webp
    Разработка мобильного приложения для компании FEEDME
    756
  • image_mobile-applications_xoomer_471_0.webp
    Разработка мобильного приложения для компании XOOMER
    624
  • image_mobile-applications_rhl_428_0.webp
    Разработка мобильного приложения для компании RHL
    1054
  • image_mobile-applications_zippy_411_0.webp
    Разработка мобильного приложения для компании ZIPPY
    947
  • image_mobile-applications_affhome_429_0.webp
    Разработка мобильного приложения для компании Affhome
    862
  • image_mobile-applications_flavors_409_0.webp
    Разработка мобильного приложения для компании FLAVORS
    445

Реализация просмотра доходности DeFi-позиций в мобильном кошельке

DeFi-позиции — ликвидность в Uniswap v3, стейкинг в Lido, лендинг в Aave — у каждого протокола свои смарт-контракты, свои методы расчёта доходности и своя логика определения текущего баланса. Агрегировать это в единый экран «ваши позиции» без готового агрегатора сложно: нужно знать адреса контрактов каждого протокола, ABI-интерфейсы, формулы расчёта APY.

Источники данных для DeFi-позиций

DeFi Llama API — бесплатный агрегатор протоколов. Эндпоинт /tvl/{protocol} возвращает TVL, /yields — текущие APY по пулам. Хорошо подходит для отображения рыночных данных, но не даёт позиции конкретного адреса.

Zapper API / Zerion API — агрегаторы портфелей. Один запрос с адресом кошелька возвращает все DeFi-позиции по поддерживаемым протоколам с текущим балансом и P&L. Zerion поддерживает 400+ протоколов на 10+ сетях. Платные, но экономят месяц разработки.

Прямые вызовы смарт-контрактов через eth_call — для специфических протоколов или кастомных данных, которых нет в агрегаторах.

Читаем позицию напрямую из контракта: Aave v3

Для Aave v3 основной контракт — UiPoolDataProviderV3. Один eth_call возвращает все данные по всем резервам пользователя:

// Вызов через web3dart
final contract = DeployedContract(
  ContractAbi.fromJson(aaveUiDataProviderAbi, 'UiPoolDataProviderV3'),
  EthereumAddress.fromHex('0x91c0eA31b49B69Ea18607702c5d9aC360bf3dE7d'), // Ethereum mainnet
);

final result = await ethClient.call(
  contract: contract,
  function: contract.function('getUserReservesData'),
  params: [
    EthereumAddress.fromHex(poolAddressProvider), // Aave pool address provider
    EthereumAddress.fromHex(userAddress),
  ],
);

// result[0] — List<UserReserveData>: токен, currentATokenBalance, currentVariableDebt, ...

Структура UserReserveData содержит currentATokenBalance (сколько депозитировано с учётом накопленных процентов) и currentVariableDebt (переменный долг). APY вычисляется из liquidityRate резерва через формулу APY = (1 + liquidityRate/10^27 / secondsPerYear)^secondsPerYear - 1.

Uniswap v3: позиции с диапазоном цен

Uniswap v3 — сложнее, потому что каждая позиция — NFT с индивидуальным диапазоном концентрированной ликвидности. NFT-позиции хранятся в NonfungiblePositionManager (адрес 0xC36442b4a4522E871399CD717aBDD847Ab11FE88 на mainnet).

Для получения позиций пользователя нужно:

  1. balanceOf(userAddress) — количество NFT-позиций
  2. tokenOfOwnerByIndex(userAddress, index) — token IDs для каждой позиции
  3. positions(tokenId) — параметры позиции: token0/token1, fee tier, tickLower, tickUpper, liquidity

Расчёт текущего количества token0/token1 из liquidity и текущего sqrtPriceX96 — нетривиальная математика по формулам Uniswap v3 whitepaper. Правильнее использовать готовый @uniswap/v3-sdk на JS через WebView bridge или порт формул на Dart/Kotlin/Swift.

Проще: Uniswap Subgraph на The Graph возвращает position с уже посчитанным collectedFeesToken0, collectedFeesToken1, depositedToken0, depositedToken1.

Расчёт P&L по DeFi-позиции

P&L = (текущая стоимость позиции в USD) - (первоначально вложенная стоимость в USD)

Подводный камень: impermanent loss. Если вложили 1 ETH + 1000 USDC в пул на Uniswap v3, а ETH вырос — в пуле станет меньше ETH и больше USDC. Просто сравнить текущий баланс с начальным в USD недостаточно — нужно учитывать IL относительно hold-стратегии.

Для отображения P&L пользователю: показываем «fees earned» отдельно от «price change of underlying assets» — это понятнее, чем единое число P&L.

Обновление данных и кэширование

DeFi-данные меняются с каждым блоком (~12 секунд на Ethereum). Запрашивать их при каждом открытии экрана — достаточно, pull-to-refresh — стандартный UX-паттерн. Кэшировать с TTL 60 секунд: пользователи не ожидают real-time точности для лендинга.

Для стейкинга-позиций с медленным накоплением доходности (Lido stETH) — локально считаем накопленный yield по текущему APY и времени с последнего обновления, отображаем оптимистичную оценку без лишних запросов.

Что входит в работу

  • Выбор и интеграция источников данных (агрегаторы или прямые контракты)
  • Отображение позиций для приоритетных протоколов (Aave, Uniswap, Compound, Lido и др.)
  • Расчёт текущего баланса и APY
  • Отображение fees earned и P&L
  • Кэширование с правильным TTL
  • Поддержка нескольких сетей (Ethereum, Arbitrum, Optimism, Base)

Сроки

Интеграция через агрегатор (Zerion/Zapper) с отображением позиций: 1–2 недели. Прямая интеграция с 3–5 протоколами с кастомным расчётом P&L: 4–6 недель. Стоимость рассчитывается индивидуально.