@galacticcouncil/sdk 7.0.2 → 7.1.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/build/index.cjs +2 -2
- package/build/index.mjs +2 -2
- package/build/types/aave/AaveClient.d.ts +75 -0
- package/build/types/aave/AaveUtils.d.ts +10 -0
- package/build/types/{evm/abi/Aave.d.ts → aave/abi/AavePool.d.ts} +35 -1
- package/build/types/aave/abi/AavePoolDataProvider.d.ts +384 -0
- package/build/types/aave/abi/index.d.ts +2 -0
- package/build/types/aave/const.d.ts +6 -0
- package/build/types/aave/index.d.ts +4 -0
- package/build/types/aave/types.d.ts +10 -0
- package/build/types/evm/index.d.ts +0 -2
- package/build/types/index.d.ts +1 -0
- package/build/types/utils/bignumber.d.ts +1 -1
- package/package.json +1 -1
- package/build/types/evm/abi/Erc20.d.ts +0 -150
- package/build/types/evm/abi/index.d.ts +0 -1
- package/build/types/evm/const.d.ts +0 -4
package/build/index.mjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import"@galacticcouncil/api-augment/hydradx";import"@galacticcouncil/api-augment/basilisk";var _=class{api;constructor(e){this.api=e}get chainDecimals(){return this.api.registry.chainDecimals[0]}get chainToken(){return this.api.registry.chainTokens[0]}async dryRun(e,t){let s;try{s=await this.api.call.dryRunApi.dryRunCall({System:{Signed:e}},t.inner.toHex())}catch(r){throw console.error(r),new Error("Dry run execution failed!")}if(s.isOk)return s.asOk;throw console.log(s.asErr.toHuman()),new Error("Dry run execution error!")}log(e,...t){let s=typeof window>"u"?process.env.GC_DEBUG:window.localStorage.getItem("gc.debug");this.getLogValue(s)&&console.log(e,...t)}getLogValue(e){switch(e){case!0:case"true":case 1:case"1":case"on":case"yes":return!0;default:return!1}}};var ws=2090,xe=1e3,re="1",Os=2034,H=63,z=18,L="0",Bs=12,J=15;var K=class extends _{SUPPORTED_TYPES=["StableSwap","Bond","Token","External","Erc20"];constructor(e){super(e)}async safeSharesQuery(){try{let e=await this.api.query.stableswap.pools.entries();return new Map(e.map(([{args:[t]},s])=>[t.toString(),s.unwrap()]))}catch{return new Map([])}}async safeBondsQuery(){try{let e=await this.api.query.bonds.bonds.entries();return new Map(e.map(([{args:[t]},s])=>[t.toString(),s.unwrap()]))}catch{return new Map([])}}async metadataQuery(){try{let e=await this.api.query.assetRegistry.assetMetadataMap.entries();return new Map(e.map(([{args:[t]},s])=>{let{decimals:r,symbol:o}=s.unwrap();return[t.toString(),{decimals:r.toNumber(),symbol:o.toHuman()}]}))}catch{return new Map([])}}async locationsQuery(){try{let e=await this.api.query.assetRegistry.assetLocations.entries();return new Map(e.map(([{args:[t]},s])=>[t.toString(),s.unwrap()]))}catch{return new Map([])}}getSystemTokenName(e){switch(e){case"HDX":return"Hydration";case"BSX":return"Basilisk";default:return e}}getToken(e,t,s,r){if(e==L){let u=this.api.consts.balances.existentialDeposit;return{id:L,name:this.getSystemTokenName(this.chainToken),symbol:this.chainToken,decimals:this.chainDecimals,icon:this.chainToken,type:"Token",isSufficient:!0,existentialDeposit:u.toString()}}let{name:o,assetType:i,isSufficient:n,existentialDeposit:a}=t,{symbol:l,decimals:c}=s.get(e)??{};return{id:e,name:o.toHuman(),symbol:l,decimals:c,icon:l,type:i.toHuman(),isSufficient:n?n.toHuman():!0,location:r?.toJSON(),existentialDeposit:a.toString()}}getBond(e,t,s,r){let[o,i]=r,{assetType:n,isSufficient:a,existentialDeposit:l}=t,{symbol:c,decimals:u}=this.getToken(o.toString(),t,s),g=i.toNumber(),p=new Intl.DateTimeFormat("en-GB"),P=[c,"Bond",p.format(g)].join(" ");return{id:e,name:P,symbol:c+"b",decimals:u,icon:c,type:n.toString(),isSufficient:a.toHuman(),existentialDeposit:l.toString(),underlyingAssetId:o.toString(),maturity:g}}getShares(e,t,s,r){let{assets:o}=r,{name:i,symbol:n,assetType:a,isSufficient:l,existentialDeposit:c}=t,g=o.map(h=>h.toString()).map(h=>{let{symbol:f}=this.getToken(h,t,s);return[h,f]}),p=Object.fromEntries(g),P=Object.values(p);return{id:e,name:P.join(", "),symbol:n?.isSome?n.toHuman():i.toHuman(),decimals:18,icon:P.join("/"),type:a.toString(),isSufficient:l.toHuman(),existentialDeposit:c.toString(),meta:p}}getExternal(e,t,s,r){let o=this.getToken(e,t,new Map,r),i=s?.find(n=>n.internalId===o.id);return i?{...o,decimals:i.decimals,name:i.name,symbol:i.symbol,icon:i.symbol,isWhiteListed:i.isWhiteListed}:o}normalizeMetadata(e,t){return t.size?t:new Map(e.map(([{args:[s]},r])=>{let{decimals:o,symbol:i}=r.unwrap();return[s.toString(),{decimals:Number(o.toString()),symbol:i.toHuman()}]}))}getSupportedAssets(e){return e.filter(([t,s])=>{if(s.isNone)return!1;let r=s.unwrap();return this.isSupportedAsset(r)})}async getOnChainAssets(e,t){let[s,r,o,i,n]=await Promise.all([this.api.query.assetRegistry.assets.entries(),this.locationsQuery(),this.safeSharesQuery(),this.safeBondsQuery(),this.metadataQuery()]),a=this.getSupportedAssets(s),l=this.normalizeMetadata(a,n),c=a.map(([{args:[u]},g])=>{let p=g.unwrap(),P=r.get(u.toString()),{assetType:h}=p;switch(h.toString()){case"Bond":let f=i.get(u.toString());return this.getBond(u.toString(),p,l,f);case"StableSwap":let S=o.get(u.toString());return this.getShares(u.toString(),p,l,S);case"External":return this.getExternal(u.toString(),p,t,P);default:return this.getToken(u.toString(),p,l,P)}});return e?c:c.filter(u=>this.isValidAsset(u))}isValidAsset(e){let t=Math.sign(e.decimals);return!!e.symbol&&(t===0||t===1)}isSupportedAsset(e){let t=e.assetType.toString();return this.SUPPORTED_TYPES.includes(t)}};import{BigNumber as w}from"bignumber.js";var je=12;w.config({EXPONENTIAL_AT:[-100,100],ROUNDING_MODE:4,DECIMAL_PLACES:je});var b=d(0),T=d(1),Ns=d("Infinity");function B(m,e){let t=new w(e.toString()),s=new w(10).pow(t);return m.times(s)}function d(m){return new w(m.toString())}var G=class extends _{constructor(e){super(e)}async getBalance(e,t){let s=await this.api.query.assetRegistry.assets(t),{assetType:r}=s.unwrap();return r.toString()==="Erc20"?this.getErc20Balance(e,t):t===L?this.getSystemBalance(e):this.getTokenBalance(e,t)}async getSystemBalance(e){let{data:t}=await this.api.query.system.account(e);return this.calculateFreeBalance(t)}async getTokenBalance(e,t){let{free:s,reserved:r,frozen:o}=await this.api.query.tokens.accounts(e,t);return this.calculateFreeBalance({free:s,feeFrozen:r,frozen:o})}async getErc20Balance(e,t){let{free:s,reserved:r,frozen:o}=await this.getTokenBalanceData(e,t);return this.calculateFreeBalance({free:s,feeFrozen:0n,frozen:o})}async subscribeSystemBalance(e,t){return this.api.query.system.account(e,({data:s})=>t(L,this.calculateFreeBalance(s)))}async subscribeTokenBalance(e,t,s){let o=t.filter(i=>i.type!=="Erc20").filter(i=>i.id!==L).map(i=>[e,i.id]);return this.api.query.tokens.accounts.multi(o,i=>{let n=[];i.forEach((a,l)=>{let c=this.calculateFreeBalance(a),u=o[l][1];n.push([u,c])}),s(n)})}async subscribeErc20Balance(e,t,s){let r=t.filter(i=>i.type==="Erc20"),o=async()=>{let i=[];(await Promise.all(r.map(async a=>[a.id,await this.getErc20Balance(e,a.id)]))).forEach(([a,l])=>{i.push([a,l])}),s(i)};return await o(),this.api.rpc.chain.subscribeNewHeads(async()=>{o()})}async getTokenBalanceData(e,t){return this.api.call.currenciesApi.account(t,e)}calculateFreeBalance(e){let{free:t,miscFrozen:s,feeFrozen:r,frozen:o}=e,i=new w(t),n=new w(s||o),a=new w(r||0n),l=n.gt(a)?n:a;return i.minus(l)}};import{fixed_from_rational as Ne}from"@galacticcouncil/math-liquidity-mining";import{GenericAccountId32 as Ze}from"@polkadot/types";import{u8aConcat as Re}from"@polkadot/util";import{isAddress as Ee}from"@polkadot/util-crypto";var we=class extends _{balanceClient;constructor(e){super(e),this.balanceClient=new G(e)}secondsInYear=new w(365.2425).times(24).times(60).times(60);async getOmnipoolFarms(e){let t=await this.api.query.omnipoolWarehouseLM.activeYieldFarm.entries(e);return await Promise.all(t.map(async([r,o])=>{let[,i]=r.args,n=o.unwrap().toString(),a=i.toString(),l=(await this.api.query.omnipoolWarehouseLM.globalFarm(a)).unwrap(),c=(await this.api.query.omnipoolWarehouseLM.yieldFarm(e,a,n)).unwrap(),u=await this.getOraclePrice(l)??l.priceAdjustment.toString(),p=this.getAccountResolver(this.api.registry)(Number(a),!1).toString(),P=l.rewardCurrency.toString(),h=await this.balanceClient.getTokenBalanceData(p,P);return{assetId:e,globalFarm:l,yieldFarm:c,priceAdjustment:u,potBalance:h.free.toString()}}))}async getIsolatedPoolFarms(e){let t=await this.api.query.xykWarehouseLM.activeYieldFarm.entries(e);return await Promise.all(t.map(async([r,o])=>{let[,i]=r.args,n=o.unwrap().toString(),a=i.toString(),l=(await this.api.query.xykWarehouseLM.globalFarm(a)).unwrap(),c=(await this.api.query.xykWarehouseLM.yieldFarm(e,a,n)).unwrap(),u=await this.getOraclePrice(l)??l.priceAdjustment.toString(),p=this.getAccountResolver(this.api.registry)(Number(a),!0).toString(),P=l.rewardCurrency.toString(),h=await this.balanceClient.getTokenBalanceData(p,P);return{assetId:e,globalFarm:l,yieldFarm:c,priceAdjustment:u,potBalance:h.free.toString()}}))}async getOraclePrice(e){let t=e.rewardCurrency.toString(),s=e.incentivizedAsset.toString(),r=[t,s].sort();if(t===s)return new w(1).shiftedBy(18).toString();let o=await this.api.query.emaOracle.oracles("omnipool",r,"TenMinutes");if(o.isNone)return;let[i]=o.unwrap(),n=i.price.n.toString(),a=i.price.d.toString(),l;return Number(t)<Number(s)?l=Ne(n,a):l=Ne(a,n),l}getGlobalRewardPerPeriod(e,t,s,r){let i=e.times(t).shiftedBy(-18).times(r).shiftedBy(-18);return i.gte(s)?s:i}getPoolYieldPerPeriod(e,t,s,r){return e.times(t).div(s.times(r).shiftedBy(-18))}padEndU8a(e,t){return Re(e,Array(Math.max(0,t-e.length)).fill(0))}getAccountResolver=e=>(t,s)=>{let r="modl",o=s?"0x78796b4c4d704944":"0x4f6d6e6957684c4d";return new Ze(e,this.padEndU8a(Re(r,o,typeof t!="number"?t.toU8a():[t]),32))};async getFarmApr(e,t){if(t==="isolatedpool"&&!Ee(e))throw new Error("You must pass an address of isolated pool as id");if(t==="omnipool"&&Ee(e))throw new Error("You must pass an asset id of omnipool");let s=6,r=t==="omnipool"?await this.getOmnipoolFarms(e):await this.getIsolatedPoolFarms(e);return r.length?r.map(({yieldFarm:n,globalFarm:a,priceAdjustment:l,potBalance:c})=>{let u=new w(a.totalSharesZ.toString()),g=a.plannedYieldingPeriods.toString(),p=new w(a.yieldPerPeriod.toString()),P=new w(a.maxRewardPerPeriod.toString()),h=a.blocksPerPeriod.toString(),f=new w(n.multiplier.toString()).shiftedBy(-18),S=this.secondsInYear.div(new w(s).times(h)),y;if(u.isZero())y=p.times(f).times(S);else{let U=this.getGlobalRewardPerPeriod(u,p,P,l);y=this.getPoolYieldPerPeriod(U,f,u,l).times(S)}let I=new w(a.pendingRewards.toString()).plus(a.accumulatedPaidRewards.toString()),A=P.times(g),x=c?I.plus(c):A;return I.div(x).gte(.999)?b:y.div(t==="isolatedpool"?2:1).times(100)}).reduce((n,a)=>n.plus(a),b).toString():void 0}};var oe=class extends Error{constructor(e){super(),this.message=`${e} pool invalid`,this.name="PoolNotFound"}},ke=class extends Error{constructor(e,t){super(),this.message=`${e} pool missing ${t}`,this.name="PoolConfigNotFound"}},X=class extends Error{constructor(e,t){super(),this.message=`Route from ${e} to ${t} not found in pool configuration`,this.name="RouteNotFound"}},_e=class extends Error{constructor(e){super(),this.message=`Asset ${e} not available in current network`,this.name="AssetNotFound"}},Le=class extends Error{constructor(e){super(),this.message=`Storage missing ${e}`,this.name="StorageConfigNotFound"}},De=class extends Error{constructor(e){super(),this.message=`Subscription type "${e}" not supported`,this.name="SubscriptionNotSupported"}},Ce=class extends Error{constructor(e){super(),this.message=`${e}`,this.name="ProviderConfigNotFound"}};var ne=[{anonymous:!1,inputs:[{indexed:!0,internalType:"address",name:"reserve",type:"address"},{indexed:!1,internalType:"address",name:"user",type:"address"},{indexed:!0,internalType:"address",name:"onBehalfOf",type:"address"},{indexed:!1,internalType:"uint256",name:"amount",type:"uint256"},{indexed:!0,internalType:"uint16",name:"referralCode",type:"uint16"}],name:"Supply",type:"event"},{anonymous:!1,inputs:[{indexed:!0,internalType:"address",name:"reserve",type:"address"},{indexed:!0,internalType:"address",name:"user",type:"address"},{indexed:!0,internalType:"address",name:"to",type:"address"},{indexed:!1,internalType:"uint256",name:"amount",type:"uint256"}],name:"Withdraw",type:"event"},{inputs:[{internalType:"address",name:"asset",type:"address"},{internalType:"uint256",name:"amount",type:"uint256"},{internalType:"address",name:"to",type:"address"}],name:"withdraw",outputs:[{internalType:"uint256",name:"",type:"uint256"}],stateMutability:"nonpayable",type:"function"},{anonymous:!1,inputs:[{indexed:!0,internalType:"address",name:"reserve",type:"address"},{indexed:!1,internalType:"address",name:"user",type:"address"},{indexed:!0,internalType:"address",name:"onBehalfOf",type:"address"},{indexed:!1,internalType:"uint256",name:"amount",type:"uint256"},{indexed:!1,internalType:"enum DataTypes.InterestRateMode",name:"interestRateMode",type:"uint8"},{indexed:!1,internalType:"uint256",name:"borrowRate",type:"uint256"},{indexed:!0,internalType:"uint16",name:"referralCode",type:"uint16"}],name:"Borrow",type:"event"},{inputs:[{internalType:"address",name:"asset",type:"address"},{internalType:"uint256",name:"amount",type:"uint256"},{internalType:"uint256",name:"interestRateMode",type:"uint256"},{internalType:"uint16",name:"referralCode",type:"uint16"},{internalType:"address",name:"onBehalfOf",type:"address"}],name:"borrow",outputs:[],stateMutability:"nonpayable",type:"function"},{anonymous:!1,inputs:[{indexed:!0,internalType:"address",name:"reserve",type:"address"},{indexed:!0,internalType:"address",name:"user",type:"address"},{indexed:!0,internalType:"address",name:"repayer",type:"address"},{indexed:!1,internalType:"uint256",name:"amount",type:"uint256"},{indexed:!1,internalType:"bool",name:"useATokens",type:"bool"}],name:"Repay",type:"event"}];var Me="0x1b02E051683b5cfaC5929C25E84adb26ECf87B38",Ge=1000000n,Oe=5,He=BigInt("0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");import{defineChain as Qe}from"viem";var qe=["https://rpc.hydradx.cloud","https://hydration-rpc.n.dwellir.com","https://hydration.dotters.network","https://rpc.helikon.io/hydradx","https://hydration.ibp.network","https://rpc.cay.hydration.cloud","https://rpc.parm.hydration.cloud","https://rpc.roach.hydration.cloud","https://rpc.zipp.hydration.cloud","https://rpc.sin.hydration.cloud","https://rpc.coke.hydration.cloud"],Ue=["wss://rpc.hydradx.cloud","wss://hydration-rpc.n.dwellir.com","wss://hydration.dotters.network","wss://rpc.helikon.io/hydradx","wss://hydration.ibp.network","wss://rpc.cay.hydration.cloud","wss://rpc.parm.hydration.cloud","wss://rpc.roach.hydration.cloud","wss://rpc.zipp.hydration.cloud","wss://rpc.sin.hydration.cloud","wss://rpc.coke.hydration.cloud"],We=Qe({id:222222,name:"Hydration",network:"hydration",nativeCurrency:{decimals:18,name:"WETH",symbol:"WETH"},rpcUrls:{public:{http:qe,webSocket:Ue},default:{http:qe,webSocket:Ue}},blockExplorers:{default:{name:"Hydration Explorer",url:"https://explorer.evm.hydration.cloud"}},testnet:!1});import{createPublicClient as Xe,createWalletClient as et,custom as tt,http as st,webSocket as rt}from"viem";var ie=class{chain;constructor(e){this.chain=e||We}get chainId(){return this.chain.id}get chainCurrency(){return this.chain.nativeCurrency.symbol}get chainDecimals(){return this.chain.nativeCurrency.decimals}getProvider(){return Xe({chain:this.chain,transport:st()})}getWsProvider(){return Xe({chain:this.chain,transport:rt()})}getSigner(e){return et({account:e,chain:this.chain,transport:tt(window.ethereum)})}};import{LRUCache as is}from"@thi.ng/cache";import{memoize1 as ns}from"@thi.ng/memoize";var R=(o=>(o.Aave="Aave",o.LBP="Lbp",o.Omni="Omnipool",o.Stable="Stableswap",o.XYK="Xyk",o))(R||{}),Y=(o=>(o.UnknownError="UnknownError",o.InsufficientTradingAmount="InsufficientTradingAmount",o.MaxInRatioExceeded="MaxInRatioExceeded",o.MaxOutRatioExceeded="MaxOutRatioExceeded",o.TradeNotAllowed="TradeNotAllowed",o))(Y||{});var ae=class m{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;static fromPool(e){return new m(e.address,e.tokens,e.maxInRatio,e.maxOutRatio,e.minTradingLimit)}constructor(e,t,s,r,o){this.type="Aave",this.address=e,this.tokens=t,this.maxInRatio=s,this.maxOutRatio=r,this.minTradingLimit=o}validatePair(e,t){return!0}parsePair(e,t){let s=new Map(this.tokens.map(a=>[a.id,a])),r=s.get(e),o=s.get(t);if(r==null)throw new Error("Pool does not contain tokenIn");if(o==null)throw new Error("Pool does not contain tokenOut");let i=d(r.balance),n=d(o.balance);return{assetIn:e,assetOut:t,decimalsIn:r.decimals,decimalsOut:o.decimals,balanceIn:i,balanceOut:n,assetInED:b,assetOutED:b}}validateAndBuy(e,t,s){let r=this.calculateInGivenOut(e,t),o=[];return t.isGreaterThan(e.balanceOut)&&o.push("TradeNotAllowed"),{amountIn:r,calculatedIn:r,amountOut:t,feePct:0,errors:o}}validateAndSell(e,t,s){let r=this.calculateOutGivenIn(e,t),o=[];return r.isGreaterThan(e.balanceOut)&&o.push("TradeNotAllowed"),{amountIn:t,calculatedOut:r,amountOut:r,feePct:0,errors:o}}calculateInGivenOut(e,t){return t}calculateOutGivenIn(e,t){return t}spotPriceInGivenOut(e){return B(T,e.decimalsOut)}spotPriceOutGivenIn(e){return B(T,e.decimalsIn)}calculateTradeFee(e,t){return b}};import{encodeAddress as it}from"@polkadot/util-crypto";import{stringToU8a as at}from"@polkadot/util";import{decodeEventLog as lt}from"viem";var $=class{static fromAssetId(e){let t=Number(e),s=Buffer.alloc(20,0);return s[15]=1,s.writeUInt32BE(t,16),"0x"+s.toString("hex")}static toAssetId(e){let t=Buffer.from(e.replace("0x",""),"hex");return t.length!==20||!this.isAssetAddress(e)?null:t.readUInt32BE(16)}static isAssetAddress(e){let t=Buffer.from("0000000000000000000000000000000100000000","hex"),s=Buffer.from(e.replace("0x",""),"hex");return s.length!==20?!1:s.subarray(0,16).equals(t.subarray(0,16))}};function Ye(m,e){let t=[];return JSON.stringify(m,(s,r)=>(r&&r[e]&&t.push(r),r)),t[0]}function Ar(m,e,t){let s;return JSON.stringify(m,(r,o)=>(o&&o[e]===t&&(s=o),o)),s}var vr=(m,e)=>typeof e=="bigint"?e.toString():e;import{memoize1 as ot}from"@thi.ng/memoize";import{TLRUCache as nt}from"@thi.ng/cache";var D=class extends G{pools=[];subs=[];assets=new Map([]);mem=0;memPoolsCache=new nt(null,{maxlen:1,ttl:60*60*1e3,release:e=>{this.mem>e&&this.log(this.getPoolType(),`mem ${e} released at`,new Date)}});memPools=ot(e=>(this.log(this.getPoolType(),`mem ${e} sync`),this.getPools()),this.memPoolsCache);constructor(e){super(e)}get augmentedPools(){return this.pools.filter(e=>this.isValidPool(e)).map(e=>this.withMetadata(e))}async withAssets(e){this.assets=new Map(e.map(t=>[t.id,t])),this.mem=this.mem+1}async getPoolsMem(){return await this.memPools(this.mem)}async getPools(){this.unsubscribe(),this.pools=await this.loadPools(),this.subs=this.subscribe();let e=this.getPoolType();return this.log(e,`mem ${this.mem} pools(${this.augmentedPools.length})`),this.log(e,`mem ${this.mem} subs(${this.subs.length})`),this.augmentedPools}subscribe(){return this.augmentedPools.map(t=>{let s=[];try{let o=this.subscribePoolChange(t);s.push(o)}catch{}if(t.type==="Aave")return s;let r=this.subscribeTokensPoolBalance(t);if(s.push(r),this.hasSystemAsset(t)){let o=this.subscribeSystemPoolBalance(t);s.push(o)}if(this.hasErc20Asset(t)){let o=this.subscribeErc20PoolBalance(t);s.push(o)}return this.subscribeLog(t),s}).flat()}hasSystemAsset(e){return e.tokens.some(t=>t.id==="0")}hasErc20Asset(e){return e.tokens.some(t=>t.type==="Erc20")}unsubscribe(){this.subs.forEach(e=>{e.then(t=>t())})}subscribeLog(e){let t=e.address.substring(0,10).concat("...");this.log(`${e.type} mem ${this.mem} [${t}] balance subscribed`)}subscribeSystemPoolBalance(e){return this.subscribeSystemBalance(e.address,this.updateBalanceCallback(e))}subscribeTokensPoolBalance(e){let t=(s,r)=>s.id!==r;return this.subscribeTokenBalance(e.address,e.tokens,this.updateBalancesCallback(e,t))}subscribeErc20PoolBalance(e){return this.subscribeErc20Balance(e.address,e.tokens,this.updateBalancesCallback(e,()=>!0))}isValidPool(e){return e.type==="Xyk"?e.tokens.every(t=>this.assets.get(t.id)):!0}withMetadata(e){return e.tokens=e.tokens.map(t=>{let s=this.assets.get(t.id);return{...t,...s}}),e}updateBalancesCallback(e,t){return function(s){s.forEach(([r,o])=>{let i=e.tokens.findIndex(n=>n.id==r);i>=0&&t(e,r)&&(e.tokens[i].balance=o.toString())})}}updateBalanceCallback(e){return function(t,s){let r=e.tokens.findIndex(o=>o.id==t);r>=0&&(e.tokens[r].balance=s.toString())}}};var ct=["Supply","Withdraw","Repay","Borrow"],le=class extends D{isSupported(){return this.api.call.aaveTradeExecutor.pools!==void 0}async loadPools(){return(await this.api.call.aaveTradeExecutor.pools()).map(({reserve:t,atoken:s,liqudityIn:r,liqudityOut:o})=>({address:this.getPoolId(t.toString(),s.toString()),type:"Aave",tokens:[{id:t.toString(),balance:r.toString()},{id:s.toString(),balance:o.toString()}],...this.getPoolLimits()}))}async getPoolFees(e,t){return{}}getPoolType(){return"Aave"}getPoolId(e,t){let s=e+"/"+t;return it(at(s.padEnd(32,"\0")),63)}subscribePoolChange(e){let[t,s]=e.tokens,r=this.getReserveH160Id(t);return this.api.query.system.events(o=>{o.forEach(i=>{let{event:n}=i,a=`${n.section}:${n.method}`;if(a==="router:Executed"){let{assetIn:l,assetOut:c}=n.data.toHuman(),u=l.replace(/,/g,""),g=c.replace(/,/g,"");(u===s.id||g===s.id)&&(this.log(`Sync AAVE [router:Executed] :: ${u}:${g}`),this.updatePoolState(e))}if(a==="evm:Log"){let{log:l}=n.data.toHuman();try{let{eventName:c,args:u}=lt({abi:ne,topics:l.topics,data:l.data});ct.includes(c)&&u.reserve.toLowerCase()===r.toLowerCase()&&(this.log(`Sync AAVE [evm:Log] :: ${c} ${t.symbol}(${t.id})`),this.updatePoolState(e))}catch{}}})})}async updatePoolState(e){let[t,s]=e.tokens,{liqudityIn:r,liqudityOut:o}=await this.api.call.aaveTradeExecutor.pool(t.id,s.id);e.tokens=e.tokens.map(i=>{let n=i.id===t.id?r.toString():o.toString();return{...i,balance:n}})}getReserveH160Id(e){return e.type==="Erc20"?Ye(e.location,"accountKey20").accountKey20.key:$.fromAssetId(e.id)}getPoolLimits(){return{maxInRatio:0,maxOutRatio:0,minTradingLimit:0}}};import{calculate_in_given_out as ut,calculate_out_given_in as mt,calculate_linear_weights as pt,calculate_pool_trade_fee as dt,get_spot_price as gt}from"@galacticcouncil/math-lbp";var M=class{static getSpotPrice(e,t,s,r,o){return gt(e,t,s,r,o)}static calculateInGivenOut(e,t,s,r,o){return ut(e,t,s,r,o)}static calculateOutGivenIn(e,t,s,r,o){return mt(e,t,s,r,o)}static calculateLinearWeights(e,t,s,r,o){return pt(e,t,s,r,o)}static calculatePoolTradeFee(e,t,s){return dt(e,t,s)}};function F(m,e){return m.shiftedBy(-1*e).toString()}function v(m){return m[0]/m[1]*100}function k(m){return m[0]/m[1]}function E(m){return[m/1e3,1e3]}var ce=class m{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;fee;repayFeeApply;static fromPool(e){return new m(e.address,e.tokens,e.maxInRatio,e.maxOutRatio,e.minTradingLimit,e.fee,e.repayFeeApply)}constructor(e,t,s,r,o,i,n){this.type="Lbp",this.address=e,this.tokens=t,this.maxInRatio=s,this.maxOutRatio=r,this.minTradingLimit=o,this.fee=i,this.repayFeeApply=n}validatePair(e,t){return!0}parsePair(e,t){let s=new Map(this.tokens.map(a=>[a.id,a])),r=s.get(e),o=s.get(t);if(r==null)throw new Error("Pool does not contain tokenIn");if(o==null)throw new Error("Pool does not contain tokenOut");let i=d(r.balance),n=d(o.balance);return{assetIn:e,assetOut:t,balanceIn:i,balanceOut:n,decimalsIn:r.decimals,decimalsOut:o.decimals,weightIn:r.weight,weightOut:o.weight}}validateAndBuy(e,t,s){let r=this.tokens[0].id,o=[];t.isLessThan(this.minTradingLimit)&&o.push("InsufficientTradingAmount");let i=e.balanceOut.div(this.maxOutRatio);if(t.isGreaterThan(i)&&o.push("MaxOutRatioExceeded"),r===e.assetOut){let n=this.calculateTradeFee(t,s),a=v(this.repayFeeApply?s.repayFee:s.exchangeFee),l=t.plus(n),c=this.calculateInGivenOut(e,l),u=e.balanceIn.div(this.maxInRatio);return c.isGreaterThan(u)&&o.push("MaxInRatioExceeded"),{amountIn:c,calculatedIn:c,amountOut:t,feePct:a,errors:o}}else{let n=this.calculateInGivenOut(e,t),a=e.balanceIn.div(this.maxInRatio);return n.isGreaterThan(a)&&o.push("MaxInRatioExceeded"),{amountIn:n,calculatedIn:n,amountOut:t,feePct:0,errors:o}}}validateAndSell(e,t,s){let r=this.tokens[0].id,o=[];t.isLessThan(this.minTradingLimit)&&o.push("InsufficientTradingAmount");let i=e.balanceIn.div(this.maxInRatio);if(t.isGreaterThan(i)&&o.push("MaxInRatioExceeded"),r===e.assetIn){let n=this.calculateOutGivenIn(e,t),a=e.balanceOut.div(this.maxOutRatio);return n.isGreaterThan(a)&&o.push("MaxOutRatioExceeded"),{amountIn:t,calculatedOut:n,amountOut:n,feePct:0,errors:o}}else{let n=this.calculateOutGivenIn(e,t),a=this.calculateTradeFee(n,s),l=v(this.repayFeeApply?s.repayFee:s.exchangeFee),c=n.minus(a),u=e.balanceOut.div(this.maxOutRatio);return c.isGreaterThan(u)&&o.push("MaxOutRatioExceeded"),{amountIn:t,calculatedOut:n,amountOut:c,feePct:l,errors:o}}}calculateInGivenOut(e,t){let s=M.calculateInGivenOut(e.balanceIn.toString(),e.balanceOut.toString(),e.weightIn.toString(),e.weightOut.toString(),t.toFixed(0)),r=d(s);return r.isNegative()?b:r}calculateOutGivenIn(e,t){let s=M.calculateOutGivenIn(e.balanceIn.toString(),e.balanceOut.toString(),e.weightIn.toString(),e.weightOut.toString(),t.toFixed(0)),r=d(s);return r.isNegative()?b:r}spotPriceInGivenOut(e){let t=M.getSpotPrice(e.balanceOut.toString(),e.balanceIn.toString(),e.weightOut.toString(),e.weightIn.toString(),B(T,e.decimalsOut).toString());return d(t)}spotPriceOutGivenIn(e){let t=M.getSpotPrice(e.balanceIn.toString(),e.balanceOut.toString(),e.weightIn.toString(),e.weightOut.toString(),B(T,e.decimalsIn).toString());return d(t)}calculateTradeFee(e,t){let s=M.calculatePoolTradeFee(e.toString(),this.repayFeeApply?t.repayFee[0]:t.exchangeFee[0],this.repayFeeApply?t.repayFee[1]:t.exchangeFee[1]);return d(s)}};var ue=class extends D{MAX_FINAL_WEIGHT=B(d(100),6);poolsData=new Map([]);isSupported(){return this.api.query.lbp!==void 0}async loadPools(){let[e,t]=await Promise.all([this.api.query.lbp.poolData.entries(),this.api.query.parachainSystem.validationData()]),{relayParentNumber:s}=t.unwrap(),r=e.filter(([o,i])=>this.isActivePool(i.unwrap(),s)).map(async([{args:[o]},i])=>{let n=i.unwrap(),a=o.toString(),l=await this.getPoolDelta(a,n,s.toString());return this.poolsData.set(o.toString(),n),{address:a,type:"Lbp",fee:n.fee.toJSON(),...l,...this.getPoolLimits()}});return Promise.all(r)}async getPoolFees(e,t){let s=this.pools.find(r=>r.address===t);return{repayFee:this.getRepayFee(),exchangeFee:s.fee}}getPoolType(){return"Lbp"}async subscribePoolChange(e){return this.api.query.parachainSystem.validationData(async t=>{let{relayParentNumber:s}=t.unwrap(),r=this.poolsData.get(e.address);if(this.isActivePool(r,s)){let i=await this.getPoolDelta(e.address,r,s.toString());Object.assign(e,i)}else{let i=this.pools.findIndex(n=>n.address==e.address);this.pools.splice(i,1)}})}async getPoolDelta(e,t,s){let{start:r,end:o,assets:i,initialWeight:n,finalWeight:a,repayTarget:l,feeCollector:c}=t,u=M.calculateLinearWeights(r.toString(),o.toString(),n.toString(),a.toString(),s),[g,p]=i,P=g.toString(),h=d(u),f=p.toString(),S=this.MAX_FINAL_WEIGHT.minus(d(h)),[y,I,A]=await Promise.all([this.isRepayFeeApplied(P,l.toString(),c.toString()),this.getBalance(e,P),this.getBalance(e,f)]);return{repayFeeApply:y,tokens:[{id:P,weight:h,balance:I.toString()},{id:f,weight:S,balance:A.toString()}]}}isActivePool(e,t){if(e.start.isEmpty||e.end.isEmpty)return!1;let s=e.start.unwrap().toNumber(),r=e.end.unwrap().toNumber();return t.toNumber()>=s&&t.toNumber()<r}async isRepayFeeApplied(e,t,s){let r=d(t);if(r.isZero())return!1;try{return(await this.getBalance(e,s)).isLessThan(r)}catch{return!0}}getRepayFee(){return this.api.consts.lbp.repayFee.toJSON()}getPoolLimits(){let e=this.api.consts.lbp.maxInRatio.toJSON(),t=this.api.consts.lbp.maxOutRatio.toJSON(),s=this.api.consts.lbp.minTradingLimit.toJSON();return{maxInRatio:e,maxOutRatio:t,minTradingLimit:s}}};import{calculate_in_given_out as Pt,calculate_lrna_in_given_out as ht,calculate_out_given_in as bt,calculate_out_given_lrna_in as ft,calculate_pool_trade_fee as yt,calculate_spot_price as St,calculate_lrna_spot_price as xt,calculate_shares as wt,calculate_liquidity_out as Ot,calculate_liquidity_lrna_out as Bt,calculate_liquidity_hub_in as It,is_sell_allowed as At,is_buy_allowed as vt,is_add_liquidity_allowed as Tt,is_remove_liquidity_allowed as Ft,recalculate_asset_fee as Nt,recalculate_protocol_fee as Rt,verify_asset_cap as Et}from"@galacticcouncil/math-omnipool";var O=class{static calculateSpotPrice(e,t,s,r){return St(e,t,s,r)}static calculateLrnaSpotPrice(e,t){return xt(e,t)}static calculateInGivenOut(e,t,s,r,o,i,n,a,l){return Pt(e,t,s,r,o,i,n,a,l)}static calculateLrnaInGivenOut(e,t,s,r,o){return ht(e,t,s,r,o)}static calculateOutGivenIn(e,t,s,r,o,i,n,a,l){return bt(e,t,s,r,o,i,n,a,l)}static calculateOutGivenLrnaIn(e,t,s,r,o){return ft(e,t,s,r,o)}static calculatePoolTradeFee(e,t,s){return yt(e,t,s)}static calculateShares(e,t,s,r){return wt(e,t,s,r)}static calculateLiquidityOut(e,t,s,r,o,i,n,a){return Ot(e,t,s,r,o,i,n,a)}static calculateLiquidityLRNAOut(e,t,s,r,o,i,n,a){return Bt(e,t,s,r,o,i,n,a)}static calculateCapDifference(e,t,s,r){let o=w(t),i=w(e),n=w(r),l=w(s).shiftedBy(-18);if(o.div(n).lt(l)){let u=l.times(n).minus(o).times(i),g=o.times(w(1).minus(l));return u.div(g).toFixed(0)}else return"0"}static calculateLimitHubIn(e,t,s,r){return It(e,t,s,r)}static isSellAllowed(e){return At(e)}static isBuyAllowed(e){return vt(e)}static isAddLiquidityAllowed(e){return Tt(e)}static isRemoveLiquidityAllowed(e){return Ft(e)}static recalculateAssetFee(e,t,s,r,o,i,n,a,l,c,u){return Nt(e,t,s,r,o,i,n,a,l,c,u)}static recalculateProtocolFee(e,t,s,r,o,i,n,a,l,c,u){return Rt(e,t,s,r,o,i,n,a,l,c,u)}static verifyAssetCap(e,t,s,r){return Et(e,t,s,r)}};var me=class m{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;hubAssetId;static fromPool(e){return new m(e.address,e.tokens,e.maxInRatio,e.maxOutRatio,e.minTradingLimit,e.hubAssetId)}constructor(e,t,s,r,o,i){this.type="Omnipool",this.address=e,this.tokens=t,this.maxInRatio=s,this.maxOutRatio=r,this.minTradingLimit=o,this.hubAssetId=i}validatePair(e,t){return this.hubAssetId!=t}parsePair(e,t){let s=new Map(this.tokens.map(c=>[c.id,c])),r=s.get(e),o=s.get(t);if(r==null)throw new Error("Pool does not contain tokenIn");if(o==null)throw new Error("Pool does not contain tokenOut");let i=d(r.balance),n=d(o.balance),a=d(r.existentialDeposit),l=d(o.existentialDeposit);return{assetIn:e,assetOut:t,hubReservesIn:r.hubReserves,hubReservesOut:o.hubReserves,sharesIn:r.shares,sharesOut:o.shares,decimalsIn:r.decimals,decimalsOut:o.decimals,balanceIn:i,balanceOut:n,tradeableIn:r.tradeable,tradeableOut:o.tradeable,assetInED:a,assetOutED:l}}validateAndBuy(e,t,s){let r=this.calculateInGivenOut(e,t),o=this.calculateInGivenOut(e,t,s),i=o.minus(r),n=r===b?b:i.div(r).multipliedBy(100).decimalPlaces(2),a=[],l=O.isSellAllowed(e.tradeableIn),c=O.isBuyAllowed(e.tradeableOut);(!l||!c)&&a.push("TradeNotAllowed"),(t.isLessThan(this.minTradingLimit)||r.isLessThan(e.assetInED))&&a.push("InsufficientTradingAmount");let u=e.balanceOut.div(this.maxOutRatio);t.isGreaterThan(u)&&a.push("MaxOutRatioExceeded");let g=e.balanceIn.div(this.maxInRatio);return o.isGreaterThan(g)&&a.push("MaxInRatioExceeded"),{amountIn:o,calculatedIn:r,amountOut:t,feePct:n.toNumber(),errors:a}}validateAndSell(e,t,s){let r=this.calculateOutGivenIn(e,t),o=this.calculateOutGivenIn(e,t,s),n=r.minus(o).div(r).multipliedBy(100).decimalPlaces(2),a=[],l=O.isSellAllowed(e.tradeableIn),c=O.isBuyAllowed(e.tradeableOut);(!l||!c)&&a.push("TradeNotAllowed"),(t.isLessThan(this.minTradingLimit)||r.isLessThan(e.assetOutED))&&a.push("InsufficientTradingAmount");let u=e.balanceIn.div(this.maxInRatio);t.isGreaterThan(u)&&a.push("MaxInRatioExceeded");let g=e.balanceOut.div(this.maxOutRatio);return o.isGreaterThan(g)&&a.push("MaxOutRatioExceeded"),{amountIn:t,calculatedOut:r,amountOut:o,feePct:n.toNumber(),errors:a}}calculateInGivenOut(e,t,s){if(e.assetIn==this.hubAssetId)return this.calculateLrnaInGivenOut(e,t,s);let r=O.calculateInGivenOut(e.balanceIn.toString(),e.hubReservesIn.toString(),e.sharesIn.toString(),e.balanceOut.toString(),e.hubReservesOut.toString(),e.sharesOut.toString(),t.toFixed(0),s?k(s.assetFee).toString():b.toString(),s?k(s.protocolFee).toString():b.toString()),o=d(r);return o.isNegative()?b:o}calculateLrnaInGivenOut(e,t,s){let r=O.calculateLrnaInGivenOut(e.balanceOut.toString(),e.hubReservesOut.toString(),e.sharesOut.toString(),t.toFixed(0),s?k(s.assetFee).toString():b.toString()),o=d(r);return o.isNegative()?b:o}calculateOutGivenIn(e,t,s){if(e.assetIn==this.hubAssetId)return this.calculateOutGivenLrnaIn(e,t,s);let r=O.calculateOutGivenIn(e.balanceIn.toString(),e.hubReservesIn.toString(),e.sharesIn.toString(),e.balanceOut.toString(),e.hubReservesOut.toString(),e.sharesOut.toString(),t.toFixed(0),s?k(s.assetFee).toString():b.toString(),s?k(s.protocolFee).toString():b.toString()),o=d(r);return o.isNegative()?b:o}calculateOutGivenLrnaIn(e,t,s){let r=O.calculateOutGivenLrnaIn(e.balanceOut.toString(),e.hubReservesOut.toString(),e.sharesOut.toString(),t.toFixed(0),s?k(s.assetFee).toString():b.toString()),o=d(r);return o.isNegative()?b:o}spotPriceInGivenOut(e){if(e.assetIn==this.hubAssetId)return this.spotPriceLrnaInGivenOut(e);let t=O.calculateSpotPrice(e.balanceOut.toString(),e.hubReservesOut.toString(),e.balanceIn.toString(),e.hubReservesIn.toString());return d(t).shiftedBy(-1*(18-e.decimalsOut)).decimalPlaces(0,1)}spotPriceLrnaInGivenOut(e){let t=O.calculateLrnaSpotPrice(e.hubReservesOut.toString(),e.balanceOut.toString());return d(t).shiftedBy(-1*(18-e.decimalsOut)).decimalPlaces(0,1)}spotPriceOutGivenIn(e){if(e.assetIn==this.hubAssetId)return this.spotPriceOutGivenLrnaIn(e);let t=O.calculateSpotPrice(e.balanceIn.toString(),e.hubReservesIn.toString(),e.balanceOut.toString(),e.hubReservesOut.toString());return d(t).shiftedBy(-1*(18-e.decimalsIn)).decimalPlaces(0,1)}spotPriceOutGivenLrnaIn(e){let t=O.calculateLrnaSpotPrice(e.balanceOut.toString(),e.hubReservesOut.toString());return d(t).shiftedBy(-1*(18-e.decimalsIn)).decimalPlaces(0,1)}};import{encodeAddress as kt}from"@polkadot/util-crypto";import{stringToU8a as _t}from"@polkadot/util";var pe=class extends D{isSupported(){return this.api.query.omnipool!==void 0}async loadPools(){let e=this.api.consts.omnipool.hubAssetId.toString(),t=this.getPoolId(),[s,r,o]=await Promise.all([this.api.query.omnipool.assets.entries(),this.api.query.omnipool.hubAssetTradability(),this.getBalance(t,e)]),i=s.map(async([{args:[a]},l])=>{let{hubReserve:c,shares:u,tradable:g,cap:p,protocolShares:P}=l.unwrap(),h=await this.getBalance(t,a.toString());return{id:a.toString(),hubReserves:d(c.toString()),shares:d(u.toString()),tradeable:g.bits.toNumber(),balance:h.toString(),cap:d(p.toString()),protocolShares:d(P.toString())}}),n=await Promise.all(i);return n.push({id:e,tradeable:r.bits.toNumber(),balance:o.toString()}),[{address:t,type:"Omnipool",hubAssetId:e,tokens:n,...this.getPoolLimits()}]}async getPoolFees(e,t){let s=e.assetOut,r=e.assetIn,o="omnipool",i="Short",n=A=>A===L?[L,re]:[re,A],[a,l,c,u]=await Promise.all([this.api.query.system.number(),this.api.query.dynamicFees.assetFee(s),this.api.query.emaOracle.oracles(o,n(s),i),this.api.query.emaOracle.oracles(o,n(r),i)]),[g,p,P]=this.getAssetFee(e,a.toNumber(),l,c),[h,f,S]=r===re?[0,0,0]:this.getProtocolFee(e,a.toNumber(),l,u),y=g+h,I=P+S;return{assetFee:E(p),protocolFee:E(f),min:E(y),max:E(I)}}getPoolType(){return"Omnipool"}async subscribePoolChange(e){let t=e.tokens.map(s=>s.id);return this.api.query.omnipool.assets.multi(t,s=>{e.tokens=s.map((r,o)=>{let i=e.tokens[o];if(r.isNone)return i;let n=r.unwrap();return this.updateTokenState(i,n)})})}updateTokenState(e,t){let{hubReserve:s,shares:r,tradable:o,cap:i,protocolShares:n}=t;return{...e,hubReserves:d(s.toString()),shares:d(r.toString()),cap:d(i.toString()),protocolShares:d(n.toString()),tradeable:o.bits.toNumber()}}getAssetFee(e,t,s,r){let{assetOut:o,balanceOut:i}=e,{minFee:n,maxFee:a,decay:l,amplification:c}=this.api.consts.dynamicFees.assetFeeParameters,u=E(n.toNumber()),g=E(a.toNumber());if(s.isNone||r.isNone)return[n.toNumber(),n.toNumber(),a.toNumber()];let[p]=r.unwrap(),{assetFee:P,timestamp:h}=s.unwrap(),f=t-h.toNumber(),S=p.volume.bIn.toString(),y=p.volume.bOut.toString(),I=p.liquidity.b.toString();o===L&&(S=p.volume.aIn.toString(),y=p.volume.aOut.toString(),I=p.liquidity.a.toString());let A=E(P.toNumber()),x=O.recalculateAssetFee(S,y,I,"9",i.toString(),v(A).toString(),f.toString(),v(u).toString(),v(g).toString(),l.toString(),c.toString());return[n.toNumber(),Number(x)*1e4,a.toNumber()]}getProtocolFee(e,t,s,r){let{assetIn:o,balanceIn:i}=e,{minFee:n,maxFee:a,decay:l,amplification:c}=this.api.consts.dynamicFees.protocolFeeParameters,u=E(n.toNumber()),g=E(a.toNumber());if(s.isNone||r.isNone)return[n.toNumber(),n.toNumber(),a.toNumber()];let[p]=r.unwrap(),{protocolFee:P,timestamp:h}=s.unwrap(),f=t-h.toNumber(),S=p.volume.bIn.toString(),y=p.volume.bOut.toString(),I=p.liquidity.b.toString();o===L&&(S=p.volume.aIn.toString(),y=p.volume.aOut.toString(),I=p.liquidity.a.toString());let A=E(P.toNumber()),x=O.recalculateProtocolFee(S,y,I,"9",i.toString(),v(A).toString(),f.toString(),v(u).toString(),v(g).toString(),l.toString(),c.toString());return[n.toNumber(),Number(x)*1e4,a.toNumber()]}getPoolId(){return kt(_t("modlomnipool".padEnd(32,"\0")),63)}getPoolLimits(){let e=this.api.consts.omnipool.maxInRatio.toJSON(),t=this.api.consts.omnipool.maxOutRatio.toJSON(),s=this.api.consts.omnipool.minimumTradingLimit.toJSON();return{maxInRatio:e,maxOutRatio:t,minTradingLimit:s}}};import{calculate_in_given_out as Lt,calculate_out_given_in as Dt,calculate_pool_trade_fee as Ct,get_spot_price as Mt,calculate_liquidity_in as Gt,calculate_shares as Ht,calculate_spot_price as qt,calculate_spot_price_with_fee as Ut,calculate_liquidity_out_asset_a as Wt,calculate_liquidity_out_asset_b as Xt}from"@galacticcouncil/math-xyk";var q=class{static getSpotPrice(e,t,s){return Mt(e,t,s)}static calculateInGivenOut(e,t,s){return Lt(e,t,s)}static calculateOutGivenIn(e,t,s){return Dt(e,t,s)}static calculatePoolTradeFee(e,t,s){return Ct(e,t,s)}static calculateLiquidityIn(e,t,s){return Gt(e,t,s)}static calculateSpotPrice(e,t){return qt(e,t)}static calculateSpotPriceWithFee(e,t,s,r){return Ut(e,t,s,r)}static calculateShares(e,t,s){return Ht(e,t,s)}static calculateLiquidityOutAssetA(e,t,s,r){return Wt(e,t,s,r)}static calculateLiquidityOutAssetB(e,t,s,r){return Xt(e,t,s,r)}};var de=class m{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;static fromPool(e){return new m(e.address,e.tokens,e.maxInRatio,e.maxOutRatio,e.minTradingLimit)}constructor(e,t,s,r,o){this.type="Xyk",this.address=e,this.tokens=t,this.maxInRatio=s,this.maxOutRatio=r,this.minTradingLimit=o}validatePair(e,t){return!0}parsePair(e,t){let s=new Map(this.tokens.map(c=>[c.id,c])),r=s.get(e),o=s.get(t);if(r==null)throw new Error("Pool does not contain tokenIn");if(o==null)throw new Error("Pool does not contain tokenOut");let i=d(r.balance),n=d(o.balance),a=d(r.existentialDeposit),l=d(o.existentialDeposit);return{assetIn:e,assetOut:t,decimalsIn:r.decimals,decimalsOut:o.decimals,balanceIn:i,balanceOut:n,assetInED:a,assetOutED:l}}validateAndBuy(e,t,s){let r=this.calculateInGivenOut(e,t),o=this.calculateTradeFee(r,s),i=v(s.exchangeFee),n=r.plus(o),a=[];(t.isLessThan(this.minTradingLimit)||r.isLessThan(e.assetInED))&&a.push("InsufficientTradingAmount");let l=e.balanceOut.div(this.maxOutRatio);t.isGreaterThan(l)&&a.push("MaxOutRatioExceeded");let c=e.balanceIn.div(this.maxInRatio);return n.isGreaterThan(c)&&a.push("MaxInRatioExceeded"),{amountIn:n,calculatedIn:r,amountOut:t,feePct:i,errors:a}}validateAndSell(e,t,s){let r=this.calculateOutGivenIn(e,t),o=this.calculateTradeFee(r,s),i=v(s.exchangeFee),n=r.minus(o),a=[];(t.isLessThan(this.minTradingLimit)||r.isLessThan(e.assetOutED))&&a.push("InsufficientTradingAmount");let l=e.balanceIn.div(this.maxInRatio);t.isGreaterThan(l)&&a.push("MaxInRatioExceeded");let c=e.balanceOut.div(this.maxOutRatio);return n.isGreaterThan(c)&&a.push("MaxOutRatioExceeded"),{amountIn:t,calculatedOut:r,amountOut:n,feePct:i,errors:a}}calculateInGivenOut(e,t){let s=q.calculateInGivenOut(e.balanceIn.toString(),e.balanceOut.toString(),t.toFixed(0)),r=d(s);return r.isNegative()?b:r}calculateOutGivenIn(e,t){let s=q.calculateOutGivenIn(e.balanceIn.toString(),e.balanceOut.toString(),t.toFixed(0)),r=d(s);return r.isNegative()?b:r}spotPriceInGivenOut(e){let t=q.calculateSpotPrice(e.balanceOut.toString(),e.balanceIn.toString()),s=B(T,18-e.decimalsOut);return d(t).div(s)}spotPriceOutGivenIn(e){let t=q.calculateSpotPrice(e.balanceIn.toString(),e.balanceOut.toString()),s=B(T,18-e.decimalsIn);return d(t).div(s)}calculateTradeFee(e,t){let s=q.calculatePoolTradeFee(e.toString(),t.exchangeFee[0],t.exchangeFee[1]);return d(s)}};var ge=class extends D{isSupported(){return this.api.query.xyk!==void 0}async loadPools(){let t=(await this.api.query.xyk.poolAssets.entries()).map(async([{args:[s]},r])=>{let o=s.toString(),[i,n]=r.unwrap(),[a,l]=await Promise.all([this.getBalance(o,i.toString()),this.getBalance(o,n.toString())]);return{address:o,type:"Xyk",tokens:[{id:i.toString(),balance:a.toString()},{id:n.toString(),balance:l.toString()}],...this.getPoolLimits()}});return Promise.all(t)}async getPoolFees(e,t){return{exchangeFee:this.getExchangeFee()}}getPoolType(){return"Xyk"}subscribePoolChange(e){throw new Error("Pool change subscription not supported!")}getExchangeFee(){return this.api.consts.xyk.getExchangeFee.toJSON()}getPoolLimits(){let e=this.api.consts.xyk.maxInRatio.toJSON(),t=this.api.consts.xyk.maxOutRatio.toJSON(),s=this.api.consts.xyk.minTradingLimit.toJSON();return{maxInRatio:e,maxOutRatio:t,minTradingLimit:s}}};import{calculate_in_given_out as Yt,calculate_out_given_in as $t,calculate_amplification as zt,calculate_add_one_asset as Jt,calculate_liquidity_out_one_asset as Kt,calculate_pool_trade_fee as Vt,calculate_shares as jt,calculate_shares_for_amount as Zt,calculate_spot_price_with_fee as Qt,pool_account_name as es,recalculate_peg as ts}from"@galacticcouncil/math-stableswap";var N=class{static getPoolAddress(e){return es(e)}static defaultPegs(e){let t=[];for(let s=0;s<e;s++)t.push(["1","1"]);return t}static calculateAmplification(e,t,s,r,o){return zt(e,t,s,r,o)}static calculateInGivenOut(e,t,s,r,o,i,n){return Yt(e,t,s,r,o,i,n)}static calculateAddOneAsset(e,t,s,r,o,i,n){return Jt(e,t,s,r,o,i,n)}static calculateSharesForAmount(e,t,s,r,o,i,n){return Zt(e,t,s,r,o,i,n)}static calculateOutGivenIn(e,t,s,r,o,i,n){return $t(e,t,s,r,o,i,n)}static calculateLiquidityOutOneAsset(e,t,s,r,o,i,n){return Kt(e,t,s,r,o,i,n)}static calculateShares(e,t,s,r,o,i){return jt(e,t,s,r,o,i)}static calculateSpotPriceWithFee(e,t,s,r,o,i,n,a){return Qt(e,t,s,r,o,i,n,a)}static calculatePoolTradeFee(e,t,s){return Vt(e,t,s)}static recalculatePegs(e,t,s,r,o){let i=ts(e,t,s,r,o);return JSON.parse(i)}};var Pe=class m{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;amplification;id;fee;totalIssuance;pegs;pegsFee;static fromPool(e){return new m(e.address,e.tokens,e.maxInRatio,e.maxOutRatio,e.minTradingLimit,e.amplification,e.id,e.fee,e.totalIssuance,e.pegs,e.pegsFee)}constructor(e,t,s,r,o,i,n,a,l,c,u){this.type="Stableswap",this.address=e,this.tokens=t,this.maxInRatio=s,this.maxOutRatio=r,this.minTradingLimit=o,this.amplification=i,this.id=n,this.fee=a,this.totalIssuance=l,this.pegs=c,this.pegsFee=u}validatePair(e,t){return!0}parsePair(e,t){let s=new Map(this.tokens.map(c=>[c.id,c])),r=s.get(e),o=s.get(t);if(r==null)throw new Error("Pool does not contain tokenIn");if(o==null)throw new Error("Pool does not contain tokenOut");let i=d(r.balance),n=d(o.balance),a=d(r.existentialDeposit),l=d(o.existentialDeposit);return{assetIn:e,assetOut:t,balanceIn:i,balanceOut:n,decimalsIn:r.decimals,decimalsOut:o.decimals,tradeableIn:this.id===e?15:r.tradeable,tradeableOut:this.id===t?15:o.tradeable,assetInED:a,assetOutED:l}}validateAndBuy(e,t,s){let r=this.calculateInGivenOut(e,t),o=this.calculateInGivenOut(e,t,s),i=v(s.fee),n=[],a=O.isSellAllowed(e.tradeableIn),l=O.isBuyAllowed(e.tradeableOut);return(!a||!l)&&n.push("TradeNotAllowed"),(t.isLessThan(this.minTradingLimit)||r.isLessThan(e.assetInED))&&n.push("InsufficientTradingAmount"),{amountIn:o,calculatedIn:r,amountOut:t,feePct:i,errors:n}}validateAndSell(e,t,s){let r=this.calculateOutGivenIn(e,t),o=this.calculateOutGivenIn(e,t,s),i=v(s.fee),n=[],a=O.isSellAllowed(e.tradeableIn),l=O.isBuyAllowed(e.tradeableOut);return(!a||!l)&&n.push("TradeNotAllowed"),(t.isLessThan(this.minTradingLimit)||r.isLessThan(e.assetOutED))&&n.push("InsufficientTradingAmount"),{amountIn:t,calculatedOut:r,amountOut:o,feePct:i,errors:n}}calculateIn(e,t,s){let r=N.calculateInGivenOut(this.getReserves(),Number(e.assetIn),Number(e.assetOut),t.toFixed(0),this.amplification,s?k(s.fee).toString():b.toString(),this.getPegs()),o=d(r);return o.isNegative()?b:o}calculateAddOneAsset(e,t,s){let r=N.calculateAddOneAsset(this.getReserves(),t.toFixed(0),Number(e.assetIn),this.amplification,this.totalIssuance,s?k(s.fee).toString():b.toString(),this.getPegs()),o=d(r);return o.isNegative()?b:o}calculateSharesForAmount(e,t,s){let r=N.calculateSharesForAmount(this.getReserves(),Number(e.assetOut),t.toFixed(0),this.amplification,this.totalIssuance,s?k(s.fee).toString():b.toString(),this.getPegs()),o=d(r);return o.isNegative()?b:o}calculateInGivenOut(e,t,s){return e.assetOut==this.id?this.calculateAddOneAsset(e,t,s):e.assetIn==this.id?this.calculateSharesForAmount(e,t,s):this.calculateIn(e,t,s)}spotPriceInGivenOut(e){let t=N.calculateSpotPriceWithFee(this.id,this.getReserves(),this.amplification,e.assetOut,e.assetIn,this.totalIssuance,"0",this.getPegs());if(e.assetOut==this.id)return d(t);if(e.assetIn==this.id){let r=B(T,e.decimalsIn-e.decimalsOut);return d(t).div(r)}let s=B(T,18-e.decimalsIn);return d(t).div(s)}calculateOut(e,t,s){let r=N.calculateOutGivenIn(this.getReserves(),Number(e.assetIn),Number(e.assetOut),t.toFixed(0),this.amplification,s?k(s.fee).toString():b.toString(),this.getPegs()),o=d(r);return o.isNegative()?b:o}calculateWithdrawOneAsset(e,t,s){let r=N.calculateLiquidityOutOneAsset(this.getReserves(),t.toFixed(0),Number(e.assetOut),this.amplification,this.totalIssuance,s?k(s.fee).toString():b.toString(),this.getPegs()),o=d(r);return o.isNegative()?b:o}calculateShares(e,t,s){let r=N.calculateShares(this.getReserves(),this.getAssets(e.assetIn,t),this.amplification,this.totalIssuance,s?k(s.fee).toString():b.toString(),this.getPegs()),o=d(r);return o.isNegative()?b:o}calculateOutGivenIn(e,t,s){return e.assetIn==this.id?this.calculateWithdrawOneAsset(e,t,s):e.assetOut==this.id?this.calculateShares(e,t,s):this.calculateOut(e,t,s)}spotPriceOutGivenIn(e){let t=N.calculateSpotPriceWithFee(this.id,this.getReserves(),this.amplification,e.assetIn,e.assetOut,this.totalIssuance,"0",this.getPegs());if(e.assetIn==this.id)return d(t);if(e.assetOut==this.id){let r=B(T,e.decimalsOut-e.decimalsIn);return d(t).div(r)}let s=B(T,18-e.decimalsOut);return d(t).div(s)}calculateTradeFee(e,t){let s=N.calculatePoolTradeFee(e.toString(),t.fee[0],t.fee[1]);return d(s)}getPegs(){return JSON.stringify(this.pegs)}getReserves(){let e=this.tokens.filter(t=>t.id!=this.id).map(({id:t,balance:s,decimals:r})=>({asset_id:Number(t),amount:s,decimals:r}));return JSON.stringify(e)}getAssets(e,t){let s={asset_id:Number(e),amount:t.toFixed(0)};return JSON.stringify([s])}};import{blake2AsHex as ss,encodeAddress as rs}from"@polkadot/util-crypto";var os=340282366920938463463374607431768211455n,he=class extends D{stablePools=new Map([]);isSupported(){return this.api.query.stableswap!==void 0}isPegSupported(){return this.api.query.stableswap.poolPegs!==void 0}async loadPools(){let[e,t]=await Promise.all([this.api.query.stableswap.pools.entries(),this.api.query.system.number()]),s=t.toNumber(),r=e.map(async([{args:[o]},i])=>{let n=i.unwrap(),a=o.toString(),l=this.getPoolAddress(a),[c,u,g]=await Promise.all([this.getPoolDelta(a,n,s.toString()),this.getPoolTokens(l,a,n),this.getPoolPegs(a,n,s.toString())]);return this.stablePools.set(l,n),{address:l,id:a,type:"Stableswap",fee:E(n.fee.toNumber()),tokens:u,...c,...g,...this.getPoolLimits()}});return Promise.all(r)}async getPoolFees(e,t){return{fee:this.pools.find(r=>r.address===t).pegsFee}}getPoolType(){return"Stableswap"}async subscribePoolChange(e){return this.api.query.system.number(async t=>{let s=t.toString(),r=this.stablePools.get(e.address);if(r){let[o,i]=await Promise.all([this.getPoolDelta(e.id,r,s),this.getPoolPegs(e.id,r,s)]);Object.assign(e,o,i)}})}async getPoolDelta(e,t,s){let{initialAmplification:r,finalAmplification:o,initialBlock:i,finalBlock:n}=t,a=N.calculateAmplification(r.toString(),o.toString(),i.toString(),n.toString(),s),l=await this.api.query.tokens.totalIssuance(e);return{amplification:a,totalIssuance:l.toString()}}async getPoolTokens(e,t,s){let{assets:r}=s,o=r.map(async n=>{let[a,l]=await Promise.all([this.api.query.stableswap.assetTradability(t,n.toString()),this.getBalance(e,n.toString())]);return{id:n.toString(),tradeable:a.bits.toNumber(),balance:l.toString()}}),i=await Promise.all(o);return i.push({id:t,tradeable:15,balance:os.toString()}),i}getPoolDefaultPegs(e){let t=e.fee,s=N.defaultPegs(e.assets.length);return{pegsFee:E(t.toNumber()),pegs:s}}async getPoolPegs(e,t,s){if(!this.isPegSupported())return this.getPoolDefaultPegs(t);let r=await this.api.query.stableswap.poolPegs(e);if(r.isNone)return this.getPoolDefaultPegs(t);let o=r.unwrap(),i=await this.getLatestPegs(t,o,s),n=this.getRecentPegs(o),a=o.maxPegUpdate.toHuman(),l=t.fee.toHuman(),[c,u]=N.recalculatePegs(JSON.stringify(n),JSON.stringify(i),s,a.replace(/%/g,""),l.replace(/%/g,"")),g=Number(c)*1e4;return{pegsFee:E(g),pegs:u}}getRecentPegs(e){let{current:t}=e;return Array.from(t.entries()).map(([s,r])=>r.map(o=>o.toString()))}async getLatestPegs(e,t,s){let{source:r}=t,o=Array.from(e.assets.entries()).map(([n,a])=>a.toString()),i=r.map(async(n,a)=>{if(n.isOracle){let[l,c,u]=n.asOracle,g=[u.toString(),o[a]].map(y=>Number(y)).sort((y,I)=>y-I),p=await this.api.query.emaOracle.oracles(l,g,c),[{price:P,updatedAt:h}]=p.unwrap(),f=P.n.toString(),S=P.d.toString();return u.toString()===g[0].toString()?[[f,S],h.toString()]:[[S,f],h.toString()]}else return[n.asValue.map(l=>l.toString()),s]});return Promise.all(i)}getPoolAddress(e){let t=Number(e),s=N.getPoolAddress(t);return rs(ss(s),63)}getPoolLimits(){return{maxInRatio:0,maxOutRatio:0,minTradingLimit:this.api.consts.stableswap.minTradingLimit.toJSON()}}};var V=class extends _{api;assetClient;aaveClient;xykClient;omniClient;lbpClient;stableClient;clients=[];onChainAssets=[];memRegistry=ns(e=>(this.log(`Registry mem ${e} sync`),this.syncRegistry()));constructor(e){super(e),this.api=e,this.assetClient=new K(this.api),this.aaveClient=new le(this.api),this.xykClient=new ge(this.api),this.omniClient=new pe(this.api),this.lbpClient=new ue(this.api),this.stableClient=new he(this.api),this.clients=[this.aaveClient,this.xykClient,this.omniClient,this.lbpClient,this.stableClient]}get assets(){return this.onChainAssets}get isRegistrySynced(){return this.onChainAssets.length>0}async syncRegistry(e){let t=await this.assetClient.getOnChainAssets(!1,e);this.clients.forEach(s=>s.withAssets(t)),this.onChainAssets=t}async getPools(e){return this.isRegistrySynced||await this.memRegistry(1),e.length==0?(await Promise.all(this.clients.filter(r=>r.isSupported()).map(r=>r.getPoolsMem()))).flat():(await Promise.all(this.clients.filter(s=>e.some(r=>r===s.getPoolType())).map(s=>s.getPoolsMem()))).flat()}destroy(){this.aaveClient.unsubscribe(),this.xykClient.unsubscribe(),this.omniClient.unsubscribe(),this.lbpClient.unsubscribe(),this.stableClient.unsubscribe()}async getPoolFees(e,t){switch(t.type){case"Aave":return this.aaveClient.getPoolFees(e,t.address);case"Xyk":return this.xykClient.getPoolFees(e,t.address);case"Omnipool":return this.omniClient.getPoolFees(e,t.address);case"Lbp":return this.lbpClient.getPoolFees(e,t.address);case"Stableswap":return this.stableClient.getPoolFees(e,t.address);default:throw new oe(t.type)}}};var Be=class extends V{feeCache;disconnectSubscribeNewHeads=null;constructor(e){super(e),this.feeCache=new is(null),this.api.rpc.chain.subscribeNewHeads(async t=>{this.feeCache.release()}).then(t=>{this.disconnectSubscribeNewHeads=t})}async getPoolFees(e,t){let s=[t.address,e.assetIn,e.assetOut].join("-");if(this.feeCache.has(s))return this.feeCache.get(s);{let o=await super.getPoolFees(e,t);return this.feeCache.set(s,o),o}}async destroy(){this.log(`Destroying pool cache!
|
|
2
|
-
Items: [${this.feeCache.length}]`),this.feeCache.release(),this.disconnectSubscribeNewHeads?.()}};var j=class{static get(e){switch(e.type){case"Aave":return ae.fromPool(e);case"Xyk":return de.fromPool(e);case"Omnipool":return me.fromPool(e);case"Lbp":return ce.fromPool(e);case"Stableswap":return Pe.fromPool(e);default:throw new Error("Pool type "+e.type+" is not supported yet")}}};var be=class{constructor(e=1/0){this.capacity=e}storage=[];enqueue(e){if(this.size()===this.capacity)throw Error("Queue has reached max capacity, you cannot add more items");this.storage.push(e)}dequeue(){return this.storage.shift()}size(){return this.storage.length}};var as=5,Z=class{isNotVisited(e,t){let s=!0;return t.forEach(r=>{(r[0]===e[0]||r[1]===e[1])&&(s=!1)}),s}findPaths(e,t,s){let r=[],o=new be,i=[];for(i.push([t,""]),o.enqueue(i);o.size()>0;){let n=o.dequeue();if(n==null||n.length>as)return r;let a=n[n.length-1];(s===null||a[0]===s)&&r.push(n),e.get(a[0])?.forEach(c=>{if(this.isNotVisited(c,n)){let u=[...n];u.push(c),o.enqueue(u)}})}return r}buildAndPopulateGraph(e,t){let s=new Map;for(let r of e)s.set(parseInt(r),[]);for(let[r,o,i]of t){let n=parseInt(o),a=parseInt(i);s.get(n)?.push([a,r])}return s}};function Ie(m){let e={};for(let t of m){let s=t.tokens.length;for(let r=0;r<s;r++){e[t.tokens[r].id]||(e[t.tokens[r].id]=[]);for(let o=0;o<s;o++){if(r==o)continue;let i=[t.address,t.tokens[r].id,t.tokens[o].id];e[t.tokens[r].id].push(i)}}}return e}var Q=class{getProposals(e,t,s){let r=Ie(s),o=Object.keys(r),i=o.map(c=>r[c]).flat(),n=new Z,a=n.buildAndPopulateGraph(o,i),l=n.findPaths(a,parseInt(e),t?parseInt(t):null);return this.parsePaths(l)}parsePaths(e){let t=[];for(let s of e){let r=[];for(let o=0;o<s.length;o++){let i=s[o],n=s[o+1];if(n==null)break;r.push(this.toEdge(i,n))}t.push(r)}return t}toEdge(e,t){return[t[1],e[0].toString(),t[0].toString()]}};var ee=class{routeSuggester;routerOptions;poolService;defaultRouterOptions={includeOnly:[]};constructor(e,t){this.poolService=e,this.routeSuggester=new Q,this.routerOptions={...this.defaultRouterOptions,...t}}async getPools(){let e=this.routerOptions.includeOnly;return await this.poolService.getPools(e)}async getAllAssets(){let e=await this.getPools();if(e.length===0)throw new Error("No pools configured");let t=await this.getAssets(e);return[...new Map(t).values()]}async getAssetPairs(e){let t=await this.getPools();if(t.length===0)throw new Error("No pools configured");let{assets:s,poolsMap:r}=await this.validateToken(e,t),i=this.getPaths(e,null,r,t).map(n=>n[n.length-1].assetOut);return this.toAssets([...new Set(i)],s)}async getAllPaths(e,t){let s=await this.getPools();if(s.length===0)throw new Error("No pools configured");let{poolsMap:r}=await this.validateTokenPair(e,t,s);return this.getPaths(e,t,r,s)}async getAssets(e){let t=e.map(s=>s.tokens.map(r=>({id:r.id,name:r.name,symbol:r.symbol,decimals:r.decimals,icon:r.icon,type:r.type,isSufficient:r.isSufficient,existentialDeposit:r.existentialDeposit,meta:r.meta,location:r.location,isWhiteListed:r.isWhiteListed}))).flat();return new Map(t.map(s=>[s.id,s]))}getPaths(e,t,s,r){return this.routeSuggester.getProposals(e,t,r).filter(n=>this.validPath(n,s)).map(n=>this.toHops(n,s))}async validateTokenPair(e,t,s){let r=await this.getAssets(s);if(r.get(e)==null)throw new Error(e+" is not supported token");if(r.get(t)==null)throw new Error(t+" is not supported token");let o=this.getPoolMap(s);return{assets:r,poolsMap:o}}async validateToken(e,t){let s=await this.getAssets(t);if(s.get(e)==null)throw new Error(e+" is not supported token");let r=this.getPoolMap(t);return{assets:s,poolsMap:r}}getPoolMap(e){return new Map(e.map(t=>[t.address,j.get(t)]))}validPath(e,t){return e.length>0&&e.map(s=>this.validEdge(s,t)).reduce((s,r)=>s&&r)}validEdge([e,t,s],r){return r.get(e)?.validatePair(t,s)||!1}toHops(e,t){return e.map(([s,r,o])=>{let i=t.get(s);return{poolAddress:s,poolId:i?.id,pool:i?.type,assetIn:r,assetOut:o}})}toAssets(e,t){return e.map(s=>t.get(s))}};var ls=d("100");function qa(m,e){return m.minus(e).abs().div(m.plus(e).div(2)).multipliedBy(100).decimalPlaces(2)}function te(m,e){return m.minus(e).div(e).multipliedBy(100).decimalPlaces(2)}function $e(m,e){return T.minus(e.div(m)).multipliedBy(100).decimalPlaces(2)}function ze(m,e){return e.div(m).minus(T).multipliedBy(100).decimalPlaces(2)}function se(m,e){return(e<.01||e>100)&&new Error("Supported range is from 0.01% - 100%"),m.div(ls).multipliedBy(e).decimalPlaces(0,1)}var Ae=(t=>(t.Buy="Buy",t.Sell="Sell",t))(Ae||{});var ve=class extends ee{isDirectTrade(e){return e.length==1}findBestSellRoute(e){let t=e.sort((s,r)=>{let o=s[s.length-1].amountOut,i=r[r.length-1].amountOut;return o.isGreaterThan(i)?-1:1});return t.find(s=>s.every(r=>r.errors.length==0))||t[0]}getRouteFeeRange(e){if(e.filter(s=>s.tradeFeeRange).length>0){let s=e.map(o=>o.tradeFeeRange?.[0]??o.tradeFeePct).reduce((o,i)=>o+i),r=e.map(o=>o.tradeFeeRange?.[1]??o.tradeFeePct).reduce((o,i)=>o+i);return[s,r]}}getPoolFeeRange(e){let t=e.min?v(e.min):void 0,s=e.max?v(e.max):void 0;if(t&&s)return[t,s]}async getBestSell(e,t,s){return this.getSell(e,t,s)}async getSell(e,t,s,r){let o=await super.getPools();if(o.length===0)throw new Error("No pools configured");let{poolsMap:i}=await super.validateTokenPair(e,t,o),n=super.getPaths(e,t,i,o);if(n.length===0)throw new X(e,t);let a;if(r)a=await this.toSellSwaps(s,r,i);else{let x=n.map(async U=>await this.toSellSwaps(s,U,i)),C=await Promise.all(x);a=this.findBestSellRoute(C)}let l=a[0],c=a[a.length-1],u=this.isDirectTrade(a),g=a.map(x=>x.spotPrice.shiftedBy(-1*x.assetOutDecimals)).reduce((x,C)=>x.multipliedBy(C)),p=B(g,c.assetOutDecimals),P=u?c.calculatedOut:this.calculateDelta0Y(l.amountIn,a,i),h=c.amountOut,f=u?c.tradeFeePct:$e(P,h).toNumber(),S=P.minus(h),y=this.getRouteFeeRange(a),I=l.amountIn.shiftedBy(-1*l.assetInDecimals).multipliedBy(p),A=te(P,I);return{type:"Sell",amountIn:l.amountIn,amountOut:c.amountOut,spotPrice:p,tradeFee:S,tradeFeePct:f,tradeFeeRange:y,priceImpactPct:A.toNumber(),swaps:a,toHuman(){return{type:"Sell",amountIn:F(l.amountIn,l.assetInDecimals),amountOut:F(c.amountOut,c.assetOutDecimals),spotPrice:F(p,c.assetOutDecimals),tradeFee:F(S,c.assetOutDecimals),tradeFeePct:f,tradeFeeRange:y,priceImpactPct:A.toNumber(),swaps:a.map(x=>x.toHuman())}}}}calculateDelta0Y(e,t,s){let r=[];for(let o=0;o<t.length;o++){let i=t[o],n=s.get(i.poolAddress);if(n==null)throw new Error("Pool does not exit");let a=n.parsePair(i.assetIn,i.assetOut),l;o>0?l=r[o-1]:l=e;let c=n.calculateOutGivenIn(a,l);r.push(c)}return r[r.length-1]}async toSellSwaps(e,t,s){let r=[];for(let o=0;o<t.length;o++){let i=t[o],n=s.get(i.poolAddress);if(n==null)throw new Error("Pool does not exit");let a=n.parsePair(i.assetIn,i.assetOut),l;o>0?l=r[o-1].amountOut:l=B(d(e),a.decimalsIn).decimalPlaces(0,1);let c=await this.poolService.getPoolFees(a,n),{amountOut:u,calculatedOut:g,feePct:p,errors:P}=n.validateAndSell(a,l,c),h=this.getPoolFeeRange(c),f=n.spotPriceOutGivenIn(a),S=l.shiftedBy(-1*a.decimalsIn).multipliedBy(f),y=te(g,S);r.push({...i,assetInDecimals:a.decimalsIn,assetOutDecimals:a.decimalsOut,amountIn:l,calculatedOut:g,amountOut:u,spotPrice:f,tradeFeePct:p,tradeFeeRange:h,priceImpactPct:y.toNumber(),errors:P,isSupply(){return n.type==="Aave"&&n.tokens[0].id===i.assetIn},isWithdraw(){return n.type==="Aave"&&n.tokens[1].id===i.assetIn},toHuman(){return{...i,amountIn:F(l,a.decimalsIn),calculatedOut:F(g,a.decimalsOut),amountOut:F(u,a.decimalsOut),spotPrice:F(f,a.decimalsOut),tradeFeePct:p,tradeFeeRange:h,priceImpactPct:y.toNumber(),errors:P}}})}return r}async getMostLiquidRoute(e,t){let s=await super.getPools(),{poolsMap:r}=await super.validateTokenPair(e,t,s),o=super.getPaths(e,t,r,s);if(o.length===0)throw new X(e,t);let l=s.filter(p=>p.tokens.some(P=>P.id===e&&P.id!==p.id)).map(p=>p.type==="Aave"?p.tokens:p.tokens.filter(P=>P.id===e)).map(p=>p.map(P=>d(P.balance).shiftedBy(-1*P.decimals)).reduce((P,h)=>P.plus(h))).sort((p,P)=>P.isLessThan(p)?-1:1)[0].div(100).multipliedBy(.1),c=o.map(async p=>await this.toSellSwaps(l,p,r)),u=await Promise.all(c);return this.findBestSellRoute(u).map(p=>({poolAddress:p.poolAddress,poolId:p?.poolId,pool:p.pool,assetIn:p.assetIn,assetOut:p.assetOut}))}async getBestSpotPrice(e,t){let s=await super.getPools();if(s.length===0)throw new Error("No pools configured");let{poolsMap:r}=await super.validateTokenPair(e,t,s);if(super.getPaths(e,t,r,s).length===0)return Promise.resolve(void 0);let i=await this.getMostLiquidRoute(e,t),n=await this.toSellSwaps("1",i,r),a=n.map(u=>u.spotPrice.shiftedBy(-1*u.assetOutDecimals)).reduce((u,g)=>u.multipliedBy(g)),l=n[n.length-1].assetOutDecimals;return{amount:B(a,l),decimals:l}}findBestBuyRoute(e){let t=e.sort((s,r)=>{let o=s[0].amountIn,i=r[0].amountIn;return o.isGreaterThan(i)?1:-1});return t.find(s=>s.every(r=>r.errors.length==0))||t[0]}async getBestBuy(e,t,s){return this.getBuy(e,t,s)}async getBuy(e,t,s,r){let o=await super.getPools();if(o.length===0)throw new Error("No pools configured");let{poolsMap:i}=await super.validateTokenPair(e,t,o),n=super.getPaths(e,t,i,o);if(n.length===0)throw new X(e,t);let a;if(r)a=await this.toBuySwaps(s,r,i);else{let x=n.map(async U=>await this.toBuySwaps(s,U,i)),C=await Promise.all(x);a=this.findBestBuyRoute(C)}let l=a[a.length-1],c=a[0],u=this.isDirectTrade(a),g=a.map(x=>x.spotPrice.shiftedBy(-1*x.assetInDecimals)).reduce((x,C)=>x.multipliedBy(C)),p=B(g,c.assetInDecimals),P=u?c.calculatedIn:this.calculateDelta0X(l.amountOut,a,i),h=c.amountIn,f=u?c.tradeFeePct:ze(P,h).toNumber(),S=h.minus(P),y=this.getRouteFeeRange(a),I=l.amountOut.shiftedBy(-1*l.assetOutDecimals).multipliedBy(p),A;return P.isZero()?A=-100:A=te(I,P).toNumber(),{type:"Buy",amountOut:l.amountOut,amountIn:c.amountIn,spotPrice:p,tradeFee:S,tradeFeePct:f,tradeFeeRange:y,priceImpactPct:A,swaps:a,toHuman(){return{type:"Buy",amountOut:F(l.amountOut,l.assetOutDecimals),amountIn:F(c.amountIn,c.assetInDecimals),spotPrice:F(p,c.assetInDecimals),tradeFee:F(S,c.assetInDecimals),tradeFeePct:f,tradeFeeRange:y,priceImpactPct:A,swaps:a.map(x=>x.toHuman())}}}}calculateDelta0X(e,t,s){let r=[];for(let o=t.length-1;o>=0;o--){let i=t[o],n=s.get(i.poolAddress);if(n==null)throw new Error("Pool does not exit");let a=n.parsePair(i.assetIn,i.assetOut),l;o==t.length-1?l=e:l=r[0];let c=n.calculateInGivenOut(a,l);r.unshift(c)}return r[0]}async toBuySwaps(e,t,s){let r=[];for(let o=t.length-1;o>=0;o--){let i=t[o],n=s.get(i.poolAddress);if(n==null)throw new Error("Pool does not exit");let a=n.parsePair(i.assetIn,i.assetOut),l;o==t.length-1?l=B(d(e),a.decimalsOut).decimalPlaces(0,1):l=r[0].amountIn;let c=await this.poolService.getPoolFees(a,n),{amountIn:u,calculatedIn:g,feePct:p,errors:P}=n.validateAndBuy(a,l,c),h=this.getPoolFeeRange(c),f=n.spotPriceInGivenOut(a),S=l.shiftedBy(-1*a.decimalsOut).multipliedBy(f),y;g.isZero()?y=-100:y=te(S,g).toNumber(),r.unshift({...i,assetInDecimals:a.decimalsIn,assetOutDecimals:a.decimalsOut,amountOut:l,calculatedIn:g,amountIn:u,spotPrice:f,tradeFeePct:p,tradeFeeRange:h,priceImpactPct:y,errors:P,isSupply(){return n.type==="Aave"&&n.tokens[0].id===i.assetIn},isWithdraw(){return n.type==="Aave"&&n.tokens[1].id===i.assetIn},toHuman(){return{...i,amountOut:F(l,a.decimalsOut),calculatedIn:F(g,a.decimalsIn),amountIn:F(u,a.decimalsIn),spotPrice:F(f,a.decimalsIn),tradeFeePct:p,tradeFeeRange:h,priceImpactPct:y,errors:P}}})}return r}};import{encodeFunctionData as Ps}from"viem";import{decodeAddress as fe,encodeAddress as Ke}from"@polkadot/util-crypto";import{hexToU8a as cs,isHex as us,u8aToHex as ms}from"@polkadot/util";import{Buffer as W}from"buffer";var Je=W.from("ETH\0");function ps(m){if(!m)return!1;try{let e=fe(m,!0);return W.from(e.subarray(0,Je.length)).equals(Je)}catch{return!1}}function ds(m){return!!/^0x[a-fA-F0-9]{40}$/.test(m)}function gs(m){try{let e=us(m)?cs(m):fe(m);return Ke(e),!0}catch{return!1}}var ye=class m{static prefixBytes=W.from("ETH\0");static toAccount=e=>{let t=W.from(e.slice(2),"hex");return Ke(new Uint8Array(W.concat([m.prefixBytes,t,W.alloc(8)])),63)};static fromAccount=e=>{let s=fe(e).slice(m.prefixBytes.length,-8);return"0x"+W.from(s).toString("hex")};static fromSS58=e=>{let s=fe(e).slice(0,20);return ms(s)};static fromAny=e=>{if(ds(e))return e;if(ps(e))return m.fromAccount(e);if(gs(e))return m.fromSS58(e);throw new Error("Unknown address type")}};var Te=class extends _{balanceClient;evmClient;constructor(e){super(e),this.balanceClient=new G(e),this.evmClient=new ie}buildBuyTx(e,t=1){if(e.type!=="Buy")throw new Error("Not permitted");let{amountIn:s,amountOut:r,swaps:o}=e,i=o[0],n=o[o.length-1],a=se(s,t),l=i.assetIn,c=n.assetOut,u=s.plus(a),g;return this.isDirectOmnipoolTrade(o)?g=this.api.tx.omnipool.buy(c,l,r.toFixed(),u.toFixed()):g=this.api.tx.router.buy(l,c,r.toFixed(),u.toFixed(),this.buildRoute(o)),{hex:g.toHex(),name:"RouterBuy",get:()=>g,dryRun:p=>this.dryRun(p,g)}}buildSellTx(e,t=1){if(e.type!=="Sell")throw new Error("Not permitted");let{amountIn:s,amountOut:r,swaps:o}=e,i=o[0],n=o[o.length-1],a=se(r,t),l=i.assetIn,c=n.assetOut,u=r.minus(a),g;return this.isDirectOmnipoolTrade(o)?g=this.api.tx.omnipool.sell(l,c,s.toFixed(),u.toFixed()):g=this.api.tx.router.sell(l,c,s.toFixed(),u.toFixed(),this.buildRoute(o)),{hex:g.toHex(),name:"RouterSell",get:()=>g,dryRun:p=>this.dryRun(p,g)}}buildSellAllTx(e,t=1){if(e.type!=="Sell")throw new Error("Not permitted");let{amountOut:s,swaps:r}=e,o=r[0],i=r[r.length-1],n=se(s,t),a=o.assetIn,l=i.assetOut,c=s.minus(n),u=this.api.tx.router.sellAll(a,l,c.toFixed(),this.buildRoute(r));return{hex:u.toHex(),name:"RouterSellAll",get:()=>u,dryRun:g=>this.dryRun(g,u)}}async buildWithdrawAndSellReserveTx(e,t,s=1){let{amountIn:r,amountOut:o,swaps:i}=t,n=i[0],a=i[i.length-1];if(!n.isWithdraw())throw new Error("Not permitted");let l=n.assetIn,c=n.assetOut,[u,g]=await Promise.all([this.evmClient.getProvider().getGasPrice(),this.balanceClient.getBalance(e,l)]),p=r.isGreaterThanOrEqualTo(g.minus(5)),P=u*10n/100n,h=ye.fromAny(e),f=p?He:BigInt(r.toFixed()),S=$.fromAssetId(c),y=Ps({abi:ne,functionName:"withdraw",args:[S,f,h]}),I=this.api.tx.evm.call(h,Me,y,0n,Ge,u+P,u+P,null,[]),A=se(o,s),x=c,C=a.assetOut,U=o.minus(A),Fe=this.api.tx.router.sell(x,C,r.minus(5).toFixed(),U.toFixed(),this.buildRoute(i.slice(1))),Se=this.api.tx.utility.batchAll([I,Fe]);return{hex:Se.toHex(),name:"WithdrawAndRouterReserveSell",get:()=>Se,dryRun:Ve=>this.dryRun(Ve,Se)}}buildRoute(e){return e.map(({assetIn:t,assetOut:s,pool:r,poolId:o})=>r==="Stableswap"?{pool:{Stableswap:o},assetIn:t,assetOut:s}:{pool:r,assetIn:t,assetOut:s})}isDirectOmnipoolTrade(e){return e.length===1&&e[0].pool==="Omnipool"}};export{ne as AAVE_ABI,Ge as AAVE_GAS_LIMIT,Me as AAVE_PROXY,Oe as AAVE_ROUNDING_THRESHOLD,He as AAVE_UINT_256_MAX,os as AMOUNT_MAX,ae as AavePool,le as AavePoolClient,K as AssetClient,_e as AssetNotFound,ws as BASILISK_PARACHAIN_ID,G as BalanceClient,w as BigNumber,Be as CachingPoolService,je as DECIMAL_PLACES,xe as DENOMINATOR,$ as ERC20,ie as EvmClient,we as FarmClient,ye as H160,re as HUB_ASSET_ID,Os as HYDRADX_PARACHAIN_ID,H as HYDRADX_SS58_PREFIX,Ns as INFINITY,M as LbpMath,ce as LbpPool,ue as LbpPoolClient,T as ONE,O as OmniMath,me as OmniPool,pe as OmniPoolClient,_ as PolkadotApiClient,ke as PoolConfigNotFound,Y as PoolError,j as PoolFactory,oe as PoolNotFound,V as PoolService,R as PoolType,Ce as ProviderConfigNotFound,z as RUNTIME_DECIMALS,X as RouteNotFound,ee as Router,Bs as SYSTEM_ASSET_DECIMALS,L as SYSTEM_ASSET_ID,N as StableMath,Pe as StableSwap,he as StableSwapClient,Le as StorageConfigNotFound,De as SubscriptionNotSupported,J as TRADEABLE_DEFAULT,ve as TradeRouter,Ae as TradeType,Te as TradeUtils,q as XykMath,de as XykPool,ge as XykPoolClient,b as ZERO,vr as bnFormatter,d as bnum,ze as calculateBuyFee,qa as calculateDiffToAvg,te as calculateDiffToRef,$e as calculateSellFee,We as evmMainnet,Ye as findNestedKey,Ar as findNestedObj,se as getFraction,ps as isEvmAccount,ds as isEvmAddress,gs as isSs58Address,B as scale};
|
|
1
|
+
var $=[{anonymous:!1,inputs:[{indexed:!0,internalType:"address",name:"reserve",type:"address"},{indexed:!1,internalType:"address",name:"user",type:"address"},{indexed:!0,internalType:"address",name:"onBehalfOf",type:"address"},{indexed:!1,internalType:"uint256",name:"amount",type:"uint256"},{indexed:!0,internalType:"uint16",name:"referralCode",type:"uint16"}],name:"Supply",type:"event"},{anonymous:!1,inputs:[{indexed:!0,internalType:"address",name:"reserve",type:"address"},{indexed:!0,internalType:"address",name:"user",type:"address"},{indexed:!0,internalType:"address",name:"to",type:"address"},{indexed:!1,internalType:"uint256",name:"amount",type:"uint256"}],name:"Withdraw",type:"event"},{inputs:[{internalType:"address",name:"asset",type:"address"},{internalType:"uint256",name:"amount",type:"uint256"},{internalType:"address",name:"to",type:"address"}],name:"withdraw",outputs:[{internalType:"uint256",name:"",type:"uint256"}],stateMutability:"nonpayable",type:"function"},{anonymous:!1,inputs:[{indexed:!0,internalType:"address",name:"reserve",type:"address"},{indexed:!1,internalType:"address",name:"user",type:"address"},{indexed:!0,internalType:"address",name:"onBehalfOf",type:"address"},{indexed:!1,internalType:"uint256",name:"amount",type:"uint256"},{indexed:!1,internalType:"enum DataTypes.InterestRateMode",name:"interestRateMode",type:"uint8"},{indexed:!1,internalType:"uint256",name:"borrowRate",type:"uint256"},{indexed:!0,internalType:"uint16",name:"referralCode",type:"uint16"}],name:"Borrow",type:"event"},{inputs:[{internalType:"address",name:"asset",type:"address"},{internalType:"uint256",name:"amount",type:"uint256"},{internalType:"uint256",name:"interestRateMode",type:"uint256"},{internalType:"uint16",name:"referralCode",type:"uint16"},{internalType:"address",name:"onBehalfOf",type:"address"}],name:"borrow",outputs:[],stateMutability:"nonpayable",type:"function"},{anonymous:!1,inputs:[{indexed:!0,internalType:"address",name:"reserve",type:"address"},{indexed:!0,internalType:"address",name:"user",type:"address"},{indexed:!0,internalType:"address",name:"repayer",type:"address"},{indexed:!1,internalType:"uint256",name:"amount",type:"uint256"},{indexed:!1,internalType:"bool",name:"useATokens",type:"bool"}],name:"Repay",type:"event"},{inputs:[{internalType:"address",name:"user",type:"address"}],name:"getUserAccountData",outputs:[{internalType:"uint256",name:"totalCollateralBase",type:"uint256"},{internalType:"uint256",name:"totalDebtBase",type:"uint256"},{internalType:"uint256",name:"availableBorrowsBase",type:"uint256"},{internalType:"uint256",name:"currentLiquidationThreshold",type:"uint256"},{internalType:"uint256",name:"ltv",type:"uint256"},{internalType:"uint256",name:"healthFactor",type:"uint256"}],stateMutability:"view",type:"function"}];var Oe=[{inputs:[{internalType:"contract IEACAggregatorProxy",name:"_networkBaseTokenPriceInUsdProxyAggregator",type:"address"},{internalType:"contract IEACAggregatorProxy",name:"_marketReferenceCurrencyPriceInUsdProxyAggregator",type:"address"}],stateMutability:"nonpayable",type:"constructor"},{inputs:[],name:"ETH_CURRENCY_UNIT",outputs:[{internalType:"uint256",name:"",type:"uint256"}],stateMutability:"view",type:"function"},{inputs:[],name:"MKR_ADDRESS",outputs:[{internalType:"address",name:"",type:"address"}],stateMutability:"view",type:"function"},{inputs:[{internalType:"bytes32",name:"_bytes32",type:"bytes32"}],name:"bytes32ToString",outputs:[{internalType:"string",name:"",type:"string"}],stateMutability:"pure",type:"function"},{inputs:[{internalType:"contract IPoolAddressesProvider",name:"provider",type:"address"}],name:"getReservesData",outputs:[{components:[{internalType:"address",name:"underlyingAsset",type:"address"},{internalType:"string",name:"name",type:"string"},{internalType:"string",name:"symbol",type:"string"},{internalType:"uint256",name:"decimals",type:"uint256"},{internalType:"uint256",name:"baseLTVasCollateral",type:"uint256"},{internalType:"uint256",name:"reserveLiquidationThreshold",type:"uint256"},{internalType:"uint256",name:"reserveLiquidationBonus",type:"uint256"},{internalType:"uint256",name:"reserveFactor",type:"uint256"},{internalType:"bool",name:"usageAsCollateralEnabled",type:"bool"},{internalType:"bool",name:"borrowingEnabled",type:"bool"},{internalType:"bool",name:"stableBorrowRateEnabled",type:"bool"},{internalType:"bool",name:"isActive",type:"bool"},{internalType:"bool",name:"isFrozen",type:"bool"},{internalType:"uint128",name:"liquidityIndex",type:"uint128"},{internalType:"uint128",name:"variableBorrowIndex",type:"uint128"},{internalType:"uint128",name:"liquidityRate",type:"uint128"},{internalType:"uint128",name:"variableBorrowRate",type:"uint128"},{internalType:"uint128",name:"stableBorrowRate",type:"uint128"},{internalType:"uint40",name:"lastUpdateTimestamp",type:"uint40"},{internalType:"address",name:"aTokenAddress",type:"address"},{internalType:"address",name:"stableDebtTokenAddress",type:"address"},{internalType:"address",name:"variableDebtTokenAddress",type:"address"},{internalType:"address",name:"interestRateStrategyAddress",type:"address"},{internalType:"uint256",name:"availableLiquidity",type:"uint256"},{internalType:"uint256",name:"totalPrincipalStableDebt",type:"uint256"},{internalType:"uint256",name:"averageStableRate",type:"uint256"},{internalType:"uint256",name:"stableDebtLastUpdateTimestamp",type:"uint256"},{internalType:"uint256",name:"totalScaledVariableDebt",type:"uint256"},{internalType:"uint256",name:"priceInMarketReferenceCurrency",type:"uint256"},{internalType:"address",name:"priceOracle",type:"address"},{internalType:"uint256",name:"variableRateSlope1",type:"uint256"},{internalType:"uint256",name:"variableRateSlope2",type:"uint256"},{internalType:"uint256",name:"stableRateSlope1",type:"uint256"},{internalType:"uint256",name:"stableRateSlope2",type:"uint256"},{internalType:"uint256",name:"baseStableBorrowRate",type:"uint256"},{internalType:"uint256",name:"baseVariableBorrowRate",type:"uint256"},{internalType:"uint256",name:"optimalUsageRatio",type:"uint256"},{internalType:"bool",name:"isPaused",type:"bool"},{internalType:"bool",name:"isSiloedBorrowing",type:"bool"},{internalType:"uint128",name:"accruedToTreasury",type:"uint128"},{internalType:"uint128",name:"unbacked",type:"uint128"},{internalType:"uint128",name:"isolationModeTotalDebt",type:"uint128"},{internalType:"bool",name:"flashLoanEnabled",type:"bool"},{internalType:"uint256",name:"debtCeiling",type:"uint256"},{internalType:"uint256",name:"debtCeilingDecimals",type:"uint256"},{internalType:"uint8",name:"eModeCategoryId",type:"uint8"},{internalType:"uint256",name:"borrowCap",type:"uint256"},{internalType:"uint256",name:"supplyCap",type:"uint256"},{internalType:"uint16",name:"eModeLtv",type:"uint16"},{internalType:"uint16",name:"eModeLiquidationThreshold",type:"uint16"},{internalType:"uint16",name:"eModeLiquidationBonus",type:"uint16"},{internalType:"address",name:"eModePriceSource",type:"address"},{internalType:"string",name:"eModeLabel",type:"string"},{internalType:"bool",name:"borrowableInIsolation",type:"bool"}],internalType:"struct IUiPoolDataProviderV3.AggregatedReserveData[]",name:"",type:"tuple[]"},{components:[{internalType:"uint256",name:"marketReferenceCurrencyUnit",type:"uint256"},{internalType:"int256",name:"marketReferenceCurrencyPriceInUsd",type:"int256"},{internalType:"int256",name:"networkBaseTokenPriceInUsd",type:"int256"},{internalType:"uint8",name:"networkBaseTokenPriceDecimals",type:"uint8"}],internalType:"struct IUiPoolDataProviderV3.BaseCurrencyInfo",name:"",type:"tuple"}],stateMutability:"view",type:"function"},{inputs:[{internalType:"contract IPoolAddressesProvider",name:"provider",type:"address"}],name:"getReservesList",outputs:[{internalType:"address[]",name:"",type:"address[]"}],stateMutability:"view",type:"function"},{inputs:[{internalType:"contract IPoolAddressesProvider",name:"provider",type:"address"},{internalType:"address",name:"user",type:"address"}],name:"getUserReservesData",outputs:[{components:[{internalType:"address",name:"underlyingAsset",type:"address"},{internalType:"uint256",name:"scaledATokenBalance",type:"uint256"},{internalType:"bool",name:"usageAsCollateralEnabledOnUser",type:"bool"},{internalType:"uint256",name:"stableBorrowRate",type:"uint256"},{internalType:"uint256",name:"scaledVariableDebt",type:"uint256"},{internalType:"uint256",name:"principalStableDebt",type:"uint256"},{internalType:"uint256",name:"stableBorrowLastUpdateTimestamp",type:"uint256"}],internalType:"struct IUiPoolDataProviderV3.UserReserveData[]",name:"",type:"tuple[]"},{internalType:"uint8",name:"",type:"uint8"}],stateMutability:"view",type:"function"},{inputs:[],name:"marketReferenceCurrencyPriceInUsdProxyAggregator",outputs:[{internalType:"contract IEACAggregatorProxy",name:"",type:"address"}],stateMutability:"view",type:"function"},{inputs:[],name:"networkBaseTokenPriceInUsdProxyAggregator",outputs:[{internalType:"contract IEACAggregatorProxy",name:"",type:"address"}],stateMutability:"view",type:"function"}];var le="0x1b02E051683b5cfaC5929C25E84adb26ECf87B38",Ae="0x112b087b60C1a166130d59266363C45F8aa99db0",Ie="0xf3Ba4D1b50f78301BDD7EAEa9B67822A15FCA691",De=1000000n;var Ce=BigInt("0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");import{defineChain as st}from"viem";var Le=["https://rpc.hydradx.cloud","https://hydration-rpc.n.dwellir.com","https://hydration.dotters.network","https://rpc.helikon.io/hydradx","https://hydration.ibp.network","https://rpc.cay.hydration.cloud","https://rpc.parm.hydration.cloud","https://rpc.roach.hydration.cloud","https://rpc.zipp.hydration.cloud","https://rpc.sin.hydration.cloud","https://rpc.coke.hydration.cloud"],Me=["wss://rpc.hydradx.cloud","wss://hydration-rpc.n.dwellir.com","wss://hydration.dotters.network","wss://rpc.helikon.io/hydradx","wss://hydration.ibp.network","wss://rpc.cay.hydration.cloud","wss://rpc.parm.hydration.cloud","wss://rpc.roach.hydration.cloud","wss://rpc.zipp.hydration.cloud","wss://rpc.sin.hydration.cloud","wss://rpc.coke.hydration.cloud"],Ge=st({id:222222,name:"Hydration",network:"hydration",nativeCurrency:{decimals:18,name:"WETH",symbol:"WETH"},rpcUrls:{public:{http:Le,webSocket:Me},default:{http:Le,webSocket:Me}},blockExplorers:{default:{name:"Hydration Explorer",url:"https://explorer.evm.hydration.cloud"}},testnet:!1});import{createPublicClient as qe,createWalletClient as rt,custom as nt,http as ot,webSocket as it}from"viem";var V=class{chain;constructor(e){this.chain=e||Ge}get chainId(){return this.chain.id}get chainCurrency(){return this.chain.nativeCurrency.symbol}get chainDecimals(){return this.chain.nativeCurrency.decimals}getProvider(){return qe({chain:this.chain,transport:ot()})}getWsProvider(){return qe({chain:this.chain,transport:it()})}getSigner(e){return rt({account:e,chain:this.chain,transport:nt(window.ethereum)})}};var j=class{evmClient;constructor(){this.evmClient=new V}async getReservesData(){return await this.evmClient.getProvider().readContract({abi:Oe,address:Ae,args:[Ie],functionName:"getReservesData"})}async getUserReservesData(e){return await this.evmClient.getProvider().readContract({abi:Oe,address:Ae,args:[Ie,e],functionName:"getUserReservesData"})}async getUserAccountData(e){return await this.evmClient.getProvider().readContract({abi:$,address:le,args:[e],functionName:"getUserAccountData"})}};import{decodeAddress as ue,encodeAddress as Ue}from"@polkadot/util-crypto";import{hexToU8a as at,isHex as lt,u8aToHex as ct}from"@polkadot/util";import{Buffer as X}from"buffer";var Ys=2090,Te=1e3,ce="1",$s=2034,H=63,Z=18,_="0",Vs=12,Q=15;var He=X.from("ETH\0");function ut(p){if(!p)return!1;try{let e=ue(p,!0);return X.from(e.subarray(0,He.length)).equals(He)}catch{return!1}}function mt(p){return!!/^0x[a-fA-F0-9]{40}$/.test(p)}function pt(p){try{let e=lt(p)?at(p):ue(p);return Ue(e),!0}catch{return!1}}var z=class p{static prefixBytes=X.from("ETH\0");static toAccount=e=>{let t=X.from(e.slice(2),"hex");return Ue(new Uint8Array(X.concat([p.prefixBytes,t,X.alloc(8)])),63)};static fromAccount=e=>{let s=ue(e).slice(p.prefixBytes.length,-8);return"0x"+X.from(s).toString("hex")};static fromSS58=e=>{let s=ue(e).slice(0,20);return ct(s)};static fromAny=e=>{if(mt(e))return e;if(ut(e))return p.fromAccount(e);if(pt(e))return p.fromSS58(e);throw new Error("Unknown address type")}};var U=class{static fromAssetId(e){let t=Number(e),s=Buffer.alloc(20,0);return s[15]=1,s.writeUInt32BE(t,16),"0x"+s.toString("hex")}static toAssetId(e){let t=Buffer.from(e.replace("0x",""),"hex");return t.length!==20||!this.isAssetAddress(e)?null:t.readUInt32BE(16)}static isAssetAddress(e){let t=Buffer.from("0000000000000000000000000000000100000000","hex"),s=Buffer.from(e.replace("0x",""),"hex");return s.length!==20?!1:s.subarray(0,16).equals(t.subarray(0,16))}};import{BigNumber as S}from"bignumber.js";var dt=12;S.config({EXPONENTIAL_AT:[-100,100],ROUNDING_MODE:4,DECIMAL_PLACES:dt});var b=m(0),v=m(1),sr=m("Infinity");function I(p,e){let t=new S(e.toString()),s=new S(10).pow(t);return p.times(s)}function m(p){return new S(p.toString())}var gt=m("1e27"),lr=m("1e8"),cr=m("31536000"),ur=m("999999999"),Pt=m("1.01"),ve=class{client;constructor(){this.client=new j}async loadCtx(e,t){let s=z.fromAny(e),r=U.fromAssetId(t),[n,i,o]=await Promise.all([this.client.getReservesData(),this.client.getUserReservesData(s),this.client.getUserAccountData(s)]),[a,l]=o,[c]=n,[u,g]=i,d=c.find(({underlyingAsset:Y})=>Y.toLowerCase()===r.toLowerCase()),P=u.find(({underlyingAsset:Y})=>Y.toLowerCase()===r.toLowerCase());if(!d||!P)throw new Error("Missing reserve or userReserve for "+t);let h=Number(d.decimals),y=m(d.priceInMarketReferenceCurrency),w=m(g===d.eModeCategoryId?d.eModeLiquidationThreshold:d.reserveLiquidationThreshold).div(1e4),f=m(d.liquidityIndex),O=m(P.scaledATokenBalance),A=m(a),x=m(l),k=d.usageAsCollateralEnabled&&P.usageAsCollateralEnabledOnUser&&m(P.scaledATokenBalance).gt(0),G=O.multipliedBy(f).dividedBy(gt).decimalPlaces(0,S.ROUND_DOWN);return{decimals:h,isCollateralAsset:k,priceInRef:y,reserveLiquidationThreshold:w,totalCollateralBase:A,totalDebtBase:x,userBalance:G}}async getMaxWithdraw(e,t){let{decimals:s,priceInRef:r,reserveLiquidationThreshold:n,totalCollateralBase:i,totalDebtBase:o,userBalance:a}=await this.loadCtx(e,t),l=m(i),c=m(o),u=Pt.multipliedBy(c).div(n).decimalPlaces(0,S.ROUND_UP),d=l.minus(u).decimalPlaces(0,1).multipliedBy(m(10).pow(s)).dividedBy(r).decimalPlaces(0,S.ROUND_DOWN);return{amount:S.minimum(a,d),decimals:s}}async getHealthFactorAfterWithdraw(e,t,s){let{decimals:r,isCollateralAsset:n,priceInRef:i,reserveLiquidationThreshold:o,totalCollateralBase:a,totalDebtBase:l}=await this.loadCtx(e,t),c=n?m(s).multipliedBy(i).dividedBy(m(10).pow(r)).decimalPlaces(0,S.ROUND_DOWN):b,u=a.minus(c);return u.lte(0)?0:u.multipliedBy(o).dividedBy(l).decimalPlaces(6,S.ROUND_DOWN).toNumber()}async getHealthFactorAfterSupply(e,t,s){let{decimals:r,priceInRef:n,reserveLiquidationThreshold:i,totalCollateralBase:o,totalDebtBase:a}=await this.loadCtx(e,t),l=m(s).multipliedBy(n).dividedBy(m(10).pow(r)).decimalPlaces(0,S.ROUND_DOWN),c=o.plus(l);return c.lte(0)?0:c.multipliedBy(i).dividedBy(a).decimalPlaces(6,S.ROUND_DOWN).toNumber()}};import"@galacticcouncil/api-augment/hydradx";import"@galacticcouncil/api-augment/basilisk";var D=class{api;constructor(e){this.api=e}get chainDecimals(){return this.api.registry.chainDecimals[0]}get chainToken(){return this.api.registry.chainTokens[0]}async dryRun(e,t){let s;try{s=await this.api.call.dryRunApi.dryRunCall({System:{Signed:e}},t.inner.toHex())}catch(r){throw console.error(r),new Error("Dry run execution failed!")}if(s.isOk)return s.asOk;throw console.log(s.asErr.toHuman()),new Error("Dry run execution error!")}log(e,...t){let s=typeof window>"u"?process.env.GC_DEBUG:window.localStorage.getItem("gc.debug");this.getLogValue(s)&&console.log(e,...t)}getLogValue(e){switch(e){case!0:case"true":case 1:case"1":case"on":case"yes":return!0;default:return!1}}};var ee=class extends D{SUPPORTED_TYPES=["StableSwap","Bond","Token","External","Erc20"];constructor(e){super(e)}async safeSharesQuery(){try{let e=await this.api.query.stableswap.pools.entries();return new Map(e.map(([{args:[t]},s])=>[t.toString(),s.unwrap()]))}catch{return new Map([])}}async safeBondsQuery(){try{let e=await this.api.query.bonds.bonds.entries();return new Map(e.map(([{args:[t]},s])=>[t.toString(),s.unwrap()]))}catch{return new Map([])}}async metadataQuery(){try{let e=await this.api.query.assetRegistry.assetMetadataMap.entries();return new Map(e.map(([{args:[t]},s])=>{let{decimals:r,symbol:n}=s.unwrap();return[t.toString(),{decimals:r.toNumber(),symbol:n.toHuman()}]}))}catch{return new Map([])}}async locationsQuery(){try{let e=await this.api.query.assetRegistry.assetLocations.entries();return new Map(e.map(([{args:[t]},s])=>[t.toString(),s.unwrap()]))}catch{return new Map([])}}getSystemTokenName(e){switch(e){case"HDX":return"Hydration";case"BSX":return"Basilisk";default:return e}}getToken(e,t,s,r){if(e==_){let u=this.api.consts.balances.existentialDeposit;return{id:_,name:this.getSystemTokenName(this.chainToken),symbol:this.chainToken,decimals:this.chainDecimals,icon:this.chainToken,type:"Token",isSufficient:!0,existentialDeposit:u.toString()}}let{name:n,assetType:i,isSufficient:o,existentialDeposit:a}=t,{symbol:l,decimals:c}=s.get(e)??{};return{id:e,name:n.toHuman(),symbol:l,decimals:c,icon:l,type:i.toHuman(),isSufficient:o?o.toHuman():!0,location:r?.toJSON(),existentialDeposit:a.toString()}}getBond(e,t,s,r){let[n,i]=r,{assetType:o,isSufficient:a,existentialDeposit:l}=t,{symbol:c,decimals:u}=this.getToken(n.toString(),t,s),g=i.toNumber(),d=new Intl.DateTimeFormat("en-GB"),P=[c,"Bond",d.format(g)].join(" ");return{id:e,name:P,symbol:c+"b",decimals:u,icon:c,type:o.toString(),isSufficient:a.toHuman(),existentialDeposit:l.toString(),underlyingAssetId:n.toString(),maturity:g}}getShares(e,t,s,r){let{assets:n}=r,{name:i,symbol:o,assetType:a,isSufficient:l,existentialDeposit:c}=t,g=n.map(h=>h.toString()).map(h=>{let{symbol:y}=this.getToken(h,t,s);return[h,y]}),d=Object.fromEntries(g),P=Object.values(d);return{id:e,name:P.join(", "),symbol:o?.isSome?o.toHuman():i.toHuman(),decimals:18,icon:P.join("/"),type:a.toString(),isSufficient:l.toHuman(),existentialDeposit:c.toString(),meta:d}}getExternal(e,t,s,r){let n=this.getToken(e,t,new Map,r),i=s?.find(o=>o.internalId===n.id);return i?{...n,decimals:i.decimals,name:i.name,symbol:i.symbol,icon:i.symbol,isWhiteListed:i.isWhiteListed}:n}normalizeMetadata(e,t){return t.size?t:new Map(e.map(([{args:[s]},r])=>{let{decimals:n,symbol:i}=r.unwrap();return[s.toString(),{decimals:Number(n.toString()),symbol:i.toHuman()}]}))}getSupportedAssets(e){return e.filter(([t,s])=>{if(s.isNone)return!1;let r=s.unwrap();return this.isSupportedAsset(r)})}async getOnChainAssets(e,t){let[s,r,n,i,o]=await Promise.all([this.api.query.assetRegistry.assets.entries(),this.locationsQuery(),this.safeSharesQuery(),this.safeBondsQuery(),this.metadataQuery()]),a=this.getSupportedAssets(s),l=this.normalizeMetadata(a,o),c=a.map(([{args:[u]},g])=>{let d=g.unwrap(),P=r.get(u.toString()),{assetType:h}=d;switch(h.toString()){case"Bond":let y=i.get(u.toString());return this.getBond(u.toString(),d,l,y);case"StableSwap":let w=n.get(u.toString());return this.getShares(u.toString(),d,l,w);case"External":return this.getExternal(u.toString(),d,t,P);default:return this.getToken(u.toString(),d,l,P)}});return e?c:c.filter(u=>this.isValidAsset(u))}isValidAsset(e){let t=Math.sign(e.decimals);return!!e.symbol&&(t===0||t===1)}isSupportedAsset(e){let t=e.assetType.toString();return this.SUPPORTED_TYPES.includes(t)}};var q=class extends D{constructor(e){super(e)}async getBalance(e,t){let s=await this.api.query.assetRegistry.assets(t),{assetType:r}=s.unwrap();return r.toString()==="Erc20"?this.getErc20Balance(e,t):t===_?this.getSystemBalance(e):this.getTokenBalance(e,t)}async getSystemBalance(e){let{data:t}=await this.api.query.system.account(e);return this.calculateFreeBalance(t)}async getTokenBalance(e,t){let{free:s,reserved:r,frozen:n}=await this.api.query.tokens.accounts(e,t);return this.calculateFreeBalance({free:s,feeFrozen:r,frozen:n})}async getErc20Balance(e,t){let{free:s,reserved:r,frozen:n}=await this.getTokenBalanceData(e,t);return this.calculateFreeBalance({free:s,feeFrozen:0n,frozen:n})}async subscribeSystemBalance(e,t){return this.api.query.system.account(e,({data:s})=>t(_,this.calculateFreeBalance(s)))}async subscribeTokenBalance(e,t,s){let n=t.filter(i=>i.type!=="Erc20").filter(i=>i.id!==_).map(i=>[e,i.id]);return this.api.query.tokens.accounts.multi(n,i=>{let o=[];i.forEach((a,l)=>{let c=this.calculateFreeBalance(a),u=n[l][1];o.push([u,c])}),s(o)})}async subscribeErc20Balance(e,t,s){let r=t.filter(i=>i.type==="Erc20"),n=async()=>{let i=[];(await Promise.all(r.map(async a=>[a.id,await this.getErc20Balance(e,a.id)]))).forEach(([a,l])=>{i.push([a,l])}),s(i)};return await n(),this.api.rpc.chain.subscribeNewHeads(async()=>{n()})}async getTokenBalanceData(e,t){return this.api.call.currenciesApi.account(t,e)}calculateFreeBalance(e){let{free:t,miscFrozen:s,feeFrozen:r,frozen:n}=e,i=new S(t),o=new S(s||n),a=new S(r||0n),l=o.gt(a)?o:a;return i.minus(l)}};import{fixed_from_rational as We}from"@galacticcouncil/math-liquidity-mining";import{GenericAccountId32 as ht}from"@polkadot/types";import{u8aConcat as Xe}from"@polkadot/util";import{isAddress as Ye}from"@polkadot/util-crypto";var Ne=class extends D{balanceClient;constructor(e){super(e),this.balanceClient=new q(e)}secondsInYear=new S(365.2425).times(24).times(60).times(60);async getOmnipoolFarms(e){let t=await this.api.query.omnipoolWarehouseLM.activeYieldFarm.entries(e);return await Promise.all(t.map(async([r,n])=>{let[,i]=r.args,o=n.unwrap().toString(),a=i.toString(),l=(await this.api.query.omnipoolWarehouseLM.globalFarm(a)).unwrap(),c=(await this.api.query.omnipoolWarehouseLM.yieldFarm(e,a,o)).unwrap(),u=await this.getOraclePrice(l)??l.priceAdjustment.toString(),d=this.getAccountResolver(this.api.registry)(Number(a),!1).toString(),P=l.rewardCurrency.toString(),h=await this.balanceClient.getTokenBalanceData(d,P);return{assetId:e,globalFarm:l,yieldFarm:c,priceAdjustment:u,potBalance:h.free.toString()}}))}async getIsolatedPoolFarms(e){let t=await this.api.query.xykWarehouseLM.activeYieldFarm.entries(e);return await Promise.all(t.map(async([r,n])=>{let[,i]=r.args,o=n.unwrap().toString(),a=i.toString(),l=(await this.api.query.xykWarehouseLM.globalFarm(a)).unwrap(),c=(await this.api.query.xykWarehouseLM.yieldFarm(e,a,o)).unwrap(),u=await this.getOraclePrice(l)??l.priceAdjustment.toString(),d=this.getAccountResolver(this.api.registry)(Number(a),!0).toString(),P=l.rewardCurrency.toString(),h=await this.balanceClient.getTokenBalanceData(d,P);return{assetId:e,globalFarm:l,yieldFarm:c,priceAdjustment:u,potBalance:h.free.toString()}}))}async getOraclePrice(e){let t=e.rewardCurrency.toString(),s=e.incentivizedAsset.toString(),r=[t,s].sort();if(t===s)return new S(1).shiftedBy(18).toString();let n=await this.api.query.emaOracle.oracles("omnipool",r,"TenMinutes");if(n.isNone)return;let[i]=n.unwrap(),o=i.price.n.toString(),a=i.price.d.toString(),l;return Number(t)<Number(s)?l=We(o,a):l=We(a,o),l}getGlobalRewardPerPeriod(e,t,s,r){let i=e.times(t).shiftedBy(-18).times(r).shiftedBy(-18);return i.gte(s)?s:i}getPoolYieldPerPeriod(e,t,s,r){return e.times(t).div(s.times(r).shiftedBy(-18))}padEndU8a(e,t){return Xe(e,Array(Math.max(0,t-e.length)).fill(0))}getAccountResolver=e=>(t,s)=>{let r="modl",n=s?"0x78796b4c4d704944":"0x4f6d6e6957684c4d";return new ht(e,this.padEndU8a(Xe(r,n,typeof t!="number"?t.toU8a():[t]),32))};async getFarmApr(e,t){if(t==="isolatedpool"&&!Ye(e))throw new Error("You must pass an address of isolated pool as id");if(t==="omnipool"&&Ye(e))throw new Error("You must pass an asset id of omnipool");let s=6,r=t==="omnipool"?await this.getOmnipoolFarms(e):await this.getIsolatedPoolFarms(e);return r.length?r.map(({yieldFarm:o,globalFarm:a,priceAdjustment:l,potBalance:c})=>{let u=new S(a.totalSharesZ.toString()),g=a.plannedYieldingPeriods.toString(),d=new S(a.yieldPerPeriod.toString()),P=new S(a.maxRewardPerPeriod.toString()),h=a.blocksPerPeriod.toString(),y=new S(o.multiplier.toString()).shiftedBy(-18),w=this.secondsInYear.div(new S(s).times(h)),f;if(u.isZero())f=d.times(y).times(w);else{let G=this.getGlobalRewardPerPeriod(u,d,P,l);f=this.getPoolYieldPerPeriod(G,y,u,l).times(w)}let O=new S(a.pendingRewards.toString()).plus(a.accumulatedPaidRewards.toString()),A=P.times(g),x=c?O.plus(c):A;return O.div(x).gte(.999)?b:f.div(t==="isolatedpool"?2:1).times(100)}).reduce((o,a)=>o.plus(a),b).toString():void 0}};var me=class extends Error{constructor(e){super(),this.message=`${e} pool invalid`,this.name="PoolNotFound"}},$e=class extends Error{constructor(e,t){super(),this.message=`${e} pool missing ${t}`,this.name="PoolConfigNotFound"}},J=class extends Error{constructor(e,t){super(),this.message=`Route from ${e} to ${t} not found in pool configuration`,this.name="RouteNotFound"}},Ve=class extends Error{constructor(e){super(),this.message=`Asset ${e} not available in current network`,this.name="AssetNotFound"}},ze=class extends Error{constructor(e){super(),this.message=`Storage missing ${e}`,this.name="StorageConfigNotFound"}},Je=class extends Error{constructor(e){super(),this.message=`Subscription type "${e}" not supported`,this.name="SubscriptionNotSupported"}},Ke=class extends Error{constructor(e){super(),this.message=`${e}`,this.name="ProviderConfigNotFound"}};import{LRUCache as fs}from"@thi.ng/cache";import{memoize1 as ys}from"@thi.ng/memoize";var R=(n=>(n.Aave="Aave",n.LBP="Lbp",n.Omni="Omnipool",n.Stable="Stableswap",n.XYK="Xyk",n))(R||{}),K=(n=>(n.UnknownError="UnknownError",n.InsufficientTradingAmount="InsufficientTradingAmount",n.MaxInRatioExceeded="MaxInRatioExceeded",n.MaxOutRatioExceeded="MaxOutRatioExceeded",n.TradeNotAllowed="TradeNotAllowed",n))(K||{});var pe=class p{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;static fromPool(e){return new p(e.address,e.tokens,e.maxInRatio,e.maxOutRatio,e.minTradingLimit)}constructor(e,t,s,r,n){this.type="Aave",this.address=e,this.tokens=t,this.maxInRatio=s,this.maxOutRatio=r,this.minTradingLimit=n}validatePair(e,t){return!0}parsePair(e,t){let s=new Map(this.tokens.map(a=>[a.id,a])),r=s.get(e),n=s.get(t);if(r==null)throw new Error("Pool does not contain tokenIn");if(n==null)throw new Error("Pool does not contain tokenOut");let i=m(r.balance),o=m(n.balance);return{assetIn:e,assetOut:t,decimalsIn:r.decimals,decimalsOut:n.decimals,balanceIn:i,balanceOut:o,assetInED:b,assetOutED:b}}validateAndBuy(e,t,s){let r=this.calculateInGivenOut(e,t),n=[];return t.isGreaterThan(e.balanceOut)&&n.push("TradeNotAllowed"),{amountIn:r,calculatedIn:r,amountOut:t,feePct:0,errors:n}}validateAndSell(e,t,s){let r=this.calculateOutGivenIn(e,t),n=[];return r.isGreaterThan(e.balanceOut)&&n.push("TradeNotAllowed"),{amountIn:t,calculatedOut:r,amountOut:r,feePct:0,errors:n}}calculateInGivenOut(e,t){return t}calculateOutGivenIn(e,t){return t}spotPriceInGivenOut(e){return I(v,e.decimalsOut)}spotPriceOutGivenIn(e){return I(v,e.decimalsIn)}calculateTradeFee(e,t){return b}};import{encodeAddress as ft}from"@polkadot/util-crypto";import{stringToU8a as St}from"@polkadot/util";import{decodeEventLog as wt}from"viem";function je(p,e){let t=[];return JSON.stringify(p,(s,r)=>(r&&r[e]&&t.push(r),r)),t[0]}function tn(p,e,t){let s;return JSON.stringify(p,(r,n)=>(n&&n[e]===t&&(s=n),n)),s}var sn=(p,e)=>typeof e=="bigint"?e.toString():e;import{memoize1 as bt}from"@thi.ng/memoize";import{TLRUCache as yt}from"@thi.ng/cache";var C=class extends q{pools=[];subs=[];assets=new Map([]);mem=0;memPoolsCache=new yt(null,{maxlen:1,ttl:60*60*1e3,release:e=>{this.mem>e&&this.log(this.getPoolType(),`mem ${e} released at`,new Date)}});memPools=bt(e=>(this.log(this.getPoolType(),`mem ${e} sync`),this.getPools()),this.memPoolsCache);constructor(e){super(e)}get augmentedPools(){return this.pools.filter(e=>this.isValidPool(e)).map(e=>this.withMetadata(e))}async withAssets(e){this.assets=new Map(e.map(t=>[t.id,t])),this.mem=this.mem+1}async getPoolsMem(){return await this.memPools(this.mem)}async getPools(){this.unsubscribe(),this.pools=await this.loadPools(),this.subs=this.subscribe();let e=this.getPoolType();return this.log(e,`mem ${this.mem} pools(${this.augmentedPools.length})`),this.log(e,`mem ${this.mem} subs(${this.subs.length})`),this.augmentedPools}subscribe(){return this.augmentedPools.map(t=>{let s=[];try{let n=this.subscribePoolChange(t);s.push(n)}catch{}if(t.type==="Aave")return s;let r=this.subscribeTokensPoolBalance(t);if(s.push(r),this.hasSystemAsset(t)){let n=this.subscribeSystemPoolBalance(t);s.push(n)}if(this.hasErc20Asset(t)){let n=this.subscribeErc20PoolBalance(t);s.push(n)}return this.subscribeLog(t),s}).flat()}hasSystemAsset(e){return e.tokens.some(t=>t.id==="0")}hasErc20Asset(e){return e.tokens.some(t=>t.type==="Erc20")}unsubscribe(){this.subs.forEach(e=>{e.then(t=>t())})}subscribeLog(e){let t=e.address.substring(0,10).concat("...");this.log(`${e.type} mem ${this.mem} [${t}] balance subscribed`)}subscribeSystemPoolBalance(e){return this.subscribeSystemBalance(e.address,this.updateBalanceCallback(e))}subscribeTokensPoolBalance(e){let t=(s,r)=>s.id!==r;return this.subscribeTokenBalance(e.address,e.tokens,this.updateBalancesCallback(e,t))}subscribeErc20PoolBalance(e){return this.subscribeErc20Balance(e.address,e.tokens,this.updateBalancesCallback(e,()=>!0))}isValidPool(e){return e.type==="Xyk"?e.tokens.every(t=>this.assets.get(t.id)):!0}withMetadata(e){return e.tokens=e.tokens.map(t=>{let s=this.assets.get(t.id);return{...t,...s}}),e}updateBalancesCallback(e,t){return function(s){s.forEach(([r,n])=>{let i=e.tokens.findIndex(o=>o.id==r);i>=0&&t(e,r)&&(e.tokens[i].balance=n.toString())})}}updateBalanceCallback(e){return function(t,s){let r=e.tokens.findIndex(n=>n.id==t);r>=0&&(e.tokens[r].balance=s.toString())}}};var xt=["Supply","Withdraw","Repay","Borrow"],de=class extends C{isSupported(){return this.api.call.aaveTradeExecutor.pools!==void 0}async loadPools(){return(await this.api.call.aaveTradeExecutor.pools()).map(({reserve:t,atoken:s,liqudityIn:r,liqudityOut:n})=>({address:this.getPoolId(t.toString(),s.toString()),type:"Aave",tokens:[{id:t.toString(),balance:r.toString()},{id:s.toString(),balance:n.toString()}],...this.getPoolLimits()}))}async getPoolFees(e,t){return{}}getPoolType(){return"Aave"}getPoolId(e,t){let s=e+"/"+t;return ft(St(s.padEnd(32,"\0")),63)}subscribePoolChange(e){let[t,s]=e.tokens,r=this.getReserveH160Id(t);return this.api.query.system.events(n=>{n.forEach(i=>{let{event:o}=i,a=`${o.section}:${o.method}`;if(a==="router:Executed"){let{assetIn:l,assetOut:c}=o.data.toHuman(),u=l.replace(/,/g,""),g=c.replace(/,/g,"");(u===s.id||g===s.id)&&(this.log(`Sync AAVE [router:Executed] :: ${u}:${g}`),this.updatePoolState(e))}if(a==="evm:Log"){let{log:l}=o.data.toHuman();try{let{eventName:c,args:u}=wt({abi:$,topics:l.topics,data:l.data});xt.includes(c)&&u.reserve.toLowerCase()===r.toLowerCase()&&(this.log(`Sync AAVE [evm:Log] :: ${c} ${t.symbol}(${t.id})`),this.updatePoolState(e))}catch{}}})})}async updatePoolState(e){let[t,s]=e.tokens,{liqudityIn:r,liqudityOut:n}=await this.api.call.aaveTradeExecutor.pool(t.id,s.id);e.tokens=e.tokens.map(i=>{let o=i.id===t.id?r.toString():n.toString();return{...i,balance:o}})}getReserveH160Id(e){return e.type==="Erc20"?je(e.location,"accountKey20").accountKey20.key:U.fromAssetId(e.id)}getPoolLimits(){return{maxInRatio:0,maxOutRatio:0,minTradingLimit:0}}};import{calculate_in_given_out as Bt,calculate_out_given_in as Ot,calculate_linear_weights as At,calculate_pool_trade_fee as It,get_spot_price as Tt}from"@galacticcouncil/math-lbp";var M=class{static getSpotPrice(e,t,s,r,n){return Tt(e,t,s,r,n)}static calculateInGivenOut(e,t,s,r,n){return Bt(e,t,s,r,n)}static calculateOutGivenIn(e,t,s,r,n){return Ot(e,t,s,r,n)}static calculateLinearWeights(e,t,s,r,n){return At(e,t,s,r,n)}static calculatePoolTradeFee(e,t,s){return It(e,t,s)}};function N(p,e){return p.shiftedBy(-1*e).toString()}function L(p){return p[0]/p[1]*100}function T(p){return p[0]/p[1]}function E(p){return[p/1e3,1e3]}var ge=class p{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;fee;repayFeeApply;static fromPool(e){return new p(e.address,e.tokens,e.maxInRatio,e.maxOutRatio,e.minTradingLimit,e.fee,e.repayFeeApply)}constructor(e,t,s,r,n,i,o){this.type="Lbp",this.address=e,this.tokens=t,this.maxInRatio=s,this.maxOutRatio=r,this.minTradingLimit=n,this.fee=i,this.repayFeeApply=o}validatePair(e,t){return!0}parsePair(e,t){let s=new Map(this.tokens.map(a=>[a.id,a])),r=s.get(e),n=s.get(t);if(r==null)throw new Error("Pool does not contain tokenIn");if(n==null)throw new Error("Pool does not contain tokenOut");let i=m(r.balance),o=m(n.balance);return{assetIn:e,assetOut:t,balanceIn:i,balanceOut:o,decimalsIn:r.decimals,decimalsOut:n.decimals,weightIn:r.weight,weightOut:n.weight}}validateAndBuy(e,t,s){let r=this.tokens[0].id,n=[];t.isLessThan(this.minTradingLimit)&&n.push("InsufficientTradingAmount");let i=e.balanceOut.div(this.maxOutRatio);if(t.isGreaterThan(i)&&n.push("MaxOutRatioExceeded"),r===e.assetOut){let o=this.calculateTradeFee(t,s),a=L(this.repayFeeApply?s.repayFee:s.exchangeFee),l=t.plus(o),c=this.calculateInGivenOut(e,l),u=e.balanceIn.div(this.maxInRatio);return c.isGreaterThan(u)&&n.push("MaxInRatioExceeded"),{amountIn:c,calculatedIn:c,amountOut:t,feePct:a,errors:n}}else{let o=this.calculateInGivenOut(e,t),a=e.balanceIn.div(this.maxInRatio);return o.isGreaterThan(a)&&n.push("MaxInRatioExceeded"),{amountIn:o,calculatedIn:o,amountOut:t,feePct:0,errors:n}}}validateAndSell(e,t,s){let r=this.tokens[0].id,n=[];t.isLessThan(this.minTradingLimit)&&n.push("InsufficientTradingAmount");let i=e.balanceIn.div(this.maxInRatio);if(t.isGreaterThan(i)&&n.push("MaxInRatioExceeded"),r===e.assetIn){let o=this.calculateOutGivenIn(e,t),a=e.balanceOut.div(this.maxOutRatio);return o.isGreaterThan(a)&&n.push("MaxOutRatioExceeded"),{amountIn:t,calculatedOut:o,amountOut:o,feePct:0,errors:n}}else{let o=this.calculateOutGivenIn(e,t),a=this.calculateTradeFee(o,s),l=L(this.repayFeeApply?s.repayFee:s.exchangeFee),c=o.minus(a),u=e.balanceOut.div(this.maxOutRatio);return c.isGreaterThan(u)&&n.push("MaxOutRatioExceeded"),{amountIn:t,calculatedOut:o,amountOut:c,feePct:l,errors:n}}}calculateInGivenOut(e,t){let s=M.calculateInGivenOut(e.balanceIn.toString(),e.balanceOut.toString(),e.weightIn.toString(),e.weightOut.toString(),t.toFixed(0)),r=m(s);return r.isNegative()?b:r}calculateOutGivenIn(e,t){let s=M.calculateOutGivenIn(e.balanceIn.toString(),e.balanceOut.toString(),e.weightIn.toString(),e.weightOut.toString(),t.toFixed(0)),r=m(s);return r.isNegative()?b:r}spotPriceInGivenOut(e){let t=M.getSpotPrice(e.balanceOut.toString(),e.balanceIn.toString(),e.weightOut.toString(),e.weightIn.toString(),I(v,e.decimalsOut).toString());return m(t)}spotPriceOutGivenIn(e){let t=M.getSpotPrice(e.balanceIn.toString(),e.balanceOut.toString(),e.weightIn.toString(),e.weightOut.toString(),I(v,e.decimalsIn).toString());return m(t)}calculateTradeFee(e,t){let s=M.calculatePoolTradeFee(e.toString(),this.repayFeeApply?t.repayFee[0]:t.exchangeFee[0],this.repayFeeApply?t.repayFee[1]:t.exchangeFee[1]);return m(s)}};var Pe=class extends C{MAX_FINAL_WEIGHT=I(m(100),6);poolsData=new Map([]);isSupported(){return this.api.query.lbp!==void 0}async loadPools(){let[e,t]=await Promise.all([this.api.query.lbp.poolData.entries(),this.api.query.parachainSystem.validationData()]),{relayParentNumber:s}=t.unwrap(),r=e.filter(([n,i])=>this.isActivePool(i.unwrap(),s)).map(async([{args:[n]},i])=>{let o=i.unwrap(),a=n.toString(),l=await this.getPoolDelta(a,o,s.toString());return this.poolsData.set(n.toString(),o),{address:a,type:"Lbp",fee:o.fee.toJSON(),...l,...this.getPoolLimits()}});return Promise.all(r)}async getPoolFees(e,t){let s=this.pools.find(r=>r.address===t);return{repayFee:this.getRepayFee(),exchangeFee:s.fee}}getPoolType(){return"Lbp"}async subscribePoolChange(e){return this.api.query.parachainSystem.validationData(async t=>{let{relayParentNumber:s}=t.unwrap(),r=this.poolsData.get(e.address);if(this.isActivePool(r,s)){let i=await this.getPoolDelta(e.address,r,s.toString());Object.assign(e,i)}else{let i=this.pools.findIndex(o=>o.address==e.address);this.pools.splice(i,1)}})}async getPoolDelta(e,t,s){let{start:r,end:n,assets:i,initialWeight:o,finalWeight:a,repayTarget:l,feeCollector:c}=t,u=M.calculateLinearWeights(r.toString(),n.toString(),o.toString(),a.toString(),s),[g,d]=i,P=g.toString(),h=m(u),y=d.toString(),w=this.MAX_FINAL_WEIGHT.minus(m(h)),[f,O,A]=await Promise.all([this.isRepayFeeApplied(P,l.toString(),c.toString()),this.getBalance(e,P),this.getBalance(e,y)]);return{repayFeeApply:f,tokens:[{id:P,weight:h,balance:O.toString()},{id:y,weight:w,balance:A.toString()}]}}isActivePool(e,t){if(e.start.isEmpty||e.end.isEmpty)return!1;let s=e.start.unwrap().toNumber(),r=e.end.unwrap().toNumber();return t.toNumber()>=s&&t.toNumber()<r}async isRepayFeeApplied(e,t,s){let r=m(t);if(r.isZero())return!1;try{return(await this.getBalance(e,s)).isLessThan(r)}catch{return!0}}getRepayFee(){return this.api.consts.lbp.repayFee.toJSON()}getPoolLimits(){let e=this.api.consts.lbp.maxInRatio.toJSON(),t=this.api.consts.lbp.maxOutRatio.toJSON(),s=this.api.consts.lbp.minTradingLimit.toJSON();return{maxInRatio:e,maxOutRatio:t,minTradingLimit:s}}};import{calculate_in_given_out as vt,calculate_lrna_in_given_out as Nt,calculate_out_given_in as Ft,calculate_out_given_lrna_in as Rt,calculate_pool_trade_fee as Et,calculate_spot_price as kt,calculate_lrna_spot_price as _t,calculate_shares as Dt,calculate_liquidity_out as Ct,calculate_liquidity_lrna_out as Lt,calculate_liquidity_hub_in as Mt,is_sell_allowed as Gt,is_buy_allowed as qt,is_add_liquidity_allowed as Ht,is_remove_liquidity_allowed as Ut,recalculate_asset_fee as Wt,recalculate_protocol_fee as Xt,verify_asset_cap as Yt}from"@galacticcouncil/math-omnipool";var B=class{static calculateSpotPrice(e,t,s,r){return kt(e,t,s,r)}static calculateLrnaSpotPrice(e,t){return _t(e,t)}static calculateInGivenOut(e,t,s,r,n,i,o,a,l){return vt(e,t,s,r,n,i,o,a,l)}static calculateLrnaInGivenOut(e,t,s,r,n){return Nt(e,t,s,r,n)}static calculateOutGivenIn(e,t,s,r,n,i,o,a,l){return Ft(e,t,s,r,n,i,o,a,l)}static calculateOutGivenLrnaIn(e,t,s,r,n){return Rt(e,t,s,r,n)}static calculatePoolTradeFee(e,t,s){return Et(e,t,s)}static calculateShares(e,t,s,r){return Dt(e,t,s,r)}static calculateLiquidityOut(e,t,s,r,n,i,o,a){return Ct(e,t,s,r,n,i,o,a)}static calculateLiquidityLRNAOut(e,t,s,r,n,i,o,a){return Lt(e,t,s,r,n,i,o,a)}static calculateCapDifference(e,t,s,r){let n=S(t),i=S(e),o=S(r),l=S(s).shiftedBy(-18);if(n.div(o).lt(l)){let u=l.times(o).minus(n).times(i),g=n.times(S(1).minus(l));return u.div(g).toFixed(0)}else return"0"}static calculateLimitHubIn(e,t,s,r){return Mt(e,t,s,r)}static isSellAllowed(e){return Gt(e)}static isBuyAllowed(e){return qt(e)}static isAddLiquidityAllowed(e){return Ht(e)}static isRemoveLiquidityAllowed(e){return Ut(e)}static recalculateAssetFee(e,t,s,r,n,i,o,a,l,c,u){return Wt(e,t,s,r,n,i,o,a,l,c,u)}static recalculateProtocolFee(e,t,s,r,n,i,o,a,l,c,u){return Xt(e,t,s,r,n,i,o,a,l,c,u)}static verifyAssetCap(e,t,s,r){return Yt(e,t,s,r)}};var he=class p{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;hubAssetId;static fromPool(e){return new p(e.address,e.tokens,e.maxInRatio,e.maxOutRatio,e.minTradingLimit,e.hubAssetId)}constructor(e,t,s,r,n,i){this.type="Omnipool",this.address=e,this.tokens=t,this.maxInRatio=s,this.maxOutRatio=r,this.minTradingLimit=n,this.hubAssetId=i}validatePair(e,t){return this.hubAssetId!=t}parsePair(e,t){let s=new Map(this.tokens.map(c=>[c.id,c])),r=s.get(e),n=s.get(t);if(r==null)throw new Error("Pool does not contain tokenIn");if(n==null)throw new Error("Pool does not contain tokenOut");let i=m(r.balance),o=m(n.balance),a=m(r.existentialDeposit),l=m(n.existentialDeposit);return{assetIn:e,assetOut:t,hubReservesIn:r.hubReserves,hubReservesOut:n.hubReserves,sharesIn:r.shares,sharesOut:n.shares,decimalsIn:r.decimals,decimalsOut:n.decimals,balanceIn:i,balanceOut:o,tradeableIn:r.tradeable,tradeableOut:n.tradeable,assetInED:a,assetOutED:l}}validateAndBuy(e,t,s){let r=this.calculateInGivenOut(e,t),n=this.calculateInGivenOut(e,t,s),i=n.minus(r),o=r===b?b:i.div(r).multipliedBy(100).decimalPlaces(2),a=[],l=B.isSellAllowed(e.tradeableIn),c=B.isBuyAllowed(e.tradeableOut);(!l||!c)&&a.push("TradeNotAllowed"),(t.isLessThan(this.minTradingLimit)||r.isLessThan(e.assetInED))&&a.push("InsufficientTradingAmount");let u=e.balanceOut.div(this.maxOutRatio);t.isGreaterThan(u)&&a.push("MaxOutRatioExceeded");let g=e.balanceIn.div(this.maxInRatio);return n.isGreaterThan(g)&&a.push("MaxInRatioExceeded"),{amountIn:n,calculatedIn:r,amountOut:t,feePct:o.toNumber(),errors:a}}validateAndSell(e,t,s){let r=this.calculateOutGivenIn(e,t),n=this.calculateOutGivenIn(e,t,s),o=r.minus(n).div(r).multipliedBy(100).decimalPlaces(2),a=[],l=B.isSellAllowed(e.tradeableIn),c=B.isBuyAllowed(e.tradeableOut);(!l||!c)&&a.push("TradeNotAllowed"),(t.isLessThan(this.minTradingLimit)||r.isLessThan(e.assetOutED))&&a.push("InsufficientTradingAmount");let u=e.balanceIn.div(this.maxInRatio);t.isGreaterThan(u)&&a.push("MaxInRatioExceeded");let g=e.balanceOut.div(this.maxOutRatio);return n.isGreaterThan(g)&&a.push("MaxOutRatioExceeded"),{amountIn:t,calculatedOut:r,amountOut:n,feePct:o.toNumber(),errors:a}}calculateInGivenOut(e,t,s){if(e.assetIn==this.hubAssetId)return this.calculateLrnaInGivenOut(e,t,s);let r=B.calculateInGivenOut(e.balanceIn.toString(),e.hubReservesIn.toString(),e.sharesIn.toString(),e.balanceOut.toString(),e.hubReservesOut.toString(),e.sharesOut.toString(),t.toFixed(0),s?T(s.assetFee).toString():b.toString(),s?T(s.protocolFee).toString():b.toString()),n=m(r);return n.isNegative()?b:n}calculateLrnaInGivenOut(e,t,s){let r=B.calculateLrnaInGivenOut(e.balanceOut.toString(),e.hubReservesOut.toString(),e.sharesOut.toString(),t.toFixed(0),s?T(s.assetFee).toString():b.toString()),n=m(r);return n.isNegative()?b:n}calculateOutGivenIn(e,t,s){if(e.assetIn==this.hubAssetId)return this.calculateOutGivenLrnaIn(e,t,s);let r=B.calculateOutGivenIn(e.balanceIn.toString(),e.hubReservesIn.toString(),e.sharesIn.toString(),e.balanceOut.toString(),e.hubReservesOut.toString(),e.sharesOut.toString(),t.toFixed(0),s?T(s.assetFee).toString():b.toString(),s?T(s.protocolFee).toString():b.toString()),n=m(r);return n.isNegative()?b:n}calculateOutGivenLrnaIn(e,t,s){let r=B.calculateOutGivenLrnaIn(e.balanceOut.toString(),e.hubReservesOut.toString(),e.sharesOut.toString(),t.toFixed(0),s?T(s.assetFee).toString():b.toString()),n=m(r);return n.isNegative()?b:n}spotPriceInGivenOut(e){if(e.assetIn==this.hubAssetId)return this.spotPriceLrnaInGivenOut(e);let t=B.calculateSpotPrice(e.balanceOut.toString(),e.hubReservesOut.toString(),e.balanceIn.toString(),e.hubReservesIn.toString());return m(t).shiftedBy(-1*(18-e.decimalsOut)).decimalPlaces(0,1)}spotPriceLrnaInGivenOut(e){let t=B.calculateLrnaSpotPrice(e.hubReservesOut.toString(),e.balanceOut.toString());return m(t).shiftedBy(-1*(18-e.decimalsOut)).decimalPlaces(0,1)}spotPriceOutGivenIn(e){if(e.assetIn==this.hubAssetId)return this.spotPriceOutGivenLrnaIn(e);let t=B.calculateSpotPrice(e.balanceIn.toString(),e.hubReservesIn.toString(),e.balanceOut.toString(),e.hubReservesOut.toString());return m(t).shiftedBy(-1*(18-e.decimalsIn)).decimalPlaces(0,1)}spotPriceOutGivenLrnaIn(e){let t=B.calculateLrnaSpotPrice(e.balanceOut.toString(),e.hubReservesOut.toString());return m(t).shiftedBy(-1*(18-e.decimalsIn)).decimalPlaces(0,1)}};import{encodeAddress as $t}from"@polkadot/util-crypto";import{stringToU8a as Vt}from"@polkadot/util";var be=class extends C{isSupported(){return this.api.query.omnipool!==void 0}async loadPools(){let e=this.api.consts.omnipool.hubAssetId.toString(),t=this.getPoolId(),[s,r,n]=await Promise.all([this.api.query.omnipool.assets.entries(),this.api.query.omnipool.hubAssetTradability(),this.getBalance(t,e)]),i=s.map(async([{args:[a]},l])=>{let{hubReserve:c,shares:u,tradable:g,cap:d,protocolShares:P}=l.unwrap(),h=await this.getBalance(t,a.toString());return{id:a.toString(),hubReserves:m(c.toString()),shares:m(u.toString()),tradeable:g.bits.toNumber(),balance:h.toString(),cap:m(d.toString()),protocolShares:m(P.toString())}}),o=await Promise.all(i);return o.push({id:e,tradeable:r.bits.toNumber(),balance:n.toString()}),[{address:t,type:"Omnipool",hubAssetId:e,tokens:o,...this.getPoolLimits()}]}async getPoolFees(e,t){let s=e.assetOut,r=e.assetIn,n="omnipool",i="Short",o=A=>A===_?[_,ce]:[ce,A],[a,l,c,u]=await Promise.all([this.api.query.system.number(),this.api.query.dynamicFees.assetFee(s),this.api.query.emaOracle.oracles(n,o(s),i),this.api.query.emaOracle.oracles(n,o(r),i)]),[g,d,P]=this.getAssetFee(e,a.toNumber(),l,c),[h,y,w]=r===ce?[0,0,0]:this.getProtocolFee(e,a.toNumber(),l,u),f=g+h,O=P+w;return{assetFee:E(d),protocolFee:E(y),min:E(f),max:E(O)}}getPoolType(){return"Omnipool"}async subscribePoolChange(e){let t=e.tokens.map(s=>s.id);return this.api.query.omnipool.assets.multi(t,s=>{e.tokens=s.map((r,n)=>{let i=e.tokens[n];if(r.isNone)return i;let o=r.unwrap();return this.updateTokenState(i,o)})})}updateTokenState(e,t){let{hubReserve:s,shares:r,tradable:n,cap:i,protocolShares:o}=t;return{...e,hubReserves:m(s.toString()),shares:m(r.toString()),cap:m(i.toString()),protocolShares:m(o.toString()),tradeable:n.bits.toNumber()}}getAssetFee(e,t,s,r){let{assetOut:n,balanceOut:i}=e,{minFee:o,maxFee:a,decay:l,amplification:c}=this.api.consts.dynamicFees.assetFeeParameters,u=E(o.toNumber()),g=E(a.toNumber());if(s.isNone||r.isNone)return[o.toNumber(),o.toNumber(),a.toNumber()];let[d]=r.unwrap(),{assetFee:P,timestamp:h}=s.unwrap(),y=t-h.toNumber(),w=d.volume.bIn.toString(),f=d.volume.bOut.toString(),O=d.liquidity.b.toString();n===_&&(w=d.volume.aIn.toString(),f=d.volume.aOut.toString(),O=d.liquidity.a.toString());let A=E(P.toNumber()),x=B.recalculateAssetFee(w,f,O,"9",i.toString(),T(A).toString(),y.toString(),T(u).toString(),T(g).toString(),l.toString(),c.toString());return[o.toNumber(),Number(x)*1e6,a.toNumber()]}getProtocolFee(e,t,s,r){let{assetIn:n,balanceIn:i}=e,{minFee:o,maxFee:a,decay:l,amplification:c}=this.api.consts.dynamicFees.protocolFeeParameters,u=E(o.toNumber()),g=E(a.toNumber());if(s.isNone||r.isNone)return[o.toNumber(),o.toNumber(),a.toNumber()];let[d]=r.unwrap(),{protocolFee:P,timestamp:h}=s.unwrap(),y=t-h.toNumber(),w=d.volume.bIn.toString(),f=d.volume.bOut.toString(),O=d.liquidity.b.toString();n===_&&(w=d.volume.aIn.toString(),f=d.volume.aOut.toString(),O=d.liquidity.a.toString());let A=E(P.toNumber()),x=B.recalculateProtocolFee(w,f,O,"9",i.toString(),T(A).toString(),y.toString(),T(u).toString(),T(g).toString(),l.toString(),c.toString());return[o.toNumber(),Number(x)*1e6,a.toNumber()]}getPoolId(){return $t(Vt("modlomnipool".padEnd(32,"\0")),63)}getPoolLimits(){let e=this.api.consts.omnipool.maxInRatio.toJSON(),t=this.api.consts.omnipool.maxOutRatio.toJSON(),s=this.api.consts.omnipool.minimumTradingLimit.toJSON();return{maxInRatio:e,maxOutRatio:t,minTradingLimit:s}}};import{calculate_in_given_out as zt,calculate_out_given_in as Jt,calculate_pool_trade_fee as Kt,get_spot_price as jt,calculate_liquidity_in as Zt,calculate_shares as Qt,calculate_spot_price as es,calculate_spot_price_with_fee as ts,calculate_liquidity_out_asset_a as ss,calculate_liquidity_out_asset_b as rs}from"@galacticcouncil/math-xyk";var W=class{static getSpotPrice(e,t,s){return jt(e,t,s)}static calculateInGivenOut(e,t,s){return zt(e,t,s)}static calculateOutGivenIn(e,t,s){return Jt(e,t,s)}static calculatePoolTradeFee(e,t,s){return Kt(e,t,s)}static calculateLiquidityIn(e,t,s){return Zt(e,t,s)}static calculateSpotPrice(e,t){return es(e,t)}static calculateSpotPriceWithFee(e,t,s,r){return ts(e,t,s,r)}static calculateShares(e,t,s){return Qt(e,t,s)}static calculateLiquidityOutAssetA(e,t,s,r){return ss(e,t,s,r)}static calculateLiquidityOutAssetB(e,t,s,r){return rs(e,t,s,r)}};var ye=class p{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;static fromPool(e){return new p(e.address,e.tokens,e.maxInRatio,e.maxOutRatio,e.minTradingLimit)}constructor(e,t,s,r,n){this.type="Xyk",this.address=e,this.tokens=t,this.maxInRatio=s,this.maxOutRatio=r,this.minTradingLimit=n}validatePair(e,t){return!0}parsePair(e,t){let s=new Map(this.tokens.map(c=>[c.id,c])),r=s.get(e),n=s.get(t);if(r==null)throw new Error("Pool does not contain tokenIn");if(n==null)throw new Error("Pool does not contain tokenOut");let i=m(r.balance),o=m(n.balance),a=m(r.existentialDeposit),l=m(n.existentialDeposit);return{assetIn:e,assetOut:t,decimalsIn:r.decimals,decimalsOut:n.decimals,balanceIn:i,balanceOut:o,assetInED:a,assetOutED:l}}validateAndBuy(e,t,s){let r=this.calculateInGivenOut(e,t),n=this.calculateTradeFee(r,s),i=L(s.exchangeFee),o=r.plus(n),a=[];(t.isLessThan(this.minTradingLimit)||r.isLessThan(e.assetInED))&&a.push("InsufficientTradingAmount");let l=e.balanceOut.div(this.maxOutRatio);t.isGreaterThan(l)&&a.push("MaxOutRatioExceeded");let c=e.balanceIn.div(this.maxInRatio);return o.isGreaterThan(c)&&a.push("MaxInRatioExceeded"),{amountIn:o,calculatedIn:r,amountOut:t,feePct:i,errors:a}}validateAndSell(e,t,s){let r=this.calculateOutGivenIn(e,t),n=this.calculateTradeFee(r,s),i=L(s.exchangeFee),o=r.minus(n),a=[];(t.isLessThan(this.minTradingLimit)||r.isLessThan(e.assetOutED))&&a.push("InsufficientTradingAmount");let l=e.balanceIn.div(this.maxInRatio);t.isGreaterThan(l)&&a.push("MaxInRatioExceeded");let c=e.balanceOut.div(this.maxOutRatio);return o.isGreaterThan(c)&&a.push("MaxOutRatioExceeded"),{amountIn:t,calculatedOut:r,amountOut:o,feePct:i,errors:a}}calculateInGivenOut(e,t){let s=W.calculateInGivenOut(e.balanceIn.toString(),e.balanceOut.toString(),t.toFixed(0)),r=m(s);return r.isNegative()?b:r}calculateOutGivenIn(e,t){let s=W.calculateOutGivenIn(e.balanceIn.toString(),e.balanceOut.toString(),t.toFixed(0)),r=m(s);return r.isNegative()?b:r}spotPriceInGivenOut(e){let t=W.calculateSpotPrice(e.balanceOut.toString(),e.balanceIn.toString()),s=I(v,18-e.decimalsOut);return m(t).div(s)}spotPriceOutGivenIn(e){let t=W.calculateSpotPrice(e.balanceIn.toString(),e.balanceOut.toString()),s=I(v,18-e.decimalsIn);return m(t).div(s)}calculateTradeFee(e,t){let s=W.calculatePoolTradeFee(e.toString(),t.exchangeFee[0],t.exchangeFee[1]);return m(s)}};var fe=class extends C{isSupported(){return this.api.query.xyk!==void 0}async loadPools(){let t=(await this.api.query.xyk.poolAssets.entries()).map(async([{args:[s]},r])=>{let n=s.toString(),[i,o]=r.unwrap(),[a,l]=await Promise.all([this.getBalance(n,i.toString()),this.getBalance(n,o.toString())]);return{address:n,type:"Xyk",tokens:[{id:i.toString(),balance:a.toString()},{id:o.toString(),balance:l.toString()}],...this.getPoolLimits()}});return Promise.all(t)}async getPoolFees(e,t){return{exchangeFee:this.getExchangeFee()}}getPoolType(){return"Xyk"}subscribePoolChange(e){throw new Error("Pool change subscription not supported!")}getExchangeFee(){return this.api.consts.xyk.getExchangeFee.toJSON()}getPoolLimits(){let e=this.api.consts.xyk.maxInRatio.toJSON(),t=this.api.consts.xyk.maxOutRatio.toJSON(),s=this.api.consts.xyk.minTradingLimit.toJSON();return{maxInRatio:e,maxOutRatio:t,minTradingLimit:s}}};import{calculate_in_given_out as ns,calculate_out_given_in as os,calculate_amplification as is,calculate_add_one_asset as as,calculate_liquidity_out_one_asset as ls,calculate_pool_trade_fee as cs,calculate_shares as us,calculate_shares_for_amount as ms,calculate_spot_price_with_fee as ps,pool_account_name as ds,recalculate_peg as gs}from"@galacticcouncil/math-stableswap";var F=class{static getPoolAddress(e){return ds(e)}static defaultPegs(e){let t=[];for(let s=0;s<e;s++)t.push(["1","1"]);return t}static calculateAmplification(e,t,s,r,n){return is(e,t,s,r,n)}static calculateInGivenOut(e,t,s,r,n,i,o){return ns(e,t,s,r,n,i,o)}static calculateAddOneAsset(e,t,s,r,n,i,o){return as(e,t,s,r,n,i,o)}static calculateSharesForAmount(e,t,s,r,n,i,o){return ms(e,t,s,r,n,i,o)}static calculateOutGivenIn(e,t,s,r,n,i,o){return os(e,t,s,r,n,i,o)}static calculateLiquidityOutOneAsset(e,t,s,r,n,i,o){return ls(e,t,s,r,n,i,o)}static calculateShares(e,t,s,r,n,i){return us(e,t,s,r,n,i)}static calculateSpotPriceWithFee(e,t,s,r,n,i,o,a){return ps(e,t,s,r,n,i,o,a)}static calculatePoolTradeFee(e,t,s){return cs(e,t,s)}static recalculatePegs(e,t,s,r,n){let i=gs(e,t,s,r,n);return JSON.parse(i)}};var Se=class p{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;amplification;id;fee;totalIssuance;pegs;pegsFee;static fromPool(e){return new p(e.address,e.tokens,e.maxInRatio,e.maxOutRatio,e.minTradingLimit,e.amplification,e.id,e.fee,e.totalIssuance,e.pegs,e.pegsFee)}constructor(e,t,s,r,n,i,o,a,l,c,u){this.type="Stableswap",this.address=e,this.tokens=t,this.maxInRatio=s,this.maxOutRatio=r,this.minTradingLimit=n,this.amplification=i,this.id=o,this.fee=a,this.totalIssuance=l,this.pegs=c,this.pegsFee=u}validatePair(e,t){return!0}parsePair(e,t){let s=new Map(this.tokens.map(c=>[c.id,c])),r=s.get(e),n=s.get(t);if(r==null)throw new Error("Pool does not contain tokenIn");if(n==null)throw new Error("Pool does not contain tokenOut");let i=m(r.balance),o=m(n.balance),a=m(r.existentialDeposit),l=m(n.existentialDeposit);return{assetIn:e,assetOut:t,balanceIn:i,balanceOut:o,decimalsIn:r.decimals,decimalsOut:n.decimals,tradeableIn:this.id===e?15:r.tradeable,tradeableOut:this.id===t?15:n.tradeable,assetInED:a,assetOutED:l}}validateAndBuy(e,t,s){let r=this.calculateInGivenOut(e,t),n=this.calculateInGivenOut(e,t,s),i=L(s.fee),o=[],a=B.isSellAllowed(e.tradeableIn),l=B.isBuyAllowed(e.tradeableOut);return(!a||!l)&&o.push("TradeNotAllowed"),(t.isLessThan(this.minTradingLimit)||r.isLessThan(e.assetInED))&&o.push("InsufficientTradingAmount"),{amountIn:n,calculatedIn:r,amountOut:t,feePct:i,errors:o}}validateAndSell(e,t,s){let r=this.calculateOutGivenIn(e,t),n=this.calculateOutGivenIn(e,t,s),i=L(s.fee),o=[],a=B.isSellAllowed(e.tradeableIn),l=B.isBuyAllowed(e.tradeableOut);return(!a||!l)&&o.push("TradeNotAllowed"),(t.isLessThan(this.minTradingLimit)||r.isLessThan(e.assetOutED))&&o.push("InsufficientTradingAmount"),{amountIn:t,calculatedOut:r,amountOut:n,feePct:i,errors:o}}calculateIn(e,t,s){let r=F.calculateInGivenOut(this.getReserves(),Number(e.assetIn),Number(e.assetOut),t.toFixed(0),this.amplification,s?T(s.fee).toString():b.toString(),this.getPegs()),n=m(r);return n.isNegative()?b:n}calculateAddOneAsset(e,t,s){let r=F.calculateAddOneAsset(this.getReserves(),t.toFixed(0),Number(e.assetIn),this.amplification,this.totalIssuance,s?T(s.fee).toString():b.toString(),this.getPegs()),n=m(r);return n.isNegative()?b:n}calculateSharesForAmount(e,t,s){let r=F.calculateSharesForAmount(this.getReserves(),Number(e.assetOut),t.toFixed(0),this.amplification,this.totalIssuance,s?T(s.fee).toString():b.toString(),this.getPegs()),n=m(r);return n.isNegative()?b:n}calculateInGivenOut(e,t,s){return e.assetOut==this.id?this.calculateAddOneAsset(e,t,s):e.assetIn==this.id?this.calculateSharesForAmount(e,t,s):this.calculateIn(e,t,s)}spotPriceInGivenOut(e){let t=F.calculateSpotPriceWithFee(this.id,this.getReserves(),this.amplification,e.assetOut,e.assetIn,this.totalIssuance,"0",this.getPegs());if(e.assetOut==this.id)return m(t);if(e.assetIn==this.id){let r=I(v,e.decimalsIn-e.decimalsOut);return m(t).div(r)}let s=I(v,18-e.decimalsIn);return m(t).div(s)}calculateOut(e,t,s){let r=F.calculateOutGivenIn(this.getReserves(),Number(e.assetIn),Number(e.assetOut),t.toFixed(0),this.amplification,s?T(s.fee).toString():b.toString(),this.getPegs()),n=m(r);return n.isNegative()?b:n}calculateWithdrawOneAsset(e,t,s){let r=F.calculateLiquidityOutOneAsset(this.getReserves(),t.toFixed(0),Number(e.assetOut),this.amplification,this.totalIssuance,s?T(s.fee).toString():b.toString(),this.getPegs()),n=m(r);return n.isNegative()?b:n}calculateShares(e,t,s){let r=F.calculateShares(this.getReserves(),this.getAssets(e.assetIn,t),this.amplification,this.totalIssuance,s?T(s.fee).toString():b.toString(),this.getPegs()),n=m(r);return n.isNegative()?b:n}calculateOutGivenIn(e,t,s){return e.assetIn==this.id?this.calculateWithdrawOneAsset(e,t,s):e.assetOut==this.id?this.calculateShares(e,t,s):this.calculateOut(e,t,s)}spotPriceOutGivenIn(e){let t=F.calculateSpotPriceWithFee(this.id,this.getReserves(),this.amplification,e.assetIn,e.assetOut,this.totalIssuance,"0",this.getPegs());if(e.assetIn==this.id)return m(t);if(e.assetOut==this.id){let r=I(v,e.decimalsOut-e.decimalsIn);return m(t).div(r)}let s=I(v,18-e.decimalsOut);return m(t).div(s)}calculateTradeFee(e,t){let s=F.calculatePoolTradeFee(e.toString(),t.fee[0],t.fee[1]);return m(s)}getPegs(){return JSON.stringify(this.pegs)}getReserves(){let e=this.tokens.filter(t=>t.id!=this.id).map(({id:t,balance:s,decimals:r})=>({asset_id:Number(t),amount:s,decimals:r}));return JSON.stringify(e)}getAssets(e,t){let s={asset_id:Number(e),amount:t.toFixed(0)};return JSON.stringify([s])}};import{blake2AsHex as Ps,encodeAddress as hs}from"@polkadot/util-crypto";var bs=340282366920938463463374607431768211455n,we=class extends C{stablePools=new Map([]);isSupported(){return this.api.query.stableswap!==void 0}isPegSupported(){return this.api.query.stableswap.poolPegs!==void 0}async loadPools(){let[e,t]=await Promise.all([this.api.query.stableswap.pools.entries(),this.api.query.system.number()]),s=t.toNumber(),r=e.map(async([{args:[n]},i])=>{let o=i.unwrap(),a=n.toString(),l=this.getPoolAddress(a),[c,u,g]=await Promise.all([this.getPoolDelta(a,o,s.toString()),this.getPoolTokens(l,a,o),this.getPoolPegs(a,o,s.toString())]);return this.stablePools.set(l,o),{address:l,id:a,type:"Stableswap",fee:E(o.fee.toNumber()),tokens:u,...c,...g,...this.getPoolLimits()}});return Promise.all(r)}async getPoolFees(e,t){return{fee:this.pools.find(r=>r.address===t).pegsFee}}getPoolType(){return"Stableswap"}async subscribePoolChange(e){return this.api.query.system.number(async t=>{let s=t.toString(),r=this.stablePools.get(e.address);if(r){let[n,i]=await Promise.all([this.getPoolDelta(e.id,r,s),this.getPoolPegs(e.id,r,s)]);Object.assign(e,n,i)}})}async getPoolDelta(e,t,s){let{initialAmplification:r,finalAmplification:n,initialBlock:i,finalBlock:o}=t,a=F.calculateAmplification(r.toString(),n.toString(),i.toString(),o.toString(),s),l=await this.api.query.tokens.totalIssuance(e);return{amplification:a,totalIssuance:l.toString()}}async getPoolTokens(e,t,s){let{assets:r}=s,n=r.map(async o=>{let[a,l]=await Promise.all([this.api.query.stableswap.assetTradability(t,o.toString()),this.getBalance(e,o.toString())]);return{id:o.toString(),tradeable:a.bits.toNumber(),balance:l.toString()}}),i=await Promise.all(n);return i.push({id:t,tradeable:15,balance:bs.toString()}),i}getPoolDefaultPegs(e){let t=e.fee,s=F.defaultPegs(e.assets.length);return{pegsFee:E(t.toNumber()),pegs:s}}async getPoolPegs(e,t,s){if(!this.isPegSupported())return this.getPoolDefaultPegs(t);let r=await this.api.query.stableswap.poolPegs(e);if(r.isNone)return this.getPoolDefaultPegs(t);let n=r.unwrap(),i=await this.getLatestPegs(t,n,s),o=this.getRecentPegs(n),a=n.maxPegUpdate.toHuman(),l=t.fee.toHuman(),[c,u]=F.recalculatePegs(JSON.stringify(o),JSON.stringify(i),s,a.replace(/%/g,""),l.replace(/%/g,"")),g=Number(c)*1e4;return{pegsFee:E(g),pegs:u}}getRecentPegs(e){let{current:t}=e;return Array.from(t.entries()).map(([s,r])=>r.map(n=>n.toString()))}async getLatestPegs(e,t,s){let{source:r}=t,n=Array.from(e.assets.entries()).map(([o,a])=>a.toString()),i=r.map(async(o,a)=>{if(o.isOracle){let[l,c,u]=o.asOracle,g=[u.toString(),n[a]].map(f=>Number(f)).sort((f,O)=>f-O),d=await this.api.query.emaOracle.oracles(l,g,c),[{price:P,updatedAt:h}]=d.unwrap(),y=P.n.toString(),w=P.d.toString();return u.toString()===g[0].toString()?[[y,w],h.toString()]:[[w,y],h.toString()]}else return[o.asValue.map(l=>l.toString()),s]});return Promise.all(i)}getPoolAddress(e){let t=Number(e),s=F.getPoolAddress(t);return hs(Ps(s),63)}getPoolLimits(){return{maxInRatio:0,maxOutRatio:0,minTradingLimit:this.api.consts.stableswap.minTradingLimit.toJSON()}}};var te=class extends D{api;assetClient;aaveClient;xykClient;omniClient;lbpClient;stableClient;clients=[];onChainAssets=[];memRegistry=ys(e=>(this.log(`Registry mem ${e} sync`),this.syncRegistry()));constructor(e){super(e),this.api=e,this.assetClient=new ee(this.api),this.aaveClient=new de(this.api),this.xykClient=new fe(this.api),this.omniClient=new be(this.api),this.lbpClient=new Pe(this.api),this.stableClient=new we(this.api),this.clients=[this.aaveClient,this.xykClient,this.omniClient,this.lbpClient,this.stableClient]}get assets(){return this.onChainAssets}get isRegistrySynced(){return this.onChainAssets.length>0}async syncRegistry(e){let t=await this.assetClient.getOnChainAssets(!1,e);this.clients.forEach(s=>s.withAssets(t)),this.onChainAssets=t}async getPools(e){return this.isRegistrySynced||await this.memRegistry(1),e.length==0?(await Promise.all(this.clients.filter(r=>r.isSupported()).map(r=>r.getPoolsMem()))).flat():(await Promise.all(this.clients.filter(s=>e.some(r=>r===s.getPoolType())).map(s=>s.getPoolsMem()))).flat()}destroy(){this.aaveClient.unsubscribe(),this.xykClient.unsubscribe(),this.omniClient.unsubscribe(),this.lbpClient.unsubscribe(),this.stableClient.unsubscribe()}async getPoolFees(e,t){switch(t.type){case"Aave":return this.aaveClient.getPoolFees(e,t.address);case"Xyk":return this.xykClient.getPoolFees(e,t.address);case"Omnipool":return this.omniClient.getPoolFees(e,t.address);case"Lbp":return this.lbpClient.getPoolFees(e,t.address);case"Stableswap":return this.stableClient.getPoolFees(e,t.address);default:throw new me(t.type)}}};var Fe=class extends te{feeCache;disconnectSubscribeNewHeads=null;constructor(e){super(e),this.feeCache=new fs(null),this.api.rpc.chain.subscribeNewHeads(async t=>{this.feeCache.release()}).then(t=>{this.disconnectSubscribeNewHeads=t})}async getPoolFees(e,t){let s=[t.address,e.assetIn,e.assetOut].join("-");if(this.feeCache.has(s))return this.feeCache.get(s);{let n=await super.getPoolFees(e,t);return this.feeCache.set(s,n),n}}async destroy(){this.log(`Destroying pool cache!
|
|
2
|
+
Items: [${this.feeCache.length}]`),this.feeCache.release(),this.disconnectSubscribeNewHeads?.()}};var se=class{static get(e){switch(e.type){case"Aave":return pe.fromPool(e);case"Xyk":return ye.fromPool(e);case"Omnipool":return he.fromPool(e);case"Lbp":return ge.fromPool(e);case"Stableswap":return Se.fromPool(e);default:throw new Error("Pool type "+e.type+" is not supported yet")}}};var xe=class{constructor(e=1/0){this.capacity=e}storage=[];enqueue(e){if(this.size()===this.capacity)throw Error("Queue has reached max capacity, you cannot add more items");this.storage.push(e)}dequeue(){return this.storage.shift()}size(){return this.storage.length}};var Ss=5,re=class{isNotVisited(e,t){let s=!0;return t.forEach(r=>{(r[0]===e[0]||r[1]===e[1])&&(s=!1)}),s}findPaths(e,t,s){let r=[],n=new xe,i=[];for(i.push([t,""]),n.enqueue(i);n.size()>0;){let o=n.dequeue();if(o==null||o.length>Ss)return r;let a=o[o.length-1];(s===null||a[0]===s)&&r.push(o),e.get(a[0])?.forEach(c=>{if(this.isNotVisited(c,o)){let u=[...o];u.push(c),n.enqueue(u)}})}return r}buildAndPopulateGraph(e,t){let s=new Map;for(let r of e)s.set(parseInt(r),[]);for(let[r,n,i]of t){let o=parseInt(n),a=parseInt(i);s.get(o)?.push([a,r])}return s}};function Re(p){let e={};for(let t of p){let s=t.tokens.length;for(let r=0;r<s;r++){e[t.tokens[r].id]||(e[t.tokens[r].id]=[]);for(let n=0;n<s;n++){if(r==n)continue;let i=[t.address,t.tokens[r].id,t.tokens[n].id];e[t.tokens[r].id].push(i)}}}return e}var ne=class{getProposals(e,t,s){let r=Re(s),n=Object.keys(r),i=n.map(c=>r[c]).flat(),o=new re,a=o.buildAndPopulateGraph(n,i),l=o.findPaths(a,parseInt(e),t?parseInt(t):null);return this.parsePaths(l)}parsePaths(e){let t=[];for(let s of e){let r=[];for(let n=0;n<s.length;n++){let i=s[n],o=s[n+1];if(o==null)break;r.push(this.toEdge(i,o))}t.push(r)}return t}toEdge(e,t){return[t[1],e[0].toString(),t[0].toString()]}};var oe=class{routeSuggester;routerOptions;poolService;defaultRouterOptions={includeOnly:[]};constructor(e,t){this.poolService=e,this.routeSuggester=new ne,this.routerOptions={...this.defaultRouterOptions,...t}}async getPools(){let e=this.routerOptions.includeOnly;return await this.poolService.getPools(e)}async getAllAssets(){let e=await this.getPools();if(e.length===0)throw new Error("No pools configured");let t=await this.getAssets(e);return[...new Map(t).values()]}async getAssetPairs(e){let t=await this.getPools();if(t.length===0)throw new Error("No pools configured");let{assets:s,poolsMap:r}=await this.validateToken(e,t),i=this.getPaths(e,null,r,t).map(o=>o[o.length-1].assetOut);return this.toAssets([...new Set(i)],s)}async getAllPaths(e,t){let s=await this.getPools();if(s.length===0)throw new Error("No pools configured");let{poolsMap:r}=await this.validateTokenPair(e,t,s);return this.getPaths(e,t,r,s)}async getAssets(e){let t=e.map(s=>s.tokens.map(r=>({id:r.id,name:r.name,symbol:r.symbol,decimals:r.decimals,icon:r.icon,type:r.type,isSufficient:r.isSufficient,existentialDeposit:r.existentialDeposit,meta:r.meta,location:r.location,isWhiteListed:r.isWhiteListed}))).flat();return new Map(t.map(s=>[s.id,s]))}getPaths(e,t,s,r){return this.routeSuggester.getProposals(e,t,r).filter(o=>this.validPath(o,s)).map(o=>this.toHops(o,s))}async validateTokenPair(e,t,s){let r=await this.getAssets(s);if(r.get(e)==null)throw new Error(e+" is not supported token");if(r.get(t)==null)throw new Error(t+" is not supported token");let n=this.getPoolMap(s);return{assets:r,poolsMap:n}}async validateToken(e,t){let s=await this.getAssets(t);if(s.get(e)==null)throw new Error(e+" is not supported token");let r=this.getPoolMap(t);return{assets:s,poolsMap:r}}getPoolMap(e){return new Map(e.map(t=>[t.address,se.get(t)]))}validPath(e,t){return e.length>0&&e.map(s=>this.validEdge(s,t)).reduce((s,r)=>s&&r)}validEdge([e,t,s],r){return r.get(e)?.validatePair(t,s)||!1}toHops(e,t){return e.map(([s,r,n])=>{let i=t.get(s);return{poolAddress:s,poolId:i?.id,pool:i?.type,assetIn:r,assetOut:n}})}toAssets(e,t){return e.map(s=>t.get(s))}};var ws=m("100");function hl(p,e){return p.minus(e).abs().div(p.plus(e).div(2)).multipliedBy(100).decimalPlaces(2)}function ie(p,e){return p.minus(e).div(e).multipliedBy(100).decimalPlaces(2)}function Ze(p,e){return v.minus(e.div(p)).multipliedBy(100).decimalPlaces(2)}function Qe(p,e){return e.div(p).minus(v).multipliedBy(100).decimalPlaces(2)}function ae(p,e){return(e<.01||e>100)&&new Error("Supported range is from 0.01% - 100%"),p.div(ws).multipliedBy(e).decimalPlaces(0,1)}var Ee=(t=>(t.Buy="Buy",t.Sell="Sell",t))(Ee||{});var ke=class extends oe{isDirectTrade(e){return e.length==1}findBestSellRoute(e){let t=e.sort((s,r)=>{let n=s[s.length-1].amountOut,i=r[r.length-1].amountOut;return n.isGreaterThan(i)?-1:1});return t.find(s=>s.every(r=>r.errors.length==0))||t[0]}getRouteFeeRange(e){if(e.filter(s=>s.tradeFeeRange).length>0){let s=e.map(n=>n.tradeFeeRange?.[0]??n.tradeFeePct).reduce((n,i)=>n+i),r=e.map(n=>n.tradeFeeRange?.[1]??n.tradeFeePct).reduce((n,i)=>n+i);return[s,r]}}getPoolFeeRange(e){let t=e.min?L(e.min):void 0,s=e.max?L(e.max):void 0;if(t&&s)return[t,s]}async getBestSell(e,t,s){return this.getSell(e,t,s)}async getSell(e,t,s,r){let n=await super.getPools();if(n.length===0)throw new Error("No pools configured");let{poolsMap:i}=await super.validateTokenPair(e,t,n),o=super.getPaths(e,t,i,n);if(o.length===0)throw new J(e,t);let a;if(r)a=await this.toSellSwaps(s,r,i);else{let x=o.map(async G=>await this.toSellSwaps(s,G,i)),k=await Promise.all(x);a=this.findBestSellRoute(k)}let l=a[0],c=a[a.length-1],u=this.isDirectTrade(a),g=a.map(x=>x.spotPrice.shiftedBy(-1*x.assetOutDecimals)).reduce((x,k)=>x.multipliedBy(k)),d=I(g,c.assetOutDecimals),P=u?c.calculatedOut:this.calculateDelta0Y(l.amountIn,a,i),h=c.amountOut,y=u?c.tradeFeePct:Ze(P,h).toNumber(),w=P.minus(h),f=this.getRouteFeeRange(a),O=l.amountIn.shiftedBy(-1*l.assetInDecimals).multipliedBy(d),A=ie(P,O);return{type:"Sell",amountIn:l.amountIn,amountOut:c.amountOut,spotPrice:d,tradeFee:w,tradeFeePct:y,tradeFeeRange:f,priceImpactPct:A.toNumber(),swaps:a,toHuman(){return{type:"Sell",amountIn:N(l.amountIn,l.assetInDecimals),amountOut:N(c.amountOut,c.assetOutDecimals),spotPrice:N(d,c.assetOutDecimals),tradeFee:N(w,c.assetOutDecimals),tradeFeePct:y,tradeFeeRange:f,priceImpactPct:A.toNumber(),swaps:a.map(x=>x.toHuman())}}}}calculateDelta0Y(e,t,s){let r=[];for(let n=0;n<t.length;n++){let i=t[n],o=s.get(i.poolAddress);if(o==null)throw new Error("Pool does not exit");let a=o.parsePair(i.assetIn,i.assetOut),l;n>0?l=r[n-1]:l=e;let c=o.calculateOutGivenIn(a,l);r.push(c)}return r[r.length-1]}async toSellSwaps(e,t,s){let r=[];for(let n=0;n<t.length;n++){let i=t[n],o=s.get(i.poolAddress);if(o==null)throw new Error("Pool does not exit");let a=o.parsePair(i.assetIn,i.assetOut),l;n>0?l=r[n-1].amountOut:l=I(m(e),a.decimalsIn).decimalPlaces(0,1);let c=await this.poolService.getPoolFees(a,o),{amountOut:u,calculatedOut:g,feePct:d,errors:P}=o.validateAndSell(a,l,c),h=this.getPoolFeeRange(c),y=o.spotPriceOutGivenIn(a),w=l.shiftedBy(-1*a.decimalsIn).multipliedBy(y),f=ie(g,w);r.push({...i,assetInDecimals:a.decimalsIn,assetOutDecimals:a.decimalsOut,amountIn:l,calculatedOut:g,amountOut:u,spotPrice:y,tradeFeePct:d,tradeFeeRange:h,priceImpactPct:f.toNumber(),errors:P,isSupply(){return o.type==="Aave"&&o.tokens[0].id===i.assetIn},isWithdraw(){return o.type==="Aave"&&o.tokens[1].id===i.assetIn},toHuman(){return{...i,amountIn:N(l,a.decimalsIn),calculatedOut:N(g,a.decimalsOut),amountOut:N(u,a.decimalsOut),spotPrice:N(y,a.decimalsOut),tradeFeePct:d,tradeFeeRange:h,priceImpactPct:f.toNumber(),errors:P}}})}return r}async getMostLiquidRoute(e,t){let s=await super.getPools(),{poolsMap:r}=await super.validateTokenPair(e,t,s),n=super.getPaths(e,t,r,s);if(n.length===0)throw new J(e,t);let l=s.filter(d=>d.tokens.some(P=>P.id===e&&P.id!==d.id)).map(d=>d.type==="Aave"?d.tokens:d.tokens.filter(P=>P.id===e)).map(d=>d.map(P=>m(P.balance).shiftedBy(-1*P.decimals)).reduce((P,h)=>P.plus(h))).sort((d,P)=>P.isLessThan(d)?-1:1)[0].div(100).multipliedBy(.1),c=n.map(async d=>await this.toSellSwaps(l,d,r)),u=await Promise.all(c);return this.findBestSellRoute(u).map(d=>({poolAddress:d.poolAddress,poolId:d?.poolId,pool:d.pool,assetIn:d.assetIn,assetOut:d.assetOut}))}async getBestSpotPrice(e,t){let s=await super.getPools();if(s.length===0)throw new Error("No pools configured");let{poolsMap:r}=await super.validateTokenPair(e,t,s);if(super.getPaths(e,t,r,s).length===0)return Promise.resolve(void 0);let i=await this.getMostLiquidRoute(e,t),o=await this.toSellSwaps("1",i,r),a=o.map(u=>u.spotPrice.shiftedBy(-1*u.assetOutDecimals)).reduce((u,g)=>u.multipliedBy(g)),l=o[o.length-1].assetOutDecimals;return{amount:I(a,l),decimals:l}}findBestBuyRoute(e){let t=e.sort((s,r)=>{let n=s[0].amountIn,i=r[0].amountIn;return n.isGreaterThan(i)?1:-1});return t.find(s=>s.every(r=>r.errors.length==0))||t[0]}async getBestBuy(e,t,s){return this.getBuy(e,t,s)}async getBuy(e,t,s,r){let n=await super.getPools();if(n.length===0)throw new Error("No pools configured");let{poolsMap:i}=await super.validateTokenPair(e,t,n),o=super.getPaths(e,t,i,n);if(o.length===0)throw new J(e,t);let a;if(r)a=await this.toBuySwaps(s,r,i);else{let x=o.map(async G=>await this.toBuySwaps(s,G,i)),k=await Promise.all(x);a=this.findBestBuyRoute(k)}let l=a[a.length-1],c=a[0],u=this.isDirectTrade(a),g=a.map(x=>x.spotPrice.shiftedBy(-1*x.assetInDecimals)).reduce((x,k)=>x.multipliedBy(k)),d=I(g,c.assetInDecimals),P=u?c.calculatedIn:this.calculateDelta0X(l.amountOut,a,i),h=c.amountIn,y=u?c.tradeFeePct:Qe(P,h).toNumber(),w=h.minus(P),f=this.getRouteFeeRange(a),O=l.amountOut.shiftedBy(-1*l.assetOutDecimals).multipliedBy(d),A;return P.isZero()?A=-100:A=ie(O,P).toNumber(),{type:"Buy",amountOut:l.amountOut,amountIn:c.amountIn,spotPrice:d,tradeFee:w,tradeFeePct:y,tradeFeeRange:f,priceImpactPct:A,swaps:a,toHuman(){return{type:"Buy",amountOut:N(l.amountOut,l.assetOutDecimals),amountIn:N(c.amountIn,c.assetInDecimals),spotPrice:N(d,c.assetInDecimals),tradeFee:N(w,c.assetInDecimals),tradeFeePct:y,tradeFeeRange:f,priceImpactPct:A,swaps:a.map(x=>x.toHuman())}}}}calculateDelta0X(e,t,s){let r=[];for(let n=t.length-1;n>=0;n--){let i=t[n],o=s.get(i.poolAddress);if(o==null)throw new Error("Pool does not exit");let a=o.parsePair(i.assetIn,i.assetOut),l;n==t.length-1?l=e:l=r[0];let c=o.calculateInGivenOut(a,l);r.unshift(c)}return r[0]}async toBuySwaps(e,t,s){let r=[];for(let n=t.length-1;n>=0;n--){let i=t[n],o=s.get(i.poolAddress);if(o==null)throw new Error("Pool does not exit");let a=o.parsePair(i.assetIn,i.assetOut),l;n==t.length-1?l=I(m(e),a.decimalsOut).decimalPlaces(0,1):l=r[0].amountIn;let c=await this.poolService.getPoolFees(a,o),{amountIn:u,calculatedIn:g,feePct:d,errors:P}=o.validateAndBuy(a,l,c),h=this.getPoolFeeRange(c),y=o.spotPriceInGivenOut(a),w=l.shiftedBy(-1*a.decimalsOut).multipliedBy(y),f;g.isZero()?f=-100:f=ie(w,g).toNumber(),r.unshift({...i,assetInDecimals:a.decimalsIn,assetOutDecimals:a.decimalsOut,amountOut:l,calculatedIn:g,amountIn:u,spotPrice:y,tradeFeePct:d,tradeFeeRange:h,priceImpactPct:f,errors:P,isSupply(){return o.type==="Aave"&&o.tokens[0].id===i.assetIn},isWithdraw(){return o.type==="Aave"&&o.tokens[1].id===i.assetIn},toHuman(){return{...i,amountOut:N(l,a.decimalsOut),calculatedIn:N(g,a.decimalsIn),amountIn:N(u,a.decimalsIn),spotPrice:N(y,a.decimalsIn),tradeFeePct:d,tradeFeeRange:h,priceImpactPct:f,errors:P}}})}return r}};import{encodeFunctionData as xs}from"viem";var _e=class extends D{balanceClient;evmClient;constructor(e){super(e),this.balanceClient=new q(e),this.evmClient=new V}buildBuyTx(e,t=1){if(e.type!=="Buy")throw new Error("Not permitted");let{amountIn:s,amountOut:r,swaps:n}=e,i=n[0],o=n[n.length-1],a=ae(s,t),l=i.assetIn,c=o.assetOut,u=s.plus(a),g;return this.isDirectOmnipoolTrade(n)?g=this.api.tx.omnipool.buy(c,l,r.toFixed(),u.toFixed()):g=this.api.tx.router.buy(l,c,r.toFixed(),u.toFixed(),this.buildRoute(n)),{hex:g.toHex(),name:"RouterBuy",get:()=>g,dryRun:d=>this.dryRun(d,g)}}buildSellTx(e,t=1){if(e.type!=="Sell")throw new Error("Not permitted");let{amountIn:s,amountOut:r,swaps:n}=e,i=n[0],o=n[n.length-1],a=ae(r,t),l=i.assetIn,c=o.assetOut,u=r.minus(a),g;return this.isDirectOmnipoolTrade(n)?g=this.api.tx.omnipool.sell(l,c,s.toFixed(),u.toFixed()):g=this.api.tx.router.sell(l,c,s.toFixed(),u.toFixed(),this.buildRoute(n)),{hex:g.toHex(),name:"RouterSell",get:()=>g,dryRun:d=>this.dryRun(d,g)}}buildSellAllTx(e,t=1){if(e.type!=="Sell")throw new Error("Not permitted");let{amountOut:s,swaps:r}=e,n=r[0],i=r[r.length-1],o=ae(s,t),a=n.assetIn,l=i.assetOut,c=s.minus(o),u=this.api.tx.router.sellAll(a,l,c.toFixed(),this.buildRoute(r));return{hex:u.toHex(),name:"RouterSellAll",get:()=>u,dryRun:g=>this.dryRun(g,u)}}async buildWithdrawAndSellReserveTx(e,t,s=1){let{amountIn:r,amountOut:n,swaps:i}=t,o=i[0],a=i[i.length-1];if(!o.isWithdraw())throw new Error("Not permitted");let l=o.assetIn,c=o.assetOut,[u,g]=await Promise.all([this.evmClient.getProvider().getGasPrice(),this.balanceClient.getBalance(e,l)]),d=r.isGreaterThanOrEqualTo(g.minus(5)),P=u*10n/100n,h=z.fromAny(e),y=d?Ce:BigInt(r.toFixed()),w=U.fromAssetId(c),f=xs({abi:$,functionName:"withdraw",args:[w,y,h]}),O=this.api.tx.evm.call(h,le,f,0n,De,u+P,u+P,null,[]),A=ae(n,s),x=c,k=a.assetOut,G=n.minus(A),Y=this.api.tx.router.sell(x,k,r.minus(5).toFixed(),G.toFixed(),this.buildRoute(i.slice(1))),Be=this.api.tx.utility.batchAll([O,Y]);return{hex:Be.toHex(),name:"WithdrawAndRouterReserveSell",get:()=>Be,dryRun:tt=>this.dryRun(tt,Be)}}buildRoute(e){return e.map(({assetIn:t,assetOut:s,pool:r,poolId:n})=>r==="Stableswap"?{pool:{Stableswap:n},assetIn:t,assetOut:s}:{pool:r,assetIn:t,assetOut:s})}isDirectOmnipoolTrade(e){return e.length===1&&e[0].pool==="Omnipool"}};export{bs as AMOUNT_MAX,j as AaveClient,pe as AavePool,de as AavePoolClient,ve as AaveUtils,ee as AssetClient,Ve as AssetNotFound,Ys as BASILISK_PARACHAIN_ID,q as BalanceClient,S as BigNumber,Fe as CachingPoolService,dt as DECIMAL_PLACES,Te as DENOMINATOR,U as ERC20,V as EvmClient,Ne as FarmClient,z as H160,ce as HUB_ASSET_ID,$s as HYDRADX_PARACHAIN_ID,H as HYDRADX_SS58_PREFIX,sr as INFINITY,M as LbpMath,ge as LbpPool,Pe as LbpPoolClient,v as ONE,B as OmniMath,he as OmniPool,be as OmniPoolClient,D as PolkadotApiClient,$e as PoolConfigNotFound,K as PoolError,se as PoolFactory,me as PoolNotFound,te as PoolService,R as PoolType,Ke as ProviderConfigNotFound,Z as RUNTIME_DECIMALS,J as RouteNotFound,oe as Router,Vs as SYSTEM_ASSET_DECIMALS,_ as SYSTEM_ASSET_ID,F as StableMath,Se as StableSwap,we as StableSwapClient,ze as StorageConfigNotFound,Je as SubscriptionNotSupported,Q as TRADEABLE_DEFAULT,ke as TradeRouter,Ee as TradeType,_e as TradeUtils,W as XykMath,ye as XykPool,fe as XykPoolClient,b as ZERO,sn as bnFormatter,m as bnum,Qe as calculateBuyFee,hl as calculateDiffToAvg,ie as calculateDiffToRef,Ze as calculateSellFee,Ge as evmMainnet,je as findNestedKey,tn as findNestedObj,ae as getFraction,ut as isEvmAccount,mt as isEvmAddress,pt as isSs58Address,I as scale};
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
export declare class AaveClient {
|
|
2
|
+
private evmClient;
|
|
3
|
+
constructor();
|
|
4
|
+
getReservesData(): Promise<readonly [readonly {
|
|
5
|
+
underlyingAsset: `0x${string}`;
|
|
6
|
+
name: string;
|
|
7
|
+
symbol: string;
|
|
8
|
+
decimals: bigint;
|
|
9
|
+
baseLTVasCollateral: bigint;
|
|
10
|
+
reserveLiquidationThreshold: bigint;
|
|
11
|
+
reserveLiquidationBonus: bigint;
|
|
12
|
+
reserveFactor: bigint;
|
|
13
|
+
usageAsCollateralEnabled: boolean;
|
|
14
|
+
borrowingEnabled: boolean;
|
|
15
|
+
stableBorrowRateEnabled: boolean;
|
|
16
|
+
isActive: boolean;
|
|
17
|
+
isFrozen: boolean;
|
|
18
|
+
liquidityIndex: bigint;
|
|
19
|
+
variableBorrowIndex: bigint;
|
|
20
|
+
liquidityRate: bigint;
|
|
21
|
+
variableBorrowRate: bigint;
|
|
22
|
+
stableBorrowRate: bigint;
|
|
23
|
+
lastUpdateTimestamp: number;
|
|
24
|
+
aTokenAddress: `0x${string}`;
|
|
25
|
+
stableDebtTokenAddress: `0x${string}`;
|
|
26
|
+
variableDebtTokenAddress: `0x${string}`;
|
|
27
|
+
interestRateStrategyAddress: `0x${string}`;
|
|
28
|
+
availableLiquidity: bigint;
|
|
29
|
+
totalPrincipalStableDebt: bigint;
|
|
30
|
+
averageStableRate: bigint;
|
|
31
|
+
stableDebtLastUpdateTimestamp: bigint;
|
|
32
|
+
totalScaledVariableDebt: bigint;
|
|
33
|
+
priceInMarketReferenceCurrency: bigint;
|
|
34
|
+
priceOracle: `0x${string}`;
|
|
35
|
+
variableRateSlope1: bigint;
|
|
36
|
+
variableRateSlope2: bigint;
|
|
37
|
+
stableRateSlope1: bigint;
|
|
38
|
+
stableRateSlope2: bigint;
|
|
39
|
+
baseStableBorrowRate: bigint;
|
|
40
|
+
baseVariableBorrowRate: bigint;
|
|
41
|
+
optimalUsageRatio: bigint;
|
|
42
|
+
isPaused: boolean;
|
|
43
|
+
isSiloedBorrowing: boolean;
|
|
44
|
+
accruedToTreasury: bigint;
|
|
45
|
+
unbacked: bigint;
|
|
46
|
+
isolationModeTotalDebt: bigint;
|
|
47
|
+
flashLoanEnabled: boolean;
|
|
48
|
+
debtCeiling: bigint;
|
|
49
|
+
debtCeilingDecimals: bigint;
|
|
50
|
+
eModeCategoryId: number;
|
|
51
|
+
borrowCap: bigint;
|
|
52
|
+
supplyCap: bigint;
|
|
53
|
+
eModeLtv: number;
|
|
54
|
+
eModeLiquidationThreshold: number;
|
|
55
|
+
eModeLiquidationBonus: number;
|
|
56
|
+
eModePriceSource: `0x${string}`;
|
|
57
|
+
eModeLabel: string;
|
|
58
|
+
borrowableInIsolation: boolean;
|
|
59
|
+
}[], {
|
|
60
|
+
marketReferenceCurrencyUnit: bigint;
|
|
61
|
+
marketReferenceCurrencyPriceInUsd: bigint;
|
|
62
|
+
networkBaseTokenPriceInUsd: bigint;
|
|
63
|
+
networkBaseTokenPriceDecimals: number;
|
|
64
|
+
}]>;
|
|
65
|
+
getUserReservesData(user: string): Promise<readonly [readonly {
|
|
66
|
+
underlyingAsset: `0x${string}`;
|
|
67
|
+
scaledATokenBalance: bigint;
|
|
68
|
+
usageAsCollateralEnabledOnUser: boolean;
|
|
69
|
+
stableBorrowRate: bigint;
|
|
70
|
+
scaledVariableDebt: bigint;
|
|
71
|
+
principalStableDebt: bigint;
|
|
72
|
+
stableBorrowLastUpdateTimestamp: bigint;
|
|
73
|
+
}[], number]>;
|
|
74
|
+
getUserAccountData(user: string): Promise<readonly [bigint, bigint, bigint, bigint, bigint, bigint]>;
|
|
75
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { BigNumber } from '../utils/bignumber';
|
|
2
|
+
import { Amount } from '../types';
|
|
3
|
+
export declare class AaveUtils {
|
|
4
|
+
private client;
|
|
5
|
+
constructor();
|
|
6
|
+
private loadCtx;
|
|
7
|
+
getMaxWithdraw(user: string, reserve: string): Promise<Amount>;
|
|
8
|
+
getHealthFactorAfterWithdraw(user: string, reserve: string, withdrawAmount: BigNumber): Promise<number>;
|
|
9
|
+
getHealthFactorAfterSupply(user: string, reserve: string, supplyAmount: BigNumber): Promise<number>;
|
|
10
|
+
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
export declare const
|
|
1
|
+
export declare const AAVE_POOL_ABI: readonly [{
|
|
2
2
|
readonly anonymous: false;
|
|
3
3
|
readonly inputs: readonly [{
|
|
4
4
|
readonly indexed: true;
|
|
@@ -171,4 +171,38 @@ export declare const AAVE_ABI: readonly [{
|
|
|
171
171
|
}];
|
|
172
172
|
readonly name: "Repay";
|
|
173
173
|
readonly type: "event";
|
|
174
|
+
}, {
|
|
175
|
+
readonly inputs: readonly [{
|
|
176
|
+
readonly internalType: "address";
|
|
177
|
+
readonly name: "user";
|
|
178
|
+
readonly type: "address";
|
|
179
|
+
}];
|
|
180
|
+
readonly name: "getUserAccountData";
|
|
181
|
+
readonly outputs: readonly [{
|
|
182
|
+
readonly internalType: "uint256";
|
|
183
|
+
readonly name: "totalCollateralBase";
|
|
184
|
+
readonly type: "uint256";
|
|
185
|
+
}, {
|
|
186
|
+
readonly internalType: "uint256";
|
|
187
|
+
readonly name: "totalDebtBase";
|
|
188
|
+
readonly type: "uint256";
|
|
189
|
+
}, {
|
|
190
|
+
readonly internalType: "uint256";
|
|
191
|
+
readonly name: "availableBorrowsBase";
|
|
192
|
+
readonly type: "uint256";
|
|
193
|
+
}, {
|
|
194
|
+
readonly internalType: "uint256";
|
|
195
|
+
readonly name: "currentLiquidationThreshold";
|
|
196
|
+
readonly type: "uint256";
|
|
197
|
+
}, {
|
|
198
|
+
readonly internalType: "uint256";
|
|
199
|
+
readonly name: "ltv";
|
|
200
|
+
readonly type: "uint256";
|
|
201
|
+
}, {
|
|
202
|
+
readonly internalType: "uint256";
|
|
203
|
+
readonly name: "healthFactor";
|
|
204
|
+
readonly type: "uint256";
|
|
205
|
+
}];
|
|
206
|
+
readonly stateMutability: "view";
|
|
207
|
+
readonly type: "function";
|
|
174
208
|
}];
|