@galacticcouncil/sdk-next 0.30.3 → 0.31.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/build/index.cjs CHANGED
@@ -1 +1 @@
1
- "use strict";var vn=Object.create;var De=Object.defineProperty;var Sn=Object.getOwnPropertyDescriptor;var wn=Object.getOwnPropertyNames;var xn=Object.getPrototypeOf,Tn=Object.prototype.hasOwnProperty;var ar=(c,t)=>()=>(c&&(t=c(c=0)),t);var R=(c,t)=>{for(var e in t)De(c,e,{get:t[e],enumerable:!0})},Me=(c,t,e,i)=>{if(t&&typeof t=="object"||typeof t=="function")for(let r of wn(t))!Tn.call(c,r)&&r!==e&&De(c,r,{get:()=>t[r],enumerable:!(i=Sn(t,r))||i.enumerable});return c},Bt=(c,t,e)=>(Me(c,t,"default"),e&&Me(e,t,"default")),ft=(c,t,e)=>(e=c!=null?vn(xn(c)):{},Me(t||!c||!c.__esModule?De(e,"default",{value:c,enumerable:!0}):e,c)),In=c=>Me(De({},"__esModule",{value:!0}),c);var Jt={};var dr=ar(()=>{Bt(Jt,require("@polkadot-api/smoldot"))});var Zt={};var gr=ar(()=>{Bt(Zt,require("@polkadot-api/known-chains/polkadot"))});var ps={};R(ps,{QueryBus:()=>le,aave:()=>xi,api:()=>fi,async:()=>ae,calc:()=>H,client:()=>Ai,const:()=>_i,createSdkContext:()=>us,error:()=>Bi,evm:()=>Fi,farm:()=>qi,fmt:()=>_,json:()=>Dt,math:()=>V,pool:()=>zi,sor:()=>Zi,staking:()=>er,tx:()=>rr});module.exports=In(ps);var fi={};R(fi,{Papi:()=>D,Watcher:()=>Qt,getSm:()=>On,getWs:()=>An});var cr=require("@galacticcouncil/descriptors");var lr=require("@galacticcouncil/common"),Le=require("rxjs");var bt=require("rxjs"),q=require("rxjs/operators");function or(c,{intervalMs:t=5e3,rpcTimeoutMs:e=1e4}={}){let i=()=>(0,bt.defer)(()=>(0,bt.from)(c._request("system_health",[]))).pipe((0,q.timeout)({first:e}),(0,q.map)(()=>"online"),(0,q.catchError)(()=>(0,bt.of)("offline")));return(0,bt.of)({state:"offline",delayMs:0}).pipe((0,q.expand)(n=>(0,bt.timer)(n.delayMs).pipe((0,q.switchMap)(i),(0,q.map)(s=>({state:s,delayMs:t})))),(0,q.skip)(1),(0,q.map)(n=>n.state),(0,q.distinctUntilChanged)(),(0,q.shareReplay)({bufferSize:1,refCount:!0}))}var{logger:_n}=lr.log,Qt=class c{static instance=null;bestBlock$;finalizedBlock$;connection$;constructor(t){this.bestBlock$=this.watched("watcher(bestBlock)",t.getUnsafeApi().query.System.Number.watchValue("best")),this.finalizedBlock$=this.watched("watcher(finalizedBlock)",t.finalizedBlock$),this.connection$=this.watched("watcher(connection)",or(t))}static getInstance(t){return this.instance||(this.instance=new c(t)),this.instance}watched(t,e){return e.pipe((0,Le.tap)({error:i=>_n.error(t,i)}),(0,Le.shareReplay)({bufferSize:1,refCount:!0}))}};var D=class{client;api;watcher;constructor(t){this.client=t,this.api=this.client.getTypedApi(cr.hydration),this.watcher=Qt.getInstance(this.client)}};var ur=require("polkadot-api/ws-provider"),pr=require("polkadot-api/logs-provider"),mr=require("@polkadot-api/legacy-provider"),An=(c,t={})=>{let e=typeof c=="string"?c.split(","):c,i=(0,ur.getWsProvider)(e,{innerEnhancer:(0,mr.withLegacy)(),...t});return(0,pr.withLogsRecorder)(r=>console.log(r),i),i};var hr=require("polkadot-api/sm-provider");async function On(c){let{start:t}=await Promise.resolve().then(()=>(dr(),Jt)),{chainSpec:e}=await Promise.resolve().then(()=>(gr(),Zt)),i=t(),r=await i.addChain({chainSpec:e}),n=await i.addChain({chainSpec:c,potentialRelayChains:[r]});return(0,hr.getSmProvider)(n)}var xi={};R(xi,{AAVE_GAS_LIMIT:()=>Si,AAVE_LENDING_POOL_ADDRESS:()=>He,AAVE_POOL_ABI:()=>Pi,AAVE_POOL_DATA_PROVIDER:()=>Ne,AAVE_POOL_DATA_PROVIDER_ABI:()=>qe,AAVE_POOL_PROXY:()=>vi,AAVE_ROUNDING_THRESHOLD:()=>Ms,AAVE_UINT_256_MAX:()=>Bn,AaveClient:()=>te,AaveUtils:()=>Tt});var Pi=[{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 qe=[{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 vi="0x1b02E051683b5cfaC5929C25E84adb26ECf87B38",Ne="0x112b087b60C1a166130d59266363C45F8aa99db0",He="0xf3Ba4D1b50f78301BDD7EAEa9B67822A15FCA691",Si=1000000n,Ms=5,Bn=BigInt("0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");var te=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:qe,address:Ne,args:[He],functionName:"getReservesData"})}async getUserReservesData(t){return await this.client.readContract({abi:qe,address:Ne,args:[He,t],functionName:"getUserReservesData"})}async getUserAccountData(t){return await this.client.readContract({abi:Pi,address:vi,args:[t],functionName:"getUserAccountData"})}};var N=ft(require("big.js")),it=require("@galacticcouncil/common");var{ERC20:Rt}=it.erc20,{H160:wi}=it.h160,Rn=1.01,Fn=31536000n,br=4,Ge=-1,Ue=10n**27n,Tt=class{client;constructor(t){this.client=new te(t)}async getSummary(t){let e=wi.fromAny(t),[i,r,n,s]=await Promise.all([this.client.getReservesData(),this.client.getUserReservesData(e),this.client.getUserAccountData(e),this.client.getBlockTimestamp()]),[a]=i,[o,l]=r,[u,p,d,m,h,b]=n,g=it.big.toDecimal(b,18),f=[];for(let y of o){let S=y.underlyingAsset.toLowerCase(),v=a.find(({underlyingAsset:yi})=>yi.toLowerCase()===S);if(!v)throw new Error("Missing pool reserve for "+S);let T=y.scaledATokenBalance,O=v.liquidityIndex,L=v.liquidityRate,U=v.availableLiquidity,ct=v.priceInMarketReferenceCurrency,ht=s+6,Q=this.calculateLinearInterest(L,v.lastUpdateTimestamp,ht),et=O*Q/Ue,jt=T*et/Ue,Ce=Number(l!==0&&l===v.eModeCategoryId?v.eModeLiquidationThreshold:v.reserveLiquidationThreshold)/1e4,Ee=v.usageAsCollateralEnabled&&y.usageAsCollateralEnabledOnUser&&y.scaledATokenBalance>0n,ke=Rt.toAssetId(S);f.push({aTokenBalance:jt,availableLiquidity:U,decimals:Number(v.decimals),isCollateral:Ee,priceInRef:ct,reserveId:ke,reserveAsset:S,reserveLiquidationThreshold:Ce})}return{healthFactor:Number(g),currentLiquidationThreshold:Number(it.big.toDecimal(m,br)),totalCollateral:u,totalDebt:p,reserves:f}}async hasBorrowPositions(t){let e=wi.fromAny(t),i=await this.client.getUserAccountData(e),[r,n]=i;return n>0n}async getHealthFactor(t){let e=wi.fromAny(t),i=await this.client.getUserAccountData(e),[r,n,s,a,o,l]=i;return this.calculateHealthFactorFromBalances(n,r,a)}async getHealthFactorAfterWithdraw(t,e,i){let{totalCollateral:r,totalDebt:n,reserves:s,currentLiquidationThreshold:a}=await this.getSummary(t);if(n===0n)return Ge;let o=Rt.fromAssetId(e),l=s.find(S=>S.reserveAsset===o);if(!l)throw new Error("Missing reserve ctx for "+o);let{decimals:u,isCollateral:p,priceInRef:d,reserveLiquidationThreshold:m}=l,h=it.big.toBigInt(i,u),b=p?h*d/10n**BigInt(u):0n,g=r-b;if(g<=0n)return 0;let f=(0,N.default)(r.toString()).mul(a).minus((0,N.default)(b.toString()).mul(m)).div(g.toString()),y=(0,N.default)(g.toString()).mul(f).div(n.toString()).toFixed(6,N.default.roundDown);return Number(y)}async getHealthFactorAfterSupply(t,e,i){let{totalCollateral:r,totalDebt:n,reserves:s,currentLiquidationThreshold:a}=await this.getSummary(t);if(n===0n)return Ge;let o=Rt.fromAssetId(e),l=s.find(y=>y.reserveAsset===o);if(!l)throw new Error("Missing reserve ctx for "+o);let{decimals:u,priceInRef:p,reserveLiquidationThreshold:d}=l,h=it.big.toBigInt(i,u)*p/10n**BigInt(u),b=r+h;if(b<=0n)return 0;let g=(0,N.default)(r.toString()).mul(a).plus((0,N.default)(h.toString()).mul(d)).div(b.toString()),f=(0,N.default)(b.toString()).mul(g).div(n.toString()).toFixed(6,N.default.roundDown);return Number(f)}async getHealthFactorAfterSwap(t,e,i,r,n){let{totalDebt:s,reserves:a,healthFactor:o}=await this.getSummary(t);if(s===0n)return Ge;let l=Rt.fromAssetId(i),u=Rt.fromAssetId(n),p=a.find(O=>O.reserveAsset===l),d=a.find(O=>O.reserveAsset===u);if(!p)throw new Error(`Missing reserve ctx for ${l}`);if(!d)throw new Error(`Missing reserve ctx for ${d}`);let m=it.big.toBigInt(e,p.decimals),h=it.big.toBigInt(r,d.decimals),b=m*p.priceInRef/10n**BigInt(p.decimals),g=h*d.priceInRef/10n**BigInt(d.decimals),f=p.isCollateral?(0,N.default)(b.toString()).mul(p.reserveLiquidationThreshold):(0,N.default)(0),v=(0,N.default)(g.toString()).mul(d.reserveLiquidationThreshold).minus(f).div(s.toString()),T=(0,N.default)(o).plus(v).toFixed(6,N.default.roundDown);return Number(T)}async getMaxWithdraw(t,e){let{totalDebt:i,reserves:r,healthFactor:n}=await this.getSummary(t),s=Rt.fromAssetId(e),a=r.find(o=>o.reserveAsset===s);if(!a)throw new Error("Missing reserve ctx for "+s);return this.calculateWithdrawMax(a,i,n)}async getMaxWithdrawAll(t){let{totalDebt:e,reserves:i,healthFactor:r}=await this.getSummary(t),n={};for(let s of i){let a=this.calculateWithdrawMax(s,e,r);s.reserveId&&(n[s.reserveId]=a)}return n}calculateWithdrawMax(t,e,i){let{aTokenBalance:r,availableLiquidity:n,decimals:s,priceInRef:a,reserveLiquidationThreshold:o,isCollateral:l}=t,u=r;if(l&&e>0n){let d=i-Rn;if(d>0){let m=(0,N.default)(d).mul(e.toString()).div(o).toFixed(0,N.default.roundDown),h=(0,N.default)(m).div(a.toString()).mul(10**s).toFixed(0,N.default.roundDown);u=r<BigInt(h)?r:BigInt(h)}else u=0n}return{amount:u<n?u:n,decimals:s}}calculateLinearInterest(t,e,i){let r=i-e;if(r<=0)return Ue;let n=t*BigInt(r)/Fn;return Ue+n}calculateHealthFactorFromBalances(t,e,i){if(t===0n)return Ge;let r=e*i/t,n=it.big.toDecimal(r,br);return Number(n)}};var Ai={};R(Ai,{AssetClient:()=>Ft,BalanceClient:()=>ut,ChainParams:()=>Mt});var Ft=class extends D{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[n]=i;return[n,r]}))}async queryBonds(){let e=await this.api.query.Bonds.Bonds.getEntries();return new Map(e.map(({keyArgs:i,value:r})=>{let[n]=i;return[n,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[n]=i;return[n,r]}))}async queryAssetLocations(){let e=await this.api.query.AssetRegistry.AssetLocations.getEntries();return new Map(e.map(({keyArgs:i,value:r})=>{let[n]=i;return[n,r]}))}async mapToken(t,e,i,r){let{name:n,asset_type:s,is_sufficient:a,existential_deposit:o}=e,{symbol:l,decimals:u}=i.get(t)??{};return{id:t,name:n?.asText(),symbol:l,decimals:u,icon:l,type:s.type,isSufficient:a,location:r,existentialDeposit:o}}async mapBond(t,e,i,r){let[n,s]=r,{asset_type:a,is_sufficient:o,existential_deposit:l}=e,{symbol:u,decimals:p}=await this.mapToken(n,e,i),d=Number(s),m=new Intl.DateTimeFormat("en-GB"),h=[u,"Bond",m.format(d)].join(" ");return{id:t,name:h,symbol:u+"b",decimals:p,icon:u,type:a.type,isSufficient:o,existentialDeposit:l,underlyingAssetId:n,maturity:d}}async mapShares(t,e,i,r){let{assets:n}=r,{name:s,symbol:a,asset_type:o,is_sufficient:l,existential_deposit:u}=e,p=await Promise.all(n.map(async h=>{let{symbol:b}=await this.mapToken(h,e,i);return[h,b]})),d=Object.fromEntries(p),m=Object.values(d);return{id:t,name:m.join(", "),symbol:a?.asText()||s?.asText(),decimals:18,icon:m.join("/"),type:o.type,isSufficient:l,existentialDeposit:u,meta:d}}async mapExternal(t,e,i,r){let n=await this.mapToken(t,e,new Map,r),s=i?.find(a=>a.internalId===n.id);return s?{...n,decimals:s.decimals,name:s.name,symbol:s.symbol,icon:s.symbol,isWhiteListed:s.isWhiteListed}:n}parseMetadata(t){return new Map(Array.from(t,([e,i])=>[e,{symbol:i.symbol?.asText(),decimals:i.decimals}]))}async getSupported(t,e){let[i,r,n,s]=await Promise.all([this.queryAssets(),this.queryAssetLocations(),this.queryShares(),this.queryBonds()]),a=this.parseMetadata(i),o=[];for(let[l,u]of Array.from(i)){let p=r.get(l),{asset_type:d}=u,m;switch(d.type){case"Bond":let h=s.get(l);m=await this.mapBond(l,u,a,h);break;case"StableSwap":let b=n.get(l);m=await this.mapShares(l,u,a,b);break;case"External":m=await this.mapExternal(l,u,e,p);break;default:m=await this.mapToken(l,u,a,p)}o.push(m)}return t?o:o.filter(l=>this.isValidAsset(l))}isValidAsset(t){let e=Math.sign(t.decimals);return!!t.symbol&&(e===0||e===1)}};var yr=require("@galacticcouncil/common"),J=require("rxjs"),w=require("rxjs/operators");var _i={};R(_i,{HUB_ASSET_ID:()=>ee,HYDRATION_OMNIPOOL_ADDRESS:()=>En,HYDRATION_PARACHAIN_ID:()=>Cn,PERBILL_DENOMINATOR:()=>Ti,PERMILL_DENOMINATOR:()=>Ct,SYSTEM_ASSET_DECIMALS:()=>Ii,SYSTEM_ASSET_ID:()=>E,TRADEABLE_DEFAULT:()=>Et});var Ct=1e6,Ti=1e9,E=0,Ii=12,Cn=2034,En="7L53bUTBbfuj14UpdCNPwmgzzHSsrsTWBHX5pys32mVWM3C1",ee=1,Et=15;var{logger:kt}=yr.log,ut=class extends D{constructor(t){super(t)}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:"best"});return this.getBreakdown(i)}async getTokenBalance(t,e){let r=await this.api.query.Tokens.Accounts.getValue(t,e,{at:"best"});return this.getBreakdown(r)}async getErc20Balance(t,e){return this.getBalanceData(t,e)}watchBalance(t){return(0,J.defer)(()=>{let e=this.watchSystemBalance(t),i=this.watchTokensBalance(t),r=this.watchErc20Balance(t);return(0,J.combineLatest)([e,i,r]).pipe((0,w.connect)(n=>(0,J.concat)(n.pipe((0,w.take)(1)),n.pipe((0,w.skip)(1),(0,w.debounceTime)(250)))))}).pipe((0,w.map)(e=>e.flat()),(0,w.startWith)([]),(0,w.bufferCount)(2,1),(0,w.map)(([e,i],r)=>r===0?i:this.getDeltas(e,i))).pipe((0,w.tap)({subscribe:()=>kt.debug("balance: subscribe",t),error:e=>kt.error("balance",e)}),(0,w.retry)({delay:1e3}))}watchSystemBalance(t){let e=this.api.query.System.Account;return(0,J.defer)(()=>e.watchValue(t,"best")).pipe((0,w.map)(i=>({id:0,balance:this.getBreakdown(i.data)})),(0,w.tap)({error:i=>kt.error("balance(system)",i)}))}watchTokenBalance(t,e){let i=this.api.query.Tokens.Accounts;return(0,J.defer)(()=>i.watchValue(t,e,"best")).pipe((0,w.map)(r=>({id:e,balance:this.getBreakdown(r)})),(0,w.tap)({error:r=>kt.error("balance(token)",r)}))}watchTokensBalance(t){let e=this.api.query.Tokens.Accounts;return(0,J.defer)(()=>e.watchEntries(t,{at:"best"})).pipe((0,w.distinctUntilChanged)((i,r)=>!r.deltas),(0,w.map)(({deltas:i})=>{let r=[];return i?.deleted.forEach(n=>{let[s,a]=n.args;r.push({id:a,balance:this.getBreakdown({free:0n,reserved:0n,frozen:0n})})}),i?.upserted.forEach(n=>{let[s,a]=n.args;r.push({id:a,balance:this.getBreakdown(n.value)})}),r}),(0,w.tap)({error:i=>kt.error("balance(tokens)",i)}))}watchErc20Balance(t,e){let i=async()=>(await this.api.query.AssetRegistry.Assets.getEntries({at:"best"})).filter(({value:s})=>s.asset_type.type==="Erc20").map(({keyArgs:s})=>{let[a]=s;return a}),r=async n=>(await Promise.all(n.map(async a=>[a,await this.getBalanceData(t,a)]))).map(([a,o])=>({id:a,balance:o}));return(0,J.defer)(()=>(0,J.from)(e?Promise.resolve(e):i()).pipe((0,w.switchMap)(n=>this.watcher.bestBlock$.pipe((0,w.startWith)(null),(0,w.switchMap)(()=>(0,J.from)(r(n))))),(0,w.pairwise)(),(0,w.map)(([n,s],a)=>a===0?s.filter(o=>o.balance.transferable>0n):this.getDeltas(n,s)),(0,w.distinctUntilChanged)((n,s)=>s.length===0),(0,w.tap)({error:n=>kt.error("balance(erc20)",n)})))}async getBalanceData(t,e){let i=await this.api.apis.CurrenciesApi.account(e,t,{at:"best"});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=(n,s)=>n!==void 0&&s!==void 0&&n.transferable===s.transferable&&n.total===s.total,r=t.reduce((n,s)=>(n.set(s.id,s.balance),n),new Map);return e.filter(n=>!i(n.balance,r.get(n.id)))}};var Mt=class extends D{_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 Bi={};R(Bi,{AssetNotFound:()=>Oi,PoolNotFound:()=>ie,RouteNotFound:()=>re});var Oi=class extends Error{constructor(t){super(),this.message=`${t} not found`,this.name="AssetNotFound"}},ie=class extends Error{constructor(t){super(),this.message=`${t} pool invalid`,this.name="PoolNotFound"}},re=class extends Error{constructor(t,e){super(),this.message=`Route from ${t} to ${e} not found in current configuration`,this.name="RouteNotFound"}};var Fi={};R(Fi,{EvmClient:()=>se,EvmRpcAdapter:()=>ne,createChain:()=>Ri});var It=require("polkadot-api"),fr=require("@galacticcouncil/descriptors"),Ve=require("viem"),kn=10000000n,ne=class{api;constructor(t){this.api=t.getTypedApi(fr.hydration)}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:n}=t,s=(0,Ve.encodeFunctionData)({abi:e,functionName:r,args:n}),a=this.api.apis.EthereumRuntimeRPCApi.call,o=await this.api.compatibilityToken,l=a.isCompatible(It.CompatibilityLevel.BackwardsCompatible,o);console.log(l);let u=await this.api.apis.EthereumRuntimeRPCApi.call(It.FixedSizeBinary.fromText(""),It.FixedSizeBinary.fromHex(i),It.Binary.fromHex(s),[0n,0n,0n,0n],[kn,0n,0n,0n],void 0,void 0,void 0,!1,[]);if(console.log(u),!u.success)throw console.error(r,u.value.type),new Error("Contract read failure");let{exit_reason:p,value:d,used_gas:m}=u.value;if(console.log(m),p.type==="Succeed")return(0,Ve.decodeFunctionResult)({abi:e,functionName:r,data:d.asHex()});throw console.log(r,p.type,p.value.type),new Error("Contract read error")})};var Pr=require("viem"),Mn=["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"],Ri=()=>(0,Pr.defineChain)({id:222222,name:"Hydration",network:"hydration",nativeCurrency:{decimals:18,name:"WETH",symbol:"WETH"},rpcUrls:{default:{http:Mn}},blockExplorers:{default:{name:"Hydration Explorer",url:"https://hydration.subscan.io"}},testnet:!1});var pt=require("viem");var se=class{client;chain;constructor(t){this.client=t,this.chain=Ri()}get chainId(){return this.chain.id}get chainCurrency(){return this.chain.nativeCurrency.symbol}get chainDecimals(){return this.chain.nativeCurrency.decimals}getProvider(){return(0,pt.createPublicClient)({chain:this.chain,transport:(0,pt.http)()})}getWsProvider(){return(0,pt.createPublicClient)({transport:(0,pt.custom)({request:({method:t,params:e})=>this.client._request(t,e||[])})})}getSigner(t){return(0,pt.createWalletClient)({account:t,chain:this.chain,transport:(0,pt.custom)(window.ethereum)})}getRPCAdapter(){return new ne(this.client)}};var qi={};R(qi,{LiquidityMiningApi:()=>ce,LiquidityMiningClient:()=>ue});var Er=require("polkadot-api"),W=ft(require("big.js")),vt=require("@galacticcouncil/common"),Li=require("@galacticcouncil/math-liquidity-mining");var ae={};R(ae,{withTimeout:()=>Dn});function Dn(c,t,e="timeout"){return new Promise((i,r)=>{let n=setTimeout(()=>r(new Error(e)),t);c.then(s=>{clearTimeout(n),i(s)},s=>{clearTimeout(n),r(s)})})}var H={};R(H,{getFraction:()=>qn,mulScaled:()=>Sr,mulSpot:()=>Ln});var vr=require("@galacticcouncil/common");function Sr(c,t,e,i,r){let n=e+i-r,s=c*t;return n>0?s/BigInt(10)**BigInt(n):n<0?s*BigInt(10)**BigInt(-n):s}function Ln(c,t,e,i){return Sr(c,t,e,vr.RUNTIME_DECIMALS,i)}function qn(c,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 c*r/(BigInt(100)*i)}var _={};R(_,{FeeUtils:()=>Ci,shiftNeg:()=>Nn});var wr=ft(require("big.js"));var Ci=class c{static toPct(t){let[e,i]=t;return c.safeDivide(e*100,i)}static toRaw(t){let[e,i]=t;return c.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 Nn(c,t){let e=(0,wr.default)(typeof c=="bigint"?c.toString():c);return t===0?e.toString():e.div(Math.pow(10,t)).toString()}var Dt={};R(Dt,{findNestedKey:()=>Hn,findNestedObj:()=>Gn,jsonFormatter:()=>Un});var Hn=(c,t)=>{let e=[];return JSON.stringify(c,(i,r)=>(r&&r[t]&&e.push(r),r)),e[0]},Gn=(c,t,e)=>{let i;return JSON.stringify(c,(r,n)=>(n&&n[t]===e&&(i=n),n)),i},Un=(c,t)=>typeof t=="bigint"?t.toString():t;var V={};R(V,{calculateBuyFee:()=>zn,calculateDiffToAvg:()=>Vn,calculateDiffToRef:()=>Wn,calculateSellFee:()=>Yn});var mt=ft(require("big.js"));function Vn(c,t){let e=(0,mt.default)(c.toString()),i=(0,mt.default)(t.toString());return e.minus(i).abs().div(e.plus(i).div(2)).mul(100).round(2).toNumber()}function Wn(c,t){if(t===0n)return 0;let e=(0,mt.default)(c.toString()),i=(0,mt.default)(t.toString());return e.minus(i).div(i).mul(100).round(2).toNumber()}function Yn(c,t){if(c===0n)return 0;let e=(0,mt.default)(c.toString()),i=(0,mt.default)(t.toString());return(0,mt.default)(1).minus(i.div(e)).mul(100).round(2).toNumber()}function zn(c,t){if(c===0n)return 0;let e=(0,mt.default)(c.toString());return(0,mt.default)(t.toString()).div(e).minus(1).mul(100).round(2).toNumber()}var oe=(c,t)=>c===t?0:c==null?t==null?0:-1:t==null?c==null?0:1:typeof c.compare=="function"?c.compare(t):typeof t.compare=="function"?-t.compare(c):c<t?-1:c>t?1:0;var We=(c,t=e=>e!==void 0?": "+e:"")=>class extends Error{origMessage;constructor(e){super(c(e)+t(e)),this.origMessage=e!==void 0?String(e):""}};var $n=We(()=>"illegal argument(s)"),xr=c=>{throw new $n(c)};var Xn=We(()=>"index out of bounds"),Ei=c=>{throw new Xn(c)},Ye=(c,t,e)=>(c<t||c>=e)&&Ei(c);var Tr=23283064365386963e-26,ze=class{float(t=1){return this.int()*Tr*t}probability(t){return this.float()<t}norm(t=1){return(this.int()*Tr-.5)*2*t}normMinMax(t,e){let i=this.minmax(t,e);return this.float()<.5?i:-i}minmax(t,e){return this.float()*(e-t)+t}minmaxInt(t,e){t|=0;let i=(e|0)-t;return i?t+this.int()%i:t}minmaxUint(t,e){t>>>=0;let i=(e>>>0)-t;return i?t+this.int()%i:t}};var $e=class extends ze{constructor(t){super(),this.rnd=t}float(t=1){return this.rnd()*t}norm(t=1){return(this.rnd()-.5)*2*t}int(){return this.rnd()*4294967296>>>0}};var Ir=new $e(Math.random);var _r=c=>c!=null&&typeof c!="function"&&c.length!==void 0;var Ar=Object.getPrototypeOf({}),Xe="function",Or="string",Lt=(c,t)=>{let e;if(c===t)return!0;if(c!=null){if(typeof c.equiv===Xe)return c.equiv(t)}else return c==t;if(t!=null){if(typeof t.equiv===Xe)return t.equiv(c)}else return c==t;return typeof c===Or||typeof t===Or?!1:(e=Object.getPrototypeOf(c),(e==null||e===Ar)&&(e=Object.getPrototypeOf(t),e==null||e===Ar)?Jn(c,t):typeof c!==Xe&&c.length!==void 0&&typeof t!==Xe&&t.length!==void 0?Kn(c,t):c instanceof Set&&t instanceof Set?jn(c,t):c instanceof Map&&t instanceof Map?Qn(c,t):c instanceof Date&&t instanceof Date?c.getTime()===t.getTime():c instanceof RegExp&&t instanceof RegExp?c.toString()===t.toString():c!==c&&t!==t)},Kn=(c,t,e=Lt)=>{let i=c.length;if(i===t.length)for(;i-- >0&&e(c[i],t[i]););return i<0},jn=(c,t,e=Lt)=>c.size===t.size&&e([...c.keys()].sort(),[...t.keys()].sort()),Qn=(c,t,e=Lt)=>c.size===t.size&&e([...c].sort(),[...t].sort()),Jn=(c,t,e=Lt)=>{if(Object.keys(c).length!==Object.keys(t).length)return!1;for(let i in c)if(!t.hasOwnProperty(i)||!e(c[i],t[i]))return!1;return!0};var ki=class{value;constructor(t){this.value=t}deref(){return this.value}};var Br=c=>c instanceof ki;var Ke=class c{_head;_length=0;constructor(t){t&&this.into(t)}get length(){return this._length}get head(){return this._head}[Symbol.iterator](){return Rr("next",this._head)}reverseIterator(){return Rr("prev",this.tail)}clear(){this.release()}compare(t,e=oe){let i=this._length;if(i<t._length)return-1;if(i>t._length)return 1;if(i===0)return 0;{let r=this._head,n=t._head,s=0;for(;i-- >0&&s===0;)s=e(r.value,n.value),r=r.next,n=n.next;return s}}concat(...t){let e=this.copy();for(let i of t)e.into(i);return e}equiv(t){if(!(t instanceof c||_r(t))||this._length!==t.length)return!1;if(!this._length||this===t)return!0;let e=t[Symbol.iterator](),i=this._head;for(let r=this._length;r-- >0;){if(!Lt(i.value,e.next().value))return!1;i=i.next}return!0}filter(t){let e=this.empty();return this.traverse(i=>(t(i.value)&&e.append(i.value),!0)),e}find(t){return this.traverse(e=>e.value!==t)}findWith(t){return this.traverse(e=>!t(e.value))}first(){return this._head?.value}insertSorted(t,e){e=e||oe;for(let i=this._head,r=this._length;r-- >0;){if(e(t,i.value)<=0)return this.insertBefore(i,t);i=i.next}return this.append(t)}into(t){for(let e of t)this.append(e);return this}nth(t,e){let i=this.nthCell(t);return i?i.value:e}nthCellUnsafe(t){let e,i;for(t<=this._length>>>1?(e=this._head,i="next"):(e=this.tail,i="prev",t=this._length-t-1);t-- >0&&e;)e=e[i];return e}peek(){return this.tail?.value}$reduce(t,e){let i=this._head;for(let r=this._length;r-- >0&&!Br(e);)e=t(e,i.value),i=i.next;return e}reduce(t,e){return this.$reduce(t,e)}release(){let t=this._head;if(!t)return!0;let e;for(let i=this._length;i-- >0;)e=t.next,delete t.value,delete t.prev,delete t.next,t=e;return this._head=void 0,this._length=0,!0}reverse(){let t=this._head,e=this.tail,i=(this._length>>>1)+(this._length&1);for(;t&&e&&i>0;){let r=t.value;t.value=e.value,e.value=r,t=t.next,e=e.prev,i--}return this}setHead(t){let e=this._head;return e?(e.value=t,e):this.prepend(t)}setNth(t,e){let i=this.nthCell(t);return!i&&Ei(t),i.value=e,i}setTail(t){let e=this.tail;return e?(e.value=t,e):this.append(t)}swap(t,e){if(t!==e){let i=t.value;t.value=e.value,e.value=i}return this}toArray(t=[]){return this.traverse(e=>(t.push(e.value),!0)),t}toJSON(){return this.toArray()}toString(){let t=[];return this.traverse(e=>(t.push(String(e.value)),!0)),t.join(", ")}traverse(t,e=this._head,i){if(!this._head)return;let r=e;do{if(!t(r))break;r=r.next}while(r!==i);return r}_map(t,e){return this.traverse(i=>(t.append(e(i.value)),!0)),t}};function*Rr(c,t){for(;t;)yield t.value,t=t[c]}var je=class c extends Ke{_tail;constructor(t){super(),t&&this.into(t)}get tail(){return this._tail}append(t){if(this._tail){let e={value:t,prev:this._tail};return this._tail.next=e,this._tail=e,this._length++,e}else return this.prepend(t)}asHead(t){return t===this._head?this:(this.remove(t),this._head.prev=t,t.next=this._head,t.prev=void 0,this._head=t,this._length++,this)}asTail(t){return t===this._tail?this:(this.remove(t),this._tail.next=t,t.prev=this._tail,t.next=void 0,this._tail=t,this._length++,this)}cons(t){return this.prepend(t),this}copy(){return new c(this)}*cycle(){for(;;)yield*this}drop(){let t=this._head;if(t)return this._head=t.next,this._head?this._head.prev=void 0:this._tail=void 0,this._length--,t.value}empty(){return new c}insertAfter(t,e){let i={value:e,next:t.next,prev:t};return t.next?t.next.prev=i:this._tail=i,t.next=i,this._length++,i}insertAfterNth(t,e){return t<0&&(t+=this._length),t>=this._length-1?this.append(e):(Ye(t,0,this._length),this.insertAfter(this.nthCellUnsafe(t),e))}insertBefore(t,e){let i={value:e,next:t,prev:t.prev};return t.prev?t.prev.next=i:this._head=i,t.prev=i,this._length++,i}insertBeforeNth(t,e){return t<0&&(t+=this._length),t<=0?this.prepend(e):(Ye(t,0,this._length),this.insertBefore(this.nthCellUnsafe(t),e))}map(t){return this._map(new c,t)}nth(t,e){let i=this.nthCell(t);return i?i.value:e}nthCell(t){if(t<0&&(t+=this._length),!(t<0||t>=this._length))return this.nthCellUnsafe(t)}pop(){let t=this._tail;if(t)return this._tail=t.prev,this._tail?this._tail.next=void 0:this._head=void 0,this._length--,t.value}prepend(t){let e={value:t,next:this._head};return this._head?this._head.prev=e:this._tail=e,this._head=e,this._length++,e}push(t){return this.append(t),this}release(){return this._tail=void 0,super.release()}remove(t){return t.prev?t.prev.next=t.next:this._head=t.next,t.next?t.next.prev=t.prev:this._tail=t.prev,this._length--,this}rotateLeft(){switch(this._length){case 0:case 1:return this;case 2:return this.swap(this._head,this._tail);default:return this.push(this.drop())}}rotateRight(){switch(this._length){case 0:case 1:return this;case 2:return this.swap(this._head,this._tail);default:let t=this.peek();return this.pop(),this.prepend(t),this}}seq(t=0,e=this.length){if(t>=e||t<0)return;let i=this.nthCell(t),r=this.nthCell(e-1),n=s=>({first(){return s.value},next(){return s!==r&&s.next?n(s.next):void 0}});return i?n(i):void 0}shuffle(t,e=Ir){if(this._length<2)return this;for(t=t!==void 0?t:Math.ceil(1.5*Math.log2(this._length));t>0;t--){let i=this._head;for(;i;){let r=i.next;e.probability(.5)?this.asHead(i):this.asTail(i),i=r}}return this}slice(t=0,e=this.length){let i=t<0?t+this._length:t,r=e<0?e+this._length:e;(i<0||r<0)&&xr("invalid indices: ${from} / ${to}");let n=new c,s=this.nthCell(i);for(;s&&++i<=r;)n.push(s.value),s=s.next;return n}sort(t=oe){if(!this._length)return this;let e=1;for(;;){let i=this._head;this._head=void 0,this._tail=void 0;let r=0;for(;i;){r++;let n=i,s=0;for(let o=0;o<e&&(s++,n=n.next,!!n);o++);let a=e;for(;s>0||a>0&&n;){let o;s===0?(o=n,n=n.next,a--):!n||a===0||t(i.value,n.value)<=0?(o=i,i=i.next,s--):(o=n,n=n.next,a--),this._tail?this._tail.next=o:this._head=o,o.prev=this._tail,this._tail=o}i=n}if(this._tail.next=void 0,r<=1)return this;e*=2}}splice(t,e=0,i){let r;typeof t=="number"?(t<0&&(t+=this._length),Ye(t,0,this._length),r=this.nthCellUnsafe(t)):r=t;let n=new c;if(e>0)for(;r&&e-- >0;)this.remove(r),n.push(r.value),r=r.next;else r&&(r=r.next);if(i)if(r)for(let s of i)this.insertBefore(r,s);else for(let s of i)this.push(s);return n}};var Qe=class c{map;items;opts;_size;constructor(t,e){let i={maxlen:1/0,maxsize:1/0,map:()=>new Map,ksize:()=>0,vsize:()=>0,...e};this.map=i.map(),this.items=new je,this._size=0,this.opts=i,t&&this.into(t)}get length(){return this.items.length}get size(){return this._size}[Symbol.iterator](){return this.entries()}*entries(){for(let t of this.items)yield[t.k,t]}*keys(){for(let t of this.items)yield t.k}*values(){for(let t of this.items)yield t.v}copy(){let t=this.empty();t.items=this.items.copy();let e=t.items.head;for(;e;)t.map.set(e.value.k,e),e=e.next;return t}empty(){return new c(null,this.opts)}release(){this._size=0,this.map.clear();let t=this.opts.release;if(t){let e;for(;e=this.items.drop();)t(e.k,e.v);return!0}return this.items.release()}has(t){return this.map.has(t)}get(t,e){let i=this.map.get(t);return i?this.resetEntry(i):e}set(t,e){let i=this.opts.ksize(t)+this.opts.vsize(e),r=this.map.get(t),n=Math.max(0,i-(r?r.value.s:0));return this._size+=n,this.ensureSize()?this.doSetEntry(r,t,e,i):this._size-=n,e}into(t){for(let e of t)this.set(e[0],e[1]);return this}async getSet(t,e){let i=this.map.get(t);return i?this.resetEntry(i):this.set(t,await e())}delete(t){let e=this.map.get(t);return e?(this.removeEntry(e),!0):!1}resetEntry(t){return this.items.asTail(t),t.value.v}ensureSize(){let{release:t,maxsize:e,maxlen:i}=this.opts;for(;this._size>e||this.length>=i;){let r=this.items.drop();if(!r)return!1;this.map.delete(r.k),t?.(r.k,r.v),this._size-=r.s}return!0}removeEntry(t){let e=t.value;this.map.delete(e.k),this.items.remove(t),this.opts.release?.(e.k,e.v),this._size-=e.s}doSetEntry(t,e,i,r){t?(this.opts.update?.(e,t.value.v,i),t.value.v=i,t.value.s=r,this.items.asTail(t)):(this.items.push({k:e,v:i,s:r}),this.map.set(e,this.items.tail))}};var _t=class c extends Qe{constructor(t,e){super(t,{ttl:3600*1e3,autoExtend:!1,...e})}empty(){return new c(null,this.opts)}has(t){return this.get(t)!==void 0}get(t,e){let i=this.map.get(t);if(i){if(i.value.t>=Date.now())return this.resetEntry(i);this.removeEntry(i)}return e}set(t,e,i=this.opts.ttl){let r=this.opts.ksize(t)+this.opts.vsize(e),n=this.map.get(t),s=Math.max(0,r-(n?n.value.s:0));return this._size+=s,this.ensureSize()?this.doSetEntry(n,t,e,r,i):this._size-=s,e}async getSet(t,e,i=this.opts.ttl){let r=this.get(t);return r!==void 0?r:this.set(t,await e(),i)}prune(){let t=Date.now(),e=this.items.head,i=0;for(;e;)e.value.t<t&&(this.removeEntry(e),i++),e=e.next;return i}ensureSize(){let{maxlen:t,maxsize:e}=this.opts,i=Date.now(),r=this.items.head;for(;r&&(this._size>e||this.length>=t);)r.value.t<i&&this.removeEntry(r),r=r.next;return super.ensureSize()}doSetEntry(t,e,i,r,n=this.opts.ttl){let s=Date.now()+n;t?(this.opts.update?.(e,t.value.v,i),t.value.v=i,t.value.s=r,t.value.t=s,this.items.asTail(t)):(this.items.push({k:e,v:i,s:r,t:s,ttl:n}),this.map.set(e,this.items.tail))}resetEntry(t){return this.opts.autoExtend&&(t.value.t=Date.now()+t.value.ttl),super.resetEntry(t)}};var le=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 n=new Map,s=r!==void 0?new _t(null,{ttl:r}):new _t;return{get:(...u)=>{let p=i(...u);if(n.has(p)){this.log("[live]",t,p);let m=n.get(p);return Promise.resolve(m)}if(s.has(p))return this.log("[memo]",t,p),s.get(p);this.log("[fetch]",t,p);let d=e(...u).catch(m=>{throw s.delete(p),m});return s.set(p,d),d},set:(u,...p)=>{let d=i(...p);this.log("[set-live]",t,d),n.set(d,u)},clear:()=>{this.log("[clear]",t),n.clear(),s.release()}}}};var Je=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,n]=t[i];this.result.set(this.getKey(n,r),e[i].free)}}freeBalance(t,e){return this.result.get(this.getKey(t,e))??0n}transfer(t,e,i,r){let n=this.getKey(t,e),s=this.getKey(t,i),a=this.result.get(n)??0n,o=this.result.get(s)??0n;if(a<r)throw new Error("Attempting to transfer more than is present");this.result.set(n,a+r),this.result.set(s,o+r)}};var Pt=ft(require("big.js")),at=require("@galacticcouncil/math-liquidity-mining");var Mi=ft(require("big.js")),Di=(0,Mi.default)(10).pow(18),Fr=BigInt((0,Mi.default)(1).pow(18).toString()),Cr=6e3;var Zn="1000000000000000000",Ze=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),n=e-t.updated_at,s=this.getAccount(t.id),a=r?.existential_deposit;if(!a)throw new Error("Missing reward currency asset list");let o=this.multiCurrency.freeBalance(t.reward_currency,s),l=(0,Pt.default)(a.toString()),u=(0,Pt.default)(o.toString()).minus(l.lt(o.toString())?a.toString():o.toString()),p=(0,Pt.default)((0,at.calculate_global_farm_rewards)(t.total_shares_z.toString(),i.toString(),(0,Pt.default)(t.yield_per_period.toString()).mul(Di).round(0,Pt.default.roundDown).toFixed(),t.max_reward_per_period.toString(),n.toFixed()));if(u.lt(p)&&(p=u),p.eq(0))return t;let d=this.getAccount(0);return this.multiCurrency.transfer(t.reward_currency,s,d,BigInt(p.toFixed())),{...t,accumulated_rpz:BigInt((0,at.calculate_accumulated_rps)(t.accumulated_rpz.toString(),t.total_shares_z.toString(),p.toFixed()))}}syncYieldFarm(t,e,i){if(t.state.type!=="Active"||t.updated_at===i)return null;if(t.total_valued_shares===0n)return{...t,updated_at:i};let r=(0,at.calculate_yield_farm_delta_rpvs)(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=(0,Pt.default)(1).mul(Di).round(0,Pt.default.roundDown).toString();if(!e)return i;let{initial_reward_percentage:r,scale_coef:n}=e;return(0,at.calculate_loyalty_multiplier)(t.toFixed(),r.toString(),n.toFixed())}async claimRewards(t,e,i,r,n){if(e.state.type==="Terminated")return null;let s=Math.floor(r/t.blocks_per_period);if(i.updated_at===s)return null;let a=await this.syncGlobalFarm(t,s,n);if(!a)return null;let o=this.syncYieldFarm(e,a,s);if(!o)return null;let l=o.total_stopped-i.stopped_at_creation,u=o.updated_at-i.entered_at-l,p=this.getLoyaltyMultiplier(u,o.loyalty_curve),d=BigInt((0,at.calculate_user_reward)(i.accumulated_rpvs.toString(),i.valued_shares.toString(),i.accumulated_claimed_rewards.toString(),o.accumulated_rpvs.toString(),p)),m=BigInt((0,at.calculate_user_reward)(i.accumulated_rpvs.toString(),i.valued_shares.toString(),i.accumulated_claimed_rewards.toString(),o.accumulated_rpvs.toString(),Zn));return{reward:d,maxReward:m,assetId:a.reward_currency,yieldFarmId:o.id,isActiveFarm:o.state.type==="Active"}}};var ts=(0,W.default)(365.2425).times(24).times(60).times(60),ce=class{balance;client;options;constructor(t,e,i={}){this.client=t,this.balance=e,this.options=Object.freeze({blockTime:i.blockTime??Cr})}get blockTime(){return this.options.blockTime}async getOraclePrice(t,e){let i=[t,e].sort((n,s)=>n-s);if(t===e)return Fr;let r=await this.client.getOraclePrice(i);if(r){let{n,d:s}=r[0].price,a;return t<e?a=(0,Li.fixed_from_rational)(n.toString(),s.toString()):a=(0,Li.fixed_from_rational)(s.toString(),n.toString()),BigInt(a)}}getFarmAddress=(t,e)=>{let i=Buffer.from("modl","utf-8"),r=Buffer.from(e?"78796b4c4d704944":"4f6d6e6957684c4d","hex"),n=Buffer.from([t]),s=Buffer.concat([i,r,n]),o="0x"+Buffer.concat([s,Buffer.alloc(32-s.length)]).toString("hex");return(0,Er.AccountId)(vt.HYDRATION_SS58_PREFIX).dec(o)};getGlobalRewardPerPeriod(t,e,i,r){let n=(0,W.default)(r).times(t.toString()).times(e.toString()).div(Math.pow(10,vt.RUNTIME_DECIMALS));return n.gte(i.toString())?i.toString():n.toString()}getPoolYieldPerPeriod(t,e,i,r){let n=(0,W.default)(t.toString()).times(e),s=(0,W.default)(i.toString()).times(r);return n.div(s.toString()).toString()}farmData(t,e,i){let{yieldFarm:r,globalFarm:n,priceAdjustment:s,balance:a,id:o}=t,{multiplier:l,loyalty_curve:u}=r,{blocks_per_period:p,yield_per_period:d,total_shares_z:m,max_reward_per_period:h,pending_rewards:b,accumulated_paid_rewards:g,planned_yielding_periods:f,updated_at:y,incentivized_asset:S,reward_currency:v,price_adjustment:T,min_deposit:O}=n,L=_.shiftNeg(s??T,vt.RUNTIME_DECIMALS),U=_.shiftNeg(l,vt.RUNTIME_DECIMALS),ct=_.shiftNeg(u?.initial_reward_percentage??0,vt.RUNTIME_DECIMALS),ht=ts.div((0,W.default)(this.blockTime).div(1e3).times(p)).toString(),Q;if(m<=0)Q=(0,W.default)(U).times(d.toString()).times(ht).toString();else{let fn=this.getGlobalRewardPerPeriod(m,d,h,L),Pn=this.getPoolYieldPerPeriod(fn,U,m,L);Q=(0,W.default)(Pn).times(ht).toString()}let et=b+g,jt=h*BigInt(f),Fe=a.transferable+et,nr=Fe-et,Ce=(0,W.default)(nr.toString()).div(h.toString()),Ee=(0,W.default)(e).div(p.toString()).toString(),ke=(m>=0?Ce.plus(y):Ce.plus(Ee)).toString(),yi=(0,W.default)(ke).times(p).toString(),bn=(0,W.default)(m.toString()).div((0,W.default)(h.toString()).div(d.toString())).div(Math.pow(10,vt.RUNTIME_DECIMALS)).times(100).times(L).toFixed(2),sr=(0,W.default)(et.toString()).div(Fe.toString()).gte(.999);Q=sr?"0":(0,W.default)(Q).div(i?2:1).times(100).toString();let yn=ct?(0,W.default)(Q).times(ct).toString():void 0;return{apr:Q,minApr:yn,isDistributed:sr,estimatedEndPeriod:ke,estimatedEndBlock:yi,maxRewards:jt,incentivizedAsset:S,rewardCurrency:v,loyaltyCurve:u,currentPeriod:Ee,potMaxRewards:Fe,fullness:bn,yieldFarmId:r.id,globalFarmId:n.id,poolId:o,distributedRewards:et,plannedYieldingPeriods:f,minDeposit:O,blocksPerPeriod:p}}async getAllOmnipoolFarms(){let e=(await this.client.getAllOmnipooFarms()).reduce((r,n)=>r.includes(n.keyArgs[0].toString())?r:[...r,n.keyArgs[0].toString()],[]),i=await Promise.all(e.map(async r=>{let n=await this.getOmnipoolFarms(r);if(n)return[r,n]}));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:n,value:s})=>{let[,a]=n,o=s,l=await this.client.getOmnipoolGlobalFarm(a),u=await this.client.getOmnipoolYieldFarm(Number(t),a,o);if(!l||!u)return;let p=l.reward_currency,d=l.incentivized_asset,m=this.getFarmAddress(a),h=await this.getOraclePrice(p,d),b=await this.balance.getBalance(m,p);return{id:t,globalFarm:l,yieldFarm:u,priceAdjustment:h,balance:b}}));return i?r.map(n=>n?this.farmData(n,i):void 0):[]}async getAllIsolatedFarms(){let e=(await this.client.getAllIsolatedFarms()).reduce((r,n)=>r.includes(n.keyArgs[0].toString())?r:[...r,n.keyArgs[0].toString()],[]),i=await Promise.all(e.map(async r=>{let n=await this.getIsolatedFarms(r);if(n)return[r,n]}));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:n,value:s})=>{let[,a]=n,o=s,l=await this.client.getIsolatedGlobalFarm(a),u=await this.client.getIsolatedYieldFarm(t,a,o);if(!l||!u)return;let p=l.reward_currency,d=l.incentivized_asset,m=this.getFarmAddress(a,!0),h=await this.getOraclePrice(p,d),b=await this.balance.getBalance(m,p);return{id:t,globalFarm:l,yieldFarm:u,priceAdjustment:h,balance:b,farmAddress:m}}));return i?r.map(n=>n?this.farmData(n,i,!0):void 0):[]}async getDepositReward(t,e,i,r){let n=e.global_farm_id,s=e.yield_farm_id,a=i?await this.client.getIsolatedYieldFarm(t,n,s):await this.client.getOmnipoolYieldFarm(Number(t),n,s),o=i?await this.client.getIsolatedGlobalFarm(n):await this.client.getOmnipoolGlobalFarm(n);if(!o||!a)return;let l=o.reward_currency,u=o.incentivized_asset,p=[[this.getFarmAddress(0,i),o.reward_currency],[this.getFarmAddress(o.id,i),o.reward_currency]],d=await this.getAccountAssetBalances(p),m=await this.getOraclePrice(l,u),h=new Je(p,d),g=await new Ze(y=>this.getFarmAddress(y),y=>this.client.getAsset(y),h).claimRewards(o,a,e,r,m??o.price_adjustment);if(!g)return;let f=await this.client.getAsset(g.assetId);if(f&&!(g.reward<=f.existential_deposit))return g}async getAccountAssetBalances(t){let[e,i]=await Promise.all([Promise.all(t.filter(([n,s])=>s!==0).map(([n,s])=>this.balance.getTokenBalance(n,s))),Promise.all(t.filter(([n,s])=>s===0).map(([n])=>this.balance.getSystemBalance(n)))]),r=[];for(let n=0,s=0;n+s<t.length;){let a=n+s,[,o]=t[a];o===0?(r.push(i[s]),s+=1):(r.push(e[n]),n+=1)}return r}};var ti=require("polkadot-api"),ue=class extends D{omnipoolAssetIds=[];async getOraclePrice(t){return await this.api.query.EmaOracle.Oracles.getValue(ti.Binary.fromText("omnipool"),t,(0,ti.Enum)("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 zi={};R(zi,{PoolContextProvider:()=>Yt,PoolError:()=>St,PoolFactory:()=>Wt,PoolType:()=>C,aave:()=>Vi,hsm:()=>Yi,lbp:()=>Ni,omni:()=>Hi,stable:()=>Gi,xyk:()=>Ui});var Ni={};R(Ni,{LbpMath:()=>ot,LbpPool:()=>pe,LbpPoolClient:()=>me});var dt=require("@galacticcouncil/math-lbp"),ot=class{static getSpotPrice(t,e,i,r,n){return(0,dt.get_spot_price)(t,e,i,r,n)}static calculateInGivenOut(t,e,i,r,n){return(0,dt.calculate_in_given_out)(t,e,i,r,n)}static calculateOutGivenIn(t,e,i,r,n){return(0,dt.calculate_out_given_in)(t,e,i,r,n)}static calculateLinearWeights(t,e,i,r,n){return(0,dt.calculate_linear_weights)(t,e,i,r,n)}static calculatePoolTradeFee(t,e,i){return(0,dt.calculate_pool_trade_fee)(t,e,i)}};var qt=require("@galacticcouncil/common");var C=(s=>(s.Aave="Aave",s.LBP="LBP",s.Omni="Omnipool",s.Stable="Stableswap",s.XYK="XYK",s.HSM="HSM",s))(C||{}),St=(u=>(u.UnknownError="UnknownError",u.FacilitatorCapacityExceeded="FacilitatorCapacityExceeded",u.InsufficientTradingAmount="InsufficientTradingAmount",u.InsufficientCollateral="InsufficientCollateral",u.MaxHoldingExceeded="MaxHoldingExceeded",u.MaxInRatioExceeded="MaxInRatioExceeded",u.MaxOutRatioExceeded="MaxOutRatioExceeded",u.TradeNotAllowed="TradeNotAllowed",u.MaxBuyBackExceeded="MaxBuyBackExceeded",u.MaxBuyPriceExceeded="MaxBuyPriceExceeded",u))(St||{});var{FeeUtils:kr}=_,pe=class c{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;fee;repayFeeApply;static fromPool(t){return new c(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(s=>[s.id,s])),r=i.get(t),n=i.get(e);if(r==null)throw new Error("Pool does not contain tokenIn");if(n==null)throw new Error("Pool does not contain tokenOut");return{assetIn:t,assetOut:e,balanceIn:r.balance,balanceOut:n.balance,decimalsIn:r.decimals,decimalsOut:n.decimals,weightIn:r.weight,weightOut:n.weight}}validateAndBuy(t,e,i){let r=this.tokens[0].id,n=[];e<this.minTradingLimit&&n.push("InsufficientTradingAmount");let s=t.balanceOut/this.maxOutRatio;if(e>s&&n.push("MaxOutRatioExceeded"),r===t.assetOut){let a=this.calculateTradeFee(e,i),o=kr.toPct(this.repayFeeApply?i.repayFee:i.exchangeFee),l=e+a,u=this.calculateInGivenOut(t,l),p=t.balanceIn/this.maxInRatio;return u>p&&n.push("MaxInRatioExceeded"),{amountIn:u,calculatedIn:u,amountOut:e,feePct:o,errors:n}}else{let a=this.calculateInGivenOut(t,e),o=t.balanceIn/this.maxInRatio;return a>o&&n.push("MaxInRatioExceeded"),{amountIn:a,calculatedIn:a,amountOut:e,feePct:0,errors:n}}}validateAndSell(t,e,i){let r=this.tokens[0].id,n=[];e<this.minTradingLimit&&n.push("InsufficientTradingAmount");let s=t.balanceIn/this.maxInRatio;if(e>s&&n.push("MaxInRatioExceeded"),r===t.assetIn){let a=this.calculateOutGivenIn(t,e),o=t.balanceOut/this.maxOutRatio;return a>o&&n.push("MaxOutRatioExceeded"),{amountIn:e,calculatedOut:a,amountOut:a,feePct:0,errors:n}}else{let a=this.calculateOutGivenIn(t,e),o=this.calculateTradeFee(a,i),l=kr.toPct(this.repayFeeApply?i.repayFee:i.exchangeFee),u=a-o,p=t.balanceOut/this.maxOutRatio;return u>p&&n.push("MaxOutRatioExceeded"),{amountIn:e,calculatedOut:a,amountOut:u,feePct:l,errors:n}}}calculateInGivenOut(t,e){let i=ot.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=ot.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=ot.getSpotPrice(t.balanceOut.toString(),t.balanceIn.toString(),t.weightOut.toString(),t.weightIn.toString(),qt.big.toBigInt(1,qt.RUNTIME_DECIMALS).toString());return BigInt(e)}spotPriceOutGivenIn(t){let e=ot.getSpotPrice(t.balanceIn.toString(),t.balanceOut.toString(),t.weightIn.toString(),t.weightOut.toString(),qt.big.toBigInt(1,qt.RUNTIME_DECIMALS).toString());return BigInt(e)}calculateTradeFee(t,e){let i=ot.calculatePoolTradeFee(t.toString(),this.repayFeeApply?e.repayFee[0]:e.exchangeFee[0],this.repayFeeApply?e.repayFee[1]:e.exchangeFee[1]);return BigInt(i)}};var qr=require("polkadot-api"),Nt=require("rxjs");var Mr=(c,t=new Map)=>e=>{let i;return t.has(e)?t.get(e):(t.set(e,i=c(e)),i)};var F=require("rxjs"),P=require("rxjs/operators");var Dr=require("rxjs"),ei=class{store$=new Dr.BehaviorSubject([]);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((a,o)=>[a.address,o])),r=await t(e),n=e.slice(),s=new Set;for(let a of r){let o=i.get(a.address);o===void 0?(i.set(a.address,n.length),n.push(a)):n[o]=a,s.add(a.address)}this.changeset=s,this.store$.next(n)}).catch(console.error)}destroy(){this.store$.complete()}};var Lr=require("@galacticcouncil/common");var es={Aave:"AAVE",LBP:"LBP",Omnipool:"OMNI",Stableswap:"STBL",XYK:"XYK",HSM:"HSM"},{logger:ii}=Lr.log,ri=class{type;constructor(t){this.type=t}prefix(){return this.pad(`pool(${es[this.type]})`,10)}trace(t,...e){ii.trace(`${this.prefix()} ${t} :`,...e)}debug(t,...e){ii.debug(`${this.prefix()} ${t} :`,...e)}info(t,...e){ii.info(`${this.prefix()} ${t} :`,...e)}error(t,...e){ii.error(`${this.prefix()} ${t} :`,...e)}pad(t,e){return t.length>=e?t:t+" ".repeat(e-t.length)}};var{withTimeout:is}=ae,rs=3e3,j=class extends D{evm;balance;store=new ei;log;shared$;resync$=new F.ReplaySubject(1);resyncAt=0;resyncPending=!1;mem=0;memPoolsCache=new _t(null,{ttl:6*1e3});memPools=Mr(t=>(this.log.info("pool_sync",{mem:t}),this.loadPools()),this.memPoolsCache);constructor(t,e){super(t),this.evm=e,this.balance=new ut(t),this.log=new ri(this.getPoolType())}async getMemPools(){return this.memPools(this.mem)}async getPools(){return(await this.getMemPools()).filter(e=>this.hasValidAssets(e))}getSubscriber(){return this.shared$||(this.shared$=this.subscribeStore()),this.shared$.pipe((0,P.startWith)([]),(0,P.bufferCount)(2,1),(0,P.map)(([t,e])=>t.length===0?e:this.store.applyChangeset(e)),(0,P.filter)(t=>t.length>0),(0,P.throttleTime)(1e3,void 0,{leading:!0,trailing:!0}))}subscribeStore(){return(0,F.defer)(()=>{let t=new F.Subscription;return t.add(this.startWatchdog()),this.resync$.next(),this.resync$.pipe((0,P.switchMap)(()=>{let e=new F.Subscription;return(0,F.from)(is(this.getMemPools(),6e4,"getMemPools stalled")).pipe((0,P.tap)(()=>this.log.info("pool_synced",{mem:this.mem})),(0,P.map)(r=>r.filter(n=>this.hasValidAssets(n))),(0,P.tap)(r=>this.store.set(r)),(0,P.catchError)(()=>(this.log.error("pool_seed_error",{mem:this.mem}),this.requestResync(!0),F.EMPTY))).pipe((0,P.tap)(()=>{e.add(this.subscribeBalances()),e.add(this.subscribeUpdates())}),(0,P.switchMap)(r=>(0,F.merge)((0,F.of)(r),this.store.asObservable().pipe((0,P.skip)(1)))),(0,P.finalize)(()=>{e.unsubscribe()}))}),(0,P.finalize)(()=>t.unsubscribe()),(0,P.share)({connector:()=>new F.ReplaySubject(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 n=this.balance.watchSystemBalance(i);r.push(n)}if(this.hasErc20Asset(e)){let n=e.tokens.filter(a=>a.type==="Erc20").map(a=>a.id),s=this.balance.watchErc20Balance(i,n);r.push(s)}return(0,F.combineLatest)(r).pipe((0,P.map)(n=>n.flat()),(0,P.pairwise)(),(0,P.map)(([n,s])=>this.balance.getDeltas(n,s)),(0,P.filter)(n=>n.length>0),(0,P.map)(n=>[i,n]))});return(0,F.merge)(...t).pipe((0,P.bufferTime)(250),(0,P.filter)(e=>e.length>0),(0,P.map)(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})=>i>0n&&!!e)}updateBalances=(t,e)=>{let i=[],r=new Map(t.map(n=>[n.address,n]));for(let[n,s]of e){let a=r.get(n);if(a){let o=a.tokens.map(l=>{let u=s.find(p=>p.id===l.id);return u&&l.id!==a.id?{...l,balance:u.balance.transferable}:l});i.push({...a,tokens:o})}}return i};resync(t=!1){let e=Date.now();!t&&e-this.resyncAt<rs||(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((0,P.pairwise)(),(0,P.filter)(([n,s])=>n==="offline"&&s==="online"),(0,P.tap)(()=>{this.log.debug("watchdog_recover_online",{mem:this.mem}),this.requestResync()}),(0,P.catchError)(n=>(this.log.error("watchdog_recovery_error",n),F.EMPTY)),(0,P.repeat)({delay:1e3})),r=this.watcher.finalizedBlock$.pipe((0,P.pairwise)(),(0,P.tap)(([n,s])=>{let a=Number(n.number),o=Number(s.number),l=o-a;l>=3&&(this.log.debug("watchdog_gap",{from:a,to:o,gap:l}),this.requestResync())}),(0,P.catchError)(n=>(this.log.error("watchdog_gap_error",n),F.EMPTY)),(0,P.repeat)({delay:1e3}));return(0,F.merge)(i,r).subscribe()}watchGuard(t){return e=>e.pipe((0,P.tap)({error:i=>{this.log.error(t,i),this.requestResync(!0)}}),(0,P.finalize)(()=>{this.log.debug(t,"unsub")}),(0,P.catchError)(()=>F.EMPTY))}};var me=class extends j{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:n,final_weight:s}=t,a=ot.calculateLinearWeights(i?i.toString():"0",r?r.toString():"0",n.toString(),s.toString(),e.toString()),o=BigInt(a),l=this.MAX_FINAL_WEIGHT-BigInt(o);return[o,l]}async isSupported(){let t=this.api.query.LBP.PoolData,e=await this.api.compatibilityToken;return t.isCompatible(qr.CompatibilityLevel.BackwardsCompatible,e)}async loadPools(){let[t,e,i]=await Promise.all([this.api.query.LBP.PoolData.getEntries({at:"best"}),this.api.query.ParachainSystem.ValidationData.getValue({at:"best"}),this.getPoolLimits()]),r=e?.relay_parent_number||0,n=t.filter(({value:s})=>e&&this.isActivePool(s,r)).map(async({keyArgs:s,value:a})=>{let[o]=s,l=o.toString(),u=await this.getPoolDelta(l,a,r);return{address:l,type:"LBP",fee:a.fee,...u,...i}});return Promise.all(n)}async getPoolDelta(t,e,i){let{assets:r,repay_target:n,fee_collector:s}=e,[a,o]=this.getPoolWeights(e,i),[l,u]=r,[p,d,m,h,b]=await Promise.all([this.isRepayFeeApplied(l,n,s.toString()),this.balance.getBalance(t,l),this.api.query.AssetRegistry.Assets.getValue(l),this.balance.getBalance(t,u),this.api.query.AssetRegistry.Assets.getValue(u)]);return{repayFeeApply:p,tokens:[{id:l,decimals:m?.decimals,existentialDeposit:m?.existential_deposit,balance:d.transferable,weight:a,type:m?.asset_type.type},{id:u,decimals:b?.decimals,existentialDeposit:b?.existential_deposit,balance:h.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(n=>n.address===e);return{repayFee:await this.getRepayFee(),exchangeFee:i.fee}}subscribeValidationData(){return this.api.query.ParachainSystem.ValidationData.watchValue("best").pipe((0,Nt.filter)(t=>t!==void 0),(0,Nt.distinctUntilChanged)((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 n=this.poolsData.get(r.address);if(n){let{assets:s,repay_target:a,fee_collector:o}=n,[l]=s,[u,p]=this.getPoolWeights(n,t),[d,m]=r.tokens,h=[{...d,weight:u},{...m,weight:p}],b=await this.isRepayFeeApplied(l,a,o.toString());i.push({...r,tokens:h,repayFeeApply:b})}}return i})})}subscribeUpdates(){let t=new Nt.Subscription;return t.add(this.subscribeValidationData()),t}};var Hi={};R(Hi,{OmniMath:()=>B,OmniPool:()=>de,OmniPoolClient:()=>ge});var x=require("@galacticcouncil/math-omnipool"),At=ft(require("big.js")),B=class{static calculateSpotPrice(t,e,i,r){return(0,x.calculate_spot_price)(t,e,i,r)}static calculateLrnaSpotPrice(t,e){return(0,x.calculate_lrna_spot_price)(t,e)}static calculateInGivenOut(t,e,i,r,n,s,a,o,l){return(0,x.calculate_in_given_out)(t,e,i,r,n,s,a,o,l)}static calculateLrnaInGivenOut(t,e,i,r,n){return(0,x.calculate_lrna_in_given_out)(t,e,i,r,n)}static calculateOutGivenIn(t,e,i,r,n,s,a,o,l){return(0,x.calculate_out_given_in)(t,e,i,r,n,s,a,o,l)}static calculateOutGivenLrnaIn(t,e,i,r,n){return(0,x.calculate_out_given_lrna_in)(t,e,i,r,n)}static calculateShares(t,e,i,r){return(0,x.calculate_shares)(t,e,i,r)}static calculateLiquidityOut(t,e,i,r,n,s,a,o){return(0,x.calculate_liquidity_out)(t,e,i,r,n,s,a,o)}static calculateLiquidityLRNAOut(t,e,i,r,n,s,a,o){return(0,x.calculate_liquidity_lrna_out)(t,e,i,r,n,s,a,o)}static calculateCapDifference(t,e,i,r){let n=(0,At.default)(e),s=(0,At.default)(t),a=(0,At.default)(r),o=(0,At.default)(i),l=(0,At.default)(10).pow(18),u=o.div(l);if(n.div(a).lt(u)){let d=u.times(a).minus(n).times(s),m=n.times((0,At.default)(1).minus(u));return d.div(m).toFixed(0)}else return"0"}static calculateLimitHubIn(t,e,i,r){return(0,x.calculate_liquidity_hub_in)(t,e,i,r)}static isSellAllowed(t){return(0,x.is_sell_allowed)(t)}static isBuyAllowed(t){return(0,x.is_buy_allowed)(t)}static isAddLiquidityAllowed(t){return(0,x.is_add_liquidity_allowed)(t)}static isRemoveLiquidityAllowed(t){return(0,x.is_remove_liquidity_allowed)(t)}static recalculateAssetFee(t,e,i,r,n,s,a,o,l,u,p){return(0,x.recalculate_asset_fee)(t,e,i,r,n,s,a,o,l,u,p)}static recalculateProtocolFee(t,e,i,r,n,s,a,o,l,u,p){return(0,x.recalculate_protocol_fee)(t,e,i,r,n,s,a,o,l,u,p)}static verifyAssetCap(t,e,i,r){return(0,x.verify_asset_cap)(t,e,i,r)}};var Nr=require("@galacticcouncil/common");var{FeeUtils:Ht}=_,de=class c{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;hubAssetId;static fromPool(t){return new c(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(s=>[s.id,s])),r=i.get(t),n=i.get(e);if(r==null)throw new Error("Pool does not contain tokenIn");if(n==null)throw new Error("Pool does not contain tokenOut");return{assetIn:t,assetOut:e,hubReservesIn:r.hubReserves,hubReservesOut:n.hubReserves,sharesIn:r.shares,sharesOut:n.shares,decimalsIn:r.decimals,decimalsOut:n.decimals,balanceIn:r.balance,balanceOut:n.balance,tradeableIn:r.tradeable,tradeableOut:n.tradeable,assetInEd:r.existentialDeposit,assetOutEd:n.existentialDeposit}}validateAndBuy(t,e,i){let r=this.calculateInGivenOut(t,e),n=this.calculateInGivenOut(t,e,i),s=r===0n?0:V.calculateDiffToRef(n,r),a=[],o=B.isSellAllowed(t.tradeableIn),l=B.isBuyAllowed(t.tradeableOut);(!o||!l)&&a.push("TradeNotAllowed"),(e<this.minTradingLimit||r<t.assetInEd)&&a.push("InsufficientTradingAmount");let u=t.balanceOut/this.maxOutRatio;e>u&&a.push("MaxOutRatioExceeded");let p=t.balanceIn/this.maxInRatio;return n>p&&a.push("MaxInRatioExceeded"),{amountIn:n,calculatedIn:r,amountOut:e,feePct:s,errors:a}}validateAndSell(t,e,i){let r=this.calculateOutGivenIn(t,e),n=this.calculateOutGivenIn(t,e,i),s=V.calculateDiffToRef(r,n),a=[],o=B.isSellAllowed(t.tradeableIn),l=B.isBuyAllowed(t.tradeableOut);(!o||!l)&&a.push("TradeNotAllowed"),(e<this.minTradingLimit||r<t.assetOutEd)&&a.push("InsufficientTradingAmount");let u=t.balanceIn/this.maxInRatio;e>u&&a.push("MaxInRatioExceeded");let p=t.balanceOut/this.maxOutRatio;return n>p&&a.push("MaxOutRatioExceeded"),{amountIn:e,calculatedOut:r,amountOut:n,feePct:s,errors:a}}calculateInGivenOut(t,e,i){if(t.assetIn==this.hubAssetId)return this.calculateLrnaInGivenOut(t,e,i);let r=B.calculateInGivenOut(t.balanceIn.toString(),t.hubReservesIn.toString(),t.sharesIn.toString(),t.balanceOut.toString(),t.hubReservesOut.toString(),t.sharesOut.toString(),e.toString(),i?Ht.toRaw(i.assetFee).toString():"0",i?Ht.toRaw(i.protocolFee).toString():"0"),n=BigInt(r);return n<0n?0n:n}calculateLrnaInGivenOut(t,e,i){let r=B.calculateLrnaInGivenOut(t.balanceOut.toString(),t.hubReservesOut.toString(),t.sharesOut.toString(),e.toString(),i?Ht.toRaw(i.assetFee).toString():"0"),n=BigInt(r);return n<0n?0n:n}calculateOutGivenIn(t,e,i){if(t.assetIn==this.hubAssetId)return this.calculateOutGivenLrnaIn(t,e,i);let r=B.calculateOutGivenIn(t.balanceIn.toString(),t.hubReservesIn.toString(),t.sharesIn.toString(),t.balanceOut.toString(),t.hubReservesOut.toString(),t.sharesOut.toString(),e.toString(),i?Ht.toRaw(i.assetFee).toString():"0",i?Ht.toRaw(i.protocolFee).toString():"0"),n=BigInt(r);return n<0n?0n:n}calculateOutGivenLrnaIn(t,e,i){let r=B.calculateOutGivenLrnaIn(t.balanceOut.toString(),t.hubReservesOut.toString(),t.sharesOut.toString(),e.toString(),i?Ht.toRaw(i.assetFee).toString():"0"),n=BigInt(r);return n<0n?0n:n}spotPriceInGivenOut(t){if(t.assetIn==this.hubAssetId)return this.spotPriceLrnaInGivenOut(t);let e=B.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=B.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=B.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=B.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 n=Nr.big.pow10(Math.abs(r));return r>0?t*n:t/n}};var wt=require("polkadot-api"),Ur=require("@polkadot-api/utils"),A=require("rxjs"),Vr=require("@galacticcouncil/common");var{FeeUtils:G}=_,Hr=wt.Binary.fromText("omnipool"),Gr=(0,wt.Enum)("Short"),ge=class extends j{queryBus=new le;block=0;dynamicFeesConfig=this.queryBus.scope("DynamicFees.AssetFeeConfiguration",t=>this.api.query.DynamicFees.AssetFeeConfiguration.getValue(t,{at:"best"}),t=>String(t));dynamicFees=this.queryBus.scope("DynamicFees.AssetFee",t=>this.api.query.DynamicFees.AssetFee.getValue(t,{at:"best"}),t=>String(t),6*1e3);emaOracles=this.queryBus.scope("EmaOracle.Oracles.Short",t=>this.api.query.EmaOracle.Oracles.getValue(Hr,t,Gr,{at:"best"}),t=>t.join(":"),6*1e3);getPoolType(){return"Omnipool"}getPoolAddress(){let t="modlomnipool".padEnd(32,"\0"),e=new TextEncoder().encode(t),i=(0,Ur.toHex)(e);return(0,wt.AccountId)(Vr.HYDRATION_SS58_PREFIX).dec(i)}getOraclePair(t){return t===0?[0,1]:[1,t]}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(){let t=this.api.query.Omnipool.Assets,e=await this.api.compatibilityToken;return t.isCompatible(wt.CompatibilityLevel.BackwardsCompatible,e)}async loadPools(){let t=await this.api.constants.Omnipool.HubAssetId(),e=this.getPoolAddress(),[i,r,n,s,a]=await Promise.all([this.api.query.Omnipool.Assets.getEntries({at:"best"}),this.api.query.Omnipool.HubAssetTradability.getValue(),this.api.query.AssetRegistry.Assets.getValue(t),this.balance.getBalance(e,t),this.getPoolLimits()]),o=i.map(async({keyArgs:u,value:p})=>{let[d]=u,{hub_reserve:m,shares:h,tradable:b,cap:g,protocol_shares:f}=p,[y,S]=await Promise.all([this.api.query.AssetRegistry.Assets.getValue(d),this.balance.getBalance(e,d)]);return{id:d,decimals:y?.decimals,existentialDeposit:y?.existential_deposit,balance:S.transferable,cap:g,hubReserves:m,protocolShares:f,shares:h,tradeable:b,type:y?.asset_type.type}}),l=await Promise.all(o);return l.push({id:t,decimals:n?.decimals,existentialDeposit:n?.existential_deposit,balance:s.transferable,tradeable:r,type:n?.asset_type.type}),[{address:e,type:"Omnipool",hubAssetId:t,tokens:l,...a}]}async getPoolFees(t){let e=t.assetOut,i=t.assetIn,r=await this.dynamicFeesConfig.get(e);if(r?.type==="Fixed"){let{asset_fee:y,protocol_fee:S}=r.value;return{assetFee:G.fromPermill(y),protocolFee:G.fromPermill(S)}}let n=this.getOraclePair(e),s=this.getOraclePair(i),[a,o,l]=await Promise.all([this.dynamicFees.get(e),this.emaOracles.get(n),this.emaOracles.get(s)]),[u,p,d]=await this.getAssetFee(t,this.block,a,o,r?.value.asset_fee_params),[m,h,b]=i===1?[0,0,0]:await this.getProtocolFee(t,this.block,a,l,r?.value.protocol_fee_params),g=u+m,f=d+b;return{assetFee:G.fromPermill(p),protocolFee:G.fromPermill(h),min:G.fromPermill(g),max:G.fromPermill(f)}}async getAssetFee(t,e,i,r,n){let{assetOut:s,balanceOut:a}=t,{min_fee:o,max_fee:l,decay:u,amplification:p}=n||await this.api.constants.DynamicFees.AssetFeeParameters();if(!i||!r)return[o,o,l];let d=G.fromPermill(o),m=G.fromPermill(l),[h]=r,{asset_fee:b,timestamp:g}=i,f=Math.max(1,e-g),y=h.volume.b_in.toString(),S=h.volume.b_out.toString(),v=h.liquidity.b.toString();s===0&&(y=h.volume.a_in.toString(),S=h.volume.a_out.toString(),v=h.liquidity.a.toString());let T=G.fromPermill(b),O=B.recalculateAssetFee(y,S,v,"9",a.toString(),G.toRaw(T).toString(),f.toString(),G.toRaw(d).toString(),G.toRaw(m).toString(),u.toString(),p.toString());return[o,Number(O)*1e6,l]}async getProtocolFee(t,e,i,r,n){let{assetIn:s,balanceIn:a}=t,{min_fee:o,max_fee:l,decay:u,amplification:p}=n||await this.api.constants.DynamicFees.ProtocolFeeParameters();if(!i||!r)return[o,o,l];let d=G.fromPermill(o),m=G.fromPermill(l),[h]=r,{protocol_fee:b,timestamp:g}=i,f=Math.max(1,e-g),y=h.volume.b_in.toString(),S=h.volume.b_out.toString(),v=h.liquidity.b.toString();s===0&&(y=h.volume.a_in.toString(),S=h.volume.a_out.toString(),v=h.liquidity.a.toString());let T=G.fromPermill(b),O=B.recalculateProtocolFee(y,S,v,"9",a.toString(),G.toRaw(T).toString(),f.toString(),G.toRaw(d).toString(),G.toRaw(m).toString(),u.toString(),p.toString());return[o,Number(O)*1e6,l]}subscribeEmaOracles(){let[t]=this.store.pools,i=t.tokens.map(r=>r.id).map(r=>this.getOraclePair(r)).map(r=>this.api.query.EmaOracle.Oracles.watchValue(Hr,r,Gr,"best").pipe((0,A.filter)(n=>n!==void 0),(0,A.map)((n,s)=>({value:n,index:s})),(0,A.tap)(({index:n})=>{n>0&&this.log.trace("emaOracle.Oracles",r.join(":"))}),(0,A.map)(({value:n})=>({pair:r,value:n}))));return(0,A.merge)(...i).pipe((0,A.finalize)(()=>this.emaOracles.clear()),this.watchGuard("emaOracle.Oracles")).subscribe(r=>{let{pair:n,value:s}=r;this.emaOracles.set(s,n)})}subscribeDynamicFees(){return this.api.query.DynamicFees.AssetFee.watchEntries({at:"best"}).pipe((0,A.distinctUntilChanged)((t,e)=>!e.deltas),(0,A.map)((t,e)=>({value:t,index:e})),(0,A.tap)(({value:t,index:e})=>{e>0&&this.log.trace("dynamicFees.AssetFee",t.deltas?.upserted)}),(0,A.finalize)(()=>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((0,A.distinctUntilChanged)((t,e)=>!e.deltas),(0,A.map)((t,e)=>({value:t,index:e})),(0,A.tap)(({value:t,index:e})=>{e>0&&this.log.trace("dynamicFees.AssetFeeConfiguration",t.deltas?.upserted)}),(0,A.finalize)(()=>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((0,A.distinctUntilChanged)((t,e)=>!e.deltas),(0,A.map)((t,e)=>({value:t,index:e})),(0,A.tap)(({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((n,s)=>{let[a]=s.args;return n.set(a,s.value),n},new Map),r=e.tokens.map(n=>{let s=i?.get(n.id);return s?this.updateTokenState(n,s):n});return[{...e,tokens:r}]})})}subscribeUpdates(){let t=new A.Subscription;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:n,cap:s,protocol_shares:a}=e;return{...t,cap:s,hubReserves:i,protocolShares:a,shares:r,tradeable:n}}};var Gi={};R(Gi,{StableMath:()=>Y,StableSwap:()=>Ot,StableSwapClient:()=>be});var k=require("@galacticcouncil/math-stableswap"),Y=class{static getPoolAddress(t){return(0,k.pool_account_name)(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,n){return(0,k.calculate_amplification)(t,e,i,r,n)}static calculateInGivenOut(t,e,i,r,n,s,a){return(0,k.calculate_in_given_out)(t,e,i,r,n,s,a)}static calculateAddOneAsset(t,e,i,r,n,s,a){return(0,k.calculate_add_one_asset)(t,e,i,r,n,s,a)}static calculateSharesForAmount(t,e,i,r,n,s,a){return(0,k.calculate_shares_for_amount)(t,e,i,r,n,s,a)}static calculateOutGivenIn(t,e,i,r,n,s,a){return(0,k.calculate_out_given_in)(t,e,i,r,n,s,a)}static calculateLiquidityOutOneAsset(t,e,i,r,n,s,a){return(0,k.calculate_liquidity_out_one_asset)(t,e,i,r,n,s,a)}static calculateShares(t,e,i,r,n,s){return(0,k.calculate_shares)(t,e,i,r,n,s)}static calculateSpotPriceWithFee(t,e,i,r,n,s,a,o){return(0,k.calculate_spot_price_with_fee)(t,e,i,r,n,s,a,o)}static recalculatePegs(t,e,i,r,n,s){let a=(0,k.recalculate_peg)(t,e,i,r,n,s);return JSON.parse(a)}};var he=require("@galacticcouncil/common");var{FeeUtils:Gt}=_,Ot=class c{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;amplification;isRampPeriod;id;fee;totalIssuance;pegs;static fromPool(t){return new c(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(s=>[s.id,s])),r=i.get(t),n=i.get(e);if(r==null)throw new Error("Pool does not contain tokenIn");if(n==null)throw new Error("Pool does not contain tokenOut");return{assetIn:t,assetOut:e,balanceIn:r.balance,balanceOut:n.balance,decimalsIn:r.decimals,decimalsOut:n.decimals,tradeableIn:this.id===t?15:r.tradeable,tradeableOut:this.id===e?15:n.tradeable,assetInEd:r.existentialDeposit,assetOutEd:n.existentialDeposit}}validateAndBuy(t,e,i){let r=this.calculateInGivenOut(t,e),n=this.calculateInGivenOut(t,e,i),s=r===0n?0:V.calculateDiffToRef(n,r),a=[],o=B.isSellAllowed(t.tradeableIn),l=B.isBuyAllowed(t.tradeableOut);return(!o||!l)&&a.push("TradeNotAllowed"),(e<this.minTradingLimit||r<t.assetInEd)&&a.push("InsufficientTradingAmount"),{amountIn:n,calculatedIn:r,amountOut:e,feePct:s,errors:a}}validateAndSell(t,e,i){let r=this.calculateOutGivenIn(t,e),n=this.calculateOutGivenIn(t,e,i),s=V.calculateDiffToRef(r,n),a=[],o=B.isSellAllowed(t.tradeableIn),l=B.isBuyAllowed(t.tradeableOut);return(!o||!l)&&a.push("TradeNotAllowed"),(e<this.minTradingLimit||r<t.assetOutEd)&&a.push("InsufficientTradingAmount"),{amountIn:e,calculatedOut:r,amountOut:n,feePct:s,errors:a}}calculateIn(t,e,i){let r=Y.calculateInGivenOut(this.getReserves(),Number(t.assetIn),Number(t.assetOut),e.toString(),this.amplification.toString(),i?Gt.toRaw(i.fee).toString():"0",this.getPegs()),n=BigInt(r);return n<0n?0n:n}calculateAddOneAsset(t,e,i){let r=Y.calculateAddOneAsset(this.getReserves(),e.toString(),Number(t.assetIn),this.amplification.toString(),this.totalIssuance.toString(),i?Gt.toRaw(i.fee).toString():"0",this.getPegs()),n=BigInt(r);return n<0n?0n:n}calculateSharesForAmount(t,e,i){let r=Y.calculateSharesForAmount(this.getReserves(),Number(t.assetOut),e.toString(),this.amplification.toString(),this.totalIssuance.toString(),i?Gt.toRaw(i.fee).toString():"0",this.getPegs()),n=BigInt(r);return n<0n?0n:n}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=Y.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=Y.calculateOutGivenIn(this.getReserves(),Number(t.assetIn),Number(t.assetOut),e.toString(),this.amplification.toString(),i?Gt.toRaw(i.fee).toString():"0",this.getPegs()),n=BigInt(r);return n<0n?0n:n}calculateWithdrawOneAsset(t,e,i){let r=Y.calculateLiquidityOutOneAsset(this.getReserves(),e.toString(),Number(t.assetOut),this.amplification.toString(),this.totalIssuance.toString(),i?Gt.toRaw(i.fee).toString():"0",this.getPegs()),n=BigInt(r);return n<0n?0n:n}calculateShares(t,e,i){let r=Y.calculateShares(this.getReserves(),this.getAssets(t.assetIn,e),this.amplification.toString(),this.totalIssuance.toString(),i?Gt.toRaw(i.fee).toString():"0",this.getPegs()),n=BigInt(r);return n<0n?0n:n}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=Y.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,Dt.jsonFormatter)}getAssets(t,e){let i={asset_id:Number(t),amount:e.toString()};return JSON.stringify([i],Dt.jsonFormatter)}normalizeSpot(t,e,i,r,n){return e?t*he.big.pow10(he.RUNTIME_DECIMALS-n):i?t/he.big.pow10(n-r):t}};var ni=require("polkadot-api"),Wr=require("@polkadot-api/utils"),Yr=require("@noble/hashes/blake2b"),Z=require("rxjs"),si=require("@galacticcouncil/common");var{FeeUtils:ns}=_,be=class extends j{poolsData=new Map([]);getPoolType(){return"Stableswap"}getPoolAddress(t){let e=Y.getPoolAddress(t),i=(0,Yr.blake2b)(e,{dkLen:32}),r=(0,Wr.toHex)(i);return(0,ni.AccountId)(si.HYDRATION_SS58_PREFIX).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:n,final_block:s}=t,a=Y.calculateAmplification(i.toString(),r.toString(),n.toString(),s.toString(),e.toString()),o=Number(a)<r;return{amplification:BigInt(a),isRampPeriod:o}}async getPoolTokens(t,e){let i=this.getPoolAddress(t),r=e.assets.map(async n=>{let[s,a,o]=await Promise.all([this.api.query.Stableswap.AssetTradability.getValue(t,n),this.api.query.AssetRegistry.Assets.getValue(n),this.balance.getBalance(i,n)]);return{id:n,decimals:a?.decimals,existentialDeposit:a?.existential_deposit,balance:o.transferable,tradeable:s,type:a?.asset_type.type}});return Promise.all(r)}async isSupported(){let t=this.api.query.Stableswap.Pools,e=await this.api.compatibilityToken;return t.isCompatible(ni.CompatibilityLevel.BackwardsCompatible,e)}async loadPools(){let[t,e,i]=await Promise.all([this.api.query.Stableswap.Pools.getEntries({at:"best"}),this.api.query.System.Number.getValue({at:"best"}),this.getPoolLimits()]),r=t.map(async({keyArgs:n,value:s})=>{let[a]=n,o=this.getPoolAddress(a),[l,u,p]=await Promise.all([this.getPoolTokens(a,s),this.api.query.Stableswap.PoolPegs.getValue(a,{at:"best"}),this.api.query.Tokens.TotalIssuance.getValue(a,{at:"best"})]),d=this.getPoolAmplification(s,e),m=u?this.getRecentPegs(u):this.getDefaultPegs(s);return l.push({id:a,tradeable:15,balance:p,decimals:si.RUNTIME_DECIMALS}),this.poolsData.set(a,s),{address:o,id:a,type:"Stableswap",fee:ns.fromPermill(s.fee),tokens:l,totalIssuance:p,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 Y.defaultPegs(t.assets.length)}getRecentPegs(t){let{current:e}=t;return Array.from(e.entries()).map(([i,r])=>r.map(n=>n.toString()))}subscribeIssuance(){let e=this.store.pools.map(i=>i.id).map(i=>this.api.query.Tokens.TotalIssuance.watchValue(i,"best").pipe((0,Z.map)((r,n)=>({value:r,index:n})),(0,Z.tap)(({index:r,value:n})=>{r>0&&this.log.trace("tokens.TotalIssuance",i,n)}),(0,Z.map)(({value:r})=>({id:i,value:r}))));return(0,Z.merge)(...e).pipe(this.watchGuard("tokens.TotalIssuance")).subscribe(i=>{let{id:r,value:n}=i;this.store.update(s=>{let a=[];return s.filter(o=>o.id===r).forEach(o=>{let l=o.tokens.map(u=>u.id===r?{...u,balance:n}:u);a.push({...o,tokens:l,totalIssuance:n})}),a})})}subscribePoolPegs(){return this.api.query.Stableswap.PoolPegs.watchEntries({at:"best"}).pipe((0,Z.distinctUntilChanged)((t,e)=>!e.deltas),(0,Z.map)((t,e)=>({value:t,index:e})),(0,Z.tap)(({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(n=>[n.id,n]));return t?.upserted.forEach(({args:n,value:s})=>{let[a]=n,o=r.get(a);if(o){let l=this.getRecentPegs(s);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 n=this.poolsData.get(r.id);if(n){let s=this.getPoolAmplification(n,t);i.push({...r,...s})}}),i})})}subscribeUpdates(){let t=new Z.Subscription;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={};R(Ui,{XykMath:()=>yt,XykPool:()=>ye,XykPoolClient:()=>fe});var M=require("@galacticcouncil/math-xyk"),yt=class{static getSpotPrice(t,e,i){return(0,M.get_spot_price)(t,e,i)}static calculateInGivenOut(t,e,i){return(0,M.calculate_in_given_out)(t,e,i)}static calculateOutGivenIn(t,e,i){return(0,M.calculate_out_given_in)(t,e,i)}static calculatePoolTradeFee(t,e,i){return(0,M.calculate_pool_trade_fee)(t,e,i)}static calculateLiquidityIn(t,e,i){return(0,M.calculate_liquidity_in)(t,e,i)}static calculateSpotPrice(t,e){return(0,M.calculate_spot_price)(t,e)}static calculateSpotPriceWithFee(t,e,i,r){return(0,M.calculate_spot_price_with_fee)(t,e,i,r)}static calculateShares(t,e,i){return(0,M.calculate_shares)(t,e,i)}static calculateLiquidityOutAssetA(t,e,i,r){return(0,M.calculate_liquidity_out_asset_a)(t,e,i,r)}static calculateLiquidityOutAssetB(t,e,i,r){return(0,M.calculate_liquidity_out_asset_b)(t,e,i,r)}};var $r=require("@galacticcouncil/common");var{FeeUtils:zr}=_,ye=class c{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;static fromPool(t){return new c(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(s=>[s.id,s])),r=i.get(t),n=i.get(e);if(r==null)throw new Error("Pool does not contain tokenIn");if(n==null)throw new Error("Pool does not contain tokenOut");return{assetIn:t,assetOut:e,decimalsIn:r.decimals,decimalsOut:n.decimals,balanceIn:r.balance,balanceOut:n.balance,assetInEd:r.existentialDeposit,assetOutEd:n.existentialDeposit}}validateAndBuy(t,e,i){let r=this.calculateInGivenOut(t,e),n=this.calculateTradeFee(r,i),s=zr.toPct(i.exchangeFee),a=r+n,o=[];(e<this.minTradingLimit||r<t.assetInEd)&&o.push("InsufficientTradingAmount");let l=t.balanceOut/this.maxOutRatio;e>l&&o.push("MaxOutRatioExceeded");let u=t.balanceIn/this.maxInRatio;return a>u&&o.push("MaxInRatioExceeded"),{amountIn:a,calculatedIn:r,amountOut:e,feePct:s,errors:o}}validateAndSell(t,e,i){let r=this.calculateOutGivenIn(t,e),n=this.calculateTradeFee(r,i),s=zr.toPct(i.exchangeFee),a=r-n,o=[];(e<this.minTradingLimit||r<t.assetOutEd)&&o.push("InsufficientTradingAmount");let l=t.balanceIn/this.maxInRatio;e>l&&o.push("MaxInRatioExceeded");let u=t.balanceOut/this.maxOutRatio;return a>u&&o.push("MaxOutRatioExceeded"),{amountIn:e,calculatedOut:r,amountOut:a,feePct:s,errors:o}}calculateInGivenOut(t,e){let i=yt.calculateInGivenOut(t.balanceIn.toString(),t.balanceOut.toString(),e.toString()),r=BigInt(i);return r<0n?0n:r}calculateOutGivenIn(t,e){let i=yt.calculateOutGivenIn(t.balanceIn.toString(),t.balanceOut.toString(),e.toString()),r=BigInt(i);return r<0n?0n:r}spotPriceInGivenOut(t){let e=yt.calculateSpotPrice(t.balanceOut.toString(),t.balanceIn.toString());return this.normalizeSpot(BigInt(e),t.decimalsOut,t.decimalsIn)}spotPriceOutGivenIn(t){let e=yt.calculateSpotPrice(t.balanceIn.toString(),t.balanceOut.toString());return this.normalizeSpot(BigInt(e),t.decimalsIn,t.decimalsOut)}calculateTradeFee(t,e){let i=yt.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 n=$r.big.pow10(Math.abs(r));return r>0?t*n:t/n}};var Xr=require("polkadot-api"),Kr=require("rxjs");var fe=class extends j{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(){let t=this.api.query.XYK.PoolAssets,e=await this.api.compatibilityToken;return t.isCompatible(Xr.CompatibilityLevel.BackwardsCompatible,e)}async loadPools(){let[t,e]=await Promise.all([this.api.query.XYK.PoolAssets.getEntries(),this.getPoolLimits()]),i=t.map(async({keyArgs:r,value:n})=>{let[s]=r,[a,o]=n,[l,u,p,d]=await Promise.all([this.balance.getBalance(s,a),this.api.query.AssetRegistry.Assets.getValue(a),this.balance.getBalance(s,o),this.api.query.AssetRegistry.Assets.getValue(o)]);return{address:s,type:"XYK",tokens:[{id:a,decimals:u?.decimals||this.decimals.get(a),existentialDeposit:u?.existential_deposit,balance:l.transferable,type:u?.asset_type.type},{id:o,decimals:d?.decimals||this.decimals.get(o),existentialDeposit:d?.existential_deposit,balance:p.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 Kr.Subscription.EMPTY}};var Vi={};R(Vi,{AavePool:()=>Pe,AavePoolClient:()=>ve});var Ut=require("@galacticcouncil/common");var Pe=class c{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;static fromPool(t){return new c(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(s=>[s.id,s])),r=i.get(t),n=i.get(e);if(r==null)throw new Error("Pool does not contain tokenIn");if(n==null)throw new Error("Pool does not contain tokenOut");return{assetIn:t,assetOut:e,balanceIn:r.balance,balanceOut:n.balance,decimalsIn:r.decimals,decimalsOut:n.decimals,assetInEd:0n,assetOutEd:0n}}validateAndBuy(t,e,i){let r=this.calculateInGivenOut(t,e),n=[];return e>t.balanceOut&&n.push("TradeNotAllowed"),{amountIn:r,calculatedIn:r,amountOut:e,feePct:0,errors:n}}validateAndSell(t,e,i){let r=this.calculateOutGivenIn(t,e),n=[];return r>t.balanceOut&&n.push("TradeNotAllowed"),{amountIn:e,calculatedOut:r,amountOut:r,feePct:0,errors:n}}calculateInGivenOut(t,e){return e}calculateOutGivenIn(t,e){return e}spotPriceInGivenOut(t){return Ut.big.toBigInt(1,Ut.RUNTIME_DECIMALS)}spotPriceOutGivenIn(t){return Ut.big.toBigInt(1,Ut.RUNTIME_DECIMALS)}calculateTradeFee(t,e){return 0n}};var Qr=require("polkadot-api"),Jr=require("@polkadot-api/utils"),gt=require("rxjs"),Zr=require("viem"),ai=require("@galacticcouncil/common");var jr=[{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:ss}=ai.erc20,as=["Supply","Withdraw","Repay","Borrow"],ve=class extends j{getPoolType(){return"Aave"}async isSupported(){return!0}getPoolId(t,e){let i=t+"/"+e,r=new TextEncoder().encode(i.padEnd(32,"\0")),n=(0,Jr.toHex)(r);return(0,Qr.AccountId)(ai.HYDRATION_SS58_PREFIX).dec(n)}getPoolLimits(){return{maxInRatio:0n,maxOutRatio:0n,minTradingLimit:0n}}async loadPools(){let e=(await this.api.apis.AaveTradeExecutor.pools({at:"best"})).map(async({reserve:i,atoken:r,liqudity_in:n,liqudity_out:s})=>{let[a,o,l,u]=await Promise.all([this.api.query.AssetRegistry.Assets.getValue(i),this.api.query.AssetRegistry.AssetLocations.getValue(i),this.api.query.AssetRegistry.Assets.getValue(r),this.api.query.AssetRegistry.AssetLocations.getValue(r)]);return{address:this.getPoolId(i,r),type:"Aave",tokens:[{id:i,decimals:a?.decimals,existentialDeposit:a?.existential_deposit,balance:n,location:o,type:a?.asset_type.type},{id:r,decimals:l?.decimals,existentialDeposit:l?.existential_deposit,balance:s,location:u,type:l?.asset_type.type}],...this.getPoolLimits()}});return Promise.all(e)}async getPoolDelta(t){let[e,i]=t.tokens,{liqudity_in:r,liqudity_out:n}=await this.api.apis.AaveTradeExecutor.pool(e.id,i.id,{at:"best"});return t.tokens.map(s=>{let a=s.id===e.id?r:n;return{...s,balance:a}})}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.asHex()}throw new Error("Invalid aave reserve multilocation")}return ss.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.map(s=>s.asHex()),n=i.asHex();try{let{eventName:s,args:a}=(0,Zr.decodeEventLog)({abi:jr,topics:r,data:n}),o=a.reserve.toLowerCase();return{eventName:s,reserve:o,key:`${s}:${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((0,gt.map)(({payload:i})=>this.parseRouterLog(i)),(0,gt.filter)(({assetIn:i,assetOut:r})=>e.includes(i)||e.includes(r)),this.watchGuard("router.Execute")).subscribe(({assetIn:i,assetOut:r,key:n})=>{this.log.trace("router.Executed",n),this.store.update(async s=>{let a=[];for(let o of s){let[l,u]=o.tokens;if(u.id===i||u.id===r){let d=await this.getPoolDelta(o);a.push({...o,tokens:d})}}return a})})}subscribeEvmLog(){return this.api.event.EVM.Log.watch().pipe((0,gt.map)(({payload:t})=>this.parseEvmLog(t)),(0,gt.filter)(t=>t!==void 0),(0,gt.filter)(({eventName:t})=>as.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 n of i){let[s]=n.tokens;if(this.getReserveH160Id(s).toLowerCase()===t){let o=await this.getPoolDelta(n);r.push({...n,tokens:o})}}return r})})}subscribeBalances(){return gt.Subscription.EMPTY}subscribeUpdates(){let t=new gt.Subscription;return t.add(this.subscribeRouterExecuted()),t.add(this.subscribeEvmLog()),t}};var Yi={};R(Yi,{HsmMath:()=>rt,HsmPool:()=>Se,HsmPoolClient:()=>Te});var z=require("@galacticcouncil/math-hsm"),rt=class{static calculateCollateralInGivenHollarOut(t,e,i){return(0,z.calculate_collateral_in_given_hollar_out)(t,e,i)}static calculateCollateralOutGivenHollarIn(t,e,i){return(0,z.calculate_collateral_out_given_hollar_in)(t,e,i)}static calculateHollarOutGivenCollateralIn(t,e,i){return(0,z.calculate_hollar_out_given_collateral_in)(t,e,i)}static calculateHollarInGivenCollateralOut(t,e,i){return(0,z.calculate_hollar_in_given_collateral_out)(t,e,i)}static calculateImbalance(t,e,i){return(0,z.calculate_imbalance)(t,e,i)}static calculateBuybackLimit(t,e){return(0,z.calculate_buyback_limit)(t,e)}static calculateBuybackPriceWithFee(t,e,i){return(0,z.calculate_buyback_price_with_fee)(t,e,i)}static calculateMaxPrice(t,e){return(0,z.calculate_max_price)(t,e)}};var nt=require("@galacticcouncil/common");var{FeeUtils:Vt}=_,Se=class c extends Ot{hsmAddress;hsmMintCapacity;hollarId;hollarH160;collateralId;collateralBalance;maxBuyPriceCoefficient;maxInHolding;purchaseFee;buyBackFee;buyBackRate;static fromPool(t){return new c(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,r){let n=this.calculateBuybackLimit(t);e>n&&r.push("MaxBuyBackExceeded");let s=this.calculateBuyPrice(t,e,i),a=this.calculateMaxPrice(t);return s>a&&r.push("MaxBuyPriceExceeded"),i>this.collateralBalance&&r.push("InsufficientCollateral"),r}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,i,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=rt.calculateHollarInGivenCollateralOut(e.toString(),i.toString(),Vt.toRaw(this.buyBackFee).toString());return BigInt(r)}calculateCollateralInGivenHollarOut(t){let e=this.getCollateralPeg(),i=rt.calculateCollateralInGivenHollarOut(t.toString(),JSON.stringify(e),Vt.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=rt.calculateCollateralOutGivenHollarIn(e.toString(),i.toString(),Vt.toRaw(this.buyBackFee).toString());return BigInt(r)}calculateHollarOutGivenCollateralIn(t){let e=this.getCollateralPeg(),i=rt.calculateHollarOutGivenCollateralIn(t.toString(),JSON.stringify(e),Vt.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=rt.calculateImbalance(t.balanceIn.toString(),JSON.stringify(e),t.balanceOut.toString());return BigInt(i)}calculateBuybackLimit(t){let e=this.calculateImbalance(t),i=rt.calculateBuybackLimit(e.toString(),Vt.toRaw(this.buyBackRate).toString());return BigInt(i)}calculateBuyPrice(t,e,i){let r=rt.calculateBuybackPriceWithFee(i.toString(),e.toString(),Vt.toRaw(this.buyBackFee).toString()),[n,s]=JSON.parse(r),a=nt.big.pow10(t.decimalsIn+nt.RUNTIME_DECIMALS-t.decimalsOut);return BigInt(n)*a/BigInt(s)}calculateMaxPrice(t){let e=this.getCollateralPeg(),i=rt.calculateMaxPrice(JSON.stringify(e),this.maxBuyPriceCoefficient.toString()),[r,n]=JSON.parse(i),s=nt.big.pow10(nt.RUNTIME_DECIMALS-t.decimalsOut);return BigInt(r)*s/BigInt(n)}spotPriceInGivenOut(t){let e=nt.big.toBigInt(1,nt.RUNTIME_DECIMALS);return this.calculateInGivenOut(t,e)}spotPriceOutGivenIn(t){let e=nt.big.toBigInt(1,nt.RUNTIME_DECIMALS);return this.calculateOutGivenIn(t,e)}getCollateralPeg(){let t=this.tokens.findIndex(r=>r.id!==this.hollarId),e=this.pegs[t],i=this.tokens[t].decimals;return this.isDefaultPeg(e)?[nt.big.toBigInt(1,18).toString(),nt.big.toBigInt(1,i).toString()]:e}isDefaultPeg(t){let[e,i]=t;return Array.isArray(t)&&t.length===2&&e==="1"&&i==="1"}};var oi=require("polkadot-api"),en=require("@polkadot-api/utils"),$=require("rxjs"),rn=require("viem"),li=require("@galacticcouncil/common");var we=[{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 xe=class{client;constructor(t){this.client=t.getWsProvider()}async getFacilitatorCapacity(t,e){let[i,r]=await this.client.readContract({abi:we,address:t,functionName:"getFacilitatorBucket",args:[e]});return i-r}};var{FeeUtils:Wi}=_,{H160:tn}=li.h160,os=["FacilitatorBucketCapacityUpdated","FacilitatorBucketLevelUpdated"],Te=class extends j{ghoClient;stableClient;constructor(t,e,i){super(t,e),this.stableClient=i,this.ghoClient=new xe(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.asHex()}}throw Error("Invalid hollar multilocation")}getPoolAddress(t){let e=t.padEnd(32,"\0"),i=new TextEncoder().encode(e),r=(0,en.toHex)(i);return(0,oi.AccountId)(li.HYDRATION_SS58_PREFIX).dec(r)}async isSupported(){let t=this.api.query.HSM.Collaterals,e=await this.api.compatibilityToken;return t.isCompatible(oi.CompatibilityLevel.BackwardsCompatible,e)}async loadPools(){let t=await this.api.constants.HSM.HollarId(),[e,i,r]=await Promise.all([this.api.query.AssetRegistry.AssetLocations.getValue(t),this.api.query.HSM.Collaterals.getEntries({at:"best"}),this.stableClient.getPools()]);if(i.length===0)return[];let n=this.getFacilitatorAddress(),s=tn.fromAny(n),a=this.getHollarAddress(e),o=await this.ghoClient.getFacilitatorCapacity(a,s),l=i.map(async({keyArgs:p,value:d})=>{let[m]=p,{pool_id:h,max_buy_price_coefficient:b,max_in_holding:g,purchase_fee:f,buy_back_fee:y,buyback_rate:S}=d,v=r.find(T=>T.id===h);if(v){let T=this.getPoolId(h),O=await this.balance.getBalance(n,m);return{...v,address:T,type:"HSM",tokens:v.tokens.filter(L=>L.id!==h),hsmAddress:n,hsmMintCapacity:o,hollarId:t,hollarH160:a,collateralId:m,collateralBalance:O.transferable,maxBuyPriceCoefficient:b,maxInHolding:g,purchaseFee:Wi.fromPermill(f),buyBackFee:Wi.fromPermill(y),buyBackRate:Wi.fromPerbill(S)}}});return(await Promise.all(l)).filter(p=>p!==null)}async getPoolFees(){return{}}parseEvmLog(t){let{topics:e,data:i}=t.log,r=e.map(s=>s.asHex()),n=i.asHex();try{let{eventName:s,args:a}=(0,rn.decodeEventLog)({abi:we,topics:r,data:n}),o=a.facilitatorAddress.toLowerCase();return{eventName:s,facilitator:o,key:`${s}:${o}`}}catch{return}}subscribeEvmLog(){return this.api.event.EVM.Log.watch().pipe((0,$.map)(({payload:t})=>this.parseEvmLog(t)),(0,$.filter)(t=>t!==void 0),(0,$.filter)(({eventName:t})=>os.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:n,hollarH160:s}]=i,a=tn.fromAny(n);if(a.toLowerCase()===e){let l=await this.ghoClient.getFacilitatorCapacity(s,a);for(let u of i)r.push({...u,hsmMintCapacity:l})}return r})})}subscribeCollateralBalance(){let t=[],e=[];this.store.pools.forEach(n=>{let{tokens:s,collateralId:a}=n;s.find(l=>l.id===a).type==="Erc20"?e.push(a):t.push(a)});let[{hsmAddress:i}]=this.store.pools,r=[];if(t.length>0){let n=this.balance.watchTokensBalance(i);r.push(n)}if(e.length>0){let n=this.balance.watchErc20Balance(i,e);r.push(n)}return r.length>0?(0,$.combineLatest)(r).pipe((0,$.map)(n=>n.flat()),(0,$.pairwise)(),(0,$.map)(([n,s])=>this.balance.getDeltas(n,s)),this.watchGuard("balances")).subscribe(n=>{this.store.update(s=>{let a=[],o=new Map(s.map(l=>[l.collateralId,l]));return n.forEach(({id:l,balance:u})=>{let p=o.get(l);p&&(this.log.trace("balances",{id:l,balance:u}),a.push({...p,collateralBalance:u.transferable}))}),a})}):$.Subscription.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 n of i){let s=e.get(n.id);s&&r.push({...n,fee:s.fee,tokens:s.tokens.filter(a=>a.id!==n.id),totalIssuance:s.totalIssuance,pegs:s.pegs,amplification:s.amplification,isRampPeriod:s.isRampPeriod})}return r})})}subscribeBalances(){return $.Subscription.EMPTY}subscribeUpdates(){let t=new $.Subscription;return t.add(this.subscribeCollateralBalance()),t.add(this.subscribeStableswapUpdates()),t.add(this.subscribeEvmLog()),t}};var Wt=class{static get(t){switch(t.type){case"Aave":return Pe.fromPool(t);case"XYK":return ye.fromPool(t);case"Omnipool":return de.fromPool(t);case"LBP":return pe.fromPool(t);case"Stableswap":return Ot.fromPool(t);case"HSM":return Se.fromPool(t);default:throw new Error("Pool type "+t.type+" is not supported yet")}}};var nn=require("@galacticcouncil/common"),lt=require("rxjs");var{logger:ls}=nn.log,Yt=class extends D{evm;aave;omnipool;stableswap;hsm;xyk;lbp;active=new Set([]);pools=new Map([]);clients=[];aaveSub=lt.Subscription.EMPTY;omniSub=lt.Subscription.EMPTY;stableSub=lt.Subscription.EMPTY;hsmSub=lt.Subscription.EMPTY;xykSub=lt.Subscription.EMPTY;lbpSub=lt.Subscription.EMPTY;isReady=!1;isDestroyed=new lt.Subject;constructor(t,e){super(t),this.evm=e,this.aave=new ve(t,e),this.omnipool=new ge(t,e),this.stableswap=new be(t,e),this.hsm=new Te(t,e,this.stableswap),this.xyk=new fe(t,e),this.lbp=new me(t,e),this.clients=[this.aave,this.omnipool,this.stableswap,this.hsm,this.xyk,this.lbp]}subscribe(t){return t.getSubscriber().pipe((0,lt.takeUntil)(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")||(ls.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 ie(e.type)}};var Zi={};R(Zi,{DCA_TIME_RESERVE:()=>on,DEFAULT_BLOCK_TIME:()=>an,DEFAULT_MIN_BUDGET:()=>Ki,ORDER_MIN_BLOCK_PERIOD:()=>ln,Router:()=>zt,TWAP_EXECUTION_INTERVAL:()=>Oe,TWAP_MAX_DURATION:()=>Qi,TWAP_MAX_PRICE_IMPACT:()=>ji,TWAP_TX_MULTIPLIER:()=>Kp,TradeOrderError:()=>Xi,TradeOrderType:()=>ui,TradeRouteBuilder:()=>st,TradeRouter:()=>xt,TradeScheduler:()=>$t,TradeType:()=>ci});var Ie=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 cs=10,_e=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=[],n=new Ie,s=[];for(s.push([e,""]),n.enqueue(s);n.size()>0;){let a=n.dequeue();if(!a||a.length>cs)continue;let o=a[a.length-1];(i===null||o[0]===i)&&r.push(a),t.get(o[0])?.forEach(u=>{if(this.isNotVisited(u,a)){let p=[...a];p.push(u),n.enqueue(p)}})}return r}findShortestPaths(t,e,i){let r=[],n=new Ie,s=[];s.push([e,""]),n.enqueue(s);let a=1/0;for(;n.size()>0;){let o=n.dequeue();if(!o)continue;let l=o[o.length-1];if(l[0]===i){o.length<a?(a=o.length,r.length=0,r.push(o)):o.length===a&&r.push(o);continue}let u=t.get(l[0]);for(let p of u??[])this.isNotVisited(p,o)&&n.enqueue([...o,p])}return r}buildAndPopulateGraph(t,e){let i=new Map;for(let r of t)i.set(parseInt(r),[]);for(let[r,n,s]of e)i.get(n)?.push([s,r]);return i}};function $i(c){let t={};for(let e of c){let i=e.tokens.length;for(let r=0;r<i;r++){t[e.tokens[r].id]||(t[e.tokens[r].id]=[]);for(let n=0;n<i;n++){if(r==n)continue;let s=[e.address,e.tokens[r].id,e.tokens[n].id];t[e.tokens[r].id].push(s)}}}return t}var Ae=class{getProposals(t,e,i){let r=i.filter(g=>g.type==="XYK"),n=i.filter(g=>g.type!=="XYK"),s=new Set(n.map(g=>g.tokens).flat().map(g=>g.id)),a=s.has(t),o=s.has(e),l=new _e,u=g=>{let f=$i(g),y=Object.keys(f),S=y.flatMap(v=>f[v]);return l.buildAndPopulateGraph(y,S)};if(!a&&!o){let g=r.filter(S=>S.tokens.find(v=>v.id===t)||S.tokens.find(v=>v.id===e)),f=u(g),y=l.findPaths(f,t,e);return this.parsePaths(y)}if(a&&o){let g=u(n),f=l.findPaths(g,t,e);return this.parsePaths(f)}let p=a?e:t,d=r.filter(g=>g.tokens.some(f=>f.id===p));if(d.length===0)return[];let m=[...n,...d],h=u(m),b=l.findPaths(h,t,e);return this.parsePaths(b)}parsePaths(t){let e=[];for(let i of t){let r=[];for(let n=0;n<i.length;n++){let s=i[n],a=i[n+1];if(a==null)break;r.push(this.toEdge(s,a))}e.push(r)}return e}toEdge(t,e){return[e[1],t[0],e[0]]}};var zt=class{routeSuggester;routeProposals;ctx;filter={};constructor(t){this.ctx=t,this.routeSuggester=new Ae,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),n=new Set(i);return t.filter(s=>n.has(s.type)?!1:r.size>0?r.has(s.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(s=>this.validPath(s,r)).map(s=>this.toHops(s,r))}getProposals(t,e,i){let r=this.buildRouteKey(t,e,i);if(this.routeProposals.has(r))return this.routeProposals.get(r);let n=this.routeSuggester.getProposals(t,e,i);return this.routeProposals.set(r,n),n}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,Wt.get(e)]))}toHops(t,e){return t.map(([i,r,n])=>{let s=e.get(i);return{poolAddress:i,poolId:s?.id,pool:s?.type,assetIn:r,assetOut:n}})}};var I=require("@galacticcouncil/common");var ci=(e=>(e.Buy="Buy",e.Sell="Sell",e))(ci||{}),ui=(i=>(i.Dca="Dca",i.TwapSell="TwapSell",i.TwapBuy="TwapBuy",i))(ui||{}),Xi=(i=>(i.OrderTooSmall="OrderTooSmall",i.OrderTooBig="OrderTooBig",i.OrderImpactTooBig="OrderImpactTooBig",i))(Xi||{});var{FeeUtils:sn}=_,xt=class extends zt{mlr;constructor(t){super(t),this.mlr=new Map}onFilterChanged(){this.mlr.clear()}buildCtxSync(t,e,i){let r=super.validateInput(t,e,i),n=super.getPaths(t,e,i);if(!n.length)throw new re(t,e);return{paths:n,pools:i,poolsMap:r}}async withCtx(t,e,i){let r=await super.getPools(),n=this.buildCtxSync(t,e,r);return i(n)}isDirectTrade(t){return t.length==1}findBestSellRoute(t){let e=t.sort((i,r)=>{let n=i[i.length-1].amountOut,s=r[r.length-1].amountOut;return n>s?-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(n=>n.tradeFeeRange?.[0]??n.tradeFeePct).reduce((n,s)=>n+s),r=t.map(n=>n.tradeFeeRange?.[1]??n.tradeFeePct).reduce((n,s)=>n+s);return[i,r]}}getPoolFeeRange(t){let e=t.min?sn.toPct(t.min):void 0,i=t.max?sn.toPct(t.max):void 0;if(e&&i)return[e,i]}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:n,poolsMap:s})=>{let a;if(r)a=await this.toSellSwaps(i,r,s);else{let o=n.map(u=>this.toSellSwaps(i,u,s)),l=await Promise.all(o);a=this.findBestSellRoute(l)}return this.buildSell(s,a)})}async getSells(t,e,i){return this.withCtx(t,e,async({paths:r,poolsMap:n})=>{let s=r.map(o=>this.toSellSwaps(i,o,n));return(await Promise.all(s)).filter(o=>o.every(l=>l.errors.length==0)).map(o=>this.buildSell(n,o)).sort((o,l)=>o.amountOut>l.amountOut?-1:1)})}buildSell(t,e){let i=e[0],r=e[e.length-1],n=this.isDirectTrade(e),s=this.getSellSpot(e),a=r.amountOut,o=n?r.calculatedOut:this.calculateDelta0Y(i.amountIn,e,t),l=o-a,u=this.getRouteFeeRange(e),p=n?r.tradeFeePct:V.calculateSellFee(o,a),d=H.mulSpot(i.amountIn,s,i.assetInDecimals,r.assetOutDecimals),m=V.calculateDiffToRef(o,d);return{type:"Sell",amountIn:i.amountIn,amountOut:r.amountOut,spotPrice:s,tradeFee:l,tradeFeePct:p,tradeFeeRange:u,priceImpactPct:m,swaps:e,toHuman(){return{type:"Sell",amountIn:I.big.toDecimal(i.amountIn,i.assetInDecimals),amountOut:I.big.toDecimal(r.amountOut,r.assetOutDecimals),spotPrice:I.big.toDecimal(s,I.RUNTIME_DECIMALS),tradeFee:I.big.toDecimal(l,r.assetOutDecimals),tradeFeePct:p,tradeFeeRange:u,priceImpactPct:m,swaps:e.map(h=>h.toHuman())}}}}calculateSpot(t){return t.map(e=>e.spotPrice).reduce((e,i)=>e*i/10n**BigInt(I.RUNTIME_DECIMALS))}calculateDelta0Y(t,e,i){let r=[];for(let n=0;n<e.length;n++){let s=e[n],a=i.get(s.poolAddress);if(a==null)throw new Error("Pool does not exit");let o=a.parsePair(s.assetIn,s.assetOut),l;n>0?l=r[n-1]:l=t;let u=a.calculateOutGivenIn(o,l);r.push(u)}return r[r.length-1]}async calculateMostLiquidRoute(t,e,i){let{paths:r,pools:n,poolsMap:s}=i,l=n.filter(b=>b.tokens.some(g=>g.id===t)).map(b=>b.type==="Aave"?b.tokens:b.tokens.filter(g=>g.id===t)).map(b=>b.map(g=>g.balance).reduce((g,f)=>g+f)).sort((b,g)=>g<b?-1:1)[0],u=H.getFraction(l,.1),p=await Promise.all(r.map(b=>this.toSellSwaps(u,b,s))),m=this.findBestSellRoute(p).map(b=>({poolAddress:b.poolAddress,poolId:b?.poolId,pool:b.pool,assetIn:b.assetIn,assetOut:b.assetOut})),h=this.buildRouteKey(t,e,n);return this.mlr.set(h,m),m}async toSellSwaps(t,e,i){let r=[];for(let n=0;n<e.length;n++){let s=e[n],a=i.get(s.poolAddress);if(a==null)throw new Error("Pool does not exit");let o=a.parsePair(s.assetIn,s.assetOut),l;n>0?l=r[n-1].amountOut:l=typeof t=="string"?I.big.toBigInt(t,o.decimalsIn):t;let u=await this.ctx.getPoolFees(o,a),{amountOut:p,calculatedOut:d,feePct:m,errors:h}=a.validateAndSell(o,l,u),b=this.getPoolFeeRange(u),g=a.spotPriceOutGivenIn(o),f=H.mulSpot(l,g,o.decimalsIn,o.decimalsOut),y=V.calculateDiffToRef(d,f);r.push({...s,assetInDecimals:o.decimalsIn,assetOutDecimals:o.decimalsOut,amountIn:l,amountOut:p,calculatedOut:d,spotPrice:g,tradeFeePct:m,tradeFeeRange:b,priceImpactPct:y,errors:h,isSupply(){return a.type==="Aave"&&a.tokens[0].id===s.assetIn},isWithdraw(){return a.type==="Aave"&&a.tokens[1].id===s.assetIn},toHuman(){return{...s,amountIn:I.big.toDecimal(l,o.decimalsIn),amountOut:I.big.toDecimal(p,o.decimalsOut),calculatedOut:I.big.toDecimal(d,o.decimalsOut),spotPrice:I.big.toDecimal(g,I.RUNTIME_DECIMALS),tradeFeePct:m,tradeFeeRange:b,priceImpactPct:y,errors:h}}})}return r}async getMostLiquidRoute(t,e){return this.withCtx(t,e,async i=>{let r=this.buildRouteKey(t,e,i.pools),n=this.mlr.get(r);return n||this.calculateMostLiquidRoute(t,e,i)})}async getSpotPrice(t,e){return this.withCtx(t,e,async i=>{let{pools:r,poolsMap:n}=i,s=this.buildRouteKey(t,e,r),a=this.mlr.get(s);a||(a=await this.calculateMostLiquidRoute(t,e,i));let o=await this.toSellSwaps("1",a,n);return{amount:this.getSellSpot(o),decimals:I.RUNTIME_DECIMALS}}).catch(()=>{})}findBestBuyRoute(t){let e=t.sort((i,r)=>{let n=i[0].amountIn,s=r[0].amountIn;return n>s?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:n,poolsMap:s})=>{let a;if(r)a=await this.toBuySwaps(i,r,s);else{let o=n.map(u=>this.toBuySwaps(i,u,s)),l=await Promise.all(o);a=this.findBestBuyRoute(l)}return this.buildBuy(s,a)})}async getBuys(t,e,i){return this.withCtx(t,e,async({paths:r,poolsMap:n})=>{let s=r.map(o=>this.toBuySwaps(i,o,n));return(await Promise.all(s)).filter(o=>o.every(l=>l.errors.length==0)).map(o=>this.buildBuy(n,o)).sort((o,l)=>o.amountIn>l.amountIn?1:-1)})}buildBuy(t,e){let i=e[e.length-1],r=e[0],n=this.isDirectTrade(e),s=this.getBuySpot(e),a=r.amountIn,o=n?r.calculatedIn:this.calculateDelta0X(i.amountOut,e,t),l=a-o,u=this.getRouteFeeRange(e),p=n?r.tradeFeePct:V.calculateBuyFee(o,a),d=H.mulSpot(i.amountOut,s,i.assetOutDecimals,r.assetInDecimals),m;return o===0n?m=-100:m=V.calculateDiffToRef(d,o),{type:"Buy",amountOut:i.amountOut,amountIn:r.amountIn,spotPrice:s,tradeFee:l,tradeFeePct:p,tradeFeeRange:u,priceImpactPct:m,swaps:e,toHuman(){return{type:"Buy",amountOut:I.big.toDecimal(i.amountOut,i.assetOutDecimals),amountIn:I.big.toDecimal(r.amountIn,r.assetInDecimals),spotPrice:I.big.toDecimal(s,I.RUNTIME_DECIMALS),tradeFee:I.big.toDecimal(l,r.assetInDecimals),tradeFeePct:p,tradeFeeRange:u,priceImpactPct:m,swaps:e.map(h=>h.toHuman())}}}}calculateDelta0X(t,e,i){let r=[];for(let n=e.length-1;n>=0;n--){let s=e[n],a=i.get(s.poolAddress);if(a==null)throw new Error("Pool does not exit");let o=a.parsePair(s.assetIn,s.assetOut),l;n==e.length-1?l=t:l=r[0];let u=a.calculateInGivenOut(o,l);r.unshift(u)}return r[0]}async toBuySwaps(t,e,i){let r=[];for(let n=e.length-1;n>=0;n--){let s=e[n],a=i.get(s.poolAddress);if(a==null)throw new Error("Pool does not exit");let o=a.parsePair(s.assetIn,s.assetOut),l;n==e.length-1?l=typeof t=="string"?I.big.toBigInt(t,o.decimalsOut):t:l=r[0].amountIn;let u=await this.ctx.getPoolFees(o,a),{amountIn:p,calculatedIn:d,feePct:m,errors:h}=a.validateAndBuy(o,l,u),b=this.getPoolFeeRange(u),g=a.spotPriceInGivenOut(o),f=H.mulSpot(l,g,o.decimalsOut,o.decimalsIn),y;d===0n?y=-100:y=V.calculateDiffToRef(f,d),r.unshift({...s,assetInDecimals:o.decimalsIn,assetOutDecimals:o.decimalsOut,amountOut:l,amountIn:p,calculatedIn:d,spotPrice:g,tradeFeePct:m,tradeFeeRange:b,priceImpactPct:y,errors:h,isSupply(){return a.type==="Aave"&&a.tokens[0].id===s.assetIn},isWithdraw(){return a.type==="Aave"&&a.tokens[1].id===s.assetIn},toHuman(){return{...s,amountOut:I.big.toDecimal(l,o.decimalsOut),amountIn:I.big.toDecimal(p,o.decimalsIn),calculatedIn:I.big.toDecimal(d,o.decimalsIn),spotPrice:I.big.toDecimal(g,I.RUNTIME_DECIMALS),tradeFeePct:m,tradeFeeRange:b,priceImpactPct:y,errors:h}}})}return r}};var X=require("@galacticcouncil/common");var an=6e3,Ki=1000000000000000n,Oe=6,ji=-5,Qi=216e5,Kp=3,on=.1,ln=6;var Ji=require("polkadot-api");var st=class{static build(t){return t.map(({assetIn:e,assetOut:i,pool:r,poolId:n})=>r==="Stableswap"?{pool:(0,Ji.Enum)("Stableswap",n),asset_in:e,asset_out:i}:{pool:(0,Ji.Enum)(r),asset_in:e,asset_out:i})}};var $t=class{schedulerOptions;router;constructor(t,e={}){this.router=new xt(t),this.router.withFilter({exclude:["HSM"]}),this.schedulerOptions=Object.freeze({blockTime:e.blockTime??6e3,minBudgetInNative:e.minBudgetInNative??Ki})}get blockTime(){return this.schedulerOptions.blockTime}get minOrderBudget(){return this.schedulerOptions.minBudgetInNative}async getDcaOrder(t,e,i,r,n){let s=await this.router.getBestSell(t,e,i),{amountIn:a,swaps:o,priceImpactPct:l}=s,u=o[0],p=o[o.length-1],{assetInDecimals:d}=u,{assetOutDecimals:m}=p,h=Math.abs(l),b=await this.getMinimumOrderBudget(t,d),g=this.getOptimalTradeCount(h),f=this.getMaximumTradeCount(a,b,r),y=n||Math.min(g,f),S=Math.round(r/y),v=a/BigInt(y),T=await this.router.getBestSell(t,e,v),O=a<b,L=[];O&&L.push("OrderTooSmall");let U=T.amountOut*BigInt(y),ct=this.toBlockPeriod(S),ht=T.tradeFee*BigInt(y),Q=st.build(o),et={assetIn:t,assetOut:e,errors:L,maxTradeCount:f,tradeCount:y,tradeFee:ht,tradeImpactPct:T.priceImpactPct,tradePeriod:ct,tradeRoute:Q,type:"Dca"};return{...et,amountIn:a,amountOut:U,tradeAmountIn:T.amountIn,tradeAmountOut:T.amountOut,toHuman(){return{...et,amountIn:X.big.toDecimal(a,d),amountOut:X.big.toDecimal(U,m),tradeAmountIn:X.big.toDecimal(T.amountIn,d),tradeAmountOut:X.big.toDecimal(T.amountOut,m)}}}}async getMinimumOrderBudget(t,e){if(0===t)return this.minOrderBudget;let i=await this.router.getSpotPrice(0,t);if(i)return H.mulSpot(this.minOrderBudget,i.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 n=Number(t/r),s=Math.floor(i/this.blockTime),a=Math.max(0,Math.floor(s*(1-.1)));return Math.min(n,a)}getOptimalTradeCount(t){let e=Math.round(t*10)||1;return Math.max(e,3)}async getTwapSellOrder(t,e,i){let r=await this.router.getBestSell(t,e,i),{amountIn:n,swaps:s,priceImpactPct:a}=r,o=s[0],l=s[s.length-1],{assetInDecimals:u}=o,{assetOutDecimals:p}=l,d=Math.abs(a),m=this.getTwapTradeCount(d),h=n/BigInt(m),[b,g]=await Promise.all([this.getMinimumOrderBudget(t,u),this.router.getBestSell(o.assetIn,l.assetOut,h)]),f=m===1,y=n<b,S=g.priceImpactPct<-5,v=[];y||f?v.push("OrderTooSmall"):S&&v.push("OrderImpactTooBig");let T=g.amountOut*BigInt(m),O=g.tradeFee*BigInt(m),L=st.build(s),U={assetIn:t,assetOut:e,errors:v,tradeCount:m,tradeImpactPct:g.priceImpactPct,tradePeriod:6,tradeRoute:L,type:"TwapSell"};return{...U,amountIn:n,amountOut:T,tradeAmountIn:g.amountIn,tradeAmountOut:g.amountOut,tradeFee:O,toHuman(){return{...U,amountIn:X.big.toDecimal(n,u),amountOut:X.big.toDecimal(T,p),tradeAmountIn:X.big.toDecimal(g.amountIn,u),tradeAmountOut:X.big.toDecimal(g.amountOut,p),tradeFee:X.big.toDecimal(O,p)}}}}async getTwapBuyOrder(t,e,i){let r=await this.router.getBestBuy(t,e,i),{amountOut:n,swaps:s,priceImpactPct:a}=r,o=s[0],l=s[s.length-1],{assetInDecimals:u}=o,{assetOutDecimals:p}=l,d=Math.abs(a),m=this.getTwapTradeCount(d),h=n/BigInt(m),[b,g]=await Promise.all([this.getMinimumOrderBudget(t,u),this.router.getBestBuy(o.assetIn,l.assetOut,h)]),f=g.amountIn*BigInt(m),y=m===1,S=f<b,v=g.priceImpactPct<-5,T=[];S||y?T.push("OrderTooSmall"):v&&T.push("OrderImpactTooBig");let O=g.tradeFee*BigInt(m),L=st.build(s),U={assetIn:t,assetOut:e,errors:T,tradeCount:m,tradeImpactPct:g.priceImpactPct,tradePeriod:6,tradeRoute:L,type:"TwapBuy"};return{...U,amountIn:f,amountOut:n,tradeAmountIn:g.amountIn,tradeAmountOut:g.amountOut,tradeFee:O,toHuman(){return{...U,amountIn:X.big.toDecimal(f,u),amountOut:X.big.toDecimal(n,p),tradeAmountIn:X.big.toDecimal(g.amountIn,u),tradeAmountOut:X.big.toDecimal(g.amountOut,p),tradeFee:X.big.toDecimal(O,u)}}}}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)}};var er={};R(er,{BIG_10:()=>gn,BIG_BILL:()=>tr,StakingApi:()=>Be,StakingClient:()=>Re});var K=require("@galacticcouncil/math-staking"),tt=ft(require("big.js"));var pi={none:.1,locked1x:1,locked2x:2,locked3x:3,locked4x:4,locked5x:5,locked6x:6},cn=c=>Object.keys(pi).includes(c);var un=require("polkadot-api"),pn=require("@polkadot-api/utils"),mn=require("@galacticcouncil/common");function dn(c){let t=("modl"+c).padEnd(32,"\0"),e=new TextEncoder().encode(t),i=(0,pn.toHex)(e);return(0,un.AccountId)(mn.HYDRATION_SS58_PREFIX).dec(i)}var mi="20000000000000000",di="2000",gn=(0,tt.default)(10),tr=(0,tt.default)(gn.pow(12)),Be=class{client;balance;constructor(t,e){this.client=t,this.balance=e}async getPotBalance(){let t=await this.client.getPalletId(),e=dn(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,n=await i.reduce(async(s,[a,o])=>{let l=await s,u=a,p=o.amount,d=o.conviction.type.toLowerCase(),m=await this.client.getReferendumInfo(u);return m&&(m.type==="Approved"||m.type==="Rejected")&&cn(d)&&l.push({id:u,amount:p,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:n}}async getStake(t){let e=await this.client.getNFTCollectionId(),[i,r]=await Promise.all([this.client.getStaking(),this.client.getUniques(t,e)]),n=r.find(s=>s)?.itemId;return{totalStake:i?.total_stake,accumulatedRewardPerStake:i?.accumulated_reward_per_stake,potReservedBalance:i?.pot_reserved_balance,positionId:n,stakePosition:n?await this.getStakingPosition(n):void 0}}getCurrentActionPoints(t,e,i,r){let n=(0,tt.default)(0),s=(0,tt.default)(0),a=pi.locked6x,o=(0,tt.default)(i.toString()).mul(a),l=100,u=[];t.forEach(m=>{let h=pi[m.conviction],b=r.includes(m.id.toString());b&&u.push(m.id.toString());let g=(0,tt.default)(m.amount.toString()).mul(l).div(o);n=n.plus(Math.floor(g.mul(h).toNumber())),s=s.plus(Math.floor(g.mul(b?a:h).toNumber()))});let p=Math.floor((0,tt.default)(i.toString()).mul(a).mul(l).div(o).toNumber());r.forEach(m=>{u.includes(m)||(s=s.plus(p))});let d={democracyVote:1};return n=n.mul(d.democracyVote),n=n.plus(e.toString()||"0"),s=s.mul(d.democracyVote),s=s.plus(e.toString()||"0"),{currentActionPoints:n.toString(),maxActionPoints:s.toString()}}async getRewards(t,e,i){let r=await this.getStake(t),{potReservedBalance:n,accumulatedRewardPerStake:s,totalStake:a,stakePosition:o}=r;if(!o)return;let[l,u,p,d,m,h,b]=await Promise.all([this.getPotBalance(),this.client.getPeriodLength(),this.client.getUnclaimablePeriods(),this.client.getTimePointsPerPeriod(),this.client.getTimePointsWeight(),this.client.getActionPointsWeight(),this.client.getSixBlockSince()]),g=(0,tt.default)(l.transferable.toString()).minus(n.toString()),f=g.gt(0)&&a>0?(0,K.calculate_accumulated_rps)(s.toString(),g.toString(),a.toString()):s.toString(),y=(0,K.calculate_period_number)(u.toString(),i,b),S=(0,K.calculate_period_number)(u.toString(),o.createdAt.toString(),b),v=(0,K.calculate_rewards)(f,o.rewardPerStake.toString(),o.stake.toString()),T=this.getCurrentActionPoints(o.votes,o.actionPoints,o.stake,e),O=(0,K.calculate_points)(S,y,d.toString(),m.toString(),T.currentActionPoints,h.toString(),o.accumulatedSlashPoints.toString()),L=(0,K.sigmoid)(O,mi,di),U=(()=>{if(!e.length)return;let jt=(0,K.calculate_points)(S,y,d.toString(),m.toString(),T.maxActionPoints.toString(),h.toString(),o.accumulatedSlashPoints.toString());return(0,K.sigmoid)(jt,mi,di)})(),ct=(0,tt.default)(v).plus(o.accumulatedUnpaidRewards.toString()).plus(o.accumulatedLockedRewards.toString());if((0,tt.default)(y).minus(S).lte(p.toString()))return{rewards:"0",payablePercentage:L,extraPayablePercentage:U,constants:{a:mi,b:di}};let ht=(0,K.calculate_percentage_amount)(ct.toString(),L),Q=(0,tt.default)(o.accumulatedLockedRewards.toString()),et=Q.gt(ht)?Q:(0,tt.default)(ht);return{rewards:et.div(tr).toString(),maxRewards:ct.div(tr).toString(),allocatedRewardsPercentage:et.div(ct).mul(100).toNumber(),points:O,payablePercentage:L,extraPayablePercentage:U,constants:{a:mi,b:di}}}};var Re=class extends D{async getPalletId(){let t=this.api.constants.Staking.PalletId;return(await t()).asText()}async getPeriodLength(){let t=this.api.constants.Staking.PeriodLength;return await t()}async getUnclaimablePeriods(){let t=this.api.constants.Staking.UnclaimablePeriods;return await t()}async getNFTCollectionId(){let t=this.api.constants.Staking.NFTCollectionId;return await t()}async getStaking(){return await this.api.query.Staking.Staking.getValue()}async getUniques(t,e){return(await this.api.query.Uniques.Account.getEntries(t,e)).map(({keyArgs:s})=>{let[a,o,l]=s;return{address:a,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 rr={};R(rr,{TxBuilderFactory:()=>Kt});var ir=require("polkadot-api");function hn(c){let t=[],e=c;for(;e&&typeof e=="object"&&"type"in e;)t.push(e.type),e=e.value;return t.join(".")}var Xt=class extends D{evm;evmClient;balance;aaveUtils;constructor(t,e){super(t),this.evm=e,this.evmClient=e.getWsProvider(),this.balance=new ut(t),this.aaveUtils=new Tt(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:Si})}async dryRun(t,e){let i=(0,ir.Enum)("Signed",t),r=(0,ir.Enum)("system",i),s=await this.client.getUnsafeApi().apis.DryRunApi.dry_run_call(r,e.decodedCall),a=s.success&&!s.value.execution_result.success?s.value.execution_result.value.error:null;if(a){let o=hn(a.value);throw new Error("Dry run execution error!",{cause:o})}return s}isDirectOmnipoolTrade(t){return t.length===1&&t[0].pool==="Omnipool"}};var gi=class extends Xt{_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],n=await this.balance.getBalance(this.beneficiary,r);return t>=n.transferable-5n?this.buildSellAllTx():this.buildSellTx()}async buildBuyTx(){let{amountIn:t,amountOut:e,swaps:i}=this.trade,r=i[0],n=i[i.length-1],s=H.getFraction(t,this.slippagePct),a=r.assetIn,o=n.assetOut,l=t+s,u;return this.isDirectOmnipoolTrade(i)?u=this.api.tx.Omnipool.buy({asset_in:a,asset_out:o,amount:e,max_sell_amount:l}):u=this.api.tx.Router.buy({asset_in:a,asset_out:o,amount_out:e,max_amount_in:l,route:st.build(i)}),await this.aaveUtils.hasBorrowPositions(this.beneficiary)&&(u=await this.dispatchWithExtraGas(u)),this.wrapTx("RouterBuy",u)}async buildSellTx(){let{amountIn:t,amountOut:e,swaps:i}=this.trade,r=i[0],n=i[i.length-1],s=H.getFraction(e,this.slippagePct),a=r.assetIn,o=n.assetOut,l=e-s,u;return this.isDirectOmnipoolTrade(i)?u=this.api.tx.Omnipool.sell({asset_in:a,asset_out:o,amount:t,min_buy_amount:l}):u=this.api.tx.Router.sell({asset_in:a,asset_out:o,amount_in:t,min_amount_out:l,route:st.build(i)}),await this.aaveUtils.hasBorrowPositions(this.beneficiary)&&(u=await this.dispatchWithExtraGas(u)),this.wrapTx("RouterSell",u)}async buildSellAllTx(){let{amountOut:t,swaps:e}=this.trade,i=e[0],r=e[e.length-1],n=H.getFraction(t,this.slippagePct),s=i.assetIn,a=r.assetOut,o=t-n,l=this.api.tx.Router.sell_all({asset_in:s,asset_out:a,min_amount_out:o,route:st.build(e)});return await this.aaveUtils.hasBorrowPositions(this.beneficiary)&&(l=await this.dispatchWithExtraGas(l)),this.wrapTx("RouterSellAll",l)}};var hi=require("polkadot-api");var bi=class extends Xt{_order;_beneficiary;_maxRetries=3;_slippagePct=1;setOrder(t){return this._order=t,this}withBeneficiary(t){return this._beneficiary=t,this}withMaxRetries(t){return this._maxRetries=t,this}withSlippage(t){return this._slippagePct=t,this}get order(){if(!this._order)throw new Error("Order not set. Use setOrder().");return this._order}get beneficiary(){if(!this._beneficiary)throw new Error("Beneficiary not set. Use withBeneficiary().");return this._beneficiary}get maxRetries(){return this._maxRetries}get slippagePct(){return this._slippagePct}async build(){let{type:t}=this.order;switch(t){case"Dca":return this.buildDcaTx();case"TwapSell":return this.buildTwapSellTx();case"TwapBuy":return this.buildTwapBuyTx();default:throw new Error(`Unsupported TradeOrderType: ${t}`)}}buildDcaTx(){let{amountIn:t,assetIn:e,assetOut:i,tradeAmountIn:r,tradePeriod:n,tradeRoute:s}=this.order,a=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:(0,hi.Enum)("Sell",{asset_in:e,asset_out:i,amount_in:r,min_amount_out:0n,route:s})},start_execution_block:void 0});return this.wrapTx("DcaSchedule",a)}buildTwapSellTx(){let{amountIn:t,assetIn:e,assetOut:i,tradeAmountIn:r,tradeAmountOut:n,tradePeriod:s,tradeRoute:a}=this.order,o=H.getFraction(n,this.slippagePct),l=n-o,u=this.api.tx.DCA.schedule({schedule:{owner:this.beneficiary,period:s,max_retries:this.maxRetries,total_amount:t,slippage:this.slippagePct*1e4,stability_threshold:void 0,order:(0,hi.Enum)("Sell",{asset_in:e,asset_out:i,amount_in:r,min_amount_out:l,route:a})},start_execution_block:void 0});return this.wrapTx("DcaSchedule.twapSell",u)}buildTwapBuyTx(){let{amountIn:t,assetIn:e,assetOut:i,tradeAmountIn:r,tradeAmountOut:n,tradePeriod:s,tradeRoute:a}=this.order,o=H.getFraction(r,this.slippagePct),l=r+o,u=this.api.tx.DCA.schedule({schedule:{owner:this.beneficiary,period:s,max_retries:this.maxRetries,total_amount:t,slippage:this.slippagePct*1e4,stability_threshold:void 0,order:(0,hi.Enum)("Buy",{asset_in:e,asset_out:i,amount_out:n,max_amount_in:l,route:a})},start_execution_block:void 0});return this.wrapTx("DcaSchedule.twapBuy",u)}};var Kt=class{client;evmClient;constructor(t,e){this.client=t,this.evmClient=e}trade(t){return new gi(this.client,this.evmClient).setTrade(t)}order(t){return new bi(this.client,this.evmClient).setOrder(t)}};async function us(c){let t=new Mt(c),e=new se(c),[i,r]=await Promise.all([t.getBlockTime(),t.getMinOrderBudget()]),n=new Yt(c,e).withAave().withOmnipool().withStableswap().withHsm().withXyk(),s=new ut(c),a=new Re(c),o=new ue(c),l=new Tt(e),u=new xt(n),p=new $t(n,{blockTime:i,minBudgetInNative:r}),d=new Be(a,s),m=new ce(o,s,{blockTime:i});return{api:{aave:l,router:u,scheduler:p,staking:d,farm:m},client:{asset:new Ft(c),balance:s,evm:e},ctx:{pool:n},tx:new Kt(c,e),destroy:()=>{n.destroy()}}}0&&(module.exports={QueryBus,aave,api,async,calc,client,const:null,createSdkContext,error,evm,farm,fmt,json,math,pool,sor,staking,tx});
1
+ "use strict";var vn=Object.create;var De=Object.defineProperty;var Sn=Object.getOwnPropertyDescriptor;var wn=Object.getOwnPropertyNames;var xn=Object.getPrototypeOf,Tn=Object.prototype.hasOwnProperty;var ai=(c,t)=>()=>(c&&(t=c(c=0)),t);var R=(c,t)=>{for(var e in t)De(c,e,{get:t[e],enumerable:!0})},Me=(c,t,e,r)=>{if(t&&typeof t=="object"||typeof t=="function")for(let i of wn(t))!Tn.call(c,i)&&i!==e&&De(c,i,{get:()=>t[i],enumerable:!(r=Sn(t,i))||r.enumerable});return c},Bt=(c,t,e)=>(Me(c,t,"default"),e&&Me(e,t,"default")),ft=(c,t,e)=>(e=c!=null?vn(xn(c)):{},Me(t||!c||!c.__esModule?De(e,"default",{value:c,enumerable:!0}):e,c)),In=c=>Me(De({},"__esModule",{value:!0}),c);var Jt={};var di=ai(()=>{Bt(Jt,require("@polkadot-api/smoldot"))});var Zt={};var gi=ai(()=>{Bt(Zt,require("@polkadot-api/known-chains/polkadot"))});var ps={};R(ps,{QueryBus:()=>le,aave:()=>xr,api:()=>fr,async:()=>ae,calc:()=>H,client:()=>Or,const:()=>_r,createSdkContext:()=>us,error:()=>Br,evm:()=>Fr,farm:()=>qr,fmt:()=>_,json:()=>Dt,math:()=>W,pool:()=>zr,sor:()=>Zr,staking:()=>ei,tx:()=>ii});module.exports=In(ps);var fr={};R(fr,{Papi:()=>D,Watcher:()=>Qt,getSm:()=>An,getWs:()=>On});var ci=require("@galacticcouncil/descriptors");var li=require("@galacticcouncil/common"),Le=require("rxjs");var bt=require("rxjs"),q=require("rxjs/operators");function oi(c,{intervalMs:t=5e3,rpcTimeoutMs:e=1e4}={}){let r=()=>(0,bt.defer)(()=>(0,bt.from)(c._request("system_health",[]))).pipe((0,q.timeout)({first:e}),(0,q.map)(()=>"online"),(0,q.catchError)(()=>(0,bt.of)("offline")));return(0,bt.of)({state:"offline",delayMs:0}).pipe((0,q.expand)(n=>(0,bt.timer)(n.delayMs).pipe((0,q.switchMap)(r),(0,q.map)(s=>({state:s,delayMs:t})))),(0,q.skip)(1),(0,q.map)(n=>n.state),(0,q.distinctUntilChanged)(),(0,q.shareReplay)({bufferSize:1,refCount:!0}))}var{logger:_n}=li.log,Qt=class c{static instance=null;bestBlock$;finalizedBlock$;connection$;constructor(t){this.bestBlock$=this.watched("watcher(bestBlock)",t.getUnsafeApi().query.System.Number.watchValue("best")),this.finalizedBlock$=this.watched("watcher(finalizedBlock)",t.finalizedBlock$),this.connection$=this.watched("watcher(connection)",oi(t))}static getInstance(t){return this.instance||(this.instance=new c(t)),this.instance}watched(t,e){return e.pipe((0,Le.tap)({error:r=>_n.error(t,r)}),(0,Le.shareReplay)({bufferSize:1,refCount:!0}))}};var D=class{client;api;watcher;constructor(t){this.client=t,this.api=this.client.getTypedApi(ci.hydration),this.watcher=Qt.getInstance(this.client)}};var ui=require("polkadot-api/ws-provider"),pi=require("polkadot-api/logs-provider"),mi=require("@polkadot-api/legacy-provider"),On=(c,t={})=>{let e=typeof c=="string"?c.split(","):c,r=(0,ui.getWsProvider)(e,{innerEnhancer:(0,mi.withLegacy)(),...t});return(0,pi.withLogsRecorder)(i=>console.log(i),r),r};var hi=require("polkadot-api/sm-provider");async function An(c){let{start:t}=await Promise.resolve().then(()=>(di(),Jt)),{chainSpec:e}=await Promise.resolve().then(()=>(gi(),Zt)),r=t(),i=await r.addChain({chainSpec:e}),n=await r.addChain({chainSpec:c,potentialRelayChains:[i]});return(0,hi.getSmProvider)(n)}var xr={};R(xr,{AAVE_GAS_LIMIT:()=>Sr,AAVE_LENDING_POOL_ADDRESS:()=>He,AAVE_POOL_ABI:()=>Pr,AAVE_POOL_DATA_PROVIDER:()=>Ne,AAVE_POOL_DATA_PROVIDER_ABI:()=>qe,AAVE_POOL_PROXY:()=>vr,AAVE_ROUNDING_THRESHOLD:()=>Ms,AAVE_UINT_256_MAX:()=>Bn,AaveClient:()=>te,AaveUtils:()=>Tt});var Pr=[{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 qe=[{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 vr="0x1b02E051683b5cfaC5929C25E84adb26ECf87B38",Ne="0x112b087b60C1a166130d59266363C45F8aa99db0",He="0xf3Ba4D1b50f78301BDD7EAEa9B67822A15FCA691",Sr=1000000n,Ms=5,Bn=BigInt("0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");var te=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:qe,address:Ne,args:[He],functionName:"getReservesData"})}async getUserReservesData(t){return await this.client.readContract({abi:qe,address:Ne,args:[He,t],functionName:"getUserReservesData"})}async getUserAccountData(t){return await this.client.readContract({abi:Pr,address:vr,args:[t],functionName:"getUserAccountData"})}};var N=ft(require("big.js")),it=require("@galacticcouncil/common");var{ERC20:Rt}=it.erc20,{H160:wr}=it.h160,Rn=1.01,Fn=31536000n,bi=4,Ge=-1,Ue=10n**27n,Tt=class{client;constructor(t){this.client=new te(t)}async getSummary(t){let e=wr.fromAny(t),[r,i,n,s]=await Promise.all([this.client.getReservesData(),this.client.getUserReservesData(e),this.client.getUserAccountData(e),this.client.getBlockTimestamp()]),[a]=r,[o,l]=i,[u,p,d,m,h,b]=n,g=it.big.toDecimal(b,18),f=[];for(let y of o){let S=y.underlyingAsset.toLowerCase(),v=a.find(({underlyingAsset:yr})=>yr.toLowerCase()===S);if(!v)throw new Error("Missing pool reserve for "+S);let T=y.scaledATokenBalance,A=v.liquidityIndex,L=v.liquidityRate,V=v.availableLiquidity,ct=v.priceInMarketReferenceCurrency,ht=s+6,Q=this.calculateLinearInterest(L,v.lastUpdateTimestamp,ht),rt=A*Q/Ue,jt=T*rt/Ue,Ce=Number(l!==0&&l===v.eModeCategoryId?v.eModeLiquidationThreshold:v.reserveLiquidationThreshold)/1e4,Ee=v.usageAsCollateralEnabled&&y.usageAsCollateralEnabledOnUser&&y.scaledATokenBalance>0n,ke=Rt.toAssetId(S);f.push({aTokenBalance:jt,availableLiquidity:V,decimals:Number(v.decimals),isCollateral:Ee,priceInRef:ct,reserveId:ke,reserveAsset:S,reserveLiquidationThreshold:Ce})}return{healthFactor:Number(g),currentLiquidationThreshold:Number(it.big.toDecimal(m,bi)),totalCollateral:u,totalDebt:p,reserves:f}}async hasBorrowPositions(t){let e=wr.fromAny(t),r=await this.client.getUserAccountData(e),[i,n]=r;return n>0n}async getHealthFactor(t){let e=wr.fromAny(t),r=await this.client.getUserAccountData(e),[i,n,s,a,o,l]=r;return this.calculateHealthFactorFromBalances(n,i,a)}async getHealthFactorAfterWithdraw(t,e,r){let{totalCollateral:i,totalDebt:n,reserves:s,currentLiquidationThreshold:a}=await this.getSummary(t);if(n===0n)return Ge;let o=Rt.fromAssetId(e),l=s.find(S=>S.reserveAsset===o);if(!l)throw new Error("Missing reserve ctx for "+o);let{decimals:u,isCollateral:p,priceInRef:d,reserveLiquidationThreshold:m}=l,h=it.big.toBigInt(r,u),b=p?h*d/10n**BigInt(u):0n,g=i-b;if(g<=0n)return 0;let f=(0,N.default)(i.toString()).mul(a).minus((0,N.default)(b.toString()).mul(m)).div(g.toString()),y=(0,N.default)(g.toString()).mul(f).div(n.toString()).toFixed(6,N.default.roundDown);return Number(y)}async getHealthFactorAfterSupply(t,e,r){let{totalCollateral:i,totalDebt:n,reserves:s,currentLiquidationThreshold:a}=await this.getSummary(t);if(n===0n)return Ge;let o=Rt.fromAssetId(e),l=s.find(y=>y.reserveAsset===o);if(!l)throw new Error("Missing reserve ctx for "+o);let{decimals:u,priceInRef:p,reserveLiquidationThreshold:d}=l,h=it.big.toBigInt(r,u)*p/10n**BigInt(u),b=i+h;if(b<=0n)return 0;let g=(0,N.default)(i.toString()).mul(a).plus((0,N.default)(h.toString()).mul(d)).div(b.toString()),f=(0,N.default)(b.toString()).mul(g).div(n.toString()).toFixed(6,N.default.roundDown);return Number(f)}async getHealthFactorAfterSwap(t,e,r,i,n){let{totalDebt:s,reserves:a,healthFactor:o}=await this.getSummary(t);if(s===0n)return Ge;let l=Rt.fromAssetId(r),u=Rt.fromAssetId(n),p=a.find(A=>A.reserveAsset===l),d=a.find(A=>A.reserveAsset===u);if(!p)throw new Error(`Missing reserve ctx for ${l}`);if(!d)throw new Error(`Missing reserve ctx for ${d}`);let m=it.big.toBigInt(e,p.decimals),h=it.big.toBigInt(i,d.decimals),b=m*p.priceInRef/10n**BigInt(p.decimals),g=h*d.priceInRef/10n**BigInt(d.decimals),f=p.isCollateral?(0,N.default)(b.toString()).mul(p.reserveLiquidationThreshold):(0,N.default)(0),v=(0,N.default)(g.toString()).mul(d.reserveLiquidationThreshold).minus(f).div(s.toString()),T=(0,N.default)(o).plus(v).toFixed(6,N.default.roundDown);return Number(T)}async getMaxWithdraw(t,e){let{totalDebt:r,reserves:i,healthFactor:n}=await this.getSummary(t),s=Rt.fromAssetId(e),a=i.find(o=>o.reserveAsset===s);if(!a)throw new Error("Missing reserve ctx for "+s);return this.calculateWithdrawMax(a,r,n)}async getMaxWithdrawAll(t){let{totalDebt:e,reserves:r,healthFactor:i}=await this.getSummary(t),n={};for(let s of r){let a=this.calculateWithdrawMax(s,e,i);s.reserveId&&(n[s.reserveId]=a)}return n}calculateWithdrawMax(t,e,r){let{aTokenBalance:i,availableLiquidity:n,decimals:s,priceInRef:a,reserveLiquidationThreshold:o,isCollateral:l}=t,u=i;if(l&&e>0n){let d=r-Rn;if(d>0){let m=(0,N.default)(d).mul(e.toString()).div(o).toFixed(0,N.default.roundDown),h=(0,N.default)(m).div(a.toString()).mul(10**s).toFixed(0,N.default.roundDown);u=i<BigInt(h)?i:BigInt(h)}else u=0n}return{amount:u<n?u:n,decimals:s}}calculateLinearInterest(t,e,r){let i=r-e;if(i<=0)return Ue;let n=t*BigInt(i)/Fn;return Ue+n}calculateHealthFactorFromBalances(t,e,r){if(t===0n)return Ge;let i=e*r/t,n=it.big.toDecimal(i,bi);return Number(n)}};var Or={};R(Or,{AssetClient:()=>Ft,BalanceClient:()=>ut,ChainParams:()=>Mt});var Ft=class extends D{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[n]=r;return[n,i]}))}async queryBonds(){let e=await this.api.query.Bonds.Bonds.getEntries();return new Map(e.map(({keyArgs:r,value:i})=>{let[n]=r;return[n,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[n]=r;return[n,i]}))}async queryAssetLocations(){let e=await this.api.query.AssetRegistry.AssetLocations.getEntries();return new Map(e.map(({keyArgs:r,value:i})=>{let[n]=r;return[n,i]}))}async mapToken(t,e,r,i){let{name:n,asset_type:s,is_sufficient:a,existential_deposit:o}=e,{symbol:l,decimals:u}=r.get(t)??{};return{id:t,name:n?.asText(),symbol:l,decimals:u,icon:l,type:s.type,isSufficient:a,location:i,existentialDeposit:o}}async mapBond(t,e,r,i){let[n,s]=i,{asset_type:a,is_sufficient:o,existential_deposit:l}=e,{symbol:u,decimals:p}=await this.mapToken(n,e,r),d=Number(s),m=new Intl.DateTimeFormat("en-GB"),h=[u,"Bond",m.format(d)].join(" ");return{id:t,name:h,symbol:u+"b",decimals:p,icon:u,type:a.type,isSufficient:o,existentialDeposit:l,underlyingAssetId:n,maturity:d}}async mapShares(t,e,r,i){let{assets:n}=i,{name:s,symbol:a,asset_type:o,is_sufficient:l,existential_deposit:u}=e,p=await Promise.all(n.map(async h=>{let{symbol:b}=await this.mapToken(h,e,r);return[h,b]})),d=Object.fromEntries(p),m=Object.values(d);return{id:t,name:m.join(", "),symbol:a?.asText()||s?.asText(),decimals:18,icon:m.join("/"),type:o.type,isSufficient:l,existentialDeposit:u,meta:d}}async mapExternal(t,e,r,i){let n=await this.mapToken(t,e,new Map,i),s=r?.find(a=>a.internalId===n.id);return s?{...n,decimals:s.decimals,name:s.name,symbol:s.symbol,icon:s.symbol,isWhiteListed:s.isWhiteListed}:n}parseMetadata(t){return new Map(Array.from(t,([e,r])=>[e,{symbol:r.symbol?.asText(),decimals:r.decimals}]))}async getSupported(t,e){let[r,i,n,s]=await Promise.all([this.queryAssets(),this.queryAssetLocations(),this.queryShares(),this.queryBonds()]),a=this.parseMetadata(r),o=[];for(let[l,u]of Array.from(r)){let p=i.get(l),{asset_type:d}=u,m;switch(d.type){case"Bond":let h=s.get(l);m=await this.mapBond(l,u,a,h);break;case"StableSwap":let b=n.get(l);m=await this.mapShares(l,u,a,b);break;case"External":m=await this.mapExternal(l,u,e,p);break;default:m=await this.mapToken(l,u,a,p)}o.push(m)}return t?o:o.filter(l=>this.isValidAsset(l))}isValidAsset(t){let e=Math.sign(t.decimals);return!!t.symbol&&(e===0||e===1)}};var yi=require("@galacticcouncil/common"),J=require("rxjs"),w=require("rxjs/operators");var _r={};R(_r,{HUB_ASSET_ID:()=>ee,HYDRATION_OMNIPOOL_ADDRESS:()=>En,HYDRATION_PARACHAIN_ID:()=>Cn,PERBILL_DENOMINATOR:()=>Tr,PERMILL_DENOMINATOR:()=>Ct,SYSTEM_ASSET_DECIMALS:()=>Ir,SYSTEM_ASSET_ID:()=>E,TRADEABLE_DEFAULT:()=>Et});var Ct=1e6,Tr=1e9,E=0,Ir=12,Cn=2034,En="7L53bUTBbfuj14UpdCNPwmgzzHSsrsTWBHX5pys32mVWM3C1",ee=1,Et=15;var{logger:kt}=yi.log,ut=class extends D{constructor(t){super(t)}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:"best"});return this.getBreakdown(r)}async getTokenBalance(t,e){let i=await this.api.query.Tokens.Accounts.getValue(t,e,{at:"best"});return this.getBreakdown(i)}async getErc20Balance(t,e){return this.getBalanceData(t,e)}watchBalance(t){return(0,J.defer)(()=>{let e=this.watchSystemBalance(t),r=this.watchTokensBalance(t),i=this.watchErc20Balance(t);return(0,J.combineLatest)([e,r,i]).pipe((0,w.connect)(n=>(0,J.concat)(n.pipe((0,w.take)(1)),n.pipe((0,w.skip)(1),(0,w.debounceTime)(250)))))}).pipe((0,w.map)(e=>e.flat()),(0,w.startWith)([]),(0,w.bufferCount)(2,1),(0,w.map)(([e,r],i)=>i===0?r:this.getDeltas(e,r))).pipe((0,w.tap)({subscribe:()=>kt.debug("balance: subscribe",t),error:e=>kt.error("balance",e)}),(0,w.retry)({delay:1e3}))}watchSystemBalance(t){let e=this.api.query.System.Account;return(0,J.defer)(()=>e.watchValue(t,"best")).pipe((0,w.map)(r=>({id:0,balance:this.getBreakdown(r.data)})),(0,w.tap)({error:r=>kt.error("balance(system)",r)}))}watchTokenBalance(t,e){let r=this.api.query.Tokens.Accounts;return(0,J.defer)(()=>r.watchValue(t,e,"best")).pipe((0,w.map)(i=>({id:e,balance:this.getBreakdown(i)})),(0,w.tap)({error:i=>kt.error("balance(token)",i)}))}watchTokensBalance(t){let e=this.api.query.Tokens.Accounts;return(0,J.defer)(()=>e.watchEntries(t,{at:"best"})).pipe((0,w.distinctUntilChanged)((r,i)=>!i.deltas),(0,w.map)(({deltas:r})=>{let i=[];return r?.deleted.forEach(n=>{let[s,a]=n.args;i.push({id:a,balance:this.getBreakdown({free:0n,reserved:0n,frozen:0n})})}),r?.upserted.forEach(n=>{let[s,a]=n.args;i.push({id:a,balance:this.getBreakdown(n.value)})}),i}),(0,w.tap)({error:r=>kt.error("balance(tokens)",r)}))}watchErc20Balance(t,e){let r=async()=>(await this.api.query.AssetRegistry.Assets.getEntries({at:"best"})).filter(({value:s})=>s.asset_type.type==="Erc20").map(({keyArgs:s})=>{let[a]=s;return a}),i=async n=>(await Promise.all(n.map(async a=>[a,await this.getBalanceData(t,a)]))).map(([a,o])=>({id:a,balance:o}));return(0,J.defer)(()=>(0,J.from)(e?Promise.resolve(e):r()).pipe((0,w.switchMap)(n=>this.watcher.bestBlock$.pipe((0,w.startWith)(null),(0,w.switchMap)(()=>(0,J.from)(i(n))))),(0,w.pairwise)(),(0,w.map)(([n,s],a)=>a===0?s.filter(o=>o.balance.transferable>0n):this.getDeltas(n,s)),(0,w.distinctUntilChanged)((n,s)=>s.length===0),(0,w.tap)({error:n=>kt.error("balance(erc20)",n)})))}async getBalanceData(t,e){let r=await this.api.apis.CurrenciesApi.account(e,t,{at:"best"});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=(n,s)=>n!==void 0&&s!==void 0&&n.transferable===s.transferable&&n.total===s.total,i=t.reduce((n,s)=>(n.set(s.id,s.balance),n),new Map);return e.filter(n=>!r(n.balance,i.get(n.id)))}};var Mt=class extends D{_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 Br={};R(Br,{AssetNotFound:()=>Ar,PoolNotFound:()=>re,RouteNotFound:()=>ie});var Ar=class extends Error{constructor(t){super(),this.message=`${t} not found`,this.name="AssetNotFound"}},re=class extends Error{constructor(t){super(),this.message=`${t} pool invalid`,this.name="PoolNotFound"}},ie=class extends Error{constructor(t,e){super(),this.message=`Route from ${t} to ${e} not found in current configuration`,this.name="RouteNotFound"}};var Fr={};R(Fr,{EvmClient:()=>se,EvmRpcAdapter:()=>ne,createChain:()=>Rr});var It=require("polkadot-api"),fi=require("@galacticcouncil/descriptors"),Ve=require("viem"),kn=10000000n,ne=class{api;constructor(t){this.api=t.getTypedApi(fi.hydration)}async getBlock(){let t=await this.api.query.Ethereum.CurrentBlock.getValue({at:"best"}),{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:n}=t,s=(0,Ve.encodeFunctionData)({abi:e,functionName:i,args:n}),a=this.api.apis.EthereumRuntimeRPCApi.call,o=await this.api.compatibilityToken,l=a.isCompatible(It.CompatibilityLevel.BackwardsCompatible,o);console.log(l);let u=await this.api.apis.EthereumRuntimeRPCApi.call(It.FixedSizeBinary.fromText(""),It.FixedSizeBinary.fromHex(r),It.Binary.fromHex(s),[0n,0n,0n,0n],[kn,0n,0n,0n],void 0,void 0,void 0,!1,[]);if(console.log(u),!u.success)throw console.error(i,u.value.type),new Error("Contract read failure");let{exit_reason:p,value:d,used_gas:m}=u.value;if(console.log(m),p.type==="Succeed")return(0,Ve.decodeFunctionResult)({abi:e,functionName:i,data:d.asHex()});throw console.log(i,p.type,p.value.type),new Error("Contract read error")})};var Pi=require("viem"),Mn=["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"],Rr=()=>(0,Pi.defineChain)({id:222222,name:"Hydration",network:"hydration",nativeCurrency:{decimals:18,name:"WETH",symbol:"WETH"},rpcUrls:{default:{http:Mn}},blockExplorers:{default:{name:"Hydration Explorer",url:"https://hydration.subscan.io"}},testnet:!1});var pt=require("viem");var se=class{client;chain;constructor(t){this.client=t,this.chain=Rr()}get chainId(){return this.chain.id}get chainCurrency(){return this.chain.nativeCurrency.symbol}get chainDecimals(){return this.chain.nativeCurrency.decimals}getProvider(){return(0,pt.createPublicClient)({chain:this.chain,transport:(0,pt.http)()})}getWsProvider(){return(0,pt.createPublicClient)({transport:(0,pt.custom)({request:({method:t,params:e})=>this.client._request(t,e||[])})})}getSigner(t){return(0,pt.createWalletClient)({account:t,chain:this.chain,transport:(0,pt.custom)(window.ethereum)})}getRPCAdapter(){return new ne(this.client)}};var qr={};R(qr,{LiquidityMiningApi:()=>ce,LiquidityMiningClient:()=>ue});var Ei=require("polkadot-api"),Y=ft(require("big.js")),vt=require("@galacticcouncil/common"),Lr=require("@galacticcouncil/math-liquidity-mining");var ae={};R(ae,{withTimeout:()=>Dn});function Dn(c,t,e="timeout"){return new Promise((r,i)=>{let n=setTimeout(()=>i(new Error(e)),t);c.then(s=>{clearTimeout(n),r(s)},s=>{clearTimeout(n),i(s)})})}var H={};R(H,{getFraction:()=>qn,mulScaled:()=>Si,mulSpot:()=>Ln});var vi=require("@galacticcouncil/common");function Si(c,t,e,r,i){let n=e+r-i,s=c*t;return n>0?s/BigInt(10)**BigInt(n):n<0?s*BigInt(10)**BigInt(-n):s}function Ln(c,t,e,r){return Si(c,t,e,vi.RUNTIME_DECIMALS,r)}function qn(c,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 c*i/(BigInt(100)*r)}var _={};R(_,{FeeUtils:()=>Cr,shiftNeg:()=>Nn});var wi=ft(require("big.js"));var Cr=class c{static toPct(t){let[e,r]=t;return c.safeDivide(e*100,r)}static toRaw(t){let[e,r]=t;return c.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 Nn(c,t){let e=(0,wi.default)(typeof c=="bigint"?c.toString():c);return t===0?e.toString():e.div(Math.pow(10,t)).toString()}var Dt={};R(Dt,{findNestedKey:()=>Hn,findNestedObj:()=>Gn,jsonFormatter:()=>Un});var Hn=(c,t)=>{let e=[];return JSON.stringify(c,(r,i)=>(i&&i[t]&&e.push(i),i)),e[0]},Gn=(c,t,e)=>{let r;return JSON.stringify(c,(i,n)=>(n&&n[t]===e&&(r=n),n)),r},Un=(c,t)=>typeof t=="bigint"?t.toString():t;var W={};R(W,{calculateBuyFee:()=>zn,calculateDiffToAvg:()=>Vn,calculateDiffToRef:()=>Wn,calculateSellFee:()=>Yn});var mt=ft(require("big.js"));function Vn(c,t){let e=(0,mt.default)(c.toString()),r=(0,mt.default)(t.toString());return e.minus(r).abs().div(e.plus(r).div(2)).mul(100).round(2).toNumber()}function Wn(c,t){if(t===0n)return 0;let e=(0,mt.default)(c.toString()),r=(0,mt.default)(t.toString());return e.minus(r).div(r).mul(100).round(2).toNumber()}function Yn(c,t){if(c===0n)return 0;let e=(0,mt.default)(c.toString()),r=(0,mt.default)(t.toString());return(0,mt.default)(1).minus(r.div(e)).mul(100).round(2).toNumber()}function zn(c,t){if(c===0n)return 0;let e=(0,mt.default)(c.toString());return(0,mt.default)(t.toString()).div(e).minus(1).mul(100).round(2).toNumber()}var oe=(c,t)=>c===t?0:c==null?t==null?0:-1:t==null?c==null?0:1:typeof c.compare=="function"?c.compare(t):typeof t.compare=="function"?-t.compare(c):c<t?-1:c>t?1:0;var We=(c,t=e=>e!==void 0?": "+e:"")=>class extends Error{origMessage;constructor(e){super(c(e)+t(e)),this.origMessage=e!==void 0?String(e):""}};var $n=We(()=>"illegal argument(s)"),xi=c=>{throw new $n(c)};var Xn=We(()=>"index out of bounds"),Er=c=>{throw new Xn(c)},Ye=(c,t,e)=>(c<t||c>=e)&&Er(c);var Ti=23283064365386963e-26,ze=class{float(t=1){return this.int()*Ti*t}probability(t){return this.float()<t}norm(t=1){return(this.int()*Ti-.5)*2*t}normMinMax(t,e){let r=this.minmax(t,e);return this.float()<.5?r:-r}minmax(t,e){return this.float()*(e-t)+t}minmaxInt(t,e){t|=0;let r=(e|0)-t;return r?t+this.int()%r:t}minmaxUint(t,e){t>>>=0;let r=(e>>>0)-t;return r?t+this.int()%r:t}};var $e=class extends ze{constructor(t){super(),this.rnd=t}float(t=1){return this.rnd()*t}norm(t=1){return(this.rnd()-.5)*2*t}int(){return this.rnd()*4294967296>>>0}};var Ii=new $e(Math.random);var _i=c=>c!=null&&typeof c!="function"&&c.length!==void 0;var Oi=Object.getPrototypeOf({}),Xe="function",Ai="string",Lt=(c,t)=>{let e;if(c===t)return!0;if(c!=null){if(typeof c.equiv===Xe)return c.equiv(t)}else return c==t;if(t!=null){if(typeof t.equiv===Xe)return t.equiv(c)}else return c==t;return typeof c===Ai||typeof t===Ai?!1:(e=Object.getPrototypeOf(c),(e==null||e===Oi)&&(e=Object.getPrototypeOf(t),e==null||e===Oi)?Jn(c,t):typeof c!==Xe&&c.length!==void 0&&typeof t!==Xe&&t.length!==void 0?Kn(c,t):c instanceof Set&&t instanceof Set?jn(c,t):c instanceof Map&&t instanceof Map?Qn(c,t):c instanceof Date&&t instanceof Date?c.getTime()===t.getTime():c instanceof RegExp&&t instanceof RegExp?c.toString()===t.toString():c!==c&&t!==t)},Kn=(c,t,e=Lt)=>{let r=c.length;if(r===t.length)for(;r-- >0&&e(c[r],t[r]););return r<0},jn=(c,t,e=Lt)=>c.size===t.size&&e([...c.keys()].sort(),[...t.keys()].sort()),Qn=(c,t,e=Lt)=>c.size===t.size&&e([...c].sort(),[...t].sort()),Jn=(c,t,e=Lt)=>{if(Object.keys(c).length!==Object.keys(t).length)return!1;for(let r in c)if(!t.hasOwnProperty(r)||!e(c[r],t[r]))return!1;return!0};var kr=class{value;constructor(t){this.value=t}deref(){return this.value}};var Bi=c=>c instanceof kr;var Ke=class c{_head;_length=0;constructor(t){t&&this.into(t)}get length(){return this._length}get head(){return this._head}[Symbol.iterator](){return Ri("next",this._head)}reverseIterator(){return Ri("prev",this.tail)}clear(){this.release()}compare(t,e=oe){let r=this._length;if(r<t._length)return-1;if(r>t._length)return 1;if(r===0)return 0;{let i=this._head,n=t._head,s=0;for(;r-- >0&&s===0;)s=e(i.value,n.value),i=i.next,n=n.next;return s}}concat(...t){let e=this.copy();for(let r of t)e.into(r);return e}equiv(t){if(!(t instanceof c||_i(t))||this._length!==t.length)return!1;if(!this._length||this===t)return!0;let e=t[Symbol.iterator](),r=this._head;for(let i=this._length;i-- >0;){if(!Lt(r.value,e.next().value))return!1;r=r.next}return!0}filter(t){let e=this.empty();return this.traverse(r=>(t(r.value)&&e.append(r.value),!0)),e}find(t){return this.traverse(e=>e.value!==t)}findWith(t){return this.traverse(e=>!t(e.value))}first(){return this._head?.value}insertSorted(t,e){e=e||oe;for(let r=this._head,i=this._length;i-- >0;){if(e(t,r.value)<=0)return this.insertBefore(r,t);r=r.next}return this.append(t)}into(t){for(let e of t)this.append(e);return this}nth(t,e){let r=this.nthCell(t);return r?r.value:e}nthCellUnsafe(t){let e,r;for(t<=this._length>>>1?(e=this._head,r="next"):(e=this.tail,r="prev",t=this._length-t-1);t-- >0&&e;)e=e[r];return e}peek(){return this.tail?.value}$reduce(t,e){let r=this._head;for(let i=this._length;i-- >0&&!Bi(e);)e=t(e,r.value),r=r.next;return e}reduce(t,e){return this.$reduce(t,e)}release(){let t=this._head;if(!t)return!0;let e;for(let r=this._length;r-- >0;)e=t.next,delete t.value,delete t.prev,delete t.next,t=e;return this._head=void 0,this._length=0,!0}reverse(){let t=this._head,e=this.tail,r=(this._length>>>1)+(this._length&1);for(;t&&e&&r>0;){let i=t.value;t.value=e.value,e.value=i,t=t.next,e=e.prev,r--}return this}setHead(t){let e=this._head;return e?(e.value=t,e):this.prepend(t)}setNth(t,e){let r=this.nthCell(t);return!r&&Er(t),r.value=e,r}setTail(t){let e=this.tail;return e?(e.value=t,e):this.append(t)}swap(t,e){if(t!==e){let r=t.value;t.value=e.value,e.value=r}return this}toArray(t=[]){return this.traverse(e=>(t.push(e.value),!0)),t}toJSON(){return this.toArray()}toString(){let t=[];return this.traverse(e=>(t.push(String(e.value)),!0)),t.join(", ")}traverse(t,e=this._head,r){if(!this._head)return;let i=e;do{if(!t(i))break;i=i.next}while(i!==r);return i}_map(t,e){return this.traverse(r=>(t.append(e(r.value)),!0)),t}};function*Ri(c,t){for(;t;)yield t.value,t=t[c]}var je=class c extends Ke{_tail;constructor(t){super(),t&&this.into(t)}get tail(){return this._tail}append(t){if(this._tail){let e={value:t,prev:this._tail};return this._tail.next=e,this._tail=e,this._length++,e}else return this.prepend(t)}asHead(t){return t===this._head?this:(this.remove(t),this._head.prev=t,t.next=this._head,t.prev=void 0,this._head=t,this._length++,this)}asTail(t){return t===this._tail?this:(this.remove(t),this._tail.next=t,t.prev=this._tail,t.next=void 0,this._tail=t,this._length++,this)}cons(t){return this.prepend(t),this}copy(){return new c(this)}*cycle(){for(;;)yield*this}drop(){let t=this._head;if(t)return this._head=t.next,this._head?this._head.prev=void 0:this._tail=void 0,this._length--,t.value}empty(){return new c}insertAfter(t,e){let r={value:e,next:t.next,prev:t};return t.next?t.next.prev=r:this._tail=r,t.next=r,this._length++,r}insertAfterNth(t,e){return t<0&&(t+=this._length),t>=this._length-1?this.append(e):(Ye(t,0,this._length),this.insertAfter(this.nthCellUnsafe(t),e))}insertBefore(t,e){let r={value:e,next:t,prev:t.prev};return t.prev?t.prev.next=r:this._head=r,t.prev=r,this._length++,r}insertBeforeNth(t,e){return t<0&&(t+=this._length),t<=0?this.prepend(e):(Ye(t,0,this._length),this.insertBefore(this.nthCellUnsafe(t),e))}map(t){return this._map(new c,t)}nth(t,e){let r=this.nthCell(t);return r?r.value:e}nthCell(t){if(t<0&&(t+=this._length),!(t<0||t>=this._length))return this.nthCellUnsafe(t)}pop(){let t=this._tail;if(t)return this._tail=t.prev,this._tail?this._tail.next=void 0:this._head=void 0,this._length--,t.value}prepend(t){let e={value:t,next:this._head};return this._head?this._head.prev=e:this._tail=e,this._head=e,this._length++,e}push(t){return this.append(t),this}release(){return this._tail=void 0,super.release()}remove(t){return t.prev?t.prev.next=t.next:this._head=t.next,t.next?t.next.prev=t.prev:this._tail=t.prev,this._length--,this}rotateLeft(){switch(this._length){case 0:case 1:return this;case 2:return this.swap(this._head,this._tail);default:return this.push(this.drop())}}rotateRight(){switch(this._length){case 0:case 1:return this;case 2:return this.swap(this._head,this._tail);default:let t=this.peek();return this.pop(),this.prepend(t),this}}seq(t=0,e=this.length){if(t>=e||t<0)return;let r=this.nthCell(t),i=this.nthCell(e-1),n=s=>({first(){return s.value},next(){return s!==i&&s.next?n(s.next):void 0}});return r?n(r):void 0}shuffle(t,e=Ii){if(this._length<2)return this;for(t=t!==void 0?t:Math.ceil(1.5*Math.log2(this._length));t>0;t--){let r=this._head;for(;r;){let i=r.next;e.probability(.5)?this.asHead(r):this.asTail(r),r=i}}return this}slice(t=0,e=this.length){let r=t<0?t+this._length:t,i=e<0?e+this._length:e;(r<0||i<0)&&xi("invalid indices: ${from} / ${to}");let n=new c,s=this.nthCell(r);for(;s&&++r<=i;)n.push(s.value),s=s.next;return n}sort(t=oe){if(!this._length)return this;let e=1;for(;;){let r=this._head;this._head=void 0,this._tail=void 0;let i=0;for(;r;){i++;let n=r,s=0;for(let o=0;o<e&&(s++,n=n.next,!!n);o++);let a=e;for(;s>0||a>0&&n;){let o;s===0?(o=n,n=n.next,a--):!n||a===0||t(r.value,n.value)<=0?(o=r,r=r.next,s--):(o=n,n=n.next,a--),this._tail?this._tail.next=o:this._head=o,o.prev=this._tail,this._tail=o}r=n}if(this._tail.next=void 0,i<=1)return this;e*=2}}splice(t,e=0,r){let i;typeof t=="number"?(t<0&&(t+=this._length),Ye(t,0,this._length),i=this.nthCellUnsafe(t)):i=t;let n=new c;if(e>0)for(;i&&e-- >0;)this.remove(i),n.push(i.value),i=i.next;else i&&(i=i.next);if(r)if(i)for(let s of r)this.insertBefore(i,s);else for(let s of r)this.push(s);return n}};var Qe=class c{map;items;opts;_size;constructor(t,e){let r={maxlen:1/0,maxsize:1/0,map:()=>new Map,ksize:()=>0,vsize:()=>0,...e};this.map=r.map(),this.items=new je,this._size=0,this.opts=r,t&&this.into(t)}get length(){return this.items.length}get size(){return this._size}[Symbol.iterator](){return this.entries()}*entries(){for(let t of this.items)yield[t.k,t]}*keys(){for(let t of this.items)yield t.k}*values(){for(let t of this.items)yield t.v}copy(){let t=this.empty();t.items=this.items.copy();let e=t.items.head;for(;e;)t.map.set(e.value.k,e),e=e.next;return t}empty(){return new c(null,this.opts)}release(){this._size=0,this.map.clear();let t=this.opts.release;if(t){let e;for(;e=this.items.drop();)t(e.k,e.v);return!0}return this.items.release()}has(t){return this.map.has(t)}get(t,e){let r=this.map.get(t);return r?this.resetEntry(r):e}set(t,e){let r=this.opts.ksize(t)+this.opts.vsize(e),i=this.map.get(t),n=Math.max(0,r-(i?i.value.s:0));return this._size+=n,this.ensureSize()?this.doSetEntry(i,t,e,r):this._size-=n,e}into(t){for(let e of t)this.set(e[0],e[1]);return this}async getSet(t,e){let r=this.map.get(t);return r?this.resetEntry(r):this.set(t,await e())}delete(t){let e=this.map.get(t);return e?(this.removeEntry(e),!0):!1}resetEntry(t){return this.items.asTail(t),t.value.v}ensureSize(){let{release:t,maxsize:e,maxlen:r}=this.opts;for(;this._size>e||this.length>=r;){let i=this.items.drop();if(!i)return!1;this.map.delete(i.k),t?.(i.k,i.v),this._size-=i.s}return!0}removeEntry(t){let e=t.value;this.map.delete(e.k),this.items.remove(t),this.opts.release?.(e.k,e.v),this._size-=e.s}doSetEntry(t,e,r,i){t?(this.opts.update?.(e,t.value.v,r),t.value.v=r,t.value.s=i,this.items.asTail(t)):(this.items.push({k:e,v:r,s:i}),this.map.set(e,this.items.tail))}};var _t=class c extends Qe{constructor(t,e){super(t,{ttl:3600*1e3,autoExtend:!1,...e})}empty(){return new c(null,this.opts)}has(t){return this.get(t)!==void 0}get(t,e){let r=this.map.get(t);if(r){if(r.value.t>=Date.now())return this.resetEntry(r);this.removeEntry(r)}return e}set(t,e,r=this.opts.ttl){let i=this.opts.ksize(t)+this.opts.vsize(e),n=this.map.get(t),s=Math.max(0,i-(n?n.value.s:0));return this._size+=s,this.ensureSize()?this.doSetEntry(n,t,e,i,r):this._size-=s,e}async getSet(t,e,r=this.opts.ttl){let i=this.get(t);return i!==void 0?i:this.set(t,await e(),r)}prune(){let t=Date.now(),e=this.items.head,r=0;for(;e;)e.value.t<t&&(this.removeEntry(e),r++),e=e.next;return r}ensureSize(){let{maxlen:t,maxsize:e}=this.opts,r=Date.now(),i=this.items.head;for(;i&&(this._size>e||this.length>=t);)i.value.t<r&&this.removeEntry(i),i=i.next;return super.ensureSize()}doSetEntry(t,e,r,i,n=this.opts.ttl){let s=Date.now()+n;t?(this.opts.update?.(e,t.value.v,r),t.value.v=r,t.value.s=i,t.value.t=s,this.items.asTail(t)):(this.items.push({k:e,v:r,s:i,t:s,ttl:n}),this.map.set(e,this.items.tail))}resetEntry(t){return this.opts.autoExtend&&(t.value.t=Date.now()+t.value.ttl),super.resetEntry(t)}};var le=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 n=new Map,s=i!==void 0?new _t(null,{ttl:i}):new _t;return{get:(...u)=>{let p=r(...u);if(n.has(p)){this.log("[live]",t,p);let m=n.get(p);return Promise.resolve(m)}if(s.has(p))return this.log("[memo]",t,p),s.get(p);this.log("[fetch]",t,p);let d=e(...u).catch(m=>{throw s.delete(p),m});return s.set(p,d),d},set:(u,...p)=>{let d=r(...p);this.log("[set-live]",t,d),n.set(d,u)},clear:()=>{this.log("[clear]",t),n.clear(),s.release()}}}};var Je=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,n]=t[r];this.result.set(this.getKey(n,i),e[r].free)}}freeBalance(t,e){return this.result.get(this.getKey(t,e))??0n}transfer(t,e,r,i){let n=this.getKey(t,e),s=this.getKey(t,r),a=this.result.get(n)??0n,o=this.result.get(s)??0n;if(a<i)throw new Error("Attempting to transfer more than is present");this.result.set(n,a+i),this.result.set(s,o+i)}};var Pt=ft(require("big.js")),st=require("@galacticcouncil/math-liquidity-mining");var Mr=ft(require("big.js")),Dr=(0,Mr.default)(10).pow(18),Fi=BigInt((0,Mr.default)(1).pow(18).toString()),Ci=6e3;var Zn="1000000000000000000",Ze=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),n=e-t.updated_at,s=this.getAccount(t.id),a=i?.existential_deposit;if(!a)throw new Error("Missing reward currency asset list");let o=this.multiCurrency.freeBalance(t.reward_currency,s),l=(0,Pt.default)(a.toString()),u=(0,Pt.default)(o.toString()).minus(l.lt(o.toString())?a.toString():o.toString()),p=(0,Pt.default)((0,st.calculate_global_farm_rewards)(t.total_shares_z.toString(),r.toString(),(0,Pt.default)(t.yield_per_period.toString()).mul(Dr).round(0,Pt.default.roundDown).toFixed(),t.max_reward_per_period.toString(),n.toFixed()));if(u.lt(p)&&(p=u),p.eq(0))return t;let d=this.getAccount(0);return this.multiCurrency.transfer(t.reward_currency,s,d,BigInt(p.toFixed())),{...t,accumulated_rpz:BigInt((0,st.calculate_accumulated_rps)(t.accumulated_rpz.toString(),t.total_shares_z.toString(),p.toFixed()))}}syncYieldFarm(t,e,r){if(t.state.type!=="Active"||t.updated_at===r)return null;if(t.total_valued_shares===0n)return{...t,updated_at:r};let i=(0,st.calculate_yield_farm_delta_rpvs)(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=(0,Pt.default)(1).mul(Dr).round(0,Pt.default.roundDown).toString();if(!e)return r;let{initial_reward_percentage:i,scale_coef:n}=e;return(0,st.calculate_loyalty_multiplier)(t.toFixed(),i.toString(),n.toFixed())}async claimRewards(t,e,r,i,n){if(e.state.type==="Terminated")return null;let s=Math.floor(i/t.blocks_per_period);if(r.updated_at===s)return null;let a=await this.syncGlobalFarm(t,s,n);if(!a)return null;let o=this.syncYieldFarm(e,a,s);if(!o)return null;let l=o.total_stopped-r.stopped_at_creation,u=o.updated_at-r.entered_at-l,p=this.getLoyaltyMultiplier(u,o.loyalty_curve),d=BigInt((0,st.calculate_user_reward)(r.accumulated_rpvs.toString(),r.valued_shares.toString(),r.accumulated_claimed_rewards.toString(),o.accumulated_rpvs.toString(),p)),m=BigInt((0,st.calculate_user_reward)(r.accumulated_rpvs.toString(),r.valued_shares.toString(),r.accumulated_claimed_rewards.toString(),o.accumulated_rpvs.toString(),Zn));return{reward:d,maxReward:m,assetId:a.reward_currency,yieldFarmId:o.id,isActiveFarm:o.state.type==="Active"}}};var ts=(0,Y.default)(365.2425).times(24).times(60).times(60),ce=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((n,s)=>n-s);if(t===e)return Fi;let i=await this.client.getOraclePrice(r);if(i){let{n,d:s}=i[0].price,a;return t<e?a=(0,Lr.fixed_from_rational)(n.toString(),s.toString()):a=(0,Lr.fixed_from_rational)(s.toString(),n.toString()),BigInt(a)}}getFarmAddress=(t,e)=>{let r=Buffer.from("modl","utf-8"),i=Buffer.from(e?"78796b4c4d704944":"4f6d6e6957684c4d","hex"),n=Buffer.from([t]),s=Buffer.concat([r,i,n]),o="0x"+Buffer.concat([s,Buffer.alloc(32-s.length)]).toString("hex");return(0,Ei.AccountId)(vt.HYDRATION_SS58_PREFIX).dec(o)};getGlobalRewardPerPeriod(t,e,r,i){let n=(0,Y.default)(i).times(t.toString()).times(e.toString()).div(Math.pow(10,vt.RUNTIME_DECIMALS));return n.gte(r.toString())?r.toString():n.toString()}getPoolYieldPerPeriod(t,e,r,i){let n=(0,Y.default)(t.toString()).times(e),s=(0,Y.default)(r.toString()).times(i);return n.div(s.toString()).toString()}farmData(t,e,r){let{yieldFarm:i,globalFarm:n,priceAdjustment:s,balance:a,id:o}=t,{multiplier:l,loyalty_curve:u}=i,{blocks_per_period:p,yield_per_period:d,total_shares_z:m,max_reward_per_period:h,pending_rewards:b,accumulated_paid_rewards:g,planned_yielding_periods:f,updated_at:y,incentivized_asset:S,reward_currency:v,price_adjustment:T,min_deposit:A}=n,L=_.shiftNeg(s??T,vt.RUNTIME_DECIMALS),V=_.shiftNeg(l,vt.RUNTIME_DECIMALS),ct=_.shiftNeg(u?.initial_reward_percentage??0,vt.RUNTIME_DECIMALS),ht=ts.div((0,Y.default)(this.blockTime).div(1e3).times(p)).toString(),Q;if(m<=0)Q=(0,Y.default)(V).times(d.toString()).times(ht).toString();else{let fn=this.getGlobalRewardPerPeriod(m,d,h,L),Pn=this.getPoolYieldPerPeriod(fn,V,m,L);Q=(0,Y.default)(Pn).times(ht).toString()}let rt=b+g,jt=h*BigInt(f),Fe=a.transferable+rt,ni=Fe-rt,Ce=(0,Y.default)(ni.toString()).div(h.toString()),Ee=(0,Y.default)(e).div(p.toString()).toString(),ke=(m>=0?Ce.plus(y):Ce.plus(Ee)).toString(),yr=(0,Y.default)(ke).times(p).toString(),bn=(0,Y.default)(m.toString()).div((0,Y.default)(h.toString()).div(d.toString())).div(Math.pow(10,vt.RUNTIME_DECIMALS)).times(100).times(L).toFixed(2),si=(0,Y.default)(rt.toString()).div(Fe.toString()).gte(.999);Q=si?"0":(0,Y.default)(Q).div(r?2:1).times(100).toString();let yn=ct?(0,Y.default)(Q).times(ct).toString():void 0;return{apr:Q,minApr:yn,isDistributed:si,estimatedEndPeriod:ke,estimatedEndBlock:yr,maxRewards:jt,incentivizedAsset:S,rewardCurrency:v,loyaltyCurve:u,currentPeriod:Ee,potMaxRewards:Fe,fullness:bn,yieldFarmId:i.id,globalFarmId:n.id,poolId:o,distributedRewards:rt,plannedYieldingPeriods:f,minDeposit:A,blocksPerPeriod:p}}async getAllOmnipoolFarms(){let e=(await this.client.getAllOmnipooFarms()).reduce((i,n)=>i.includes(n.keyArgs[0].toString())?i:[...i,n.keyArgs[0].toString()],[]),r=await Promise.all(e.map(async i=>{let n=await this.getOmnipoolFarms(i);if(n)return[i,n]}));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:n,value:s})=>{let[,a]=n,o=s,l=await this.client.getOmnipoolGlobalFarm(a),u=await this.client.getOmnipoolYieldFarm(Number(t),a,o);if(!l||!u)return;let p=l.reward_currency,d=l.incentivized_asset,m=this.getFarmAddress(a),h=await this.getOraclePrice(p,d),b=await this.balance.getBalance(m,p);return{id:t,globalFarm:l,yieldFarm:u,priceAdjustment:h,balance:b}}));return r?i.map(n=>n?this.farmData(n,r):void 0):[]}async getAllIsolatedFarms(){let e=(await this.client.getAllIsolatedFarms()).reduce((i,n)=>i.includes(n.keyArgs[0].toString())?i:[...i,n.keyArgs[0].toString()],[]),r=await Promise.all(e.map(async i=>{let n=await this.getIsolatedFarms(i);if(n)return[i,n]}));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:n,value:s})=>{let[,a]=n,o=s,l=await this.client.getIsolatedGlobalFarm(a),u=await this.client.getIsolatedYieldFarm(t,a,o);if(!l||!u)return;let p=l.reward_currency,d=l.incentivized_asset,m=this.getFarmAddress(a,!0),h=await this.getOraclePrice(p,d),b=await this.balance.getBalance(m,p);return{id:t,globalFarm:l,yieldFarm:u,priceAdjustment:h,balance:b,farmAddress:m}}));return r?i.map(n=>n?this.farmData(n,r,!0):void 0):[]}async getDepositReward(t,e,r,i){let n=e.global_farm_id,s=e.yield_farm_id,a=r?await this.client.getIsolatedYieldFarm(t,n,s):await this.client.getOmnipoolYieldFarm(Number(t),n,s),o=r?await this.client.getIsolatedGlobalFarm(n):await this.client.getOmnipoolGlobalFarm(n);if(!o||!a)return;let l=o.reward_currency,u=o.incentivized_asset,p=[[this.getFarmAddress(0,r),o.reward_currency],[this.getFarmAddress(o.id,r),o.reward_currency]],d=await this.getAccountAssetBalances(p),m=await this.getOraclePrice(l,u),h=new Je(p,d),g=await new Ze(y=>this.getFarmAddress(y),y=>this.client.getAsset(y),h).claimRewards(o,a,e,i,m??o.price_adjustment);if(!g)return;let f=await this.client.getAsset(g.assetId);if(f&&!(g.reward<=f.existential_deposit))return g}async getAccountAssetBalances(t){let[e,r]=await Promise.all([Promise.all(t.filter(([n,s])=>s!==0).map(([n,s])=>this.balance.getTokenBalance(n,s))),Promise.all(t.filter(([n,s])=>s===0).map(([n])=>this.balance.getSystemBalance(n)))]),i=[];for(let n=0,s=0;n+s<t.length;){let a=n+s,[,o]=t[a];o===0?(i.push(r[s]),s+=1):(i.push(e[n]),n+=1)}return i}};var tr=require("polkadot-api"),ue=class extends D{omnipoolAssetIds=[];async getOraclePrice(t){return await this.api.query.EmaOracle.Oracles.getValue(tr.Binary.fromText("omnipool"),t,(0,tr.Enum)("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 zr={};R(zr,{PoolContextProvider:()=>Yt,PoolError:()=>St,PoolFactory:()=>Wt,PoolType:()=>C,aave:()=>Vr,hsm:()=>Yr,lbp:()=>Nr,omni:()=>Hr,stable:()=>Gr,xyk:()=>Ur});var Nr={};R(Nr,{LbpMath:()=>at,LbpPool:()=>pe,LbpPoolClient:()=>me});var dt=require("@galacticcouncil/math-lbp"),at=class{static getSpotPrice(t,e,r,i,n){return(0,dt.get_spot_price)(t,e,r,i,n)}static calculateInGivenOut(t,e,r,i,n){return(0,dt.calculate_in_given_out)(t,e,r,i,n)}static calculateOutGivenIn(t,e,r,i,n){return(0,dt.calculate_out_given_in)(t,e,r,i,n)}static calculateLinearWeights(t,e,r,i,n){return(0,dt.calculate_linear_weights)(t,e,r,i,n)}static calculatePoolTradeFee(t,e,r){return(0,dt.calculate_pool_trade_fee)(t,e,r)}};var qt=require("@galacticcouncil/common");var C=(s=>(s.Aave="Aave",s.LBP="LBP",s.Omni="Omnipool",s.Stable="Stableswap",s.XYK="XYK",s.HSM="HSM",s))(C||{}),St=(u=>(u.UnknownError="UnknownError",u.FacilitatorCapacityExceeded="FacilitatorCapacityExceeded",u.InsufficientTradingAmount="InsufficientTradingAmount",u.InsufficientCollateral="InsufficientCollateral",u.MaxHoldingExceeded="MaxHoldingExceeded",u.MaxInRatioExceeded="MaxInRatioExceeded",u.MaxOutRatioExceeded="MaxOutRatioExceeded",u.TradeNotAllowed="TradeNotAllowed",u.MaxBuyBackExceeded="MaxBuyBackExceeded",u.MaxBuyPriceExceeded="MaxBuyPriceExceeded",u))(St||{});var{FeeUtils:ki}=_,pe=class c{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;fee;repayFeeApply;static fromPool(t){return new c(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(s=>[s.id,s])),i=r.get(t),n=r.get(e);if(i==null)throw new Error("Pool does not contain tokenIn");if(n==null)throw new Error("Pool does not contain tokenOut");return{assetIn:t,assetOut:e,balanceIn:i.balance,balanceOut:n.balance,decimalsIn:i.decimals,decimalsOut:n.decimals,weightIn:i.weight,weightOut:n.weight}}validateAndBuy(t,e,r){let i=this.tokens[0].id,n=[];e<this.minTradingLimit&&n.push("InsufficientTradingAmount");let s=t.balanceOut/this.maxOutRatio;if(e>s&&n.push("MaxOutRatioExceeded"),i===t.assetOut){let a=this.calculateTradeFee(e,r),o=ki.toPct(this.repayFeeApply?r.repayFee:r.exchangeFee),l=e+a,u=this.calculateInGivenOut(t,l),p=t.balanceIn/this.maxInRatio;return u>p&&n.push("MaxInRatioExceeded"),{amountIn:u,calculatedIn:u,amountOut:e,feePct:o,errors:n}}else{let a=this.calculateInGivenOut(t,e),o=t.balanceIn/this.maxInRatio;return a>o&&n.push("MaxInRatioExceeded"),{amountIn:a,calculatedIn:a,amountOut:e,feePct:0,errors:n}}}validateAndSell(t,e,r){let i=this.tokens[0].id,n=[];e<this.minTradingLimit&&n.push("InsufficientTradingAmount");let s=t.balanceIn/this.maxInRatio;if(e>s&&n.push("MaxInRatioExceeded"),i===t.assetIn){let a=this.calculateOutGivenIn(t,e),o=t.balanceOut/this.maxOutRatio;return a>o&&n.push("MaxOutRatioExceeded"),{amountIn:e,calculatedOut:a,amountOut:a,feePct:0,errors:n}}else{let a=this.calculateOutGivenIn(t,e),o=this.calculateTradeFee(a,r),l=ki.toPct(this.repayFeeApply?r.repayFee:r.exchangeFee),u=a-o,p=t.balanceOut/this.maxOutRatio;return u>p&&n.push("MaxOutRatioExceeded"),{amountIn:e,calculatedOut:a,amountOut:u,feePct:l,errors:n}}}calculateInGivenOut(t,e){let r=at.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=at.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=at.getSpotPrice(t.balanceOut.toString(),t.balanceIn.toString(),t.weightOut.toString(),t.weightIn.toString(),qt.big.toBigInt(1,qt.RUNTIME_DECIMALS).toString());return BigInt(e)}spotPriceOutGivenIn(t){let e=at.getSpotPrice(t.balanceIn.toString(),t.balanceOut.toString(),t.weightIn.toString(),t.weightOut.toString(),qt.big.toBigInt(1,qt.RUNTIME_DECIMALS).toString());return BigInt(e)}calculateTradeFee(t,e){let r=at.calculatePoolTradeFee(t.toString(),this.repayFeeApply?e.repayFee[0]:e.exchangeFee[0],this.repayFeeApply?e.repayFee[1]:e.exchangeFee[1]);return BigInt(r)}};var qi=require("polkadot-api"),Nt=require("rxjs");var Mi=(c,t=new Map)=>e=>{let r;return t.has(e)?t.get(e):(t.set(e,r=c(e)),r)};var F=require("rxjs"),P=require("rxjs/operators");var Di=require("rxjs"),er=class{store$=new Di.BehaviorSubject([]);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((a,o)=>[a.address,o])),i=await t(e),n=e.slice(),s=new Set;for(let a of i){let o=r.get(a.address);o===void 0?(r.set(a.address,n.length),n.push(a)):n[o]=a,s.add(a.address)}this.changeset=s,this.store$.next(n)}).catch(console.error)}destroy(){this.store$.complete()}};var Li=require("@galacticcouncil/common");var es={Aave:"AAVE",LBP:"LBP",Omnipool:"OMNI",Stableswap:"STBL",XYK:"XYK",HSM:"HSM"},{logger:rr}=Li.log,ir=class{type;constructor(t){this.type=t}prefix(){return this.pad(`pool(${es[this.type]})`,10)}trace(t,...e){rr.trace(`${this.prefix()} ${t} :`,...e)}debug(t,...e){rr.debug(`${this.prefix()} ${t} :`,...e)}info(t,...e){rr.info(`${this.prefix()} ${t} :`,...e)}error(t,...e){rr.error(`${this.prefix()} ${t} :`,...e)}pad(t,e){return t.length>=e?t:t+" ".repeat(e-t.length)}};var{withTimeout:rs}=ae,is=3e3,j=class extends D{evm;balance;store=new er;log;shared$;resync$=new F.ReplaySubject(1);resyncAt=0;resyncPending=!1;mem=0;memPoolsCache=new _t(null,{ttl:6*1e3});memPools=Mi(t=>(this.log.info("pool_sync",{mem:t}),this.loadPools()),this.memPoolsCache);constructor(t,e){super(t),this.evm=e,this.balance=new ut(t),this.log=new ir(this.getPoolType())}async getMemPools(){return this.memPools(this.mem)}async getPools(){return(await this.getMemPools()).filter(e=>this.hasValidAssets(e))}getSubscriber(){return this.shared$||(this.shared$=this.subscribeStore()),this.shared$.pipe((0,P.startWith)([]),(0,P.bufferCount)(2,1),(0,P.map)(([t,e])=>t.length===0?e:this.store.applyChangeset(e)),(0,P.filter)(t=>t.length>0),(0,P.throttleTime)(1e3,void 0,{leading:!0,trailing:!0}))}subscribeStore(){return(0,F.defer)(()=>{let t=new F.Subscription;return t.add(this.startWatchdog()),this.resync$.next(),this.resync$.pipe((0,P.switchMap)(()=>{let e=new F.Subscription;return(0,F.from)(rs(this.getMemPools(),6e4,"getMemPools stalled")).pipe((0,P.tap)(()=>this.log.info("pool_synced",{mem:this.mem})),(0,P.map)(i=>i.filter(n=>this.hasValidAssets(n))),(0,P.tap)(i=>this.store.set(i)),(0,P.catchError)(()=>(this.log.error("pool_seed_error",{mem:this.mem}),this.requestResync(!0),F.EMPTY))).pipe((0,P.tap)(()=>{e.add(this.subscribeBalances()),e.add(this.subscribeUpdates())}),(0,P.switchMap)(i=>(0,F.merge)((0,F.of)(i),this.store.asObservable().pipe((0,P.skip)(1)))),(0,P.finalize)(()=>{e.unsubscribe()}))}),(0,P.finalize)(()=>t.unsubscribe()),(0,P.share)({connector:()=>new F.ReplaySubject(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 n=this.balance.watchSystemBalance(r);i.push(n)}if(this.hasErc20Asset(e)){let n=e.tokens.filter(a=>a.type==="Erc20").map(a=>a.id),s=this.balance.watchErc20Balance(r,n);i.push(s)}return(0,F.combineLatest)(i).pipe((0,P.map)(n=>n.flat()),(0,P.pairwise)(),(0,P.map)(([n,s])=>this.balance.getDeltas(n,s)),(0,P.filter)(n=>n.length>0),(0,P.map)(n=>[r,n]))});return(0,F.merge)(...t).pipe((0,P.bufferTime)(250),(0,P.filter)(e=>e.length>0),(0,P.map)(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})=>r>0n&&!!e)}updateBalances=(t,e)=>{let r=[],i=new Map(t.map(n=>[n.address,n]));for(let[n,s]of e){let a=i.get(n);if(a){let o=a.tokens.map(l=>{let u=s.find(p=>p.id===l.id);return u&&l.id!==a.id?{...l,balance:u.balance.transferable}:l});r.push({...a,tokens:o})}}return r};resync(t=!1){let e=Date.now();!t&&e-this.resyncAt<is||(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((0,P.pairwise)(),(0,P.filter)(([n,s])=>n==="offline"&&s==="online"),(0,P.tap)(()=>{this.log.debug("watchdog_recover_online",{mem:this.mem}),this.requestResync()}),(0,P.catchError)(n=>(this.log.error("watchdog_recovery_error",n),F.EMPTY)),(0,P.repeat)({delay:1e3})),i=this.watcher.finalizedBlock$.pipe((0,P.pairwise)(),(0,P.tap)(([n,s])=>{let a=Number(n.number),o=Number(s.number),l=o-a;l>=3&&(this.log.debug("watchdog_gap",{from:a,to:o,gap:l}),this.requestResync())}),(0,P.catchError)(n=>(this.log.error("watchdog_gap_error",n),F.EMPTY)),(0,P.repeat)({delay:1e3}));return(0,F.merge)(r,i).subscribe()}watchGuard(t){return e=>e.pipe((0,P.tap)({error:r=>{this.log.error(t,r),this.requestResync(!0)}}),(0,P.finalize)(()=>{this.log.debug(t,"unsub")}),(0,P.catchError)(()=>F.EMPTY))}};var me=class extends j{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:n,final_weight:s}=t,a=at.calculateLinearWeights(r?r.toString():"0",i?i.toString():"0",n.toString(),s.toString(),e.toString()),o=BigInt(a),l=this.MAX_FINAL_WEIGHT-BigInt(o);return[o,l]}async isSupported(){let t=this.api.query.LBP.PoolData,e=await this.api.compatibilityToken;return t.isCompatible(qi.CompatibilityLevel.BackwardsCompatible,e)}async loadPools(){let[t,e,r]=await Promise.all([this.api.query.LBP.PoolData.getEntries({at:"best"}),this.api.query.ParachainSystem.ValidationData.getValue({at:"best"}),this.getPoolLimits()]),i=e?.relay_parent_number||0,n=t.filter(({value:s})=>e&&this.isActivePool(s,i)).map(async({keyArgs:s,value:a})=>{let[o]=s,l=o.toString(),u=await this.getPoolDelta(l,a,i);return{address:l,type:"LBP",fee:a.fee,...u,...r}});return Promise.all(n)}async getPoolDelta(t,e,r){let{assets:i,repay_target:n,fee_collector:s}=e,[a,o]=this.getPoolWeights(e,r),[l,u]=i,[p,d,m,h,b]=await Promise.all([this.isRepayFeeApplied(l,n,s.toString()),this.balance.getBalance(t,l),this.api.query.AssetRegistry.Assets.getValue(l),this.balance.getBalance(t,u),this.api.query.AssetRegistry.Assets.getValue(u)]);return{repayFeeApply:p,tokens:[{id:l,decimals:m?.decimals,existentialDeposit:m?.existential_deposit,balance:d.transferable,weight:a,type:m?.asset_type.type},{id:u,decimals:b?.decimals,existentialDeposit:b?.existential_deposit,balance:h.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(n=>n.address===e);return{repayFee:await this.getRepayFee(),exchangeFee:r.fee}}subscribeValidationData(){return this.api.query.ParachainSystem.ValidationData.watchValue("best").pipe((0,Nt.filter)(t=>t!==void 0),(0,Nt.distinctUntilChanged)((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 n=this.poolsData.get(i.address);if(n){let{assets:s,repay_target:a,fee_collector:o}=n,[l]=s,[u,p]=this.getPoolWeights(n,t),[d,m]=i.tokens,h=[{...d,weight:u},{...m,weight:p}],b=await this.isRepayFeeApplied(l,a,o.toString());r.push({...i,tokens:h,repayFeeApply:b})}}return r})})}subscribeUpdates(){let t=new Nt.Subscription;return t.add(this.subscribeValidationData()),t}};var Hr={};R(Hr,{OmniMath:()=>B,OmniPool:()=>de,OmniPoolClient:()=>ge});var x=require("@galacticcouncil/math-omnipool"),Ot=ft(require("big.js")),B=class{static calculateSpotPrice(t,e,r,i){return(0,x.calculate_spot_price)(t,e,r,i)}static calculateLrnaSpotPrice(t,e){return(0,x.calculate_lrna_spot_price)(t,e)}static calculateInGivenOut(t,e,r,i,n,s,a,o,l){return(0,x.calculate_in_given_out)(t,e,r,i,n,s,a,o,l)}static calculateLrnaInGivenOut(t,e,r,i,n){return(0,x.calculate_lrna_in_given_out)(t,e,r,i,n)}static calculateOutGivenIn(t,e,r,i,n,s,a,o,l){return(0,x.calculate_out_given_in)(t,e,r,i,n,s,a,o,l)}static calculateOutGivenLrnaIn(t,e,r,i,n){return(0,x.calculate_out_given_lrna_in)(t,e,r,i,n)}static calculateShares(t,e,r,i){return(0,x.calculate_shares)(t,e,r,i)}static calculateLiquidityOut(t,e,r,i,n,s,a,o){return(0,x.calculate_liquidity_out)(t,e,r,i,n,s,a,o)}static calculateLiquidityLRNAOut(t,e,r,i,n,s,a,o){return(0,x.calculate_liquidity_lrna_out)(t,e,r,i,n,s,a,o)}static calculateCapDifference(t,e,r,i){let n=(0,Ot.default)(e),s=(0,Ot.default)(t),a=(0,Ot.default)(i),o=(0,Ot.default)(r),l=(0,Ot.default)(10).pow(18),u=o.div(l);if(n.div(a).lt(u)){let d=u.times(a).minus(n).times(s),m=n.times((0,Ot.default)(1).minus(u));return d.div(m).toFixed(0)}else return"0"}static calculateLimitHubIn(t,e,r,i){return(0,x.calculate_liquidity_hub_in)(t,e,r,i)}static isSellAllowed(t){return(0,x.is_sell_allowed)(t)}static isBuyAllowed(t){return(0,x.is_buy_allowed)(t)}static isAddLiquidityAllowed(t){return(0,x.is_add_liquidity_allowed)(t)}static isRemoveLiquidityAllowed(t){return(0,x.is_remove_liquidity_allowed)(t)}static recalculateAssetFee(t,e,r,i,n,s,a,o,l,u,p){return(0,x.recalculate_asset_fee)(t,e,r,i,n,s,a,o,l,u,p)}static recalculateProtocolFee(t,e,r,i,n,s,a,o,l,u,p){return(0,x.recalculate_protocol_fee)(t,e,r,i,n,s,a,o,l,u,p)}static verifyAssetCap(t,e,r,i){return(0,x.verify_asset_cap)(t,e,r,i)}};var Ni=require("@galacticcouncil/common");var{FeeUtils:Ht}=_,de=class c{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;hubAssetId;static fromPool(t){return new c(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(s=>[s.id,s])),i=r.get(t),n=r.get(e);if(i==null)throw new Error("Pool does not contain tokenIn");if(n==null)throw new Error("Pool does not contain tokenOut");return{assetIn:t,assetOut:e,hubReservesIn:i.hubReserves,hubReservesOut:n.hubReserves,sharesIn:i.shares,sharesOut:n.shares,decimalsIn:i.decimals,decimalsOut:n.decimals,balanceIn:i.balance,balanceOut:n.balance,tradeableIn:i.tradeable,tradeableOut:n.tradeable,assetInEd:i.existentialDeposit,assetOutEd:n.existentialDeposit}}validateAndBuy(t,e,r){let i=this.calculateInGivenOut(t,e),n=this.calculateInGivenOut(t,e,r),s=i===0n?0:W.calculateDiffToRef(n,i),a=[],o=B.isSellAllowed(t.tradeableIn),l=B.isBuyAllowed(t.tradeableOut);(!o||!l)&&a.push("TradeNotAllowed"),(e<this.minTradingLimit||i<t.assetInEd)&&a.push("InsufficientTradingAmount");let u=t.balanceOut/this.maxOutRatio;e>u&&a.push("MaxOutRatioExceeded");let p=t.balanceIn/this.maxInRatio;return n>p&&a.push("MaxInRatioExceeded"),{amountIn:n,calculatedIn:i,amountOut:e,feePct:s,errors:a}}validateAndSell(t,e,r){let i=this.calculateOutGivenIn(t,e),n=this.calculateOutGivenIn(t,e,r),s=W.calculateDiffToRef(i,n),a=[],o=B.isSellAllowed(t.tradeableIn),l=B.isBuyAllowed(t.tradeableOut);(!o||!l)&&a.push("TradeNotAllowed"),(e<this.minTradingLimit||i<t.assetOutEd)&&a.push("InsufficientTradingAmount");let u=t.balanceIn/this.maxInRatio;e>u&&a.push("MaxInRatioExceeded");let p=t.balanceOut/this.maxOutRatio;return n>p&&a.push("MaxOutRatioExceeded"),{amountIn:e,calculatedOut:i,amountOut:n,feePct:s,errors:a}}calculateInGivenOut(t,e,r){if(t.assetIn==this.hubAssetId)return this.calculateLrnaInGivenOut(t,e,r);let i=B.calculateInGivenOut(t.balanceIn.toString(),t.hubReservesIn.toString(),t.sharesIn.toString(),t.balanceOut.toString(),t.hubReservesOut.toString(),t.sharesOut.toString(),e.toString(),r?Ht.toRaw(r.assetFee).toString():"0",r?Ht.toRaw(r.protocolFee).toString():"0"),n=BigInt(i);return n<0n?0n:n}calculateLrnaInGivenOut(t,e,r){let i=B.calculateLrnaInGivenOut(t.balanceOut.toString(),t.hubReservesOut.toString(),t.sharesOut.toString(),e.toString(),r?Ht.toRaw(r.assetFee).toString():"0"),n=BigInt(i);return n<0n?0n:n}calculateOutGivenIn(t,e,r){if(t.assetIn==this.hubAssetId)return this.calculateOutGivenLrnaIn(t,e,r);let i=B.calculateOutGivenIn(t.balanceIn.toString(),t.hubReservesIn.toString(),t.sharesIn.toString(),t.balanceOut.toString(),t.hubReservesOut.toString(),t.sharesOut.toString(),e.toString(),r?Ht.toRaw(r.assetFee).toString():"0",r?Ht.toRaw(r.protocolFee).toString():"0"),n=BigInt(i);return n<0n?0n:n}calculateOutGivenLrnaIn(t,e,r){let i=B.calculateOutGivenLrnaIn(t.balanceOut.toString(),t.hubReservesOut.toString(),t.sharesOut.toString(),e.toString(),r?Ht.toRaw(r.assetFee).toString():"0"),n=BigInt(i);return n<0n?0n:n}spotPriceInGivenOut(t){if(t.assetIn==this.hubAssetId)return this.spotPriceLrnaInGivenOut(t);let e=B.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=B.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=B.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=B.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 n=Ni.big.pow10(Math.abs(i));return i>0?t*n:t/n}};var wt=require("polkadot-api"),Ui=require("@polkadot-api/utils"),O=require("rxjs"),Vi=require("@galacticcouncil/common");var{FeeUtils:G}=_,Hi=wt.Binary.fromText("omnipool"),Gi=(0,wt.Enum)("Short"),ge=class extends j{queryBus=new le;block=0;dynamicFeesConfig=this.queryBus.scope("DynamicFees.AssetFeeConfiguration",t=>this.api.query.DynamicFees.AssetFeeConfiguration.getValue(t,{at:"best"}),t=>String(t));dynamicFees=this.queryBus.scope("DynamicFees.AssetFee",t=>this.api.query.DynamicFees.AssetFee.getValue(t,{at:"best"}),t=>String(t),6*1e3);emaOracles=this.queryBus.scope("EmaOracle.Oracles.Short",t=>this.api.query.EmaOracle.Oracles.getValue(Hi,t,Gi,{at:"best"}),t=>t.join(":"),6*1e3);getPoolType(){return"Omnipool"}getPoolAddress(){let t="modlomnipool".padEnd(32,"\0"),e=new TextEncoder().encode(t),r=(0,Ui.toHex)(e);return(0,wt.AccountId)(Vi.HYDRATION_SS58_PREFIX).dec(r)}getOraclePair(t){return t===0?[0,1]:[1,t]}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(){let t=this.api.query.Omnipool.Assets,e=await this.api.compatibilityToken;return t.isCompatible(wt.CompatibilityLevel.BackwardsCompatible,e)}async loadPools(){let t=await this.api.constants.Omnipool.HubAssetId(),e=this.getPoolAddress(),[r,i,n,s,a]=await Promise.all([this.api.query.Omnipool.Assets.getEntries({at:"best"}),this.api.query.Omnipool.HubAssetTradability.getValue(),this.api.query.AssetRegistry.Assets.getValue(t),this.balance.getBalance(e,t),this.getPoolLimits()]),o=r.map(async({keyArgs:u,value:p})=>{let[d]=u,{hub_reserve:m,shares:h,tradable:b,cap:g,protocol_shares:f}=p,[y,S]=await Promise.all([this.api.query.AssetRegistry.Assets.getValue(d),this.balance.getBalance(e,d)]);return{id:d,decimals:y?.decimals,existentialDeposit:y?.existential_deposit,balance:S.transferable,cap:g,hubReserves:m,protocolShares:f,shares:h,tradeable:b,type:y?.asset_type.type}}),l=await Promise.all(o);return l.push({id:t,decimals:n?.decimals,existentialDeposit:n?.existential_deposit,balance:s.transferable,tradeable:i,type:n?.asset_type.type}),[{address:e,type:"Omnipool",hubAssetId:t,tokens:l,...a}]}async getPoolFees(t){let e=t.assetOut,r=t.assetIn,i=await this.dynamicFeesConfig.get(e);if(i?.type==="Fixed"){let{asset_fee:y,protocol_fee:S}=i.value;return{assetFee:G.fromPermill(y),protocolFee:G.fromPermill(S)}}let n=this.getOraclePair(e),s=this.getOraclePair(r),[a,o,l]=await Promise.all([this.dynamicFees.get(e),this.emaOracles.get(n),this.emaOracles.get(s)]),[u,p,d]=await this.getAssetFee(t,this.block,a,o,i?.value.asset_fee_params),[m,h,b]=r===1?[0,0,0]:await this.getProtocolFee(t,this.block,a,l,i?.value.protocol_fee_params),g=u+m,f=d+b;return{assetFee:G.fromPermill(p),protocolFee:G.fromPermill(h),min:G.fromPermill(g),max:G.fromPermill(f)}}async getAssetFee(t,e,r,i,n){let{assetOut:s,balanceOut:a}=t,{min_fee:o,max_fee:l,decay:u,amplification:p}=n||await this.api.constants.DynamicFees.AssetFeeParameters();if(!r||!i)return[o,o,l];let d=G.fromPermill(o),m=G.fromPermill(l),[h]=i,{asset_fee:b,timestamp:g}=r,f=Math.max(1,e-g),y=h.volume.b_in.toString(),S=h.volume.b_out.toString(),v=h.liquidity.b.toString();s===0&&(y=h.volume.a_in.toString(),S=h.volume.a_out.toString(),v=h.liquidity.a.toString());let T=G.fromPermill(b),A=B.recalculateAssetFee(y,S,v,"9",a.toString(),G.toRaw(T).toString(),f.toString(),G.toRaw(d).toString(),G.toRaw(m).toString(),u.toString(),p.toString());return[o,Number(A)*1e6,l]}async getProtocolFee(t,e,r,i,n){let{assetIn:s,balanceIn:a}=t,{min_fee:o,max_fee:l,decay:u,amplification:p}=n||await this.api.constants.DynamicFees.ProtocolFeeParameters();if(!r||!i)return[o,o,l];let d=G.fromPermill(o),m=G.fromPermill(l),[h]=i,{protocol_fee:b,timestamp:g}=r,f=Math.max(1,e-g),y=h.volume.b_in.toString(),S=h.volume.b_out.toString(),v=h.liquidity.b.toString();s===0&&(y=h.volume.a_in.toString(),S=h.volume.a_out.toString(),v=h.liquidity.a.toString());let T=G.fromPermill(b),A=B.recalculateProtocolFee(y,S,v,"9",a.toString(),G.toRaw(T).toString(),f.toString(),G.toRaw(d).toString(),G.toRaw(m).toString(),u.toString(),p.toString());return[o,Number(A)*1e6,l]}subscribeEmaOracles(){let[t]=this.store.pools,r=t.tokens.map(i=>i.id).map(i=>this.getOraclePair(i)).map(i=>this.api.query.EmaOracle.Oracles.watchValue(Hi,i,Gi,"best").pipe((0,O.filter)(n=>n!==void 0),(0,O.map)((n,s)=>({value:n,index:s})),(0,O.tap)(({index:n})=>{n>0&&this.log.trace("emaOracle.Oracles",i.join(":"))}),(0,O.map)(({value:n})=>({pair:i,value:n}))));return(0,O.merge)(...r).pipe((0,O.finalize)(()=>this.emaOracles.clear()),this.watchGuard("emaOracle.Oracles")).subscribe(i=>{let{pair:n,value:s}=i;this.emaOracles.set(s,n)})}subscribeDynamicFees(){return this.api.query.DynamicFees.AssetFee.watchEntries({at:"best"}).pipe((0,O.distinctUntilChanged)((t,e)=>!e.deltas),(0,O.map)((t,e)=>({value:t,index:e})),(0,O.tap)(({value:t,index:e})=>{e>0&&this.log.trace("dynamicFees.AssetFee",t.deltas?.upserted)}),(0,O.finalize)(()=>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((0,O.distinctUntilChanged)((t,e)=>!e.deltas),(0,O.map)((t,e)=>({value:t,index:e})),(0,O.tap)(({value:t,index:e})=>{e>0&&this.log.trace("dynamicFees.AssetFeeConfiguration",t.deltas?.upserted)}),(0,O.finalize)(()=>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((0,O.distinctUntilChanged)((t,e)=>!e.deltas),(0,O.map)((t,e)=>({value:t,index:e})),(0,O.tap)(({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((n,s)=>{let[a]=s.args;return n.set(a,s.value),n},new Map),i=e.tokens.map(n=>{let s=r?.get(n.id);return s?this.updateTokenState(n,s):n});return[{...e,tokens:i}]})})}subscribeUpdates(){let t=new O.Subscription;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:n,cap:s,protocol_shares:a}=e;return{...t,cap:s,hubReserves:r,protocolShares:a,shares:i,tradeable:n}}};var Gr={};R(Gr,{StableMath:()=>z,StableSwap:()=>At,StableSwapClient:()=>be});var k=require("@galacticcouncil/math-stableswap"),z=class{static getPoolAddress(t){return(0,k.pool_account_name)(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,n){return(0,k.calculate_amplification)(t,e,r,i,n)}static calculateInGivenOut(t,e,r,i,n,s,a){return(0,k.calculate_in_given_out)(t,e,r,i,n,s,a)}static calculateAddOneAsset(t,e,r,i,n,s,a){return(0,k.calculate_add_one_asset)(t,e,r,i,n,s,a)}static calculateSharesForAmount(t,e,r,i,n,s,a){return(0,k.calculate_shares_for_amount)(t,e,r,i,n,s,a)}static calculateOutGivenIn(t,e,r,i,n,s,a){return(0,k.calculate_out_given_in)(t,e,r,i,n,s,a)}static calculateLiquidityOutOneAsset(t,e,r,i,n,s,a){return(0,k.calculate_liquidity_out_one_asset)(t,e,r,i,n,s,a)}static calculateShares(t,e,r,i,n,s){return(0,k.calculate_shares)(t,e,r,i,n,s)}static calculateSpotPriceWithFee(t,e,r,i,n,s,a,o){return(0,k.calculate_spot_price_with_fee)(t,e,r,i,n,s,a,o)}static recalculatePegs(t,e,r,i,n,s){let a=(0,k.recalculate_peg)(t,e,r,i,n,s);return JSON.parse(a)}};var he=require("@galacticcouncil/common");var{FeeUtils:Gt}=_,At=class c{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;amplification;isRampPeriod;id;fee;totalIssuance;pegs;static fromPool(t){return new c(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(s=>[s.id,s])),i=r.get(t),n=r.get(e);if(i==null)throw new Error("Pool does not contain tokenIn");if(n==null)throw new Error("Pool does not contain tokenOut");return{assetIn:t,assetOut:e,balanceIn:i.balance,balanceOut:n.balance,decimalsIn:i.decimals,decimalsOut:n.decimals,tradeableIn:this.id===t?15:i.tradeable,tradeableOut:this.id===e?15:n.tradeable,assetInEd:i.existentialDeposit,assetOutEd:n.existentialDeposit}}validateAndBuy(t,e,r){let i=this.calculateInGivenOut(t,e),n=this.calculateInGivenOut(t,e,r),s=i===0n?0:W.calculateDiffToRef(n,i),a=[],o=B.isSellAllowed(t.tradeableIn),l=B.isBuyAllowed(t.tradeableOut);return(!o||!l)&&a.push("TradeNotAllowed"),(e<this.minTradingLimit||i<t.assetInEd)&&a.push("InsufficientTradingAmount"),{amountIn:n,calculatedIn:i,amountOut:e,feePct:s,errors:a}}validateAndSell(t,e,r){let i=this.calculateOutGivenIn(t,e),n=this.calculateOutGivenIn(t,e,r),s=W.calculateDiffToRef(i,n),a=[],o=B.isSellAllowed(t.tradeableIn),l=B.isBuyAllowed(t.tradeableOut);return(!o||!l)&&a.push("TradeNotAllowed"),(e<this.minTradingLimit||i<t.assetOutEd)&&a.push("InsufficientTradingAmount"),{amountIn:e,calculatedOut:i,amountOut:n,feePct:s,errors:a}}calculateIn(t,e,r){let i=z.calculateInGivenOut(this.getReserves(),Number(t.assetIn),Number(t.assetOut),e.toString(),this.amplification.toString(),r?Gt.toRaw(r.fee).toString():"0",this.getPegs()),n=BigInt(i);return n<0n?0n:n}calculateAddOneAsset(t,e,r){let i=z.calculateAddOneAsset(this.getReserves(),e.toString(),Number(t.assetIn),this.amplification.toString(),this.totalIssuance.toString(),r?Gt.toRaw(r.fee).toString():"0",this.getPegs()),n=BigInt(i);return n<0n?0n:n}calculateSharesForAmount(t,e,r){let i=z.calculateSharesForAmount(this.getReserves(),Number(t.assetOut),e.toString(),this.amplification.toString(),this.totalIssuance.toString(),r?Gt.toRaw(r.fee).toString():"0",this.getPegs()),n=BigInt(i);return n<0n?0n:n}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=z.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=z.calculateOutGivenIn(this.getReserves(),Number(t.assetIn),Number(t.assetOut),e.toString(),this.amplification.toString(),r?Gt.toRaw(r.fee).toString():"0",this.getPegs()),n=BigInt(i);return n<0n?0n:n}calculateWithdrawOneAsset(t,e,r){let i=z.calculateLiquidityOutOneAsset(this.getReserves(),e.toString(),Number(t.assetOut),this.amplification.toString(),this.totalIssuance.toString(),r?Gt.toRaw(r.fee).toString():"0",this.getPegs()),n=BigInt(i);return n<0n?0n:n}calculateShares(t,e,r){let i=z.calculateShares(this.getReserves(),this.getAssets(t.assetIn,e),this.amplification.toString(),this.totalIssuance.toString(),r?Gt.toRaw(r.fee).toString():"0",this.getPegs()),n=BigInt(i);return n<0n?0n:n}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=z.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,Dt.jsonFormatter)}getAssets(t,e){let r={asset_id:Number(t),amount:e.toString()};return JSON.stringify([r],Dt.jsonFormatter)}normalizeSpot(t,e,r,i,n){return e?t*he.big.pow10(he.RUNTIME_DECIMALS-n):r?t/he.big.pow10(n-i):t}};var nr=require("polkadot-api"),Wi=require("@polkadot-api/utils"),Yi=require("@noble/hashes/blake2b"),Z=require("rxjs"),sr=require("@galacticcouncil/common");var{FeeUtils:ns}=_,be=class extends j{poolsData=new Map([]);getPoolType(){return"Stableswap"}getPoolAddress(t){let e=z.getPoolAddress(t),r=(0,Yi.blake2b)(e,{dkLen:32}),i=(0,Wi.toHex)(r);return(0,nr.AccountId)(sr.HYDRATION_SS58_PREFIX).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:n,final_block:s}=t,a=z.calculateAmplification(r.toString(),i.toString(),n.toString(),s.toString(),e.toString()),o=Number(a)<i;return{amplification:BigInt(a),isRampPeriod:o}}async getPoolTokens(t,e){let r=this.getPoolAddress(t),i=e.assets.map(async n=>{let[s,a,o]=await Promise.all([this.api.query.Stableswap.AssetTradability.getValue(t,n),this.api.query.AssetRegistry.Assets.getValue(n),this.balance.getBalance(r,n)]);return{id:n,decimals:a?.decimals,existentialDeposit:a?.existential_deposit,balance:o.transferable,tradeable:s,type:a?.asset_type.type}});return Promise.all(i)}async isSupported(){let t=this.api.query.Stableswap.Pools,e=await this.api.compatibilityToken;return t.isCompatible(nr.CompatibilityLevel.BackwardsCompatible,e)}async loadPools(){let[t,e,r]=await Promise.all([this.api.query.Stableswap.Pools.getEntries({at:"best"}),this.api.query.System.Number.getValue({at:"best"}),this.getPoolLimits()]),i=t.map(async({keyArgs:n,value:s})=>{let[a]=n,o=this.getPoolAddress(a),[l,u,p]=await Promise.all([this.getPoolTokens(a,s),this.api.query.Stableswap.PoolPegs.getValue(a,{at:"best"}),this.api.query.Tokens.TotalIssuance.getValue(a,{at:"best"})]),d=this.getPoolAmplification(s,e),m=u?this.getRecentPegs(u):this.getDefaultPegs(s);return l.push({id:a,tradeable:15,balance:p,decimals:sr.RUNTIME_DECIMALS}),this.poolsData.set(a,s),{address:o,id:a,type:"Stableswap",fee:ns.fromPermill(s.fee),tokens:l,totalIssuance:p,pegs:m,...r,...d}});return Promise.all(i)}async getPoolFees(t,e){return{fee:this.store.pools.find(i=>i.address===e).fee}}getDefaultPegs(t){return z.defaultPegs(t.assets.length)}getRecentPegs(t){let{current:e}=t;return Array.from(e.entries()).map(([r,i])=>i.map(n=>n.toString()))}subscribeIssuance(){let e=this.store.pools.map(r=>r.id).map(r=>this.api.query.Tokens.TotalIssuance.watchValue(r,"best").pipe((0,Z.map)((i,n)=>({value:i,index:n})),(0,Z.tap)(({index:i,value:n})=>{i>0&&this.log.trace("tokens.TotalIssuance",r,n)}),(0,Z.map)(({value:i})=>({id:r,value:i}))));return(0,Z.merge)(...e).pipe(this.watchGuard("tokens.TotalIssuance")).subscribe(r=>{let{id:i,value:n}=r;this.store.update(s=>{let a=[];return s.filter(o=>o.id===i).forEach(o=>{let l=o.tokens.map(u=>u.id===i?{...u,balance:n}:u);a.push({...o,tokens:l,totalIssuance:n})}),a})})}subscribePoolPegs(){return this.api.query.Stableswap.PoolPegs.watchEntries({at:"best"}).pipe((0,Z.distinctUntilChanged)((t,e)=>!e.deltas),(0,Z.map)((t,e)=>({value:t,index:e})),(0,Z.tap)(({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 r=[],i=new Map(e.map(n=>[n.id,n]));return t?.upserted.forEach(({args:n,value:s})=>{let[a]=n,o=i.get(a);if(o){let l=this.getRecentPegs(s);r.push({...o,pegs:l})}}),r})}})}subscribeBlock(){return this.watcher.bestBlock$.pipe(this.watchGuard("watcher.bestBlock")).subscribe(t=>{this.store.update(e=>{let r=[];return e.filter(i=>i.isRampPeriod).forEach(i=>{let n=this.poolsData.get(i.id);if(n){let s=this.getPoolAmplification(n,t);r.push({...i,...s})}}),r})})}subscribeUpdates(){let t=new Z.Subscription;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 Ur={};R(Ur,{XykMath:()=>yt,XykPool:()=>ye,XykPoolClient:()=>fe});var M=require("@galacticcouncil/math-xyk"),yt=class{static getSpotPrice(t,e,r){return(0,M.get_spot_price)(t,e,r)}static calculateInGivenOut(t,e,r){return(0,M.calculate_in_given_out)(t,e,r)}static calculateOutGivenIn(t,e,r){return(0,M.calculate_out_given_in)(t,e,r)}static calculatePoolTradeFee(t,e,r){return(0,M.calculate_pool_trade_fee)(t,e,r)}static calculateLiquidityIn(t,e,r){return(0,M.calculate_liquidity_in)(t,e,r)}static calculateSpotPrice(t,e){return(0,M.calculate_spot_price)(t,e)}static calculateSpotPriceWithFee(t,e,r,i){return(0,M.calculate_spot_price_with_fee)(t,e,r,i)}static calculateShares(t,e,r){return(0,M.calculate_shares)(t,e,r)}static calculateLiquidityOutAssetA(t,e,r,i){return(0,M.calculate_liquidity_out_asset_a)(t,e,r,i)}static calculateLiquidityOutAssetB(t,e,r,i){return(0,M.calculate_liquidity_out_asset_b)(t,e,r,i)}};var $i=require("@galacticcouncil/common");var{FeeUtils:zi}=_,ye=class c{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;static fromPool(t){return new c(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(s=>[s.id,s])),i=r.get(t),n=r.get(e);if(i==null)throw new Error("Pool does not contain tokenIn");if(n==null)throw new Error("Pool does not contain tokenOut");return{assetIn:t,assetOut:e,decimalsIn:i.decimals,decimalsOut:n.decimals,balanceIn:i.balance,balanceOut:n.balance,assetInEd:i.existentialDeposit,assetOutEd:n.existentialDeposit}}validateAndBuy(t,e,r){let i=this.calculateInGivenOut(t,e),n=this.calculateTradeFee(i,r),s=zi.toPct(r.exchangeFee),a=i+n,o=[];(e<this.minTradingLimit||i<t.assetInEd)&&o.push("InsufficientTradingAmount");let l=t.balanceOut/this.maxOutRatio;e>l&&o.push("MaxOutRatioExceeded");let u=t.balanceIn/this.maxInRatio;return a>u&&o.push("MaxInRatioExceeded"),{amountIn:a,calculatedIn:i,amountOut:e,feePct:s,errors:o}}validateAndSell(t,e,r){let i=this.calculateOutGivenIn(t,e),n=this.calculateTradeFee(i,r),s=zi.toPct(r.exchangeFee),a=i-n,o=[];(e<this.minTradingLimit||i<t.assetOutEd)&&o.push("InsufficientTradingAmount");let l=t.balanceIn/this.maxInRatio;e>l&&o.push("MaxInRatioExceeded");let u=t.balanceOut/this.maxOutRatio;return a>u&&o.push("MaxOutRatioExceeded"),{amountIn:e,calculatedOut:i,amountOut:a,feePct:s,errors:o}}calculateInGivenOut(t,e){let r=yt.calculateInGivenOut(t.balanceIn.toString(),t.balanceOut.toString(),e.toString()),i=BigInt(r);return i<0n?0n:i}calculateOutGivenIn(t,e){let r=yt.calculateOutGivenIn(t.balanceIn.toString(),t.balanceOut.toString(),e.toString()),i=BigInt(r);return i<0n?0n:i}spotPriceInGivenOut(t){let e=yt.calculateSpotPrice(t.balanceOut.toString(),t.balanceIn.toString());return this.normalizeSpot(BigInt(e),t.decimalsOut,t.decimalsIn)}spotPriceOutGivenIn(t){let e=yt.calculateSpotPrice(t.balanceIn.toString(),t.balanceOut.toString());return this.normalizeSpot(BigInt(e),t.decimalsIn,t.decimalsOut)}calculateTradeFee(t,e){let r=yt.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 n=$i.big.pow10(Math.abs(i));return i>0?t*n:t/n}};var Xi=require("polkadot-api"),Ki=require("rxjs");var fe=class extends j{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(){let t=this.api.query.XYK.PoolAssets,e=await this.api.compatibilityToken;return t.isCompatible(Xi.CompatibilityLevel.BackwardsCompatible,e)}async loadPools(){let[t,e]=await Promise.all([this.api.query.XYK.PoolAssets.getEntries(),this.getPoolLimits()]),r=t.map(async({keyArgs:i,value:n})=>{let[s]=i,[a,o]=n,[l,u,p,d]=await Promise.all([this.balance.getBalance(s,a),this.api.query.AssetRegistry.Assets.getValue(a),this.balance.getBalance(s,o),this.api.query.AssetRegistry.Assets.getValue(o)]);return{address:s,type:"XYK",tokens:[{id:a,decimals:u?.decimals||this.decimals.get(a),existentialDeposit:u?.existential_deposit,balance:l.transferable,type:u?.asset_type.type},{id:o,decimals:d?.decimals||this.decimals.get(o),existentialDeposit:d?.existential_deposit,balance:p.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 Ki.Subscription.EMPTY}};var Vr={};R(Vr,{AavePool:()=>Pe,AavePoolClient:()=>ve});var Ut=require("@galacticcouncil/common");var Pe=class c{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;static fromPool(t){return new c(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(s=>[s.id,s])),i=r.get(t),n=r.get(e);if(i==null)throw new Error("Pool does not contain tokenIn");if(n==null)throw new Error("Pool does not contain tokenOut");return{assetIn:t,assetOut:e,balanceIn:i.balance,balanceOut:n.balance,decimalsIn:i.decimals,decimalsOut:n.decimals,assetInEd:0n,assetOutEd:0n}}validateAndBuy(t,e,r){let i=this.calculateInGivenOut(t,e),n=[];return e>t.balanceOut&&n.push("TradeNotAllowed"),{amountIn:i,calculatedIn:i,amountOut:e,feePct:0,errors:n}}validateAndSell(t,e,r){let i=this.calculateOutGivenIn(t,e),n=[];return i>t.balanceOut&&n.push("TradeNotAllowed"),{amountIn:e,calculatedOut:i,amountOut:i,feePct:0,errors:n}}calculateInGivenOut(t,e){return e}calculateOutGivenIn(t,e){return e}spotPriceInGivenOut(t){return Ut.big.toBigInt(1,Ut.RUNTIME_DECIMALS)}spotPriceOutGivenIn(t){return Ut.big.toBigInt(1,Ut.RUNTIME_DECIMALS)}calculateTradeFee(t,e){return 0n}};var Qi=require("polkadot-api"),Ji=require("@polkadot-api/utils"),gt=require("rxjs"),Zi=require("viem"),ar=require("@galacticcouncil/common");var ji=[{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:ss}=ar.erc20,as=["Supply","Withdraw","Repay","Borrow"],ve=class extends j{getPoolType(){return"Aave"}async isSupported(){return!0}getPoolId(t,e){let r=t+"/"+e,i=new TextEncoder().encode(r.padEnd(32,"\0")),n=(0,Ji.toHex)(i);return(0,Qi.AccountId)(ar.HYDRATION_SS58_PREFIX).dec(n)}getPoolLimits(){return{maxInRatio:0n,maxOutRatio:0n,minTradingLimit:0n}}async loadPools(){let e=(await this.api.apis.AaveTradeExecutor.pools({at:"best"})).map(async({reserve:r,atoken:i,liqudity_in:n,liqudity_out:s})=>{let[a,o,l,u]=await Promise.all([this.api.query.AssetRegistry.Assets.getValue(r),this.api.query.AssetRegistry.AssetLocations.getValue(r),this.api.query.AssetRegistry.Assets.getValue(i),this.api.query.AssetRegistry.AssetLocations.getValue(i)]);return{address:this.getPoolId(r,i),type:"Aave",tokens:[{id:r,decimals:a?.decimals,existentialDeposit:a?.existential_deposit,balance:n,location:o,type:a?.asset_type.type},{id:i,decimals:l?.decimals,existentialDeposit:l?.existential_deposit,balance:s,location:u,type:l?.asset_type.type}],...this.getPoolLimits()}});return Promise.all(e)}async getPoolDelta(t){let[e,r]=t.tokens,{liqudity_in:i,liqudity_out:n}=await this.api.apis.AaveTradeExecutor.pool(e.id,r.id,{at:"best"});return t.tokens.map(s=>{let a=s.id===e.id?i:n;return{...s,balance:a}})}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.asHex()}throw new Error("Invalid aave reserve multilocation")}return ss.fromAssetId(t.id)}parseRouterLog(t){let{asset_in:e,asset_out:r}=t;return{assetIn:e,assetOut:r,key:`${e}:${r}`}}parseEvmLog(t){let{topics:e,data:r}=t.log,i=e.map(s=>s.asHex()),n=r.asHex();try{let{eventName:s,args:a}=(0,Zi.decodeEventLog)({abi:ji,topics:i,data:n}),o=a.reserve.toLowerCase();return{eventName:s,reserve:o,key:`${s}:${o}`}}catch{return}}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((0,gt.map)(({payload:r})=>this.parseRouterLog(r)),(0,gt.filter)(({assetIn:r,assetOut:i})=>e.includes(r)||e.includes(i)),this.watchGuard("router.Execute")).subscribe(({assetIn:r,assetOut:i,key:n})=>{this.log.trace("router.Executed",n),this.store.update(async s=>{let a=[];for(let o of s){let[l,u]=o.tokens;if(u.id===r||u.id===i){let d=await this.getPoolDelta(o);a.push({...o,tokens:d})}}return a})})}subscribeEvmLog(){return this.api.event.EVM.Log.watch().pipe((0,gt.map)(({payload:t})=>this.parseEvmLog(t)),(0,gt.filter)(t=>t!==void 0),(0,gt.filter)(({eventName:t})=>as.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 n of r){let[s]=n.tokens;if(this.getReserveH160Id(s).toLowerCase()===t){let o=await this.getPoolDelta(n);i.push({...n,tokens:o})}}return i})})}subscribeBalances(){return gt.Subscription.EMPTY}subscribeUpdates(){let t=new gt.Subscription;return t.add(this.subscribeRouterExecuted()),t.add(this.subscribeEvmLog()),t}};var Yr={};R(Yr,{HsmMath:()=>nt,HsmPool:()=>Se,HsmPoolClient:()=>Te});var $=require("@galacticcouncil/math-hsm"),nt=class{static calculateCollateralInGivenHollarOut(t,e,r){return(0,$.calculate_collateral_in_given_hollar_out)(t,e,r)}static calculateCollateralOutGivenHollarIn(t,e,r){return(0,$.calculate_collateral_out_given_hollar_in)(t,e,r)}static calculateHollarOutGivenCollateralIn(t,e,r){return(0,$.calculate_hollar_out_given_collateral_in)(t,e,r)}static calculateHollarInGivenCollateralOut(t,e,r){return(0,$.calculate_hollar_in_given_collateral_out)(t,e,r)}static calculateImbalance(t,e,r){return(0,$.calculate_imbalance)(t,e,r)}static calculateBuybackLimit(t,e){return(0,$.calculate_buyback_limit)(t,e)}static calculateBuybackPriceWithFee(t,e,r){return(0,$.calculate_buyback_price_with_fee)(t,e,r)}static calculateMaxPrice(t,e){return(0,$.calculate_max_price)(t,e)}};var ot=require("@galacticcouncil/common");var{FeeUtils:Vt}=_,Se=class c extends At{hsmAddress;hsmMintCapacity;hollarId;hollarH160;collateralId;collateralBalance;maxBuyPriceCoefficient;maxInHolding;purchaseFee;buyBackFee;buyBackRate;static fromPool(t){return new c(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,i){let n=this.calculateBuybackLimit(t);e>n&&i.push("MaxBuyBackExceeded");let s=this.calculateBuyPrice(t,e,r),a=this.calculateMaxPrice(t);return s>a&&i.push("MaxBuyPriceExceeded"),r>this.collateralBalance&&i.push("InsufficientCollateral"),i}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,r,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=nt.calculateHollarInGivenCollateralOut(e.toString(),r.toString(),Vt.toRaw(this.buyBackFee).toString());return BigInt(i)}calculateCollateralInGivenHollarOut(t){let e=this.getCollateralPeg(),r=nt.calculateCollateralInGivenHollarOut(t.toString(),JSON.stringify(e),Vt.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=nt.calculateCollateralOutGivenHollarIn(e.toString(),r.toString(),Vt.toRaw(this.buyBackFee).toString());return BigInt(i)}calculateHollarOutGivenCollateralIn(t){let e=this.getCollateralPeg(),r=nt.calculateHollarOutGivenCollateralIn(t.toString(),JSON.stringify(e),Vt.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=nt.calculateImbalance(t.balanceIn.toString(),JSON.stringify(e),t.balanceOut.toString());return BigInt(r)}calculateBuybackLimit(t){let e=this.calculateImbalance(t),r=nt.calculateBuybackLimit(e.toString(),Vt.toRaw(this.buyBackRate).toString());return BigInt(r)}calculateBuyPrice(t,e,r){let i=nt.calculateBuybackPriceWithFee(r.toString(),e.toString(),Vt.toRaw(this.buyBackFee).toString()),[n,s]=JSON.parse(i),a=ot.big.pow10(t.decimalsIn+ot.RUNTIME_DECIMALS-t.decimalsOut);return BigInt(n)*a/BigInt(s)}calculateMaxPrice(t){let e=this.getCollateralPeg(),r=nt.calculateMaxPrice(JSON.stringify(e),this.maxBuyPriceCoefficient.toString()),[i,n]=JSON.parse(r),s=ot.big.pow10(ot.RUNTIME_DECIMALS-t.decimalsOut);return BigInt(i)*s/BigInt(n)}spotPriceInGivenOut(t){let e=ot.big.toBigInt(1,t.decimalsOut);return this.normalizeSpotPrice(this.calculateInGivenOut(t,e),t.decimalsOut,t.decimalsIn)}spotPriceOutGivenIn(t){let e=ot.big.toBigInt(1,t.decimalsIn);return this.normalizeSpotPrice(this.calculateOutGivenIn(t,e),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)?[ot.big.toBigInt(1,18).toString(),ot.big.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 n=ot.big.pow10(Math.abs(i));return i>0?t*n:t/n}};var or=require("polkadot-api"),en=require("@polkadot-api/utils"),X=require("rxjs"),rn=require("viem"),lr=require("@galacticcouncil/common");var we=[{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 xe=class{client;constructor(t){this.client=t.getWsProvider()}async getFacilitatorCapacity(t,e){let[r,i]=await this.client.readContract({abi:we,address:t,functionName:"getFacilitatorBucket",args:[e]});return r-i}};var{FeeUtils:Wr}=_,{H160:tn}=lr.h160,os=["FacilitatorBucketCapacityUpdated","FacilitatorBucketLevelUpdated"],Te=class extends j{ghoClient;stableClient;constructor(t,e,r){super(t,e),this.stableClient=r,this.ghoClient=new xe(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.asHex()}}throw Error("Invalid hollar multilocation")}getPoolAddress(t){let e=t.padEnd(32,"\0"),r=new TextEncoder().encode(e),i=(0,en.toHex)(r);return(0,or.AccountId)(lr.HYDRATION_SS58_PREFIX).dec(i)}async isSupported(){let t=this.api.query.HSM.Collaterals,e=await this.api.compatibilityToken;return t.isCompatible(or.CompatibilityLevel.BackwardsCompatible,e)}async loadPools(){let t=await this.api.constants.HSM.HollarId(),[e,r,i]=await Promise.all([this.api.query.AssetRegistry.AssetLocations.getValue(t),this.api.query.HSM.Collaterals.getEntries({at:"best"}),this.stableClient.getPools()]);if(r.length===0)return[];let n=this.getFacilitatorAddress(),s=tn.fromAny(n),a=this.getHollarAddress(e),o=await this.ghoClient.getFacilitatorCapacity(a,s),l=r.map(async({keyArgs:p,value:d})=>{let[m]=p,{pool_id:h,max_buy_price_coefficient:b,max_in_holding:g,purchase_fee:f,buy_back_fee:y,buyback_rate:S}=d,v=i.find(T=>T.id===h);if(v){let T=this.getPoolId(h),A=await this.balance.getBalance(n,m);return{...v,address:T,type:"HSM",tokens:v.tokens.filter(L=>L.id!==h),hsmAddress:n,hsmMintCapacity:o,hollarId:t,hollarH160:a,collateralId:m,collateralBalance:A.transferable,maxBuyPriceCoefficient:b,maxInHolding:g,purchaseFee:Wr.fromPermill(f),buyBackFee:Wr.fromPermill(y),buyBackRate:Wr.fromPerbill(S)}}});return(await Promise.all(l)).filter(p=>p!==null)}async getPoolFees(){return{}}parseEvmLog(t){let{topics:e,data:r}=t.log,i=e.map(s=>s.asHex()),n=r.asHex();try{let{eventName:s,args:a}=(0,rn.decodeEventLog)({abi:we,topics:i,data:n}),o=a.facilitatorAddress.toLowerCase();return{eventName:s,facilitator:o,key:`${s}:${o}`}}catch{return}}subscribeEvmLog(){return this.api.event.EVM.Log.watch().pipe((0,X.map)(({payload:t})=>this.parseEvmLog(t)),(0,X.filter)(t=>t!==void 0),(0,X.filter)(({eventName:t})=>os.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:n,hollarH160:s}]=r,a=tn.fromAny(n);if(a.toLowerCase()===e){let l=await this.ghoClient.getFacilitatorCapacity(s,a);for(let u of r)i.push({...u,hsmMintCapacity:l})}return i})})}subscribeCollateralBalance(){let t=[],e=[];this.store.pools.forEach(n=>{let{tokens:s,collateralId:a}=n;s.find(l=>l.id===a).type==="Erc20"?e.push(a):t.push(a)});let[{hsmAddress:r}]=this.store.pools,i=[];if(t.length>0){let n=this.balance.watchTokensBalance(r);i.push(n)}if(e.length>0){let n=this.balance.watchErc20Balance(r,e);i.push(n)}return i.length>0?(0,X.combineLatest)(i).pipe((0,X.map)(n=>n.flat()),(0,X.pairwise)(),(0,X.map)(([n,s])=>this.balance.getDeltas(n,s)),this.watchGuard("balances")).subscribe(n=>{this.store.update(s=>{let a=[],o=new Map(s.map(l=>[l.collateralId,l]));return n.forEach(({id:l,balance:u})=>{let p=o.get(l);p&&(this.log.trace("balances",{id:l,balance:u}),a.push({...p,collateralBalance:u.transferable}))}),a})}):X.Subscription.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 n of r){let s=e.get(n.id);s&&i.push({...n,fee:s.fee,tokens:s.tokens.filter(a=>a.id!==n.id),totalIssuance:s.totalIssuance,pegs:s.pegs,amplification:s.amplification,isRampPeriod:s.isRampPeriod})}return i})})}subscribeBalances(){return X.Subscription.EMPTY}subscribeUpdates(){let t=new X.Subscription;return t.add(this.subscribeCollateralBalance()),t.add(this.subscribeStableswapUpdates()),t.add(this.subscribeEvmLog()),t}};var Wt=class{static get(t){switch(t.type){case"Aave":return Pe.fromPool(t);case"XYK":return ye.fromPool(t);case"Omnipool":return de.fromPool(t);case"LBP":return pe.fromPool(t);case"Stableswap":return At.fromPool(t);case"HSM":return Se.fromPool(t);default:throw new Error("Pool type "+t.type+" is not supported yet")}}};var nn=require("@galacticcouncil/common"),lt=require("rxjs");var{logger:ls}=nn.log,Yt=class extends D{evm;aave;omnipool;stableswap;hsm;xyk;lbp;active=new Set([]);pools=new Map([]);clients=[];aaveSub=lt.Subscription.EMPTY;omniSub=lt.Subscription.EMPTY;stableSub=lt.Subscription.EMPTY;hsmSub=lt.Subscription.EMPTY;xykSub=lt.Subscription.EMPTY;lbpSub=lt.Subscription.EMPTY;isReady=!1;isDestroyed=new lt.Subject;constructor(t,e){super(t),this.evm=e,this.aave=new ve(t,e),this.omnipool=new ge(t,e),this.stableswap=new be(t,e),this.hsm=new Te(t,e,this.stableswap),this.xyk=new fe(t,e),this.lbp=new me(t,e),this.clients=[this.aave,this.omnipool,this.stableswap,this.hsm,this.xyk,this.lbp]}subscribe(t){return t.getSubscriber().pipe((0,lt.takeUntil)(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")||(ls.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 re(e.type)}};var Zr={};R(Zr,{DCA_TIME_RESERVE:()=>on,DEFAULT_BLOCK_TIME:()=>an,DEFAULT_MIN_BUDGET:()=>Kr,ORDER_MIN_BLOCK_PERIOD:()=>ln,Router:()=>zt,TWAP_EXECUTION_INTERVAL:()=>Ae,TWAP_MAX_DURATION:()=>Qr,TWAP_MAX_PRICE_IMPACT:()=>jr,TWAP_TX_MULTIPLIER:()=>Kp,TradeOrderError:()=>Xr,TradeOrderType:()=>ur,TradeRouteBuilder:()=>tt,TradeRouter:()=>xt,TradeScheduler:()=>$t,TradeType:()=>cr});var Ie=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 cs=10,_e=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=[],n=new Ie,s=[];for(s.push([e,""]),n.enqueue(s);n.size()>0;){let a=n.dequeue();if(!a||a.length>cs)continue;let o=a[a.length-1];(r===null||o[0]===r)&&i.push(a),t.get(o[0])?.forEach(u=>{if(this.isNotVisited(u,a)){let p=[...a];p.push(u),n.enqueue(p)}})}return i}findShortestPaths(t,e,r){let i=[],n=new Ie,s=[];s.push([e,""]),n.enqueue(s);let a=1/0;for(;n.size()>0;){let o=n.dequeue();if(!o)continue;let l=o[o.length-1];if(l[0]===r){o.length<a?(a=o.length,i.length=0,i.push(o)):o.length===a&&i.push(o);continue}let u=t.get(l[0]);for(let p of u??[])this.isNotVisited(p,o)&&n.enqueue([...o,p])}return i}buildAndPopulateGraph(t,e){let r=new Map;for(let i of t)r.set(parseInt(i),[]);for(let[i,n,s]of e)r.get(n)?.push([s,i]);return r}};function $r(c){let t={};for(let e of c){let r=e.tokens.length;for(let i=0;i<r;i++){t[e.tokens[i].id]||(t[e.tokens[i].id]=[]);for(let n=0;n<r;n++){if(i==n)continue;let s=[e.address,e.tokens[i].id,e.tokens[n].id];t[e.tokens[i].id].push(s)}}}return t}var Oe=class{getProposals(t,e,r){let i=r.filter(g=>g.type==="XYK"),n=r.filter(g=>g.type!=="XYK"),s=new Set(n.map(g=>g.tokens).flat().map(g=>g.id)),a=s.has(t),o=s.has(e),l=new _e,u=g=>{let f=$r(g),y=Object.keys(f),S=y.flatMap(v=>f[v]);return l.buildAndPopulateGraph(y,S)};if(!a&&!o){let g=i.filter(S=>S.tokens.find(v=>v.id===t)||S.tokens.find(v=>v.id===e)),f=u(g),y=l.findPaths(f,t,e);return this.parsePaths(y)}if(a&&o){let g=u(n),f=l.findPaths(g,t,e);return this.parsePaths(f)}let p=a?e:t,d=i.filter(g=>g.tokens.some(f=>f.id===p));if(d.length===0)return[];let m=[...n,...d],h=u(m),b=l.findPaths(h,t,e);return this.parsePaths(b)}parsePaths(t){let e=[];for(let r of t){let i=[];for(let n=0;n<r.length;n++){let s=r[n],a=r[n+1];if(a==null)break;i.push(this.toEdge(s,a))}e.push(i)}return e}toEdge(t,e){return[e[1],t[0],e[0]]}};var zt=class{routeSuggester;routeProposals;ctx;filter={};constructor(t){this.ctx=t,this.routeSuggester=new Oe,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),n=new Set(r);return t.filter(s=>n.has(s.type)?!1:i.size>0?i.has(s.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(s=>this.validPath(s,i)).map(s=>this.toHops(s,i))}getProposals(t,e,r){let i=this.buildRouteKey(t,e,r);if(this.routeProposals.has(i))return this.routeProposals.get(i);let n=this.routeSuggester.getProposals(t,e,r);return this.routeProposals.set(i,n),n}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,Wt.get(e)]))}toHops(t,e){return t.map(([r,i,n])=>{let s=e.get(r);return{poolAddress:r,poolId:s?.id,pool:s?.type,assetIn:i,assetOut:n}})}};var I=require("@galacticcouncil/common");var cr=(e=>(e.Buy="Buy",e.Sell="Sell",e))(cr||{}),ur=(r=>(r.Dca="Dca",r.TwapSell="TwapSell",r.TwapBuy="TwapBuy",r))(ur||{}),Xr=(r=>(r.OrderTooSmall="OrderTooSmall",r.OrderTooBig="OrderTooBig",r.OrderImpactTooBig="OrderImpactTooBig",r))(Xr||{});var{FeeUtils:sn}=_,xt=class extends zt{mlr;constructor(t){super(t),this.mlr=new Map}onFilterChanged(){this.mlr.clear()}buildCtxSync(t,e,r){let i=super.validateInput(t,e,r),n=super.getPaths(t,e,r);if(!n.length)throw new ie(t,e);return{paths:n,pools:r,poolsMap:i}}async withCtx(t,e,r){let i=await super.getPools(),n=this.buildCtxSync(t,e,i);return r(n)}isDirectTrade(t){return t.length==1}findBestSellRoute(t){let e=t.sort((r,i)=>{let n=r[r.length-1].amountOut,s=i[i.length-1].amountOut;return n>s?-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(n=>n.tradeFeeRange?.[0]??n.tradeFeePct).reduce((n,s)=>n+s),i=t.map(n=>n.tradeFeeRange?.[1]??n.tradeFeePct).reduce((n,s)=>n+s);return[r,i]}}getPoolFeeRange(t){let e=t.min?sn.toPct(t.min):void 0,r=t.max?sn.toPct(t.max):void 0;if(e&&r)return[e,r]}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:n,poolsMap:s})=>{let a;if(i)a=await this.toSellSwaps(r,i,s);else{let o=n.map(u=>this.toSellSwaps(r,u,s)),l=await Promise.all(o);a=this.findBestSellRoute(l)}return this.buildSell(s,a)})}async getSells(t,e,r){return this.withCtx(t,e,async({paths:i,poolsMap:n})=>{let s=i.map(o=>this.toSellSwaps(r,o,n));return(await Promise.all(s)).filter(o=>o.every(l=>l.errors.length==0)).map(o=>this.buildSell(n,o)).sort((o,l)=>o.amountOut>l.amountOut?-1:1)})}buildSell(t,e){let r=e[0],i=e[e.length-1],n=this.isDirectTrade(e),s=this.getSellSpot(e),a=i.amountOut,o=n?i.calculatedOut:this.calculateDelta0Y(r.amountIn,e,t),l=o-a,u=this.getRouteFeeRange(e),p=n?i.tradeFeePct:W.calculateSellFee(o,a),d=H.mulSpot(r.amountIn,s,r.assetInDecimals,i.assetOutDecimals),m=W.calculateDiffToRef(o,d);return{type:"Sell",amountIn:r.amountIn,amountOut:i.amountOut,spotPrice:s,tradeFee:l,tradeFeePct:p,tradeFeeRange:u,priceImpactPct:m,swaps:e,toHuman(){return{type:"Sell",amountIn:I.big.toDecimal(r.amountIn,r.assetInDecimals),amountOut:I.big.toDecimal(i.amountOut,i.assetOutDecimals),spotPrice:I.big.toDecimal(s,I.RUNTIME_DECIMALS),tradeFee:I.big.toDecimal(l,i.assetOutDecimals),tradeFeePct:p,tradeFeeRange:u,priceImpactPct:m,swaps:e.map(h=>h.toHuman())}}}}calculateSpot(t){return t.map(e=>e.spotPrice).reduce((e,r)=>e*r/10n**BigInt(I.RUNTIME_DECIMALS))}calculateDelta0Y(t,e,r){let i=[];for(let n=0;n<e.length;n++){let s=e[n],a=r.get(s.poolAddress);if(a==null)throw new Error("Pool does not exit");let o=a.parsePair(s.assetIn,s.assetOut),l;n>0?l=i[n-1]:l=t;let u=a.calculateOutGivenIn(o,l);i.push(u)}return i[i.length-1]}async calculateMostLiquidRoute(t,e,r){let{paths:i,pools:n,poolsMap:s}=r,l=n.filter(b=>b.tokens.some(g=>g.id===t)).map(b=>b.type==="Aave"?b.tokens:b.tokens.filter(g=>g.id===t)).map(b=>b.map(g=>g.balance).reduce((g,f)=>g+f)).sort((b,g)=>g<b?-1:1)[0],u=H.getFraction(l,.1),p=await Promise.all(i.map(b=>this.toSellSwaps(u,b,s))),m=this.findBestSellRoute(p).map(b=>({poolAddress:b.poolAddress,poolId:b?.poolId,pool:b.pool,assetIn:b.assetIn,assetOut:b.assetOut})),h=this.buildRouteKey(t,e,n);return this.mlr.set(h,m),m}async toSellSwaps(t,e,r){let i=[];for(let n=0;n<e.length;n++){let s=e[n],a=r.get(s.poolAddress);if(a==null)throw new Error("Pool does not exit");let o=a.parsePair(s.assetIn,s.assetOut),l;n>0?l=i[n-1].amountOut:l=typeof t=="string"?I.big.toBigInt(t,o.decimalsIn):t;let u=await this.ctx.getPoolFees(o,a),{amountOut:p,calculatedOut:d,feePct:m,errors:h}=a.validateAndSell(o,l,u),b=this.getPoolFeeRange(u),g=a.spotPriceOutGivenIn(o),f=H.mulSpot(l,g,o.decimalsIn,o.decimalsOut),y=W.calculateDiffToRef(d,f);i.push({...s,assetInDecimals:o.decimalsIn,assetOutDecimals:o.decimalsOut,amountIn:l,amountOut:p,calculatedOut:d,spotPrice:g,tradeFeePct:m,tradeFeeRange:b,priceImpactPct:y,errors:h,isSupply(){return a.type==="Aave"&&a.tokens[0].id===s.assetIn},isWithdraw(){return a.type==="Aave"&&a.tokens[1].id===s.assetIn},toHuman(){return{...s,amountIn:I.big.toDecimal(l,o.decimalsIn),amountOut:I.big.toDecimal(p,o.decimalsOut),calculatedOut:I.big.toDecimal(d,o.decimalsOut),spotPrice:I.big.toDecimal(g,I.RUNTIME_DECIMALS),tradeFeePct:m,tradeFeeRange:b,priceImpactPct:y,errors:h}}})}return i}async getMostLiquidRoute(t,e){return this.withCtx(t,e,async r=>{let i=this.buildRouteKey(t,e,r.pools),n=this.mlr.get(i);return n||this.calculateMostLiquidRoute(t,e,r)})}async getSpotPrice(t,e){return this.withCtx(t,e,async r=>{let{pools:i,poolsMap:n}=r,s=this.buildRouteKey(t,e,i),a=this.mlr.get(s);a||(a=await this.calculateMostLiquidRoute(t,e,r));let o=await this.toSellSwaps("1",a,n);return{amount:this.getSellSpot(o),decimals:I.RUNTIME_DECIMALS}}).catch(()=>{})}findBestBuyRoute(t){let e=t.sort((r,i)=>{let n=r[0].amountIn,s=i[0].amountIn;return n>s?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:n,poolsMap:s})=>{let a;if(i)a=await this.toBuySwaps(r,i,s);else{let o=n.map(u=>this.toBuySwaps(r,u,s)),l=await Promise.all(o);a=this.findBestBuyRoute(l)}return this.buildBuy(s,a)})}async getBuys(t,e,r){return this.withCtx(t,e,async({paths:i,poolsMap:n})=>{let s=i.map(o=>this.toBuySwaps(r,o,n));return(await Promise.all(s)).filter(o=>o.every(l=>l.errors.length==0)).map(o=>this.buildBuy(n,o)).sort((o,l)=>o.amountIn>l.amountIn?1:-1)})}buildBuy(t,e){let r=e[e.length-1],i=e[0],n=this.isDirectTrade(e),s=this.getBuySpot(e),a=i.amountIn,o=n?i.calculatedIn:this.calculateDelta0X(r.amountOut,e,t),l=a-o,u=this.getRouteFeeRange(e),p=n?i.tradeFeePct:W.calculateBuyFee(o,a),d=H.mulSpot(r.amountOut,s,r.assetOutDecimals,i.assetInDecimals),m;return o===0n?m=-100:m=W.calculateDiffToRef(d,o),{type:"Buy",amountOut:r.amountOut,amountIn:i.amountIn,spotPrice:s,tradeFee:l,tradeFeePct:p,tradeFeeRange:u,priceImpactPct:m,swaps:e,toHuman(){return{type:"Buy",amountOut:I.big.toDecimal(r.amountOut,r.assetOutDecimals),amountIn:I.big.toDecimal(i.amountIn,i.assetInDecimals),spotPrice:I.big.toDecimal(s,I.RUNTIME_DECIMALS),tradeFee:I.big.toDecimal(l,i.assetInDecimals),tradeFeePct:p,tradeFeeRange:u,priceImpactPct:m,swaps:e.map(h=>h.toHuman())}}}}calculateDelta0X(t,e,r){let i=[];for(let n=e.length-1;n>=0;n--){let s=e[n],a=r.get(s.poolAddress);if(a==null)throw new Error("Pool does not exit");let o=a.parsePair(s.assetIn,s.assetOut),l;n==e.length-1?l=t:l=i[0];let u=a.calculateInGivenOut(o,l);i.unshift(u)}return i[0]}async toBuySwaps(t,e,r){let i=[];for(let n=e.length-1;n>=0;n--){let s=e[n],a=r.get(s.poolAddress);if(a==null)throw new Error("Pool does not exit");let o=a.parsePair(s.assetIn,s.assetOut),l;n==e.length-1?l=typeof t=="string"?I.big.toBigInt(t,o.decimalsOut):t:l=i[0].amountIn;let u=await this.ctx.getPoolFees(o,a),{amountIn:p,calculatedIn:d,feePct:m,errors:h}=a.validateAndBuy(o,l,u),b=this.getPoolFeeRange(u),g=a.spotPriceInGivenOut(o),f=H.mulSpot(l,g,o.decimalsOut,o.decimalsIn),y;d===0n?y=-100:y=W.calculateDiffToRef(f,d),i.unshift({...s,assetInDecimals:o.decimalsIn,assetOutDecimals:o.decimalsOut,amountOut:l,amountIn:p,calculatedIn:d,spotPrice:g,tradeFeePct:m,tradeFeeRange:b,priceImpactPct:y,errors:h,isSupply(){return a.type==="Aave"&&a.tokens[0].id===s.assetIn},isWithdraw(){return a.type==="Aave"&&a.tokens[1].id===s.assetIn},toHuman(){return{...s,amountOut:I.big.toDecimal(l,o.decimalsOut),amountIn:I.big.toDecimal(p,o.decimalsIn),calculatedIn:I.big.toDecimal(d,o.decimalsIn),spotPrice:I.big.toDecimal(g,I.RUNTIME_DECIMALS),tradeFeePct:m,tradeFeeRange:b,priceImpactPct:y,errors:h}}})}return i}};var U=require("@galacticcouncil/common");var an=6e3,Kr=1000000000000000n,Ae=6,jr=-5,Qr=216e5,Kp=3,on=.1,ln=6;var Jr=require("polkadot-api");var tt=class{static build(t){return t.map(({assetIn:e,assetOut:r,pool:i,poolId:n})=>i==="Stableswap"?{pool:(0,Jr.Enum)("Stableswap",n),asset_in:e,asset_out:r}:{pool:(0,Jr.Enum)(i),asset_in:e,asset_out:r})}};var $t=class{schedulerOptions;router;constructor(t,e={}){this.router=new xt(t),this.router.withFilter({exclude:["HSM"]}),this.schedulerOptions=Object.freeze({blockTime:e.blockTime??6e3,minBudgetInNative:e.minBudgetInNative??Kr})}get blockTime(){return this.schedulerOptions.blockTime}get minOrderBudget(){return this.schedulerOptions.minBudgetInNative}async getDcaOrder(t,e,r,i,n){let s=await this.router.getBestSell(t,e,r),{amountIn:a,swaps:o,priceImpactPct:l}=s,u=o[0],p=o[o.length-1],{assetInDecimals:d}=u,{assetOutDecimals:m}=p,h=Math.abs(l),b=await this.getMinimumOrderBudget(t,d),g=this.getOptimalTradeCount(h),f=this.getMaximumTradeCount(a,b,i),y=n||Math.min(g,f),S=Math.round(i/y),v=a/BigInt(y),T=await this.router.getBestSell(t,e,v),A=a<b,L=[];A&&L.push("OrderTooSmall");let V=T.amountOut*BigInt(y),ct=this.toBlockPeriod(S),ht=T.tradeFee*BigInt(y),Q=tt.build(o),rt={assetIn:t,assetOut:e,errors:L,maxTradeCount:f,tradeCount:y,tradeFee:ht,tradeImpactPct:T.priceImpactPct,tradePeriod:ct,tradeRoute:Q,type:"Dca"};return{...rt,amountIn:a,amountOut:V,tradeAmountIn:T.amountIn,tradeAmountOut:T.amountOut,toHuman(){return{...rt,amountIn:U.big.toDecimal(a,d),amountOut:U.big.toDecimal(V,m),tradeAmountIn:U.big.toDecimal(T.amountIn,d),tradeAmountOut:U.big.toDecimal(T.amountOut,m)}}}}async getMinimumOrderBudget(t,e){if(0===t)return this.minOrderBudget;let r=await this.router.getSpotPrice(0,t);if(r)return H.mulSpot(this.minOrderBudget,r.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 n=Number(t/i),s=Math.floor(r/this.blockTime),a=Math.max(0,Math.floor(s*(1-.1)));return Math.min(n,a)}getOptimalTradeCount(t){let e=Math.round(t*10)||1;return Math.max(e,3)}async getOpenBudgetDcaOrder(t,e,r,i){let n=await this.router.getBestSell(t,e,r),{swaps:s}=n,a=s[0],o=s[s.length-1],{assetInDecimals:l}=a,{assetOutDecimals:u}=o,p=await this.getMinimumOrderBudget(t,l),d=n.amountIn<p,m=[];d&&m.push("OrderTooSmall");let h=this.toBlockPeriod(i),b=tt.build(s),g={assetIn:t,assetOut:e,errors:m,maxTradeCount:0,tradeCount:0,tradeFee:n.tradeFee,tradeImpactPct:n.priceImpactPct,tradePeriod:h,tradeRoute:b,type:"Dca"};return{...g,amountIn:0n,amountOut:0n,tradeAmountIn:n.amountIn,tradeAmountOut:n.amountOut,toHuman(){return{...g,amountIn:"0",amountOut:"0",tradeAmountIn:U.big.toDecimal(n.amountIn,l),tradeAmountOut:U.big.toDecimal(n.amountOut,u)}}}}async getTwapSellOrder(t,e,r){let i=await this.router.getBestSell(t,e,r),{amountIn:n,swaps:s,priceImpactPct:a}=i,o=s[0],l=s[s.length-1],{assetInDecimals:u}=o,{assetOutDecimals:p}=l,d=Math.abs(a),m=this.getTwapTradeCount(d),h=n/BigInt(m),[b,g]=await Promise.all([this.getMinimumOrderBudget(t,u),this.router.getBestSell(o.assetIn,l.assetOut,h)]),f=m===1,y=n<b,S=g.priceImpactPct<-5,v=[];y||f?v.push("OrderTooSmall"):S&&v.push("OrderImpactTooBig");let T=g.amountOut*BigInt(m),A=g.tradeFee*BigInt(m),L=tt.build(s),V={assetIn:t,assetOut:e,errors:v,tradeCount:m,tradeImpactPct:g.priceImpactPct,tradePeriod:6,tradeRoute:L,type:"TwapSell"};return{...V,amountIn:n,amountOut:T,tradeAmountIn:g.amountIn,tradeAmountOut:g.amountOut,tradeFee:A,toHuman(){return{...V,amountIn:U.big.toDecimal(n,u),amountOut:U.big.toDecimal(T,p),tradeAmountIn:U.big.toDecimal(g.amountIn,u),tradeAmountOut:U.big.toDecimal(g.amountOut,p),tradeFee:U.big.toDecimal(A,p)}}}}async getTwapBuyOrder(t,e,r){let i=await this.router.getBestBuy(t,e,r),{amountOut:n,swaps:s,priceImpactPct:a}=i,o=s[0],l=s[s.length-1],{assetInDecimals:u}=o,{assetOutDecimals:p}=l,d=Math.abs(a),m=this.getTwapTradeCount(d),h=n/BigInt(m),[b,g]=await Promise.all([this.getMinimumOrderBudget(t,u),this.router.getBestBuy(o.assetIn,l.assetOut,h)]),f=g.amountIn*BigInt(m),y=m===1,S=f<b,v=g.priceImpactPct<-5,T=[];S||y?T.push("OrderTooSmall"):v&&T.push("OrderImpactTooBig");let A=g.tradeFee*BigInt(m),L=tt.build(s),V={assetIn:t,assetOut:e,errors:T,tradeCount:m,tradeImpactPct:g.priceImpactPct,tradePeriod:6,tradeRoute:L,type:"TwapBuy"};return{...V,amountIn:f,amountOut:n,tradeAmountIn:g.amountIn,tradeAmountOut:g.amountOut,tradeFee:A,toHuman(){return{...V,amountIn:U.big.toDecimal(f,u),amountOut:U.big.toDecimal(n,p),tradeAmountIn:U.big.toDecimal(g.amountIn,u),tradeAmountOut:U.big.toDecimal(g.amountOut,p),tradeFee:U.big.toDecimal(A,u)}}}}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)}};var ei={};R(ei,{BIG_10:()=>gn,BIG_BILL:()=>ti,StakingApi:()=>Be,StakingClient:()=>Re});var K=require("@galacticcouncil/math-staking"),et=ft(require("big.js"));var pr={none:.1,locked1x:1,locked2x:2,locked3x:3,locked4x:4,locked5x:5,locked6x:6},cn=c=>Object.keys(pr).includes(c);var un=require("polkadot-api"),pn=require("@polkadot-api/utils"),mn=require("@galacticcouncil/common");function dn(c){let t=("modl"+c).padEnd(32,"\0"),e=new TextEncoder().encode(t),r=(0,pn.toHex)(e);return(0,un.AccountId)(mn.HYDRATION_SS58_PREFIX).dec(r)}var mr="20000000000000000",dr="2000",gn=(0,et.default)(10),ti=(0,et.default)(gn.pow(12)),Be=class{client;balance;constructor(t,e){this.client=t,this.balance=e}async getPotBalance(){let t=await this.client.getPalletId(),e=dn(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,n=await r.reduce(async(s,[a,o])=>{let l=await s,u=a,p=o.amount,d=o.conviction.type.toLowerCase(),m=await this.client.getReferendumInfo(u);return m&&(m.type==="Approved"||m.type==="Rejected")&&cn(d)&&l.push({id:u,amount:p,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:n}}async getStake(t){let e=await this.client.getNFTCollectionId(),[r,i]=await Promise.all([this.client.getStaking(),this.client.getUniques(t,e)]),n=i.find(s=>s)?.itemId;return{totalStake:r?.total_stake,accumulatedRewardPerStake:r?.accumulated_reward_per_stake,potReservedBalance:r?.pot_reserved_balance,positionId:n,stakePosition:n?await this.getStakingPosition(n):void 0}}getCurrentActionPoints(t,e,r,i){let n=(0,et.default)(0),s=(0,et.default)(0),a=pr.locked6x,o=(0,et.default)(r.toString()).mul(a),l=100,u=[];t.forEach(m=>{let h=pr[m.conviction],b=i.includes(m.id.toString());b&&u.push(m.id.toString());let g=(0,et.default)(m.amount.toString()).mul(l).div(o);n=n.plus(Math.floor(g.mul(h).toNumber())),s=s.plus(Math.floor(g.mul(b?a:h).toNumber()))});let p=Math.floor((0,et.default)(r.toString()).mul(a).mul(l).div(o).toNumber());i.forEach(m=>{u.includes(m)||(s=s.plus(p))});let d={democracyVote:1};return n=n.mul(d.democracyVote),n=n.plus(e.toString()||"0"),s=s.mul(d.democracyVote),s=s.plus(e.toString()||"0"),{currentActionPoints:n.toString(),maxActionPoints:s.toString()}}async getRewards(t,e,r){let i=await this.getStake(t),{potReservedBalance:n,accumulatedRewardPerStake:s,totalStake:a,stakePosition:o}=i;if(!o)return;let[l,u,p,d,m,h,b]=await Promise.all([this.getPotBalance(),this.client.getPeriodLength(),this.client.getUnclaimablePeriods(),this.client.getTimePointsPerPeriod(),this.client.getTimePointsWeight(),this.client.getActionPointsWeight(),this.client.getSixBlockSince()]),g=(0,et.default)(l.transferable.toString()).minus(n.toString()),f=g.gt(0)&&a>0?(0,K.calculate_accumulated_rps)(s.toString(),g.toString(),a.toString()):s.toString(),y=(0,K.calculate_period_number)(u.toString(),r,b),S=(0,K.calculate_period_number)(u.toString(),o.createdAt.toString(),b),v=(0,K.calculate_rewards)(f,o.rewardPerStake.toString(),o.stake.toString()),T=this.getCurrentActionPoints(o.votes,o.actionPoints,o.stake,e),A=(0,K.calculate_points)(S,y,d.toString(),m.toString(),T.currentActionPoints,h.toString(),o.accumulatedSlashPoints.toString()),L=(0,K.sigmoid)(A,mr,dr),V=(()=>{if(!e.length)return;let jt=(0,K.calculate_points)(S,y,d.toString(),m.toString(),T.maxActionPoints.toString(),h.toString(),o.accumulatedSlashPoints.toString());return(0,K.sigmoid)(jt,mr,dr)})(),ct=(0,et.default)(v).plus(o.accumulatedUnpaidRewards.toString()).plus(o.accumulatedLockedRewards.toString());if((0,et.default)(y).minus(S).lte(p.toString()))return{rewards:"0",payablePercentage:L,extraPayablePercentage:V,constants:{a:mr,b:dr}};let ht=(0,K.calculate_percentage_amount)(ct.toString(),L),Q=(0,et.default)(o.accumulatedLockedRewards.toString()),rt=Q.gt(ht)?Q:(0,et.default)(ht);return{rewards:rt.div(ti).toString(),maxRewards:ct.div(ti).toString(),allocatedRewardsPercentage:rt.div(ct).mul(100).toNumber(),points:A,payablePercentage:L,extraPayablePercentage:V,constants:{a:mr,b:dr}}}};var Re=class extends D{async getPalletId(){let t=this.api.constants.Staking.PalletId;return(await t()).asText()}async getPeriodLength(){let t=this.api.constants.Staking.PeriodLength;return await t()}async getUnclaimablePeriods(){let t=this.api.constants.Staking.UnclaimablePeriods;return await t()}async getNFTCollectionId(){let t=this.api.constants.Staking.NFTCollectionId;return await t()}async getStaking(){return await this.api.query.Staking.Staking.getValue()}async getUniques(t,e){return(await this.api.query.Uniques.Account.getEntries(t,e)).map(({keyArgs:s})=>{let[a,o,l]=s;return{address:a,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 ii={};R(ii,{TxBuilderFactory:()=>Kt});var ri=require("polkadot-api");function hn(c){let t=[],e=c;for(;e&&typeof e=="object"&&"type"in e;)t.push(e.type),e=e.value;return t.join(".")}var Xt=class extends D{evm;evmClient;balance;aaveUtils;constructor(t,e){super(t),this.evm=e,this.evmClient=e.getWsProvider(),this.balance=new ut(t),this.aaveUtils=new Tt(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:Sr})}async dryRun(t,e){let r=(0,ri.Enum)("Signed",t),i=(0,ri.Enum)("system",r),s=await this.client.getUnsafeApi().apis.DryRunApi.dry_run_call(i,e.decodedCall),a=s.success&&!s.value.execution_result.success?s.value.execution_result.value.error:null;if(a){let o=hn(a.value);throw new Error("Dry run execution error!",{cause:o})}return s}isDirectOmnipoolTrade(t){return t.length===1&&t[0].pool==="Omnipool"}};var gr=class extends Xt{_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],n=await this.balance.getBalance(this.beneficiary,i);return t>=n.transferable-5n?this.buildSellAllTx():this.buildSellTx()}async buildBuyTx(){let{amountIn:t,amountOut:e,swaps:r}=this.trade,i=r[0],n=r[r.length-1],s=H.getFraction(t,this.slippagePct),a=i.assetIn,o=n.assetOut,l=t+s,u;return this.isDirectOmnipoolTrade(r)?u=this.api.tx.Omnipool.buy({asset_in:a,asset_out:o,amount:e,max_sell_amount:l}):u=this.api.tx.Router.buy({asset_in:a,asset_out:o,amount_out:e,max_amount_in:l,route:tt.build(r)}),await this.aaveUtils.hasBorrowPositions(this.beneficiary)&&(u=await this.dispatchWithExtraGas(u)),this.wrapTx("RouterBuy",u)}async buildSellTx(){let{amountIn:t,amountOut:e,swaps:r}=this.trade,i=r[0],n=r[r.length-1],s=H.getFraction(e,this.slippagePct),a=i.assetIn,o=n.assetOut,l=e-s,u;return this.isDirectOmnipoolTrade(r)?u=this.api.tx.Omnipool.sell({asset_in:a,asset_out:o,amount:t,min_buy_amount:l}):u=this.api.tx.Router.sell({asset_in:a,asset_out:o,amount_in:t,min_amount_out:l,route:tt.build(r)}),await this.aaveUtils.hasBorrowPositions(this.beneficiary)&&(u=await this.dispatchWithExtraGas(u)),this.wrapTx("RouterSell",u)}async buildSellAllTx(){let{amountOut:t,swaps:e}=this.trade,r=e[0],i=e[e.length-1],n=H.getFraction(t,this.slippagePct),s=r.assetIn,a=i.assetOut,o=t-n,l=this.api.tx.Router.sell_all({asset_in:s,asset_out:a,min_amount_out:o,route:tt.build(e)});return await this.aaveUtils.hasBorrowPositions(this.beneficiary)&&(l=await this.dispatchWithExtraGas(l)),this.wrapTx("RouterSellAll",l)}};var hr=require("polkadot-api");var br=class extends Xt{_order;_beneficiary;_maxRetries=3;_slippagePct=1;setOrder(t){return this._order=t,this}withBeneficiary(t){return this._beneficiary=t,this}withMaxRetries(t){return this._maxRetries=t,this}withSlippage(t){return this._slippagePct=t,this}get order(){if(!this._order)throw new Error("Order not set. Use setOrder().");return this._order}get beneficiary(){if(!this._beneficiary)throw new Error("Beneficiary not set. Use withBeneficiary().");return this._beneficiary}get maxRetries(){return this._maxRetries}get slippagePct(){return this._slippagePct}async build(){let{type:t}=this.order;switch(t){case"Dca":return this.buildDcaTx();case"TwapSell":return this.buildTwapSellTx();case"TwapBuy":return this.buildTwapBuyTx();default:throw new Error(`Unsupported TradeOrderType: ${t}`)}}buildDcaTx(){let{amountIn:t,assetIn:e,assetOut:r,tradeAmountIn:i,tradePeriod:n,tradeRoute:s}=this.order,a=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:(0,hr.Enum)("Sell",{asset_in:e,asset_out:r,amount_in:i,min_amount_out:0n,route:s})},start_execution_block:void 0});return this.wrapTx("DcaSchedule",a)}buildTwapSellTx(){let{amountIn:t,assetIn:e,assetOut:r,tradeAmountIn:i,tradeAmountOut:n,tradePeriod:s,tradeRoute:a}=this.order,o=H.getFraction(n,this.slippagePct),l=n-o,u=this.api.tx.DCA.schedule({schedule:{owner:this.beneficiary,period:s,max_retries:this.maxRetries,total_amount:t,slippage:this.slippagePct*1e4,stability_threshold:void 0,order:(0,hr.Enum)("Sell",{asset_in:e,asset_out:r,amount_in:i,min_amount_out:l,route:a})},start_execution_block:void 0});return this.wrapTx("DcaSchedule.twapSell",u)}buildTwapBuyTx(){let{amountIn:t,assetIn:e,assetOut:r,tradeAmountIn:i,tradeAmountOut:n,tradePeriod:s,tradeRoute:a}=this.order,o=H.getFraction(i,this.slippagePct),l=i+o,u=this.api.tx.DCA.schedule({schedule:{owner:this.beneficiary,period:s,max_retries:this.maxRetries,total_amount:t,slippage:this.slippagePct*1e4,stability_threshold:void 0,order:(0,hr.Enum)("Buy",{asset_in:e,asset_out:r,amount_out:n,max_amount_in:l,route:a})},start_execution_block:void 0});return this.wrapTx("DcaSchedule.twapBuy",u)}};var Kt=class{client;evmClient;constructor(t,e){this.client=t,this.evmClient=e}trade(t){return new gr(this.client,this.evmClient).setTrade(t)}order(t){return new br(this.client,this.evmClient).setOrder(t)}};async function us(c){let t=new Mt(c),e=new se(c),[r,i]=await Promise.all([t.getBlockTime(),t.getMinOrderBudget()]),n=new Yt(c,e).withAave().withOmnipool().withStableswap().withHsm().withXyk(),s=new ut(c),a=new Re(c),o=new ue(c),l=new Tt(e),u=new xt(n),p=new $t(n,{blockTime:r,minBudgetInNative:i}),d=new Be(a,s),m=new ce(o,s,{blockTime:r});return{api:{aave:l,router:u,scheduler:p,staking:d,farm:m},client:{asset:new Ft(c),balance:s,evm:e},ctx:{pool:n},tx:new Kt(c,e),destroy:()=>{n.destroy()}}}0&&(module.exports={QueryBus,aave,api,async,calc,client,const:null,createSdkContext,error,evm,farm,fmt,json,math,pool,sor,staking,tx});