@merkl/api 0.21.46 → 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/src/cache/index.d.ts +1 -1
- package/dist/src/constants.d.ts +8 -8
- package/dist/src/eden/index.d.ts +16937 -8167
- package/dist/src/eden/index.js +1 -1
- package/dist/src/engine/deprecated/dynamicData/implementations/Ajna.d.ts +1 -1
- package/dist/src/engine/deprecated/dynamicData/implementations/Badger.d.ts +1 -1
- package/dist/src/engine/deprecated/dynamicData/implementations/Clamm.d.ts +1 -1
- package/dist/src/engine/deprecated/dynamicData/implementations/Compound.d.ts +1 -1
- package/dist/src/engine/deprecated/dynamicData/implementations/CompoundV3.d.ts +1 -1
- package/dist/src/engine/deprecated/dynamicData/implementations/Dolomite.d.ts +1 -1
- package/dist/src/engine/deprecated/dynamicData/implementations/ERC721.d.ts +2 -2
- package/dist/src/engine/deprecated/dynamicData/implementations/ERCMultiToken.d.ts +2 -2
- package/dist/src/engine/deprecated/dynamicData/implementations/EigenLayer.d.ts +1 -1
- package/dist/src/engine/deprecated/dynamicData/implementations/Encompassing.d.ts +1 -1
- package/dist/src/engine/deprecated/dynamicData/implementations/Erc20.d.ts +105 -3
- package/dist/src/engine/deprecated/dynamicData/implementations/Erc20Snapshot.d.ts +1 -1
- package/dist/src/engine/deprecated/dynamicData/implementations/EventBased.d.ts +1 -1
- package/dist/src/engine/deprecated/dynamicData/implementations/Hyperdrive.d.ts +2 -2
- package/dist/src/engine/deprecated/dynamicData/implementations/Morpho.d.ts +1 -1
- package/dist/src/engine/deprecated/dynamicData/implementations/Radiant.d.ts +1 -1
- package/dist/src/engine/deprecated/dynamicData/implementations/Silo.d.ts +1 -1
- package/dist/src/engine/deprecated/dynamicData/implementations/UniswapV4.d.ts +1 -1
- package/dist/src/engine/deprecated/dynamicData/implementations/Vest.d.ts +1 -1
- package/dist/src/engine/deprecated/dynamicData/implementations/default.d.ts +2 -2
- package/dist/src/engine/deprecated/dynamicData/utils/fetchA51Strategies.d.ts +1 -1
- package/dist/src/engine/deprecated/dynamicData/utils/fetchClamInfo.d.ts +1 -1
- package/dist/src/engine/deprecated/dynamicData/utils/fetchLogs.d.ts +1 -1
- package/dist/src/engine/deprecated/dynamicData/utils/getCompV2ForksVaults.d.ts +1 -1
- package/dist/src/engine/deprecated/dynamicData/utils/getDolomiteMarkets.d.ts +1 -1
- package/dist/src/engine/deprecated/dynamicData/utils/getEulerV2Vaults.d.ts +1 -1
- package/dist/src/engine/deprecated/dynamicData/utils/getFixedApr.d.ts +1 -1
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/GenericProcessor.d.ts +6 -6
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/helpers/factoryFinder.d.ts +1 -1
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/helpers/hardcoded.d.ts +2 -2
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/helpers/ownerFinder.d.ts +1 -1
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/helpers/treasuryFinder.d.ts +1 -1
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/AaveProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/AnglesLiquid.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/AssetProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/AuraProcessor.d.ts +4 -4
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/BEXRewardGaugeProcessor.d.ts +4 -4
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/BalancerGaugeProcessor.d.ts +4 -4
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/BalancerPoolProcessor.d.ts +4 -4
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/BalancerV3PoolProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/BeefyProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/BunniV2Processor.d.ts +4 -4
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/CompoundProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/ERC4626Processor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/EnzymeProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/EqualizerGaugeProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/EulerBorrowProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/EulerLendProcessor.d.ts +2 -2
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/FluidProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/FraxProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/GammaALMProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/GammaProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/GearboxProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/HanjiVaultProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/HoldStationProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/HourglassProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/MaverickBPProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/MetamorphoProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/NoLinkVaultProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/PendleProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/PendleYTProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/RadiantProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/RfxProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/Satlayer.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/SpectraProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/SpectraYTProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/SpliceProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/StabilityProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/SturdySiloProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/TempestVaultProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/TemplateProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/TorosProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/UniswapProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/VicunaProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/WoofiProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/ZkSwapThreePoolProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/curveNPoolProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/curveProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/processorMapping.d.ts +1 -1
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/stakedCurveProcessor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/xU308Processor.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/subtypesPrices.d.ts +3 -3
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/subtypesRound1.d.ts +1 -1
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/subtypesRound2.d.ts +2 -2
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/subtypesRound3.d.ts +2 -2
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/subtypesRound4.d.ts +2 -2
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/tokenTypeStruct.d.ts +2 -2
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/tokenTypeToProtocolAndAction.d.ts +3 -3
- package/dist/src/engine/implementations/Ajna/metadata.d.ts +5 -5
- package/dist/src/engine/implementations/Ajna/tvl.d.ts +2 -2
- package/dist/src/engine/implementations/Ambient/metadata.d.ts +5 -5
- package/dist/src/engine/implementations/Ambient/tvl.d.ts +2 -2
- package/dist/src/engine/implementations/Badger/metadata.d.ts +4 -4
- package/dist/src/engine/implementations/Clamm/metadata.d.ts +22 -22
- package/dist/src/engine/implementations/Compound/metadata.d.ts +4 -4
- package/dist/src/engine/implementations/CompoundV3/metadata.d.ts +4 -4
- package/dist/src/engine/implementations/Default/metadata.d.ts +3 -3
- package/dist/src/engine/implementations/Dolomite/metadata.d.ts +5 -5
- package/dist/src/engine/implementations/EigenLayer/metadata.d.ts +5 -5
- package/dist/src/engine/implementations/EigenLayer/tvl.d.ts +2 -2
- package/dist/src/engine/implementations/Encompassing/metadata.d.ts +3 -3
- package/dist/src/engine/implementations/Erc20/metadata.d.ts +4 -4
- package/dist/src/engine/implementations/Erc20/subTypes/detect.d.ts +2 -2
- package/dist/src/engine/implementations/Erc20/subTypes/factories.d.ts +4 -4
- package/dist/src/engine/implementations/Erc20/subTypes/implementations/aave/metadata.d.ts +6 -6
- package/dist/src/engine/implementations/Erc20/subTypes/implementations/aave/tvl.d.ts +4 -4
- package/dist/src/engine/implementations/Erc20/subTypes/implementations/euler/metadata.d.ts +6 -6
- package/dist/src/engine/implementations/Erc20/subTypes/implementations/euler/tvl.d.ts +2 -2
- package/dist/src/engine/implementations/Erc20/subTypes/implementations/gearbox/metadata.d.ts +5 -5
- package/dist/src/engine/implementations/Erc20/subTypes/implementations/gearbox/tvl.d.ts +4 -4
- package/dist/src/engine/implementations/Erc20/subTypes/implementations/hypurrfiIsolatedMarket/metadata.d.ts +6 -6
- package/dist/src/engine/implementations/Erc20/subTypes/implementations/hypurrfiIsolatedMarket/tvl.d.ts +4 -4
- package/dist/src/engine/implementations/Erc20/subTypes/implementations/lendleVaults/metadata.d.ts +5 -5
- package/dist/src/engine/implementations/Erc20/subTypes/implementations/lendleVaults/tvl.d.ts +4 -4
- package/dist/src/engine/implementations/Erc20/subTypes/implementations/metamorpho/metadata.d.ts +17 -0
- package/dist/src/engine/implementations/Erc20/subTypes/implementations/metamorpho/tvl.d.ts +6 -0
- package/dist/src/engine/implementations/Erc20/subTypes/implementations/pino/metadata.d.ts +4 -4
- package/dist/src/engine/implementations/Erc20/subTypes/implementations/pino/tvl.d.ts +4 -4
- package/dist/src/engine/implementations/Erc20/subTypes/implementations/termmax/metadata.d.ts +5 -5
- package/dist/src/engine/implementations/Erc20/subTypes/implementations/termmax/tvl.d.ts +4 -4
- package/dist/src/engine/implementations/Erc20/subTypes/implementations/termmaxVault/metadata.d.ts +18 -0
- package/dist/src/engine/implementations/Erc20/subTypes/implementations/termmaxVault/tvl.d.ts +6 -0
- package/dist/src/engine/implementations/Erc20/subTypes/implementations/uniswapV2/metadata.d.ts +5 -5
- package/dist/src/engine/implementations/Erc20/subTypes/implementations/uniswapV2/tvl.d.ts +4 -4
- package/dist/src/engine/implementations/Erc20/subTypes/index.d.ts +3 -2
- package/dist/src/engine/implementations/Erc20/tvl.d.ts +4 -4
- package/dist/src/engine/implementations/Erc20Snapshot/metadata.d.ts +4 -4
- package/dist/src/engine/implementations/Erc721/metadata.d.ts +4 -4
- package/dist/src/engine/implementations/ErcMultiToken/metadata.d.ts +6 -6
- package/dist/src/engine/implementations/EventBased/metadata.d.ts +5 -5
- package/dist/src/engine/implementations/FraxLend/metadataBorrow.d.ts +24 -0
- package/dist/src/engine/implementations/FraxLend/metadataCollateral.d.ts +18 -0
- package/dist/src/engine/implementations/FraxLend/tvlBorrow.d.ts +7 -0
- package/dist/src/engine/implementations/FraxLend/tvlCollateral.d.ts +7 -0
- package/dist/src/engine/implementations/Hyperdrive/metadata.d.ts +5 -5
- package/dist/src/engine/implementations/Invalid/metadata.d.ts +2 -2
- package/dist/src/engine/implementations/Ion/metadata.d.ts +5 -5
- package/dist/src/engine/implementations/JsonAirdrop/metadata.d.ts +7 -7
- package/dist/src/engine/implementations/Locker/metadata.d.ts +5 -5
- package/dist/src/engine/implementations/Locker/tvl.d.ts +2 -2
- package/dist/src/engine/implementations/Morpho/metadata.d.ts +7 -7
- package/dist/src/engine/implementations/MultiLog/metadata.d.ts +4 -4
- package/dist/src/engine/implementations/MultiLog/tvl.d.ts +3 -3
- package/dist/src/engine/implementations/Radiant/metadata.d.ts +4 -4
- package/dist/src/engine/implementations/Silo/metadata.d.ts +5 -5
- package/dist/src/engine/implementations/UniswapV4/metadata.d.ts +5 -5
- package/dist/src/engine/implementations/UniswapV4/tvl.d.ts +2 -2
- package/dist/src/engine/implementations/Vest/metadata.d.ts +4 -4
- package/dist/src/engine/implementations/morphoBorrow/metadata.d.ts +20 -0
- package/dist/src/engine/implementations/morphoBorrow/tvl.d.ts +7 -0
- package/dist/src/engine/implementations/morphoCollateral/metadata.d.ts +20 -0
- package/dist/src/engine/implementations/morphoCollateral/tvl.d.ts +7 -0
- package/dist/src/engine/implementations/morphoSupply/metadata.d.ts +20 -0
- package/dist/src/engine/implementations/morphoSupply/tvl.d.ts +7 -0
- package/dist/src/engine/metadata/factory.d.ts +1 -1
- package/dist/src/engine/tvl/factory.d.ts +2 -2
- package/dist/src/engine/tvl/logStates.d.ts +1 -1
- package/dist/src/hooks/checkQueryAddressValidity.d.ts +6 -2
- package/dist/src/hooks/checkQueryChainIdValidity.d.ts +6 -2
- package/dist/src/index.d.ts +5548 -2626
- package/dist/src/jobs/{dynamic-data.d.ts → update-v3-caches.d.ts} +4 -1
- package/dist/src/libs/computeFee.d.ts +1 -1
- package/dist/src/libs/deprecated-merklv3/index.d.ts +3 -3
- package/dist/src/libs/merklChainData.d.ts +1 -1
- package/dist/src/libs/parse/marketsWithCache.d.ts +1 -1
- package/dist/src/libs/positions/EigenLayer/index.d.ts +2 -2
- package/dist/src/libs/positions/ajna/index.d.ts +2 -2
- package/dist/src/libs/positions/badger/index.d.ts +2 -2
- package/dist/src/libs/positions/clamm/index.d.ts +1 -1
- package/dist/src/libs/positions/clamm/thegraph/fetchAlmPositions.d.ts +1 -1
- package/dist/src/libs/positions/clamm/thegraph/fetchAmmPositions.d.ts +1 -1
- package/dist/src/libs/positions/clamm/thegraph/fetchFarmedPositions.d.ts +1 -1
- package/dist/src/libs/positions/compound/index.d.ts +2 -2
- package/dist/src/libs/positions/dolomite/index.d.ts +2 -2
- package/dist/src/libs/positions/erc20/index.d.ts +2 -2
- package/dist/src/libs/positions/euler/index.d.ts +2 -2
- package/dist/src/libs/positions/index.d.ts +1 -1
- package/dist/src/libs/positions/morpho/index.d.ts +2 -2
- package/dist/src/libs/positions/prepareFetch.d.ts +1 -1
- package/dist/src/libs/positions/silo/index.d.ts +2 -2
- package/dist/src/libs/positions/types.d.ts +1 -1
- package/dist/src/libs/staticCampaigns.d.ts +1 -1
- package/dist/src/libs/tokens/balances.d.ts +1 -1
- package/dist/src/libs/tokens/tokenInfo.d.ts +1 -1
- package/dist/src/modules/v4/accounting/accounting.controller.d.ts +98 -33
- package/dist/src/modules/v4/accounting/accounting.repository.d.ts +41 -41
- package/dist/src/modules/v4/accounting/accounting.service.d.ts +7 -7
- package/dist/src/modules/v4/apr/apr.model.d.ts +8 -8
- package/dist/src/modules/v4/apr/apr.service.d.ts +1 -1
- package/dist/src/modules/v4/authentication/authentication.controller.d.ts +24 -2
- package/dist/src/modules/v4/blacklist/blacklist.controller.d.ts +64 -37
- package/dist/src/modules/v4/blacklist/blacklist.repository.d.ts +4 -4
- package/dist/src/modules/v4/blacklist/blacklist.service.d.ts +5 -5
- package/dist/src/modules/v4/boost/boost.controller.d.ts +25 -3
- package/dist/src/modules/v4/cache/cache.repository.d.ts +1 -1
- package/dist/src/modules/v4/cache/cache.service.d.ts +1 -1
- package/dist/src/modules/v4/campaign/campaign.controller.d.ts +665 -504
- package/dist/src/modules/v4/campaign/campaign.model.d.ts +30 -9
- package/dist/src/modules/v4/campaign/campaign.repository.d.ts +191 -191
- package/dist/src/modules/v4/campaign/campaign.service.d.ts +415 -319
- package/dist/src/modules/v4/campaign/campaign.test.controller.d.ts +352 -282
- package/dist/src/modules/v4/chain/chain.controller.d.ts +91 -47
- package/dist/src/modules/v4/chain/chain.model.d.ts +11 -3
- package/dist/src/modules/v4/chain/chain.repository.d.ts +10 -10
- package/dist/src/modules/v4/chain/chain.service.d.ts +10 -10
- package/dist/src/modules/v4/chainInteraction/chainInteraction.service.d.ts +1 -1
- package/dist/src/modules/v4/claims/claims.controller.d.ts +15 -2
- package/dist/src/modules/v4/claims/claims.repository.d.ts +1 -1
- package/dist/src/modules/v4/claims/claims.service.d.ts +3 -3
- package/dist/src/modules/v4/computedValue/computedValue.controller.d.ts +47 -7
- package/dist/src/modules/v4/computedValue/computedValue.repository.d.ts +2 -2
- package/dist/src/modules/v4/computedValue/computedValue.service.d.ts +2 -2
- package/dist/src/modules/v4/creator/creator.controller.d.ts +160 -88
- package/dist/src/modules/v4/creator/creator.model.d.ts +1 -1
- package/dist/src/modules/v4/creator/creator.repository.d.ts +20 -20
- package/dist/src/modules/v4/creator/creator.service.d.ts +47 -47
- package/dist/src/modules/v4/dynamicData/dynamicData.model.d.ts +1 -1
- package/dist/src/modules/v4/dynamicData/dynamicData.service.d.ts +1 -1
- package/dist/src/modules/v4/enso/enso.service.d.ts +17 -17
- package/dist/src/modules/v4/explorer/explorer.controller.d.ts +19 -6
- package/dist/src/modules/v4/explorer/explorer.model.d.ts +2 -2
- package/dist/src/modules/v4/explorer/explorer.repository.d.ts +5 -5
- package/dist/src/modules/v4/explorer/explorer.service.d.ts +7 -7
- package/dist/src/modules/v4/interaction/interaction.controller.d.ts +39 -8
- package/dist/src/modules/v4/interaction/interaction.model.d.ts +1 -1
- package/dist/src/modules/v4/interaction/interaction.service.d.ts +2 -2
- package/dist/src/modules/v4/kyberzap/kyberzap.service.d.ts +1 -1
- package/dist/src/modules/v4/liquidity/implementations/AjnaPositionFetcher.d.ts +2 -2
- package/dist/src/modules/v4/liquidity/implementations/BadgerPositionFetcher.d.ts +2 -2
- package/dist/src/modules/v4/liquidity/implementations/ClammPositionFetcher.d.ts +2 -2
- package/dist/src/modules/v4/liquidity/implementations/DolomitePositionFetcher.d.ts +2 -2
- package/dist/src/modules/v4/liquidity/implementations/ERC20PositionFetcher.d.ts +3 -3
- package/dist/src/modules/v4/liquidity/implementations/EulerPositionFetcher.d.ts +2 -2
- package/dist/src/modules/v4/liquidity/liquidity.controller.d.ts +24 -13
- package/dist/src/modules/v4/liquidity/liquidity.model.d.ts +2 -2
- package/dist/src/modules/v4/liquidity/liquidity.repository.d.ts +1 -1
- package/dist/src/modules/v4/merklRoot/merklRoot.controller.d.ts +42 -22
- package/dist/src/modules/v4/merklRoot/merklRoot.repository.d.ts +7 -7
- package/dist/src/modules/v4/merklRoot/merklRoot.service.d.ts +18 -8
- package/dist/src/modules/v4/nodes/node.controller.d.ts +65 -0
- package/dist/src/modules/v4/nodes/node.model.d.ts +21 -0
- package/dist/src/modules/v4/nodes/node.repository.d.ts +21 -0
- package/dist/src/modules/v4/nodes/node.service.d.ts +21 -0
- package/dist/src/modules/v4/opportunity/opportunity.controller.d.ts +743 -644
- package/dist/src/modules/v4/opportunity/opportunity.converter.d.ts +111 -5
- package/dist/src/modules/v4/opportunity/opportunity.model.d.ts +116 -81
- package/dist/src/modules/v4/opportunity/opportunity.repository.d.ts +408 -408
- package/dist/src/modules/v4/opportunity/opportunity.service.d.ts +489 -459
- package/dist/src/modules/v4/parse/parse.controller.d.ts +64 -0
- package/dist/src/modules/v4/parse/parse.model.d.ts +10 -0
- package/dist/src/modules/v4/payload/payload.controller.d.ts +125 -0
- package/dist/src/modules/v4/payload/payload.model.d.ts +307 -0
- package/dist/src/modules/v4/payload/payload.service.d.ts +27 -0
- package/dist/src/modules/v4/price/price.controller.d.ts +93 -50
- package/dist/src/modules/v4/price/price.model.d.ts +16 -16
- package/dist/src/modules/v4/price/price.repository.d.ts +11 -11
- package/dist/src/modules/v4/price/price.service.d.ts +9 -9
- package/dist/src/modules/v4/prisma/index.d.ts +1 -1
- package/dist/src/modules/v4/programPayload/programPayload.controller.d.ts +939 -146
- package/dist/src/modules/v4/programPayload/programPayload.model.d.ts +12 -14
- package/dist/src/modules/v4/programPayload/programPayload.repository.d.ts +451 -362
- package/dist/src/modules/v4/programPayload/programPayload.service.d.ts +40 -19
- package/dist/src/modules/v4/protocol/protocol.controller.d.ts +117 -67
- package/dist/src/modules/v4/protocol/protocol.model.d.ts +2 -2
- package/dist/src/modules/v4/protocol/protocol.repository.d.ts +29 -29
- package/dist/src/modules/v4/protocol/protocol.service.d.ts +9 -6
- package/dist/src/modules/v4/referral/referral.controller.d.ts +29 -7
- package/dist/src/modules/v4/referral/referral.service.d.ts +8 -8
- package/dist/src/modules/v4/reward/reward.controller.d.ts +261 -93
- package/dist/src/modules/v4/reward/reward.converter.d.ts +1 -1
- package/dist/src/modules/v4/reward/reward.model.d.ts +3 -3
- package/dist/src/modules/v4/reward/reward.repository.d.ts +55 -54
- package/dist/src/modules/v4/reward/reward.service.d.ts +260 -260
- package/dist/src/modules/v4/router.d.ts +4706 -2394
- package/dist/src/modules/v4/status/status.controller.d.ts +127 -64
- package/dist/src/modules/v4/status/status.model.d.ts +10 -10
- package/dist/src/modules/v4/status/status.repository.d.ts +35 -35
- package/dist/src/modules/v4/status/status.service.d.ts +23 -23
- package/dist/src/modules/v4/token/token.controller.d.ts +224 -130
- package/dist/src/modules/v4/token/token.model.d.ts +1 -1
- package/dist/src/modules/v4/token/token.repository.d.ts +41 -37
- package/dist/src/modules/v4/token/token.service.d.ts +106 -101
- package/dist/src/modules/v4/turtle/turtle.controller.d.ts +15 -2
- package/dist/src/modules/v4/tvl/tvl.model.d.ts +5 -5
- package/dist/src/modules/v4/tvl/tvl.service.d.ts +1 -1
- package/dist/src/modules/v4/uniswap/uniswap.controller.d.ts +248 -11
- package/dist/src/modules/v4/uniswap/uniswap.model.d.ts +3 -3
- package/dist/src/modules/v4/uniswap/uniswap.repository.d.ts +4 -4
- package/dist/src/modules/v4/uniswap/uniswap.service.d.ts +3 -3
- package/dist/src/modules/v4/user/user.controller.d.ts +175 -164
- package/dist/src/modules/v4/user/user.model.d.ts +10 -1
- package/dist/src/modules/v4/user/user.repository.d.ts +7 -7
- package/dist/src/modules/v4/user/user.service.d.ts +7 -7
- package/dist/src/plugins/error-handling.plugin.d.ts +7 -3
- package/dist/src/routes/v1/allowances.d.ts +18 -5
- package/dist/src/routes/v1/balances.d.ts +16 -3
- package/dist/src/routes/v1/prices.d.ts +15 -2
- package/dist/src/routes/v1/router.d.ts +44 -4
- package/dist/src/routes/v1/tokens.d.ts +15 -2
- package/dist/src/routes/v2/merkl.d.ts +41 -4
- package/dist/src/routes/v2/router.d.ts +41 -4
- package/dist/src/routes/v3/app.d.ts +15 -2
- package/dist/src/routes/v3/blacklist.d.ts +15 -2
- package/dist/src/routes/v3/campaign/delay.d.ts +27 -16
- package/dist/src/routes/v3/campaignClaims.d.ts +15 -2
- package/dist/src/routes/v3/campaignUnclaimed.d.ts +15 -2
- package/dist/src/routes/v3/campaigns.d.ts +17 -4
- package/dist/src/routes/v3/campaignsForMainParameter.d.ts +15 -2
- package/dist/src/routes/v3/campaignsRewardsReport.d.ts +15 -2
- package/dist/src/routes/v3/claims.d.ts +15 -2
- package/dist/src/routes/v3/compoundV2.d.ts +15 -2
- package/dist/src/routes/v3/createCampaign.d.ts +16 -3
- package/dist/src/routes/v3/dolomite.d.ts +15 -2
- package/dist/src/routes/v3/euler.d.ts +43 -14
- package/dist/src/routes/v3/fetch.d.ts +15 -2
- package/dist/src/routes/v3/health.d.ts +15 -2
- package/dist/src/routes/v3/lostyield.d.ts +15 -2
- package/dist/src/routes/v3/merkl.d.ts +34 -6
- package/dist/src/routes/v3/morphoMarkets.d.ts +15 -2
- package/dist/src/routes/v3/morphoVaults.d.ts +15 -2
- package/dist/src/routes/v3/multiChainPositions.d.ts +15 -2
- package/dist/src/routes/v3/opportunity.d.ts +72 -6
- package/dist/src/routes/v3/overview.d.ts +15 -2
- package/dist/src/routes/v3/parse.d.ts +15 -2
- package/dist/src/routes/v3/payload.d.ts +19 -6
- package/dist/src/routes/v3/poolInfo.d.ts +18 -5
- package/dist/src/routes/v3/positions.d.ts +15 -2
- package/dist/src/routes/v3/radiant.d.ts +15 -2
- package/dist/src/routes/v3/recipients.d.ts +15 -2
- package/dist/src/routes/v3/rewards.d.ts +18 -5
- package/dist/src/routes/v3/rewardsReport.d.ts +16 -3
- package/dist/src/routes/v3/router.d.ts +608 -55
- package/dist/src/routes/v3/silo.d.ts +15 -2
- package/dist/src/routes/v3/token.d.ts +16 -3
- package/dist/src/routes/v3/twt/participants.d.ts +24 -13
- package/dist/src/routes/v3/uniswapv4.d.ts +192 -19
- package/dist/src/routes/v3/updates.d.ts +15 -2
- package/dist/src/routes/v3/userRewards.d.ts +18 -5
- package/dist/src/utils/decodeCalls.d.ts +1 -1
- package/dist/src/utils/encodeCalls.d.ts +2 -2
- package/dist/src/utils/error.d.ts +8 -4
- package/dist/src/utils/generateCardName.d.ts +2 -2
- package/dist/src/utils/generic.d.ts +2 -2
- package/dist/src/utils/lastBlockBefore.d.ts +1 -1
- package/dist/src/utils/logger.d.ts +0 -8
- package/dist/src/utils/pricer.d.ts +1 -1
- package/dist/src/utils/prices/chainlinkRead.d.ts +1 -1
- package/dist/src/utils/prices/curveVirtualPrice.d.ts +1 -1
- package/dist/src/utils/prices/getDQUICK.d.ts +1 -1
- package/dist/src/utils/prices/priceFetcherFactory.d.ts +1 -1
- package/dist/src/utils/prices/services/OnChainCallService.d.ts +1 -1
- package/dist/src/utils/prices/services/coinGeckoService.d.ts +1 -1
- package/dist/src/utils/prices/services/defillamaService.d.ts +1 -1
- package/dist/src/utils/prices/services/dexScreenerService.d.ts +1 -1
- package/dist/src/utils/prices/services/erc4626Service.d.ts +1 -1
- package/dist/src/utils/prices/services/getERC4626.d.ts +1 -1
- package/dist/src/utils/prices/services/indexCoopService.d.ts +1 -1
- package/dist/src/utils/prices/services/priceFetcher.d.ts +1 -1
- package/dist/src/utils/prices/uniV2Price.d.ts +1 -1
- package/dist/src/utils/providers.d.ts +113 -2
- package/dist/src/utils/queries/allCampaigns.d.ts +1 -2
- package/dist/src/utils/sanitizeChain.d.ts +2 -2
- package/dist/src/utils/stryke.d.ts +1 -1
- package/dist/src/utils/throw.d.ts +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/package.json +28 -48
- package/dist/database/api/.generated/default.d.ts +0 -1
- package/dist/database/api/.generated/default.js +0 -1
- package/dist/database/api/.generated/drizzle/schema.d.ts +0 -3342
- package/dist/database/api/.generated/drizzle/schema.js +0 -928
- package/dist/database/api/.generated/drizzle/schema.ts +0 -989
- package/dist/database/api/.generated/edge.d.ts +0 -1
- package/dist/database/api/.generated/edge.js +0 -725
- package/dist/database/api/.generated/index-browser.js +0 -696
- package/dist/database/api/.generated/index.d.ts +0 -48645
- package/dist/database/api/.generated/index.js +0 -758
- package/dist/database/api/.generated/libquery_engine-debian-openssl-3.0.x.so.node +0 -0
- package/dist/database/api/.generated/libquery_engine-linux-arm64-openssl-1.1.x.so.node +0 -0
- package/dist/database/api/.generated/libquery_engine-linux-arm64-openssl-3.0.x.so.node +0 -0
- package/dist/database/api/.generated/libquery_engine-linux-musl-arm64-openssl-3.0.x.so.node +0 -0
- package/dist/database/api/.generated/package.json +0 -97
- package/dist/database/api/.generated/runtime/edge-esm.js +0 -31
- package/dist/database/api/.generated/runtime/edge.js +0 -31
- package/dist/database/api/.generated/runtime/index-browser.d.ts +0 -365
- package/dist/database/api/.generated/runtime/index-browser.js +0 -13
- package/dist/database/api/.generated/runtime/library.d.ts +0 -3447
- package/dist/database/api/.generated/runtime/library.js +0 -143
- package/dist/database/api/.generated/runtime/react-native.js +0 -80
- package/dist/database/api/.generated/runtime/wasm.js +0 -32
- package/dist/database/api/.generated/schema.prisma +0 -482
- package/dist/database/api/.generated/wasm.d.ts +0 -1
- package/dist/database/api/.generated/wasm.js +0 -696
- package/dist/database/engine/.generated/default.d.ts +0 -1
- package/dist/database/engine/.generated/default.js +0 -1
- package/dist/database/engine/.generated/edge.d.ts +0 -1
- package/dist/database/engine/.generated/edge.js +0 -485
- package/dist/database/engine/.generated/index-browser.js +0 -456
- package/dist/database/engine/.generated/index.d.ts +0 -22107
- package/dist/database/engine/.generated/index.js +0 -518
- package/dist/database/engine/.generated/libquery_engine-debian-openssl-3.0.x.so.node +0 -0
- package/dist/database/engine/.generated/libquery_engine-linux-arm64-openssl-1.1.x.so.node +0 -0
- package/dist/database/engine/.generated/libquery_engine-linux-arm64-openssl-3.0.x.so.node +0 -0
- package/dist/database/engine/.generated/libquery_engine-linux-musl-arm64-openssl-3.0.x.so.node +0 -0
- package/dist/database/engine/.generated/package.json +0 -97
- package/dist/database/engine/.generated/runtime/edge-esm.js +0 -31
- package/dist/database/engine/.generated/runtime/edge.js +0 -31
- package/dist/database/engine/.generated/runtime/index-browser.d.ts +0 -365
- package/dist/database/engine/.generated/runtime/index-browser.js +0 -13
- package/dist/database/engine/.generated/runtime/library.d.ts +0 -3447
- package/dist/database/engine/.generated/runtime/library.js +0 -143
- package/dist/database/engine/.generated/runtime/react-native.js +0 -80
- package/dist/database/engine/.generated/runtime/wasm.js +0 -32
- package/dist/database/engine/.generated/schema.prisma +0 -248
- package/dist/database/engine/.generated/wasm.d.ts +0 -1
- package/dist/database/engine/.generated/wasm.js +0 -456
- package/dist/database/index.d.ts +0 -29
- package/dist/database/index.js +0 -17
- package/dist/src/cache/declaration.js +0 -121
- package/dist/src/cache/index.js +0 -161
- package/dist/src/cache/redis.js +0 -57
- package/dist/src/constants.js +0 -93
- package/dist/src/engine/deprecated/dynamicData/implementations/Ajna.js +0 -107
- package/dist/src/engine/deprecated/dynamicData/implementations/Badger.js +0 -90
- package/dist/src/engine/deprecated/dynamicData/implementations/Clamm.js +0 -975
- package/dist/src/engine/deprecated/dynamicData/implementations/Compound.js +0 -139
- package/dist/src/engine/deprecated/dynamicData/implementations/CompoundV3.js +0 -101
- package/dist/src/engine/deprecated/dynamicData/implementations/Dolomite.js +0 -59
- package/dist/src/engine/deprecated/dynamicData/implementations/ERC721.js +0 -87
- package/dist/src/engine/deprecated/dynamicData/implementations/ERCMultiToken.js +0 -161
- package/dist/src/engine/deprecated/dynamicData/implementations/EigenLayer.js +0 -67
- package/dist/src/engine/deprecated/dynamicData/implementations/Encompassing.js +0 -26
- package/dist/src/engine/deprecated/dynamicData/implementations/Erc20.js +0 -162
- package/dist/src/engine/deprecated/dynamicData/implementations/Erc20Snapshot.js +0 -32
- package/dist/src/engine/deprecated/dynamicData/implementations/EventBased.js +0 -129
- package/dist/src/engine/deprecated/dynamicData/implementations/Hyperdrive.js +0 -112
- package/dist/src/engine/deprecated/dynamicData/implementations/Morpho.js +0 -132
- package/dist/src/engine/deprecated/dynamicData/implementations/Radiant.js +0 -123
- package/dist/src/engine/deprecated/dynamicData/implementations/Silo.js +0 -112
- package/dist/src/engine/deprecated/dynamicData/implementations/UniswapV4.js +0 -255
- package/dist/src/engine/deprecated/dynamicData/implementations/Vest.js +0 -61
- package/dist/src/engine/deprecated/dynamicData/implementations/default.js +0 -5
- package/dist/src/engine/deprecated/dynamicData/utils/fetchA51Strategies.js +0 -44
- package/dist/src/engine/deprecated/dynamicData/utils/fetchClamInfo.js +0 -27
- package/dist/src/engine/deprecated/dynamicData/utils/fetchLogs.js +0 -149
- package/dist/src/engine/deprecated/dynamicData/utils/getCompV2ForksVaults.js +0 -141
- package/dist/src/engine/deprecated/dynamicData/utils/getContractCreationBlock.js +0 -44
- package/dist/src/engine/deprecated/dynamicData/utils/getDolomiteMarkets.js +0 -53
- package/dist/src/engine/deprecated/dynamicData/utils/getEulerV2Vaults.js +0 -266
- package/dist/src/engine/deprecated/dynamicData/utils/getFixedApr.js +0 -27
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/GenericProcessor.js +0 -335
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/helpers/eulerVaultNames.js +0 -13
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/helpers/factoryFinder.js +0 -47
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/helpers/getBlacklistedSupply.js +0 -22
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/helpers/getCrossCurveTokenPrice.js +0 -13
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/helpers/hardcoded.js +0 -30
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/helpers/metamorphoTvl.d.ts +0 -1
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/helpers/metamorphoTvl.js +0 -35
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/helpers/ownerFinder.js +0 -16
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/helpers/spliceTVL.js +0 -23
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/helpers/treasuryFinder.js +0 -10
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/AaveProcessor.js +0 -26
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/AnglesLiquid.js +0 -51
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/AssetProcessor.js +0 -48
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/AuraProcessor.js +0 -113
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/BEXRewardGaugeProcessor.js +0 -111
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/BalancerGaugeProcessor.js +0 -86
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/BalancerPoolProcessor.js +0 -101
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/BalancerV3PoolProcessor.js +0 -81
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/BeefyProcessor.js +0 -54
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/BunniV2Processor.js +0 -91
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/CompoundProcessor.js +0 -37
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/ERC4626Processor.js +0 -37
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/EnzymeProcessor.js +0 -52
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/EqualizerGaugeProcessor.js +0 -54
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/EulerBorrowProcessor.js +0 -51
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/EulerLendProcessor.js +0 -58
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/FluidProcessor.js +0 -37
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/FraxProcessor.js +0 -42
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/GammaALMProcessor.js +0 -52
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/GammaProcessor.js +0 -67
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/GearboxProcessor.js +0 -58
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/HanjiVaultProcessor.js +0 -63
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/HoldStationProcessor.js +0 -35
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/HourglassProcessor.js +0 -35
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/MaverickBPProcessor.js +0 -78
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/MetamorphoProcessor.js +0 -48
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/NoLinkVaultProcessor.js +0 -82
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/PendleProcessor.js +0 -30
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/PendleYTProcessor.js +0 -30
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/RadiantProcessor.js +0 -59
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/RfxProcessor.js +0 -71
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/Satlayer.js +0 -28
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/SpectraProcessor.js +0 -42
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/SpectraYTProcessor.js +0 -40
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/SpliceProcessor.js +0 -37
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/StabilityProcessor.js +0 -30
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/SturdySiloProcessor.js +0 -38
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/TempestVaultProcessor.js +0 -83
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/TemplateProcessor.js +0 -40
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/TorosProcessor.js +0 -34
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/UniswapProcessor.js +0 -72
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/VicunaProcessor.js +0 -36
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/WoofiProcessor.js +0 -41
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/ZkSwapThreePoolProcessor.js +0 -60
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/curveNPoolProcessor.js +0 -102
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/curveProcessor.js +0 -85
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/processorMapping.js +0 -159
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/stakedCurveProcessor.js +0 -88
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/implementations/xU308Processor.js +0 -42
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/subtypesPrices.js +0 -28
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/subtypesRound1.js +0 -353
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/subtypesRound2.js +0 -22
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/subtypesRound3.js +0 -22
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/subtypesRound4.js +0 -22
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/tokenTypeStruct.js +0 -1
- package/dist/src/engine/deprecated/erc20SubTypeProcessors/tokenTypeToProtocolAndAction.js +0 -155
- package/dist/src/engine/implementations/Ajna/metadata.js +0 -59
- package/dist/src/engine/implementations/Ajna/tvl.js +0 -91
- package/dist/src/engine/implementations/Ambient/metadata.js +0 -36
- package/dist/src/engine/implementations/Ambient/tvl.js +0 -178
- package/dist/src/engine/implementations/Badger/metadata.js +0 -31
- package/dist/src/engine/implementations/Clamm/metadata.js +0 -176
- package/dist/src/engine/implementations/Compound/metadata.js +0 -23
- package/dist/src/engine/implementations/CompoundV3/metadata.js +0 -23
- package/dist/src/engine/implementations/Default/metadata.js +0 -12
- package/dist/src/engine/implementations/Dolomite/metadata.js +0 -20
- package/dist/src/engine/implementations/EigenLayer/metadata.js +0 -12
- package/dist/src/engine/implementations/EigenLayer/tvl.js +0 -60
- package/dist/src/engine/implementations/Encompassing/metadata.js +0 -43
- package/dist/src/engine/implementations/Erc20/metadata.js +0 -64
- package/dist/src/engine/implementations/Erc20/subTypes/detect.js +0 -170
- package/dist/src/engine/implementations/Erc20/subTypes/factories.js +0 -69
- package/dist/src/engine/implementations/Erc20/subTypes/implementations/aave/metadata.js +0 -46
- package/dist/src/engine/implementations/Erc20/subTypes/implementations/aave/tvl.js +0 -51
- package/dist/src/engine/implementations/Erc20/subTypes/implementations/euler/metadata.js +0 -35
- package/dist/src/engine/implementations/Erc20/subTypes/implementations/euler/tvl.js +0 -59
- package/dist/src/engine/implementations/Erc20/subTypes/implementations/gearbox/metadata.js +0 -21
- package/dist/src/engine/implementations/Erc20/subTypes/implementations/gearbox/tvl.js +0 -46
- package/dist/src/engine/implementations/Erc20/subTypes/implementations/hypurrfiIsolatedMarket/metadata.js +0 -40
- package/dist/src/engine/implementations/Erc20/subTypes/implementations/hypurrfiIsolatedMarket/tvl.js +0 -57
- package/dist/src/engine/implementations/Erc20/subTypes/implementations/lendleVaults/metadata.js +0 -20
- package/dist/src/engine/implementations/Erc20/subTypes/implementations/lendleVaults/tvl.js +0 -52
- package/dist/src/engine/implementations/Erc20/subTypes/implementations/pino/metadata.js +0 -38
- package/dist/src/engine/implementations/Erc20/subTypes/implementations/pino/tvl.js +0 -83
- package/dist/src/engine/implementations/Erc20/subTypes/implementations/termmax/metadata.js +0 -24
- package/dist/src/engine/implementations/Erc20/subTypes/implementations/termmax/tvl.js +0 -69
- package/dist/src/engine/implementations/Erc20/subTypes/implementations/uniswapV2/metadata.js +0 -65
- package/dist/src/engine/implementations/Erc20/subTypes/implementations/uniswapV2/tvl.js +0 -94
- package/dist/src/engine/implementations/Erc20/subTypes/index.js +0 -119
- package/dist/src/engine/implementations/Erc20/tvl.js +0 -99
- package/dist/src/engine/implementations/Erc20Snapshot/metadata.js +0 -11
- package/dist/src/engine/implementations/Erc721/metadata.js +0 -13
- package/dist/src/engine/implementations/ErcMultiToken/metadata.js +0 -63
- package/dist/src/engine/implementations/EventBased/metadata.js +0 -181
- package/dist/src/engine/implementations/Hyperdrive/metadata.js +0 -29
- package/dist/src/engine/implementations/Invalid/metadata.js +0 -10
- package/dist/src/engine/implementations/Ion/metadata.js +0 -16
- package/dist/src/engine/implementations/JsonAirdrop/metadata.js +0 -43
- package/dist/src/engine/implementations/Locker/metadata.js +0 -36
- package/dist/src/engine/implementations/Locker/tvl.js +0 -26
- package/dist/src/engine/implementations/Morpho/metadata.js +0 -63
- package/dist/src/engine/implementations/MultiLog/metadata.js +0 -36
- package/dist/src/engine/implementations/MultiLog/tvl.js +0 -59
- package/dist/src/engine/implementations/Radiant/metadata.js +0 -33
- package/dist/src/engine/implementations/Silo/metadata.js +0 -20
- package/dist/src/engine/implementations/UniswapV4/metadata.js +0 -36
- package/dist/src/engine/implementations/UniswapV4/tvl.js +0 -158
- package/dist/src/engine/implementations/Vest/metadata.js +0 -13
- package/dist/src/engine/metadata/factory.js +0 -76
- package/dist/src/engine/tvl/factory.js +0 -87
- package/dist/src/engine/tvl/logStates.js +0 -106
- package/dist/src/errors/BadRequest.error.js +0 -7
- package/dist/src/errors/Conflict.error.js +0 -7
- package/dist/src/errors/HttpError.js +0 -17
- package/dist/src/errors/InvalidParameter.error.js +0 -7
- package/dist/src/errors/NotFound.error.js +0 -12
- package/dist/src/errors/Opportunity.error.js +0 -11
- package/dist/src/errors/UnableToFindPrice.error.js +0 -7
- package/dist/src/errors/Unauthorized.error.js +0 -7
- package/dist/src/errors/VoidString.error.js +0 -7
- package/dist/src/errors/index.js +0 -6
- package/dist/src/guards/BackOffice.guard.js +0 -10
- package/dist/src/guards/Engine.guard.js +0 -9
- package/dist/src/guards/TokenAuth.guard.js +0 -10
- package/dist/src/guards/VerifyJwt.guard.js +0 -13
- package/dist/src/hooks/checkQueryAddressValidity.js +0 -7
- package/dist/src/hooks/checkQueryChainIdValidity.js +0 -7
- package/dist/src/index.js +0 -113
- package/dist/src/jobs/dynamic-data.js +0 -159
- package/dist/src/jobs/pendings.js +0 -238
- package/dist/src/jobs/prices.js +0 -10
- package/dist/src/jobs/reward-breakdowns.js +0 -163
- package/dist/src/jobs/rewards.js +0 -112
- package/dist/src/jobs/set-dungeon-keeper.js +0 -90
- package/dist/src/jobs/update-analytics.js +0 -548
- package/dist/src/jobs/update-dynamic-data.js +0 -57
- package/dist/src/jobs/update-euler-vaults.js +0 -18
- package/dist/src/jobs/update-rpc-calls-cache.js +0 -30
- package/dist/src/jobs/update-uniswap-v4-pools.js +0 -15
- package/dist/src/libs/computeFee.js +0 -34
- package/dist/src/libs/deprecated-merklv3/index.js +0 -183
- package/dist/src/libs/getTokensList.js +0 -19
- package/dist/src/libs/merklChainData.js +0 -116
- package/dist/src/libs/parse/marketsWithCache.js +0 -8
- package/dist/src/libs/positions/EigenLayer/index.js +0 -54
- package/dist/src/libs/positions/ajna/index.js +0 -107
- package/dist/src/libs/positions/badger/index.js +0 -80
- package/dist/src/libs/positions/clamm/index.js +0 -412
- package/dist/src/libs/positions/clamm/thegraph/fetchAlmPositions.js +0 -36
- package/dist/src/libs/positions/clamm/thegraph/fetchAmmPositions.js +0 -36
- package/dist/src/libs/positions/clamm/thegraph/fetchFarmedPositions.js +0 -42
- package/dist/src/libs/positions/clamm/thegraph/index.js +0 -163
- package/dist/src/libs/positions/compound/index.js +0 -91
- package/dist/src/libs/positions/dolomite/index.js +0 -51
- package/dist/src/libs/positions/erc20/index.js +0 -55
- package/dist/src/libs/positions/euler/index.js +0 -56
- package/dist/src/libs/positions/index.js +0 -56
- package/dist/src/libs/positions/morpho/index.js +0 -177
- package/dist/src/libs/positions/prepareFetch.js +0 -392
- package/dist/src/libs/positions/silo/index.js +0 -68
- package/dist/src/libs/positions/types.js +0 -1
- package/dist/src/libs/staticCampaigns.js +0 -15
- package/dist/src/libs/tokens/allowances.js +0 -18
- package/dist/src/libs/tokens/balances.js +0 -128
- package/dist/src/libs/tokens/tokenInfo.js +0 -22
- package/dist/src/modules/v4/accounting/accounting.controller.js +0 -61
- package/dist/src/modules/v4/accounting/accounting.model.js +0 -32
- package/dist/src/modules/v4/accounting/accounting.repository.js +0 -154
- package/dist/src/modules/v4/accounting/accounting.service.js +0 -107
- package/dist/src/modules/v4/airflow/airflow.service.js +0 -20
- package/dist/src/modules/v4/apr/apr.model.js +0 -13
- package/dist/src/modules/v4/apr/apr.service.js +0 -52
- package/dist/src/modules/v4/authentication/authentication.controller.js +0 -23
- package/dist/src/modules/v4/authentication/authentication.model.js +0 -6
- package/dist/src/modules/v4/authentication/authentication.service.js +0 -31
- package/dist/src/modules/v4/blacklist/blacklist.controller.js +0 -42
- package/dist/src/modules/v4/blacklist/blacklist.model.js +0 -13
- package/dist/src/modules/v4/blacklist/blacklist.repository.js +0 -50
- package/dist/src/modules/v4/blacklist/blacklist.service.js +0 -31
- package/dist/src/modules/v4/boost/boost.controller.js +0 -15
- package/dist/src/modules/v4/boost/boost.model.js +0 -14
- package/dist/src/modules/v4/boost/boost.service.js +0 -20
- package/dist/src/modules/v4/bucket/bucket.model.js +0 -85
- package/dist/src/modules/v4/bucket/bucket.service.js +0 -178
- package/dist/src/modules/v4/cache/cache.model.js +0 -14
- package/dist/src/modules/v4/cache/cache.repository.js +0 -22
- package/dist/src/modules/v4/cache/cache.service.js +0 -59
- package/dist/src/modules/v4/campaign/campaign.controller.js +0 -174
- package/dist/src/modules/v4/campaign/campaign.model.js +0 -140
- package/dist/src/modules/v4/campaign/campaign.repository.js +0 -535
- package/dist/src/modules/v4/campaign/campaign.service.js +0 -455
- package/dist/src/modules/v4/campaign/campaign.test.controller.js +0 -127
- package/dist/src/modules/v4/chain/chain.controller.js +0 -44
- package/dist/src/modules/v4/chain/chain.model.js +0 -36
- package/dist/src/modules/v4/chain/chain.repository.js +0 -79
- package/dist/src/modules/v4/chain/chain.service.js +0 -55
- package/dist/src/modules/v4/chainInteraction/chainInteraction.service.js +0 -4
- package/dist/src/modules/v4/claims/claims.controller.js +0 -19
- package/dist/src/modules/v4/claims/claims.model.js +0 -1
- package/dist/src/modules/v4/claims/claims.repository.js +0 -39
- package/dist/src/modules/v4/claims/claims.service.js +0 -40
- package/dist/src/modules/v4/coingecko/coingecko.model.js +0 -1
- package/dist/src/modules/v4/coingecko/coingecko.repository.js +0 -9
- package/dist/src/modules/v4/coingecko/coingecko.service.js +0 -65
- package/dist/src/modules/v4/computedValue/computedValue.controller.js +0 -46
- package/dist/src/modules/v4/computedValue/computedValue.model.js +0 -30
- package/dist/src/modules/v4/computedValue/computedValue.repository.js +0 -48
- package/dist/src/modules/v4/computedValue/computedValue.service.js +0 -23
- package/dist/src/modules/v4/creator/creator.controller.js +0 -43
- package/dist/src/modules/v4/creator/creator.model.js +0 -42
- package/dist/src/modules/v4/creator/creator.repository.js +0 -69
- package/dist/src/modules/v4/creator/creator.service.js +0 -92
- package/dist/src/modules/v4/dynamicData/dynamicData.model.js +0 -56
- package/dist/src/modules/v4/dynamicData/dynamicData.service.js +0 -263
- package/dist/src/modules/v4/enso/enso.model.js +0 -147
- package/dist/src/modules/v4/enso/enso.service.js +0 -116
- package/dist/src/modules/v4/explorer/explorer.controller.js +0 -13
- package/dist/src/modules/v4/explorer/explorer.model.js +0 -8
- package/dist/src/modules/v4/explorer/explorer.repository.js +0 -23
- package/dist/src/modules/v4/explorer/explorer.service.js +0 -24
- package/dist/src/modules/v4/icon/icon.model.js +0 -1
- package/dist/src/modules/v4/icon/icon.service.js +0 -16
- package/dist/src/modules/v4/interaction/interaction.controller.js +0 -45
- package/dist/src/modules/v4/interaction/interaction.model.js +0 -25
- package/dist/src/modules/v4/interaction/interaction.service.js +0 -95
- package/dist/src/modules/v4/kyberzap/kyberzap.model.js +0 -83
- package/dist/src/modules/v4/kyberzap/kyberzap.service.js +0 -176
- package/dist/src/modules/v4/liquidity/implementations/AjnaPositionFetcher.js +0 -90
- package/dist/src/modules/v4/liquidity/implementations/BadgerPositionFetcher.js +0 -69
- package/dist/src/modules/v4/liquidity/implementations/ClammPositionFetcher.js +0 -61
- package/dist/src/modules/v4/liquidity/implementations/DolomitePositionFetcher.js +0 -45
- package/dist/src/modules/v4/liquidity/implementations/ERC20PositionFetcher.js +0 -47
- package/dist/src/modules/v4/liquidity/implementations/EulerPositionFetcher.js +0 -40
- package/dist/src/modules/v4/liquidity/liquidity.controller.js +0 -16
- package/dist/src/modules/v4/liquidity/liquidity.model.js +0 -5
- package/dist/src/modules/v4/liquidity/liquidity.repository.js +0 -6
- package/dist/src/modules/v4/liquidity/liquidity.service.js +0 -34
- package/dist/src/modules/v4/merklRoot/merklRoot.controller.js +0 -31
- package/dist/src/modules/v4/merklRoot/merklRoot.model.js +0 -12
- package/dist/src/modules/v4/merklRoot/merklRoot.repository.js +0 -56
- package/dist/src/modules/v4/merklRoot/merklRoot.service.js +0 -48
- package/dist/src/modules/v4/opportunity/opportunity.controller.js +0 -189
- package/dist/src/modules/v4/opportunity/opportunity.converter.js +0 -174
- package/dist/src/modules/v4/opportunity/opportunity.model.js +0 -132
- package/dist/src/modules/v4/opportunity/opportunity.repository.js +0 -515
- package/dist/src/modules/v4/opportunity/opportunity.service.js +0 -380
- package/dist/src/modules/v4/opportunity/transform-id.pipe.js +0 -6
- package/dist/src/modules/v4/opportunity/validate-id.pipe.js +0 -12
- package/dist/src/modules/v4/price/price.controller.js +0 -56
- package/dist/src/modules/v4/price/price.model.js +0 -12
- package/dist/src/modules/v4/price/price.repository.js +0 -22
- package/dist/src/modules/v4/price/price.service.js +0 -63
- package/dist/src/modules/v4/prisma/index.js +0 -1
- package/dist/src/modules/v4/programPayload/programPayload.controller.js +0 -85
- package/dist/src/modules/v4/programPayload/programPayload.model.js +0 -179
- package/dist/src/modules/v4/programPayload/programPayload.repository.js +0 -7553
- package/dist/src/modules/v4/programPayload/programPayload.service.js +0 -240
- package/dist/src/modules/v4/protocol/protocol.controller.js +0 -42
- package/dist/src/modules/v4/protocol/protocol.model.js +0 -186
- package/dist/src/modules/v4/protocol/protocol.repository.js +0 -175
- package/dist/src/modules/v4/protocol/protocol.service.js +0 -73
- package/dist/src/modules/v4/referral/referral.controller.js +0 -25
- package/dist/src/modules/v4/referral/referral.model.js +0 -12
- package/dist/src/modules/v4/referral/referral.service.js +0 -171
- package/dist/src/modules/v4/reward/reward.controller.js +0 -140
- package/dist/src/modules/v4/reward/reward.converter.js +0 -124
- package/dist/src/modules/v4/reward/reward.model.js +0 -153
- package/dist/src/modules/v4/reward/reward.repository.js +0 -350
- package/dist/src/modules/v4/reward/reward.service.js +0 -406
- package/dist/src/modules/v4/router.js +0 -93
- package/dist/src/modules/v4/status/status.controller.js +0 -68
- package/dist/src/modules/v4/status/status.model.js +0 -34
- package/dist/src/modules/v4/status/status.repository.js +0 -146
- package/dist/src/modules/v4/status/status.service.js +0 -150
- package/dist/src/modules/v4/token/token.controller.js +0 -118
- package/dist/src/modules/v4/token/token.model.js +0 -87
- package/dist/src/modules/v4/token/token.repository.js +0 -192
- package/dist/src/modules/v4/token/token.service.js +0 -410
- package/dist/src/modules/v4/tracer/tracer.service.js +0 -30
- package/dist/src/modules/v4/turtle/turtle.controller.js +0 -20
- package/dist/src/modules/v4/turtle/turtle.repository.js +0 -40
- package/dist/src/modules/v4/turtle/turtle.service.js +0 -28
- package/dist/src/modules/v4/tvl/tvl.model.js +0 -13
- package/dist/src/modules/v4/tvl/tvl.service.js +0 -63
- package/dist/src/modules/v4/uniswap/uniswap.controller.js +0 -100
- package/dist/src/modules/v4/uniswap/uniswap.model.js +0 -46
- package/dist/src/modules/v4/uniswap/uniswap.repository.js +0 -12
- package/dist/src/modules/v4/uniswap/uniswap.service.js +0 -245
- package/dist/src/modules/v4/user/user.controller.js +0 -77
- package/dist/src/modules/v4/user/user.model.js +0 -66
- package/dist/src/modules/v4/user/user.repository.js +0 -41
- package/dist/src/modules/v4/user/user.service.js +0 -102
- package/dist/src/plugins/error-handling.plugin.js +0 -34
- package/dist/src/routes/v1/allowances.js +0 -115
- package/dist/src/routes/v1/balances.js +0 -25
- package/dist/src/routes/v1/prices.js +0 -9
- package/dist/src/routes/v1/router.js +0 -6
- package/dist/src/routes/v1/tokens.js +0 -17
- package/dist/src/routes/v2/merkl.js +0 -13
- package/dist/src/routes/v2/router.js +0 -3
- package/dist/src/routes/v3/app.js +0 -43
- package/dist/src/routes/v3/blacklist.js +0 -19
- package/dist/src/routes/v3/campaign/delay.js +0 -81
- package/dist/src/routes/v3/campaignClaims.js +0 -29
- package/dist/src/routes/v3/campaignUnclaimed.js +0 -28
- package/dist/src/routes/v3/campaigns.js +0 -136
- package/dist/src/routes/v3/campaignsForMainParameter.js +0 -33
- package/dist/src/routes/v3/campaignsRewardsReport.js +0 -48
- package/dist/src/routes/v3/claims.js +0 -16
- package/dist/src/routes/v3/compoundV2.js +0 -9
- package/dist/src/routes/v3/createCampaign.js +0 -66
- package/dist/src/routes/v3/dolomite.js +0 -12
- package/dist/src/routes/v3/euler.js +0 -52
- package/dist/src/routes/v3/fetch.js +0 -27
- package/dist/src/routes/v3/health.js +0 -13
- package/dist/src/routes/v3/lostyield.js +0 -101
- package/dist/src/routes/v3/merkl.js +0 -119
- package/dist/src/routes/v3/morphoMarkets.js +0 -27
- package/dist/src/routes/v3/morphoVaults.js +0 -22
- package/dist/src/routes/v3/multiChainPositions.js +0 -70
- package/dist/src/routes/v3/opportunity.js +0 -28
- package/dist/src/routes/v3/overview.js +0 -72
- package/dist/src/routes/v3/parse.js +0 -23
- package/dist/src/routes/v3/payload.js +0 -40
- package/dist/src/routes/v3/poolInfo.js +0 -88
- package/dist/src/routes/v3/positions.js +0 -62
- package/dist/src/routes/v3/radiant.js +0 -26
- package/dist/src/routes/v3/recipients.js +0 -29
- package/dist/src/routes/v3/rewards.js +0 -36
- package/dist/src/routes/v3/rewardsReport.js +0 -40
- package/dist/src/routes/v3/router.js +0 -70
- package/dist/src/routes/v3/silo.js +0 -20
- package/dist/src/routes/v3/token.js +0 -24
- package/dist/src/routes/v3/twt/participants.js +0 -63
- package/dist/src/routes/v3/uniswapv4.js +0 -29
- package/dist/src/routes/v3/updates.js +0 -47
- package/dist/src/routes/v3/userRewards.js +0 -63
- package/dist/src/scripts/fill-coingecko-data.js +0 -3
- package/dist/src/scripts/fill-descriptions.js +0 -101
- package/dist/src/scripts/fill-unknown-tokens.js +0 -58
- package/dist/src/scripts/reparse-opportunities.js +0 -75
- package/dist/src/types/external/spectraAPI.js +0 -1
- package/dist/src/types/index.js +0 -1
- package/dist/src/utils/TailSampler.js +0 -23
- package/dist/src/utils/bigintToString.js +0 -20
- package/dist/src/utils/caseChanges.js +0 -15
- package/dist/src/utils/decodeCalls.js +0 -340
- package/dist/src/utils/encodeCalls.js +0 -506
- package/dist/src/utils/error.js +0 -114
- package/dist/src/utils/execute.js +0 -117
- package/dist/src/utils/generateCardName.js +0 -209
- package/dist/src/utils/generic.js +0 -43
- package/dist/src/utils/hashArray.js +0 -7
- package/dist/src/utils/lastBlockBefore.js +0 -78
- package/dist/src/utils/logger.js +0 -52
- package/dist/src/utils/parseDistributionType.js +0 -16
- package/dist/src/utils/pricer.js +0 -189
- package/dist/src/utils/prices/chainlinkRead.js +0 -8
- package/dist/src/utils/prices/curveVirtualPrice.js +0 -7
- package/dist/src/utils/prices/getDQUICK.js +0 -8
- package/dist/src/utils/prices/priceFetcherFactory.js +0 -32
- package/dist/src/utils/prices/priceService.js +0 -274
- package/dist/src/utils/prices/services/OnChainCallService.js +0 -38
- package/dist/src/utils/prices/services/coinGeckoService.js +0 -63
- package/dist/src/utils/prices/services/defillamaService.js +0 -53
- package/dist/src/utils/prices/services/dexScreenerService.js +0 -62
- package/dist/src/utils/prices/services/erc4626Service.js +0 -38
- package/dist/src/utils/prices/services/getERC4626.js +0 -11
- package/dist/src/utils/prices/services/indexCoopService.js +0 -55
- package/dist/src/utils/prices/services/priceFetcher.js +0 -1
- package/dist/src/utils/prices/uniV2Price.js +0 -40
- package/dist/src/utils/providers.js +0 -37
- package/dist/src/utils/queries/allCampaigns.js +0 -12
- package/dist/src/utils/sanitizeChain.js +0 -6
- package/dist/src/utils/stryke.js +0 -4
- package/dist/src/utils/throw.js +0 -55
- package/dist/tsconfig.package.tsbuildinfo +0 -1
@@ -1,380 +0,0 @@
|
|
1
|
-
import { NotFoundError } from "@/errors";
|
2
|
-
import { TTLPresets } from "@/modules/v4/cache/cache.model";
|
3
|
-
import { CacheService } from "@/modules/v4/cache/cache.service";
|
4
|
-
import { CampaignRepository } from "@/modules/v4/campaign/campaign.repository";
|
5
|
-
import { CampaignService } from "@/modules/v4/campaign/campaign.service";
|
6
|
-
import { TokenService } from "@/modules/v4/token/token.service";
|
7
|
-
import { UserService } from "@/modules/v4/user/user.service";
|
8
|
-
import { log } from "@/utils/logger";
|
9
|
-
import { AprType, Status } from "@db/api";
|
10
|
-
import { Campaign as CampaignType, numberToBigInt } from "@sdk";
|
11
|
-
import moment from "moment";
|
12
|
-
import { metadataBuilderFactory } from "../../../engine/metadata/factory";
|
13
|
-
import { ChainService } from "../chain/chain.service";
|
14
|
-
import { ProtocolService } from "../protocol/protocol.service";
|
15
|
-
import { OpportunityRepository } from "./opportunity.repository";
|
16
|
-
export class OpportunityService {
|
17
|
-
static hashId(opportunity) {
|
18
|
-
return Bun.hash(`${opportunity.chainId}${opportunity.type}${opportunity.identifier}`).toString();
|
19
|
-
}
|
20
|
-
static async getAprBins(query) {
|
21
|
-
const BINS_COUNT = 20;
|
22
|
-
const opportunities = await OpportunityRepository.findMany({
|
23
|
-
...query,
|
24
|
-
status: "LIVE",
|
25
|
-
sort: "apr",
|
26
|
-
order: "asc",
|
27
|
-
items: 0,
|
28
|
-
});
|
29
|
-
const mid = Math.floor(opportunities.length / 2);
|
30
|
-
const median = opportunities.length % 2 !== 0
|
31
|
-
? opportunities[mid].apr
|
32
|
-
: (opportunities[mid - 1].apr + opportunities[mid].apr) / 2;
|
33
|
-
const threshold = 5 * median;
|
34
|
-
if (opportunities.length < 2)
|
35
|
-
throw new Error("Not enough opportunities");
|
36
|
-
const maxAprUnderThreshold = opportunities.filter(o => o.apr <= threshold).at(-1)?.apr ?? 0;
|
37
|
-
const minAprAbove0 = opportunities.find(o => o.apr > 0)?.apr ?? 0;
|
38
|
-
const binWidth = (maxAprUnderThreshold - minAprAbove0) / BINS_COUNT;
|
39
|
-
const bins = new Array(BINS_COUNT);
|
40
|
-
for (let i = 0; i < BINS_COUNT; i++)
|
41
|
-
bins[i] = 0;
|
42
|
-
let overThreshold = 0;
|
43
|
-
for (const opportunity of opportunities) {
|
44
|
-
if (opportunity.apr > 0 && opportunity.apr < threshold)
|
45
|
-
bins[Math.min(Math.floor(opportunity.apr / binWidth), BINS_COUNT - 1)]++;
|
46
|
-
else
|
47
|
-
overThreshold++;
|
48
|
-
}
|
49
|
-
return {
|
50
|
-
min: opportunities[0].apr,
|
51
|
-
max: opportunities[opportunities.length - 1].apr,
|
52
|
-
overThreshold,
|
53
|
-
binWidth,
|
54
|
-
bins,
|
55
|
-
};
|
56
|
-
}
|
57
|
-
static async getTvlBins(query) {
|
58
|
-
const BINS_COUNT = 20;
|
59
|
-
const opportunities = await OpportunityRepository.findMany({
|
60
|
-
...query,
|
61
|
-
status: "LIVE,SOON",
|
62
|
-
sort: "tvl",
|
63
|
-
order: "asc",
|
64
|
-
items: 0,
|
65
|
-
});
|
66
|
-
if (opportunities.length < 2)
|
67
|
-
throw new Error("Not enough opportunities");
|
68
|
-
const binWidth = (opportunities[opportunities.length - 1].tvl - opportunities[0].tvl) / BINS_COUNT;
|
69
|
-
const bins = new Array(BINS_COUNT);
|
70
|
-
for (let i = 0; i < BINS_COUNT; i++)
|
71
|
-
bins[i] = 0;
|
72
|
-
for (const opportunity of opportunities)
|
73
|
-
bins[Math.min(Math.floor(opportunity.tvl / binWidth), BINS_COUNT - 1)]++;
|
74
|
-
return {
|
75
|
-
min: opportunities[0].tvl,
|
76
|
-
max: opportunities[opportunities.length - 1].tvl,
|
77
|
-
binWidth,
|
78
|
-
bins,
|
79
|
-
};
|
80
|
-
}
|
81
|
-
static async override(id, data) {
|
82
|
-
const opportunity = await OpportunityRepository.findUniqueOrThrow(id);
|
83
|
-
const overrides = opportunity.manualOverrides ?? [];
|
84
|
-
overrides.push(...Object.keys(data).filter(k => k !== undefined && !overrides.includes(k)));
|
85
|
-
return await OpportunityRepository.update(id, { ...data, manualOverrides: overrides });
|
86
|
-
}
|
87
|
-
static async deleteOverrides(id, overridesToDelete) {
|
88
|
-
const opportunity = await OpportunityRepository.findUniqueOrThrow(id);
|
89
|
-
const overrides = opportunity.manualOverrides ?? [];
|
90
|
-
const newOverrides = overrides.filter(override => !overridesToDelete.includes(override));
|
91
|
-
await OpportunityRepository.update(id, { manualOverrides: newOverrides });
|
92
|
-
return await OpportunityService.recreate(id);
|
93
|
-
}
|
94
|
-
/**
|
95
|
-
* create an opportunity without campaigns
|
96
|
-
* @param newOpp the new opportunity to create
|
97
|
-
* @returns {Promise<Opportunity|undefined>}
|
98
|
-
*/
|
99
|
-
static async create(newOpp) {
|
100
|
-
const id = OpportunityService.hashId(newOpp);
|
101
|
-
return await OpportunityRepository.create({ ...newOpp, id });
|
102
|
-
}
|
103
|
-
/**
|
104
|
-
* build/fetch metadata of a campaign's opportunity
|
105
|
-
* @param campaign
|
106
|
-
*/
|
107
|
-
static async #getMetadata(campaign, opportunityIdentifier) {
|
108
|
-
const campaignType = CampaignType[campaign.type];
|
109
|
-
return await metadataBuilderFactory(campaignType).build(campaign, opportunityIdentifier);
|
110
|
-
}
|
111
|
-
/**
|
112
|
-
* @param upsert whether to update the opportunity if it already exists in database
|
113
|
-
* @param dryRun whether to skip the opportunity table interaction and just return the computed opportunity
|
114
|
-
* @returns the opportunity entity computed
|
115
|
-
*/
|
116
|
-
static async createFromCampaign(campaign, opportunityIdentifier, upsert = false, dryRun = false) {
|
117
|
-
if (dryRun)
|
118
|
-
log.info(`opportunity creation dry run for ${campaign.campaignId} of type ${campaign.type}`);
|
119
|
-
const metadata = await OpportunityService.#getMetadata(campaign, opportunityIdentifier);
|
120
|
-
const tags = (await UserService.findUnique(campaign.creatorAddress))?.tags ?? [];
|
121
|
-
const opportunityId = OpportunityService.hashId({
|
122
|
-
chainId: campaign.computeChainId,
|
123
|
-
identifier: opportunityIdentifier,
|
124
|
-
type: campaign.type,
|
125
|
-
});
|
126
|
-
const tokens = (await TokenService.findManyOrCreate(metadata.tokens)).filter(t => t !== undefined);
|
127
|
-
const now = moment().unix();
|
128
|
-
const protocol = (await ProtocolService.findMany({ id: metadata.mainProtocol, test: true }))?.[0];
|
129
|
-
const campaignUrl = campaign.params?.url;
|
130
|
-
const opportunity = {
|
131
|
-
id: opportunityId,
|
132
|
-
chainId: campaign.computeChainId,
|
133
|
-
type: campaign.type,
|
134
|
-
identifier: opportunityIdentifier, // mainParameter
|
135
|
-
name: metadata.name,
|
136
|
-
status: now >= +campaign.startTimestamp && now < +campaign.endTimestamp
|
137
|
-
? Status.LIVE
|
138
|
-
: now > +campaign.endTimestamp
|
139
|
-
? Status.PAST
|
140
|
-
: Status.SOON,
|
141
|
-
action: metadata.action,
|
142
|
-
tokens,
|
143
|
-
mainProtocol: metadata.mainProtocol,
|
144
|
-
description: await OpportunityService.description(metadata.action, tokens, protocol, campaign.computeChainId),
|
145
|
-
howToSteps: OpportunityService.howToSteps(metadata.action, tokens, protocol),
|
146
|
-
// If creator has specified a deposit URL, use it
|
147
|
-
// Else if we have the specific logic to handle the deposit URL, use it
|
148
|
-
// Else if the protocol has a deposit URL, use it
|
149
|
-
depositUrl: campaignUrl
|
150
|
-
? campaignUrl
|
151
|
-
: !!metadata.depositUrl
|
152
|
-
? metadata.depositUrl
|
153
|
-
: !!metadata.mainProtocol && !!protocol?.url
|
154
|
-
? protocol?.url
|
155
|
-
: undefined,
|
156
|
-
explorerAddress: metadata.explorerAddress,
|
157
|
-
tags,
|
158
|
-
};
|
159
|
-
if (!dryRun)
|
160
|
-
return await OpportunityRepository.create(opportunity, upsert);
|
161
|
-
return opportunity;
|
162
|
-
}
|
163
|
-
/**
|
164
|
-
* deletes and recreates an opportunity with fresh data
|
165
|
-
*/
|
166
|
-
static async recreate(opportunityId, campaignId) {
|
167
|
-
const opportunity = await OpportunityRepository.findUnique(opportunityId);
|
168
|
-
if (!opportunity)
|
169
|
-
throw new NotFoundError();
|
170
|
-
const sortedCampaigns = opportunity?.Campaigns.filter(campaign => campaignId ? campaign.campaignId === campaignId : true).sort((a, b) => Number(b.endTimestamp) - Number(a.endTimestamp));
|
171
|
-
let firstCampaign = sortedCampaigns[0];
|
172
|
-
const firstCampaigns = sortedCampaigns.filter(campaign => campaign.startTimestamp <= BigInt(moment().unix()));
|
173
|
-
if (firstCampaigns.length > 0)
|
174
|
-
firstCampaign = firstCampaigns[0];
|
175
|
-
return await OpportunityService.createFromCampaign(CampaignService.format(await CampaignService.findUniqueOrThrow(firstCampaign.id)), opportunity.identifier, true // Upserting
|
176
|
-
);
|
177
|
-
}
|
178
|
-
/**
|
179
|
-
* Finds opportunities based on filters of its campaigns
|
180
|
-
* @notice campaigns are filtered as well
|
181
|
-
* @param where
|
182
|
-
* @returns opportunities
|
183
|
-
*/
|
184
|
-
static async findManyByCampaigns(where) {
|
185
|
-
const opportunities = await OpportunityRepository.findManyByCampaigns(CampaignRepository.transformQueryToPrismaFilters(where).where);
|
186
|
-
return opportunities.map(o => {
|
187
|
-
return OpportunityService.formatResponse(o);
|
188
|
-
});
|
189
|
-
}
|
190
|
-
static async getUniqueWithCampaignsOrThrow(opportunityId, withTest = false, withPoints = false) {
|
191
|
-
const id = typeof opportunityId === "string" ? opportunityId : OpportunityService.hashId(opportunityId);
|
192
|
-
const opportunity = await OpportunityRepository.findUniqueOrThrow(id, withTest, withTest ? withTest : withPoints, true);
|
193
|
-
return OpportunityService.formatResponse(opportunity);
|
194
|
-
}
|
195
|
-
static async findUniqueOrThrow(opportunityId, withCampaigns = false, withTest = false, withPoints = false) {
|
196
|
-
const id = typeof opportunityId === "string" ? opportunityId : OpportunityService.hashId(opportunityId);
|
197
|
-
const opportunity = await OpportunityRepository.findUniqueOrThrow(id, withTest, withTest ? withTest : withPoints, withCampaigns);
|
198
|
-
return OpportunityService.formatResponse(opportunity);
|
199
|
-
}
|
200
|
-
/**
|
201
|
-
* Get the list of opportunities satisfying the query
|
202
|
-
* @param query
|
203
|
-
* @returns A list of opportunities
|
204
|
-
*/
|
205
|
-
static async findMany(query) {
|
206
|
-
// Bypass cache in test mode
|
207
|
-
if (query.test)
|
208
|
-
return (await OpportunityRepository.findMany(query)).map(c => OpportunityService.formatResponse(c));
|
209
|
-
return await CacheService.wrap(TTLPresets.MIN_5, async (query) => {
|
210
|
-
return (await OpportunityRepository.findMany(query)).map(c => OpportunityService.formatResponse(c));
|
211
|
-
}, query);
|
212
|
-
}
|
213
|
-
/**
|
214
|
-
* Counts the number of opportunities that complies to query
|
215
|
-
* @description used for pagination purposes
|
216
|
-
* @param query
|
217
|
-
* @returns the number of opportunities
|
218
|
-
*/
|
219
|
-
static async countMany(query) {
|
220
|
-
return await OpportunityRepository.countMany(query);
|
221
|
-
}
|
222
|
-
static async findLiveWithCampaigns(chainId, take) {
|
223
|
-
return await CacheService.wrap(TTLPresets.MIN_10, async (chainId) => {
|
224
|
-
const opportunities = await OpportunityRepository.findLiveWithCampaigns(chainId, take);
|
225
|
-
return opportunities.map(o => {
|
226
|
-
return OpportunityService.formatResponse(o);
|
227
|
-
});
|
228
|
-
}, chainId);
|
229
|
-
}
|
230
|
-
static formatResponse(opportunity) {
|
231
|
-
const { DailyRewardsRecords, AprRecords, TvlRecords, Campaigns, ...opp } = opportunity;
|
232
|
-
const rewardsRecord = DailyRewardsRecords.length === 0
|
233
|
-
? {
|
234
|
-
id: "",
|
235
|
-
total: 0,
|
236
|
-
timestamp: 0n,
|
237
|
-
breakdowns: [],
|
238
|
-
}
|
239
|
-
: (DailyRewardsRecords?.map(({ id, total, timestamp, DailyRewardsBreakdown: breakdowns }) => ({
|
240
|
-
id,
|
241
|
-
total,
|
242
|
-
timestamp,
|
243
|
-
breakdowns: breakdowns.map(({ Campaign, value, ...breakdown }) => {
|
244
|
-
return {
|
245
|
-
token: Campaign.RewardToken,
|
246
|
-
amount: numberToBigInt(value, Campaign.RewardToken.decimals),
|
247
|
-
value: (Campaign.RewardToken.price ?? 1) * value,
|
248
|
-
distributionType: Campaign.distributionType,
|
249
|
-
...breakdown,
|
250
|
-
};
|
251
|
-
}),
|
252
|
-
}))?.[0] ?? undefined);
|
253
|
-
const tvlRecord = TvlRecords.length === 0
|
254
|
-
? {
|
255
|
-
id: "",
|
256
|
-
total: 0,
|
257
|
-
timestamp: 0n,
|
258
|
-
breakdowns: [],
|
259
|
-
}
|
260
|
-
: (TvlRecords?.map(({ id, total, timestamp, TvlBreakdown: breakdowns }) => ({
|
261
|
-
id,
|
262
|
-
total,
|
263
|
-
timestamp,
|
264
|
-
breakdowns,
|
265
|
-
}))?.[0] ?? undefined);
|
266
|
-
const aprRecord = opp.status === "LIVE"
|
267
|
-
? (AprRecords?.map(({ cumulated, timestamp, AprBreakdown: breakdowns }) => ({
|
268
|
-
cumulated,
|
269
|
-
timestamp,
|
270
|
-
breakdowns: breakdowns.map(({ identifier, type, ...breakdown }) => {
|
271
|
-
if (type === AprType.CAMPAIGN) {
|
272
|
-
const campaign = DailyRewardsRecords?.[0]?.DailyRewardsBreakdown?.map(breakdown => breakdown.Campaign).find(c => c.campaignId === identifier);
|
273
|
-
if (campaign) {
|
274
|
-
return {
|
275
|
-
distributionType: campaign.distributionType,
|
276
|
-
identifier,
|
277
|
-
type,
|
278
|
-
...breakdown,
|
279
|
-
};
|
280
|
-
}
|
281
|
-
}
|
282
|
-
return {
|
283
|
-
identifier,
|
284
|
-
type,
|
285
|
-
...breakdown,
|
286
|
-
};
|
287
|
-
}),
|
288
|
-
}))?.[0] ?? undefined)
|
289
|
-
: {
|
290
|
-
cumulated: 0,
|
291
|
-
timestamp: AprRecords?.[0]?.timestamp ?? 0n,
|
292
|
-
breakdowns: !AprRecords?.[0]?.AprBreakdown?.[0] ? [] : [{ ...AprRecords?.[0]?.AprBreakdown[0], value: 0 }],
|
293
|
-
};
|
294
|
-
const formated = {
|
295
|
-
...OpportunityService.formatResponseBase(opp),
|
296
|
-
apr: opp.apr,
|
297
|
-
aprRecord,
|
298
|
-
tvlRecord,
|
299
|
-
rewardsRecord,
|
300
|
-
campaigns: !!Campaigns ? Campaigns?.map(c => CampaignService.format(c)) : undefined,
|
301
|
-
//TODO: change this to accomodate all return types
|
302
|
-
};
|
303
|
-
// biome-ignore lint/performance/noDelete: <explanation>
|
304
|
-
if (!Campaigns)
|
305
|
-
delete formated.campaigns;
|
306
|
-
return formated;
|
307
|
-
}
|
308
|
-
static formatResponseBase(opportunity) {
|
309
|
-
let { mainProtocolId, id, Tokens, Chain, Protocols, MainProtocol, lastCampaignCreatedAt, depositUrl, explorerAddress, manualOverrides, ...opp } = opportunity;
|
310
|
-
if (mainProtocolId === "unknown") {
|
311
|
-
MainProtocol = null;
|
312
|
-
}
|
313
|
-
return {
|
314
|
-
...opp,
|
315
|
-
id,
|
316
|
-
depositUrl: depositUrl ?? undefined,
|
317
|
-
explorerAddress: explorerAddress ?? undefined,
|
318
|
-
lastCampaignCreatedAt: lastCampaignCreatedAt.toISOString(),
|
319
|
-
tokens: Tokens.map(t => TokenService.format(t)),
|
320
|
-
chain: Chain,
|
321
|
-
protocol: MainProtocol ?? undefined,
|
322
|
-
};
|
323
|
-
}
|
324
|
-
static aggregate(query, field) {
|
325
|
-
return OpportunityRepository.aggregateSum(field, query);
|
326
|
-
}
|
327
|
-
static aggregateMin(query, field) {
|
328
|
-
return OpportunityRepository.aggregateMin(field, query);
|
329
|
-
}
|
330
|
-
static aggregateMax(query, field) {
|
331
|
-
return OpportunityRepository.aggregateMax(field, query);
|
332
|
-
}
|
333
|
-
static async update(id, data) {
|
334
|
-
return await OpportunityRepository.update(id, data);
|
335
|
-
}
|
336
|
-
static async updateMany(ids, data) {
|
337
|
-
return await OpportunityRepository.updateMany(ids, data);
|
338
|
-
}
|
339
|
-
static async description(action, tokens, protocol, chainId) {
|
340
|
-
const chain = await ChainService.findUniqueOrThrow(chainId);
|
341
|
-
const symbols = tokens?.map(t => t.symbol).join("-");
|
342
|
-
if (action === "POOL")
|
343
|
-
return `Earn rewards by providing liquidity to the ${protocol?.name} ${symbols} pool on ${chain.name}, or through a liquidity manager supported by Merkl`;
|
344
|
-
if (action === "HOLD")
|
345
|
-
return `Earn rewards by holding ${symbols} or by staking it in a supported contract`;
|
346
|
-
if (action === "LEND")
|
347
|
-
return `Earn rewards by lending ${symbols} to ${protocol?.name} on ${chain.name}`;
|
348
|
-
if (action === "BORROW")
|
349
|
-
return `Earn rewards by taking a long position on ${protocol?.name} ${symbols} on ${chain.name}`;
|
350
|
-
if (action === "DROP")
|
351
|
-
return `Visit your dashboard to check if you've earned rewards from this airdrop`;
|
352
|
-
if (action === "LONG")
|
353
|
-
return `Borrow ${symbols} on ${protocol?.name} on ${chain.name}`;
|
354
|
-
if (action === "SHORT")
|
355
|
-
return `Earn rewards by taking a short position on ${protocol?.name} ${symbols} on ${chain.name}`;
|
356
|
-
if (action === "SWAP")
|
357
|
-
return `Earn rewards by trading ${symbols} on ${chain.name}`;
|
358
|
-
return "";
|
359
|
-
}
|
360
|
-
static howToSteps(action, tokens, protocol) {
|
361
|
-
const symbols = tokens?.map(t => t.symbol).join("-");
|
362
|
-
if (action === "POOL")
|
363
|
-
return [`Provide liquidity on ${protocol?.name}.`, "Earn rewards based on your liquidity position."];
|
364
|
-
if (action === "HOLD")
|
365
|
-
return [`Hold ${symbols}.`, "Rewards accumulate automatically."];
|
366
|
-
if (action === "LEND")
|
367
|
-
return [`Lend assets on ${protocol?.name}.`, "Rewards accumulate automatically."];
|
368
|
-
if (action === "BORROW")
|
369
|
-
return [`Borrow assets on ${protocol?.name}.`, "Rewards accumulate automatically."];
|
370
|
-
if (action === "DROP")
|
371
|
-
return ["Check your eligibility on Merkl."];
|
372
|
-
if (action === "LONG")
|
373
|
-
return [`Open a long position on ${protocol?.name}.`, "Rewards accumulate automatically."];
|
374
|
-
if (action === "SHORT")
|
375
|
-
return [`Open a short position on ${protocol?.name}.`, "Rewards accumulate automatically."];
|
376
|
-
if (action === "SWAP")
|
377
|
-
return [`Swap on ${protocol?.name}.`, "Rewards accumulate automatically."];
|
378
|
-
return [];
|
379
|
-
}
|
380
|
-
}
|
@@ -1,6 +0,0 @@
|
|
1
|
-
import { CampaignService } from "@/modules/v4/campaign/campaign.service";
|
2
|
-
export function transformId({ params }) {
|
3
|
-
const [chainId, type, campaignId] = params.id.split("-");
|
4
|
-
if (!Number.isNaN(+type))
|
5
|
-
params.id = `${chainId}-${CampaignService.getTypeFromV3(+type)}-${campaignId}`;
|
6
|
-
}
|
@@ -1,12 +0,0 @@
|
|
1
|
-
import { BadRequestError } from "@/errors";
|
2
|
-
import { Campaign as CampaignType } from "@sdk";
|
3
|
-
export const validateId = ({ params }) => {
|
4
|
-
if (!params.id.includes("-")) {
|
5
|
-
if (/[0-9]{1,20}/.test(params.id))
|
6
|
-
return;
|
7
|
-
throw new BadRequestError("Invalid Opportunity id");
|
8
|
-
}
|
9
|
-
const [_chainId, type, _campaignId] = params.id.split("-");
|
10
|
-
if (!Object.values(CampaignType).includes(type))
|
11
|
-
throw new BadRequestError("Invalid Campaign type", Object.keys(CampaignType));
|
12
|
-
};
|
@@ -1,56 +0,0 @@
|
|
1
|
-
import { ConflictError } from "@/errors/Conflict.error";
|
2
|
-
import { AuthorizationHeadersDto, BackOfficeGuard } from "@/guards/BackOffice.guard";
|
3
|
-
import Elysia from "elysia";
|
4
|
-
import { CreatePriceSourceDto, PriceSourceIdentifier, UpdatePriceSourceDto } from "./price.model";
|
5
|
-
import { PriceService } from "./price.service";
|
6
|
-
// ─── Prices Controller ───────────────────────────────────────────────────────
|
7
|
-
export const PriceController = new Elysia({ prefix: "/prices", detail: { tags: ["Prices"], hide: true } })
|
8
|
-
// ─── Get All Prices ──────────────────────────────────────────────────
|
9
|
-
.get("/", async () => await PriceService.findMany())
|
10
|
-
.get("/array", async () => await PriceService.findManyArray())
|
11
|
-
// ─── Get Price By Token Symbol ───────────────────────────────────────
|
12
|
-
.get("/symbol/:symbol", async ({ params }) => await PriceService.fetchPriceBySymbol(params.symbol), {
|
13
|
-
params: PriceSourceIdentifier,
|
14
|
-
})
|
15
|
-
// ─── Price Sources Group ─────────────────────────────────────────────
|
16
|
-
.group("/sources", app => {
|
17
|
-
return (app
|
18
|
-
// ─── Get All Price Sources ───────────────────
|
19
|
-
.get("/", async () => await PriceService.findManyPriceSources({}))
|
20
|
-
// ─── Get Price Source By Token Symbol ────────
|
21
|
-
.get("/symbol/:symbol", async ({ params }) => await PriceService.getPriceSourceBySymbol(params.symbol), {
|
22
|
-
params: PriceSourceIdentifier,
|
23
|
-
})
|
24
|
-
// ─── Create A Price Source ───────────────────
|
25
|
-
.post("/", async ({ body }) => {
|
26
|
-
try {
|
27
|
-
return await PriceService.createPriceSource(body);
|
28
|
-
}
|
29
|
-
catch (err) {
|
30
|
-
if (err && err.code === "P2002") {
|
31
|
-
throw new ConflictError();
|
32
|
-
}
|
33
|
-
throw err;
|
34
|
-
}
|
35
|
-
}, {
|
36
|
-
headers: AuthorizationHeadersDto,
|
37
|
-
body: CreatePriceSourceDto,
|
38
|
-
beforeHandle: BackOfficeGuard,
|
39
|
-
detail: { hide: true },
|
40
|
-
})
|
41
|
-
// ─── Update A Price Source ───────────────────
|
42
|
-
.patch("/symbol/:symbol", async ({ params, body }) => await PriceService.updatePriceSource(params.symbol, body), {
|
43
|
-
headers: AuthorizationHeadersDto,
|
44
|
-
params: PriceSourceIdentifier,
|
45
|
-
body: UpdatePriceSourceDto,
|
46
|
-
beforeHandle: BackOfficeGuard,
|
47
|
-
detail: { hide: true },
|
48
|
-
})
|
49
|
-
// ─── Delete A Price Source ───────────────────
|
50
|
-
.delete("/symbol/:symbol", async ({ params }) => await PriceService.deletePriceSource(params.symbol), {
|
51
|
-
headers: AuthorizationHeadersDto,
|
52
|
-
params: PriceSourceIdentifier,
|
53
|
-
beforeHandle: BackOfficeGuard,
|
54
|
-
detail: { hide: true },
|
55
|
-
}));
|
56
|
-
});
|
@@ -1,12 +0,0 @@
|
|
1
|
-
import { PriceSourceMethod } from "@db/api";
|
2
|
-
import { t } from "elysia";
|
3
|
-
// ─── DTOs ────────────────────────────────────────────────────────────────────
|
4
|
-
export const CreatePriceSourceDto = t.Object({
|
5
|
-
symbol: t.String(),
|
6
|
-
method: t.Enum(PriceSourceMethod),
|
7
|
-
args: t.Object({}, { additionalProperties: true }),
|
8
|
-
});
|
9
|
-
export const UpdatePriceSourceDto = t.Partial(CreatePriceSourceDto);
|
10
|
-
export const PriceSourceIdentifier = t.Object({
|
11
|
-
symbol: t.String(),
|
12
|
-
});
|
@@ -1,22 +0,0 @@
|
|
1
|
-
import { apiDbClient } from "@db";
|
2
|
-
export class PriceRepository {
|
3
|
-
static async findBySymbolOrThrow(symbol) {
|
4
|
-
return await apiDbClient.priceSource.findUniqueOrThrow({ where: { symbol } });
|
5
|
-
}
|
6
|
-
static async findManyPriceSources(query) {
|
7
|
-
return await apiDbClient.priceSource.findMany({
|
8
|
-
where: {
|
9
|
-
method: query?.method ?? undefined,
|
10
|
-
},
|
11
|
-
});
|
12
|
-
}
|
13
|
-
static async create(priceSource) {
|
14
|
-
return await apiDbClient.priceSource.create({ data: priceSource });
|
15
|
-
}
|
16
|
-
static async updateBySymbol(unique, newPriceSource) {
|
17
|
-
return await apiDbClient.priceSource.update({ where: { symbol: unique }, data: newPriceSource });
|
18
|
-
}
|
19
|
-
static async deleteBySymbol(symbol) {
|
20
|
-
return await apiDbClient.priceSource.delete({ where: { symbol } });
|
21
|
-
}
|
22
|
-
}
|
@@ -1,63 +0,0 @@
|
|
1
|
-
import { UnableToFindPrice } from "@/errors";
|
2
|
-
import { Pricer } from "@/utils/pricer";
|
3
|
-
import PriceFetcherFactory from "@/utils/prices/priceFetcherFactory";
|
4
|
-
import { PriceSourceMethod } from "@db/api";
|
5
|
-
import { TokenService } from "../token/token.service";
|
6
|
-
import { PriceRepository } from "./price.repository";
|
7
|
-
export class PriceService {
|
8
|
-
// ─── Prices ──────────────────────────────────────────────────────────
|
9
|
-
static async findMany() {
|
10
|
-
return (await Pricer.load()).prices;
|
11
|
-
}
|
12
|
-
static async findManyArray() {
|
13
|
-
return (await Pricer.load()).getArray();
|
14
|
-
}
|
15
|
-
/** Fetches a single price */
|
16
|
-
static async fetchPriceBySymbol(symbol) {
|
17
|
-
const priceSource = await PriceRepository.findBySymbolOrThrow(symbol);
|
18
|
-
if (!priceSource) {
|
19
|
-
throw new Error(`Price source with symbol ${symbol} not found`);
|
20
|
-
}
|
21
|
-
if (priceSource.method === PriceSourceMethod.CONSTANT) {
|
22
|
-
return priceSource.args.value;
|
23
|
-
}
|
24
|
-
if (priceSource.method === PriceSourceMethod.EQUAL_TO) {
|
25
|
-
return PriceService.fetchPriceBySymbol(priceSource.args.token);
|
26
|
-
}
|
27
|
-
return (await PriceFetcherFactory.instance.get(priceSource.method).getPrice([priceSource]))?.[0]?.rate;
|
28
|
-
}
|
29
|
-
// ─── Price Sources ───────────────────────────────────────────────────
|
30
|
-
static async getPriceSourceBySymbol(symbol) {
|
31
|
-
return await PriceRepository.findBySymbolOrThrow(symbol);
|
32
|
-
}
|
33
|
-
static async findManyPriceSources(query) {
|
34
|
-
return await PriceRepository.findManyPriceSources(query);
|
35
|
-
}
|
36
|
-
static async createPriceSource(priceSource) {
|
37
|
-
const created = await PriceRepository.create(priceSource);
|
38
|
-
try {
|
39
|
-
const price = await PriceService.fetchPriceBySymbol(created.symbol);
|
40
|
-
if (price === undefined || price === null) {
|
41
|
-
throw new Error();
|
42
|
-
}
|
43
|
-
if (priceSource.symbol.startsWith("0x")) {
|
44
|
-
await TokenService.updateAddressPrices(priceSource.symbol, price);
|
45
|
-
}
|
46
|
-
else {
|
47
|
-
await TokenService.updateSymbolPrices(priceSource.symbol, price, []);
|
48
|
-
}
|
49
|
-
return price;
|
50
|
-
}
|
51
|
-
catch (e) {
|
52
|
-
console.error(e);
|
53
|
-
await PriceRepository.deleteBySymbol(created.symbol);
|
54
|
-
throw new UnableToFindPrice(e.toString());
|
55
|
-
}
|
56
|
-
}
|
57
|
-
static async updatePriceSource(symbol, newPriceSource) {
|
58
|
-
return await PriceRepository.updateBySymbol(symbol, newPriceSource);
|
59
|
-
}
|
60
|
-
static async deletePriceSource(symbol) {
|
61
|
-
return await PriceRepository.deleteBySymbol(symbol);
|
62
|
-
}
|
63
|
-
}
|
@@ -1 +0,0 @@
|
|
1
|
-
export {};
|
@@ -1,85 +0,0 @@
|
|
1
|
-
import { AuthorizationHeadersDto, BackOfficeGuard } from "@/guards/BackOffice.guard";
|
2
|
-
// import { AuthorizationHeadersDto, BackOfficeGuard } from "@/guards/BackOffice.guard";
|
3
|
-
import Elysia, { t } from "elysia";
|
4
|
-
import { throwOnUnsupportedChainId } from "src/utils/throw";
|
5
|
-
import { CampaignAmountsInputDto, CampaignDataDto, CampaignPayloadInputDto, ProgramPayloadInputDto, SinglePayloadInputDto, } from "./programPayload.model";
|
6
|
-
import { ProgramPayloadService } from "./programPayload.service";
|
7
|
-
// ─── ProgramPaylod Controller ───────────────────────────────────────────────────────
|
8
|
-
export const ProgramPayloadController = new Elysia({ prefix: "/program-payload", detail: { tags: ["ProgramPayload"] } })
|
9
|
-
// ─── Get payload for a specific campaign key ───────────────────────────────────────
|
10
|
-
.get("/", async ({ query }) => {
|
11
|
-
return ProgramPayloadService.buildPayload(query);
|
12
|
-
}, {
|
13
|
-
query: CampaignPayloadInputDto,
|
14
|
-
// headers: AuthorizationHeadersDto,
|
15
|
-
beforeHandle: ({ query, headers }) => {
|
16
|
-
// BackOfficeGuard({ headers });
|
17
|
-
throwOnUnsupportedChainId(query.distributionChainId);
|
18
|
-
},
|
19
|
-
})
|
20
|
-
.get("/config", async ({ query }) => {
|
21
|
-
return ProgramPayloadService.buildConfig(query);
|
22
|
-
}, {
|
23
|
-
query: CampaignPayloadInputDto,
|
24
|
-
// headers: AuthorizationHeadersDto,
|
25
|
-
beforeHandle: ({ query, headers }) => {
|
26
|
-
// BackOfficeGuard({ headers });
|
27
|
-
throwOnUnsupportedChainId(query.distributionChainId);
|
28
|
-
},
|
29
|
-
detail: { description: "Generate the configuration for a specific hardcoded campaign from a program" },
|
30
|
-
})
|
31
|
-
.get("/template-config/:campaignType", async ({ params }) => {
|
32
|
-
return ProgramPayloadService.buildConfigTemplate(params);
|
33
|
-
}, {
|
34
|
-
params: t.Object({ campaignType: t.Number() }),
|
35
|
-
detail: { description: "Generate the template configuration with expected types for a specific campaign" },
|
36
|
-
})
|
37
|
-
.get("/campaignData", async ({ query }) => {
|
38
|
-
return ProgramPayloadService.buildCampaignData(query);
|
39
|
-
}, {
|
40
|
-
query: CampaignPayloadInputDto,
|
41
|
-
// headers: AuthorizationHeadersDto,
|
42
|
-
beforeHandle: ({ query, headers }) => {
|
43
|
-
// BackOfficeGuard({ headers });
|
44
|
-
throwOnUnsupportedChainId(query.distributionChainId);
|
45
|
-
},
|
46
|
-
detail: { description: "Generate the campaign data for a specific hardcoded campaign from a program" },
|
47
|
-
})
|
48
|
-
.get("/program", async ({ query }) => {
|
49
|
-
return ProgramPayloadService.buildProgramPayload(query);
|
50
|
-
}, {
|
51
|
-
query: ProgramPayloadInputDto,
|
52
|
-
// headers: AuthorizationHeadersDto,
|
53
|
-
beforeHandle: ({ query, headers }) => {
|
54
|
-
// BackOfficeGuard({ headers });
|
55
|
-
throwOnUnsupportedChainId(query.distributionChainId);
|
56
|
-
},
|
57
|
-
detail: { description: "Generate the complete payload for a program" },
|
58
|
-
})
|
59
|
-
.post("/program/withAmounts", async ({ query, body }) => {
|
60
|
-
return ProgramPayloadService.buildProgramPayloadWithAmounts(query, body);
|
61
|
-
}, {
|
62
|
-
query: ProgramPayloadInputDto,
|
63
|
-
body: CampaignAmountsInputDto,
|
64
|
-
beforeHandle: ({ query }) => {
|
65
|
-
throwOnUnsupportedChainId(query.distributionChainId);
|
66
|
-
},
|
67
|
-
detail: { description: "Generate the payload with the campaigns and amounts provided" },
|
68
|
-
})
|
69
|
-
.post("/payload/from-config", async ({ query, body }) => {
|
70
|
-
return ProgramPayloadService.buildPayloadFromConfig(body, query.debug);
|
71
|
-
}, {
|
72
|
-
query: t.Object({ debug: t.Optional(t.Boolean({ description: "Debug mode" })) }),
|
73
|
-
body: SinglePayloadInputDto,
|
74
|
-
detail: { description: "BETA FEATURE : Generate the payload from a config file." },
|
75
|
-
})
|
76
|
-
.post("/parse/from-campaign-data", async ({ body }) => {
|
77
|
-
return ProgramPayloadService.buildConfigFromCampaignData(body);
|
78
|
-
}, {
|
79
|
-
headers: AuthorizationHeadersDto,
|
80
|
-
body: CampaignDataDto,
|
81
|
-
beforeHandle: ({ headers }) => {
|
82
|
-
BackOfficeGuard({ headers });
|
83
|
-
},
|
84
|
-
detail: { hide: true },
|
85
|
-
});
|