agentwallet-sdk 3.0.0 → 3.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (130) hide show
  1. package/README.md +214 -1
  2. package/dist/fiat/index.d.ts +10 -0
  3. package/dist/fiat/index.d.ts.map +1 -0
  4. package/dist/fiat/index.js +9 -0
  5. package/dist/fiat/index.js.map +1 -0
  6. package/dist/fiat/onramp.d.ts +101 -0
  7. package/dist/fiat/onramp.d.ts.map +1 -0
  8. package/dist/fiat/onramp.js +155 -0
  9. package/dist/fiat/onramp.js.map +1 -0
  10. package/dist/fiat/providers/index.d.ts +16 -0
  11. package/dist/fiat/providers/index.d.ts.map +1 -0
  12. package/dist/fiat/providers/index.js +30 -0
  13. package/dist/fiat/providers/index.js.map +1 -0
  14. package/dist/fiat/providers/moonpay.d.ts +22 -0
  15. package/dist/fiat/providers/moonpay.d.ts.map +1 -0
  16. package/dist/fiat/providers/moonpay.js +107 -0
  17. package/dist/fiat/providers/moonpay.js.map +1 -0
  18. package/dist/fiat/providers/stripe.d.ts +26 -0
  19. package/dist/fiat/providers/stripe.d.ts.map +1 -0
  20. package/dist/fiat/providers/stripe.js +135 -0
  21. package/dist/fiat/providers/stripe.js.map +1 -0
  22. package/dist/fiat/providers/transak.d.ts +26 -0
  23. package/dist/fiat/providers/transak.d.ts.map +1 -0
  24. package/dist/fiat/providers/transak.js +119 -0
  25. package/dist/fiat/providers/transak.js.map +1 -0
  26. package/dist/fiat/types.d.ts +106 -0
  27. package/dist/fiat/types.d.ts.map +1 -0
  28. package/dist/fiat/types.js +13 -0
  29. package/dist/fiat/types.js.map +1 -0
  30. package/dist/gas/index.d.ts +4 -0
  31. package/dist/gas/index.d.ts.map +1 -0
  32. package/dist/gas/index.js +3 -0
  33. package/dist/gas/index.js.map +1 -0
  34. package/dist/gas/sponsor.d.ts +70 -0
  35. package/dist/gas/sponsor.d.ts.map +1 -0
  36. package/dist/gas/sponsor.js +193 -0
  37. package/dist/gas/sponsor.js.map +1 -0
  38. package/dist/gas/types.d.ts +76 -0
  39. package/dist/gas/types.d.ts.map +1 -0
  40. package/dist/gas/types.js +21 -0
  41. package/dist/gas/types.js.map +1 -0
  42. package/dist/index.d.ts +72 -62
  43. package/dist/index.d.ts.map +1 -1
  44. package/dist/index.js +11 -0
  45. package/dist/index.js.map +1 -1
  46. package/dist/settlement/index.d.ts +4 -0
  47. package/dist/settlement/index.d.ts.map +1 -0
  48. package/dist/settlement/index.js +3 -0
  49. package/dist/settlement/index.js.map +1 -0
  50. package/dist/settlement/types.d.ts +66 -0
  51. package/dist/settlement/types.d.ts.map +1 -0
  52. package/dist/settlement/types.js +37 -0
  53. package/dist/settlement/types.js.map +1 -0
  54. package/dist/settlement/verifier.d.ts +75 -0
  55. package/dist/settlement/verifier.d.ts.map +1 -0
  56. package/dist/settlement/verifier.js +354 -0
  57. package/dist/settlement/verifier.js.map +1 -0
  58. package/dist/swap/index.d.ts +1 -0
  59. package/dist/swap/index.d.ts.map +1 -1
  60. package/dist/swap/index.js +2 -0
  61. package/dist/swap/index.js.map +1 -1
  62. package/dist/swap/router/cache.d.ts +13 -0
  63. package/dist/swap/router/cache.d.ts.map +1 -0
  64. package/dist/swap/router/cache.js +30 -0
  65. package/dist/swap/router/cache.js.map +1 -0
  66. package/dist/swap/router/flashbots.d.ts +10 -0
  67. package/dist/swap/router/flashbots.d.ts.map +1 -0
  68. package/dist/swap/router/flashbots.js +43 -0
  69. package/dist/swap/router/flashbots.js.map +1 -0
  70. package/dist/swap/router/health.d.ts +17 -0
  71. package/dist/swap/router/health.d.ts.map +1 -0
  72. package/dist/swap/router/health.js +38 -0
  73. package/dist/swap/router/health.js.map +1 -0
  74. package/dist/swap/router/index.d.ts +10 -0
  75. package/dist/swap/router/index.d.ts.map +1 -0
  76. package/dist/swap/router/index.js +10 -0
  77. package/dist/swap/router/index.js.map +1 -0
  78. package/dist/swap/router/providers/cowswap.d.ts +11 -0
  79. package/dist/swap/router/providers/cowswap.d.ts.map +1 -0
  80. package/dist/swap/router/providers/cowswap.js +79 -0
  81. package/dist/swap/router/providers/cowswap.js.map +1 -0
  82. package/dist/swap/router/providers/index.d.ts +20 -0
  83. package/dist/swap/router/providers/index.d.ts.map +1 -0
  84. package/dist/swap/router/providers/index.js +32 -0
  85. package/dist/swap/router/providers/index.js.map +1 -0
  86. package/dist/swap/router/providers/jupiter.d.ts +12 -0
  87. package/dist/swap/router/providers/jupiter.d.ts.map +1 -0
  88. package/dist/swap/router/providers/jupiter.js +73 -0
  89. package/dist/swap/router/providers/jupiter.js.map +1 -0
  90. package/dist/swap/router/providers/lifi.d.ts +11 -0
  91. package/dist/swap/router/providers/lifi.d.ts.map +1 -0
  92. package/dist/swap/router/providers/lifi.js +123 -0
  93. package/dist/swap/router/providers/lifi.js.map +1 -0
  94. package/dist/swap/router/providers/oneinch.d.ts +13 -0
  95. package/dist/swap/router/providers/oneinch.d.ts.map +1 -0
  96. package/dist/swap/router/providers/oneinch.js +71 -0
  97. package/dist/swap/router/providers/oneinch.js.map +1 -0
  98. package/dist/swap/router/providers/paraswap.d.ts +11 -0
  99. package/dist/swap/router/providers/paraswap.d.ts.map +1 -0
  100. package/dist/swap/router/providers/paraswap.js +73 -0
  101. package/dist/swap/router/providers/paraswap.js.map +1 -0
  102. package/dist/swap/router/providers/uniswap.d.ts +31 -0
  103. package/dist/swap/router/providers/uniswap.d.ts.map +1 -0
  104. package/dist/swap/router/providers/uniswap.js +116 -0
  105. package/dist/swap/router/providers/uniswap.js.map +1 -0
  106. package/dist/swap/router/providers/zerox.d.ts +13 -0
  107. package/dist/swap/router/providers/zerox.d.ts.map +1 -0
  108. package/dist/swap/router/providers/zerox.js +94 -0
  109. package/dist/swap/router/providers/zerox.js.map +1 -0
  110. package/dist/swap/router/router.d.ts +86 -0
  111. package/dist/swap/router/router.d.ts.map +1 -0
  112. package/dist/swap/router/router.js +224 -0
  113. package/dist/swap/router/router.js.map +1 -0
  114. package/dist/swap/router/rsi/engine.d.ts +60 -0
  115. package/dist/swap/router/rsi/engine.d.ts.map +1 -0
  116. package/dist/swap/router/rsi/engine.js +483 -0
  117. package/dist/swap/router/rsi/engine.js.map +1 -0
  118. package/dist/swap/router/rsi/index.d.ts +3 -0
  119. package/dist/swap/router/rsi/index.d.ts.map +1 -0
  120. package/dist/swap/router/rsi/index.js +3 -0
  121. package/dist/swap/router/rsi/index.js.map +1 -0
  122. package/dist/swap/router/rsi/types.d.ts +106 -0
  123. package/dist/swap/router/rsi/types.d.ts.map +1 -0
  124. package/dist/swap/router/rsi/types.js +3 -0
  125. package/dist/swap/router/rsi/types.js.map +1 -0
  126. package/dist/swap/router/types.d.ts +120 -0
  127. package/dist/swap/router/types.d.ts.map +1 -0
  128. package/dist/swap/router/types.js +16 -0
  129. package/dist/swap/router/types.js.map +1 -0
  130. package/package.json +1 -1
@@ -0,0 +1,79 @@
1
+ import { buildQuote } from './uniswap.js';
2
+ const COWSWAP_CHAINS = ['ethereum', 'arbitrum', 'base', 'gnosis'];
3
+ /** CowSwap network slug mapping */
4
+ const COW_NETWORK = {
5
+ ethereum: 'mainnet',
6
+ arbitrum: 'arbitrum_one',
7
+ base: 'base',
8
+ gnosis: 'xdai',
9
+ };
10
+ const COWSWAP_API_BASE = 'https://api.cow.fi';
11
+ export class CowSwapProvider {
12
+ constructor(options = {}) {
13
+ this.name = 'cowswap';
14
+ this.supportedChains = COWSWAP_CHAINS;
15
+ this.fetcher = options.fetcher;
16
+ }
17
+ async getQuote(params, timeoutMs) {
18
+ if (!COWSWAP_CHAINS.includes(params.chain.toLowerCase()))
19
+ return null;
20
+ if (this.fetcher)
21
+ return this.fetcher(params);
22
+ const network = COW_NETWORK[params.chain.toLowerCase()];
23
+ if (!network)
24
+ return null;
25
+ const url = `${COWSWAP_API_BASE}/${network}/api/v1/quote`;
26
+ // CowSwap requires a from/seller address for accurate quotes
27
+ const seller = params.fromAddress ?? '0x0000000000000000000000000000000000000000';
28
+ const body = {
29
+ sellToken: params.fromToken,
30
+ buyToken: params.toToken,
31
+ sellAmountBeforeFee: params.amount,
32
+ from: seller,
33
+ kind: 'sell',
34
+ partiallyFillable: false,
35
+ };
36
+ const controller = new AbortController();
37
+ const timer = setTimeout(() => controller.abort(), timeoutMs);
38
+ try {
39
+ const res = await fetch(url, {
40
+ method: 'POST',
41
+ headers: { 'Content-Type': 'application/json', 'Accept': 'application/json' },
42
+ body: JSON.stringify(body),
43
+ signal: controller.signal,
44
+ });
45
+ if (!res.ok)
46
+ return null;
47
+ const data = (await res.json());
48
+ const quote = data.quote;
49
+ if (!quote)
50
+ return null;
51
+ const toAmount = BigInt(String(quote.buyAmount ?? '0'));
52
+ // CowSwap has no gas cost for the user — protocol takes fee from sell token
53
+ const feeAmount = BigInt(String(quote.feeAmount ?? '0'));
54
+ // Fee in bps: feeAmount / sellAmount * 10000
55
+ const sellAmt = BigInt(params.amount);
56
+ const platformFeeBps = sellAmt > 0n ? Number((feeAmount * 10000n) / sellAmt) : 0;
57
+ return buildQuote({
58
+ provider: 'cowswap',
59
+ params,
60
+ toAmount,
61
+ gasEstimate: 0n,
62
+ gasEstimateUsd: 0,
63
+ platformFee: platformFeeBps,
64
+ priceImpact: 0,
65
+ route: ['CoW Protocol'],
66
+ estimatedTimeMs: 30000, // batch auctions ~30s
67
+ mevProtected: true,
68
+ metadata: data,
69
+ });
70
+ }
71
+ catch {
72
+ return null;
73
+ }
74
+ finally {
75
+ clearTimeout(timer);
76
+ }
77
+ }
78
+ }
79
+ //# sourceMappingURL=cowswap.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cowswap.js","sourceRoot":"","sources":["../../../../src/swap/router/providers/cowswap.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,20 @@
1
+ export { UniswapProvider, buildQuote } from './uniswap.js';
2
+ export { JupiterProvider } from './jupiter.js';
3
+ export { OneInchProvider } from './oneinch.js';
4
+ export { ZeroXProvider } from './zerox.js';
5
+ export { ParaSwapProvider } from './paraswap.js';
6
+ export { CowSwapProvider } from './cowswap.js';
7
+ export { LiFiProvider } from './lifi.js';
8
+ import type { ISwapProvider } from '../types.js';
9
+ export interface ProviderRegistryOptions {
10
+ oneInchApiKey?: string;
11
+ zeroxApiKey?: string;
12
+ /** Inject custom provider fetchers (for testing) */
13
+ fetchers?: Record<string, (params: import('../types.js').QuoteParams) => Promise<import('../types.js').AggregatorQuote | null>>;
14
+ }
15
+ /**
16
+ * Build the default provider list.
17
+ * Providers requiring API keys are included but will return null gracefully if no key given.
18
+ */
19
+ export declare function buildDefaultProviders(options?: ProviderRegistryOptions): ISwapProvider[];
20
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/swap/router/providers/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC3D,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAC/C,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAC/C,OAAO,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAC3C,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAC/C,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AAEzC,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AASjD,MAAM,WAAW,uBAAuB;IACtC,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,oDAAoD;IACpD,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,MAAM,EAAE,OAAO,aAAa,EAAE,WAAW,KAAK,OAAO,CAAC,OAAO,aAAa,EAAE,eAAe,GAAG,IAAI,CAAC,CAAC,CAAC;CACjI;AAED;;;GAGG;AACH,wBAAgB,qBAAqB,CAAC,OAAO,GAAE,uBAA4B,GAAG,aAAa,EAAE,CAW5F"}
@@ -0,0 +1,32 @@
1
+ // [MAX-ADDED] Provider registry for SmartSwapRouter
2
+ export { UniswapProvider, buildQuote } from './uniswap.js';
3
+ export { JupiterProvider } from './jupiter.js';
4
+ export { OneInchProvider } from './oneinch.js';
5
+ export { ZeroXProvider } from './zerox.js';
6
+ export { ParaSwapProvider } from './paraswap.js';
7
+ export { CowSwapProvider } from './cowswap.js';
8
+ export { LiFiProvider } from './lifi.js';
9
+ import { UniswapProvider } from './uniswap.js';
10
+ import { JupiterProvider } from './jupiter.js';
11
+ import { OneInchProvider } from './oneinch.js';
12
+ import { ZeroXProvider } from './zerox.js';
13
+ import { ParaSwapProvider } from './paraswap.js';
14
+ import { CowSwapProvider } from './cowswap.js';
15
+ import { LiFiProvider } from './lifi.js';
16
+ /**
17
+ * Build the default provider list.
18
+ * Providers requiring API keys are included but will return null gracefully if no key given.
19
+ */
20
+ export function buildDefaultProviders(options = {}) {
21
+ const f = options.fetchers ?? {};
22
+ return [
23
+ new UniswapProvider(f.uniswap ? { fetcher: f.uniswap } : {}),
24
+ new JupiterProvider(f.jupiter ? { fetcher: f.jupiter } : {}),
25
+ new OneInchProvider({ apiKey: options.oneInchApiKey, ...(f['1inch'] ? { fetcher: f['1inch'] } : {}) }),
26
+ new ZeroXProvider({ apiKey: options.zeroxApiKey, ...(f['0x'] ? { fetcher: f['0x'] } : {}) }),
27
+ new ParaSwapProvider(f.paraswap ? { fetcher: f.paraswap } : {}),
28
+ new CowSwapProvider(f.cowswap ? { fetcher: f.cowswap } : {}),
29
+ new LiFiProvider(f.lifi ? { fetcher: f.lifi } : {}),
30
+ ];
31
+ }
32
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/swap/router/providers/index.ts"],"names":[],"mappings":"AAAA,oDAAoD;AACpD,OAAO,EAAE,eAAe,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC3D,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAC/C,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAC/C,OAAO,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAC3C,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAC/C,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AAGzC,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAC/C,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAC/C,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAC/C,OAAO,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAC3C,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAC/C,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AASzC;;;GAGG;AACH,MAAM,UAAU,qBAAqB,CAAC,UAAmC,EAAE;IACzE,MAAM,CAAC,GAAG,OAAO,CAAC,QAAQ,IAAI,EAAE,CAAC;IACjC,OAAO;QACL,IAAI,eAAe,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QAC5D,IAAI,eAAe,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QAC5D,IAAI,eAAe,CAAC,EAAE,MAAM,EAAE,OAAO,CAAC,aAAa,EAAE,GAAG,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC;QACtG,IAAI,aAAa,CAAC,EAAE,MAAM,EAAE,OAAO,CAAC,WAAW,EAAE,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC;QAC5F,IAAI,gBAAgB,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QAC/D,IAAI,eAAe,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QAC5D,IAAI,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;KACpD,CAAC;AACJ,CAAC"}
@@ -0,0 +1,12 @@
1
+ import type { ISwapProvider, AggregatorQuote, QuoteParams } from '../types.js';
2
+ export declare class JupiterProvider implements ISwapProvider {
3
+ readonly name = "jupiter";
4
+ readonly supportedChains: string[];
5
+ /** Optional fetch override for testing */
6
+ private readonly fetcher?;
7
+ constructor(options?: {
8
+ fetcher?: (p: QuoteParams) => Promise<AggregatorQuote | null>;
9
+ });
10
+ getQuote(params: QuoteParams, timeoutMs: number): Promise<AggregatorQuote | null>;
11
+ }
12
+ //# sourceMappingURL=jupiter.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"jupiter.d.ts","sourceRoot":"","sources":["../../../../src/swap/router/providers/jupiter.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,aAAa,EAAE,eAAe,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAqB/E,qBAAa,eAAgB,YAAW,aAAa;IACnD,QAAQ,CAAC,IAAI,aAAa;IAC1B,QAAQ,CAAC,eAAe,WAAc;IAEtC,0CAA0C;IAC1C,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAC,CAA2D;gBAExE,OAAO,GAAE;QAAE,OAAO,CAAC,EAAE,CAAC,CAAC,EAAE,WAAW,KAAK,OAAO,CAAC,eAAe,GAAG,IAAI,CAAC,CAAA;KAAO;IAIrF,QAAQ,CAAC,MAAM,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,eAAe,GAAG,IAAI,CAAC;CAqDxF"}
@@ -0,0 +1,73 @@
1
+ import { buildQuote } from './uniswap.js';
2
+ const JUPITER_API_BASE = 'https://quote-api.jup.ag/v6';
3
+ /** Well-known Solana mint addresses */
4
+ const SOLANA_MINTS = {
5
+ SOL: 'So11111111111111111111111111111111111111112',
6
+ USDC: 'EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v',
7
+ USDT: 'Es9vMFrzaCERmJfrF4H2FYD4KCoNkY11McCe8BenwNYB',
8
+ BONK: 'DezXAZ8z7PnrnRJjz3wXBoRgixCa6xjnB7YaB1pPB263',
9
+ JUP: 'JUPyiwrYJFskUPiHa7hkeR8VUtAeFoSYbKedZNsDvCN',
10
+ RAY: '4k3Dyjzvzp8eMZWUXbBCjEvwSkkk59S5iCNLY3QrkX6R',
11
+ WIF: 'EKpQGSJtjMFqKZ9KQanSqYXRcF8fBopzLHYxdM65zcjm',
12
+ };
13
+ function resolveSolanaMint(token) {
14
+ if (token.length >= 32 && token.length <= 44)
15
+ return token; // already a mint
16
+ return SOLANA_MINTS[token.toUpperCase()] ?? token;
17
+ }
18
+ export class JupiterProvider {
19
+ constructor(options = {}) {
20
+ this.name = 'jupiter';
21
+ this.supportedChains = ['solana'];
22
+ this.fetcher = options.fetcher;
23
+ }
24
+ async getQuote(params, timeoutMs) {
25
+ if (params.chain.toLowerCase() !== 'solana')
26
+ return null;
27
+ if (this.fetcher) {
28
+ return this.fetcher(params);
29
+ }
30
+ const inputMint = resolveSolanaMint(params.fromToken);
31
+ const outputMint = resolveSolanaMint(params.toToken);
32
+ const slippageBps = params.slippageBps ?? 50;
33
+ const url = new URL(`${JUPITER_API_BASE}/quote`);
34
+ url.searchParams.set('inputMint', inputMint);
35
+ url.searchParams.set('outputMint', outputMint);
36
+ url.searchParams.set('amount', params.amount);
37
+ url.searchParams.set('slippageBps', String(slippageBps));
38
+ const controller = new AbortController();
39
+ const timer = setTimeout(() => controller.abort(), timeoutMs);
40
+ try {
41
+ const res = await fetch(url.toString(), { signal: controller.signal });
42
+ if (!res.ok)
43
+ return null;
44
+ const data = (await res.json());
45
+ const toAmount = BigInt(String(data.outAmount ?? '0'));
46
+ // Jupiter quotes are gasless for the user (fees come from price impact)
47
+ const priceImpact = Number(data.priceImpactPct ?? '0');
48
+ // Parse route
49
+ const routePlan = data.routePlan;
50
+ const route = routePlan?.map((r) => r.swapInfo?.label ?? 'Unknown').filter(Boolean) ?? ['Jupiter'];
51
+ return buildQuote({
52
+ provider: 'jupiter',
53
+ params,
54
+ toAmount,
55
+ gasEstimate: 0n,
56
+ gasEstimateUsd: 0,
57
+ platformFee: 0,
58
+ priceImpact,
59
+ route,
60
+ estimatedTimeMs: 400,
61
+ mevProtected: false,
62
+ metadata: data,
63
+ });
64
+ }
65
+ catch {
66
+ return null;
67
+ }
68
+ finally {
69
+ clearTimeout(timer);
70
+ }
71
+ }
72
+ }
73
+ //# sourceMappingURL=jupiter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"jupiter.js","sourceRoot":"","sources":["../../../../src/swap/router/providers/jupiter.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,11 @@
1
+ import type { ISwapProvider, AggregatorQuote, QuoteParams } from '../types.js';
2
+ export declare class LiFiProvider implements ISwapProvider {
3
+ readonly name = "lifi";
4
+ readonly supportedChains: string[];
5
+ private readonly fetcher?;
6
+ constructor(options?: {
7
+ fetcher?: (p: QuoteParams) => Promise<AggregatorQuote | null>;
8
+ });
9
+ getQuote(params: QuoteParams, timeoutMs: number): Promise<AggregatorQuote | null>;
10
+ }
11
+ //# sourceMappingURL=lifi.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lifi.d.ts","sourceRoot":"","sources":["../../../../src/swap/router/providers/lifi.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,aAAa,EAAE,eAAe,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AA0C/E,qBAAa,YAAa,YAAW,aAAa;IAChD,QAAQ,CAAC,IAAI,UAAU;IACvB,QAAQ,CAAC,eAAe,WAAe;IAEvC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAC,CAA2D;gBAExE,OAAO,GAAE;QAAE,OAAO,CAAC,EAAE,CAAC,CAAC,EAAE,WAAW,KAAK,OAAO,CAAC,eAAe,GAAG,IAAI,CAAC,CAAA;KAAO;IAIrF,QAAQ,CAAC,MAAM,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,eAAe,GAAG,IAAI,CAAC;CAmFxF"}
@@ -0,0 +1,123 @@
1
+ import { CHAIN_IDS } from '../types.js';
2
+ import { buildQuote } from './uniswap.js';
3
+ // LI.FI supports a large number of chains; list the main ones
4
+ const LIFI_CHAINS = [
5
+ 'ethereum', 'base', 'arbitrum', 'optimism', 'polygon', 'avalanche', 'bnb',
6
+ 'gnosis', 'fantom', 'celo', 'moonbeam', 'moonriver', 'cronos', 'aurora',
7
+ 'fuse', 'velas', 'evmos', 'boba', 'metis', 'okc', 'linea', 'scroll',
8
+ 'zksync', 'polygonzkevm', 'mantle', 'blast', 'mode',
9
+ ];
10
+ const LIFI_API_BASE = 'https://li.quest/v1';
11
+ /** LI.FI uses chain IDs; supplement our map with extra chains */
12
+ const LIFI_EXTRA_CHAIN_IDS = {
13
+ fantom: 250,
14
+ celo: 42220,
15
+ moonbeam: 1284,
16
+ moonriver: 1285,
17
+ cronos: 25,
18
+ aurora: 1313161554,
19
+ fuse: 122,
20
+ velas: 106,
21
+ evmos: 9001,
22
+ boba: 288,
23
+ metis: 1088,
24
+ okc: 66,
25
+ linea: 59144,
26
+ scroll: 534352,
27
+ zksync: 324,
28
+ polygonzkevm: 1101,
29
+ mantle: 5000,
30
+ blast: 81457,
31
+ mode: 34443,
32
+ };
33
+ function getChainId(chain) {
34
+ const id = CHAIN_IDS[chain] ?? LIFI_EXTRA_CHAIN_IDS[chain];
35
+ return id ?? null;
36
+ }
37
+ export class LiFiProvider {
38
+ constructor(options = {}) {
39
+ this.name = 'lifi';
40
+ this.supportedChains = LIFI_CHAINS;
41
+ this.fetcher = options.fetcher;
42
+ }
43
+ async getQuote(params, timeoutMs) {
44
+ if (!LIFI_CHAINS.includes(params.chain.toLowerCase()))
45
+ return null;
46
+ if (this.fetcher)
47
+ return this.fetcher(params);
48
+ const chainId = getChainId(params.chain.toLowerCase());
49
+ if (!chainId)
50
+ return null;
51
+ const url = new URL(`${LIFI_API_BASE}/quote`);
52
+ url.searchParams.set('fromChain', String(chainId));
53
+ url.searchParams.set('toChain', String(chainId)); // same-chain swap
54
+ url.searchParams.set('fromToken', params.fromToken);
55
+ url.searchParams.set('toToken', params.toToken);
56
+ url.searchParams.set('fromAmount', params.amount);
57
+ if (params.fromAddress)
58
+ url.searchParams.set('fromAddress', params.fromAddress);
59
+ const controller = new AbortController();
60
+ const timer = setTimeout(() => controller.abort(), timeoutMs);
61
+ try {
62
+ const res = await fetch(url.toString(), {
63
+ headers: { 'Accept': 'application/json' },
64
+ signal: controller.signal,
65
+ });
66
+ if (!res.ok)
67
+ return null;
68
+ const data = (await res.json());
69
+ const estimate = data.estimate;
70
+ if (!estimate)
71
+ return null;
72
+ const toAmount = BigInt(String(estimate.toAmount ?? '0'));
73
+ const gasCosts = estimate.gasCosts;
74
+ const gasEstimate = BigInt(String(gasCosts?.[0]?.['estimate'] ?? '200000'));
75
+ const gasEstimateUsd = Number(gasCosts?.[0]?.['amountUSD'] ?? 0);
76
+ // Tool steps (bridges/swaps)
77
+ const action = data.action;
78
+ const includedSteps = data.includedSteps;
79
+ const route = includedSteps
80
+ ? includedSteps.map((s) => {
81
+ const details = s['toolDetails'];
82
+ return String(details?.['name'] ?? s['tool'] ?? 'LI.FI');
83
+ })
84
+ : ['LI.FI'];
85
+ // Extract tx data if available
86
+ let txData;
87
+ const tx = data.transactionRequest;
88
+ if (tx?.to && tx?.data) {
89
+ txData = {
90
+ to: String(tx.to),
91
+ data: String(tx.data),
92
+ value: BigInt(String(tx.value ?? '0')),
93
+ gasLimit: gasEstimate,
94
+ };
95
+ }
96
+ const feeCosts = estimate.feeCosts;
97
+ const totalFeeUsd = feeCosts?.reduce((sum, f) => sum + Number(f.amountUSD ?? 0), 0) ?? 0;
98
+ const sellAmtNum = Number(params.amount);
99
+ const platformFeeBps = sellAmtNum > 0 ? Math.round((totalFeeUsd / sellAmtNum) * 10000) : 0;
100
+ return buildQuote({
101
+ provider: 'lifi',
102
+ params,
103
+ toAmount,
104
+ gasEstimate,
105
+ gasEstimateUsd,
106
+ platformFee: platformFeeBps,
107
+ priceImpact: 0,
108
+ route: [...new Set(route)],
109
+ estimatedTimeMs: 20000,
110
+ mevProtected: false,
111
+ txData,
112
+ metadata: data,
113
+ });
114
+ }
115
+ catch {
116
+ return null;
117
+ }
118
+ finally {
119
+ clearTimeout(timer);
120
+ }
121
+ }
122
+ }
123
+ //# sourceMappingURL=lifi.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lifi.js","sourceRoot":"","sources":["../../../../src/swap/router/providers/lifi.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,13 @@
1
+ import type { ISwapProvider, AggregatorQuote, QuoteParams } from '../types.js';
2
+ export declare class OneInchProvider implements ISwapProvider {
3
+ readonly name = "1inch";
4
+ readonly supportedChains: string[];
5
+ private readonly apiKey;
6
+ private readonly fetcher?;
7
+ constructor(options?: {
8
+ apiKey?: string;
9
+ fetcher?: (p: QuoteParams) => Promise<AggregatorQuote | null>;
10
+ });
11
+ getQuote(params: QuoteParams, timeoutMs: number): Promise<AggregatorQuote | null>;
12
+ }
13
+ //# sourceMappingURL=oneinch.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"oneinch.d.ts","sourceRoot":"","sources":["../../../../src/swap/router/providers/oneinch.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,aAAa,EAAE,eAAe,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAO/E,qBAAa,eAAgB,YAAW,aAAa;IACnD,QAAQ,CAAC,IAAI,WAAW;IACxB,QAAQ,CAAC,eAAe,WAAkB;IAE1C,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAqB;IAC5C,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAC,CAA2D;gBAExE,OAAO,GAAE;QACnB,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,OAAO,CAAC,EAAE,CAAC,CAAC,EAAE,WAAW,KAAK,OAAO,CAAC,eAAe,GAAG,IAAI,CAAC,CAAC;KAC1D;IAKA,QAAQ,CAAC,MAAM,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,eAAe,GAAG,IAAI,CAAC;CA+DxF"}
@@ -0,0 +1,71 @@
1
+ import { CHAIN_IDS } from '../types.js';
2
+ import { buildQuote } from './uniswap.js';
3
+ const ONEINCH_CHAINS = ['ethereum', 'base', 'arbitrum', 'optimism', 'polygon', 'avalanche', 'bnb'];
4
+ const ONEINCH_API_BASE = 'https://api.1inch.dev/swap/v6.0';
5
+ export class OneInchProvider {
6
+ constructor(options = {}) {
7
+ this.name = '1inch';
8
+ this.supportedChains = ONEINCH_CHAINS;
9
+ this.apiKey = options.apiKey;
10
+ this.fetcher = options.fetcher;
11
+ }
12
+ async getQuote(params, timeoutMs) {
13
+ if (!ONEINCH_CHAINS.includes(params.chain.toLowerCase()))
14
+ return null;
15
+ if (!this.apiKey && !this.fetcher)
16
+ return null; // No key = skip gracefully
17
+ if (this.fetcher)
18
+ return this.fetcher(params);
19
+ const chainId = CHAIN_IDS[params.chain.toLowerCase()];
20
+ if (!chainId)
21
+ return null;
22
+ const url = new URL(`${ONEINCH_API_BASE}/${chainId}/quote`);
23
+ url.searchParams.set('src', params.fromToken);
24
+ url.searchParams.set('dst', params.toToken);
25
+ url.searchParams.set('amount', params.amount);
26
+ if (params.fromAddress)
27
+ url.searchParams.set('from', params.fromAddress);
28
+ const controller = new AbortController();
29
+ const timer = setTimeout(() => controller.abort(), timeoutMs);
30
+ try {
31
+ const res = await fetch(url.toString(), {
32
+ headers: {
33
+ 'Authorization': `Bearer ${this.apiKey}`,
34
+ 'Accept': 'application/json',
35
+ },
36
+ signal: controller.signal,
37
+ });
38
+ if (!res.ok)
39
+ return null;
40
+ const data = (await res.json());
41
+ const toAmount = BigInt(String(data.toAmount ?? data.dstAmount ?? '0'));
42
+ const gasEstimate = BigInt(String(data.estimatedGas ?? '200000'));
43
+ // 1inch doesn't return gas USD directly; estimate at ~30 gwei
44
+ const gasEstimateUsd = Number(gasEstimate) * 30e-9 * 2500; // rough: 30 gwei * $2500 ETH
45
+ // Extract protocol route
46
+ const protocols = data.protocols;
47
+ const route = [];
48
+ protocols?.forEach((outer) => outer?.forEach((inner) => inner?.forEach((hop) => hop?.name && !route.includes(hop.name) && route.push(hop.name))));
49
+ return buildQuote({
50
+ provider: '1inch',
51
+ params,
52
+ toAmount,
53
+ gasEstimate,
54
+ gasEstimateUsd,
55
+ platformFee: 0,
56
+ priceImpact: 0,
57
+ route: route.length > 0 ? route : ['1inch'],
58
+ estimatedTimeMs: 30000, // Fusion orders can take ~30s
59
+ mevProtected: true, // 1inch Fusion is MEV-protected
60
+ metadata: data,
61
+ });
62
+ }
63
+ catch {
64
+ return null;
65
+ }
66
+ finally {
67
+ clearTimeout(timer);
68
+ }
69
+ }
70
+ }
71
+ //# sourceMappingURL=oneinch.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"oneinch.js","sourceRoot":"","sources":["../../../../src/swap/router/providers/oneinch.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,11 @@
1
+ import type { ISwapProvider, AggregatorQuote, QuoteParams } from '../types.js';
2
+ export declare class ParaSwapProvider implements ISwapProvider {
3
+ readonly name = "paraswap";
4
+ readonly supportedChains: string[];
5
+ private readonly fetcher?;
6
+ constructor(options?: {
7
+ fetcher?: (p: QuoteParams) => Promise<AggregatorQuote | null>;
8
+ });
9
+ getQuote(params: QuoteParams, timeoutMs: number): Promise<AggregatorQuote | null>;
10
+ }
11
+ //# sourceMappingURL=paraswap.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"paraswap.d.ts","sourceRoot":"","sources":["../../../../src/swap/router/providers/paraswap.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,aAAa,EAAE,eAAe,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAO/E,qBAAa,gBAAiB,YAAW,aAAa;IACpD,QAAQ,CAAC,IAAI,cAAc;IAC3B,QAAQ,CAAC,eAAe,WAAmB;IAE3C,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAC,CAA2D;gBAExE,OAAO,GAAE;QAAE,OAAO,CAAC,EAAE,CAAC,CAAC,EAAE,WAAW,KAAK,OAAO,CAAC,eAAe,GAAG,IAAI,CAAC,CAAA;KAAO;IAIrF,QAAQ,CAAC,MAAM,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,eAAe,GAAG,IAAI,CAAC;CAmExF"}
@@ -0,0 +1,73 @@
1
+ import { CHAIN_IDS } from '../types.js';
2
+ import { buildQuote } from './uniswap.js';
3
+ const PARASWAP_CHAINS = ['ethereum', 'base', 'arbitrum', 'optimism', 'polygon', 'avalanche'];
4
+ const PARASWAP_API_BASE = 'https://apiv5.paraswap.io';
5
+ export class ParaSwapProvider {
6
+ constructor(options = {}) {
7
+ this.name = 'paraswap';
8
+ this.supportedChains = PARASWAP_CHAINS;
9
+ this.fetcher = options.fetcher;
10
+ }
11
+ async getQuote(params, timeoutMs) {
12
+ if (!PARASWAP_CHAINS.includes(params.chain.toLowerCase()))
13
+ return null;
14
+ if (this.fetcher)
15
+ return this.fetcher(params);
16
+ const chainId = CHAIN_IDS[params.chain.toLowerCase()];
17
+ if (!chainId)
18
+ return null;
19
+ const url = new URL(`${PARASWAP_API_BASE}/prices`);
20
+ url.searchParams.set('srcToken', params.fromToken);
21
+ url.searchParams.set('destToken', params.toToken);
22
+ url.searchParams.set('amount', params.amount);
23
+ url.searchParams.set('network', String(chainId));
24
+ url.searchParams.set('side', 'SELL');
25
+ if (params.fromAddress)
26
+ url.searchParams.set('userAddress', params.fromAddress);
27
+ const controller = new AbortController();
28
+ const timer = setTimeout(() => controller.abort(), timeoutMs);
29
+ try {
30
+ const res = await fetch(url.toString(), {
31
+ headers: { 'Accept': 'application/json' },
32
+ signal: controller.signal,
33
+ });
34
+ if (!res.ok)
35
+ return null;
36
+ const data = (await res.json());
37
+ const priceRoute = data.priceRoute;
38
+ if (!priceRoute)
39
+ return null;
40
+ const toAmount = BigInt(String(priceRoute.destAmount ?? '0'));
41
+ const gasEstimate = BigInt(String(priceRoute.gasCost ?? '200000'));
42
+ const gasEstimateUsd = Number(priceRoute.gasCostUSD ?? 0);
43
+ const priceImpact = Number(priceRoute.tokenTransferProxy ?? 0);
44
+ // Parse bestRoute
45
+ const bestRoute = priceRoute.bestRoute;
46
+ const route = [];
47
+ bestRoute?.forEach((leg) => leg.swaps?.forEach((swap) => swap.swapExchanges?.forEach((ex) => {
48
+ if (ex.exchange && !route.includes(ex.exchange))
49
+ route.push(ex.exchange);
50
+ })));
51
+ return buildQuote({
52
+ provider: 'paraswap',
53
+ params,
54
+ toAmount,
55
+ gasEstimate,
56
+ gasEstimateUsd,
57
+ platformFee: 0,
58
+ priceImpact,
59
+ route: route.length > 0 ? route : ['ParaSwap'],
60
+ estimatedTimeMs: 15000,
61
+ mevProtected: false,
62
+ metadata: priceRoute,
63
+ });
64
+ }
65
+ catch {
66
+ return null;
67
+ }
68
+ finally {
69
+ clearTimeout(timer);
70
+ }
71
+ }
72
+ }
73
+ //# sourceMappingURL=paraswap.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"paraswap.js","sourceRoot":"","sources":["../../../../src/swap/router/providers/paraswap.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,31 @@
1
+ import type { ISwapProvider, AggregatorQuote, QuoteParams } from '../types.js';
2
+ /**
3
+ * UniswapProvider — wraps the existing Uniswap V3 QuoterV2 via on-chain read.
4
+ * In router context we simulate a quote using known pool data.
5
+ * For real execution, use SwapModule directly.
6
+ */
7
+ export declare class UniswapProvider implements ISwapProvider {
8
+ readonly name = "uniswap";
9
+ readonly supportedChains: string[];
10
+ /** Optional QuoterV2 fetch override for testing */
11
+ private readonly fetcher?;
12
+ constructor(options?: {
13
+ fetcher?: (p: QuoteParams) => Promise<AggregatorQuote | null>;
14
+ });
15
+ getQuote(params: QuoteParams, timeoutMs: number): Promise<AggregatorQuote | null>;
16
+ }
17
+ export declare function buildQuote(opts: {
18
+ provider: string;
19
+ params: QuoteParams;
20
+ toAmount: bigint;
21
+ gasEstimate: bigint;
22
+ gasEstimateUsd: number;
23
+ platformFee: number;
24
+ priceImpact: number;
25
+ route: string[];
26
+ estimatedTimeMs: number;
27
+ mevProtected: boolean;
28
+ txData?: AggregatorQuote['txData'];
29
+ metadata?: Record<string, unknown>;
30
+ }): AggregatorQuote;
31
+ //# sourceMappingURL=uniswap.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"uniswap.d.ts","sourceRoot":"","sources":["../../../../src/swap/router/providers/uniswap.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,aAAa,EAAE,eAAe,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAM/E;;;;GAIG;AACH,qBAAa,eAAgB,YAAW,aAAa;IACnD,QAAQ,CAAC,IAAI,aAAa;IAC1B,QAAQ,CAAC,eAAe,WAAkB;IAE1C,mDAAmD;IACnD,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAC,CAA2D;gBAExE,OAAO,GAAE;QAAE,OAAO,CAAC,EAAE,CAAC,CAAC,EAAE,WAAW,KAAK,OAAO,CAAC,eAAe,GAAG,IAAI,CAAC,CAAA;KAAO;IAIrF,QAAQ,CAAC,MAAM,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,eAAe,GAAG,IAAI,CAAC;CA+DxF;AAsBD,wBAAgB,UAAU,CAAC,IAAI,EAAE;IAC/B,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,EAAE,WAAW,CAAC;IACpB,QAAQ,EAAE,MAAM,CAAC;IACjB,WAAW,EAAE,MAAM,CAAC;IACpB,cAAc,EAAE,MAAM,CAAC;IACvB,WAAW,EAAE,MAAM,CAAC;IACpB,WAAW,EAAE,MAAM,CAAC;IACpB,KAAK,EAAE,MAAM,EAAE,CAAC;IAChB,eAAe,EAAE,MAAM,CAAC;IACxB,YAAY,EAAE,OAAO,CAAC;IACtB,MAAM,CAAC,EAAE,eAAe,CAAC,QAAQ,CAAC,CAAC;IACnC,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACpC,GAAG,eAAe,CAwBlB"}