@merkl/api 0.10.129 → 0.10.130
Sign up to get free protection for your applications and to get access to all the features.
- package/dist/database/api/.generated/default.js +1 -0
- package/dist/database/api/.generated/edge.js +609 -0
- package/dist/database/api/.generated/index-browser.js +586 -0
- package/dist/database/api/.generated/index.js +638 -0
- package/dist/database/api/.generated/runtime/edge-esm.js +31 -0
- package/dist/database/api/.generated/runtime/edge.js +31 -0
- package/dist/database/api/.generated/runtime/index-browser.js +13 -0
- package/dist/database/api/.generated/runtime/library.js +143 -0
- package/dist/database/api/.generated/runtime/react-native.js +80 -0
- package/dist/database/api/.generated/runtime/wasm.js +32 -0
- package/dist/database/api/.generated/wasm.js +586 -0
- package/dist/database/api/seeder/resources/protocol.js +341 -0
- package/dist/database/engine/.generated/default.js +1 -0
- package/dist/database/engine/.generated/edge.js +438 -0
- package/dist/database/engine/.generated/index-browser.js +415 -0
- package/dist/database/engine/.generated/index.js +467 -0
- package/dist/database/engine/.generated/runtime/edge-esm.js +31 -0
- package/dist/database/engine/.generated/runtime/edge.js +31 -0
- package/dist/database/engine/.generated/runtime/index-browser.js +13 -0
- package/dist/database/engine/.generated/runtime/library.js +143 -0
- package/dist/database/engine/.generated/runtime/react-native.js +80 -0
- package/dist/database/engine/.generated/runtime/wasm.js +32 -0
- package/dist/database/engine/.generated/wasm.js +415 -0
- package/dist/node_modules/@elysiajs/eden/eden/LICENSE +7 -0
- package/dist/node_modules/@elysiajs/eden/eden/README.md +46 -0
- package/dist/node_modules/@elysiajs/eden/eden/bunfig.toml +2 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/chunk-2IHGLN7W.mjs +1 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/chunk-7WO4HTSU.mjs +1 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/chunk-XYW4OUFN.mjs +1 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/chunk-YAG46HFR.mjs +1 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/errors.d.ts +5 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/fetch/index.d.ts +4 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/fetch/types.d.ts +44 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/fetch.d.mts +48 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/fetch.d.ts +48 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/fetch.global.js +1 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/fetch.js +1 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/fetch.mjs +1 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/index.d.mts +5 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/index.d.ts +5 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/index.global.js +1 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/index.js +1 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/index.mjs +1 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/treaty/index.d.ts +17 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/treaty/types.d.ts +99 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/treaty/utils.d.ts +1 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/treaty.d.mts +114 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/treaty.d.ts +114 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/treaty.global.js +1 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/treaty.js +1 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/treaty.mjs +1 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/treaty2/index.d.ts +5 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/treaty2/types.d.ts +86 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/treaty2/ws.d.ts +14 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/treaty2.d.mts +103 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/treaty2.d.ts +103 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/treaty2.global.js +1 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/treaty2.js +1 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/treaty2.mjs +1 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/types-C41kuZ-K.d.mts +44 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/types-C41kuZ-K.d.ts +44 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/types.d.ts +39 -0
- package/dist/node_modules/@elysiajs/eden/eden/dist/utils/parsingUtils.d.ts +6 -0
- package/dist/node_modules/@elysiajs/eden/eden/package.json +85 -0
- package/dist/package.json +2 -2
- package/dist/src/backgroundJobs/index.js +44 -0
- package/dist/src/backgroundJobs/jobs/campaignsCacheUpdater.js +160 -0
- package/dist/src/backgroundJobs/jobs/health.js +15 -0
- package/dist/src/backgroundJobs/jobs/opportunityUpdater.js +63 -0
- package/dist/src/backgroundJobs/jobs/priceUpdater.js +16 -0
- package/dist/src/backgroundJobs/jobs/sync.js +33 -0
- package/dist/src/cache/declaration.js +146 -0
- package/dist/src/cache/index.js +152 -0
- package/dist/src/cache/redis.js +49 -0
- package/dist/src/constants.js +119 -0
- package/dist/src/entities/campaign.js +134 -0
- package/dist/src/entities/opportunity.js +549 -0
- package/dist/src/errors/BadRequest.error.js +7 -0
- package/dist/src/errors/Conflict.error.js +7 -0
- package/dist/src/errors/HttpError.js +11 -0
- package/dist/src/errors/NotFound.error.js +7 -0
- package/dist/src/errors/Opportunity.error.js +11 -0
- package/dist/src/errors/Unauthorized.error.js +7 -0
- package/dist/src/errors/index.js +5 -0
- package/dist/src/guards/BackOffice.guard.js +10 -0
- package/dist/src/guards/Engine.guard.js +10 -0
- package/dist/src/guards/TokenAuth.guard.js +10 -0
- package/dist/src/hooks/checkQueryAddressValidity.js +7 -0
- package/dist/src/hooks/checkQueryChainIdValidity.js +7 -0
- package/dist/src/index.js +79 -0
- package/dist/src/internal/controllers/endingCampaigns.js +41 -0
- package/dist/src/internal/controllers/unclaimed.js +36 -0
- package/dist/src/internal/index.js +30 -0
- package/dist/src/libs/campaigns/campaignTypes/AjnaDynamicData.js +111 -0
- package/dist/src/libs/campaigns/campaignTypes/BadgerDynamicData.js +93 -0
- package/dist/src/libs/campaigns/campaignTypes/CLAMMDynamicData.js +942 -0
- package/dist/src/libs/campaigns/campaignTypes/CompoundDynamicData.js +90 -0
- package/dist/src/libs/campaigns/campaignTypes/DolomiteDynamicData.js +60 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20DynamicData.js +162 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20DynamicDataRefacto.js +159 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/helpers/eulerVaultNames.js +13 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/helpers/factoryFinder.js +29 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/helpers/getBlacklistedSupply.js +22 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/helpers/metamorphoTvl.js +35 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/helpers/spliceTVL.js +21 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/helpers/tokenType.js +106 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/AaveProcessor.js +26 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/AssetProcessor.js +47 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/AuraProcessor.js +103 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/BalancerGaugeProcessor.js +83 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/BalancerPoolProcessor.js +99 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/BeefyProcessor.js +51 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/CompoundProcessor.js +36 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/EnzymeProcessor.js +51 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/EulerBorrowProcessor.js +46 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/EulerLendProcessor.js +47 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/FluidProcessor.js +36 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/FraxProcessor.js +41 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/GearboxProcessor.js +44 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/GenericProcessor.js +239 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/MetamorphoProcessor.js +43 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/PendleProcessor.js +31 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/RadiantProcessor.js +58 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/RfxProcessor.js +64 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/SpliceProcessor.js +35 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/SturdySiloProcessor.js +37 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/TemplateProcessor.js +40 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/TorosProcessor.js +33 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/UniswapProcessor.js +48 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/WoofiProcessor.js +40 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/curveProcessor.js +68 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/processor/processorMapping.js +77 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/subtypesPrices.js +583 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/subtypesPricesRefactoFinal.js +24 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/subtypesRound1.js +1209 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/subtypesRound1RefactoFinal.js +194 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/subtypesRound2.js +645 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/subtypesRound2RefactoFinal.js +22 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/subtypesRound3.js +392 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/subtypesRound3RefactoFinal.js +22 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/subtypesRound4.js +323 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20SubTypes/subtypesRound4RefactoFinal.js +22 -0
- package/dist/src/libs/campaigns/campaignTypes/ERC20_SNAPSHOTDynamicData.js +38 -0
- package/dist/src/libs/campaigns/campaignTypes/EulerDynamicData.js +165 -0
- package/dist/src/libs/campaigns/campaignTypes/JSON_AIRDROPDynamicData.js +19 -0
- package/dist/src/libs/campaigns/campaignTypes/MORPHODynamicData.js +120 -0
- package/dist/src/libs/campaigns/campaignTypes/RadiantDynamicData.js +112 -0
- package/dist/src/libs/campaigns/campaignTypes/SILODynamicData.js +113 -0
- package/dist/src/libs/campaigns/campaignsDynamicData.js +83 -0
- package/dist/src/libs/campaigns/campaignsDynamicDataRefacto.js +78 -0
- package/dist/src/libs/campaigns/getCampaigns.js +18 -0
- package/dist/src/libs/campaigns/utils/fetchA51Strategies.js +44 -0
- package/dist/src/libs/campaigns/utils/fetchClamInfo.js +27 -0
- package/dist/src/libs/campaigns/utils/fetchLogs.js +91 -0
- package/dist/src/libs/campaigns/utils/getCompV2ForksVaults.js +122 -0
- package/dist/src/libs/campaigns/utils/getContractCreationBlock.js +44 -0
- package/dist/src/libs/campaigns/utils/getDolomiteMarkets.js +50 -0
- package/dist/src/libs/campaigns/utils/getEulerV2Vaults.js +87 -0
- package/dist/src/libs/campaigns/utils/getLastEligibilityRatio.js +56 -0
- package/dist/src/libs/computeFee.js +34 -0
- package/dist/src/libs/custom/twtParticipants.js +54 -0
- package/dist/src/libs/deprecated-merklv3/index.js +184 -0
- package/dist/src/libs/getTokensList.js +37 -0
- package/dist/src/libs/merklChainData.js +129 -0
- package/dist/src/libs/parse/marketsWithCache.js +8 -0
- package/dist/src/libs/positions/ajna/index.js +107 -0
- package/dist/src/libs/positions/badger/index.js +79 -0
- package/dist/src/libs/positions/clamm/index.js +419 -0
- package/dist/src/libs/positions/clamm/thegraph/fetchAlmPositions.js +35 -0
- package/dist/src/libs/positions/clamm/thegraph/fetchAmmPositions.js +35 -0
- package/dist/src/libs/positions/clamm/thegraph/fetchFarmedPositions.js +44 -0
- package/dist/src/libs/positions/clamm/thegraph/index.js +162 -0
- package/dist/src/libs/positions/compound/index.js +93 -0
- package/dist/src/libs/positions/dolomite/index.js +49 -0
- package/dist/src/libs/positions/erc20/index.js +55 -0
- package/dist/src/libs/positions/euler/index.js +57 -0
- package/dist/src/libs/positions/index.js +48 -0
- package/dist/src/libs/positions/morpho/index.js +177 -0
- package/dist/src/libs/positions/prepareFetch.js +339 -0
- package/dist/src/libs/positions/silo/index.js +67 -0
- package/dist/src/libs/positions/types.js +1 -0
- package/dist/src/libs/reports/campaignReport.js +37 -0
- package/dist/src/libs/reports/mainParameterRewards.js +48 -0
- package/dist/src/libs/rewards/userRewards.js +154 -0
- package/dist/src/libs/staticCampaigns.js +10 -0
- package/dist/src/libs/tokens/balances.js +126 -0
- package/dist/src/libs/tokens/tokenInfo.js +22 -0
- package/dist/src/modules/v4/accounting/accounting.controller.js +66 -0
- package/dist/src/modules/v4/accounting/accounting.model.js +32 -0
- package/dist/src/modules/v4/accounting/accounting.repository.js +100 -0
- package/dist/src/modules/v4/accounting/accounting.service.js +78 -0
- package/dist/src/modules/v4/accounting/index.js +3 -0
- package/dist/src/modules/v4/apr/apr.controller.js +1 -0
- package/dist/src/modules/v4/apr/apr.model.js +1 -0
- package/dist/src/modules/v4/apr/apr.repository.js +1 -0
- package/dist/src/modules/v4/apr/apr.service.js +40 -0
- package/dist/src/modules/v4/apr/index.js +2 -0
- package/dist/src/modules/v4/blacklist/blacklist.controller.js +45 -0
- package/dist/src/modules/v4/blacklist/blacklist.model.js +13 -0
- package/dist/src/modules/v4/blacklist/blacklist.repository.js +56 -0
- package/dist/src/modules/v4/blacklist/blacklist.service.js +24 -0
- package/dist/src/modules/v4/blacklist/index.js +3 -0
- package/dist/src/modules/v4/cache/cache.model.js +14 -0
- package/dist/src/modules/v4/cache/cache.repository.js +10 -0
- package/dist/src/modules/v4/cache/cache.service.js +44 -0
- package/dist/src/modules/v4/cache/index.js +1 -0
- package/dist/src/modules/v4/campaign/campaign.controller.js +56 -0
- package/dist/src/modules/v4/campaign/campaign.model.js +54 -0
- package/dist/src/modules/v4/campaign/campaign.repository.js +346 -0
- package/dist/src/modules/v4/campaign/campaign.service.js +203 -0
- package/dist/src/modules/v4/campaign/index.js +3 -0
- package/dist/src/modules/v4/chain/chain.controller.js +40 -0
- package/dist/src/modules/v4/chain/chain.model.js +17 -0
- package/dist/src/modules/v4/chain/chain.repository.js +64 -0
- package/dist/src/modules/v4/chain/chain.service.js +42 -0
- package/dist/src/modules/v4/chain/index.js +3 -0
- package/dist/src/modules/v4/dynamicData/dynamicData.controller.js +19 -0
- package/dist/src/modules/v4/dynamicData/dynamicData.model.js +6 -0
- package/dist/src/modules/v4/dynamicData/dynamicData.repository.js +1 -0
- package/dist/src/modules/v4/dynamicData/dynamicData.service.js +49 -0
- package/dist/src/modules/v4/dynamicData/index.js +3 -0
- package/dist/src/modules/v4/enso/enso.model.js +108 -0
- package/dist/src/modules/v4/enso/enso.service.js +46 -0
- package/dist/src/modules/v4/explorer/explorer.model.js +2 -0
- package/dist/src/modules/v4/explorer/explorer.repository.js +23 -0
- package/dist/src/modules/v4/explorer/explorer.service.js +24 -0
- package/dist/src/modules/v4/explorer/index.js +1 -0
- package/dist/src/modules/v4/index.js +4 -0
- package/dist/src/modules/v4/merklRoot/index.js +3 -0
- package/dist/src/modules/v4/merklRoot/merklRoot.controller.js +19 -0
- package/dist/src/modules/v4/merklRoot/merklRoot.model.js +6 -0
- package/dist/src/modules/v4/merklRoot/merklRoot.repository.js +31 -0
- package/dist/src/modules/v4/merklRoot/merklRoot.service.js +38 -0
- package/dist/src/modules/v4/opportunity/index.js +3 -0
- package/dist/src/modules/v4/opportunity/opportunity.controller.js +69 -0
- package/dist/src/modules/v4/opportunity/opportunity.model.js +36 -0
- package/dist/src/modules/v4/opportunity/opportunity.repository.d.ts +14 -0
- package/dist/src/modules/v4/opportunity/opportunity.repository.js +217 -0
- package/dist/src/modules/v4/opportunity/opportunity.service.d.ts +0 -15
- package/dist/src/modules/v4/opportunity/opportunity.service.js +180 -0
- package/dist/src/modules/v4/opportunity/subservices/getAjnaMetadata.service.js +50 -0
- package/dist/src/modules/v4/opportunity/subservices/getBadgerMetadata.service.js +23 -0
- package/dist/src/modules/v4/opportunity/subservices/getClammMetadata.service.js +33 -0
- package/dist/src/modules/v4/opportunity/subservices/getCompoundMetadata.service.js +18 -0
- package/dist/src/modules/v4/opportunity/subservices/getDolomiteMetadata.service.js +15 -0
- package/dist/src/modules/v4/opportunity/subservices/getErc20Metadata.service.js +63 -0
- package/dist/src/modules/v4/opportunity/subservices/getErc20SnapshotMetadata.service.js +8 -0
- package/dist/src/modules/v4/opportunity/subservices/getEulerMetadata.service.js +30 -0
- package/dist/src/modules/v4/opportunity/subservices/getJsonAirDropMetadata.service.js +36 -0
- package/dist/src/modules/v4/opportunity/subservices/getMorphoMetadata.service.js +19 -0
- package/dist/src/modules/v4/opportunity/subservices/getRadiantMetadata.service.js +9 -0
- package/dist/src/modules/v4/opportunity/subservices/getSiloMetadata.service.js +13 -0
- package/dist/src/modules/v4/opportunity/transform-id.pipe.js +6 -0
- package/dist/src/modules/v4/opportunity/validate-id.pipe.js +12 -0
- package/dist/src/modules/v4/participate/participate.controller.js +66 -0
- package/dist/src/modules/v4/participate/participate.model.js +24 -0
- package/dist/src/modules/v4/participate/participate.service.js +33 -0
- package/dist/src/modules/v4/price/index.js +3 -0
- package/dist/src/modules/v4/price/price.controller.js +62 -0
- package/dist/src/modules/v4/price/price.model.js +12 -0
- package/dist/src/modules/v4/price/price.repository.js +18 -0
- package/dist/src/modules/v4/price/price.service.js +44 -0
- package/dist/src/modules/v4/prisma/index.js +1 -0
- package/dist/src/modules/v4/protocol/index.js +3 -0
- package/dist/src/modules/v4/protocol/protocol.controller.js +23 -0
- package/dist/src/modules/v4/protocol/protocol.model.js +68 -0
- package/dist/src/modules/v4/protocol/protocol.repository.js +37 -0
- package/dist/src/modules/v4/protocol/protocol.service.js +77 -0
- package/dist/src/modules/v4/reward/index.js +3 -0
- package/dist/src/modules/v4/reward/reward.controller.js +52 -0
- package/dist/src/modules/v4/reward/reward.model.js +104 -0
- package/dist/src/modules/v4/reward/reward.repository.js +237 -0
- package/dist/src/modules/v4/reward/reward.service.js +283 -0
- package/dist/src/modules/v4/reward/rewardConvertor.service.js +136 -0
- package/dist/src/modules/v4/router.js +57 -0
- package/dist/src/modules/v4/status/index.js +3 -0
- package/dist/src/modules/v4/status/status.controller.js +48 -0
- package/dist/src/modules/v4/status/status.model.js +24 -0
- package/dist/src/modules/v4/status/status.repository.js +88 -0
- package/dist/src/modules/v4/status/status.service.js +60 -0
- package/dist/src/modules/v4/token/index.js +3 -0
- package/dist/src/modules/v4/token/token.controller.js +32 -0
- package/dist/src/modules/v4/token/token.model.js +23 -0
- package/dist/src/modules/v4/token/token.repository.js +128 -0
- package/dist/src/modules/v4/token/token.service.js +268 -0
- package/dist/src/modules/v4/tvl/index.js +2 -0
- package/dist/src/modules/v4/tvl/tvl.controller.js +1 -0
- package/dist/src/modules/v4/tvl/tvl.model.js +1 -0
- package/dist/src/modules/v4/tvl/tvl.repository.js +1 -0
- package/dist/src/modules/v4/tvl/tvl.service.js +49 -0
- package/dist/src/modules/v4/uniswapV4/index.js +4 -0
- package/dist/src/modules/v4/uniswapV4/uniswapV4.controller.js +11 -0
- package/dist/src/modules/v4/uniswapV4/uniswapV4.model.js +17 -0
- package/dist/src/modules/v4/uniswapV4/uniswapV4.repository.js +2 -0
- package/dist/src/modules/v4/uniswapV4/uniswapV4.service.js +73 -0
- package/dist/src/modules/v4/user/index.js +3 -0
- package/dist/src/modules/v4/user/user.controller.js +69 -0
- package/dist/src/modules/v4/user/user.model.js +18 -0
- package/dist/src/modules/v4/user/user.repository.js +38 -0
- package/dist/src/modules/v4/user/user.service.js +50 -0
- package/dist/src/plugins/error-handling.plugin.js +28 -0
- package/dist/src/plugins/logger.plugin.js +22 -0
- package/dist/src/routes/v1/allowances.js +115 -0
- package/dist/src/routes/v1/balances.js +25 -0
- package/dist/src/routes/v1/prices.js +11 -0
- package/dist/src/routes/v1/tokens.js +17 -0
- package/dist/src/routes/v2/merkl.js +13 -0
- package/dist/src/routes/v3/ERC20Campaigns.js +63 -0
- package/dist/src/routes/v3/app.js +18 -0
- package/dist/src/routes/v3/blacklist.js +18 -0
- package/dist/src/routes/v3/campaign/delay.js +78 -0
- package/dist/src/routes/v3/campaignClaims.js +24 -0
- package/dist/src/routes/v3/campaignReport.js +22 -0
- package/dist/src/routes/v3/campaignUnclaimed.js +28 -0
- package/dist/src/routes/v3/campaigns.js +101 -0
- package/dist/src/routes/v3/campaignsForMainParameter.js +19 -0
- package/dist/src/routes/v3/campaignsInfo.js +54 -0
- package/dist/src/routes/v3/campaignsRewardsReport.js +47 -0
- package/dist/src/routes/v3/claims.js +45 -0
- package/dist/src/routes/v3/compoundV2.js +9 -0
- package/dist/src/routes/v3/createCampaign.js +66 -0
- package/dist/src/routes/v3/dolomite.js +9 -0
- package/dist/src/routes/v3/euler.js +9 -0
- package/dist/src/routes/v3/exports/campaigns.js +28 -0
- package/dist/src/routes/v3/fetch.js +27 -0
- package/dist/src/routes/v3/health.js +13 -0
- package/dist/src/routes/v3/lostyield.js +98 -0
- package/dist/src/routes/v3/merkl.js +119 -0
- package/dist/src/routes/v3/morphoMarkets.js +27 -0
- package/dist/src/routes/v3/morphoVaults.js +22 -0
- package/dist/src/routes/v3/multiChainPositions.js +69 -0
- package/dist/src/routes/v3/opportunity.js +63 -0
- package/dist/src/routes/v3/overview.js +73 -0
- package/dist/src/routes/v3/parse.js +23 -0
- package/dist/src/routes/v3/payload.js +40 -0
- package/dist/src/routes/v3/poolInfo.js +88 -0
- package/dist/src/routes/v3/positions.js +62 -0
- package/dist/src/routes/v3/radiant.js +26 -0
- package/dist/src/routes/v3/recipients.js +20 -0
- package/dist/src/routes/v3/rewards.js +33 -0
- package/dist/src/routes/v3/rewardsReport.js +51 -0
- package/dist/src/routes/v3/rootForTimestamp.js +47 -0
- package/dist/src/routes/v3/silo.js +20 -0
- package/dist/src/routes/v3/token.js +24 -0
- package/dist/src/routes/v3/tokenUnclaimed.js +24 -0
- package/dist/src/routes/v3/twt/participants.js +11 -0
- package/dist/src/routes/v3/updates.js +47 -0
- package/dist/src/routes/v3/userRewards.js +59 -0
- package/dist/src/types/index.js +6 -0
- package/dist/src/types/parameters/Action.js +11 -0
- package/dist/src/types/parameters/Chain.js +13 -0
- package/dist/src/types/parameters/ChainCampaignId.js +13 -0
- package/dist/src/types/parameters/MainParameter.js +19 -0
- package/dist/src/types/parameters/OpportunityId.js +14 -0
- package/dist/src/types/parameters/Timestamp.js +16 -0
- package/dist/src/types/parameters/Type.js +15 -0
- package/dist/src/types/parameters/index.js +17 -0
- package/dist/src/types/returnTypes.js +1 -0
- package/dist/src/types/utils.js +1 -0
- package/dist/src/utils/addString.js +6 -0
- package/dist/src/utils/bigintToString.js +20 -0
- package/dist/src/utils/crypto.js +4 -0
- package/dist/src/utils/decodeCalls.js +170 -0
- package/dist/src/utils/encodeCalls.js +240 -0
- package/dist/src/utils/error.js +90 -0
- package/dist/src/utils/execute.js +41 -0
- package/dist/src/utils/generateCardName.js +89 -0
- package/dist/src/utils/generic.js +117 -0
- package/dist/src/utils/hashArray.js +4 -0
- package/dist/src/utils/lastBlockBefore.js +78 -0
- package/dist/src/utils/logger.js +52 -0
- package/dist/src/utils/pricer.js +180 -0
- package/dist/src/utils/prices/chainlinkRead.js +8 -0
- package/dist/src/utils/prices/curveVirtualPrice.js +7 -0
- package/dist/src/utils/prices/getDQUICK.js +8 -0
- package/dist/src/utils/prices/priceFetcherFactory.js +29 -0
- package/dist/src/utils/prices/priceService.js +328 -0
- package/dist/src/utils/prices/services/coinGeckoService.js +53 -0
- package/dist/src/utils/prices/services/defillamaService.js +53 -0
- package/dist/src/utils/prices/services/dexScreenerService.js +62 -0
- package/dist/src/utils/prices/services/erc4626Service.js +30 -0
- package/dist/src/utils/prices/services/getERC4626.js +11 -0
- package/dist/src/utils/prices/services/indexCoopService.js +55 -0
- package/dist/src/utils/prices/services/priceFetcher.js +1 -0
- package/dist/src/utils/prices/uniV2Price.js +40 -0
- package/dist/src/utils/prisma.js +12 -0
- package/dist/src/utils/providers.js +30 -0
- package/dist/src/utils/queries/activeCampaigns.js +22 -0
- package/dist/src/utils/queries/allCampaigns.js +51 -0
- package/dist/src/utils/queries/campaignsForMainParameter.js +23 -0
- package/dist/src/utils/queries/claimsOverTime.js +111 -0
- package/dist/src/utils/queries/endingCampaigns.js +21 -0
- package/dist/src/utils/queries/futureCampaigns.js +19 -0
- package/dist/src/utils/queries/mainParameterCampaigns.js +11 -0
- package/dist/src/utils/queries/rewardsAmount.js +106 -0
- package/dist/src/utils/queries/unclaimed.js +81 -0
- package/dist/src/utils/rateLimit.js +13 -0
- package/dist/src/utils/stryke.js +4 -0
- package/dist/src/utils/throw.js +27 -0
- package/dist/src/utils/validation.js +20 -0
- package/dist/tsconfig.package.tsbuildinfo +1 -1
- package/package.json +2 -2
@@ -0,0 +1,47 @@
|
|
1
|
+
import { t } from "elysia";
|
2
|
+
import { merklChainDataWithCache } from "../../libs/merklChainData";
|
3
|
+
import { getCampaignRewardsDeltaWithCache, getCampaignRewardsWithCache } from "../../libs/reports/campaignReport";
|
4
|
+
import { ChainCampaignId } from "../../types/parameters/ChainCampaignId";
|
5
|
+
import { Timestamp } from "../../types/parameters/Timestamp";
|
6
|
+
export const query = t.Object({
|
7
|
+
chain_campaignIds: t.Array(ChainCampaignId.type, {
|
8
|
+
style: "pipeDelimited",
|
9
|
+
examples: {
|
10
|
+
"Shuffle on Ethereum": {
|
11
|
+
value: "1_0xf69d17aa75d36c4a9c6402fd9abc012b66a7947acaa2b20b267fe3ef10733421|1_0x817b90779d8b6789b832c9bafe9aaa22bc907f072dedb31ef0bfb280bf6a037e",
|
12
|
+
},
|
13
|
+
},
|
14
|
+
}),
|
15
|
+
from: t.Optional(Timestamp.type),
|
16
|
+
to: t.Optional(Timestamp.type),
|
17
|
+
});
|
18
|
+
export default (app) => app.get("", async ({ query: { chain_campaignIds, from, to }, set }) => {
|
19
|
+
const rewards = [];
|
20
|
+
const campaigns = chain_campaignIds.map(c_c => {
|
21
|
+
const [chain, campaignId] = c_c.split("_");
|
22
|
+
return [Number.parseInt(chain), campaignId];
|
23
|
+
});
|
24
|
+
const hasValidTimeframe = !!to && !!from;
|
25
|
+
if (!hasValidTimeframe) {
|
26
|
+
const uniqueChains = Array.from(campaigns.reduce((set, [chain]) => set.add(chain), new Set()));
|
27
|
+
const roots = {};
|
28
|
+
for (const chain of uniqueChains)
|
29
|
+
roots[chain] = (await merklChainDataWithCache(chain)).merkleRoot;
|
30
|
+
for (const [chain, campaignId] of campaigns)
|
31
|
+
rewards.push(...(await getCampaignRewardsWithCache(chain, roots[chain] ?? "", campaignId?.toLowerCase())));
|
32
|
+
}
|
33
|
+
else {
|
34
|
+
for (const [chain, campaignId] of campaigns) {
|
35
|
+
rewards.push(...(await getCampaignRewardsDeltaWithCache(chain, from, to, campaignId?.toLowerCase())));
|
36
|
+
}
|
37
|
+
}
|
38
|
+
return rewards;
|
39
|
+
}, {
|
40
|
+
transform({ query }) {
|
41
|
+
query.chain_campaignIds =
|
42
|
+
query.chain_campaignIds?.split?.("|") ??
|
43
|
+
query.chain_campaignIds;
|
44
|
+
},
|
45
|
+
query,
|
46
|
+
tags: ["Rewards"],
|
47
|
+
});
|
@@ -0,0 +1,45 @@
|
|
1
|
+
import { engineDbClient } from "../../utils/prisma";
|
2
|
+
import { ChainId, isSupportedChain } from "@sdk";
|
3
|
+
import { t } from "elysia";
|
4
|
+
import checkQueryAddressValidity from "../../hooks/checkQueryAddressValidity";
|
5
|
+
import { CLAIMS_FOR_CREATOR_TAG, CLAIMS_FOR_CREATOR_TAG_GROUPED, CLAIMS_FOR_USER, CLAIMS_FOR_USER_GROUPED, } from "../../utils/queries/claimsOverTime";
|
6
|
+
export const query = t.Object({
|
7
|
+
creatorTag: t.Optional(t.String()),
|
8
|
+
chainIds: t.Optional(t.Union([t.String(), t.Array(t.String())])),
|
9
|
+
byReason: t.Optional(t.BooleanString()),
|
10
|
+
user: t.String(),
|
11
|
+
});
|
12
|
+
export default (app) => app.use(checkQueryAddressValidity()).get("", async ({ query, path, set }) => {
|
13
|
+
const creatorTag = query.creatorTag;
|
14
|
+
const rawChainIds = query.chainIds;
|
15
|
+
const user = query.user;
|
16
|
+
let chainIds;
|
17
|
+
if (!rawChainIds) {
|
18
|
+
chainIds = Object.keys(ChainId)
|
19
|
+
.map(k => Number.parseInt(k))
|
20
|
+
.filter(k => isSupportedChain(k, "merkl"));
|
21
|
+
}
|
22
|
+
else if (typeof rawChainIds === "string") {
|
23
|
+
chainIds = [Number.parseInt(rawChainIds)];
|
24
|
+
}
|
25
|
+
else {
|
26
|
+
chainIds = rawChainIds.map(chainId => Number.parseInt(chainId));
|
27
|
+
}
|
28
|
+
let byReason = true;
|
29
|
+
if (query.byReason !== undefined) {
|
30
|
+
byReason = query.byReason;
|
31
|
+
}
|
32
|
+
if (!byReason) {
|
33
|
+
if (!!creatorTag) {
|
34
|
+
return await engineDbClient.$queryRaw(CLAIMS_FOR_CREATOR_TAG_GROUPED(chainIds, user, creatorTag));
|
35
|
+
}
|
36
|
+
return await engineDbClient.$queryRaw(CLAIMS_FOR_USER_GROUPED(chainIds, user));
|
37
|
+
}
|
38
|
+
if (!!creatorTag) {
|
39
|
+
return await engineDbClient.$queryRaw(CLAIMS_FOR_CREATOR_TAG(chainIds, user, creatorTag));
|
40
|
+
}
|
41
|
+
return await engineDbClient.$queryRaw(CLAIMS_FOR_USER(chainIds, user));
|
42
|
+
}, {
|
43
|
+
query,
|
44
|
+
tags: ["Rewards"],
|
45
|
+
});
|
@@ -0,0 +1,9 @@
|
|
1
|
+
import { getCompoundV2ForksVaultsWithCache } from "../../libs/campaigns/utils/getCompV2ForksVaults";
|
2
|
+
import { t } from "elysia";
|
3
|
+
export const response = t.Array(t.Object({ address: t.String(), asset: t.String(), chaind: t.Number(), debtTokenAddress: t.String() }));
|
4
|
+
export default (app) => app.get("", async () => {
|
5
|
+
return await getCompoundV2ForksVaultsWithCache();
|
6
|
+
}, {
|
7
|
+
query: t.Object({}),
|
8
|
+
tags: ["Protocols"],
|
9
|
+
});
|
@@ -0,0 +1,66 @@
|
|
1
|
+
import { BN2Number, DistributionCreatorInterface, registry } from "@sdk";
|
2
|
+
import { t } from "elysia";
|
3
|
+
import checkQueryAddressValidity from "../../hooks/checkQueryAddressValidity";
|
4
|
+
import checkQueryChainIdValidity from "../../hooks/checkQueryChainIdValidity";
|
5
|
+
import { merklChainDataWithCache } from "../../libs/merklChainData";
|
6
|
+
import { executeSimple } from "../../utils/execute";
|
7
|
+
export const query = t.Object({
|
8
|
+
chainId: t.Numeric(),
|
9
|
+
user: t.String(),
|
10
|
+
});
|
11
|
+
export default (app) => app
|
12
|
+
.use(checkQueryChainIdValidity())
|
13
|
+
.use(checkQueryAddressValidity())
|
14
|
+
.get("", async (request) => {
|
15
|
+
const chainId = request.query.chainId;
|
16
|
+
const user = request.query.user;
|
17
|
+
const { feeRebate, signed } = await executeSimple(chainId, campaignCreationUserInfo(user, chainId));
|
18
|
+
// Need to get the message and valid tokens from cache
|
19
|
+
const { message, validRewardTokens } = await merklChainDataWithCache(chainId);
|
20
|
+
return {
|
21
|
+
feeRebate,
|
22
|
+
message,
|
23
|
+
signed,
|
24
|
+
validRewardTokens,
|
25
|
+
};
|
26
|
+
}, {
|
27
|
+
query,
|
28
|
+
tags: ["Campaigns"],
|
29
|
+
});
|
30
|
+
async function campaignCreationUserInfo(user, chainId) {
|
31
|
+
const creatorAddress = registry(chainId)?.Merkl?.DistributionCreator;
|
32
|
+
const calls = [
|
33
|
+
{
|
34
|
+
callData: DistributionCreatorInterface.encodeFunctionData("feeRebate", [user]),
|
35
|
+
target: creatorAddress,
|
36
|
+
},
|
37
|
+
{
|
38
|
+
callData: DistributionCreatorInterface.encodeFunctionData("userSignatures", [user]),
|
39
|
+
target: creatorAddress,
|
40
|
+
},
|
41
|
+
{
|
42
|
+
callData: DistributionCreatorInterface.encodeFunctionData("userSignatureWhitelist", [user]),
|
43
|
+
target: creatorAddress,
|
44
|
+
},
|
45
|
+
{
|
46
|
+
callData: DistributionCreatorInterface.encodeFunctionData("messageHash"),
|
47
|
+
target: creatorAddress,
|
48
|
+
},
|
49
|
+
];
|
50
|
+
return {
|
51
|
+
cached: false,
|
52
|
+
call: {
|
53
|
+
callData: calls,
|
54
|
+
handler: () => { },
|
55
|
+
reducer: async (result) => {
|
56
|
+
let i = 0;
|
57
|
+
const feeRebate = BN2Number(DistributionCreatorInterface.decodeFunctionResult("feeRebate", result[i++])[0]?.toString());
|
58
|
+
const signature = DistributionCreatorInterface.decodeFunctionResult("userSignatures", result[i++])[0]?.toString();
|
59
|
+
const signatureWhitelist = DistributionCreatorInterface.decodeFunctionResult("userSignatureWhitelist", result[i++])[0]?.toString();
|
60
|
+
const messageHash = DistributionCreatorInterface.decodeFunctionResult("messageHash", result[i++])[0]?.toString();
|
61
|
+
const signed = signature === messageHash || signatureWhitelist === messageHash;
|
62
|
+
return { feeRebate, signed };
|
63
|
+
},
|
64
|
+
},
|
65
|
+
};
|
66
|
+
}
|
@@ -0,0 +1,9 @@
|
|
1
|
+
import { t } from "elysia";
|
2
|
+
import { getDolomiteMarketWithCache } from "../../libs/campaigns/utils/getDolomiteMarkets";
|
3
|
+
export const response = t.Array(t.Object({ index: t.Number(), token: t.String(), symbol: t.String() }));
|
4
|
+
export default (app) => app.get("", async () => {
|
5
|
+
return await getDolomiteMarketWithCache();
|
6
|
+
}, {
|
7
|
+
query: t.Object({}),
|
8
|
+
tags: ["Protocols"],
|
9
|
+
});
|
@@ -0,0 +1,9 @@
|
|
1
|
+
import { getEulerV2VaultsWithCache } from "../../libs/campaigns/utils/getEulerV2Vaults";
|
2
|
+
import { t } from "elysia";
|
3
|
+
export const response = t.Array(t.Object({ address: t.String(), asset: t.String(), chaind: t.Number(), debtTokenAddress: t.String() }));
|
4
|
+
export default (app) => app.get("", async () => {
|
5
|
+
return await getEulerV2VaultsWithCache();
|
6
|
+
}, {
|
7
|
+
query: t.Object({}),
|
8
|
+
tags: ["Protocols"],
|
9
|
+
});
|
@@ -0,0 +1,28 @@
|
|
1
|
+
import checkQueryChainIdValidity from "../../../hooks/checkQueryChainIdValidity";
|
2
|
+
import { staticCampaignWithCache } from "../../../libs/staticCampaigns";
|
3
|
+
import { engineDbClient } from "../../../utils/prisma";
|
4
|
+
import { t } from "elysia";
|
5
|
+
export const query = t.Object({
|
6
|
+
chainId: t.Numeric(),
|
7
|
+
minIndex: t.Optional(t.Numeric()),
|
8
|
+
});
|
9
|
+
export default (app) => app.use(checkQueryChainIdValidity()).get("", async ({ query }) => {
|
10
|
+
const chainId = query.chainId;
|
11
|
+
const minIndex = query.minIndex;
|
12
|
+
if (!!minIndex || minIndex === 0) {
|
13
|
+
// Query from minIndex
|
14
|
+
return await engineDbClient.campaigns.findMany({
|
15
|
+
where: {
|
16
|
+
chainId: chainId,
|
17
|
+
index: {
|
18
|
+
gte: minIndex,
|
19
|
+
},
|
20
|
+
},
|
21
|
+
});
|
22
|
+
}
|
23
|
+
// Query all campaigns
|
24
|
+
return await staticCampaignWithCache(chainId);
|
25
|
+
}, {
|
26
|
+
query,
|
27
|
+
tags: ["Campaigns"],
|
28
|
+
});
|
@@ -0,0 +1,27 @@
|
|
1
|
+
import { DistributionCreator__factory, parseCampaign, registry } from "@sdk";
|
2
|
+
import { t } from "elysia";
|
3
|
+
import checkQueryChainIdValidity from "../../hooks/checkQueryChainIdValidity";
|
4
|
+
import { providers } from "../../utils/providers";
|
5
|
+
export const query = t.Object({
|
6
|
+
chainId: t.Numeric(),
|
7
|
+
index: t.Numeric(),
|
8
|
+
});
|
9
|
+
/** Fetch params */
|
10
|
+
export default (app) => app.use(checkQueryChainIdValidity()).get("", async (request) => {
|
11
|
+
const chainId = request.query.chainId;
|
12
|
+
/** Merkl reward manager contract */
|
13
|
+
const distributionCreator = DistributionCreator__factory.connect(registry(chainId)?.Merkl?.DistributionCreator, providers[chainId]);
|
14
|
+
const campaignStruct = await distributionCreator.campaignList(request.query.index);
|
15
|
+
try {
|
16
|
+
const parsingResult = await parseCampaign(chainId, campaignStruct, request.query.index ?? 0);
|
17
|
+
if (parsingResult.success)
|
18
|
+
return JSON.stringify(parsingResult.parsedCampaign);
|
19
|
+
throw parsingResult.message;
|
20
|
+
}
|
21
|
+
catch (e) {
|
22
|
+
return { message: `Error parsing campaign: ${e}`, name: "Error" };
|
23
|
+
}
|
24
|
+
}, {
|
25
|
+
query,
|
26
|
+
tags: ["Campaigns"],
|
27
|
+
});
|
@@ -0,0 +1,13 @@
|
|
1
|
+
import { Redis } from "../../cache";
|
2
|
+
import { t } from "elysia";
|
3
|
+
export const response = t.Object({ success: t.Boolean() });
|
4
|
+
export default (app) => app.get("", async () => {
|
5
|
+
// Check if the cache is working
|
6
|
+
await Redis.get("Prices");
|
7
|
+
return {
|
8
|
+
success: true,
|
9
|
+
};
|
10
|
+
}, {
|
11
|
+
query: t.Object({}),
|
12
|
+
tags: ["Onchain"],
|
13
|
+
});
|
@@ -0,0 +1,98 @@
|
|
1
|
+
import { Redis } from "../../cache";
|
2
|
+
import { getLastBlockBeforeWithCache } from "../../utils/lastBlockBefore";
|
3
|
+
import { BN2Number, ChainId, DAY, ERC20Interface } from "@sdk";
|
4
|
+
import { t } from "elysia";
|
5
|
+
import { utils } from "ethers";
|
6
|
+
import moment from "moment";
|
7
|
+
import checkQueryAddressValidity from "../../hooks/checkQueryAddressValidity";
|
8
|
+
import { getTokensListWithCache } from "../../libs/getTokensList";
|
9
|
+
import { batchMulticallCallWithRetry } from "../../utils/generic";
|
10
|
+
import { log } from "../../utils/logger";
|
11
|
+
import { providers } from "../../utils/providers";
|
12
|
+
const CONSTANTS = {
|
13
|
+
[ChainId.MAINNET]: [
|
14
|
+
utils.getAddress("0xa0b86991c6218b36c1d19d4a2e9eb0ce3606eb48"),
|
15
|
+
utils.getAddress("0xdac17f958d2ee523a2206206994597c13d831ec7"),
|
16
|
+
],
|
17
|
+
[ChainId.BASE]: [
|
18
|
+
utils.getAddress("0x833589fcd6edb6e08f4c7c32d4f71b54bda02913"),
|
19
|
+
utils.getAddress("0xfde4C96c8593536E31F229EA8f37b2ADa2699bb2"),
|
20
|
+
],
|
21
|
+
[ChainId.ARBITRUM]: [
|
22
|
+
utils.getAddress("0xaf88d065e77c8cc2239327c5edb3a432268e5831"),
|
23
|
+
utils.getAddress("0xfd086bc7cd5c481dcc9c85ebe478a1c0b69fcbb9"),
|
24
|
+
],
|
25
|
+
[ChainId.OPTIMISM]: [
|
26
|
+
utils.getAddress("0x0b2c639c533813f4aa9d7837caf62653d097ff85"),
|
27
|
+
utils.getAddress("0x94b008aa00579c1307b0ef2c499ad98a8ce58e58"),
|
28
|
+
],
|
29
|
+
[ChainId.POLYGON]: [
|
30
|
+
utils.getAddress("0x3c499c542cef5e3811e1192ce70d8cc03d5c3359"),
|
31
|
+
utils.getAddress("0xc2132d05d31c914a87c6611c10748aeb04b58e8f"),
|
32
|
+
],
|
33
|
+
};
|
34
|
+
const getLostYield = async (user) => {
|
35
|
+
const tokenList = await getTokensListWithCache();
|
36
|
+
const result = {};
|
37
|
+
const now = moment().unix();
|
38
|
+
const LOOKBACK = 30 * DAY;
|
39
|
+
const AVERAGING_PERIOD = 2 * DAY;
|
40
|
+
const promises = Object.keys(CONSTANTS).map(chainId => (async () => {
|
41
|
+
try {
|
42
|
+
result[chainId] = {};
|
43
|
+
for (const token of CONSTANTS[Number.parseInt(chainId)]) {
|
44
|
+
result[chainId][token] = { total: 0, yield: 0 };
|
45
|
+
}
|
46
|
+
const currentBlockNumber = await providers[Number.parseInt(chainId)].getBlockNumber();
|
47
|
+
const startBlockNumber = await getLastBlockBeforeWithCache(Math.floor((now - LOOKBACK) / AVERAGING_PERIOD) * AVERAGING_PERIOD, Number.parseInt(chainId));
|
48
|
+
const AVERAGING_PERIOD_IN_BLOCKS = Math.floor((currentBlockNumber - startBlockNumber) / (LOOKBACK / AVERAGING_PERIOD));
|
49
|
+
let blockNumber = startBlockNumber;
|
50
|
+
const averagingPromises = [];
|
51
|
+
let blocksByChain = 0;
|
52
|
+
while (blockNumber < currentBlockNumber) {
|
53
|
+
blocksByChain++;
|
54
|
+
averagingPromises.push((async () => {
|
55
|
+
const calls = [];
|
56
|
+
for (const token of CONSTANTS[Number.parseInt(chainId)]) {
|
57
|
+
calls.push({
|
58
|
+
target: token,
|
59
|
+
callData: ERC20Interface.encodeFunctionData("balanceOf", [user]),
|
60
|
+
allowFailure: true,
|
61
|
+
});
|
62
|
+
}
|
63
|
+
// console.log(`Calling multicall with ${calls.length} calls for block ${blockNumber} on chain ${chainId}`);
|
64
|
+
const results = await batchMulticallCallWithRetry(Number.parseInt(chainId), { calls, blockNumber });
|
65
|
+
let i = 0;
|
66
|
+
for (const token of CONSTANTS[Number.parseInt(chainId)]) {
|
67
|
+
const tokenDetails = tokenList[Number.parseInt(chainId)][utils.getAddress(token)];
|
68
|
+
const balance = ERC20Interface.decodeFunctionResult("balanceOf", results[i++].returnData)[0];
|
69
|
+
result[chainId][token].total += BN2Number(balance, tokenDetails.decimals);
|
70
|
+
}
|
71
|
+
})());
|
72
|
+
blockNumber += AVERAGING_PERIOD_IN_BLOCKS;
|
73
|
+
}
|
74
|
+
await Promise.all(averagingPromises);
|
75
|
+
for (const token of CONSTANTS[Number.parseInt(chainId)]) {
|
76
|
+
result[chainId][token].total = result[chainId][token].total / blocksByChain;
|
77
|
+
result[chainId][token].yield = result[chainId][token].total * 0.04;
|
78
|
+
}
|
79
|
+
}
|
80
|
+
catch (e) {
|
81
|
+
log.error(`Failed to get yield data for ${user} on chain ${chainId}`, e);
|
82
|
+
}
|
83
|
+
})());
|
84
|
+
await Promise.all(promises);
|
85
|
+
return result;
|
86
|
+
};
|
87
|
+
export const query = t.Object({
|
88
|
+
user: t.String(),
|
89
|
+
});
|
90
|
+
export const response = t.Record(t.String({ title: "ChainId" }), t.Record(t.String({ title: "TokenAddress" }), t.Object({ total: t.Number(), yield: t.Number() })));
|
91
|
+
export default (app) => app.use(checkQueryAddressValidity()).get("", async ({ query }) => {
|
92
|
+
return await Redis.getOrSet(`LostYield_${query.user}`, getLostYield, query.user);
|
93
|
+
}, {
|
94
|
+
query: t.Object({
|
95
|
+
user: t.String(),
|
96
|
+
}),
|
97
|
+
tags: ["Protocols"],
|
98
|
+
});
|
@@ -0,0 +1,119 @@
|
|
1
|
+
import { getClamsInfo } from "../../libs/deprecated-merklv3";
|
2
|
+
import { AMM, ChainId, isSupportedChain } from "@sdk";
|
3
|
+
import { t } from "elysia";
|
4
|
+
import checkQueryAddressValidity from "../../hooks/checkQueryAddressValidity";
|
5
|
+
import { InvalidParameter } from "../../utils/error";
|
6
|
+
import { throwOnUnsupportedChainId } from "../../utils/throw";
|
7
|
+
export const query = t.Object({
|
8
|
+
AMMs: t.Optional(t.Union([t.String(), t.Array(t.String())])),
|
9
|
+
chainIds: t.Optional(t.Union([t.Numeric(), t.Array(t.Numeric())])),
|
10
|
+
user: t.Optional(t.String()),
|
11
|
+
onlyLive: t.Optional(t.String()),
|
12
|
+
});
|
13
|
+
export const response = t.Record(t.String({ title: "Merkl" }), t.Object({
|
14
|
+
merkleRoot: t.Optional(t.String()),
|
15
|
+
message: t.Optional(t.String()),
|
16
|
+
validRewardTokens: t.Optional(t.Array(t.Object({
|
17
|
+
decimals: t.Number(),
|
18
|
+
minimumAmountPerEpoch: t.Number(),
|
19
|
+
symbol: t.String(),
|
20
|
+
token: t.String(),
|
21
|
+
}))),
|
22
|
+
pools: t.Record(t.String(), t.Object({
|
23
|
+
alm: t.Object({}),
|
24
|
+
amm: t.Number(),
|
25
|
+
ammAlgo: t.Number(),
|
26
|
+
ammAlgoName: t.String(),
|
27
|
+
ammName: t.String(),
|
28
|
+
aprs: t.Object({}),
|
29
|
+
chainId: t.Number(),
|
30
|
+
decimalsToken0: t.Number(),
|
31
|
+
decimalsToken1: t.Number(),
|
32
|
+
disputeLive: t.Boolean(),
|
33
|
+
distributionData: t.Array(t.Unknown()),
|
34
|
+
endOfDisputePeriod: t.Number(),
|
35
|
+
meanAPR: t.Number(),
|
36
|
+
pool: t.String(),
|
37
|
+
poolBalanceToken0: t.Number(),
|
38
|
+
poolBalanceToken1: t.Number(),
|
39
|
+
poolFee: t.Number(),
|
40
|
+
poolTotalLiquidity: t.Number(),
|
41
|
+
rewardsPerToken: t.Object({}),
|
42
|
+
symbolToken0: t.String(),
|
43
|
+
symbolToken1: t.String(),
|
44
|
+
tick: t.Number(),
|
45
|
+
token0: t.String(),
|
46
|
+
token1: t.String(),
|
47
|
+
tvl: t.Union([t.Number(), t.Null()]),
|
48
|
+
})),
|
49
|
+
}));
|
50
|
+
export const merklRoute = async ({ query, set }) => {
|
51
|
+
const user = query.user;
|
52
|
+
let AMMs;
|
53
|
+
let rawAMMs = query.AMMs;
|
54
|
+
if (!rawAMMs) {
|
55
|
+
rawAMMs = query["AMMs[]"];
|
56
|
+
}
|
57
|
+
if (!rawAMMs) {
|
58
|
+
rawAMMs = query["AMMs[0]"];
|
59
|
+
}
|
60
|
+
if (!rawAMMs) {
|
61
|
+
AMMs = undefined;
|
62
|
+
}
|
63
|
+
else if (typeof rawAMMs === "string") {
|
64
|
+
if (rawAMMs.includes(",")) {
|
65
|
+
AMMs = rawAMMs.split(",");
|
66
|
+
}
|
67
|
+
else {
|
68
|
+
AMMs = [rawAMMs];
|
69
|
+
}
|
70
|
+
}
|
71
|
+
if (!!AMMs) {
|
72
|
+
AMMs = AMMs.map(amm => {
|
73
|
+
return amm.toLowerCase();
|
74
|
+
});
|
75
|
+
for (const filterAMM of AMMs) {
|
76
|
+
if (Object.keys(AMM)
|
77
|
+
.filter(amm => Number.isNaN(Number(amm)))
|
78
|
+
.map(amm => {
|
79
|
+
return amm.toLowerCase();
|
80
|
+
})
|
81
|
+
.indexOf(filterAMM.toLowerCase()) === -1) {
|
82
|
+
throw new InvalidParameter(`API for Merkl products by Angle Labs does not support this type of AMM: ${filterAMM}`);
|
83
|
+
}
|
84
|
+
}
|
85
|
+
}
|
86
|
+
let rawChainIds = query.chainIds;
|
87
|
+
if (!rawChainIds) {
|
88
|
+
rawChainIds = query["chainIds[]"];
|
89
|
+
}
|
90
|
+
if (!rawChainIds) {
|
91
|
+
rawChainIds = query["chainIds[0]"];
|
92
|
+
}
|
93
|
+
let chainIds;
|
94
|
+
if (!rawChainIds) {
|
95
|
+
chainIds = Object.keys(ChainId)
|
96
|
+
.map(k => Number.parseInt(k))
|
97
|
+
.filter(k => isSupportedChain(k, "merkl"));
|
98
|
+
}
|
99
|
+
else if (typeof rawChainIds === "number") {
|
100
|
+
chainIds = [rawChainIds];
|
101
|
+
}
|
102
|
+
else if (typeof rawChainIds === "string") {
|
103
|
+
chainIds = [Number.parseInt(rawChainIds)];
|
104
|
+
}
|
105
|
+
else {
|
106
|
+
chainIds = rawChainIds;
|
107
|
+
}
|
108
|
+
for (const chainId of chainIds)
|
109
|
+
throwOnUnsupportedChainId(chainId);
|
110
|
+
let onlyLive = false;
|
111
|
+
if (query.onlyLive === "true") {
|
112
|
+
onlyLive = true;
|
113
|
+
}
|
114
|
+
return getClamsInfo(chainIds, AMMs, user, onlyLive);
|
115
|
+
};
|
116
|
+
export default (app) => app.use(checkQueryAddressValidity()).get("", merklRoute, {
|
117
|
+
// query,
|
118
|
+
tags: ["Merkl"],
|
119
|
+
});
|
@@ -0,0 +1,27 @@
|
|
1
|
+
import { getMorphoMarketsWithCache } from "../../libs/parse/marketsWithCache";
|
2
|
+
import { MorphoSubCampaignType } from "@sdk";
|
3
|
+
import { t } from "elysia";
|
4
|
+
export const query = t.Object({
|
5
|
+
repository: t.String(),
|
6
|
+
chainId: t.Numeric(),
|
7
|
+
});
|
8
|
+
const asset = t.Object({
|
9
|
+
address: t.String(),
|
10
|
+
chain: t.Object({ network: t.String() }),
|
11
|
+
symbol: t.String(),
|
12
|
+
});
|
13
|
+
export const response = t.Array(t.Object({
|
14
|
+
uniqueKey: t.String(),
|
15
|
+
whitelisted: t.Boolean(),
|
16
|
+
lltv: t.Numeric(),
|
17
|
+
loanAsset: asset,
|
18
|
+
collateralAsset: asset,
|
19
|
+
}));
|
20
|
+
export default (app) => app.get("", async (request) => {
|
21
|
+
const chainId = request.query.chainId;
|
22
|
+
if (request.query.repository !== MorphoSubCampaignType.META.toString())
|
23
|
+
return await getMorphoMarketsWithCache(chainId, request.query.repository);
|
24
|
+
}, {
|
25
|
+
query,
|
26
|
+
tags: ["Protocols"],
|
27
|
+
});
|
@@ -0,0 +1,22 @@
|
|
1
|
+
import { getMorphoMarketsWithCache } from "../../libs/parse/marketsWithCache";
|
2
|
+
import { MorphoSubCampaignType } from "@sdk";
|
3
|
+
import { t } from "elysia";
|
4
|
+
export const query = t.Object({
|
5
|
+
repository: t.String(),
|
6
|
+
chainId: t.Numeric(),
|
7
|
+
});
|
8
|
+
export const response = t.Array(t.Object({
|
9
|
+
address: t.String(),
|
10
|
+
name: t.String(),
|
11
|
+
whitelisted: t.Boolean(),
|
12
|
+
symbol: t.String(),
|
13
|
+
chain: t.Object({ network: t.String() }),
|
14
|
+
}));
|
15
|
+
export default (app) => app.get("", async (request) => {
|
16
|
+
const chainId = request.query.chainId;
|
17
|
+
if (request.query.repository === MorphoSubCampaignType.META.toString())
|
18
|
+
return await getMorphoMarketsWithCache(chainId, request.query.repository);
|
19
|
+
}, {
|
20
|
+
query,
|
21
|
+
tags: ["Protocols"],
|
22
|
+
});
|
@@ -0,0 +1,69 @@
|
|
1
|
+
import { Redis } from "../../cache";
|
2
|
+
import { ChainId, isSupportedChain } from "@sdk";
|
3
|
+
import { t } from "elysia";
|
4
|
+
import checkQueryAddressValidity from "../../hooks/checkQueryAddressValidity";
|
5
|
+
import { getUserPositionsV2 } from "../../libs/positions";
|
6
|
+
import { prepareFetch } from "../../libs/positions/prepareFetch";
|
7
|
+
import { throwOnUnsupportedChainId } from "../../utils/throw";
|
8
|
+
export const query = t.Object({
|
9
|
+
chainIds: t.Optional(t.Union([t.String(), t.Array(t.String())])),
|
10
|
+
user: t.String(),
|
11
|
+
creatorTag: t.String(),
|
12
|
+
});
|
13
|
+
export default (app) => app.use(checkQueryAddressValidity()).get("", async ({ query, set }) => {
|
14
|
+
let rawChainIds = query.chainIds;
|
15
|
+
if (typeof rawChainIds === "string" && rawChainIds.includes(",")) {
|
16
|
+
rawChainIds = rawChainIds.split(",");
|
17
|
+
}
|
18
|
+
let chainIds;
|
19
|
+
if (!rawChainIds) {
|
20
|
+
chainIds = Object.keys(ChainId)
|
21
|
+
.map(k => Number.parseInt(k))
|
22
|
+
.filter(k => isSupportedChain(k, "merkl"));
|
23
|
+
}
|
24
|
+
else if (typeof rawChainIds === "string") {
|
25
|
+
chainIds = [Number.parseInt(rawChainIds)];
|
26
|
+
}
|
27
|
+
else {
|
28
|
+
chainIds = rawChainIds.map(chainId => Number.parseInt(chainId));
|
29
|
+
}
|
30
|
+
for (const chainId of chainIds)
|
31
|
+
throwOnUnsupportedChainId(chainId);
|
32
|
+
const user = query.user;
|
33
|
+
for (const chainId of chainIds)
|
34
|
+
throwOnUnsupportedChainId(chainId);
|
35
|
+
const cacheKeys = chainIds.map(chainId => `LiveCampaigns_${chainId}`);
|
36
|
+
const cacheData = await Redis.getMany(cacheKeys);
|
37
|
+
const promises = [];
|
38
|
+
let i = 0;
|
39
|
+
for (const chainId of chainIds) {
|
40
|
+
if (!cacheData[i]) {
|
41
|
+
promises.push(getUserPositionsV2({}, chainId, user));
|
42
|
+
i++;
|
43
|
+
continue;
|
44
|
+
}
|
45
|
+
const allOpportunities = cacheData[i];
|
46
|
+
const positionsToCheck = {};
|
47
|
+
for (const campaigns of Object.values(allOpportunities)) {
|
48
|
+
for (const campaign of Object.values(campaigns)) {
|
49
|
+
if (campaign.tags.includes(query.creatorTag)) {
|
50
|
+
const type = campaign.campaignType;
|
51
|
+
positionsToCheck[type] = prepareFetch(type, positionsToCheck[type] ? positionsToCheck[type] : {}, campaign);
|
52
|
+
}
|
53
|
+
}
|
54
|
+
}
|
55
|
+
promises.push(getUserPositionsV2(positionsToCheck, chainId, user));
|
56
|
+
i++;
|
57
|
+
}
|
58
|
+
const result = await Promise.all(promises);
|
59
|
+
i = 0;
|
60
|
+
const finalResult = {};
|
61
|
+
for (const chainId of chainIds) {
|
62
|
+
finalResult[chainId] = result[i];
|
63
|
+
i++;
|
64
|
+
}
|
65
|
+
return finalResult;
|
66
|
+
}, {
|
67
|
+
query,
|
68
|
+
tags: ["Protocols"],
|
69
|
+
});
|
@@ -0,0 +1,63 @@
|
|
1
|
+
import { Redis } from "../../cache";
|
2
|
+
import { t } from "elysia";
|
3
|
+
import { fillCampaigns } from "../../entities/opportunity";
|
4
|
+
import param from "../../types/parameters";
|
5
|
+
export const query = t.Object({
|
6
|
+
campaigns: t.Optional(t.Boolean()),
|
7
|
+
testTokens: t.Optional(t.Boolean()),
|
8
|
+
mainParameter: t.Optional(param.MainParameter.type),
|
9
|
+
chainId: t.Optional(param.Chain.type),
|
10
|
+
type: t.Optional(param.Type.type),
|
11
|
+
action: t.Optional(param.Action.type),
|
12
|
+
tag: t.Optional(t.String()),
|
13
|
+
});
|
14
|
+
export const response = t.Record(t.TemplateLiteral([param.Type.type, t.Literal("_"), param.MainParameter.type]), t.Object({
|
15
|
+
id: t.TemplateLiteral([param.Type.type, t.Literal("_"), param.MainParameter.type]),
|
16
|
+
name: t.String(),
|
17
|
+
chainId: param.Chain.type,
|
18
|
+
action: t.String(),
|
19
|
+
status: t.String(),
|
20
|
+
tags: t.Optional(t.Array(t.String())),
|
21
|
+
tokenIcons: t.Array(t.String()),
|
22
|
+
rewardTokenIcons: t.Array(t.String()),
|
23
|
+
dailyRewardTokens: t.Unknown(),
|
24
|
+
campaigns: t.Object({ type: t.Number() }, { additionalProperties: true }),
|
25
|
+
}));
|
26
|
+
export default (app) => {
|
27
|
+
return app.get("", async ({ query: { campaigns: showCampaigns, ...filters } }) => {
|
28
|
+
const opportunities = await Redis.get(filters?.testTokens ? "OpportunitiesWithTest" : "Opportunities");
|
29
|
+
const returnedOpportunities = {};
|
30
|
+
const corresponds = (opp) => {
|
31
|
+
if (filters.type !== undefined && filters.type !== opp.campaigns.type)
|
32
|
+
return false;
|
33
|
+
if (filters.action !== undefined && filters.action !== opp.action)
|
34
|
+
return false;
|
35
|
+
if (filters.chainId !== undefined && filters.chainId !== opp.chainId)
|
36
|
+
return false;
|
37
|
+
if (filters.mainParameter !== undefined &&
|
38
|
+
filters.mainParameter?.toLowerCase() !== opp.id.split("_")?.[1]?.toLowerCase())
|
39
|
+
return false;
|
40
|
+
if (filters.tag !== undefined && !opp.tags?.includes(filters.tag))
|
41
|
+
return false;
|
42
|
+
return true;
|
43
|
+
};
|
44
|
+
for (const [id, opportunity] of Object.entries(opportunities)) {
|
45
|
+
if (!corresponds(opportunity))
|
46
|
+
continue;
|
47
|
+
returnedOpportunities[id] = opportunity;
|
48
|
+
}
|
49
|
+
if (!showCampaigns)
|
50
|
+
return returnedOpportunities;
|
51
|
+
return await fillCampaigns(returnedOpportunities, !showCampaigns, filters.testTokens);
|
52
|
+
}, {
|
53
|
+
transform({ query }) {
|
54
|
+
query.chainId = !query.chainId ? undefined : Number.parseInt(query.chainId);
|
55
|
+
query.type = !query.type ? undefined : Number.parseInt(query.type);
|
56
|
+
query.campaigns = query.campaigns === "false" ? false : !!query.campaigns;
|
57
|
+
query.testTokens = query.testTokens === "false" ? false : !!query.testTokens;
|
58
|
+
},
|
59
|
+
query,
|
60
|
+
response: { 200: response },
|
61
|
+
tags: ["Opportunity"],
|
62
|
+
});
|
63
|
+
};
|