-
Notifications
You must be signed in to change notification settings - Fork 5.4k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge remote-tracking branch 'upstream/main'
- Loading branch information
Showing
244 changed files
with
3,975 additions
and
4,364 deletions.
There are no files selected for viewing
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
const { getUniTVL } = require('../helper/unknownTokens') | ||
|
||
const FACTORY = "0x2b6852CeDEF193ece9814Ee99BE4A4Df7F463557" // This factory is on AirDAO Mainnet (Chain Id: 16718) | ||
|
||
const dexTVL = getUniTVL({ factory: FACTORY, useDefaultCoreAssets: true, fetchBalances: true, }) | ||
|
||
module.exports = { | ||
misrepresentedTokens: true, | ||
methodology: `Uses factory(${FACTORY}) address to find and price Liquidity Pool pairs.`, | ||
airdao: { | ||
tvl: dexTVL | ||
} | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,17 +1,11 @@ | ||
const { getUniTVL } = require('../helper/unknownTokens'); | ||
|
||
|
||
const tvl = getUniTVL({ factory: '0xAf39606bec181887951Ab6912Ac7EA216Bd6E4B4', useDefaultCoreAssets: true, fetchBalances: true, }) | ||
|
||
module.exports = { | ||
misrepresentedTokens: true, | ||
ethereum:{ | ||
tvl: getUniTVL({ factory: '0x6624Ac5F9abFA36174511607860e81C8dB9e84E9', useDefaultCoreAssets: true, fetchBalances: true, }), | ||
}, | ||
arbitrum:{ | ||
tvl: getUniTVL({ factory: '0x40Cbdf84475f8Dd7C9a9c665eDE551EeaaF21F8d', useDefaultCoreAssets: true, fetchBalances: true, }), | ||
}, | ||
base:{ | ||
tvl: getUniTVL({ factory: '0xD2156Bb9ed200FE88705443BfFcA788BA8b205f6', useDefaultCoreAssets: true, fetchBalances: true, }), | ||
}, | ||
bsc:{ | ||
tvl: getUniTVL({ factory: '0x40Cbdf84475f8Dd7C9a9c665eDE551EeaaF21F8d', useDefaultCoreAssets: true, fetchBalances: true, }), | ||
}, | ||
ethereum: { tvl, }, | ||
arbitrum: { tvl, }, | ||
base: { tvl, }, | ||
bsc: { tvl, }, | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,110 @@ | ||
const { call } = require('../helper/chain/stacks-api') | ||
const { getCache, setCache } = require('../helper/cache') | ||
const { sleep } = require('../helper/utils') | ||
const sdk = require('@defillama/sdk') | ||
|
||
const factory = 'SP102V8P0F7JX67ARQ77WEA3D3CFB5XW39REDT0AM.amm-pool-v2-01' | ||
|
||
async function tvl(api) { | ||
// https://docs.alexgo.io/developers/smart-contracts | ||
|
||
|
||
// get simple weight pool data | ||
const simpleWeightAMM = 'SP3K8BC0PPEVCV7NZ6QSRWPQ2JE9E5B6N3PA0KBR9.simple-weight-pool-alex' | ||
let { value: swPools } = await call({ target: simpleWeightAMM, abi: 'get-pools' }) | ||
swPools = swPools.map(i => i.value) | ||
for (const { value: pool } of swPools) { | ||
const inputArgs = ['token-x', 'token-y'].map(key => pool[key]) | ||
const { value: poolData } = await call({ target: simpleWeightAMM, abi: 'get-pool-details', inputArgs }) | ||
api.add(pool['token-x'].value, poolData['balance-x'].value) | ||
api.add(pool['token-y'].value, poolData['balance-y'].value) | ||
await sleep(2100) | ||
} | ||
|
||
|
||
|
||
// get fixed weight pool data | ||
const fixedWeightAMM = 'SP3K8BC0PPEVCV7NZ6QSRWPQ2JE9E5B6N3PA0KBR9.fixed-weight-pool-v1-01' | ||
let { value: fwPools } = await call({ target: fixedWeightAMM, abi: 'get-pools' }) | ||
fwPools = fwPools.map(i => i.value) | ||
for (const { value: pool } of fwPools) { | ||
const inputArgs = ['token-x', 'token-y', 'weight-x', 'weight-y'].map(key => pool[key]) | ||
const { value: poolData } = await call({ target: fixedWeightAMM, abi: 'get-pool-details', inputArgs }) | ||
api.add(pool['token-x'].value, poolData['balance-x'].value) | ||
api.add(pool['token-y'].value, poolData['balance-y'].value) | ||
await sleep(2100) | ||
} | ||
|
||
|
||
|
||
// update cache for amm v2 pools & token metadata | ||
const cache = await getCache('alex/ammv2', 'stacks') | ||
if (!cache.pairData) cache.pairData = [] | ||
if (!cache.tokenMetadata) cache.tokenMetadata = {} | ||
const currentPairCount = cache.pairData.length | ||
let hasMorePairs = true | ||
let i = currentPairCount + 1 | ||
do { | ||
try { | ||
const pairData = await call({ target: factory, abi: 'get-pool-details-by-id', inputArgs: [{ type: 'number', value: i }] }) | ||
if (!pairData.value?.factor) hasMorePairs = false | ||
else | ||
cache.pairData.push(pairData.value) | ||
i++ | ||
await sleep(2100) | ||
} catch (e) { | ||
sdk.log('error fetching pair data', e) | ||
hasMorePairs = false | ||
} | ||
} while (hasMorePairs) | ||
let cacheNeedsUpdate = cache.pairData.length > currentPairCount | ||
const tokenSet = new Set(cache.pairData.flatMap(pair => [pair['token-x'], pair['token-y']]).map(token => token.value) | ||
.filter(token => !cache.tokenMetadata[token]) | ||
) | ||
const tokensMissingMetadata = Array.from(tokenSet) | ||
if (tokensMissingMetadata.length > 0) { | ||
cacheNeedsUpdate = true | ||
for (const token of tokensMissingMetadata) { | ||
try { | ||
const decimals = await call({ target: token, abi: 'get-decimals' }) | ||
const symbol = await call({ target: token, abi: 'get-symbol' }) | ||
let baseToken = {} | ||
let baseDecimals = {} | ||
let baseSymbol = {} | ||
try { | ||
baseDecimals = await call({ target: token, abi: 'get-base-decimals' }) | ||
baseToken = await call({ target: token, abi: 'get-base-token' }) | ||
if (typeof baseToken === 'string') baseToken = { value: baseToken } | ||
if (baseToken.value) { | ||
baseSymbol = await call({ target: baseToken.value, abi: 'get-symbol' }) | ||
} | ||
} catch (e) { | ||
// sdk.log('error fetching base token metadata', e) | ||
} | ||
cache.tokenMetadata[token] = { decimals: decimals.value, symbol: symbol.value, baseToken: baseToken.value, baseDecimals: baseDecimals.value, baseSymbol: baseSymbol.value } | ||
await sleep(2100) | ||
} catch (e) { | ||
sdk.log('error fetching token metadata', e) | ||
} | ||
} | ||
} | ||
|
||
api.log('pair count', cache.pairData.length) | ||
if (cacheNeedsUpdate) | ||
await setCache('alex/ammv2', 'stacks', cache) | ||
|
||
|
||
|
||
// add amm v2 tvl | ||
for (const pair of cache.pairData) { | ||
const { value: bals } = await call({ target: factory, abi: 'get-balances', inputArgs: [pair['token-x'], pair['token-y'], pair.factor] }) | ||
api.add(pair['token-x'].value, bals['balance-x'].value) | ||
api.add(pair['token-y'].value, bals['balance-y'].value) | ||
await sleep(600) | ||
} | ||
return api.getBalances() | ||
} | ||
|
||
module.exports = { | ||
stacks: { tvl } | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
const { get_account_tvl } = require("../helper/chain/eos"); | ||
|
||
const accounts = ["nftmt.worlds", "stake.worlds", "lore.worlds", "arena.worlds", "boost.worlds"] | ||
|
||
// AlienWorlds | ||
// https://alienworlds.io/ | ||
async function wax() { | ||
const tokens = [ | ||
["eosio.token", "WAX", "wax"], | ||
]; | ||
return await get_account_tvl(accounts, tokens, "wax"); | ||
} | ||
async function staking() { | ||
const tokens = [ | ||
["alien.worlds", "TLM", "alien-worlds"], | ||
]; | ||
return await get_account_tvl(accounts, tokens, "wax"); | ||
} | ||
|
||
module.exports = { | ||
methodology: `AlienWorlds TVL is achieved by querying token balances from Staking, Voting & Gaming smart contract(s).`, | ||
wax: { | ||
tvl: wax, | ||
staking, | ||
}, | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,29 @@ | ||
const ADDRESSES = require('../helper/coreAssets.json'); | ||
const { sumTokensExport } = require('../helper/unwrapLPs'); | ||
|
||
const tokens = [ | ||
ADDRESSES.ethereum.USDT, | ||
]; | ||
|
||
const walletAddresses = { | ||
ethereum: ['0xA61a6E696B7C566DA42B80dA27d96e7104bcec99'], | ||
arbitrum: ['0x552E7A55802f3350C707a243E402aa50Eda9D286'] | ||
|
||
}; | ||
|
||
const tokenAddress = { | ||
ethereum: [ADDRESSES.ethereum.USDT], | ||
arbitrum: [ADDRESSES.arbitrum.USDT], | ||
|
||
|
||
} | ||
|
||
module.exports = { | ||
ethereum: { | ||
tvl: sumTokensExport({ owners: walletAddresses.ethereum, tokens: tokenAddress.ethereum }), | ||
}, | ||
arbitrum: { | ||
tvl: sumTokensExport({ owners: walletAddresses.arbitrum, tokens: tokenAddress.arbitrum }), | ||
}, | ||
|
||
}; |
Oops, something went wrong.