@galacticcouncil/sdk-next 1.2.0 → 1.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (48) hide show
  1. package/build/aave/AaveLog.d.ts +4 -0
  2. package/build/aave/index.cjs +1 -1
  3. package/build/aave/index.d.ts +2 -0
  4. package/build/aave/index.mjs +1 -1
  5. package/build/aave/types.d.ts +7 -0
  6. package/build/evm/adapter.d.ts +3 -1
  7. package/build/evm/client.d.ts +3 -1
  8. package/build/evm/index.cjs +1 -1
  9. package/build/evm/index.mjs +1 -1
  10. package/build/gho/GhoTokenLog.d.ts +4 -0
  11. package/build/gho/index.d.ts +4 -2
  12. package/build/{pool/hsm → gho}/types.d.ts +1 -1
  13. package/build/index.cjs +1 -1
  14. package/build/index.d.ts +1 -0
  15. package/build/index.mjs +1 -1
  16. package/build/indexer/BlockFetcher.d.ts +10 -0
  17. package/build/indexer/Indexer.d.ts +19 -0
  18. package/build/indexer/IndexerStats.d.ts +33 -0
  19. package/build/indexer/RpcPool.d.ts +12 -0
  20. package/build/indexer/Semaphore.d.ts +9 -0
  21. package/build/indexer/index.cjs +1 -0
  22. package/build/indexer/index.d.ts +9 -0
  23. package/build/indexer/index.mjs +1 -0
  24. package/build/indexer/scale.d.ts +1 -0
  25. package/build/indexer/types.d.ts +17 -0
  26. package/build/oracle/MmOracleClient.d.ts +1 -1
  27. package/build/oracle/MmOracleLog.d.ts +4 -0
  28. package/build/oracle/abi.d.ts +11 -84
  29. package/build/oracle/index.d.ts +2 -0
  30. package/build/oracle/mappings.d.ts +25 -0
  31. package/build/oracle/types.d.ts +11 -0
  32. package/build/pool/aave/AavePoolClient.d.ts +0 -1
  33. package/build/pool/aave/types.d.ts +0 -6
  34. package/build/pool/hsm/HsmPoolClient.d.ts +0 -1
  35. package/build/pool/index.cjs +1 -1
  36. package/build/pool/index.mjs +1 -1
  37. package/build/pool/stable/StableSwap.d.ts +1 -1
  38. package/build/pool/stable/StableSwapClient.d.ts +12 -3
  39. package/build/pool/stable/StableSwapPeg.d.ts +7 -0
  40. package/build/pool/stable/types.d.ts +12 -1
  41. package/build/sor/index.cjs +1 -1
  42. package/build/sor/index.mjs +1 -1
  43. package/build/tx/TxBuilder.d.ts +2 -2
  44. package/build/tx/TxBuilderFactory.d.ts +3 -1
  45. package/build/tx/index.cjs +1 -1
  46. package/build/tx/index.mjs +1 -1
  47. package/package.json +6 -1
  48. package/build/pool/aave/AaveAbi.d.ts +0 -126
package/build/index.mjs CHANGED
@@ -1 +1 @@
1
- var Vr=Object.defineProperty;var O=(p,t)=>{for(var e in t)Vr(p,e,{get:t[e],enumerable:!0})};import Ur from"buffer";typeof window<"u"&&(window.Buffer=Ur.Buffer);var Bi={};O(Bi,{Papi:()=>R,Watcher:()=>Et,getSm:()=>pa,getWs:()=>ua});import{hydration as na,hydrationNext as sa,hydrationIce as oa}from"@galacticcouncil/descriptors";import{log as ta}from"@galacticcouncil/common";import{map as ea,shareReplay as ia,tap as ra}from"rxjs";import{defer as Wr,from as Yr,of as Oi,timer as $r}from"rxjs";import{catchError as Xr,distinctUntilChanged as zr,expand as Kr,map as We,shareReplay as jr,skip as Qr,switchMap as Jr,timeout as Zr}from"rxjs/operators";function Ai(p,{intervalMs:t=5e3,rpcTimeoutMs:e=1e4}={}){let i=()=>Wr(()=>Yr(p._request("system_health",[]))).pipe(Zr({first:e}),We(()=>"online"),Xr(()=>Oi("offline")));return Oi({state:"offline",delayMs:0}).pipe(Kr(a=>$r(a.delayMs).pipe(Jr(i),We(n=>({state:n,delayMs:t})))),Qr(1),We(a=>a.state),zr(),jr({bufferSize:1,refCount:!0}))}var{logger:aa}=ta,Et=class p{static instance=null;bestBlock$;finalizedBlock$;connection$;constructor(t){this.bestBlock$=this.watched("watcher(bestBlock)",t.getUnsafeApi().query.System.Number.watchValue({at:"best"}).pipe(ea(({value:e})=>e))),this.finalizedBlock$=this.watched("watcher(finalizedBlock)",t.finalizedBlock$),this.connection$=this.watched("watcher(connection)",Ai(t))}static getInstance(t){return this.instance||(this.instance=new p(t)),this.instance}watched(t,e){return e.pipe(ra({error:i=>aa.error(t,i)}),ia({bufferSize:1,refCount:!0}))}};var R=class{client;api;apiNext;apiIce;watcher;at;constructor(t,e){this.client=t,this.api=this.client.getTypedApi(na),this.apiNext=this.client.getTypedApi(sa),this.apiIce=this.client.getTypedApi(oa),this.watcher=Et.getInstance(this.client),this.at=e??"best"}};import{getWsProvider as la}from"polkadot-api/ws";import{withLogsRecorder as ca}from"polkadot-api/logs-provider";var ua=(p,t={})=>{let e=typeof p=="string"?p.split(","):p,i=la(e,t);return ca(r=>console.log(r),i),i};async function pa(p){let{getSmProvider:t}=await import("polkadot-api/sm-provider"),{start:e}=await import("polkadot-api/smoldot"),{chainSpec:i}=await import("polkadot-api/chains/polkadot"),r=e(),a=await r.addChain({chainSpec:i}),n=await r.addChain({chainSpec:p,potentialRelayChains:[a]});return t(()=>n)}var Fi={};O(Fi,{AAVE_GAS_LIMIT:()=>Xe,AAVE_LENDING_POOL_ADDRESS:()=>be,AAVE_POOL_ABI:()=>Ye,AAVE_POOL_DATA_PROVIDER:()=>he,AAVE_POOL_DATA_PROVIDER_ABI:()=>ge,AAVE_POOL_PROXY:()=>$e,AAVE_ROUNDING_THRESHOLD:()=>pl,AAVE_UINT_256_MAX:()=>ma,AaveClient:()=>Ct,AaveUtils:()=>at});var Ye=[{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 ge=[{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 $e="0x1b02E051683b5cfaC5929C25E84adb26ECf87B38",he="0x112b087b60C1a166130d59266363C45F8aa99db0",be="0xf3Ba4D1b50f78301BDD7EAEa9B67822A15FCA691",Xe=1000000n,pl=5,ma=BigInt("0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");var Ct=class{client;constructor(t){this.client=t.getWsProvider()}async getBlockTimestamp(){let t=await this.client.getBlock();return Number(t.timestamp)}async getReservesData(){return await this.client.readContract({abi:ge,address:he,args:[be],functionName:"getReservesData"})}async getUserReservesData(t){return await this.client.readContract({abi:ge,address:he,args:[be,t],functionName:"getUserReservesData"})}async getUserAccountData(t){return await this.client.readContract({abi:Ye,address:$e,args:[t],functionName:"getUserAccountData"})}};import E from"big.js";import{big as rt,erc20 as da,h160 as ga}from"@galacticcouncil/common";var{ERC20:pt}=da,{H160:ze}=ga,ha=1.01,ba=31536000n,_i=4,ye=-1,fe=10n**27n,at=class{client;constructor(t){this.client=new Ct(t)}async getSummary(t){let e=ze.fromAny(t),[i,r,a,n]=await Promise.all([this.client.getReservesData(),this.client.getUserReservesData(e),this.client.getUserAccountData(e),this.client.getBlockTimestamp()]),[s]=i,[o,l]=r,[c,u,d,m,g,b]=a,h=rt.toDecimal(b,18),y=[];for(let f of o){let S=f.underlyingAsset.toLowerCase(),P=s.find(({underlyingAsset:Ue})=>Ue.toLowerCase()===S);if(!P)throw new Error("Missing pool reserve for "+S);let w=f.scaledATokenBalance,x=P.liquidityIndex,_=P.liquidityRate,H=P.availableLiquidity,k=P.priceInMarketReferenceCurrency,j=n+6,G=this.calculateLinearInterest(_,P.lastUpdateTimestamp,j),$=x*G/fe,tt=w*$/fe,pe=Number(l!==0&&l===P.eModeCategoryId?P.eModeLiquidationThreshold:P.reserveLiquidationThreshold)/1e4,me=P.usageAsCollateralEnabled&&f.usageAsCollateralEnabledOnUser&&f.scaledATokenBalance>0n,de=pt.toAssetId(S);y.push({aTokenBalance:tt,availableLiquidity:H,decimals:Number(P.decimals),isCollateral:me,priceInRef:k,reserveId:de,reserveAsset:S,reserveLiquidationThreshold:pe})}return{healthFactor:Number(h),currentLiquidationThreshold:Number(rt.toDecimal(m,_i)),totalCollateral:c,totalDebt:u,reserves:y}}async hasBorrowPositions(t){let e=ze.fromAny(t),i=await this.client.getUserAccountData(e),[r,a]=i;return a>0n}async getHealthFactor(t){let e=ze.fromAny(t),i=await this.client.getUserAccountData(e),[r,a,n,s,o,l]=i;return this.calculateHealthFactorFromBalances(a,r,s)}async getHealthFactorAfterWithdraw(t,e,i){let{totalCollateral:r,totalDebt:a,reserves:n,currentLiquidationThreshold:s}=await this.getSummary(t);if(a===0n)return ye;let o=pt.fromAssetId(e),l=n.find(S=>S.reserveAsset===o);if(!l)throw new Error("Missing reserve ctx for "+o);let{decimals:c,isCollateral:u,priceInRef:d,reserveLiquidationThreshold:m}=l,g=rt.toBigInt(i,c),b=u?g*d/10n**BigInt(c):0n,h=r-b;if(h<=0n)return 0;let y=E(r.toString()).mul(s).minus(E(b.toString()).mul(m)).div(h.toString()),f=E(h.toString()).mul(y).div(a.toString()).toFixed(6,E.roundDown);return Number(f)}async getHealthFactorAfterSupply(t,e,i){let{totalCollateral:r,totalDebt:a,reserves:n,currentLiquidationThreshold:s}=await this.getSummary(t);if(a===0n)return ye;let o=pt.fromAssetId(e),l=n.find(f=>f.reserveAsset===o);if(!l)throw new Error("Missing reserve ctx for "+o);let{decimals:c,priceInRef:u,reserveLiquidationThreshold:d}=l,g=rt.toBigInt(i,c)*u/10n**BigInt(c),b=r+g;if(b<=0n)return 0;let h=E(r.toString()).mul(s).plus(E(g.toString()).mul(d)).div(b.toString()),y=E(b.toString()).mul(h).div(a.toString()).toFixed(6,E.roundDown);return Number(y)}async getHealthFactorAfterSwap(t,e,i,r,a){let{totalDebt:n,reserves:s,healthFactor:o}=await this.getSummary(t);if(n===0n)return ye;let l=pt.fromAssetId(i),c=pt.fromAssetId(a),u=s.find(x=>x.reserveAsset===l),d=s.find(x=>x.reserveAsset===c);if(!u)throw new Error(`Missing reserve ctx for ${l}`);if(!d)throw new Error(`Missing reserve ctx for ${d}`);let m=rt.toBigInt(e,u.decimals),g=rt.toBigInt(r,d.decimals),b=m*u.priceInRef/10n**BigInt(u.decimals),h=g*d.priceInRef/10n**BigInt(d.decimals),y=u.isCollateral?E(b.toString()).mul(u.reserveLiquidationThreshold):E(0),P=(d.isCollateral?E(h.toString()).mul(d.reserveLiquidationThreshold):E(0)).minus(y).div(n.toString()),w=E(o).plus(P).toFixed(6,E.roundDown);return Number(w)}async getMaxWithdraw(t,e){let{totalDebt:i,reserves:r,healthFactor:a}=await this.getSummary(t),n=pt.fromAssetId(e),s=r.find(o=>o.reserveAsset===n);if(!s)throw new Error("Missing reserve ctx for "+n);return this.calculateWithdrawMax(s,i,a)}async getMaxWithdrawAll(t){let{totalDebt:e,reserves:i,healthFactor:r}=await this.getSummary(t),a={};for(let n of i){let s=this.calculateWithdrawMax(n,e,r);n.reserveId&&(a[n.reserveId]=s)}return a}calculateWithdrawMax(t,e,i){let{aTokenBalance:r,availableLiquidity:a,decimals:n,priceInRef:s,reserveLiquidationThreshold:o,isCollateral:l}=t,c=r;if(l&&e>0n){let d=i-ha;if(d>0){let m=E(d).mul(e.toString()).div(o).toFixed(0,E.roundDown),g=E(m).div(s.toString()).mul(10**n).toFixed(0,E.roundDown);c=r<BigInt(g)?r:BigInt(g)}else c=0n}return{amount:c<a?c:a,decimals:n}}calculateLinearInterest(t,e,i){let r=i-e;if(r<=0)return fe;let a=t*BigInt(r)/ba;return fe+a}calculateHealthFactorFromBalances(t,e,i){if(t===0n)return ye;let r=e*i/t,a=rt.toDecimal(r,_i);return Number(a)}};var Li={};O(Li,{AssetClient:()=>mt,BalanceClient:()=>z,ChainParams:()=>ft});import{Binary as Pe}from"polkadot-api";var mt=class extends R{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:i,value:r})=>{let[a]=i;return[a,r]}))}async queryBonds(){let e=await this.api.query.Bonds.Bonds.getEntries();return new Map(e.map(({keyArgs:i,value:r})=>{let[a]=i;return[a,r]}))}async queryAssets(){let e=await this.api.query.AssetRegistry.Assets.getEntries();return new Map(e.filter(({value:i})=>{let{asset_type:r}=i;return this.SUPPORTED_TYPES.includes(r.type)}).map(({keyArgs:i,value:r})=>{let[a]=i;return[a,r]}))}async queryAssetLocations(){let e=await this.api.query.AssetRegistry.AssetLocations.getEntries();return new Map(e.map(({keyArgs:i,value:r})=>{let[a]=i;return[a,r]}))}async mapToken(t,e,i,r){let{name:a,asset_type:n,is_sufficient:s,existential_deposit:o}=e,{symbol:l,decimals:c}=i.get(t)??{};return{id:t,name:a?Pe.toText(a):void 0,symbol:l,decimals:c,icon:l,type:n.type,isSufficient:s,location:r,existentialDeposit:o}}async mapBond(t,e,i,r){let[a,n]=r,{asset_type:s,is_sufficient:o,existential_deposit:l}=e,{symbol:c,decimals:u}=await this.mapToken(a,e,i),d=Number(n),m=new Intl.DateTimeFormat("en-GB"),g=[c,"Bond",m.format(d)].join(" ");return{id:t,name:g,symbol:c+"b",decimals:u,icon:c,type:s.type,isSufficient:o,existentialDeposit:l,underlyingAssetId:a,maturity:d}}async mapShares(t,e,i,r){let{assets:a}=r,{name:n,symbol:s,asset_type:o,is_sufficient:l,existential_deposit:c}=e,u=await Promise.all(a.map(async g=>{let{symbol:b}=await this.mapToken(g,e,i);return[g,b]})),d=Object.fromEntries(u),m=Object.values(d);return{id:t,name:m.join(", "),symbol:s&&Pe.toText(s)||n&&Pe.toText(n),decimals:18,icon:m.join("/"),type:o.type,isSufficient:l,existentialDeposit:c,meta:d}}async mapExternal(t,e,i,r){let a=await this.mapToken(t,e,new Map,r),n=i?.find(s=>s.internalId===a.id);return n?{...a,decimals:n.decimals,name:n.name,symbol:n.symbol,icon:n.symbol,isWhiteListed:n.isWhiteListed}:a}parseMetadata(t){return new Map(Array.from(t,([e,i])=>[e,{symbol:i.symbol?Pe.toText(i.symbol):void 0,decimals:i.decimals}]))}async getSupported(t,e){let[i,r,a,n]=await Promise.all([this.queryAssets(),this.queryAssetLocations(),this.queryShares(),this.queryBonds()]),s=this.parseMetadata(i),o=[];for(let[l,c]of Array.from(i)){let u=r.get(l),{asset_type:d}=c,m;switch(d.type){case"Bond":let g=n.get(l);m=await this.mapBond(l,c,s,g);break;case"StableSwap":let b=a.get(l);m=await this.mapShares(l,c,s,b);break;case"External":m=await this.mapExternal(l,c,e,u);break;default:m=await this.mapToken(l,c,s,u)}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{log as Pa}from"@galacticcouncil/common";import{combineLatest as Sa,concat as wa,defer as kt,from as Ei}from"rxjs";import{bufferCount as Ci,distinctUntilChanged as ki,debounceTime as Ta,map as bt,retry as xa,startWith as Di,switchMap as Mi,tap as Dt,take as va,skip as Ia,connect as Oa}from"rxjs/operators";var Ri={};O(Ri,{HUB_ASSET_ID:()=>gt,HYDRATION_OMNIPOOL_ADDRESS:()=>fa,HYDRATION_PARACHAIN_ID:()=>ya,PERBILL_DENOMINATOR:()=>Ke,PERMILL_DENOMINATOR:()=>dt,SYSTEM_ASSET_DECIMALS:()=>Se,SYSTEM_ASSET_ID:()=>A,TRADEABLE_DEFAULT:()=>ht});var dt=1e6,Ke=1e9,A=0,Se=12,ya=2034,fa="7L53bUTBbfuj14UpdCNPwmgzzHSsrsTWBHX5pys32mVWM3C1",gt=1,ht=15;var{logger:yt}=Pa,z=class extends R{erc20Ids=null;constructor(t,e){super(t,e)}async getBalance(t,e){return e===0?this.getSystemBalance(t):this.getBalanceData(t,e)}async getSystemBalance(t){let e=this.api.query.System.Account,{data:i}=await e.getValue(t,{at:this.at});return this.getBreakdown(i)}async getTokenBalance(t,e){let r=await this.api.query.Tokens.Accounts.getValue(t,e,{at:this.at});return this.getBreakdown(r)}async getErc20Balance(t,e){return this.getBalanceData(t,e)}watchBalance(t){return kt(()=>{let e=this.watchSystemBalance(t),i=this.watchTokensBalance(t),r=this.watchErc20Balance(t);return Sa([e,i,r]).pipe(Oa(a=>wa(a.pipe(va(1)),a.pipe(Ia(1),Ta(250)))))}).pipe(bt(e=>e.flat()),Di([]),Ci(2,1),bt(([e,i],r)=>r===0?i:this.getDeltas(e,i))).pipe(Dt({subscribe:()=>yt.debug("balance: subscribe",t),error:e=>yt.error("balance",e)}),xa({delay:1e3}))}watchSystemBalance(t){let e=this.api.query.System.Account;return kt(()=>e.watchValue(t,{at:"best"})).pipe(bt(({value:i})=>({id:0,balance:this.getBreakdown(i.data)})),Dt({error:i=>yt.error("balance(system)",i)}))}watchTokenBalance(t,e){let i=this.api.query.Tokens.Accounts;return kt(()=>i.watchValue(t,e,{at:"best"})).pipe(bt(({value:r})=>({id:e,balance:this.getBreakdown(r)})),Dt({error:r=>yt.error("balance(token)",r)}))}watchTokensBalance(t){let e=this.api.query.Tokens.Accounts;return kt(()=>e.watchEntries(t,{at:"best"})).pipe(ki((i,r)=>!r.deltas),bt(({deltas:i})=>{let r=[];return i?.deleted.forEach(a=>{let[n,s]=a.args;r.push({id:s,balance:this.getBreakdown({free:0n,reserved:0n,frozen:0n})})}),i?.upserted.forEach(a=>{let[n,s]=a.args;r.push({id:s,balance:this.getBreakdown(a.value)})}),r}),Dt({error:i=>yt.error("balance(tokens)",i)}))}watchErc20Balance(t,e){let i=async()=>{if(this.erc20Ids)return this.erc20Ids;let a=await this.api.query.AssetRegistry.Assets.getEntries({at:"best"});return this.erc20Ids=a.filter(({value:n})=>n.asset_type.type==="Erc20").map(({keyArgs:n})=>{let[s]=n;return s}),this.erc20Ids},r=async a=>(await Promise.all(a.map(async s=>[s,await this.getBalanceData(t,s)]))).map(([s,o])=>({id:s,balance:o}));return kt(()=>Ei(e?Promise.resolve(e):i()).pipe(Mi(a=>this.watcher.bestBlock$.pipe(Mi(()=>Ei(r(a))))),Di([]),Ci(2,1),bt(([a,n],s)=>s===0?n.filter(o=>o.balance.total>0n):this.getDeltas(a,n)),ki((a,n)=>n.length===0),Dt({error:a=>yt.error("balance(erc20)",a)})))}async getBalanceData(t,e){let i=await this.api.apis.CurrenciesApi.account(e,t,{at:this.at});return this.getBreakdown(i)}getBreakdown(t){let e=t.free>=t.frozen?t.free-t.frozen:0n,i=t.free+t.reserved;return{free:t.free,reserved:t.reserved,frozen:t.frozen,total:i,transferable:e}}getDeltas(t,e){let i=(a,n)=>a!==void 0&&n!==void 0&&a.transferable===n.transferable&&a.total===n.total,r=t.reduce((a,n)=>(a.set(n.id,n.balance),a),new Map);return e.filter(a=>!i(a.balance,r.get(a.id)))}};var ft=class extends R{_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}};var qi={};O(qi,{AssetNotFound:()=>je,PoolNotFound:()=>nt,RouteNotFound:()=>Mt});var je=class extends Error{constructor(t){super(),this.message=`${t} not found`,this.name="AssetNotFound"}},nt=class extends Error{constructor(t){super(),this.message=`${t} pool invalid`,this.name="PoolNotFound"}},Mt=class extends Error{constructor(t,e){super(),this.message=`Route from ${t} to ${e} not found in current configuration`,this.name="RouteNotFound"}};var Vi={};O(Vi,{EvmClient:()=>qt,EvmRpcAdapter:()=>Lt,createChain:()=>Qe});import{Binary as Hi}from"polkadot-api";import{hydration as Aa}from"@galacticcouncil/descriptors";import{encodeFunctionData as Ba,decodeFunctionResult as _a}from"viem";var Fa=10000000n,Lt=class{api;constructor(t){this.api=t.getTypedApi(Aa)}async getBlock(){let t=await this.api.query.Ethereum.CurrentBlock.getValue({at:"best"}),{header:e}=t,i=e.timestamp/1000n,[r]=e.number;return{timestamp:i,number:r}}readContract=(async t=>{let{abi:e,address:i,functionName:r,args:a}=t,n=Ba({abi:e,functionName:r,args:a}),s=await this.api.apis.EthereumRuntimeRPCApi.call("0x0000000000000000000000000000000000000000",i,Hi.fromHex(n),[0n,0n,0n,0n],[Fa,0n,0n,0n],void 0,void 0,void 0,!1,[],[]);if(!s.success)throw console.error(r,s.value.type),new Error("Contract read failure");let{exit_reason:o,value:l,used_gas:c}=s.value;if(console.log(c),o.type==="Succeed")return _a({abi:e,functionName:r,data:Hi.toHex(l)});throw console.log(r,o.type,o.value.type),new Error("Contract read error")})};import{defineChain as Ra}from"viem";var Ea=["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"],Qe=()=>Ra({id:222222,name:"Hydration",network:"hydration",nativeCurrency:{decimals:18,name:"WETH",symbol:"WETH"},rpcUrls:{default:{http:Ea}},blockExplorers:{default:{name:"Hydration Explorer",url:"https://hydration.subscan.io"}},testnet:!1});import{createPublicClient as Ni,createWalletClient as Ca,custom as Gi,http as ka}from"viem";var qt=class{client;chain;constructor(t){this.client=t,this.chain=Qe()}get chainId(){return this.chain.id}get chainCurrency(){return this.chain.nativeCurrency.symbol}get chainDecimals(){return this.chain.nativeCurrency.decimals}getProvider(){return Ni({chain:this.chain,transport:ka()})}getWsProvider(){return Ni({transport:Gi({request:({method:t,params:e})=>this.client._request(t,e||[])})})}getSigner(t){return Ca({account:t,chain:this.chain,transport:Gi(window.ethereum)})}getRPCAdapter(){return new Lt(this.client)}};var Ji={};O(Ji,{LiquidityMiningApi:()=>Nt,LiquidityMiningClient:()=>Gt});import{AccountId as Za}from"polkadot-api";import q from"big.js";import{HYDRATION_SS58_PREFIX as tn,RUNTIME_DECIMALS as Pt}from"@galacticcouncil/common";import{fixed_from_rational as ji}from"@galacticcouncil/math-liquidity-mining";var we={};O(we,{withTimeout:()=>Da});function Da(p,t,e="timeout"){return new Promise((i,r)=>{let a=setTimeout(()=>r(new Error(e)),t);p.then(n=>{clearTimeout(a),i(n)},n=>{clearTimeout(a),r(n)})})}var B={};O(B,{divSpot:()=>La,getFraction:()=>qa,mulScaled:()=>Wi,mulSpot:()=>Ma});import{RUNTIME_DECIMALS as Ui}from"@galacticcouncil/common";function Wi(p,t,e,i,r){let a=e+i-r,n=p*t;return a>0?n/BigInt(10)**BigInt(a):a<0?n*BigInt(10)**BigInt(-a):n}function Ma(p,t,e,i){return Wi(p,t,e,Ui,i)}function La(p,t,e,i){if(t===0n)return 0n;let r=BigInt(10)**BigInt(Ui+i-e);return p*r/t}function qa(p,t,e=2){if(t<.01||t>100)throw new Error("Supported range is from 0.01% - 100%");let i=BigInt(10)**BigInt(e),r=BigInt(Math.round(t*Number(i)));return p*r/(BigInt(100)*i)}var T={};O(T,{FeeUtils:()=>Je,shiftNeg:()=>Na});import Ha from"big.js";var Je=class p{static toPct(t){let[e,i]=t;return p.safeDivide(e*100,i)}static toRaw(t){let[e,i]=t;return p.safeDivide(e,i)}static fromPermill(t){return[t,1e6]}static fromPerbill(t){return[t,1e9]}static fromRate(t,e){return[t,e]}static safeDivide(t,e,i=12){let r=10**i;return Math.round(t*r/e)/r}static safeRound(t){return parseFloat(t.toPrecision(15))}};function Na(p,t){let e=Ha(typeof p=="bigint"?p.toString():p);return t===0?e.toString():e.div(Math.pow(10,t)).toString()}var Ht={};O(Ht,{findNestedKey:()=>Ga,findNestedObj:()=>Va,jsonFormatter:()=>Ua});var Ga=(p,t)=>{let e=[];return JSON.stringify(p,(i,r)=>(r&&r[t]&&e.push(r),r)),e[0]},Va=(p,t,e)=>{let i;return JSON.stringify(p,(r,a)=>(a&&a[t]===e&&(i=a),a)),i},Ua=(p,t)=>typeof t=="bigint"?t.toString():t;var L={};O(L,{calculateBuyFee:()=>Xa,calculateDiffToAvg:()=>Wa,calculateDiffToRef:()=>Ya,calculateSellFee:()=>$a});import Q from"big.js";function Wa(p,t){let e=Q(p.toString()),i=Q(t.toString());return e.minus(i).abs().div(e.plus(i).div(2)).mul(100).round(2).toNumber()}function Ya(p,t){if(t===0n)return 0;let e=Q(p.toString()),i=Q(t.toString());return e.minus(i).div(i).mul(100).round(2).toNumber()}function $a(p,t){if(p===0n)return 0;let e=Q(p.toString()),i=Q(t.toString());return Q(1).minus(i.div(e)).mul(100).round(2).toNumber()}function Xa(p,t){if(p===0n)return 0;let e=Q(p.toString());return Q(t.toString()).div(e).minus(1).mul(100).round(2).toNumber()}import{TLRUCache as Yi}from"@thi.ng/cache";var Te=class{debug;constructor(t){this.debug=t||!1}log(t,e,i){this.debug&&console.log(t,e,i)}scope(t,e,i,r){let a=new Map,n=r!==void 0?new Yi(null,{ttl:r}):new Yi;return{get:(...c)=>{let u=i(...c);if(a.has(u)){this.log("[live]",t,u);let m=a.get(u);return Promise.resolve(m)}if(n.has(u))return this.log("[memo]",t,u),n.get(u);this.log("[fetch]",t,u);let d=e(...c).catch(m=>{throw n.delete(u),m});return n.set(u,d),d},set:(c,...u)=>{let d=i(...u);this.log("[set-live]",t,d),a.set(d,c)},clear:()=>{this.log("[clear]",t),a.clear(),n.release()}}}};var xe=class{result=new Map;getKey(t,e){return[e,t.toString()].join(",")}constructor(t,e){for(let i=0;i<t.length;++i){let[r,a]=t[i];this.result.set(this.getKey(a,r),e[i].free)}}freeBalance(t,e){return this.result.get(this.getKey(t,e))??0n}transfer(t,e,i,r){let a=this.getKey(t,e),n=this.getKey(t,i),s=this.result.get(a)??0n,o=this.result.get(n)??0n;if(s<r)throw new Error("Attempting to transfer more than is present");this.result.set(a,s+r),this.result.set(n,o+r)}};import st from"big.js";import{calculate_accumulated_rps as za,calculate_global_farm_rewards as Ka,calculate_loyalty_multiplier as ja,calculate_user_reward as Ki,calculate_yield_farm_delta_rpvs as Qa}from"@galacticcouncil/math-liquidity-mining";import $i from"big.js";var Ze=$i(10).pow(18),Xi=BigInt($i(1).pow(18).toString()),zi=6e3;var Ja="1000000000000000000",ve=class{constructor(t,e,i){this.getAccount=t;this.getAsset=e;this.multiCurrency=i}async syncGlobalFarm(t,e,i){if(t.state.type!=="Active"||t.updated_at===e)return null;if(t.total_shares_z===0n)return t;let r=await this.getAsset(t.reward_currency),a=e-t.updated_at,n=this.getAccount(t.id),s=r?.existential_deposit;if(!s)throw new Error("Missing reward currency asset list");let o=this.multiCurrency.freeBalance(t.reward_currency,n),l=st(s.toString()),c=st(o.toString()).minus(l.lt(o.toString())?s.toString():o.toString()),u=st(Ka(t.total_shares_z.toString(),i.toString(),st(t.yield_per_period.toString()).mul(Ze).round(0,st.roundDown).toFixed(),t.max_reward_per_period.toString(),a.toFixed()));if(c.lt(u)&&(u=c),u.eq(0))return t;let d=this.getAccount(0);return this.multiCurrency.transfer(t.reward_currency,n,d,BigInt(u.toFixed())),{...t,accumulated_rpz:BigInt(za(t.accumulated_rpz.toString(),t.total_shares_z.toString(),u.toFixed()))}}syncYieldFarm(t,e,i){if(t.state.type!=="Active"||t.updated_at===i)return t;if(t.total_valued_shares===0n)return{...t,updated_at:i};let r=Qa(t.accumulated_rpz.toString(),e.accumulated_rpz.toString(),t.multiplier.toString(),t.total_valued_shares.toString());return{...t,accumulated_rpvs:t.accumulated_rpvs+BigInt(r),updated_at:i}}getLoyaltyMultiplier(t,e){let i=st(1).mul(Ze).round(0,st.roundDown).toString();if(!e)return i;let{initial_reward_percentage:r,scale_coef:a}=e;return ja(t.toFixed(),r.toString(),a.toFixed())}async claimRewards(t,e,i,r,a){if(e.state.type==="Terminated")return null;let n=Math.floor(r/t.blocks_per_period);if(i.updated_at===n)return null;let s=await this.syncGlobalFarm(t,n,a);if(!s)return null;let o=this.syncYieldFarm(e,s,n);if(!o)return null;let l=o.total_stopped-i.stopped_at_creation,c=o.updated_at-i.entered_at-l,u=this.getLoyaltyMultiplier(c,o.loyalty_curve),d=BigInt(Ki(i.accumulated_rpvs.toString(),i.valued_shares.toString(),i.accumulated_claimed_rewards.toString(),o.accumulated_rpvs.toString(),u)),m=BigInt(Ki(i.accumulated_rpvs.toString(),i.valued_shares.toString(),i.accumulated_claimed_rewards.toString(),o.accumulated_rpvs.toString(),Ja));return{reward:d,maxReward:m,assetId:s.reward_currency,yieldFarmId:o.id,isActiveFarm:o.state.type==="Active"}}};var en=q(365.2425).times(24).times(60).times(60),Nt=class{balance;client;options;constructor(t,e,i={}){this.client=t,this.balance=e,this.options=Object.freeze({blockTime:i.blockTime??zi})}get blockTime(){return this.options.blockTime}async getOraclePrice(t,e){let i=[t,e].sort((a,n)=>a-n);if(t===e)return Xi;let r=await this.client.getOraclePrice(i);if(r){let{n:a,d:n}=r[0].price,s;return t<e?s=ji(a.toString(),n.toString()):s=ji(n.toString(),a.toString()),BigInt(s)}}getFarmAddress=(t,e)=>{let i=Buffer.from("modl","utf-8"),r=Buffer.from(e?"78796b4c4d704944":"4f6d6e6957684c4d","hex"),a=Buffer.from([t]),n=Buffer.concat([i,r,a]),o="0x"+Buffer.concat([n,Buffer.alloc(32-n.length)]).toString("hex");return Za(tn).dec(o)};getGlobalRewardPerPeriod(t,e,i,r){let a=q(r).times(t.toString()).times(e.toString()).div(Math.pow(10,Pt));return a.gte(i.toString())?i.toString():a.toString()}getPoolYieldPerPeriod(t,e,i,r){let a=q(t.toString()).times(e),n=q(i.toString()).times(r);return a.div(n.toString()).toString()}farmData(t,e,i){let{yieldFarm:r,globalFarm:a,priceAdjustment:n,balance:s,id:o}=t,{multiplier:l,loyalty_curve:c}=r,{blocks_per_period:u,yield_per_period:d,total_shares_z:m,max_reward_per_period:g,pending_rewards:b,accumulated_paid_rewards:h,planned_yielding_periods:y,updated_at:f,incentivized_asset:S,reward_currency:P,price_adjustment:w,min_deposit:x}=a,_=T.shiftNeg(n??w,Pt),H=T.shiftNeg(l,Pt),k=T.shiftNeg(c?.initial_reward_percentage??0,Pt),j=en.div(q(this.blockTime).div(1e3).times(u)).toString(),G;if(m<=0)G=q(H).times(d.toString()).times(j).div(Math.pow(10,Pt)).toString();else{let Nr=this.getGlobalRewardPerPeriod(m,d,g,_),Gr=this.getPoolYieldPerPeriod(Nr,H,m,_);G=q(Gr).times(j).toString()}let $=b+h,tt=g*BigInt(y),ue=s.transferable+$,vi=ue-$,pe=q(vi.toString()).div(g.toString()),me=q(e).div(u.toString()).toString(),de=(m>=0?pe.plus(f):pe.plus(me)).toString(),Ue=q(de).times(u).toString(),qr=q(m.toString()).div(q(g.toString()).div(d.toString())).div(Math.pow(10,Pt)).times(100).times(_).toFixed(2),Ii=q($.toString()).div(ue.toString()).gte(.999);G=Ii?"0":q(G).div(i?2:1).times(100).toString();let Hr=k?q(G).times(k).toString():void 0;return{apr:G,minApr:Hr,isDistributed:Ii,estimatedEndPeriod:de,estimatedEndBlock:Ue,maxRewards:tt,incentivizedAsset:S,rewardCurrency:P,loyaltyCurve:c,currentPeriod:me,potMaxRewards:ue,fullness:qr,yieldFarmId:r.id,globalFarmId:a.id,poolId:o,distributedRewards:$,plannedYieldingPeriods:y,minDeposit:x,blocksPerPeriod:u}}async getAllOmnipoolFarms(){let e=(await this.client.getAllOmnipooFarms()).reduce((r,a)=>r.includes(a.keyArgs[0].toString())?r:[...r,a.keyArgs[0].toString()],[]),i=await Promise.all(e.map(async r=>{let a=await this.getOmnipoolFarms(r);if(a)return[r,a]}));return Object.fromEntries(i.filter(r=>!!r))}async getOmnipoolFarms(t){let e=await this.client.getOmnipooFarms(Number(t)),i=await this.client.getRelayBlockNumber(),r=await Promise.all(e.map(async({keyArgs:a,value:n})=>{let[,s]=a,o=n,l=await this.client.getOmnipoolGlobalFarm(s),c=await this.client.getOmnipoolYieldFarm(Number(t),s,o);if(!l||!c)return;let u=l.reward_currency,d=l.incentivized_asset,m=this.getFarmAddress(s),g=await this.getOraclePrice(u,d),b=await this.balance.getBalance(m,u);return{id:t,globalFarm:l,yieldFarm:c,priceAdjustment:g,balance:b}}));return i?r.map(a=>a?this.farmData(a,i):void 0):[]}async getAllIsolatedFarms(){let e=(await this.client.getAllIsolatedFarms()).reduce((r,a)=>r.includes(a.keyArgs[0].toString())?r:[...r,a.keyArgs[0].toString()],[]),i=await Promise.all(e.map(async r=>{let a=await this.getIsolatedFarms(r);if(a)return[r,a]}));return Object.fromEntries(i.filter(r=>!!r))}async getIsolatedFarms(t){let e=await this.client.getIsolatedFarms(t),i=await this.client.getRelayBlockNumber(),r=await Promise.all(e.map(async({keyArgs:a,value:n})=>{let[,s]=a,o=n,l=await this.client.getIsolatedGlobalFarm(s),c=await this.client.getIsolatedYieldFarm(t,s,o);if(!l||!c)return;let u=l.reward_currency,d=l.incentivized_asset,m=this.getFarmAddress(s,!0),g=await this.getOraclePrice(u,d),b=await this.balance.getBalance(m,u);return{id:t,globalFarm:l,yieldFarm:c,priceAdjustment:g,balance:b,farmAddress:m}}));return i?r.map(a=>a?this.farmData(a,i,!0):void 0):[]}async getDepositReward(t,e,i,r){let a=e.global_farm_id,n=e.yield_farm_id,s=i?await this.client.getIsolatedYieldFarm(t,a,n):await this.client.getOmnipoolYieldFarm(Number(t),a,n),o=i?await this.client.getIsolatedGlobalFarm(a):await this.client.getOmnipoolGlobalFarm(a);if(!o||!s)return;let l=o.reward_currency,c=o.incentivized_asset,u=[[this.getFarmAddress(0,i),o.reward_currency],[this.getFarmAddress(o.id,i),o.reward_currency]],d=await this.getAccountAssetBalances(u),m=await this.getOraclePrice(l,c),g=new xe(u,d),h=await new ve(f=>this.getFarmAddress(f),f=>this.client.getAsset(f),g).claimRewards(o,s,e,r,m??o.price_adjustment);if(!h)return;let y=await this.client.getAsset(h.assetId);if(y&&!(h.reward<=y.existential_deposit))return h}async getAccountAssetBalances(t){let[e,i]=await Promise.all([Promise.all(t.filter(([a,n])=>n!==0).map(([a,n])=>this.balance.getTokenBalance(a,n))),Promise.all(t.filter(([a,n])=>n===0).map(([a])=>this.balance.getSystemBalance(a)))]),r=[];for(let a=0,n=0;a+n<t.length;){let s=a+n,[,o]=t[s];o===0?(r.push(i[n]),n+=1):(r.push(e[a]),a+=1)}return r}};import{Binary as Qi,Enum as rn}from"polkadot-api";var an=Qi.toHex(Qi.fromText("omnipool")),Gt=class extends R{omnipoolAssetIds=[];async getOraclePrice(t){return await this.api.query.EmaOracle.Oracles.getValue(an,t,rn("TenMinutes"))}async getRelayBlockNumber(){return(await this.api.query.ParachainSystem.ValidationData.getValue())?.relay_parent_number}async getAllOmnipooFarms(){return this.api.query.OmnipoolWarehouseLM.ActiveYieldFarm.getEntries()}async getOmnipooFarms(t){return this.api.query.OmnipoolWarehouseLM.ActiveYieldFarm.getEntries(t)}async getOmnipoolGlobalFarm(t){return this.api.query.OmnipoolWarehouseLM.GlobalFarm.getValue(t,{at:"best"})}async getOmnipoolYieldFarm(t,e,i){return this.api.query.OmnipoolWarehouseLM.YieldFarm.getValue(t,e,i,{at:"best"})}async getAllIsolatedFarms(){return this.api.query.XYKWarehouseLM.ActiveYieldFarm.getEntries()}async getIsolatedFarms(t){return this.api.query.XYKWarehouseLM.ActiveYieldFarm.getEntries(t)}async getIsolatedGlobalFarm(t){return this.api.query.XYKWarehouseLM.GlobalFarm.getValue(t,{at:"best"})}async getIsolatedYieldFarm(t,e,i){return this.api.query.XYKWarehouseLM.YieldFarm.getValue(t,e,i,{at:"best"})}async getAsset(t){return this.api.query.AssetRegistry.Assets.getValue(t)}};var Pr={};O(Pr,{PoolContextProvider:()=>At,PoolError:()=>et,PoolFactory:()=>Ot,PoolType:()=>v,SnapshotPoolCtxProvider:()=>Ce,aave:()=>mi,hsm:()=>bi,lbp:()=>ai,omni:()=>li,stable:()=>ci,xyk:()=>ui});var ai={};O(ai,{LbpMath:()=>X,LbpPool:()=>Vt,LbpPoolClient:()=>Yt});import{calculate_in_given_out as nn,calculate_out_given_in as sn,calculate_linear_weights as on,calculate_pool_trade_fee as ln,get_spot_price as cn}from"@galacticcouncil/math-lbp";var X=class{static getSpotPrice(t,e,i,r,a){return cn(t,e,i,r,a)}static calculateInGivenOut(t,e,i,r,a){return nn(t,e,i,r,a)}static calculateOutGivenIn(t,e,i,r,a){return sn(t,e,i,r,a)}static calculateLinearWeights(t,e,i,r,a){return on(t,e,i,r,a)}static calculatePoolTradeFee(t,e,i){return ln(t,e,i)}};import{big as Zi,RUNTIME_DECIMALS as tr}from"@galacticcouncil/common";var v=(n=>(n.Aave="Aave",n.LBP="LBP",n.Omni="Omnipool",n.Stable="Stableswap",n.XYK="XYK",n.HSM="HSM",n))(v||{}),et=(c=>(c.UnknownError="UnknownError",c.FacilitatorCapacityExceeded="FacilitatorCapacityExceeded",c.InsufficientTradingAmount="InsufficientTradingAmount",c.InsufficientCollateral="InsufficientCollateral",c.MaxHoldingExceeded="MaxHoldingExceeded",c.MaxInRatioExceeded="MaxInRatioExceeded",c.MaxOutRatioExceeded="MaxOutRatioExceeded",c.TradeNotAllowed="TradeNotAllowed",c.MaxBuyBackExceeded="MaxBuyBackExceeded",c.MaxBuyPriceExceeded="MaxBuyPriceExceeded",c))(et||{});var{FeeUtils:er}=T,Vt=class p{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;fee;repayFeeApply;static fromPool(t){return new p(t)}constructor(t){this.type="LBP",this.address=t.address,this.tokens=t.tokens,this.maxInRatio=t.maxInRatio,this.maxOutRatio=t.maxOutRatio,this.minTradingLimit=t.minTradingLimit,this.fee=t.fee,this.repayFeeApply=t.repayFeeApply}validatePair(t,e){return!0}parsePair(t,e){let i=new Map(this.tokens.map(n=>[n.id,n])),r=i.get(t),a=i.get(e);if(r==null)throw new Error("Pool does not contain tokenIn");if(a==null)throw new Error("Pool does not contain tokenOut");return{assetIn:t,assetOut:e,balanceIn:r.balance,balanceOut:a.balance,decimalsIn:r.decimals,decimalsOut:a.decimals,weightIn:r.weight,weightOut:a.weight}}validateAndBuy(t,e,i){let r=this.tokens[0].id,a=[];e<this.minTradingLimit&&a.push("InsufficientTradingAmount");let n=t.balanceOut/this.maxOutRatio;if(e>n&&a.push("MaxOutRatioExceeded"),r===t.assetOut){let s=this.calculateTradeFee(e,i),o=er.toPct(this.repayFeeApply?i.repayFee:i.exchangeFee),l=e+s,c=this.calculateInGivenOut(t,l),u=t.balanceIn/this.maxInRatio;return c>u&&a.push("MaxInRatioExceeded"),{amountIn:c,calculatedIn:c,amountOut:e,feePct:o,errors:a}}else{let s=this.calculateInGivenOut(t,e),o=t.balanceIn/this.maxInRatio;return s>o&&a.push("MaxInRatioExceeded"),{amountIn:s,calculatedIn:s,amountOut:e,feePct:0,errors:a}}}validateAndSell(t,e,i){let r=this.tokens[0].id,a=[];e<this.minTradingLimit&&a.push("InsufficientTradingAmount");let n=t.balanceIn/this.maxInRatio;if(e>n&&a.push("MaxInRatioExceeded"),r===t.assetIn){let s=this.calculateOutGivenIn(t,e),o=t.balanceOut/this.maxOutRatio;return s>o&&a.push("MaxOutRatioExceeded"),{amountIn:e,calculatedOut:s,amountOut:s,feePct:0,errors:a}}else{let s=this.calculateOutGivenIn(t,e),o=this.calculateTradeFee(s,i),l=er.toPct(this.repayFeeApply?i.repayFee:i.exchangeFee),c=s-o,u=t.balanceOut/this.maxOutRatio;return c>u&&a.push("MaxOutRatioExceeded"),{amountIn:e,calculatedOut:s,amountOut:c,feePct:l,errors:a}}}calculateInGivenOut(t,e){let i=X.calculateInGivenOut(t.balanceIn.toString(),t.balanceOut.toString(),t.weightIn.toString(),t.weightOut.toString(),e.toString()),r=BigInt(i);return r<0n?0n:r}calculateOutGivenIn(t,e){let i=X.calculateOutGivenIn(t.balanceIn.toString(),t.balanceOut.toString(),t.weightIn.toString(),t.weightOut.toString(),e.toString()),r=BigInt(i);return r<0n?0n:r}spotPriceInGivenOut(t){let e=X.getSpotPrice(t.balanceOut.toString(),t.balanceIn.toString(),t.weightOut.toString(),t.weightIn.toString(),Zi.toBigInt(1,tr).toString());return BigInt(e)}spotPriceOutGivenIn(t){let e=X.getSpotPrice(t.balanceIn.toString(),t.balanceOut.toString(),t.weightIn.toString(),t.weightOut.toString(),Zi.toBigInt(1,tr).toString());return BigInt(e)}calculateTradeFee(t,e){let i=X.calculatePoolTradeFee(t.toString(),this.repayFeeApply?e.repayFee[0]:e.exchangeFee[0],this.repayFeeApply?e.repayFee[1]:e.exchangeFee[1]);return BigInt(i)}};import{CompatibilityLevel as Bn}from"polkadot-api";import{Subscription as _n,distinctUntilChanged as Fn,filter as Rn,map as En}from"rxjs";import{memoize1 as dn}from"@thi.ng/memoize";import{TLRUCache as gn}from"@thi.ng/cache";import{ReplaySubject as ir,Subscription as rr,combineLatest as hn,defer as bn,from as yn,interval as fn,merge as ti,of as Pn,EMPTY as Ut}from"rxjs";import{bufferCount as Sn,bufferTime as wn,catchError as Wt,filter as Be,finalize as ei,map as St,pairwise as ii,repeat as ri,skip as Tn,share as xn,startWith as vn,switchMap as ar,tap as ot,throttleTime as In}from"rxjs/operators";import{BehaviorSubject as un}from"rxjs";var Ie=class{store$=new un([]);updateQueue=Promise.resolve();changeset=new Set;get pools(){return this.store$.value}asObservable(){return this.store$.asObservable()}applyChangeset(t){return this.changeset.size===0?[]:t.filter(e=>this.changeset.has(e.address))}set(t){this.changeset=new Set(t.map(e=>e.address)),this.store$.next(t)}update(t){this.updateQueue=this.updateQueue.then(async()=>{let e=this.store$.value,i=new Map(e.map((s,o)=>[s.address,o])),r=await t(e),a=e.slice(),n=new Set;for(let s of r){let o=i.get(s.address);o===void 0?(i.set(s.address,a.length),a.push(s)):a[o]=s,n.add(s.address)}this.changeset=n,this.store$.next(a)}).catch(console.error)}destroy(){this.store$.complete()}};import{log as pn}from"@galacticcouncil/common";var mn={Aave:"AAVE",LBP:"LBP",Omnipool:"OMNI",Stableswap:"STBL",XYK:"XYK",HSM:"HSM"},{logger:Oe}=pn,Ae=class{type;constructor(t){this.type=t}prefix(){return this.pad(`pool(${mn[this.type]})`,10)}trace(t,...e){Oe.trace(`${this.prefix()} ${t} :`,...e)}debug(t,...e){Oe.debug(`${this.prefix()} ${t} :`,...e)}info(t,...e){Oe.info(`${this.prefix()} ${t} :`,...e)}error(t,...e){Oe.error(`${this.prefix()} ${t} :`,...e)}pad(t,e){return t.length>=e?t:t+" ".repeat(e-t.length)}};var{withTimeout:On}=we,An=3e3,N=class extends R{evm;balance;store=new Ie;log;shared$;resync$=new ir(1);resyncAt=0;resyncPending=!1;mem=0;memPoolsCache=new gn(null,{ttl:6*1e3});memPools=dn(t=>(this.log.info("pool_sync",{mem:t}),this.loadPools()),this.memPoolsCache);constructor(t,e,i){super(t,i),this.evm=e,this.balance=new z(t,i),this.log=new Ae(this.getPoolType())}async getMemPools(){return this.memPools(this.mem)}async getPools(){let e=(await this.getMemPools()).filter(i=>this.hasValidAssets(i));return this.store.set(e),e}getSubscriber(){return this.shared$||(this.shared$=this.subscribeStore()),this.shared$.pipe(vn([]),Sn(2,1),St(([t,e])=>t.length===0?e:this.store.applyChangeset(e)),Be(t=>t.length>0),In(1e3,void 0,{leading:!0,trailing:!0}))}subscribeStore(){return bn(()=>{let t=new rr;return t.add(this.startWatchdog()),this.resync$.next(),this.resync$.pipe(ar(()=>{let e=new rr;return yn(On(this.getMemPools(),6e4,"getMemPools stalled")).pipe(ot(()=>this.log.info("pool_synced",{mem:this.mem})),St(r=>r.filter(a=>this.hasValidAssets(a))),ot(r=>this.store.set(r)),Wt(()=>(this.log.error("pool_seed_error",{mem:this.mem}),this.requestResync(),Ut))).pipe(ot(()=>{e.add(this.subscribeBalances()),e.add(this.subscribeUpdates())}),ar(r=>ti(Pn(r),this.store.asObservable().pipe(Tn(1)))),ei(()=>{e.unsubscribe()}))}),ei(()=>t.unsubscribe()))}).pipe(xn({connector:()=>new ir(1),resetOnRefCountZero:!0}))}subscribeBalances(){let t=this.store.pools.map(e=>{let{address:i}=e,r=[this.balance.watchTokensBalance(i)];if(this.hasSystemAsset(e)){let a=this.balance.watchSystemBalance(i);r.push(a)}if(this.hasErc20Asset(e)){let a=e.tokens.filter(s=>s.type==="Erc20").map(s=>s.id),n=this.balance.watchErc20Balance(i,a);r.push(n)}return hn(r).pipe(St(a=>a.flat()),ii(),St(([a,n])=>this.balance.getDeltas(a,n)),Be(a=>a.length>0),St(a=>[i,a]))});return ti(...t).pipe(wn(250),Be(e=>e.length>0),St(e=>new Map(e)),this.watchGuard("balances")).subscribe(e=>{this.store.update(i=>this.updateBalances(i,e))})}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(({decimals:e,balance:i})=>t.type==="XYK"?i>0n&&!!e:!!e)}updateBalances=(t,e)=>{let i=[],r=new Map(t.map(a=>[a.address,a]));for(let[a,n]of e){let s=r.get(a);if(s){let o=s.tokens.map(l=>{let c=n.find(u=>u.id===l.id);return c&&l.id!==s.id?{...l,balance:c.balance.transferable}:l});i.push({...s,tokens:o})}}return i};resync(t=!1){let e=Date.now();!t&&e-this.resyncAt<An||(this.resyncAt=e,this.mem++,this.resync$.next())}requestResync(t=!1){this.resyncPending||(this.resyncPending=!0,setTimeout(()=>{this.resyncPending=!1,this.resync(t)},0))}startWatchdog(){let r=this.watcher.connection$.pipe(ii(),Be(([s,o])=>s==="offline"&&o==="online"),ot(()=>{this.log.debug("watchdog_recover_online",{mem:this.mem}),this.requestResync()}),Wt(s=>(this.log.error("watchdog_recovery_error",s),Ut)),ri({delay:1e3})),a=this.watcher.finalizedBlock$.pipe(ii(),ot(([s,o])=>{let l=Number(s.number),c=Number(o.number),u=c-l;u>=3&&(this.log.debug("watchdog_gap",{from:l,to:c,gap:u}),this.requestResync())}),Wt(s=>(this.log.error("watchdog_gap_error",s),Ut)),ri({delay:1e3})),n=fn(36e5).pipe(ot(()=>{this.log.debug("watchdog_periodic",{mem:this.mem}),this.requestResync()}),Wt(s=>(this.log.error("watchdog_periodic_error",s),Ut)),ri({delay:1e3}));return ti(r,a,n).subscribe()}watchGuard(t){return e=>e.pipe(ot({error:i=>{this.log.error(t,i),this.requestResync(!0)}}),ei(()=>{this.log.debug(t,"unsub")}),Wt(()=>Ut))}};var Yt=class extends N{MAX_FINAL_WEIGHT=100000000n;poolsData=new Map([]);getPoolType(){return"LBP"}async getPoolLimits(){let[t,e,i]=await Promise.all([this.api.constants.LBP.MaxInRatio(),this.api.constants.LBP.MaxOutRatio(),this.api.constants.LBP.MinTradingLimit()]);return{maxInRatio:t,maxOutRatio:e,minTradingLimit:i}}getPoolWeights(t,e){let{start:i,end:r,initial_weight:a,final_weight:n}=t,s=X.calculateLinearWeights(i?i.toString():"0",r?r.toString():"0",a.toString(),n.toString(),e.toString()),o=BigInt(s),l=this.MAX_FINAL_WEIGHT-BigInt(o);return[o,l]}async isSupported(){return(await this.api.getStaticApis()).compat.query.LBP.PoolData.isCompatible(Bn.BackwardsCompatible)}async loadPools(){let[t,e,i]=await Promise.all([this.api.query.LBP.PoolData.getEntries({at:this.at}),this.api.query.ParachainSystem.ValidationData.getValue({at:this.at}),this.getPoolLimits()]),r=e?.relay_parent_number||0,a=t.filter(({value:n})=>e&&this.isActivePool(n,r)).map(async({keyArgs:n,value:s})=>{let[o]=n,l=o.toString(),c=await this.getPoolDelta(l,s,r);return{address:l,type:"LBP",fee:s.fee,...c,...i}});return Promise.all(a)}async getPoolDelta(t,e,i){let{assets:r,repay_target:a,fee_collector:n}=e,[s,o]=this.getPoolWeights(e,i),[l,c]=r,[u,d,m,g,b]=await Promise.all([this.isRepayFeeApplied(l,a,n.toString()),this.balance.getBalance(t,l),this.api.query.AssetRegistry.Assets.getValue(l,{at:this.at}),this.balance.getBalance(t,c),this.api.query.AssetRegistry.Assets.getValue(c,{at:this.at})]);return{repayFeeApply:u,tokens:[{id:l,decimals:m?.decimals,existentialDeposit:m?.existential_deposit,balance:d.transferable,weight:s,type:m?.asset_type.type},{id:c,decimals:b?.decimals,existentialDeposit:b?.existential_deposit,balance:g.transferable,weight:o,type:b?.asset_type.type}]}}isActivePool(t,e){let{start:i,end:r}=t;return i&&r?e>=i&&e<r:!1}async isRepayFeeApplied(t,e,i){if(e===0n)return!1;try{return(await this.balance.getBalance(i,t)).transferable<e}catch{return!0}}async getRepayFee(){return await this.api.constants.LBP.repay_fee()}async getPoolFees(t,e){let i=this.store.pools.find(a=>a.address===e);return{repayFee:await this.getRepayFee(),exchangeFee:i.fee}}subscribeValidationData(){return this.api.query.ParachainSystem.ValidationData.watchValue({at:"best"}).pipe(En(({value:t})=>t),Rn(t=>t!==void 0),Fn((t,e)=>t.relay_parent_number===e.relay_parent_number),this.watchGuard("parachainSystem.ValidationData")).subscribe(({relay_parent_number:t})=>{this.store.update(async e=>{let i=[];for(let r of e){let a=this.poolsData.get(r.address);if(a){let{assets:n,repay_target:s,fee_collector:o}=a,[l]=n,[c,u]=this.getPoolWeights(a,t),[d,m]=r.tokens,g=[{...d,weight:c},{...m,weight:u}],b=await this.isRepayFeeApplied(l,s,o.toString());i.push({...r,tokens:g,repayFeeApply:b})}}return i})})}subscribeUpdates(){let t=new _n;return t.add(this.subscribeValidationData()),t}};var li={};O(li,{OmniMath:()=>I,OmniPool:()=>$t,OmniPoolClient:()=>Xt,OmniPoolFee:()=>lt,getEmaKey:()=>_e,getEmaPair:()=>Tt});import{calculate_in_given_out as Cn,calculate_lrna_in_given_out as kn,calculate_out_given_in as Dn,calculate_out_given_lrna_in as Mn,calculate_spot_price as Ln,calculate_lrna_spot_price as qn,calculate_shares as Hn,calculate_liquidity_out as Nn,calculate_liquidity_lrna_out as Gn,verify_asset_cap as Vn,calculate_liquidity_hub_in as Un,is_sell_allowed as Wn,is_buy_allowed as Yn,is_add_liquidity_allowed as $n,is_remove_liquidity_allowed as Xn,recalculate_asset_fee as zn,recalculate_protocol_fee as Kn}from"@galacticcouncil/math-omnipool";import wt from"big.js";var I=class{static calculateSpotPrice(t,e,i,r){return Ln(t,e,i,r)}static calculateLrnaSpotPrice(t,e){return qn(t,e)}static calculateInGivenOut(t,e,i,r,a,n,s,o,l,c){return Cn(t,e,i,r,a,n,s,o,l,c)}static calculateLrnaInGivenOut(t,e,i,r,a,n){return kn(t,e,i,r,a,n)}static calculateOutGivenIn(t,e,i,r,a,n,s,o,l,c){return Dn(t,e,i,r,a,n,s,o,l,c)}static calculateOutGivenLrnaIn(t,e,i,r,a,n){return Mn(t,e,i,r,a,n)}static calculateShares(t,e,i,r){return Hn(t,e,i,r)}static calculateLiquidityOut(t,e,i,r,a,n,s,o){return Nn(t,e,i,r,a,n,s,o)}static calculateLiquidityLRNAOut(t,e,i,r,a,n,s,o){return Gn(t,e,i,r,a,n,s,o)}static calculateCapDifference(t,e,i,r){let a=wt(e),n=wt(t),s=wt(r),o=wt(i),l=wt(10).pow(18),c=o.div(l);if(a.div(s).lt(c)){let d=c.times(s).minus(a).times(n),m=a.times(wt(1).minus(c));return d.div(m).toFixed(0)}else return"0"}static calculateLimitHubIn(t,e,i,r){return Un(t,e,i,r)}static isSellAllowed(t){return Wn(t)}static isBuyAllowed(t){return Yn(t)}static isAddLiquidityAllowed(t){return $n(t)}static isRemoveLiquidityAllowed(t){return Xn(t)}static recalculateAssetFee(t,e,i,r,a,n,s,o,l,c,u){return zn(t,e,i,r,a,n,s,o,l,c,u)}static recalculateProtocolFee(t,e,i,r,a,n,s,o,l,c,u){return Kn(t,e,i,r,a,n,s,o,l,c,u)}static verifyAssetCap(t,e,i,r){return Vn(t,e,i,r)}};import{big as jn}from"@galacticcouncil/common";var{FeeUtils:K}=T,$t=class p{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;hubAssetId;static fromPool(t){return new p(t)}constructor(t){this.type="Omnipool",this.address=t.address,this.tokens=t.tokens,this.maxInRatio=t.maxInRatio,this.maxOutRatio=t.maxOutRatio,this.minTradingLimit=t.minTradingLimit,this.hubAssetId=t.hubAssetId}validatePair(t,e){return this.hubAssetId!=e}parsePair(t,e){let i=new Map(this.tokens.map(n=>[n.id,n])),r=i.get(t),a=i.get(e);if(r==null)throw new Error("Pool does not contain tokenIn");if(a==null)throw new Error("Pool does not contain tokenOut");return{assetIn:t,assetOut:e,hubReservesIn:r.hubReserves,hubReservesOut:a.hubReserves,sharesIn:r.shares,sharesOut:a.shares,decimalsIn:r.decimals,decimalsOut:a.decimals,balanceIn:r.balance,balanceOut:a.balance,tradeableIn:r.tradeable,tradeableOut:a.tradeable,assetInEd:r.existentialDeposit,assetOutEd:a.existentialDeposit}}validateAndBuy(t,e,i){let r=this.calculateInGivenOut(t,e),a=this.calculateInGivenOut(t,e,i),n=r===0n?0:L.calculateBuyFee(r,a),s=[],o=I.isSellAllowed(t.tradeableIn),l=I.isBuyAllowed(t.tradeableOut);(!o||!l)&&s.push("TradeNotAllowed"),(e<this.minTradingLimit||r<t.assetInEd)&&s.push("InsufficientTradingAmount");let c=t.balanceOut/this.maxOutRatio;e>c&&s.push("MaxOutRatioExceeded");let u=t.balanceIn/this.maxInRatio;return a>u&&s.push("MaxInRatioExceeded"),{amountIn:a,calculatedIn:r,amountOut:e,feePct:n,errors:s}}validateAndSell(t,e,i){let r=this.calculateOutGivenIn(t,e),a=this.calculateOutGivenIn(t,e,i),n=L.calculateSellFee(r,a),s=[],o=I.isSellAllowed(t.tradeableIn),l=I.isBuyAllowed(t.tradeableOut);(!o||!l)&&s.push("TradeNotAllowed"),(e<this.minTradingLimit||r<t.assetOutEd)&&s.push("InsufficientTradingAmount");let c=t.balanceIn/this.maxInRatio;e>c&&s.push("MaxInRatioExceeded");let u=t.balanceOut/this.maxOutRatio;return a>u&&s.push("MaxOutRatioExceeded"),{amountIn:e,calculatedOut:r,amountOut:a,feePct:n,errors:s}}calculateInGivenOut(t,e,i){if(t.assetIn==this.hubAssetId)return this.calculateLrnaInGivenOut(t,e,i);let r=I.calculateInGivenOut(t.balanceIn.toString(),t.hubReservesIn.toString(),t.sharesIn.toString(),t.balanceOut.toString(),t.hubReservesOut.toString(),t.sharesOut.toString(),e.toString(),i?K.toRaw(i.assetFee).toString():"0",i?K.toRaw(i.protocolFee).toString():"0",i?K.toRaw(i.maxSlipFee).toString():"0"),a=BigInt(r);return a<0n?0n:a}calculateLrnaInGivenOut(t,e,i){let r=I.calculateLrnaInGivenOut(t.balanceOut.toString(),t.hubReservesOut.toString(),t.sharesOut.toString(),e.toString(),i?K.toRaw(i.assetFee).toString():"0",i?K.toRaw(i.maxSlipFee).toString():"0"),a=BigInt(r);return a<0n?0n:a}calculateOutGivenIn(t,e,i){if(t.assetIn==this.hubAssetId)return this.calculateOutGivenLrnaIn(t,e,i);let r=I.calculateOutGivenIn(t.balanceIn.toString(),t.hubReservesIn.toString(),t.sharesIn.toString(),t.balanceOut.toString(),t.hubReservesOut.toString(),t.sharesOut.toString(),e.toString(),i?K.toRaw(i.assetFee).toString():"0",i?K.toRaw(i.protocolFee).toString():"0",i?K.toRaw(i.maxSlipFee).toString():"0"),a=BigInt(r);return a<0n?0n:a}calculateOutGivenLrnaIn(t,e,i){let r=I.calculateOutGivenLrnaIn(t.balanceOut.toString(),t.hubReservesOut.toString(),t.sharesOut.toString(),e.toString(),i?K.toRaw(i.assetFee).toString():"0",i?K.toRaw(i.maxSlipFee).toString():"0"),a=BigInt(r);return a<0n?0n:a}spotPriceInGivenOut(t){if(t.assetIn==this.hubAssetId)return this.spotPriceLrnaInGivenOut(t);let e=I.calculateSpotPrice(t.balanceOut.toString(),t.hubReservesOut.toString(),t.balanceIn.toString(),t.hubReservesIn.toString());return this.normalizeSpot(BigInt(e),t.decimalsOut,t.decimalsIn)}spotPriceLrnaInGivenOut(t){let e=I.calculateLrnaSpotPrice(t.hubReservesOut.toString(),t.balanceOut.toString());return this.normalizeSpot(BigInt(e),t.decimalsOut,t.decimalsIn)}spotPriceOutGivenIn(t){if(t.assetIn==this.hubAssetId)return this.spotPriceOutGivenLrnaIn(t);let e=I.calculateSpotPrice(t.balanceIn.toString(),t.hubReservesIn.toString(),t.balanceOut.toString(),t.hubReservesOut.toString());return this.normalizeSpot(BigInt(e),t.decimalsIn,t.decimalsOut)}spotPriceOutGivenLrnaIn(t){let e=I.calculateLrnaSpotPrice(t.balanceOut.toString(),t.hubReservesOut.toString());return this.normalizeSpot(BigInt(e),t.decimalsIn,t.decimalsOut)}normalizeSpot(t,e,i){let r=e-i;if(r===0)return t;let a=jn.pow10(Math.abs(r));return r>0?t*a:t/a}};import{AccountId as Qn,Binary as nr,CompatibilityLevel as Jn,Enum as Zn}from"polkadot-api";import{toHex as ts}from"@polkadot-api/utils";import{Subscription as es,distinctUntilChanged as ni,filter as is,finalize as si,map as xt,merge as rs,tap as Fe}from"rxjs";import{HYDRATION_SS58_PREFIX as as}from"@galacticcouncil/common";var{FeeUtils:D}=T,lt=class p{static compute(t,e,i,r,a,n,s,o){let l=t.assetIn,[c,u,d]=p.getAssetFee(t,e,i,r,n),m=0,g=0,b=0;l!==1&&([m,g,b]=p.getProtocolFee(t,e,i,a,s));let h=c+m,y=d+b;return{assetFee:D.fromPermill(u),protocolFee:D.fromPermill(g),maxSlipFee:D.fromPermill(o),min:D.fromPermill(h),max:D.fromPermill(y)}}static getAssetFee(t,e,i,r,a){let{assetOut:n,balanceOut:s}=t,{min_fee:o,max_fee:l,decay:c,amplification:u}=a;if(!i||!r)return[o,o,l];let d=D.fromPermill(o),m=D.fromPermill(l),[g]=r,{asset_fee:b,timestamp:h}=i,y=Math.max(1,e-h),f=g.volume.b_in.toString(),S=g.volume.b_out.toString(),P=g.liquidity.b.toString();n===0&&(f=g.volume.a_in.toString(),S=g.volume.a_out.toString(),P=g.liquidity.a.toString());let w=D.fromPermill(b),x=I.recalculateAssetFee(f,S,P,"9",s.toString(),D.toRaw(w).toString(),y.toString(),D.toRaw(d).toString(),D.toRaw(m).toString(),c.toString(),u.toString());return[o,Number(x)*1e6,l]}static getProtocolFee(t,e,i,r,a){let{assetIn:n,balanceIn:s}=t,{min_fee:o,max_fee:l,decay:c,amplification:u}=a;if(!i||!r)return[o,o,l];let d=D.fromPermill(o),m=D.fromPermill(l),[g]=r,{protocol_fee:b,timestamp:h}=i,y=Math.max(1,e-h),f=g.volume.b_in.toString(),S=g.volume.b_out.toString(),P=g.liquidity.b.toString();n===0&&(f=g.volume.a_in.toString(),S=g.volume.a_out.toString(),P=g.liquidity.a.toString());let w=D.fromPermill(b),x=I.recalculateProtocolFee(f,S,P,"9",s.toString(),D.toRaw(w).toString(),y.toString(),D.toRaw(d).toString(),D.toRaw(m).toString(),c.toString(),u.toString());return[o,Number(x)*1e6,l]}};var Tt=p=>p===0?[0,1]:[1,p],_e=p=>Tt(p).join(":");var{FeeUtils:oi}=T,sr=nr.toHex(nr.fromText("omnipool")),or=Zn("Short"),Xt=class extends N{queryBus=new Te;block=0;dynamicFeesConfig=this.queryBus.scope("DynamicFees.AssetFeeConfiguration",t=>this.api.query.DynamicFees.AssetFeeConfiguration.getValue(t,{at:this.at}),t=>String(t));dynamicFees=this.queryBus.scope("DynamicFees.AssetFee",t=>this.api.query.DynamicFees.AssetFee.getValue(t,{at:this.at}),t=>String(t),6*1e3);maxSlipFee=this.queryBus.scope("Omnipool.SlipFee",()=>this.apiNext.query.Omnipool.SlipFee.getValue({at:this.at}),()=>"slipFee");emaOracles=this.queryBus.scope("EmaOracle.Oracles.Short",t=>this.api.query.EmaOracle.Oracles.getValue(sr,t,or,{at:this.at}),t=>t.join(":"),6*1e3);getPoolType(){return"Omnipool"}getPoolAddress(){let t="modlomnipool".padEnd(32,"\0"),e=new TextEncoder().encode(t),i=ts(e);return Qn(as).dec(i)}async getPoolLimits(){let[t,e,i]=await Promise.all([this.api.constants.Omnipool.MaxInRatio(),this.api.constants.Omnipool.MaxOutRatio(),this.api.constants.Omnipool.MinimumTradingLimit()]);return{maxInRatio:t,maxOutRatio:e,minTradingLimit:i}}async isSupported(){return(await this.api.getStaticApis()).compat.query.Omnipool.Assets.isCompatible(Jn.BackwardsCompatible)}async loadPools(){let t=await this.api.constants.Omnipool.HubAssetId(),e=this.getPoolAddress(),[i,r,a,n,s,o]=await Promise.all([this.api.query.Omnipool.Assets.getEntries({at:this.at}),this.api.query.Omnipool.HubAssetTradability.getValue({at:this.at}),this.api.query.AssetRegistry.Assets.getValue(t,{at:this.at}),this.balance.getBalance(e,t),this.getPoolLimits(),this.api.query.System.Number.getValue({at:this.at})]);this.block=o;let l=i.map(async({keyArgs:u,value:d})=>{let[m]=u,{hub_reserve:g,shares:b,tradable:h,cap:y,protocol_shares:f}=d,[S,P]=await Promise.all([this.api.query.AssetRegistry.Assets.getValue(m,{at:this.at}),this.balance.getBalance(e,m)]);return{id:m,decimals:S?.decimals,existentialDeposit:S?.existential_deposit,balance:P.transferable,cap:y,hubReserves:g,protocolShares:f,shares:b,tradeable:h,type:S?.asset_type.type}}),c=await Promise.all(l);return c.push({id:t,decimals:a?.decimals,existentialDeposit:a?.existential_deposit,balance:n.transferable,tradeable:r,type:a?.asset_type.type}),[{address:e,type:"Omnipool",hubAssetId:t,tokens:c,...s}]}async getPoolFees(t){let e=t.assetOut,i=t.assetIn,a=await this.maxSlipFee.get()??0,n=await this.dynamicFeesConfig.get(e);if(n?.type==="Fixed"){let{asset_fee:d,protocol_fee:m}=n.value;return{assetFee:oi.fromPermill(d),protocolFee:oi.fromPermill(m),maxSlipFee:oi.fromPermill(a)}}let[s,o,l,c,u]=await Promise.all([this.dynamicFees.get(e),this.emaOracles.get(Tt(e)),this.emaOracles.get(Tt(i)),n?n.value.asset_fee_params:this.api.constants.DynamicFees.AssetFeeParameters(),n?n.value.protocol_fee_params:this.api.constants.DynamicFees.ProtocolFeeParameters()]);return lt.compute(t,this.block,s,o,l,c,u,a)}subscribeEmaOracles(){let[t]=this.store.pools,i=t.tokens.map(r=>r.id).map(r=>Tt(r)).map(r=>this.api.query.EmaOracle.Oracles.watchValue(sr,r,or,{at:"best"}).pipe(xt(({value:a})=>a),is(a=>a!==void 0),xt((a,n)=>({value:a,index:n})),Fe(({index:a})=>{a>0&&this.log.trace("emaOracle.Oracles",r.join(":"))}),xt(({value:a})=>({pair:r,value:a}))));return rs(...i).pipe(si(()=>this.emaOracles.clear()),this.watchGuard("emaOracle.Oracles")).subscribe(r=>{let{pair:a,value:n}=r;this.emaOracles.set(n,a)})}subscribeDynamicFees(){return this.api.query.DynamicFees.AssetFee.watchEntries({at:"best"}).pipe(ni((t,e)=>!e.deltas),xt((t,e)=>({value:t,index:e})),Fe(({value:t,index:e})=>{e>0&&this.log.trace("dynamicFees.AssetFee",t.deltas?.upserted)}),si(()=>this.dynamicFees.clear()),this.watchGuard("dynamicFees.AssetFee")).subscribe(({value:{deltas:t}})=>{t?.upserted.forEach(e=>{let[i]=e.args;this.dynamicFees.set(e.value,i)})})}subscribeDynamicFeesConfig(){return this.api.query.DynamicFees.AssetFeeConfiguration.watchEntries({at:"best"}).pipe(ni((t,e)=>!e.deltas),xt((t,e)=>({value:t,index:e})),Fe(({value:t,index:e})=>{e>0&&this.log.trace("dynamicFees.AssetFeeConfiguration",t.deltas?.upserted)}),si(()=>this.dynamicFeesConfig.clear()),this.watchGuard("dynamicFees.AssetFeeConfiguration")).subscribe(({value:{deltas:t}})=>{t?.upserted.forEach(e=>{let[i]=e.args;this.dynamicFeesConfig.set(e.value,i)})})}subscribeBlock(){return this.watcher.bestBlock$.pipe(this.watchGuard("watcher.bestBlock")).subscribe(t=>{this.block=t})}subscribeAssets(){return this.api.query.Omnipool.Assets.watchEntries({at:"best"}).pipe(ni((t,e)=>!e.deltas),xt((t,e)=>({value:t,index:e})),Fe(({value:t,index:e})=>{e>0&&this.log.trace("omnipool.Assets",t.deltas?.upserted)}),this.watchGuard("omnipool.Assets")).subscribe(({value:{deltas:t}})=>{this.store.update(([e])=>{let i=t?.upserted.reduce((a,n)=>{let[s]=n.args;return a.set(s,n.value),a},new Map),r=e.tokens.map(a=>{let n=i?.get(a.id);return n?this.updateTokenState(a,n):a});return[{...e,tokens:r}]})})}subscribeUpdates(){let t=new es;return t.add(this.subscribeAssets()),t.add(this.subscribeDynamicFees()),t.add(this.subscribeDynamicFeesConfig()),t.add(this.subscribeEmaOracles()),t.add(this.subscribeBlock()),t}updateTokenState(t,e){let{hub_reserve:i,shares:r,tradable:a,cap:n,protocol_shares:s}=e;return{...t,cap:n,hubReserves:i,protocolShares:s,shares:r,tradeable:a}}};var ci={};O(ci,{StableMath:()=>M,StableSwap:()=>ct,StableSwapClient:()=>zt});import{calculate_in_given_out as ns,calculate_out_given_in as ss,calculate_amplification as os,calculate_add_one_asset as ls,calculate_liquidity_out_one_asset as cs,calculate_shares as us,calculate_shares_for_amount as ps,calculate_spot_price_with_fee as ms,pool_account_name as ds,recalculate_peg as gs}from"@galacticcouncil/math-stableswap";var M=class{static getPoolAddress(t){return ds(t)}static defaultPegs(t){let e=[];for(let i=0;i<t;i++)e.push(["1","1"]);return e}static calculateAmplification(t,e,i,r,a){return os(t,e,i,r,a)}static calculateInGivenOut(t,e,i,r,a,n,s){return ns(t,e,i,r,a,n,s)}static calculateAddOneAsset(t,e,i,r,a,n,s){return ls(t,e,i,r,a,n,s)}static calculateSharesForAmount(t,e,i,r,a,n,s){return ps(t,e,i,r,a,n,s)}static calculateOutGivenIn(t,e,i,r,a,n,s){return ss(t,e,i,r,a,n,s)}static calculateLiquidityOutOneAsset(t,e,i,r,a,n,s){return cs(t,e,i,r,a,n,s)}static calculateShares(t,e,i,r,a,n){return us(t,e,i,r,a,n)}static calculateSpotPriceWithFee(t,e,i,r,a,n,s,o){return ms(t,e,i,r,a,n,s,o)}static recalculatePegs(t,e,i,r,a,n){let s=gs(t,e,i,r,a,n);return JSON.parse(s)}};import{RUNTIME_DECIMALS as hs,big as lr}from"@galacticcouncil/common";var{FeeUtils:vt}=T,ct=class p{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;amplification;isRampPeriod;id;fee;totalIssuance;pegs;static fromPool(t){return new p(t)}constructor(t){this.type="Stableswap",this.address=t.address,this.tokens=t.tokens,this.maxInRatio=t.maxInRatio,this.maxOutRatio=t.maxOutRatio,this.minTradingLimit=t.minTradingLimit,this.amplification=t.amplification,this.isRampPeriod=t.isRampPeriod,this.id=t.id,this.fee=t.fee,this.totalIssuance=t.totalIssuance,this.pegs=t.pegs}validatePair(t,e){return!0}parsePair(t,e){let i=new Map(this.tokens.map(n=>[n.id,n])),r=i.get(t),a=i.get(e);if(r==null)throw new Error("Pool does not contain tokenIn");if(a==null)throw new Error("Pool does not contain tokenOut");return{assetIn:t,assetOut:e,balanceIn:r.balance,balanceOut:a.balance,decimalsIn:r.decimals,decimalsOut:a.decimals,tradeableIn:this.id===t?15:r.tradeable,tradeableOut:this.id===e?15:a.tradeable,assetInEd:r.existentialDeposit,assetOutEd:a.existentialDeposit}}validateAndBuy(t,e,i){let r=this.calculateInGivenOut(t,e),a=this.calculateInGivenOut(t,e,i),n=r===0n?0:L.calculateBuyFee(r,a),s=[],o=I.isSellAllowed(t.tradeableIn),l=I.isBuyAllowed(t.tradeableOut);return(!o||!l)&&s.push("TradeNotAllowed"),(e<this.minTradingLimit||r<t.assetInEd)&&s.push("InsufficientTradingAmount"),{amountIn:a,calculatedIn:r,amountOut:e,feePct:n,errors:s}}validateAndSell(t,e,i){let r=this.calculateOutGivenIn(t,e),a=this.calculateOutGivenIn(t,e,i),n=L.calculateSellFee(r,a),s=[],o=I.isSellAllowed(t.tradeableIn),l=I.isBuyAllowed(t.tradeableOut);return(!o||!l)&&s.push("TradeNotAllowed"),(e<this.minTradingLimit||r<t.assetOutEd)&&s.push("InsufficientTradingAmount"),{amountIn:e,calculatedOut:r,amountOut:a,feePct:n,errors:s}}calculateIn(t,e,i){let r=M.calculateInGivenOut(this.getReserves(),Number(t.assetIn),Number(t.assetOut),e.toString(),this.amplification.toString(),i?vt.toRaw(i.fee).toString():"0",this.getPegs()),a=BigInt(r);return a<0n?0n:a}calculateAddOneAsset(t,e,i){let r=M.calculateAddOneAsset(this.getReserves(),e.toString(),Number(t.assetIn),this.amplification.toString(),this.totalIssuance.toString(),i?vt.toRaw(i.fee).toString():"0",this.getPegs()),a=BigInt(r);return a<0n?0n:a}calculateSharesForAmount(t,e,i){let r=M.calculateSharesForAmount(this.getReserves(),Number(t.assetOut),e.toString(),this.amplification.toString(),this.totalIssuance.toString(),i?vt.toRaw(i.fee).toString():"0",this.getPegs()),a=BigInt(r);return a<0n?0n:a}calculateInGivenOut(t,e,i){return t.assetOut==this.id?this.calculateAddOneAsset(t,e,i):t.assetIn==this.id?this.calculateSharesForAmount(t,e,i):this.calculateIn(t,e,i)}spotPriceInGivenOut(t){let e=M.calculateSpotPriceWithFee(this.id.toString(),this.getReserves(),this.amplification.toString(),t.assetOut.toString(),t.assetIn.toString(),this.totalIssuance.toString(),"0",this.getPegs());return this.normalizeSpot(BigInt(e),t.assetOut===this.id,t.assetIn===this.id,t.decimalsOut,t.decimalsIn)}calculateOut(t,e,i){let r=M.calculateOutGivenIn(this.getReserves(),Number(t.assetIn),Number(t.assetOut),e.toString(),this.amplification.toString(),i?vt.toRaw(i.fee).toString():"0",this.getPegs()),a=BigInt(r);return a<0n?0n:a}calculateWithdrawOneAsset(t,e,i){let r=M.calculateLiquidityOutOneAsset(this.getReserves(),e.toString(),Number(t.assetOut),this.amplification.toString(),this.totalIssuance.toString(),i?vt.toRaw(i.fee).toString():"0",this.getPegs()),a=BigInt(r);return a<0n?0n:a}calculateShares(t,e,i){let r=M.calculateShares(this.getReserves(),this.getAssets(t.assetIn,e),this.amplification.toString(),this.totalIssuance.toString(),i?vt.toRaw(i.fee).toString():"0",this.getPegs()),a=BigInt(r);return a<0n?0n:a}calculateOutGivenIn(t,e,i){return t.assetIn==this.id?this.calculateWithdrawOneAsset(t,e,i):t.assetOut==this.id?this.calculateShares(t,e,i):this.calculateOut(t,e,i)}spotPriceOutGivenIn(t){let e=M.calculateSpotPriceWithFee(this.id.toString(),this.getReserves(),this.amplification.toString(),t.assetIn.toString(),t.assetOut.toString(),this.totalIssuance.toString(),"0",this.getPegs());return this.normalizeSpot(BigInt(e),t.assetIn===this.id,t.assetOut===this.id,t.decimalsIn,t.decimalsOut)}getPegs(){return JSON.stringify(this.pegs)}getReserves(){let t=this.tokens.filter(e=>e.id!=this.id).map(({id:e,balance:i,decimals:r})=>({asset_id:e,amount:i,decimals:r}));return JSON.stringify(t,Ht.jsonFormatter)}getAssets(t,e){let i={asset_id:Number(t),amount:e.toString()};return JSON.stringify([i],Ht.jsonFormatter)}normalizeSpot(t,e,i,r,a){return e?t*lr.pow10(hs-a):i?t/lr.pow10(a-r):t}};import{AccountId as bs,CompatibilityLevel as ys}from"polkadot-api";import{toHex as fs}from"@polkadot-api/utils";import{blake2b as Ps}from"@noble/hashes/blake2b";import{Subscription as Ss,distinctUntilChanged as ws,map as Re,merge as Ts,tap as cr}from"rxjs";import{HYDRATION_SS58_PREFIX as xs,RUNTIME_DECIMALS as vs}from"@galacticcouncil/common";var{FeeUtils:Is}=T,zt=class extends N{poolsData=new Map([]);getPoolType(){return"Stableswap"}getPoolAddress(t){let e=M.getPoolAddress(t),i=Ps(e,{dkLen:32}),r=fs(i);return bs(xs).dec(r)}async getPoolLimits(){return{maxInRatio:0n,maxOutRatio:0n,minTradingLimit:await this.api.constants.Stableswap.MinTradingLimit()}}getPoolAmplification(t,e){let{initial_amplification:i,final_amplification:r,initial_block:a,final_block:n}=t,s=M.calculateAmplification(i.toString(),r.toString(),a.toString(),n.toString(),e.toString()),o=Number(s)<r;return{amplification:BigInt(s),isRampPeriod:o}}async getPoolTokens(t,e){let i=this.getPoolAddress(t),r=e.assets.map(async a=>{let[n,s,o]=await Promise.all([this.api.query.Stableswap.AssetTradability.getValue(t,a,{at:this.at}),this.api.query.AssetRegistry.Assets.getValue(a,{at:this.at}),this.balance.getBalance(i,a)]);return{id:a,decimals:s?.decimals,existentialDeposit:s?.existential_deposit,balance:o.transferable,tradeable:n,type:s?.asset_type.type}});return Promise.all(r)}async isSupported(){return(await this.api.getStaticApis()).compat.query.Stableswap.Pools.isCompatible(ys.BackwardsCompatible)}async loadPools(){let[t,e,i]=await Promise.all([this.api.query.Stableswap.Pools.getEntries({at:this.at}),this.api.query.System.Number.getValue({at:this.at}),this.getPoolLimits()]),r=t.map(async({keyArgs:a,value:n})=>{let[s]=a,o=this.getPoolAddress(s),[l,c,u]=await Promise.all([this.getPoolTokens(s,n),this.api.query.Stableswap.PoolPegs.getValue(s,{at:this.at}),this.api.query.Tokens.TotalIssuance.getValue(s,{at:this.at})]),d=this.getPoolAmplification(n,e),m=c?this.getRecentPegs(c):this.getDefaultPegs(n);return l.push({id:s,tradeable:15,balance:u,decimals:vs}),this.poolsData.set(s,n),{address:o,id:s,type:"Stableswap",fee:Is.fromPermill(n.fee),tokens:l,totalIssuance:u,pegs:m,...i,...d}});return Promise.all(r)}async getPoolFees(t,e){return{fee:this.store.pools.find(r=>r.address===e).fee}}getDefaultPegs(t){return M.defaultPegs(t.assets.length)}getRecentPegs(t){let{current:e}=t;return Array.from(e.entries()).map(([i,r])=>r.map(a=>a.toString()))}subscribeIssuance(){let e=this.store.pools.map(i=>i.id).map(i=>this.api.query.Tokens.TotalIssuance.watchValue(i,{at:"best"}).pipe(Re(({value:r})=>r),Re((r,a)=>({value:r,index:a})),cr(({index:r,value:a})=>{r>0&&this.log.trace("tokens.TotalIssuance",i,a)}),Re(({value:r})=>({id:i,value:r}))));return Ts(...e).pipe(this.watchGuard("tokens.TotalIssuance")).subscribe(i=>{let{id:r,value:a}=i;this.store.update(n=>{let s=[];return n.filter(o=>o.id===r).forEach(o=>{let l=o.tokens.map(c=>c.id===r?{...c,balance:a}:c);s.push({...o,tokens:l,totalIssuance:a})}),s})})}subscribePoolPegs(){return this.api.query.Stableswap.PoolPegs.watchEntries({at:"best"}).pipe(ws((t,e)=>!e.deltas),Re((t,e)=>({value:t,index:e})),cr(({value:t,index:e})=>{e>0&&this.log.trace("stableswap.PoolPegs",t.deltas?.upserted)}),this.watchGuard("stableswap.PoolPegs")).subscribe({error:t=>this.log.error("stableswap.PoolPegs",t),next:({value:{deltas:t}})=>{this.store.update(e=>{let i=[],r=new Map(e.map(a=>[a.id,a]));return t?.upserted.forEach(({args:a,value:n})=>{let[s]=a,o=r.get(s);if(o){let l=this.getRecentPegs(n);i.push({...o,pegs:l})}}),i})}})}subscribeBlock(){return this.watcher.bestBlock$.pipe(this.watchGuard("watcher.bestBlock")).subscribe(t=>{this.store.update(e=>{let i=[];return e.filter(r=>r.isRampPeriod).forEach(r=>{let a=this.poolsData.get(r.id);if(a){let n=this.getPoolAmplification(a,t);i.push({...r,...n})}}),i})})}subscribeUpdates(){let t=new Ss;return t.add(this.subscribePoolPegs()),t.add(this.subscribeIssuance()),this.hasOnRamps()&&t.add(this.subscribeBlock()),t}hasOnRamps(){return this.store.pools.filter(t=>t.isRampPeriod).length>0}};var ui={};O(ui,{XykMath:()=>J,XykPool:()=>Kt,XykPoolClient:()=>jt});import{calculate_in_given_out as Os,calculate_out_given_in as As,calculate_pool_trade_fee as Bs,get_spot_price as _s,calculate_liquidity_in as Fs,calculate_shares as Rs,calculate_spot_price as Es,calculate_spot_price_with_fee as Cs,calculate_liquidity_out_asset_a as ks,calculate_liquidity_out_asset_b as Ds}from"@galacticcouncil/math-xyk";var J=class{static getSpotPrice(t,e,i){return _s(t,e,i)}static calculateInGivenOut(t,e,i){return Os(t,e,i)}static calculateOutGivenIn(t,e,i){return As(t,e,i)}static calculatePoolTradeFee(t,e,i){return Bs(t,e,i)}static calculateLiquidityIn(t,e,i){return Fs(t,e,i)}static calculateSpotPrice(t,e){return Es(t,e)}static calculateSpotPriceWithFee(t,e,i,r){return Cs(t,e,i,r)}static calculateShares(t,e,i){return Rs(t,e,i)}static calculateLiquidityOutAssetA(t,e,i,r){return ks(t,e,i,r)}static calculateLiquidityOutAssetB(t,e,i,r){return Ds(t,e,i,r)}};import{big as Ms}from"@galacticcouncil/common";var{FeeUtils:ur}=T,Kt=class p{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;static fromPool(t){return new p(t)}constructor(t){this.type="XYK",this.address=t.address,this.tokens=t.tokens,this.maxInRatio=t.maxInRatio,this.maxOutRatio=t.maxOutRatio,this.minTradingLimit=t.minTradingLimit}validatePair(t,e){return!0}parsePair(t,e){let i=new Map(this.tokens.map(n=>[n.id,n])),r=i.get(t),a=i.get(e);if(r==null)throw new Error("Pool does not contain tokenIn");if(a==null)throw new Error("Pool does not contain tokenOut");return{assetIn:t,assetOut:e,decimalsIn:r.decimals,decimalsOut:a.decimals,balanceIn:r.balance,balanceOut:a.balance,assetInEd:r.existentialDeposit,assetOutEd:a.existentialDeposit}}validateAndBuy(t,e,i){let r=this.calculateInGivenOut(t,e),a=this.calculateTradeFee(r,i),n=ur.toPct(i.exchangeFee),s=r+a,o=[];(e<this.minTradingLimit||r<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:r,amountOut:e,feePct:n,errors:o}}validateAndSell(t,e,i){let r=this.calculateOutGivenIn(t,e),a=this.calculateTradeFee(r,i),n=ur.toPct(i.exchangeFee),s=r-a,o=[];(e<this.minTradingLimit||r<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:r,amountOut:s,feePct:n,errors:o}}calculateInGivenOut(t,e){let i=J.calculateInGivenOut(t.balanceIn.toString(),t.balanceOut.toString(),e.toString()),r=BigInt(i);return r<0n?0n:r}calculateOutGivenIn(t,e){let i=J.calculateOutGivenIn(t.balanceIn.toString(),t.balanceOut.toString(),e.toString()),r=BigInt(i);return r<0n?0n:r}spotPriceInGivenOut(t){let e=J.calculateSpotPrice(t.balanceOut.toString(),t.balanceIn.toString());return this.normalizeSpot(BigInt(e),t.decimalsOut,t.decimalsIn)}spotPriceOutGivenIn(t){let e=J.calculateSpotPrice(t.balanceIn.toString(),t.balanceOut.toString());return this.normalizeSpot(BigInt(e),t.decimalsIn,t.decimalsOut)}calculateTradeFee(t,e){let i=J.calculatePoolTradeFee(t.toString(),e.exchangeFee[0],e.exchangeFee[1]);return BigInt(i)}normalizeSpot(t,e,i){let r=e-i;if(r===0)return t;let a=Ms.pow10(Math.abs(r));return r>0?t*a:t/a}};import{CompatibilityLevel as Ls}from"polkadot-api";import{Subscription as qs}from"rxjs";var jt=class extends N{decimals=new Map([]);getPoolType(){return"XYK"}async withOverride(t){this.decimals=t?new Map(t.map(e=>[e.id,e.decimals])):new Map}async getPoolLimits(){let[t,e,i]=await Promise.all([this.api.constants.XYK.MaxInRatio(),this.api.constants.XYK.MaxOutRatio(),this.api.constants.XYK.MinTradingLimit()]);return{maxInRatio:t,maxOutRatio:e,minTradingLimit:i}}async isSupported(){return(await this.api.getStaticApis()).compat.query.XYK.PoolAssets.isCompatible(Ls.BackwardsCompatible)}async loadPools(){let[t,e]=await Promise.all([this.api.query.XYK.PoolAssets.getEntries({at:this.at}),this.getPoolLimits()]),i=t.map(async({keyArgs:r,value:a})=>{let[n]=r,[s,o]=a,[l,c,u,d]=await Promise.all([this.balance.getBalance(n,s),this.api.query.AssetRegistry.Assets.getValue(s,{at:this.at}),this.balance.getBalance(n,o),this.api.query.AssetRegistry.Assets.getValue(o,{at:this.at})]);return{address:n,type:"XYK",tokens:[{id:s,decimals:c?.decimals||this.decimals.get(s),existentialDeposit:c?.existential_deposit,balance:l.transferable,type:c?.asset_type.type},{id:o,decimals:d?.decimals||this.decimals.get(o),existentialDeposit:d?.existential_deposit,balance:u.transferable,type:d?.asset_type.type}],...e}});return Promise.all(i)}async getPoolFees(){return{exchangeFee:await this.getExchangeFee()}}async getExchangeFee(){return await this.api.constants.XYK.GetExchangeFee()}subscribeUpdates(){return qs.EMPTY}};var mi={};O(mi,{AavePool:()=>Qt,AavePoolClient:()=>Jt});import{big as pr,RUNTIME_DECIMALS as mr}from"@galacticcouncil/common";var Qt=class p{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;static fromPool(t){return new p(t)}constructor(t){this.type="Aave",this.address=t.address,this.tokens=t.tokens,this.maxInRatio=t.maxInRatio,this.maxOutRatio=t.maxOutRatio,this.minTradingLimit=t.minTradingLimit}validatePair(t,e){return!0}parsePair(t,e){let i=new Map(this.tokens.map(n=>[n.id,n])),r=i.get(t),a=i.get(e);if(r==null)throw new Error("Pool does not contain tokenIn");if(a==null)throw new Error("Pool does not contain tokenOut");return{assetIn:t,assetOut:e,balanceIn:r.balance,balanceOut:a.balance,decimalsIn:r.decimals,decimalsOut:a.decimals,assetInEd:0n,assetOutEd:0n}}validateAndBuy(t,e,i){let r=this.calculateInGivenOut(t,e),a=[];return e>t.balanceOut&&a.push("TradeNotAllowed"),{amountIn:r,calculatedIn:r,amountOut:e,feePct:0,errors:a}}validateAndSell(t,e,i){let r=this.calculateOutGivenIn(t,e),a=[];return r>t.balanceOut&&a.push("TradeNotAllowed"),{amountIn:e,calculatedOut:r,amountOut:r,feePct:0,errors:a}}calculateInGivenOut(t,e){return e}calculateOutGivenIn(t,e){return e}spotPriceInGivenOut(t){return pr.toBigInt(1,mr)}spotPriceOutGivenIn(t){return pr.toBigInt(1,mr)}calculateTradeFee(t,e){return 0n}};import{AccountId as Hs,Binary as Ns}from"polkadot-api";import{toHex as Gs}from"@polkadot-api/utils";import{Subscription as gr,filter as pi,map as hr,mergeMap as br}from"rxjs";import{decodeEventLog as Vs}from"viem";import{erc20 as Us,HYDRATION_SS58_PREFIX as Ws}from"@galacticcouncil/common";var dr=[{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:Ys}=Us,$s=["Supply","Withdraw","Repay","Borrow"],Jt=class extends N{getPoolType(){return"Aave"}async isSupported(){return!0}getPoolId(t,e){let i=t+"/"+e,r=new TextEncoder().encode(i.padEnd(32,"\0")),a=Gs(r);return Hs(Ws).dec(a)}getPoolLimits(){return{maxInRatio:0n,maxOutRatio:0n,minTradingLimit:0n}}async loadPools(){let e=(await this.api.apis.AaveTradeExecutor.pools({at:this.at})).map(async({reserve:i,atoken:r,liqudity_in:a,liqudity_out:n})=>{let[s,o,l,c]=await Promise.all([this.api.query.AssetRegistry.Assets.getValue(i,{at:this.at}),this.api.query.AssetRegistry.AssetLocations.getValue(i,{at:this.at}),this.api.query.AssetRegistry.Assets.getValue(r,{at:this.at}),this.api.query.AssetRegistry.AssetLocations.getValue(r,{at:this.at})]);return{address:this.getPoolId(i,r),type:"Aave",tokens:[{id:i,decimals:s?.decimals,existentialDeposit:s?.existential_deposit,balance:a,location:o,type:s?.asset_type.type},{id:r,decimals:l?.decimals,existentialDeposit:l?.existential_deposit,balance:n,location:c,type:l?.asset_type.type}],...this.getPoolLimits()}});return Promise.all(e)}async getPoolDelta(t){let[e,i]=t.tokens,{liqudity_in:r,liqudity_out:a}=await this.api.apis.AaveTradeExecutor.pool(e.id,i.id,{at:this.at});return t.tokens.map(n=>{let s=n.id===e.id?r:a;return{...n,balance:s}})}async getPoolFees(){return{}}getReserveH160Id(t){if(t.type==="Erc20"&&t.location){let e=t.location.interior;if(e.type==="X1"&&e.value.type==="AccountKey20"){let{value:i}=e.value;return i.key}throw new Error("Invalid aave reserve multilocation")}return Ys.fromAssetId(t.id)}parseRouterLog(t){let{asset_in:e,asset_out:i}=t;return{assetIn:e,assetOut:i,key:`${e}:${i}`}}parseEvmLog(t){let{topics:e,data:i}=t.log,r=e,a=Ns.toHex(i);try{let{eventName:n,args:s}=Vs({abi:dr,topics:r,data:a}),o=s.reserve.toLowerCase();return{eventName:n,reserve:o,key:`${n}:${o}`}}catch{return}}subscribeRouterExecuted(){let e=this.store.pools.map(i=>i.tokens).map(([i,r])=>r).map(i=>i.id);return this.api.event.Router.Executed.watch().pipe(br(({events:i})=>i),hr(({payload:i})=>this.parseRouterLog(i)),pi(({assetIn:i,assetOut:r})=>e.includes(i)||e.includes(r)),this.watchGuard("router.Execute")).subscribe(({assetIn:i,assetOut:r,key:a})=>{this.log.trace("router.Executed",a),this.store.update(async n=>{let s=[];for(let o of n){let[l,c]=o.tokens;if(c.id===i||c.id===r){let d=await this.getPoolDelta(o);s.push({...o,tokens:d})}}return s})})}subscribeEvmLog(){return this.api.event.EVM.Log.watch().pipe(br(({events:t})=>t),hr(({payload:t})=>this.parseEvmLog(t)),pi(t=>t!==void 0),pi(({eventName:t})=>$s.includes(t)),this.watchGuard("evm.Log")).subscribe(({reserve:t,eventName:e})=>{this.log.trace(`evm.Log.${e}`,t),this.store.update(async i=>{let r=[];for(let a of i){let[n]=a.tokens;if(this.getReserveH160Id(n).toLowerCase()===t){let o=await this.getPoolDelta(a);r.push({...a,tokens:o})}}return r})})}subscribeBalances(){return gr.EMPTY}subscribeUpdates(){let t=new gr;return t.add(this.subscribeRouterExecuted()),t.add(this.subscribeEvmLog()),t}};var bi={};O(bi,{HsmMath:()=>U,HsmPool:()=>Zt,HsmPoolClient:()=>ie});import{calculate_collateral_in_given_hollar_out as Xs,calculate_collateral_out_given_hollar_in as zs,calculate_hollar_in_given_collateral_out as Ks,calculate_hollar_out_given_collateral_in as js,calculate_imbalance as Qs,calculate_max_price as Js,calculate_buyback_limit as Zs,calculate_buyback_price_with_fee as to}from"@galacticcouncil/math-hsm";var U=class{static calculateCollateralInGivenHollarOut(t,e,i){return Xs(t,e,i)}static calculateCollateralOutGivenHollarIn(t,e,i){return zs(t,e,i)}static calculateHollarOutGivenCollateralIn(t,e,i){return js(t,e,i)}static calculateHollarInGivenCollateralOut(t,e,i){return Ks(t,e,i)}static calculateImbalance(t,e,i){return Qs(t,e,i)}static calculateBuybackLimit(t,e){return Zs(t,e)}static calculateBuybackPriceWithFee(t,e,i){return to(t,e,i)}static calculateMaxPrice(t,e){return Js(t,e)}};import{big as Z,RUNTIME_DECIMALS as Ee}from"@galacticcouncil/common";var{FeeUtils:It}=T,Zt=class p extends ct{hsmAddress;hsmMintCapacity;hollarId;hollarH160;collateralId;collateralBalance;maxBuyPriceCoefficient;maxInHolding;purchaseFee;buyBackFee;buyBackRate;static fromPool(t){return new p(t)}constructor(t){super(t),this.type="HSM",this.hsmAddress=t.hsmAddress,this.hsmMintCapacity=t.hsmMintCapacity,this.hollarId=t.hollarId,this.hollarH160=t.hollarH160,this.collateralId=t.collateralId,this.collateralBalance=t.collateralBalance,this.maxBuyPriceCoefficient=t.maxBuyPriceCoefficient,this.maxInHolding=t.maxInHolding,this.purchaseFee=t.purchaseFee,this.buyBackFee=t.buyBackFee,this.buyBackRate=t.buyBackRate}validatePair(t,e){return!0}parsePair(t,e){return super.parsePair(t,e)}validateTradeHollarIn(t,e,i){let r=this.parsePair(t.assetOut,t.assetIn),a=super.calculateInGivenOut(r,e,{fee:this.fee}),n=this.calculateBuybackLimit(t);e>n&&i.push("MaxBuyBackExceeded");let s=this.calculateMaxPrice(t);return this.calculateBuyPrice(t,e,a)>s&&i.push("MaxBuyPriceExceeded"),a>this.collateralBalance&&i.push("InsufficientCollateral"),i}validateTradeHollarOut(t,e,i){return this.collateralBalance+t>this.maxInHolding&&i.push("MaxHoldingExceeded"),e>this.hsmMintCapacity&&i.push("FacilitatorCapacityExceeded"),i}validateTradeConstraints(t,e,i){let r=[];return t.assetIn===this.hollarId?this.validateTradeHollarIn(t,e,r):this.validateTradeHollarOut(e,i,r)}validateAndBuy(t,e){let i=this.calculateInGivenOut(t,e),r=this.validateTradeConstraints(t,i,e);return{amountIn:i,calculatedIn:i,amountOut:e,feePct:0,errors:r}}validateAndSell(t,e){let i=this.calculateOutGivenIn(t,e),r=this.validateTradeConstraints(t,e,i);return{amountIn:e,calculatedOut:i,amountOut:i,feePct:0,errors:r}}calculateHollarInGivenCollateralOut(t,e){let i=super.calculateInGivenOut(t,e,{fee:this.fee}),r=U.calculateHollarInGivenCollateralOut(e.toString(),i.toString(),It.toRaw(this.buyBackFee).toString());return BigInt(r)}calculateCollateralInGivenHollarOut(t){let e=this.getCollateralPeg(),i=U.calculateCollateralInGivenHollarOut(t.toString(),JSON.stringify(e),It.toRaw(this.purchaseFee).toString());return BigInt(i)}calculateInGivenOut(t,e){return t.assetOut==this.hollarId?this.calculateCollateralInGivenHollarOut(e):this.calculateHollarInGivenCollateralOut(t,e)}calculateCollateralOutGivenHollarIn(t,e){let i=super.calculateOutGivenIn(t,e,{fee:this.fee}),r=U.calculateCollateralOutGivenHollarIn(e.toString(),i.toString(),It.toRaw(this.buyBackFee).toString());return BigInt(r)}calculateHollarOutGivenCollateralIn(t){let e=this.getCollateralPeg(),i=U.calculateHollarOutGivenCollateralIn(t.toString(),JSON.stringify(e),It.toRaw(this.purchaseFee).toString());return BigInt(i)}calculateOutGivenIn(t,e){return t.assetIn==this.hollarId?this.calculateCollateralOutGivenHollarIn(t,e):this.calculateHollarOutGivenCollateralIn(e)}calculateImbalance(t){let e=this.getCollateralPeg(),i=U.calculateImbalance(t.balanceIn.toString(),JSON.stringify(e),t.balanceOut.toString());return BigInt(i)}calculateBuybackLimit(t){let e=this.calculateImbalance(t),i=U.calculateBuybackLimit(e.toString(),It.toRaw(this.buyBackRate).toString());return BigInt(i)}calculateBuyPrice(t,e,i){let r=U.calculateBuybackPriceWithFee(i.toString(),e.toString(),It.toRaw(this.buyBackFee).toString()),[a,n]=JSON.parse(r),s=Z.pow10(t.decimalsIn+Ee-t.decimalsOut);return BigInt(a)*s/BigInt(n)}calculateMaxPrice(t){let e=this.getCollateralPeg(),i=U.calculateMaxPrice(JSON.stringify(e),this.maxBuyPriceCoefficient.toString()),[r,a]=JSON.parse(i),n=Z.pow10(Ee-t.decimalsOut);return BigInt(r)*n/BigInt(a)}spotPriceInGivenOut(t){let e=Z.toBigInt(1,t.decimalsOut),r=this.calculateInGivenOut(t,e)*Z.pow10(Ee-t.decimalsOut);return this.normalizeSpotPrice(r,t.decimalsOut,t.decimalsIn)}spotPriceOutGivenIn(t){let e=Z.toBigInt(1,t.decimalsIn),r=this.calculateOutGivenIn(t,e)*Z.pow10(Ee-t.decimalsIn);return this.normalizeSpotPrice(r,t.decimalsIn,t.decimalsOut)}getCollateralPeg(){let t=this.tokens.findIndex(r=>r.id!==this.hollarId),e=this.pegs[t],i=this.tokens[t].decimals;return this.isDefaultPeg(e)?[Z.toBigInt(1,18).toString(),Z.toBigInt(1,i).toString()]:e}isDefaultPeg(t){let[e,i]=t;return Array.isArray(t)&&t.length===2&&e==="1"&&i==="1"}normalizeSpotPrice(t,e,i){let r=e-i;if(r===0)return t;let a=Z.pow10(Math.abs(r));return r>0?t*a:t/a}};import{AccountId as eo,Binary as io,CompatibilityLevel as ro}from"polkadot-api";import{toHex as ao}from"@polkadot-api/utils";import{Subscription as di,combineLatest as no,filter as yr,map as gi,mergeMap as so,pairwise as oo}from"rxjs";import{decodeEventLog as lo}from"viem";import{h160 as co,HYDRATION_SS58_PREFIX as uo}from"@galacticcouncil/common";var te=[{inputs:[{internalType:"address",name:"facilitator",type:"address"}],name:"getFacilitator",outputs:[{type:"tuple",components:[{name:"addr",type:"address"},{name:"label",type:"bytes32"},{name:"bucketCapacity",type:"uint128"},{name:"bucketLevel",type:"uint128"}]}],stateMutability:"view",type:"function"},{inputs:[{internalType:"address",name:"facilitator",type:"address"}],name:"getFacilitatorBucket",outputs:[{internalType:"uint256",name:"",type:"uint256"},{internalType:"uint256",name:"",type:"uint256"}],stateMutability:"view",type:"function"},{inputs:[],name:"getFacilitatorsList",outputs:[{internalType:"address[]",name:"",type:"address[]"}],stateMutability:"view",type:"function"},{anonymous:!1,inputs:[{indexed:!0,internalType:"address",name:"facilitatorAddress",type:"address"},{indexed:!0,internalType:"bytes32",name:"label",type:"bytes32"},{indexed:!1,internalType:"uint256",name:"bucketCapacity",type:"uint256"}],name:"FacilitatorAdded",type:"event"},{anonymous:!1,inputs:[{indexed:!0,internalType:"address",name:"facilitatorAddress",type:"address"},{indexed:!1,internalType:"uint256",name:"oldCapacity",type:"uint256"},{indexed:!1,internalType:"uint256",name:"newCapacity",type:"uint256"}],name:"FacilitatorBucketCapacityUpdated",type:"event"},{anonymous:!1,inputs:[{indexed:!0,internalType:"address",name:"facilitatorAddress",type:"address"},{indexed:!1,internalType:"uint256",name:"oldLevel",type:"uint256"},{indexed:!1,internalType:"uint256",name:"newLevel",type:"uint256"}],name:"FacilitatorBucketLevelUpdated",type:"event"},{anonymous:!1,inputs:[{indexed:!0,internalType:"address",name:"facilitatorAddress",type:"address"}],name:"FacilitatorRemoved",type:"event"}];var ee=class{client;constructor(t){this.client=t.getWsProvider()}async getFacilitatorCapacity(t,e){let[i,r]=await this.client.readContract({abi:te,address:t,functionName:"getFacilitatorBucket",args:[e]});return i-r}};var{FeeUtils:hi}=T,{H160:fr}=co,po=["FacilitatorBucketCapacityUpdated","FacilitatorBucketLevelUpdated"],ie=class extends N{ghoClient;stableClient;constructor(t,e,i,r){super(t,e,r),this.stableClient=i,this.ghoClient=new ee(e)}getPoolType(){return"HSM"}getPoolId(t){return this.getPoolAddress("hsm:"+t)}getFacilitatorAddress(){return this.getPoolAddress("modlpy/hsmod")}getHollarAddress(t){if(t){let e=t.interior;if(e.type==="X1"&&e.value.type==="AccountKey20"){let{value:i}=e.value;return i.key}}throw Error("Invalid hollar multilocation")}getPoolAddress(t){let e=t.padEnd(32,"\0"),i=new TextEncoder().encode(e),r=ao(i);return eo(uo).dec(r)}async isSupported(){return(await this.api.getStaticApis()).compat.query.HSM.Collaterals.isCompatible(ro.BackwardsCompatible)}async loadPools(){let t=await this.api.constants.HSM.HollarId(),[e,i,r]=await Promise.all([this.api.query.AssetRegistry.AssetLocations.getValue(t,{at:this.at}),this.api.query.HSM.Collaterals.getEntries({at:this.at}),this.stableClient.getPools()]);if(i.length===0)return[];let a=this.getFacilitatorAddress(),n=fr.fromAny(a),s=this.getHollarAddress(e),o=await this.ghoClient.getFacilitatorCapacity(s,n),l=i.map(async({keyArgs:u,value:d})=>{let[m]=u,{pool_id:g,max_buy_price_coefficient:b,max_in_holding:h,purchase_fee:y,buy_back_fee:f,buyback_rate:S}=d,P=r.find(w=>w.id===g);if(P){let w=this.getPoolId(g),x=await this.balance.getBalance(a,m);return{...P,address:w,type:"HSM",tokens:P.tokens.filter(_=>_.id!==g),hsmAddress:a,hsmMintCapacity:o,hollarId:t,hollarH160:s,collateralId:m,collateralBalance:x.transferable,maxBuyPriceCoefficient:b,maxInHolding:h,purchaseFee:hi.fromPermill(y),buyBackFee:hi.fromPermill(f),buyBackRate:hi.fromPerbill(S)}}});return(await Promise.all(l)).filter(u=>u!==null)}async getPoolFees(){return{}}parseEvmLog(t){let{topics:e,data:i}=t.log,r=e,a=io.toHex(i);try{let{eventName:n,args:s}=lo({abi:te,topics:r,data:a}),o=s.facilitatorAddress.toLowerCase();return{eventName:n,facilitator:o,key:`${n}:${o}`}}catch{return}}subscribeEvmLog(){return this.api.event.EVM.Log.watch().pipe(so(({events:t})=>t),gi(({payload:t})=>this.parseEvmLog(t)),yr(t=>t!==void 0),yr(({eventName:t})=>po.includes(t)),this.watchGuard("evm.Log")).subscribe(({eventName:t,facilitator:e})=>{this.log.trace(`evm.Log.${t}`,e),this.store.update(async i=>{let r=[],[{hsmAddress:a,hollarH160:n}]=i,s=fr.fromAny(a);if(s.toLowerCase()===e){let l=await this.ghoClient.getFacilitatorCapacity(n,s);for(let c of i)r.push({...c,hsmMintCapacity:l})}return r})})}subscribeCollateralBalance(){let t=[],e=[];this.store.pools.forEach(a=>{let{tokens:n,collateralId:s}=a;n.find(l=>l.id===s).type==="Erc20"?e.push(s):t.push(s)});let[{hsmAddress:i}]=this.store.pools,r=[];if(t.length>0){let a=this.balance.watchTokensBalance(i);r.push(a)}if(e.length>0){let a=this.balance.watchErc20Balance(i,e);r.push(a)}return r.length>0?no(r).pipe(gi(a=>a.flat()),oo(),gi(([a,n])=>this.balance.getDeltas(a,n)),this.watchGuard("balances")).subscribe(a=>{this.store.update(n=>{let s=[],o=new Map(n.map(l=>[l.collateralId,l]));return a.forEach(({id:l,balance:c})=>{let u=o.get(l);u&&(this.log.trace("balances",{id:l,balance:c}),s.push({...u,collateralBalance:c.transferable}))}),s})}):di.EMPTY}subscribeStableswapUpdates(){return this.stableClient.getSubscriber().pipe(this.watchGuard("stableswap.updates")).subscribe(t=>{let e=new Map(t.map(i=>[i.id,i]));this.store.update(i=>{let r=[];for(let a of i){let n=e.get(a.id);n&&r.push({...a,fee:n.fee,tokens:n.tokens.filter(s=>s.id!==a.id),totalIssuance:n.totalIssuance,pegs:n.pegs,amplification:n.amplification,isRampPeriod:n.isRampPeriod})}return r})})}subscribeBalances(){return di.EMPTY}subscribeUpdates(){let t=new di;return t.add(this.subscribeCollateralBalance()),t.add(this.subscribeStableswapUpdates()),t.add(this.subscribeEvmLog()),t}};var Ot=class{static get(t){switch(t.type){case"Aave":return Qt.fromPool(t);case"XYK":return Kt.fromPool(t);case"Omnipool":return $t.fromPool(t);case"LBP":return Vt.fromPool(t);case"Stableswap":return ct.fromPool(t);case"HSM":return Zt.fromPool(t);default:throw new Error("Pool type "+t.type+" is not supported yet")}}};import{log as mo}from"@galacticcouncil/common";import{Subject as go,Subscription as ut,takeUntil as ho}from"rxjs";var{logger:bo}=mo,At=class extends R{evm;aave;omnipool;stableswap;hsm;xyk;lbp;active=new Set([]);pools=new Map([]);clients=[];aaveSub=ut.EMPTY;omniSub=ut.EMPTY;stableSub=ut.EMPTY;hsmSub=ut.EMPTY;xykSub=ut.EMPTY;lbpSub=ut.EMPTY;isReady=!1;isDestroyed=new go;constructor(t,e,i){super(t,i),this.evm=e,this.aave=new Jt(t,e,i),this.omnipool=new Xt(t,e,i),this.stableswap=new zt(t,e,i),this.hsm=new ie(t,e,this.stableswap,i),this.xyk=new jt(t,e,i),this.lbp=new Yt(t,e,i),this.clients=[this.aave,this.omnipool,this.stableswap,this.hsm,this.xyk,this.lbp]}get isHistorical(){return this.at!=="best"&&this.at!=="finalized"}subscribe(t){return this.isHistorical?ut.EMPTY:t.getSubscriber().pipe(ho(this.isDestroyed)).subscribe(e=>{e.forEach(i=>{this.pools.set(i.address,i)})})}withAave(){return this.aaveSub.unsubscribe(),this.aaveSub=this.subscribe(this.aave),this.active.add("Aave"),this}withOmnipool(){return this.omniSub.unsubscribe(),this.omniSub=this.subscribe(this.omnipool),this.active.add("Omnipool"),this}withStableswap(){return this.stableSub.unsubscribe(),this.stableSub=this.subscribe(this.stableswap),this.active.add("Stableswap"),this}withHsm(){return this.active.has("Stableswap")||(bo.info("[PoolContextProvider] auto-activating stableswap"),this.withStableswap()),this.hsmSub.unsubscribe(),this.hsmSub=this.subscribe(this.hsm),this.active.add("HSM"),this}withXyk(t){return this.xyk.withOverride(t),this.xykSub.unsubscribe(),this.xykSub=this.subscribe(this.xyk),this.active.add("XYK"),this}withLbp(){return this.lbpSub.unsubscribe(),this.lbpSub=this.subscribe(this.lbp),this.active.add("LBP"),this}destroy(){this.isDestroyed.next(!0),this.isDestroyed.complete(),this.active.clear(),this.pools.clear(),this.isReady=!1}async getPools(){if(this.isReady){let e=this.pools.values();return Array.from(e)}let t=await Promise.all(this.clients.filter(e=>this.active.has(e.getPoolType())).map(e=>e.getPools()));return this.isReady=!0,t.flat()}async getPoolFees(t,e){let i=this.clients.find(r=>r.getPoolType()===e.type);if(i)return i.getPoolFees(t,e.address);throw new nt(e.type)}};var Ce=class{constructor(t){this.snapshot=t;let{aave:e,xyk:i,lbp:r,stable:a,omni:n}=t.pools;this.flat=[...e,...i,...r,...a,...n]}flat;async getPools(){return this.flat}async getPoolFees(t,e){let{block:i,states:r}=this.snapshot;switch(e.type){case"Aave":return{};case"XYK":{let{exchangeFee:a}=r.xyk;return{exchangeFee:a}}case"LBP":{let{repayFee:a}=r.lbp;return{exchangeFee:e.fee,repayFee:a}}case"Stableswap":return{fee:e.fee};case"Omnipool":{let a=t.assetOut,n=t.assetIn,{dynamicFees:s,emaOracles:o,assetFeeParams:l,protocolFeeParams:c,maxSlipFee:u}=r.omni,d=s.find(({asset:b})=>b===a)?.fee,m=o.find(({pair:b})=>b.join(":")===_e(a))?.oracle,g=o.find(({pair:b})=>b.join(":")===_e(n))?.oracle;return lt.compute(t,i,d,m,g,l,c,u)}default:throw new nt(e.type)}}};var Ir={};O(Ir,{DCA_TIME_RESERVE:()=>Tr,DEFAULT_BLOCK_TIME:()=>wr,DEFAULT_MIN_BUDGET:()=>Pi,ORDER_MIN_BLOCK_PERIOD:()=>xr,Router:()=>Bt,TWAP_EXECUTION_INTERVAL:()=>oe,TWAP_MAX_DURATION:()=>wi,TWAP_MAX_PRICE_IMPACT:()=>Si,TWAP_TX_MULTIPLIER:()=>sy,TradeOrderError:()=>fi,TradeOrderType:()=>se,TradeRouteBuilder:()=>V,TradeRouter:()=>it,TradeScheduler:()=>Ft,TradeType:()=>ke});var re=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 yo=10,ae=class{isNotVisited(t,e){let i=!0;return e.forEach(r=>{(r[0]===t[0]||r[1]===t[1])&&(i=!1)}),i}findPaths(t,e,i){let r=[],a=new re,n=[];for(n.push([e,""]),a.enqueue(n);a.size()>0;){let s=a.dequeue();if(!s||s.length>yo)continue;let o=s[s.length-1];(i===null||o[0]===i)&&r.push(s),t.get(o[0])?.forEach(c=>{if(this.isNotVisited(c,s)){let u=[...s];u.push(c),a.enqueue(u)}})}return r}findShortestPaths(t,e,i){let r=[],a=new re,n=[];n.push([e,""]),a.enqueue(n);let s=1/0;for(;a.size()>0;){let o=a.dequeue();if(!o)continue;let l=o[o.length-1];if(l[0]===i){o.length<s?(s=o.length,r.length=0,r.push(o)):o.length===s&&r.push(o);continue}let c=t.get(l[0]);for(let u of c??[])this.isNotVisited(u,o)&&a.enqueue([...o,u])}return r}buildAndPopulateGraph(t,e){let i=new Map;for(let r of t)i.set(parseInt(r),[]);for(let[r,a,n]of e)i.get(a)?.push([n,r]);return i}};function yi(p){let t={};for(let e of p){let i=e.tokens.length;for(let r=0;r<i;r++){t[e.tokens[r].id]||(t[e.tokens[r].id]=[]);for(let a=0;a<i;a++){if(r==a)continue;let n=[e.address,e.tokens[r].id,e.tokens[a].id];t[e.tokens[r].id].push(n)}}}return t}var ne=class{getProposals(t,e,i){let r=i.filter(h=>h.type==="XYK"),a=i.filter(h=>h.type!=="XYK"),n=new Set(a.map(h=>h.tokens).flat().map(h=>h.id)),s=n.has(t),o=n.has(e),l=new ae,c=h=>{let y=yi(h),f=Object.keys(y),S=f.flatMap(P=>y[P]);return l.buildAndPopulateGraph(f,S)};if(!s&&!o){let h=r.filter(S=>S.tokens.find(P=>P.id===t)||S.tokens.find(P=>P.id===e)),y=c(h),f=l.findPaths(y,t,e);return this.parsePaths(f)}if(s&&o){let h=c(a),y=l.findPaths(h,t,e);return this.parsePaths(y)}let u=s?e:t,d=r.filter(h=>h.tokens.some(y=>y.id===u));if(d.length===0)return[];let m=[...a,...d],g=c(m),b=l.findPaths(g,t,e);return this.parsePaths(b)}parsePaths(t){let e=[];for(let i of t){let r=[];for(let a=0;a<i.length;a++){let n=i[a],s=i[a+1];if(s==null)break;r.push(this.toEdge(n,s))}e.push(r)}return e}toEdge(t,e){return[e[1],t[0],e[0]]}};var Bt=class{routeSuggester;routeProposals;ctx;filter={};constructor(t){this.ctx=t,this.routeSuggester=new ne,this.routeProposals=new Map}async withFilter(t){this.filter=t||{},this.routeProposals.clear(),this.onFilterChanged()}onFilterChanged(){}buildRouteKey(t,e,i){return`${t}->${e}::${i.length}`}applyPoolFilter(t){let{useOnly:e=[],exclude:i=[]}=this.filter,r=new Set(e),a=new Set(i);return t.filter(n=>a.has(n.type)?!1:r.size>0?r.has(n.type):!0)}async getPools(){let t=await this.ctx.getPools();return this.applyPoolFilter(t)}async getRoutes(t,e){let i=await this.getPools();return this.validateInput(t,e,i),this.getPaths(t,e,i)}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(r=>r!==t).map(r=>this.getRoutes(r,t)))).filter(r=>r.length>0).map(([r])=>r[0].assetIn).sort()}validateInput(t,e,i){if(i.length===0)throw new Error("No pools configured");if(t===e)throw new Error("Trading pair can't be identical");let r=this.getAssets(i);if(!r.has(t))throw new Error(t+" is not supported asset");if(!r.has(e))throw new Error(e+" is not supported asset");return this.toPoolsMap(i)}getAssets(t){let e=t.map(i=>i.tokens.map(r=>r.id)).flat().sort((i,r)=>i>r?1:-1);return new Set(e)}getPaths(t,e,i){let r=this.toPoolsMap(i);return this.getProposals(t,e,i).filter(n=>this.validPath(n,r)).map(n=>this.toHops(n,r))}getProposals(t,e,i){let r=this.buildRouteKey(t,e,i);if(this.routeProposals.has(r))return this.routeProposals.get(r);let a=this.routeSuggester.getProposals(t,e,i);return this.routeProposals.set(r,a),a}validPath(t,e){return t.length>0&&t.map(i=>this.validEdge(i,e)).reduce((i,r)=>i&&r)}validEdge([t,e,i],r){return r.get(t)?.validatePair(e,i)||!1}toPoolsMap(t){return new Map(t.map(e=>[e.address,Ot.get(e)]))}toHops(t,e){return t.map(([i,r,a])=>{let n=e.get(i);return{poolAddress:i,poolId:n?.id,pool:n?.type,assetIn:r,assetOut:a}})}};import{big as C,RUNTIME_DECIMALS as _t}from"@galacticcouncil/common";var ke=(e=>(e.Buy="Buy",e.Sell="Sell",e))(ke||{}),se=(i=>(i.Dca="Dca",i.TwapSell="TwapSell",i.TwapBuy="TwapBuy",i))(se||{}),fi=(i=>(i.OrderTooSmall="OrderTooSmall",i.OrderTooBig="OrderTooBig",i.OrderImpactTooBig="OrderImpactTooBig",i))(fi||{});var{FeeUtils:Sr}=T,it=class extends Bt{mlr;constructor(t){super(t),this.mlr=new Map}onFilterChanged(){this.mlr.clear()}buildCtxSync(t,e,i){let r=super.validateInput(t,e,i),a=super.getPaths(t,e,i);if(!a.length)throw new Mt(t,e);return{paths:a,pools:i,poolsMap:r}}async withCtx(t,e,i){let r=await super.getPools(),a=this.buildCtxSync(t,e,r);return i(a)}isDirectTrade(t){return t.length==1}findBestSellRoute(t){let e=t.sort((i,r)=>{let a=i[i.length-1].amountOut,n=r[r.length-1].amountOut;return a>n?-1:1});return e.find(i=>i.every(r=>r.errors.length==0))||e[0]}getRouteFeeRange(t){if(t.filter(i=>i.tradeFeeRange).length>0){let i=t.map(a=>a.tradeFeeRange?.[0]??a.tradeFeePct).reduce((a,n)=>a+n),r=t.map(a=>a.tradeFeeRange?.[1]??a.tradeFeePct).reduce((a,n)=>a+n);return[i,r]}}getPoolFeeRange(t,e){let i=t.min?Sr.toPct(t.min):void 0,r=t.max?Sr.toPct(t.max):void 0;if(i&&r)return[i,Math.max(r,e)]}async getBestSell(t,e,i){return this.getSell(t,e,i)}getSellSpot(t){let e=t[t.length-1];return t.length===1?e.spotPrice:this.calculateSpot(t)}async getSell(t,e,i,r){return this.withCtx(t,e,async({paths:a,poolsMap:n})=>{let s;if(r)s=await this.toSellSwaps(i,r,n);else{let o=a.map(c=>this.toSellSwaps(i,c,n)),l=await Promise.all(o);s=this.findBestSellRoute(l)}return this.buildSell(n,s)})}async getSells(t,e,i){return this.withCtx(t,e,async({paths:r,poolsMap:a})=>{let n=r.map(o=>this.toSellSwaps(i,o,a));return(await Promise.all(n)).filter(o=>o.every(l=>l.errors.length==0)).map(o=>this.buildSell(a,o)).sort((o,l)=>o.amountOut>l.amountOut?-1:1)})}buildSell(t,e){let i=e[0],r=e[e.length-1],a=this.isDirectTrade(e),n=this.getSellSpot(e),s=r.amountOut,o=a?r.calculatedOut:this.calculateDelta0Y(i.amountIn,e,t),l=o-s,c=this.getRouteFeeRange(e),u=a?r.tradeFeePct:L.calculateSellFee(o,s),d=B.mulSpot(i.amountIn,n,i.assetInDecimals,r.assetOutDecimals),m=L.calculateDiffToRef(o,d);return{type:"Sell",amountIn:i.amountIn,amountOut:r.amountOut,spotPrice:n,tradeFee:l,tradeFeePct:u,tradeFeeRange:c,priceImpactPct:m,swaps:e,toHuman(){return{type:"Sell",amountIn:C.toDecimal(i.amountIn,i.assetInDecimals),amountOut:C.toDecimal(r.amountOut,r.assetOutDecimals),spotPrice:C.toDecimal(n,_t),tradeFee:C.toDecimal(l,r.assetOutDecimals),tradeFeePct:u,tradeFeeRange:c,priceImpactPct:m,swaps:e.map(g=>g.toHuman())}}}}calculateSpot(t){return t.map(e=>e.spotPrice).reduce((e,i)=>e*i/10n**BigInt(_t))}calculateDelta0Y(t,e,i){let r=[];for(let a=0;a<e.length;a++){let n=e[a],s=i.get(n.poolAddress);if(s==null)throw new Error("Pool does not exit");let o=s.parsePair(n.assetIn,n.assetOut),l;a>0?l=r[a-1]:l=t;let c=s.calculateOutGivenIn(o,l);r.push(c)}return r[r.length-1]}async calculateMostLiquidRoute(t,e,i){let{paths:r,pools:a,poolsMap:n}=i,l=a.filter(b=>b.tokens.some(h=>h.id===t)).map(b=>b.type==="Aave"?b.tokens:b.tokens.filter(h=>h.id===t)).map(b=>b.map(h=>h.balance).reduce((h,y)=>h+y)).sort((b,h)=>h<b?-1:1)[0],c=B.getFraction(l,.1),u=await Promise.all(r.map(b=>this.toSellSwaps(c,b,n))),m=this.findBestSellRoute(u).map(b=>({poolAddress:b.poolAddress,poolId:b?.poolId,pool:b.pool,assetIn:b.assetIn,assetOut:b.assetOut})),g=this.buildRouteKey(t,e,a);return this.mlr.set(g,m),m}async toSellSwaps(t,e,i){let r=[];for(let a=0;a<e.length;a++){let n=e[a],s=i.get(n.poolAddress);if(s==null)throw new Error("Pool does not exit");let o=s.parsePair(n.assetIn,n.assetOut),l;a>0?l=r[a-1].amountOut:l=typeof t=="string"?C.toBigInt(t,o.decimalsIn):t;let c=await this.ctx.getPoolFees(o,s),{amountOut:u,calculatedOut:d,feePct:m,errors:g}=s.validateAndSell(o,l,c),b=this.getPoolFeeRange(c,m),h=s.spotPriceOutGivenIn(o),y=B.mulSpot(l,h,o.decimalsIn,o.decimalsOut),f=L.calculateDiffToRef(d,y);r.push({...n,assetInDecimals:o.decimalsIn,assetOutDecimals:o.decimalsOut,amountIn:l,amountOut:u,calculatedOut:d,spotPrice:h,tradeFeePct:m,tradeFeeRange:b,priceImpactPct:f,errors:g,isSupply(){return s.type==="Aave"&&s.tokens[0].id===n.assetIn},isWithdraw(){return s.type==="Aave"&&s.tokens[1].id===n.assetIn},toHuman(){return{...n,amountIn:C.toDecimal(l,o.decimalsIn),amountOut:C.toDecimal(u,o.decimalsOut),calculatedOut:C.toDecimal(d,o.decimalsOut),spotPrice:C.toDecimal(h,_t),tradeFeePct:m,tradeFeeRange:b,priceImpactPct:f,errors:g}}})}return r}async getMostLiquidRoute(t,e){return this.withCtx(t,e,async i=>{let r=this.buildRouteKey(t,e,i.pools),a=this.mlr.get(r);return a||this.calculateMostLiquidRoute(t,e,i)})}async getSpotPrice(t,e){return this.withCtx(t,e,async i=>{let{pools:r,poolsMap:a}=i,n=this.buildRouteKey(t,e,r),s=this.mlr.get(n);s||(s=await this.calculateMostLiquidRoute(t,e,i));let o=await this.toSellSwaps("1",s,a);return{amount:this.getSellSpot(o),decimals:_t}}).catch(()=>{})}findBestBuyRoute(t){let e=t.sort((i,r)=>{let a=i[0].amountIn,n=r[0].amountIn;return a>n?1:-1});return e.find(i=>i.every(r=>r.errors.length==0))||e[0]}async getBestBuy(t,e,i){return this.getBuy(t,e,i)}getBuySpot(t){let e=t[0];return t.length===1?e.spotPrice:this.calculateSpot(t)}async getBuy(t,e,i,r){return this.withCtx(t,e,async({paths:a,poolsMap:n})=>{let s;if(r)s=await this.toBuySwaps(i,r,n);else{let o=a.map(c=>this.toBuySwaps(i,c,n)),l=await Promise.all(o);s=this.findBestBuyRoute(l)}return this.buildBuy(n,s)})}async getBuys(t,e,i){return this.withCtx(t,e,async({paths:r,poolsMap:a})=>{let n=r.map(o=>this.toBuySwaps(i,o,a));return(await Promise.all(n)).filter(o=>o.every(l=>l.errors.length==0)).map(o=>this.buildBuy(a,o)).sort((o,l)=>o.amountIn>l.amountIn?1:-1)})}buildBuy(t,e){let i=e[e.length-1],r=e[0],a=this.isDirectTrade(e),n=this.getBuySpot(e),s=r.amountIn,o=a?r.calculatedIn:this.calculateDelta0X(i.amountOut,e,t),l=s-o,c=this.getRouteFeeRange(e),u=a?r.tradeFeePct:L.calculateBuyFee(o,s),d=B.mulSpot(i.amountOut,n,i.assetOutDecimals,r.assetInDecimals),m;return o===0n?m=-100:m=L.calculateDiffToRef(d,o),{type:"Buy",amountOut:i.amountOut,amountIn:r.amountIn,spotPrice:n,tradeFee:l,tradeFeePct:u,tradeFeeRange:c,priceImpactPct:m,swaps:e,toHuman(){return{type:"Buy",amountOut:C.toDecimal(i.amountOut,i.assetOutDecimals),amountIn:C.toDecimal(r.amountIn,r.assetInDecimals),spotPrice:C.toDecimal(n,_t),tradeFee:C.toDecimal(l,r.assetInDecimals),tradeFeePct:u,tradeFeeRange:c,priceImpactPct:m,swaps:e.map(g=>g.toHuman())}}}}calculateDelta0X(t,e,i){let r=[];for(let a=e.length-1;a>=0;a--){let n=e[a],s=i.get(n.poolAddress);if(s==null)throw new Error("Pool does not exit");let o=s.parsePair(n.assetIn,n.assetOut),l;a==e.length-1?l=t:l=r[0];let c=s.calculateInGivenOut(o,l);r.unshift(c)}return r[0]}async toBuySwaps(t,e,i){let r=[];for(let a=e.length-1;a>=0;a--){let n=e[a],s=i.get(n.poolAddress);if(s==null)throw new Error("Pool does not exit");let o=s.parsePair(n.assetIn,n.assetOut),l;a==e.length-1?l=typeof t=="string"?C.toBigInt(t,o.decimalsOut):t:l=r[0].amountIn;let c=await this.ctx.getPoolFees(o,s),{amountIn:u,calculatedIn:d,feePct:m,errors:g}=s.validateAndBuy(o,l,c),b=this.getPoolFeeRange(c,m),h=s.spotPriceInGivenOut(o),y=B.mulSpot(l,h,o.decimalsOut,o.decimalsIn),f;d===0n?f=-100:f=L.calculateDiffToRef(y,d),r.unshift({...n,assetInDecimals:o.decimalsIn,assetOutDecimals:o.decimalsOut,amountOut:l,amountIn:u,calculatedIn:d,spotPrice:h,tradeFeePct:m,tradeFeeRange:b,priceImpactPct:f,errors:g,isSupply(){return s.type==="Aave"&&s.tokens[0].id===n.assetIn},isWithdraw(){return s.type==="Aave"&&s.tokens[1].id===n.assetIn},toHuman(){return{...n,amountOut:C.toDecimal(l,o.decimalsOut),amountIn:C.toDecimal(u,o.decimalsIn),calculatedIn:C.toDecimal(d,o.decimalsIn),spotPrice:C.toDecimal(h,_t),tradeFeePct:m,tradeFeeRange:b,priceImpactPct:f,errors:g}}})}return r}};import{big as F}from"@galacticcouncil/common";var wr=6e3,Pi=1000000000000000n,oe=6,Si=-5,wi=216e5,sy=3,Tr=.1,xr=6;import{Enum as vr}from"polkadot-api";var V=class{static build(t){return t.map(({assetIn:e,assetOut:i,pool:r,poolId:a})=>r==="Stableswap"?{pool:vr("Stableswap",a),asset_in:e,asset_out:i}:{pool:vr(r),asset_in:e,asset_out:i})}};var Ft=class{schedulerOptions;router;constructor(t,e={}){this.router=new it(t),this.router.withFilter({exclude:["HSM"]}),this.schedulerOptions=Object.freeze({blockTime:e.blockTime??6e3,minBudgetInNative:e.minBudgetInNative??Pi})}get blockTime(){return this.schedulerOptions.blockTime}get minOrderBudget(){return this.schedulerOptions.minBudgetInNative}async getDcaOrder(t,e,i,r,a){let n=await this.router.getBestSell(t,e,i),{amountIn:s,swaps:o,priceImpactPct:l}=n,c=o[0],u=o[o.length-1],{assetInDecimals:d}=c,{assetOutDecimals:m}=u,g=Math.abs(l),b=await this.getMinimumOrderBudget(t,d),h=this.getOptimalTradeCount(g),y=this.getMaximumTradeCount(s,b,r),f=a||Math.min(h,y),S=Math.round(r/f),P=s/BigInt(f),w=await this.router.getBestSell(t,e,P),x=s<b,_=[];x&&_.push("OrderTooSmall");let H=await this.getAssetOutEd(u),k=w.amountOut*BigInt(f),j=this.toBlockPeriod(S),G=w.tradeFee*BigInt(f),$=V.build(o),tt={assetIn:t,assetOut:e,assetOutEd:H,errors:_,maxTradeCount:y,tradeCount:f,tradeFee:G,tradeImpactPct:w.priceImpactPct,tradePeriod:j,tradeRoute:$,type:"Dca"};return{...tt,amountIn:s,amountOut:k,tradeAmountIn:w.amountIn,tradeAmountOut:w.amountOut,toHuman(){return{...tt,amountIn:F.toDecimal(s,d),amountOut:F.toDecimal(k,m),assetOutEd:F.toDecimal(H,m),tradeAmountIn:F.toDecimal(w.amountIn,d),tradeAmountOut:F.toDecimal(w.amountOut,m)}}}}async getMinimumOrderBudget(t,e){if(0===t)return this.minOrderBudget;let i=await this.router.getSpotPrice(0,t);if(i)return B.mulSpot(this.minOrderBudget,i.amount,12,e);let r=await this.router.getSpotPrice(t,0);if(r)return B.divSpot(this.minOrderBudget,r.amount,12,e);throw new Error("Unable to calculate order budget")}getMaximumTradeCount(t,e,i){let r=e*2n/10n;if(r===0n)return 0;let a=Number(t/r),n=Math.floor(i/this.blockTime),s=Math.max(0,Math.floor(n*(1-.1)));return Math.min(a,s)}getOptimalTradeCount(t){let e=Math.round(t*10)||1;return Math.max(e,3)}async getOpenBudgetDcaOrder(t,e,i,r){let a=await this.router.getBestSell(t,e,i),{swaps:n}=a,s=n[0],o=n[n.length-1],{assetInDecimals:l}=s,{assetOutDecimals:c}=o,u=await this.getMinimumOrderBudget(t,l),d=a.amountIn<u,m=[];d&&m.push("OrderTooSmall");let g=await this.getAssetOutEd(o),b=this.toBlockPeriod(r),h=V.build(n),y={assetIn:t,assetOut:e,assetOutEd:g,errors:m,maxTradeCount:0,tradeCount:0,tradeFee:a.tradeFee,tradeImpactPct:a.priceImpactPct,tradePeriod:b,tradeRoute:h,type:"Dca"};return{...y,amountIn:0n,amountOut:0n,tradeAmountIn:a.amountIn,tradeAmountOut:a.amountOut,toHuman(){return{...y,amountIn:"0",amountOut:"0",assetOutEd:F.toDecimal(g,c),tradeAmountIn:F.toDecimal(a.amountIn,l),tradeAmountOut:F.toDecimal(a.amountOut,c)}}}}async getTwapSellOrder(t,e,i){let r=await this.router.getBestSell(t,e,i),{amountIn:a,swaps:n,priceImpactPct:s}=r,o=n[0],l=n[n.length-1],{assetInDecimals:c}=o,{assetOutDecimals:u}=l,d=Math.abs(s),m=this.getTwapTradeCount(d),g=a/BigInt(m),[b,h]=await Promise.all([this.getMinimumOrderBudget(t,c),this.router.getBestSell(o.assetIn,l.assetOut,g)]),y=m===1,f=a<b,S=h.priceImpactPct<-5,P=[];f||y?P.push("OrderTooSmall"):S&&P.push("OrderImpactTooBig");let w=await this.getAssetOutEd(l),x=h.amountOut*BigInt(m),_=h.tradeFee*BigInt(m),H=V.build(n),k={assetIn:t,assetOut:e,assetOutEd:w,errors:P,tradeCount:m,tradeImpactPct:h.priceImpactPct,tradePeriod:6,tradeRoute:H,type:"TwapSell"};return{...k,amountIn:a,amountOut:x,tradeAmountIn:h.amountIn,tradeAmountOut:h.amountOut,tradeFee:_,toHuman(){return{...k,amountIn:F.toDecimal(a,c),amountOut:F.toDecimal(x,u),assetOutEd:F.toDecimal(w,u),tradeAmountIn:F.toDecimal(h.amountIn,c),tradeAmountOut:F.toDecimal(h.amountOut,u),tradeFee:F.toDecimal(_,u)}}}}async getTwapBuyOrder(t,e,i){let r=await this.router.getBestBuy(t,e,i),{amountOut:a,swaps:n,priceImpactPct:s}=r,o=n[0],l=n[n.length-1],{assetInDecimals:c}=o,{assetOutDecimals:u}=l,d=Math.abs(s),m=this.getTwapTradeCount(d),g=a/BigInt(m),[b,h]=await Promise.all([this.getMinimumOrderBudget(t,c),this.router.getBestBuy(o.assetIn,l.assetOut,g)]),y=h.amountIn*BigInt(m),f=m===1,S=y<b,P=h.priceImpactPct<-5,w=[];S||f?w.push("OrderTooSmall"):P&&w.push("OrderImpactTooBig");let x=await this.getAssetOutEd(l),_=h.tradeFee*BigInt(m),H=V.build(n),k={assetIn:t,assetOut:e,assetOutEd:x,errors:w,tradeCount:m,tradeImpactPct:h.priceImpactPct,tradePeriod:6,tradeRoute:H,type:"TwapBuy"};return{...k,amountIn:y,amountOut:a,tradeAmountIn:h.amountIn,tradeAmountOut:h.amountOut,tradeFee:_,toHuman(){return{...k,amountIn:F.toDecimal(y,c),amountOut:F.toDecimal(a,u),assetOutEd:F.toDecimal(x,u),tradeAmountIn:F.toDecimal(h.amountIn,c),tradeAmountOut:F.toDecimal(h.amountOut,u),tradeFee:F.toDecimal(_,c)}}}}getTwapTradeCount(t){let e=this.getOptimalTradeCount(t);if(this.getTwapExecutionTime(e)>216e5){let r=216e5/(this.blockTime*6);return Math.round(r)}return e}getTwapExecutionTime(t){return t*6*this.blockTime}toBlockPeriod(t){let e=t/this.blockTime,i=Math.round(e);return Math.max(i,6)}async getAssetOutEd(t){let r=(await this.router.getPools()).find(a=>a.address===t.poolAddress)?.tokens.find(a=>a.id===t.assetOut);if(!r)throw new Error(`Asset ${t.assetOut} not found in pool ${t.poolAddress}`);return r.existentialDeposit}};var Cr={};O(Cr,{BIG_10:()=>Rr,BIG_BILL:()=>Ti,StakingApi:()=>le,StakingClient:()=>ce});import{calculate_accumulated_rps as wo,calculate_percentage_amount as To,calculate_period_number as Br,calculate_points as _r,calculate_rewards as xo,sigmoid as Fr}from"@galacticcouncil/math-staking";import W from"big.js";var De={none:.1,locked1x:1,locked2x:2,locked3x:3,locked4x:4,locked5x:5,locked6x:6},Or=p=>Object.keys(De).includes(p);import{AccountId as fo}from"polkadot-api";import{toHex as Po}from"@polkadot-api/utils";import{HYDRATION_SS58_PREFIX as So}from"@galacticcouncil/common";function Ar(p){let t=("modl"+p).padEnd(32,"\0"),e=new TextEncoder().encode(t),i=Po(e);return fo(So).dec(i)}var Me="20000000000000000",Le="2000",Rr=W(10),Ti=W(Rr.pow(12)),le=class{client;balance;constructor(t,e){this.client=t,this.balance=e}async getPotBalance(){let t=await this.client.getPalletId(),e=Ar(t);return await this.balance.getBalance(e,0)}async getStakingPosition(t){let[e,i]=await Promise.all([this.client.getStakingPositionsValue(t),this.client.getStakingVotes(t)]);if(!e)return;let r=e.created_at,a=await i.reduce(async(n,[s,o])=>{let l=await n,c=s,u=o.amount,d=o.conviction.type.toLowerCase(),m=await this.client.getReferendumInfo(c);return m&&(m.type==="Approved"||m.type==="Rejected")&&Or(d)&&l.push({id:c,amount:u,conviction:d}),l},Promise.resolve([]));return{stake:e.stake,rewardPerStake:e.reward_per_stake,createdAt:r,actionPoints:e.action_points,accumulatedUnpaidRewards:e.accumulated_unpaid_rewards,accumulatedSlashPoints:e.accumulated_slash_points,accumulatedLockedRewards:e.accumulated_locked_rewards,votes:a}}async getStake(t){let e=await this.client.getNFTCollectionId(),[i,r]=await Promise.all([this.client.getStaking(),this.client.getUniques(t,e)]),a=r.find(n=>n)?.itemId;return{totalStake:i?.total_stake,accumulatedRewardPerStake:i?.accumulated_reward_per_stake,potReservedBalance:i?.pot_reserved_balance,positionId:a,stakePosition:a?await this.getStakingPosition(a):void 0}}getCurrentActionPoints(t,e,i,r){let a=W(0),n=W(0),s=De.locked6x,o=W(i.toString()).mul(s),l=100,c=[];t.forEach(m=>{let g=De[m.conviction],b=r.includes(m.id.toString());b&&c.push(m.id.toString());let h=W(m.amount.toString()).mul(l).div(o);a=a.plus(Math.floor(h.mul(g).toNumber())),n=n.plus(Math.floor(h.mul(b?s:g).toNumber()))});let u=Math.floor(W(i.toString()).mul(s).mul(l).div(o).toNumber());r.forEach(m=>{c.includes(m)||(n=n.plus(u))});let d={democracyVote:1};return a=a.mul(d.democracyVote),a=a.plus(e.toString()||"0"),n=n.mul(d.democracyVote),n=n.plus(e.toString()||"0"),{currentActionPoints:a.toString(),maxActionPoints:n.toString()}}async getRewards(t,e,i){let r=await this.getStake(t),{potReservedBalance:a,accumulatedRewardPerStake:n,totalStake:s,stakePosition:o}=r;if(!o)return;let[l,c,u,d,m,g,b]=await Promise.all([this.getPotBalance(),this.client.getPeriodLength(),this.client.getUnclaimablePeriods(),this.client.getTimePointsPerPeriod(),this.client.getTimePointsWeight(),this.client.getActionPointsWeight(),this.client.getSixBlockSince()]),h=W(l.transferable.toString()).minus(a.toString()),y=h.gt(0)&&s>0?wo(n.toString(),h.toString(),s.toString()):n.toString(),f=Br(c.toString(),i,b),S=Br(c.toString(),o.createdAt.toString(),b),P=xo(y,o.rewardPerStake.toString(),o.stake.toString()),w=this.getCurrentActionPoints(o.votes,o.actionPoints,o.stake,e),x=_r(S,f,d.toString(),m.toString(),w.currentActionPoints,g.toString(),o.accumulatedSlashPoints.toString()),_=Fr(x,Me,Le),H=(()=>{if(!e.length)return;let tt=_r(S,f,d.toString(),m.toString(),w.maxActionPoints.toString(),g.toString(),o.accumulatedSlashPoints.toString());return Fr(tt,Me,Le)})(),k=W(P).plus(o.accumulatedUnpaidRewards.toString()).plus(o.accumulatedLockedRewards.toString());if(W(f).minus(S).lte(u.toString()))return{rewards:"0",payablePercentage:_,extraPayablePercentage:H,constants:{a:Me,b:Le}};let j=To(k.toString(),_),G=W(o.accumulatedLockedRewards.toString()),$=G.gt(j)?G:W(j);return{rewards:$.div(Ti).toString(),maxRewards:k.div(Ti).toString(),allocatedRewardsPercentage:$.div(k).mul(100).toNumber(),points:x,payablePercentage:_,extraPayablePercentage:H,constants:{a:Me,b:Le}}}};import{Binary as Er}from"polkadot-api";var ce=class extends R{async getPalletId(){let t=this.api.constants.Staking.PalletId,e=await t();return Er.toText(Er.fromHex(e))}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:n})=>{let[s,o,l]=n;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 getTimePointsPerPeriod(){let t=this.api.constants.Staking.TimePointsPerPeriod;return await t()}async getTimePointsWeight(){let t=this.api.constants.Staking.TimePointsWeight;return await t()/1e6}async getActionPointsWeight(){let t=this.api.constants.Staking.ActionPointsWeight;return await t()/1e9}async getSixBlockSince(){return(await this.api.query.Staking.SixSecBlocksSince.getValue()).toString()}};var Lr={};O(Lr,{TxBuilderFactory:()=>Rt});import{Enum as Dr}from"polkadot-api";function kr(p){let t=[],e=p;for(;e&&typeof e=="object"&&"type"in e;)t.push(e.type),e=e.value;return t.join(".")}var Y=class extends R{evm;evmClient;balance;aaveUtils;constructor(t,e){super(t),this.evm=e,this.evmClient=e.getWsProvider(),this.balance=new z(t),this.aaveUtils=new at(e)}wrapTx(t,e){return{name:t,get:()=>e,dryRun:i=>this.dryRun(i,e)}}async dispatchWithExtraGas(t){return this.api.tx.Dispatcher.dispatch_with_extra_gas({call:t.decodedCall,extra_gas:Xe})}async dryRun(t,e){let i=Dr("Signed",t),r=Dr("system",i),n=await this.client.getUnsafeApi().apis.DryRunApi.dry_run_call(r,e.decodedCall,4),s=n.success&&!n.value.execution_result.success?n.value.execution_result.value.error:null;if(s){let o=s.type==="Module"?kr(s.value):s.type;throw new Error("Dry run execution error!",{cause:o})}return n}isDirectOmnipoolTrade(t){return t.length===1&&t[0].pool==="Omnipool"}};var qe=class extends Y{_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:i}=this.trade;if(i==="Buy")return this.buildBuyTx();let{assetIn:r}=e[0],a=await this.balance.getBalance(this.beneficiary,r);return t>=a.transferable-5n?this.buildSellAllTx():this.buildSellTx()}async buildBuyTx(){let{amountIn:t,amountOut:e,swaps:i}=this.trade,r=i[0],a=i[i.length-1],n=B.getFraction(t,this.slippagePct),s=r.assetIn,o=a.assetOut,l=t+n,c;return this.isDirectOmnipoolTrade(i)?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:V.build(i)}),await this.aaveUtils.hasBorrowPositions(this.beneficiary)&&(c=await this.dispatchWithExtraGas(c)),this.wrapTx("RouterBuy",c)}async buildSellTx(){let{amountIn:t,amountOut:e,swaps:i}=this.trade,r=i[0],a=i[i.length-1],n=B.getFraction(e,this.slippagePct),s=r.assetIn,o=a.assetOut,l=e-n,c;return this.isDirectOmnipoolTrade(i)?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:V.build(i)}),await this.aaveUtils.hasBorrowPositions(this.beneficiary)&&(c=await this.dispatchWithExtraGas(c)),this.wrapTx("RouterSell",c)}async buildSellAllTx(){let{amountOut:t,swaps:e}=this.trade,i=e[0],r=e[e.length-1],a=B.getFraction(t,this.slippagePct),n=i.assetIn,s=r.assetOut,o=t-a,l=this.api.tx.Router.sell_all({asset_in:n,asset_out:s,min_amount_out:o,route:V.build(e)});return await this.aaveUtils.hasBorrowPositions(this.beneficiary)&&(l=await this.dispatchWithExtraGas(l)),this.wrapTx("RouterSellAll",l)}};import{Enum as xi}from"polkadot-api";var He=class extends Y{_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}`)}}async buildDcaTx(){let{amountIn:t,assetIn:e,assetOut:i,tradeAmountIn:r,tradePeriod:a,tradeRoute:n}=this.order,s=this.api.tx.DCA.schedule({schedule:{owner:this.beneficiary,period:a,max_retries:this.maxRetries,total_amount:t,slippage:this.slippagePct*1e4,stability_threshold:void 0,order:xi("Sell",{asset_in:e,asset_out:i,amount_in:r,min_amount_out:0n,route:n})},start_execution_block:void 0});return await this.aaveUtils.hasBorrowPositions(this.beneficiary)&&(s=await this.dispatchWithExtraGas(s)),this.wrapTx("DcaSchedule",s)}async buildTwapSellTx(){let{amountIn:t,assetIn:e,assetOut:i,tradeAmountIn:r,tradeAmountOut:a,tradePeriod:n,tradeRoute:s}=this.order,o=B.getFraction(a,this.slippagePct),l=a-o,c=this.api.tx.DCA.schedule({schedule:{owner:this.beneficiary,period:n,max_retries:this.maxRetries,total_amount:t,slippage:this.slippagePct*1e4,stability_threshold:void 0,order:xi("Sell",{asset_in:e,asset_out:i,amount_in:r,min_amount_out:l,route:s})},start_execution_block:void 0});return await this.aaveUtils.hasBorrowPositions(this.beneficiary)&&(c=await this.dispatchWithExtraGas(c)),this.wrapTx("DcaSchedule.twapSell",c)}async buildTwapBuyTx(){let{amountIn:t,assetIn:e,assetOut:i,tradeAmountIn:r,tradeAmountOut:a,tradePeriod:n,tradeRoute:s}=this.order,o=B.getFraction(r,this.slippagePct),l=r+o,c=this.api.tx.DCA.schedule({schedule:{owner:this.beneficiary,period:n,max_retries:this.maxRetries,total_amount:t,slippage:this.slippagePct*1e4,stability_threshold:void 0,order:xi("Buy",{asset_in:e,asset_out:i,amount_out:a,max_amount_in:l,route:s})},start_execution_block:void 0});return await this.aaveUtils.hasBorrowPositions(this.beneficiary)&&(c=await this.dispatchWithExtraGas(c)),this.wrapTx("DcaSchedule.twapBuy",c)}};import{Enum as vo}from"polkadot-api";var Ne=class extends Y{_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,amountOut:e,swaps:i}=this.trade,r=i[0],a=i[i.length-1],n=r.assetIn,s=a.assetOut,o=B.getFraction(e,this.slippagePct),l=e-o,c=vo("Swap",{asset_in:n,asset_out:s,amount_in:t,amount_out:l,partial:!1}),u=this.apiIce.tx.Intent.submit_intent({intent:{data:c}});return await this.aaveUtils.hasBorrowPositions(this.beneficiary)&&(u=await this.dispatchWithExtraGas(u)),this.wrapTx("IntentSwap",u)}};import{Enum as Io}from"polkadot-api";var Ge=class extends Y{_trade;_beneficiary;_minAmountOut;_deadline;_partial=!0;setTrade(t){return this._trade=t,this}withBeneficiary(t){return this._beneficiary=t,this}withPartial(t){return this._partial=t,this}withMinAmountOut(t){return this._minAmountOut=t,this}withDeadline(t){return this._deadline=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 partial(){return this._partial}get minAmountOut(){return this._minAmountOut}get deadline(){return this._deadline}async build(){let{amountIn:t,amountOut:e,swaps:i}=this.trade,r=i[0],a=i[i.length-1],n=r.assetIn,s=a.assetOut,o=Io("Swap",{asset_in:n,asset_out:s,amount_in:t,amount_out:this.minAmountOut??e,partial:this.partial}),l=this.apiIce.tx.Intent.submit_intent({intent:{data:o,deadline:this.deadline}});return await this.aaveUtils.hasBorrowPositions(this.beneficiary)&&(l=await this.dispatchWithExtraGas(l)),this.wrapTx("IntentLimitOrder",l)}};import{Enum as Mr}from"polkadot-api";var Ve=class extends Y{_order;_beneficiary;_slippagePct=1;setOrder(t){return this._order=t,this}withBeneficiary(t){return this._beneficiary=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 slippagePct(){return this._slippagePct}async build(){let{type:t}=this.order;switch(t){case"Dca":return this.buildDcaTx();case"TwapSell":case"TwapBuy":return this.buildTwapTx();default:throw new Error(`Unsupported TradeOrderType: ${t}`)}}async buildDcaTx(){let{amountIn:t,assetIn:e,assetOut:i,assetOutEd:r,tradeAmountIn:a,tradePeriod:n}=this.order,s=Mr("Dca",{asset_in:e,asset_out:i,amount_in:a,amount_out:r,slippage:this.slippagePct*1e4,budget:t,period:n}),o=this.apiIce.tx.Intent.submit_intent({intent:{data:s}});return await this.aaveUtils.hasBorrowPositions(this.beneficiary)&&(o=await this.dispatchWithExtraGas(o)),this.wrapTx("IntentDcaSchedule",o)}async buildTwapTx(){let{amountIn:t,assetIn:e,assetOut:i,tradeAmountIn:r,tradeAmountOut:a,tradePeriod:n}=this.order,s=B.getFraction(a,this.slippagePct),o=a-s,l=Mr("Dca",{asset_in:e,asset_out:i,amount_in:r,amount_out:o,slippage:this.slippagePct*1e4,budget:t,period:n}),c=this.apiIce.tx.Intent.submit_intent({intent:{data:l}});return await this.aaveUtils.hasBorrowPositions(this.beneficiary)&&(c=await this.dispatchWithExtraGas(c)),this.wrapTx("IntentDcaSchedule.twap",c)}};var Rt=class{client;evmClient;constructor(t,e){this.client=t,this.evmClient=e}trade(t){return new qe(this.client,this.evmClient).setTrade(t)}order(t){return new He(this.client,this.evmClient).setOrder(t)}intentMarket(t){return new Ne(this.client,this.evmClient).setTrade(t)}intentLimit(t){return new Ge(this.client,this.evmClient).setTrade(t)}intentOrder(t){return new Ve(this.client,this.evmClient).setOrder(t)}};async function uP(p,t){let{at:e}=t??{},i=new ft(p),r=new qt(p),[a,n]=await Promise.all([i.getBlockTime(),i.getMinOrderBudget()]),s=new At(p,r,e).withAave().withOmnipool().withStableswap().withXyk(),o=new z(p),l=new ce(p),c=new Gt(p),u=new at(r),d=new it(s),m=new Ft(s,{blockTime:a,minBudgetInNative:n}),g=new le(l,o),b=new Nt(c,o,{blockTime:a});return{api:{aave:u,router:d,scheduler:m,staking:g,farm:b},client:{asset:new mt(p),balance:o,evm:r},ctx:{pool:s},tx:new Rt(p,r),destroy:()=>{s.destroy()}}}export{Te as QueryBus,Fi as aave,Bi as api,we as async,B as calc,Li as client,Ri as const,uP as createSdkContext,qi as error,Vi as evm,Ji as farm,T as fmt,Ht as json,L as math,Pr as pool,Ir as sor,Cr as staking,Lr as tx};
1
+ var ma=Object.defineProperty;var A=(m,t)=>{for(var e in t)ma(m,e,{get:t[e],enumerable:!0})};import pa from"buffer";typeof window<"u"&&(window.Buffer=pa.Buffer);var Vr={};A(Vr,{Papi:()=>E,Watcher:()=>qt,getSm:()=>ka,getWs:()=>ir});import{hydration as Ba,hydrationNext as _a,hydrationIce as Fa}from"@galacticcouncil/descriptors";import{log as va}from"@galacticcouncil/common";import{map as Ta,shareReplay as Ia,tap as Aa}from"rxjs";import{defer as da,from as ga,of as Gr,timer as ha}from"rxjs";import{catchError as ba,distinctUntilChanged as ya,expand as fa,map as rr,shareReplay as Pa,skip as Sa,switchMap as wa,timeout as xa}from"rxjs/operators";function Ur(m,{intervalMs:t=5e3,rpcTimeoutMs:e=1e4}={}){let r=()=>da(()=>ga(m._request("system_health",[]))).pipe(xa({first:e}),rr(()=>"online"),ba(()=>Gr("offline")));return Gr({state:"offline",delayMs:0}).pipe(fa(a=>ha(a.delayMs).pipe(wa(r),rr(n=>({state:n,delayMs:t})))),Sa(1),rr(a=>a.state),ya(),Pa({bufferSize:1,refCount:!0}))}var{logger:Oa}=va,qt=class m{static instance=null;bestBlock$;finalizedBlock$;connection$;constructor(t){this.bestBlock$=this.watched("watcher(bestBlock)",t.getUnsafeApi().query.System.Number.watchValue({at:"best"}).pipe(Ta(({value:e})=>e))),this.finalizedBlock$=this.watched("watcher(finalizedBlock)",t.finalizedBlock$),this.connection$=this.watched("watcher(connection)",Ur(t))}static getInstance(t){return this.instance||(this.instance=new m(t)),this.instance}watched(t,e){return e.pipe(Aa({error:r=>Oa.error(t,r)}),Ia({bufferSize:1,refCount:!0}))}};var E=class{client;api;apiNext;apiIce;watcher;at;constructor(t,e){this.client=t,this.api=this.client.getTypedApi(Ba),this.apiNext=this.client.getTypedApi(_a),this.apiIce=this.client.getTypedApi(Fa),this.watcher=qt.getInstance(this.client),this.at=e??"best"}};import{getWsProvider as Ea}from"polkadot-api/ws";import{withLogsRecorder as Ra}from"polkadot-api/logs-provider";var ir=(m,t={})=>{let e=typeof m=="string"?m.split(","):m,r=Ea(e,t);return Ra(i=>console.log(i),r),r};async function ka(m){let{getSmProvider:t}=await import("polkadot-api/sm-provider"),{start:e}=await import("polkadot-api/smoldot"),{chainSpec:r}=await import("polkadot-api/chains/polkadot"),i=e(),a=await i.addChain({chainSpec:r}),n=await i.addChain({chainSpec:m,potentialRelayChains:[a]});return t(()=>n)}var Wr={};A(Wr,{AAVE_GAS_LIMIT:()=>nr,AAVE_LENDING_POOL_ADDRESS:()=>Ie,AAVE_POOL_ABI:()=>Ht,AAVE_POOL_DATA_PROVIDER:()=>Te,AAVE_POOL_DATA_PROVIDER_ABI:()=>ve,AAVE_POOL_PROXY:()=>ar,AAVE_ROUNDING_THRESHOLD:()=>Dl,AAVE_UINT_256_MAX:()=>Ca,AaveClient:()=>Nt,AaveLog:()=>Gt,AaveUtils:()=>nt});var Ht=[{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 ve=[{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 ar="0x1b02E051683b5cfaC5929C25E84adb26ECf87B38",Te="0x112b087b60C1a166130d59266363C45F8aa99db0",Ie="0xf3Ba4D1b50f78301BDD7EAEa9B67822A15FCA691",nr=1000000n,Dl=5,Ca=BigInt("0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");var Nt=class{client;constructor(t){this.client=t.getWsProvider()}async getBlockTimestamp(){let t=await this.client.getBlock();return Number(t.timestamp)}async getReservesData(){return await this.client.readContract({abi:ve,address:Te,args:[Ie],functionName:"getReservesData"})}async getUserReservesData(t){return await this.client.readContract({abi:ve,address:Te,args:[Ie,t],functionName:"getUserReservesData"})}async getUserAccountData(t){return await this.client.readContract({abi:Ht,address:ar,args:[t],functionName:"getUserAccountData"})}};import{Binary as Ma}from"polkadot-api";import{decodeEventLog as Da}from"viem";var Gt=class{static parse(t){let{topics:e,data:r}=t.log,i=Ma.toHex(r);try{let{eventName:a,args:n}=Da({abi:Ht,topics:e,data:i}),s=n.reserve.toLowerCase();return{eventName:a,reserve:s,key:`${a}:${s}`}}catch{return}}};import R from"big.js";import{big as at,erc20 as La,h160 as qa}from"@galacticcouncil/common";var{ERC20:dt}=La,{H160:sr}=qa,Ha=1.01,Na=31536000n,Yr=4,Ae=-1,Oe=10n**27n,nt=class{client;constructor(t){this.client=new Nt(t)}async getSummary(t){let e=sr.fromAny(t),[r,i,a,n]=await Promise.all([this.client.getReservesData(),this.client.getUserReservesData(e),this.client.getUserAccountData(e),this.client.getBlockTimestamp()]),[s]=r,[o,l]=i,[c,u,d,p,g,b]=a,h=at.toDecimal(b,18),y=[];for(let f of o){let S=f.underlyingAsset.toLowerCase(),P=s.find(({underlyingAsset:er})=>er.toLowerCase()===S);if(!P)throw new Error("Missing pool reserve for "+S);let w=f.scaledATokenBalance,v=P.liquidityIndex,_=P.liquidityRate,H=P.availableLiquidity,M=P.priceInMarketReferenceCurrency,j=n+6,G=this.calculateLinearInterest(_,P.lastUpdateTimestamp,j),$=v*G/Oe,tt=w*$/Oe,Se=Number(l!==0&&l===P.eModeCategoryId?P.eModeLiquidationThreshold:P.reserveLiquidationThreshold)/1e4,we=P.usageAsCollateralEnabled&&f.usageAsCollateralEnabledOnUser&&f.scaledATokenBalance>0n,xe=dt.toAssetId(S);y.push({aTokenBalance:tt,availableLiquidity:H,decimals:Number(P.decimals),isCollateral:we,priceInRef:M,reserveId:xe,reserveAsset:S,reserveLiquidationThreshold:Se})}return{healthFactor:Number(h),currentLiquidationThreshold:Number(at.toDecimal(p,Yr)),totalCollateral:c,totalDebt:u,reserves:y}}async hasBorrowPositions(t){let e=sr.fromAny(t),r=await this.client.getUserAccountData(e),[i,a]=r;return a>0n}async getHealthFactor(t){let e=sr.fromAny(t),r=await this.client.getUserAccountData(e),[i,a,n,s,o,l]=r;return this.calculateHealthFactorFromBalances(a,i,s)}async getHealthFactorAfterWithdraw(t,e,r){let{totalCollateral:i,totalDebt:a,reserves:n,currentLiquidationThreshold:s}=await this.getSummary(t);if(a===0n)return Ae;let o=dt.fromAssetId(e),l=n.find(S=>S.reserveAsset===o);if(!l)throw new Error("Missing reserve ctx for "+o);let{decimals:c,isCollateral:u,priceInRef:d,reserveLiquidationThreshold:p}=l,g=at.toBigInt(r,c),b=u?g*d/10n**BigInt(c):0n,h=i-b;if(h<=0n)return 0;let y=R(i.toString()).mul(s).minus(R(b.toString()).mul(p)).div(h.toString()),f=R(h.toString()).mul(y).div(a.toString()).toFixed(6,R.roundDown);return Number(f)}async getHealthFactorAfterSupply(t,e,r){let{totalCollateral:i,totalDebt:a,reserves:n,currentLiquidationThreshold:s}=await this.getSummary(t);if(a===0n)return Ae;let o=dt.fromAssetId(e),l=n.find(f=>f.reserveAsset===o);if(!l)throw new Error("Missing reserve ctx for "+o);let{decimals:c,priceInRef:u,reserveLiquidationThreshold:d}=l,g=at.toBigInt(r,c)*u/10n**BigInt(c),b=i+g;if(b<=0n)return 0;let h=R(i.toString()).mul(s).plus(R(g.toString()).mul(d)).div(b.toString()),y=R(b.toString()).mul(h).div(a.toString()).toFixed(6,R.roundDown);return Number(y)}async getHealthFactorAfterSwap(t,e,r,i,a){let{totalDebt:n,reserves:s,healthFactor:o}=await this.getSummary(t);if(n===0n)return Ae;let l=dt.fromAssetId(r),c=dt.fromAssetId(a),u=s.find(v=>v.reserveAsset===l),d=s.find(v=>v.reserveAsset===c);if(!u)throw new Error(`Missing reserve ctx for ${l}`);if(!d)throw new Error(`Missing reserve ctx for ${d}`);let p=at.toBigInt(e,u.decimals),g=at.toBigInt(i,d.decimals),b=p*u.priceInRef/10n**BigInt(u.decimals),h=g*d.priceInRef/10n**BigInt(d.decimals),y=u.isCollateral?R(b.toString()).mul(u.reserveLiquidationThreshold):R(0),P=(d.isCollateral?R(h.toString()).mul(d.reserveLiquidationThreshold):R(0)).minus(y).div(n.toString()),w=R(o).plus(P).toFixed(6,R.roundDown);return Number(w)}async getMaxWithdraw(t,e){let{totalDebt:r,reserves:i,healthFactor:a}=await this.getSummary(t),n=dt.fromAssetId(e),s=i.find(o=>o.reserveAsset===n);if(!s)throw new Error("Missing reserve ctx for "+n);return this.calculateWithdrawMax(s,r,a)}async getMaxWithdrawAll(t){let{totalDebt:e,reserves:r,healthFactor:i}=await this.getSummary(t),a={};for(let n of r){let s=this.calculateWithdrawMax(n,e,i);n.reserveId&&(a[n.reserveId]=s)}return a}calculateWithdrawMax(t,e,r){let{aTokenBalance:i,availableLiquidity:a,decimals:n,priceInRef:s,reserveLiquidationThreshold:o,isCollateral:l}=t,c=i;if(l&&e>0n){let d=r-Ha;if(d>0){let p=R(d).mul(e.toString()).div(o).toFixed(0,R.roundDown),g=R(p).div(s.toString()).mul(10**n).toFixed(0,R.roundDown);c=i<BigInt(g)?i:BigInt(g)}else c=0n}return{amount:c<a?c:a,decimals:n}}calculateLinearInterest(t,e,r){let i=r-e;if(i<=0)return Oe;let a=t*BigInt(i)/Na;return Oe+a}calculateHealthFactorFromBalances(t,e,r){if(t===0n)return Ae;let i=e*r/t,a=at.toDecimal(i,Yr);return Number(a)}};var Jr={};A(Jr,{AssetClient:()=>gt,BalanceClient:()=>X,ChainParams:()=>Pt});import{Binary as Be}from"polkadot-api";var gt=class extends E{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:r,value:i})=>{let[a]=r;return[a,i]}))}async queryBonds(){let e=await this.api.query.Bonds.Bonds.getEntries();return new Map(e.map(({keyArgs:r,value:i})=>{let[a]=r;return[a,i]}))}async queryAssets(){let e=await this.api.query.AssetRegistry.Assets.getEntries();return new Map(e.filter(({value:r})=>{let{asset_type:i}=r;return this.SUPPORTED_TYPES.includes(i.type)}).map(({keyArgs:r,value:i})=>{let[a]=r;return[a,i]}))}async queryAssetLocations(){let e=await this.api.query.AssetRegistry.AssetLocations.getEntries();return new Map(e.map(({keyArgs:r,value:i})=>{let[a]=r;return[a,i]}))}async mapToken(t,e,r,i){let{name:a,asset_type:n,is_sufficient:s,existential_deposit:o}=e,{symbol:l,decimals:c}=r.get(t)??{};return{id:t,name:a?Be.toText(a):void 0,symbol:l,decimals:c,icon:l,type:n.type,isSufficient:s,location:i,existentialDeposit:o}}async mapBond(t,e,r,i){let[a,n]=i,{asset_type:s,is_sufficient:o,existential_deposit:l}=e,{symbol:c,decimals:u}=await this.mapToken(a,e,r),d=Number(n),p=new Intl.DateTimeFormat("en-GB"),g=[c,"Bond",p.format(d)].join(" ");return{id:t,name:g,symbol:c+"b",decimals:u,icon:c,type:s.type,isSufficient:o,existentialDeposit:l,underlyingAssetId:a,maturity:d}}async mapShares(t,e,r,i){let{assets:a}=i,{name:n,symbol:s,asset_type:o,is_sufficient:l,existential_deposit:c}=e,u=await Promise.all(a.map(async g=>{let{symbol:b}=await this.mapToken(g,e,r);return[g,b]})),d=Object.fromEntries(u),p=Object.values(d);return{id:t,name:p.join(", "),symbol:s&&Be.toText(s)||n&&Be.toText(n),decimals:18,icon:p.join("/"),type:o.type,isSufficient:l,existentialDeposit:c,meta:d}}async mapExternal(t,e,r,i){let a=await this.mapToken(t,e,new Map,i),n=r?.find(s=>s.internalId===a.id);return n?{...a,decimals:n.decimals,name:n.name,symbol:n.symbol,icon:n.symbol,isWhiteListed:n.isWhiteListed}:a}parseMetadata(t){return new Map(Array.from(t,([e,r])=>[e,{symbol:r.symbol?Be.toText(r.symbol):void 0,decimals:r.decimals}]))}async getSupported(t,e){let[r,i,a,n]=await Promise.all([this.queryAssets(),this.queryAssetLocations(),this.queryShares(),this.queryBonds()]),s=this.parseMetadata(r),o=[];for(let[l,c]of Array.from(r)){let u=i.get(l),{asset_type:d}=c,p;switch(d.type){case"Bond":let g=n.get(l);p=await this.mapBond(l,c,s,g);break;case"StableSwap":let b=a.get(l);p=await this.mapShares(l,c,s,b);break;case"External":p=await this.mapExternal(l,c,e,u);break;default:p=await this.mapToken(l,c,s,u)}o.push(p)}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{log as Va}from"@galacticcouncil/common";import{combineLatest as Ya,concat as Wa,defer as Ut,from as zr}from"rxjs";import{bufferCount as Xr,distinctUntilChanged as Kr,debounceTime as $a,map as yt,retry as za,startWith as jr,switchMap as Qr,tap as Vt,take as Xa,skip as Ka,connect as ja}from"rxjs/operators";var $r={};A($r,{HUB_ASSET_ID:()=>ht,HYDRATION_OMNIPOOL_ADDRESS:()=>Ua,HYDRATION_PARACHAIN_ID:()=>Ga,PERBILL_DENOMINATOR:()=>or,PERMILL_DENOMINATOR:()=>et,SYSTEM_ASSET_DECIMALS:()=>_e,SYSTEM_ASSET_ID:()=>O,TRADEABLE_DEFAULT:()=>bt});var et=1e6,or=1e9,O=0,_e=12,Ga=2034,Ua="7L53bUTBbfuj14UpdCNPwmgzzHSsrsTWBHX5pys32mVWM3C1",ht=1,bt=15;var{logger:ft}=Va,X=class extends E{erc20Ids=null;constructor(t,e){super(t,e)}async getBalance(t,e){return e===0?this.getSystemBalance(t):this.getBalanceData(t,e)}async getSystemBalance(t){let e=this.api.query.System.Account,{data:r}=await e.getValue(t,{at:this.at});return this.getBreakdown(r)}async getTokenBalance(t,e){let i=await this.api.query.Tokens.Accounts.getValue(t,e,{at:this.at});return this.getBreakdown(i)}async getErc20Balance(t,e){return this.getBalanceData(t,e)}watchBalance(t){return Ut(()=>{let e=this.watchSystemBalance(t),r=this.watchTokensBalance(t),i=this.watchErc20Balance(t);return Ya([e,r,i]).pipe(ja(a=>Wa(a.pipe(Xa(1)),a.pipe(Ka(1),$a(250)))))}).pipe(yt(e=>e.flat()),jr([]),Xr(2,1),yt(([e,r],i)=>i===0?r:this.getDeltas(e,r))).pipe(Vt({subscribe:()=>ft.debug("balance: subscribe",t),error:e=>ft.error("balance",e)}),za({delay:1e3}))}watchSystemBalance(t){let e=this.api.query.System.Account;return Ut(()=>e.watchValue(t,{at:"best"})).pipe(yt(({value:r})=>({id:0,balance:this.getBreakdown(r.data)})),Vt({error:r=>ft.error("balance(system)",r)}))}watchTokenBalance(t,e){let r=this.api.query.Tokens.Accounts;return Ut(()=>r.watchValue(t,e,{at:"best"})).pipe(yt(({value:i})=>({id:e,balance:this.getBreakdown(i)})),Vt({error:i=>ft.error("balance(token)",i)}))}watchTokensBalance(t){let e=this.api.query.Tokens.Accounts;return Ut(()=>e.watchEntries(t,{at:"best"})).pipe(Kr((r,i)=>!i.deltas),yt(({deltas:r})=>{let i=[];return r?.deleted.forEach(a=>{let[n,s]=a.args;i.push({id:s,balance:this.getBreakdown({free:0n,reserved:0n,frozen:0n})})}),r?.upserted.forEach(a=>{let[n,s]=a.args;i.push({id:s,balance:this.getBreakdown(a.value)})}),i}),Vt({error:r=>ft.error("balance(tokens)",r)}))}watchErc20Balance(t,e){let r=async()=>{if(this.erc20Ids)return this.erc20Ids;let a=await this.api.query.AssetRegistry.Assets.getEntries({at:"best"});return this.erc20Ids=a.filter(({value:n})=>n.asset_type.type==="Erc20").map(({keyArgs:n})=>{let[s]=n;return s}),this.erc20Ids},i=async a=>(await Promise.all(a.map(async s=>[s,await this.getBalanceData(t,s)]))).map(([s,o])=>({id:s,balance:o}));return Ut(()=>zr(e?Promise.resolve(e):r()).pipe(Qr(a=>this.watcher.bestBlock$.pipe(Qr(()=>zr(i(a))))),jr([]),Xr(2,1),yt(([a,n],s)=>s===0?n.filter(o=>o.balance.total>0n):this.getDeltas(a,n)),Kr((a,n)=>n.length===0),Vt({error:a=>ft.error("balance(erc20)",a)})))}async getBalanceData(t,e){let r=await this.api.apis.CurrenciesApi.account(e,t,{at:this.at});return this.getBreakdown(r)}getBreakdown(t){let e=t.free>=t.frozen?t.free-t.frozen:0n,r=t.free+t.reserved;return{free:t.free,reserved:t.reserved,frozen:t.frozen,total:r,transferable:e}}getDeltas(t,e){let r=(a,n)=>a!==void 0&&n!==void 0&&a.transferable===n.transferable&&a.total===n.total,i=t.reduce((a,n)=>(a.set(n.id,n.balance),a),new Map);return e.filter(a=>!r(a.balance,i.get(a.id)))}};var Pt=class extends E{_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}};var Zr={};A(Zr,{AssetNotFound:()=>lr,PoolNotFound:()=>st,RouteNotFound:()=>Yt});var lr=class extends Error{constructor(t){super(),this.message=`${t} not found`,this.name="AssetNotFound"}},st=class extends Error{constructor(t){super(),this.message=`${t} pool invalid`,this.name="PoolNotFound"}},Yt=class extends Error{constructor(t,e){super(),this.message=`Route from ${t} to ${e} not found in current configuration`,this.name="RouteNotFound"}};var ii={};A(ii,{EvmClient:()=>$t,EvmRpcAdapter:()=>Wt,createChain:()=>cr});import{Binary as ti}from"polkadot-api";import{hydration as Qa}from"@galacticcouncil/descriptors";import{encodeFunctionData as Ja,decodeFunctionResult as Za}from"viem";var tn=10000000n,Wt=class{api;at;constructor(t,e="best"){this.api=t.getTypedApi(Qa),this.at=e}async getBlock(){let t=await this.api.query.Ethereum.CurrentBlock.getValue({at:this.at}),{header:e}=t,r=e.timestamp/1000n,[i]=e.number;return{timestamp:r,number:i}}readContract=(async t=>{let{abi:e,address:r,functionName:i,args:a}=t,n=Ja({abi:e,functionName:i,args:a}),s=await this.api.apis.EthereumRuntimeRPCApi.call("0x0000000000000000000000000000000000000000",r,ti.fromHex(n),[0n,0n,0n,0n],[tn,0n,0n,0n],void 0,void 0,void 0,!1,[],[],{at:this.at});if(!s.success)throw console.error(i,s.value.type),new Error("Contract read failure");let{exit_reason:o,value:l,used_gas:c}=s.value;if(o.type==="Succeed")return Za({abi:e,functionName:i,data:ti.toHex(l)});throw console.log(i,o.type,o.value.type),new Error("Contract read error")})};import{defineChain as en}from"viem";var rn=["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"],cr=()=>en({id:222222,name:"Hydration",network:"hydration",nativeCurrency:{decimals:18,name:"WETH",symbol:"WETH"},rpcUrls:{default:{http:rn}},blockExplorers:{default:{name:"Hydration Explorer",url:"https://hydration.subscan.io"}},testnet:!1});import{createPublicClient as ei,createWalletClient as an,custom as ri,http as nn}from"viem";var $t=class{client;at;chain;constructor(t,e="best"){this.client=t,this.at=e,this.chain=cr()}get chainId(){return this.chain.id}get chainCurrency(){return this.chain.nativeCurrency.symbol}get chainDecimals(){return this.chain.nativeCurrency.decimals}getProvider(){return ei({chain:this.chain,transport:nn()})}getWsProvider(){return ei({transport:ri({request:({method:t,params:e})=>this.client._request(t,e||[])})})}getSigner(t){return an({account:t,chain:this.chain,transport:ri(window.ethereum)})}getRPCAdapter(){return new Wt(this.client,this.at)}};var di={};A(di,{LiquidityMiningApi:()=>Xt,LiquidityMiningClient:()=>Kt});import{AccountId as Tn}from"polkadot-api";import q from"big.js";import{HYDRATION_SS58_PREFIX as In,RUNTIME_DECIMALS as wt}from"@galacticcouncil/common";import{fixed_from_rational as mi}from"@galacticcouncil/math-liquidity-mining";var Fe={};A(Fe,{withTimeout:()=>sn});function sn(m,t,e="timeout"){return new Promise((r,i)=>{let a=setTimeout(()=>i(new Error(e)),t);m.then(n=>{clearTimeout(a),r(n)},n=>{clearTimeout(a),i(n)})})}var B={};A(B,{divSpot:()=>ln,getFraction:()=>cn,mulScaled:()=>ni,mulSpot:()=>on});import{RUNTIME_DECIMALS as ai}from"@galacticcouncil/common";function ni(m,t,e,r,i){let a=e+r-i,n=m*t;return a>0?n/BigInt(10)**BigInt(a):a<0?n*BigInt(10)**BigInt(-a):n}function on(m,t,e,r){return ni(m,t,e,ai,r)}function ln(m,t,e,r){if(t===0n)return 0n;let i=BigInt(10)**BigInt(ai+r-e);return m*i/t}function cn(m,t,e=2){if(t<.01||t>100)throw new Error("Supported range is from 0.01% - 100%");let r=BigInt(10)**BigInt(e),i=BigInt(Math.round(t*Number(r)));return m*i/(BigInt(100)*r)}var x={};A(x,{FeeUtils:()=>ur,shiftNeg:()=>mn});import un from"big.js";var ur=class m{static toPct(t){let[e,r]=t;return m.safeDivide(e*100,r)}static toRaw(t){let[e,r]=t;return m.safeDivide(e,r)}static fromPermill(t){return[t,1e6]}static fromPerbill(t){return[t,1e9]}static fromRate(t,e){return[t,e]}static safeDivide(t,e,r=12){let i=10**r;return Math.round(t*i/e)/i}static safeRound(t){return parseFloat(t.toPrecision(15))}};function mn(m,t){let e=un(typeof m=="bigint"?m.toString():m);return t===0?e.toString():e.div(Math.pow(10,t)).toString()}var zt={};A(zt,{findNestedKey:()=>pn,findNestedObj:()=>dn,jsonFormatter:()=>gn});var pn=(m,t)=>{let e=[];return JSON.stringify(m,(r,i)=>(i&&i[t]&&e.push(i),i)),e[0]},dn=(m,t,e)=>{let r;return JSON.stringify(m,(i,a)=>(a&&a[t]===e&&(r=a),a)),r},gn=(m,t)=>typeof t=="bigint"?t.toString():t;var L={};A(L,{calculateBuyFee:()=>fn,calculateDiffToAvg:()=>hn,calculateDiffToRef:()=>bn,calculateSellFee:()=>yn});import Q from"big.js";function hn(m,t){let e=Q(m.toString()),r=Q(t.toString());return e.minus(r).abs().div(e.plus(r).div(2)).mul(100).round(2).toNumber()}function bn(m,t){if(t===0n)return 0;let e=Q(m.toString()),r=Q(t.toString());return e.minus(r).div(r).mul(100).round(2).toNumber()}function yn(m,t){if(m===0n)return 0;let e=Q(m.toString()),r=Q(t.toString());return Q(1).minus(r.div(e)).mul(100).round(2).toNumber()}function fn(m,t){if(m===0n)return 0;let e=Q(m.toString());return Q(t.toString()).div(e).minus(1).mul(100).round(2).toNumber()}import{TLRUCache as si}from"@thi.ng/cache";var St=class{debug;constructor(t){this.debug=t||!1}log(t,e,r){this.debug&&console.log(t,e,r)}scope(t,e,r,i){let a=new Map,n=i!==void 0?new si(null,{ttl:i}):new si;return{get:(...c)=>{let u=r(...c);if(a.has(u)){this.log("[live]",t,u);let p=a.get(u);return Promise.resolve(p)}if(n.has(u))return this.log("[memo]",t,u),n.get(u);this.log("[fetch]",t,u);let d=e(...c).catch(p=>{throw n.delete(u),p});return n.set(u,d),d},set:(c,...u)=>{let d=r(...u);this.log("[set-live]",t,d),a.set(d,c)},clear:()=>{this.log("[clear]",t),a.clear(),n.release()}}}};var Ee=class{result=new Map;getKey(t,e){return[e,t.toString()].join(",")}constructor(t,e){for(let r=0;r<t.length;++r){let[i,a]=t[r];this.result.set(this.getKey(a,i),e[r].free)}}freeBalance(t,e){return this.result.get(this.getKey(t,e))??0n}transfer(t,e,r,i){let a=this.getKey(t,e),n=this.getKey(t,r),s=this.result.get(a)??0n,o=this.result.get(n)??0n;if(s<i)throw new Error("Attempting to transfer more than is present");this.result.set(a,s+i),this.result.set(n,o+i)}};import ot from"big.js";import{calculate_accumulated_rps as Pn,calculate_global_farm_rewards as Sn,calculate_loyalty_multiplier as wn,calculate_user_reward as ui,calculate_yield_farm_delta_rpvs as xn}from"@galacticcouncil/math-liquidity-mining";import oi from"big.js";var mr=oi(10).pow(18),li=BigInt(oi(1).pow(18).toString()),ci=6e3;var vn="1000000000000000000",Re=class{constructor(t,e,r){this.getAccount=t;this.getAsset=e;this.multiCurrency=r}async syncGlobalFarm(t,e,r){if(t.state.type!=="Active"||t.updated_at===e)return null;if(t.total_shares_z===0n)return t;let i=await this.getAsset(t.reward_currency),a=e-t.updated_at,n=this.getAccount(t.id),s=i?.existential_deposit;if(!s)throw new Error("Missing reward currency asset list");let o=this.multiCurrency.freeBalance(t.reward_currency,n),l=ot(s.toString()),c=ot(o.toString()).minus(l.lt(o.toString())?s.toString():o.toString()),u=ot(Sn(t.total_shares_z.toString(),r.toString(),ot(t.yield_per_period.toString()).mul(mr).round(0,ot.roundDown).toFixed(),t.max_reward_per_period.toString(),a.toFixed()));if(c.lt(u)&&(u=c),u.eq(0))return t;let d=this.getAccount(0);return this.multiCurrency.transfer(t.reward_currency,n,d,BigInt(u.toFixed())),{...t,accumulated_rpz:BigInt(Pn(t.accumulated_rpz.toString(),t.total_shares_z.toString(),u.toFixed()))}}syncYieldFarm(t,e,r){if(t.state.type!=="Active"||t.updated_at===r)return t;if(t.total_valued_shares===0n)return{...t,updated_at:r};let i=xn(t.accumulated_rpz.toString(),e.accumulated_rpz.toString(),t.multiplier.toString(),t.total_valued_shares.toString());return{...t,accumulated_rpvs:t.accumulated_rpvs+BigInt(i),updated_at:r}}getLoyaltyMultiplier(t,e){let r=ot(1).mul(mr).round(0,ot.roundDown).toString();if(!e)return r;let{initial_reward_percentage:i,scale_coef:a}=e;return wn(t.toFixed(),i.toString(),a.toFixed())}async claimRewards(t,e,r,i,a){if(e.state.type==="Terminated")return null;let n=Math.floor(i/t.blocks_per_period);if(r.updated_at===n)return null;let s=await this.syncGlobalFarm(t,n,a);if(!s)return null;let o=this.syncYieldFarm(e,s,n);if(!o)return null;let l=o.total_stopped-r.stopped_at_creation,c=o.updated_at-r.entered_at-l,u=this.getLoyaltyMultiplier(c,o.loyalty_curve),d=BigInt(ui(r.accumulated_rpvs.toString(),r.valued_shares.toString(),r.accumulated_claimed_rewards.toString(),o.accumulated_rpvs.toString(),u)),p=BigInt(ui(r.accumulated_rpvs.toString(),r.valued_shares.toString(),r.accumulated_claimed_rewards.toString(),o.accumulated_rpvs.toString(),vn));return{reward:d,maxReward:p,assetId:s.reward_currency,yieldFarmId:o.id,isActiveFarm:o.state.type==="Active"}}};var An=q(365.2425).times(24).times(60).times(60),Xt=class{balance;client;options;constructor(t,e,r={}){this.client=t,this.balance=e,this.options=Object.freeze({blockTime:r.blockTime??ci})}get blockTime(){return this.options.blockTime}async getOraclePrice(t,e){let r=[t,e].sort((a,n)=>a-n);if(t===e)return li;let i=await this.client.getOraclePrice(r);if(i){let{n:a,d:n}=i[0].price,s;return t<e?s=mi(a.toString(),n.toString()):s=mi(n.toString(),a.toString()),BigInt(s)}}getFarmAddress=(t,e)=>{let r=Buffer.from("modl","utf-8"),i=Buffer.from(e?"78796b4c4d704944":"4f6d6e6957684c4d","hex"),a=Buffer.from([t]),n=Buffer.concat([r,i,a]),o="0x"+Buffer.concat([n,Buffer.alloc(32-n.length)]).toString("hex");return Tn(In).dec(o)};getGlobalRewardPerPeriod(t,e,r,i){let a=q(i).times(t.toString()).times(e.toString()).div(Math.pow(10,wt));return a.gte(r.toString())?r.toString():a.toString()}getPoolYieldPerPeriod(t,e,r,i){let a=q(t.toString()).times(e),n=q(r.toString()).times(i);return a.div(n.toString()).toString()}farmData(t,e,r){let{yieldFarm:i,globalFarm:a,priceAdjustment:n,balance:s,id:o}=t,{multiplier:l,loyalty_curve:c}=i,{blocks_per_period:u,yield_per_period:d,total_shares_z:p,max_reward_per_period:g,pending_rewards:b,accumulated_paid_rewards:h,planned_yielding_periods:y,updated_at:f,incentivized_asset:S,reward_currency:P,price_adjustment:w,min_deposit:v}=a,_=x.shiftNeg(n??w,wt),H=x.shiftNeg(l,wt),M=x.shiftNeg(c?.initial_reward_percentage??0,wt),j=An.div(q(this.blockTime).div(1e3).times(u)).toString(),G;if(p<=0)G=q(H).times(d.toString()).times(j).div(Math.pow(10,wt)).toString();else{let ca=this.getGlobalRewardPerPeriod(p,d,g,_),ua=this.getPoolYieldPerPeriod(ca,H,p,_);G=q(ua).times(j).toString()}let $=b+h,tt=g*BigInt(y),Pe=s.transferable+$,Hr=Pe-$,Se=q(Hr.toString()).div(g.toString()),we=q(e).div(u.toString()).toString(),xe=(p>=0?Se.plus(f):Se.plus(we)).toString(),er=q(xe).times(u).toString(),oa=q(p.toString()).div(q(g.toString()).div(d.toString())).div(Math.pow(10,wt)).times(100).times(_).toFixed(2),Nr=q($.toString()).div(Pe.toString()).gte(.999);G=Nr?"0":q(G).div(r?2:1).times(100).toString();let la=M?q(G).times(M).toString():void 0;return{apr:G,minApr:la,isDistributed:Nr,estimatedEndPeriod:xe,estimatedEndBlock:er,maxRewards:tt,incentivizedAsset:S,rewardCurrency:P,loyaltyCurve:c,currentPeriod:we,potMaxRewards:Pe,fullness:oa,yieldFarmId:i.id,globalFarmId:a.id,poolId:o,distributedRewards:$,plannedYieldingPeriods:y,minDeposit:v,blocksPerPeriod:u}}async getAllOmnipoolFarms(){let e=(await this.client.getAllOmnipooFarms()).reduce((i,a)=>i.includes(a.keyArgs[0].toString())?i:[...i,a.keyArgs[0].toString()],[]),r=await Promise.all(e.map(async i=>{let a=await this.getOmnipoolFarms(i);if(a)return[i,a]}));return Object.fromEntries(r.filter(i=>!!i))}async getOmnipoolFarms(t){let e=await this.client.getOmnipooFarms(Number(t)),r=await this.client.getRelayBlockNumber(),i=await Promise.all(e.map(async({keyArgs:a,value:n})=>{let[,s]=a,o=n,l=await this.client.getOmnipoolGlobalFarm(s),c=await this.client.getOmnipoolYieldFarm(Number(t),s,o);if(!l||!c)return;let u=l.reward_currency,d=l.incentivized_asset,p=this.getFarmAddress(s),g=await this.getOraclePrice(u,d),b=await this.balance.getBalance(p,u);return{id:t,globalFarm:l,yieldFarm:c,priceAdjustment:g,balance:b}}));return r?i.map(a=>a?this.farmData(a,r):void 0):[]}async getAllIsolatedFarms(){let e=(await this.client.getAllIsolatedFarms()).reduce((i,a)=>i.includes(a.keyArgs[0].toString())?i:[...i,a.keyArgs[0].toString()],[]),r=await Promise.all(e.map(async i=>{let a=await this.getIsolatedFarms(i);if(a)return[i,a]}));return Object.fromEntries(r.filter(i=>!!i))}async getIsolatedFarms(t){let e=await this.client.getIsolatedFarms(t),r=await this.client.getRelayBlockNumber(),i=await Promise.all(e.map(async({keyArgs:a,value:n})=>{let[,s]=a,o=n,l=await this.client.getIsolatedGlobalFarm(s),c=await this.client.getIsolatedYieldFarm(t,s,o);if(!l||!c)return;let u=l.reward_currency,d=l.incentivized_asset,p=this.getFarmAddress(s,!0),g=await this.getOraclePrice(u,d),b=await this.balance.getBalance(p,u);return{id:t,globalFarm:l,yieldFarm:c,priceAdjustment:g,balance:b,farmAddress:p}}));return r?i.map(a=>a?this.farmData(a,r,!0):void 0):[]}async getDepositReward(t,e,r,i){let a=e.global_farm_id,n=e.yield_farm_id,s=r?await this.client.getIsolatedYieldFarm(t,a,n):await this.client.getOmnipoolYieldFarm(Number(t),a,n),o=r?await this.client.getIsolatedGlobalFarm(a):await this.client.getOmnipoolGlobalFarm(a);if(!o||!s)return;let l=o.reward_currency,c=o.incentivized_asset,u=[[this.getFarmAddress(0,r),o.reward_currency],[this.getFarmAddress(o.id,r),o.reward_currency]],d=await this.getAccountAssetBalances(u),p=await this.getOraclePrice(l,c),g=new Ee(u,d),h=await new Re(f=>this.getFarmAddress(f),f=>this.client.getAsset(f),g).claimRewards(o,s,e,i,p??o.price_adjustment);if(!h)return;let y=await this.client.getAsset(h.assetId);if(y&&!(h.reward<=y.existential_deposit))return h}async getAccountAssetBalances(t){let[e,r]=await Promise.all([Promise.all(t.filter(([a,n])=>n!==0).map(([a,n])=>this.balance.getTokenBalance(a,n))),Promise.all(t.filter(([a,n])=>n===0).map(([a])=>this.balance.getSystemBalance(a)))]),i=[];for(let a=0,n=0;a+n<t.length;){let s=a+n,[,o]=t[s];o===0?(i.push(r[n]),n+=1):(i.push(e[a]),a+=1)}return i}};import{Binary as pi,Enum as On}from"polkadot-api";var Bn=pi.toHex(pi.fromText("omnipool")),Kt=class extends E{omnipoolAssetIds=[];async getOraclePrice(t){return await this.api.query.EmaOracle.Oracles.getValue(Bn,t,On("TenMinutes"))}async getRelayBlockNumber(){return(await this.api.query.ParachainSystem.ValidationData.getValue())?.relay_parent_number}async getAllOmnipooFarms(){return this.api.query.OmnipoolWarehouseLM.ActiveYieldFarm.getEntries()}async getOmnipooFarms(t){return this.api.query.OmnipoolWarehouseLM.ActiveYieldFarm.getEntries(t)}async getOmnipoolGlobalFarm(t){return this.api.query.OmnipoolWarehouseLM.GlobalFarm.getValue(t,{at:"best"})}async getOmnipoolYieldFarm(t,e,r){return this.api.query.OmnipoolWarehouseLM.YieldFarm.getValue(t,e,r,{at:"best"})}async getAllIsolatedFarms(){return this.api.query.XYKWarehouseLM.ActiveYieldFarm.getEntries()}async getIsolatedFarms(t){return this.api.query.XYKWarehouseLM.ActiveYieldFarm.getEntries(t)}async getIsolatedGlobalFarm(t){return this.api.query.XYKWarehouseLM.GlobalFarm.getValue(t,{at:"best"})}async getIsolatedYieldFarm(t,e,r){return this.api.query.XYKWarehouseLM.YieldFarm.getValue(t,e,r,{at:"best"})}async getAsset(t){return this.api.query.AssetRegistry.Assets.getValue(t)}};var hi={};A(hi,{BlockFetcher:()=>xt,IndexerStats:()=>lt,RpcPool:()=>Ce,SYSTEM_EVENTS_KEY:()=>pr,Semaphore:()=>vt,decodeCompactLength:()=>ke,indexBlocks:()=>gi});function ke(m){let t=m.startsWith("0x")?m.slice(2):m;if(t.length<2)return 0;let e=parseInt(t.slice(0,2),16);switch(e&3){case 0:return e>>2;case 1:{if(t.length<4)return 0;let i=e;return(parseInt(t.slice(2,4),16)<<8|i)>>2}case 2:{if(t.length<8)return 0;let i=e,a=parseInt(t.slice(2,4),16),n=parseInt(t.slice(4,6),16);return(parseInt(t.slice(6,8),16)<<24|n<<16|a<<8|i)>>>2}default:return 0}}var pr="0x26aa394eea5630e07c48ae0c9558cef780d41e5e16056765bc8461851072c9d7";var xt=class m{constructor(t){this.select=t}static withClient(t){return new m(()=>t)}async getHash(t){let r=await this.select()._request("chain_getBlockHash",[t]);return r&&r.length===66?r:null}async getBlock(t,e={}){let r=await this.getHash(t);return r?this.getBlockAt(t,r,e):null}async getBlockAt(t,e,r={}){let i=this.select(),[a,n]=await Promise.all([r.withBlock?i._request("chain_getBlock",[e]):Promise.resolve(null),r.withEvents?i._request("state_getStorage",[pr,e]):Promise.resolve(null)]),s=a?.block?.extrinsics??[],o=a?.block?.header,l=a?JSON.stringify(a).length:0,c=n?n.length/2:0;return{number:t,hash:e,header:o,extrinsics:s,eventsHex:n??void 0,eventsCount:n?ke(n):0,bytes:l+c}}};var lt=class{blocks=0;events=0;extrinsics=0;bytes=0;errors=0;startedAt=0;batchTimes=[];start(){this.startedAt=performance.now()}recordBlock(t={}){this.blocks++,t.events&&(this.events+=t.events),t.extrinsics&&(this.extrinsics+=t.extrinsics),t.bytes&&(this.bytes+=t.bytes)}recordBatch(t){this.batchTimes.push(t)}recordError(){this.errors++}elapsedMs(){return this.startedAt===0?0:performance.now()-this.startedAt}percentile(t){if(this.batchTimes.length===0)return 0;let e=[...this.batchTimes].sort((i,a)=>i-a),r=Math.floor(t/100*e.length);return e[Math.min(r,e.length-1)]}snapshot(){let t=this.elapsedMs(),e=t/1e3;return{blocks:this.blocks,events:this.events,extrinsics:this.extrinsics,bytes:this.bytes,errors:this.errors,elapsedMs:t,blocksPerSec:e>0?this.blocks/e:0,eventsPerSec:e>0?this.events/e:0,batchP50Ms:this.percentile(50),batchP95Ms:this.percentile(95),batchP99Ms:this.percentile(99)}}};import{createClient as _n}from"polkadot-api";var Ce=class m{clients=[];owned;idx=0;constructor(t,e){if(t.length===0)throw new Error("RpcPool requires at least one client");this.clients=t,this.owned=e}static fromEndpoints(t){let r=(typeof t=="string"?t.split(","):t).map(i=>_n(ir(i)));return new m(r,!0)}static fromClients(t){return new m(t,!1)}size(){return this.clients.length}next(){let t=this.clients[this.idx%this.clients.length];return this.idx++,t}destroy(){if(this.owned)for(let t of this.clients)t.destroy()}};var vt=class{constructor(t){this.max=t;if(t<1)throw new Error("Semaphore max must be >= 1")}queue=[];running=0;async acquire(){if(this.running<this.max){this.running++;return}return new Promise(t=>{this.queue.push(()=>{this.running++,t()})})}release(){this.running--;let t=this.queue.shift();t&&t()}async run(t){await this.acquire();try{return await t()}finally{this.release()}}};async function gi(m){let{pool:t,fromBlock:e,blockCount:r,concurrency:i=100,batchSize:a=50,withBlock:n=!1,withEvents:s=!1,onBlock:o,onError:l}=m;if(r<=0){let g=m.stats??new lt;return g.start(),{stats:g}}let c=m.stats??new lt,u=new vt(i),d=new xt(()=>t.next()),p=[];for(let g=0;g<r;g+=a){let b=[];for(let h=0;h<a&&g+h<r;h++)b.push(e+g+h);p.push(b)}return c.start(),await Promise.all(p.map(g=>u.run(async()=>{let b=performance.now();await Promise.all(g.map(async h=>{let y=null;try{y=await d.getBlock(h,{withBlock:n,withEvents:s})}catch(f){c.recordError(),l?.(f,h);return}if(!y){c.recordError();return}if(c.recordBlock({events:y.eventsCount,extrinsics:y.extrinsics.length,bytes:y.bytes}),o)try{await o(y)}catch(f){c.recordError(),l?.(f,h)}})),c.recordBatch(performance.now()-b)}))),{stats:c}}var Ui={};A(Ui,{PoolContextProvider:()=>kt,PoolError:()=>rt,PoolFactory:()=>Rt,PoolType:()=>T,SnapshotPoolCtxProvider:()=>We,aave:()=>Or,hsm:()=>Er,lbp:()=>yr,omni:()=>wr,stable:()=>Tr,xyk:()=>Ir});var yr={};A(yr,{LbpMath:()=>z,LbpPool:()=>jt,LbpPoolClient:()=>Zt});import{calculate_in_given_out as Fn,calculate_out_given_in as En,calculate_linear_weights as Rn,calculate_pool_trade_fee as kn,get_spot_price as Cn}from"@galacticcouncil/math-lbp";var z=class{static getSpotPrice(t,e,r,i,a){return Cn(t,e,r,i,a)}static calculateInGivenOut(t,e,r,i,a){return Fn(t,e,r,i,a)}static calculateOutGivenIn(t,e,r,i,a){return En(t,e,r,i,a)}static calculateLinearWeights(t,e,r,i,a){return Rn(t,e,r,i,a)}static calculatePoolTradeFee(t,e,r){return kn(t,e,r)}};import{big as bi,RUNTIME_DECIMALS as yi}from"@galacticcouncil/common";var T=(n=>(n.Aave="Aave",n.LBP="LBP",n.Omni="Omnipool",n.Stable="Stableswap",n.XYK="XYK",n.HSM="HSM",n))(T||{}),rt=(c=>(c.UnknownError="UnknownError",c.FacilitatorCapacityExceeded="FacilitatorCapacityExceeded",c.InsufficientTradingAmount="InsufficientTradingAmount",c.InsufficientCollateral="InsufficientCollateral",c.MaxHoldingExceeded="MaxHoldingExceeded",c.MaxInRatioExceeded="MaxInRatioExceeded",c.MaxOutRatioExceeded="MaxOutRatioExceeded",c.TradeNotAllowed="TradeNotAllowed",c.MaxBuyBackExceeded="MaxBuyBackExceeded",c.MaxBuyPriceExceeded="MaxBuyPriceExceeded",c))(rt||{});var{FeeUtils:fi}=x,jt=class m{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;fee;repayFeeApply;static fromPool(t){return new m(t)}constructor(t){this.type="LBP",this.address=t.address,this.tokens=t.tokens,this.maxInRatio=t.maxInRatio,this.maxOutRatio=t.maxOutRatio,this.minTradingLimit=t.minTradingLimit,this.fee=t.fee,this.repayFeeApply=t.repayFeeApply}validatePair(t,e){return!0}parsePair(t,e){let r=new Map(this.tokens.map(n=>[n.id,n])),i=r.get(t),a=r.get(e);if(i==null)throw new Error("Pool does not contain tokenIn");if(a==null)throw new Error("Pool does not contain tokenOut");return{assetIn:t,assetOut:e,balanceIn:i.balance,balanceOut:a.balance,decimalsIn:i.decimals,decimalsOut:a.decimals,weightIn:i.weight,weightOut:a.weight}}validateAndBuy(t,e,r){let i=this.tokens[0].id,a=[];e<this.minTradingLimit&&a.push("InsufficientTradingAmount");let n=t.balanceOut/this.maxOutRatio;if(e>n&&a.push("MaxOutRatioExceeded"),i===t.assetOut){let s=this.calculateTradeFee(e,r),o=fi.toPct(this.repayFeeApply?r.repayFee:r.exchangeFee),l=e+s,c=this.calculateInGivenOut(t,l),u=t.balanceIn/this.maxInRatio;return c>u&&a.push("MaxInRatioExceeded"),{amountIn:c,calculatedIn:c,amountOut:e,feePct:o,errors:a}}else{let s=this.calculateInGivenOut(t,e),o=t.balanceIn/this.maxInRatio;return s>o&&a.push("MaxInRatioExceeded"),{amountIn:s,calculatedIn:s,amountOut:e,feePct:0,errors:a}}}validateAndSell(t,e,r){let i=this.tokens[0].id,a=[];e<this.minTradingLimit&&a.push("InsufficientTradingAmount");let n=t.balanceIn/this.maxInRatio;if(e>n&&a.push("MaxInRatioExceeded"),i===t.assetIn){let s=this.calculateOutGivenIn(t,e),o=t.balanceOut/this.maxOutRatio;return s>o&&a.push("MaxOutRatioExceeded"),{amountIn:e,calculatedOut:s,amountOut:s,feePct:0,errors:a}}else{let s=this.calculateOutGivenIn(t,e),o=this.calculateTradeFee(s,r),l=fi.toPct(this.repayFeeApply?r.repayFee:r.exchangeFee),c=s-o,u=t.balanceOut/this.maxOutRatio;return c>u&&a.push("MaxOutRatioExceeded"),{amountIn:e,calculatedOut:s,amountOut:c,feePct:l,errors:a}}}calculateInGivenOut(t,e){let r=z.calculateInGivenOut(t.balanceIn.toString(),t.balanceOut.toString(),t.weightIn.toString(),t.weightOut.toString(),e.toString()),i=BigInt(r);return i<0n?0n:i}calculateOutGivenIn(t,e){let r=z.calculateOutGivenIn(t.balanceIn.toString(),t.balanceOut.toString(),t.weightIn.toString(),t.weightOut.toString(),e.toString()),i=BigInt(r);return i<0n?0n:i}spotPriceInGivenOut(t){let e=z.getSpotPrice(t.balanceOut.toString(),t.balanceIn.toString(),t.weightOut.toString(),t.weightIn.toString(),bi.toBigInt(1,yi).toString());return BigInt(e)}spotPriceOutGivenIn(t){let e=z.getSpotPrice(t.balanceIn.toString(),t.balanceOut.toString(),t.weightIn.toString(),t.weightOut.toString(),bi.toBigInt(1,yi).toString());return BigInt(e)}calculateTradeFee(t,e){let r=z.calculatePoolTradeFee(t.toString(),this.repayFeeApply?e.repayFee[0]:e.exchangeFee[0],this.repayFeeApply?e.repayFee[1]:e.exchangeFee[1]);return BigInt(r)}};import{CompatibilityLevel as Zn}from"polkadot-api";import{Subscription as ts,distinctUntilChanged as es,filter as rs,map as is}from"rxjs";import{memoize1 as qn}from"@thi.ng/memoize";import{TLRUCache as Hn}from"@thi.ng/cache";import{ReplaySubject as Pi,Subscription as Si,combineLatest as Nn,defer as Gn,from as Un,interval as Vn,merge as dr,of as Yn,EMPTY as Qt}from"rxjs";import{bufferCount as Wn,bufferTime as $n,catchError as Jt,filter as qe,finalize as gr,map as Tt,pairwise as hr,repeat as br,skip as zn,share as Xn,startWith as Kn,switchMap as wi,tap as ct,throttleTime as jn}from"rxjs/operators";import{BehaviorSubject as Mn}from"rxjs";var Me=class{store$=new Mn([]);updateQueue=Promise.resolve();changeset=new Set;get pools(){return this.store$.value}asObservable(){return this.store$.asObservable()}applyChangeset(t){return this.changeset.size===0?[]:t.filter(e=>this.changeset.has(e.address))}set(t){this.changeset=new Set(t.map(e=>e.address)),this.store$.next(t)}update(t){this.updateQueue=this.updateQueue.then(async()=>{let e=this.store$.value,r=new Map(e.map((s,o)=>[s.address,o])),i=await t(e),a=e.slice(),n=new Set;for(let s of i){let o=r.get(s.address);o===void 0?(r.set(s.address,a.length),a.push(s)):a[o]=s,n.add(s.address)}this.changeset=n,this.store$.next(a)}).catch(console.error)}destroy(){this.store$.complete()}};import{log as Dn}from"@galacticcouncil/common";var Ln={Aave:"AAVE",LBP:"LBP",Omnipool:"OMNI",Stableswap:"STBL",XYK:"XYK",HSM:"HSM"},{logger:De}=Dn,Le=class{type;constructor(t){this.type=t}prefix(){return this.pad(`pool(${Ln[this.type]})`,10)}trace(t,...e){De.trace(`${this.prefix()} ${t} :`,...e)}debug(t,...e){De.debug(`${this.prefix()} ${t} :`,...e)}info(t,...e){De.info(`${this.prefix()} ${t} :`,...e)}error(t,...e){De.error(`${this.prefix()} ${t} :`,...e)}pad(t,e){return t.length>=e?t:t+" ".repeat(e-t.length)}};var{withTimeout:Qn}=Fe,Jn=3e3,N=class extends E{evm;balance;store=new Me;log;shared$;resync$=new Pi(1);resyncAt=0;resyncPending=!1;mem=0;memPoolsCache=new Hn(null,{ttl:6*1e3});memPools=qn(t=>(this.log.info("pool_sync",{mem:t}),this.loadPools()),this.memPoolsCache);constructor(t,e,r){super(t,r),this.evm=e,this.balance=new X(t,r),this.log=new Le(this.getPoolType())}async getMemPools(){return this.memPools(this.mem)}async getPools(){let e=(await this.getMemPools()).filter(r=>this.hasValidAssets(r));return this.store.set(e),e}getSubscriber(){return this.shared$||(this.shared$=this.subscribeStore()),this.shared$.pipe(Kn([]),Wn(2,1),Tt(([t,e])=>t.length===0?e:this.store.applyChangeset(e)),qe(t=>t.length>0),jn(1e3,void 0,{leading:!0,trailing:!0}))}subscribeStore(){return Gn(()=>{let t=new Si;return t.add(this.startWatchdog()),this.resync$.next(),this.resync$.pipe(wi(()=>{let e=new Si;return Un(Qn(this.getMemPools(),6e4,"getMemPools stalled")).pipe(ct(()=>this.log.info("pool_synced",{mem:this.mem})),Tt(i=>i.filter(a=>this.hasValidAssets(a))),ct(i=>this.store.set(i)),Jt(()=>(this.log.error("pool_seed_error",{mem:this.mem}),this.requestResync(),Qt))).pipe(ct(()=>{e.add(this.subscribeBalances()),e.add(this.subscribeUpdates())}),wi(i=>dr(Yn(i),this.store.asObservable().pipe(zn(1)))),gr(()=>{e.unsubscribe()}))}),gr(()=>t.unsubscribe()))}).pipe(Xn({connector:()=>new Pi(1),resetOnRefCountZero:!0}))}subscribeBalances(){let t=this.store.pools.map(e=>{let{address:r}=e,i=[this.balance.watchTokensBalance(r)];if(this.hasSystemAsset(e)){let a=this.balance.watchSystemBalance(r);i.push(a)}if(this.hasErc20Asset(e)){let a=e.tokens.filter(s=>s.type==="Erc20").map(s=>s.id),n=this.balance.watchErc20Balance(r,a);i.push(n)}return Nn(i).pipe(Tt(a=>a.flat()),hr(),Tt(([a,n])=>this.balance.getDeltas(a,n)),qe(a=>a.length>0),Tt(a=>[r,a]))});return dr(...t).pipe($n(250),qe(e=>e.length>0),Tt(e=>new Map(e)),this.watchGuard("balances")).subscribe(e=>{this.store.update(r=>this.updateBalances(r,e))})}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(({decimals:e,balance:r})=>t.type==="XYK"?r>0n&&!!e:!!e)}updateBalances=(t,e)=>{let r=[],i=new Map(t.map(a=>[a.address,a]));for(let[a,n]of e){let s=i.get(a);if(s){let o=s.tokens.map(l=>{let c=n.find(u=>u.id===l.id);return c&&l.id!==s.id?{...l,balance:c.balance.transferable}:l});r.push({...s,tokens:o})}}return r};resync(t=!1){let e=Date.now();!t&&e-this.resyncAt<Jn||(this.resyncAt=e,this.mem++,this.resync$.next())}requestResync(t=!1){this.resyncPending||(this.resyncPending=!0,setTimeout(()=>{this.resyncPending=!1,this.resync(t)},0))}startWatchdog(){let i=this.watcher.connection$.pipe(hr(),qe(([s,o])=>s==="offline"&&o==="online"),ct(()=>{this.log.debug("watchdog_recover_online",{mem:this.mem}),this.requestResync()}),Jt(s=>(this.log.error("watchdog_recovery_error",s),Qt)),br({delay:1e3})),a=this.watcher.finalizedBlock$.pipe(hr(),ct(([s,o])=>{let l=Number(s.number),c=Number(o.number),u=c-l;u>=3&&(this.log.debug("watchdog_gap",{from:l,to:c,gap:u}),this.requestResync())}),Jt(s=>(this.log.error("watchdog_gap_error",s),Qt)),br({delay:1e3})),n=Vn(36e5).pipe(ct(()=>{this.log.debug("watchdog_periodic",{mem:this.mem}),this.requestResync()}),Jt(s=>(this.log.error("watchdog_periodic_error",s),Qt)),br({delay:1e3}));return dr(i,a,n).subscribe()}watchGuard(t){return e=>e.pipe(ct({error:r=>{this.log.error(t,r),this.requestResync(!0)}}),gr(()=>{this.log.debug(t,"unsub")}),Jt(()=>Qt))}};var Zt=class extends N{MAX_FINAL_WEIGHT=100000000n;poolsData=new Map([]);getPoolType(){return"LBP"}async getPoolLimits(){let[t,e,r]=await Promise.all([this.api.constants.LBP.MaxInRatio(),this.api.constants.LBP.MaxOutRatio(),this.api.constants.LBP.MinTradingLimit()]);return{maxInRatio:t,maxOutRatio:e,minTradingLimit:r}}getPoolWeights(t,e){let{start:r,end:i,initial_weight:a,final_weight:n}=t,s=z.calculateLinearWeights(r?r.toString():"0",i?i.toString():"0",a.toString(),n.toString(),e.toString()),o=BigInt(s),l=this.MAX_FINAL_WEIGHT-BigInt(o);return[o,l]}async isSupported(){return(await this.api.getStaticApis()).compat.query.LBP.PoolData.isCompatible(Zn.BackwardsCompatible)}async loadPools(){let[t,e,r]=await Promise.all([this.api.query.LBP.PoolData.getEntries({at:this.at}),this.api.query.ParachainSystem.ValidationData.getValue({at:this.at}),this.getPoolLimits()]),i=e?.relay_parent_number||0,a=t.filter(({value:n})=>e&&this.isActivePool(n,i)).map(async({keyArgs:n,value:s})=>{let[o]=n,l=o.toString(),c=await this.getPoolDelta(l,s,i);return{address:l,type:"LBP",fee:s.fee,...c,...r}});return Promise.all(a)}async getPoolDelta(t,e,r){let{assets:i,repay_target:a,fee_collector:n}=e,[s,o]=this.getPoolWeights(e,r),[l,c]=i,[u,d,p,g,b]=await Promise.all([this.isRepayFeeApplied(l,a,n.toString()),this.balance.getBalance(t,l),this.api.query.AssetRegistry.Assets.getValue(l,{at:this.at}),this.balance.getBalance(t,c),this.api.query.AssetRegistry.Assets.getValue(c,{at:this.at})]);return{repayFeeApply:u,tokens:[{id:l,decimals:p?.decimals,existentialDeposit:p?.existential_deposit,balance:d.transferable,weight:s,type:p?.asset_type.type},{id:c,decimals:b?.decimals,existentialDeposit:b?.existential_deposit,balance:g.transferable,weight:o,type:b?.asset_type.type}]}}isActivePool(t,e){let{start:r,end:i}=t;return r&&i?e>=r&&e<i:!1}async isRepayFeeApplied(t,e,r){if(e===0n)return!1;try{return(await this.balance.getBalance(r,t)).transferable<e}catch{return!0}}async getRepayFee(){return await this.api.constants.LBP.repay_fee()}async getPoolFees(t,e){let r=this.store.pools.find(a=>a.address===e);return{repayFee:await this.getRepayFee(),exchangeFee:r.fee}}subscribeValidationData(){return this.api.query.ParachainSystem.ValidationData.watchValue({at:"best"}).pipe(is(({value:t})=>t),rs(t=>t!==void 0),es((t,e)=>t.relay_parent_number===e.relay_parent_number),this.watchGuard("parachainSystem.ValidationData")).subscribe(({relay_parent_number:t})=>{this.store.update(async e=>{let r=[];for(let i of e){let a=this.poolsData.get(i.address);if(a){let{assets:n,repay_target:s,fee_collector:o}=a,[l]=n,[c,u]=this.getPoolWeights(a,t),[d,p]=i.tokens,g=[{...d,weight:c},{...p,weight:u}],b=await this.isRepayFeeApplied(l,s,o.toString());r.push({...i,tokens:g,repayFeeApply:b})}}return r})})}subscribeUpdates(){let t=new ts;return t.add(this.subscribeValidationData()),t}};var wr={};A(wr,{OmniMath:()=>I,OmniPool:()=>te,OmniPoolClient:()=>ee,OmniPoolFee:()=>ut,getEmaKey:()=>He,getEmaPair:()=>At});import{calculate_in_given_out as as,calculate_lrna_in_given_out as ns,calculate_out_given_in as ss,calculate_out_given_lrna_in as os,calculate_spot_price as ls,calculate_lrna_spot_price as cs,calculate_shares as us,calculate_liquidity_out as ms,calculate_liquidity_lrna_out as ps,verify_asset_cap as ds,calculate_liquidity_hub_in as gs,is_sell_allowed as hs,is_buy_allowed as bs,is_add_liquidity_allowed as ys,is_remove_liquidity_allowed as fs,recalculate_asset_fee as Ps,recalculate_protocol_fee as Ss}from"@galacticcouncil/math-omnipool";import It from"big.js";var I=class{static calculateSpotPrice(t,e,r,i){return ls(t,e,r,i)}static calculateLrnaSpotPrice(t,e){return cs(t,e)}static calculateInGivenOut(t,e,r,i,a,n,s,o,l,c){return as(t,e,r,i,a,n,s,o,l,c)}static calculateLrnaInGivenOut(t,e,r,i,a,n){return ns(t,e,r,i,a,n)}static calculateOutGivenIn(t,e,r,i,a,n,s,o,l,c){return ss(t,e,r,i,a,n,s,o,l,c)}static calculateOutGivenLrnaIn(t,e,r,i,a,n){return os(t,e,r,i,a,n)}static calculateShares(t,e,r,i){return us(t,e,r,i)}static calculateLiquidityOut(t,e,r,i,a,n,s,o){return ms(t,e,r,i,a,n,s,o)}static calculateLiquidityLRNAOut(t,e,r,i,a,n,s,o){return ps(t,e,r,i,a,n,s,o)}static calculateCapDifference(t,e,r,i){let a=It(e),n=It(t),s=It(i),o=It(r),l=It(10).pow(18),c=o.div(l);if(a.div(s).lt(c)){let d=c.times(s).minus(a).times(n),p=a.times(It(1).minus(c));return d.div(p).toFixed(0)}else return"0"}static calculateLimitHubIn(t,e,r,i){return gs(t,e,r,i)}static isSellAllowed(t){return hs(t)}static isBuyAllowed(t){return bs(t)}static isAddLiquidityAllowed(t){return ys(t)}static isRemoveLiquidityAllowed(t){return fs(t)}static recalculateAssetFee(t,e,r,i,a,n,s,o,l,c,u){return Ps(t,e,r,i,a,n,s,o,l,c,u)}static recalculateProtocolFee(t,e,r,i,a,n,s,o,l,c,u){return Ss(t,e,r,i,a,n,s,o,l,c,u)}static verifyAssetCap(t,e,r,i){return ds(t,e,r,i)}};import{big as ws}from"@galacticcouncil/common";var{FeeUtils:K}=x,te=class m{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;hubAssetId;static fromPool(t){return new m(t)}constructor(t){this.type="Omnipool",this.address=t.address,this.tokens=t.tokens,this.maxInRatio=t.maxInRatio,this.maxOutRatio=t.maxOutRatio,this.minTradingLimit=t.minTradingLimit,this.hubAssetId=t.hubAssetId}validatePair(t,e){return this.hubAssetId!=e}parsePair(t,e){let r=new Map(this.tokens.map(n=>[n.id,n])),i=r.get(t),a=r.get(e);if(i==null)throw new Error("Pool does not contain tokenIn");if(a==null)throw new Error("Pool does not contain tokenOut");return{assetIn:t,assetOut:e,hubReservesIn:i.hubReserves,hubReservesOut:a.hubReserves,sharesIn:i.shares,sharesOut:a.shares,decimalsIn:i.decimals,decimalsOut:a.decimals,balanceIn:i.balance,balanceOut:a.balance,tradeableIn:i.tradeable,tradeableOut:a.tradeable,assetInEd:i.existentialDeposit,assetOutEd:a.existentialDeposit}}validateAndBuy(t,e,r){let i=this.calculateInGivenOut(t,e),a=this.calculateInGivenOut(t,e,r),n=i===0n?0:L.calculateBuyFee(i,a),s=[],o=I.isSellAllowed(t.tradeableIn),l=I.isBuyAllowed(t.tradeableOut);(!o||!l)&&s.push("TradeNotAllowed"),(e<this.minTradingLimit||i<t.assetInEd)&&s.push("InsufficientTradingAmount");let c=t.balanceOut/this.maxOutRatio;e>c&&s.push("MaxOutRatioExceeded");let u=t.balanceIn/this.maxInRatio;return a>u&&s.push("MaxInRatioExceeded"),{amountIn:a,calculatedIn:i,amountOut:e,feePct:n,errors:s}}validateAndSell(t,e,r){let i=this.calculateOutGivenIn(t,e),a=this.calculateOutGivenIn(t,e,r),n=L.calculateSellFee(i,a),s=[],o=I.isSellAllowed(t.tradeableIn),l=I.isBuyAllowed(t.tradeableOut);(!o||!l)&&s.push("TradeNotAllowed"),(e<this.minTradingLimit||i<t.assetOutEd)&&s.push("InsufficientTradingAmount");let c=t.balanceIn/this.maxInRatio;e>c&&s.push("MaxInRatioExceeded");let u=t.balanceOut/this.maxOutRatio;return a>u&&s.push("MaxOutRatioExceeded"),{amountIn:e,calculatedOut:i,amountOut:a,feePct:n,errors:s}}calculateInGivenOut(t,e,r){if(t.assetIn==this.hubAssetId)return this.calculateLrnaInGivenOut(t,e,r);let i=I.calculateInGivenOut(t.balanceIn.toString(),t.hubReservesIn.toString(),t.sharesIn.toString(),t.balanceOut.toString(),t.hubReservesOut.toString(),t.sharesOut.toString(),e.toString(),r?K.toRaw(r.assetFee).toString():"0",r?K.toRaw(r.protocolFee).toString():"0",r?K.toRaw(r.maxSlipFee).toString():"0"),a=BigInt(i);return a<0n?0n:a}calculateLrnaInGivenOut(t,e,r){let i=I.calculateLrnaInGivenOut(t.balanceOut.toString(),t.hubReservesOut.toString(),t.sharesOut.toString(),e.toString(),r?K.toRaw(r.assetFee).toString():"0",r?K.toRaw(r.maxSlipFee).toString():"0"),a=BigInt(i);return a<0n?0n:a}calculateOutGivenIn(t,e,r){if(t.assetIn==this.hubAssetId)return this.calculateOutGivenLrnaIn(t,e,r);let i=I.calculateOutGivenIn(t.balanceIn.toString(),t.hubReservesIn.toString(),t.sharesIn.toString(),t.balanceOut.toString(),t.hubReservesOut.toString(),t.sharesOut.toString(),e.toString(),r?K.toRaw(r.assetFee).toString():"0",r?K.toRaw(r.protocolFee).toString():"0",r?K.toRaw(r.maxSlipFee).toString():"0"),a=BigInt(i);return a<0n?0n:a}calculateOutGivenLrnaIn(t,e,r){let i=I.calculateOutGivenLrnaIn(t.balanceOut.toString(),t.hubReservesOut.toString(),t.sharesOut.toString(),e.toString(),r?K.toRaw(r.assetFee).toString():"0",r?K.toRaw(r.maxSlipFee).toString():"0"),a=BigInt(i);return a<0n?0n:a}spotPriceInGivenOut(t){if(t.assetIn==this.hubAssetId)return this.spotPriceLrnaInGivenOut(t);let e=I.calculateSpotPrice(t.balanceOut.toString(),t.hubReservesOut.toString(),t.balanceIn.toString(),t.hubReservesIn.toString());return this.normalizeSpot(BigInt(e),t.decimalsOut,t.decimalsIn)}spotPriceLrnaInGivenOut(t){let e=I.calculateLrnaSpotPrice(t.hubReservesOut.toString(),t.balanceOut.toString());return this.normalizeSpot(BigInt(e),t.decimalsOut,t.decimalsIn)}spotPriceOutGivenIn(t){if(t.assetIn==this.hubAssetId)return this.spotPriceOutGivenLrnaIn(t);let e=I.calculateSpotPrice(t.balanceIn.toString(),t.hubReservesIn.toString(),t.balanceOut.toString(),t.hubReservesOut.toString());return this.normalizeSpot(BigInt(e),t.decimalsIn,t.decimalsOut)}spotPriceOutGivenLrnaIn(t){let e=I.calculateLrnaSpotPrice(t.balanceOut.toString(),t.hubReservesOut.toString());return this.normalizeSpot(BigInt(e),t.decimalsIn,t.decimalsOut)}normalizeSpot(t,e,r){let i=e-r;if(i===0)return t;let a=ws.pow10(Math.abs(i));return i>0?t*a:t/a}};import{AccountId as xs,Binary as xi,CompatibilityLevel as vs,Enum as Ts}from"polkadot-api";import{toHex as Is}from"@polkadot-api/utils";import{Subscription as As,distinctUntilChanged as fr,filter as Os,finalize as Pr,map as Ot,merge as Bs,tap as Ne}from"rxjs";import{HYDRATION_SS58_PREFIX as _s}from"@galacticcouncil/common";var{FeeUtils:D}=x,ut=class m{static compute(t,e,r,i,a,n,s,o){let l=t.assetIn,[c,u,d]=m.getAssetFee(t,e,r,i,n),p=0,g=0,b=0;l!==1&&([p,g,b]=m.getProtocolFee(t,e,r,a,s));let h=c+p,y=d+b;return{assetFee:D.fromPermill(u),protocolFee:D.fromPermill(g),maxSlipFee:D.fromPermill(o),min:D.fromPermill(h),max:D.fromPermill(y)}}static getAssetFee(t,e,r,i,a){let{assetOut:n,balanceOut:s}=t,{min_fee:o,max_fee:l,decay:c,amplification:u}=a;if(!r||!i)return[o,o,l];let d=D.fromPermill(o),p=D.fromPermill(l),[g]=i,{asset_fee:b,timestamp:h}=r,y=Math.max(1,e-h),f=g.volume.b_in.toString(),S=g.volume.b_out.toString(),P=g.liquidity.b.toString();n===0&&(f=g.volume.a_in.toString(),S=g.volume.a_out.toString(),P=g.liquidity.a.toString());let w=D.fromPermill(b),v=I.recalculateAssetFee(f,S,P,"9",s.toString(),D.toRaw(w).toString(),y.toString(),D.toRaw(d).toString(),D.toRaw(p).toString(),c.toString(),u.toString());return[o,Number(v)*1e6,l]}static getProtocolFee(t,e,r,i,a){let{assetIn:n,balanceIn:s}=t,{min_fee:o,max_fee:l,decay:c,amplification:u}=a;if(!r||!i)return[o,o,l];let d=D.fromPermill(o),p=D.fromPermill(l),[g]=i,{protocol_fee:b,timestamp:h}=r,y=Math.max(1,e-h),f=g.volume.b_in.toString(),S=g.volume.b_out.toString(),P=g.liquidity.b.toString();n===0&&(f=g.volume.a_in.toString(),S=g.volume.a_out.toString(),P=g.liquidity.a.toString());let w=D.fromPermill(b),v=I.recalculateProtocolFee(f,S,P,"9",s.toString(),D.toRaw(w).toString(),y.toString(),D.toRaw(d).toString(),D.toRaw(p).toString(),c.toString(),u.toString());return[o,Number(v)*1e6,l]}};var At=m=>m===0?[0,1]:[1,m],He=m=>At(m).join(":");var{FeeUtils:Sr}=x,vi=xi.toHex(xi.fromText("omnipool")),Ti=Ts("Short"),ee=class extends N{queryBus=new St;block=0;dynamicFeesConfig=this.queryBus.scope("DynamicFees.AssetFeeConfiguration",t=>this.api.query.DynamicFees.AssetFeeConfiguration.getValue(t,{at:this.at}),t=>String(t));dynamicFees=this.queryBus.scope("DynamicFees.AssetFee",t=>this.api.query.DynamicFees.AssetFee.getValue(t,{at:this.at}),t=>String(t),6*1e3);maxSlipFee=this.queryBus.scope("Omnipool.SlipFee",()=>this.apiNext.query.Omnipool.SlipFee.getValue({at:this.at}),()=>"slipFee");emaOracles=this.queryBus.scope("EmaOracle.Oracles.Short",t=>this.api.query.EmaOracle.Oracles.getValue(vi,t,Ti,{at:this.at}),t=>t.join(":"),6*1e3);getPoolType(){return"Omnipool"}getPoolAddress(){let t="modlomnipool".padEnd(32,"\0"),e=new TextEncoder().encode(t),r=Is(e);return xs(_s).dec(r)}async getPoolLimits(){let[t,e,r]=await Promise.all([this.api.constants.Omnipool.MaxInRatio(),this.api.constants.Omnipool.MaxOutRatio(),this.api.constants.Omnipool.MinimumTradingLimit()]);return{maxInRatio:t,maxOutRatio:e,minTradingLimit:r}}async isSupported(){return(await this.api.getStaticApis()).compat.query.Omnipool.Assets.isCompatible(vs.BackwardsCompatible)}async loadPools(){let t=await this.api.constants.Omnipool.HubAssetId(),e=this.getPoolAddress(),[r,i,a,n,s,o]=await Promise.all([this.api.query.Omnipool.Assets.getEntries({at:this.at}),this.api.query.Omnipool.HubAssetTradability.getValue({at:this.at}),this.api.query.AssetRegistry.Assets.getValue(t,{at:this.at}),this.balance.getBalance(e,t),this.getPoolLimits(),this.api.query.System.Number.getValue({at:this.at})]);this.block=o;let l=r.map(async({keyArgs:u,value:d})=>{let[p]=u,{hub_reserve:g,shares:b,tradable:h,cap:y,protocol_shares:f}=d,[S,P]=await Promise.all([this.api.query.AssetRegistry.Assets.getValue(p,{at:this.at}),this.balance.getBalance(e,p)]);return{id:p,decimals:S?.decimals,existentialDeposit:S?.existential_deposit,balance:P.transferable,cap:y,hubReserves:g,protocolShares:f,shares:b,tradeable:h,type:S?.asset_type.type}}),c=await Promise.all(l);return c.push({id:t,decimals:a?.decimals,existentialDeposit:a?.existential_deposit,balance:n.transferable,tradeable:i,type:a?.asset_type.type}),[{address:e,type:"Omnipool",hubAssetId:t,tokens:c,...s}]}async getPoolFees(t){let e=t.assetOut,r=t.assetIn,a=await this.maxSlipFee.get()??0,n=await this.dynamicFeesConfig.get(e);if(n?.type==="Fixed"){let{asset_fee:d,protocol_fee:p}=n.value;return{assetFee:Sr.fromPermill(d),protocolFee:Sr.fromPermill(p),maxSlipFee:Sr.fromPermill(a)}}let[s,o,l,c,u]=await Promise.all([this.dynamicFees.get(e),this.emaOracles.get(At(e)),this.emaOracles.get(At(r)),n?n.value.asset_fee_params:this.api.constants.DynamicFees.AssetFeeParameters(),n?n.value.protocol_fee_params:this.api.constants.DynamicFees.ProtocolFeeParameters()]);return ut.compute(t,this.block,s,o,l,c,u,a)}subscribeEmaOracles(){let[t]=this.store.pools,r=t.tokens.map(i=>i.id).map(i=>At(i)).map(i=>this.api.query.EmaOracle.Oracles.watchValue(vi,i,Ti,{at:"best"}).pipe(Ot(({value:a})=>a),Os(a=>a!==void 0),Ot((a,n)=>({value:a,index:n})),Ne(({index:a})=>{a>0&&this.log.trace("emaOracle.Oracles",i.join(":"))}),Ot(({value:a})=>({pair:i,value:a}))));return Bs(...r).pipe(Pr(()=>this.emaOracles.clear()),this.watchGuard("emaOracle.Oracles")).subscribe(i=>{let{pair:a,value:n}=i;this.emaOracles.set(n,a)})}subscribeDynamicFees(){return this.api.query.DynamicFees.AssetFee.watchEntries({at:"best"}).pipe(fr((t,e)=>!e.deltas),Ot((t,e)=>({value:t,index:e})),Ne(({value:t,index:e})=>{e>0&&this.log.trace("dynamicFees.AssetFee",t.deltas?.upserted)}),Pr(()=>this.dynamicFees.clear()),this.watchGuard("dynamicFees.AssetFee")).subscribe(({value:{deltas:t}})=>{t?.upserted.forEach(e=>{let[r]=e.args;this.dynamicFees.set(e.value,r)})})}subscribeDynamicFeesConfig(){return this.api.query.DynamicFees.AssetFeeConfiguration.watchEntries({at:"best"}).pipe(fr((t,e)=>!e.deltas),Ot((t,e)=>({value:t,index:e})),Ne(({value:t,index:e})=>{e>0&&this.log.trace("dynamicFees.AssetFeeConfiguration",t.deltas?.upserted)}),Pr(()=>this.dynamicFeesConfig.clear()),this.watchGuard("dynamicFees.AssetFeeConfiguration")).subscribe(({value:{deltas:t}})=>{t?.upserted.forEach(e=>{let[r]=e.args;this.dynamicFeesConfig.set(e.value,r)})})}subscribeBlock(){return this.watcher.bestBlock$.pipe(this.watchGuard("watcher.bestBlock")).subscribe(t=>{this.block=t})}subscribeAssets(){return this.api.query.Omnipool.Assets.watchEntries({at:"best"}).pipe(fr((t,e)=>!e.deltas),Ot((t,e)=>({value:t,index:e})),Ne(({value:t,index:e})=>{e>0&&this.log.trace("omnipool.Assets",t.deltas?.upserted)}),this.watchGuard("omnipool.Assets")).subscribe(({value:{deltas:t}})=>{this.store.update(([e])=>{let r=t?.upserted.reduce((a,n)=>{let[s]=n.args;return a.set(s,n.value),a},new Map),i=e.tokens.map(a=>{let n=r?.get(a.id);return n?this.updateTokenState(a,n):a});return[{...e,tokens:i}]})})}subscribeUpdates(){let t=new As;return t.add(this.subscribeAssets()),t.add(this.subscribeDynamicFees()),t.add(this.subscribeDynamicFeesConfig()),t.add(this.subscribeEmaOracles()),t.add(this.subscribeBlock()),t}updateTokenState(t,e){let{hub_reserve:r,shares:i,tradable:a,cap:n,protocol_shares:s}=e;return{...t,cap:n,hubReserves:r,protocolShares:s,shares:i,tradeable:a}}};var Tr={};A(Tr,{StableMath:()=>k,StableSwap:()=>mt,StableSwapClient:()=>ne});import{calculate_in_given_out as Fs,calculate_out_given_in as Es,calculate_amplification as Rs,calculate_add_one_asset as ks,calculate_liquidity_out_one_asset as Cs,calculate_shares as Ms,calculate_shares_for_amount as Ds,calculate_spot_price_with_fee as Ls,pool_account_name as qs,recalculate_peg as Hs}from"@galacticcouncil/math-stableswap";var k=class{static getPoolAddress(t){return qs(t)}static defaultPegs(t){let e=[];for(let r=0;r<t;r++)e.push(["1","1"]);return e}static calculateAmplification(t,e,r,i,a){return Rs(t,e,r,i,a)}static calculateInGivenOut(t,e,r,i,a,n,s){return Fs(t,e,r,i,a,n,s)}static calculateAddOneAsset(t,e,r,i,a,n,s){return ks(t,e,r,i,a,n,s)}static calculateSharesForAmount(t,e,r,i,a,n,s){return Ds(t,e,r,i,a,n,s)}static calculateOutGivenIn(t,e,r,i,a,n,s){return Es(t,e,r,i,a,n,s)}static calculateLiquidityOutOneAsset(t,e,r,i,a,n,s){return Cs(t,e,r,i,a,n,s)}static calculateShares(t,e,r,i,a,n){return Ms(t,e,r,i,a,n)}static calculateSpotPriceWithFee(t,e,r,i,a,n,s,o){return Ls(t,e,r,i,a,n,s,o)}static recalculatePegs(t,e,r,i,a,n){let s=Hs(t,e,r,i,a,n);return JSON.parse(s)}};import{RUNTIME_DECIMALS as Ns,big as Ii}from"@galacticcouncil/common";var{FeeUtils:Bt}=x,mt=class m{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;amplification;isRampPeriod;id;fee;totalIssuance;pegs;static fromPool(t){return new m(t)}constructor(t){this.type="Stableswap",this.address=t.address,this.tokens=t.tokens,this.maxInRatio=t.maxInRatio,this.maxOutRatio=t.maxOutRatio,this.minTradingLimit=t.minTradingLimit,this.amplification=t.amplification,this.isRampPeriod=t.isRampPeriod,this.id=t.id,this.fee=t.fee,this.totalIssuance=t.totalIssuance,this.pegs=t.pegs}validatePair(t,e){return!0}parsePair(t,e){let r=new Map(this.tokens.map(n=>[n.id,n])),i=r.get(t),a=r.get(e);if(i==null)throw new Error("Pool does not contain tokenIn");if(a==null)throw new Error("Pool does not contain tokenOut");return{assetIn:t,assetOut:e,balanceIn:i.balance,balanceOut:a.balance,decimalsIn:i.decimals,decimalsOut:a.decimals,tradeableIn:this.id===t?15:i.tradeable,tradeableOut:this.id===e?15:a.tradeable,assetInEd:i.existentialDeposit,assetOutEd:a.existentialDeposit}}validateAndBuy(t,e,r){let i=this.calculateInGivenOut(t,e),a=this.calculateInGivenOut(t,e,r),n=i===0n?0:L.calculateBuyFee(i,a),s=[],o=I.isSellAllowed(t.tradeableIn),l=I.isBuyAllowed(t.tradeableOut);return(!o||!l)&&s.push("TradeNotAllowed"),(e<this.minTradingLimit||i<t.assetInEd)&&s.push("InsufficientTradingAmount"),{amountIn:a,calculatedIn:i,amountOut:e,feePct:n,errors:s}}validateAndSell(t,e,r){let i=this.calculateOutGivenIn(t,e),a=this.calculateOutGivenIn(t,e,r),n=L.calculateSellFee(i,a),s=[],o=I.isSellAllowed(t.tradeableIn),l=I.isBuyAllowed(t.tradeableOut);return(!o||!l)&&s.push("TradeNotAllowed"),(e<this.minTradingLimit||i<t.assetOutEd)&&s.push("InsufficientTradingAmount"),{amountIn:e,calculatedOut:i,amountOut:a,feePct:n,errors:s}}calculateIn(t,e,r){let i=k.calculateInGivenOut(this.getReserves(),Number(t.assetIn),Number(t.assetOut),e.toString(),this.amplification.toString(),r?Bt.toRaw(r.fee).toString():"0",this.getPegs()),a=BigInt(i);return a<0n?0n:a}calculateAddOneAsset(t,e,r){let i=k.calculateAddOneAsset(this.getReserves(),e.toString(),Number(t.assetIn),this.amplification.toString(),this.totalIssuance.toString(),r?Bt.toRaw(r.fee).toString():"0",this.getPegs()),a=BigInt(i);return a<0n?0n:a}calculateSharesForAmount(t,e,r){let i=k.calculateSharesForAmount(this.getReserves(),Number(t.assetOut),e.toString(),this.amplification.toString(),this.totalIssuance.toString(),r?Bt.toRaw(r.fee).toString():"0",this.getPegs()),a=BigInt(i);return a<0n?0n:a}calculateInGivenOut(t,e,r){return t.assetOut==this.id?this.calculateAddOneAsset(t,e,r):t.assetIn==this.id?this.calculateSharesForAmount(t,e,r):this.calculateIn(t,e,r)}spotPriceInGivenOut(t){let e=k.calculateSpotPriceWithFee(this.id.toString(),this.getReserves(),this.amplification.toString(),t.assetOut.toString(),t.assetIn.toString(),this.totalIssuance.toString(),"0",this.getPegs());return this.normalizeSpot(BigInt(e),t.assetOut===this.id,t.assetIn===this.id,t.decimalsOut,t.decimalsIn)}calculateOut(t,e,r){let i=k.calculateOutGivenIn(this.getReserves(),Number(t.assetIn),Number(t.assetOut),e.toString(),this.amplification.toString(),r?Bt.toRaw(r.fee).toString():"0",this.getPegs()),a=BigInt(i);return a<0n?0n:a}calculateWithdrawOneAsset(t,e,r){let i=k.calculateLiquidityOutOneAsset(this.getReserves(),e.toString(),Number(t.assetOut),this.amplification.toString(),this.totalIssuance.toString(),r?Bt.toRaw(r.fee).toString():"0",this.getPegs()),a=BigInt(i);return a<0n?0n:a}calculateShares(t,e,r){let i=k.calculateShares(this.getReserves(),this.getAssets(t.assetIn,e),this.amplification.toString(),this.totalIssuance.toString(),r?Bt.toRaw(r.fee).toString():"0",this.getPegs()),a=BigInt(i);return a<0n?0n:a}calculateOutGivenIn(t,e,r){return t.assetIn==this.id?this.calculateWithdrawOneAsset(t,e,r):t.assetOut==this.id?this.calculateShares(t,e,r):this.calculateOut(t,e,r)}spotPriceOutGivenIn(t){let e=k.calculateSpotPriceWithFee(this.id.toString(),this.getReserves(),this.amplification.toString(),t.assetIn.toString(),t.assetOut.toString(),this.totalIssuance.toString(),"0",this.getPegs());return this.normalizeSpot(BigInt(e),t.assetIn===this.id,t.assetOut===this.id,t.decimalsIn,t.decimalsOut)}getPegs(){return JSON.stringify(this.pegs)}getReserves(){let t=this.tokens.filter(e=>e.id!=this.id).map(({id:e,balance:r,decimals:i})=>({asset_id:e,amount:r,decimals:i}));return JSON.stringify(t,zt.jsonFormatter)}getAssets(t,e){let r={asset_id:Number(t),amount:e.toString()};return JSON.stringify([r],zt.jsonFormatter)}normalizeSpot(t,e,r,i,a){return e?t*Ii.pow10(Ns-a):r?t/Ii.pow10(a-i):t}};import{AccountId as Us,CompatibilityLevel as Vs}from"polkadot-api";import{toHex as Ys}from"@polkadot-api/utils";import{blake2b as Ws}from"@noble/hashes/blake2b";import{Subscription as $s,distinctUntilChanged as ki,filter as zs,map as Ft,merge as Xs,tap as vr}from"rxjs";import{HYDRATION_SS58_PREFIX as Ks,RUNTIME_DECIMALS as js}from"@galacticcouncil/common";import{Binary as Gs}from"polkadot-api";import{decodeEventLog as Bi}from"viem";var xr=[{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"}],Ai=[{anonymous:!1,inputs:[{indexed:!1,name:"key",type:"string"},{indexed:!1,name:"value",type:"uint128"},{indexed:!1,name:"timestamp",type:"uint128"}],name:"OracleUpdate",type:"event"}],Oi=[{anonymous:!1,inputs:[{indexed:!0,name:"roundId",type:"uint80"},{indexed:!1,name:"answer",type:"int256"},{indexed:!1,name:"timestamp",type:"uint256"}],name:"PriceUpdated",type:"event"}];var re=class{static parse(t){let{address:e,topics:r,data:i}=t.log,a=e.toLowerCase(),n=Gs.toHex(i);try{let{eventName:s,args:o}=Bi({abi:Oi,topics:r,data:n});return{eventName:`ManagedOracle.${s}`,emitter:a,value:o.answer,timestamp:o.timestamp}}catch{}try{let{eventName:s,args:o}=Bi({abi:Ai,topics:r,data:n});return{eventName:`DIA.${s}`,emitter:a,key:o.key,value:o.value,timestamp:o.timestamp}}catch{}}};var ie=class{adapter;constructor(t){this.adapter=t.getRPCAdapter()}async getData(t,e=6){let[r,i,a]=await Promise.all([this.adapter.readContract({abi:xr,address:t,functionName:"latestRoundData"}),this.adapter.readContract({abi:xr,address:t,functionName:"decimals"}),this.adapter.getBlock()]),[n,s,o,l]=r,c=a.number-(a.timestamp-l)/BigInt(e),u=Number(c);return{price:s,decimals:i,updatedAt:u<0?0:u}}};var _i={"EUR/USD":"0xaa47a5662269270d3df33ae08f806e383611575c","sUSDs/USD":"0x4b32bffc6acd751446e79e8687ef3815fd7924fd","sUSDe/USD":"0x22cdea305cee63d082e79f8c5db939eecd0265d0"},Fi={"0xcfab6a4031c70da0f0cf6f31a252c16119db3611":"0xaafd758688cefd0a7b7770a825f1aad551e16185"},Ei={"bifrosto:5:15:LastBlock":"0xaafd758688cefd0a7b7770a825f1aad551e16185"};function Ri(m,t,e){let r=Buffer.from(m.replace(/^0x/,""),"hex").toString("ascii").replace(/\0+$/,""),[i,a]=[t[0],t[1]].sort((n,s)=>n-s);return`${r}:${i}:${a}:${e}`}var{FeeUtils:_t}=x,ae=class m{static compute(t,e,r,i){let a=m.getRecent(e),n=_t.fromPermill(t.fee),s=_t.fromPerbill(e.max_peg_update),o=r.map(({pair:g,updatedAt:b})=>[g,b]),l=r.find(g=>g.source),c=e.updated_at?e.updated_at.toString():l?.updatedAt;if(!c)throw new Error("Current peg unknown!");let[u,d]=k.recalculatePegs(JSON.stringify(a),c,JSON.stringify(o),i.toString(),_t.toRaw(s).toString(),_t.toRaw(n).toString()),p=Number(u)*1e6;return{pegsFee:_t.fromPermill(p),pegs:d}}static getDefault(t){return{pegsFee:_t.fromPermill(t.fee),pegs:k.defaultPegs(t.assets.length)}}static getRecent(t){let{current:e}=t;return Array.from(e.entries()).map(([r,i])=>i.map(a=>a.toString()))}};var{FeeUtils:Qs}=x,Js=["ManagedOracle.PriceUpdated","DIA.OracleUpdate"],ne=class extends N{poolsData=new Map([]);mmOracle=new ie(this.evm);mmAddresses=new Set;mmRouting={byEmitter:new Map,byDiaKey:new Map,byEma:new Map};queryBus=new St;emaOracles=this.queryBus.scope("EmaOracle.Oracles",(t,e,r)=>this.api.query.EmaOracle.Oracles.getValue(t,e,r,{at:this.at}),(t,e,r)=>`${t.toString()}:${e.join(":")}:${r.type}`,6*1e3);mmOracles=this.queryBus.scope("MmOracle",t=>this.mmOracle.getData(t),t=>t.toLowerCase(),600*1e3);pegs=this.queryBus.scope("Stableswap.PoolPegs",t=>this.api.query.Stableswap.PoolPegs.getValue(t,{at:this.at}),t=>String(t),6*1e3);getPoolType(){return"Stableswap"}getPoolAddress(t){let e=k.getPoolAddress(t),r=Ws(e,{dkLen:32}),i=Ys(r);return Us(Ks).dec(i)}async getPoolLimits(){return{maxInRatio:0n,maxOutRatio:0n,minTradingLimit:await this.api.constants.Stableswap.MinTradingLimit()}}getPoolAmplification(t,e){let{initial_amplification:r,final_amplification:i,initial_block:a,final_block:n}=t,s=k.calculateAmplification(r.toString(),i.toString(),a.toString(),n.toString(),e.toString()),o=Number(s)<i;return{amplification:BigInt(s),isRampPeriod:o}}async getPoolTokens(t,e){let r=this.getPoolAddress(t),i=e.assets.map(async a=>{let[n,s,o]=await Promise.all([this.api.query.Stableswap.AssetTradability.getValue(t,a,{at:this.at}),this.api.query.AssetRegistry.Assets.getValue(a,{at:this.at}),this.balance.getBalance(r,a)]);return{id:a,decimals:s?.decimals,existentialDeposit:s?.existential_deposit,balance:o.transferable,tradeable:n,type:s?.asset_type.type}});return Promise.all(i)}buildRouting(){this.mmRouting.byEmitter.clear(),this.mmRouting.byDiaKey.clear(),this.mmRouting.byEma.clear();for(let t of this.mmAddresses)this.mmRouting.byEmitter.set(t,t);for(let[t,e]of Object.entries(Fi)){let r=t.toLowerCase(),i=e.toLowerCase();this.mmAddresses.has(i)&&this.mmRouting.byEmitter.set(r,i)}for(let[t,e]of Object.entries(_i)){let r=e.toLowerCase();this.mmAddresses.has(r)&&this.mmRouting.byDiaKey.set(t,r)}for(let[t,e]of Object.entries(Ei)){let r=e.toLowerCase();this.mmAddresses.has(r)&&this.mmRouting.byEma.set(t,r)}}async isSupported(){return(await this.api.getStaticApis()).compat.query.Stableswap.Pools.isCompatible(Vs.BackwardsCompatible)}async loadPools(){let[t,e,r,i]=await Promise.all([this.api.query.Stableswap.Pools.getEntries({at:this.at}),this.api.query.Stableswap.PoolPegs.getEntries({at:this.at}),this.api.query.System.Number.getValue({at:this.at}),this.getPoolLimits()]);for(let{keyArgs:n,value:s}of e){let[o]=n;this.pegs.set(s,o);for(let l of s.source)l.type==="MMOracle"&&this.mmAddresses.add(l.value.toString().toLowerCase())}this.buildRouting();let a=t.map(async({keyArgs:n,value:s})=>{let[o]=n,l=this.getPoolAddress(o),[c,u,d,p]=await Promise.all([this.getPoolTokens(o,s),this.getPoolAmplification(s,r),this.getPoolPegs(o,s,r),this.api.query.Tokens.TotalIssuance.getValue(o,{at:this.at})]);return c.push({id:o,tradeable:15,balance:p,decimals:js}),this.poolsData.set(o,s),{address:l,id:o,type:"Stableswap",fee:Qs.fromPermill(s.fee),tokens:c,totalIssuance:p,...d,...i,...u}});return Promise.all(a)}async getPoolFees(t,e){return{fee:this.store.pools.find(i=>i.address===e).fee}}async getPoolPegs(t,e,r){let i=await this.pegs.get(t);if(!i)return ae.getDefault(e);let a=await this.getLatestPegs(e,i,r);return ae.compute(e,i,a,r)}async getLatestPegs(t,e,r){let{source:i}=e,a=t.assets,n=i.map(async(s,o)=>{if(s.type==="Oracle"){let[l,c,u]=s.value,d=[u,a[o]].sort((y,f)=>y-f),p=await this.emaOracles.get(l,d,c);if(!p)throw new Error("EmaOracle missing for "+l+" / "+d);let[{price:g,updated_at:b}]=p;return{pair:u===d[0]?[g.n.toString(),g.d.toString()]:[g.d.toString(),g.n.toString()],updatedAt:b.toString(),source:s.type}}if(s.type==="MMOracle"){let l=s.value.toString(),{price:c,decimals:u,updatedAt:d}=await this.mmOracles.get(l),p=(10n**BigInt(u)).toString();return{pair:[c.toString(),p],updatedAt:d.toString(),source:s.type}}if(s.type==="Value")return{pair:s.value.map(c=>c.toString()),updatedAt:r.toString()};throw new Error(s+" source not supported")});return Promise.all(n)}subscribeIssuance(){let e=this.store.pools.map(r=>r.id).map(r=>this.api.query.Tokens.TotalIssuance.watchValue(r,{at:"best"}).pipe(Ft(({value:i})=>i),Ft((i,a)=>({value:i,index:a})),vr(({index:i,value:a})=>{i>0&&this.log.trace("tokens.TotalIssuance",r,a)}),Ft(({value:i})=>({id:r,value:i}))));return Xs(...e).pipe(this.watchGuard("tokens.TotalIssuance")).subscribe(r=>{let{id:i,value:a}=r;this.store.update(n=>{let s=[];return n.filter(o=>o.id===i).forEach(o=>{let l=o.tokens.map(c=>c.id===i?{...c,balance:a}:c);s.push({...o,tokens:l,totalIssuance:a})}),s})})}subscribePoolPegs(){return this.api.query.Stableswap.PoolPegs.watchEntries({at:"best"}).pipe(ki((t,e)=>!e.deltas),Ft((t,e)=>({value:t,index:e})),vr(({value:t,index:e})=>{e>0&&this.log.trace("stableswap.PoolPegs",t.deltas?.upserted)}),this.watchGuard("stableswap.PoolPegs")).subscribe({error:t=>this.log.error("stableswap.PoolPegs",t),next:({value:{deltas:t}})=>{for(let{args:e,value:r}of t?.upserted??[]){let[i]=e;this.pegs.set(r,i)}}})}subscribeEmaOracles(){return this.api.query.EmaOracle.Oracles.watchEntries({at:"best"}).pipe(ki((t,e)=>!e.deltas),Ft((t,e)=>({value:t,index:e})),vr(({value:t,index:e})=>{e>0&&this.log.trace("emaOracle.Oracles",t.deltas?.upserted)}),this.watchGuard("emaOracle.Oracles")).subscribe(async({value:{deltas:t}})=>{let e=new Set;for(let{args:r,value:i}of t?.upserted??[]){let[a,n,s]=r;this.emaOracles.set(i,a,n,s);let o=Ri(a,n,s.type),l=this.mmRouting.byEma.get(o);l&&e.add(l)}for(let r of e){let i=await this.mmOracle.getData(r);this.log.trace("mmOracle.Hybrid",{h160:r,fresh:i}),this.mmOracles.set(i,r)}})}subscribeMMOracles(){return this.api.event.EVM.Log.watch().pipe(Ft(({events:t})=>t.map(e=>re.parse(e.payload)).filter(e=>!!e).filter(({eventName:e})=>Js.includes(e))),zs(t=>t.length>0),this.watchGuard("evm.Log")).subscribe(async t=>{let e=new Set;for(let r of t){if(console.log(r),r.eventName==="ManagedOracle.PriceUpdated"){let i=this.mmRouting.byEmitter.get(r.emitter);i&&e.add(i)}if(r.eventName==="DIA.OracleUpdate"&&r.key){let i=this.mmRouting.byDiaKey.get(r.key);i&&e.add(i)}}for(let r of e){let i=await this.mmOracle.getData(r);this.log.trace("mmOracle",{h160:r,fresh:i}),this.mmOracles.set(i,r)}})}subscribeBlock(){return this.watcher.bestBlock$.pipe(this.watchGuard("watcher.bestBlock")).subscribe(t=>{this.store.update(async e=>{let r=[];for(let i of e){let a=this.poolsData.get(i.id);if(a){let n=await this.getPoolPegs(i.id,a,t),s=this.getPoolAmplification(a,t);r.push({...i,...n,...s})}}return r})})}subscribeUpdates(){let t=new $s;return t.add(this.subscribePoolPegs()),t.add(this.subscribeEmaOracles()),t.add(this.subscribeMMOracles()),t.add(this.subscribeIssuance()),t.add(this.subscribeBlock()),t}};var Ir={};A(Ir,{XykMath:()=>J,XykPool:()=>se,XykPoolClient:()=>oe});import{calculate_in_given_out as Zs,calculate_out_given_in as to,calculate_pool_trade_fee as eo,get_spot_price as ro,calculate_liquidity_in as io,calculate_shares as ao,calculate_spot_price as no,calculate_spot_price_with_fee as so,calculate_liquidity_out_asset_a as oo,calculate_liquidity_out_asset_b as lo}from"@galacticcouncil/math-xyk";var J=class{static getSpotPrice(t,e,r){return ro(t,e,r)}static calculateInGivenOut(t,e,r){return Zs(t,e,r)}static calculateOutGivenIn(t,e,r){return to(t,e,r)}static calculatePoolTradeFee(t,e,r){return eo(t,e,r)}static calculateLiquidityIn(t,e,r){return io(t,e,r)}static calculateSpotPrice(t,e){return no(t,e)}static calculateSpotPriceWithFee(t,e,r,i){return so(t,e,r,i)}static calculateShares(t,e,r){return ao(t,e,r)}static calculateLiquidityOutAssetA(t,e,r,i){return oo(t,e,r,i)}static calculateLiquidityOutAssetB(t,e,r,i){return lo(t,e,r,i)}};import{big as co}from"@galacticcouncil/common";var{FeeUtils:Ci}=x,se=class m{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;static fromPool(t){return new m(t)}constructor(t){this.type="XYK",this.address=t.address,this.tokens=t.tokens,this.maxInRatio=t.maxInRatio,this.maxOutRatio=t.maxOutRatio,this.minTradingLimit=t.minTradingLimit}validatePair(t,e){return!0}parsePair(t,e){let r=new Map(this.tokens.map(n=>[n.id,n])),i=r.get(t),a=r.get(e);if(i==null)throw new Error("Pool does not contain tokenIn");if(a==null)throw new Error("Pool does not contain tokenOut");return{assetIn:t,assetOut:e,decimalsIn:i.decimals,decimalsOut:a.decimals,balanceIn:i.balance,balanceOut:a.balance,assetInEd:i.existentialDeposit,assetOutEd:a.existentialDeposit}}validateAndBuy(t,e,r){let i=this.calculateInGivenOut(t,e),a=this.calculateTradeFee(i,r),n=Ci.toPct(r.exchangeFee),s=i+a,o=[];(e<this.minTradingLimit||i<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:i,amountOut:e,feePct:n,errors:o}}validateAndSell(t,e,r){let i=this.calculateOutGivenIn(t,e),a=this.calculateTradeFee(i,r),n=Ci.toPct(r.exchangeFee),s=i-a,o=[];(e<this.minTradingLimit||i<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:i,amountOut:s,feePct:n,errors:o}}calculateInGivenOut(t,e){let r=J.calculateInGivenOut(t.balanceIn.toString(),t.balanceOut.toString(),e.toString()),i=BigInt(r);return i<0n?0n:i}calculateOutGivenIn(t,e){let r=J.calculateOutGivenIn(t.balanceIn.toString(),t.balanceOut.toString(),e.toString()),i=BigInt(r);return i<0n?0n:i}spotPriceInGivenOut(t){let e=J.calculateSpotPrice(t.balanceOut.toString(),t.balanceIn.toString());return this.normalizeSpot(BigInt(e),t.decimalsOut,t.decimalsIn)}spotPriceOutGivenIn(t){let e=J.calculateSpotPrice(t.balanceIn.toString(),t.balanceOut.toString());return this.normalizeSpot(BigInt(e),t.decimalsIn,t.decimalsOut)}calculateTradeFee(t,e){let r=J.calculatePoolTradeFee(t.toString(),e.exchangeFee[0],e.exchangeFee[1]);return BigInt(r)}normalizeSpot(t,e,r){let i=e-r;if(i===0)return t;let a=co.pow10(Math.abs(i));return i>0?t*a:t/a}};import{CompatibilityLevel as uo}from"polkadot-api";import{Subscription as mo}from"rxjs";var oe=class extends N{decimals=new Map([]);getPoolType(){return"XYK"}async withOverride(t){this.decimals=t?new Map(t.map(e=>[e.id,e.decimals])):new Map}async getPoolLimits(){let[t,e,r]=await Promise.all([this.api.constants.XYK.MaxInRatio(),this.api.constants.XYK.MaxOutRatio(),this.api.constants.XYK.MinTradingLimit()]);return{maxInRatio:t,maxOutRatio:e,minTradingLimit:r}}async isSupported(){return(await this.api.getStaticApis()).compat.query.XYK.PoolAssets.isCompatible(uo.BackwardsCompatible)}async loadPools(){let[t,e]=await Promise.all([this.api.query.XYK.PoolAssets.getEntries({at:this.at}),this.getPoolLimits()]),r=t.map(async({keyArgs:i,value:a})=>{let[n]=i,[s,o]=a,[l,c,u,d]=await Promise.all([this.balance.getBalance(n,s),this.api.query.AssetRegistry.Assets.getValue(s,{at:this.at}),this.balance.getBalance(n,o),this.api.query.AssetRegistry.Assets.getValue(o,{at:this.at})]);return{address:n,type:"XYK",tokens:[{id:s,decimals:c?.decimals||this.decimals.get(s),existentialDeposit:c?.existential_deposit,balance:l.transferable,type:c?.asset_type.type},{id:o,decimals:d?.decimals||this.decimals.get(o),existentialDeposit:d?.existential_deposit,balance:u.transferable,type:d?.asset_type.type}],...e}});return Promise.all(r)}async getPoolFees(){return{exchangeFee:await this.getExchangeFee()}}async getExchangeFee(){return await this.api.constants.XYK.GetExchangeFee()}subscribeUpdates(){return mo.EMPTY}};var Or={};A(Or,{AavePool:()=>le,AavePoolClient:()=>ce});import{big as Mi,RUNTIME_DECIMALS as Di}from"@galacticcouncil/common";var le=class m{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;static fromPool(t){return new m(t)}constructor(t){this.type="Aave",this.address=t.address,this.tokens=t.tokens,this.maxInRatio=t.maxInRatio,this.maxOutRatio=t.maxOutRatio,this.minTradingLimit=t.minTradingLimit}validatePair(t,e){return!0}parsePair(t,e){let r=new Map(this.tokens.map(n=>[n.id,n])),i=r.get(t),a=r.get(e);if(i==null)throw new Error("Pool does not contain tokenIn");if(a==null)throw new Error("Pool does not contain tokenOut");return{assetIn:t,assetOut:e,balanceIn:i.balance,balanceOut:a.balance,decimalsIn:i.decimals,decimalsOut:a.decimals,assetInEd:0n,assetOutEd:0n}}validateAndBuy(t,e,r){let i=this.calculateInGivenOut(t,e),a=[];return e>t.balanceOut&&a.push("TradeNotAllowed"),{amountIn:i,calculatedIn:i,amountOut:e,feePct:0,errors:a}}validateAndSell(t,e,r){let i=this.calculateOutGivenIn(t,e),a=[];return i>t.balanceOut&&a.push("TradeNotAllowed"),{amountIn:e,calculatedOut:i,amountOut:i,feePct:0,errors:a}}calculateInGivenOut(t,e){return e}calculateOutGivenIn(t,e){return e}spotPriceInGivenOut(t){return Mi.toBigInt(1,Di)}spotPriceOutGivenIn(t){return Mi.toBigInt(1,Di)}calculateTradeFee(t,e){return 0n}};import{AccountId as po}from"polkadot-api";import{toHex as go}from"@polkadot-api/utils";import{Subscription as Li,filter as Ar,map as qi,mergeMap as Hi}from"rxjs";import{erc20 as ho,HYDRATION_SS58_PREFIX as bo}from"@galacticcouncil/common";var{ERC20:yo}=ho,fo=["Supply","Withdraw","Repay","Borrow"],ce=class extends N{getPoolType(){return"Aave"}async isSupported(){return!0}getPoolId(t,e){let r=t+"/"+e,i=new TextEncoder().encode(r.padEnd(32,"\0")),a=go(i);return po(bo).dec(a)}getPoolLimits(){return{maxInRatio:0n,maxOutRatio:0n,minTradingLimit:0n}}async loadPools(){let e=(await this.api.apis.AaveTradeExecutor.pools({at:this.at})).map(async({reserve:r,atoken:i,liqudity_in:a,liqudity_out:n})=>{let[s,o,l,c]=await Promise.all([this.api.query.AssetRegistry.Assets.getValue(r,{at:this.at}),this.api.query.AssetRegistry.AssetLocations.getValue(r,{at:this.at}),this.api.query.AssetRegistry.Assets.getValue(i,{at:this.at}),this.api.query.AssetRegistry.AssetLocations.getValue(i,{at:this.at})]);return{address:this.getPoolId(r,i),type:"Aave",tokens:[{id:r,decimals:s?.decimals,existentialDeposit:s?.existential_deposit,balance:a,location:o,type:s?.asset_type.type},{id:i,decimals:l?.decimals,existentialDeposit:l?.existential_deposit,balance:n,location:c,type:l?.asset_type.type}],...this.getPoolLimits()}});return Promise.all(e)}async getPoolDelta(t){let[e,r]=t.tokens,{liqudity_in:i,liqudity_out:a}=await this.api.apis.AaveTradeExecutor.pool(e.id,r.id,{at:this.at});return t.tokens.map(n=>{let s=n.id===e.id?i:a;return{...n,balance:s}})}async getPoolFees(){return{}}getReserveH160Id(t){if(t.type==="Erc20"&&t.location){let e=t.location.interior;if(e.type==="X1"&&e.value.type==="AccountKey20"){let{value:r}=e.value;return r.key}throw new Error("Invalid aave reserve multilocation")}return yo.fromAssetId(t.id)}parseRouterLog(t){let{asset_in:e,asset_out:r}=t;return{assetIn:e,assetOut:r,key:`${e}:${r}`}}subscribeRouterExecuted(){let e=this.store.pools.map(r=>r.tokens).map(([r,i])=>i).map(r=>r.id);return this.api.event.Router.Executed.watch().pipe(Hi(({events:r})=>r),qi(({payload:r})=>this.parseRouterLog(r)),Ar(({assetIn:r,assetOut:i})=>e.includes(r)||e.includes(i)),this.watchGuard("router.Execute")).subscribe(({assetIn:r,assetOut:i,key:a})=>{this.log.trace("router.Executed",a),this.store.update(async n=>{let s=[];for(let o of n){let[l,c]=o.tokens;if(c.id===r||c.id===i){let d=await this.getPoolDelta(o);s.push({...o,tokens:d})}}return s})})}subscribeEvmLog(){return this.api.event.EVM.Log.watch().pipe(Hi(({events:t})=>t),qi(({payload:t})=>Gt.parse(t)),Ar(t=>t!==void 0),Ar(({eventName:t})=>fo.includes(t)),this.watchGuard("evm.Log")).subscribe(({reserve:t,eventName:e})=>{this.log.trace(`evm.Log.${e}`,t),this.store.update(async r=>{let i=[];for(let a of r){let[n]=a.tokens;if(this.getReserveH160Id(n).toLowerCase()===t){let o=await this.getPoolDelta(a);i.push({...a,tokens:o})}}return i})})}subscribeBalances(){return Li.EMPTY}subscribeUpdates(){let t=new Li;return t.add(this.subscribeRouterExecuted()),t.add(this.subscribeEvmLog()),t}};var Er={};A(Er,{HsmMath:()=>V,HsmPool:()=>ue,HsmPoolClient:()=>me});import{calculate_collateral_in_given_hollar_out as Po,calculate_collateral_out_given_hollar_in as So,calculate_hollar_in_given_collateral_out as wo,calculate_hollar_out_given_collateral_in as xo,calculate_imbalance as vo,calculate_max_price as To,calculate_buyback_limit as Io,calculate_buyback_price_with_fee as Ao}from"@galacticcouncil/math-hsm";var V=class{static calculateCollateralInGivenHollarOut(t,e,r){return Po(t,e,r)}static calculateCollateralOutGivenHollarIn(t,e,r){return So(t,e,r)}static calculateHollarOutGivenCollateralIn(t,e,r){return xo(t,e,r)}static calculateHollarInGivenCollateralOut(t,e,r){return wo(t,e,r)}static calculateImbalance(t,e,r){return vo(t,e,r)}static calculateBuybackLimit(t,e){return Io(t,e)}static calculateBuybackPriceWithFee(t,e,r){return Ao(t,e,r)}static calculateMaxPrice(t,e){return To(t,e)}};import{big as Z,RUNTIME_DECIMALS as Ge}from"@galacticcouncil/common";var{FeeUtils:Et}=x,ue=class m extends mt{hsmAddress;hsmMintCapacity;hollarId;hollarH160;collateralId;collateralBalance;maxBuyPriceCoefficient;maxInHolding;purchaseFee;buyBackFee;buyBackRate;static fromPool(t){return new m(t)}constructor(t){super(t),this.type="HSM",this.hsmAddress=t.hsmAddress,this.hsmMintCapacity=t.hsmMintCapacity,this.hollarId=t.hollarId,this.hollarH160=t.hollarH160,this.collateralId=t.collateralId,this.collateralBalance=t.collateralBalance,this.maxBuyPriceCoefficient=t.maxBuyPriceCoefficient,this.maxInHolding=t.maxInHolding,this.purchaseFee=t.purchaseFee,this.buyBackFee=t.buyBackFee,this.buyBackRate=t.buyBackRate}validatePair(t,e){return!0}parsePair(t,e){return super.parsePair(t,e)}validateTradeHollarIn(t,e,r){let i=this.parsePair(t.assetOut,t.assetIn),a=super.calculateInGivenOut(i,e,{fee:this.fee}),n=this.calculateBuybackLimit(t);e>n&&r.push("MaxBuyBackExceeded");let s=this.calculateMaxPrice(t);return this.calculateBuyPrice(t,e,a)>s&&r.push("MaxBuyPriceExceeded"),a>this.collateralBalance&&r.push("InsufficientCollateral"),r}validateTradeHollarOut(t,e,r){return this.collateralBalance+t>this.maxInHolding&&r.push("MaxHoldingExceeded"),e>this.hsmMintCapacity&&r.push("FacilitatorCapacityExceeded"),r}validateTradeConstraints(t,e,r){let i=[];return t.assetIn===this.hollarId?this.validateTradeHollarIn(t,e,i):this.validateTradeHollarOut(e,r,i)}validateAndBuy(t,e){let r=this.calculateInGivenOut(t,e),i=this.validateTradeConstraints(t,r,e);return{amountIn:r,calculatedIn:r,amountOut:e,feePct:0,errors:i}}validateAndSell(t,e){let r=this.calculateOutGivenIn(t,e),i=this.validateTradeConstraints(t,e,r);return{amountIn:e,calculatedOut:r,amountOut:r,feePct:0,errors:i}}calculateHollarInGivenCollateralOut(t,e){let r=super.calculateInGivenOut(t,e,{fee:this.fee}),i=V.calculateHollarInGivenCollateralOut(e.toString(),r.toString(),Et.toRaw(this.buyBackFee).toString());return BigInt(i)}calculateCollateralInGivenHollarOut(t){let e=this.getCollateralPeg(),r=V.calculateCollateralInGivenHollarOut(t.toString(),JSON.stringify(e),Et.toRaw(this.purchaseFee).toString());return BigInt(r)}calculateInGivenOut(t,e){return t.assetOut==this.hollarId?this.calculateCollateralInGivenHollarOut(e):this.calculateHollarInGivenCollateralOut(t,e)}calculateCollateralOutGivenHollarIn(t,e){let r=super.calculateOutGivenIn(t,e,{fee:this.fee}),i=V.calculateCollateralOutGivenHollarIn(e.toString(),r.toString(),Et.toRaw(this.buyBackFee).toString());return BigInt(i)}calculateHollarOutGivenCollateralIn(t){let e=this.getCollateralPeg(),r=V.calculateHollarOutGivenCollateralIn(t.toString(),JSON.stringify(e),Et.toRaw(this.purchaseFee).toString());return BigInt(r)}calculateOutGivenIn(t,e){return t.assetIn==this.hollarId?this.calculateCollateralOutGivenHollarIn(t,e):this.calculateHollarOutGivenCollateralIn(e)}calculateImbalance(t){let e=this.getCollateralPeg(),r=V.calculateImbalance(t.balanceIn.toString(),JSON.stringify(e),t.balanceOut.toString());return BigInt(r)}calculateBuybackLimit(t){let e=this.calculateImbalance(t),r=V.calculateBuybackLimit(e.toString(),Et.toRaw(this.buyBackRate).toString());return BigInt(r)}calculateBuyPrice(t,e,r){let i=V.calculateBuybackPriceWithFee(r.toString(),e.toString(),Et.toRaw(this.buyBackFee).toString()),[a,n]=JSON.parse(i),s=Z.pow10(t.decimalsIn+Ge-t.decimalsOut);return BigInt(a)*s/BigInt(n)}calculateMaxPrice(t){let e=this.getCollateralPeg(),r=V.calculateMaxPrice(JSON.stringify(e),this.maxBuyPriceCoefficient.toString()),[i,a]=JSON.parse(r),n=Z.pow10(Ge-t.decimalsOut);return BigInt(i)*n/BigInt(a)}spotPriceInGivenOut(t){let e=Z.toBigInt(1,t.decimalsOut),i=this.calculateInGivenOut(t,e)*Z.pow10(Ge-t.decimalsOut);return this.normalizeSpotPrice(i,t.decimalsOut,t.decimalsIn)}spotPriceOutGivenIn(t){let e=Z.toBigInt(1,t.decimalsIn),i=this.calculateOutGivenIn(t,e)*Z.pow10(Ge-t.decimalsIn);return this.normalizeSpotPrice(i,t.decimalsIn,t.decimalsOut)}getCollateralPeg(){let t=this.tokens.findIndex(i=>i.id!==this.hollarId),e=this.pegs[t],r=this.tokens[t].decimals;return this.isDefaultPeg(e)?[Z.toBigInt(1,18).toString(),Z.toBigInt(1,r).toString()]:e}isDefaultPeg(t){let[e,r]=t;return Array.isArray(t)&&t.length===2&&e==="1"&&r==="1"}normalizeSpotPrice(t,e,r){let i=e-r;if(i===0)return t;let a=Z.pow10(Math.abs(i));return i>0?t*a:t/a}};import{AccountId as _o,CompatibilityLevel as Fo}from"polkadot-api";import{toHex as Eo}from"@polkadot-api/utils";import{Subscription as Br,combineLatest as Ro,filter as Ni,map as _r,mergeMap as ko,pairwise as Co}from"rxjs";import{h160 as Mo,HYDRATION_SS58_PREFIX as Do}from"@galacticcouncil/common";import{Binary as Oo}from"polkadot-api";import{decodeEventLog as Bo}from"viem";var Ue=[{inputs:[{internalType:"address",name:"facilitator",type:"address"}],name:"getFacilitator",outputs:[{type:"tuple",components:[{name:"addr",type:"address"},{name:"label",type:"bytes32"},{name:"bucketCapacity",type:"uint128"},{name:"bucketLevel",type:"uint128"}]}],stateMutability:"view",type:"function"},{inputs:[{internalType:"address",name:"facilitator",type:"address"}],name:"getFacilitatorBucket",outputs:[{internalType:"uint256",name:"",type:"uint256"},{internalType:"uint256",name:"",type:"uint256"}],stateMutability:"view",type:"function"},{inputs:[],name:"getFacilitatorsList",outputs:[{internalType:"address[]",name:"",type:"address[]"}],stateMutability:"view",type:"function"},{anonymous:!1,inputs:[{indexed:!0,internalType:"address",name:"facilitatorAddress",type:"address"},{indexed:!0,internalType:"bytes32",name:"label",type:"bytes32"},{indexed:!1,internalType:"uint256",name:"bucketCapacity",type:"uint256"}],name:"FacilitatorAdded",type:"event"},{anonymous:!1,inputs:[{indexed:!0,internalType:"address",name:"facilitatorAddress",type:"address"},{indexed:!1,internalType:"uint256",name:"oldCapacity",type:"uint256"},{indexed:!1,internalType:"uint256",name:"newCapacity",type:"uint256"}],name:"FacilitatorBucketCapacityUpdated",type:"event"},{anonymous:!1,inputs:[{indexed:!0,internalType:"address",name:"facilitatorAddress",type:"address"},{indexed:!1,internalType:"uint256",name:"oldLevel",type:"uint256"},{indexed:!1,internalType:"uint256",name:"newLevel",type:"uint256"}],name:"FacilitatorBucketLevelUpdated",type:"event"},{anonymous:!1,inputs:[{indexed:!0,internalType:"address",name:"facilitatorAddress",type:"address"}],name:"FacilitatorRemoved",type:"event"}];var Ve=class{static parse(t){let{topics:e,data:r}=t.log,i=Oo.toHex(r);try{let{eventName:a,args:n}=Bo({abi:Ue,topics:e,data:i}),s=n.facilitatorAddress.toLowerCase();return{eventName:a,facilitator:s,key:`${a}:${s}`}}catch{return}}};var Ye=class{client;constructor(t){this.client=t.getWsProvider()}async getFacilitatorCapacity(t,e){let[r,i]=await this.client.readContract({abi:Ue,address:t,functionName:"getFacilitatorBucket",args:[e]});return r-i}};var{FeeUtils:Fr}=x,{H160:Gi}=Mo,Lo=["FacilitatorBucketCapacityUpdated","FacilitatorBucketLevelUpdated"],me=class extends N{ghoClient;stableClient;constructor(t,e,r,i){super(t,e,i),this.stableClient=r,this.ghoClient=new Ye(e)}getPoolType(){return"HSM"}getPoolId(t){return this.getPoolAddress("hsm:"+t)}getFacilitatorAddress(){return this.getPoolAddress("modlpy/hsmod")}getHollarAddress(t){if(t){let e=t.interior;if(e.type==="X1"&&e.value.type==="AccountKey20"){let{value:r}=e.value;return r.key}}throw Error("Invalid hollar multilocation")}getPoolAddress(t){let e=t.padEnd(32,"\0"),r=new TextEncoder().encode(e),i=Eo(r);return _o(Do).dec(i)}async isSupported(){return(await this.api.getStaticApis()).compat.query.HSM.Collaterals.isCompatible(Fo.BackwardsCompatible)}async loadPools(){let t=await this.api.constants.HSM.HollarId(),[e,r,i]=await Promise.all([this.api.query.AssetRegistry.AssetLocations.getValue(t,{at:this.at}),this.api.query.HSM.Collaterals.getEntries({at:this.at}),this.stableClient.getPools()]);if(r.length===0)return[];let a=this.getFacilitatorAddress(),n=Gi.fromAny(a),s=this.getHollarAddress(e),o=await this.ghoClient.getFacilitatorCapacity(s,n),l=r.map(async({keyArgs:u,value:d})=>{let[p]=u,{pool_id:g,max_buy_price_coefficient:b,max_in_holding:h,purchase_fee:y,buy_back_fee:f,buyback_rate:S}=d,P=i.find(w=>w.id===g);if(P){let w=this.getPoolId(g),v=await this.balance.getBalance(a,p);return{...P,address:w,type:"HSM",tokens:P.tokens.filter(_=>_.id!==g),hsmAddress:a,hsmMintCapacity:o,hollarId:t,hollarH160:s,collateralId:p,collateralBalance:v.transferable,maxBuyPriceCoefficient:b,maxInHolding:h,purchaseFee:Fr.fromPermill(y),buyBackFee:Fr.fromPermill(f),buyBackRate:Fr.fromPerbill(S)}}});return(await Promise.all(l)).filter(u=>u!==null)}async getPoolFees(){return{}}subscribeEvmLog(){return this.api.event.EVM.Log.watch().pipe(ko(({events:t})=>t),_r(({payload:t})=>Ve.parse(t)),Ni(t=>t!==void 0),Ni(({eventName:t})=>Lo.includes(t)),this.watchGuard("evm.Log")).subscribe(({eventName:t,facilitator:e})=>{this.log.trace(`evm.Log.${t}`,e),this.store.update(async r=>{let i=[],[{hsmAddress:a,hollarH160:n}]=r,s=Gi.fromAny(a);if(s.toLowerCase()===e){let l=await this.ghoClient.getFacilitatorCapacity(n,s);for(let c of r)i.push({...c,hsmMintCapacity:l})}return i})})}subscribeCollateralBalance(){let t=[],e=[];this.store.pools.forEach(a=>{let{tokens:n,collateralId:s}=a;n.find(l=>l.id===s).type==="Erc20"?e.push(s):t.push(s)});let[{hsmAddress:r}]=this.store.pools,i=[];if(t.length>0){let a=this.balance.watchTokensBalance(r);i.push(a)}if(e.length>0){let a=this.balance.watchErc20Balance(r,e);i.push(a)}return i.length>0?Ro(i).pipe(_r(a=>a.flat()),Co(),_r(([a,n])=>this.balance.getDeltas(a,n)),this.watchGuard("balances")).subscribe(a=>{this.store.update(n=>{let s=[],o=new Map(n.map(l=>[l.collateralId,l]));return a.forEach(({id:l,balance:c})=>{let u=o.get(l);u&&(this.log.trace("balances",{id:l,balance:c}),s.push({...u,collateralBalance:c.transferable}))}),s})}):Br.EMPTY}subscribeStableswapUpdates(){return this.stableClient.getSubscriber().pipe(this.watchGuard("stableswap.updates")).subscribe(t=>{let e=new Map(t.map(r=>[r.id,r]));this.store.update(r=>{let i=[];for(let a of r){let n=e.get(a.id);n&&i.push({...a,fee:n.fee,tokens:n.tokens.filter(s=>s.id!==a.id),totalIssuance:n.totalIssuance,pegs:n.pegs,amplification:n.amplification,isRampPeriod:n.isRampPeriod})}return i})})}subscribeBalances(){return Br.EMPTY}subscribeUpdates(){let t=new Br;return t.add(this.subscribeCollateralBalance()),t.add(this.subscribeStableswapUpdates()),t.add(this.subscribeEvmLog()),t}};var Rt=class{static get(t){switch(t.type){case"Aave":return le.fromPool(t);case"XYK":return se.fromPool(t);case"Omnipool":return te.fromPool(t);case"LBP":return jt.fromPool(t);case"Stableswap":return mt.fromPool(t);case"HSM":return ue.fromPool(t);default:throw new Error("Pool type "+t.type+" is not supported yet")}}};import{log as qo}from"@galacticcouncil/common";import{Subject as Ho,Subscription as pt,takeUntil as No}from"rxjs";var{logger:Go}=qo,kt=class extends E{evm;aave;omnipool;stableswap;hsm;xyk;lbp;active=new Set([]);pools=new Map([]);clients=[];aaveSub=pt.EMPTY;omniSub=pt.EMPTY;stableSub=pt.EMPTY;hsmSub=pt.EMPTY;xykSub=pt.EMPTY;lbpSub=pt.EMPTY;isReady=!1;isDestroyed=new Ho;constructor(t,e,r){super(t,r),this.evm=e,this.aave=new ce(t,e,r),this.omnipool=new ee(t,e,r),this.stableswap=new ne(t,e,r),this.hsm=new me(t,e,this.stableswap,r),this.xyk=new oe(t,e,r),this.lbp=new Zt(t,e,r),this.clients=[this.aave,this.omnipool,this.stableswap,this.hsm,this.xyk,this.lbp]}get isHistorical(){return this.at!=="best"&&this.at!=="finalized"}subscribe(t){return this.isHistorical?pt.EMPTY:t.getSubscriber().pipe(No(this.isDestroyed)).subscribe(e=>{e.forEach(r=>{this.pools.set(r.address,r)})})}withAave(){return this.aaveSub.unsubscribe(),this.aaveSub=this.subscribe(this.aave),this.active.add("Aave"),this}withOmnipool(){return this.omniSub.unsubscribe(),this.omniSub=this.subscribe(this.omnipool),this.active.add("Omnipool"),this}withStableswap(){return this.stableSub.unsubscribe(),this.stableSub=this.subscribe(this.stableswap),this.active.add("Stableswap"),this}withHsm(){return this.active.has("Stableswap")||(Go.info("[PoolContextProvider] auto-activating stableswap"),this.withStableswap()),this.hsmSub.unsubscribe(),this.hsmSub=this.subscribe(this.hsm),this.active.add("HSM"),this}withXyk(t){return this.xyk.withOverride(t),this.xykSub.unsubscribe(),this.xykSub=this.subscribe(this.xyk),this.active.add("XYK"),this}withLbp(){return this.lbpSub.unsubscribe(),this.lbpSub=this.subscribe(this.lbp),this.active.add("LBP"),this}destroy(){this.isDestroyed.next(!0),this.isDestroyed.complete(),this.active.clear(),this.pools.clear(),this.isReady=!1}async getPools(){if(this.isReady){let e=this.pools.values();return Array.from(e)}let t=await Promise.all(this.clients.filter(e=>this.active.has(e.getPoolType())).map(e=>e.getPools()));return this.isReady=!0,t.flat()}async getPoolFees(t,e){let r=this.clients.find(i=>i.getPoolType()===e.type);if(r)return r.getPoolFees(t,e.address);throw new st(e.type)}};var We=class{constructor(t){this.snapshot=t;let{aave:e,xyk:r,lbp:i,stable:a,omni:n}=t.pools;this.flat=[...e,...r,...i,...a,...n]}flat;async getPools(){return this.flat}async getPoolFees(t,e){let{block:r,states:i}=this.snapshot;switch(e.type){case"Aave":return{};case"XYK":{let{exchangeFee:a}=i.xyk;return{exchangeFee:a}}case"LBP":{let{repayFee:a}=i.lbp;return{exchangeFee:e.fee,repayFee:a}}case"Stableswap":return{fee:e.fee};case"Omnipool":{let a=t.assetOut,n=t.assetIn,{dynamicFees:s,emaOracles:o,assetFeeParams:l,protocolFeeParams:c,maxSlipFee:u}=i.omni,d=s.find(({asset:b})=>b===a)?.fee,p=o.find(({pair:b})=>b.join(":")===He(a))?.oracle,g=o.find(({pair:b})=>b.join(":")===He(n))?.oracle;return ut.compute(t,r,d,p,g,l,c,u)}default:throw new st(e.type)}}};var Xi={};A(Xi,{DCA_TIME_RESERVE:()=>Wi,DEFAULT_BLOCK_TIME:()=>Yi,DEFAULT_MIN_BUDGET:()=>Cr,ORDER_MIN_BLOCK_PERIOD:()=>$i,Router:()=>Ct,TWAP_EXECUTION_INTERVAL:()=>be,TWAP_MAX_DURATION:()=>Dr,TWAP_MAX_PRICE_IMPACT:()=>Mr,TWAP_TX_MULTIPLIER:()=>tP,TradeOrderError:()=>kr,TradeOrderType:()=>he,TradeRouteBuilder:()=>U,TradeRouter:()=>it,TradeScheduler:()=>Dt,TradeType:()=>$e});var pe=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 Uo=10,de=class{isNotVisited(t,e){let r=!0;return e.forEach(i=>{(i[0]===t[0]||i[1]===t[1])&&(r=!1)}),r}findPaths(t,e,r){let i=[],a=new pe,n=[];for(n.push([e,""]),a.enqueue(n);a.size()>0;){let s=a.dequeue();if(!s||s.length>Uo)continue;let o=s[s.length-1];(r===null||o[0]===r)&&i.push(s),t.get(o[0])?.forEach(c=>{if(this.isNotVisited(c,s)){let u=[...s];u.push(c),a.enqueue(u)}})}return i}findShortestPaths(t,e,r){let i=[],a=new pe,n=[];n.push([e,""]),a.enqueue(n);let s=1/0;for(;a.size()>0;){let o=a.dequeue();if(!o)continue;let l=o[o.length-1];if(l[0]===r){o.length<s?(s=o.length,i.length=0,i.push(o)):o.length===s&&i.push(o);continue}let c=t.get(l[0]);for(let u of c??[])this.isNotVisited(u,o)&&a.enqueue([...o,u])}return i}buildAndPopulateGraph(t,e){let r=new Map;for(let i of t)r.set(parseInt(i),[]);for(let[i,a,n]of e)r.get(a)?.push([n,i]);return r}};function Rr(m){let t={};for(let e of m){let r=e.tokens.length;for(let i=0;i<r;i++){t[e.tokens[i].id]||(t[e.tokens[i].id]=[]);for(let a=0;a<r;a++){if(i==a)continue;let n=[e.address,e.tokens[i].id,e.tokens[a].id];t[e.tokens[i].id].push(n)}}}return t}var ge=class{getProposals(t,e,r){let i=r.filter(h=>h.type==="XYK"),a=r.filter(h=>h.type!=="XYK"),n=new Set(a.map(h=>h.tokens).flat().map(h=>h.id)),s=n.has(t),o=n.has(e),l=new de,c=h=>{let y=Rr(h),f=Object.keys(y),S=f.flatMap(P=>y[P]);return l.buildAndPopulateGraph(f,S)};if(!s&&!o){let h=i.filter(S=>S.tokens.find(P=>P.id===t)||S.tokens.find(P=>P.id===e)),y=c(h),f=l.findPaths(y,t,e);return this.parsePaths(f)}if(s&&o){let h=c(a),y=l.findPaths(h,t,e);return this.parsePaths(y)}let u=s?e:t,d=i.filter(h=>h.tokens.some(y=>y.id===u));if(d.length===0)return[];let p=[...a,...d],g=c(p),b=l.findPaths(g,t,e);return this.parsePaths(b)}parsePaths(t){let e=[];for(let r of t){let i=[];for(let a=0;a<r.length;a++){let n=r[a],s=r[a+1];if(s==null)break;i.push(this.toEdge(n,s))}e.push(i)}return e}toEdge(t,e){return[e[1],t[0],e[0]]}};var Ct=class{routeSuggester;routeProposals;ctx;filter={};constructor(t){this.ctx=t,this.routeSuggester=new ge,this.routeProposals=new Map}async withFilter(t){this.filter=t||{},this.routeProposals.clear(),this.onFilterChanged()}onFilterChanged(){}buildRouteKey(t,e,r){return`${t}->${e}::${r.length}`}applyPoolFilter(t){let{useOnly:e=[],exclude:r=[]}=this.filter,i=new Set(e),a=new Set(r);return t.filter(n=>a.has(n.type)?!1:i.size>0?i.has(n.type):!0)}async getPools(){let t=await this.ctx.getPools();return this.applyPoolFilter(t)}async getRoutes(t,e){let r=await this.getPools();return this.validateInput(t,e,r),this.getPaths(t,e,r)}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(i=>i!==t).map(i=>this.getRoutes(i,t)))).filter(i=>i.length>0).map(([i])=>i[0].assetIn).sort()}validateInput(t,e,r){if(r.length===0)throw new Error("No pools configured");if(t===e)throw new Error("Trading pair can't be identical");let i=this.getAssets(r);if(!i.has(t))throw new Error(t+" is not supported asset");if(!i.has(e))throw new Error(e+" is not supported asset");return this.toPoolsMap(r)}getAssets(t){let e=t.map(r=>r.tokens.map(i=>i.id)).flat().sort((r,i)=>r>i?1:-1);return new Set(e)}getPaths(t,e,r){let i=this.toPoolsMap(r);return this.getProposals(t,e,r).filter(n=>this.validPath(n,i)).map(n=>this.toHops(n,i))}getProposals(t,e,r){let i=this.buildRouteKey(t,e,r);if(this.routeProposals.has(i))return this.routeProposals.get(i);let a=this.routeSuggester.getProposals(t,e,r);return this.routeProposals.set(i,a),a}validPath(t,e){return t.length>0&&t.map(r=>this.validEdge(r,e)).reduce((r,i)=>r&&i)}validEdge([t,e,r],i){return i.get(t)?.validatePair(e,r)||!1}toPoolsMap(t){return new Map(t.map(e=>[e.address,Rt.get(e)]))}toHops(t,e){return t.map(([r,i,a])=>{let n=e.get(r);return{poolAddress:r,poolId:n?.id,pool:n?.type,assetIn:i,assetOut:a}})}};import{big as C,RUNTIME_DECIMALS as Mt}from"@galacticcouncil/common";var $e=(e=>(e.Buy="Buy",e.Sell="Sell",e))($e||{}),he=(r=>(r.Dca="Dca",r.TwapSell="TwapSell",r.TwapBuy="TwapBuy",r))(he||{}),kr=(r=>(r.OrderTooSmall="OrderTooSmall",r.OrderTooBig="OrderTooBig",r.OrderImpactTooBig="OrderImpactTooBig",r))(kr||{});var{FeeUtils:Vi}=x,it=class extends Ct{mlr;constructor(t){super(t),this.mlr=new Map}onFilterChanged(){this.mlr.clear()}buildCtxSync(t,e,r){let i=super.validateInput(t,e,r),a=super.getPaths(t,e,r);if(!a.length)throw new Yt(t,e);return{paths:a,pools:r,poolsMap:i}}async withCtx(t,e,r){let i=await super.getPools(),a=this.buildCtxSync(t,e,i);return r(a)}isDirectTrade(t){return t.length==1}findBestSellRoute(t){let e=t.sort((r,i)=>{let a=r[r.length-1].amountOut,n=i[i.length-1].amountOut;return a>n?-1:1});return e.find(r=>r.every(i=>i.errors.length==0))||e[0]}getRouteFeeRange(t){if(t.filter(r=>r.tradeFeeRange).length>0){let r=t.map(a=>a.tradeFeeRange?.[0]??a.tradeFeePct).reduce((a,n)=>a+n),i=t.map(a=>a.tradeFeeRange?.[1]??a.tradeFeePct).reduce((a,n)=>a+n);return[r,i]}}getPoolFeeRange(t,e){let r=t.min?Vi.toPct(t.min):void 0,i=t.max?Vi.toPct(t.max):void 0;if(r&&i)return[r,Math.max(i,e)]}async getBestSell(t,e,r){return this.getSell(t,e,r)}getSellSpot(t){let e=t[t.length-1];return t.length===1?e.spotPrice:this.calculateSpot(t)}async getSell(t,e,r,i){return this.withCtx(t,e,async({paths:a,poolsMap:n})=>{let s;if(i)s=await this.toSellSwaps(r,i,n);else{let o=a.map(c=>this.toSellSwaps(r,c,n)),l=await Promise.all(o);s=this.findBestSellRoute(l)}return this.buildSell(n,s)})}async getSells(t,e,r){return this.withCtx(t,e,async({paths:i,poolsMap:a})=>{let n=i.map(o=>this.toSellSwaps(r,o,a));return(await Promise.all(n)).filter(o=>o.every(l=>l.errors.length==0)).map(o=>this.buildSell(a,o)).sort((o,l)=>o.amountOut>l.amountOut?-1:1)})}buildSell(t,e){let r=e[0],i=e[e.length-1],a=this.isDirectTrade(e),n=this.getSellSpot(e),s=i.amountOut,o=a?i.calculatedOut:this.calculateDelta0Y(r.amountIn,e,t),l=o-s,c=this.getRouteFeeRange(e),u=a?i.tradeFeePct:L.calculateSellFee(o,s),d=B.mulSpot(r.amountIn,n,r.assetInDecimals,i.assetOutDecimals),p=L.calculateDiffToRef(o,d);return{type:"Sell",amountIn:r.amountIn,amountOut:i.amountOut,spotPrice:n,tradeFee:l,tradeFeePct:u,tradeFeeRange:c,priceImpactPct:p,swaps:e,toHuman(){return{type:"Sell",amountIn:C.toDecimal(r.amountIn,r.assetInDecimals),amountOut:C.toDecimal(i.amountOut,i.assetOutDecimals),spotPrice:C.toDecimal(n,Mt),tradeFee:C.toDecimal(l,i.assetOutDecimals),tradeFeePct:u,tradeFeeRange:c,priceImpactPct:p,swaps:e.map(g=>g.toHuman())}}}}calculateSpot(t){return t.map(e=>e.spotPrice).reduce((e,r)=>e*r/10n**BigInt(Mt))}calculateDelta0Y(t,e,r){let i=[];for(let a=0;a<e.length;a++){let n=e[a],s=r.get(n.poolAddress);if(s==null)throw new Error("Pool does not exit");let o=s.parsePair(n.assetIn,n.assetOut),l;a>0?l=i[a-1]:l=t;let c=s.calculateOutGivenIn(o,l);i.push(c)}return i[i.length-1]}async calculateMostLiquidRoute(t,e,r){let{paths:i,pools:a,poolsMap:n}=r,l=a.filter(b=>b.tokens.some(h=>h.id===t)).map(b=>b.type==="Aave"?b.tokens:b.tokens.filter(h=>h.id===t)).map(b=>b.map(h=>h.balance).reduce((h,y)=>h+y)).sort((b,h)=>h<b?-1:1)[0],c=B.getFraction(l,.1),u=await Promise.all(i.map(b=>this.toSellSwaps(c,b,n))),p=this.findBestSellRoute(u).map(b=>({poolAddress:b.poolAddress,poolId:b?.poolId,pool:b.pool,assetIn:b.assetIn,assetOut:b.assetOut})),g=this.buildRouteKey(t,e,a);return this.mlr.set(g,p),p}async toSellSwaps(t,e,r){let i=[];for(let a=0;a<e.length;a++){let n=e[a],s=r.get(n.poolAddress);if(s==null)throw new Error("Pool does not exit");let o=s.parsePair(n.assetIn,n.assetOut),l;a>0?l=i[a-1].amountOut:l=typeof t=="string"?C.toBigInt(t,o.decimalsIn):t;let c=await this.ctx.getPoolFees(o,s),{amountOut:u,calculatedOut:d,feePct:p,errors:g}=s.validateAndSell(o,l,c),b=this.getPoolFeeRange(c,p),h=s.spotPriceOutGivenIn(o),y=B.mulSpot(l,h,o.decimalsIn,o.decimalsOut),f=L.calculateDiffToRef(d,y);i.push({...n,assetInDecimals:o.decimalsIn,assetOutDecimals:o.decimalsOut,amountIn:l,amountOut:u,calculatedOut:d,spotPrice:h,tradeFeePct:p,tradeFeeRange:b,priceImpactPct:f,errors:g,isSupply(){return s.type==="Aave"&&s.tokens[0].id===n.assetIn},isWithdraw(){return s.type==="Aave"&&s.tokens[1].id===n.assetIn},toHuman(){return{...n,amountIn:C.toDecimal(l,o.decimalsIn),amountOut:C.toDecimal(u,o.decimalsOut),calculatedOut:C.toDecimal(d,o.decimalsOut),spotPrice:C.toDecimal(h,Mt),tradeFeePct:p,tradeFeeRange:b,priceImpactPct:f,errors:g}}})}return i}async getMostLiquidRoute(t,e){return this.withCtx(t,e,async r=>{let i=this.buildRouteKey(t,e,r.pools),a=this.mlr.get(i);return a||this.calculateMostLiquidRoute(t,e,r)})}async getSpotPrice(t,e){return this.withCtx(t,e,async r=>{let{pools:i,poolsMap:a}=r,n=this.buildRouteKey(t,e,i),s=this.mlr.get(n);s||(s=await this.calculateMostLiquidRoute(t,e,r));let o=await this.toSellSwaps("1",s,a);return{amount:this.getSellSpot(o),decimals:Mt}}).catch(()=>{})}findBestBuyRoute(t){let e=t.sort((r,i)=>{let a=r[0].amountIn,n=i[0].amountIn;return a>n?1:-1});return e.find(r=>r.every(i=>i.errors.length==0))||e[0]}async getBestBuy(t,e,r){return this.getBuy(t,e,r)}getBuySpot(t){let e=t[0];return t.length===1?e.spotPrice:this.calculateSpot(t)}async getBuy(t,e,r,i){return this.withCtx(t,e,async({paths:a,poolsMap:n})=>{let s;if(i)s=await this.toBuySwaps(r,i,n);else{let o=a.map(c=>this.toBuySwaps(r,c,n)),l=await Promise.all(o);s=this.findBestBuyRoute(l)}return this.buildBuy(n,s)})}async getBuys(t,e,r){return this.withCtx(t,e,async({paths:i,poolsMap:a})=>{let n=i.map(o=>this.toBuySwaps(r,o,a));return(await Promise.all(n)).filter(o=>o.every(l=>l.errors.length==0)).map(o=>this.buildBuy(a,o)).sort((o,l)=>o.amountIn>l.amountIn?1:-1)})}buildBuy(t,e){let r=e[e.length-1],i=e[0],a=this.isDirectTrade(e),n=this.getBuySpot(e),s=i.amountIn,o=a?i.calculatedIn:this.calculateDelta0X(r.amountOut,e,t),l=s-o,c=this.getRouteFeeRange(e),u=a?i.tradeFeePct:L.calculateBuyFee(o,s),d=B.mulSpot(r.amountOut,n,r.assetOutDecimals,i.assetInDecimals),p;return o===0n?p=-100:p=L.calculateDiffToRef(d,o),{type:"Buy",amountOut:r.amountOut,amountIn:i.amountIn,spotPrice:n,tradeFee:l,tradeFeePct:u,tradeFeeRange:c,priceImpactPct:p,swaps:e,toHuman(){return{type:"Buy",amountOut:C.toDecimal(r.amountOut,r.assetOutDecimals),amountIn:C.toDecimal(i.amountIn,i.assetInDecimals),spotPrice:C.toDecimal(n,Mt),tradeFee:C.toDecimal(l,i.assetInDecimals),tradeFeePct:u,tradeFeeRange:c,priceImpactPct:p,swaps:e.map(g=>g.toHuman())}}}}calculateDelta0X(t,e,r){let i=[];for(let a=e.length-1;a>=0;a--){let n=e[a],s=r.get(n.poolAddress);if(s==null)throw new Error("Pool does not exit");let o=s.parsePair(n.assetIn,n.assetOut),l;a==e.length-1?l=t:l=i[0];let c=s.calculateInGivenOut(o,l);i.unshift(c)}return i[0]}async toBuySwaps(t,e,r){let i=[];for(let a=e.length-1;a>=0;a--){let n=e[a],s=r.get(n.poolAddress);if(s==null)throw new Error("Pool does not exit");let o=s.parsePair(n.assetIn,n.assetOut),l;a==e.length-1?l=typeof t=="string"?C.toBigInt(t,o.decimalsOut):t:l=i[0].amountIn;let c=await this.ctx.getPoolFees(o,s),{amountIn:u,calculatedIn:d,feePct:p,errors:g}=s.validateAndBuy(o,l,c),b=this.getPoolFeeRange(c,p),h=s.spotPriceInGivenOut(o),y=B.mulSpot(l,h,o.decimalsOut,o.decimalsIn),f;d===0n?f=-100:f=L.calculateDiffToRef(y,d),i.unshift({...n,assetInDecimals:o.decimalsIn,assetOutDecimals:o.decimalsOut,amountOut:l,amountIn:u,calculatedIn:d,spotPrice:h,tradeFeePct:p,tradeFeeRange:b,priceImpactPct:f,errors:g,isSupply(){return s.type==="Aave"&&s.tokens[0].id===n.assetIn},isWithdraw(){return s.type==="Aave"&&s.tokens[1].id===n.assetIn},toHuman(){return{...n,amountOut:C.toDecimal(l,o.decimalsOut),amountIn:C.toDecimal(u,o.decimalsIn),calculatedIn:C.toDecimal(d,o.decimalsIn),spotPrice:C.toDecimal(h,Mt),tradeFeePct:p,tradeFeeRange:b,priceImpactPct:f,errors:g}}})}return i}};import{big as F}from"@galacticcouncil/common";var Yi=6e3,Cr=1000000000000000n,be=6,Mr=-5,Dr=216e5,tP=3,Wi=.1,$i=6;import{Enum as zi}from"polkadot-api";var U=class{static build(t){return t.map(({assetIn:e,assetOut:r,pool:i,poolId:a})=>i==="Stableswap"?{pool:zi("Stableswap",a),asset_in:e,asset_out:r}:{pool:zi(i),asset_in:e,asset_out:r})}};var Dt=class{schedulerOptions;router;constructor(t,e={}){this.router=new it(t),this.router.withFilter({exclude:["HSM"]}),this.schedulerOptions=Object.freeze({blockTime:e.blockTime??6e3,minBudgetInNative:e.minBudgetInNative??Cr})}get blockTime(){return this.schedulerOptions.blockTime}get minOrderBudget(){return this.schedulerOptions.minBudgetInNative}async getDcaOrder(t,e,r,i,a){let n=await this.router.getBestSell(t,e,r),{amountIn:s,swaps:o,priceImpactPct:l}=n,c=o[0],u=o[o.length-1],{assetInDecimals:d}=c,{assetOutDecimals:p}=u,g=Math.abs(l),b=await this.getMinimumOrderBudget(t,d),h=this.getOptimalTradeCount(g),y=this.getMaximumTradeCount(s,b,i),f=a||Math.min(h,y),S=Math.round(i/f),P=s/BigInt(f),w=await this.router.getBestSell(t,e,P),v=s<b,_=[];v&&_.push("OrderTooSmall");let H=await this.getAssetOutEd(u),M=w.amountOut*BigInt(f),j=this.toBlockPeriod(S),G=w.tradeFee*BigInt(f),$=U.build(o),tt={assetIn:t,assetOut:e,assetOutEd:H,errors:_,maxTradeCount:y,tradeCount:f,tradeFee:G,tradeImpactPct:w.priceImpactPct,tradePeriod:j,tradeRoute:$,type:"Dca"};return{...tt,amountIn:s,amountOut:M,tradeAmountIn:w.amountIn,tradeAmountOut:w.amountOut,toHuman(){return{...tt,amountIn:F.toDecimal(s,d),amountOut:F.toDecimal(M,p),assetOutEd:F.toDecimal(H,p),tradeAmountIn:F.toDecimal(w.amountIn,d),tradeAmountOut:F.toDecimal(w.amountOut,p)}}}}async getMinimumOrderBudget(t,e){if(0===t)return this.minOrderBudget;let r=await this.router.getSpotPrice(0,t);if(r)return B.mulSpot(this.minOrderBudget,r.amount,12,e);let i=await this.router.getSpotPrice(t,0);if(i)return B.divSpot(this.minOrderBudget,i.amount,12,e);throw new Error("Unable to calculate order budget")}getMaximumTradeCount(t,e,r){let i=e*2n/10n;if(i===0n)return 0;let a=Number(t/i),n=Math.floor(r/this.blockTime),s=Math.max(0,Math.floor(n*(1-.1)));return Math.min(a,s)}getOptimalTradeCount(t){let e=Math.round(t*10)||1;return Math.max(e,3)}async getOpenBudgetDcaOrder(t,e,r,i){let a=await this.router.getBestSell(t,e,r),{swaps:n}=a,s=n[0],o=n[n.length-1],{assetInDecimals:l}=s,{assetOutDecimals:c}=o,u=await this.getMinimumOrderBudget(t,l),d=a.amountIn<u,p=[];d&&p.push("OrderTooSmall");let g=await this.getAssetOutEd(o),b=this.toBlockPeriod(i),h=U.build(n),y={assetIn:t,assetOut:e,assetOutEd:g,errors:p,maxTradeCount:0,tradeCount:0,tradeFee:a.tradeFee,tradeImpactPct:a.priceImpactPct,tradePeriod:b,tradeRoute:h,type:"Dca"};return{...y,amountIn:0n,amountOut:0n,tradeAmountIn:a.amountIn,tradeAmountOut:a.amountOut,toHuman(){return{...y,amountIn:"0",amountOut:"0",assetOutEd:F.toDecimal(g,c),tradeAmountIn:F.toDecimal(a.amountIn,l),tradeAmountOut:F.toDecimal(a.amountOut,c)}}}}async getTwapSellOrder(t,e,r){let i=await this.router.getBestSell(t,e,r),{amountIn:a,swaps:n,priceImpactPct:s}=i,o=n[0],l=n[n.length-1],{assetInDecimals:c}=o,{assetOutDecimals:u}=l,d=Math.abs(s),p=this.getTwapTradeCount(d),g=a/BigInt(p),[b,h]=await Promise.all([this.getMinimumOrderBudget(t,c),this.router.getBestSell(o.assetIn,l.assetOut,g)]),y=p===1,f=a<b,S=h.priceImpactPct<-5,P=[];f||y?P.push("OrderTooSmall"):S&&P.push("OrderImpactTooBig");let w=await this.getAssetOutEd(l),v=h.amountOut*BigInt(p),_=h.tradeFee*BigInt(p),H=U.build(n),M={assetIn:t,assetOut:e,assetOutEd:w,errors:P,tradeCount:p,tradeImpactPct:h.priceImpactPct,tradePeriod:6,tradeRoute:H,type:"TwapSell"};return{...M,amountIn:a,amountOut:v,tradeAmountIn:h.amountIn,tradeAmountOut:h.amountOut,tradeFee:_,toHuman(){return{...M,amountIn:F.toDecimal(a,c),amountOut:F.toDecimal(v,u),assetOutEd:F.toDecimal(w,u),tradeAmountIn:F.toDecimal(h.amountIn,c),tradeAmountOut:F.toDecimal(h.amountOut,u),tradeFee:F.toDecimal(_,u)}}}}async getTwapBuyOrder(t,e,r){let i=await this.router.getBestBuy(t,e,r),{amountOut:a,swaps:n,priceImpactPct:s}=i,o=n[0],l=n[n.length-1],{assetInDecimals:c}=o,{assetOutDecimals:u}=l,d=Math.abs(s),p=this.getTwapTradeCount(d),g=a/BigInt(p),[b,h]=await Promise.all([this.getMinimumOrderBudget(t,c),this.router.getBestBuy(o.assetIn,l.assetOut,g)]),y=h.amountIn*BigInt(p),f=p===1,S=y<b,P=h.priceImpactPct<-5,w=[];S||f?w.push("OrderTooSmall"):P&&w.push("OrderImpactTooBig");let v=await this.getAssetOutEd(l),_=h.tradeFee*BigInt(p),H=U.build(n),M={assetIn:t,assetOut:e,assetOutEd:v,errors:w,tradeCount:p,tradeImpactPct:h.priceImpactPct,tradePeriod:6,tradeRoute:H,type:"TwapBuy"};return{...M,amountIn:y,amountOut:a,tradeAmountIn:h.amountIn,tradeAmountOut:h.amountOut,tradeFee:_,toHuman(){return{...M,amountIn:F.toDecimal(y,c),amountOut:F.toDecimal(a,u),assetOutEd:F.toDecimal(v,u),tradeAmountIn:F.toDecimal(h.amountIn,c),tradeAmountOut:F.toDecimal(h.amountOut,u),tradeFee:F.toDecimal(_,c)}}}}getTwapTradeCount(t){let e=this.getOptimalTradeCount(t);if(this.getTwapExecutionTime(e)>216e5){let i=216e5/(this.blockTime*6);return Math.round(i)}return e}getTwapExecutionTime(t){return t*6*this.blockTime}toBlockPeriod(t){let e=t/this.blockTime,r=Math.round(e);return Math.max(r,6)}async getAssetOutEd(t){let i=(await this.router.getPools()).find(a=>a.address===t.poolAddress)?.tokens.find(a=>a.id===t.assetOut);if(!i)throw new Error(`Asset ${t.assetOut} not found in pool ${t.poolAddress}`);return i.existentialDeposit}};var ra={};A(ra,{BIG_10:()=>ta,BIG_BILL:()=>Lr,StakingApi:()=>ye,StakingClient:()=>fe});import{calculate_accumulated_rps as $o,calculate_percentage_amount as zo,calculate_period_number as Qi,calculate_points as Ji,calculate_rewards as Xo,sigmoid as Zi}from"@galacticcouncil/math-staking";import Y from"big.js";var ze={none:.1,locked1x:1,locked2x:2,locked3x:3,locked4x:4,locked5x:5,locked6x:6},Ki=m=>Object.keys(ze).includes(m);import{AccountId as Vo}from"polkadot-api";import{toHex as Yo}from"@polkadot-api/utils";import{HYDRATION_SS58_PREFIX as Wo}from"@galacticcouncil/common";function ji(m){let t=("modl"+m).padEnd(32,"\0"),e=new TextEncoder().encode(t),r=Yo(e);return Vo(Wo).dec(r)}var Xe="20000000000000000",Ke="2000",ta=Y(10),Lr=Y(ta.pow(12)),ye=class{client;balance;constructor(t,e){this.client=t,this.balance=e}async getPotBalance(){let t=await this.client.getPalletId(),e=ji(t);return await this.balance.getBalance(e,0)}async getStakingPosition(t){let[e,r]=await Promise.all([this.client.getStakingPositionsValue(t),this.client.getStakingVotes(t)]);if(!e)return;let i=e.created_at,a=await r.reduce(async(n,[s,o])=>{let l=await n,c=s,u=o.amount,d=o.conviction.type.toLowerCase(),p=await this.client.getReferendumInfo(c);return p&&(p.type==="Approved"||p.type==="Rejected")&&Ki(d)&&l.push({id:c,amount:u,conviction:d}),l},Promise.resolve([]));return{stake:e.stake,rewardPerStake:e.reward_per_stake,createdAt:i,actionPoints:e.action_points,accumulatedUnpaidRewards:e.accumulated_unpaid_rewards,accumulatedSlashPoints:e.accumulated_slash_points,accumulatedLockedRewards:e.accumulated_locked_rewards,votes:a}}async getStake(t){let e=await this.client.getNFTCollectionId(),[r,i]=await Promise.all([this.client.getStaking(),this.client.getUniques(t,e)]),a=i.find(n=>n)?.itemId;return{totalStake:r?.total_stake,accumulatedRewardPerStake:r?.accumulated_reward_per_stake,potReservedBalance:r?.pot_reserved_balance,positionId:a,stakePosition:a?await this.getStakingPosition(a):void 0}}getCurrentActionPoints(t,e,r,i){let a=Y(0),n=Y(0),s=ze.locked6x,o=Y(r.toString()).mul(s),l=100,c=[];t.forEach(p=>{let g=ze[p.conviction],b=i.includes(p.id.toString());b&&c.push(p.id.toString());let h=Y(p.amount.toString()).mul(l).div(o);a=a.plus(Math.floor(h.mul(g).toNumber())),n=n.plus(Math.floor(h.mul(b?s:g).toNumber()))});let u=Math.floor(Y(r.toString()).mul(s).mul(l).div(o).toNumber());i.forEach(p=>{c.includes(p)||(n=n.plus(u))});let d={democracyVote:1};return a=a.mul(d.democracyVote),a=a.plus(e.toString()||"0"),n=n.mul(d.democracyVote),n=n.plus(e.toString()||"0"),{currentActionPoints:a.toString(),maxActionPoints:n.toString()}}async getRewards(t,e,r){let i=await this.getStake(t),{potReservedBalance:a,accumulatedRewardPerStake:n,totalStake:s,stakePosition:o}=i;if(!o)return;let[l,c,u,d,p,g,b]=await Promise.all([this.getPotBalance(),this.client.getPeriodLength(),this.client.getUnclaimablePeriods(),this.client.getTimePointsPerPeriod(),this.client.getTimePointsWeight(),this.client.getActionPointsWeight(),this.client.getSixBlockSince()]),h=Y(l.transferable.toString()).minus(a.toString()),y=h.gt(0)&&s>0?$o(n.toString(),h.toString(),s.toString()):n.toString(),f=Qi(c.toString(),r,b),S=Qi(c.toString(),o.createdAt.toString(),b),P=Xo(y,o.rewardPerStake.toString(),o.stake.toString()),w=this.getCurrentActionPoints(o.votes,o.actionPoints,o.stake,e),v=Ji(S,f,d.toString(),p.toString(),w.currentActionPoints,g.toString(),o.accumulatedSlashPoints.toString()),_=Zi(v,Xe,Ke),H=(()=>{if(!e.length)return;let tt=Ji(S,f,d.toString(),p.toString(),w.maxActionPoints.toString(),g.toString(),o.accumulatedSlashPoints.toString());return Zi(tt,Xe,Ke)})(),M=Y(P).plus(o.accumulatedUnpaidRewards.toString()).plus(o.accumulatedLockedRewards.toString());if(Y(f).minus(S).lte(u.toString()))return{rewards:"0",payablePercentage:_,extraPayablePercentage:H,constants:{a:Xe,b:Ke}};let j=zo(M.toString(),_),G=Y(o.accumulatedLockedRewards.toString()),$=G.gt(j)?G:Y(j);return{rewards:$.div(Lr).toString(),maxRewards:M.div(Lr).toString(),allocatedRewardsPercentage:$.div(M).mul(100).toNumber(),points:v,payablePercentage:_,extraPayablePercentage:H,constants:{a:Xe,b:Ke}}}};import{Binary as ea}from"polkadot-api";var fe=class extends E{async getPalletId(){let t=this.api.constants.Staking.PalletId,e=await t();return ea.toText(ea.fromHex(e))}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:n})=>{let[s,o,l]=n;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 getTimePointsPerPeriod(){let t=this.api.constants.Staking.TimePointsPerPeriod;return await t()}async getTimePointsWeight(){let t=this.api.constants.Staking.TimePointsWeight;return await t()/1e6}async getActionPointsWeight(){let t=this.api.constants.Staking.ActionPointsWeight;return await t()/1e9}async getSixBlockSince(){return(await this.api.query.Staking.SixSecBlocksSince.getValue()).toString()}};var sa={};A(sa,{TxBuilderFactory:()=>Lt});import{Enum as aa}from"polkadot-api";function ia(m){let t=[],e=m;for(;e&&typeof e=="object"&&"type"in e;)t.push(e.type),e=e.value;return t.join(".")}var W=class extends E{evm;evmClient;balance;aaveUtils;constructor(t,e,r){super(t,r),this.evm=e,this.evmClient=e.getWsProvider(),this.balance=new X(t,r),this.aaveUtils=new nt(e)}wrapTx(t,e){return{name:t,get:()=>e,dryRun:r=>this.dryRun(r,e)}}async dispatchWithExtraGas(t){return this.api.tx.Dispatcher.dispatch_with_extra_gas({call:t.decodedCall,extra_gas:nr})}async dryRun(t,e){let r=aa("Signed",t),i=aa("system",r),n=await this.client.getUnsafeApi().apis.DryRunApi.dry_run_call(i,e.decodedCall,4,{at:this.at}),s=n.success&&!n.value.execution_result.success?n.value.execution_result.value.error:null;if(s){let o=s.type==="Module"?ia(s.value):s.type;throw new Error("Dry run execution error!",{cause:o})}return n}isDirectOmnipoolTrade(t){return t.length===1&&t[0].pool==="Omnipool"}};var je=class extends W{_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:r}=this.trade;if(r==="Buy")return this.buildBuyTx();let{assetIn:i}=e[0],a=await this.balance.getBalance(this.beneficiary,i);return t>=a.transferable-5n?this.buildSellAllTx():this.buildSellTx()}async buildBuyTx(){let{amountIn:t,amountOut:e,swaps:r}=this.trade,i=r[0],a=r[r.length-1],n=B.getFraction(t,this.slippagePct),s=i.assetIn,o=a.assetOut,l=t+n,c;return this.isDirectOmnipoolTrade(r)?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:U.build(r)}),await this.aaveUtils.hasBorrowPositions(this.beneficiary)&&(c=await this.dispatchWithExtraGas(c)),this.wrapTx("RouterBuy",c)}async buildSellTx(){let{amountIn:t,amountOut:e,swaps:r}=this.trade,i=r[0],a=r[r.length-1],n=B.getFraction(e,this.slippagePct),s=i.assetIn,o=a.assetOut,l=e-n,c;return this.isDirectOmnipoolTrade(r)?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:U.build(r)}),await this.aaveUtils.hasBorrowPositions(this.beneficiary)&&(c=await this.dispatchWithExtraGas(c)),this.wrapTx("RouterSell",c)}async buildSellAllTx(){let{amountOut:t,swaps:e}=this.trade,r=e[0],i=e[e.length-1],a=B.getFraction(t,this.slippagePct),n=r.assetIn,s=i.assetOut,o=t-a,l=this.api.tx.Router.sell_all({asset_in:n,asset_out:s,min_amount_out:o,route:U.build(e)});return await this.aaveUtils.hasBorrowPositions(this.beneficiary)&&(l=await this.dispatchWithExtraGas(l)),this.wrapTx("RouterSellAll",l)}};import{Enum as qr}from"polkadot-api";var Qe=class extends W{_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}`)}}async buildDcaTx(){let{amountIn:t,assetIn:e,assetOut:r,tradeAmountIn:i,tradePeriod:a,tradeRoute:n}=this.order,s=this.api.tx.DCA.schedule({schedule:{owner:this.beneficiary,period:a,max_retries:this.maxRetries,total_amount:t,slippage:this.slippagePct*1e4,stability_threshold:void 0,order:qr("Sell",{asset_in:e,asset_out:r,amount_in:i,min_amount_out:0n,route:n})},start_execution_block:void 0});return await this.aaveUtils.hasBorrowPositions(this.beneficiary)&&(s=await this.dispatchWithExtraGas(s)),this.wrapTx("DcaSchedule",s)}async buildTwapSellTx(){let{amountIn:t,assetIn:e,assetOut:r,tradeAmountIn:i,tradeAmountOut:a,tradePeriod:n,tradeRoute:s}=this.order,o=B.getFraction(a,this.slippagePct),l=a-o,c=this.api.tx.DCA.schedule({schedule:{owner:this.beneficiary,period:n,max_retries:this.maxRetries,total_amount:t,slippage:this.slippagePct*1e4,stability_threshold:void 0,order:qr("Sell",{asset_in:e,asset_out:r,amount_in:i,min_amount_out:l,route:s})},start_execution_block:void 0});return await this.aaveUtils.hasBorrowPositions(this.beneficiary)&&(c=await this.dispatchWithExtraGas(c)),this.wrapTx("DcaSchedule.twapSell",c)}async buildTwapBuyTx(){let{amountIn:t,assetIn:e,assetOut:r,tradeAmountIn:i,tradeAmountOut:a,tradePeriod:n,tradeRoute:s}=this.order,o=B.getFraction(i,this.slippagePct),l=i+o,c=this.api.tx.DCA.schedule({schedule:{owner:this.beneficiary,period:n,max_retries:this.maxRetries,total_amount:t,slippage:this.slippagePct*1e4,stability_threshold:void 0,order:qr("Buy",{asset_in:e,asset_out:r,amount_out:a,max_amount_in:l,route:s})},start_execution_block:void 0});return await this.aaveUtils.hasBorrowPositions(this.beneficiary)&&(c=await this.dispatchWithExtraGas(c)),this.wrapTx("DcaSchedule.twapBuy",c)}};import{Enum as Ko}from"polkadot-api";var Je=class extends W{_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,amountOut:e,swaps:r}=this.trade,i=r[0],a=r[r.length-1],n=i.assetIn,s=a.assetOut,o=B.getFraction(e,this.slippagePct),l=e-o,c=Ko("Swap",{asset_in:n,asset_out:s,amount_in:t,amount_out:l,partial:!1}),u=this.apiIce.tx.Intent.submit_intent({intent:{data:c}});return await this.aaveUtils.hasBorrowPositions(this.beneficiary)&&(u=await this.dispatchWithExtraGas(u)),this.wrapTx("IntentSwap",u)}};import{Enum as jo}from"polkadot-api";var Ze=class extends W{_trade;_beneficiary;_minAmountOut;_deadline;_partial=!0;setTrade(t){return this._trade=t,this}withBeneficiary(t){return this._beneficiary=t,this}withPartial(t){return this._partial=t,this}withMinAmountOut(t){return this._minAmountOut=t,this}withDeadline(t){return this._deadline=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 partial(){return this._partial}get minAmountOut(){return this._minAmountOut}get deadline(){return this._deadline}async build(){let{amountIn:t,amountOut:e,swaps:r}=this.trade,i=r[0],a=r[r.length-1],n=i.assetIn,s=a.assetOut,o=jo("Swap",{asset_in:n,asset_out:s,amount_in:t,amount_out:this.minAmountOut??e,partial:this.partial}),l=this.apiIce.tx.Intent.submit_intent({intent:{data:o,deadline:this.deadline}});return await this.aaveUtils.hasBorrowPositions(this.beneficiary)&&(l=await this.dispatchWithExtraGas(l)),this.wrapTx("IntentLimitOrder",l)}};import{Enum as na}from"polkadot-api";var tr=class extends W{_order;_beneficiary;_slippagePct=1;setOrder(t){return this._order=t,this}withBeneficiary(t){return this._beneficiary=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 slippagePct(){return this._slippagePct}async build(){let{type:t}=this.order;switch(t){case"Dca":return this.buildDcaTx();case"TwapSell":case"TwapBuy":return this.buildTwapTx();default:throw new Error(`Unsupported TradeOrderType: ${t}`)}}async buildDcaTx(){let{amountIn:t,assetIn:e,assetOut:r,assetOutEd:i,tradeAmountIn:a,tradePeriod:n}=this.order,s=na("Dca",{asset_in:e,asset_out:r,amount_in:a,amount_out:i,slippage:this.slippagePct*1e4,budget:t,period:n}),o=this.apiIce.tx.Intent.submit_intent({intent:{data:s}});return await this.aaveUtils.hasBorrowPositions(this.beneficiary)&&(o=await this.dispatchWithExtraGas(o)),this.wrapTx("IntentDcaSchedule",o)}async buildTwapTx(){let{amountIn:t,assetIn:e,assetOut:r,tradeAmountIn:i,tradeAmountOut:a,tradePeriod:n}=this.order,s=B.getFraction(a,this.slippagePct),o=a-s,l=na("Dca",{asset_in:e,asset_out:r,amount_in:i,amount_out:o,slippage:this.slippagePct*1e4,budget:t,period:n}),c=this.apiIce.tx.Intent.submit_intent({intent:{data:l}});return await this.aaveUtils.hasBorrowPositions(this.beneficiary)&&(c=await this.dispatchWithExtraGas(c)),this.wrapTx("IntentDcaSchedule.twap",c)}};var Lt=class{client;evmClient;at;constructor(t,e,r){this.client=t,this.evmClient=e,this.at=r}trade(t){return new je(this.client,this.evmClient,this.at).setTrade(t)}order(t){return new Qe(this.client,this.evmClient,this.at).setOrder(t)}intentMarket(t){return new Je(this.client,this.evmClient).setTrade(t)}intentLimit(t){return new Ze(this.client,this.evmClient).setTrade(t)}intentOrder(t){return new tr(this.client,this.evmClient).setOrder(t)}};async function aw(m,t){let{at:e}=t??{},r=new Pt(m),i=new $t(m,e),[a,n]=await Promise.all([r.getBlockTime(),r.getMinOrderBudget()]),s=new kt(m,i,e).withAave().withOmnipool().withStableswap().withXyk(),o=new X(m,e),l=new fe(m),c=new Kt(m),u=new nt(i),d=new it(s),p=new Dt(s,{blockTime:a,minBudgetInNative:n}),g=new ye(l,o),b=new Xt(c,o,{blockTime:a});return{api:{aave:u,router:d,scheduler:p,staking:g,farm:b},client:{asset:new gt(m),balance:o,evm:i},ctx:{pool:s},tx:new Lt(m,i,e),destroy:()=>{s.destroy()}}}export{St as QueryBus,Wr as aave,Vr as api,Fe as async,B as calc,Jr as client,$r as const,aw as createSdkContext,Zr as error,ii as evm,di as farm,x as fmt,hi as indexer,zt as json,L as math,Ui as pool,Xi as sor,ra as staking,sa as tx};