@galacticcouncil/sdk-next 1.1.0 → 1.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (60) hide show
  1. package/build/aave/AaveLog.d.ts +4 -0
  2. package/build/aave/index.cjs +1 -1
  3. package/build/aave/index.d.ts +2 -0
  4. package/build/aave/index.mjs +1 -1
  5. package/build/aave/types.d.ts +7 -0
  6. package/build/api/Papi.d.ts +2 -1
  7. package/build/client/index.cjs +1 -1
  8. package/build/client/index.mjs +1 -1
  9. package/build/evm/adapter.d.ts +3 -1
  10. package/build/evm/client.d.ts +3 -1
  11. package/build/evm/index.cjs +1 -1
  12. package/build/evm/index.mjs +1 -1
  13. package/build/farm/index.cjs +1 -1
  14. package/build/farm/index.mjs +1 -1
  15. package/build/gho/GhoTokenLog.d.ts +4 -0
  16. package/build/gho/index.d.ts +4 -2
  17. package/build/{pool/hsm → gho}/types.d.ts +1 -1
  18. package/build/index.cjs +1 -1
  19. package/build/index.d.ts +1 -0
  20. package/build/index.mjs +1 -1
  21. package/build/indexer/BlockFetcher.d.ts +10 -0
  22. package/build/indexer/Indexer.d.ts +19 -0
  23. package/build/indexer/IndexerStats.d.ts +33 -0
  24. package/build/indexer/RpcPool.d.ts +12 -0
  25. package/build/indexer/Semaphore.d.ts +9 -0
  26. package/build/indexer/index.cjs +1 -0
  27. package/build/indexer/index.d.ts +9 -0
  28. package/build/indexer/index.mjs +1 -0
  29. package/build/indexer/scale.d.ts +1 -0
  30. package/build/indexer/types.d.ts +17 -0
  31. package/build/oracle/MmOracleClient.d.ts +1 -1
  32. package/build/oracle/MmOracleLog.d.ts +4 -0
  33. package/build/oracle/abi.d.ts +11 -84
  34. package/build/oracle/index.d.ts +2 -0
  35. package/build/oracle/mappings.d.ts +25 -0
  36. package/build/oracle/types.d.ts +11 -0
  37. package/build/pool/aave/AavePoolClient.d.ts +0 -1
  38. package/build/pool/aave/types.d.ts +0 -6
  39. package/build/pool/hsm/HsmPoolClient.d.ts +0 -1
  40. package/build/pool/index.cjs +1 -1
  41. package/build/pool/index.mjs +1 -1
  42. package/build/pool/stable/StableSwap.d.ts +1 -1
  43. package/build/pool/stable/StableSwapClient.d.ts +12 -3
  44. package/build/pool/stable/StableSwapPeg.d.ts +7 -0
  45. package/build/pool/stable/types.d.ts +12 -1
  46. package/build/sor/TradeScheduler.d.ts +10 -0
  47. package/build/sor/index.cjs +1 -1
  48. package/build/sor/index.mjs +1 -1
  49. package/build/sor/types.d.ts +1 -0
  50. package/build/staking/index.cjs +1 -1
  51. package/build/staking/index.mjs +1 -1
  52. package/build/tx/IntentLimitTxBuilder.d.ts +21 -0
  53. package/build/tx/IntentMarketTxBuilder.d.ts +15 -0
  54. package/build/tx/IntentOrderTxBuilder.d.ts +17 -0
  55. package/build/tx/TxBuilder.d.ts +2 -2
  56. package/build/tx/TxBuilderFactory.d.ts +9 -1
  57. package/build/tx/index.cjs +1 -1
  58. package/build/tx/index.mjs +1 -1
  59. package/package.json +7 -2
  60. package/build/pool/aave/AaveAbi.d.ts +0 -126
@@ -1 +1 @@
1
- "use strict";var Ie=Object.create;var yt=Object.defineProperty;var we=Object.getOwnPropertyDescriptor;var Oe=Object.getOwnPropertyNames;var xe=Object.getPrototypeOf,Te=Object.prototype.hasOwnProperty;var Z=(c,t)=>{for(var e in t)yt(c,e,{get:t[e],enumerable:!0})},jt=(c,t,e,s)=>{if(t&&typeof t=="object"||typeof t=="function")for(let a of Oe(t))!Te.call(c,a)&&a!==e&&yt(c,a,{get:()=>t[a],enumerable:!(s=we(t,a))||s.enumerable});return c};var Rt=(c,t,e)=>(e=c!=null?Ie(xe(c)):{},jt(t||!c||!c.__esModule?yt(e,"default",{value:c,enumerable:!0}):e,c)),ve=c=>jt(yt({},"__esModule",{value:!0}),c);var ds={};Z(ds,{DCA_TIME_RESERVE:()=>he,DEFAULT_BLOCK_TIME:()=>ge,DEFAULT_MIN_BUDGET:()=>$t,ORDER_MIN_BLOCK_PERIOD:()=>be,Router:()=>nt,TWAP_EXECUTION_INTERVAL:()=>Pt,TWAP_MAX_DURATION:()=>Yt,TWAP_MAX_PRICE_IMPACT:()=>Xt,TWAP_TX_MULTIPLIER:()=>Hl,TradeOrderError:()=>Wt,TradeOrderType:()=>Ut,TradeRouteBuilder:()=>U,TradeRouter:()=>rt,TradeScheduler:()=>Et,TradeType:()=>Vt});module.exports=ve(ds);var lt=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 Be=10,ct=class{isNotVisited(t,e){let s=!0;return e.forEach(a=>{(a[0]===t[0]||a[1]===t[1])&&(s=!1)}),s}findPaths(t,e,s){let a=[],i=new lt,o=[];for(o.push([e,""]),i.enqueue(o);i.size()>0;){let n=i.dequeue();if(!n||n.length>Be)continue;let r=n[n.length-1];(s===null||r[0]===s)&&a.push(n),t.get(r[0])?.forEach(u=>{if(this.isNotVisited(u,n)){let p=[...n];p.push(u),i.enqueue(p)}})}return a}findShortestPaths(t,e,s){let a=[],i=new lt,o=[];o.push([e,""]),i.enqueue(o);let n=1/0;for(;i.size()>0;){let r=i.dequeue();if(!r)continue;let l=r[r.length-1];if(l[0]===s){r.length<n?(n=r.length,a.length=0,a.push(r)):r.length===n&&a.push(r);continue}let u=t.get(l[0]);for(let p of u??[])this.isNotVisited(p,r)&&i.enqueue([...r,p])}return a}buildAndPopulateGraph(t,e){let s=new Map;for(let a of t)s.set(parseInt(a),[]);for(let[a,i,o]of e)s.get(i)?.push([o,a]);return s}};function kt(c){let t={};for(let e of c){let s=e.tokens.length;for(let a=0;a<s;a++){t[e.tokens[a].id]||(t[e.tokens[a].id]=[]);for(let i=0;i<s;i++){if(a==i)continue;let o=[e.address,e.tokens[a].id,e.tokens[i].id];t[e.tokens[a].id].push(o)}}}return t}var H=require("@galacticcouncil/math-lbp"),G=class{static getSpotPrice(t,e,s,a,i){return(0,H.get_spot_price)(t,e,s,a,i)}static calculateInGivenOut(t,e,s,a,i){return(0,H.calculate_in_given_out)(t,e,s,a,i)}static calculateOutGivenIn(t,e,s,a,i){return(0,H.calculate_out_given_in)(t,e,s,a,i)}static calculateLinearWeights(t,e,s,a,i){return(0,H.calculate_linear_weights)(t,e,s,a,i)}static calculatePoolTradeFee(t,e,s){return(0,H.calculate_pool_trade_fee)(t,e,s)}};var tt=require("@galacticcouncil/common");var ft={};Z(ft,{withTimeout:()=>Ae});function Ae(c,t,e="timeout"){return new Promise((s,a)=>{let i=setTimeout(()=>a(new Error(e)),t);c.then(o=>{clearTimeout(i),s(o)},o=>{clearTimeout(i),a(o)})})}var C={};Z(C,{divSpot:()=>_e,getFraction:()=>Ee,mulScaled:()=>Qt,mulSpot:()=>Fe});var Ct=require("@galacticcouncil/common");function Qt(c,t,e,s,a){let i=e+s-a,o=c*t;return i>0?o/BigInt(10)**BigInt(i):i<0?o*BigInt(10)**BigInt(-i):o}function Fe(c,t,e,s){return Qt(c,t,e,Ct.RUNTIME_DECIMALS,s)}function _e(c,t,e,s){if(t===0n)return 0n;let a=BigInt(10)**BigInt(Ct.RUNTIME_DECIMALS+s-e);return c*a/t}function Ee(c,t,e=2){if(t<.01||t>100)throw new Error("Supported range is from 0.01% - 100%");let s=BigInt(10)**BigInt(e),a=BigInt(Math.round(t*Number(s)));return c*a/(BigInt(100)*s)}var S={};Z(S,{FeeUtils:()=>Mt,shiftNeg:()=>ke});var Zt=Rt(require("big.js"));var Mt=class c{static toPct(t){let[e,s]=t;return c.safeDivide(e*100,s)}static toRaw(t){let[e,s]=t;return c.safeDivide(e,s)}static fromPermill(t){return[t,1e6]}static fromPerbill(t){return[t,1e9]}static fromRate(t,e){return[t,e]}static safeDivide(t,e,s=12){let a=10**s;return Math.round(t*a/e)/a}static safeRound(t){return parseFloat(t.toPrecision(15))}};function ke(c,t){let e=(0,Zt.default)(typeof c=="bigint"?c.toString():c);return t===0?e.toString():e.div(Math.pow(10,t)).toString()}var ut={};Z(ut,{findNestedKey:()=>Ce,findNestedObj:()=>Me,jsonFormatter:()=>Le});var Ce=(c,t)=>{let e=[];return JSON.stringify(c,(s,a)=>(a&&a[t]&&e.push(a),a)),e[0]},Me=(c,t,e)=>{let s;return JSON.stringify(c,(a,i)=>(i&&i[t]===e&&(s=i),i)),s},Le=(c,t)=>typeof t=="bigint"?t.toString():t;var A={};Z(A,{calculateBuyFee:()=>qe,calculateDiffToAvg:()=>De,calculateDiffToRef:()=>He,calculateSellFee:()=>Ne});var N=Rt(require("big.js"));function De(c,t){let e=(0,N.default)(c.toString()),s=(0,N.default)(t.toString());return e.minus(s).abs().div(e.plus(s).div(2)).mul(100).round(2).toNumber()}function He(c,t){if(t===0n)return 0;let e=(0,N.default)(c.toString()),s=(0,N.default)(t.toString());return e.minus(s).div(s).mul(100).round(2).toNumber()}function Ne(c,t){if(c===0n)return 0;let e=(0,N.default)(c.toString()),s=(0,N.default)(t.toString());return(0,N.default)(1).minus(s.div(e)).mul(100).round(2).toNumber()}function qe(c,t){if(c===0n)return 0;let e=(0,N.default)(c.toString());return(0,N.default)(t.toString()).div(e).minus(1).mul(100).round(2).toNumber()}var{FeeUtils:te}=S,St=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 s=new Map(this.tokens.map(o=>[o.id,o])),a=s.get(t),i=s.get(e);if(a==null)throw new Error("Pool does not contain tokenIn");if(i==null)throw new Error("Pool does not contain tokenOut");return{assetIn:t,assetOut:e,balanceIn:a.balance,balanceOut:i.balance,decimalsIn:a.decimals,decimalsOut:i.decimals,weightIn:a.weight,weightOut:i.weight}}validateAndBuy(t,e,s){let a=this.tokens[0].id,i=[];e<this.minTradingLimit&&i.push("InsufficientTradingAmount");let o=t.balanceOut/this.maxOutRatio;if(e>o&&i.push("MaxOutRatioExceeded"),a===t.assetOut){let n=this.calculateTradeFee(e,s),r=te.toPct(this.repayFeeApply?s.repayFee:s.exchangeFee),l=e+n,u=this.calculateInGivenOut(t,l),p=t.balanceIn/this.maxInRatio;return u>p&&i.push("MaxInRatioExceeded"),{amountIn:u,calculatedIn:u,amountOut:e,feePct:r,errors:i}}else{let n=this.calculateInGivenOut(t,e),r=t.balanceIn/this.maxInRatio;return n>r&&i.push("MaxInRatioExceeded"),{amountIn:n,calculatedIn:n,amountOut:e,feePct:0,errors:i}}}validateAndSell(t,e,s){let a=this.tokens[0].id,i=[];e<this.minTradingLimit&&i.push("InsufficientTradingAmount");let o=t.balanceIn/this.maxInRatio;if(e>o&&i.push("MaxInRatioExceeded"),a===t.assetIn){let n=this.calculateOutGivenIn(t,e),r=t.balanceOut/this.maxOutRatio;return n>r&&i.push("MaxOutRatioExceeded"),{amountIn:e,calculatedOut:n,amountOut:n,feePct:0,errors:i}}else{let n=this.calculateOutGivenIn(t,e),r=this.calculateTradeFee(n,s),l=te.toPct(this.repayFeeApply?s.repayFee:s.exchangeFee),u=n-r,p=t.balanceOut/this.maxOutRatio;return u>p&&i.push("MaxOutRatioExceeded"),{amountIn:e,calculatedOut:n,amountOut:u,feePct:l,errors:i}}}calculateInGivenOut(t,e){let s=G.calculateInGivenOut(t.balanceIn.toString(),t.balanceOut.toString(),t.weightIn.toString(),t.weightOut.toString(),e.toString()),a=BigInt(s);return a<0n?0n:a}calculateOutGivenIn(t,e){let s=G.calculateOutGivenIn(t.balanceIn.toString(),t.balanceOut.toString(),t.weightIn.toString(),t.weightOut.toString(),e.toString()),a=BigInt(s);return a<0n?0n:a}spotPriceInGivenOut(t){let e=G.getSpotPrice(t.balanceOut.toString(),t.balanceIn.toString(),t.weightOut.toString(),t.weightIn.toString(),tt.big.toBigInt(1,tt.RUNTIME_DECIMALS).toString());return BigInt(e)}spotPriceOutGivenIn(t){let e=G.getSpotPrice(t.balanceIn.toString(),t.balanceOut.toString(),t.weightIn.toString(),t.weightOut.toString(),tt.big.toBigInt(1,tt.RUNTIME_DECIMALS).toString());return BigInt(e)}calculateTradeFee(t,e){let s=G.calculatePoolTradeFee(t.toString(),this.repayFeeApply?e.repayFee[0]:e.exchangeFee[0],this.repayFeeApply?e.repayFee[1]:e.exchangeFee[1]);return BigInt(s)}};var Xe=require("polkadot-api"),xt=require("rxjs");var V=require("rxjs"),E=require("rxjs/operators");var se=require("@galacticcouncil/descriptors");var ee=require("@galacticcouncil/common"),Lt=require("rxjs");var It=require("rxjs"),$=require("rxjs/operators");var{logger:Us}=ee.log;var Ge=require("polkadot-api/ws"),Ve=require("polkadot-api/logs-provider");var Ue=require("polkadot-api");var ae=require("@galacticcouncil/common"),Ot=require("rxjs"),M=require("rxjs/operators");var{logger:ca}=ae.log;var $e=require("rxjs");var ie=require("@galacticcouncil/common");var wa={Aave:"AAVE",LBP:"LBP",Omnipool:"OMNI",Stableswap:"STBL",XYK:"XYK",HSM:"HSM"},{logger:Oa}=ie.log;var{withTimeout:qa}=ft;var h=require("@galacticcouncil/math-omnipool"),K=Rt(require("big.js")),w=class{static calculateSpotPrice(t,e,s,a){return(0,h.calculate_spot_price)(t,e,s,a)}static calculateLrnaSpotPrice(t,e){return(0,h.calculate_lrna_spot_price)(t,e)}static calculateInGivenOut(t,e,s,a,i,o,n,r,l,u){return(0,h.calculate_in_given_out)(t,e,s,a,i,o,n,r,l,u)}static calculateLrnaInGivenOut(t,e,s,a,i,o){return(0,h.calculate_lrna_in_given_out)(t,e,s,a,i,o)}static calculateOutGivenIn(t,e,s,a,i,o,n,r,l,u){return(0,h.calculate_out_given_in)(t,e,s,a,i,o,n,r,l,u)}static calculateOutGivenLrnaIn(t,e,s,a,i,o){return(0,h.calculate_out_given_lrna_in)(t,e,s,a,i,o)}static calculateShares(t,e,s,a){return(0,h.calculate_shares)(t,e,s,a)}static calculateLiquidityOut(t,e,s,a,i,o,n,r){return(0,h.calculate_liquidity_out)(t,e,s,a,i,o,n,r)}static calculateLiquidityLRNAOut(t,e,s,a,i,o,n,r){return(0,h.calculate_liquidity_lrna_out)(t,e,s,a,i,o,n,r)}static calculateCapDifference(t,e,s,a){let i=(0,K.default)(e),o=(0,K.default)(t),n=(0,K.default)(a),r=(0,K.default)(s),l=(0,K.default)(10).pow(18),u=r.div(l);if(i.div(n).lt(u)){let b=u.times(n).minus(i).times(o),d=i.times((0,K.default)(1).minus(u));return b.div(d).toFixed(0)}else return"0"}static calculateLimitHubIn(t,e,s,a){return(0,h.calculate_liquidity_hub_in)(t,e,s,a)}static isSellAllowed(t){return(0,h.is_sell_allowed)(t)}static isBuyAllowed(t){return(0,h.is_buy_allowed)(t)}static isAddLiquidityAllowed(t){return(0,h.is_add_liquidity_allowed)(t)}static isRemoveLiquidityAllowed(t){return(0,h.is_remove_liquidity_allowed)(t)}static recalculateAssetFee(t,e,s,a,i,o,n,r,l,u,p){return(0,h.recalculate_asset_fee)(t,e,s,a,i,o,n,r,l,u,p)}static recalculateProtocolFee(t,e,s,a,i,o,n,r,l,u,p){return(0,h.recalculate_protocol_fee)(t,e,s,a,i,o,n,r,l,u,p)}static verifyAssetCap(t,e,s,a){return(0,h.verify_asset_cap)(t,e,s,a)}};var oe=require("@galacticcouncil/common");var{FeeUtils:q}=S,Tt=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 s=new Map(this.tokens.map(o=>[o.id,o])),a=s.get(t),i=s.get(e);if(a==null)throw new Error("Pool does not contain tokenIn");if(i==null)throw new Error("Pool does not contain tokenOut");return{assetIn:t,assetOut:e,hubReservesIn:a.hubReserves,hubReservesOut:i.hubReserves,sharesIn:a.shares,sharesOut:i.shares,decimalsIn:a.decimals,decimalsOut:i.decimals,balanceIn:a.balance,balanceOut:i.balance,tradeableIn:a.tradeable,tradeableOut:i.tradeable,assetInEd:a.existentialDeposit,assetOutEd:i.existentialDeposit}}validateAndBuy(t,e,s){let a=this.calculateInGivenOut(t,e),i=this.calculateInGivenOut(t,e,s),o=a===0n?0:A.calculateBuyFee(a,i),n=[],r=w.isSellAllowed(t.tradeableIn),l=w.isBuyAllowed(t.tradeableOut);(!r||!l)&&n.push("TradeNotAllowed"),(e<this.minTradingLimit||a<t.assetInEd)&&n.push("InsufficientTradingAmount");let u=t.balanceOut/this.maxOutRatio;e>u&&n.push("MaxOutRatioExceeded");let p=t.balanceIn/this.maxInRatio;return i>p&&n.push("MaxInRatioExceeded"),{amountIn:i,calculatedIn:a,amountOut:e,feePct:o,errors:n}}validateAndSell(t,e,s){let a=this.calculateOutGivenIn(t,e),i=this.calculateOutGivenIn(t,e,s),o=A.calculateSellFee(a,i),n=[],r=w.isSellAllowed(t.tradeableIn),l=w.isBuyAllowed(t.tradeableOut);(!r||!l)&&n.push("TradeNotAllowed"),(e<this.minTradingLimit||a<t.assetOutEd)&&n.push("InsufficientTradingAmount");let u=t.balanceIn/this.maxInRatio;e>u&&n.push("MaxInRatioExceeded");let p=t.balanceOut/this.maxOutRatio;return i>p&&n.push("MaxOutRatioExceeded"),{amountIn:e,calculatedOut:a,amountOut:i,feePct:o,errors:n}}calculateInGivenOut(t,e,s){if(t.assetIn==this.hubAssetId)return this.calculateLrnaInGivenOut(t,e,s);let a=w.calculateInGivenOut(t.balanceIn.toString(),t.hubReservesIn.toString(),t.sharesIn.toString(),t.balanceOut.toString(),t.hubReservesOut.toString(),t.sharesOut.toString(),e.toString(),s?q.toRaw(s.assetFee).toString():"0",s?q.toRaw(s.protocolFee).toString():"0",s?q.toRaw(s.maxSlipFee).toString():"0"),i=BigInt(a);return i<0n?0n:i}calculateLrnaInGivenOut(t,e,s){let a=w.calculateLrnaInGivenOut(t.balanceOut.toString(),t.hubReservesOut.toString(),t.sharesOut.toString(),e.toString(),s?q.toRaw(s.assetFee).toString():"0",s?q.toRaw(s.maxSlipFee).toString():"0"),i=BigInt(a);return i<0n?0n:i}calculateOutGivenIn(t,e,s){if(t.assetIn==this.hubAssetId)return this.calculateOutGivenLrnaIn(t,e,s);let a=w.calculateOutGivenIn(t.balanceIn.toString(),t.hubReservesIn.toString(),t.sharesIn.toString(),t.balanceOut.toString(),t.hubReservesOut.toString(),t.sharesOut.toString(),e.toString(),s?q.toRaw(s.assetFee).toString():"0",s?q.toRaw(s.protocolFee).toString():"0",s?q.toRaw(s.maxSlipFee).toString():"0"),i=BigInt(a);return i<0n?0n:i}calculateOutGivenLrnaIn(t,e,s){let a=w.calculateOutGivenLrnaIn(t.balanceOut.toString(),t.hubReservesOut.toString(),t.sharesOut.toString(),e.toString(),s?q.toRaw(s.assetFee).toString():"0",s?q.toRaw(s.maxSlipFee).toString():"0"),i=BigInt(a);return i<0n?0n:i}spotPriceInGivenOut(t){if(t.assetIn==this.hubAssetId)return this.spotPriceLrnaInGivenOut(t);let e=w.calculateSpotPrice(t.balanceOut.toString(),t.hubReservesOut.toString(),t.balanceIn.toString(),t.hubReservesIn.toString());return this.normalizeSpot(BigInt(e),t.decimalsOut,t.decimalsIn)}spotPriceLrnaInGivenOut(t){let e=w.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=w.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=w.calculateLrnaSpotPrice(t.balanceOut.toString(),t.hubReservesOut.toString());return this.normalizeSpot(BigInt(e),t.decimalsIn,t.decimalsOut)}normalizeSpot(t,e,s){let a=e-s;if(a===0)return t;let i=oe.big.pow10(Math.abs(a));return a>0?t*i:t/i}};var j=require("polkadot-api"),je=require("@polkadot-api/utils"),Q=require("rxjs"),Qe=require("@galacticcouncil/common");var{FeeUtils:bi}=S;var{FeeUtils:Ei}=S,Ri=j.Binary.toHex(j.Binary.fromText("omnipool")),ki=(0,j.Enum)("Short");var x=require("@galacticcouncil/math-stableswap"),k=class{static getPoolAddress(t){return(0,x.pool_account_name)(t)}static defaultPegs(t){let e=[];for(let s=0;s<t;s++)e.push(["1","1"]);return e}static calculateAmplification(t,e,s,a,i){return(0,x.calculate_amplification)(t,e,s,a,i)}static calculateInGivenOut(t,e,s,a,i,o,n){return(0,x.calculate_in_given_out)(t,e,s,a,i,o,n)}static calculateAddOneAsset(t,e,s,a,i,o,n){return(0,x.calculate_add_one_asset)(t,e,s,a,i,o,n)}static calculateSharesForAmount(t,e,s,a,i,o,n){return(0,x.calculate_shares_for_amount)(t,e,s,a,i,o,n)}static calculateOutGivenIn(t,e,s,a,i,o,n){return(0,x.calculate_out_given_in)(t,e,s,a,i,o,n)}static calculateLiquidityOutOneAsset(t,e,s,a,i,o,n){return(0,x.calculate_liquidity_out_one_asset)(t,e,s,a,i,o,n)}static calculateShares(t,e,s,a,i,o){return(0,x.calculate_shares)(t,e,s,a,i,o)}static calculateSpotPriceWithFee(t,e,s,a,i,o,n,r){return(0,x.calculate_spot_price_with_fee)(t,e,s,a,i,o,n,r)}static recalculatePegs(t,e,s,a,i,o){let n=(0,x.recalculate_peg)(t,e,s,a,i,o);return JSON.parse(n)}};var dt=require("@galacticcouncil/common");var{FeeUtils:et}=S,st=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 s=new Map(this.tokens.map(o=>[o.id,o])),a=s.get(t),i=s.get(e);if(a==null)throw new Error("Pool does not contain tokenIn");if(i==null)throw new Error("Pool does not contain tokenOut");return{assetIn:t,assetOut:e,balanceIn:a.balance,balanceOut:i.balance,decimalsIn:a.decimals,decimalsOut:i.decimals,tradeableIn:this.id===t?15:a.tradeable,tradeableOut:this.id===e?15:i.tradeable,assetInEd:a.existentialDeposit,assetOutEd:i.existentialDeposit}}validateAndBuy(t,e,s){let a=this.calculateInGivenOut(t,e),i=this.calculateInGivenOut(t,e,s),o=a===0n?0:A.calculateBuyFee(a,i),n=[],r=w.isSellAllowed(t.tradeableIn),l=w.isBuyAllowed(t.tradeableOut);return(!r||!l)&&n.push("TradeNotAllowed"),(e<this.minTradingLimit||a<t.assetInEd)&&n.push("InsufficientTradingAmount"),{amountIn:i,calculatedIn:a,amountOut:e,feePct:o,errors:n}}validateAndSell(t,e,s){let a=this.calculateOutGivenIn(t,e),i=this.calculateOutGivenIn(t,e,s),o=A.calculateSellFee(a,i),n=[],r=w.isSellAllowed(t.tradeableIn),l=w.isBuyAllowed(t.tradeableOut);return(!r||!l)&&n.push("TradeNotAllowed"),(e<this.minTradingLimit||a<t.assetOutEd)&&n.push("InsufficientTradingAmount"),{amountIn:e,calculatedOut:a,amountOut:i,feePct:o,errors:n}}calculateIn(t,e,s){let a=k.calculateInGivenOut(this.getReserves(),Number(t.assetIn),Number(t.assetOut),e.toString(),this.amplification.toString(),s?et.toRaw(s.fee).toString():"0",this.getPegs()),i=BigInt(a);return i<0n?0n:i}calculateAddOneAsset(t,e,s){let a=k.calculateAddOneAsset(this.getReserves(),e.toString(),Number(t.assetIn),this.amplification.toString(),this.totalIssuance.toString(),s?et.toRaw(s.fee).toString():"0",this.getPegs()),i=BigInt(a);return i<0n?0n:i}calculateSharesForAmount(t,e,s){let a=k.calculateSharesForAmount(this.getReserves(),Number(t.assetOut),e.toString(),this.amplification.toString(),this.totalIssuance.toString(),s?et.toRaw(s.fee).toString():"0",this.getPegs()),i=BigInt(a);return i<0n?0n:i}calculateInGivenOut(t,e,s){return t.assetOut==this.id?this.calculateAddOneAsset(t,e,s):t.assetIn==this.id?this.calculateSharesForAmount(t,e,s):this.calculateIn(t,e,s)}spotPriceInGivenOut(t){let e=k.calculateSpotPriceWithFee(this.id.toString(),this.getReserves(),this.amplification.toString(),t.assetOut.toString(),t.assetIn.toString(),this.totalIssuance.toString(),"0",this.getPegs());return this.normalizeSpot(BigInt(e),t.assetOut===this.id,t.assetIn===this.id,t.decimalsOut,t.decimalsIn)}calculateOut(t,e,s){let a=k.calculateOutGivenIn(this.getReserves(),Number(t.assetIn),Number(t.assetOut),e.toString(),this.amplification.toString(),s?et.toRaw(s.fee).toString():"0",this.getPegs()),i=BigInt(a);return i<0n?0n:i}calculateWithdrawOneAsset(t,e,s){let a=k.calculateLiquidityOutOneAsset(this.getReserves(),e.toString(),Number(t.assetOut),this.amplification.toString(),this.totalIssuance.toString(),s?et.toRaw(s.fee).toString():"0",this.getPegs()),i=BigInt(a);return i<0n?0n:i}calculateShares(t,e,s){let a=k.calculateShares(this.getReserves(),this.getAssets(t.assetIn,e),this.amplification.toString(),this.totalIssuance.toString(),s?et.toRaw(s.fee).toString():"0",this.getPegs()),i=BigInt(a);return i<0n?0n:i}calculateOutGivenIn(t,e,s){return t.assetIn==this.id?this.calculateWithdrawOneAsset(t,e,s):t.assetOut==this.id?this.calculateShares(t,e,s):this.calculateOut(t,e,s)}spotPriceOutGivenIn(t){let e=k.calculateSpotPriceWithFee(this.id.toString(),this.getReserves(),this.amplification.toString(),t.assetIn.toString(),t.assetOut.toString(),this.totalIssuance.toString(),"0",this.getPegs());return this.normalizeSpot(BigInt(e),t.assetIn===this.id,t.assetOut===this.id,t.decimalsIn,t.decimalsOut)}getPegs(){return JSON.stringify(this.pegs)}getReserves(){let t=this.tokens.filter(e=>e.id!=this.id).map(({id:e,balance:s,decimals:a})=>({asset_id:e,amount:s,decimals:a}));return JSON.stringify(t,ut.jsonFormatter)}getAssets(t,e){let s={asset_id:Number(t),amount:e.toString()};return JSON.stringify([s],ut.jsonFormatter)}normalizeSpot(t,e,s,a,i){return e?t*dt.big.pow10(dt.RUNTIME_DECIMALS-i):s?t/dt.big.pow10(i-a):t}};var ne=require("polkadot-api"),Ze=require("@polkadot-api/utils"),ts=require("@noble/hashes/blake2b"),gt=require("rxjs"),re=require("@galacticcouncil/common");var{FeeUtils:go}=S;var T=require("@galacticcouncil/math-xyk"),X=class{static getSpotPrice(t,e,s){return(0,T.get_spot_price)(t,e,s)}static calculateInGivenOut(t,e,s){return(0,T.calculate_in_given_out)(t,e,s)}static calculateOutGivenIn(t,e,s){return(0,T.calculate_out_given_in)(t,e,s)}static calculatePoolTradeFee(t,e,s){return(0,T.calculate_pool_trade_fee)(t,e,s)}static calculateLiquidityIn(t,e,s){return(0,T.calculate_liquidity_in)(t,e,s)}static calculateSpotPrice(t,e){return(0,T.calculate_spot_price)(t,e)}static calculateSpotPriceWithFee(t,e,s,a){return(0,T.calculate_spot_price_with_fee)(t,e,s,a)}static calculateShares(t,e,s){return(0,T.calculate_shares)(t,e,s)}static calculateLiquidityOutAssetA(t,e,s,a){return(0,T.calculate_liquidity_out_asset_a)(t,e,s,a)}static calculateLiquidityOutAssetB(t,e,s,a){return(0,T.calculate_liquidity_out_asset_b)(t,e,s,a)}};var ce=require("@galacticcouncil/common");var{FeeUtils:le}=S,vt=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 s=new Map(this.tokens.map(o=>[o.id,o])),a=s.get(t),i=s.get(e);if(a==null)throw new Error("Pool does not contain tokenIn");if(i==null)throw new Error("Pool does not contain tokenOut");return{assetIn:t,assetOut:e,decimalsIn:a.decimals,decimalsOut:i.decimals,balanceIn:a.balance,balanceOut:i.balance,assetInEd:a.existentialDeposit,assetOutEd:i.existentialDeposit}}validateAndBuy(t,e,s){let a=this.calculateInGivenOut(t,e),i=this.calculateTradeFee(a,s),o=le.toPct(s.exchangeFee),n=a+i,r=[];(e<this.minTradingLimit||a<t.assetInEd)&&r.push("InsufficientTradingAmount");let l=t.balanceOut/this.maxOutRatio;e>l&&r.push("MaxOutRatioExceeded");let u=t.balanceIn/this.maxInRatio;return n>u&&r.push("MaxInRatioExceeded"),{amountIn:n,calculatedIn:a,amountOut:e,feePct:o,errors:r}}validateAndSell(t,e,s){let a=this.calculateOutGivenIn(t,e),i=this.calculateTradeFee(a,s),o=le.toPct(s.exchangeFee),n=a-i,r=[];(e<this.minTradingLimit||a<t.assetOutEd)&&r.push("InsufficientTradingAmount");let l=t.balanceIn/this.maxInRatio;e>l&&r.push("MaxInRatioExceeded");let u=t.balanceOut/this.maxOutRatio;return n>u&&r.push("MaxOutRatioExceeded"),{amountIn:e,calculatedOut:a,amountOut:n,feePct:o,errors:r}}calculateInGivenOut(t,e){let s=X.calculateInGivenOut(t.balanceIn.toString(),t.balanceOut.toString(),e.toString()),a=BigInt(s);return a<0n?0n:a}calculateOutGivenIn(t,e){let s=X.calculateOutGivenIn(t.balanceIn.toString(),t.balanceOut.toString(),e.toString()),a=BigInt(s);return a<0n?0n:a}spotPriceInGivenOut(t){let e=X.calculateSpotPrice(t.balanceOut.toString(),t.balanceIn.toString());return this.normalizeSpot(BigInt(e),t.decimalsOut,t.decimalsIn)}spotPriceOutGivenIn(t){let e=X.calculateSpotPrice(t.balanceIn.toString(),t.balanceOut.toString());return this.normalizeSpot(BigInt(e),t.decimalsIn,t.decimalsOut)}calculateTradeFee(t,e){let s=X.calculatePoolTradeFee(t.toString(),e.exchangeFee[0],e.exchangeFee[1]);return BigInt(s)}normalizeSpot(t,e,s){let a=e-s;if(a===0)return t;let i=ce.big.pow10(Math.abs(a));return a>0?t*i:t/i}};var ss=require("polkadot-api"),as=require("rxjs");var at=require("@galacticcouncil/common");var Bt=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 s=new Map(this.tokens.map(o=>[o.id,o])),a=s.get(t),i=s.get(e);if(a==null)throw new Error("Pool does not contain tokenIn");if(i==null)throw new Error("Pool does not contain tokenOut");return{assetIn:t,assetOut:e,balanceIn:a.balance,balanceOut:i.balance,decimalsIn:a.decimals,decimalsOut:i.decimals,assetInEd:0n,assetOutEd:0n}}validateAndBuy(t,e,s){let a=this.calculateInGivenOut(t,e),i=[];return e>t.balanceOut&&i.push("TradeNotAllowed"),{amountIn:a,calculatedIn:a,amountOut:e,feePct:0,errors:i}}validateAndSell(t,e,s){let a=this.calculateOutGivenIn(t,e),i=[];return a>t.balanceOut&&i.push("TradeNotAllowed"),{amountIn:e,calculatedOut:a,amountOut:a,feePct:0,errors:i}}calculateInGivenOut(t,e){return e}calculateOutGivenIn(t,e){return e}spotPriceInGivenOut(t){return at.big.toBigInt(1,at.RUNTIME_DECIMALS)}spotPriceOutGivenIn(t){return at.big.toBigInt(1,at.RUNTIME_DECIMALS)}calculateTradeFee(t,e){return 0n}};var ue=require("polkadot-api"),os=require("@polkadot-api/utils"),At=require("rxjs"),ns=require("viem"),Ht=require("@galacticcouncil/common");var{ERC20:un}=Ht.erc20;var B=require("@galacticcouncil/math-hsm"),L=class{static calculateCollateralInGivenHollarOut(t,e,s){return(0,B.calculate_collateral_in_given_hollar_out)(t,e,s)}static calculateCollateralOutGivenHollarIn(t,e,s){return(0,B.calculate_collateral_out_given_hollar_in)(t,e,s)}static calculateHollarOutGivenCollateralIn(t,e,s){return(0,B.calculate_hollar_out_given_collateral_in)(t,e,s)}static calculateHollarInGivenCollateralOut(t,e,s){return(0,B.calculate_hollar_in_given_collateral_out)(t,e,s)}static calculateImbalance(t,e,s){return(0,B.calculate_imbalance)(t,e,s)}static calculateBuybackLimit(t,e){return(0,B.calculate_buyback_limit)(t,e)}static calculateBuybackPriceWithFee(t,e,s){return(0,B.calculate_buyback_price_with_fee)(t,e,s)}static calculateMaxPrice(t,e){return(0,B.calculate_max_price)(t,e)}};var F=require("@galacticcouncil/common");var{FeeUtils:it}=S,Ft=class c extends st{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,s){let a=this.parsePair(t.assetOut,t.assetIn),i=super.calculateInGivenOut(a,e,{fee:this.fee}),o=this.calculateBuybackLimit(t);e>o&&s.push("MaxBuyBackExceeded");let n=this.calculateMaxPrice(t);return this.calculateBuyPrice(t,e,i)>n&&s.push("MaxBuyPriceExceeded"),i>this.collateralBalance&&s.push("InsufficientCollateral"),s}validateTradeHollarOut(t,e,s){return this.collateralBalance+t>this.maxInHolding&&s.push("MaxHoldingExceeded"),e>this.hsmMintCapacity&&s.push("FacilitatorCapacityExceeded"),s}validateTradeConstraints(t,e,s){let a=[];return t.assetIn===this.hollarId?this.validateTradeHollarIn(t,e,a):this.validateTradeHollarOut(e,s,a)}validateAndBuy(t,e){let s=this.calculateInGivenOut(t,e),a=this.validateTradeConstraints(t,s,e);return{amountIn:s,calculatedIn:s,amountOut:e,feePct:0,errors:a}}validateAndSell(t,e){let s=this.calculateOutGivenIn(t,e),a=this.validateTradeConstraints(t,e,s);return{amountIn:e,calculatedOut:s,amountOut:s,feePct:0,errors:a}}calculateHollarInGivenCollateralOut(t,e){let s=super.calculateInGivenOut(t,e,{fee:this.fee}),a=L.calculateHollarInGivenCollateralOut(e.toString(),s.toString(),it.toRaw(this.buyBackFee).toString());return BigInt(a)}calculateCollateralInGivenHollarOut(t){let e=this.getCollateralPeg(),s=L.calculateCollateralInGivenHollarOut(t.toString(),JSON.stringify(e),it.toRaw(this.purchaseFee).toString());return BigInt(s)}calculateInGivenOut(t,e){return t.assetOut==this.hollarId?this.calculateCollateralInGivenHollarOut(e):this.calculateHollarInGivenCollateralOut(t,e)}calculateCollateralOutGivenHollarIn(t,e){let s=super.calculateOutGivenIn(t,e,{fee:this.fee}),a=L.calculateCollateralOutGivenHollarIn(e.toString(),s.toString(),it.toRaw(this.buyBackFee).toString());return BigInt(a)}calculateHollarOutGivenCollateralIn(t){let e=this.getCollateralPeg(),s=L.calculateHollarOutGivenCollateralIn(t.toString(),JSON.stringify(e),it.toRaw(this.purchaseFee).toString());return BigInt(s)}calculateOutGivenIn(t,e){return t.assetIn==this.hollarId?this.calculateCollateralOutGivenHollarIn(t,e):this.calculateHollarOutGivenCollateralIn(e)}calculateImbalance(t){let e=this.getCollateralPeg(),s=L.calculateImbalance(t.balanceIn.toString(),JSON.stringify(e),t.balanceOut.toString());return BigInt(s)}calculateBuybackLimit(t){let e=this.calculateImbalance(t),s=L.calculateBuybackLimit(e.toString(),it.toRaw(this.buyBackRate).toString());return BigInt(s)}calculateBuyPrice(t,e,s){let a=L.calculateBuybackPriceWithFee(s.toString(),e.toString(),it.toRaw(this.buyBackFee).toString()),[i,o]=JSON.parse(a),n=F.big.pow10(t.decimalsIn+F.RUNTIME_DECIMALS-t.decimalsOut);return BigInt(i)*n/BigInt(o)}calculateMaxPrice(t){let e=this.getCollateralPeg(),s=L.calculateMaxPrice(JSON.stringify(e),this.maxBuyPriceCoefficient.toString()),[a,i]=JSON.parse(s),o=F.big.pow10(F.RUNTIME_DECIMALS-t.decimalsOut);return BigInt(a)*o/BigInt(i)}spotPriceInGivenOut(t){let e=F.big.toBigInt(1,t.decimalsOut),a=this.calculateInGivenOut(t,e)*F.big.pow10(F.RUNTIME_DECIMALS-t.decimalsOut);return this.normalizeSpotPrice(a,t.decimalsOut,t.decimalsIn)}spotPriceOutGivenIn(t){let e=F.big.toBigInt(1,t.decimalsIn),a=this.calculateOutGivenIn(t,e)*F.big.pow10(F.RUNTIME_DECIMALS-t.decimalsIn);return this.normalizeSpotPrice(a,t.decimalsIn,t.decimalsOut)}getCollateralPeg(){let t=this.tokens.findIndex(a=>a.id!==this.hollarId),e=this.pegs[t],s=this.tokens[t].decimals;return this.isDefaultPeg(e)?[F.big.toBigInt(1,18).toString(),F.big.toBigInt(1,s).toString()]:e}isDefaultPeg(t){let[e,s]=t;return Array.isArray(t)&&t.length===2&&e==="1"&&s==="1"}normalizeSpotPrice(t,e,s){let a=e-s;if(a===0)return t;let i=F.big.pow10(Math.abs(a));return a>0?t*i:t/i}};var Nt=require("polkadot-api"),cs=require("@polkadot-api/utils"),ot=require("rxjs"),us=require("viem"),qt=require("@galacticcouncil/common");var{FeeUtils:qn}=S,{H160:Gn}=qt.h160;var ht=class{static get(t){switch(t.type){case"Aave":return Bt.fromPool(t);case"XYK":return vt.fromPool(t);case"Omnipool":return Tt.fromPool(t);case"LBP":return St.fromPool(t);case"Stableswap":return st.fromPool(t);case"HSM":return Ft.fromPool(t);default:throw new Error("Pool type "+t.type+" is not supported yet")}}};var pe=require("@galacticcouncil/common"),Gt=require("rxjs");var _t=class extends Error{constructor(t,e){super(),this.message=`Route from ${t} to ${e} not found in current configuration`,this.name="RouteNotFound"}};var{logger:Fr}=pe.log;var bt=class{getProposals(t,e,s){let a=s.filter(m=>m.type==="XYK"),i=s.filter(m=>m.type!=="XYK"),o=new Set(i.map(m=>m.tokens).flat().map(m=>m.id)),n=o.has(t),r=o.has(e),l=new ct,u=m=>{let y=kt(m),f=Object.keys(y),D=f.flatMap(R=>y[R]);return l.buildAndPopulateGraph(f,D)};if(!n&&!r){let m=a.filter(D=>D.tokens.find(R=>R.id===t)||D.tokens.find(R=>R.id===e)),y=u(m),f=l.findPaths(y,t,e);return this.parsePaths(f)}if(n&&r){let m=u(i),y=l.findPaths(m,t,e);return this.parsePaths(y)}let p=n?e:t,b=a.filter(m=>m.tokens.some(y=>y.id===p));if(b.length===0)return[];let d=[...i,...b],I=u(d),g=l.findPaths(I,t,e);return this.parsePaths(g)}parsePaths(t){let e=[];for(let s of t){let a=[];for(let i=0;i<s.length;i++){let o=s[i],n=s[i+1];if(n==null)break;a.push(this.toEdge(o,n))}e.push(a)}return e}toEdge(t,e){return[e[1],t[0],e[0]]}};var nt=class{routeSuggester;routeProposals;ctx;filter={};constructor(t){this.ctx=t,this.routeSuggester=new bt,this.routeProposals=new Map}async withFilter(t){this.filter=t||{},this.routeProposals.clear(),this.onFilterChanged()}onFilterChanged(){}buildRouteKey(t,e,s){return`${t}->${e}::${s.length}`}applyPoolFilter(t){let{useOnly:e=[],exclude:s=[]}=this.filter,a=new Set(e),i=new Set(s);return t.filter(o=>i.has(o.type)?!1:a.size>0?a.has(o.type):!0)}async getPools(){let t=await this.ctx.getPools();return this.applyPoolFilter(t)}async getRoutes(t,e){let s=await this.getPools();return this.validateInput(t,e,s),this.getPaths(t,e,s)}async getTradeableAssets(){let t=await this.getPools(),e=this.getAssets(t);return Array.from(e)}async getRouteableAssets(t){let e=await this.getTradeableAssets();return(await Promise.all(e.filter(a=>a!==t).map(a=>this.getRoutes(a,t)))).filter(a=>a.length>0).map(([a])=>a[0].assetIn).sort()}validateInput(t,e,s){if(s.length===0)throw new Error("No pools configured");if(t===e)throw new Error("Trading pair can't be identical");let a=this.getAssets(s);if(!a.has(t))throw new Error(t+" is not supported asset");if(!a.has(e))throw new Error(e+" is not supported asset");return this.toPoolsMap(s)}getAssets(t){let e=t.map(s=>s.tokens.map(a=>a.id)).flat().sort((s,a)=>s>a?1:-1);return new Set(e)}getPaths(t,e,s){let a=this.toPoolsMap(s);return this.getProposals(t,e,s).filter(o=>this.validPath(o,a)).map(o=>this.toHops(o,a))}getProposals(t,e,s){let a=this.buildRouteKey(t,e,s);if(this.routeProposals.has(a))return this.routeProposals.get(a);let i=this.routeSuggester.getProposals(t,e,s);return this.routeProposals.set(a,i),i}validPath(t,e){return t.length>0&&t.map(s=>this.validEdge(s,e)).reduce((s,a)=>s&&a)}validEdge([t,e,s],a){return a.get(t)?.validatePair(e,s)||!1}toPoolsMap(t){return new Map(t.map(e=>[e.address,ht.get(e)]))}toHops(t,e){return t.map(([s,a,i])=>{let o=e.get(s);return{poolAddress:s,poolId:o?.id,pool:o?.type,assetIn:a,assetOut:i}})}};var P=require("@galacticcouncil/common");var Vt=(e=>(e.Buy="Buy",e.Sell="Sell",e))(Vt||{}),Ut=(s=>(s.Dca="Dca",s.TwapSell="TwapSell",s.TwapBuy="TwapBuy",s))(Ut||{}),Wt=(s=>(s.OrderTooSmall="OrderTooSmall",s.OrderTooBig="OrderTooBig",s.OrderImpactTooBig="OrderImpactTooBig",s))(Wt||{});var{FeeUtils:de}=S,rt=class extends nt{mlr;constructor(t){super(t),this.mlr=new Map}onFilterChanged(){this.mlr.clear()}buildCtxSync(t,e,s){let a=super.validateInput(t,e,s),i=super.getPaths(t,e,s);if(!i.length)throw new _t(t,e);return{paths:i,pools:s,poolsMap:a}}async withCtx(t,e,s){let a=await super.getPools(),i=this.buildCtxSync(t,e,a);return s(i)}isDirectTrade(t){return t.length==1}findBestSellRoute(t){let e=t.sort((s,a)=>{let i=s[s.length-1].amountOut,o=a[a.length-1].amountOut;return i>o?-1:1});return e.find(s=>s.every(a=>a.errors.length==0))||e[0]}getRouteFeeRange(t){if(t.filter(s=>s.tradeFeeRange).length>0){let s=t.map(i=>i.tradeFeeRange?.[0]??i.tradeFeePct).reduce((i,o)=>i+o),a=t.map(i=>i.tradeFeeRange?.[1]??i.tradeFeePct).reduce((i,o)=>i+o);return[s,a]}}getPoolFeeRange(t,e){let s=t.min?de.toPct(t.min):void 0,a=t.max?de.toPct(t.max):void 0;if(s&&a)return[s,Math.max(a,e)]}async getBestSell(t,e,s){return this.getSell(t,e,s)}getSellSpot(t){let e=t[t.length-1];return t.length===1?e.spotPrice:this.calculateSpot(t)}async getSell(t,e,s,a){return this.withCtx(t,e,async({paths:i,poolsMap:o})=>{let n;if(a)n=await this.toSellSwaps(s,a,o);else{let r=i.map(u=>this.toSellSwaps(s,u,o)),l=await Promise.all(r);n=this.findBestSellRoute(l)}return this.buildSell(o,n)})}async getSells(t,e,s){return this.withCtx(t,e,async({paths:a,poolsMap:i})=>{let o=a.map(r=>this.toSellSwaps(s,r,i));return(await Promise.all(o)).filter(r=>r.every(l=>l.errors.length==0)).map(r=>this.buildSell(i,r)).sort((r,l)=>r.amountOut>l.amountOut?-1:1)})}buildSell(t,e){let s=e[0],a=e[e.length-1],i=this.isDirectTrade(e),o=this.getSellSpot(e),n=a.amountOut,r=i?a.calculatedOut:this.calculateDelta0Y(s.amountIn,e,t),l=r-n,u=this.getRouteFeeRange(e),p=i?a.tradeFeePct:A.calculateSellFee(r,n),b=C.mulSpot(s.amountIn,o,s.assetInDecimals,a.assetOutDecimals),d=A.calculateDiffToRef(r,b);return{type:"Sell",amountIn:s.amountIn,amountOut:a.amountOut,spotPrice:o,tradeFee:l,tradeFeePct:p,tradeFeeRange:u,priceImpactPct:d,swaps:e,toHuman(){return{type:"Sell",amountIn:P.big.toDecimal(s.amountIn,s.assetInDecimals),amountOut:P.big.toDecimal(a.amountOut,a.assetOutDecimals),spotPrice:P.big.toDecimal(o,P.RUNTIME_DECIMALS),tradeFee:P.big.toDecimal(l,a.assetOutDecimals),tradeFeePct:p,tradeFeeRange:u,priceImpactPct:d,swaps:e.map(I=>I.toHuman())}}}}calculateSpot(t){return t.map(e=>e.spotPrice).reduce((e,s)=>e*s/10n**BigInt(P.RUNTIME_DECIMALS))}calculateDelta0Y(t,e,s){let a=[];for(let i=0;i<e.length;i++){let o=e[i],n=s.get(o.poolAddress);if(n==null)throw new Error("Pool does not exit");let r=n.parsePair(o.assetIn,o.assetOut),l;i>0?l=a[i-1]:l=t;let u=n.calculateOutGivenIn(r,l);a.push(u)}return a[a.length-1]}async calculateMostLiquidRoute(t,e,s){let{paths:a,pools:i,poolsMap:o}=s,l=i.filter(g=>g.tokens.some(m=>m.id===t)).map(g=>g.type==="Aave"?g.tokens:g.tokens.filter(m=>m.id===t)).map(g=>g.map(m=>m.balance).reduce((m,y)=>m+y)).sort((g,m)=>m<g?-1:1)[0],u=C.getFraction(l,.1),p=await Promise.all(a.map(g=>this.toSellSwaps(u,g,o))),d=this.findBestSellRoute(p).map(g=>({poolAddress:g.poolAddress,poolId:g?.poolId,pool:g.pool,assetIn:g.assetIn,assetOut:g.assetOut})),I=this.buildRouteKey(t,e,i);return this.mlr.set(I,d),d}async toSellSwaps(t,e,s){let a=[];for(let i=0;i<e.length;i++){let o=e[i],n=s.get(o.poolAddress);if(n==null)throw new Error("Pool does not exit");let r=n.parsePair(o.assetIn,o.assetOut),l;i>0?l=a[i-1].amountOut:l=typeof t=="string"?P.big.toBigInt(t,r.decimalsIn):t;let u=await this.ctx.getPoolFees(r,n),{amountOut:p,calculatedOut:b,feePct:d,errors:I}=n.validateAndSell(r,l,u),g=this.getPoolFeeRange(u,d),m=n.spotPriceOutGivenIn(r),y=C.mulSpot(l,m,r.decimalsIn,r.decimalsOut),f=A.calculateDiffToRef(b,y);a.push({...o,assetInDecimals:r.decimalsIn,assetOutDecimals:r.decimalsOut,amountIn:l,amountOut:p,calculatedOut:b,spotPrice:m,tradeFeePct:d,tradeFeeRange:g,priceImpactPct:f,errors:I,isSupply(){return n.type==="Aave"&&n.tokens[0].id===o.assetIn},isWithdraw(){return n.type==="Aave"&&n.tokens[1].id===o.assetIn},toHuman(){return{...o,amountIn:P.big.toDecimal(l,r.decimalsIn),amountOut:P.big.toDecimal(p,r.decimalsOut),calculatedOut:P.big.toDecimal(b,r.decimalsOut),spotPrice:P.big.toDecimal(m,P.RUNTIME_DECIMALS),tradeFeePct:d,tradeFeeRange:g,priceImpactPct:f,errors:I}}})}return a}async getMostLiquidRoute(t,e){return this.withCtx(t,e,async s=>{let a=this.buildRouteKey(t,e,s.pools),i=this.mlr.get(a);return i||this.calculateMostLiquidRoute(t,e,s)})}async getSpotPrice(t,e){return this.withCtx(t,e,async s=>{let{pools:a,poolsMap:i}=s,o=this.buildRouteKey(t,e,a),n=this.mlr.get(o);n||(n=await this.calculateMostLiquidRoute(t,e,s));let r=await this.toSellSwaps("1",n,i);return{amount:this.getSellSpot(r),decimals:P.RUNTIME_DECIMALS}}).catch(()=>{})}findBestBuyRoute(t){let e=t.sort((s,a)=>{let i=s[0].amountIn,o=a[0].amountIn;return i>o?1:-1});return e.find(s=>s.every(a=>a.errors.length==0))||e[0]}async getBestBuy(t,e,s){return this.getBuy(t,e,s)}getBuySpot(t){let e=t[0];return t.length===1?e.spotPrice:this.calculateSpot(t)}async getBuy(t,e,s,a){return this.withCtx(t,e,async({paths:i,poolsMap:o})=>{let n;if(a)n=await this.toBuySwaps(s,a,o);else{let r=i.map(u=>this.toBuySwaps(s,u,o)),l=await Promise.all(r);n=this.findBestBuyRoute(l)}return this.buildBuy(o,n)})}async getBuys(t,e,s){return this.withCtx(t,e,async({paths:a,poolsMap:i})=>{let o=a.map(r=>this.toBuySwaps(s,r,i));return(await Promise.all(o)).filter(r=>r.every(l=>l.errors.length==0)).map(r=>this.buildBuy(i,r)).sort((r,l)=>r.amountIn>l.amountIn?1:-1)})}buildBuy(t,e){let s=e[e.length-1],a=e[0],i=this.isDirectTrade(e),o=this.getBuySpot(e),n=a.amountIn,r=i?a.calculatedIn:this.calculateDelta0X(s.amountOut,e,t),l=n-r,u=this.getRouteFeeRange(e),p=i?a.tradeFeePct:A.calculateBuyFee(r,n),b=C.mulSpot(s.amountOut,o,s.assetOutDecimals,a.assetInDecimals),d;return r===0n?d=-100:d=A.calculateDiffToRef(b,r),{type:"Buy",amountOut:s.amountOut,amountIn:a.amountIn,spotPrice:o,tradeFee:l,tradeFeePct:p,tradeFeeRange:u,priceImpactPct:d,swaps:e,toHuman(){return{type:"Buy",amountOut:P.big.toDecimal(s.amountOut,s.assetOutDecimals),amountIn:P.big.toDecimal(a.amountIn,a.assetInDecimals),spotPrice:P.big.toDecimal(o,P.RUNTIME_DECIMALS),tradeFee:P.big.toDecimal(l,a.assetInDecimals),tradeFeePct:p,tradeFeeRange:u,priceImpactPct:d,swaps:e.map(I=>I.toHuman())}}}}calculateDelta0X(t,e,s){let a=[];for(let i=e.length-1;i>=0;i--){let o=e[i],n=s.get(o.poolAddress);if(n==null)throw new Error("Pool does not exit");let r=n.parsePair(o.assetIn,o.assetOut),l;i==e.length-1?l=t:l=a[0];let u=n.calculateInGivenOut(r,l);a.unshift(u)}return a[0]}async toBuySwaps(t,e,s){let a=[];for(let i=e.length-1;i>=0;i--){let o=e[i],n=s.get(o.poolAddress);if(n==null)throw new Error("Pool does not exit");let r=n.parsePair(o.assetIn,o.assetOut),l;i==e.length-1?l=typeof t=="string"?P.big.toBigInt(t,r.decimalsOut):t:l=a[0].amountIn;let u=await this.ctx.getPoolFees(r,n),{amountIn:p,calculatedIn:b,feePct:d,errors:I}=n.validateAndBuy(r,l,u),g=this.getPoolFeeRange(u,d),m=n.spotPriceInGivenOut(r),y=C.mulSpot(l,m,r.decimalsOut,r.decimalsIn),f;b===0n?f=-100:f=A.calculateDiffToRef(y,b),a.unshift({...o,assetInDecimals:r.decimalsIn,assetOutDecimals:r.decimalsOut,amountOut:l,amountIn:p,calculatedIn:b,spotPrice:m,tradeFeePct:d,tradeFeeRange:g,priceImpactPct:f,errors:I,isSupply(){return n.type==="Aave"&&n.tokens[0].id===o.assetIn},isWithdraw(){return n.type==="Aave"&&n.tokens[1].id===o.assetIn},toHuman(){return{...o,amountOut:P.big.toDecimal(l,r.decimalsOut),amountIn:P.big.toDecimal(p,r.decimalsIn),calculatedIn:P.big.toDecimal(b,r.decimalsIn),spotPrice:P.big.toDecimal(m,P.RUNTIME_DECIMALS),tradeFeePct:d,tradeFeeRange:g,priceImpactPct:f,errors:I}}})}return a}};var v=require("@galacticcouncil/common");var ge=6e3,$t=1000000000000000n,Pt=6,Xt=-5,Yt=216e5,Hl=3,he=.1,be=6;var zt=require("polkadot-api");var U=class{static build(t){return t.map(({assetIn:e,assetOut:s,pool:a,poolId:i})=>a==="Stableswap"?{pool:(0,zt.Enum)("Stableswap",i),asset_in:e,asset_out:s}:{pool:(0,zt.Enum)(a),asset_in:e,asset_out:s})}};var Et=class{schedulerOptions;router;constructor(t,e={}){this.router=new rt(t),this.router.withFilter({exclude:["HSM"]}),this.schedulerOptions=Object.freeze({blockTime:e.blockTime??6e3,minBudgetInNative:e.minBudgetInNative??$t})}get blockTime(){return this.schedulerOptions.blockTime}get minOrderBudget(){return this.schedulerOptions.minBudgetInNative}async getDcaOrder(t,e,s,a,i){let o=await this.router.getBestSell(t,e,s),{amountIn:n,swaps:r,priceImpactPct:l}=o,u=r[0],p=r[r.length-1],{assetInDecimals:b}=u,{assetOutDecimals:d}=p,I=Math.abs(l),g=await this.getMinimumOrderBudget(t,b),m=this.getOptimalTradeCount(I),y=this.getMaximumTradeCount(n,g,a),f=i||Math.min(m,y),D=Math.round(a/f),R=n/BigInt(f),_=await this.router.getBestSell(t,e,R),Y=n<g,J=[];Y&&J.push("OrderTooSmall");let W=_.amountOut*BigInt(f),ye=this.toBlockPeriod(D),fe=_.tradeFee*BigInt(f),Se=U.build(r),Kt={assetIn:t,assetOut:e,errors:J,maxTradeCount:y,tradeCount:f,tradeFee:fe,tradeImpactPct:_.priceImpactPct,tradePeriod:ye,tradeRoute:Se,type:"Dca"};return{...Kt,amountIn:n,amountOut:W,tradeAmountIn:_.amountIn,tradeAmountOut:_.amountOut,toHuman(){return{...Kt,amountIn:v.big.toDecimal(n,b),amountOut:v.big.toDecimal(W,d),tradeAmountIn:v.big.toDecimal(_.amountIn,b),tradeAmountOut:v.big.toDecimal(_.amountOut,d)}}}}async getMinimumOrderBudget(t,e){if(0===t)return this.minOrderBudget;let s=await this.router.getSpotPrice(0,t);if(s)return C.mulSpot(this.minOrderBudget,s.amount,12,e);let a=await this.router.getSpotPrice(t,0);if(a)return C.divSpot(this.minOrderBudget,a.amount,12,e);throw new Error("Unable to calculate order budget")}getMaximumTradeCount(t,e,s){let a=e*2n/10n;if(a===0n)return 0;let i=Number(t/a),o=Math.floor(s/this.blockTime),n=Math.max(0,Math.floor(o*(1-.1)));return Math.min(i,n)}getOptimalTradeCount(t){let e=Math.round(t*10)||1;return Math.max(e,3)}async getOpenBudgetDcaOrder(t,e,s,a){let i=await this.router.getBestSell(t,e,s),{swaps:o}=i,n=o[0],r=o[o.length-1],{assetInDecimals:l}=n,{assetOutDecimals:u}=r,p=await this.getMinimumOrderBudget(t,l),b=i.amountIn<p,d=[];b&&d.push("OrderTooSmall");let I=this.toBlockPeriod(a),g=U.build(o),m={assetIn:t,assetOut:e,errors:d,maxTradeCount:0,tradeCount:0,tradeFee:i.tradeFee,tradeImpactPct:i.priceImpactPct,tradePeriod:I,tradeRoute:g,type:"Dca"};return{...m,amountIn:0n,amountOut:0n,tradeAmountIn:i.amountIn,tradeAmountOut:i.amountOut,toHuman(){return{...m,amountIn:"0",amountOut:"0",tradeAmountIn:v.big.toDecimal(i.amountIn,l),tradeAmountOut:v.big.toDecimal(i.amountOut,u)}}}}async getTwapSellOrder(t,e,s){let a=await this.router.getBestSell(t,e,s),{amountIn:i,swaps:o,priceImpactPct:n}=a,r=o[0],l=o[o.length-1],{assetInDecimals:u}=r,{assetOutDecimals:p}=l,b=Math.abs(n),d=this.getTwapTradeCount(b),I=i/BigInt(d),[g,m]=await Promise.all([this.getMinimumOrderBudget(t,u),this.router.getBestSell(r.assetIn,l.assetOut,I)]),y=d===1,f=i<g,D=m.priceImpactPct<-5,R=[];f||y?R.push("OrderTooSmall"):D&&R.push("OrderImpactTooBig");let _=m.amountOut*BigInt(d),Y=m.tradeFee*BigInt(d),J=U.build(o),W={assetIn:t,assetOut:e,errors:R,tradeCount:d,tradeImpactPct:m.priceImpactPct,tradePeriod:6,tradeRoute:J,type:"TwapSell"};return{...W,amountIn:i,amountOut:_,tradeAmountIn:m.amountIn,tradeAmountOut:m.amountOut,tradeFee:Y,toHuman(){return{...W,amountIn:v.big.toDecimal(i,u),amountOut:v.big.toDecimal(_,p),tradeAmountIn:v.big.toDecimal(m.amountIn,u),tradeAmountOut:v.big.toDecimal(m.amountOut,p),tradeFee:v.big.toDecimal(Y,p)}}}}async getTwapBuyOrder(t,e,s){let a=await this.router.getBestBuy(t,e,s),{amountOut:i,swaps:o,priceImpactPct:n}=a,r=o[0],l=o[o.length-1],{assetInDecimals:u}=r,{assetOutDecimals:p}=l,b=Math.abs(n),d=this.getTwapTradeCount(b),I=i/BigInt(d),[g,m]=await Promise.all([this.getMinimumOrderBudget(t,u),this.router.getBestBuy(r.assetIn,l.assetOut,I)]),y=m.amountIn*BigInt(d),f=d===1,D=y<g,R=m.priceImpactPct<-5,_=[];D||f?_.push("OrderTooSmall"):R&&_.push("OrderImpactTooBig");let Y=m.tradeFee*BigInt(d),J=U.build(o),W={assetIn:t,assetOut:e,errors:_,tradeCount:d,tradeImpactPct:m.priceImpactPct,tradePeriod:6,tradeRoute:J,type:"TwapBuy"};return{...W,amountIn:y,amountOut:i,tradeAmountIn:m.amountIn,tradeAmountOut:m.amountOut,tradeFee:Y,toHuman(){return{...W,amountIn:v.big.toDecimal(y,u),amountOut:v.big.toDecimal(i,p),tradeAmountIn:v.big.toDecimal(m.amountIn,u),tradeAmountOut:v.big.toDecimal(m.amountOut,p),tradeFee:v.big.toDecimal(Y,u)}}}}getTwapTradeCount(t){let e=this.getOptimalTradeCount(t);if(this.getTwapExecutionTime(e)>216e5){let a=216e5/(this.blockTime*6);return Math.round(a)}return e}getTwapExecutionTime(t){return t*6*this.blockTime}toBlockPeriod(t){let e=t/this.blockTime,s=Math.round(e);return Math.max(s,6)}};0&&(module.exports={DCA_TIME_RESERVE,DEFAULT_BLOCK_TIME,DEFAULT_MIN_BUDGET,ORDER_MIN_BLOCK_PERIOD,Router,TWAP_EXECUTION_INTERVAL,TWAP_MAX_DURATION,TWAP_MAX_PRICE_IMPACT,TWAP_TX_MULTIPLIER,TradeOrderError,TradeOrderType,TradeRouteBuilder,TradeRouter,TradeScheduler,TradeType});
1
+ "use strict";var Te=Object.create;var St=Object.defineProperty;var ve=Object.getOwnPropertyDescriptor;var we=Object.getOwnPropertyNames;var Ie=Object.getPrototypeOf,Oe=Object.prototype.hasOwnProperty;var tt=(c,t)=>{for(var e in t)St(c,e,{get:t[e],enumerable:!0})},Zt=(c,t,e,a)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of we(t))!Oe.call(c,s)&&s!==e&&St(c,s,{get:()=>t[s],enumerable:!(a=ve(t,s))||a.enumerable});return c};var Tt=(c,t,e)=>(e=c!=null?Te(Ie(c)):{},Zt(t||!c||!c.__esModule?St(e,"default",{value:c,enumerable:!0}):e,c)),xe=c=>Zt(St({},"__esModule",{value:!0}),c);var wa={};tt(wa,{DCA_TIME_RESERVE:()=>be,DEFAULT_BLOCK_TIME:()=>ge,DEFAULT_MIN_BUDGET:()=>Kt,ORDER_MIN_BLOCK_PERIOD:()=>he,Router:()=>lt,TWAP_EXECUTION_INTERVAL:()=>ft,TWAP_MAX_DURATION:()=>jt,TWAP_MAX_PRICE_IMPACT:()=>zt,TWAP_TX_MULTIPLIER:()=>nu,TradeOrderError:()=>Xt,TradeOrderType:()=>Yt,TradeRouteBuilder:()=>V,TradeRouter:()=>ct,TradeScheduler:()=>kt,TradeType:()=>Wt});module.exports=xe(wa);var ut=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 Ae=10,pt=class{isNotVisited(t,e){let a=!0;return e.forEach(s=>{(s[0]===t[0]||s[1]===t[1])&&(a=!1)}),a}findPaths(t,e,a){let s=[],n=new ut,i=[];for(i.push([e,""]),n.enqueue(i);n.size()>0;){let r=n.dequeue();if(!r||r.length>Ae)continue;let o=r[r.length-1];(a===null||o[0]===a)&&s.push(r),t.get(o[0])?.forEach(u=>{if(this.isNotVisited(u,r)){let m=[...r];m.push(u),n.enqueue(m)}})}return s}findShortestPaths(t,e,a){let s=[],n=new ut,i=[];i.push([e,""]),n.enqueue(i);let r=1/0;for(;n.size()>0;){let o=n.dequeue();if(!o)continue;let l=o[o.length-1];if(l[0]===a){o.length<r?(r=o.length,s.length=0,s.push(o)):o.length===r&&s.push(o);continue}let u=t.get(l[0]);for(let m of u??[])this.isNotVisited(m,o)&&n.enqueue([...o,m])}return s}buildAndPopulateGraph(t,e){let a=new Map;for(let s of t)a.set(parseInt(s),[]);for(let[s,n,i]of e)a.get(n)?.push([i,s]);return a}};function Mt(c){let t={};for(let e of c){let a=e.tokens.length;for(let s=0;s<a;s++){t[e.tokens[s].id]||(t[e.tokens[s].id]=[]);for(let n=0;n<a;n++){if(s==n)continue;let i=[e.address,e.tokens[s].id,e.tokens[n].id];t[e.tokens[s].id].push(i)}}}return t}var N=require("@galacticcouncil/math-lbp"),G=class{static getSpotPrice(t,e,a,s,n){return(0,N.get_spot_price)(t,e,a,s,n)}static calculateInGivenOut(t,e,a,s,n){return(0,N.calculate_in_given_out)(t,e,a,s,n)}static calculateOutGivenIn(t,e,a,s,n){return(0,N.calculate_out_given_in)(t,e,a,s,n)}static calculateLinearWeights(t,e,a,s,n){return(0,N.calculate_linear_weights)(t,e,a,s,n)}static calculatePoolTradeFee(t,e,a){return(0,N.calculate_pool_trade_fee)(t,e,a)}};var et=require("@galacticcouncil/common");var vt={};tt(vt,{withTimeout:()=>Be});function Be(c,t,e="timeout"){return new Promise((a,s)=>{let n=setTimeout(()=>s(new Error(e)),t);c.then(i=>{clearTimeout(n),a(i)},i=>{clearTimeout(n),s(i)})})}var k={};tt(k,{divSpot:()=>Fe,getFraction:()=>Re,mulScaled:()=>te,mulSpot:()=>Ee});var Dt=require("@galacticcouncil/common");function te(c,t,e,a,s){let n=e+a-s,i=c*t;return n>0?i/BigInt(10)**BigInt(n):n<0?i*BigInt(10)**BigInt(-n):i}function Ee(c,t,e,a){return te(c,t,e,Dt.RUNTIME_DECIMALS,a)}function Fe(c,t,e,a){if(t===0n)return 0n;let s=BigInt(10)**BigInt(Dt.RUNTIME_DECIMALS+a-e);return c*s/t}function Re(c,t,e=2){if(t<.01||t>100)throw new Error("Supported range is from 0.01% - 100%");let a=BigInt(10)**BigInt(e),s=BigInt(Math.round(t*Number(a)));return c*s/(BigInt(100)*a)}var f={};tt(f,{FeeUtils:()=>Lt,shiftNeg:()=>Ce});var ee=Tt(require("big.js"));var Lt=class c{static toPct(t){let[e,a]=t;return c.safeDivide(e*100,a)}static toRaw(t){let[e,a]=t;return c.safeDivide(e,a)}static fromPermill(t){return[t,1e6]}static fromPerbill(t){return[t,1e9]}static fromRate(t,e){return[t,e]}static safeDivide(t,e,a=12){let s=10**a;return Math.round(t*s/e)/s}static safeRound(t){return parseFloat(t.toPrecision(15))}};function Ce(c,t){let e=(0,ee.default)(typeof c=="bigint"?c.toString():c);return t===0?e.toString():e.div(Math.pow(10,t)).toString()}var mt={};tt(mt,{findNestedKey:()=>ke,findNestedObj:()=>Me,jsonFormatter:()=>De});var ke=(c,t)=>{let e=[];return JSON.stringify(c,(a,s)=>(s&&s[t]&&e.push(s),s)),e[0]},Me=(c,t,e)=>{let a;return JSON.stringify(c,(s,n)=>(n&&n[t]===e&&(a=n),n)),a},De=(c,t)=>typeof t=="bigint"?t.toString():t;var B={};tt(B,{calculateBuyFee:()=>qe,calculateDiffToAvg:()=>Le,calculateDiffToRef:()=>Ne,calculateSellFee:()=>He});var H=Tt(require("big.js"));function Le(c,t){let e=(0,H.default)(c.toString()),a=(0,H.default)(t.toString());return e.minus(a).abs().div(e.plus(a).div(2)).mul(100).round(2).toNumber()}function Ne(c,t){if(t===0n)return 0;let e=(0,H.default)(c.toString()),a=(0,H.default)(t.toString());return e.minus(a).div(a).mul(100).round(2).toNumber()}function He(c,t){if(c===0n)return 0;let e=(0,H.default)(c.toString()),a=(0,H.default)(t.toString());return(0,H.default)(1).minus(a.div(e)).mul(100).round(2).toNumber()}function qe(c,t){if(c===0n)return 0;let e=(0,H.default)(c.toString());return(0,H.default)(t.toString()).div(e).minus(1).mul(100).round(2).toNumber()}var{FeeUtils:ae}=f,wt=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 a=new Map(this.tokens.map(i=>[i.id,i])),s=a.get(t),n=a.get(e);if(s==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:s.balance,balanceOut:n.balance,decimalsIn:s.decimals,decimalsOut:n.decimals,weightIn:s.weight,weightOut:n.weight}}validateAndBuy(t,e,a){let s=this.tokens[0].id,n=[];e<this.minTradingLimit&&n.push("InsufficientTradingAmount");let i=t.balanceOut/this.maxOutRatio;if(e>i&&n.push("MaxOutRatioExceeded"),s===t.assetOut){let r=this.calculateTradeFee(e,a),o=ae.toPct(this.repayFeeApply?a.repayFee:a.exchangeFee),l=e+r,u=this.calculateInGivenOut(t,l),m=t.balanceIn/this.maxInRatio;return u>m&&n.push("MaxInRatioExceeded"),{amountIn:u,calculatedIn:u,amountOut:e,feePct:o,errors:n}}else{let r=this.calculateInGivenOut(t,e),o=t.balanceIn/this.maxInRatio;return r>o&&n.push("MaxInRatioExceeded"),{amountIn:r,calculatedIn:r,amountOut:e,feePct:0,errors:n}}}validateAndSell(t,e,a){let s=this.tokens[0].id,n=[];e<this.minTradingLimit&&n.push("InsufficientTradingAmount");let i=t.balanceIn/this.maxInRatio;if(e>i&&n.push("MaxInRatioExceeded"),s===t.assetIn){let r=this.calculateOutGivenIn(t,e),o=t.balanceOut/this.maxOutRatio;return r>o&&n.push("MaxOutRatioExceeded"),{amountIn:e,calculatedOut:r,amountOut:r,feePct:0,errors:n}}else{let r=this.calculateOutGivenIn(t,e),o=this.calculateTradeFee(r,a),l=ae.toPct(this.repayFeeApply?a.repayFee:a.exchangeFee),u=r-o,m=t.balanceOut/this.maxOutRatio;return u>m&&n.push("MaxOutRatioExceeded"),{amountIn:e,calculatedOut:r,amountOut:u,feePct:l,errors:n}}}calculateInGivenOut(t,e){let a=G.calculateInGivenOut(t.balanceIn.toString(),t.balanceOut.toString(),t.weightIn.toString(),t.weightOut.toString(),e.toString()),s=BigInt(a);return s<0n?0n:s}calculateOutGivenIn(t,e){let a=G.calculateOutGivenIn(t.balanceIn.toString(),t.balanceOut.toString(),t.weightIn.toString(),t.weightOut.toString(),e.toString()),s=BigInt(a);return s<0n?0n:s}spotPriceInGivenOut(t){let e=G.getSpotPrice(t.balanceOut.toString(),t.balanceIn.toString(),t.weightOut.toString(),t.weightIn.toString(),et.big.toBigInt(1,et.RUNTIME_DECIMALS).toString());return BigInt(e)}spotPriceOutGivenIn(t){let e=G.getSpotPrice(t.balanceIn.toString(),t.balanceOut.toString(),t.weightIn.toString(),t.weightOut.toString(),et.big.toBigInt(1,et.RUNTIME_DECIMALS).toString());return BigInt(e)}calculateTradeFee(t,e){let a=G.calculatePoolTradeFee(t.toString(),this.repayFeeApply?e.repayFee[0]:e.exchangeFee[0],this.repayFeeApply?e.repayFee[1]:e.exchangeFee[1]);return BigInt(a)}};var Ye=require("polkadot-api"),At=require("rxjs");var U=require("rxjs"),R=require("rxjs/operators");var qt=require("@galacticcouncil/descriptors");var se=require("@galacticcouncil/common"),Ht=require("rxjs");var It=require("rxjs"),Y=require("rxjs/operators");var{logger:Za}=se.log;var Ge=require("polkadot-api/ws"),Ue=require("polkadot-api/logs-provider");var Ve=require("polkadot-api");var ne=require("@galacticcouncil/common"),xt=require("rxjs"),M=require("rxjs/operators");var{logger:fs}=ne.log;var We=require("rxjs");var ie=require("@galacticcouncil/common");var _s={Aave:"AAVE",LBP:"LBP",Omnipool:"OMNI",Stableswap:"STBL",XYK:"XYK",HSM:"HSM"},{logger:Cs}=ie.log;var{withTimeout:js}=vt;var b=require("@galacticcouncil/math-omnipool"),j=Tt(require("big.js")),v=class{static calculateSpotPrice(t,e,a,s){return(0,b.calculate_spot_price)(t,e,a,s)}static calculateLrnaSpotPrice(t,e){return(0,b.calculate_lrna_spot_price)(t,e)}static calculateInGivenOut(t,e,a,s,n,i,r,o,l,u){return(0,b.calculate_in_given_out)(t,e,a,s,n,i,r,o,l,u)}static calculateLrnaInGivenOut(t,e,a,s,n,i){return(0,b.calculate_lrna_in_given_out)(t,e,a,s,n,i)}static calculateOutGivenIn(t,e,a,s,n,i,r,o,l,u){return(0,b.calculate_out_given_in)(t,e,a,s,n,i,r,o,l,u)}static calculateOutGivenLrnaIn(t,e,a,s,n,i){return(0,b.calculate_out_given_lrna_in)(t,e,a,s,n,i)}static calculateShares(t,e,a,s){return(0,b.calculate_shares)(t,e,a,s)}static calculateLiquidityOut(t,e,a,s,n,i,r,o){return(0,b.calculate_liquidity_out)(t,e,a,s,n,i,r,o)}static calculateLiquidityLRNAOut(t,e,a,s,n,i,r,o){return(0,b.calculate_liquidity_lrna_out)(t,e,a,s,n,i,r,o)}static calculateCapDifference(t,e,a,s){let n=(0,j.default)(e),i=(0,j.default)(t),r=(0,j.default)(s),o=(0,j.default)(a),l=(0,j.default)(10).pow(18),u=o.div(l);if(n.div(r).lt(u)){let h=u.times(r).minus(n).times(i),d=n.times((0,j.default)(1).minus(u));return h.div(d).toFixed(0)}else return"0"}static calculateLimitHubIn(t,e,a,s){return(0,b.calculate_liquidity_hub_in)(t,e,a,s)}static isSellAllowed(t){return(0,b.is_sell_allowed)(t)}static isBuyAllowed(t){return(0,b.is_buy_allowed)(t)}static isAddLiquidityAllowed(t){return(0,b.is_add_liquidity_allowed)(t)}static isRemoveLiquidityAllowed(t){return(0,b.is_remove_liquidity_allowed)(t)}static recalculateAssetFee(t,e,a,s,n,i,r,o,l,u,m){return(0,b.recalculate_asset_fee)(t,e,a,s,n,i,r,o,l,u,m)}static recalculateProtocolFee(t,e,a,s,n,i,r,o,l,u,m){return(0,b.recalculate_protocol_fee)(t,e,a,s,n,i,r,o,l,u,m)}static verifyAssetCap(t,e,a,s){return(0,b.verify_asset_cap)(t,e,a,s)}};var re=require("@galacticcouncil/common");var{FeeUtils:q}=f,Bt=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 a=new Map(this.tokens.map(i=>[i.id,i])),s=a.get(t),n=a.get(e);if(s==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:s.hubReserves,hubReservesOut:n.hubReserves,sharesIn:s.shares,sharesOut:n.shares,decimalsIn:s.decimals,decimalsOut:n.decimals,balanceIn:s.balance,balanceOut:n.balance,tradeableIn:s.tradeable,tradeableOut:n.tradeable,assetInEd:s.existentialDeposit,assetOutEd:n.existentialDeposit}}validateAndBuy(t,e,a){let s=this.calculateInGivenOut(t,e),n=this.calculateInGivenOut(t,e,a),i=s===0n?0:B.calculateBuyFee(s,n),r=[],o=v.isSellAllowed(t.tradeableIn),l=v.isBuyAllowed(t.tradeableOut);(!o||!l)&&r.push("TradeNotAllowed"),(e<this.minTradingLimit||s<t.assetInEd)&&r.push("InsufficientTradingAmount");let u=t.balanceOut/this.maxOutRatio;e>u&&r.push("MaxOutRatioExceeded");let m=t.balanceIn/this.maxInRatio;return n>m&&r.push("MaxInRatioExceeded"),{amountIn:n,calculatedIn:s,amountOut:e,feePct:i,errors:r}}validateAndSell(t,e,a){let s=this.calculateOutGivenIn(t,e),n=this.calculateOutGivenIn(t,e,a),i=B.calculateSellFee(s,n),r=[],o=v.isSellAllowed(t.tradeableIn),l=v.isBuyAllowed(t.tradeableOut);(!o||!l)&&r.push("TradeNotAllowed"),(e<this.minTradingLimit||s<t.assetOutEd)&&r.push("InsufficientTradingAmount");let u=t.balanceIn/this.maxInRatio;e>u&&r.push("MaxInRatioExceeded");let m=t.balanceOut/this.maxOutRatio;return n>m&&r.push("MaxOutRatioExceeded"),{amountIn:e,calculatedOut:s,amountOut:n,feePct:i,errors:r}}calculateInGivenOut(t,e,a){if(t.assetIn==this.hubAssetId)return this.calculateLrnaInGivenOut(t,e,a);let s=v.calculateInGivenOut(t.balanceIn.toString(),t.hubReservesIn.toString(),t.sharesIn.toString(),t.balanceOut.toString(),t.hubReservesOut.toString(),t.sharesOut.toString(),e.toString(),a?q.toRaw(a.assetFee).toString():"0",a?q.toRaw(a.protocolFee).toString():"0",a?q.toRaw(a.maxSlipFee).toString():"0"),n=BigInt(s);return n<0n?0n:n}calculateLrnaInGivenOut(t,e,a){let s=v.calculateLrnaInGivenOut(t.balanceOut.toString(),t.hubReservesOut.toString(),t.sharesOut.toString(),e.toString(),a?q.toRaw(a.assetFee).toString():"0",a?q.toRaw(a.maxSlipFee).toString():"0"),n=BigInt(s);return n<0n?0n:n}calculateOutGivenIn(t,e,a){if(t.assetIn==this.hubAssetId)return this.calculateOutGivenLrnaIn(t,e,a);let s=v.calculateOutGivenIn(t.balanceIn.toString(),t.hubReservesIn.toString(),t.sharesIn.toString(),t.balanceOut.toString(),t.hubReservesOut.toString(),t.sharesOut.toString(),e.toString(),a?q.toRaw(a.assetFee).toString():"0",a?q.toRaw(a.protocolFee).toString():"0",a?q.toRaw(a.maxSlipFee).toString():"0"),n=BigInt(s);return n<0n?0n:n}calculateOutGivenLrnaIn(t,e,a){let s=v.calculateOutGivenLrnaIn(t.balanceOut.toString(),t.hubReservesOut.toString(),t.sharesOut.toString(),e.toString(),a?q.toRaw(a.assetFee).toString():"0",a?q.toRaw(a.maxSlipFee).toString():"0"),n=BigInt(s);return n<0n?0n:n}spotPriceInGivenOut(t){if(t.assetIn==this.hubAssetId)return this.spotPriceLrnaInGivenOut(t);let e=v.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=v.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=v.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=v.calculateLrnaSpotPrice(t.balanceOut.toString(),t.hubReservesOut.toString());return this.normalizeSpot(BigInt(e),t.decimalsIn,t.decimalsOut)}normalizeSpot(t,e,a){let s=e-a;if(s===0)return t;let n=re.big.pow10(Math.abs(s));return s>0?t*n:t/n}};var Q=require("polkadot-api"),Qe=require("@polkadot-api/utils"),J=require("rxjs"),Je=require("@galacticcouncil/common");var{FeeUtils:An}=f;var{FeeUtils:Gn}=f,Un=Q.Binary.toHex(Q.Binary.fromText("omnipool")),Vn=(0,Q.Enum)("Short");var O=require("@galacticcouncil/math-stableswap"),C=class{static getPoolAddress(t){return(0,O.pool_account_name)(t)}static defaultPegs(t){let e=[];for(let a=0;a<t;a++)e.push(["1","1"]);return e}static calculateAmplification(t,e,a,s,n){return(0,O.calculate_amplification)(t,e,a,s,n)}static calculateInGivenOut(t,e,a,s,n,i,r){return(0,O.calculate_in_given_out)(t,e,a,s,n,i,r)}static calculateAddOneAsset(t,e,a,s,n,i,r){return(0,O.calculate_add_one_asset)(t,e,a,s,n,i,r)}static calculateSharesForAmount(t,e,a,s,n,i,r){return(0,O.calculate_shares_for_amount)(t,e,a,s,n,i,r)}static calculateOutGivenIn(t,e,a,s,n,i,r){return(0,O.calculate_out_given_in)(t,e,a,s,n,i,r)}static calculateLiquidityOutOneAsset(t,e,a,s,n,i,r){return(0,O.calculate_liquidity_out_one_asset)(t,e,a,s,n,i,r)}static calculateShares(t,e,a,s,n,i){return(0,O.calculate_shares)(t,e,a,s,n,i)}static calculateSpotPriceWithFee(t,e,a,s,n,i,r,o){return(0,O.calculate_spot_price_with_fee)(t,e,a,s,n,i,r,o)}static recalculatePegs(t,e,a,s,n,i){let r=(0,O.recalculate_peg)(t,e,a,s,n,i);return JSON.parse(r)}};var bt=require("@galacticcouncil/common");var{FeeUtils:at}=f,st=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 a=new Map(this.tokens.map(i=>[i.id,i])),s=a.get(t),n=a.get(e);if(s==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:s.balance,balanceOut:n.balance,decimalsIn:s.decimals,decimalsOut:n.decimals,tradeableIn:this.id===t?15:s.tradeable,tradeableOut:this.id===e?15:n.tradeable,assetInEd:s.existentialDeposit,assetOutEd:n.existentialDeposit}}validateAndBuy(t,e,a){let s=this.calculateInGivenOut(t,e),n=this.calculateInGivenOut(t,e,a),i=s===0n?0:B.calculateBuyFee(s,n),r=[],o=v.isSellAllowed(t.tradeableIn),l=v.isBuyAllowed(t.tradeableOut);return(!o||!l)&&r.push("TradeNotAllowed"),(e<this.minTradingLimit||s<t.assetInEd)&&r.push("InsufficientTradingAmount"),{amountIn:n,calculatedIn:s,amountOut:e,feePct:i,errors:r}}validateAndSell(t,e,a){let s=this.calculateOutGivenIn(t,e),n=this.calculateOutGivenIn(t,e,a),i=B.calculateSellFee(s,n),r=[],o=v.isSellAllowed(t.tradeableIn),l=v.isBuyAllowed(t.tradeableOut);return(!o||!l)&&r.push("TradeNotAllowed"),(e<this.minTradingLimit||s<t.assetOutEd)&&r.push("InsufficientTradingAmount"),{amountIn:e,calculatedOut:s,amountOut:n,feePct:i,errors:r}}calculateIn(t,e,a){let s=C.calculateInGivenOut(this.getReserves(),Number(t.assetIn),Number(t.assetOut),e.toString(),this.amplification.toString(),a?at.toRaw(a.fee).toString():"0",this.getPegs()),n=BigInt(s);return n<0n?0n:n}calculateAddOneAsset(t,e,a){let s=C.calculateAddOneAsset(this.getReserves(),e.toString(),Number(t.assetIn),this.amplification.toString(),this.totalIssuance.toString(),a?at.toRaw(a.fee).toString():"0",this.getPegs()),n=BigInt(s);return n<0n?0n:n}calculateSharesForAmount(t,e,a){let s=C.calculateSharesForAmount(this.getReserves(),Number(t.assetOut),e.toString(),this.amplification.toString(),this.totalIssuance.toString(),a?at.toRaw(a.fee).toString():"0",this.getPegs()),n=BigInt(s);return n<0n?0n:n}calculateInGivenOut(t,e,a){return t.assetOut==this.id?this.calculateAddOneAsset(t,e,a):t.assetIn==this.id?this.calculateSharesForAmount(t,e,a):this.calculateIn(t,e,a)}spotPriceInGivenOut(t){let e=C.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,a){let s=C.calculateOutGivenIn(this.getReserves(),Number(t.assetIn),Number(t.assetOut),e.toString(),this.amplification.toString(),a?at.toRaw(a.fee).toString():"0",this.getPegs()),n=BigInt(s);return n<0n?0n:n}calculateWithdrawOneAsset(t,e,a){let s=C.calculateLiquidityOutOneAsset(this.getReserves(),e.toString(),Number(t.assetOut),this.amplification.toString(),this.totalIssuance.toString(),a?at.toRaw(a.fee).toString():"0",this.getPegs()),n=BigInt(s);return n<0n?0n:n}calculateShares(t,e,a){let s=C.calculateShares(this.getReserves(),this.getAssets(t.assetIn,e),this.amplification.toString(),this.totalIssuance.toString(),a?at.toRaw(a.fee).toString():"0",this.getPegs()),n=BigInt(s);return n<0n?0n:n}calculateOutGivenIn(t,e,a){return t.assetIn==this.id?this.calculateWithdrawOneAsset(t,e,a):t.assetOut==this.id?this.calculateShares(t,e,a):this.calculateOut(t,e,a)}spotPriceOutGivenIn(t){let e=C.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:a,decimals:s})=>({asset_id:e,amount:a,decimals:s}));return JSON.stringify(t,mt.jsonFormatter)}getAssets(t,e){let a={asset_id:Number(t),amount:e.toString()};return JSON.stringify([a],mt.jsonFormatter)}normalizeSpot(t,e,a,s,n){return e?t*bt.big.pow10(bt.RUNTIME_DECIMALS-n):a?t/bt.big.pow10(n-s):t}};var oe=require("polkadot-api"),na=require("@polkadot-api/utils"),ia=require("@noble/hashes/blake2b"),nt=require("rxjs"),le=require("@galacticcouncil/common");var ta=require("polkadot-api"),ea=require("viem");var{FeeUtils:Ri}=f;var{FeeUtils:Ji}=f;var x=require("@galacticcouncil/math-xyk"),X=class{static getSpotPrice(t,e,a){return(0,x.get_spot_price)(t,e,a)}static calculateInGivenOut(t,e,a){return(0,x.calculate_in_given_out)(t,e,a)}static calculateOutGivenIn(t,e,a){return(0,x.calculate_out_given_in)(t,e,a)}static calculatePoolTradeFee(t,e,a){return(0,x.calculate_pool_trade_fee)(t,e,a)}static calculateLiquidityIn(t,e,a){return(0,x.calculate_liquidity_in)(t,e,a)}static calculateSpotPrice(t,e){return(0,x.calculate_spot_price)(t,e)}static calculateSpotPriceWithFee(t,e,a,s){return(0,x.calculate_spot_price_with_fee)(t,e,a,s)}static calculateShares(t,e,a){return(0,x.calculate_shares)(t,e,a)}static calculateLiquidityOutAssetA(t,e,a,s){return(0,x.calculate_liquidity_out_asset_a)(t,e,a,s)}static calculateLiquidityOutAssetB(t,e,a,s){return(0,x.calculate_liquidity_out_asset_b)(t,e,a,s)}};var ue=require("@galacticcouncil/common");var{FeeUtils:ce}=f,Et=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 a=new Map(this.tokens.map(i=>[i.id,i])),s=a.get(t),n=a.get(e);if(s==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:s.decimals,decimalsOut:n.decimals,balanceIn:s.balance,balanceOut:n.balance,assetInEd:s.existentialDeposit,assetOutEd:n.existentialDeposit}}validateAndBuy(t,e,a){let s=this.calculateInGivenOut(t,e),n=this.calculateTradeFee(s,a),i=ce.toPct(a.exchangeFee),r=s+n,o=[];(e<this.minTradingLimit||s<t.assetInEd)&&o.push("InsufficientTradingAmount");let l=t.balanceOut/this.maxOutRatio;e>l&&o.push("MaxOutRatioExceeded");let u=t.balanceIn/this.maxInRatio;return r>u&&o.push("MaxInRatioExceeded"),{amountIn:r,calculatedIn:s,amountOut:e,feePct:i,errors:o}}validateAndSell(t,e,a){let s=this.calculateOutGivenIn(t,e),n=this.calculateTradeFee(s,a),i=ce.toPct(a.exchangeFee),r=s-n,o=[];(e<this.minTradingLimit||s<t.assetOutEd)&&o.push("InsufficientTradingAmount");let l=t.balanceIn/this.maxInRatio;e>l&&o.push("MaxInRatioExceeded");let u=t.balanceOut/this.maxOutRatio;return r>u&&o.push("MaxOutRatioExceeded"),{amountIn:e,calculatedOut:s,amountOut:r,feePct:i,errors:o}}calculateInGivenOut(t,e){let a=X.calculateInGivenOut(t.balanceIn.toString(),t.balanceOut.toString(),e.toString()),s=BigInt(a);return s<0n?0n:s}calculateOutGivenIn(t,e){let a=X.calculateOutGivenIn(t.balanceIn.toString(),t.balanceOut.toString(),e.toString()),s=BigInt(a);return s<0n?0n:s}spotPriceInGivenOut(t){let e=X.calculateSpotPrice(t.balanceOut.toString(),t.balanceIn.toString());return this.normalizeSpot(BigInt(e),t.decimalsOut,t.decimalsIn)}spotPriceOutGivenIn(t){let e=X.calculateSpotPrice(t.balanceIn.toString(),t.balanceOut.toString());return this.normalizeSpot(BigInt(e),t.decimalsIn,t.decimalsOut)}calculateTradeFee(t,e){let a=X.calculatePoolTradeFee(t.toString(),e.exchangeFee[0],e.exchangeFee[1]);return BigInt(a)}normalizeSpot(t,e,a){let s=e-a;if(s===0)return t;let n=ue.big.pow10(Math.abs(s));return s>0?t*n:t/n}};var oa=require("polkadot-api"),la=require("rxjs");var it=require("@galacticcouncil/common");var Ft=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 a=new Map(this.tokens.map(i=>[i.id,i])),s=a.get(t),n=a.get(e);if(s==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:s.balance,balanceOut:n.balance,decimalsIn:s.decimals,decimalsOut:n.decimals,assetInEd:0n,assetOutEd:0n}}validateAndBuy(t,e,a){let s=this.calculateInGivenOut(t,e),n=[];return e>t.balanceOut&&n.push("TradeNotAllowed"),{amountIn:s,calculatedIn:s,amountOut:e,feePct:0,errors:n}}validateAndSell(t,e,a){let s=this.calculateOutGivenIn(t,e),n=[];return s>t.balanceOut&&n.push("TradeNotAllowed"),{amountIn:e,calculatedOut:s,amountOut:s,feePct:0,errors:n}}calculateInGivenOut(t,e){return e}calculateOutGivenIn(t,e){return e}spotPriceInGivenOut(t){return it.big.toBigInt(1,it.RUNTIME_DECIMALS)}spotPriceOutGivenIn(t){return it.big.toBigInt(1,it.RUNTIME_DECIMALS)}calculateTradeFee(t,e){return 0n}};var ga=require("polkadot-api"),ba=require("@polkadot-api/utils"),Rt=require("rxjs"),Ut=require("@galacticcouncil/common");var $r=BigInt("0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");var pa=require("polkadot-api"),ma=require("viem");var da=Tt(require("big.js")),ht=require("@galacticcouncil/common");var{ERC20:so}=ht.erc20,{H160:no}=ht.h160;var io=10n**27n;var{ERC20:wo}=Ut.erc20;var A=require("@galacticcouncil/math-hsm"),D=class{static calculateCollateralInGivenHollarOut(t,e,a){return(0,A.calculate_collateral_in_given_hollar_out)(t,e,a)}static calculateCollateralOutGivenHollarIn(t,e,a){return(0,A.calculate_collateral_out_given_hollar_in)(t,e,a)}static calculateHollarOutGivenCollateralIn(t,e,a){return(0,A.calculate_hollar_out_given_collateral_in)(t,e,a)}static calculateHollarInGivenCollateralOut(t,e,a){return(0,A.calculate_hollar_in_given_collateral_out)(t,e,a)}static calculateImbalance(t,e,a){return(0,A.calculate_imbalance)(t,e,a)}static calculateBuybackLimit(t,e){return(0,A.calculate_buyback_limit)(t,e)}static calculateBuybackPriceWithFee(t,e,a){return(0,A.calculate_buyback_price_with_fee)(t,e,a)}static calculateMaxPrice(t,e){return(0,A.calculate_max_price)(t,e)}};var E=require("@galacticcouncil/common");var{FeeUtils:rt}=f,_t=class c extends st{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,a){let s=this.parsePair(t.assetOut,t.assetIn),n=super.calculateInGivenOut(s,e,{fee:this.fee}),i=this.calculateBuybackLimit(t);e>i&&a.push("MaxBuyBackExceeded");let r=this.calculateMaxPrice(t);return this.calculateBuyPrice(t,e,n)>r&&a.push("MaxBuyPriceExceeded"),n>this.collateralBalance&&a.push("InsufficientCollateral"),a}validateTradeHollarOut(t,e,a){return this.collateralBalance+t>this.maxInHolding&&a.push("MaxHoldingExceeded"),e>this.hsmMintCapacity&&a.push("FacilitatorCapacityExceeded"),a}validateTradeConstraints(t,e,a){let s=[];return t.assetIn===this.hollarId?this.validateTradeHollarIn(t,e,s):this.validateTradeHollarOut(e,a,s)}validateAndBuy(t,e){let a=this.calculateInGivenOut(t,e),s=this.validateTradeConstraints(t,a,e);return{amountIn:a,calculatedIn:a,amountOut:e,feePct:0,errors:s}}validateAndSell(t,e){let a=this.calculateOutGivenIn(t,e),s=this.validateTradeConstraints(t,e,a);return{amountIn:e,calculatedOut:a,amountOut:a,feePct:0,errors:s}}calculateHollarInGivenCollateralOut(t,e){let a=super.calculateInGivenOut(t,e,{fee:this.fee}),s=D.calculateHollarInGivenCollateralOut(e.toString(),a.toString(),rt.toRaw(this.buyBackFee).toString());return BigInt(s)}calculateCollateralInGivenHollarOut(t){let e=this.getCollateralPeg(),a=D.calculateCollateralInGivenHollarOut(t.toString(),JSON.stringify(e),rt.toRaw(this.purchaseFee).toString());return BigInt(a)}calculateInGivenOut(t,e){return t.assetOut==this.hollarId?this.calculateCollateralInGivenHollarOut(e):this.calculateHollarInGivenCollateralOut(t,e)}calculateCollateralOutGivenHollarIn(t,e){let a=super.calculateOutGivenIn(t,e,{fee:this.fee}),s=D.calculateCollateralOutGivenHollarIn(e.toString(),a.toString(),rt.toRaw(this.buyBackFee).toString());return BigInt(s)}calculateHollarOutGivenCollateralIn(t){let e=this.getCollateralPeg(),a=D.calculateHollarOutGivenCollateralIn(t.toString(),JSON.stringify(e),rt.toRaw(this.purchaseFee).toString());return BigInt(a)}calculateOutGivenIn(t,e){return t.assetIn==this.hollarId?this.calculateCollateralOutGivenHollarIn(t,e):this.calculateHollarOutGivenCollateralIn(e)}calculateImbalance(t){let e=this.getCollateralPeg(),a=D.calculateImbalance(t.balanceIn.toString(),JSON.stringify(e),t.balanceOut.toString());return BigInt(a)}calculateBuybackLimit(t){let e=this.calculateImbalance(t),a=D.calculateBuybackLimit(e.toString(),rt.toRaw(this.buyBackRate).toString());return BigInt(a)}calculateBuyPrice(t,e,a){let s=D.calculateBuybackPriceWithFee(a.toString(),e.toString(),rt.toRaw(this.buyBackFee).toString()),[n,i]=JSON.parse(s),r=E.big.pow10(t.decimalsIn+E.RUNTIME_DECIMALS-t.decimalsOut);return BigInt(n)*r/BigInt(i)}calculateMaxPrice(t){let e=this.getCollateralPeg(),a=D.calculateMaxPrice(JSON.stringify(e),this.maxBuyPriceCoefficient.toString()),[s,n]=JSON.parse(a),i=E.big.pow10(E.RUNTIME_DECIMALS-t.decimalsOut);return BigInt(s)*i/BigInt(n)}spotPriceInGivenOut(t){let e=E.big.toBigInt(1,t.decimalsOut),s=this.calculateInGivenOut(t,e)*E.big.pow10(E.RUNTIME_DECIMALS-t.decimalsOut);return this.normalizeSpotPrice(s,t.decimalsOut,t.decimalsIn)}spotPriceOutGivenIn(t){let e=E.big.toBigInt(1,t.decimalsIn),s=this.calculateOutGivenIn(t,e)*E.big.pow10(E.RUNTIME_DECIMALS-t.decimalsIn);return this.normalizeSpotPrice(s,t.decimalsIn,t.decimalsOut)}getCollateralPeg(){let t=this.tokens.findIndex(s=>s.id!==this.hollarId),e=this.pegs[t],a=this.tokens[t].decimals;return this.isDefaultPeg(e)?[E.big.toBigInt(1,18).toString(),E.big.toBigInt(1,a).toString()]:e}isDefaultPeg(t){let[e,a]=t;return Array.isArray(t)&&t.length===2&&e==="1"&&a==="1"}normalizeSpotPrice(t,e,a){let s=e-a;if(s===0)return t;let n=E.big.pow10(Math.abs(s));return s>0?t*n:t/n}};var pe=require("polkadot-api"),Sa=require("@polkadot-api/utils"),ot=require("rxjs"),Vt=require("@galacticcouncil/common");var Pa=require("polkadot-api"),fa=require("viem");var{FeeUtils:rl}=f,{H160:ol}=Vt.h160;var yt=class{static get(t){switch(t.type){case"Aave":return Ft.fromPool(t);case"XYK":return Et.fromPool(t);case"Omnipool":return Bt.fromPool(t);case"LBP":return wt.fromPool(t);case"Stableswap":return st.fromPool(t);case"HSM":return _t.fromPool(t);default:throw new Error("Pool type "+t.type+" is not supported yet")}}};var me=require("@galacticcouncil/common"),$t=require("rxjs");var Ct=class extends Error{constructor(t,e){super(),this.message=`Route from ${t} to ${e} not found in current configuration`,this.name="RouteNotFound"}};var{logger:zl}=me.log;var Pt=class{getProposals(t,e,a){let s=a.filter(p=>p.type==="XYK"),n=a.filter(p=>p.type!=="XYK"),i=new Set(n.map(p=>p.tokens).flat().map(p=>p.id)),r=i.has(t),o=i.has(e),l=new pt,u=p=>{let y=Mt(p),T=Object.keys(y),L=T.flatMap(_=>y[_]);return l.buildAndPopulateGraph(T,L)};if(!r&&!o){let p=s.filter(L=>L.tokens.find(_=>_.id===t)||L.tokens.find(_=>_.id===e)),y=u(p),T=l.findPaths(y,t,e);return this.parsePaths(T)}if(r&&o){let p=u(n),y=l.findPaths(p,t,e);return this.parsePaths(y)}let m=r?e:t,h=s.filter(p=>p.tokens.some(y=>y.id===m));if(h.length===0)return[];let d=[...n,...h],S=u(d),g=l.findPaths(S,t,e);return this.parsePaths(g)}parsePaths(t){let e=[];for(let a of t){let s=[];for(let n=0;n<a.length;n++){let i=a[n],r=a[n+1];if(r==null)break;s.push(this.toEdge(i,r))}e.push(s)}return e}toEdge(t,e){return[e[1],t[0],e[0]]}};var lt=class{routeSuggester;routeProposals;ctx;filter={};constructor(t){this.ctx=t,this.routeSuggester=new Pt,this.routeProposals=new Map}async withFilter(t){this.filter=t||{},this.routeProposals.clear(),this.onFilterChanged()}onFilterChanged(){}buildRouteKey(t,e,a){return`${t}->${e}::${a.length}`}applyPoolFilter(t){let{useOnly:e=[],exclude:a=[]}=this.filter,s=new Set(e),n=new Set(a);return t.filter(i=>n.has(i.type)?!1:s.size>0?s.has(i.type):!0)}async getPools(){let t=await this.ctx.getPools();return this.applyPoolFilter(t)}async getRoutes(t,e){let a=await this.getPools();return this.validateInput(t,e,a),this.getPaths(t,e,a)}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(s=>s!==t).map(s=>this.getRoutes(s,t)))).filter(s=>s.length>0).map(([s])=>s[0].assetIn).sort()}validateInput(t,e,a){if(a.length===0)throw new Error("No pools configured");if(t===e)throw new Error("Trading pair can't be identical");let s=this.getAssets(a);if(!s.has(t))throw new Error(t+" is not supported asset");if(!s.has(e))throw new Error(e+" is not supported asset");return this.toPoolsMap(a)}getAssets(t){let e=t.map(a=>a.tokens.map(s=>s.id)).flat().sort((a,s)=>a>s?1:-1);return new Set(e)}getPaths(t,e,a){let s=this.toPoolsMap(a);return this.getProposals(t,e,a).filter(i=>this.validPath(i,s)).map(i=>this.toHops(i,s))}getProposals(t,e,a){let s=this.buildRouteKey(t,e,a);if(this.routeProposals.has(s))return this.routeProposals.get(s);let n=this.routeSuggester.getProposals(t,e,a);return this.routeProposals.set(s,n),n}validPath(t,e){return t.length>0&&t.map(a=>this.validEdge(a,e)).reduce((a,s)=>a&&s)}validEdge([t,e,a],s){return s.get(t)?.validatePair(e,a)||!1}toPoolsMap(t){return new Map(t.map(e=>[e.address,yt.get(e)]))}toHops(t,e){return t.map(([a,s,n])=>{let i=e.get(a);return{poolAddress:a,poolId:i?.id,pool:i?.type,assetIn:s,assetOut:n}})}};var P=require("@galacticcouncil/common");var Wt=(e=>(e.Buy="Buy",e.Sell="Sell",e))(Wt||{}),Yt=(a=>(a.Dca="Dca",a.TwapSell="TwapSell",a.TwapBuy="TwapBuy",a))(Yt||{}),Xt=(a=>(a.OrderTooSmall="OrderTooSmall",a.OrderTooBig="OrderTooBig",a.OrderImpactTooBig="OrderImpactTooBig",a))(Xt||{});var{FeeUtils:de}=f,ct=class extends lt{mlr;constructor(t){super(t),this.mlr=new Map}onFilterChanged(){this.mlr.clear()}buildCtxSync(t,e,a){let s=super.validateInput(t,e,a),n=super.getPaths(t,e,a);if(!n.length)throw new Ct(t,e);return{paths:n,pools:a,poolsMap:s}}async withCtx(t,e,a){let s=await super.getPools(),n=this.buildCtxSync(t,e,s);return a(n)}isDirectTrade(t){return t.length==1}findBestSellRoute(t){let e=t.sort((a,s)=>{let n=a[a.length-1].amountOut,i=s[s.length-1].amountOut;return n>i?-1:1});return e.find(a=>a.every(s=>s.errors.length==0))||e[0]}getRouteFeeRange(t){if(t.filter(a=>a.tradeFeeRange).length>0){let a=t.map(n=>n.tradeFeeRange?.[0]??n.tradeFeePct).reduce((n,i)=>n+i),s=t.map(n=>n.tradeFeeRange?.[1]??n.tradeFeePct).reduce((n,i)=>n+i);return[a,s]}}getPoolFeeRange(t,e){let a=t.min?de.toPct(t.min):void 0,s=t.max?de.toPct(t.max):void 0;if(a&&s)return[a,Math.max(s,e)]}async getBestSell(t,e,a){return this.getSell(t,e,a)}getSellSpot(t){let e=t[t.length-1];return t.length===1?e.spotPrice:this.calculateSpot(t)}async getSell(t,e,a,s){return this.withCtx(t,e,async({paths:n,poolsMap:i})=>{let r;if(s)r=await this.toSellSwaps(a,s,i);else{let o=n.map(u=>this.toSellSwaps(a,u,i)),l=await Promise.all(o);r=this.findBestSellRoute(l)}return this.buildSell(i,r)})}async getSells(t,e,a){return this.withCtx(t,e,async({paths:s,poolsMap:n})=>{let i=s.map(o=>this.toSellSwaps(a,o,n));return(await Promise.all(i)).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 a=e[0],s=e[e.length-1],n=this.isDirectTrade(e),i=this.getSellSpot(e),r=s.amountOut,o=n?s.calculatedOut:this.calculateDelta0Y(a.amountIn,e,t),l=o-r,u=this.getRouteFeeRange(e),m=n?s.tradeFeePct:B.calculateSellFee(o,r),h=k.mulSpot(a.amountIn,i,a.assetInDecimals,s.assetOutDecimals),d=B.calculateDiffToRef(o,h);return{type:"Sell",amountIn:a.amountIn,amountOut:s.amountOut,spotPrice:i,tradeFee:l,tradeFeePct:m,tradeFeeRange:u,priceImpactPct:d,swaps:e,toHuman(){return{type:"Sell",amountIn:P.big.toDecimal(a.amountIn,a.assetInDecimals),amountOut:P.big.toDecimal(s.amountOut,s.assetOutDecimals),spotPrice:P.big.toDecimal(i,P.RUNTIME_DECIMALS),tradeFee:P.big.toDecimal(l,s.assetOutDecimals),tradeFeePct:m,tradeFeeRange:u,priceImpactPct:d,swaps:e.map(S=>S.toHuman())}}}}calculateSpot(t){return t.map(e=>e.spotPrice).reduce((e,a)=>e*a/10n**BigInt(P.RUNTIME_DECIMALS))}calculateDelta0Y(t,e,a){let s=[];for(let n=0;n<e.length;n++){let i=e[n],r=a.get(i.poolAddress);if(r==null)throw new Error("Pool does not exit");let o=r.parsePair(i.assetIn,i.assetOut),l;n>0?l=s[n-1]:l=t;let u=r.calculateOutGivenIn(o,l);s.push(u)}return s[s.length-1]}async calculateMostLiquidRoute(t,e,a){let{paths:s,pools:n,poolsMap:i}=a,l=n.filter(g=>g.tokens.some(p=>p.id===t)).map(g=>g.type==="Aave"?g.tokens:g.tokens.filter(p=>p.id===t)).map(g=>g.map(p=>p.balance).reduce((p,y)=>p+y)).sort((g,p)=>p<g?-1:1)[0],u=k.getFraction(l,.1),m=await Promise.all(s.map(g=>this.toSellSwaps(u,g,i))),d=this.findBestSellRoute(m).map(g=>({poolAddress:g.poolAddress,poolId:g?.poolId,pool:g.pool,assetIn:g.assetIn,assetOut:g.assetOut})),S=this.buildRouteKey(t,e,n);return this.mlr.set(S,d),d}async toSellSwaps(t,e,a){let s=[];for(let n=0;n<e.length;n++){let i=e[n],r=a.get(i.poolAddress);if(r==null)throw new Error("Pool does not exit");let o=r.parsePair(i.assetIn,i.assetOut),l;n>0?l=s[n-1].amountOut:l=typeof t=="string"?P.big.toBigInt(t,o.decimalsIn):t;let u=await this.ctx.getPoolFees(o,r),{amountOut:m,calculatedOut:h,feePct:d,errors:S}=r.validateAndSell(o,l,u),g=this.getPoolFeeRange(u,d),p=r.spotPriceOutGivenIn(o),y=k.mulSpot(l,p,o.decimalsIn,o.decimalsOut),T=B.calculateDiffToRef(h,y);s.push({...i,assetInDecimals:o.decimalsIn,assetOutDecimals:o.decimalsOut,amountIn:l,amountOut:m,calculatedOut:h,spotPrice:p,tradeFeePct:d,tradeFeeRange:g,priceImpactPct:T,errors:S,isSupply(){return r.type==="Aave"&&r.tokens[0].id===i.assetIn},isWithdraw(){return r.type==="Aave"&&r.tokens[1].id===i.assetIn},toHuman(){return{...i,amountIn:P.big.toDecimal(l,o.decimalsIn),amountOut:P.big.toDecimal(m,o.decimalsOut),calculatedOut:P.big.toDecimal(h,o.decimalsOut),spotPrice:P.big.toDecimal(p,P.RUNTIME_DECIMALS),tradeFeePct:d,tradeFeeRange:g,priceImpactPct:T,errors:S}}})}return s}async getMostLiquidRoute(t,e){return this.withCtx(t,e,async a=>{let s=this.buildRouteKey(t,e,a.pools),n=this.mlr.get(s);return n||this.calculateMostLiquidRoute(t,e,a)})}async getSpotPrice(t,e){return this.withCtx(t,e,async a=>{let{pools:s,poolsMap:n}=a,i=this.buildRouteKey(t,e,s),r=this.mlr.get(i);r||(r=await this.calculateMostLiquidRoute(t,e,a));let o=await this.toSellSwaps("1",r,n);return{amount:this.getSellSpot(o),decimals:P.RUNTIME_DECIMALS}}).catch(()=>{})}findBestBuyRoute(t){let e=t.sort((a,s)=>{let n=a[0].amountIn,i=s[0].amountIn;return n>i?1:-1});return e.find(a=>a.every(s=>s.errors.length==0))||e[0]}async getBestBuy(t,e,a){return this.getBuy(t,e,a)}getBuySpot(t){let e=t[0];return t.length===1?e.spotPrice:this.calculateSpot(t)}async getBuy(t,e,a,s){return this.withCtx(t,e,async({paths:n,poolsMap:i})=>{let r;if(s)r=await this.toBuySwaps(a,s,i);else{let o=n.map(u=>this.toBuySwaps(a,u,i)),l=await Promise.all(o);r=this.findBestBuyRoute(l)}return this.buildBuy(i,r)})}async getBuys(t,e,a){return this.withCtx(t,e,async({paths:s,poolsMap:n})=>{let i=s.map(o=>this.toBuySwaps(a,o,n));return(await Promise.all(i)).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 a=e[e.length-1],s=e[0],n=this.isDirectTrade(e),i=this.getBuySpot(e),r=s.amountIn,o=n?s.calculatedIn:this.calculateDelta0X(a.amountOut,e,t),l=r-o,u=this.getRouteFeeRange(e),m=n?s.tradeFeePct:B.calculateBuyFee(o,r),h=k.mulSpot(a.amountOut,i,a.assetOutDecimals,s.assetInDecimals),d;return o===0n?d=-100:d=B.calculateDiffToRef(h,o),{type:"Buy",amountOut:a.amountOut,amountIn:s.amountIn,spotPrice:i,tradeFee:l,tradeFeePct:m,tradeFeeRange:u,priceImpactPct:d,swaps:e,toHuman(){return{type:"Buy",amountOut:P.big.toDecimal(a.amountOut,a.assetOutDecimals),amountIn:P.big.toDecimal(s.amountIn,s.assetInDecimals),spotPrice:P.big.toDecimal(i,P.RUNTIME_DECIMALS),tradeFee:P.big.toDecimal(l,s.assetInDecimals),tradeFeePct:m,tradeFeeRange:u,priceImpactPct:d,swaps:e.map(S=>S.toHuman())}}}}calculateDelta0X(t,e,a){let s=[];for(let n=e.length-1;n>=0;n--){let i=e[n],r=a.get(i.poolAddress);if(r==null)throw new Error("Pool does not exit");let o=r.parsePair(i.assetIn,i.assetOut),l;n==e.length-1?l=t:l=s[0];let u=r.calculateInGivenOut(o,l);s.unshift(u)}return s[0]}async toBuySwaps(t,e,a){let s=[];for(let n=e.length-1;n>=0;n--){let i=e[n],r=a.get(i.poolAddress);if(r==null)throw new Error("Pool does not exit");let o=r.parsePair(i.assetIn,i.assetOut),l;n==e.length-1?l=typeof t=="string"?P.big.toBigInt(t,o.decimalsOut):t:l=s[0].amountIn;let u=await this.ctx.getPoolFees(o,r),{amountIn:m,calculatedIn:h,feePct:d,errors:S}=r.validateAndBuy(o,l,u),g=this.getPoolFeeRange(u,d),p=r.spotPriceInGivenOut(o),y=k.mulSpot(l,p,o.decimalsOut,o.decimalsIn),T;h===0n?T=-100:T=B.calculateDiffToRef(y,h),s.unshift({...i,assetInDecimals:o.decimalsIn,assetOutDecimals:o.decimalsOut,amountOut:l,amountIn:m,calculatedIn:h,spotPrice:p,tradeFeePct:d,tradeFeeRange:g,priceImpactPct:T,errors:S,isSupply(){return r.type==="Aave"&&r.tokens[0].id===i.assetIn},isWithdraw(){return r.type==="Aave"&&r.tokens[1].id===i.assetIn},toHuman(){return{...i,amountOut:P.big.toDecimal(l,o.decimalsOut),amountIn:P.big.toDecimal(m,o.decimalsIn),calculatedIn:P.big.toDecimal(h,o.decimalsIn),spotPrice:P.big.toDecimal(p,P.RUNTIME_DECIMALS),tradeFeePct:d,tradeFeeRange:g,priceImpactPct:T,errors:S}}})}return s}};var w=require("@galacticcouncil/common");var ge=6e3,Kt=1000000000000000n,ft=6,zt=-5,jt=216e5,nu=3,be=.1,he=6;var Qt=require("polkadot-api");var V=class{static build(t){return t.map(({assetIn:e,assetOut:a,pool:s,poolId:n})=>s==="Stableswap"?{pool:(0,Qt.Enum)("Stableswap",n),asset_in:e,asset_out:a}:{pool:(0,Qt.Enum)(s),asset_in:e,asset_out:a})}};var kt=class{schedulerOptions;router;constructor(t,e={}){this.router=new ct(t),this.router.withFilter({exclude:["HSM"]}),this.schedulerOptions=Object.freeze({blockTime:e.blockTime??6e3,minBudgetInNative:e.minBudgetInNative??Kt})}get blockTime(){return this.schedulerOptions.blockTime}get minOrderBudget(){return this.schedulerOptions.minBudgetInNative}async getDcaOrder(t,e,a,s,n){let i=await this.router.getBestSell(t,e,a),{amountIn:r,swaps:o,priceImpactPct:l}=i,u=o[0],m=o[o.length-1],{assetInDecimals:h}=u,{assetOutDecimals:d}=m,S=Math.abs(l),g=await this.getMinimumOrderBudget(t,h),p=this.getOptimalTradeCount(S),y=this.getMaximumTradeCount(r,g,s),T=n||Math.min(p,y),L=Math.round(s/T),_=r/BigInt(T),F=await this.router.getBestSell(t,e,_),K=r<g,$=[];K&&$.push("OrderTooSmall");let Z=await this.getAssetOutEd(m),W=F.amountOut*BigInt(T),Pe=this.toBlockPeriod(L),fe=F.tradeFee*BigInt(T),Se=V.build(o),Jt={assetIn:t,assetOut:e,assetOutEd:Z,errors:$,maxTradeCount:y,tradeCount:T,tradeFee:fe,tradeImpactPct:F.priceImpactPct,tradePeriod:Pe,tradeRoute:Se,type:"Dca"};return{...Jt,amountIn:r,amountOut:W,tradeAmountIn:F.amountIn,tradeAmountOut:F.amountOut,toHuman(){return{...Jt,amountIn:w.big.toDecimal(r,h),amountOut:w.big.toDecimal(W,d),assetOutEd:w.big.toDecimal(Z,d),tradeAmountIn:w.big.toDecimal(F.amountIn,h),tradeAmountOut:w.big.toDecimal(F.amountOut,d)}}}}async getMinimumOrderBudget(t,e){if(0===t)return this.minOrderBudget;let a=await this.router.getSpotPrice(0,t);if(a)return k.mulSpot(this.minOrderBudget,a.amount,12,e);let s=await this.router.getSpotPrice(t,0);if(s)return k.divSpot(this.minOrderBudget,s.amount,12,e);throw new Error("Unable to calculate order budget")}getMaximumTradeCount(t,e,a){let s=e*2n/10n;if(s===0n)return 0;let n=Number(t/s),i=Math.floor(a/this.blockTime),r=Math.max(0,Math.floor(i*(1-.1)));return Math.min(n,r)}getOptimalTradeCount(t){let e=Math.round(t*10)||1;return Math.max(e,3)}async getOpenBudgetDcaOrder(t,e,a,s){let n=await this.router.getBestSell(t,e,a),{swaps:i}=n,r=i[0],o=i[i.length-1],{assetInDecimals:l}=r,{assetOutDecimals:u}=o,m=await this.getMinimumOrderBudget(t,l),h=n.amountIn<m,d=[];h&&d.push("OrderTooSmall");let S=await this.getAssetOutEd(o),g=this.toBlockPeriod(s),p=V.build(i),y={assetIn:t,assetOut:e,assetOutEd:S,errors:d,maxTradeCount:0,tradeCount:0,tradeFee:n.tradeFee,tradeImpactPct:n.priceImpactPct,tradePeriod:g,tradeRoute:p,type:"Dca"};return{...y,amountIn:0n,amountOut:0n,tradeAmountIn:n.amountIn,tradeAmountOut:n.amountOut,toHuman(){return{...y,amountIn:"0",amountOut:"0",assetOutEd:w.big.toDecimal(S,u),tradeAmountIn:w.big.toDecimal(n.amountIn,l),tradeAmountOut:w.big.toDecimal(n.amountOut,u)}}}}async getTwapSellOrder(t,e,a){let s=await this.router.getBestSell(t,e,a),{amountIn:n,swaps:i,priceImpactPct:r}=s,o=i[0],l=i[i.length-1],{assetInDecimals:u}=o,{assetOutDecimals:m}=l,h=Math.abs(r),d=this.getTwapTradeCount(h),S=n/BigInt(d),[g,p]=await Promise.all([this.getMinimumOrderBudget(t,u),this.router.getBestSell(o.assetIn,l.assetOut,S)]),y=d===1,T=n<g,L=p.priceImpactPct<-5,_=[];T||y?_.push("OrderTooSmall"):L&&_.push("OrderImpactTooBig");let F=await this.getAssetOutEd(l),K=p.amountOut*BigInt(d),$=p.tradeFee*BigInt(d),Z=V.build(i),W={assetIn:t,assetOut:e,assetOutEd:F,errors:_,tradeCount:d,tradeImpactPct:p.priceImpactPct,tradePeriod:6,tradeRoute:Z,type:"TwapSell"};return{...W,amountIn:n,amountOut:K,tradeAmountIn:p.amountIn,tradeAmountOut:p.amountOut,tradeFee:$,toHuman(){return{...W,amountIn:w.big.toDecimal(n,u),amountOut:w.big.toDecimal(K,m),assetOutEd:w.big.toDecimal(F,m),tradeAmountIn:w.big.toDecimal(p.amountIn,u),tradeAmountOut:w.big.toDecimal(p.amountOut,m),tradeFee:w.big.toDecimal($,m)}}}}async getTwapBuyOrder(t,e,a){let s=await this.router.getBestBuy(t,e,a),{amountOut:n,swaps:i,priceImpactPct:r}=s,o=i[0],l=i[i.length-1],{assetInDecimals:u}=o,{assetOutDecimals:m}=l,h=Math.abs(r),d=this.getTwapTradeCount(h),S=n/BigInt(d),[g,p]=await Promise.all([this.getMinimumOrderBudget(t,u),this.router.getBestBuy(o.assetIn,l.assetOut,S)]),y=p.amountIn*BigInt(d),T=d===1,L=y<g,_=p.priceImpactPct<-5,F=[];L||T?F.push("OrderTooSmall"):_&&F.push("OrderImpactTooBig");let K=await this.getAssetOutEd(l),$=p.tradeFee*BigInt(d),Z=V.build(i),W={assetIn:t,assetOut:e,assetOutEd:K,errors:F,tradeCount:d,tradeImpactPct:p.priceImpactPct,tradePeriod:6,tradeRoute:Z,type:"TwapBuy"};return{...W,amountIn:y,amountOut:n,tradeAmountIn:p.amountIn,tradeAmountOut:p.amountOut,tradeFee:$,toHuman(){return{...W,amountIn:w.big.toDecimal(y,u),amountOut:w.big.toDecimal(n,m),assetOutEd:w.big.toDecimal(K,m),tradeAmountIn:w.big.toDecimal(p.amountIn,u),tradeAmountOut:w.big.toDecimal(p.amountOut,m),tradeFee:w.big.toDecimal($,u)}}}}getTwapTradeCount(t){let e=this.getOptimalTradeCount(t);if(this.getTwapExecutionTime(e)>216e5){let s=216e5/(this.blockTime*6);return Math.round(s)}return e}getTwapExecutionTime(t){return t*6*this.blockTime}toBlockPeriod(t){let e=t/this.blockTime,a=Math.round(e);return Math.max(a,6)}async getAssetOutEd(t){let s=(await this.router.getPools()).find(n=>n.address===t.poolAddress)?.tokens.find(n=>n.id===t.assetOut);if(!s)throw new Error(`Asset ${t.assetOut} not found in pool ${t.poolAddress}`);return s.existentialDeposit}};0&&(module.exports={DCA_TIME_RESERVE,DEFAULT_BLOCK_TIME,DEFAULT_MIN_BUDGET,ORDER_MIN_BLOCK_PERIOD,Router,TWAP_EXECUTION_INTERVAL,TWAP_MAX_DURATION,TWAP_MAX_PRICE_IMPACT,TWAP_TX_MULTIPLIER,TradeOrderError,TradeOrderType,TradeRouteBuilder,TradeRouter,TradeScheduler,TradeType});
@@ -1 +1 @@
1
- var Wt=Object.defineProperty;var $=(u,t)=>{for(var e in t)Wt(u,e,{get:t[e],enumerable:!0})};import Xt from"buffer";typeof window<"u"&&(window.Buffer=Xt.Buffer);var Y=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 $t=10,z=class{isNotVisited(t,e){let s=!0;return e.forEach(a=>{(a[0]===t[0]||a[1]===t[1])&&(s=!1)}),s}findPaths(t,e,s){let a=[],i=new Y,o=[];for(o.push([e,""]),i.enqueue(o);i.size()>0;){let r=i.dequeue();if(!r||r.length>$t)continue;let n=r[r.length-1];(s===null||n[0]===s)&&a.push(r),t.get(n[0])?.forEach(c=>{if(this.isNotVisited(c,r)){let p=[...r];p.push(c),i.enqueue(p)}})}return a}findShortestPaths(t,e,s){let a=[],i=new Y,o=[];o.push([e,""]),i.enqueue(o);let r=1/0;for(;i.size()>0;){let n=i.dequeue();if(!n)continue;let l=n[n.length-1];if(l[0]===s){n.length<r?(r=n.length,a.length=0,a.push(n)):n.length===r&&a.push(n);continue}let c=t.get(l[0]);for(let p of c??[])this.isNotVisited(p,n)&&i.enqueue([...n,p])}return a}buildAndPopulateGraph(t,e){let s=new Map;for(let a of t)s.set(parseInt(a),[]);for(let[a,i,o]of e)s.get(i)?.push([o,a]);return s}};function pt(u){let t={};for(let e of u){let s=e.tokens.length;for(let a=0;a<s;a++){t[e.tokens[a].id]||(t[e.tokens[a].id]=[]);for(let i=0;i<s;i++){if(a==i)continue;let o=[e.address,e.tokens[a].id,e.tokens[i].id];t[e.tokens[a].id].push(o)}}}return t}import{calculate_in_given_out as Yt,calculate_out_given_in as zt,calculate_linear_weights as Kt,calculate_pool_trade_fee as jt,get_spot_price as Qt}from"@galacticcouncil/math-lbp";var R=class{static getSpotPrice(t,e,s,a,i){return Qt(t,e,s,a,i)}static calculateInGivenOut(t,e,s,a,i){return Yt(t,e,s,a,i)}static calculateOutGivenIn(t,e,s,a,i){return zt(t,e,s,a,i)}static calculateLinearWeights(t,e,s,a,i){return Kt(t,e,s,a,i)}static calculatePoolTradeFee(t,e,s){return jt(t,e,s)}};import{big as xt,RUNTIME_DECIMALS as Ot}from"@galacticcouncil/common";var at={};$(at,{withTimeout:()=>Jt});function Jt(u,t,e="timeout"){return new Promise((s,a)=>{let i=setTimeout(()=>a(new Error(e)),t);u.then(o=>{clearTimeout(i),s(o)},o=>{clearTimeout(i),a(o)})})}var A={};$(A,{divSpot:()=>te,getFraction:()=>ee,mulScaled:()=>St,mulSpot:()=>Zt});import{RUNTIME_DECIMALS as ft}from"@galacticcouncil/common";function St(u,t,e,s,a){let i=e+s-a,o=u*t;return i>0?o/BigInt(10)**BigInt(i):i<0?o*BigInt(10)**BigInt(-i):o}function Zt(u,t,e,s){return St(u,t,e,ft,s)}function te(u,t,e,s){if(t===0n)return 0n;let a=BigInt(10)**BigInt(ft+s-e);return u*a/t}function ee(u,t,e=2){if(t<.01||t>100)throw new Error("Supported range is from 0.01% - 100%");let s=BigInt(10)**BigInt(e),a=BigInt(Math.round(t*Number(s)));return u*a/(BigInt(100)*s)}var y={};$(y,{FeeUtils:()=>dt,shiftNeg:()=>ie});import ae from"big.js";var dt=class u{static toPct(t){let[e,s]=t;return u.safeDivide(e*100,s)}static toRaw(t){let[e,s]=t;return u.safeDivide(e,s)}static fromPermill(t){return[t,1e6]}static fromPerbill(t){return[t,1e9]}static fromRate(t,e){return[t,e]}static safeDivide(t,e,s=12){let a=10**s;return Math.round(t*a/e)/a}static safeRound(t){return parseFloat(t.toPrecision(15))}};function ie(u,t){let e=ae(typeof u=="bigint"?u.toString():u);return t===0?e.toString():e.div(Math.pow(10,t)).toString()}var K={};$(K,{findNestedKey:()=>oe,findNestedObj:()=>re,jsonFormatter:()=>ne});var oe=(u,t)=>{let e=[];return JSON.stringify(u,(s,a)=>(a&&a[t]&&e.push(a),a)),e[0]},re=(u,t,e)=>{let s;return JSON.stringify(u,(a,i)=>(i&&i[t]===e&&(s=i),i)),s},ne=(u,t)=>typeof t=="bigint"?t.toString():t;var w={};$(w,{calculateBuyFee:()=>me,calculateDiffToAvg:()=>le,calculateDiffToRef:()=>ce,calculateSellFee:()=>ue});import k from"big.js";function le(u,t){let e=k(u.toString()),s=k(t.toString());return e.minus(s).abs().div(e.plus(s).div(2)).mul(100).round(2).toNumber()}function ce(u,t){if(t===0n)return 0;let e=k(u.toString()),s=k(t.toString());return e.minus(s).div(s).mul(100).round(2).toNumber()}function ue(u,t){if(u===0n)return 0;let e=k(u.toString()),s=k(t.toString());return k(1).minus(s.div(e)).mul(100).round(2).toNumber()}function me(u,t){if(u===0n)return 0;let e=k(u.toString());return k(t.toString()).div(e).minus(1).mul(100).round(2).toNumber()}import{TLRUCache as js}from"@thi.ng/cache";var{FeeUtils:wt}=y,it=class u{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;fee;repayFeeApply;static fromPool(t){return new u(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 s=new Map(this.tokens.map(o=>[o.id,o])),a=s.get(t),i=s.get(e);if(a==null)throw new Error("Pool does not contain tokenIn");if(i==null)throw new Error("Pool does not contain tokenOut");return{assetIn:t,assetOut:e,balanceIn:a.balance,balanceOut:i.balance,decimalsIn:a.decimals,decimalsOut:i.decimals,weightIn:a.weight,weightOut:i.weight}}validateAndBuy(t,e,s){let a=this.tokens[0].id,i=[];e<this.minTradingLimit&&i.push("InsufficientTradingAmount");let o=t.balanceOut/this.maxOutRatio;if(e>o&&i.push("MaxOutRatioExceeded"),a===t.assetOut){let r=this.calculateTradeFee(e,s),n=wt.toPct(this.repayFeeApply?s.repayFee:s.exchangeFee),l=e+r,c=this.calculateInGivenOut(t,l),p=t.balanceIn/this.maxInRatio;return c>p&&i.push("MaxInRatioExceeded"),{amountIn:c,calculatedIn:c,amountOut:e,feePct:n,errors:i}}else{let r=this.calculateInGivenOut(t,e),n=t.balanceIn/this.maxInRatio;return r>n&&i.push("MaxInRatioExceeded"),{amountIn:r,calculatedIn:r,amountOut:e,feePct:0,errors:i}}}validateAndSell(t,e,s){let a=this.tokens[0].id,i=[];e<this.minTradingLimit&&i.push("InsufficientTradingAmount");let o=t.balanceIn/this.maxInRatio;if(e>o&&i.push("MaxInRatioExceeded"),a===t.assetIn){let r=this.calculateOutGivenIn(t,e),n=t.balanceOut/this.maxOutRatio;return r>n&&i.push("MaxOutRatioExceeded"),{amountIn:e,calculatedOut:r,amountOut:r,feePct:0,errors:i}}else{let r=this.calculateOutGivenIn(t,e),n=this.calculateTradeFee(r,s),l=wt.toPct(this.repayFeeApply?s.repayFee:s.exchangeFee),c=r-n,p=t.balanceOut/this.maxOutRatio;return c>p&&i.push("MaxOutRatioExceeded"),{amountIn:e,calculatedOut:r,amountOut:c,feePct:l,errors:i}}}calculateInGivenOut(t,e){let s=R.calculateInGivenOut(t.balanceIn.toString(),t.balanceOut.toString(),t.weightIn.toString(),t.weightOut.toString(),e.toString()),a=BigInt(s);return a<0n?0n:a}calculateOutGivenIn(t,e){let s=R.calculateOutGivenIn(t.balanceIn.toString(),t.balanceOut.toString(),t.weightIn.toString(),t.weightOut.toString(),e.toString()),a=BigInt(s);return a<0n?0n:a}spotPriceInGivenOut(t){let e=R.getSpotPrice(t.balanceOut.toString(),t.balanceIn.toString(),t.weightOut.toString(),t.weightIn.toString(),xt.toBigInt(1,Ot).toString());return BigInt(e)}spotPriceOutGivenIn(t){let e=R.getSpotPrice(t.balanceIn.toString(),t.balanceOut.toString(),t.weightIn.toString(),t.weightOut.toString(),xt.toBigInt(1,Ot).toString());return BigInt(e)}calculateTradeFee(t,e){let s=R.calculatePoolTradeFee(t.toString(),this.repayFeeApply?e.repayFee[0]:e.exchangeFee[0],this.repayFeeApply?e.repayFee[1]:e.exchangeFee[1]);return BigInt(s)}};import{CompatibilityLevel as rr}from"polkadot-api";import{Subscription as lr,distinctUntilChanged as cr,filter as ur,map as mr}from"rxjs";import{memoize1 as ho}from"@thi.ng/memoize";import{TLRUCache as Po}from"@thi.ng/cache";import{ReplaySubject as Io,Subscription as xo,combineLatest as Oo,defer as wo,from as To,interval as vo,merge as Bo,of as Ao,EMPTY as Fo}from"rxjs";import{bufferCount as Eo,bufferTime as Ro,catchError as ko,filter as Co,finalize as Mo,map as Lo,pairwise as Do,repeat as Ho,skip as No,share as qo,startWith as Go,switchMap as Vo,tap as Uo,throttleTime as Wo}from"rxjs/operators";import{hydration as $a,hydrationNext as Ya}from"@galacticcouncil/descriptors";import{log as pe}from"@galacticcouncil/common";import{map as Da,shareReplay as Ha,tap as Na}from"rxjs";import{defer as ya,from as fa,of as Sa,timer as Ia}from"rxjs";import{catchError as Oa,distinctUntilChanged as wa,expand as Ta,map as va,shareReplay as Ba,skip as Aa,switchMap as Fa,timeout as _a}from"rxjs/operators";var{logger:Ga}=pe;import{getWsProvider as Ja}from"polkadot-api/ws";import{withLogsRecorder as ti}from"polkadot-api/logs-provider";import{Binary as hi}from"polkadot-api";import{log as de}from"@galacticcouncil/common";import{combineLatest as xi,concat as Oi,defer as wi,from as Ti}from"rxjs";import{bufferCount as Bi,distinctUntilChanged as Ai,debounceTime as Fi,map as _i,retry as Ei,startWith as Ri,switchMap as ki,tap as Ci,take as Mi,skip as Li,connect as Di}from"rxjs/operators";var{logger:Gi}=de;import{BehaviorSubject as eo}from"rxjs";import{log as he}from"@galacticcouncil/common";var no={Aave:"AAVE",LBP:"LBP",Omnipool:"OMNI",Stableswap:"STBL",XYK:"XYK",HSM:"HSM"},{logger:lo}=he;var{withTimeout:sr}=at;import{calculate_in_given_out as Pe,calculate_lrna_in_given_out as ye,calculate_out_given_in as fe,calculate_out_given_lrna_in as Se,calculate_spot_price as Ie,calculate_lrna_spot_price as xe,calculate_shares as Oe,calculate_liquidity_out as we,calculate_liquidity_lrna_out as Te,verify_asset_cap as ve,calculate_liquidity_hub_in as Be,is_sell_allowed as Ae,is_buy_allowed as Fe,is_add_liquidity_allowed as _e,is_remove_liquidity_allowed as Ee,recalculate_asset_fee as Re,recalculate_protocol_fee as ke}from"@galacticcouncil/math-omnipool";import G from"big.js";var S=class{static calculateSpotPrice(t,e,s,a){return Ie(t,e,s,a)}static calculateLrnaSpotPrice(t,e){return xe(t,e)}static calculateInGivenOut(t,e,s,a,i,o,r,n,l,c){return Pe(t,e,s,a,i,o,r,n,l,c)}static calculateLrnaInGivenOut(t,e,s,a,i,o){return ye(t,e,s,a,i,o)}static calculateOutGivenIn(t,e,s,a,i,o,r,n,l,c){return fe(t,e,s,a,i,o,r,n,l,c)}static calculateOutGivenLrnaIn(t,e,s,a,i,o){return Se(t,e,s,a,i,o)}static calculateShares(t,e,s,a){return Oe(t,e,s,a)}static calculateLiquidityOut(t,e,s,a,i,o,r,n){return we(t,e,s,a,i,o,r,n)}static calculateLiquidityLRNAOut(t,e,s,a,i,o,r,n){return Te(t,e,s,a,i,o,r,n)}static calculateCapDifference(t,e,s,a){let i=G(e),o=G(t),r=G(a),n=G(s),l=G(10).pow(18),c=n.div(l);if(i.div(r).lt(c)){let h=c.times(r).minus(i).times(o),d=i.times(G(1).minus(c));return h.div(d).toFixed(0)}else return"0"}static calculateLimitHubIn(t,e,s,a){return Be(t,e,s,a)}static isSellAllowed(t){return Ae(t)}static isBuyAllowed(t){return Fe(t)}static isAddLiquidityAllowed(t){return _e(t)}static isRemoveLiquidityAllowed(t){return Ee(t)}static recalculateAssetFee(t,e,s,a,i,o,r,n,l,c,p){return Re(t,e,s,a,i,o,r,n,l,c,p)}static recalculateProtocolFee(t,e,s,a,i,o,r,n,l,c,p){return ke(t,e,s,a,i,o,r,n,l,c,p)}static verifyAssetCap(t,e,s,a){return ve(t,e,s,a)}};import{big as Ce}from"@galacticcouncil/common";var{FeeUtils:E}=y,rt=class u{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;hubAssetId;static fromPool(t){return new u(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 s=new Map(this.tokens.map(o=>[o.id,o])),a=s.get(t),i=s.get(e);if(a==null)throw new Error("Pool does not contain tokenIn");if(i==null)throw new Error("Pool does not contain tokenOut");return{assetIn:t,assetOut:e,hubReservesIn:a.hubReserves,hubReservesOut:i.hubReserves,sharesIn:a.shares,sharesOut:i.shares,decimalsIn:a.decimals,decimalsOut:i.decimals,balanceIn:a.balance,balanceOut:i.balance,tradeableIn:a.tradeable,tradeableOut:i.tradeable,assetInEd:a.existentialDeposit,assetOutEd:i.existentialDeposit}}validateAndBuy(t,e,s){let a=this.calculateInGivenOut(t,e),i=this.calculateInGivenOut(t,e,s),o=a===0n?0:w.calculateBuyFee(a,i),r=[],n=S.isSellAllowed(t.tradeableIn),l=S.isBuyAllowed(t.tradeableOut);(!n||!l)&&r.push("TradeNotAllowed"),(e<this.minTradingLimit||a<t.assetInEd)&&r.push("InsufficientTradingAmount");let c=t.balanceOut/this.maxOutRatio;e>c&&r.push("MaxOutRatioExceeded");let p=t.balanceIn/this.maxInRatio;return i>p&&r.push("MaxInRatioExceeded"),{amountIn:i,calculatedIn:a,amountOut:e,feePct:o,errors:r}}validateAndSell(t,e,s){let a=this.calculateOutGivenIn(t,e),i=this.calculateOutGivenIn(t,e,s),o=w.calculateSellFee(a,i),r=[],n=S.isSellAllowed(t.tradeableIn),l=S.isBuyAllowed(t.tradeableOut);(!n||!l)&&r.push("TradeNotAllowed"),(e<this.minTradingLimit||a<t.assetOutEd)&&r.push("InsufficientTradingAmount");let c=t.balanceIn/this.maxInRatio;e>c&&r.push("MaxInRatioExceeded");let p=t.balanceOut/this.maxOutRatio;return i>p&&r.push("MaxOutRatioExceeded"),{amountIn:e,calculatedOut:a,amountOut:i,feePct:o,errors:r}}calculateInGivenOut(t,e,s){if(t.assetIn==this.hubAssetId)return this.calculateLrnaInGivenOut(t,e,s);let a=S.calculateInGivenOut(t.balanceIn.toString(),t.hubReservesIn.toString(),t.sharesIn.toString(),t.balanceOut.toString(),t.hubReservesOut.toString(),t.sharesOut.toString(),e.toString(),s?E.toRaw(s.assetFee).toString():"0",s?E.toRaw(s.protocolFee).toString():"0",s?E.toRaw(s.maxSlipFee).toString():"0"),i=BigInt(a);return i<0n?0n:i}calculateLrnaInGivenOut(t,e,s){let a=S.calculateLrnaInGivenOut(t.balanceOut.toString(),t.hubReservesOut.toString(),t.sharesOut.toString(),e.toString(),s?E.toRaw(s.assetFee).toString():"0",s?E.toRaw(s.maxSlipFee).toString():"0"),i=BigInt(a);return i<0n?0n:i}calculateOutGivenIn(t,e,s){if(t.assetIn==this.hubAssetId)return this.calculateOutGivenLrnaIn(t,e,s);let a=S.calculateOutGivenIn(t.balanceIn.toString(),t.hubReservesIn.toString(),t.sharesIn.toString(),t.balanceOut.toString(),t.hubReservesOut.toString(),t.sharesOut.toString(),e.toString(),s?E.toRaw(s.assetFee).toString():"0",s?E.toRaw(s.protocolFee).toString():"0",s?E.toRaw(s.maxSlipFee).toString():"0"),i=BigInt(a);return i<0n?0n:i}calculateOutGivenLrnaIn(t,e,s){let a=S.calculateOutGivenLrnaIn(t.balanceOut.toString(),t.hubReservesOut.toString(),t.sharesOut.toString(),e.toString(),s?E.toRaw(s.assetFee).toString():"0",s?E.toRaw(s.maxSlipFee).toString():"0"),i=BigInt(a);return i<0n?0n:i}spotPriceInGivenOut(t){if(t.assetIn==this.hubAssetId)return this.spotPriceLrnaInGivenOut(t);let e=S.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=S.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=S.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=S.calculateLrnaSpotPrice(t.balanceOut.toString(),t.hubReservesOut.toString());return this.normalizeSpot(BigInt(e),t.decimalsIn,t.decimalsOut)}normalizeSpot(t,e,s){let a=e-s;if(a===0)return t;let i=Ce.pow10(Math.abs(a));return a>0?t*i:t/i}};import{AccountId as an,Binary as Tt,CompatibilityLevel as on,Enum as De}from"polkadot-api";import{toHex as ln}from"@polkadot-api/utils";import{Subscription as un,distinctUntilChanged as mn,filter as pn,finalize as dn,map as gn,merge as hn,tap as bn}from"rxjs";import{HYDRATION_SS58_PREFIX as yn}from"@galacticcouncil/common";var{FeeUtils:zr}=y;var{FeeUtils:Bn}=y,An=Tt.toHex(Tt.fromText("omnipool")),Fn=De("Short");import{calculate_in_given_out as Ne,calculate_out_given_in as qe,calculate_amplification as Ge,calculate_add_one_asset as Ve,calculate_liquidity_out_one_asset as Ue,calculate_shares as We,calculate_shares_for_amount as Xe,calculate_spot_price_with_fee as $e,pool_account_name as Ye,recalculate_peg as ze}from"@galacticcouncil/math-stableswap";var B=class{static getPoolAddress(t){return Ye(t)}static defaultPegs(t){let e=[];for(let s=0;s<t;s++)e.push(["1","1"]);return e}static calculateAmplification(t,e,s,a,i){return Ge(t,e,s,a,i)}static calculateInGivenOut(t,e,s,a,i,o,r){return Ne(t,e,s,a,i,o,r)}static calculateAddOneAsset(t,e,s,a,i,o,r){return Ve(t,e,s,a,i,o,r)}static calculateSharesForAmount(t,e,s,a,i,o,r){return Xe(t,e,s,a,i,o,r)}static calculateOutGivenIn(t,e,s,a,i,o,r){return qe(t,e,s,a,i,o,r)}static calculateLiquidityOutOneAsset(t,e,s,a,i,o,r){return Ue(t,e,s,a,i,o,r)}static calculateShares(t,e,s,a,i,o){return We(t,e,s,a,i,o)}static calculateSpotPriceWithFee(t,e,s,a,i,o,r,n){return $e(t,e,s,a,i,o,r,n)}static recalculatePegs(t,e,s,a,i,o){let r=ze(t,e,s,a,i,o);return JSON.parse(r)}};import{RUNTIME_DECIMALS as Ke,big as vt}from"@galacticcouncil/common";var{FeeUtils:V}=y,U=class u{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;amplification;isRampPeriod;id;fee;totalIssuance;pegs;static fromPool(t){return new u(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 s=new Map(this.tokens.map(o=>[o.id,o])),a=s.get(t),i=s.get(e);if(a==null)throw new Error("Pool does not contain tokenIn");if(i==null)throw new Error("Pool does not contain tokenOut");return{assetIn:t,assetOut:e,balanceIn:a.balance,balanceOut:i.balance,decimalsIn:a.decimals,decimalsOut:i.decimals,tradeableIn:this.id===t?15:a.tradeable,tradeableOut:this.id===e?15:i.tradeable,assetInEd:a.existentialDeposit,assetOutEd:i.existentialDeposit}}validateAndBuy(t,e,s){let a=this.calculateInGivenOut(t,e),i=this.calculateInGivenOut(t,e,s),o=a===0n?0:w.calculateBuyFee(a,i),r=[],n=S.isSellAllowed(t.tradeableIn),l=S.isBuyAllowed(t.tradeableOut);return(!n||!l)&&r.push("TradeNotAllowed"),(e<this.minTradingLimit||a<t.assetInEd)&&r.push("InsufficientTradingAmount"),{amountIn:i,calculatedIn:a,amountOut:e,feePct:o,errors:r}}validateAndSell(t,e,s){let a=this.calculateOutGivenIn(t,e),i=this.calculateOutGivenIn(t,e,s),o=w.calculateSellFee(a,i),r=[],n=S.isSellAllowed(t.tradeableIn),l=S.isBuyAllowed(t.tradeableOut);return(!n||!l)&&r.push("TradeNotAllowed"),(e<this.minTradingLimit||a<t.assetOutEd)&&r.push("InsufficientTradingAmount"),{amountIn:e,calculatedOut:a,amountOut:i,feePct:o,errors:r}}calculateIn(t,e,s){let a=B.calculateInGivenOut(this.getReserves(),Number(t.assetIn),Number(t.assetOut),e.toString(),this.amplification.toString(),s?V.toRaw(s.fee).toString():"0",this.getPegs()),i=BigInt(a);return i<0n?0n:i}calculateAddOneAsset(t,e,s){let a=B.calculateAddOneAsset(this.getReserves(),e.toString(),Number(t.assetIn),this.amplification.toString(),this.totalIssuance.toString(),s?V.toRaw(s.fee).toString():"0",this.getPegs()),i=BigInt(a);return i<0n?0n:i}calculateSharesForAmount(t,e,s){let a=B.calculateSharesForAmount(this.getReserves(),Number(t.assetOut),e.toString(),this.amplification.toString(),this.totalIssuance.toString(),s?V.toRaw(s.fee).toString():"0",this.getPegs()),i=BigInt(a);return i<0n?0n:i}calculateInGivenOut(t,e,s){return t.assetOut==this.id?this.calculateAddOneAsset(t,e,s):t.assetIn==this.id?this.calculateSharesForAmount(t,e,s):this.calculateIn(t,e,s)}spotPriceInGivenOut(t){let e=B.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,s){let a=B.calculateOutGivenIn(this.getReserves(),Number(t.assetIn),Number(t.assetOut),e.toString(),this.amplification.toString(),s?V.toRaw(s.fee).toString():"0",this.getPegs()),i=BigInt(a);return i<0n?0n:i}calculateWithdrawOneAsset(t,e,s){let a=B.calculateLiquidityOutOneAsset(this.getReserves(),e.toString(),Number(t.assetOut),this.amplification.toString(),this.totalIssuance.toString(),s?V.toRaw(s.fee).toString():"0",this.getPegs()),i=BigInt(a);return i<0n?0n:i}calculateShares(t,e,s){let a=B.calculateShares(this.getReserves(),this.getAssets(t.assetIn,e),this.amplification.toString(),this.totalIssuance.toString(),s?V.toRaw(s.fee).toString():"0",this.getPegs()),i=BigInt(a);return i<0n?0n:i}calculateOutGivenIn(t,e,s){return t.assetIn==this.id?this.calculateWithdrawOneAsset(t,e,s):t.assetOut==this.id?this.calculateShares(t,e,s):this.calculateOut(t,e,s)}spotPriceOutGivenIn(t){let e=B.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:s,decimals:a})=>({asset_id:e,amount:s,decimals:a}));return JSON.stringify(t,K.jsonFormatter)}getAssets(t,e){let s={asset_id:Number(t),amount:e.toString()};return JSON.stringify([s],K.jsonFormatter)}normalizeSpot(t,e,s,a,i){return e?t*vt.pow10(Ke-i):s?t/vt.pow10(i-a):t}};import{AccountId as nl,CompatibilityLevel as ll}from"polkadot-api";import{toHex as ul}from"@polkadot-api/utils";import{blake2b as pl}from"@noble/hashes/blake2b";import{Subscription as gl,distinctUntilChanged as hl,map as bl,merge as Pl,tap as yl}from"rxjs";import{HYDRATION_SS58_PREFIX as Sl,RUNTIME_DECIMALS as Il}from"@galacticcouncil/common";var{FeeUtils:Rl}=y;import{calculate_in_given_out as Qe,calculate_out_given_in as Je,calculate_pool_trade_fee as Ze,get_spot_price as ts,calculate_liquidity_in as es,calculate_shares as ss,calculate_spot_price as as,calculate_spot_price_with_fee as is,calculate_liquidity_out_asset_a as os,calculate_liquidity_out_asset_b as rs}from"@galacticcouncil/math-xyk";var L=class{static getSpotPrice(t,e,s){return ts(t,e,s)}static calculateInGivenOut(t,e,s){return Qe(t,e,s)}static calculateOutGivenIn(t,e,s){return Je(t,e,s)}static calculatePoolTradeFee(t,e,s){return Ze(t,e,s)}static calculateLiquidityIn(t,e,s){return es(t,e,s)}static calculateSpotPrice(t,e){return as(t,e)}static calculateSpotPriceWithFee(t,e,s,a){return is(t,e,s,a)}static calculateShares(t,e,s){return ss(t,e,s)}static calculateLiquidityOutAssetA(t,e,s,a){return os(t,e,s,a)}static calculateLiquidityOutAssetB(t,e,s,a){return rs(t,e,s,a)}};import{big as ns}from"@galacticcouncil/common";var{FeeUtils:Bt}=y,nt=class u{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;static fromPool(t){return new u(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 s=new Map(this.tokens.map(o=>[o.id,o])),a=s.get(t),i=s.get(e);if(a==null)throw new Error("Pool does not contain tokenIn");if(i==null)throw new Error("Pool does not contain tokenOut");return{assetIn:t,assetOut:e,decimalsIn:a.decimals,decimalsOut:i.decimals,balanceIn:a.balance,balanceOut:i.balance,assetInEd:a.existentialDeposit,assetOutEd:i.existentialDeposit}}validateAndBuy(t,e,s){let a=this.calculateInGivenOut(t,e),i=this.calculateTradeFee(a,s),o=Bt.toPct(s.exchangeFee),r=a+i,n=[];(e<this.minTradingLimit||a<t.assetInEd)&&n.push("InsufficientTradingAmount");let l=t.balanceOut/this.maxOutRatio;e>l&&n.push("MaxOutRatioExceeded");let c=t.balanceIn/this.maxInRatio;return r>c&&n.push("MaxInRatioExceeded"),{amountIn:r,calculatedIn:a,amountOut:e,feePct:o,errors:n}}validateAndSell(t,e,s){let a=this.calculateOutGivenIn(t,e),i=this.calculateTradeFee(a,s),o=Bt.toPct(s.exchangeFee),r=a-i,n=[];(e<this.minTradingLimit||a<t.assetOutEd)&&n.push("InsufficientTradingAmount");let l=t.balanceIn/this.maxInRatio;e>l&&n.push("MaxInRatioExceeded");let c=t.balanceOut/this.maxOutRatio;return r>c&&n.push("MaxOutRatioExceeded"),{amountIn:e,calculatedOut:a,amountOut:r,feePct:o,errors:n}}calculateInGivenOut(t,e){let s=L.calculateInGivenOut(t.balanceIn.toString(),t.balanceOut.toString(),e.toString()),a=BigInt(s);return a<0n?0n:a}calculateOutGivenIn(t,e){let s=L.calculateOutGivenIn(t.balanceIn.toString(),t.balanceOut.toString(),e.toString()),a=BigInt(s);return a<0n?0n:a}spotPriceInGivenOut(t){let e=L.calculateSpotPrice(t.balanceOut.toString(),t.balanceIn.toString());return this.normalizeSpot(BigInt(e),t.decimalsOut,t.decimalsIn)}spotPriceOutGivenIn(t){let e=L.calculateSpotPrice(t.balanceIn.toString(),t.balanceOut.toString());return this.normalizeSpot(BigInt(e),t.decimalsIn,t.decimalsOut)}calculateTradeFee(t,e){let s=L.calculatePoolTradeFee(t.toString(),e.exchangeFee[0],e.exchangeFee[1]);return BigInt(s)}normalizeSpot(t,e,s){let a=e-s;if(a===0)return t;let i=ns.pow10(Math.abs(a));return a>0?t*i:t/i}};import{CompatibilityLevel as ic}from"polkadot-api";import{Subscription as rc}from"rxjs";import{big as At,RUNTIME_DECIMALS as Ft}from"@galacticcouncil/common";var lt=class u{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;static fromPool(t){return new u(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 s=new Map(this.tokens.map(o=>[o.id,o])),a=s.get(t),i=s.get(e);if(a==null)throw new Error("Pool does not contain tokenIn");if(i==null)throw new Error("Pool does not contain tokenOut");return{assetIn:t,assetOut:e,balanceIn:a.balance,balanceOut:i.balance,decimalsIn:a.decimals,decimalsOut:i.decimals,assetInEd:0n,assetOutEd:0n}}validateAndBuy(t,e,s){let a=this.calculateInGivenOut(t,e),i=[];return e>t.balanceOut&&i.push("TradeNotAllowed"),{amountIn:a,calculatedIn:a,amountOut:e,feePct:0,errors:i}}validateAndSell(t,e,s){let a=this.calculateOutGivenIn(t,e),i=[];return a>t.balanceOut&&i.push("TradeNotAllowed"),{amountIn:e,calculatedOut:a,amountOut:a,feePct:0,errors:i}}calculateInGivenOut(t,e){return e}calculateOutGivenIn(t,e){return e}spotPriceInGivenOut(t){return At.toBigInt(1,Ft)}spotPriceOutGivenIn(t){return At.toBigInt(1,Ft)}calculateTradeFee(t,e){return 0n}};import{AccountId as Hc,Binary as Nc}from"polkadot-api";import{toHex as Gc}from"@polkadot-api/utils";import{Subscription as Uc,filter as Wc,map as Xc,mergeMap as $c}from"rxjs";import{decodeEventLog as zc}from"viem";import{erc20 as cs,HYDRATION_SS58_PREFIX as jc}from"@galacticcouncil/common";var{ERC20:au}=cs;import{calculate_collateral_in_given_hollar_out as ms,calculate_collateral_out_given_hollar_in as ps,calculate_hollar_in_given_collateral_out as ds,calculate_hollar_out_given_collateral_in as gs,calculate_imbalance as hs,calculate_max_price as bs,calculate_buyback_limit as Ps,calculate_buyback_price_with_fee as ys}from"@galacticcouncil/math-hsm";var F=class{static calculateCollateralInGivenHollarOut(t,e,s){return ms(t,e,s)}static calculateCollateralOutGivenHollarIn(t,e,s){return ps(t,e,s)}static calculateHollarOutGivenCollateralIn(t,e,s){return gs(t,e,s)}static calculateHollarInGivenCollateralOut(t,e,s){return ds(t,e,s)}static calculateImbalance(t,e,s){return hs(t,e,s)}static calculateBuybackLimit(t,e){return Ps(t,e)}static calculateBuybackPriceWithFee(t,e,s){return ys(t,e,s)}static calculateMaxPrice(t,e){return bs(t,e)}};import{big as C,RUNTIME_DECIMALS as ct}from"@galacticcouncil/common";var{FeeUtils:W}=y,ut=class u extends U{hsmAddress;hsmMintCapacity;hollarId;hollarH160;collateralId;collateralBalance;maxBuyPriceCoefficient;maxInHolding;purchaseFee;buyBackFee;buyBackRate;static fromPool(t){return new u(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,s){let a=this.parsePair(t.assetOut,t.assetIn),i=super.calculateInGivenOut(a,e,{fee:this.fee}),o=this.calculateBuybackLimit(t);e>o&&s.push("MaxBuyBackExceeded");let r=this.calculateMaxPrice(t);return this.calculateBuyPrice(t,e,i)>r&&s.push("MaxBuyPriceExceeded"),i>this.collateralBalance&&s.push("InsufficientCollateral"),s}validateTradeHollarOut(t,e,s){return this.collateralBalance+t>this.maxInHolding&&s.push("MaxHoldingExceeded"),e>this.hsmMintCapacity&&s.push("FacilitatorCapacityExceeded"),s}validateTradeConstraints(t,e,s){let a=[];return t.assetIn===this.hollarId?this.validateTradeHollarIn(t,e,a):this.validateTradeHollarOut(e,s,a)}validateAndBuy(t,e){let s=this.calculateInGivenOut(t,e),a=this.validateTradeConstraints(t,s,e);return{amountIn:s,calculatedIn:s,amountOut:e,feePct:0,errors:a}}validateAndSell(t,e){let s=this.calculateOutGivenIn(t,e),a=this.validateTradeConstraints(t,e,s);return{amountIn:e,calculatedOut:s,amountOut:s,feePct:0,errors:a}}calculateHollarInGivenCollateralOut(t,e){let s=super.calculateInGivenOut(t,e,{fee:this.fee}),a=F.calculateHollarInGivenCollateralOut(e.toString(),s.toString(),W.toRaw(this.buyBackFee).toString());return BigInt(a)}calculateCollateralInGivenHollarOut(t){let e=this.getCollateralPeg(),s=F.calculateCollateralInGivenHollarOut(t.toString(),JSON.stringify(e),W.toRaw(this.purchaseFee).toString());return BigInt(s)}calculateInGivenOut(t,e){return t.assetOut==this.hollarId?this.calculateCollateralInGivenHollarOut(e):this.calculateHollarInGivenCollateralOut(t,e)}calculateCollateralOutGivenHollarIn(t,e){let s=super.calculateOutGivenIn(t,e,{fee:this.fee}),a=F.calculateCollateralOutGivenHollarIn(e.toString(),s.toString(),W.toRaw(this.buyBackFee).toString());return BigInt(a)}calculateHollarOutGivenCollateralIn(t){let e=this.getCollateralPeg(),s=F.calculateHollarOutGivenCollateralIn(t.toString(),JSON.stringify(e),W.toRaw(this.purchaseFee).toString());return BigInt(s)}calculateOutGivenIn(t,e){return t.assetIn==this.hollarId?this.calculateCollateralOutGivenHollarIn(t,e):this.calculateHollarOutGivenCollateralIn(e)}calculateImbalance(t){let e=this.getCollateralPeg(),s=F.calculateImbalance(t.balanceIn.toString(),JSON.stringify(e),t.balanceOut.toString());return BigInt(s)}calculateBuybackLimit(t){let e=this.calculateImbalance(t),s=F.calculateBuybackLimit(e.toString(),W.toRaw(this.buyBackRate).toString());return BigInt(s)}calculateBuyPrice(t,e,s){let a=F.calculateBuybackPriceWithFee(s.toString(),e.toString(),W.toRaw(this.buyBackFee).toString()),[i,o]=JSON.parse(a),r=C.pow10(t.decimalsIn+ct-t.decimalsOut);return BigInt(i)*r/BigInt(o)}calculateMaxPrice(t){let e=this.getCollateralPeg(),s=F.calculateMaxPrice(JSON.stringify(e),this.maxBuyPriceCoefficient.toString()),[a,i]=JSON.parse(s),o=C.pow10(ct-t.decimalsOut);return BigInt(a)*o/BigInt(i)}spotPriceInGivenOut(t){let e=C.toBigInt(1,t.decimalsOut),a=this.calculateInGivenOut(t,e)*C.pow10(ct-t.decimalsOut);return this.normalizeSpotPrice(a,t.decimalsOut,t.decimalsIn)}spotPriceOutGivenIn(t){let e=C.toBigInt(1,t.decimalsIn),a=this.calculateOutGivenIn(t,e)*C.pow10(ct-t.decimalsIn);return this.normalizeSpotPrice(a,t.decimalsIn,t.decimalsOut)}getCollateralPeg(){let t=this.tokens.findIndex(a=>a.id!==this.hollarId),e=this.pegs[t],s=this.tokens[t].decimals;return this.isDefaultPeg(e)?[C.toBigInt(1,18).toString(),C.toBigInt(1,s).toString()]:e}isDefaultPeg(t){let[e,s]=t;return Array.isArray(t)&&t.length===2&&e==="1"&&s==="1"}normalizeSpotPrice(t,e,s){let a=e-s;if(a===0)return t;let i=C.pow10(Math.abs(a));return a>0?t*i:t/i}};import{AccountId as Mu,Binary as Lu,CompatibilityLevel as Du}from"polkadot-api";import{toHex as qu}from"@polkadot-api/utils";import{Subscription as Uu,combineLatest as Wu,filter as Xu,map as $u,mergeMap as Yu,pairwise as zu}from"rxjs";import{decodeEventLog as ju}from"viem";import{h160 as Ss,HYDRATION_SS58_PREFIX as Ju}from"@galacticcouncil/common";var{FeeUtils:om}=y,{H160:rm}=Ss;var J=class{static get(t){switch(t.type){case"Aave":return lt.fromPool(t);case"XYK":return nt.fromPool(t);case"Omnipool":return rt.fromPool(t);case"LBP":return it.fromPool(t);case"Stableswap":return U.fromPool(t);case"HSM":return ut.fromPool(t);default:throw new Error("Pool type "+t.type+" is not supported yet")}}};import{log as Os}from"@galacticcouncil/common";import{Subject as Hm,Subscription as Nm,takeUntil as qm}from"rxjs";var mt=class extends Error{constructor(t,e){super(),this.message=`Route from ${t} to ${e} not found in current configuration`,this.name="RouteNotFound"}};var{logger:ap}=Os;var Z=class{getProposals(t,e,s){let a=s.filter(m=>m.type==="XYK"),i=s.filter(m=>m.type!=="XYK"),o=new Set(i.map(m=>m.tokens).flat().map(m=>m.id)),r=o.has(t),n=o.has(e),l=new z,c=m=>{let b=pt(m),P=Object.keys(b),_=P.flatMap(v=>b[v]);return l.buildAndPopulateGraph(P,_)};if(!r&&!n){let m=a.filter(_=>_.tokens.find(v=>v.id===t)||_.tokens.find(v=>v.id===e)),b=c(m),P=l.findPaths(b,t,e);return this.parsePaths(P)}if(r&&n){let m=c(i),b=l.findPaths(m,t,e);return this.parsePaths(b)}let p=r?e:t,h=a.filter(m=>m.tokens.some(b=>b.id===p));if(h.length===0)return[];let d=[...i,...h],f=c(d),g=l.findPaths(f,t,e);return this.parsePaths(g)}parsePaths(t){let e=[];for(let s of t){let a=[];for(let i=0;i<s.length;i++){let o=s[i],r=s[i+1];if(r==null)break;a.push(this.toEdge(o,r))}e.push(a)}return e}toEdge(t,e){return[e[1],t[0],e[0]]}};var tt=class{routeSuggester;routeProposals;ctx;filter={};constructor(t){this.ctx=t,this.routeSuggester=new Z,this.routeProposals=new Map}async withFilter(t){this.filter=t||{},this.routeProposals.clear(),this.onFilterChanged()}onFilterChanged(){}buildRouteKey(t,e,s){return`${t}->${e}::${s.length}`}applyPoolFilter(t){let{useOnly:e=[],exclude:s=[]}=this.filter,a=new Set(e),i=new Set(s);return t.filter(o=>i.has(o.type)?!1:a.size>0?a.has(o.type):!0)}async getPools(){let t=await this.ctx.getPools();return this.applyPoolFilter(t)}async getRoutes(t,e){let s=await this.getPools();return this.validateInput(t,e,s),this.getPaths(t,e,s)}async getTradeableAssets(){let t=await this.getPools(),e=this.getAssets(t);return Array.from(e)}async getRouteableAssets(t){let e=await this.getTradeableAssets();return(await Promise.all(e.filter(a=>a!==t).map(a=>this.getRoutes(a,t)))).filter(a=>a.length>0).map(([a])=>a[0].assetIn).sort()}validateInput(t,e,s){if(s.length===0)throw new Error("No pools configured");if(t===e)throw new Error("Trading pair can't be identical");let a=this.getAssets(s);if(!a.has(t))throw new Error(t+" is not supported asset");if(!a.has(e))throw new Error(e+" is not supported asset");return this.toPoolsMap(s)}getAssets(t){let e=t.map(s=>s.tokens.map(a=>a.id)).flat().sort((s,a)=>s>a?1:-1);return new Set(e)}getPaths(t,e,s){let a=this.toPoolsMap(s);return this.getProposals(t,e,s).filter(o=>this.validPath(o,a)).map(o=>this.toHops(o,a))}getProposals(t,e,s){let a=this.buildRouteKey(t,e,s);if(this.routeProposals.has(a))return this.routeProposals.get(a);let i=this.routeSuggester.getProposals(t,e,s);return this.routeProposals.set(a,i),i}validPath(t,e){return t.length>0&&t.map(s=>this.validEdge(s,e)).reduce((s,a)=>s&&a)}validEdge([t,e,s],a){return a.get(t)?.validatePair(e,s)||!1}toPoolsMap(t){return new Map(t.map(e=>[e.address,J.get(e)]))}toHops(t,e){return t.map(([s,a,i])=>{let o=e.get(s);return{poolAddress:s,poolId:o?.id,pool:o?.type,assetIn:a,assetOut:i}})}};import{big as x,RUNTIME_DECIMALS as X}from"@galacticcouncil/common";var Et=(e=>(e.Buy="Buy",e.Sell="Sell",e))(Et||{}),Rt=(s=>(s.Dca="Dca",s.TwapSell="TwapSell",s.TwapBuy="TwapBuy",s))(Rt||{}),kt=(s=>(s.OrderTooSmall="OrderTooSmall",s.OrderTooBig="OrderTooBig",s.OrderImpactTooBig="OrderImpactTooBig",s))(kt||{});var{FeeUtils:Ct}=y,et=class extends tt{mlr;constructor(t){super(t),this.mlr=new Map}onFilterChanged(){this.mlr.clear()}buildCtxSync(t,e,s){let a=super.validateInput(t,e,s),i=super.getPaths(t,e,s);if(!i.length)throw new mt(t,e);return{paths:i,pools:s,poolsMap:a}}async withCtx(t,e,s){let a=await super.getPools(),i=this.buildCtxSync(t,e,a);return s(i)}isDirectTrade(t){return t.length==1}findBestSellRoute(t){let e=t.sort((s,a)=>{let i=s[s.length-1].amountOut,o=a[a.length-1].amountOut;return i>o?-1:1});return e.find(s=>s.every(a=>a.errors.length==0))||e[0]}getRouteFeeRange(t){if(t.filter(s=>s.tradeFeeRange).length>0){let s=t.map(i=>i.tradeFeeRange?.[0]??i.tradeFeePct).reduce((i,o)=>i+o),a=t.map(i=>i.tradeFeeRange?.[1]??i.tradeFeePct).reduce((i,o)=>i+o);return[s,a]}}getPoolFeeRange(t,e){let s=t.min?Ct.toPct(t.min):void 0,a=t.max?Ct.toPct(t.max):void 0;if(s&&a)return[s,Math.max(a,e)]}async getBestSell(t,e,s){return this.getSell(t,e,s)}getSellSpot(t){let e=t[t.length-1];return t.length===1?e.spotPrice:this.calculateSpot(t)}async getSell(t,e,s,a){return this.withCtx(t,e,async({paths:i,poolsMap:o})=>{let r;if(a)r=await this.toSellSwaps(s,a,o);else{let n=i.map(c=>this.toSellSwaps(s,c,o)),l=await Promise.all(n);r=this.findBestSellRoute(l)}return this.buildSell(o,r)})}async getSells(t,e,s){return this.withCtx(t,e,async({paths:a,poolsMap:i})=>{let o=a.map(n=>this.toSellSwaps(s,n,i));return(await Promise.all(o)).filter(n=>n.every(l=>l.errors.length==0)).map(n=>this.buildSell(i,n)).sort((n,l)=>n.amountOut>l.amountOut?-1:1)})}buildSell(t,e){let s=e[0],a=e[e.length-1],i=this.isDirectTrade(e),o=this.getSellSpot(e),r=a.amountOut,n=i?a.calculatedOut:this.calculateDelta0Y(s.amountIn,e,t),l=n-r,c=this.getRouteFeeRange(e),p=i?a.tradeFeePct:w.calculateSellFee(n,r),h=A.mulSpot(s.amountIn,o,s.assetInDecimals,a.assetOutDecimals),d=w.calculateDiffToRef(n,h);return{type:"Sell",amountIn:s.amountIn,amountOut:a.amountOut,spotPrice:o,tradeFee:l,tradeFeePct:p,tradeFeeRange:c,priceImpactPct:d,swaps:e,toHuman(){return{type:"Sell",amountIn:x.toDecimal(s.amountIn,s.assetInDecimals),amountOut:x.toDecimal(a.amountOut,a.assetOutDecimals),spotPrice:x.toDecimal(o,X),tradeFee:x.toDecimal(l,a.assetOutDecimals),tradeFeePct:p,tradeFeeRange:c,priceImpactPct:d,swaps:e.map(f=>f.toHuman())}}}}calculateSpot(t){return t.map(e=>e.spotPrice).reduce((e,s)=>e*s/10n**BigInt(X))}calculateDelta0Y(t,e,s){let a=[];for(let i=0;i<e.length;i++){let o=e[i],r=s.get(o.poolAddress);if(r==null)throw new Error("Pool does not exit");let n=r.parsePair(o.assetIn,o.assetOut),l;i>0?l=a[i-1]:l=t;let c=r.calculateOutGivenIn(n,l);a.push(c)}return a[a.length-1]}async calculateMostLiquidRoute(t,e,s){let{paths:a,pools:i,poolsMap:o}=s,l=i.filter(g=>g.tokens.some(m=>m.id===t)).map(g=>g.type==="Aave"?g.tokens:g.tokens.filter(m=>m.id===t)).map(g=>g.map(m=>m.balance).reduce((m,b)=>m+b)).sort((g,m)=>m<g?-1:1)[0],c=A.getFraction(l,.1),p=await Promise.all(a.map(g=>this.toSellSwaps(c,g,o))),d=this.findBestSellRoute(p).map(g=>({poolAddress:g.poolAddress,poolId:g?.poolId,pool:g.pool,assetIn:g.assetIn,assetOut:g.assetOut})),f=this.buildRouteKey(t,e,i);return this.mlr.set(f,d),d}async toSellSwaps(t,e,s){let a=[];for(let i=0;i<e.length;i++){let o=e[i],r=s.get(o.poolAddress);if(r==null)throw new Error("Pool does not exit");let n=r.parsePair(o.assetIn,o.assetOut),l;i>0?l=a[i-1].amountOut:l=typeof t=="string"?x.toBigInt(t,n.decimalsIn):t;let c=await this.ctx.getPoolFees(n,r),{amountOut:p,calculatedOut:h,feePct:d,errors:f}=r.validateAndSell(n,l,c),g=this.getPoolFeeRange(c,d),m=r.spotPriceOutGivenIn(n),b=A.mulSpot(l,m,n.decimalsIn,n.decimalsOut),P=w.calculateDiffToRef(h,b);a.push({...o,assetInDecimals:n.decimalsIn,assetOutDecimals:n.decimalsOut,amountIn:l,amountOut:p,calculatedOut:h,spotPrice:m,tradeFeePct:d,tradeFeeRange:g,priceImpactPct:P,errors:f,isSupply(){return r.type==="Aave"&&r.tokens[0].id===o.assetIn},isWithdraw(){return r.type==="Aave"&&r.tokens[1].id===o.assetIn},toHuman(){return{...o,amountIn:x.toDecimal(l,n.decimalsIn),amountOut:x.toDecimal(p,n.decimalsOut),calculatedOut:x.toDecimal(h,n.decimalsOut),spotPrice:x.toDecimal(m,X),tradeFeePct:d,tradeFeeRange:g,priceImpactPct:P,errors:f}}})}return a}async getMostLiquidRoute(t,e){return this.withCtx(t,e,async s=>{let a=this.buildRouteKey(t,e,s.pools),i=this.mlr.get(a);return i||this.calculateMostLiquidRoute(t,e,s)})}async getSpotPrice(t,e){return this.withCtx(t,e,async s=>{let{pools:a,poolsMap:i}=s,o=this.buildRouteKey(t,e,a),r=this.mlr.get(o);r||(r=await this.calculateMostLiquidRoute(t,e,s));let n=await this.toSellSwaps("1",r,i);return{amount:this.getSellSpot(n),decimals:X}}).catch(()=>{})}findBestBuyRoute(t){let e=t.sort((s,a)=>{let i=s[0].amountIn,o=a[0].amountIn;return i>o?1:-1});return e.find(s=>s.every(a=>a.errors.length==0))||e[0]}async getBestBuy(t,e,s){return this.getBuy(t,e,s)}getBuySpot(t){let e=t[0];return t.length===1?e.spotPrice:this.calculateSpot(t)}async getBuy(t,e,s,a){return this.withCtx(t,e,async({paths:i,poolsMap:o})=>{let r;if(a)r=await this.toBuySwaps(s,a,o);else{let n=i.map(c=>this.toBuySwaps(s,c,o)),l=await Promise.all(n);r=this.findBestBuyRoute(l)}return this.buildBuy(o,r)})}async getBuys(t,e,s){return this.withCtx(t,e,async({paths:a,poolsMap:i})=>{let o=a.map(n=>this.toBuySwaps(s,n,i));return(await Promise.all(o)).filter(n=>n.every(l=>l.errors.length==0)).map(n=>this.buildBuy(i,n)).sort((n,l)=>n.amountIn>l.amountIn?1:-1)})}buildBuy(t,e){let s=e[e.length-1],a=e[0],i=this.isDirectTrade(e),o=this.getBuySpot(e),r=a.amountIn,n=i?a.calculatedIn:this.calculateDelta0X(s.amountOut,e,t),l=r-n,c=this.getRouteFeeRange(e),p=i?a.tradeFeePct:w.calculateBuyFee(n,r),h=A.mulSpot(s.amountOut,o,s.assetOutDecimals,a.assetInDecimals),d;return n===0n?d=-100:d=w.calculateDiffToRef(h,n),{type:"Buy",amountOut:s.amountOut,amountIn:a.amountIn,spotPrice:o,tradeFee:l,tradeFeePct:p,tradeFeeRange:c,priceImpactPct:d,swaps:e,toHuman(){return{type:"Buy",amountOut:x.toDecimal(s.amountOut,s.assetOutDecimals),amountIn:x.toDecimal(a.amountIn,a.assetInDecimals),spotPrice:x.toDecimal(o,X),tradeFee:x.toDecimal(l,a.assetInDecimals),tradeFeePct:p,tradeFeeRange:c,priceImpactPct:d,swaps:e.map(f=>f.toHuman())}}}}calculateDelta0X(t,e,s){let a=[];for(let i=e.length-1;i>=0;i--){let o=e[i],r=s.get(o.poolAddress);if(r==null)throw new Error("Pool does not exit");let n=r.parsePair(o.assetIn,o.assetOut),l;i==e.length-1?l=t:l=a[0];let c=r.calculateInGivenOut(n,l);a.unshift(c)}return a[0]}async toBuySwaps(t,e,s){let a=[];for(let i=e.length-1;i>=0;i--){let o=e[i],r=s.get(o.poolAddress);if(r==null)throw new Error("Pool does not exit");let n=r.parsePair(o.assetIn,o.assetOut),l;i==e.length-1?l=typeof t=="string"?x.toBigInt(t,n.decimalsOut):t:l=a[0].amountIn;let c=await this.ctx.getPoolFees(n,r),{amountIn:p,calculatedIn:h,feePct:d,errors:f}=r.validateAndBuy(n,l,c),g=this.getPoolFeeRange(c,d),m=r.spotPriceInGivenOut(n),b=A.mulSpot(l,m,n.decimalsOut,n.decimalsIn),P;h===0n?P=-100:P=w.calculateDiffToRef(b,h),a.unshift({...o,assetInDecimals:n.decimalsIn,assetOutDecimals:n.decimalsOut,amountOut:l,amountIn:p,calculatedIn:h,spotPrice:m,tradeFeePct:d,tradeFeeRange:g,priceImpactPct:P,errors:f,isSupply(){return r.type==="Aave"&&r.tokens[0].id===o.assetIn},isWithdraw(){return r.type==="Aave"&&r.tokens[1].id===o.assetIn},toHuman(){return{...o,amountOut:x.toDecimal(l,n.decimalsOut),amountIn:x.toDecimal(p,n.decimalsIn),calculatedIn:x.toDecimal(h,n.decimalsIn),spotPrice:x.toDecimal(m,X),tradeFeePct:d,tradeFeeRange:g,priceImpactPct:P,errors:f}}})}return a}};import{big as O}from"@galacticcouncil/common";var Mt=6e3,Lt=1000000000000000n,st=6,ht=-5,bt=216e5,Id=3,Dt=.1,Ht=6;import{Enum as Nt}from"polkadot-api";var D=class{static build(t){return t.map(({assetIn:e,assetOut:s,pool:a,poolId:i})=>a==="Stableswap"?{pool:Nt("Stableswap",i),asset_in:e,asset_out:s}:{pool:Nt(a),asset_in:e,asset_out:s})}};var Pt=class{schedulerOptions;router;constructor(t,e={}){this.router=new et(t),this.router.withFilter({exclude:["HSM"]}),this.schedulerOptions=Object.freeze({blockTime:e.blockTime??6e3,minBudgetInNative:e.minBudgetInNative??Lt})}get blockTime(){return this.schedulerOptions.blockTime}get minOrderBudget(){return this.schedulerOptions.minBudgetInNative}async getDcaOrder(t,e,s,a,i){let o=await this.router.getBestSell(t,e,s),{amountIn:r,swaps:n,priceImpactPct:l}=o,c=n[0],p=n[n.length-1],{assetInDecimals:h}=c,{assetOutDecimals:d}=p,f=Math.abs(l),g=await this.getMinimumOrderBudget(t,h),m=this.getOptimalTradeCount(f),b=this.getMaximumTradeCount(r,g,a),P=i||Math.min(m,b),_=Math.round(a/P),v=r/BigInt(P),T=await this.router.getBestSell(t,e,v),H=r<g,q=[];H&&q.push("OrderTooSmall");let M=T.amountOut*BigInt(P),Gt=this.toBlockPeriod(_),Vt=T.tradeFee*BigInt(P),Ut=D.build(n),yt={assetIn:t,assetOut:e,errors:q,maxTradeCount:b,tradeCount:P,tradeFee:Vt,tradeImpactPct:T.priceImpactPct,tradePeriod:Gt,tradeRoute:Ut,type:"Dca"};return{...yt,amountIn:r,amountOut:M,tradeAmountIn:T.amountIn,tradeAmountOut:T.amountOut,toHuman(){return{...yt,amountIn:O.toDecimal(r,h),amountOut:O.toDecimal(M,d),tradeAmountIn:O.toDecimal(T.amountIn,h),tradeAmountOut:O.toDecimal(T.amountOut,d)}}}}async getMinimumOrderBudget(t,e){if(0===t)return this.minOrderBudget;let s=await this.router.getSpotPrice(0,t);if(s)return A.mulSpot(this.minOrderBudget,s.amount,12,e);let a=await this.router.getSpotPrice(t,0);if(a)return A.divSpot(this.minOrderBudget,a.amount,12,e);throw new Error("Unable to calculate order budget")}getMaximumTradeCount(t,e,s){let a=e*2n/10n;if(a===0n)return 0;let i=Number(t/a),o=Math.floor(s/this.blockTime),r=Math.max(0,Math.floor(o*(1-.1)));return Math.min(i,r)}getOptimalTradeCount(t){let e=Math.round(t*10)||1;return Math.max(e,3)}async getOpenBudgetDcaOrder(t,e,s,a){let i=await this.router.getBestSell(t,e,s),{swaps:o}=i,r=o[0],n=o[o.length-1],{assetInDecimals:l}=r,{assetOutDecimals:c}=n,p=await this.getMinimumOrderBudget(t,l),h=i.amountIn<p,d=[];h&&d.push("OrderTooSmall");let f=this.toBlockPeriod(a),g=D.build(o),m={assetIn:t,assetOut:e,errors:d,maxTradeCount:0,tradeCount:0,tradeFee:i.tradeFee,tradeImpactPct:i.priceImpactPct,tradePeriod:f,tradeRoute:g,type:"Dca"};return{...m,amountIn:0n,amountOut:0n,tradeAmountIn:i.amountIn,tradeAmountOut:i.amountOut,toHuman(){return{...m,amountIn:"0",amountOut:"0",tradeAmountIn:O.toDecimal(i.amountIn,l),tradeAmountOut:O.toDecimal(i.amountOut,c)}}}}async getTwapSellOrder(t,e,s){let a=await this.router.getBestSell(t,e,s),{amountIn:i,swaps:o,priceImpactPct:r}=a,n=o[0],l=o[o.length-1],{assetInDecimals:c}=n,{assetOutDecimals:p}=l,h=Math.abs(r),d=this.getTwapTradeCount(h),f=i/BigInt(d),[g,m]=await Promise.all([this.getMinimumOrderBudget(t,c),this.router.getBestSell(n.assetIn,l.assetOut,f)]),b=d===1,P=i<g,_=m.priceImpactPct<-5,v=[];P||b?v.push("OrderTooSmall"):_&&v.push("OrderImpactTooBig");let T=m.amountOut*BigInt(d),H=m.tradeFee*BigInt(d),q=D.build(o),M={assetIn:t,assetOut:e,errors:v,tradeCount:d,tradeImpactPct:m.priceImpactPct,tradePeriod:6,tradeRoute:q,type:"TwapSell"};return{...M,amountIn:i,amountOut:T,tradeAmountIn:m.amountIn,tradeAmountOut:m.amountOut,tradeFee:H,toHuman(){return{...M,amountIn:O.toDecimal(i,c),amountOut:O.toDecimal(T,p),tradeAmountIn:O.toDecimal(m.amountIn,c),tradeAmountOut:O.toDecimal(m.amountOut,p),tradeFee:O.toDecimal(H,p)}}}}async getTwapBuyOrder(t,e,s){let a=await this.router.getBestBuy(t,e,s),{amountOut:i,swaps:o,priceImpactPct:r}=a,n=o[0],l=o[o.length-1],{assetInDecimals:c}=n,{assetOutDecimals:p}=l,h=Math.abs(r),d=this.getTwapTradeCount(h),f=i/BigInt(d),[g,m]=await Promise.all([this.getMinimumOrderBudget(t,c),this.router.getBestBuy(n.assetIn,l.assetOut,f)]),b=m.amountIn*BigInt(d),P=d===1,_=b<g,v=m.priceImpactPct<-5,T=[];_||P?T.push("OrderTooSmall"):v&&T.push("OrderImpactTooBig");let H=m.tradeFee*BigInt(d),q=D.build(o),M={assetIn:t,assetOut:e,errors:T,tradeCount:d,tradeImpactPct:m.priceImpactPct,tradePeriod:6,tradeRoute:q,type:"TwapBuy"};return{...M,amountIn:b,amountOut:i,tradeAmountIn:m.amountIn,tradeAmountOut:m.amountOut,tradeFee:H,toHuman(){return{...M,amountIn:O.toDecimal(b,c),amountOut:O.toDecimal(i,p),tradeAmountIn:O.toDecimal(m.amountIn,c),tradeAmountOut:O.toDecimal(m.amountOut,p),tradeFee:O.toDecimal(H,c)}}}}getTwapTradeCount(t){let e=this.getOptimalTradeCount(t);if(this.getTwapExecutionTime(e)>216e5){let a=216e5/(this.blockTime*6);return Math.round(a)}return e}getTwapExecutionTime(t){return t*6*this.blockTime}toBlockPeriod(t){let e=t/this.blockTime,s=Math.round(e);return Math.max(s,6)}};export{Dt as DCA_TIME_RESERVE,Mt as DEFAULT_BLOCK_TIME,Lt as DEFAULT_MIN_BUDGET,Ht as ORDER_MIN_BLOCK_PERIOD,tt as Router,st as TWAP_EXECUTION_INTERVAL,bt as TWAP_MAX_DURATION,ht as TWAP_MAX_PRICE_IMPACT,Id as TWAP_TX_MULTIPLIER,kt as TradeOrderError,Rt as TradeOrderType,D as TradeRouteBuilder,et as TradeRouter,Pt as TradeScheduler,Et as TradeType};
1
+ var $t=Object.defineProperty;var X=(u,t)=>{for(var e in t)$t(u,e,{get:t[e],enumerable:!0})};import Wt from"buffer";typeof window<"u"&&(window.Buffer=Wt.Buffer);var K=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 Yt=10,z=class{isNotVisited(t,e){let a=!0;return e.forEach(s=>{(s[0]===t[0]||s[1]===t[1])&&(a=!1)}),a}findPaths(t,e,a){let s=[],n=new K,i=[];for(i.push([e,""]),n.enqueue(i);n.size()>0;){let r=n.dequeue();if(!r||r.length>Yt)continue;let o=r[r.length-1];(a===null||o[0]===a)&&s.push(r),t.get(o[0])?.forEach(c=>{if(this.isNotVisited(c,r)){let p=[...r];p.push(c),n.enqueue(p)}})}return s}findShortestPaths(t,e,a){let s=[],n=new K,i=[];i.push([e,""]),n.enqueue(i);let r=1/0;for(;n.size()>0;){let o=n.dequeue();if(!o)continue;let l=o[o.length-1];if(l[0]===a){o.length<r?(r=o.length,s.length=0,s.push(o)):o.length===r&&s.push(o);continue}let c=t.get(l[0]);for(let p of c??[])this.isNotVisited(p,o)&&n.enqueue([...o,p])}return s}buildAndPopulateGraph(t,e){let a=new Map;for(let s of t)a.set(parseInt(s),[]);for(let[s,n,i]of e)a.get(n)?.push([i,s]);return a}};function dt(u){let t={};for(let e of u){let a=e.tokens.length;for(let s=0;s<a;s++){t[e.tokens[s].id]||(t[e.tokens[s].id]=[]);for(let n=0;n<a;n++){if(s==n)continue;let i=[e.address,e.tokens[s].id,e.tokens[n].id];t[e.tokens[s].id].push(i)}}}return t}import{calculate_in_given_out as Xt,calculate_out_given_in as Kt,calculate_linear_weights as zt,calculate_pool_trade_fee as jt,get_spot_price as Qt}from"@galacticcouncil/math-lbp";var _=class{static getSpotPrice(t,e,a,s,n){return Qt(t,e,a,s,n)}static calculateInGivenOut(t,e,a,s,n){return Xt(t,e,a,s,n)}static calculateOutGivenIn(t,e,a,s,n){return Kt(t,e,a,s,n)}static calculateLinearWeights(t,e,a,s,n){return zt(t,e,a,s,n)}static calculatePoolTradeFee(t,e,a){return jt(t,e,a)}};import{big as wt,RUNTIME_DECIMALS as It}from"@galacticcouncil/common";var nt={};X(nt,{withTimeout:()=>Jt});function Jt(u,t,e="timeout"){return new Promise((a,s)=>{let n=setTimeout(()=>s(new Error(e)),t);u.then(i=>{clearTimeout(n),a(i)},i=>{clearTimeout(n),s(i)})})}var B={};X(B,{divSpot:()=>te,getFraction:()=>ee,mulScaled:()=>vt,mulSpot:()=>Zt});import{RUNTIME_DECIMALS as Tt}from"@galacticcouncil/common";function vt(u,t,e,a,s){let n=e+a-s,i=u*t;return n>0?i/BigInt(10)**BigInt(n):n<0?i*BigInt(10)**BigInt(-n):i}function Zt(u,t,e,a){return vt(u,t,e,Tt,a)}function te(u,t,e,a){if(t===0n)return 0n;let s=BigInt(10)**BigInt(Tt+a-e);return u*s/t}function ee(u,t,e=2){if(t<.01||t>100)throw new Error("Supported range is from 0.01% - 100%");let a=BigInt(10)**BigInt(e),s=BigInt(Math.round(t*Number(a)));return u*s/(BigInt(100)*a)}var y={};X(y,{FeeUtils:()=>gt,shiftNeg:()=>ne});import se from"big.js";var gt=class u{static toPct(t){let[e,a]=t;return u.safeDivide(e*100,a)}static toRaw(t){let[e,a]=t;return u.safeDivide(e,a)}static fromPermill(t){return[t,1e6]}static fromPerbill(t){return[t,1e9]}static fromRate(t,e){return[t,e]}static safeDivide(t,e,a=12){let s=10**a;return Math.round(t*s/e)/s}static safeRound(t){return parseFloat(t.toPrecision(15))}};function ne(u,t){let e=se(typeof u=="bigint"?u.toString():u);return t===0?e.toString():e.div(Math.pow(10,t)).toString()}var j={};X(j,{findNestedKey:()=>ie,findNestedObj:()=>re,jsonFormatter:()=>oe});var ie=(u,t)=>{let e=[];return JSON.stringify(u,(a,s)=>(s&&s[t]&&e.push(s),s)),e[0]},re=(u,t,e)=>{let a;return JSON.stringify(u,(s,n)=>(n&&n[t]===e&&(a=n),n)),a},oe=(u,t)=>typeof t=="bigint"?t.toString():t;var I={};X(I,{calculateBuyFee:()=>me,calculateDiffToAvg:()=>le,calculateDiffToRef:()=>ce,calculateSellFee:()=>ue});import C from"big.js";function le(u,t){let e=C(u.toString()),a=C(t.toString());return e.minus(a).abs().div(e.plus(a).div(2)).mul(100).round(2).toNumber()}function ce(u,t){if(t===0n)return 0;let e=C(u.toString()),a=C(t.toString());return e.minus(a).div(a).mul(100).round(2).toNumber()}function ue(u,t){if(u===0n)return 0;let e=C(u.toString()),a=C(t.toString());return C(1).minus(a.div(e)).mul(100).round(2).toNumber()}function me(u,t){if(u===0n)return 0;let e=C(u.toString());return C(t.toString()).div(e).minus(1).mul(100).round(2).toNumber()}import{TLRUCache as as}from"@thi.ng/cache";var{FeeUtils:xt}=y,it=class u{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;fee;repayFeeApply;static fromPool(t){return new u(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 a=new Map(this.tokens.map(i=>[i.id,i])),s=a.get(t),n=a.get(e);if(s==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:s.balance,balanceOut:n.balance,decimalsIn:s.decimals,decimalsOut:n.decimals,weightIn:s.weight,weightOut:n.weight}}validateAndBuy(t,e,a){let s=this.tokens[0].id,n=[];e<this.minTradingLimit&&n.push("InsufficientTradingAmount");let i=t.balanceOut/this.maxOutRatio;if(e>i&&n.push("MaxOutRatioExceeded"),s===t.assetOut){let r=this.calculateTradeFee(e,a),o=xt.toPct(this.repayFeeApply?a.repayFee:a.exchangeFee),l=e+r,c=this.calculateInGivenOut(t,l),p=t.balanceIn/this.maxInRatio;return c>p&&n.push("MaxInRatioExceeded"),{amountIn:c,calculatedIn:c,amountOut:e,feePct:o,errors:n}}else{let r=this.calculateInGivenOut(t,e),o=t.balanceIn/this.maxInRatio;return r>o&&n.push("MaxInRatioExceeded"),{amountIn:r,calculatedIn:r,amountOut:e,feePct:0,errors:n}}}validateAndSell(t,e,a){let s=this.tokens[0].id,n=[];e<this.minTradingLimit&&n.push("InsufficientTradingAmount");let i=t.balanceIn/this.maxInRatio;if(e>i&&n.push("MaxInRatioExceeded"),s===t.assetIn){let r=this.calculateOutGivenIn(t,e),o=t.balanceOut/this.maxOutRatio;return r>o&&n.push("MaxOutRatioExceeded"),{amountIn:e,calculatedOut:r,amountOut:r,feePct:0,errors:n}}else{let r=this.calculateOutGivenIn(t,e),o=this.calculateTradeFee(r,a),l=xt.toPct(this.repayFeeApply?a.repayFee:a.exchangeFee),c=r-o,p=t.balanceOut/this.maxOutRatio;return c>p&&n.push("MaxOutRatioExceeded"),{amountIn:e,calculatedOut:r,amountOut:c,feePct:l,errors:n}}}calculateInGivenOut(t,e){let a=_.calculateInGivenOut(t.balanceIn.toString(),t.balanceOut.toString(),t.weightIn.toString(),t.weightOut.toString(),e.toString()),s=BigInt(a);return s<0n?0n:s}calculateOutGivenIn(t,e){let a=_.calculateOutGivenIn(t.balanceIn.toString(),t.balanceOut.toString(),t.weightIn.toString(),t.weightOut.toString(),e.toString()),s=BigInt(a);return s<0n?0n:s}spotPriceInGivenOut(t){let e=_.getSpotPrice(t.balanceOut.toString(),t.balanceIn.toString(),t.weightOut.toString(),t.weightIn.toString(),wt.toBigInt(1,It).toString());return BigInt(e)}spotPriceOutGivenIn(t){let e=_.getSpotPrice(t.balanceIn.toString(),t.balanceOut.toString(),t.weightIn.toString(),t.weightOut.toString(),wt.toBigInt(1,It).toString());return BigInt(e)}calculateTradeFee(t,e){let a=_.calculatePoolTradeFee(t.toString(),this.repayFeeApply?e.repayFee[0]:e.exchangeFee[0],this.repayFeeApply?e.repayFee[1]:e.exchangeFee[1]);return BigInt(a)}};import{CompatibilityLevel as dr}from"polkadot-api";import{Subscription as br,distinctUntilChanged as hr,filter as yr,map as Pr}from"rxjs";import{memoize1 as vi}from"@thi.ng/memoize";import{TLRUCache as Ii}from"@thi.ng/cache";import{ReplaySubject as Bi,Subscription as Ei,combineLatest as Fi,defer as Ri,from as _i,interval as Ci,merge as ki,of as Mi,EMPTY as Di}from"rxjs";import{bufferCount as Hi,bufferTime as Ni,catchError as qi,filter as Gi,finalize as Ui,map as Vi,pairwise as $i,repeat as Wi,skip as Yi,share as Xi,startWith as Ki,switchMap as zi,tap as ji,throttleTime as Qi}from"rxjs/operators";import{hydration as Js,hydrationNext as Zs,hydrationIce as tn}from"@galacticcouncil/descriptors";import{log as pe}from"@galacticcouncil/common";import{map as Vs,shareReplay as $s,tap as Ws}from"rxjs";import{defer as Is,from as xs,of as Os,timer as As}from"rxjs";import{catchError as Es,distinctUntilChanged as Fs,expand as Rs,map as _s,shareReplay as Cs,skip as ks,switchMap as Ms,timeout as Ds}from"rxjs/operators";var{logger:Xs}=pe;import{getWsProvider as rn}from"polkadot-api/ws";import{withLogsRecorder as ln}from"polkadot-api/logs-provider";import{Binary as wn}from"polkadot-api";import{log as de}from"@galacticcouncil/common";import{combineLatest as Fn,concat as Rn,defer as _n,from as Cn}from"rxjs";import{bufferCount as Mn,distinctUntilChanged as Dn,debounceTime as Ln,map as Hn,retry as Nn,startWith as qn,switchMap as Gn,tap as Un,take as Vn,skip as $n,connect as Wn}from"rxjs/operators";var{logger:zn}=de;import{BehaviorSubject as ci}from"rxjs";import{log as be}from"@galacticcouncil/common";var bi={Aave:"AAVE",LBP:"LBP",Omnipool:"OMNI",Stableswap:"STBL",XYK:"XYK",HSM:"HSM"},{logger:hi}=be;var{withTimeout:cr}=nt;import{calculate_in_given_out as ye,calculate_lrna_in_given_out as Pe,calculate_out_given_in as fe,calculate_out_given_lrna_in as Se,calculate_spot_price as Te,calculate_lrna_spot_price as ve,calculate_shares as we,calculate_liquidity_out as Ie,calculate_liquidity_lrna_out as xe,verify_asset_cap as Oe,calculate_liquidity_hub_in as Ae,is_sell_allowed as Be,is_buy_allowed as Ee,is_add_liquidity_allowed as Fe,is_remove_liquidity_allowed as Re,recalculate_asset_fee as _e,recalculate_protocol_fee as Ce}from"@galacticcouncil/math-omnipool";import U from"big.js";var S=class{static calculateSpotPrice(t,e,a,s){return Te(t,e,a,s)}static calculateLrnaSpotPrice(t,e){return ve(t,e)}static calculateInGivenOut(t,e,a,s,n,i,r,o,l,c){return ye(t,e,a,s,n,i,r,o,l,c)}static calculateLrnaInGivenOut(t,e,a,s,n,i){return Pe(t,e,a,s,n,i)}static calculateOutGivenIn(t,e,a,s,n,i,r,o,l,c){return fe(t,e,a,s,n,i,r,o,l,c)}static calculateOutGivenLrnaIn(t,e,a,s,n,i){return Se(t,e,a,s,n,i)}static calculateShares(t,e,a,s){return we(t,e,a,s)}static calculateLiquidityOut(t,e,a,s,n,i,r,o){return Ie(t,e,a,s,n,i,r,o)}static calculateLiquidityLRNAOut(t,e,a,s,n,i,r,o){return xe(t,e,a,s,n,i,r,o)}static calculateCapDifference(t,e,a,s){let n=U(e),i=U(t),r=U(s),o=U(a),l=U(10).pow(18),c=o.div(l);if(n.div(r).lt(c)){let b=c.times(r).minus(n).times(i),d=n.times(U(1).minus(c));return b.div(d).toFixed(0)}else return"0"}static calculateLimitHubIn(t,e,a,s){return Ae(t,e,a,s)}static isSellAllowed(t){return Be(t)}static isBuyAllowed(t){return Ee(t)}static isAddLiquidityAllowed(t){return Fe(t)}static isRemoveLiquidityAllowed(t){return Re(t)}static recalculateAssetFee(t,e,a,s,n,i,r,o,l,c,p){return _e(t,e,a,s,n,i,r,o,l,c,p)}static recalculateProtocolFee(t,e,a,s,n,i,r,o,l,c,p){return Ce(t,e,a,s,n,i,r,o,l,c,p)}static verifyAssetCap(t,e,a,s){return Oe(t,e,a,s)}};import{big as ke}from"@galacticcouncil/common";var{FeeUtils:R}=y,ot=class u{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;hubAssetId;static fromPool(t){return new u(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 a=new Map(this.tokens.map(i=>[i.id,i])),s=a.get(t),n=a.get(e);if(s==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:s.hubReserves,hubReservesOut:n.hubReserves,sharesIn:s.shares,sharesOut:n.shares,decimalsIn:s.decimals,decimalsOut:n.decimals,balanceIn:s.balance,balanceOut:n.balance,tradeableIn:s.tradeable,tradeableOut:n.tradeable,assetInEd:s.existentialDeposit,assetOutEd:n.existentialDeposit}}validateAndBuy(t,e,a){let s=this.calculateInGivenOut(t,e),n=this.calculateInGivenOut(t,e,a),i=s===0n?0:I.calculateBuyFee(s,n),r=[],o=S.isSellAllowed(t.tradeableIn),l=S.isBuyAllowed(t.tradeableOut);(!o||!l)&&r.push("TradeNotAllowed"),(e<this.minTradingLimit||s<t.assetInEd)&&r.push("InsufficientTradingAmount");let c=t.balanceOut/this.maxOutRatio;e>c&&r.push("MaxOutRatioExceeded");let p=t.balanceIn/this.maxInRatio;return n>p&&r.push("MaxInRatioExceeded"),{amountIn:n,calculatedIn:s,amountOut:e,feePct:i,errors:r}}validateAndSell(t,e,a){let s=this.calculateOutGivenIn(t,e),n=this.calculateOutGivenIn(t,e,a),i=I.calculateSellFee(s,n),r=[],o=S.isSellAllowed(t.tradeableIn),l=S.isBuyAllowed(t.tradeableOut);(!o||!l)&&r.push("TradeNotAllowed"),(e<this.minTradingLimit||s<t.assetOutEd)&&r.push("InsufficientTradingAmount");let c=t.balanceIn/this.maxInRatio;e>c&&r.push("MaxInRatioExceeded");let p=t.balanceOut/this.maxOutRatio;return n>p&&r.push("MaxOutRatioExceeded"),{amountIn:e,calculatedOut:s,amountOut:n,feePct:i,errors:r}}calculateInGivenOut(t,e,a){if(t.assetIn==this.hubAssetId)return this.calculateLrnaInGivenOut(t,e,a);let s=S.calculateInGivenOut(t.balanceIn.toString(),t.hubReservesIn.toString(),t.sharesIn.toString(),t.balanceOut.toString(),t.hubReservesOut.toString(),t.sharesOut.toString(),e.toString(),a?R.toRaw(a.assetFee).toString():"0",a?R.toRaw(a.protocolFee).toString():"0",a?R.toRaw(a.maxSlipFee).toString():"0"),n=BigInt(s);return n<0n?0n:n}calculateLrnaInGivenOut(t,e,a){let s=S.calculateLrnaInGivenOut(t.balanceOut.toString(),t.hubReservesOut.toString(),t.sharesOut.toString(),e.toString(),a?R.toRaw(a.assetFee).toString():"0",a?R.toRaw(a.maxSlipFee).toString():"0"),n=BigInt(s);return n<0n?0n:n}calculateOutGivenIn(t,e,a){if(t.assetIn==this.hubAssetId)return this.calculateOutGivenLrnaIn(t,e,a);let s=S.calculateOutGivenIn(t.balanceIn.toString(),t.hubReservesIn.toString(),t.sharesIn.toString(),t.balanceOut.toString(),t.hubReservesOut.toString(),t.sharesOut.toString(),e.toString(),a?R.toRaw(a.assetFee).toString():"0",a?R.toRaw(a.protocolFee).toString():"0",a?R.toRaw(a.maxSlipFee).toString():"0"),n=BigInt(s);return n<0n?0n:n}calculateOutGivenLrnaIn(t,e,a){let s=S.calculateOutGivenLrnaIn(t.balanceOut.toString(),t.hubReservesOut.toString(),t.sharesOut.toString(),e.toString(),a?R.toRaw(a.assetFee).toString():"0",a?R.toRaw(a.maxSlipFee).toString():"0"),n=BigInt(s);return n<0n?0n:n}spotPriceInGivenOut(t){if(t.assetIn==this.hubAssetId)return this.spotPriceLrnaInGivenOut(t);let e=S.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=S.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=S.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=S.calculateLrnaSpotPrice(t.balanceOut.toString(),t.hubReservesOut.toString());return this.normalizeSpot(BigInt(e),t.decimalsIn,t.decimalsOut)}normalizeSpot(t,e,a){let s=e-a;if(s===0)return t;let n=ke.pow10(Math.abs(s));return s>0?t*n:t/n}};import{AccountId as co,Binary as Ot,CompatibilityLevel as uo,Enum as He}from"polkadot-api";import{toHex as go}from"@polkadot-api/utils";import{Subscription as ho,distinctUntilChanged as yo,filter as Po,finalize as fo,map as So,merge as To,tap as vo}from"rxjs";import{HYDRATION_SS58_PREFIX as Io}from"@galacticcouncil/common";var{FeeUtils:eo}=y;var{FeeUtils:Co}=y,ko=Ot.toHex(Ot.fromText("omnipool")),Mo=He("Short");import{calculate_in_given_out as qe,calculate_out_given_in as Ge,calculate_amplification as Ue,calculate_add_one_asset as Ve,calculate_liquidity_out_one_asset as $e,calculate_shares as We,calculate_shares_for_amount as Ye,calculate_spot_price_with_fee as Xe,pool_account_name as Ke,recalculate_peg as ze}from"@galacticcouncil/math-stableswap";var A=class{static getPoolAddress(t){return Ke(t)}static defaultPegs(t){let e=[];for(let a=0;a<t;a++)e.push(["1","1"]);return e}static calculateAmplification(t,e,a,s,n){return Ue(t,e,a,s,n)}static calculateInGivenOut(t,e,a,s,n,i,r){return qe(t,e,a,s,n,i,r)}static calculateAddOneAsset(t,e,a,s,n,i,r){return Ve(t,e,a,s,n,i,r)}static calculateSharesForAmount(t,e,a,s,n,i,r){return Ye(t,e,a,s,n,i,r)}static calculateOutGivenIn(t,e,a,s,n,i,r){return Ge(t,e,a,s,n,i,r)}static calculateLiquidityOutOneAsset(t,e,a,s,n,i,r){return $e(t,e,a,s,n,i,r)}static calculateShares(t,e,a,s,n,i){return We(t,e,a,s,n,i)}static calculateSpotPriceWithFee(t,e,a,s,n,i,r,o){return Xe(t,e,a,s,n,i,r,o)}static recalculatePegs(t,e,a,s,n,i){let r=ze(t,e,a,s,n,i);return JSON.parse(r)}};import{RUNTIME_DECIMALS as je,big as At}from"@galacticcouncil/common";var{FeeUtils:V}=y,$=class u{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;amplification;isRampPeriod;id;fee;totalIssuance;pegs;static fromPool(t){return new u(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 a=new Map(this.tokens.map(i=>[i.id,i])),s=a.get(t),n=a.get(e);if(s==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:s.balance,balanceOut:n.balance,decimalsIn:s.decimals,decimalsOut:n.decimals,tradeableIn:this.id===t?15:s.tradeable,tradeableOut:this.id===e?15:n.tradeable,assetInEd:s.existentialDeposit,assetOutEd:n.existentialDeposit}}validateAndBuy(t,e,a){let s=this.calculateInGivenOut(t,e),n=this.calculateInGivenOut(t,e,a),i=s===0n?0:I.calculateBuyFee(s,n),r=[],o=S.isSellAllowed(t.tradeableIn),l=S.isBuyAllowed(t.tradeableOut);return(!o||!l)&&r.push("TradeNotAllowed"),(e<this.minTradingLimit||s<t.assetInEd)&&r.push("InsufficientTradingAmount"),{amountIn:n,calculatedIn:s,amountOut:e,feePct:i,errors:r}}validateAndSell(t,e,a){let s=this.calculateOutGivenIn(t,e),n=this.calculateOutGivenIn(t,e,a),i=I.calculateSellFee(s,n),r=[],o=S.isSellAllowed(t.tradeableIn),l=S.isBuyAllowed(t.tradeableOut);return(!o||!l)&&r.push("TradeNotAllowed"),(e<this.minTradingLimit||s<t.assetOutEd)&&r.push("InsufficientTradingAmount"),{amountIn:e,calculatedOut:s,amountOut:n,feePct:i,errors:r}}calculateIn(t,e,a){let s=A.calculateInGivenOut(this.getReserves(),Number(t.assetIn),Number(t.assetOut),e.toString(),this.amplification.toString(),a?V.toRaw(a.fee).toString():"0",this.getPegs()),n=BigInt(s);return n<0n?0n:n}calculateAddOneAsset(t,e,a){let s=A.calculateAddOneAsset(this.getReserves(),e.toString(),Number(t.assetIn),this.amplification.toString(),this.totalIssuance.toString(),a?V.toRaw(a.fee).toString():"0",this.getPegs()),n=BigInt(s);return n<0n?0n:n}calculateSharesForAmount(t,e,a){let s=A.calculateSharesForAmount(this.getReserves(),Number(t.assetOut),e.toString(),this.amplification.toString(),this.totalIssuance.toString(),a?V.toRaw(a.fee).toString():"0",this.getPegs()),n=BigInt(s);return n<0n?0n:n}calculateInGivenOut(t,e,a){return t.assetOut==this.id?this.calculateAddOneAsset(t,e,a):t.assetIn==this.id?this.calculateSharesForAmount(t,e,a):this.calculateIn(t,e,a)}spotPriceInGivenOut(t){let e=A.calculateSpotPriceWithFee(this.id.toString(),this.getReserves(),this.amplification.toString(),t.assetOut.toString(),t.assetIn.toString(),this.totalIssuance.toString(),"0",this.getPegs());return this.normalizeSpot(BigInt(e),t.assetOut===this.id,t.assetIn===this.id,t.decimalsOut,t.decimalsIn)}calculateOut(t,e,a){let s=A.calculateOutGivenIn(this.getReserves(),Number(t.assetIn),Number(t.assetOut),e.toString(),this.amplification.toString(),a?V.toRaw(a.fee).toString():"0",this.getPegs()),n=BigInt(s);return n<0n?0n:n}calculateWithdrawOneAsset(t,e,a){let s=A.calculateLiquidityOutOneAsset(this.getReserves(),e.toString(),Number(t.assetOut),this.amplification.toString(),this.totalIssuance.toString(),a?V.toRaw(a.fee).toString():"0",this.getPegs()),n=BigInt(s);return n<0n?0n:n}calculateShares(t,e,a){let s=A.calculateShares(this.getReserves(),this.getAssets(t.assetIn,e),this.amplification.toString(),this.totalIssuance.toString(),a?V.toRaw(a.fee).toString():"0",this.getPegs()),n=BigInt(s);return n<0n?0n:n}calculateOutGivenIn(t,e,a){return t.assetIn==this.id?this.calculateWithdrawOneAsset(t,e,a):t.assetOut==this.id?this.calculateShares(t,e,a):this.calculateOut(t,e,a)}spotPriceOutGivenIn(t){let e=A.calculateSpotPriceWithFee(this.id.toString(),this.getReserves(),this.amplification.toString(),t.assetIn.toString(),t.assetOut.toString(),this.totalIssuance.toString(),"0",this.getPegs());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:a,decimals:s})=>({asset_id:e,amount:a,decimals:s}));return JSON.stringify(t,j.jsonFormatter)}getAssets(t,e){let a={asset_id:Number(t),amount:e.toString()};return JSON.stringify([a],j.jsonFormatter)}normalizeSpot(t,e,a,s,n){return e?t*At.pow10(je-n):a?t/At.pow10(n-s):t}};import{AccountId as zl,CompatibilityLevel as jl}from"polkadot-api";import{toHex as Jl}from"@polkadot-api/utils";import{blake2b as tc}from"@noble/hashes/blake2b";import{Subscription as ac,distinctUntilChanged as sc,filter as nc,map as ic,merge as rc,tap as oc}from"rxjs";import{HYDRATION_SS58_PREFIX as cc,RUNTIME_DECIMALS as uc}from"@galacticcouncil/common";import{Binary as yl}from"polkadot-api";import{decodeEventLog as fl}from"viem";var{FeeUtils:ql}=y;var{FeeUtils:xc}=y;import{calculate_in_given_out as ta,calculate_out_given_in as ea,calculate_pool_trade_fee as aa,get_spot_price as sa,calculate_liquidity_in as na,calculate_shares as ia,calculate_spot_price as ra,calculate_spot_price_with_fee as oa,calculate_liquidity_out_asset_a as la,calculate_liquidity_out_asset_b as ca}from"@galacticcouncil/math-xyk";var L=class{static getSpotPrice(t,e,a){return sa(t,e,a)}static calculateInGivenOut(t,e,a){return ta(t,e,a)}static calculateOutGivenIn(t,e,a){return ea(t,e,a)}static calculatePoolTradeFee(t,e,a){return aa(t,e,a)}static calculateLiquidityIn(t,e,a){return na(t,e,a)}static calculateSpotPrice(t,e){return ra(t,e)}static calculateSpotPriceWithFee(t,e,a,s){return oa(t,e,a,s)}static calculateShares(t,e,a){return ia(t,e,a)}static calculateLiquidityOutAssetA(t,e,a,s){return la(t,e,a,s)}static calculateLiquidityOutAssetB(t,e,a,s){return ca(t,e,a,s)}};import{big as ua}from"@galacticcouncil/common";var{FeeUtils:Bt}=y,lt=class u{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;static fromPool(t){return new u(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 a=new Map(this.tokens.map(i=>[i.id,i])),s=a.get(t),n=a.get(e);if(s==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:s.decimals,decimalsOut:n.decimals,balanceIn:s.balance,balanceOut:n.balance,assetInEd:s.existentialDeposit,assetOutEd:n.existentialDeposit}}validateAndBuy(t,e,a){let s=this.calculateInGivenOut(t,e),n=this.calculateTradeFee(s,a),i=Bt.toPct(a.exchangeFee),r=s+n,o=[];(e<this.minTradingLimit||s<t.assetInEd)&&o.push("InsufficientTradingAmount");let l=t.balanceOut/this.maxOutRatio;e>l&&o.push("MaxOutRatioExceeded");let c=t.balanceIn/this.maxInRatio;return r>c&&o.push("MaxInRatioExceeded"),{amountIn:r,calculatedIn:s,amountOut:e,feePct:i,errors:o}}validateAndSell(t,e,a){let s=this.calculateOutGivenIn(t,e),n=this.calculateTradeFee(s,a),i=Bt.toPct(a.exchangeFee),r=s-n,o=[];(e<this.minTradingLimit||s<t.assetOutEd)&&o.push("InsufficientTradingAmount");let l=t.balanceIn/this.maxInRatio;e>l&&o.push("MaxInRatioExceeded");let c=t.balanceOut/this.maxOutRatio;return r>c&&o.push("MaxOutRatioExceeded"),{amountIn:e,calculatedOut:s,amountOut:r,feePct:i,errors:o}}calculateInGivenOut(t,e){let a=L.calculateInGivenOut(t.balanceIn.toString(),t.balanceOut.toString(),e.toString()),s=BigInt(a);return s<0n?0n:s}calculateOutGivenIn(t,e){let a=L.calculateOutGivenIn(t.balanceIn.toString(),t.balanceOut.toString(),e.toString()),s=BigInt(a);return s<0n?0n:s}spotPriceInGivenOut(t){let e=L.calculateSpotPrice(t.balanceOut.toString(),t.balanceIn.toString());return this.normalizeSpot(BigInt(e),t.decimalsOut,t.decimalsIn)}spotPriceOutGivenIn(t){let e=L.calculateSpotPrice(t.balanceIn.toString(),t.balanceOut.toString());return this.normalizeSpot(BigInt(e),t.decimalsIn,t.decimalsOut)}calculateTradeFee(t,e){let a=L.calculatePoolTradeFee(t.toString(),e.exchangeFee[0],e.exchangeFee[1]);return BigInt(a)}normalizeSpot(t,e,a){let s=e-a;if(s===0)return t;let n=ua.pow10(Math.abs(s));return s>0?t*n:t/n}};import{CompatibilityLevel as Qc}from"polkadot-api";import{Subscription as Zc}from"rxjs";import{big as Et,RUNTIME_DECIMALS as Ft}from"@galacticcouncil/common";var ct=class u{type;address;tokens;maxInRatio;maxOutRatio;minTradingLimit;static fromPool(t){return new u(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 a=new Map(this.tokens.map(i=>[i.id,i])),s=a.get(t),n=a.get(e);if(s==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:s.balance,balanceOut:n.balance,decimalsIn:s.decimals,decimalsOut:n.decimals,assetInEd:0n,assetOutEd:0n}}validateAndBuy(t,e,a){let s=this.calculateInGivenOut(t,e),n=[];return e>t.balanceOut&&n.push("TradeNotAllowed"),{amountIn:s,calculatedIn:s,amountOut:e,feePct:0,errors:n}}validateAndSell(t,e,a){let s=this.calculateOutGivenIn(t,e),n=[];return s>t.balanceOut&&n.push("TradeNotAllowed"),{amountIn:e,calculatedOut:s,amountOut:s,feePct:0,errors:n}}calculateInGivenOut(t,e){return e}calculateOutGivenIn(t,e){return e}spotPriceInGivenOut(t){return Et.toBigInt(1,Ft)}spotPriceOutGivenIn(t){return Et.toBigInt(1,Ft)}calculateTradeFee(t,e){return 0n}};import{AccountId as Tm}from"polkadot-api";import{toHex as wm}from"@polkadot-api/utils";import{Subscription as xm,filter as Om,map as Am,mergeMap as Bm}from"rxjs";import{erc20 as ba,HYDRATION_SS58_PREFIX as Fm}from"@galacticcouncil/common";var Mu=BigInt("0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");import{Binary as Xu}from"polkadot-api";import{decodeEventLog as zu}from"viem";import em from"big.js";import{big as sm,erc20 as da,h160 as ga}from"@galacticcouncil/common";var{ERC20:im}=da,{H160:rm}=ga;var om=10n**27n;var{ERC20:Hm}=ba;import{calculate_collateral_in_given_hollar_out as ya,calculate_collateral_out_given_hollar_in as Pa,calculate_hollar_in_given_collateral_out as fa,calculate_hollar_out_given_collateral_in as Sa,calculate_imbalance as Ta,calculate_max_price as va,calculate_buyback_limit as wa,calculate_buyback_price_with_fee as Ia}from"@galacticcouncil/math-hsm";var E=class{static calculateCollateralInGivenHollarOut(t,e,a){return ya(t,e,a)}static calculateCollateralOutGivenHollarIn(t,e,a){return Pa(t,e,a)}static calculateHollarOutGivenCollateralIn(t,e,a){return Sa(t,e,a)}static calculateHollarInGivenCollateralOut(t,e,a){return fa(t,e,a)}static calculateImbalance(t,e,a){return Ta(t,e,a)}static calculateBuybackLimit(t,e){return wa(t,e)}static calculateBuybackPriceWithFee(t,e,a){return Ia(t,e,a)}static calculateMaxPrice(t,e){return va(t,e)}};import{big as k,RUNTIME_DECIMALS as ut}from"@galacticcouncil/common";var{FeeUtils:W}=y,mt=class u extends ${hsmAddress;hsmMintCapacity;hollarId;hollarH160;collateralId;collateralBalance;maxBuyPriceCoefficient;maxInHolding;purchaseFee;buyBackFee;buyBackRate;static fromPool(t){return new u(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,a){let s=this.parsePair(t.assetOut,t.assetIn),n=super.calculateInGivenOut(s,e,{fee:this.fee}),i=this.calculateBuybackLimit(t);e>i&&a.push("MaxBuyBackExceeded");let r=this.calculateMaxPrice(t);return this.calculateBuyPrice(t,e,n)>r&&a.push("MaxBuyPriceExceeded"),n>this.collateralBalance&&a.push("InsufficientCollateral"),a}validateTradeHollarOut(t,e,a){return this.collateralBalance+t>this.maxInHolding&&a.push("MaxHoldingExceeded"),e>this.hsmMintCapacity&&a.push("FacilitatorCapacityExceeded"),a}validateTradeConstraints(t,e,a){let s=[];return t.assetIn===this.hollarId?this.validateTradeHollarIn(t,e,s):this.validateTradeHollarOut(e,a,s)}validateAndBuy(t,e){let a=this.calculateInGivenOut(t,e),s=this.validateTradeConstraints(t,a,e);return{amountIn:a,calculatedIn:a,amountOut:e,feePct:0,errors:s}}validateAndSell(t,e){let a=this.calculateOutGivenIn(t,e),s=this.validateTradeConstraints(t,e,a);return{amountIn:e,calculatedOut:a,amountOut:a,feePct:0,errors:s}}calculateHollarInGivenCollateralOut(t,e){let a=super.calculateInGivenOut(t,e,{fee:this.fee}),s=E.calculateHollarInGivenCollateralOut(e.toString(),a.toString(),W.toRaw(this.buyBackFee).toString());return BigInt(s)}calculateCollateralInGivenHollarOut(t){let e=this.getCollateralPeg(),a=E.calculateCollateralInGivenHollarOut(t.toString(),JSON.stringify(e),W.toRaw(this.purchaseFee).toString());return BigInt(a)}calculateInGivenOut(t,e){return t.assetOut==this.hollarId?this.calculateCollateralInGivenHollarOut(e):this.calculateHollarInGivenCollateralOut(t,e)}calculateCollateralOutGivenHollarIn(t,e){let a=super.calculateOutGivenIn(t,e,{fee:this.fee}),s=E.calculateCollateralOutGivenHollarIn(e.toString(),a.toString(),W.toRaw(this.buyBackFee).toString());return BigInt(s)}calculateHollarOutGivenCollateralIn(t){let e=this.getCollateralPeg(),a=E.calculateHollarOutGivenCollateralIn(t.toString(),JSON.stringify(e),W.toRaw(this.purchaseFee).toString());return BigInt(a)}calculateOutGivenIn(t,e){return t.assetIn==this.hollarId?this.calculateCollateralOutGivenHollarIn(t,e):this.calculateHollarOutGivenCollateralIn(e)}calculateImbalance(t){let e=this.getCollateralPeg(),a=E.calculateImbalance(t.balanceIn.toString(),JSON.stringify(e),t.balanceOut.toString());return BigInt(a)}calculateBuybackLimit(t){let e=this.calculateImbalance(t),a=E.calculateBuybackLimit(e.toString(),W.toRaw(this.buyBackRate).toString());return BigInt(a)}calculateBuyPrice(t,e,a){let s=E.calculateBuybackPriceWithFee(a.toString(),e.toString(),W.toRaw(this.buyBackFee).toString()),[n,i]=JSON.parse(s),r=k.pow10(t.decimalsIn+ut-t.decimalsOut);return BigInt(n)*r/BigInt(i)}calculateMaxPrice(t){let e=this.getCollateralPeg(),a=E.calculateMaxPrice(JSON.stringify(e),this.maxBuyPriceCoefficient.toString()),[s,n]=JSON.parse(a),i=k.pow10(ut-t.decimalsOut);return BigInt(s)*i/BigInt(n)}spotPriceInGivenOut(t){let e=k.toBigInt(1,t.decimalsOut),s=this.calculateInGivenOut(t,e)*k.pow10(ut-t.decimalsOut);return this.normalizeSpotPrice(s,t.decimalsOut,t.decimalsIn)}spotPriceOutGivenIn(t){let e=k.toBigInt(1,t.decimalsIn),s=this.calculateOutGivenIn(t,e)*k.pow10(ut-t.decimalsIn);return this.normalizeSpotPrice(s,t.decimalsIn,t.decimalsOut)}getCollateralPeg(){let t=this.tokens.findIndex(s=>s.id!==this.hollarId),e=this.pegs[t],a=this.tokens[t].decimals;return this.isDefaultPeg(e)?[k.toBigInt(1,18).toString(),k.toBigInt(1,a).toString()]:e}isDefaultPeg(t){let[e,a]=t;return Array.isArray(t)&&t.length===2&&e==="1"&&a==="1"}normalizeSpotPrice(t,e,a){let s=e-a;if(s===0)return t;let n=k.pow10(Math.abs(s));return s>0?t*n:t/n}};import{AccountId as Bp,CompatibilityLevel as Ep}from"polkadot-api";import{toHex as _p}from"@polkadot-api/utils";import{Subscription as Mp,combineLatest as Dp,filter as Lp,map as Hp,mergeMap as Np,pairwise as qp}from"rxjs";import{h160 as Oa,HYDRATION_SS58_PREFIX as Up}from"@galacticcouncil/common";import{Binary as cp}from"polkadot-api";import{decodeEventLog as mp}from"viem";var{FeeUtils:jp}=y,{H160:Qp}=Oa;var Z=class{static get(t){switch(t.type){case"Aave":return ct.fromPool(t);case"XYK":return lt.fromPool(t);case"Omnipool":return ot.fromPool(t);case"LBP":return it.fromPool(t);case"Stableswap":return $.fromPool(t);case"HSM":return mt.fromPool(t);default:throw new Error("Pool type "+t.type+" is not supported yet")}}};import{log as Ea}from"@galacticcouncil/common";import{Subject as Ed,Subscription as Fd,takeUntil as Rd}from"rxjs";var pt=class extends Error{constructor(t,e){super(),this.message=`Route from ${t} to ${e} not found in current configuration`,this.name="RouteNotFound"}};var{logger:Kd}=Ea;var tt=class{getProposals(t,e,a){let s=a.filter(m=>m.type==="XYK"),n=a.filter(m=>m.type!=="XYK"),i=new Set(n.map(m=>m.tokens).flat().map(m=>m.id)),r=i.has(t),o=i.has(e),l=new z,c=m=>{let h=dt(m),f=Object.keys(h),F=f.flatMap(O=>h[O]);return l.buildAndPopulateGraph(f,F)};if(!r&&!o){let m=s.filter(F=>F.tokens.find(O=>O.id===t)||F.tokens.find(O=>O.id===e)),h=c(m),f=l.findPaths(h,t,e);return this.parsePaths(f)}if(r&&o){let m=c(n),h=l.findPaths(m,t,e);return this.parsePaths(h)}let p=r?e:t,b=s.filter(m=>m.tokens.some(h=>h.id===p));if(b.length===0)return[];let d=[...n,...b],P=c(d),g=l.findPaths(P,t,e);return this.parsePaths(g)}parsePaths(t){let e=[];for(let a of t){let s=[];for(let n=0;n<a.length;n++){let i=a[n],r=a[n+1];if(r==null)break;s.push(this.toEdge(i,r))}e.push(s)}return e}toEdge(t,e){return[e[1],t[0],e[0]]}};var et=class{routeSuggester;routeProposals;ctx;filter={};constructor(t){this.ctx=t,this.routeSuggester=new tt,this.routeProposals=new Map}async withFilter(t){this.filter=t||{},this.routeProposals.clear(),this.onFilterChanged()}onFilterChanged(){}buildRouteKey(t,e,a){return`${t}->${e}::${a.length}`}applyPoolFilter(t){let{useOnly:e=[],exclude:a=[]}=this.filter,s=new Set(e),n=new Set(a);return t.filter(i=>n.has(i.type)?!1:s.size>0?s.has(i.type):!0)}async getPools(){let t=await this.ctx.getPools();return this.applyPoolFilter(t)}async getRoutes(t,e){let a=await this.getPools();return this.validateInput(t,e,a),this.getPaths(t,e,a)}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(s=>s!==t).map(s=>this.getRoutes(s,t)))).filter(s=>s.length>0).map(([s])=>s[0].assetIn).sort()}validateInput(t,e,a){if(a.length===0)throw new Error("No pools configured");if(t===e)throw new Error("Trading pair can't be identical");let s=this.getAssets(a);if(!s.has(t))throw new Error(t+" is not supported asset");if(!s.has(e))throw new Error(e+" is not supported asset");return this.toPoolsMap(a)}getAssets(t){let e=t.map(a=>a.tokens.map(s=>s.id)).flat().sort((a,s)=>a>s?1:-1);return new Set(e)}getPaths(t,e,a){let s=this.toPoolsMap(a);return this.getProposals(t,e,a).filter(i=>this.validPath(i,s)).map(i=>this.toHops(i,s))}getProposals(t,e,a){let s=this.buildRouteKey(t,e,a);if(this.routeProposals.has(s))return this.routeProposals.get(s);let n=this.routeSuggester.getProposals(t,e,a);return this.routeProposals.set(s,n),n}validPath(t,e){return t.length>0&&t.map(a=>this.validEdge(a,e)).reduce((a,s)=>a&&s)}validEdge([t,e,a],s){return s.get(t)?.validatePair(e,a)||!1}toPoolsMap(t){return new Map(t.map(e=>[e.address,Z.get(e)]))}toHops(t,e){return t.map(([a,s,n])=>{let i=e.get(a);return{poolAddress:a,poolId:i?.id,pool:i?.type,assetIn:s,assetOut:n}})}};import{big as w,RUNTIME_DECIMALS as Y}from"@galacticcouncil/common";var Rt=(e=>(e.Buy="Buy",e.Sell="Sell",e))(Rt||{}),_t=(a=>(a.Dca="Dca",a.TwapSell="TwapSell",a.TwapBuy="TwapBuy",a))(_t||{}),Ct=(a=>(a.OrderTooSmall="OrderTooSmall",a.OrderTooBig="OrderTooBig",a.OrderImpactTooBig="OrderImpactTooBig",a))(Ct||{});var{FeeUtils:kt}=y,at=class extends et{mlr;constructor(t){super(t),this.mlr=new Map}onFilterChanged(){this.mlr.clear()}buildCtxSync(t,e,a){let s=super.validateInput(t,e,a),n=super.getPaths(t,e,a);if(!n.length)throw new pt(t,e);return{paths:n,pools:a,poolsMap:s}}async withCtx(t,e,a){let s=await super.getPools(),n=this.buildCtxSync(t,e,s);return a(n)}isDirectTrade(t){return t.length==1}findBestSellRoute(t){let e=t.sort((a,s)=>{let n=a[a.length-1].amountOut,i=s[s.length-1].amountOut;return n>i?-1:1});return e.find(a=>a.every(s=>s.errors.length==0))||e[0]}getRouteFeeRange(t){if(t.filter(a=>a.tradeFeeRange).length>0){let a=t.map(n=>n.tradeFeeRange?.[0]??n.tradeFeePct).reduce((n,i)=>n+i),s=t.map(n=>n.tradeFeeRange?.[1]??n.tradeFeePct).reduce((n,i)=>n+i);return[a,s]}}getPoolFeeRange(t,e){let a=t.min?kt.toPct(t.min):void 0,s=t.max?kt.toPct(t.max):void 0;if(a&&s)return[a,Math.max(s,e)]}async getBestSell(t,e,a){return this.getSell(t,e,a)}getSellSpot(t){let e=t[t.length-1];return t.length===1?e.spotPrice:this.calculateSpot(t)}async getSell(t,e,a,s){return this.withCtx(t,e,async({paths:n,poolsMap:i})=>{let r;if(s)r=await this.toSellSwaps(a,s,i);else{let o=n.map(c=>this.toSellSwaps(a,c,i)),l=await Promise.all(o);r=this.findBestSellRoute(l)}return this.buildSell(i,r)})}async getSells(t,e,a){return this.withCtx(t,e,async({paths:s,poolsMap:n})=>{let i=s.map(o=>this.toSellSwaps(a,o,n));return(await Promise.all(i)).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 a=e[0],s=e[e.length-1],n=this.isDirectTrade(e),i=this.getSellSpot(e),r=s.amountOut,o=n?s.calculatedOut:this.calculateDelta0Y(a.amountIn,e,t),l=o-r,c=this.getRouteFeeRange(e),p=n?s.tradeFeePct:I.calculateSellFee(o,r),b=B.mulSpot(a.amountIn,i,a.assetInDecimals,s.assetOutDecimals),d=I.calculateDiffToRef(o,b);return{type:"Sell",amountIn:a.amountIn,amountOut:s.amountOut,spotPrice:i,tradeFee:l,tradeFeePct:p,tradeFeeRange:c,priceImpactPct:d,swaps:e,toHuman(){return{type:"Sell",amountIn:w.toDecimal(a.amountIn,a.assetInDecimals),amountOut:w.toDecimal(s.amountOut,s.assetOutDecimals),spotPrice:w.toDecimal(i,Y),tradeFee:w.toDecimal(l,s.assetOutDecimals),tradeFeePct:p,tradeFeeRange:c,priceImpactPct:d,swaps:e.map(P=>P.toHuman())}}}}calculateSpot(t){return t.map(e=>e.spotPrice).reduce((e,a)=>e*a/10n**BigInt(Y))}calculateDelta0Y(t,e,a){let s=[];for(let n=0;n<e.length;n++){let i=e[n],r=a.get(i.poolAddress);if(r==null)throw new Error("Pool does not exit");let o=r.parsePair(i.assetIn,i.assetOut),l;n>0?l=s[n-1]:l=t;let c=r.calculateOutGivenIn(o,l);s.push(c)}return s[s.length-1]}async calculateMostLiquidRoute(t,e,a){let{paths:s,pools:n,poolsMap:i}=a,l=n.filter(g=>g.tokens.some(m=>m.id===t)).map(g=>g.type==="Aave"?g.tokens:g.tokens.filter(m=>m.id===t)).map(g=>g.map(m=>m.balance).reduce((m,h)=>m+h)).sort((g,m)=>m<g?-1:1)[0],c=B.getFraction(l,.1),p=await Promise.all(s.map(g=>this.toSellSwaps(c,g,i))),d=this.findBestSellRoute(p).map(g=>({poolAddress:g.poolAddress,poolId:g?.poolId,pool:g.pool,assetIn:g.assetIn,assetOut:g.assetOut})),P=this.buildRouteKey(t,e,n);return this.mlr.set(P,d),d}async toSellSwaps(t,e,a){let s=[];for(let n=0;n<e.length;n++){let i=e[n],r=a.get(i.poolAddress);if(r==null)throw new Error("Pool does not exit");let o=r.parsePair(i.assetIn,i.assetOut),l;n>0?l=s[n-1].amountOut:l=typeof t=="string"?w.toBigInt(t,o.decimalsIn):t;let c=await this.ctx.getPoolFees(o,r),{amountOut:p,calculatedOut:b,feePct:d,errors:P}=r.validateAndSell(o,l,c),g=this.getPoolFeeRange(c,d),m=r.spotPriceOutGivenIn(o),h=B.mulSpot(l,m,o.decimalsIn,o.decimalsOut),f=I.calculateDiffToRef(b,h);s.push({...i,assetInDecimals:o.decimalsIn,assetOutDecimals:o.decimalsOut,amountIn:l,amountOut:p,calculatedOut:b,spotPrice:m,tradeFeePct:d,tradeFeeRange:g,priceImpactPct:f,errors:P,isSupply(){return r.type==="Aave"&&r.tokens[0].id===i.assetIn},isWithdraw(){return r.type==="Aave"&&r.tokens[1].id===i.assetIn},toHuman(){return{...i,amountIn:w.toDecimal(l,o.decimalsIn),amountOut:w.toDecimal(p,o.decimalsOut),calculatedOut:w.toDecimal(b,o.decimalsOut),spotPrice:w.toDecimal(m,Y),tradeFeePct:d,tradeFeeRange:g,priceImpactPct:f,errors:P}}})}return s}async getMostLiquidRoute(t,e){return this.withCtx(t,e,async a=>{let s=this.buildRouteKey(t,e,a.pools),n=this.mlr.get(s);return n||this.calculateMostLiquidRoute(t,e,a)})}async getSpotPrice(t,e){return this.withCtx(t,e,async a=>{let{pools:s,poolsMap:n}=a,i=this.buildRouteKey(t,e,s),r=this.mlr.get(i);r||(r=await this.calculateMostLiquidRoute(t,e,a));let o=await this.toSellSwaps("1",r,n);return{amount:this.getSellSpot(o),decimals:Y}}).catch(()=>{})}findBestBuyRoute(t){let e=t.sort((a,s)=>{let n=a[0].amountIn,i=s[0].amountIn;return n>i?1:-1});return e.find(a=>a.every(s=>s.errors.length==0))||e[0]}async getBestBuy(t,e,a){return this.getBuy(t,e,a)}getBuySpot(t){let e=t[0];return t.length===1?e.spotPrice:this.calculateSpot(t)}async getBuy(t,e,a,s){return this.withCtx(t,e,async({paths:n,poolsMap:i})=>{let r;if(s)r=await this.toBuySwaps(a,s,i);else{let o=n.map(c=>this.toBuySwaps(a,c,i)),l=await Promise.all(o);r=this.findBestBuyRoute(l)}return this.buildBuy(i,r)})}async getBuys(t,e,a){return this.withCtx(t,e,async({paths:s,poolsMap:n})=>{let i=s.map(o=>this.toBuySwaps(a,o,n));return(await Promise.all(i)).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 a=e[e.length-1],s=e[0],n=this.isDirectTrade(e),i=this.getBuySpot(e),r=s.amountIn,o=n?s.calculatedIn:this.calculateDelta0X(a.amountOut,e,t),l=r-o,c=this.getRouteFeeRange(e),p=n?s.tradeFeePct:I.calculateBuyFee(o,r),b=B.mulSpot(a.amountOut,i,a.assetOutDecimals,s.assetInDecimals),d;return o===0n?d=-100:d=I.calculateDiffToRef(b,o),{type:"Buy",amountOut:a.amountOut,amountIn:s.amountIn,spotPrice:i,tradeFee:l,tradeFeePct:p,tradeFeeRange:c,priceImpactPct:d,swaps:e,toHuman(){return{type:"Buy",amountOut:w.toDecimal(a.amountOut,a.assetOutDecimals),amountIn:w.toDecimal(s.amountIn,s.assetInDecimals),spotPrice:w.toDecimal(i,Y),tradeFee:w.toDecimal(l,s.assetInDecimals),tradeFeePct:p,tradeFeeRange:c,priceImpactPct:d,swaps:e.map(P=>P.toHuman())}}}}calculateDelta0X(t,e,a){let s=[];for(let n=e.length-1;n>=0;n--){let i=e[n],r=a.get(i.poolAddress);if(r==null)throw new Error("Pool does not exit");let o=r.parsePair(i.assetIn,i.assetOut),l;n==e.length-1?l=t:l=s[0];let c=r.calculateInGivenOut(o,l);s.unshift(c)}return s[0]}async toBuySwaps(t,e,a){let s=[];for(let n=e.length-1;n>=0;n--){let i=e[n],r=a.get(i.poolAddress);if(r==null)throw new Error("Pool does not exit");let o=r.parsePair(i.assetIn,i.assetOut),l;n==e.length-1?l=typeof t=="string"?w.toBigInt(t,o.decimalsOut):t:l=s[0].amountIn;let c=await this.ctx.getPoolFees(o,r),{amountIn:p,calculatedIn:b,feePct:d,errors:P}=r.validateAndBuy(o,l,c),g=this.getPoolFeeRange(c,d),m=r.spotPriceInGivenOut(o),h=B.mulSpot(l,m,o.decimalsOut,o.decimalsIn),f;b===0n?f=-100:f=I.calculateDiffToRef(h,b),s.unshift({...i,assetInDecimals:o.decimalsIn,assetOutDecimals:o.decimalsOut,amountOut:l,amountIn:p,calculatedIn:b,spotPrice:m,tradeFeePct:d,tradeFeeRange:g,priceImpactPct:f,errors:P,isSupply(){return r.type==="Aave"&&r.tokens[0].id===i.assetIn},isWithdraw(){return r.type==="Aave"&&r.tokens[1].id===i.assetIn},toHuman(){return{...i,amountOut:w.toDecimal(l,o.decimalsOut),amountIn:w.toDecimal(p,o.decimalsIn),calculatedIn:w.toDecimal(b,o.decimalsIn),spotPrice:w.toDecimal(m,Y),tradeFeePct:d,tradeFeeRange:g,priceImpactPct:f,errors:P}}})}return s}};import{big as v}from"@galacticcouncil/common";var Mt=6e3,Dt=1000000000000000n,st=6,yt=-5,Pt=216e5,pb=3,Lt=.1,Ht=6;import{Enum as Nt}from"polkadot-api";var H=class{static build(t){return t.map(({assetIn:e,assetOut:a,pool:s,poolId:n})=>s==="Stableswap"?{pool:Nt("Stableswap",n),asset_in:e,asset_out:a}:{pool:Nt(s),asset_in:e,asset_out:a})}};var ft=class{schedulerOptions;router;constructor(t,e={}){this.router=new at(t),this.router.withFilter({exclude:["HSM"]}),this.schedulerOptions=Object.freeze({blockTime:e.blockTime??6e3,minBudgetInNative:e.minBudgetInNative??Dt})}get blockTime(){return this.schedulerOptions.blockTime}get minOrderBudget(){return this.schedulerOptions.minBudgetInNative}async getDcaOrder(t,e,a,s,n){let i=await this.router.getBestSell(t,e,a),{amountIn:r,swaps:o,priceImpactPct:l}=i,c=o[0],p=o[o.length-1],{assetInDecimals:b}=c,{assetOutDecimals:d}=p,P=Math.abs(l),g=await this.getMinimumOrderBudget(t,b),m=this.getOptimalTradeCount(P),h=this.getMaximumTradeCount(r,g,s),f=n||Math.min(m,h),F=Math.round(s/f),O=r/BigInt(f),x=await this.router.getBestSell(t,e,O),N=r<g,M=[];N&&M.push("OrderTooSmall");let G=await this.getAssetOutEd(p),D=x.amountOut*BigInt(f),Gt=this.toBlockPeriod(F),Ut=x.tradeFee*BigInt(f),Vt=H.build(o),St={assetIn:t,assetOut:e,assetOutEd:G,errors:M,maxTradeCount:h,tradeCount:f,tradeFee:Ut,tradeImpactPct:x.priceImpactPct,tradePeriod:Gt,tradeRoute:Vt,type:"Dca"};return{...St,amountIn:r,amountOut:D,tradeAmountIn:x.amountIn,tradeAmountOut:x.amountOut,toHuman(){return{...St,amountIn:v.toDecimal(r,b),amountOut:v.toDecimal(D,d),assetOutEd:v.toDecimal(G,d),tradeAmountIn:v.toDecimal(x.amountIn,b),tradeAmountOut:v.toDecimal(x.amountOut,d)}}}}async getMinimumOrderBudget(t,e){if(0===t)return this.minOrderBudget;let a=await this.router.getSpotPrice(0,t);if(a)return B.mulSpot(this.minOrderBudget,a.amount,12,e);let s=await this.router.getSpotPrice(t,0);if(s)return B.divSpot(this.minOrderBudget,s.amount,12,e);throw new Error("Unable to calculate order budget")}getMaximumTradeCount(t,e,a){let s=e*2n/10n;if(s===0n)return 0;let n=Number(t/s),i=Math.floor(a/this.blockTime),r=Math.max(0,Math.floor(i*(1-.1)));return Math.min(n,r)}getOptimalTradeCount(t){let e=Math.round(t*10)||1;return Math.max(e,3)}async getOpenBudgetDcaOrder(t,e,a,s){let n=await this.router.getBestSell(t,e,a),{swaps:i}=n,r=i[0],o=i[i.length-1],{assetInDecimals:l}=r,{assetOutDecimals:c}=o,p=await this.getMinimumOrderBudget(t,l),b=n.amountIn<p,d=[];b&&d.push("OrderTooSmall");let P=await this.getAssetOutEd(o),g=this.toBlockPeriod(s),m=H.build(i),h={assetIn:t,assetOut:e,assetOutEd:P,errors:d,maxTradeCount:0,tradeCount:0,tradeFee:n.tradeFee,tradeImpactPct:n.priceImpactPct,tradePeriod:g,tradeRoute:m,type:"Dca"};return{...h,amountIn:0n,amountOut:0n,tradeAmountIn:n.amountIn,tradeAmountOut:n.amountOut,toHuman(){return{...h,amountIn:"0",amountOut:"0",assetOutEd:v.toDecimal(P,c),tradeAmountIn:v.toDecimal(n.amountIn,l),tradeAmountOut:v.toDecimal(n.amountOut,c)}}}}async getTwapSellOrder(t,e,a){let s=await this.router.getBestSell(t,e,a),{amountIn:n,swaps:i,priceImpactPct:r}=s,o=i[0],l=i[i.length-1],{assetInDecimals:c}=o,{assetOutDecimals:p}=l,b=Math.abs(r),d=this.getTwapTradeCount(b),P=n/BigInt(d),[g,m]=await Promise.all([this.getMinimumOrderBudget(t,c),this.router.getBestSell(o.assetIn,l.assetOut,P)]),h=d===1,f=n<g,F=m.priceImpactPct<-5,O=[];f||h?O.push("OrderTooSmall"):F&&O.push("OrderImpactTooBig");let x=await this.getAssetOutEd(l),N=m.amountOut*BigInt(d),M=m.tradeFee*BigInt(d),G=H.build(i),D={assetIn:t,assetOut:e,assetOutEd:x,errors:O,tradeCount:d,tradeImpactPct:m.priceImpactPct,tradePeriod:6,tradeRoute:G,type:"TwapSell"};return{...D,amountIn:n,amountOut:N,tradeAmountIn:m.amountIn,tradeAmountOut:m.amountOut,tradeFee:M,toHuman(){return{...D,amountIn:v.toDecimal(n,c),amountOut:v.toDecimal(N,p),assetOutEd:v.toDecimal(x,p),tradeAmountIn:v.toDecimal(m.amountIn,c),tradeAmountOut:v.toDecimal(m.amountOut,p),tradeFee:v.toDecimal(M,p)}}}}async getTwapBuyOrder(t,e,a){let s=await this.router.getBestBuy(t,e,a),{amountOut:n,swaps:i,priceImpactPct:r}=s,o=i[0],l=i[i.length-1],{assetInDecimals:c}=o,{assetOutDecimals:p}=l,b=Math.abs(r),d=this.getTwapTradeCount(b),P=n/BigInt(d),[g,m]=await Promise.all([this.getMinimumOrderBudget(t,c),this.router.getBestBuy(o.assetIn,l.assetOut,P)]),h=m.amountIn*BigInt(d),f=d===1,F=h<g,O=m.priceImpactPct<-5,x=[];F||f?x.push("OrderTooSmall"):O&&x.push("OrderImpactTooBig");let N=await this.getAssetOutEd(l),M=m.tradeFee*BigInt(d),G=H.build(i),D={assetIn:t,assetOut:e,assetOutEd:N,errors:x,tradeCount:d,tradeImpactPct:m.priceImpactPct,tradePeriod:6,tradeRoute:G,type:"TwapBuy"};return{...D,amountIn:h,amountOut:n,tradeAmountIn:m.amountIn,tradeAmountOut:m.amountOut,tradeFee:M,toHuman(){return{...D,amountIn:v.toDecimal(h,c),amountOut:v.toDecimal(n,p),assetOutEd:v.toDecimal(N,p),tradeAmountIn:v.toDecimal(m.amountIn,c),tradeAmountOut:v.toDecimal(m.amountOut,p),tradeFee:v.toDecimal(M,c)}}}}getTwapTradeCount(t){let e=this.getOptimalTradeCount(t);if(this.getTwapExecutionTime(e)>216e5){let s=216e5/(this.blockTime*6);return Math.round(s)}return e}getTwapExecutionTime(t){return t*6*this.blockTime}toBlockPeriod(t){let e=t/this.blockTime,a=Math.round(e);return Math.max(a,6)}async getAssetOutEd(t){let s=(await this.router.getPools()).find(n=>n.address===t.poolAddress)?.tokens.find(n=>n.id===t.assetOut);if(!s)throw new Error(`Asset ${t.assetOut} not found in pool ${t.poolAddress}`);return s.existentialDeposit}};export{Lt as DCA_TIME_RESERVE,Mt as DEFAULT_BLOCK_TIME,Dt as DEFAULT_MIN_BUDGET,Ht as ORDER_MIN_BLOCK_PERIOD,et as Router,st as TWAP_EXECUTION_INTERVAL,Pt as TWAP_MAX_DURATION,yt as TWAP_MAX_PRICE_IMPACT,pb as TWAP_TX_MULTIPLIER,Ct as TradeOrderError,_t as TradeOrderType,H as TradeRouteBuilder,at as TradeRouter,ft as TradeScheduler,Rt as TradeType};
@@ -43,6 +43,7 @@ export interface TradeOrder extends Humanizer {
43
43
  amountOut: bigint;
44
44
  assetIn: number;
45
45
  assetOut: number;
46
+ assetOutEd: bigint;
46
47
  errors: TradeOrderError[];
47
48
  tradeAmountIn: bigint;
48
49
  tradeAmountOut: bigint;
@@ -1 +1 @@
1
- "use strict";var et=Object.create;var b=Object.defineProperty;var nt=Object.getOwnPropertyDescriptor;var ot=Object.getOwnPropertyNames;var it=Object.getPrototypeOf,at=Object.prototype.hasOwnProperty;var rt=(n,t)=>{for(var e in t)b(n,e,{get:t[e],enumerable:!0})},$=(n,t,e,o)=>{if(t&&typeof t=="object"||typeof t=="function")for(let c of ot(t))!at.call(n,c)&&c!==e&&b(n,c,{get:()=>t[c],enumerable:!(o=nt(t,c))||o.enumerable});return n};var st=(n,t,e)=>(e=n!=null?et(it(n)):{},$(t||!n||!n.__esModule?b(e,"default",{value:n,enumerable:!0}):e,n)),ct=n=>$(b({},"__esModule",{value:!0}),n);var gt={};rt(gt,{BIG_10:()=>G,BIG_BILL:()=>N,StakingApi:()=>O,StakingClient:()=>E});module.exports=ct(gt);var l=require("@galacticcouncil/math-staking"),d=st(require("big.js"));var v={none:.1,locked1x:1,locked2x:2,locked3x:3,locked4x:4,locked5x:5,locked6x:6},z=n=>Object.keys(v).includes(n);var F=require("polkadot-api"),Y=require("@polkadot-api/utils"),j=require("@galacticcouncil/common");function X(n){let t=("modl"+n).padEnd(32,"\0"),e=new TextEncoder().encode(t),o=(0,Y.toHex)(e);return(0,F.AccountId)(j.HYDRATION_SS58_PREFIX).dec(o)}var x="20000000000000000",A="2000",G=(0,d.default)(10),N=(0,d.default)(G.pow(12)),O=class{client;balance;constructor(t,e){this.client=t,this.balance=e}async getPotBalance(){let t=await this.client.getPalletId(),e=X(t);return await this.balance.getBalance(e,0)}async getStakingPosition(t){let[e,o]=await Promise.all([this.client.getStakingPositionsValue(t),this.client.getStakingVotes(t)]);if(!e)return;let c=e.created_at,i=await o.reduce(async(a,[p,r])=>{let g=await a,S=p,P=r.amount,h=r.conviction.type.toLowerCase(),u=await this.client.getReferendumInfo(S);return u&&(u.type==="Approved"||u.type==="Rejected")&&z(h)&&g.push({id:S,amount:P,conviction:h}),g},Promise.resolve([]));return{stake:e.stake,rewardPerStake:e.reward_per_stake,createdAt:c,actionPoints:e.action_points,accumulatedUnpaidRewards:e.accumulated_unpaid_rewards,accumulatedSlashPoints:e.accumulated_slash_points,accumulatedLockedRewards:e.accumulated_locked_rewards,votes:i}}async getStake(t){let e=await this.client.getNFTCollectionId(),[o,c]=await Promise.all([this.client.getStaking(),this.client.getUniques(t,e)]),i=c.find(a=>a)?.itemId;return{totalStake:o?.total_stake,accumulatedRewardPerStake:o?.accumulated_reward_per_stake,potReservedBalance:o?.pot_reserved_balance,positionId:i,stakePosition:i?await this.getStakingPosition(i):void 0}}getCurrentActionPoints(t,e,o,c){let i=(0,d.default)(0),a=(0,d.default)(0),p=v.locked6x,r=(0,d.default)(o.toString()).mul(p),g=100,S=[];t.forEach(u=>{let f=v[u.conviction],k=c.includes(u.id.toString());k&&S.push(u.id.toString());let w=(0,d.default)(u.amount.toString()).mul(g).div(r);i=i.plus(Math.floor(w.mul(f).toNumber())),a=a.plus(Math.floor(w.mul(k?p:f).toNumber()))});let P=Math.floor((0,d.default)(o.toString()).mul(p).mul(g).div(r).toNumber());c.forEach(u=>{S.includes(u)||(a=a.plus(P))});let h={democracyVote:1};return i=i.mul(h.democracyVote),i=i.plus(e.toString()||"0"),a=a.mul(h.democracyVote),a=a.plus(e.toString()||"0"),{currentActionPoints:i.toString(),maxActionPoints:a.toString()}}async getRewards(t,e,o){let c=await this.getStake(t),{potReservedBalance:i,accumulatedRewardPerStake:a,totalStake:p,stakePosition:r}=c;if(!r)return;let[g,S,P,h,u,f,k]=await Promise.all([this.getPotBalance(),this.client.getPeriodLength(),this.client.getUnclaimablePeriods(),this.client.getTimePointsPerPeriod(),this.client.getTimePointsWeight(),this.client.getActionPointsWeight(),this.client.getSixBlockSince()]),w=(0,d.default)(g.transferable.toString()).minus(i.toString()),Q=w.gt(0)&&p>0?(0,l.calculate_accumulated_rps)(a.toString(),w.toString(),p.toString()):a.toString(),I=(0,l.calculate_period_number)(S.toString(),o,k),R=(0,l.calculate_period_number)(S.toString(),r.createdAt.toString(),k),Z=(0,l.calculate_rewards)(Q,r.rewardPerStake.toString(),r.stake.toString()),L=this.getCurrentActionPoints(r.votes,r.actionPoints,r.stake,e),M=(0,l.calculate_points)(R,I,h.toString(),u.toString(),L.currentActionPoints,f.toString(),r.accumulatedSlashPoints.toString()),B=(0,l.sigmoid)(M,x,A),W=(()=>{if(!e.length)return;let tt=(0,l.calculate_points)(R,I,h.toString(),u.toString(),L.maxActionPoints.toString(),f.toString(),r.accumulatedSlashPoints.toString());return(0,l.sigmoid)(tt,x,A)})(),q=(0,d.default)(Z).plus(r.accumulatedUnpaidRewards.toString()).plus(r.accumulatedLockedRewards.toString());if((0,d.default)(I).minus(R).lte(P.toString()))return{rewards:"0",payablePercentage:B,extraPayablePercentage:W,constants:{a:x,b:A}};let D=(0,l.calculate_percentage_amount)(q.toString(),B),U=(0,d.default)(r.accumulatedLockedRewards.toString()),H=U.gt(D)?U:(0,d.default)(D);return{rewards:H.div(N).toString(),maxRewards:q.div(N).toString(),allocatedRewardsPercentage:H.div(q).mul(100).toNumber(),points:M,payablePercentage:B,extraPayablePercentage:W,constants:{a:x,b:A}}}};var V=require("polkadot-api");var T=require("@galacticcouncil/descriptors");var K=require("@galacticcouncil/common"),y=require("rxjs");var m=require("rxjs"),s=require("rxjs/operators");function J(n,{intervalMs:t=5e3,rpcTimeoutMs:e=1e4}={}){let o=()=>(0,m.defer)(()=>(0,m.from)(n._request("system_health",[]))).pipe((0,s.timeout)({first:e}),(0,s.map)(()=>"online"),(0,s.catchError)(()=>(0,m.of)("offline")));return(0,m.of)({state:"offline",delayMs:0}).pipe((0,s.expand)(i=>(0,m.timer)(i.delayMs).pipe((0,s.switchMap)(o),(0,s.map)(a=>({state:a,delayMs:t})))),(0,s.skip)(1),(0,s.map)(i=>i.state),(0,s.distinctUntilChanged)(),(0,s.shareReplay)({bufferSize:1,refCount:!0}))}var{logger:ut}=K.log,_=class n{static instance=null;bestBlock$;finalizedBlock$;connection$;constructor(t){this.bestBlock$=this.watched("watcher(bestBlock)",t.getUnsafeApi().query.System.Number.watchValue({at:"best"}).pipe((0,y.map)(({value:e})=>e))),this.finalizedBlock$=this.watched("watcher(finalizedBlock)",t.finalizedBlock$),this.connection$=this.watched("watcher(connection)",J(t))}static getInstance(t){return this.instance||(this.instance=new n(t)),this.instance}watched(t,e){return e.pipe((0,y.tap)({error:o=>ut.error(t,o)}),(0,y.shareReplay)({bufferSize:1,refCount:!0}))}};var C=class{client;api;apiNext;watcher;at;constructor(t,e){this.client=t,this.api=this.client.getTypedApi(T.hydration),this.apiNext=this.client.getTypedApi(T.hydrationNext),this.watcher=_.getInstance(this.client),this.at=e??"best"}};var dt=require("polkadot-api/ws"),pt=require("polkadot-api/logs-provider");var E=class extends C{async getPalletId(){let t=this.api.constants.Staking.PalletId,e=await t();return V.Binary.toText(V.Binary.fromHex(e))}async getPeriodLength(){let t=this.api.constants.Staking.PeriodLength;return await t()}async getUnclaimablePeriods(){let t=this.api.constants.Staking.UnclaimablePeriods;return await t()}async getNFTCollectionId(){let t=this.api.constants.Staking.NFTCollectionId;return await t()}async getStaking(){return await this.api.query.Staking.Staking.getValue()}async getUniques(t,e){return(await this.api.query.Uniques.Account.getEntries(t,e)).map(({keyArgs:a})=>{let[p,r,g]=a;return{address:p,collectionId:r,itemId:g}})}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()}};0&&(module.exports={BIG_10,BIG_BILL,StakingApi,StakingClient});
1
+ "use strict";var et=Object.create;var v=Object.defineProperty;var nt=Object.getOwnPropertyDescriptor;var ot=Object.getOwnPropertyNames;var it=Object.getPrototypeOf,at=Object.prototype.hasOwnProperty;var rt=(n,t)=>{for(var e in t)v(n,e,{get:t[e],enumerable:!0})},$=(n,t,e,o)=>{if(t&&typeof t=="object"||typeof t=="function")for(let c of ot(t))!at.call(n,c)&&c!==e&&v(n,c,{get:()=>t[c],enumerable:!(o=nt(t,c))||o.enumerable});return n};var st=(n,t,e)=>(e=n!=null?et(it(n)):{},$(t||!n||!n.__esModule?v(e,"default",{value:n,enumerable:!0}):e,n)),ct=n=>$(v({},"__esModule",{value:!0}),n);var gt={};rt(gt,{BIG_10:()=>G,BIG_BILL:()=>N,StakingApi:()=>O,StakingClient:()=>E});module.exports=ct(gt);var l=require("@galacticcouncil/math-staking"),d=st(require("big.js"));var x={none:.1,locked1x:1,locked2x:2,locked3x:3,locked4x:4,locked5x:5,locked6x:6},z=n=>Object.keys(x).includes(n);var F=require("polkadot-api"),Y=require("@polkadot-api/utils"),j=require("@galacticcouncil/common");function X(n){let t=("modl"+n).padEnd(32,"\0"),e=new TextEncoder().encode(t),o=(0,Y.toHex)(e);return(0,F.AccountId)(j.HYDRATION_SS58_PREFIX).dec(o)}var A="20000000000000000",_="2000",G=(0,d.default)(10),N=(0,d.default)(G.pow(12)),O=class{client;balance;constructor(t,e){this.client=t,this.balance=e}async getPotBalance(){let t=await this.client.getPalletId(),e=X(t);return await this.balance.getBalance(e,0)}async getStakingPosition(t){let[e,o]=await Promise.all([this.client.getStakingPositionsValue(t),this.client.getStakingVotes(t)]);if(!e)return;let c=e.created_at,i=await o.reduce(async(a,[p,r])=>{let g=await a,S=p,f=r.amount,h=r.conviction.type.toLowerCase(),u=await this.client.getReferendumInfo(S);return u&&(u.type==="Approved"||u.type==="Rejected")&&z(h)&&g.push({id:S,amount:f,conviction:h}),g},Promise.resolve([]));return{stake:e.stake,rewardPerStake:e.reward_per_stake,createdAt:c,actionPoints:e.action_points,accumulatedUnpaidRewards:e.accumulated_unpaid_rewards,accumulatedSlashPoints:e.accumulated_slash_points,accumulatedLockedRewards:e.accumulated_locked_rewards,votes:i}}async getStake(t){let e=await this.client.getNFTCollectionId(),[o,c]=await Promise.all([this.client.getStaking(),this.client.getUniques(t,e)]),i=c.find(a=>a)?.itemId;return{totalStake:o?.total_stake,accumulatedRewardPerStake:o?.accumulated_reward_per_stake,potReservedBalance:o?.pot_reserved_balance,positionId:i,stakePosition:i?await this.getStakingPosition(i):void 0}}getCurrentActionPoints(t,e,o,c){let i=(0,d.default)(0),a=(0,d.default)(0),p=x.locked6x,r=(0,d.default)(o.toString()).mul(p),g=100,S=[];t.forEach(u=>{let k=x[u.conviction],w=c.includes(u.id.toString());w&&S.push(u.id.toString());let b=(0,d.default)(u.amount.toString()).mul(g).div(r);i=i.plus(Math.floor(b.mul(k).toNumber())),a=a.plus(Math.floor(b.mul(w?p:k).toNumber()))});let f=Math.floor((0,d.default)(o.toString()).mul(p).mul(g).div(r).toNumber());c.forEach(u=>{S.includes(u)||(a=a.plus(f))});let h={democracyVote:1};return i=i.mul(h.democracyVote),i=i.plus(e.toString()||"0"),a=a.mul(h.democracyVote),a=a.plus(e.toString()||"0"),{currentActionPoints:i.toString(),maxActionPoints:a.toString()}}async getRewards(t,e,o){let c=await this.getStake(t),{potReservedBalance:i,accumulatedRewardPerStake:a,totalStake:p,stakePosition:r}=c;if(!r)return;let[g,S,f,h,u,k,w]=await Promise.all([this.getPotBalance(),this.client.getPeriodLength(),this.client.getUnclaimablePeriods(),this.client.getTimePointsPerPeriod(),this.client.getTimePointsWeight(),this.client.getActionPointsWeight(),this.client.getSixBlockSince()]),b=(0,d.default)(g.transferable.toString()).minus(i.toString()),Q=b.gt(0)&&p>0?(0,l.calculate_accumulated_rps)(a.toString(),b.toString(),p.toString()):a.toString(),I=(0,l.calculate_period_number)(S.toString(),o,w),R=(0,l.calculate_period_number)(S.toString(),r.createdAt.toString(),w),Z=(0,l.calculate_rewards)(Q,r.rewardPerStake.toString(),r.stake.toString()),L=this.getCurrentActionPoints(r.votes,r.actionPoints,r.stake,e),M=(0,l.calculate_points)(R,I,h.toString(),u.toString(),L.currentActionPoints,k.toString(),r.accumulatedSlashPoints.toString()),B=(0,l.sigmoid)(M,A,_),W=(()=>{if(!e.length)return;let tt=(0,l.calculate_points)(R,I,h.toString(),u.toString(),L.maxActionPoints.toString(),k.toString(),r.accumulatedSlashPoints.toString());return(0,l.sigmoid)(tt,A,_)})(),q=(0,d.default)(Z).plus(r.accumulatedUnpaidRewards.toString()).plus(r.accumulatedLockedRewards.toString());if((0,d.default)(I).minus(R).lte(f.toString()))return{rewards:"0",payablePercentage:B,extraPayablePercentage:W,constants:{a:A,b:_}};let D=(0,l.calculate_percentage_amount)(q.toString(),B),U=(0,d.default)(r.accumulatedLockedRewards.toString()),H=U.gt(D)?U:(0,d.default)(D);return{rewards:H.div(N).toString(),maxRewards:q.div(N).toString(),allocatedRewardsPercentage:H.div(q).mul(100).toNumber(),points:M,payablePercentage:B,extraPayablePercentage:W,constants:{a:A,b:_}}}};var V=require("polkadot-api");var P=require("@galacticcouncil/descriptors");var K=require("@galacticcouncil/common"),y=require("rxjs");var m=require("rxjs"),s=require("rxjs/operators");function J(n,{intervalMs:t=5e3,rpcTimeoutMs:e=1e4}={}){let o=()=>(0,m.defer)(()=>(0,m.from)(n._request("system_health",[]))).pipe((0,s.timeout)({first:e}),(0,s.map)(()=>"online"),(0,s.catchError)(()=>(0,m.of)("offline")));return(0,m.of)({state:"offline",delayMs:0}).pipe((0,s.expand)(i=>(0,m.timer)(i.delayMs).pipe((0,s.switchMap)(o),(0,s.map)(a=>({state:a,delayMs:t})))),(0,s.skip)(1),(0,s.map)(i=>i.state),(0,s.distinctUntilChanged)(),(0,s.shareReplay)({bufferSize:1,refCount:!0}))}var{logger:ut}=K.log,C=class n{static instance=null;bestBlock$;finalizedBlock$;connection$;constructor(t){this.bestBlock$=this.watched("watcher(bestBlock)",t.getUnsafeApi().query.System.Number.watchValue({at:"best"}).pipe((0,y.map)(({value:e})=>e))),this.finalizedBlock$=this.watched("watcher(finalizedBlock)",t.finalizedBlock$),this.connection$=this.watched("watcher(connection)",J(t))}static getInstance(t){return this.instance||(this.instance=new n(t)),this.instance}watched(t,e){return e.pipe((0,y.tap)({error:o=>ut.error(t,o)}),(0,y.shareReplay)({bufferSize:1,refCount:!0}))}};var T=class{client;api;apiNext;apiIce;watcher;at;constructor(t,e){this.client=t,this.api=this.client.getTypedApi(P.hydration),this.apiNext=this.client.getTypedApi(P.hydrationNext),this.apiIce=this.client.getTypedApi(P.hydrationIce),this.watcher=C.getInstance(this.client),this.at=e??"best"}};var dt=require("polkadot-api/ws"),pt=require("polkadot-api/logs-provider");var E=class extends T{async getPalletId(){let t=this.api.constants.Staking.PalletId,e=await t();return V.Binary.toText(V.Binary.fromHex(e))}async getPeriodLength(){let t=this.api.constants.Staking.PeriodLength;return await t()}async getUnclaimablePeriods(){let t=this.api.constants.Staking.UnclaimablePeriods;return await t()}async getNFTCollectionId(){let t=this.api.constants.Staking.NFTCollectionId;return await t()}async getStaking(){return await this.api.query.Staking.Staking.getValue()}async getUniques(t,e){return(await this.api.query.Uniques.Account.getEntries(t,e)).map(({keyArgs:a})=>{let[p,r,g]=a;return{address:p,collectionId:r,itemId:g}})}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()}};0&&(module.exports={BIG_10,BIG_BILL,StakingApi,StakingClient});
@@ -1 +1 @@
1
- import X from"buffer";typeof window<"u"&&(window.Buffer=X.Buffer);import{calculate_accumulated_rps as Z,calculate_percentage_amount as tt,calculate_period_number as E,calculate_points as L,calculate_rewards as et,sigmoid as M}from"@galacticcouncil/math-staking";import s from"big.js";var y={none:.1,locked1x:1,locked2x:2,locked3x:3,locked4x:4,locked5x:5,locked6x:6},O=c=>Object.keys(y).includes(c);import{AccountId as G}from"polkadot-api";import{toHex as J}from"@polkadot-api/utils";import{HYDRATION_SS58_PREFIX as K}from"@galacticcouncil/common";function V(c){let t=("modl"+c).padEnd(32,"\0"),e=new TextEncoder().encode(t),n=J(e);return G(K).dec(n)}var P="20000000000000000",k="2000",nt=s(10),W=s(nt.pow(12)),D=class{client;balance;constructor(t,e){this.client=t,this.balance=e}async getPotBalance(){let t=await this.client.getPalletId(),e=V(t);return await this.balance.getBalance(e,0)}async getStakingPosition(t){let[e,n]=await Promise.all([this.client.getStakingPositionsValue(t),this.client.getStakingVotes(t)]);if(!e)return;let l=e.created_at,o=await n.reduce(async(i,[u,a])=>{let d=await i,p=u,m=a.amount,g=a.conviction.type.toLowerCase(),r=await this.client.getReferendumInfo(p);return r&&(r.type==="Approved"||r.type==="Rejected")&&O(g)&&d.push({id:p,amount:m,conviction:g}),d},Promise.resolve([]));return{stake:e.stake,rewardPerStake:e.reward_per_stake,createdAt:l,actionPoints:e.action_points,accumulatedUnpaidRewards:e.accumulated_unpaid_rewards,accumulatedSlashPoints:e.accumulated_slash_points,accumulatedLockedRewards:e.accumulated_locked_rewards,votes:o}}async getStake(t){let e=await this.client.getNFTCollectionId(),[n,l]=await Promise.all([this.client.getStaking(),this.client.getUniques(t,e)]),o=l.find(i=>i)?.itemId;return{totalStake:n?.total_stake,accumulatedRewardPerStake:n?.accumulated_reward_per_stake,potReservedBalance:n?.pot_reserved_balance,positionId:o,stakePosition:o?await this.getStakingPosition(o):void 0}}getCurrentActionPoints(t,e,n,l){let o=s(0),i=s(0),u=y.locked6x,a=s(n.toString()).mul(u),d=100,p=[];t.forEach(r=>{let S=y[r.conviction],f=l.includes(r.id.toString());f&&p.push(r.id.toString());let h=s(r.amount.toString()).mul(d).div(a);o=o.plus(Math.floor(h.mul(S).toNumber())),i=i.plus(Math.floor(h.mul(f?u:S).toNumber()))});let m=Math.floor(s(n.toString()).mul(u).mul(d).div(a).toNumber());l.forEach(r=>{p.includes(r)||(i=i.plus(m))});let g={democracyVote:1};return o=o.mul(g.democracyVote),o=o.plus(e.toString()||"0"),i=i.mul(g.democracyVote),i=i.plus(e.toString()||"0"),{currentActionPoints:o.toString(),maxActionPoints:i.toString()}}async getRewards(t,e,n){let l=await this.getStake(t),{potReservedBalance:o,accumulatedRewardPerStake:i,totalStake:u,stakePosition:a}=l;if(!a)return;let[d,p,m,g,r,S,f]=await Promise.all([this.getPotBalance(),this.client.getPeriodLength(),this.client.getUnclaimablePeriods(),this.client.getTimePointsPerPeriod(),this.client.getTimePointsWeight(),this.client.getActionPointsWeight(),this.client.getSixBlockSince()]),h=s(d.transferable.toString()).minus(o.toString()),F=h.gt(0)&&u>0?Z(i.toString(),h.toString(),u.toString()):i.toString(),v=E(p.toString(),n,f),x=E(p.toString(),a.createdAt.toString(),f),Y=et(F,a.rewardPerStake.toString(),a.stake.toString()),T=this.getCurrentActionPoints(a.votes,a.actionPoints,a.stake,e),I=L(x,v,g.toString(),r.toString(),T.currentActionPoints,S.toString(),a.accumulatedSlashPoints.toString()),A=M(I,P,k),R=(()=>{if(!e.length)return;let j=L(x,v,g.toString(),r.toString(),T.maxActionPoints.toString(),S.toString(),a.accumulatedSlashPoints.toString());return M(j,P,k)})(),_=s(Y).plus(a.accumulatedUnpaidRewards.toString()).plus(a.accumulatedLockedRewards.toString());if(s(v).minus(x).lte(m.toString()))return{rewards:"0",payablePercentage:A,extraPayablePercentage:R,constants:{a:P,b:k}};let B=tt(_.toString(),A),q=s(a.accumulatedLockedRewards.toString()),N=q.gt(B)?q:s(B);return{rewards:N.div(W).toString(),maxRewards:_.div(W).toString(),allocatedRewardsPercentage:N.div(_).mul(100).toNumber(),points:I,payablePercentage:A,extraPayablePercentage:R,constants:{a:P,b:k}}}};import{Binary as $}from"polkadot-api";import{hydration as yt,hydrationNext as Pt}from"@galacticcouncil/descriptors";import{log as gt}from"@galacticcouncil/common";import{map as mt,shareReplay as St,tap as ft}from"rxjs";import{defer as ot,from as it,of as U,timer as at}from"rxjs";import{catchError as rt,distinctUntilChanged as st,expand as ct,map as C,shareReplay as lt,skip as ut,switchMap as dt,timeout as pt}from"rxjs/operators";function H(c,{intervalMs:t=5e3,rpcTimeoutMs:e=1e4}={}){let n=()=>ot(()=>it(c._request("system_health",[]))).pipe(pt({first:e}),C(()=>"online"),rt(()=>U("offline")));return U({state:"offline",delayMs:0}).pipe(ct(o=>at(o.delayMs).pipe(dt(n),C(i=>({state:i,delayMs:t})))),ut(1),C(o=>o.state),st(),lt({bufferSize:1,refCount:!0}))}var{logger:ht}=gt,w=class c{static instance=null;bestBlock$;finalizedBlock$;connection$;constructor(t){this.bestBlock$=this.watched("watcher(bestBlock)",t.getUnsafeApi().query.System.Number.watchValue({at:"best"}).pipe(mt(({value:e})=>e))),this.finalizedBlock$=this.watched("watcher(finalizedBlock)",t.finalizedBlock$),this.connection$=this.watched("watcher(connection)",H(t))}static getInstance(t){return this.instance||(this.instance=new c(t)),this.instance}watched(t,e){return e.pipe(ft({error:n=>ht.error(t,n)}),St({bufferSize:1,refCount:!0}))}};var b=class{client;api;apiNext;watcher;at;constructor(t,e){this.client=t,this.api=this.client.getTypedApi(yt),this.apiNext=this.client.getTypedApi(Pt),this.watcher=w.getInstance(this.client),this.at=e??"best"}};import{getWsProvider as te}from"polkadot-api/ws";import{withLogsRecorder as ne}from"polkadot-api/logs-provider";var z=class extends b{async getPalletId(){let t=this.api.constants.Staking.PalletId,e=await t();return $.toText($.fromHex(e))}async getPeriodLength(){let t=this.api.constants.Staking.PeriodLength;return await t()}async getUnclaimablePeriods(){let t=this.api.constants.Staking.UnclaimablePeriods;return await t()}async getNFTCollectionId(){let t=this.api.constants.Staking.NFTCollectionId;return await t()}async getStaking(){return await this.api.query.Staking.Staking.getValue()}async getUniques(t,e){return(await this.api.query.Uniques.Account.getEntries(t,e)).map(({keyArgs:i})=>{let[u,a,d]=i;return{address:u,collectionId:a,itemId:d}})}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()}};export{nt as BIG_10,W as BIG_BILL,D as StakingApi,z as StakingClient};
1
+ import X from"buffer";typeof window<"u"&&(window.Buffer=X.Buffer);import{calculate_accumulated_rps as Z,calculate_percentage_amount as tt,calculate_period_number as E,calculate_points as L,calculate_rewards as et,sigmoid as M}from"@galacticcouncil/math-staking";import s from"big.js";var f={none:.1,locked1x:1,locked2x:2,locked3x:3,locked4x:4,locked5x:5,locked6x:6},O=c=>Object.keys(f).includes(c);import{AccountId as G}from"polkadot-api";import{toHex as J}from"@polkadot-api/utils";import{HYDRATION_SS58_PREFIX as K}from"@galacticcouncil/common";function V(c){let t=("modl"+c).padEnd(32,"\0"),e=new TextEncoder().encode(t),n=J(e);return G(K).dec(n)}var P="20000000000000000",k="2000",nt=s(10),W=s(nt.pow(12)),D=class{client;balance;constructor(t,e){this.client=t,this.balance=e}async getPotBalance(){let t=await this.client.getPalletId(),e=V(t);return await this.balance.getBalance(e,0)}async getStakingPosition(t){let[e,n]=await Promise.all([this.client.getStakingPositionsValue(t),this.client.getStakingVotes(t)]);if(!e)return;let l=e.created_at,o=await n.reduce(async(i,[u,a])=>{let d=await i,p=u,m=a.amount,g=a.conviction.type.toLowerCase(),r=await this.client.getReferendumInfo(p);return r&&(r.type==="Approved"||r.type==="Rejected")&&O(g)&&d.push({id:p,amount:m,conviction:g}),d},Promise.resolve([]));return{stake:e.stake,rewardPerStake:e.reward_per_stake,createdAt:l,actionPoints:e.action_points,accumulatedUnpaidRewards:e.accumulated_unpaid_rewards,accumulatedSlashPoints:e.accumulated_slash_points,accumulatedLockedRewards:e.accumulated_locked_rewards,votes:o}}async getStake(t){let e=await this.client.getNFTCollectionId(),[n,l]=await Promise.all([this.client.getStaking(),this.client.getUniques(t,e)]),o=l.find(i=>i)?.itemId;return{totalStake:n?.total_stake,accumulatedRewardPerStake:n?.accumulated_reward_per_stake,potReservedBalance:n?.pot_reserved_balance,positionId:o,stakePosition:o?await this.getStakingPosition(o):void 0}}getCurrentActionPoints(t,e,n,l){let o=s(0),i=s(0),u=f.locked6x,a=s(n.toString()).mul(u),d=100,p=[];t.forEach(r=>{let S=f[r.conviction],y=l.includes(r.id.toString());y&&p.push(r.id.toString());let h=s(r.amount.toString()).mul(d).div(a);o=o.plus(Math.floor(h.mul(S).toNumber())),i=i.plus(Math.floor(h.mul(y?u:S).toNumber()))});let m=Math.floor(s(n.toString()).mul(u).mul(d).div(a).toNumber());l.forEach(r=>{p.includes(r)||(i=i.plus(m))});let g={democracyVote:1};return o=o.mul(g.democracyVote),o=o.plus(e.toString()||"0"),i=i.mul(g.democracyVote),i=i.plus(e.toString()||"0"),{currentActionPoints:o.toString(),maxActionPoints:i.toString()}}async getRewards(t,e,n){let l=await this.getStake(t),{potReservedBalance:o,accumulatedRewardPerStake:i,totalStake:u,stakePosition:a}=l;if(!a)return;let[d,p,m,g,r,S,y]=await Promise.all([this.getPotBalance(),this.client.getPeriodLength(),this.client.getUnclaimablePeriods(),this.client.getTimePointsPerPeriod(),this.client.getTimePointsWeight(),this.client.getActionPointsWeight(),this.client.getSixBlockSince()]),h=s(d.transferable.toString()).minus(o.toString()),F=h.gt(0)&&u>0?Z(i.toString(),h.toString(),u.toString()):i.toString(),v=E(p.toString(),n,y),x=E(p.toString(),a.createdAt.toString(),y),Y=et(F,a.rewardPerStake.toString(),a.stake.toString()),T=this.getCurrentActionPoints(a.votes,a.actionPoints,a.stake,e),I=L(x,v,g.toString(),r.toString(),T.currentActionPoints,S.toString(),a.accumulatedSlashPoints.toString()),A=M(I,P,k),R=(()=>{if(!e.length)return;let j=L(x,v,g.toString(),r.toString(),T.maxActionPoints.toString(),S.toString(),a.accumulatedSlashPoints.toString());return M(j,P,k)})(),_=s(Y).plus(a.accumulatedUnpaidRewards.toString()).plus(a.accumulatedLockedRewards.toString());if(s(v).minus(x).lte(m.toString()))return{rewards:"0",payablePercentage:A,extraPayablePercentage:R,constants:{a:P,b:k}};let B=tt(_.toString(),A),q=s(a.accumulatedLockedRewards.toString()),N=q.gt(B)?q:s(B);return{rewards:N.div(W).toString(),maxRewards:_.div(W).toString(),allocatedRewardsPercentage:N.div(_).mul(100).toNumber(),points:I,payablePercentage:A,extraPayablePercentage:R,constants:{a:P,b:k}}}};import{Binary as $}from"polkadot-api";import{hydration as ft,hydrationNext as Pt,hydrationIce as kt}from"@galacticcouncil/descriptors";import{log as gt}from"@galacticcouncil/common";import{map as mt,shareReplay as St,tap as yt}from"rxjs";import{defer as ot,from as it,of as U,timer as at}from"rxjs";import{catchError as rt,distinctUntilChanged as st,expand as ct,map as C,shareReplay as lt,skip as ut,switchMap as dt,timeout as pt}from"rxjs/operators";function H(c,{intervalMs:t=5e3,rpcTimeoutMs:e=1e4}={}){let n=()=>ot(()=>it(c._request("system_health",[]))).pipe(pt({first:e}),C(()=>"online"),rt(()=>U("offline")));return U({state:"offline",delayMs:0}).pipe(ct(o=>at(o.delayMs).pipe(dt(n),C(i=>({state:i,delayMs:t})))),ut(1),C(o=>o.state),st(),lt({bufferSize:1,refCount:!0}))}var{logger:ht}=gt,w=class c{static instance=null;bestBlock$;finalizedBlock$;connection$;constructor(t){this.bestBlock$=this.watched("watcher(bestBlock)",t.getUnsafeApi().query.System.Number.watchValue({at:"best"}).pipe(mt(({value:e})=>e))),this.finalizedBlock$=this.watched("watcher(finalizedBlock)",t.finalizedBlock$),this.connection$=this.watched("watcher(connection)",H(t))}static getInstance(t){return this.instance||(this.instance=new c(t)),this.instance}watched(t,e){return e.pipe(yt({error:n=>ht.error(t,n)}),St({bufferSize:1,refCount:!0}))}};var b=class{client;api;apiNext;apiIce;watcher;at;constructor(t,e){this.client=t,this.api=this.client.getTypedApi(ft),this.apiNext=this.client.getTypedApi(Pt),this.apiIce=this.client.getTypedApi(kt),this.watcher=w.getInstance(this.client),this.at=e??"best"}};import{getWsProvider as ee}from"polkadot-api/ws";import{withLogsRecorder as oe}from"polkadot-api/logs-provider";var z=class extends b{async getPalletId(){let t=this.api.constants.Staking.PalletId,e=await t();return $.toText($.fromHex(e))}async getPeriodLength(){let t=this.api.constants.Staking.PeriodLength;return await t()}async getUnclaimablePeriods(){let t=this.api.constants.Staking.UnclaimablePeriods;return await t()}async getNFTCollectionId(){let t=this.api.constants.Staking.NFTCollectionId;return await t()}async getStaking(){return await this.api.query.Staking.Staking.getValue()}async getUniques(t,e){return(await this.api.query.Uniques.Account.getEntries(t,e)).map(({keyArgs:i})=>{let[u,a,d]=i;return{address:u,collectionId:a,itemId:d}})}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()}};export{nt as BIG_10,W as BIG_BILL,D as StakingApi,z as StakingClient};