Разработка системы автоматического управления health factor

Проектируем и разрабатываем блокчейн-решения полного цикла: от архитектуры смарт-контрактов до запуска DeFi-протоколов, NFT-маркетплейсов и криптобирж. Аудит безопасности, токеномика, интеграция с существующей инфраструктурой.
Показано 1 из 1 услугВсе 1306 услуг
Разработка системы автоматического управления health factor
Сложная
~1-2 недели
Часто задаваемые вопросы
Направления блокчейн-разработки
Этапы блокчейн-разработки
Последние работы
  • 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

Разработка системы автоматического управления health factor

Пользователь открывает позицию в Aave: депозит 10 ETH, займ 8000 USDC. Health factor при ETH = $2000 составляет 1.56 — комфортная зона. ETH падает до $1400 за два дня. Health factor = 1.09. Liquidation threshold пройден при 1.0 — осталось 9% буфера. Без автоматики у пользователя три варианта: держать руку на пульсе 24/7, потерять позицию на ликвидации (штраф 5-15% в зависимости от актива), или заранее переплатить за избыточный collateral. Система автоматического управления health factor делает четвёртый вариант — автономный rebalacer, который держит позицию в безопасной зоне без участия пользователя.

Математика ликвидации в Aave V3

Что такое health factor технически

HF = (∑ collateral_i × price_i × liquidationThreshold_i) / totalDebt

Каждый актив в Aave V3 имеет свой liquidationThreshold (выражен в basis points, например ETH = 8250 = 82.5%). При HF < 1.0 позиция ликвидируема. Ликвидатор вызывает liquidationCall(), получает бонус liquidationBonus (для ETH = 10500 = 105% — то есть 5% premium сверх долга).

На практике ликвидации происходят раньше 1.0 — MEV-боты мониторят mempool и включают транзакцию в тот же блок, где цена оракула обновилась. Реальный безопасный порог — HF > 1.15-1.20 для волатильных активов.

Риск Chainlink oracle latency

Aave V3 использует Chainlink агрегаторы с heartbeat 1 час для большинства пар. Во время быстрого движения цены (flash crash) оракул может опаздывать до 30-60 минут. За это время on-chain цена ETH в Aave отличается от реальной биржевой на 5-10%. Это создаёт ситуацию, когда наша система видит HF = 1.25, но после следующего оракульного обновления HF мгновенно становится 0.95 и позиция ликвидируется.

Обработка этого сценария — один из ключевых инженерных вызовов. Наша система учитывает delta между текущей Chainlink ценой и ценой на Uniswap TWAP (30-минутный) как косвенный индикатор latency-риска.

Архитектура системы управления health factor

Три стратегии ребалансирования

Стратегия 1: Repay debt. При падении HF ниже target threshold система берёт средства из резервного буфера пользователя (заранее депонированные на контракт) и частично погашает долг через repay(). Просто, предсказуемо, без сложных операций. Минус: требует резервного капитала.

Стратегия 2: Add collateral. Депозит дополнительного collateral через supply(). Также требует резервов, но не уменьшает leverage пользователя. Подходит, когда цель — удержать размер займа неизменным.

Стратегия 3: Deleverage через flash loan. Самая сложная и наиболее капиталоэффективная. Берём flash loan (Aave V3 flashLoan или Uniswap V3 flash), погашаем часть долга, выводим часть collateral, возвращаем flash loan. Пользователь платит только комиссию (~0.05% Aave, 0.05% Uniswap V3), без необходимости держать резервный капитал.

// Упрощённая логика deleverage через Aave flash loan
function executeOperation(
    address[] calldata assets,
    uint256[] calldata amounts,
    uint256[] calldata premiums,
    address initiator,
    bytes calldata params
) external returns (bool) {
    // assets[0] = долговой токен (USDC)
    // amounts[0] = сумма к погашению
    
    // 1. Погашаем долг в Aave
    IPool(aavePool).repay(assets[0], amounts[0], 2, userAddress);
    
    // 2. Выводим эквивалентный collateral
    IPool(aavePool).withdraw(collateralAsset, collateralAmount, address(this));
    
    // 3. Свапаем collateral → долговой токен через Uniswap V3
    swapExactOutputSingle(collateralAsset, assets[0], amounts[0] + premiums[0]);
    
    // 4. Возвращаем flash loan + premium
    IERC20(assets[0]).approve(aavePool, amounts[0] + premiums[0]);
    return true;
}

Триггер-механизм: Chainlink Automation

Для мониторинга HF используем Chainlink Automation (бывший Keeper Network). checkUpkeep() читает текущий HF через IPool.getUserAccountData(), сравнивает с target threshold. Если HF < threshold — performUpkeep() вызывает нужную стратегию.

Важный нюанс: checkUpkeep() выполняется off-chain нодами Chainlink. Это значит, что внутри него можно делать дорогие вычисления без газа. Мы выносим всю математику выбора стратегии туда, а performUpkeep() получает уже готовые параметры через performData.

Альтернатива — собственный keeper bot. Дешевле при высоком объёме пользователей, но требует инфраструктуры (VPS, мониторинг uptime). Для B2C продуктов рекомендуем Chainlink — нет зависимости от нашего сервера.

Ролевая модель и безопасность

Контракт управляет позицией от имени пользователя через delegatecredit механизм Aave. Пользователь выдаёт approveDelegation() нашему контракту — тот может занимать от его имени, но не выводить токены напрямую. Это важное ограничение: даже при компрометации нашего контракта атакующий не может вывести collateral без отдельного шага.

// Пользователь один раз выполняет
IVariableDebtToken(vDebtToken).approveDelegation(
    address(autoManager), 
    type(uint256).max
);

Дополнительная защита: slippage guard на все свапы (максимум 0.5% deviation от TWAP), cooldown между ребалансами (минимум 5 минут, чтобы избежать gas drain атак), ограничение максимальной суммы операции за период.

Мультипротокольная поддержка

Протокол Тип данных HF Flash loan доступен Чейны
Aave V3 getUserAccountData() Да, 0.05% ETH, Polygon, Arbitrum, Optimism
Compound V3 getBorrowableOf() Через Uniswap ETH, Polygon, Arbitrum
Morpho позиция per-market Нет native ETH, Base

Система строится с абстракцией протокола: ILendingAdapter интерфейс позволяет добавлять новые протоколы без переписывания core логики.

Процесс работы

Аналитика (2-3 дня). Определяем протоколы, активы, target HF threshold, выбираем стратегию ребалансирования. Моделируем в Python сценарии: ETH -50% за 24 часа, flash crash до -80%, gradual decline. Проверяем, что система успевает среагировать при realistic Chainlink latency.

Разработка (5-7 дней). Core контракт, adapter для Aave V3/Compound, Chainlink Automation интеграция, fuzz-тесты на граничные значения HF. Fork-тесты на mainnet с реальными позициями через vm.prank.

Тестирование edge cases (2-3 дня). Симуляция: Chainlink оракул застыл на 2 часа, Aave pool paused, Uniswap V3 pool с низкой ликвидностью. Каждый сценарий — отдельный Foundry тест с fork.

Деплой (1-2 дня). Goerli/Sepolia с тестовыми Aave, затем mainnet через multisig.

Базовая система с одной стратегией и одним протоколом — 1-1.5 недели. Мультистратегия с мультипротокольной поддержкой и кастомным дашбордом — 2-3 недели. Стоимость рассчитывается после анализа требований.