@galacticcouncil/sdk-next 0.6.0-pr194-1c1c0d6 → 0.7.0-pr169-8458cc0
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 +1 -1
- package/build/index.mjs +1 -1
- package/build/types/aave/AaveClient.d.ts +2 -2
- package/build/types/aave/AaveUtils.d.ts +1 -1
- package/build/types/client/LiquidityMiningClient.d.ts +46 -0
- package/build/types/client/index.d.ts +1 -0
- package/build/types/evm/chain.d.ts +1 -1
- package/build/types/evm/client.d.ts +3 -2
- package/build/types/evm/index.d.ts +1 -0
- package/build/types/evm/types.d.ts +7 -0
- package/build/types/factory.d.ts +1 -1
- package/build/types/oracle/MmOracleClient.d.ts +7 -0
- package/build/types/oracle/abi.d.ts +87 -0
- package/build/types/oracle/index.d.ts +2 -0
- package/build/types/oracle/types.d.ts +5 -0
- package/build/types/pool/PoolClient.d.ts +5 -1
- package/build/types/pool/PoolContextProvider.d.ts +3 -1
- package/build/types/pool/stable/StableSwapClient.d.ts +6 -6
- package/build/types/staking/StakingApi.d.ts +1 -1
- package/build/types/staking/StakingClient.d.ts +0 -5
- package/build/types/tx/TxBuilder.d.ts +4 -2
- package/build/types/tx/TxBuilderFactory.d.ts +1 -1
- package/build/types/utils/format.d.ts +10 -3
- package/package.json +3 -3
package/build/index.mjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
var $t=Object.defineProperty;var x=(u,e)=>{for(var t in e)$t(u,t,{get:e[t],enumerable:!0})};var dt={};x(dt,{Papi:()=>B,getWs:()=>en});import{hydration as Qt}from"@galacticcouncil/descriptors";function mt(u){switch(u){case!0:case"true":case 1:case"1":case"on":case"yes":return!0;default:return!1}}var B=class{client;api;constructor(e){this.client=e,this.api=this.client.getTypedApi(Qt)}log(e,...t){let n=typeof window>"u"?process.env.GC_DEBUG:window.localStorage.getItem("gc.debug");mt(n)&&console.log(e,...t)}};import{createClient as Jt}from"polkadot-api";import{withPolkadotSdkCompat as Zt}from"polkadot-api/polkadot-sdk-compat";var en=async u=>{let e=typeof u=="string"?u.split(","):u,s=(typeof window>"u"?(await import("polkadot-api/ws-provider/node")).getWsProvider:(await import("polkadot-api/ws-provider/web")).getWsProvider)(e);return Jt(Zt(s))};var vt={};x(vt,{AAVE_GAS_LIMIT:()=>We,AAVE_LENDING_POOL_ADDRESS:()=>Ee,AAVE_POOL_ABI:()=>Ue,AAVE_POOL_DATA_PROVIDER:()=>ke,AAVE_POOL_DATA_PROVIDER_ABI:()=>Fe,AAVE_POOL_PROXY:()=>Ve,AAVE_ROUNDING_THRESHOLD:()=>Oa,AAVE_UINT_256_MAX:()=>tn,AaveClient:()=>le,AaveUtils:()=>Y});var Ue=[{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 Fe=[{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 Ve="0x1b02E051683b5cfaC5929C25E84adb26ECf87B38",ke="0x112b087b60C1a166130d59266363C45F8aa99db0",Ee="0xf3Ba4D1b50f78301BDD7EAEa9B67822A15FCA691",We=1000000n,Oa=5,tn=BigInt("0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");var yt={};x(yt,{EvmClient:()=>R,evmMainnet:()=>Xe});import{defineChain as nn}from"viem";var gt=["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"],bt=["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"],Xe=nn({id:222222,name:"Hydration",network:"hydration",nativeCurrency:{decimals:18,name:"WETH",symbol:"WETH"},rpcUrls:{public:{http:gt,webSocket:bt},default:{http:gt,webSocket:bt}},blockExplorers:{default:{name:"Hydration Explorer",url:"https://explorer.evm.hydration.cloud"}},testnet:!1});import{createPublicClient as ht,createWalletClient as sn,custom as an,http as rn,webSocket as on}from"viem";var R=class{chain;constructor(e){this.chain=e||Xe}get chainId(){return this.chain.id}get chainCurrency(){return this.chain.nativeCurrency.symbol}get chainDecimals(){return this.chain.nativeCurrency.decimals}async getGasPrice(){return this.getProvider().getGasPrice()}getProvider(){return ht({chain:this.chain,transport:rn()})}getWsProvider(){return ht({chain:this.chain,transport:on()})}getSigner(e){return sn({account:e,chain:this.chain,transport:an(window.ethereum)})}};var le=class{evmClient;constructor(e){this.evmClient=e??new R}async getReservesData(){return await this.evmClient.getProvider().readContract({abi:Fe,address:ke,args:[Ee],functionName:"getReservesData"})}async getUserReservesData(e){return await this.evmClient.getProvider().readContract({abi:Fe,address:ke,args:[Ee,e],functionName:"getUserReservesData"})}async getUserAccountData(e){return await this.evmClient.getProvider().readContract({abi:Ue,address:Ve,args:[e],functionName:"getUserAccountData"})}};var y={};x(y,{asBigInt:()=>un,toBigInt:()=>cn,toDecimal:()=>ln});import W from"big.js";W.NE=-18;function ln(u,e,t=6,n){let s=W(u.toString()),a=W(10).pow(e);return s.div(a).round(t,n).toString()}function cn(u,e){let t=W(10).pow(e),s=W(u).mul(t).toFixed(0,W.roundDown);return BigInt(s)}function un(u){return BigInt(u.round(0,W.roundDown).toFixed(0))}var j={};x(j,{ERC20:()=>Ye});var Ye=class{static fromAssetId(e){let t=Buffer.alloc(20,0);return t[15]=1,t.writeUInt32BE(e,16),"0x"+t.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"),n=Buffer.from(e.replace("0x",""),"hex");return n.length!==20?!1:n.subarray(0,16).equals(t.subarray(0,16))}};var P={};x(P,{fromPermill:()=>dn,toDecimals:()=>mn,toPct:()=>pn});var Pt=1e3;function pn(u){let[e,t]=u;return e/t*100}function mn(u){let[e,t]=u;return e/t}function dn(u){return[u/Pt,Pt]}var Ce={};x(Ce,{H160:()=>Qe,isEvmAccount:()=>St,isEvmAddress:()=>xt,isSs58Address:()=>wt});import{AccountId as ce}from"polkadot-api";import{toHex as Tt}from"@polkadot-api/utils";import{Buffer as V}from"buffer";var ft={};x(ft,{HUB_ASSET_ID:()=>ze,HYDRATION_OMNIPOOL_ADDRESS:()=>hn,HYDRATION_PARACHAIN_ID:()=>bn,HYDRATION_SS58_PREFIX:()=>k,PERBILL_DENOMINATOR:()=>gn,PERMILL_DENOMINATOR:()=>Ke,RUNTIME_DECIMALS:()=>F,SYSTEM_ASSET_DECIMALS:()=>je,SYSTEM_ASSET_ID:()=>M,TRADEABLE_DEFAULT:()=>z});var F=18,Ke=1e6,gn=1e9,M=0,je=12,bn=2034,k=63,hn="7L53bUTBbfuj14UpdCNPwmgzzHSsrsTWBHX5pys32mVWM3C1",ze=1,z=15;var $e="ETH\0";function St(u){if(!u)return!1;try{let e=ce().enc(u),t=V.from($e);return V.from(e.subarray(0,t.length)).equals(t)}catch{return!1}}function xt(u){return!!/^0x[a-fA-F0-9]{40}$/.test(u)}function wt(u){try{return ce(63).enc(u),!0}catch{return!1}}var Qe=class u{static toAccount=e=>{let t=V.from(e.slice(2),"hex"),n=V.from($e),s=Uint8Array.from(V.concat([n,t,V.alloc(8)])),a=Tt(s);return ce(63).dec(a)};static fromAccount=e=>{let t=ce().enc(e),n=V.from($e),s=t.slice(n.length,-8);return"0x"+V.from(s).toString("hex")};static fromSS58=e=>{let n=ce().enc(e).slice(0,20);return Tt(n)};static fromAny=e=>{if(xt(e))return e;if(St(e))return u.fromAccount(e);if(wt(e))return u.fromSS58(e);throw new Error("Unknown address type")}};var X={};x(X,{findNestedKey:()=>yn,findNestedObj:()=>Pn,jsonFormatter:()=>fn});var yn=(u,e)=>{let t=[];return JSON.stringify(u,(n,s)=>(s&&s[e]&&t.push(s),s)),t[0]},Pn=(u,e,t)=>{let n;return JSON.stringify(u,(s,a)=>(a&&a[e]===t&&(n=a),a)),n},fn=(u,e)=>typeof e=="bigint"?e.toString():e;var I={};x(I,{calculateBuyFee:()=>wn,calculateDiffToAvg:()=>Tn,calculateDiffToRef:()=>Sn,calculateSellFee:()=>xn,getFraction:()=>In});import H from"big.js";function Tn(u,e){let t=H(u.toString()),n=H(e.toString());return t.minus(n).abs().div(t.plus(n).div(2)).mul(100).round(2).toNumber()}function Sn(u,e){if(e===0n)return 0;let t=H(u.toString()),n=H(e.toString());return t.minus(n).div(n).mul(100).round(2).toNumber()}function xn(u,e){let t=H(u.toString()),n=H(e.toString());return H(1).minus(n.div(t)).mul(100).round(2).toNumber()}function wn(u,e){let t=H(u.toString());return H(e.toString()).div(t).minus(1).mul(100).round(2).toNumber()}function In(u,e,t=2){(e<.01||e>100)&&new Error("Supported range is from 0.01% - 100%");let n=Math.pow(10,t),s=BigInt(e*n);return u*s/BigInt(100*n)}var It={};x(It,{convertToId:()=>On});import{Buffer as vn}from"buffer";function On(u){let t=vn.from(u.replace("0x",""),"hex").subarray(16);return t.readUIntBE(0,t.length)}var{ERC20:De}=j,{H160:Je}=Ce,An=1.01,Bn=99999,_n=10n**27n,Rn=10n**18n,Y=class{client;constructor(e){let t=e??new R;this.client=new le(t)}async getSummary(e){let t=Je.fromAny(e),[n,s,a]=await Promise.all([this.client.getReservesData(),this.client.getUserReservesData(t),this.client.getUserAccountData(t)]),[i]=n,[r,o]=s,[l,c,p,g,m,b]=a,h=y.toDecimal(b,18),d=[];for(let f of r){let T=f.underlyingAsset.toLowerCase(),S=i.find(({underlyingAsset:Ge})=>Ge.toLowerCase()===T);if(!S)throw new Error("Missing pool reserve for "+T);let v=f.scaledATokenBalance,D=S.liquidityIndex,N=S.priceInMarketReferenceCurrency,_=v*D/_n,_e=Number(o===S.eModeCategoryId?S.eModeLiquidationThreshold:S.reserveLiquidationThreshold)/1e4,Re=S.usageAsCollateralEnabled&&f.usageAsCollateralEnabledOnUser&&f.scaledATokenBalance>0n,He=De.toAssetId(T);d.push({aTokenBalance:_,decimals:Number(S.decimals),isCollateral:Re,priceInRef:N,reserveId:He,reserveAsset:T,reserveLiquidationThreshold:_e})}return{healthFactor:Number(h),totalCollateral:l,totalDebt:c,reserves:d}}async hasBorrowPositions(e){let t=Je.fromAny(e),n=await this.client.getUserAccountData(t),[s,a]=n;return a>0n}async getHealthFactor(e){let t=Je.fromAny(e),n=await this.client.getUserAccountData(t),[s,a,i,r,o,l]=n,c=y.toDecimal(l,18);return Number(c)}async getHealthFactorAfterWithdraw(e,t,n){let{totalCollateral:s,totalDebt:a,reserves:i}=await this.getSummary(e),r=De.fromAssetId(t),o=i.find(d=>d.reserveAsset===r);if(!o)throw new Error("Missing reserve ctx for "+r);let{decimals:l,isCollateral:c,priceInRef:p,reserveLiquidationThreshold:g}=o,m=y.toBigInt(n,l),b=c?m*p/10n**BigInt(l):0n,h=s-b;return h<=0n?0:this.calculateHealthFactor(h,g,a)}async getHealthFactorAfterSupply(e,t,n){let{totalCollateral:s,totalDebt:a,reserves:i}=await this.getSummary(e),r=De.fromAssetId(t),o=i.find(h=>h.reserveAsset===r);if(!o)throw new Error("Missing reserve ctx for "+r);let{decimals:l,priceInRef:c,reserveLiquidationThreshold:p}=o,m=y.toBigInt(n,l)*c/10n**BigInt(l),b=s+m;return b<=0n?0:this.calculateHealthFactor(b,p,a)}async getMaxWithdraw(e,t){let{totalCollateral:n,totalDebt:s,reserves:a}=await this.getSummary(e),i=De.fromAssetId(t),r=a.find(o=>o.reserveAsset===i);if(!r)throw new Error("Missing reserve ctx for "+i);return this.calculateWithdrawMax(r,n,s)}async getMaxWithdrawAll(e){let{totalCollateral:t,totalDebt:n,reserves:s}=await this.getSummary(e),a={};for(let i of s){let r=this.calculateWithdrawMax(i,t,n);i.reserveId&&(a[i.reserveId]=r)}return a}calculateHealthFactor(e,t,n){if(n===0n)return Bn;let s=10n**6n,a=y.toBigInt(t,18),i=e*a*s,r=n*Rn,o=i/r;return Number(o)/1e6}calculateRequiredCollateral(e,t,n){let s=y.toBigInt(e,18),a=y.toBigInt(t,18);return(s*n+a-1n)/a}calculateWithdrawMax(e,t,n){let{aTokenBalance:s,decimals:a,priceInRef:i,reserveLiquidationThreshold:r}=e,o=this.calculateRequiredCollateral(An,r,n),l=t-o;if(l<=0n)return{amount:0n,decimals:a};let c=l*10n**BigInt(a)/i;return{amount:s<c?s:c,decimals:a}}};var Bt={};x(Bt,{AssetClient:()=>$,BalanceClient:()=>q,ChainParams:()=>J});var $=class extends B{SUPPORTED_TYPES=["StableSwap","Bond","Token","External","Erc20"];constructor(e){super(e)}async queryShares(){let t=await this.api.query.Stableswap.Pools.getEntries();return new Map(t.map(({keyArgs:n,value:s})=>{let[a]=n;return[a,s]}))}async queryBonds(){let t=await this.api.query.Bonds.Bonds.getEntries();return new Map(t.map(({keyArgs:n,value:s})=>{let[a]=n;return[a,s]}))}async queryAssets(){let t=await this.api.query.AssetRegistry.Assets.getEntries();return new Map(t.filter(({value:n})=>{let{asset_type:s}=n;return this.SUPPORTED_TYPES.includes(s.type)}).map(({keyArgs:n,value:s})=>{let[a]=n;return[a,s]}))}async queryAssetLocations(){let t=await this.api.query.AssetRegistry.AssetLocations.getEntries();return new Map(t.map(({keyArgs:n,value:s})=>{let[a]=n;return[a,s]}))}async mapToken(e,t,n,s){let{name:a,asset_type:i,is_sufficient:r,existential_deposit:o}=t,{symbol:l,decimals:c}=n.get(e)??{};return{id:e,name:a?.asText(),symbol:l,decimals:c,icon:l,type:i.type,isSufficient:r,location:s,existentialDeposit:o}}async mapBond(e,t,n,s){let[a,i]=s,{asset_type:r,is_sufficient:o,existential_deposit:l}=t,{symbol:c,decimals:p}=await this.mapToken(a,t,n),g=Number(i),m=new Intl.DateTimeFormat("en-GB"),b=[c,"Bond",m.format(g)].join(" ");return{id:e,name:b,symbol:c+"b",decimals:p,icon:c,type:r.type,isSufficient:o,existentialDeposit:l,underlyingAssetId:a,maturity:g}}async mapShares(e,t,n,s){let{assets:a}=s,{name:i,symbol:r,asset_type:o,is_sufficient:l,existential_deposit:c}=t,p=await Promise.all(a.map(async b=>{let{symbol:h}=await this.mapToken(b,t,n);return[b,h]})),g=Object.fromEntries(p),m=Object.values(g);return{id:e,name:m.join(", "),symbol:r?.asText()||i?.asText(),decimals:18,icon:m.join("/"),type:o.type,isSufficient:l,existentialDeposit:c,meta:g}}async mapExternal(e,t,n,s){let a=await this.mapToken(e,t,new Map,s),i=n?.find(r=>r.internalId===a.id);return i?{...a,decimals:i.decimals,name:i.name,symbol:i.symbol,icon:i.symbol,isWhiteListed:i.isWhiteListed}:a}parseMetadata(e){return new Map(Array.from(e,([t,n])=>[t,{symbol:n.symbol?.asText(),decimals:n.decimals}]))}async getOnChainAssets(e,t){let[n,s,a,i]=await Promise.all([this.queryAssets(),this.queryAssetLocations(),this.queryShares(),this.queryBonds()]),r=this.parseMetadata(n),o=[];for(let[l,c]of Array.from(n)){let p=s.get(l),{asset_type:g}=c,m;switch(g.type){case"Bond":let b=i.get(l);m=await this.mapBond(l,c,r,b);break;case"StableSwap":let h=a.get(l);m=await this.mapShares(l,c,r,h);break;case"External":m=await this.mapExternal(l,c,t,p);break;default:m=await this.mapToken(l,c,r,p)}o.push(m)}return e?o:o.filter(l=>this.isValidAsset(l))}isValidAsset(e){let t=Math.sign(e.decimals);return!!e.symbol&&(t===0||t===1)}};import{Subject as Fn,bufferCount as kn,combineLatest as En,debounceTime as Cn,distinctUntilChanged as Ot,finalize as Dn,map as Q,pairwise as Mn,shareReplay as Ln,startWith as qn}from"rxjs";var q=class extends B{constructor(e){super(e)}async getBalance(e,t){return t===0?this.getSystemBalance(e):this.getTokenBalanceData(e,t)}async getSystemBalance(e){let t=this.api.query.System.Account,{data:n}=await t.getValue(e);return this.calculateBalance(n)}async getTokenBalance(e,t){let s=await this.api.query.Tokens.Accounts.getValue(e,t);return this.calculateBalance(s)}calculateBalance(e){let t=e.free>=e.frozen?e.free-e.frozen:0n,n=e.free+e.reserved;return{free:e.free,reserved:e.reserved,frozen:e.frozen,total:n,transferable:t}}async getErc20Balance(e,t){return this.getTokenBalanceData(e,t)}subscribeBalance(e){let t=this.subscribeSystemBalance(e),n=this.subscribeTokensBalance(e),s=this.subscribeErc20Balance(e);return En([t,n,s]).pipe(Cn(250),Q(a=>a.flat()),qn([]),kn(2,1),Q(([a,i],r)=>{if(r===0)return i;let o=a.reduce((c,p)=>(c.set(p.id,p.balance),c),new Map);return i.filter(c=>!At(c.balance,o.get(c.id)))}))}subscribeSystemBalance(e){return this.api.query.System.Account.watchValue(e,"best").pipe(Q(n=>({id:0,balance:this.calculateBalance(n.data)})))}subscribeTokenBalance(e,t){return this.api.query.Tokens.Accounts.watchValue(e,t,"best").pipe(Q(s=>({id:t,balance:s})))}subscribeTokensBalance(e){return this.api.query.Tokens.Accounts.watchEntries(e,{at:"best"}).pipe(Ot((n,s)=>!s.deltas),Q(({deltas:n})=>{let s=[];return n?.deleted.forEach(a=>{let[i,r]=a.args;s.push({id:r,balance:this.calculateBalance({free:0n,reserved:0n,frozen:0n})})}),n?.upserted.forEach(a=>{let[i,r]=a.args;s.push({id:r,balance:this.calculateBalance(a.value)})}),s}))}subscribeErc20Balance(e,t){let n=new Fn,s=n.pipe(Ln(1)),a=async()=>(await this.api.query.AssetRegistry.Assets.getEntries()).filter(({value:l})=>{let{asset_type:c}=l;return c.type==="Erc20"}).map(({keyArgs:l})=>{let[c]=l;return c}),i=async()=>{let o=t||await a(),l=async()=>{let g=(await Promise.all(o.map(async m=>{let b=await this.getTokenBalanceData(e,m);return[m,b]}))).map(([m,b])=>({id:m,balance:b}));n.next(g)};await l();let c=this.api.query.System.Number.watchValue("best").subscribe(l);return()=>c.unsubscribe()},r;return i().then(o=>r=o),s.pipe(Dn(()=>r?.()),Mn(),Q(([o,l],c)=>{if(c===0)return l;let p=o.reduce((m,b)=>(m.set(b.id,b.balance),m),new Map);return l.filter(m=>!At(m.balance,p.get(m.id)))}),Ot((o,l)=>l.length===0))}async getTokenBalanceData(e,t){let n=await this.api.apis.CurrenciesApi.account(t,e);return this.calculateBalance(n)}},At=(u,e)=>u!==void 0&&e!==void 0&&u.transferable===e.transferable&&u.total===e.total;var J=class extends B{_minOrderBudget;_blockTime;constructor(e){super(e)}async getBlockTime(){if(this._blockTime===void 0){let e=await this.api.constants.Aura.SlotDuration();this._blockTime=Number(e)}return this._blockTime}async getMinOrderBudget(){return this._minOrderBudget===void 0&&(this._minOrderBudget=await this.api.constants.DCA.MinBudgetInNativeCurrency()),this._minOrderBudget}};var _t={};x(_t,{AssetNotFound:()=>Ze,PoolNotFound:()=>ue,RouteNotFound:()=>pe});var Ze=class extends Error{constructor(e){super(),this.message=`${e} not found`,this.name="AssetNotFound"}},ue=class extends Error{constructor(e){super(),this.message=`${e} pool invalid`,this.name="PoolNotFound"}},pe=class extends Error{constructor(e,t){super(),this.message=`Route from ${e} to ${t} not found in current configuration`,this.name="RouteNotFound"}};var Lt={};x(Lt,{PoolContextProvider:()=>te,PoolError:()=>K,PoolFactory:()=>ee,PoolType:()=>O,aave:()=>at,lbp:()=>et,omni:()=>tt,stable:()=>nt,xyk:()=>st});var et={};x(et,{LbpMath:()=>L,LbpPool:()=>me,LbpPoolClient:()=>de});import{calculate_in_given_out as Nn,calculate_out_given_in as Hn,calculate_linear_weights as Gn,calculate_pool_trade_fee as Un,get_spot_price as Vn}from"@galacticcouncil/math-lbp";var L=class{static getSpotPrice(e,t,n,s,a){return Vn(e,t,n,s,a)}static calculateInGivenOut(e,t,n,s,a){return Nn(e,t,n,s,a)}static calculateOutGivenIn(e,t,n,s,a){return Hn(e,t,n,s,a)}static calculateLinearWeights(e,t,n,s,a){return Gn(e,t,n,s,a)}static calculatePoolTradeFee(e,t,n){return Un(e,t,n)}};var O=(a=>(a.Aave="Aave",a.LBP="LBP",a.Omni="Omnipool",a.Stable="Stableswap",a.XYK="XYK",a))(O||{}),K=(a=>(a.InsufficientTradingAmount="InsufficientTradingAmount",a.MaxInRatioExceeded="MaxInRatioExceeded",a.MaxOutRatioExceeded="MaxOutRatioExceeded",a.TradeNotAllowed="TradeNotAllowed",a.UnknownError="UnknownError",a))(K||{});var me=class u{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;fee;repayFeeApply;static fromPool(e){return new u(e.address,e.tokens,e.maxInRatio,e.maxOutRatio,e.minTradingLimit,e.fee,e.repayFeeApply)}constructor(e,t,n,s,a,i,r){this.type="LBP",this.address=e,this.tokens=t,this.maxInRatio=n,this.maxOutRatio=s,this.minTradingLimit=a,this.fee=i,this.repayFeeApply=r}validatePair(e,t){return!0}parsePair(e,t){let n=new Map(this.tokens.map(i=>[i.id,i])),s=n.get(e),a=n.get(t);if(s==null)throw new Error("Pool does not contain tokenIn");if(a==null)throw new Error("Pool does not contain tokenOut");return{assetIn:e,assetOut:t,balanceIn:s.balance,balanceOut:a.balance,decimalsIn:s.decimals,decimalsOut:a.decimals,weightIn:s.weight,weightOut:a.weight}}validateAndBuy(e,t,n){let s=this.tokens[0].id,a=[];t<this.minTradingLimit&&a.push("InsufficientTradingAmount");let i=e.balanceOut/this.maxOutRatio;if(t>i&&a.push("MaxOutRatioExceeded"),s===e.assetOut){let r=this.calculateTradeFee(t,n),o=P.toPct(this.repayFeeApply?n.repayFee:n.exchangeFee),l=t+r,c=this.calculateInGivenOut(e,l),p=e.balanceIn/this.maxInRatio;return c>p&&a.push("MaxInRatioExceeded"),{amountIn:c,calculatedIn:c,amountOut:t,feePct:o,errors:a}}else{let r=this.calculateInGivenOut(e,t),o=e.balanceIn/this.maxInRatio;return r>o&&a.push("MaxInRatioExceeded"),{amountIn:r,calculatedIn:r,amountOut:t,feePct:0,errors:a}}}validateAndSell(e,t,n){let s=this.tokens[0].id,a=[];t<this.minTradingLimit&&a.push("InsufficientTradingAmount");let i=e.balanceIn/this.maxInRatio;if(t>i&&a.push("MaxInRatioExceeded"),s===e.assetIn){let r=this.calculateOutGivenIn(e,t),o=e.balanceOut/this.maxOutRatio;return r>o&&a.push("MaxOutRatioExceeded"),{amountIn:t,calculatedOut:r,amountOut:r,feePct:0,errors:a}}else{let r=this.calculateOutGivenIn(e,t),o=this.calculateTradeFee(r,n),l=P.toPct(this.repayFeeApply?n.repayFee:n.exchangeFee),c=r-o,p=e.balanceOut/this.maxOutRatio;return c>p&&a.push("MaxOutRatioExceeded"),{amountIn:t,calculatedOut:r,amountOut:c,feePct:l,errors:a}}}calculateInGivenOut(e,t){let n=L.calculateInGivenOut(e.balanceIn.toString(),e.balanceOut.toString(),e.weightIn.toString(),e.weightOut.toString(),t.toString()),s=BigInt(n);return s<0n?0n:s}calculateOutGivenIn(e,t){let n=L.calculateOutGivenIn(e.balanceIn.toString(),e.balanceOut.toString(),e.weightIn.toString(),e.weightOut.toString(),t.toString()),s=BigInt(n);return s<0n?0n:s}spotPriceInGivenOut(e){let t=L.getSpotPrice(e.balanceOut.toString(),e.balanceIn.toString(),e.weightOut.toString(),e.weightIn.toString(),this.maxOutRatio.toString());return BigInt(t)}spotPriceOutGivenIn(e){let t=L.getSpotPrice(e.balanceIn.toString(),e.balanceOut.toString(),e.weightIn.toString(),e.weightOut.toString(),this.maxInRatio.toString());return BigInt(t)}calculateTradeFee(e,t){let n=L.calculatePoolTradeFee(e.toString(),this.repayFeeApply?t.repayFee[0]:t.exchangeFee[0],this.repayFeeApply?t.repayFee[1]:t.exchangeFee[1]);return BigInt(n)}};import{CompatibilityLevel as $n}from"polkadot-api";import{map as Qn,of as Ct,switchMap as Jn}from"rxjs";import{memoize1 as Wn}from"@thi.ng/memoize";import{combineLatest as Rt,combineLatestAll as Xn,debounceTime as Yn,firstValueFrom as Kn,from as Ft,map as kt,mergeAll as jn,of as zn,switchMap as Et}from"rxjs";var E=class extends q{override=[];mem=0;memPools=Wn(e=>(this.log(this.getPoolType(),"mem pools",e,"\u2705"),this.loadPools()));constructor(e){super(e)}async withOverride(e){this.override=e||[]}async getPoolsMem(){return this.memPools(this.mem)}async getPools(){let e=Ft(this.getPoolsMem()).pipe(Et(t=>this.subscribe(t)),Xn());return Kn(e)}getSubscriber(){return Ft(this.getPoolsMem()).pipe(Et(e=>this.subscribe(e)),jn())}subscribe(e){return e.filter(t=>this.hasValidAssets(t)).map(t=>Rt([this.subscribePoolChange(t),this.subscribePoolBalance(t)]).pipe(Yn(250),kt(([n,s])=>this.updatePool(n,s))))}subscribePoolBalance(e){if(e.type==="Aave")return zn([]);let t=[this.subscribeTokensBalance(e.address)];if(this.hasSystemAsset(e)){let n=this.subscribeSystemBalance(e.address);t.push(n)}if(this.hasErc20Asset(e)){let n=e.tokens.filter(a=>a.type==="Erc20").map(a=>a.id),s=this.subscribeErc20Balance(e.address,n);t.push(s)}return Rt(t).pipe(kt(n=>n.map(s=>Array.isArray(s)?s:[s]).flat()))}hasSystemAsset(e){return e.tokens.some(t=>t.id===0)}hasErc20Asset(e){return e.tokens.some(t=>t.type==="Erc20")}hasValidAssets(e){return e.tokens.every(({id:t,decimals:n,balance:s})=>{let a=this.override.find(r=>r.id===t),i=!!n||!!a?.decimals;return s>0n&&i})}updatePool=(e,t)=>{let n=e.tokens.map(s=>{let a=t.find(r=>r.id===s.id),i=this.override.find(r=>r.id===s.id);return a?{...s,balance:a.balance.transferable,decimals:s.decimals||i?.decimals}:{...s,decimals:s.decimals||i?.decimals}});return{...e,tokens:n}}};var de=class extends E{MAX_FINAL_WEIGHT=100000000n;poolsData=new Map([]);async loadPools(){let[e,t,n]=await Promise.all([this.api.query.LBP.PoolData.getEntries(),this.api.query.ParachainSystem.ValidationData.getValue(),this.getPoolLimits()]),s=t?.relay_parent_number||0,a=e.filter(({value:i})=>t&&this.isActivePool(i,s)).map(async({keyArgs:i,value:r})=>{let[o]=i,l=o.toString(),c=await this.getPoolDelta(l,r,s);return{address:l,type:"LBP",fee:r.fee,...c,...n}});return Promise.all(a)}async getPoolDelta(e,t,n){let{start:s,end:a,assets:i,initial_weight:r,final_weight:o,repay_target:l,fee_collector:c}=t,p=L.calculateLinearWeights(s?s.toString():"0",a?a.toString():"0",r.toString(),o.toString(),n.toString()),[g,m]=i,b=BigInt(p),h=this.MAX_FINAL_WEIGHT-BigInt(b),[d,f,T,S,v]=await Promise.all([this.isRepayFeeApplied(g,l,c.toString()),this.getBalance(e,g),this.api.query.AssetRegistry.Assets.getValue(g),this.getBalance(e,m),this.api.query.AssetRegistry.Assets.getValue(m)]);return{repayFeeApply:d,tokens:[{id:g,decimals:T?.decimals,existentialDeposit:T?.existential_deposit,balance:f.transferable,weight:b,type:T?.asset_type.type},{id:m,decimals:v?.decimals,existentialDeposit:v?.existential_deposit,balance:S.transferable,weight:h,type:v?.asset_type.type}]}}isActivePool(e,t){let{start:n,end:s}=e;return n&&s?t>=n&&t<s:!1}async isRepayFeeApplied(e,t,n){if(t===0n)return!1;try{return(await this.getBalance(n,e)).transferable<t}catch{return!0}}async getRepayFee(){return await this.api.constants.LBP.repay_fee()}async getPoolLimits(){let[e,t,n]=await Promise.all([this.api.constants.LBP.MaxInRatio(),this.api.constants.LBP.MaxOutRatio(),this.api.constants.LBP.MinTradingLimit()]);return{maxInRatio:e,maxOutRatio:t,minTradingLimit:n}}async getPoolFees(e){return{repayFee:await this.getRepayFee(),exchangeFee:e.fee}}getPoolType(){return"LBP"}async isSupported(){let e=this.api.query.LBP.PoolData,t=await this.api.compatibilityToken;return e.isCompatible($n.BackwardsCompatible,t)}subscribePoolChange(e){let t=this.api.query.ParachainSystem.ValidationData,n=this.poolsData.get(e.address);return n?t.watchValue("best").pipe(Jn(s=>s?this.getPoolDelta(e.address,n,s.relay_parent_number):Ct(e)),Qn(s=>Object.assign({},e,s))):Ct(e)}};var tt={};x(tt,{OmniMath:()=>w,OmniPool:()=>ge,OmniPoolClient:()=>be});import{calculate_in_given_out as Zn,calculate_lrna_in_given_out as es,calculate_out_given_in as ts,calculate_out_given_lrna_in as ns,calculate_spot_price as ss,calculate_lrna_spot_price as as,calculate_shares as rs,calculate_liquidity_out as is,calculate_liquidity_lrna_out as os,verify_asset_cap as ls,calculate_liquidity_hub_in as cs,is_sell_allowed as us,is_buy_allowed as ps,is_add_liquidity_allowed as ms,is_remove_liquidity_allowed as ds}from"@galacticcouncil/math-omnipool";import Z from"big.js";var w=class{static calculateSpotPrice(e,t,n,s){return ss(e,t,n,s)}static calculateLrnaSpotPrice(e,t){return as(e,t)}static calculateInGivenOut(e,t,n,s,a,i,r,o,l){return Zn(e,t,n,s,a,i,r,o,l)}static calculateLrnaInGivenOut(e,t,n,s,a){return es(e,t,n,s,a)}static calculateOutGivenIn(e,t,n,s,a,i,r,o,l){return ts(e,t,n,s,a,i,r,o,l)}static calculateOutGivenLrnaIn(e,t,n,s,a){return ns(e,t,n,s,a)}static calculateShares(e,t,n,s){return rs(e,t,n,s)}static calculateLiquidityOut(e,t,n,s,a,i,r,o){return is(e,t,n,s,a,i,r,o)}static calculateLiquidityLRNAOut(e,t,n,s,a,i,r,o){return os(e,t,n,s,a,i,r,o)}static calculateCapDifference(e,t,n,s){let a=Z(t),i=Z(e),r=Z(s),o=Z(n),l=Z(10).pow(18),c=o.div(l);if(a.div(r).lt(c)){let g=c.times(r).minus(a).times(i),m=a.times(Z(1).minus(c));return g.div(m).toFixed(0)}else return"0"}static verifyAssetCap(e,t,n,s){return ls(e,t,n,s)}static calculateLimitHubIn(e,t,n,s){return cs(e,t,n,s)}static isSellAllowed(e){return us(e)}static isBuyAllowed(e){return ps(e)}static isAddLiquidityAllowed(e){return ms(e)}static isRemoveLiquidityAllowed(e){return ds(e)}};var ge=class u{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;hubAssetId;static fromPool(e){return new u(e.address,e.tokens,e.maxInRatio,e.maxOutRatio,e.minTradingLimit,e.hubAssetId)}constructor(e,t,n,s,a,i){this.type="Omnipool",this.address=e,this.tokens=t,this.maxInRatio=n,this.maxOutRatio=s,this.minTradingLimit=a,this.hubAssetId=i}validatePair(e,t){return this.hubAssetId!=t}parsePair(e,t){let n=new Map(this.tokens.map(i=>[i.id,i])),s=n.get(e),a=n.get(t);if(s==null)throw new Error("Pool does not contain tokenIn");if(a==null)throw new Error("Pool does not contain tokenOut");return{assetIn:e,assetOut:t,hubReservesIn:s.hubReserves,hubReservesOut:a.hubReserves,sharesIn:s.shares,sharesOut:a.shares,decimalsIn:s.decimals,decimalsOut:a.decimals,balanceIn:s.balance,balanceOut:a.balance,tradeableIn:s.tradeable,tradeableOut:a.tradeable,assetInEd:s.existentialDeposit,assetOutEd:a.existentialDeposit}}validateAndBuy(e,t,n){let s=this.calculateInGivenOut(e,t),a=this.calculateInGivenOut(e,t,n),i=s===0n?0:I.calculateDiffToRef(a,s),r=[],o=w.isSellAllowed(e.tradeableIn),l=w.isBuyAllowed(e.tradeableOut);(!o||!l)&&r.push("TradeNotAllowed"),(t<this.minTradingLimit||s<e.assetInEd)&&r.push("InsufficientTradingAmount");let c=e.balanceOut/this.maxOutRatio;t>c&&r.push("MaxOutRatioExceeded");let p=e.balanceIn/this.maxInRatio;return a>p&&r.push("MaxInRatioExceeded"),{amountIn:a,calculatedIn:s,amountOut:t,feePct:i,errors:r}}validateAndSell(e,t,n){let s=this.calculateOutGivenIn(e,t),a=this.calculateOutGivenIn(e,t,n),i=I.calculateDiffToRef(s,a),r=[],o=w.isSellAllowed(e.tradeableIn),l=w.isBuyAllowed(e.tradeableOut);(!o||!l)&&r.push("TradeNotAllowed"),(t<this.minTradingLimit||s<e.assetOutEd)&&r.push("InsufficientTradingAmount");let c=e.balanceIn/this.maxInRatio;t>c&&r.push("MaxInRatioExceeded");let p=e.balanceOut/this.maxOutRatio;return a>p&&r.push("MaxOutRatioExceeded"),{amountIn:t,calculatedOut:s,amountOut:a,feePct:i,errors:r}}calculateInGivenOut(e,t,n){if(e.assetIn==this.hubAssetId)return this.calculateLrnaInGivenOut(e,t,n);let s=w.calculateInGivenOut(e.balanceIn.toString(),e.hubReservesIn.toString(),e.sharesIn.toString(),e.balanceOut.toString(),e.hubReservesOut.toString(),e.sharesOut.toString(),t.toString(),n?P.toDecimals(n.assetFee).toString():"0",n?P.toDecimals(n.protocolFee).toString():"0"),a=BigInt(s);return a<0n?0n:a}calculateLrnaInGivenOut(e,t,n){let s=w.calculateLrnaInGivenOut(e.balanceOut.toString(),e.hubReservesOut.toString(),e.sharesOut.toString(),t.toString(),n?P.toDecimals(n.assetFee).toString():"0"),a=BigInt(s);return a<0n?0n:a}calculateOutGivenIn(e,t,n){if(e.assetIn==this.hubAssetId)return this.calculateOutGivenLrnaIn(e,t,n);let s=w.calculateOutGivenIn(e.balanceIn.toString(),e.hubReservesIn.toString(),e.sharesIn.toString(),e.balanceOut.toString(),e.hubReservesOut.toString(),e.sharesOut.toString(),t.toString(),n?P.toDecimals(n.assetFee).toString():"0",n?P.toDecimals(n.protocolFee).toString():"0"),a=BigInt(s);return a<0n?0n:a}calculateOutGivenLrnaIn(e,t,n){let s=w.calculateOutGivenLrnaIn(e.balanceOut.toString(),e.hubReservesOut.toString(),e.sharesOut.toString(),t.toString(),n?P.toDecimals(n.assetFee).toString():"0"),a=BigInt(s);return a<0n?0n:a}spotPriceInGivenOut(e){if(e.assetIn==this.hubAssetId)return this.spotPriceLrnaInGivenOut(e);let t=w.calculateSpotPrice(e.balanceOut.toString(),e.hubReservesOut.toString(),e.balanceIn.toString(),e.hubReservesIn.toString()),n=Math.pow(10,18-e.decimalsOut);return BigInt(t)/BigInt(n)}spotPriceLrnaInGivenOut(e){let t=w.calculateLrnaSpotPrice(e.hubReservesOut.toString(),e.balanceOut.toString()),n=Math.pow(10,18-e.decimalsOut);return BigInt(t)/BigInt(n)}spotPriceOutGivenIn(e){if(e.assetIn==this.hubAssetId)return this.spotPriceOutGivenLrnaIn(e);let t=w.calculateSpotPrice(e.balanceIn.toString(),e.hubReservesIn.toString(),e.balanceOut.toString(),e.hubReservesOut.toString()),n=Math.pow(10,18-e.decimalsIn);return BigInt(t)/BigInt(n)}spotPriceOutGivenLrnaIn(e){let t=w.calculateLrnaSpotPrice(e.balanceOut.toString(),e.hubReservesOut.toString()),n=Math.pow(10,18-e.decimalsIn);return BigInt(t)/BigInt(n)}};import{AccountId as gs,CompatibilityLevel as bs}from"polkadot-api";import{toHex as hs}from"@polkadot-api/utils";import{distinctUntilChanged as ys,map as Dt}from"rxjs";var be=class extends E{async loadPools(){let e=await this.api.constants.Omnipool.HubAssetId(),t=this.getPoolAddress(),[n,s,a,i,r]=await Promise.all([this.api.query.Omnipool.Assets.getEntries(),this.api.query.Omnipool.HubAssetTradability.getValue(),this.api.query.AssetRegistry.Assets.getValue(e),this.getBalance(t,e),this.getPoolLimits()]),o=n.map(async({keyArgs:c,value:p})=>{let[g]=c,{hub_reserve:m,shares:b,tradable:h,cap:d,protocol_shares:f}=p,[T,S]=await Promise.all([this.api.query.AssetRegistry.Assets.getValue(g),this.getBalance(t,g)]);return{id:g,decimals:T?.decimals,existentialDeposit:T?.existential_deposit,balance:S.transferable,cap:d,hubReserves:m,protocolShares:f,shares:b,tradeable:h,type:T?.asset_type.type}}),l=await Promise.all(o);return l.push({id:e,decimals:a?.decimals,existentialDeposit:a?.existential_deposit,balance:i.transferable,tradeable:s,type:a?.asset_type.type}),[{address:t,type:"Omnipool",hubAssetId:e,tokens:l,...r}]}getPoolAddress(){let e="modlomnipool".padEnd(32,"\0"),t=new TextEncoder().encode(e),n=hs(t);return gs(63).dec(n)}async getPoolLimits(){let[e,t,n]=await Promise.all([this.api.constants.Omnipool.MaxInRatio(),this.api.constants.Omnipool.MaxOutRatio(),this.api.constants.Omnipool.MinimumTradingLimit()]);return{maxInRatio:e,maxOutRatio:t,minTradingLimit:n}}async getPoolFees(e,t){let[n,s,a]=await Promise.all([this.api.constants.DynamicFees.AssetFeeParameters(),this.api.constants.DynamicFees.ProtocolFeeParameters(),this.api.query.DynamicFees.AssetFee.getValue(t)]),i=n.min_fee+s.min_fee,r=n.max_fee+s.max_fee;if(a){let{asset_fee:o,protocol_fee:l}=a;return{assetFee:P.fromPermill(o),protocolFee:P.fromPermill(l),min:P.fromPermill(i),max:P.fromPermill(r)}}else return{assetFee:P.fromPermill(n.min_fee),protocolFee:P.fromPermill(s.min_fee),min:P.fromPermill(i),max:P.fromPermill(r)}}getPoolType(){return"Omnipool"}async isSupported(){let e=this.api.query.Omnipool.Assets,t=await this.api.compatibilityToken;return e.isCompatible(bs.BackwardsCompatible,t)}subscribePoolChange(e){return this.api.query.Omnipool.Assets.watchEntries({at:"best"}).pipe(ys((n,s)=>!s.deltas),Dt(({entries:n})=>n.map(s=>{let[a]=s.args,{hub_reserve:i,shares:r,tradable:o,cap:l,protocol_shares:c}=s.value,p=e.tokens.findIndex(m=>m.id===a);return{...e.tokens[p],cap:l,hubReserves:i,protocolShares:c,shares:r,tradeable:o}})),Dt(n=>{let s=e.tokens.find(a=>a.id===1);return{...e,tokens:[...n,s]}}))}};var nt={};x(nt,{StableMath:()=>A,StableSwap:()=>he,StableSwapClient:()=>ye});import{calculate_in_given_out as Ps,calculate_out_given_in as fs,calculate_amplification as Ts,calculate_add_one_asset as Ss,calculate_liquidity_out_one_asset as xs,calculate_shares as ws,calculate_shares_for_amount as Is,calculate_spot_price_with_fee as vs,pool_account_name as Os,recalculate_peg as As}from"@galacticcouncil/math-stableswap";var A=class{static getPoolAddress(e){return Os(e)}static defaultPegs(e){let t=[];for(let n=0;n<e;n++)t.push(["1","1"]);return t}static calculateAmplification(e,t,n,s,a){return Ts(e,t,n,s,a)}static calculateInGivenOut(e,t,n,s,a,i,r){return Ps(e,t,n,s,a,i,r)}static calculateAddOneAsset(e,t,n,s,a,i,r){return Ss(e,t,n,s,a,i,r)}static calculateSharesForAmount(e,t,n,s,a,i,r){return Is(e,t,n,s,a,i,r)}static calculateOutGivenIn(e,t,n,s,a,i,r){return fs(e,t,n,s,a,i,r)}static calculateLiquidityOutOneAsset(e,t,n,s,a,i,r){return xs(e,t,n,s,a,i,r)}static calculateShares(e,t,n,s,a,i){return ws(e,t,n,s,a,i)}static calculateSpotPriceWithFee(e,t,n,s,a,i,r,o){return vs(e,t,n,s,a,i,r,o)}static recalculatePegs(e,t,n,s,a){let i=As(e,t,n,s,a);return JSON.parse(i)}};var he=class u{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;amplification;id;fee;totalIssuance;static fromPool(e){return new u(e.address,e.tokens,e.maxInRatio,e.maxOutRatio,e.minTradingLimit,e.amplification,e.id,e.fee,e.totalIssuance)}constructor(e,t,n,s,a,i,r,o,l){this.type="Stableswap",this.address=e,this.tokens=t,this.maxInRatio=n,this.maxOutRatio=s,this.minTradingLimit=a,this.amplification=i,this.id=r,this.fee=o,this.totalIssuance=l}validatePair(e,t){return!0}parsePair(e,t){let n=new Map(this.tokens.map(i=>[i.id,i])),s=n.get(e),a=n.get(t);if(s==null)throw new Error("Pool does not contain tokenIn");if(a==null)throw new Error("Pool does not contain tokenOut");return{assetIn:e,assetOut:t,balanceIn:s.balance,balanceOut:a.balance,decimalsIn:s.decimals,decimalsOut:a.decimals,tradeableIn:this.id===e?15:s.tradeable,tradeableOut:this.id===t?15:a.tradeable,assetInEd:s.existentialDeposit,assetOutEd:a.existentialDeposit}}validateAndBuy(e,t,n){let s=this.calculateInGivenOut(e,t),a=this.calculateInGivenOut(e,t,n),i=P.toPct(n.fee),r=[],o=w.isSellAllowed(e.tradeableIn),l=w.isBuyAllowed(e.tradeableOut);return(!o||!l)&&r.push("TradeNotAllowed"),(t<this.minTradingLimit||s<e.assetInEd)&&r.push("InsufficientTradingAmount"),{amountIn:a,calculatedIn:s,amountOut:t,feePct:i,errors:r}}validateAndSell(e,t,n){let s=this.calculateOutGivenIn(e,t),a=this.calculateOutGivenIn(e,t,n),i=P.toPct(n.fee),r=[],o=w.isSellAllowed(e.tradeableIn),l=w.isBuyAllowed(e.tradeableOut);return(!o||!l)&&r.push("TradeNotAllowed"),(t<this.minTradingLimit||s<e.assetOutEd)&&r.push("InsufficientTradingAmount"),{amountIn:t,calculatedOut:s,amountOut:a,feePct:i,errors:r}}calculateIn(e,t,n){let s=A.calculateInGivenOut(this.getReserves(),Number(e.assetIn),Number(e.assetOut),t.toString(),this.amplification.toString(),n?P.toDecimals(n.fee).toString():"0",this.getPegs()),a=BigInt(s);return a<0n?0n:a}calculateAddOneAsset(e,t,n){let s=A.calculateAddOneAsset(this.getReserves(),t.toString(),Number(e.assetIn),this.amplification.toString(),this.totalIssuance.toString(),n?P.toDecimals(n.fee).toString():"0",this.getPegs()),a=BigInt(s);return a<0n?0n:a}calculateSharesForAmount(e,t,n){let s=A.calculateSharesForAmount(this.getReserves(),Number(e.assetOut),t.toString(),this.amplification.toString(),this.totalIssuance.toString(),n?P.toDecimals(n.fee).toString():"0",this.getPegs()),a=BigInt(s);return a<0n?0n:a}calculateInGivenOut(e,t,n){return e.assetOut==this.id?this.calculateAddOneAsset(e,t,n):e.assetIn==this.id?this.calculateSharesForAmount(e,t,n):this.calculateIn(e,t,n)}spotPriceInGivenOut(e){let t=A.calculateSpotPriceWithFee(this.id.toString(),this.getReserves(),this.amplification.toString(),e.assetOut.toString(),e.assetIn.toString(),this.totalIssuance.toString(),"0",this.getPegs());if(e.assetOut==this.id)return BigInt(t);if(e.assetIn==this.id){let s=Math.pow(10,e.decimalsIn-e.decimalsOut);return BigInt(t)/BigInt(s)}let n=Math.pow(10,18-e.decimalsIn);return BigInt(t)/BigInt(n)}calculateOut(e,t,n){let s=A.calculateOutGivenIn(this.getReserves(),Number(e.assetIn),Number(e.assetOut),t.toString(),this.amplification.toString(),n?P.toDecimals(n.fee).toString():"0",this.getPegs()),a=BigInt(s);return a<0n?0n:a}calculateWithdrawOneAsset(e,t,n){let s=A.calculateLiquidityOutOneAsset(this.getReserves(),t.toString(),Number(e.assetOut),this.amplification.toString(),this.totalIssuance.toString(),n?P.toDecimals(n.fee).toString():"0",this.getPegs()),a=BigInt(s);return a<0n?0n:a}calculateShares(e,t,n){let s=A.calculateShares(this.getReserves(),this.getAssets(e.assetIn,t),this.amplification.toString(),this.totalIssuance.toString(),n?P.toDecimals(n.fee).toString():"0",this.getPegs()),a=BigInt(s);return a<0n?0n:a}calculateOutGivenIn(e,t,n){return e.assetIn==this.id?this.calculateWithdrawOneAsset(e,t,n):e.assetOut==this.id?this.calculateShares(e,t,n):this.calculateOut(e,t,n)}spotPriceOutGivenIn(e){let t=A.calculateSpotPriceWithFee(this.id.toString(),this.getReserves(),this.amplification.toString(),e.assetIn.toString(),e.assetOut.toString(),this.totalIssuance.toString(),"0",this.getPegs());if(e.assetIn==this.id)return BigInt(t);if(e.assetOut==this.id){let s=Math.pow(10,e.decimalsOut-e.decimalsIn);return BigInt(t)/BigInt(s)}let n=Math.pow(10,18-e.decimalsOut);return BigInt(t)/BigInt(n)}getPegs(){let e=A.defaultPegs(this.tokens.length-1);return JSON.stringify(e)}getReserves(){let e=this.tokens.filter(t=>t.id!=this.id).map(({id:t,balance:n,decimals:s})=>({asset_id:t,amount:n,decimals:s}));return JSON.stringify(e,X.jsonFormatter)}getAssets(e,t){let n={asset_id:Number(e),amount:t.toString()};return JSON.stringify([n],X.jsonFormatter)}};import{AccountId as Bs,CompatibilityLevel as _s}from"polkadot-api";import{toHex as Rs}from"@polkadot-api/utils";import{blake2b as Fs}from"@noble/hashes/blake2b";import{map as ks,of as Es,switchMap as Cs}from"rxjs";var Ds=340282366920938463463374607431768211455n,ye=class extends E{poolsData=new Map([]);async loadPools(){let[e,t,n]=await Promise.all([this.api.query.Stableswap.Pools.getEntries(),this.api.query.System.Number.getValue(),this.getPoolLimits()]),s=e.map(async({keyArgs:a,value:i})=>{let[r]=a,o=this.getPoolAddress(r),[l,c,p]=await Promise.all([this.getPoolDelta(r,i,t),this.getPoolTokens(r,i),this.getPoolPegs(r,i,t)]);return this.poolsData.set(o,i),{address:o,id:r,type:"Stableswap",fee:P.fromPermill(i.fee),tokens:c,...l,...p,...n}});return Promise.all(s)}async getPoolDelta(e,t,n){let{initial_amplification:s,final_amplification:a,initial_block:i,final_block:r}=t,o=A.calculateAmplification(s.toString(),a.toString(),i.toString(),r.toString(),n.toString()),l=await this.api.query.Tokens.TotalIssuance.getValue(e);return{amplification:BigInt(o),totalIssuance:l}}async getPoolTokens(e,t){let n=this.getPoolAddress(e),s=t.assets.map(async r=>{let[o,l,c]=await Promise.all([this.api.query.Stableswap.AssetTradability.getValue(e,r),this.api.query.AssetRegistry.Assets.getValue(r),this.getBalance(n,r)]);return{id:r,decimals:l?.decimals,existentialDeposit:l?.existential_deposit,balance:c.transferable,tradeable:o,type:l?.asset_type.type}}),a=await Promise.all(s),i=await this.api.query.AssetRegistry.Assets.getValue(e);return a.push({id:e,decimals:i?.decimals,existentialDeposit:i?.existential_deposit,balance:Ds,tradeable:15,type:i?.asset_type.type}),a}async getPoolPegs(e,t,n){let s=await this.api.query.Stableswap.PoolPegs.getValue(e);if(!s)return this.getDefaultPegs(t);let a=await this.getLatestPegs(t,s,n),i=this.getRecentPegs(s),r=P.fromPermill(s.max_peg_update),o=P.fromPermill(t.fee),[l,c]=A.recalculatePegs(JSON.stringify(i),JSON.stringify(a),n.toString(),P.toDecimals(r).toString(),P.toDecimals(o).toString()),p=Number(l)*1e6;return{pegsFee:P.fromPermill(p),pegs:c}}getDefaultPegs(e){let t=e.fee,n=A.defaultPegs(e.assets.length);return{pegsFee:P.fromPermill(t),pegs:n}}getRecentPegs(e){let{current:t}=e;return Array.from(t.entries()).map(([n,s])=>s.map(a=>a.toString()))}async getLatestPegs(e,t,n){let{source:s}=t,a=Array.from(e.assets.entries()).map(([r,o])=>o),i=s.map(async(r,o)=>{if(r.type==="Oracle"){let[l,c,p]=r.value,g=[p,a[o]].sort((T,S)=>T-S),m=await this.api.query.EmaOracle.Oracles.getValue(l,g,c);if(!m)return;let[{price:b,updated_at:h}]=m,d=b.n.toString(),f=b.d.toString();return p.toString()===g[0].toString()?[[d,f],h.toString()]:[[f,d],h.toString()]}else return[r.value.map(l=>l.toString()),n]});return Promise.all(i)}getPoolAddress(e){let t=A.getPoolAddress(e),n=Fs(t,{dkLen:32}),s=Rs(n);return Bs(63).dec(s)}async getPoolLimits(){return{maxInRatio:0n,maxOutRatio:0n,minTradingLimit:await this.api.constants.Stableswap.MinTradingLimit()}}async getPoolFees(e){return{fee:e.fee}}getPoolType(){return"Stableswap"}async isSupported(){let e=this.api.query.Stableswap.Pools,t=await this.api.compatibilityToken;return e.isCompatible(_s.BackwardsCompatible,t)}subscribePoolChange(e){let t=this.api.query.System.Number,n=this.poolsData.get(e.address);return!n||!e.id?Es(e):t.watchValue("best").pipe(Cs(s=>this.getPoolDelta(e.id,n,s)),ks(s=>Object.assign({},e,s)))}};var st={};x(st,{XykMath:()=>G,XykPool:()=>Pe,XykPoolClient:()=>fe});import{calculate_in_given_out as Ms,calculate_out_given_in as Ls,calculate_pool_trade_fee as qs,get_spot_price as Ns,calculate_liquidity_in as Hs,calculate_shares as Gs,calculate_spot_price as Us,calculate_spot_price_with_fee as Vs,calculate_liquidity_out_asset_a as Ws,calculate_liquidity_out_asset_b as Xs}from"@galacticcouncil/math-xyk";var G=class{static getSpotPrice(e,t,n){return Ns(e,t,n)}static calculateInGivenOut(e,t,n){return Ms(e,t,n)}static calculateOutGivenIn(e,t,n){return Ls(e,t,n)}static calculatePoolTradeFee(e,t,n){return qs(e,t,n)}static calculateLiquidityIn(e,t,n){return Hs(e,t,n)}static calculateSpotPrice(e,t){return Us(e,t)}static calculateSpotPriceWithFee(e,t,n,s){return Vs(e,t,n,s)}static calculateShares(e,t,n){return Gs(e,t,n)}static calculateLiquidityOutAssetA(e,t,n,s){return Ws(e,t,n,s)}static calculateLiquidityOutAssetB(e,t,n,s){return Xs(e,t,n,s)}};var Pe=class u{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;static fromPool(e){return new u(e.address,e.tokens,e.maxInRatio,e.maxOutRatio,e.minTradingLimit)}constructor(e,t,n,s,a){this.type="XYK",this.address=e,this.tokens=t,this.maxInRatio=n,this.maxOutRatio=s,this.minTradingLimit=a}validatePair(e,t){return!0}parsePair(e,t){let n=new Map(this.tokens.map(i=>[i.id,i])),s=n.get(e),a=n.get(t);if(s==null)throw new Error("Pool does not contain tokenIn");if(a==null)throw new Error("Pool does not contain tokenOut");return{assetIn:e,assetOut:t,decimalsIn:s.decimals,decimalsOut:a.decimals,balanceIn:s.balance,balanceOut:a.balance,assetInEd:s.existentialDeposit,assetOutEd:a.existentialDeposit}}validateAndBuy(e,t,n){let s=this.calculateInGivenOut(e,t),a=this.calculateTradeFee(s,n),i=P.toPct(n.exchangeFee),r=s+a,o=[];(t<this.minTradingLimit||s<e.assetInEd)&&o.push("InsufficientTradingAmount");let l=e.balanceOut/this.maxOutRatio;t>l&&o.push("MaxOutRatioExceeded");let c=e.balanceIn/this.maxInRatio;return r>c&&o.push("MaxInRatioExceeded"),{amountIn:r,calculatedIn:s,amountOut:t,feePct:i,errors:o}}validateAndSell(e,t,n){let s=this.calculateOutGivenIn(e,t),a=this.calculateTradeFee(s,n),i=P.toPct(n.exchangeFee),r=s-a,o=[];(t<this.minTradingLimit||s<e.assetOutEd)&&o.push("InsufficientTradingAmount");let l=e.balanceIn/this.maxInRatio;t>l&&o.push("MaxInRatioExceeded");let c=e.balanceOut/this.maxOutRatio;return r>c&&o.push("MaxOutRatioExceeded"),{amountIn:t,calculatedOut:s,amountOut:r,feePct:i,errors:o}}calculateInGivenOut(e,t){let n=G.calculateInGivenOut(e.balanceIn.toString(),e.balanceOut.toString(),t.toString()),s=BigInt(n);return s<0n?0n:s}calculateOutGivenIn(e,t){let n=G.calculateOutGivenIn(e.balanceIn.toString(),e.balanceOut.toString(),t.toString()),s=BigInt(n);return s<0n?0n:s}spotPriceInGivenOut(e){let t=G.calculateSpotPrice(e.balanceOut.toString(),e.balanceIn.toString()),n=Math.pow(10,18-e.decimalsOut);return BigInt(t)/BigInt(n)}spotPriceOutGivenIn(e){let t=G.calculateSpotPrice(e.balanceIn.toString(),e.balanceOut.toString()),n=Math.pow(10,18-e.decimalsIn);return BigInt(t)/BigInt(n)}calculateTradeFee(e,t){let n=G.calculatePoolTradeFee(e.toString(),t.exchangeFee[0],t.exchangeFee[1]);return BigInt(n)}};import{CompatibilityLevel as Ys}from"polkadot-api";import{of as Ks}from"rxjs";var fe=class extends E{async loadPools(){let e=this.api.query.XYK.PoolAssets,[t,n]=await Promise.all([e.getEntries(),this.getPoolLimits()]),s=t.map(async({keyArgs:a,value:i})=>{let[r]=a,[o,l]=i,[c,p,g,m]=await Promise.all([this.getBalance(r,o),this.api.query.AssetRegistry.Assets.getValue(o),this.getBalance(r,l),this.api.query.AssetRegistry.Assets.getValue(l)]);return{address:r,type:"XYK",tokens:[{id:o,decimals:p?.decimals,existentialDeposit:p?.existential_deposit,balance:c.transferable,type:p?.asset_type.type},{id:l,decimals:m?.decimals,existentialDeposit:m?.existential_deposit,balance:g.transferable,type:m?.asset_type.type}],...n}});return Promise.all(s)}async getExchangeFee(){return await this.api.constants.XYK.GetExchangeFee()}async getPoolLimits(){let[e,t,n]=await Promise.all([this.api.constants.XYK.MaxInRatio(),this.api.constants.XYK.MaxOutRatio(),this.api.constants.XYK.MinTradingLimit()]);return{maxInRatio:e,maxOutRatio:t,minTradingLimit:n}}async getPoolFees(){return{exchangeFee:await this.getExchangeFee()}}getPoolType(){return"XYK"}async isSupported(){let e=this.api.query.XYK.PoolAssets,t=await this.api.compatibilityToken;return e.isCompatible(Ys.BackwardsCompatible,t)}subscribePoolChange(e){return Ks(e)}};var at={};x(at,{AavePool:()=>Te,AavePoolClient:()=>Se});var Te=class u{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;static fromPool(e){return new u(e.address,e.tokens,e.maxInRatio,e.maxOutRatio,e.minTradingLimit)}constructor(e,t,n,s,a){this.type="Aave",this.address=e,this.tokens=t,this.maxInRatio=n,this.maxOutRatio=s,this.minTradingLimit=a}validatePair(e,t){return!0}parsePair(e,t){let n=new Map(this.tokens.map(i=>[i.id,i])),s=n.get(e),a=n.get(t);if(s==null)throw new Error("Pool does not contain tokenIn");if(a==null)throw new Error("Pool does not contain tokenOut");return{assetIn:e,assetOut:t,balanceIn:s.balance,balanceOut:a.balance,decimalsIn:s.decimals,decimalsOut:a.decimals,assetInEd:0n,assetOutEd:0n}}validateAndBuy(e,t,n){let s=this.calculateInGivenOut(e,t),a=[];return t>e.balanceOut&&a.push("TradeNotAllowed"),{amountIn:s,calculatedIn:s,amountOut:t,feePct:0,errors:a}}validateAndSell(e,t,n){let s=this.calculateOutGivenIn(e,t),a=[];return s>e.balanceOut&&a.push("TradeNotAllowed"),{amountIn:t,calculatedOut:s,amountOut:s,feePct:0,errors:a}}calculateInGivenOut(e,t){return t}calculateOutGivenIn(e,t){return t}spotPriceInGivenOut(e){let t=Math.pow(10,e.decimalsOut);return BigInt(t)}spotPriceOutGivenIn(e){let t=Math.pow(10,e.decimalsIn);return BigInt(t)}calculateTradeFee(e,t){return 0n}};import{AccountId as js}from"polkadot-api";import{toHex as zs}from"@polkadot-api/utils";import{map as $s,merge as Qs,switchMap as Js}from"rxjs";import{decodeEventLog as Zs}from"viem";var Mt=[{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"},{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"},{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{ERC20:ea}=j,ta=["Supply","Withdraw","Repay","Borrow"],Se=class extends E{async loadPools(){let t=(await this.api.apis.AaveTradeExecutor.pools()).map(async({reserve:n,atoken:s,liqudity_in:a,liqudity_out:i})=>{let[r,o,l,c]=await Promise.all([this.api.query.AssetRegistry.Assets.getValue(n),this.api.query.AssetRegistry.AssetLocations.getValue(n),this.api.query.AssetRegistry.Assets.getValue(s),this.api.query.AssetRegistry.AssetLocations.getValue(s)]);return{address:this.getPoolId(n,s),type:"Aave",tokens:[{id:n,decimals:r?.decimals,existentialDeposit:r?.existential_deposit,balance:a,location:o,type:r?.asset_type.type},{id:s,decimals:l?.decimals,existentialDeposit:l?.existential_deposit,balance:i,location:c,type:l?.asset_type.type}],...this.getPoolLimits()}});return Promise.all(t)}async getPoolDelta(e){let[t,n]=e.tokens,{liqudity_in:s,liqudity_out:a}=await this.api.apis.AaveTradeExecutor.pool(t.id,n.id);return e.tokens.map(i=>{let r=i.id===t.id?s:a;return{...i,balance:r}})}getPoolId(e,t){let n=e+"/"+t,s=new TextEncoder().encode(n.padEnd(32,"\0")),a=zs(s);return js(63).dec(a)}getPoolLimits(){return{maxInRatio:0n,maxOutRatio:0n,minTradingLimit:0n}}async getPoolFees(e,t){return{}}getPoolType(){return"Aave"}async isSupported(){return!0}subscribePoolChange(e){let[t,n]=e.tokens,s=this.getReserveH160Id(t),a=this.api.event.Router.Executed.watch(({asset_in:r,asset_out:o})=>r===n.id||o===n.id),i=this.api.event.EVM.Log.watch(({log:r})=>{let{topics:o,data:l}=r,c=o.map(b=>b.asHex()),p=l.asHex(),{eventName:g,args:m}=Zs({abi:Mt,topics:c,data:p});return ta.includes(g)&&m.reserve.toLowerCase()===s.toLowerCase()});return Qs([a,i]).pipe(Js(()=>this.getPoolDelta(e)),$s(r=>({...e,tokens:[...r]})))}getReserveH160Id(e){return e.type==="Erc20"?X.findNestedKey(e.location,"AccountKey20").AccountKey20.key:ea.fromAssetId(e.id)}};var ee=class{static get(e){switch(e.type){case"Aave":return Te.fromPool(e);case"XYK":return Pe.fromPool(e);case"Omnipool":return ge.fromPool(e);case"LBP":return me.fromPool(e);case"Stableswap":return he.fromPool(e);default:throw new Error("Pool type "+e.type+" is not supported yet")}}};import{Subject as na,Subscription as xe,takeUntil as sa}from"rxjs";var te=class extends B{lbpClient;omniClient;stableClient;xykClient;aaveClient;active=new Set([]);clients=[];pools=new Map([]);lbpSub=xe.EMPTY;omniSub=xe.EMPTY;stableSub=xe.EMPTY;xykSub=xe.EMPTY;aaveSub=xe.EMPTY;isReady=!1;isDestroyed=new na;constructor(e){super(e),this.lbpClient=new de(e),this.omniClient=new be(e),this.stableClient=new ye(e),this.xykClient=new fe(e),this.aaveClient=new Se(e),this.clients=[this.lbpClient,this.omniClient,this.stableClient,this.xykClient,this.aaveClient]}subscribe(e){return e.getSubscriber().pipe(sa(this.isDestroyed)).subscribe(t=>{this.pools.set(t.address,t)})}withOmnipool(){return this.omniSub.unsubscribe(),this.omniSub=this.subscribe(this.omniClient),this.active.add("Omnipool"),this}withStableswap(){return this.stableSub.unsubscribe(),this.stableSub=this.subscribe(this.stableClient),this.active.add("Stableswap"),this}withLbp(){return this.lbpSub.unsubscribe(),this.lbpSub=this.subscribe(this.lbpClient),this.active.add("LBP"),this}withAave(){return this.aaveSub.unsubscribe(),this.aaveSub=this.subscribe(this.aaveClient),this.active.add("Aave"),this}withXyk(e){return this.xykClient.withOverride(e),this.xykSub.unsubscribe(),this.xykSub=this.subscribe(this.xykClient),this.active.add("XYK"),this}destroy(){this.isDestroyed.next(!0),this.isDestroyed.complete(),this.active.clear(),this.pools.clear(),this.isReady=!1}async getPools(e={}){if(this.active.size===0)throw new Error("No pools selected");if(this.isReady)return Array.from(this.pools.values());let{useOnly:t=[],exclude:n=[]}=e,s=new Set(t),a=new Set(n),i=async r=>{let o=r.getPoolType();return s.size>0?s.has(o):a.size>0?!a.has(o):r.isSupported()};return this.getFilteredPools(i)}async getFilteredPools(e){let t=await Promise.all(this.clients.map(e)),n=this.clients.filter((a,i)=>t[i]);return(await Promise.all(n.map(a=>a.getPoolsMem()))).flat()}async getPoolFees(e,t){let n=this.clients.find(s=>s.getPoolType()===e.type);if(n)return n.getPoolFees(e,t);throw new ue(e.type)}};var Gt={};x(Gt,{DEFAULT_BLOCK_TIME:()=>qt,DEFAULT_MIN_BUDGET:()=>ot,ORDER_MIN_BLOCK_PERIOD:()=>Nt,Router:()=>ne,TWAP_BLOCK_PERIOD:()=>Oe,TWAP_MAX_DURATION:()=>ct,TWAP_MAX_PRICE_IMPACT:()=>lt,TWAP_TX_MULTIPLIER:()=>Fc,TradeOrderError:()=>it,TradeOrderType:()=>Le,TradeRouteBuilder:()=>C,TradeRouter:()=>se,TradeScheduler:()=>ae,TradeType:()=>Me});var we=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 aa=8,Ie=class{isNotVisited(e,t){let n=!0;return t.forEach(s=>{(s[0]===e[0]||s[1]===e[1])&&(n=!1)}),n}findPaths(e,t,n){let s=[],a=new we,i=[];for(i.push([t,""]),a.enqueue(i);a.size()>0;){let r=a.dequeue();if(!r||r.length>aa)continue;let o=r[r.length-1];(n===null||o[0]===n)&&s.push(r),e.get(o[0])?.forEach(c=>{if(this.isNotVisited(c,r)){let p=[...r];p.push(c),a.enqueue(p)}})}return s}findShortestPaths(e,t,n){let s=[],a=new we,i=[];i.push([t,""]),a.enqueue(i);let r=1/0;for(;a.size()>0;){let o=a.dequeue();if(!o)continue;let l=o[o.length-1];if(l[0]===n){o.length<r?(r=o.length,s.length=0,s.push(o)):o.length===r&&s.push(o);continue}let c=e.get(l[0]);for(let p of c??[])this.isNotVisited(p,o)&&a.enqueue([...o,p])}return s}buildAndPopulateGraph(e,t){let n=new Map;for(let s of e)n.set(parseInt(s),[]);for(let[s,a,i]of t)n.get(a)?.push([i,s]);return n}};function rt(u){let e={};for(let t of u){let n=t.tokens.length;for(let s=0;s<n;s++){e[t.tokens[s].id]||(e[t.tokens[s].id]=[]);for(let a=0;a<n;a++){if(s==a)continue;let i=[t.address,t.tokens[s].id,t.tokens[a].id];e[t.tokens[s].id].push(i)}}}return e}var ve=class{getProposals(e,t,n){let s=n.filter(d=>d.type==="XYK"),a=n.filter(d=>d.type!=="XYK"),i=new Set(a.map(d=>d.tokens).flat().map(d=>d.id)),r=i.has(e),o=i.has(t),l=new Ie,c=d=>{let f=rt(d),T=Object.keys(f),S=T.flatMap(v=>f[v]);return l.buildAndPopulateGraph(T,S)};if(!r&&!o){let d=s.filter(S=>S.tokens.find(v=>v.id===e)||S.tokens.find(v=>v.id===t)),f=c(d),T=l.findPaths(f,e,t);return this.parsePaths(T)}if(r&&o){let d=c(a),f=l.findPaths(d,e,t);return this.parsePaths(f)}let p=r?t:e,g=s.filter(d=>d.tokens.some(f=>f.id===p));if(g.length===0)return[];let m=[...a,...g],b=c(m),h=l.findPaths(b,e,t);return this.parsePaths(h)}parsePaths(e){let t=[];for(let n of e){let s=[];for(let a=0;a<n.length;a++){let i=n[a],r=n[a+1];if(r==null)break;s.push(this.toEdge(i,r))}t.push(s)}return t}toEdge(e,t){return[t[1],e[0],t[0]]}};var ne=class{routeSuggester;routeProposals;routerOptions;ctx;constructor(e,t={}){this.ctx=e,this.routeSuggester=new ve,this.routeProposals=new Map,this.routerOptions=Object.freeze(t)}buildRouteKey(e,t,n){return`${e}->${t}::${n.length}`}async getPools(){return this.ctx.getPools(this.routerOptions)}async getRoutes(e,t){let n=await this.getPools();return this.validateInput(e,t,n),this.getPaths(e,t,n)}async getTradeableAssets(){let e=await this.getPools(),t=this.getAssets(e);return Array.from(t)}async getRouteableAssets(e){let t=await this.getTradeableAssets();return(await Promise.all(t.filter(s=>s!==e).map(s=>this.getRoutes(s,e)))).filter(s=>s.length>0).map(([s])=>s[0].assetIn).sort()}validateInput(e,t,n){if(n.length===0)throw new Error("No pools configured");if(e===t)throw new Error("Trading pair can't be identical");let s=this.getAssets(n);if(!s.has(e))throw new Error(e+" is not supported asset");if(!s.has(t))throw new Error(t+" is not supported asset");return this.toPoolsMap(n)}getAssets(e){let t=e.map(n=>n.tokens.map(s=>s.id)).flat().sort((n,s)=>n>s?1:-1);return new Set(t)}getPaths(e,t,n){let s=this.toPoolsMap(n);return this.getProposals(e,t,n).filter(i=>this.validPath(i,s)).map(i=>this.toHops(i,s))}getProposals(e,t,n){let s=this.buildRouteKey(e,t,n);if(this.routeProposals.has(s))return this.routeProposals.get(s);let a=this.routeSuggester.getProposals(e,t,n);return this.routeProposals.set(s,a),a}validPath(e,t){return e.length>0&&e.map(n=>this.validEdge(n,t)).reduce((n,s)=>n&&s)}validEdge([e,t,n],s){return s.get(e)?.validatePair(t,n)||!1}toPoolsMap(e){return new Map(e.map(t=>[t.address,ee.get(t)]))}toHops(e,t){return e.map(([n,s,a])=>{let i=t.get(n);return{poolAddress:n,poolId:i?.id,pool:i?.type,assetIn:s,assetOut:a}})}};var Me=(t=>(t.Buy="Buy",t.Sell="Sell",t))(Me||{}),Le=(n=>(n.Dca="Dca",n.TwapSell="TwapSell",n.TwapBuy="TwapBuy",n))(Le||{}),it=(n=>(n.OrderTooSmall="OrderTooSmall",n.OrderTooBig="OrderTooBig",n.OrderImpactTooBig="OrderImpactTooBig",n))(it||{});var se=class extends ne{mlr;poolsSnapshot;constructor(e,t={}){super(e,t),this.mlr=new Map}buildCtxSync(e,t){let n=this.poolsSnapshot,s=super.validateInput(e,t,n),a=super.getPaths(e,t,n);if(!a.length)throw new pe(e,t);return{paths:a,pools:n,poolsMap:s}}async withCtx(e,t,n){this.poolsSnapshot||(this.poolsSnapshot=await super.getPools());let s=this.buildCtxSync(e,t);return n(s)}isDirectTrade(e){return e.length==1}findBestSellRoute(e){let t=e.sort((n,s)=>{let a=n[n.length-1].amountOut,i=s[s.length-1].amountOut;return a>i?-1:1});return t.find(n=>n.every(s=>s.errors.length==0))||t[0]}getRouteFeeRange(e){if(e.filter(n=>n.tradeFeeRange).length>0){let n=e.map(a=>a.tradeFeeRange?.[0]??a.tradeFeePct).reduce((a,i)=>a+i),s=e.map(a=>a.tradeFeeRange?.[1]??a.tradeFeePct).reduce((a,i)=>a+i);return[n,s]}}getPoolFeeRange(e){let t=e.min?P.toPct(e.min):void 0,n=e.max?P.toPct(e.max):void 0;if(t&&n)return[t,n]}async getBestSell(e,t,n){return this.getSell(e,t,n)}getSellSpot(e){let t=e[e.length-1];if(e.length===1)return t.spotPrice;let n=e.map(r=>r.assetOutDecimals).reduce((r,o)=>r+o),s=e.map(r=>r.spotPrice).reduce((r,o)=>r*o),a=n-t.assetOutDecimals,i=Math.pow(10,a);return s/BigInt(i)}async getSell(e,t,n,s){return this.withCtx(e,t,async({paths:a,poolsMap:i})=>{let r;if(s)r=await this.toSellSwaps(n,s,i);else{let o=a.map(c=>this.toSellSwaps(n,c,i)),l=await Promise.all(o);r=this.findBestSellRoute(l)}return this.buildSell(i,r)})}buildSell(e,t){let n=t[0],s=t[t.length-1],a=this.isDirectTrade(t),i=this.getSellSpot(t),r=s.amountOut,o=a?s.calculatedOut:this.calculateDelta0Y(n.amountIn,t,e),l=o-r,c=this.getRouteFeeRange(t),p=a?s.tradeFeePct:I.calculateSellFee(o,r),g=Math.pow(10,n.assetInDecimals),m=n.amountIn*i/BigInt(g),b=I.calculateDiffToRef(o,m);return{type:"Sell",amountIn:n.amountIn,amountOut:s.amountOut,spotPrice:i,tradeFee:l,tradeFeePct:p,tradeFeeRange:c,priceImpactPct:b,swaps:t,toHuman(){return{type:"Sell",amountIn:y.toDecimal(n.amountIn,n.assetInDecimals),amountOut:y.toDecimal(s.amountOut,s.assetOutDecimals),spotPrice:y.toDecimal(i,s.assetOutDecimals),tradeFee:y.toDecimal(l,s.assetOutDecimals),tradeFeePct:p,tradeFeeRange:c,priceImpactPct:b,swaps:t.map(h=>h.toHuman())}}}}calculateDelta0Y(e,t,n){let s=[];for(let a=0;a<t.length;a++){let i=t[a],r=n.get(i.poolAddress);if(r==null)throw new Error("Pool does not exit");let o=r.parsePair(i.assetIn,i.assetOut),l;a>0?l=s[a-1]:l=e;let c=r.calculateOutGivenIn(o,l);s.push(c)}return s[s.length-1]}async calculateMostLiquidRoute(e,t,n){let{paths:s,pools:a,poolsMap:i}=n,l=a.filter(h=>h.tokens.some(d=>d.id===e)).map(h=>h.type==="Aave"?h.tokens:h.tokens.filter(d=>d.id===e)).map(h=>h.map(d=>d.balance).reduce((d,f)=>d+f)).sort((h,d)=>d<h?-1:1)[0],c=I.getFraction(l,.1),p=await Promise.all(s.map(h=>this.toSellSwaps(c,h,i))),m=this.findBestSellRoute(p).map(h=>({poolAddress:h.poolAddress,poolId:h?.poolId,pool:h.pool,assetIn:h.assetIn,assetOut:h.assetOut})),b=this.buildRouteKey(e,t,a);return this.mlr.set(b,m),m}async toSellSwaps(e,t,n){let s=[];for(let a=0;a<t.length;a++){let i=t[a],r=n.get(i.poolAddress);if(r==null)throw new Error("Pool does not exit");let o=r.parsePair(i.assetIn,i.assetOut),l;a>0?l=s[a-1].amountOut:l=typeof e=="string"?y.toBigInt(e,o.decimalsIn):e;let c=await this.ctx.getPoolFees(r,o.assetOut),{amountOut:p,calculatedOut:g,feePct:m,errors:b}=r.validateAndSell(o,l,c),h=this.getPoolFeeRange(c),d=r.spotPriceOutGivenIn(o),f=Math.pow(10,o.decimalsIn),T=l*d/BigInt(f),S=I.calculateDiffToRef(g,T);s.push({...i,assetInDecimals:o.decimalsIn,assetOutDecimals:o.decimalsOut,amountIn:l,amountOut:p,calculatedOut:g,spotPrice:d,tradeFeePct:m,tradeFeeRange:h,priceImpactPct:S,errors:b,isSupply(){return r.type==="Aave"&&r.tokens[0].id===i.assetIn},isWithdraw(){return r.type==="Aave"&&r.tokens[1].id===i.assetIn},toHuman(){return{...i,amountIn:y.toDecimal(l,o.decimalsIn),amountOut:y.toDecimal(p,o.decimalsOut),calculatedOut:y.toDecimal(g,o.decimalsOut),spotPrice:y.toDecimal(d,o.decimalsOut),tradeFeePct:m,tradeFeeRange:h,priceImpactPct:S,errors:b}}})}return s}async getMostLiquidRoute(e,t){return this.withCtx(e,t,async n=>{let s=this.buildRouteKey(e,t,n.pools),a=this.mlr.get(s);return a||this.calculateMostLiquidRoute(e,t,n)})}async getSpotPrice(e,t){return this.withCtx(e,t,async n=>{let{pools:s,poolsMap:a}=n,i=this.buildRouteKey(e,t,s),r=this.mlr.get(i);r||(r=await this.calculateMostLiquidRoute(e,t,n));let o=await this.toSellSwaps("1",r,a),l=this.getSellSpot(o),c=o[o.length-1].assetOutDecimals;return{amount:l,decimals:c}})}findBestBuyRoute(e){let t=e.sort((n,s)=>{let a=n[0].amountIn,i=s[0].amountIn;return a>i?1:-1});return t.find(n=>n.every(s=>s.errors.length==0))||t[0]}async getBestBuy(e,t,n){return this.getBuy(e,t,n)}getBuySpot(e){let t=e[0];if(e.length===1)return t.spotPrice;let n=e.map(r=>r.assetInDecimals).reduce((r,o)=>r+o),s=e.map(r=>r.spotPrice).reduce((r,o)=>r*o),a=n-t.assetInDecimals,i=Math.pow(10,a);return s/BigInt(i)}async getBuy(e,t,n,s){return this.withCtx(e,t,async({paths:a,poolsMap:i})=>{let r;if(s)r=await this.toBuySwaps(n,s,i);else{let o=a.map(c=>this.toBuySwaps(n,c,i)),l=await Promise.all(o);r=this.findBestBuyRoute(l)}return this.buildBuy(i,r)})}buildBuy(e,t){let n=t[t.length-1],s=t[0],a=this.isDirectTrade(t),i=this.getBuySpot(t),r=s.amountIn,o=a?s.calculatedIn:this.calculateDelta0X(n.amountOut,t,e),l=r-o,c=this.getRouteFeeRange(t),p=a?s.tradeFeePct:I.calculateBuyFee(o,r),g=Math.pow(10,n.assetOutDecimals),m=n.amountOut*i/BigInt(g),b;return o===0n?b=-100:b=I.calculateDiffToRef(m,o),{type:"Buy",amountOut:n.amountOut,amountIn:s.amountIn,spotPrice:i,tradeFee:l,tradeFeePct:p,tradeFeeRange:c,priceImpactPct:b,swaps:t,toHuman(){return{type:"Buy",amountOut:y.toDecimal(n.amountOut,n.assetOutDecimals),amountIn:y.toDecimal(s.amountIn,s.assetInDecimals),spotPrice:y.toDecimal(i,s.assetInDecimals),tradeFee:y.toDecimal(l,s.assetInDecimals),tradeFeePct:p,tradeFeeRange:c,priceImpactPct:b,swaps:t.map(h=>h.toHuman())}}}}calculateDelta0X(e,t,n){let s=[];for(let a=t.length-1;a>=0;a--){let i=t[a],r=n.get(i.poolAddress);if(r==null)throw new Error("Pool does not exit");let o=r.parsePair(i.assetIn,i.assetOut),l;a==t.length-1?l=e:l=s[0];let c=r.calculateInGivenOut(o,l);s.unshift(c)}return s[0]}async toBuySwaps(e,t,n){let s=[];for(let a=t.length-1;a>=0;a--){let i=t[a],r=n.get(i.poolAddress);if(r==null)throw new Error("Pool does not exit");let o=r.parsePair(i.assetIn,i.assetOut),l;a==t.length-1?l=typeof e=="string"?y.toBigInt(e,o.decimalsOut):e:l=s[0].amountIn;let c=await this.ctx.getPoolFees(r,o.assetOut),{amountIn:p,calculatedIn:g,feePct:m,errors:b}=r.validateAndBuy(o,l,c),h=this.getPoolFeeRange(c),d=r.spotPriceInGivenOut(o),f=Math.pow(10,o.decimalsOut),T=l*d/BigInt(f),S;g===0n?S=-100:S=I.calculateDiffToRef(T,g),s.unshift({...i,assetInDecimals:o.decimalsIn,assetOutDecimals:o.decimalsOut,amountOut:l,amountIn:p,calculatedIn:g,spotPrice:d,tradeFeePct:m,tradeFeeRange:h,priceImpactPct:S,errors:b,isSupply(){return r.type==="Aave"&&r.tokens[0].id===i.assetIn},isWithdraw(){return r.type==="Aave"&&r.tokens[1].id===i.assetIn},toHuman(){return{...i,amountOut:y.toDecimal(l,o.decimalsOut),amountIn:y.toDecimal(p,o.decimalsIn),calculatedIn:y.toDecimal(g,o.decimalsIn),spotPrice:y.toDecimal(d,o.decimalsIn),tradeFeePct:m,tradeFeeRange:h,priceImpactPct:S,errors:b}}})}return s}};var qt=6e3,ot=1000000000000000n,Oe=6,lt=-5,ct=216e5,Fc=3,Nt=6;import{Enum as Ht}from"polkadot-api";var C=class{static build(e){return e.map(({assetIn:t,assetOut:n,pool:s,poolId:a})=>s==="Stableswap"?{pool:Ht("Stableswap",a),asset_in:t,asset_out:n}:{pool:Ht(s),asset_in:t,asset_out:n})}};var ae=class{schedulerOptions;router;constructor(e,t={}){this.router=e,this.schedulerOptions=Object.freeze({blockTime:t.blockTime??6e3,minBudgetInNative:t.minBudgetInNative??ot})}get blockTime(){return this.schedulerOptions.blockTime}get minOrderBudget(){return this.schedulerOptions.minBudgetInNative}async getDcaOrder(e,t,n,s,a){let[i,r]=await Promise.all([this.getMinimumOrderBudget(e),this.router.getBestSell(e,t,n)]),{amountIn:o,swaps:l,priceImpactPct:c}=r,p=l[0],g=l[l.length-1],{assetInDecimals:m}=p,{assetOutDecimals:b}=g,h=Math.abs(c),d=this.getMinimumTradeCount(o,i),f=this.getOptimalTradeCount(h),T=a?Math.round(s/a):f,S=Math.ceil(s/d),v=Math.round(s/f),D=Math.round(s/T),N=o/BigInt(T),_=await this.router.getBestSell(e,t,N),U=o<i,_e=[];U&&_e.push("OrderTooSmall");let Re=_.amountOut*BigInt(T),He=this.toBlockPeriod(D),Ge=_.tradeFee*BigInt(T),zt=C.build(l),pt={assetIn:e,assetOut:t,errors:_e,frequencyMin:S,frequencyOpt:v,frequency:D,tradeCount:T,tradeFee:Ge,tradeImpactPct:_.priceImpactPct,tradePeriod:He,tradeRoute:zt,type:"Dca"};return{...pt,amountIn:o,amountOut:Re,tradeAmountIn:_.amountIn,tradeAmountOut:_.amountOut,toHuman(){return{...pt,amountIn:y.toDecimal(o,m),amountOut:y.toDecimal(Re,b),tradeAmountIn:y.toDecimal(_.amountIn,m),tradeAmountOut:y.toDecimal(_.amountOut,b)}}}}async getMinimumOrderBudget(e){if(0===e)return this.minOrderBudget;let t=await this.router.getSpotPrice(0,e),n=10n**BigInt(12);if(t)return this.minOrderBudget*t.amount/n;throw new Error("Unable to calculate order budget")}getMinimumTradeCount(e,t){let n=t*2n/10n;if(n===0n)return 0;let s=e+n/2n;return Number(s/n)}getOptimalTradeCount(e){let t=Math.round(e*10)||1;return Math.max(t,3)}async getTwapSellOrder(e,t,n){let[s,a]=await Promise.all([this.getMinimumOrderBudget(e),this.router.getBestSell(e,t,n)]),{amountIn:i,swaps:r,priceImpactPct:o}=a,l=r[0],c=r[r.length-1],{assetInDecimals:p}=l,{assetOutDecimals:g}=c,m=Math.abs(o),b=this.getTwapTradeCount(m),h=i/BigInt(b),d=await this.router.getBestSell(l.assetIn,c.assetOut,h),f=b===1,T=i<s,S=d.priceImpactPct<-5,v=[];T||f?v.push("OrderTooSmall"):S&&v.push("OrderImpactTooBig");let D=d.amountOut*BigInt(b),N=d.tradeFee*BigInt(b),_=C.build(r),U={assetIn:e,assetOut:t,errors:v,tradeCount:b,tradeImpactPct:d.priceImpactPct,tradePeriod:6,tradeRoute:_,type:"TwapSell"};return{...U,amountIn:i,amountOut:D,tradeAmountIn:d.amountIn,tradeAmountOut:d.amountOut,tradeFee:N,toHuman(){return{...U,amountIn:y.toDecimal(i,p),amountOut:y.toDecimal(D,g),tradeAmountIn:y.toDecimal(d.amountIn,p),tradeAmountOut:y.toDecimal(d.amountOut,g),tradeFee:y.toDecimal(N,g)}}}}async getTwapBuyOrder(e,t,n){let[s,a]=await Promise.all([this.getMinimumOrderBudget(e),this.router.getBestBuy(e,t,n)]),{amountOut:i,swaps:r,priceImpactPct:o}=a,l=r[0],c=r[r.length-1],{assetInDecimals:p}=l,{assetOutDecimals:g}=c,m=Math.abs(o),b=this.getTwapTradeCount(m),h=i/BigInt(b),d=await this.router.getBestBuy(l.assetIn,c.assetOut,h),f=d.amountIn*BigInt(b),T=b===1,S=f<s,v=d.priceImpactPct<-5,D=[];S||T?D.push("OrderTooSmall"):v&&D.push("OrderImpactTooBig");let N=d.tradeFee*BigInt(b),_=C.build(r),U={assetIn:e,assetOut:t,errors:D,tradeCount:b,tradeImpactPct:d.priceImpactPct,tradePeriod:6,tradeRoute:_,type:"TwapBuy"};return{...U,amountIn:f,amountOut:i,tradeAmountIn:d.amountIn,tradeAmountOut:d.amountOut,tradeFee:N,toHuman(){return{...U,amountIn:y.toDecimal(f,p),amountOut:y.toDecimal(i,g),tradeAmountIn:y.toDecimal(d.amountIn,p),tradeAmountOut:y.toDecimal(d.amountOut,g),tradeFee:y.toDecimal(N,p)}}}}getTwapTradeCount(e){let t=this.getOptimalTradeCount(e);if(this.getTwapExecutionTime(t)>216e5){let s=216e5/(this.blockTime*6);return Math.round(s)}return t}getTwapExecutionTime(e){return e*6*this.blockTime}toBlockPeriod(e){let t=e/this.blockTime,n=Math.round(t);return Math.max(n,6)}};var Xt={};x(Xt,{BIG_10:()=>Vt,BIG_BILL:()=>Wt,StakingApi:()=>Ae,StakingClient:()=>Be});import{encodeAddress as ra}from"@polkadot/util-crypto";import{stringToU8a as ia}from"@polkadot/util";import{calculate_accumulated_rps as oa,calculate_period_number as Ut,calculate_rewards as la}from"@galacticcouncil/math-staking";import re from"big.js";var Vt=re(10),Wt=re(Vt.pow(12));function ca(u){return ra(ia(("modl"+u).padEnd(32,"\0")),63)}var Ae=class{client;balanceClient;constructor(e,t){this.client=e,this.balanceClient=t}async getTransferablePotBalance(){let e=await this.client.getPalletId(),t=ca(e);return(await this.balanceClient.getBalance(t,0)).transferable}async getStakingPosition(e){let[t,n]=await Promise.all([this.client.getStakingPositionsValue(e),this.client.getStakingVotes(e)]),s=t?.created_at,a=await n.reduce(async(i,[r,o])=>{let l=await i,c=r,p=o.amount,g=o.conviction.toString(),m=await this.client.getReferendumInfo(c);return m&&(m.type==="Approved"||m.type==="Rejected")&&l.push({id:c,amount:p,conviction:g}),l},Promise.resolve([]));return{stake:t?.stake,rewardPerStake:t?.reward_per_stake,createdAt:s,actionPoints:t?.action_points,accumulatedUnpaidRewards:t?.accumulated_unpaid_rewards,accumulatedSlashPoints:t?.accumulated_slash_points,accumulatedLockedRewards:t?.accumulated_locked_rewards,votes:a}}async getStake(e){let t=await this.client.getNFTCollectionId(),[n,s]=await Promise.all([this.client.getStaking(),this.client.getUniques(e,t)]),a=s.find(i=>i)?.itemId;return{totalStake:n?.total_stake,accumulatedRewardPerStake:n?.accumulated_reward_per_stake,potReservedBalance:n?.pot_reserved_balance,positionId:a,stakePosition:a?await this.getStakingPosition(a):void 0}}async getRewards(e,t){let n=await this.getStake(e),{potReservedBalance:s,accumulatedRewardPerStake:a,totalStake:i,stakePosition:r}=n;if(!r)return;let[o,l,c,p]=await Promise.all([this.getTransferablePotBalance(),this.client.getPeriodLength(),this.client.getUnclaimablePeriods(),this.client.getSixBlockSince()]),g=re(o.toString()).minus(s.toString()),m=a.toString(),b=re(t).plus(1).toString();g.gt(0)&&i>0&&(m=oa(a.toString(),g.toString(),i.toString()));let h=Ut(l.toString(),t,p??b),d=Ut(l.toString(),r.createdAt?.toString()??"",p??b),f=la(m,r.rewardPerStake?.toString()??"",r.stake?.toString()??""),T=re(f).plus(r.accumulatedUnpaidRewards?.toString()||"0").plus(r.accumulatedLockedRewards?.toString()||"0");if(!re(h).minus(d).lte(c.toString()))return T.div(Wt).toString()}};var Be=class extends B{async getPalletId(){let e=this.api.constants.Staking.PalletId;return(await e()).asText()}async getPeriodLength(){let e=this.api.constants.Staking.PeriodLength;return await e()}async getUnclaimablePeriods(){let e=this.api.constants.Staking.UnclaimablePeriods;return await e()}async getNFTCollectionId(){let e=this.api.constants.Staking.NFTCollectionId;return await e()}async getStaking(){return await this.api.query.Staking.Staking.getValue()}async getUniques(e,t){return(await this.api.query.Uniques.Account.getEntries(e,t)).map(({keyArgs:i})=>{let[r,o,l]=i;return{address:r,collectionId:o,itemId:l}})}async getStakingPositionsValue(e){return await this.api.query.Staking.Positions.getValue(e)}async getStakingVotes(e){return await this.api.query.Staking.Votes.getValue(e)}async getReferendumInfo(e){return await this.api.query.Referenda.ReferendumInfoFor.getValue(e)}async getSixBlockSince(){return(await this.api.query.Staking.SixSecBlocksSince.getValue()).toString()}};var jt={};x(jt,{TxBuilderFactory:()=>oe});import{Enum as Kt}from"polkadot-api";function Yt(u){let e=[],t=u;for(;t&&typeof t=="object"&&"type"in t;)e.push(t.type),t=t.value;return e.join(".")}var ie=class extends B{evmClient;balanceClient;aaveUtils;constructor(e,t){super(e),this.evmClient=t??new R,this.balanceClient=new q(e),this.aaveUtils=new Y(this.evmClient)}wrapTx(e,t){return{name:e,get:()=>t,dryRun:n=>this.dryRun(n,t)}}async dispatchWithExtraGas(e){return this.api.tx.Dispatcher.dispatch_with_extra_gas({call:e.decodedCall,extra_gas:We})}async dryRun(e,t){let n=Kt("Signed",e),s=Kt("system",n),i=await this.client.getUnsafeApi().apis.DryRunApi.dry_run_call(s,t.decodedCall),r=i.success&&!i.value.execution_result.success?i.value.execution_result.value.error:null;if(r){let o=Yt(r.value);throw new Error("Dry run execution error!",{cause:o})}return i}isDirectOmnipoolTrade(e){return e.length===1&&e[0].pool==="Omnipool"}};var qe=class extends ie{_trade;_beneficiary;_slippagePct=1;setTrade(e){return this._trade=e,this}withBeneficiary(e){return this._beneficiary=e,this}withSlippage(e){return this._slippagePct=e,this}get trade(){if(!this._trade)throw new Error("Trade not set. Use setTrade().");return this._trade}get beneficiary(){if(!this._beneficiary)throw new Error("Beneficiary not set. Use withBeneficiary().");return this._beneficiary}get slippagePct(){return this._slippagePct}async build(){let{amountIn:e,swaps:t,type:n}=this.trade;if(n==="Buy")return this.buildBuyTx();let{assetIn:s}=t[0],a=await this.balanceClient.getBalance(this.beneficiary,s);return e>=a.transferable-5n?this.buildSellAllTx():this.buildSellTx()}async buildBuyTx(){let{amountIn:e,amountOut:t,swaps:n}=this.trade,s=n[0],a=n[n.length-1],i=I.getFraction(e,this.slippagePct),r=s.assetIn,o=a.assetOut,l=e+i,c;return this.isDirectOmnipoolTrade(n)?c=this.api.tx.Omnipool.buy({asset_in:r,asset_out:o,amount:t,max_sell_amount:l}):c=this.api.tx.Router.buy({asset_in:r,asset_out:o,amount_out:t,max_amount_in:l,route:C.build(n)}),this.wrapTx("RouterBuy",c)}async buildSellTx(){let{amountIn:e,amountOut:t,swaps:n}=this.trade,s=n[0],a=n[n.length-1],i=I.getFraction(t,this.slippagePct),r=s.assetIn,o=a.assetOut,l=t-i,c;return this.isDirectOmnipoolTrade(n)?c=this.api.tx.Omnipool.sell({asset_in:r,asset_out:o,amount:e,min_buy_amount:l}):c=this.api.tx.Router.sell({asset_in:r,asset_out:o,amount_in:e,min_amount_out:l,route:C.build(n)}),s.isWithdraw()&&await this.aaveUtils.hasBorrowPositions(this.beneficiary)&&(c=await this.dispatchWithExtraGas(c)),this.wrapTx("RouterSell",c)}async buildSellAllTx(){let{amountOut:e,swaps:t}=this.trade,n=t[0],s=t[t.length-1],a=I.getFraction(e,this.slippagePct),i=n.assetIn,r=s.assetOut,o=e-a,l=this.api.tx.Router.sell_all({asset_in:i,asset_out:r,min_amount_out:o,route:C.build(t)});return n.isWithdraw()&&await this.aaveUtils.hasBorrowPositions(this.beneficiary)&&(l=await this.dispatchWithExtraGas(l)),this.wrapTx("RouterSellAll",l)}};import{Enum as ut}from"polkadot-api";var Ne=class extends ie{_order;_beneficiary;_maxRetries=3;_slippagePct=1;setOrder(e){return this._order=e,this}withBeneficiary(e){return this._beneficiary=e,this}withMaxRetries(e){return this._maxRetries=e,this}withSlippage(e){return this._slippagePct=e,this}get order(){if(!this._order)throw new Error("Order not set. Use setOrder().");return this._order}get beneficiary(){if(!this._beneficiary)throw new Error("Beneficiary not set. Use withBeneficiary().");return this._beneficiary}get maxRetries(){return this._maxRetries}get slippagePct(){return this._slippagePct}async build(){let{type:e}=this.order;switch(e){case"Dca":return this.buildDcaTx();case"TwapSell":return this.buildTwapSellTx();case"TwapBuy":return this.buildTwapBuyTx();default:throw new Error(`Unsupported TradeOrderType: ${e}`)}}buildDcaTx(){let{amountIn:e,assetIn:t,assetOut:n,tradeAmountIn:s,tradePeriod:a,tradeRoute:i}=this.order,r=this.api.tx.DCA.schedule({schedule:{owner:this.beneficiary,period:a,max_retries:this.maxRetries,total_amount:e,slippage:this.slippagePct*1e4,stability_threshold:void 0,order:ut("Sell",{asset_in:t,asset_out:n,amount_in:s,min_amount_out:0n,route:i})},start_execution_block:void 0});return this.wrapTx("DcaSchedule",r)}buildTwapSellTx(){let{amountIn:e,assetIn:t,assetOut:n,tradeAmountIn:s,tradeAmountOut:a,tradePeriod:i,tradeRoute:r}=this.order,o=I.getFraction(a,this.slippagePct),l=a-o,c=this.api.tx.DCA.schedule({schedule:{owner:this.beneficiary,period:i,max_retries:this.maxRetries,total_amount:e,slippage:this.slippagePct*1e4,stability_threshold:void 0,order:ut("Sell",{asset_in:t,asset_out:n,amount_in:s,min_amount_out:l,route:r})},start_execution_block:void 0});return this.wrapTx("DcaSchedule.twapSell",c)}buildTwapBuyTx(){let{amountIn:e,assetIn:t,assetOut:n,tradeAmountIn:s,tradeAmountOut:a,tradePeriod:i,tradeRoute:r}=this.order,o=I.getFraction(s,this.slippagePct),l=s+o,c=this.api.tx.DCA.schedule({schedule:{owner:this.beneficiary,period:i,max_retries:this.maxRetries,total_amount:e,slippage:this.slippagePct*1e4,stability_threshold:void 0,order:ut("Buy",{asset_in:t,asset_out:n,amount_out:a,max_amount_in:l,route:r})},start_execution_block:void 0});return this.wrapTx("DcaSchedule.twapBuy",c)}};var oe=class{client;evmClient;constructor(e,t){this.client=e,this.evmClient=t??new R}trade(e){return new qe(this.client,this.evmClient).setTrade(e)}order(e){return new Ne(this.client,this.evmClient).setOrder(e)}};async function Gu(u,e){let t=new J(u),[n,s]=await Promise.all([t.getBlockTime(),t.getMinOrderBudget()]),a=e??new R,i=new te(u).withAave().withOmnipool().withStableswap().withXyk(),r=new Y(a),o=new se(i),l=new ae(o,{blockTime:n,minBudgetInNative:s}),c=new q(u),p=new Be(u),g=new Ae(p,c);return{api:{aave:r,router:o,scheduler:l,staking:g},client:{asset:new $(u),balance:c,evm:a},ctx:{pool:i},tx:new oe(u,a),destroy:()=>{i.destroy()}}}export{vt as aave,dt as api,y as big,Bt as client,ft as const,Gu as createSdkContext,j as erc20,_t as error,yt as evm,P as fmt,Ce as h160,X as json,I as math,Lt as pool,Gt as sor,Xt as staking,jt as tx,It as xc};
|
|
1
|
+
var hn=Object.defineProperty;var T=(u,t)=>{for(var e in t)hn(u,e,{get:t[e],enumerable:!0})};var Ae={};T(Ae,{Papi:()=>B,getWs:()=>Tn});import{hydration as Pn}from"@galacticcouncil/descriptors";function Oe(u){switch(u){case!0:case"true":case 1:case"1":case"on":case"yes":return!0;default:return!1}}var B=class{client;api;constructor(t){this.client=t,this.api=this.client.getTypedApi(Pn)}log(t,...e){let n=typeof window>"u"?process.env.GC_DEBUG:window.localStorage.getItem("gc.debug");Oe(n)&&console.log(t,...e)}};import{createClient as fn}from"polkadot-api";import{withPolkadotSdkCompat as Sn}from"polkadot-api/polkadot-sdk-compat";var Tn=async u=>{let t=typeof u=="string"?u.split(","):u,a=(typeof window>"u"?(await import("polkadot-api/ws-provider/node")).getWsProvider:(await import("polkadot-api/ws-provider/web")).getWsProvider)(t);return fn(Sn(a))};var Ce={};T(Ce,{AAVE_GAS_LIMIT:()=>ee,AAVE_LENDING_POOL_ADDRESS:()=>Wt,AAVE_POOL_ABI:()=>Zt,AAVE_POOL_DATA_PROVIDER:()=>Vt,AAVE_POOL_DATA_PROVIDER_ABI:()=>Ut,AAVE_POOL_PROXY:()=>te,AAVE_ROUNDING_THRESHOLD:()=>Xr,AAVE_UINT_256_MAX:()=>xn,AaveClient:()=>ht,AaveUtils:()=>Q});var Zt=[{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 Ut=[{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 te="0x1b02E051683b5cfaC5929C25E84adb26ECf87B38",Vt="0x112b087b60C1a166130d59266363C45F8aa99db0",Wt="0xf3Ba4D1b50f78301BDD7EAEa9B67822A15FCA691",ee=1000000n,Xr=5,xn=BigInt("0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");var ht=class{client;constructor(t){this.client=t.getWsProvider()}async getReservesData(){return await this.client.readContract({abi:Ut,address:Vt,args:[Wt],functionName:"getReservesData"})}async getUserReservesData(t){return await this.client.readContract({abi:Ut,address:Vt,args:[Wt,t],functionName:"getUserReservesData"})}async getUserAccountData(t){return await this.client.readContract({abi:Zt,address:te,args:[t],functionName:"getUserAccountData"})}};var h={};T(h,{asBigInt:()=>vn,toBigInt:()=>In,toDecimal:()=>wn});import z from"big.js";z.NE=-18;function wn(u,t,e=6,n){let a=z(u.toString()),r=z(10).pow(t);return a.div(r).round(e,n).toString()}function In(u,t){let e=z(10).pow(t),a=z(u).mul(e).toFixed(0,z.roundDown);return BigInt(a)}function vn(u){return BigInt(u.round(0,z.roundDown).toFixed(0))}var tt={};T(tt,{ERC20:()=>ne});var ne=class{static fromAssetId(t){let e=Buffer.alloc(20,0);return e[15]=1,e.writeUInt32BE(t,16),"0x"+e.toString("hex")}static toAssetId(t){let e=Buffer.from(t.replace("0x",""),"hex");return e.length!==20||!this.isAssetAddress(t)?null:e.readUInt32BE(16)}static isAssetAddress(t){let e=Buffer.from("0000000000000000000000000000000100000000","hex"),n=Buffer.from(t.replace("0x",""),"hex");return n.length!==20?!1:n.subarray(0,16).equals(e.subarray(0,16))}};var R={};T(R,{FeeUtils:()=>ie,shiftNeg:()=>ft});import Bn from"big.js";var Be={};T(Be,{HUB_ASSET_ID:()=>se,HYDRATION_OMNIPOOL_ADDRESS:()=>An,HYDRATION_PARACHAIN_ID:()=>On,HYDRATION_SS58_PREFIX:()=>k,PERBILL_DENOMINATOR:()=>ae,PERMILL_DENOMINATOR:()=>Pt,RUNTIME_DECIMALS:()=>I,SYSTEM_ASSET_DECIMALS:()=>re,SYSTEM_ASSET_ID:()=>G,TRADEABLE_DEFAULT:()=>et});var I=18,Pt=1e6,ae=1e9,G=0,re=12,On=2034,k=63,An="7L53bUTBbfuj14UpdCNPwmgzzHSsrsTWBHX5pys32mVWM3C1",se=1,et=15;var ie=class u{static toPct(t){let[e,n]=t;return u.safeDivide(e*100,n)}static toRaw(t){let[e,n]=t;return u.safeDivide(e,n)}static fromPermill(t){return[t,1e6]}static fromPerbill(t){return[t,1e9]}static fromRate(t,e){return[t,e]}static safeDivide(t,e,n=12){let a=10**n;return Math.round(t*a/e)/a}static safeRound(t){return parseFloat(t.toPrecision(15))}};function ft(u,t){let e=Bn(typeof u=="bigint"?u.toString():u);return t===0?e.toString():e.div(Math.pow(10,t)).toString()}var Yt={};T(Yt,{H160:()=>le,isEvmAccount:()=>Re,isEvmAddress:()=>Fe,isSs58Address:()=>Ee});import{AccountId as St}from"polkadot-api";import{toHex as _e}from"@polkadot-api/utils";import{Buffer as Y}from"buffer";var oe="ETH\0";function Re(u){if(!u)return!1;try{let t=St().enc(u),e=Y.from(oe);return Y.from(t.subarray(0,e.length)).equals(e)}catch{return!1}}function Fe(u){return!!/^0x[a-fA-F0-9]{40}$/.test(u)}function Ee(u){try{return St(63).enc(u),!0}catch{return!1}}var le=class u{static toAccount=t=>{let e=Y.from(t.slice(2),"hex"),n=Y.from(oe),a=Uint8Array.from(Y.concat([n,e,Y.alloc(8)])),r=_e(a);return St(63).dec(r)};static fromAccount=t=>{let e=St().enc(t),n=Y.from(oe),a=e.slice(n.length,-8);return"0x"+Y.from(a).toString("hex")};static fromSS58=t=>{let n=St().enc(t).slice(0,20);return _e(n)};static fromAny=t=>{if(Fe(t))return t;if(Re(t))return u.fromAccount(t);if(Ee(t))return u.fromSS58(t);throw new Error("Unknown address type")}};var $={};T($,{findNestedKey:()=>_n,findNestedObj:()=>Rn,jsonFormatter:()=>Fn});var _n=(u,t)=>{let e=[];return JSON.stringify(u,(n,a)=>(a&&a[t]&&e.push(a),a)),e[0]},Rn=(u,t,e)=>{let n;return JSON.stringify(u,(a,r)=>(r&&r[t]===e&&(n=r),r)),n},Fn=(u,t)=>typeof t=="bigint"?t.toString():t;var v={};T(v,{calculateBuyFee:()=>Dn,calculateDiffToAvg:()=>En,calculateDiffToRef:()=>kn,calculateSellFee:()=>Cn,getFraction:()=>Mn});import U from"big.js";function En(u,t){let e=U(u.toString()),n=U(t.toString());return e.minus(n).abs().div(e.plus(n).div(2)).mul(100).round(2).toNumber()}function kn(u,t){if(t===0n)return 0;let e=U(u.toString()),n=U(t.toString());return e.minus(n).div(n).mul(100).round(2).toNumber()}function Cn(u,t){let e=U(u.toString()),n=U(t.toString());return U(1).minus(n.div(e)).mul(100).round(2).toNumber()}function Dn(u,t){let e=U(u.toString());return U(t.toString()).div(e).minus(1).mul(100).round(2).toNumber()}function Mn(u,t,e=2){(t<.01||t>100)&&new Error("Supported range is from 0.01% - 100%");let n=Math.pow(10,e),a=BigInt(t*n);return u*a/BigInt(100*n)}var ke={};T(ke,{convertToId:()=>qn});import{Buffer as Ln}from"buffer";function qn(u){let e=Ln.from(u.replace("0x",""),"hex").subarray(16);return e.readUIntBE(0,e.length)}var{ERC20:Xt}=tt,{H160:ce}=Yt,Nn=1.01,Gn=99999,Hn=10n**27n,Un=10n**18n,Q=class{client;constructor(t){this.client=new ht(t)}async getSummary(t){let e=ce.fromAny(t),[n,a,r]=await Promise.all([this.client.getReservesData(),this.client.getUserReservesData(e),this.client.getUserAccountData(e)]),[i]=n,[s,o]=a,[l,c,p,d,m,g]=r,y=h.toDecimal(g,18),b=[];for(let P of s){let f=P.underlyingAsset.toLowerCase(),S=i.find(({underlyingAsset:j})=>j.toLowerCase()===f);if(!S)throw new Error("Missing pool reserve for "+f);let x=P.scaledATokenBalance,F=S.liquidityIndex,C=S.priceInMarketReferenceCurrency,_=x*F/Hn,N=Number(o===S.eModeCategoryId?S.eModeLiquidationThreshold:S.reserveLiquidationThreshold)/1e4,W=S.usageAsCollateralEnabled&&P.usageAsCollateralEnabledOnUser&&P.scaledATokenBalance>0n,bt=Xt.toAssetId(f);b.push({aTokenBalance:_,decimals:Number(S.decimals),isCollateral:W,priceInRef:C,reserveId:bt,reserveAsset:f,reserveLiquidationThreshold:N})}return{healthFactor:Number(y),totalCollateral:l,totalDebt:c,reserves:b}}async hasBorrowPositions(t){let e=ce.fromAny(t),n=await this.client.getUserAccountData(e),[a,r]=n;return r>0n}async getHealthFactor(t){let e=ce.fromAny(t),n=await this.client.getUserAccountData(e),[a,r,i,s,o,l]=n,c=h.toDecimal(l,18);return Number(c)}async getHealthFactorAfterWithdraw(t,e,n){let{totalCollateral:a,totalDebt:r,reserves:i}=await this.getSummary(t),s=Xt.fromAssetId(e),o=i.find(b=>b.reserveAsset===s);if(!o)throw new Error("Missing reserve ctx for "+s);let{decimals:l,isCollateral:c,priceInRef:p,reserveLiquidationThreshold:d}=o,m=h.toBigInt(n,l),g=c?m*p/10n**BigInt(l):0n,y=a-g;return y<=0n?0:this.calculateHealthFactor(y,d,r)}async getHealthFactorAfterSupply(t,e,n){let{totalCollateral:a,totalDebt:r,reserves:i}=await this.getSummary(t),s=Xt.fromAssetId(e),o=i.find(y=>y.reserveAsset===s);if(!o)throw new Error("Missing reserve ctx for "+s);let{decimals:l,priceInRef:c,reserveLiquidationThreshold:p}=o,m=h.toBigInt(n,l)*c/10n**BigInt(l),g=a+m;return g<=0n?0:this.calculateHealthFactor(g,p,r)}async getMaxWithdraw(t,e){let{totalCollateral:n,totalDebt:a,reserves:r}=await this.getSummary(t),i=Xt.fromAssetId(e),s=r.find(o=>o.reserveAsset===i);if(!s)throw new Error("Missing reserve ctx for "+i);return this.calculateWithdrawMax(s,n,a)}async getMaxWithdrawAll(t){let{totalCollateral:e,totalDebt:n,reserves:a}=await this.getSummary(t),r={};for(let i of a){let s=this.calculateWithdrawMax(i,e,n);i.reserveId&&(r[i.reserveId]=s)}return r}calculateHealthFactor(t,e,n){if(n===0n)return Gn;let a=10n**6n,r=h.toBigInt(e,18),i=t*r*a,s=n*Un,o=i/s;return Number(o)/1e6}calculateRequiredCollateral(t,e,n){let a=h.toBigInt(t,18),r=h.toBigInt(e,18);return(a*n+r-1n)/r}calculateWithdrawMax(t,e,n){let{aTokenBalance:a,decimals:r,priceInRef:i,reserveLiquidationThreshold:s}=t,o=this.calculateRequiredCollateral(Nn,s,n),l=e-o;if(l<=0n)return{amount:0n,decimals:r};let c=l*10n**BigInt(r)/i;return{amount:a<c?a:c,decimals:r}}};var qe={};T(qe,{AssetClient:()=>nt,BalanceClient:()=>D,ChainParams:()=>rt,LiquidityMining:()=>Kt});var nt=class extends B{SUPPORTED_TYPES=["StableSwap","Bond","Token","External","Erc20"];constructor(t){super(t)}async queryShares(){let e=await this.api.query.Stableswap.Pools.getEntries();return new Map(e.map(({keyArgs:n,value:a})=>{let[r]=n;return[r,a]}))}async queryBonds(){let e=await this.api.query.Bonds.Bonds.getEntries();return new Map(e.map(({keyArgs:n,value:a})=>{let[r]=n;return[r,a]}))}async queryAssets(){let e=await this.api.query.AssetRegistry.Assets.getEntries();return new Map(e.filter(({value:n})=>{let{asset_type:a}=n;return this.SUPPORTED_TYPES.includes(a.type)}).map(({keyArgs:n,value:a})=>{let[r]=n;return[r,a]}))}async queryAssetLocations(){let e=await this.api.query.AssetRegistry.AssetLocations.getEntries();return new Map(e.map(({keyArgs:n,value:a})=>{let[r]=n;return[r,a]}))}async mapToken(t,e,n,a){let{name:r,asset_type:i,is_sufficient:s,existential_deposit:o}=e,{symbol:l,decimals:c}=n.get(t)??{};return{id:t,name:r?.asText(),symbol:l,decimals:c,icon:l,type:i.type,isSufficient:s,location:a,existentialDeposit:o}}async mapBond(t,e,n,a){let[r,i]=a,{asset_type:s,is_sufficient:o,existential_deposit:l}=e,{symbol:c,decimals:p}=await this.mapToken(r,e,n),d=Number(i),m=new Intl.DateTimeFormat("en-GB"),g=[c,"Bond",m.format(d)].join(" ");return{id:t,name:g,symbol:c+"b",decimals:p,icon:c,type:s.type,isSufficient:o,existentialDeposit:l,underlyingAssetId:r,maturity:d}}async mapShares(t,e,n,a){let{assets:r}=a,{name:i,symbol:s,asset_type:o,is_sufficient:l,existential_deposit:c}=e,p=await Promise.all(r.map(async g=>{let{symbol:y}=await this.mapToken(g,e,n);return[g,y]})),d=Object.fromEntries(p),m=Object.values(d);return{id:t,name:m.join(", "),symbol:s?.asText()||i?.asText(),decimals:18,icon:m.join("/"),type:o.type,isSufficient:l,existentialDeposit:c,meta:d}}async mapExternal(t,e,n,a){let r=await this.mapToken(t,e,new Map,a),i=n?.find(s=>s.internalId===r.id);return i?{...r,decimals:i.decimals,name:i.name,symbol:i.symbol,icon:i.symbol,isWhiteListed:i.isWhiteListed}:r}parseMetadata(t){return new Map(Array.from(t,([e,n])=>[e,{symbol:n.symbol?.asText(),decimals:n.decimals}]))}async getOnChainAssets(t,e){let[n,a,r,i]=await Promise.all([this.queryAssets(),this.queryAssetLocations(),this.queryShares(),this.queryBonds()]),s=this.parseMetadata(n),o=[];for(let[l,c]of Array.from(n)){let p=a.get(l),{asset_type:d}=c,m;switch(d.type){case"Bond":let g=i.get(l);m=await this.mapBond(l,c,s,g);break;case"StableSwap":let y=r.get(l);m=await this.mapShares(l,c,s,y);break;case"External":m=await this.mapExternal(l,c,e,p);break;default:m=await this.mapToken(l,c,s,p)}o.push(m)}return t?o:o.filter(l=>this.isValidAsset(l))}isValidAsset(t){let e=Math.sign(t.decimals);return!!t.symbol&&(e===0||e===1)}};import{Subject as Vn,bufferCount as Wn,combineLatest as Yn,debounceTime as Xn,distinctUntilChanged as De,finalize as Kn,map as at,pairwise as jn,shareReplay as zn,startWith as $n}from"rxjs";var D=class extends B{constructor(t){super(t)}async getBalance(t,e){return e===0?this.getSystemBalance(t):this.getTokenBalanceData(t,e)}async getSystemBalance(t){let e=this.api.query.System.Account,{data:n}=await e.getValue(t);return this.calculateBalance(n)}async getTokenBalance(t,e){let a=await this.api.query.Tokens.Accounts.getValue(t,e);return this.calculateBalance(a)}calculateBalance(t){let e=t.free>=t.frozen?t.free-t.frozen:0n,n=t.free+t.reserved;return{free:t.free,reserved:t.reserved,frozen:t.frozen,total:n,transferable:e}}async getErc20Balance(t,e){return this.getTokenBalanceData(t,e)}subscribeBalance(t){let e=this.subscribeSystemBalance(t),n=this.subscribeTokensBalance(t),a=this.subscribeErc20Balance(t);return Yn([e,n,a]).pipe(Xn(250),at(r=>r.flat()),$n([]),Wn(2,1),at(([r,i],s)=>{if(s===0)return i;let o=r.reduce((c,p)=>(c.set(p.id,p.balance),c),new Map);return i.filter(c=>!Me(c.balance,o.get(c.id)))}))}subscribeSystemBalance(t){return this.api.query.System.Account.watchValue(t,"best").pipe(at(n=>({id:0,balance:this.calculateBalance(n.data)})))}subscribeTokenBalance(t,e){return this.api.query.Tokens.Accounts.watchValue(t,e,"best").pipe(at(a=>({id:e,balance:a})))}subscribeTokensBalance(t){return this.api.query.Tokens.Accounts.watchEntries(t,{at:"best"}).pipe(De((n,a)=>!a.deltas),at(({deltas:n})=>{let a=[];return n?.deleted.forEach(r=>{let[i,s]=r.args;a.push({id:s,balance:this.calculateBalance({free:0n,reserved:0n,frozen:0n})})}),n?.upserted.forEach(r=>{let[i,s]=r.args;a.push({id:s,balance:this.calculateBalance(r.value)})}),a}))}subscribeErc20Balance(t,e){let n=new Vn,a=n.pipe(zn(1)),r=async()=>(await this.api.query.AssetRegistry.Assets.getEntries()).filter(({value:l})=>{let{asset_type:c}=l;return c.type==="Erc20"}).map(({keyArgs:l})=>{let[c]=l;return c}),i=async()=>{let o=e||await r(),l=async()=>{let d=(await Promise.all(o.map(async m=>{let g=await this.getTokenBalanceData(t,m);return[m,g]}))).map(([m,g])=>({id:m,balance:g}));n.next(d)};await l();let c=this.api.query.System.Number.watchValue("best").subscribe(l);return()=>c.unsubscribe()},s;return i().then(o=>s=o),a.pipe(Kn(()=>s?.()),jn(),at(([o,l],c)=>{if(c===0)return l;let p=o.reduce((m,g)=>(m.set(g.id,g.balance),m),new Map);return l.filter(m=>!Me(m.balance,p.get(m.id)))}),De((o,l)=>l.length===0))}async getTokenBalanceData(t,e){let n=await this.api.apis.CurrenciesApi.account(e,t);return this.calculateBalance(n)}},Me=(u,t)=>u!==void 0&&t!==void 0&&u.transferable===t.transferable&&u.total===t.total;var rt=class extends B{_minOrderBudget;_blockTime;constructor(t){super(t)}async getBlockTime(){if(this._blockTime===void 0){let t=await this.api.constants.Aura.SlotDuration();this._blockTime=Number(t)}return this._blockTime}async getMinOrderBudget(){return this._minOrderBudget===void 0&&(this._minOrderBudget=await this.api.constants.DCA.MinBudgetInNativeCurrency()),this._minOrderBudget}};import{AccountId as Qn,Binary as Jn,Enum as Zn}from"polkadot-api";import{fixed_from_rational as Le}from"@galacticcouncil/math-liquidity-mining";import E from"big.js";var ta=BigInt(E(1).pow(18).toString()),ea=6,Kt=class extends B{balanceClient;omnipoolAssetIds=[];secondsInYear=E(365.2425).times(24).times(60).times(60);constructor(t){super(t),this.balanceClient=new D(t)}async getOraclePrice(t,e){let n=[t,e].sort((r,i)=>r-i);if(t===e)return ta;let a=await this.api.query.EmaOracle.Oracles.getValue(Jn.fromText("omnipool"),n,Zn("TenMinutes"));if(a){let{n:r,d:i}=a[0].price,s;return t<e?s=Le(r.toString(),i.toString()):s=Le(i.toString(),r.toString()),BigInt(s)}}getFarmAddress=(t,e)=>{let n=Buffer.from("modl","utf-8"),a=Buffer.from(e?"78796b4c4d704944":"4f6d6e6957684c4d","hex"),r=Buffer.from([t]),i=Buffer.concat([n,a,r]),o="0x"+Buffer.concat([i,Buffer.alloc(32-i.length)]).toString("hex");return Qn(63).dec(o)};getGlobalRewardPerPeriod(t,e,n,a){let r=E(a).times(t.toString()).times(e.toString()).div(18);return r.gte(n.toString())?n.toString():r.toString()}getPoolYieldPerPeriod(t,e,n,a){let r=E(t.toString()).times(e),i=E(n.toString()).times(a);return r.div(i.toString()).toString()}farmData(t,e,n){let{yieldFarm:a,globalFarm:r,priceAdjustment:i,balance:s}=t,{multiplier:o,loyalty_curve:l}=a,{blocks_per_period:c,yield_per_period:p,total_shares_z:d,max_reward_per_period:m,pending_rewards:g,accumulated_paid_rewards:y,planned_yielding_periods:b,updated_at:P,incentivized_asset:f,reward_currency:S,price_adjustment:x}=r,F=ft(i??x,18),C=ft(o,18),_=ft(l?.initial_reward_percentage??0,18),q=this.secondsInYear.div(E(ea).times(c)).toString(),N;if(d<0)N=E(C).times(p.toString()).times(q).toString();else{let bn=this.getGlobalRewardPerPeriod(d,p,m,F),yn=this.getPoolYieldPerPeriod(bn,C,d,F);N=E(yn).times(q).toString()}let W=g+y,bt=m*BigInt(b),j=s.transferable+W,Jt=j-W,yt=E(Jt.toString()).div(m.toString()),Ie=E(e).div(c.toString()).toString(),mn=(d>=0?yt.plus(P):yt.plus(Ie)).toString(),dn=E(d.toString()).div(E(m.toString()).div(p.toString())).div(Math.pow(10,18)).times(100).times(F).toFixed(2),ve=E(W.toString()).div(j.toString()).gte(.999);N=ve?"0":E(N).div(n?2:1).times(100).toString();let gn=_?E(N).times(_).toString():void 0;return{apr:N,minApr:gn,isDistributed:ve,estimatedEndPeriod:mn,maxRewards:bt,incentivizedAsset:f,rewardCurrency:S,loyaltyCurve:l,currentPeriod:Ie,potMaxRewards:j,fullness:dn}}async getOmnipoolFarms(t){let e=await this.api.query.OmnipoolWarehouseLM.ActiveYieldFarm.getEntries(Number(t)),a=(await this.api.query.ParachainSystem.ValidationData.getValue())?.relay_parent_number,r=await Promise.all(e.map(async({keyArgs:i,value:s})=>{let[,o]=i,l=s,c=await this.api.query.OmnipoolWarehouseLM.GlobalFarm.getValue(o),p=await this.api.query.OmnipoolWarehouseLM.YieldFarm.getValue(Number(t),o,l);if(!c||!p)return;let d=c.reward_currency,m=c.incentivized_asset,g=this.getFarmAddress(o),y=await this.getOraclePrice(d,m),b=await this.balanceClient.getTokenBalance(g,d);return{id:t,globalFarm:c,yieldFarm:p,priceAdjustment:y,balance:b}}));return a?r.map(i=>i?this.farmData(i,a):void 0):[]}async getIsolatedFarms(t){let e=await this.api.query.XYKWarehouseLM.ActiveYieldFarm.getEntries(t),a=(await this.api.query.ParachainSystem.ValidationData.getValue())?.relay_parent_number,r=await Promise.all(e.map(async({keyArgs:i,value:s})=>{let[,o]=i,l=s,c=await this.api.query.XYKWarehouseLM.GlobalFarm.getValue(o),p=await this.api.query.XYKWarehouseLM.YieldFarm.getValue(t,o,l);if(!c||!p)return;let d=c.reward_currency,m=c.incentivized_asset,g=this.getFarmAddress(o,!0),y=await this.getOraclePrice(d,m),b=await this.balanceClient.getBalance(g,d);return{id:t,globalFarm:c,yieldFarm:p,priceAdjustment:y,balance:b,farmAddress:g}}));return a?r.map(i=>i?this.farmData(i,a,!0):void 0):[]}};var Ne={};T(Ne,{AssetNotFound:()=>ue,PoolNotFound:()=>Tt,RouteNotFound:()=>xt});var ue=class extends Error{constructor(t){super(),this.message=`${t} not found`,this.name="AssetNotFound"}},Tt=class extends Error{constructor(t){super(),this.message=`${t} pool invalid`,this.name="PoolNotFound"}},xt=class extends Error{constructor(t,e){super(),this.message=`Route from ${t} to ${e} not found in current configuration`,this.name="RouteNotFound"}};var Ue={};T(Ue,{EvmClient:()=>wt,createChain:()=>pe});import{defineChain as na}from"viem";var aa=["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"],pe=()=>na({id:222222,name:"Hydration",network:"hydration",nativeCurrency:{decimals:18,name:"WETH",symbol:"WETH"},rpcUrls:{default:{http:aa}},blockExplorers:{default:{name:"Hydration Explorer",url:"https://explorer.evm.hydration.cloud"}},testnet:!1});import{createPublicClient as Ge,createWalletClient as ra,custom as He,http as sa}from"viem";var wt=class{client;chain;constructor(t){this.client=t,this.chain=pe()}get chainId(){return this.chain.id}get chainCurrency(){return this.chain.nativeCurrency.symbol}get chainDecimals(){return this.chain.nativeCurrency.decimals}getProvider(){return Ge({chain:this.chain,transport:sa()})}getWsProvider(){return Ge({transport:He({request:({method:t,params:e})=>this.client._request(t,e||[])})})}getSigner(t){return ra({account:t,chain:this.chain,transport:He(window.ethereum)})}};var Je={};T(Je,{PoolContextProvider:()=>lt,PoolError:()=>J,PoolFactory:()=>ot,PoolType:()=>O,aave:()=>he,lbp:()=>de,omni:()=>ge,stable:()=>be,xyk:()=>ye});var de={};T(de,{LbpMath:()=>H,LbpPool:()=>It,LbpPoolClient:()=>Ot});import{calculate_in_given_out as ia,calculate_out_given_in as oa,calculate_linear_weights as la,calculate_pool_trade_fee as ca,get_spot_price as ua}from"@galacticcouncil/math-lbp";var H=class{static getSpotPrice(t,e,n,a,r){return ua(t,e,n,a,r)}static calculateInGivenOut(t,e,n,a,r){return ia(t,e,n,a,r)}static calculateOutGivenIn(t,e,n,a,r){return oa(t,e,n,a,r)}static calculateLinearWeights(t,e,n,a,r){return la(t,e,n,a,r)}static calculatePoolTradeFee(t,e,n){return ca(t,e,n)}};var O=(r=>(r.Aave="Aave",r.LBP="LBP",r.Omni="Omnipool",r.Stable="Stableswap",r.XYK="XYK",r))(O||{}),J=(r=>(r.InsufficientTradingAmount="InsufficientTradingAmount",r.MaxInRatioExceeded="MaxInRatioExceeded",r.MaxOutRatioExceeded="MaxOutRatioExceeded",r.TradeNotAllowed="TradeNotAllowed",r.UnknownError="UnknownError",r))(J||{});var{FeeUtils:Ve}=R,It=class u{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;fee;repayFeeApply;static fromPool(t){return new u(t.address,t.tokens,t.maxInRatio,t.maxOutRatio,t.minTradingLimit,t.fee,t.repayFeeApply)}constructor(t,e,n,a,r,i,s){this.type="LBP",this.address=t,this.tokens=e,this.maxInRatio=n,this.maxOutRatio=a,this.minTradingLimit=r,this.fee=i,this.repayFeeApply=s}validatePair(t,e){return!0}parsePair(t,e){let n=new Map(this.tokens.map(i=>[i.id,i])),a=n.get(t),r=n.get(e);if(a==null)throw new Error("Pool does not contain tokenIn");if(r==null)throw new Error("Pool does not contain tokenOut");return{assetIn:t,assetOut:e,balanceIn:a.balance,balanceOut:r.balance,decimalsIn:a.decimals,decimalsOut:r.decimals,weightIn:a.weight,weightOut:r.weight}}validateAndBuy(t,e,n){let a=this.tokens[0].id,r=[];e<this.minTradingLimit&&r.push("InsufficientTradingAmount");let i=t.balanceOut/this.maxOutRatio;if(e>i&&r.push("MaxOutRatioExceeded"),a===t.assetOut){let s=this.calculateTradeFee(e,n),o=Ve.toPct(this.repayFeeApply?n.repayFee:n.exchangeFee),l=e+s,c=this.calculateInGivenOut(t,l),p=t.balanceIn/this.maxInRatio;return c>p&&r.push("MaxInRatioExceeded"),{amountIn:c,calculatedIn:c,amountOut:e,feePct:o,errors:r}}else{let s=this.calculateInGivenOut(t,e),o=t.balanceIn/this.maxInRatio;return s>o&&r.push("MaxInRatioExceeded"),{amountIn:s,calculatedIn:s,amountOut:e,feePct:0,errors:r}}}validateAndSell(t,e,n){let a=this.tokens[0].id,r=[];e<this.minTradingLimit&&r.push("InsufficientTradingAmount");let i=t.balanceIn/this.maxInRatio;if(e>i&&r.push("MaxInRatioExceeded"),a===t.assetIn){let s=this.calculateOutGivenIn(t,e),o=t.balanceOut/this.maxOutRatio;return s>o&&r.push("MaxOutRatioExceeded"),{amountIn:e,calculatedOut:s,amountOut:s,feePct:0,errors:r}}else{let s=this.calculateOutGivenIn(t,e),o=this.calculateTradeFee(s,n),l=Ve.toPct(this.repayFeeApply?n.repayFee:n.exchangeFee),c=s-o,p=t.balanceOut/this.maxOutRatio;return c>p&&r.push("MaxOutRatioExceeded"),{amountIn:e,calculatedOut:s,amountOut:c,feePct:l,errors:r}}}calculateInGivenOut(t,e){let n=H.calculateInGivenOut(t.balanceIn.toString(),t.balanceOut.toString(),t.weightIn.toString(),t.weightOut.toString(),e.toString()),a=BigInt(n);return a<0n?0n:a}calculateOutGivenIn(t,e){let n=H.calculateOutGivenIn(t.balanceIn.toString(),t.balanceOut.toString(),t.weightIn.toString(),t.weightOut.toString(),e.toString()),a=BigInt(n);return a<0n?0n:a}spotPriceInGivenOut(t){let e=H.getSpotPrice(t.balanceOut.toString(),t.balanceIn.toString(),t.weightOut.toString(),t.weightIn.toString(),this.maxOutRatio.toString());return BigInt(e)}spotPriceOutGivenIn(t){let e=H.getSpotPrice(t.balanceIn.toString(),t.balanceOut.toString(),t.weightIn.toString(),t.weightOut.toString(),this.maxInRatio.toString());return BigInt(e)}calculateTradeFee(t,e){let n=H.calculatePoolTradeFee(t.toString(),this.repayFeeApply?e.repayFee[0]:e.exchangeFee[0],this.repayFeeApply?e.repayFee[1]:e.exchangeFee[1]);return BigInt(n)}};import{CompatibilityLevel as ha}from"polkadot-api";import{map as Pa,of as je,switchMap as fa}from"rxjs";import{memoize1 as pa}from"@thi.ng/memoize";import{combineLatest as We,combineLatestAll as ma,debounceTime as da,firstValueFrom as ga,from as Ye,map as Xe,mergeAll as ba,of as ya,switchMap as Ke}from"rxjs";var me=[{inputs:[],name:"decimals",outputs:[{internalType:"uint8",name:"",type:"uint8"}],stateMutability:"view",type:"function"},{inputs:[],name:"description",outputs:[{internalType:"string",name:"",type:"string"}],stateMutability:"view",type:"function"},{inputs:[],name:"version",outputs:[{internalType:"uint256",name:"",type:"uint256"}],stateMutability:"view",type:"function"},{inputs:[{internalType:"uint80",name:"_roundId",type:"uint80"}],name:"getRoundData",outputs:[{internalType:"uint80",name:"roundId",type:"uint80"},{internalType:"int256",name:"answer",type:"int256"},{internalType:"uint256",name:"startedAt",type:"uint256"},{internalType:"uint256",name:"updatedAt",type:"uint256"},{internalType:"uint80",name:"answeredInRound",type:"uint80"}],stateMutability:"view",type:"function"},{inputs:[],name:"latestRoundData",outputs:[{internalType:"uint80",name:"roundId",type:"uint80"},{internalType:"int256",name:"answer",type:"int256"},{internalType:"uint256",name:"startedAt",type:"uint256"},{internalType:"uint256",name:"updatedAt",type:"uint256"},{internalType:"uint80",name:"answeredInRound",type:"uint80"}],stateMutability:"view",type:"function"}];var vt=class{client;constructor(t){this.client=t.getWsProvider()}async getData(t,e=6){let[n,a,r]=await Promise.all([this.client.readContract({abi:me,address:t,functionName:"latestRoundData"}),this.client.readContract({abi:me,address:t,functionName:"decimals"}),this.client.getBlock()]),[i,s,o,l]=n,c=r.number-(r.timestamp-l)/BigInt(e),p=Number(c);return{price:s,decimals:a,updatedAt:p<0?0:p}}};var M=class extends D{evm;mmOracle;override=[];mem=0;memPools=pa(t=>(this.log(this.getPoolType(),"mem pools",t,"\u2705"),this.loadPools()));constructor(t,e){super(t),this.evm=e,this.mmOracle=new vt(e)}async withOverride(t){this.override=t||[]}async getPoolsMem(){return this.memPools(this.mem)}async getPools(){let t=Ye(this.getPoolsMem()).pipe(Ke(e=>this.subscribe(e)),ma());return ga(t)}getSubscriber(){return Ye(this.getPoolsMem()).pipe(Ke(t=>this.subscribe(t)),ba())}subscribe(t){return t.filter(e=>this.hasValidAssets(e)).map(e=>We([this.subscribePoolChange(e),this.subscribePoolBalance(e)]).pipe(da(250),Xe(([n,a])=>this.updatePool(n,a))))}subscribePoolBalance(t){if(t.type==="Aave")return ya([]);let e=[this.subscribeTokensBalance(t.address)];if(this.hasSystemAsset(t)){let n=this.subscribeSystemBalance(t.address);e.push(n)}if(this.hasErc20Asset(t)){let n=t.tokens.filter(r=>r.type==="Erc20").map(r=>r.id),a=this.subscribeErc20Balance(t.address,n);e.push(a)}return We(e).pipe(Xe(n=>n.map(a=>Array.isArray(a)?a:[a]).flat()))}hasSystemAsset(t){return t.tokens.some(e=>e.id===0)}hasErc20Asset(t){return t.tokens.some(e=>e.type==="Erc20")}hasValidAssets(t){return t.tokens.every(({id:e,decimals:n,balance:a})=>{let r=this.override.find(s=>s.id===e),i=!!n||!!r?.decimals;return a>0n&&i})}updatePool=(t,e)=>{let n=t.tokens.map(a=>{let r=e.find(s=>s.id===a.id),i=this.override.find(s=>s.id===a.id);return r?{...a,balance:r.balance.transferable,decimals:a.decimals||i?.decimals}:{...a,decimals:a.decimals||i?.decimals}});return{...t,tokens:n}}};var Ot=class extends M{MAX_FINAL_WEIGHT=100000000n;poolsData=new Map([]);async loadPools(){let[t,e,n]=await Promise.all([this.api.query.LBP.PoolData.getEntries(),this.api.query.ParachainSystem.ValidationData.getValue(),this.getPoolLimits()]),a=e?.relay_parent_number||0,r=t.filter(({value:i})=>e&&this.isActivePool(i,a)).map(async({keyArgs:i,value:s})=>{let[o]=i,l=o.toString(),c=await this.getPoolDelta(l,s,a);return{address:l,type:"LBP",fee:s.fee,...c,...n}});return Promise.all(r)}async getPoolDelta(t,e,n){let{start:a,end:r,assets:i,initial_weight:s,final_weight:o,repay_target:l,fee_collector:c}=e,p=H.calculateLinearWeights(a?a.toString():"0",r?r.toString():"0",s.toString(),o.toString(),n.toString()),[d,m]=i,g=BigInt(p),y=this.MAX_FINAL_WEIGHT-BigInt(g),[b,P,f,S,x]=await Promise.all([this.isRepayFeeApplied(d,l,c.toString()),this.getBalance(t,d),this.api.query.AssetRegistry.Assets.getValue(d),this.getBalance(t,m),this.api.query.AssetRegistry.Assets.getValue(m)]);return{repayFeeApply:b,tokens:[{id:d,decimals:f?.decimals,existentialDeposit:f?.existential_deposit,balance:P.transferable,weight:g,type:f?.asset_type.type},{id:m,decimals:x?.decimals,existentialDeposit:x?.existential_deposit,balance:S.transferable,weight:y,type:x?.asset_type.type}]}}isActivePool(t,e){let{start:n,end:a}=t;return n&&a?e>=n&&e<a:!1}async isRepayFeeApplied(t,e,n){if(e===0n)return!1;try{return(await this.getBalance(n,t)).transferable<e}catch{return!0}}async getRepayFee(){return await this.api.constants.LBP.repay_fee()}async getPoolLimits(){let[t,e,n]=await Promise.all([this.api.constants.LBP.MaxInRatio(),this.api.constants.LBP.MaxOutRatio(),this.api.constants.LBP.MinTradingLimit()]);return{maxInRatio:t,maxOutRatio:e,minTradingLimit:n}}async getPoolFees(t){return{repayFee:await this.getRepayFee(),exchangeFee:t.fee}}getPoolType(){return"LBP"}async isSupported(){let t=this.api.query.LBP.PoolData,e=await this.api.compatibilityToken;return t.isCompatible(ha.BackwardsCompatible,e)}subscribePoolChange(t){let e=this.api.query.ParachainSystem.ValidationData,n=this.poolsData.get(t.address);return n?e.watchValue("best").pipe(fa(a=>a?this.getPoolDelta(t.address,n,a.relay_parent_number):je(t)),Pa(a=>Object.assign({},t,a))):je(t)}};var ge={};T(ge,{OmniMath:()=>w,OmniPool:()=>At,OmniPoolClient:()=>Bt});import{calculate_in_given_out as Sa,calculate_lrna_in_given_out as Ta,calculate_out_given_in as xa,calculate_out_given_lrna_in as wa,calculate_spot_price as Ia,calculate_lrna_spot_price as va,calculate_shares as Oa,calculate_liquidity_out as Aa,calculate_liquidity_lrna_out as Ba,verify_asset_cap as _a,calculate_liquidity_hub_in as Ra,is_sell_allowed as Fa,is_buy_allowed as Ea,is_add_liquidity_allowed as ka,is_remove_liquidity_allowed as Ca}from"@galacticcouncil/math-omnipool";import st from"big.js";var w=class{static calculateSpotPrice(t,e,n,a){return Ia(t,e,n,a)}static calculateLrnaSpotPrice(t,e){return va(t,e)}static calculateInGivenOut(t,e,n,a,r,i,s,o,l){return Sa(t,e,n,a,r,i,s,o,l)}static calculateLrnaInGivenOut(t,e,n,a,r){return Ta(t,e,n,a,r)}static calculateOutGivenIn(t,e,n,a,r,i,s,o,l){return xa(t,e,n,a,r,i,s,o,l)}static calculateOutGivenLrnaIn(t,e,n,a,r){return wa(t,e,n,a,r)}static calculateShares(t,e,n,a){return Oa(t,e,n,a)}static calculateLiquidityOut(t,e,n,a,r,i,s,o){return Aa(t,e,n,a,r,i,s,o)}static calculateLiquidityLRNAOut(t,e,n,a,r,i,s,o){return Ba(t,e,n,a,r,i,s,o)}static calculateCapDifference(t,e,n,a){let r=st(e),i=st(t),s=st(a),o=st(n),l=st(10).pow(18),c=o.div(l);if(r.div(s).lt(c)){let d=c.times(s).minus(r).times(i),m=r.times(st(1).minus(c));return d.div(m).toFixed(0)}else return"0"}static verifyAssetCap(t,e,n,a){return _a(t,e,n,a)}static calculateLimitHubIn(t,e,n,a){return Ra(t,e,n,a)}static isSellAllowed(t){return Fa(t)}static isBuyAllowed(t){return Ea(t)}static isAddLiquidityAllowed(t){return ka(t)}static isRemoveLiquidityAllowed(t){return Ca(t)}};var{FeeUtils:it}=R,At=class u{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;hubAssetId;static fromPool(t){return new u(t.address,t.tokens,t.maxInRatio,t.maxOutRatio,t.minTradingLimit,t.hubAssetId)}constructor(t,e,n,a,r,i){this.type="Omnipool",this.address=t,this.tokens=e,this.maxInRatio=n,this.maxOutRatio=a,this.minTradingLimit=r,this.hubAssetId=i}validatePair(t,e){return this.hubAssetId!=e}parsePair(t,e){let n=new Map(this.tokens.map(i=>[i.id,i])),a=n.get(t),r=n.get(e);if(a==null)throw new Error("Pool does not contain tokenIn");if(r==null)throw new Error("Pool does not contain tokenOut");return{assetIn:t,assetOut:e,hubReservesIn:a.hubReserves,hubReservesOut:r.hubReserves,sharesIn:a.shares,sharesOut:r.shares,decimalsIn:a.decimals,decimalsOut:r.decimals,balanceIn:a.balance,balanceOut:r.balance,tradeableIn:a.tradeable,tradeableOut:r.tradeable,assetInEd:a.existentialDeposit,assetOutEd:r.existentialDeposit}}validateAndBuy(t,e,n){let a=this.calculateInGivenOut(t,e),r=this.calculateInGivenOut(t,e,n),i=a===0n?0:v.calculateDiffToRef(r,a),s=[],o=w.isSellAllowed(t.tradeableIn),l=w.isBuyAllowed(t.tradeableOut);(!o||!l)&&s.push("TradeNotAllowed"),(e<this.minTradingLimit||a<t.assetInEd)&&s.push("InsufficientTradingAmount");let c=t.balanceOut/this.maxOutRatio;e>c&&s.push("MaxOutRatioExceeded");let p=t.balanceIn/this.maxInRatio;return r>p&&s.push("MaxInRatioExceeded"),{amountIn:r,calculatedIn:a,amountOut:e,feePct:i,errors:s}}validateAndSell(t,e,n){let a=this.calculateOutGivenIn(t,e),r=this.calculateOutGivenIn(t,e,n),i=v.calculateDiffToRef(a,r),s=[],o=w.isSellAllowed(t.tradeableIn),l=w.isBuyAllowed(t.tradeableOut);(!o||!l)&&s.push("TradeNotAllowed"),(e<this.minTradingLimit||a<t.assetOutEd)&&s.push("InsufficientTradingAmount");let c=t.balanceIn/this.maxInRatio;e>c&&s.push("MaxInRatioExceeded");let p=t.balanceOut/this.maxOutRatio;return r>p&&s.push("MaxOutRatioExceeded"),{amountIn:e,calculatedOut:a,amountOut:r,feePct:i,errors:s}}calculateInGivenOut(t,e,n){if(t.assetIn==this.hubAssetId)return this.calculateLrnaInGivenOut(t,e,n);let a=w.calculateInGivenOut(t.balanceIn.toString(),t.hubReservesIn.toString(),t.sharesIn.toString(),t.balanceOut.toString(),t.hubReservesOut.toString(),t.sharesOut.toString(),e.toString(),n?it.toRaw(n.assetFee).toString():"0",n?it.toRaw(n.protocolFee).toString():"0"),r=BigInt(a);return r<0n?0n:r}calculateLrnaInGivenOut(t,e,n){let a=w.calculateLrnaInGivenOut(t.balanceOut.toString(),t.hubReservesOut.toString(),t.sharesOut.toString(),e.toString(),n?it.toRaw(n.assetFee).toString():"0"),r=BigInt(a);return r<0n?0n:r}calculateOutGivenIn(t,e,n){if(t.assetIn==this.hubAssetId)return this.calculateOutGivenLrnaIn(t,e,n);let a=w.calculateOutGivenIn(t.balanceIn.toString(),t.hubReservesIn.toString(),t.sharesIn.toString(),t.balanceOut.toString(),t.hubReservesOut.toString(),t.sharesOut.toString(),e.toString(),n?it.toRaw(n.assetFee).toString():"0",n?it.toRaw(n.protocolFee).toString():"0"),r=BigInt(a);return r<0n?0n:r}calculateOutGivenLrnaIn(t,e,n){let a=w.calculateOutGivenLrnaIn(t.balanceOut.toString(),t.hubReservesOut.toString(),t.sharesOut.toString(),e.toString(),n?it.toRaw(n.assetFee).toString():"0"),r=BigInt(a);return r<0n?0n:r}spotPriceInGivenOut(t){if(t.assetIn==this.hubAssetId)return this.spotPriceLrnaInGivenOut(t);let e=w.calculateSpotPrice(t.balanceOut.toString(),t.hubReservesOut.toString(),t.balanceIn.toString(),t.hubReservesIn.toString()),n=Math.pow(10,18-t.decimalsOut);return BigInt(e)/BigInt(n)}spotPriceLrnaInGivenOut(t){let e=w.calculateLrnaSpotPrice(t.hubReservesOut.toString(),t.balanceOut.toString()),n=Math.pow(10,18-t.decimalsOut);return BigInt(e)/BigInt(n)}spotPriceOutGivenIn(t){if(t.assetIn==this.hubAssetId)return this.spotPriceOutGivenLrnaIn(t);let e=w.calculateSpotPrice(t.balanceIn.toString(),t.hubReservesIn.toString(),t.balanceOut.toString(),t.hubReservesOut.toString()),n=Math.pow(10,18-t.decimalsIn);return BigInt(e)/BigInt(n)}spotPriceOutGivenLrnaIn(t){let e=w.calculateLrnaSpotPrice(t.balanceOut.toString(),t.hubReservesOut.toString()),n=Math.pow(10,18-t.decimalsIn);return BigInt(e)/BigInt(n)}};import{AccountId as Da,CompatibilityLevel as Ma}from"polkadot-api";import{toHex as La}from"@polkadot-api/utils";import{distinctUntilChanged as qa,map as ze}from"rxjs";var{FeeUtils:X}=R,Bt=class extends M{async loadPools(){let t=await this.api.constants.Omnipool.HubAssetId(),e=this.getPoolAddress(),[n,a,r,i,s]=await Promise.all([this.api.query.Omnipool.Assets.getEntries(),this.api.query.Omnipool.HubAssetTradability.getValue(),this.api.query.AssetRegistry.Assets.getValue(t),this.getBalance(e,t),this.getPoolLimits()]),o=n.map(async({keyArgs:c,value:p})=>{let[d]=c,{hub_reserve:m,shares:g,tradable:y,cap:b,protocol_shares:P}=p,[f,S]=await Promise.all([this.api.query.AssetRegistry.Assets.getValue(d),this.getBalance(e,d)]);return{id:d,decimals:f?.decimals,existentialDeposit:f?.existential_deposit,balance:S.transferable,cap:b,hubReserves:m,protocolShares:P,shares:g,tradeable:y,type:f?.asset_type.type}}),l=await Promise.all(o);return l.push({id:t,decimals:r?.decimals,existentialDeposit:r?.existential_deposit,balance:i.transferable,tradeable:a,type:r?.asset_type.type}),[{address:e,type:"Omnipool",hubAssetId:t,tokens:l,...s}]}getPoolAddress(){let t="modlomnipool".padEnd(32,"\0"),e=new TextEncoder().encode(t),n=La(e);return Da(63).dec(n)}async getPoolLimits(){let[t,e,n]=await Promise.all([this.api.constants.Omnipool.MaxInRatio(),this.api.constants.Omnipool.MaxOutRatio(),this.api.constants.Omnipool.MinimumTradingLimit()]);return{maxInRatio:t,maxOutRatio:e,minTradingLimit:n}}async getPoolFees(t,e){let[n,a,r]=await Promise.all([this.api.constants.DynamicFees.AssetFeeParameters(),this.api.constants.DynamicFees.ProtocolFeeParameters(),this.api.query.DynamicFees.AssetFee.getValue(e)]),i=n.min_fee+a.min_fee,s=n.max_fee+a.max_fee;if(r){let{asset_fee:o,protocol_fee:l}=r;return{assetFee:X.fromPermill(o),protocolFee:X.fromPermill(l),min:X.fromPermill(i),max:X.fromPermill(s)}}else return{assetFee:X.fromPermill(n.min_fee),protocolFee:X.fromPermill(a.min_fee),min:X.fromPermill(i),max:X.fromPermill(s)}}getPoolType(){return"Omnipool"}async isSupported(){let t=this.api.query.Omnipool.Assets,e=await this.api.compatibilityToken;return t.isCompatible(Ma.BackwardsCompatible,e)}subscribePoolChange(t){return this.api.query.Omnipool.Assets.watchEntries({at:"best"}).pipe(qa((n,a)=>!a.deltas),ze(({entries:n})=>n.map(a=>{let[r]=a.args,{hub_reserve:i,shares:s,tradable:o,cap:l,protocol_shares:c}=a.value,p=t.tokens.findIndex(m=>m.id===r);return{...t.tokens[p],cap:l,hubReserves:i,protocolShares:c,shares:s,tradeable:o}})),ze(n=>{let a=t.tokens.find(r=>r.id===1);return{...t,tokens:[...n,a]}}))}};var be={};T(be,{StableMath:()=>A,StableSwap:()=>_t,StableSwapClient:()=>Rt});import{calculate_in_given_out as Na,calculate_out_given_in as Ga,calculate_amplification as Ha,calculate_add_one_asset as Ua,calculate_liquidity_out_one_asset as Va,calculate_shares as Wa,calculate_shares_for_amount as Ya,calculate_spot_price_with_fee as Xa,pool_account_name as Ka,recalculate_peg as ja}from"@galacticcouncil/math-stableswap";var A=class{static getPoolAddress(t){return Ka(t)}static defaultPegs(t){let e=[];for(let n=0;n<t;n++)e.push(["1","1"]);return e}static calculateAmplification(t,e,n,a,r){return Ha(t,e,n,a,r)}static calculateInGivenOut(t,e,n,a,r,i,s){return Na(t,e,n,a,r,i,s)}static calculateAddOneAsset(t,e,n,a,r,i,s){return Ua(t,e,n,a,r,i,s)}static calculateSharesForAmount(t,e,n,a,r,i,s){return Ya(t,e,n,a,r,i,s)}static calculateOutGivenIn(t,e,n,a,r,i,s){return Ga(t,e,n,a,r,i,s)}static calculateLiquidityOutOneAsset(t,e,n,a,r,i,s){return Va(t,e,n,a,r,i,s)}static calculateShares(t,e,n,a,r,i){return Wa(t,e,n,a,r,i)}static calculateSpotPriceWithFee(t,e,n,a,r,i,s,o){return Xa(t,e,n,a,r,i,s,o)}static recalculatePegs(t,e,n,a,r){let i=ja(t,e,n,a,r);return JSON.parse(i)}};var{FeeUtils:K}=R,_t=class u{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;amplification;id;fee;totalIssuance;static fromPool(t){return new u(t.address,t.tokens,t.maxInRatio,t.maxOutRatio,t.minTradingLimit,t.amplification,t.id,t.fee,t.totalIssuance)}constructor(t,e,n,a,r,i,s,o,l){this.type="Stableswap",this.address=t,this.tokens=e,this.maxInRatio=n,this.maxOutRatio=a,this.minTradingLimit=r,this.amplification=i,this.id=s,this.fee=o,this.totalIssuance=l}validatePair(t,e){return!0}parsePair(t,e){let n=new Map(this.tokens.map(i=>[i.id,i])),a=n.get(t),r=n.get(e);if(a==null)throw new Error("Pool does not contain tokenIn");if(r==null)throw new Error("Pool does not contain tokenOut");return{assetIn:t,assetOut:e,balanceIn:a.balance,balanceOut:r.balance,decimalsIn:a.decimals,decimalsOut:r.decimals,tradeableIn:this.id===t?15:a.tradeable,tradeableOut:this.id===e?15:r.tradeable,assetInEd:a.existentialDeposit,assetOutEd:r.existentialDeposit}}validateAndBuy(t,e,n){let a=this.calculateInGivenOut(t,e),r=this.calculateInGivenOut(t,e,n),i=K.toPct(n.fee),s=[],o=w.isSellAllowed(t.tradeableIn),l=w.isBuyAllowed(t.tradeableOut);return(!o||!l)&&s.push("TradeNotAllowed"),(e<this.minTradingLimit||a<t.assetInEd)&&s.push("InsufficientTradingAmount"),{amountIn:r,calculatedIn:a,amountOut:e,feePct:i,errors:s}}validateAndSell(t,e,n){let a=this.calculateOutGivenIn(t,e),r=this.calculateOutGivenIn(t,e,n),i=K.toPct(n.fee),s=[],o=w.isSellAllowed(t.tradeableIn),l=w.isBuyAllowed(t.tradeableOut);return(!o||!l)&&s.push("TradeNotAllowed"),(e<this.minTradingLimit||a<t.assetOutEd)&&s.push("InsufficientTradingAmount"),{amountIn:e,calculatedOut:a,amountOut:r,feePct:i,errors:s}}calculateIn(t,e,n){let a=A.calculateInGivenOut(this.getReserves(),Number(t.assetIn),Number(t.assetOut),e.toString(),this.amplification.toString(),n?K.toRaw(n.fee).toString():"0",this.getPegs()),r=BigInt(a);return r<0n?0n:r}calculateAddOneAsset(t,e,n){let a=A.calculateAddOneAsset(this.getReserves(),e.toString(),Number(t.assetIn),this.amplification.toString(),this.totalIssuance.toString(),n?K.toRaw(n.fee).toString():"0",this.getPegs()),r=BigInt(a);return r<0n?0n:r}calculateSharesForAmount(t,e,n){let a=A.calculateSharesForAmount(this.getReserves(),Number(t.assetOut),e.toString(),this.amplification.toString(),this.totalIssuance.toString(),n?K.toRaw(n.fee).toString():"0",this.getPegs()),r=BigInt(a);return r<0n?0n:r}calculateInGivenOut(t,e,n){return t.assetOut==this.id?this.calculateAddOneAsset(t,e,n):t.assetIn==this.id?this.calculateSharesForAmount(t,e,n):this.calculateIn(t,e,n)}spotPriceInGivenOut(t){let e=A.calculateSpotPriceWithFee(this.id.toString(),this.getReserves(),this.amplification.toString(),t.assetOut.toString(),t.assetIn.toString(),this.totalIssuance.toString(),"0",this.getPegs());if(t.assetOut==this.id)return BigInt(e);if(t.assetIn==this.id){let a=Math.pow(10,t.decimalsIn-t.decimalsOut);return BigInt(e)/BigInt(a)}let n=Math.pow(10,18-t.decimalsIn);return BigInt(e)/BigInt(n)}calculateOut(t,e,n){let a=A.calculateOutGivenIn(this.getReserves(),Number(t.assetIn),Number(t.assetOut),e.toString(),this.amplification.toString(),n?K.toRaw(n.fee).toString():"0",this.getPegs()),r=BigInt(a);return r<0n?0n:r}calculateWithdrawOneAsset(t,e,n){let a=A.calculateLiquidityOutOneAsset(this.getReserves(),e.toString(),Number(t.assetOut),this.amplification.toString(),this.totalIssuance.toString(),n?K.toRaw(n.fee).toString():"0",this.getPegs()),r=BigInt(a);return r<0n?0n:r}calculateShares(t,e,n){let a=A.calculateShares(this.getReserves(),this.getAssets(t.assetIn,e),this.amplification.toString(),this.totalIssuance.toString(),n?K.toRaw(n.fee).toString():"0",this.getPegs()),r=BigInt(a);return r<0n?0n:r}calculateOutGivenIn(t,e,n){return t.assetIn==this.id?this.calculateWithdrawOneAsset(t,e,n):t.assetOut==this.id?this.calculateShares(t,e,n):this.calculateOut(t,e,n)}spotPriceOutGivenIn(t){let e=A.calculateSpotPriceWithFee(this.id.toString(),this.getReserves(),this.amplification.toString(),t.assetIn.toString(),t.assetOut.toString(),this.totalIssuance.toString(),"0",this.getPegs());if(t.assetIn==this.id)return BigInt(e);if(t.assetOut==this.id){let a=Math.pow(10,t.decimalsOut-t.decimalsIn);return BigInt(e)/BigInt(a)}let n=Math.pow(10,18-t.decimalsOut);return BigInt(e)/BigInt(n)}getPegs(){let t=A.defaultPegs(this.tokens.length-1);return JSON.stringify(t)}getReserves(){let t=this.tokens.filter(e=>e.id!=this.id).map(({id:e,balance:n,decimals:a})=>({asset_id:e,amount:n,decimals:a}));return JSON.stringify(t,$.jsonFormatter)}getAssets(t,e){let n={asset_id:Number(t),amount:e.toString()};return JSON.stringify([n],$.jsonFormatter)}};import{AccountId as za,CompatibilityLevel as $a}from"polkadot-api";import{toHex as Qa}from"@polkadot-api/utils";import{blake2b as Ja}from"@noble/hashes/blake2b";import{map as Za,of as tr,switchMap as er}from"rxjs";var{FeeUtils:Z}=R,Rt=class extends M{poolsData=new Map([]);getPoolType(){return"Stableswap"}getPoolAddress(t){let e=A.getPoolAddress(t),n=Ja(e,{dkLen:32}),a=Qa(n);return za(63).dec(a)}async getPoolLimits(){return{maxInRatio:0n,maxOutRatio:0n,minTradingLimit:await this.api.constants.Stableswap.MinTradingLimit()}}async getPoolDelta(t,e,n){let{initial_amplification:a,final_amplification:r,initial_block:i,final_block:s}=e,o=A.calculateAmplification(a.toString(),r.toString(),i.toString(),s.toString(),n.toString()),l=await this.api.query.Tokens.TotalIssuance.getValue(t);return{amplification:BigInt(o),totalIssuance:l}}async getPoolTokens(t,e){let n=this.getPoolAddress(t),a=e.assets.map(async r=>{let[i,s,o]=await Promise.all([this.api.query.Stableswap.AssetTradability.getValue(t,r),this.api.query.AssetRegistry.Assets.getValue(r),this.getBalance(n,r)]);return{id:r,decimals:s?.decimals,existentialDeposit:s?.existential_deposit,balance:o.transferable,tradeable:i,type:s?.asset_type.type}});return Promise.all(a)}async isSupported(){let t=this.api.query.Stableswap.Pools,e=await this.api.compatibilityToken;return t.isCompatible($a.BackwardsCompatible,e)}async loadPools(){let[t,e,n]=await Promise.all([this.api.query.Stableswap.Pools.getEntries(),this.api.query.System.Number.getValue(),this.getPoolLimits()]),a=t.map(async({keyArgs:r,value:i})=>{let[s]=r,o=this.getPoolAddress(s),[l,c,p]=await Promise.all([this.getPoolDelta(s,i,e),this.getPoolTokens(s,i),this.getPoolPegs(s,i,e)]);return c.push({id:s,tradeable:15,balance:l.totalIssuance,decimals:18}),this.poolsData.set(o,i),{address:o,id:s,type:"Stableswap",fee:Z.fromPermill(i.fee),tokens:c,...l,...p,...n}});return Promise.all(a)}async getPoolFees(t){return{fee:t.fee}}async getPoolPegs(t,e,n){let a=await this.api.query.Stableswap.PoolPegs.getValue(t);if(!a)return this.getDefaultPegs(e);let r=await this.getLatestPegs(e,a,n),i=this.getRecentPegs(a),s=Z.fromPermill(a.max_peg_update),o=Z.fromPermill(e.fee),[l,c]=A.recalculatePegs(JSON.stringify(i),JSON.stringify(r),n.toString(),Z.toRaw(s).toString(),Z.toRaw(o).toString()),p=Number(l)*1e6;return{pegsFee:Z.fromPermill(p),pegs:c}}getDefaultPegs(t){let e=t.fee,n=A.defaultPegs(t.assets.length);return{pegsFee:Z.fromPermill(e),pegs:n}}getRecentPegs(t){let{current:e}=t;return Array.from(e.entries()).map(([n,a])=>a.map(r=>r.toString()))}async getLatestPegs(t,e,n){let{source:a}=e,r=Array.from(t.assets.entries()).map(([s,o])=>o),i=a.map(async(s,o)=>{if(s.type==="Oracle"){let[l,c,p]=s.value,d=[p,r[o]].sort((f,S)=>f-S),m=await this.api.query.EmaOracle.Oracles.getValue(l,d,c);if(!m)return;let[{price:g,updated_at:y}]=m,b=g.n.toString(),P=g.d.toString();return p.toString()===d[0].toString()?[[b,P],y.toString()]:[[P,b],y.toString()]}else if(s.type==="MMOracle"){let l=s.value.asHex(),{price:c,decimals:p,updatedAt:d}=await this.mmOracle.getData(l),m=10**p;return[[c.toString(),m.toString()],d.toString()]}else return[s.value.map(l=>l.toString()),n.toString()]});return Promise.all(i)}subscribePoolChange(t){let e=this.api.query.System.Number,n=this.poolsData.get(t.address);return!n||!t.id?tr(t):e.watchValue("best").pipe(er(a=>Promise.all([this.getPoolDelta(t.id,n,a),this.getPoolPegs(t.id,n,a)])),Za(([a,r])=>{let i=t.tokens.map(s=>s.id===t.id?{...s,balance:a.totalIssuance}:s);return Object.assign(t,{tokens:i},a,r)}))}};var ye={};T(ye,{XykMath:()=>V,XykPool:()=>Ft,XykPoolClient:()=>Et});import{calculate_in_given_out as nr,calculate_out_given_in as ar,calculate_pool_trade_fee as rr,get_spot_price as sr,calculate_liquidity_in as ir,calculate_shares as or,calculate_spot_price as lr,calculate_spot_price_with_fee as cr,calculate_liquidity_out_asset_a as ur,calculate_liquidity_out_asset_b as pr}from"@galacticcouncil/math-xyk";var V=class{static getSpotPrice(t,e,n){return sr(t,e,n)}static calculateInGivenOut(t,e,n){return nr(t,e,n)}static calculateOutGivenIn(t,e,n){return ar(t,e,n)}static calculatePoolTradeFee(t,e,n){return rr(t,e,n)}static calculateLiquidityIn(t,e,n){return ir(t,e,n)}static calculateSpotPrice(t,e){return lr(t,e)}static calculateSpotPriceWithFee(t,e,n,a){return cr(t,e,n,a)}static calculateShares(t,e,n){return or(t,e,n)}static calculateLiquidityOutAssetA(t,e,n,a){return ur(t,e,n,a)}static calculateLiquidityOutAssetB(t,e,n,a){return pr(t,e,n,a)}};var{FeeUtils:$e}=R,Ft=class u{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;static fromPool(t){return new u(t.address,t.tokens,t.maxInRatio,t.maxOutRatio,t.minTradingLimit)}constructor(t,e,n,a,r){this.type="XYK",this.address=t,this.tokens=e,this.maxInRatio=n,this.maxOutRatio=a,this.minTradingLimit=r}validatePair(t,e){return!0}parsePair(t,e){let n=new Map(this.tokens.map(i=>[i.id,i])),a=n.get(t),r=n.get(e);if(a==null)throw new Error("Pool does not contain tokenIn");if(r==null)throw new Error("Pool does not contain tokenOut");return{assetIn:t,assetOut:e,decimalsIn:a.decimals,decimalsOut:r.decimals,balanceIn:a.balance,balanceOut:r.balance,assetInEd:a.existentialDeposit,assetOutEd:r.existentialDeposit}}validateAndBuy(t,e,n){let a=this.calculateInGivenOut(t,e),r=this.calculateTradeFee(a,n),i=$e.toPct(n.exchangeFee),s=a+r,o=[];(e<this.minTradingLimit||a<t.assetInEd)&&o.push("InsufficientTradingAmount");let l=t.balanceOut/this.maxOutRatio;e>l&&o.push("MaxOutRatioExceeded");let c=t.balanceIn/this.maxInRatio;return s>c&&o.push("MaxInRatioExceeded"),{amountIn:s,calculatedIn:a,amountOut:e,feePct:i,errors:o}}validateAndSell(t,e,n){let a=this.calculateOutGivenIn(t,e),r=this.calculateTradeFee(a,n),i=$e.toPct(n.exchangeFee),s=a-r,o=[];(e<this.minTradingLimit||a<t.assetOutEd)&&o.push("InsufficientTradingAmount");let l=t.balanceIn/this.maxInRatio;e>l&&o.push("MaxInRatioExceeded");let c=t.balanceOut/this.maxOutRatio;return s>c&&o.push("MaxOutRatioExceeded"),{amountIn:e,calculatedOut:a,amountOut:s,feePct:i,errors:o}}calculateInGivenOut(t,e){let n=V.calculateInGivenOut(t.balanceIn.toString(),t.balanceOut.toString(),e.toString()),a=BigInt(n);return a<0n?0n:a}calculateOutGivenIn(t,e){let n=V.calculateOutGivenIn(t.balanceIn.toString(),t.balanceOut.toString(),e.toString()),a=BigInt(n);return a<0n?0n:a}spotPriceInGivenOut(t){let e=V.calculateSpotPrice(t.balanceOut.toString(),t.balanceIn.toString()),n=Math.pow(10,18-t.decimalsOut);return BigInt(e)/BigInt(n)}spotPriceOutGivenIn(t){let e=V.calculateSpotPrice(t.balanceIn.toString(),t.balanceOut.toString()),n=Math.pow(10,18-t.decimalsIn);return BigInt(e)/BigInt(n)}calculateTradeFee(t,e){let n=V.calculatePoolTradeFee(t.toString(),e.exchangeFee[0],e.exchangeFee[1]);return BigInt(n)}};import{CompatibilityLevel as mr}from"polkadot-api";import{of as dr}from"rxjs";var Et=class extends M{async loadPools(){let t=this.api.query.XYK.PoolAssets,[e,n]=await Promise.all([t.getEntries(),this.getPoolLimits()]),a=e.map(async({keyArgs:r,value:i})=>{let[s]=r,[o,l]=i,[c,p,d,m]=await Promise.all([this.getBalance(s,o),this.api.query.AssetRegistry.Assets.getValue(o),this.getBalance(s,l),this.api.query.AssetRegistry.Assets.getValue(l)]);return{address:s,type:"XYK",tokens:[{id:o,decimals:p?.decimals,existentialDeposit:p?.existential_deposit,balance:c.transferable,type:p?.asset_type.type},{id:l,decimals:m?.decimals,existentialDeposit:m?.existential_deposit,balance:d.transferable,type:m?.asset_type.type}],...n}});return Promise.all(a)}async getExchangeFee(){return await this.api.constants.XYK.GetExchangeFee()}async getPoolLimits(){let[t,e,n]=await Promise.all([this.api.constants.XYK.MaxInRatio(),this.api.constants.XYK.MaxOutRatio(),this.api.constants.XYK.MinTradingLimit()]);return{maxInRatio:t,maxOutRatio:e,minTradingLimit:n}}async getPoolFees(){return{exchangeFee:await this.getExchangeFee()}}getPoolType(){return"XYK"}async isSupported(){let t=this.api.query.XYK.PoolAssets,e=await this.api.compatibilityToken;return t.isCompatible(mr.BackwardsCompatible,e)}subscribePoolChange(t){return dr(t)}};var he={};T(he,{AavePool:()=>kt,AavePoolClient:()=>Ct});var kt=class u{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;static fromPool(t){return new u(t.address,t.tokens,t.maxInRatio,t.maxOutRatio,t.minTradingLimit)}constructor(t,e,n,a,r){this.type="Aave",this.address=t,this.tokens=e,this.maxInRatio=n,this.maxOutRatio=a,this.minTradingLimit=r}validatePair(t,e){return!0}parsePair(t,e){let n=new Map(this.tokens.map(i=>[i.id,i])),a=n.get(t),r=n.get(e);if(a==null)throw new Error("Pool does not contain tokenIn");if(r==null)throw new Error("Pool does not contain tokenOut");return{assetIn:t,assetOut:e,balanceIn:a.balance,balanceOut:r.balance,decimalsIn:a.decimals,decimalsOut:r.decimals,assetInEd:0n,assetOutEd:0n}}validateAndBuy(t,e,n){let a=this.calculateInGivenOut(t,e),r=[];return e>t.balanceOut&&r.push("TradeNotAllowed"),{amountIn:a,calculatedIn:a,amountOut:e,feePct:0,errors:r}}validateAndSell(t,e,n){let a=this.calculateOutGivenIn(t,e),r=[];return a>t.balanceOut&&r.push("TradeNotAllowed"),{amountIn:e,calculatedOut:a,amountOut:a,feePct:0,errors:r}}calculateInGivenOut(t,e){return e}calculateOutGivenIn(t,e){return e}spotPriceInGivenOut(t){let e=Math.pow(10,t.decimalsOut);return BigInt(e)}spotPriceOutGivenIn(t){let e=Math.pow(10,t.decimalsIn);return BigInt(e)}calculateTradeFee(t,e){return 0n}};import{AccountId as gr}from"polkadot-api";import{toHex as br}from"@polkadot-api/utils";import{map as yr,merge as hr,switchMap as Pr}from"rxjs";import{decodeEventLog as fr}from"viem";var Qe=[{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"},{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"},{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{ERC20:Sr}=tt,Tr=["Supply","Withdraw","Repay","Borrow"],Ct=class extends M{async loadPools(){let e=(await this.api.apis.AaveTradeExecutor.pools()).map(async({reserve:n,atoken:a,liqudity_in:r,liqudity_out:i})=>{let[s,o,l,c]=await Promise.all([this.api.query.AssetRegistry.Assets.getValue(n),this.api.query.AssetRegistry.AssetLocations.getValue(n),this.api.query.AssetRegistry.Assets.getValue(a),this.api.query.AssetRegistry.AssetLocations.getValue(a)]);return{address:this.getPoolId(n,a),type:"Aave",tokens:[{id:n,decimals:s?.decimals,existentialDeposit:s?.existential_deposit,balance:r,location:o,type:s?.asset_type.type},{id:a,decimals:l?.decimals,existentialDeposit:l?.existential_deposit,balance:i,location:c,type:l?.asset_type.type}],...this.getPoolLimits()}});return Promise.all(e)}async getPoolDelta(t){let[e,n]=t.tokens,{liqudity_in:a,liqudity_out:r}=await this.api.apis.AaveTradeExecutor.pool(e.id,n.id);return t.tokens.map(i=>{let s=i.id===e.id?a:r;return{...i,balance:s}})}getPoolId(t,e){let n=t+"/"+e,a=new TextEncoder().encode(n.padEnd(32,"\0")),r=br(a);return gr(63).dec(r)}getPoolLimits(){return{maxInRatio:0n,maxOutRatio:0n,minTradingLimit:0n}}async getPoolFees(t,e){return{}}getPoolType(){return"Aave"}async isSupported(){return!0}subscribePoolChange(t){let[e,n]=t.tokens,a=this.getReserveH160Id(e),r=this.api.event.Router.Executed.watch(({asset_in:s,asset_out:o})=>s===n.id||o===n.id),i=this.api.event.EVM.Log.watch(({log:s})=>{let{topics:o,data:l}=s,c=o.map(g=>g.asHex()),p=l.asHex(),{eventName:d,args:m}=fr({abi:Qe,topics:c,data:p});return Tr.includes(d)&&m.reserve.toLowerCase()===a.toLowerCase()});return hr([r,i]).pipe(Pr(()=>this.getPoolDelta(t)),yr(s=>({...t,tokens:[...s]})))}getReserveH160Id(t){return t.type==="Erc20"?$.findNestedKey(t.location,"AccountKey20").AccountKey20.key:Sr.fromAssetId(t.id)}};var ot=class{static get(t){switch(t.type){case"Aave":return kt.fromPool(t);case"XYK":return Ft.fromPool(t);case"Omnipool":return At.fromPool(t);case"LBP":return It.fromPool(t);case"Stableswap":return _t.fromPool(t);default:throw new Error("Pool type "+t.type+" is not supported yet")}}};import{Subject as xr,Subscription as Dt,takeUntil as wr}from"rxjs";var lt=class extends B{evm;lbpClient;omniClient;stableClient;xykClient;aaveClient;active=new Set([]);clients=[];pools=new Map([]);lbpSub=Dt.EMPTY;omniSub=Dt.EMPTY;stableSub=Dt.EMPTY;xykSub=Dt.EMPTY;aaveSub=Dt.EMPTY;isReady=!1;isDestroyed=new xr;constructor(t,e){super(t),this.evm=e,this.lbpClient=new Ot(t,e),this.omniClient=new Bt(t,e),this.stableClient=new Rt(t,e),this.xykClient=new Et(t,e),this.aaveClient=new Ct(t,e),this.clients=[this.lbpClient,this.omniClient,this.stableClient,this.xykClient,this.aaveClient]}subscribe(t){return t.getSubscriber().pipe(wr(this.isDestroyed)).subscribe(e=>{this.pools.set(e.address,e)})}withOmnipool(){return this.omniSub.unsubscribe(),this.omniSub=this.subscribe(this.omniClient),this.active.add("Omnipool"),this}withStableswap(){return this.stableSub.unsubscribe(),this.stableSub=this.subscribe(this.stableClient),this.active.add("Stableswap"),this}withLbp(){return this.lbpSub.unsubscribe(),this.lbpSub=this.subscribe(this.lbpClient),this.active.add("LBP"),this}withAave(){return this.aaveSub.unsubscribe(),this.aaveSub=this.subscribe(this.aaveClient),this.active.add("Aave"),this}withXyk(t){return this.xykClient.withOverride(t),this.xykSub.unsubscribe(),this.xykSub=this.subscribe(this.xykClient),this.active.add("XYK"),this}destroy(){this.isDestroyed.next(!0),this.isDestroyed.complete(),this.active.clear(),this.pools.clear(),this.isReady=!1}async getPools(t={}){if(this.active.size===0)throw new Error("No pools selected");if(this.isReady)return Array.from(this.pools.values());let{useOnly:e=[],exclude:n=[]}=t,a=new Set(e),r=new Set(n),i=async s=>{let o=s.getPoolType();return a.size>0?a.has(o):r.size>0?!r.has(o):s.isSupported()};return this.getFilteredPools(i)}async getFilteredPools(t){let e=await Promise.all(this.clients.map(t)),n=this.clients.filter((r,i)=>e[i]);return(await Promise.all(n.map(r=>r.getPoolsMem()))).flat()}async getPoolFees(t,e){let n=this.clients.find(a=>a.getPoolType()===t.type);if(n)return n.getPoolFees(t,e);throw new Tt(t.type)}};var an={};T(an,{DEFAULT_BLOCK_TIME:()=>tn,DEFAULT_MIN_BUDGET:()=>Se,ORDER_MIN_BLOCK_PERIOD:()=>en,Router:()=>ct,TWAP_BLOCK_PERIOD:()=>Nt,TWAP_MAX_DURATION:()=>xe,TWAP_MAX_PRICE_IMPACT:()=>Te,TWAP_TX_MULTIPLIER:()=>yu,TradeOrderError:()=>fe,TradeOrderType:()=>zt,TradeRouteBuilder:()=>L,TradeRouter:()=>ut,TradeScheduler:()=>pt,TradeType:()=>jt});var Mt=class{constructor(t=1/0){this.capacity=t}storage=[];enqueue(t){if(this.size()===this.capacity)throw Error("Queue has reached max capacity, you cannot add more items");this.storage.push(t)}dequeue(){return this.storage.shift()}size(){return this.storage.length}};var Ir=8,Lt=class{isNotVisited(t,e){let n=!0;return e.forEach(a=>{(a[0]===t[0]||a[1]===t[1])&&(n=!1)}),n}findPaths(t,e,n){let a=[],r=new Mt,i=[];for(i.push([e,""]),r.enqueue(i);r.size()>0;){let s=r.dequeue();if(!s||s.length>Ir)continue;let o=s[s.length-1];(n===null||o[0]===n)&&a.push(s),t.get(o[0])?.forEach(c=>{if(this.isNotVisited(c,s)){let p=[...s];p.push(c),r.enqueue(p)}})}return a}findShortestPaths(t,e,n){let a=[],r=new Mt,i=[];i.push([e,""]),r.enqueue(i);let s=1/0;for(;r.size()>0;){let o=r.dequeue();if(!o)continue;let l=o[o.length-1];if(l[0]===n){o.length<s?(s=o.length,a.length=0,a.push(o)):o.length===s&&a.push(o);continue}let c=t.get(l[0]);for(let p of c??[])this.isNotVisited(p,o)&&r.enqueue([...o,p])}return a}buildAndPopulateGraph(t,e){let n=new Map;for(let a of t)n.set(parseInt(a),[]);for(let[a,r,i]of e)n.get(r)?.push([i,a]);return n}};function Pe(u){let t={};for(let e of u){let n=e.tokens.length;for(let a=0;a<n;a++){t[e.tokens[a].id]||(t[e.tokens[a].id]=[]);for(let r=0;r<n;r++){if(a==r)continue;let i=[e.address,e.tokens[a].id,e.tokens[r].id];t[e.tokens[a].id].push(i)}}}return t}var qt=class{getProposals(t,e,n){let a=n.filter(b=>b.type==="XYK"),r=n.filter(b=>b.type!=="XYK"),i=new Set(r.map(b=>b.tokens).flat().map(b=>b.id)),s=i.has(t),o=i.has(e),l=new Lt,c=b=>{let P=Pe(b),f=Object.keys(P),S=f.flatMap(x=>P[x]);return l.buildAndPopulateGraph(f,S)};if(!s&&!o){let b=a.filter(S=>S.tokens.find(x=>x.id===t)||S.tokens.find(x=>x.id===e)),P=c(b),f=l.findPaths(P,t,e);return this.parsePaths(f)}if(s&&o){let b=c(r),P=l.findPaths(b,t,e);return this.parsePaths(P)}let p=s?e:t,d=a.filter(b=>b.tokens.some(P=>P.id===p));if(d.length===0)return[];let m=[...r,...d],g=c(m),y=l.findPaths(g,t,e);return this.parsePaths(y)}parsePaths(t){let e=[];for(let n of t){let a=[];for(let r=0;r<n.length;r++){let i=n[r],s=n[r+1];if(s==null)break;a.push(this.toEdge(i,s))}e.push(a)}return e}toEdge(t,e){return[e[1],t[0],e[0]]}};var ct=class{routeSuggester;routeProposals;routerOptions;ctx;constructor(t,e={}){this.ctx=t,this.routeSuggester=new qt,this.routeProposals=new Map,this.routerOptions=Object.freeze(e)}buildRouteKey(t,e,n){return`${t}->${e}::${n.length}`}async getPools(){return this.ctx.getPools(this.routerOptions)}async getRoutes(t,e){let n=await this.getPools();return this.validateInput(t,e,n),this.getPaths(t,e,n)}async getTradeableAssets(){let t=await this.getPools(),e=this.getAssets(t);return Array.from(e)}async getRouteableAssets(t){let e=await this.getTradeableAssets();return(await Promise.all(e.filter(a=>a!==t).map(a=>this.getRoutes(a,t)))).filter(a=>a.length>0).map(([a])=>a[0].assetIn).sort()}validateInput(t,e,n){if(n.length===0)throw new Error("No pools configured");if(t===e)throw new Error("Trading pair can't be identical");let a=this.getAssets(n);if(!a.has(t))throw new Error(t+" is not supported asset");if(!a.has(e))throw new Error(e+" is not supported asset");return this.toPoolsMap(n)}getAssets(t){let e=t.map(n=>n.tokens.map(a=>a.id)).flat().sort((n,a)=>n>a?1:-1);return new Set(e)}getPaths(t,e,n){let a=this.toPoolsMap(n);return this.getProposals(t,e,n).filter(i=>this.validPath(i,a)).map(i=>this.toHops(i,a))}getProposals(t,e,n){let a=this.buildRouteKey(t,e,n);if(this.routeProposals.has(a))return this.routeProposals.get(a);let r=this.routeSuggester.getProposals(t,e,n);return this.routeProposals.set(a,r),r}validPath(t,e){return t.length>0&&t.map(n=>this.validEdge(n,e)).reduce((n,a)=>n&&a)}validEdge([t,e,n],a){return a.get(t)?.validatePair(e,n)||!1}toPoolsMap(t){return new Map(t.map(e=>[e.address,ot.get(e)]))}toHops(t,e){return t.map(([n,a,r])=>{let i=e.get(n);return{poolAddress:n,poolId:i?.id,pool:i?.type,assetIn:a,assetOut:r}})}};var jt=(e=>(e.Buy="Buy",e.Sell="Sell",e))(jt||{}),zt=(n=>(n.Dca="Dca",n.TwapSell="TwapSell",n.TwapBuy="TwapBuy",n))(zt||{}),fe=(n=>(n.OrderTooSmall="OrderTooSmall",n.OrderTooBig="OrderTooBig",n.OrderImpactTooBig="OrderImpactTooBig",n))(fe||{});var{FeeUtils:Ze}=R,ut=class extends ct{mlr;poolsSnapshot;constructor(t,e={}){super(t,e),this.mlr=new Map}buildCtxSync(t,e){let n=this.poolsSnapshot,a=super.validateInput(t,e,n),r=super.getPaths(t,e,n);if(!r.length)throw new xt(t,e);return{paths:r,pools:n,poolsMap:a}}async withCtx(t,e,n){this.poolsSnapshot||(this.poolsSnapshot=await super.getPools());let a=this.buildCtxSync(t,e);return n(a)}isDirectTrade(t){return t.length==1}findBestSellRoute(t){let e=t.sort((n,a)=>{let r=n[n.length-1].amountOut,i=a[a.length-1].amountOut;return r>i?-1:1});return e.find(n=>n.every(a=>a.errors.length==0))||e[0]}getRouteFeeRange(t){if(t.filter(n=>n.tradeFeeRange).length>0){let n=t.map(r=>r.tradeFeeRange?.[0]??r.tradeFeePct).reduce((r,i)=>r+i),a=t.map(r=>r.tradeFeeRange?.[1]??r.tradeFeePct).reduce((r,i)=>r+i);return[n,a]}}getPoolFeeRange(t){let e=t.min?Ze.toPct(t.min):void 0,n=t.max?Ze.toPct(t.max):void 0;if(e&&n)return[e,n]}async getBestSell(t,e,n){return this.getSell(t,e,n)}getSellSpot(t){let e=t[t.length-1];if(t.length===1)return e.spotPrice;let n=t.map(s=>s.assetOutDecimals).reduce((s,o)=>s+o),a=t.map(s=>s.spotPrice).reduce((s,o)=>s*o),r=n-e.assetOutDecimals,i=Math.pow(10,r);return a/BigInt(i)}async getSell(t,e,n,a){return this.withCtx(t,e,async({paths:r,poolsMap:i})=>{let s;if(a)s=await this.toSellSwaps(n,a,i);else{let o=r.map(c=>this.toSellSwaps(n,c,i)),l=await Promise.all(o);s=this.findBestSellRoute(l)}return this.buildSell(i,s)})}buildSell(t,e){let n=e[0],a=e[e.length-1],r=this.isDirectTrade(e),i=this.getSellSpot(e),s=a.amountOut,o=r?a.calculatedOut:this.calculateDelta0Y(n.amountIn,e,t),l=o-s,c=this.getRouteFeeRange(e),p=r?a.tradeFeePct:v.calculateSellFee(o,s),d=Math.pow(10,n.assetInDecimals),m=n.amountIn*i/BigInt(d),g=v.calculateDiffToRef(o,m);return{type:"Sell",amountIn:n.amountIn,amountOut:a.amountOut,spotPrice:i,tradeFee:l,tradeFeePct:p,tradeFeeRange:c,priceImpactPct:g,swaps:e,toHuman(){return{type:"Sell",amountIn:h.toDecimal(n.amountIn,n.assetInDecimals),amountOut:h.toDecimal(a.amountOut,a.assetOutDecimals),spotPrice:h.toDecimal(i,a.assetOutDecimals),tradeFee:h.toDecimal(l,a.assetOutDecimals),tradeFeePct:p,tradeFeeRange:c,priceImpactPct:g,swaps:e.map(y=>y.toHuman())}}}}calculateDelta0Y(t,e,n){let a=[];for(let r=0;r<e.length;r++){let i=e[r],s=n.get(i.poolAddress);if(s==null)throw new Error("Pool does not exit");let o=s.parsePair(i.assetIn,i.assetOut),l;r>0?l=a[r-1]:l=t;let c=s.calculateOutGivenIn(o,l);a.push(c)}return a[a.length-1]}async calculateMostLiquidRoute(t,e,n){let{paths:a,pools:r,poolsMap:i}=n,l=r.filter(y=>y.tokens.some(b=>b.id===t)).map(y=>y.type==="Aave"?y.tokens:y.tokens.filter(b=>b.id===t)).map(y=>y.map(b=>b.balance).reduce((b,P)=>b+P)).sort((y,b)=>b<y?-1:1)[0],c=v.getFraction(l,.1),p=await Promise.all(a.map(y=>this.toSellSwaps(c,y,i))),m=this.findBestSellRoute(p).map(y=>({poolAddress:y.poolAddress,poolId:y?.poolId,pool:y.pool,assetIn:y.assetIn,assetOut:y.assetOut})),g=this.buildRouteKey(t,e,r);return this.mlr.set(g,m),m}async toSellSwaps(t,e,n){let a=[];for(let r=0;r<e.length;r++){let i=e[r],s=n.get(i.poolAddress);if(s==null)throw new Error("Pool does not exit");let o=s.parsePair(i.assetIn,i.assetOut),l;r>0?l=a[r-1].amountOut:l=typeof t=="string"?h.toBigInt(t,o.decimalsIn):t;let c=await this.ctx.getPoolFees(s,o.assetOut),{amountOut:p,calculatedOut:d,feePct:m,errors:g}=s.validateAndSell(o,l,c),y=this.getPoolFeeRange(c),b=s.spotPriceOutGivenIn(o),P=Math.pow(10,o.decimalsIn),f=l*b/BigInt(P),S=v.calculateDiffToRef(d,f);a.push({...i,assetInDecimals:o.decimalsIn,assetOutDecimals:o.decimalsOut,amountIn:l,amountOut:p,calculatedOut:d,spotPrice:b,tradeFeePct:m,tradeFeeRange:y,priceImpactPct:S,errors:g,isSupply(){return s.type==="Aave"&&s.tokens[0].id===i.assetIn},isWithdraw(){return s.type==="Aave"&&s.tokens[1].id===i.assetIn},toHuman(){return{...i,amountIn:h.toDecimal(l,o.decimalsIn),amountOut:h.toDecimal(p,o.decimalsOut),calculatedOut:h.toDecimal(d,o.decimalsOut),spotPrice:h.toDecimal(b,o.decimalsOut),tradeFeePct:m,tradeFeeRange:y,priceImpactPct:S,errors:g}}})}return a}async getMostLiquidRoute(t,e){return this.withCtx(t,e,async n=>{let a=this.buildRouteKey(t,e,n.pools),r=this.mlr.get(a);return r||this.calculateMostLiquidRoute(t,e,n)})}async getSpotPrice(t,e){return this.withCtx(t,e,async n=>{let{pools:a,poolsMap:r}=n,i=this.buildRouteKey(t,e,a),s=this.mlr.get(i);s||(s=await this.calculateMostLiquidRoute(t,e,n));let o=await this.toSellSwaps("1",s,r),l=this.getSellSpot(o),c=o[o.length-1].assetOutDecimals;return{amount:l,decimals:c}})}findBestBuyRoute(t){let e=t.sort((n,a)=>{let r=n[0].amountIn,i=a[0].amountIn;return r>i?1:-1});return e.find(n=>n.every(a=>a.errors.length==0))||e[0]}async getBestBuy(t,e,n){return this.getBuy(t,e,n)}getBuySpot(t){let e=t[0];if(t.length===1)return e.spotPrice;let n=t.map(s=>s.assetInDecimals).reduce((s,o)=>s+o),a=t.map(s=>s.spotPrice).reduce((s,o)=>s*o),r=n-e.assetInDecimals,i=Math.pow(10,r);return a/BigInt(i)}async getBuy(t,e,n,a){return this.withCtx(t,e,async({paths:r,poolsMap:i})=>{let s;if(a)s=await this.toBuySwaps(n,a,i);else{let o=r.map(c=>this.toBuySwaps(n,c,i)),l=await Promise.all(o);s=this.findBestBuyRoute(l)}return this.buildBuy(i,s)})}buildBuy(t,e){let n=e[e.length-1],a=e[0],r=this.isDirectTrade(e),i=this.getBuySpot(e),s=a.amountIn,o=r?a.calculatedIn:this.calculateDelta0X(n.amountOut,e,t),l=s-o,c=this.getRouteFeeRange(e),p=r?a.tradeFeePct:v.calculateBuyFee(o,s),d=Math.pow(10,n.assetOutDecimals),m=n.amountOut*i/BigInt(d),g;return o===0n?g=-100:g=v.calculateDiffToRef(m,o),{type:"Buy",amountOut:n.amountOut,amountIn:a.amountIn,spotPrice:i,tradeFee:l,tradeFeePct:p,tradeFeeRange:c,priceImpactPct:g,swaps:e,toHuman(){return{type:"Buy",amountOut:h.toDecimal(n.amountOut,n.assetOutDecimals),amountIn:h.toDecimal(a.amountIn,a.assetInDecimals),spotPrice:h.toDecimal(i,a.assetInDecimals),tradeFee:h.toDecimal(l,a.assetInDecimals),tradeFeePct:p,tradeFeeRange:c,priceImpactPct:g,swaps:e.map(y=>y.toHuman())}}}}calculateDelta0X(t,e,n){let a=[];for(let r=e.length-1;r>=0;r--){let i=e[r],s=n.get(i.poolAddress);if(s==null)throw new Error("Pool does not exit");let o=s.parsePair(i.assetIn,i.assetOut),l;r==e.length-1?l=t:l=a[0];let c=s.calculateInGivenOut(o,l);a.unshift(c)}return a[0]}async toBuySwaps(t,e,n){let a=[];for(let r=e.length-1;r>=0;r--){let i=e[r],s=n.get(i.poolAddress);if(s==null)throw new Error("Pool does not exit");let o=s.parsePair(i.assetIn,i.assetOut),l;r==e.length-1?l=typeof t=="string"?h.toBigInt(t,o.decimalsOut):t:l=a[0].amountIn;let c=await this.ctx.getPoolFees(s,o.assetOut),{amountIn:p,calculatedIn:d,feePct:m,errors:g}=s.validateAndBuy(o,l,c),y=this.getPoolFeeRange(c),b=s.spotPriceInGivenOut(o),P=Math.pow(10,o.decimalsOut),f=l*b/BigInt(P),S;d===0n?S=-100:S=v.calculateDiffToRef(f,d),a.unshift({...i,assetInDecimals:o.decimalsIn,assetOutDecimals:o.decimalsOut,amountOut:l,amountIn:p,calculatedIn:d,spotPrice:b,tradeFeePct:m,tradeFeeRange:y,priceImpactPct:S,errors:g,isSupply(){return s.type==="Aave"&&s.tokens[0].id===i.assetIn},isWithdraw(){return s.type==="Aave"&&s.tokens[1].id===i.assetIn},toHuman(){return{...i,amountOut:h.toDecimal(l,o.decimalsOut),amountIn:h.toDecimal(p,o.decimalsIn),calculatedIn:h.toDecimal(d,o.decimalsIn),spotPrice:h.toDecimal(b,o.decimalsIn),tradeFeePct:m,tradeFeeRange:y,priceImpactPct:S,errors:g}}})}return a}};var tn=6e3,Se=1000000000000000n,Nt=6,Te=-5,xe=216e5,yu=3,en=6;import{Enum as nn}from"polkadot-api";var L=class{static build(t){return t.map(({assetIn:e,assetOut:n,pool:a,poolId:r})=>a==="Stableswap"?{pool:nn("Stableswap",r),asset_in:e,asset_out:n}:{pool:nn(a),asset_in:e,asset_out:n})}};var pt=class{schedulerOptions;router;constructor(t,e={}){this.router=t,this.schedulerOptions=Object.freeze({blockTime:e.blockTime??6e3,minBudgetInNative:e.minBudgetInNative??Se})}get blockTime(){return this.schedulerOptions.blockTime}get minOrderBudget(){return this.schedulerOptions.minBudgetInNative}async getDcaOrder(t,e,n,a,r){let[i,s]=await Promise.all([this.getMinimumOrderBudget(t),this.router.getBestSell(t,e,n)]),{amountIn:o,swaps:l,priceImpactPct:c}=s,p=l[0],d=l[l.length-1],{assetInDecimals:m}=p,{assetOutDecimals:g}=d,y=Math.abs(c),b=this.getMinimumTradeCount(o,i),P=this.getOptimalTradeCount(y),f=r?Math.round(a/r):P,S=Math.ceil(a/b),x=Math.round(a/P),F=Math.round(a/f),C=o/BigInt(f),_=await this.router.getBestSell(t,e,C),q=o<i,N=[];q&&N.push("OrderTooSmall");let W=_.amountOut*BigInt(f),bt=this.toBlockPeriod(F),j=_.tradeFee*BigInt(f),Jt=L.build(l),yt={assetIn:t,assetOut:e,errors:N,frequencyMin:S,frequencyOpt:x,frequency:F,tradeCount:f,tradeFee:j,tradeImpactPct:_.priceImpactPct,tradePeriod:bt,tradeRoute:Jt,type:"Dca"};return{...yt,amountIn:o,amountOut:W,tradeAmountIn:_.amountIn,tradeAmountOut:_.amountOut,toHuman(){return{...yt,amountIn:h.toDecimal(o,m),amountOut:h.toDecimal(W,g),tradeAmountIn:h.toDecimal(_.amountIn,m),tradeAmountOut:h.toDecimal(_.amountOut,g)}}}}async getMinimumOrderBudget(t){if(0===t)return this.minOrderBudget;let e=await this.router.getSpotPrice(0,t),n=10n**BigInt(12);if(e)return this.minOrderBudget*e.amount/n;throw new Error("Unable to calculate order budget")}getMinimumTradeCount(t,e){let n=e*2n/10n;if(n===0n)return 0;let a=t+n/2n;return Number(a/n)}getOptimalTradeCount(t){let e=Math.round(t*10)||1;return Math.max(e,3)}async getTwapSellOrder(t,e,n){let[a,r]=await Promise.all([this.getMinimumOrderBudget(t),this.router.getBestSell(t,e,n)]),{amountIn:i,swaps:s,priceImpactPct:o}=r,l=s[0],c=s[s.length-1],{assetInDecimals:p}=l,{assetOutDecimals:d}=c,m=Math.abs(o),g=this.getTwapTradeCount(m),y=i/BigInt(g),b=await this.router.getBestSell(l.assetIn,c.assetOut,y),P=g===1,f=i<a,S=b.priceImpactPct<-5,x=[];f||P?x.push("OrderTooSmall"):S&&x.push("OrderImpactTooBig");let F=b.amountOut*BigInt(g),C=b.tradeFee*BigInt(g),_=L.build(s),q={assetIn:t,assetOut:e,errors:x,tradeCount:g,tradeImpactPct:b.priceImpactPct,tradePeriod:6,tradeRoute:_,type:"TwapSell"};return{...q,amountIn:i,amountOut:F,tradeAmountIn:b.amountIn,tradeAmountOut:b.amountOut,tradeFee:C,toHuman(){return{...q,amountIn:h.toDecimal(i,p),amountOut:h.toDecimal(F,d),tradeAmountIn:h.toDecimal(b.amountIn,p),tradeAmountOut:h.toDecimal(b.amountOut,d),tradeFee:h.toDecimal(C,d)}}}}async getTwapBuyOrder(t,e,n){let[a,r]=await Promise.all([this.getMinimumOrderBudget(t),this.router.getBestBuy(t,e,n)]),{amountOut:i,swaps:s,priceImpactPct:o}=r,l=s[0],c=s[s.length-1],{assetInDecimals:p}=l,{assetOutDecimals:d}=c,m=Math.abs(o),g=this.getTwapTradeCount(m),y=i/BigInt(g),b=await this.router.getBestBuy(l.assetIn,c.assetOut,y),P=b.amountIn*BigInt(g),f=g===1,S=P<a,x=b.priceImpactPct<-5,F=[];S||f?F.push("OrderTooSmall"):x&&F.push("OrderImpactTooBig");let C=b.tradeFee*BigInt(g),_=L.build(s),q={assetIn:t,assetOut:e,errors:F,tradeCount:g,tradeImpactPct:b.priceImpactPct,tradePeriod:6,tradeRoute:_,type:"TwapBuy"};return{...q,amountIn:P,amountOut:i,tradeAmountIn:b.amountIn,tradeAmountOut:b.amountOut,tradeFee:C,toHuman(){return{...q,amountIn:h.toDecimal(P,p),amountOut:h.toDecimal(i,d),tradeAmountIn:h.toDecimal(b.amountIn,p),tradeAmountOut:h.toDecimal(b.amountOut,d),tradeFee:h.toDecimal(C,p)}}}}getTwapTradeCount(t){let e=this.getOptimalTradeCount(t);if(this.getTwapExecutionTime(e)>216e5){let a=216e5/(this.blockTime*6);return Math.round(a)}return e}getTwapExecutionTime(t){return t*6*this.blockTime}toBlockPeriod(t){let e=t/this.blockTime,n=Math.round(e);return Math.max(n,6)}};var ln={};T(ln,{BIG_10:()=>sn,BIG_BILL:()=>on,StakingApi:()=>Gt,StakingClient:()=>Ht});import{encodeAddress as vr}from"@polkadot/util-crypto";import{stringToU8a as Or}from"@polkadot/util";import{calculate_accumulated_rps as Ar,calculate_period_number as rn,calculate_rewards as Br}from"@galacticcouncil/math-staking";import mt from"big.js";var sn=mt(10),on=mt(sn.pow(12));function _r(u){return vr(Or(("modl"+u).padEnd(32,"\0")),63)}var Gt=class{client;balanceClient;constructor(t,e){this.client=t,this.balanceClient=e}async getFreePotBalance(){let t=await this.client.getPalletId(),e=_r(t);return(await this.balanceClient.getBalance(e,0)).transferable}async getStakingPosition(t){let[e,n]=await Promise.all([this.client.getStakingPositionsValue(t),this.client.getStakingVotes(t)]),a=e?.created_at,r=await n.reduce(async(i,[s,o])=>{let l=await i,c=s,p=o.amount,d=o.conviction.toString(),m=await this.client.getReferendumInfo(c);return m&&(m.type==="Approved"||m.type==="Rejected")&&l.push({id:c,amount:p,conviction:d}),l},Promise.resolve([]));return{stake:e?.stake,rewardPerStake:e?.reward_per_stake,createdAt:a,actionPoints:e?.action_points,accumulatedUnpaidRewards:e?.accumulated_unpaid_rewards,accumulatedSlashPoints:e?.accumulated_slash_points,accumulatedLockedRewards:e?.accumulated_locked_rewards,votes:r}}async getStake(t){let e=await this.client.getNFTCollectionId(),[n,a]=await Promise.all([this.client.getStaking(),this.client.getUniques(t,e)]),r=a.find(i=>i)?.itemId;return{totalStake:n?.total_stake,accumulatedRewardPerStake:n?.accumulated_reward_per_stake,potReservedBalance:n?.pot_reserved_balance,positionId:r,stakePosition:r?await this.getStakingPosition(r):void 0}}async getRewards(t,e){let n=await this.getStake(t),{potReservedBalance:a,accumulatedRewardPerStake:r,totalStake:i,stakePosition:s}=n;if(!s)return;let[o,l,c,p]=await Promise.all([this.getFreePotBalance(),this.client.getPeriodLength(),this.client.getUnclaimablePeriods(),this.client.getSixBlockSince()]),d=mt(o.toString()).minus(a.toString()),m=r.toString(),g=mt(e).plus(1).toString();d.gt(0)&&i>0&&(m=Ar(r.toString(),d.toString(),i.toString()));let y=rn(l.toString(),e,p??g),b=rn(l.toString(),s.createdAt?.toString()??"",p??g),P=Br(m,s.rewardPerStake?.toString()??"",s.stake?.toString()??""),f=mt(P).plus(s.accumulatedUnpaidRewards?.toString()||"0").plus(s.accumulatedLockedRewards?.toString()||"0");if(!mt(y).minus(b).lte(c.toString()))return f.div(on).toString()}};var Ht=class extends B{async getPalletId(){let t=this.api.constants.Staking.PalletId;return(await t()).asText()}async getPeriodLength(){let t=this.api.constants.Staking.PeriodLength;return await t()}async getUnclaimablePeriods(){let t=this.api.constants.Staking.UnclaimablePeriods;return await t()}async getNFTCollectionId(){let t=this.api.constants.Staking.NFTCollectionId;return await t()}async getStaking(){return await this.api.query.Staking.Staking.getValue()}async getUniques(t,e){return(await this.api.query.Uniques.Account.getEntries(t,e)).map(({keyArgs:i})=>{let[s,o,l]=i;return{address:s,collectionId:o,itemId:l}})}async getStakingPositionsValue(t){return await this.api.query.Staking.Positions.getValue(t)}async getStakingVotes(t){return await this.api.query.Staking.Votes.getValue(t)}async getReferendumInfo(t){return await this.api.query.Referenda.ReferendumInfoFor.getValue(t)}async getSixBlockSince(){return(await this.api.query.Staking.SixSecBlocksSince.getValue()).toString()}};var pn={};T(pn,{TxBuilderFactory:()=>gt});import{Enum as un}from"polkadot-api";function cn(u){let t=[],e=u;for(;e&&typeof e=="object"&&"type"in e;)t.push(e.type),e=e.value;return t.join(".")}var dt=class extends B{evm;evmClient;balanceClient;aaveUtils;constructor(t,e){super(t),this.evm=e,this.evmClient=e.getWsProvider(),this.balanceClient=new D(t),this.aaveUtils=new Q(e)}wrapTx(t,e){return{name:t,get:()=>e,dryRun:n=>this.dryRun(n,e)}}async dispatchWithExtraGas(t){return this.api.tx.Dispatcher.dispatch_with_extra_gas({call:t.decodedCall,extra_gas:ee})}async dryRun(t,e){let n=un("Signed",t),a=un("system",n),i=await this.client.getUnsafeApi().apis.DryRunApi.dry_run_call(a,e.decodedCall),s=i.success&&!i.value.execution_result.success?i.value.execution_result.value.error:null;if(s){let o=cn(s.value);throw new Error("Dry run execution error!",{cause:o})}return i}isDirectOmnipoolTrade(t){return t.length===1&&t[0].pool==="Omnipool"}};var $t=class extends dt{_trade;_beneficiary;_slippagePct=1;setTrade(t){return this._trade=t,this}withBeneficiary(t){return this._beneficiary=t,this}withSlippage(t){return this._slippagePct=t,this}get trade(){if(!this._trade)throw new Error("Trade not set. Use setTrade().");return this._trade}get beneficiary(){if(!this._beneficiary)throw new Error("Beneficiary not set. Use withBeneficiary().");return this._beneficiary}get slippagePct(){return this._slippagePct}async build(){let{amountIn:t,swaps:e,type:n}=this.trade;if(n==="Buy")return this.buildBuyTx();let{assetIn:a}=e[0],r=await this.balanceClient.getBalance(this.beneficiary,a);return t>=r.transferable-5n?this.buildSellAllTx():this.buildSellTx()}async buildBuyTx(){let{amountIn:t,amountOut:e,swaps:n}=this.trade,a=n[0],r=n[n.length-1],i=v.getFraction(t,this.slippagePct),s=a.assetIn,o=r.assetOut,l=t+i,c;return this.isDirectOmnipoolTrade(n)?c=this.api.tx.Omnipool.buy({asset_in:s,asset_out:o,amount:e,max_sell_amount:l}):c=this.api.tx.Router.buy({asset_in:s,asset_out:o,amount_out:e,max_amount_in:l,route:L.build(n)}),this.wrapTx("RouterBuy",c)}async buildSellTx(){let{amountIn:t,amountOut:e,swaps:n}=this.trade,a=n[0],r=n[n.length-1],i=v.getFraction(e,this.slippagePct),s=a.assetIn,o=r.assetOut,l=e-i,c;return this.isDirectOmnipoolTrade(n)?c=this.api.tx.Omnipool.sell({asset_in:s,asset_out:o,amount:t,min_buy_amount:l}):c=this.api.tx.Router.sell({asset_in:s,asset_out:o,amount_in:t,min_amount_out:l,route:L.build(n)}),a.isWithdraw()&&await this.aaveUtils.hasBorrowPositions(this.beneficiary)&&(c=await this.dispatchWithExtraGas(c)),this.wrapTx("RouterSell",c)}async buildSellAllTx(){let{amountOut:t,swaps:e}=this.trade,n=e[0],a=e[e.length-1],r=v.getFraction(t,this.slippagePct),i=n.assetIn,s=a.assetOut,o=t-r,l=this.api.tx.Router.sell_all({asset_in:i,asset_out:s,min_amount_out:o,route:L.build(e)});return n.isWithdraw()&&await this.aaveUtils.hasBorrowPositions(this.beneficiary)&&(l=await this.dispatchWithExtraGas(l)),this.wrapTx("RouterSellAll",l)}};import{Enum as we}from"polkadot-api";var Qt=class extends dt{_order;_beneficiary;_maxRetries=3;_slippagePct=1;setOrder(t){return this._order=t,this}withBeneficiary(t){return this._beneficiary=t,this}withMaxRetries(t){return this._maxRetries=t,this}withSlippage(t){return this._slippagePct=t,this}get order(){if(!this._order)throw new Error("Order not set. Use setOrder().");return this._order}get beneficiary(){if(!this._beneficiary)throw new Error("Beneficiary not set. Use withBeneficiary().");return this._beneficiary}get maxRetries(){return this._maxRetries}get slippagePct(){return this._slippagePct}async build(){let{type:t}=this.order;switch(t){case"Dca":return this.buildDcaTx();case"TwapSell":return this.buildTwapSellTx();case"TwapBuy":return this.buildTwapBuyTx();default:throw new Error(`Unsupported TradeOrderType: ${t}`)}}buildDcaTx(){let{amountIn:t,assetIn:e,assetOut:n,tradeAmountIn:a,tradePeriod:r,tradeRoute:i}=this.order,s=this.api.tx.DCA.schedule({schedule:{owner:this.beneficiary,period:r,max_retries:this.maxRetries,total_amount:t,slippage:this.slippagePct*1e4,stability_threshold:void 0,order:we("Sell",{asset_in:e,asset_out:n,amount_in:a,min_amount_out:0n,route:i})},start_execution_block:void 0});return this.wrapTx("DcaSchedule",s)}buildTwapSellTx(){let{amountIn:t,assetIn:e,assetOut:n,tradeAmountIn:a,tradeAmountOut:r,tradePeriod:i,tradeRoute:s}=this.order,o=v.getFraction(r,this.slippagePct),l=r-o,c=this.api.tx.DCA.schedule({schedule:{owner:this.beneficiary,period:i,max_retries:this.maxRetries,total_amount:t,slippage:this.slippagePct*1e4,stability_threshold:void 0,order:we("Sell",{asset_in:e,asset_out:n,amount_in:a,min_amount_out:l,route:s})},start_execution_block:void 0});return this.wrapTx("DcaSchedule.twapSell",c)}buildTwapBuyTx(){let{amountIn:t,assetIn:e,assetOut:n,tradeAmountIn:a,tradeAmountOut:r,tradePeriod:i,tradeRoute:s}=this.order,o=v.getFraction(a,this.slippagePct),l=a+o,c=this.api.tx.DCA.schedule({schedule:{owner:this.beneficiary,period:i,max_retries:this.maxRetries,total_amount:t,slippage:this.slippagePct*1e4,stability_threshold:void 0,order:we("Buy",{asset_in:e,asset_out:n,amount_out:r,max_amount_in:l,route:s})},start_execution_block:void 0});return this.wrapTx("DcaSchedule.twapBuy",c)}};var gt=class{client;evmClient;constructor(t,e){this.client=t,this.evmClient=e}trade(t){return new $t(this.client,this.evmClient).setTrade(t)}order(t){return new Qt(this.client,this.evmClient).setOrder(t)}};async function Ip(u){let t=new rt(u),e=new wt(u),[n,a]=await Promise.all([t.getBlockTime(),t.getMinOrderBudget()]),r=new lt(u,e).withAave().withOmnipool().withStableswap().withXyk(),i=new Q(e),s=new ut(r),o=new pt(s,{blockTime:n,minBudgetInNative:a}),l=new D(u),c=new Ht(u),p=new Gt(c,l);return{api:{aave:i,router:s,scheduler:o,staking:p},client:{asset:new nt(u),balance:l,evm:e},ctx:{pool:r},tx:new gt(u,e),destroy:()=>{r.destroy()}}}export{Ce as aave,Ae as api,h as big,qe as client,Be as const,Ip as createSdkContext,tt as erc20,Ne as error,Ue as evm,R as fmt,Yt as h160,$ as json,v as math,Je as pool,an as sor,ln as staking,pn as tx,ke as xc};
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { EvmClient } from '../evm';
|
|
2
2
|
export declare class AaveClient {
|
|
3
|
-
private
|
|
4
|
-
constructor(
|
|
3
|
+
private client;
|
|
4
|
+
constructor(evm: EvmClient);
|
|
5
5
|
getReservesData(): Promise<readonly [readonly {
|
|
6
6
|
underlyingAsset: `0x${string}`;
|
|
7
7
|
name: string;
|
|
@@ -3,7 +3,7 @@ import { EvmClient } from '../evm';
|
|
|
3
3
|
import { Amount } from '../types';
|
|
4
4
|
export declare class AaveUtils {
|
|
5
5
|
private client;
|
|
6
|
-
constructor(
|
|
6
|
+
constructor(evm: EvmClient);
|
|
7
7
|
getSummary(user: string): Promise<AaveSummary>;
|
|
8
8
|
/**
|
|
9
9
|
* Check if user has active borrow positions
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { PolkadotClient } from 'polkadot-api';
|
|
2
|
+
import { Papi } from '../api';
|
|
3
|
+
import { BalanceClient } from './BalanceClient';
|
|
4
|
+
export declare class LiquidityMining extends Papi {
|
|
5
|
+
protected readonly balanceClient: BalanceClient;
|
|
6
|
+
protected omnipoolAssetIds: string[];
|
|
7
|
+
private secondsInYear;
|
|
8
|
+
constructor(client: PolkadotClient);
|
|
9
|
+
getOraclePrice(rewardCurrency: number, incentivizedAsset: number): Promise<bigint | undefined>;
|
|
10
|
+
private getFarmAddress;
|
|
11
|
+
private getGlobalRewardPerPeriod;
|
|
12
|
+
private getPoolYieldPerPeriod;
|
|
13
|
+
private farmData;
|
|
14
|
+
getOmnipoolFarms(id: string): Promise<({
|
|
15
|
+
apr: string;
|
|
16
|
+
minApr: string | undefined;
|
|
17
|
+
isDistributed: boolean;
|
|
18
|
+
estimatedEndPeriod: string;
|
|
19
|
+
maxRewards: bigint;
|
|
20
|
+
incentivizedAsset: number;
|
|
21
|
+
rewardCurrency: number;
|
|
22
|
+
loyaltyCurve: {
|
|
23
|
+
initial_reward_percentage: bigint;
|
|
24
|
+
scale_coef: number;
|
|
25
|
+
} | undefined;
|
|
26
|
+
currentPeriod: string;
|
|
27
|
+
potMaxRewards: bigint;
|
|
28
|
+
fullness: string;
|
|
29
|
+
} | undefined)[]>;
|
|
30
|
+
getIsolatedFarms(id: string): Promise<({
|
|
31
|
+
apr: string;
|
|
32
|
+
minApr: string | undefined;
|
|
33
|
+
isDistributed: boolean;
|
|
34
|
+
estimatedEndPeriod: string;
|
|
35
|
+
maxRewards: bigint;
|
|
36
|
+
incentivizedAsset: number;
|
|
37
|
+
rewardCurrency: number;
|
|
38
|
+
loyaltyCurve: {
|
|
39
|
+
initial_reward_percentage: bigint;
|
|
40
|
+
scale_coef: number;
|
|
41
|
+
} | undefined;
|
|
42
|
+
currentPeriod: string;
|
|
43
|
+
potMaxRewards: bigint;
|
|
44
|
+
fullness: string;
|
|
45
|
+
} | undefined)[]>;
|
|
46
|
+
}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
import { Chain } from 'viem';
|
|
2
|
-
export declare const
|
|
2
|
+
export declare const createChain: () => Chain;
|
|
@@ -1,11 +1,12 @@
|
|
|
1
|
+
import { PolkadotClient } from 'polkadot-api';
|
|
1
2
|
import { Chain, PublicClient, WalletClient } from 'viem';
|
|
2
3
|
export declare class EvmClient {
|
|
4
|
+
private client;
|
|
3
5
|
readonly chain: Chain;
|
|
4
|
-
constructor(
|
|
6
|
+
constructor(client: PolkadotClient);
|
|
5
7
|
get chainId(): number;
|
|
6
8
|
get chainCurrency(): string;
|
|
7
9
|
get chainDecimals(): number;
|
|
8
|
-
getGasPrice(): Promise<bigint>;
|
|
9
10
|
getProvider(): PublicClient;
|
|
10
11
|
getWsProvider(): PublicClient;
|
|
11
12
|
getSigner(address: string): WalletClient;
|
package/build/types/factory.d.ts
CHANGED
|
@@ -24,4 +24,4 @@ export type SdkCtx = {
|
|
|
24
24
|
tx: TxBuilderFactory;
|
|
25
25
|
destroy: () => void;
|
|
26
26
|
};
|
|
27
|
-
export declare function createSdkContext(client: PolkadotClient
|
|
27
|
+
export declare function createSdkContext(client: PolkadotClient): Promise<SdkCtx>;
|