@catalyst-team/poly-sdk 0.1.0 → 0.2.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 (201) hide show
  1. package/LICENSE +21 -0
  2. package/README.en.md +538 -0
  3. package/README.md +357 -78
  4. package/docs/00-design.md +1 -1
  5. package/docs/02-API.md +21 -21
  6. package/docs/arb/test-plan.md +387 -0
  7. package/docs/arb/test-results.md +336 -0
  8. package/docs/arbitrage.md +754 -0
  9. package/docs/reports/smart-money-analysis-2025-12-23-cn.md +840 -0
  10. package/examples/13-arbitrage-service.ts +211 -0
  11. package/examples/README.md +1 -1
  12. package/package.json +19 -19
  13. package/scripts/arb/faze-bo3-arb.ts +385 -0
  14. package/scripts/arb/settle-position.ts +190 -0
  15. package/scripts/arb/token-rebalancer.ts +420 -0
  16. package/scripts/arb-tests/01-unit-tests.ts +495 -0
  17. package/scripts/arb-tests/02-integration-tests.ts +412 -0
  18. package/scripts/arb-tests/03-e2e-tests.ts +503 -0
  19. package/scripts/arb-tests/README.md +109 -0
  20. package/scripts/verify/verify-all-apis.ts +1 -1
  21. package/src/clients/clob-api.ts +1 -1
  22. package/src/clients/gamma-api.ts +1 -1
  23. package/src/core/cache-adapter-bridge.ts +1 -1
  24. package/src/core/types.ts +3 -3
  25. package/src/core/unified-cache.ts +1 -1
  26. package/src/index.ts +25 -19
  27. package/src/services/arbitrage-service.ts +1807 -0
  28. package/.env +0 -0
  29. package/dist/__tests__/clob-api.test.d.ts +0 -5
  30. package/dist/__tests__/clob-api.test.d.ts.map +0 -1
  31. package/dist/__tests__/clob-api.test.js +0 -240
  32. package/dist/__tests__/clob-api.test.js.map +0 -1
  33. package/dist/__tests__/integration/bridge-client.integration.test.d.ts +0 -11
  34. package/dist/__tests__/integration/bridge-client.integration.test.d.ts.map +0 -1
  35. package/dist/__tests__/integration/bridge-client.integration.test.js +0 -260
  36. package/dist/__tests__/integration/bridge-client.integration.test.js.map +0 -1
  37. package/dist/__tests__/integration/clob-api.integration.test.d.ts +0 -13
  38. package/dist/__tests__/integration/clob-api.integration.test.d.ts.map +0 -1
  39. package/dist/__tests__/integration/clob-api.integration.test.js +0 -170
  40. package/dist/__tests__/integration/clob-api.integration.test.js.map +0 -1
  41. package/dist/__tests__/integration/ctf-client.integration.test.d.ts +0 -17
  42. package/dist/__tests__/integration/ctf-client.integration.test.d.ts.map +0 -1
  43. package/dist/__tests__/integration/ctf-client.integration.test.js +0 -234
  44. package/dist/__tests__/integration/ctf-client.integration.test.js.map +0 -1
  45. package/dist/__tests__/integration/data-api.integration.test.d.ts +0 -9
  46. package/dist/__tests__/integration/data-api.integration.test.d.ts.map +0 -1
  47. package/dist/__tests__/integration/data-api.integration.test.js +0 -161
  48. package/dist/__tests__/integration/data-api.integration.test.js.map +0 -1
  49. package/dist/__tests__/integration/gamma-api.integration.test.d.ts +0 -9
  50. package/dist/__tests__/integration/gamma-api.integration.test.d.ts.map +0 -1
  51. package/dist/__tests__/integration/gamma-api.integration.test.js +0 -170
  52. package/dist/__tests__/integration/gamma-api.integration.test.js.map +0 -1
  53. package/dist/__tests__/test-utils.d.ts +0 -92
  54. package/dist/__tests__/test-utils.d.ts.map +0 -1
  55. package/dist/__tests__/test-utils.js +0 -143
  56. package/dist/__tests__/test-utils.js.map +0 -1
  57. package/dist/clients/bridge-client.d.ts +0 -388
  58. package/dist/clients/bridge-client.d.ts.map +0 -1
  59. package/dist/clients/bridge-client.js +0 -587
  60. package/dist/clients/bridge-client.js.map +0 -1
  61. package/dist/clients/clob-api.d.ts +0 -318
  62. package/dist/clients/clob-api.d.ts.map +0 -1
  63. package/dist/clients/clob-api.js +0 -388
  64. package/dist/clients/clob-api.js.map +0 -1
  65. package/dist/clients/ctf-client.d.ts +0 -473
  66. package/dist/clients/ctf-client.d.ts.map +0 -1
  67. package/dist/clients/ctf-client.js +0 -915
  68. package/dist/clients/ctf-client.js.map +0 -1
  69. package/dist/clients/data-api.d.ts +0 -134
  70. package/dist/clients/data-api.d.ts.map +0 -1
  71. package/dist/clients/data-api.js +0 -265
  72. package/dist/clients/data-api.js.map +0 -1
  73. package/dist/clients/gamma-api.d.ts +0 -401
  74. package/dist/clients/gamma-api.d.ts.map +0 -1
  75. package/dist/clients/gamma-api.js +0 -352
  76. package/dist/clients/gamma-api.js.map +0 -1
  77. package/dist/clients/trading-client.d.ts +0 -252
  78. package/dist/clients/trading-client.d.ts.map +0 -1
  79. package/dist/clients/trading-client.js +0 -543
  80. package/dist/clients/trading-client.js.map +0 -1
  81. package/dist/clients/websocket-manager.d.ts +0 -100
  82. package/dist/clients/websocket-manager.d.ts.map +0 -1
  83. package/dist/clients/websocket-manager.js +0 -193
  84. package/dist/clients/websocket-manager.js.map +0 -1
  85. package/dist/core/cache-adapter-bridge.d.ts +0 -36
  86. package/dist/core/cache-adapter-bridge.d.ts.map +0 -1
  87. package/dist/core/cache-adapter-bridge.js +0 -81
  88. package/dist/core/cache-adapter-bridge.js.map +0 -1
  89. package/dist/core/cache.d.ts +0 -40
  90. package/dist/core/cache.d.ts.map +0 -1
  91. package/dist/core/cache.js +0 -71
  92. package/dist/core/cache.js.map +0 -1
  93. package/dist/core/errors.d.ts +0 -38
  94. package/dist/core/errors.d.ts.map +0 -1
  95. package/dist/core/errors.js +0 -84
  96. package/dist/core/errors.js.map +0 -1
  97. package/dist/core/rate-limiter.d.ts +0 -31
  98. package/dist/core/rate-limiter.d.ts.map +0 -1
  99. package/dist/core/rate-limiter.js +0 -70
  100. package/dist/core/rate-limiter.js.map +0 -1
  101. package/dist/core/types.d.ts +0 -314
  102. package/dist/core/types.d.ts.map +0 -1
  103. package/dist/core/types.js +0 -19
  104. package/dist/core/types.js.map +0 -1
  105. package/dist/core/unified-cache.d.ts +0 -63
  106. package/dist/core/unified-cache.d.ts.map +0 -1
  107. package/dist/core/unified-cache.js +0 -114
  108. package/dist/core/unified-cache.js.map +0 -1
  109. package/dist/index.d.ts +0 -94
  110. package/dist/index.d.ts.map +0 -1
  111. package/dist/index.js +0 -258
  112. package/dist/index.js.map +0 -1
  113. package/dist/mcp/errors.d.ts +0 -33
  114. package/dist/mcp/errors.d.ts.map +0 -1
  115. package/dist/mcp/errors.js +0 -86
  116. package/dist/mcp/errors.js.map +0 -1
  117. package/dist/mcp/index.d.ts +0 -62
  118. package/dist/mcp/index.d.ts.map +0 -1
  119. package/dist/mcp/index.js +0 -173
  120. package/dist/mcp/index.js.map +0 -1
  121. package/dist/mcp/server.d.ts +0 -17
  122. package/dist/mcp/server.d.ts.map +0 -1
  123. package/dist/mcp/server.js +0 -155
  124. package/dist/mcp/server.js.map +0 -1
  125. package/dist/mcp/tools/guide.d.ts +0 -12
  126. package/dist/mcp/tools/guide.d.ts.map +0 -1
  127. package/dist/mcp/tools/guide.js +0 -801
  128. package/dist/mcp/tools/guide.js.map +0 -1
  129. package/dist/mcp/tools/index.d.ts +0 -11
  130. package/dist/mcp/tools/index.d.ts.map +0 -1
  131. package/dist/mcp/tools/index.js +0 -27
  132. package/dist/mcp/tools/index.js.map +0 -1
  133. package/dist/mcp/tools/market.d.ts +0 -11
  134. package/dist/mcp/tools/market.d.ts.map +0 -1
  135. package/dist/mcp/tools/market.js +0 -314
  136. package/dist/mcp/tools/market.js.map +0 -1
  137. package/dist/mcp/tools/order.d.ts +0 -10
  138. package/dist/mcp/tools/order.d.ts.map +0 -1
  139. package/dist/mcp/tools/order.js +0 -258
  140. package/dist/mcp/tools/order.js.map +0 -1
  141. package/dist/mcp/tools/trade.d.ts +0 -38
  142. package/dist/mcp/tools/trade.d.ts.map +0 -1
  143. package/dist/mcp/tools/trade.js +0 -314
  144. package/dist/mcp/tools/trade.js.map +0 -1
  145. package/dist/mcp/tools/trader.d.ts +0 -11
  146. package/dist/mcp/tools/trader.d.ts.map +0 -1
  147. package/dist/mcp/tools/trader.js +0 -277
  148. package/dist/mcp/tools/trader.js.map +0 -1
  149. package/dist/mcp/tools/wallet.d.ts +0 -274
  150. package/dist/mcp/tools/wallet.d.ts.map +0 -1
  151. package/dist/mcp/tools/wallet.js +0 -579
  152. package/dist/mcp/tools/wallet.js.map +0 -1
  153. package/dist/mcp/types.d.ts +0 -413
  154. package/dist/mcp/types.d.ts.map +0 -1
  155. package/dist/mcp/types.js +0 -5
  156. package/dist/mcp/types.js.map +0 -1
  157. package/dist/services/authorization-service.d.ts +0 -97
  158. package/dist/services/authorization-service.d.ts.map +0 -1
  159. package/dist/services/authorization-service.js +0 -279
  160. package/dist/services/authorization-service.js.map +0 -1
  161. package/dist/services/market-service.d.ts +0 -108
  162. package/dist/services/market-service.d.ts.map +0 -1
  163. package/dist/services/market-service.js +0 -458
  164. package/dist/services/market-service.js.map +0 -1
  165. package/dist/services/realtime-service.d.ts +0 -82
  166. package/dist/services/realtime-service.d.ts.map +0 -1
  167. package/dist/services/realtime-service.js +0 -150
  168. package/dist/services/realtime-service.js.map +0 -1
  169. package/dist/services/swap-service.d.ts +0 -217
  170. package/dist/services/swap-service.d.ts.map +0 -1
  171. package/dist/services/swap-service.js +0 -695
  172. package/dist/services/swap-service.js.map +0 -1
  173. package/dist/services/wallet-service.d.ts +0 -94
  174. package/dist/services/wallet-service.d.ts.map +0 -1
  175. package/dist/services/wallet-service.js +0 -173
  176. package/dist/services/wallet-service.js.map +0 -1
  177. package/dist/utils/price-utils.d.ts +0 -153
  178. package/dist/utils/price-utils.d.ts.map +0 -1
  179. package/dist/utils/price-utils.js +0 -236
  180. package/dist/utils/price-utils.js.map +0 -1
  181. package/docs/01-mcp.md +0 -2041
  182. package/docs/e2e/01-trader-tools.md +0 -159
  183. package/docs/e2e/02-market-tools.md +0 -180
  184. package/docs/e2e/03-order-tools.md +0 -166
  185. package/docs/e2e/04-wallet-tools.md +0 -224
  186. package/docs/e2e/05-trading-tools.md +0 -327
  187. package/docs/e2e/06-integration-scenarios.md +0 -481
  188. package/docs/e2e/coordinator.md +0 -376
  189. package/scripts/truth.md +0 -440
  190. package/src/mcp/README.md +0 -380
  191. package/src/mcp/errors.ts +0 -124
  192. package/src/mcp/index.ts +0 -309
  193. package/src/mcp/server.ts +0 -183
  194. package/src/mcp/tools/guide.ts +0 -821
  195. package/src/mcp/tools/index.ts +0 -73
  196. package/src/mcp/tools/market.ts +0 -363
  197. package/src/mcp/tools/order.ts +0 -326
  198. package/src/mcp/tools/trade.ts +0 -417
  199. package/src/mcp/tools/trader.ts +0 -322
  200. package/src/mcp/tools/wallet.ts +0 -683
  201. package/src/mcp/types.ts +0 -472
package/src/mcp/index.ts DELETED
@@ -1,309 +0,0 @@
1
- /**
2
- * Polymarket MCP Tools
3
- *
4
- * This module provides MCP (Model Context Protocol) tools for interacting with Polymarket.
5
- * It can be used to build an MCP server that exposes Polymarket functionality to AI agents.
6
- *
7
- * Tool Categories:
8
- * - Trader Tools: Analyze traders/wallets (positions, trades, profiles, leaderboard)
9
- * - Market Tools: Discover and analyze markets (get, search, trending, trades)
10
- * - Order Tools: Analyze orderbooks (depth, best prices, execution estimates)
11
- * - Trade Tools: Execute trades (limit orders, market orders) - requires API credentials
12
- * - Wallet Tools: Deposits and authorization management
13
- *
14
- * Usage:
15
- * ```typescript
16
- * import { PolymarketSDK } from '@prediction-router/poly-sdk';
17
- * import { createMcpHandler, allToolDefinitions } from '@prediction-router/poly-sdk/mcp';
18
- *
19
- * const sdk = new PolymarketSDK();
20
- * const handler = createMcpHandler(sdk);
21
- *
22
- * // Use with MCP server
23
- * const result = await handler('get_trader_positions', { address: '0x...' });
24
- * ```
25
- */
26
-
27
- import { PolymarketSDK } from '../index.js';
28
- import { McpToolError, wrapError } from './errors.js';
29
- import {
30
- allToolDefinitions,
31
- // Guide handlers
32
- createGuideHandlers,
33
- // Trader handlers
34
- handleGetTraderPositions,
35
- handleGetTraderTrades,
36
- handleGetTraderProfile,
37
- handleGetLeaderboard,
38
- // Market handlers
39
- handleGetMarket,
40
- handleSearchMarkets,
41
- handleGetTrendingMarkets,
42
- handleGetMarketTrades,
43
- // Order handlers
44
- handleGetOrderbook,
45
- handleGetBestPrices,
46
- handleEstimateExecution,
47
- // Trade handlers
48
- handlePlaceLimitOrder,
49
- handlePlaceMarketOrder,
50
- handleCancelOrder,
51
- handleGetMyOrders,
52
- // Wallet handlers
53
- handleGetSupportedAssets,
54
- handleGetDepositAddresses,
55
- handleDepositUsdc,
56
- handleCheckAllowances,
57
- handleApproveTrading,
58
- handleSwap,
59
- handleSwapAndDeposit,
60
- handleGetTokenBalances,
61
- handleGetWalletBalances,
62
- handleGetSwapQuote,
63
- handleGetAvailablePools,
64
- } from './tools/index.js';
65
-
66
- // Re-export types
67
- export * from './types.js';
68
- export * from './errors.js';
69
- export { allToolDefinitions } from './tools/index.js';
70
-
71
- // Tool handler type
72
- export type ToolHandler = (
73
- toolName: string,
74
- args: Record<string, unknown>
75
- ) => Promise<unknown>;
76
-
77
- /**
78
- * Create an MCP tool handler for the given SDK instance
79
- */
80
- export function createMcpHandler(sdk: PolymarketSDK): ToolHandler {
81
- // Create guide handlers (no SDK dependency)
82
- const guideHandlers = createGuideHandlers();
83
-
84
- return async (toolName: string, args: Record<string, unknown>): Promise<unknown> => {
85
- try {
86
- switch (toolName) {
87
- // Guide Tool - should be called FIRST
88
- case 'get_usage_guide':
89
- return await guideHandlers.get_usage_guide(args);
90
-
91
- // Trader Tools
92
- case 'get_trader_positions':
93
- return await handleGetTraderPositions(sdk, args as { address: string });
94
-
95
- case 'get_trader_trades':
96
- return await handleGetTraderTrades(sdk, args as {
97
- address: string;
98
- limit?: number;
99
- side?: 'BUY' | 'SELL';
100
- });
101
-
102
- case 'get_trader_profile':
103
- return await handleGetTraderProfile(sdk, args as { address: string });
104
-
105
- case 'get_leaderboard':
106
- return await handleGetLeaderboard(sdk, args as {
107
- limit?: number;
108
- offset?: number;
109
- });
110
-
111
- // Market Tools
112
- case 'get_market':
113
- return await handleGetMarket(sdk, args as { identifier: string });
114
-
115
- case 'search_markets':
116
- return await handleSearchMarkets(sdk, args as {
117
- query: string;
118
- active?: boolean;
119
- limit?: number;
120
- });
121
-
122
- case 'get_trending_markets':
123
- return await handleGetTrendingMarkets(sdk, args as {
124
- limit?: number;
125
- sortBy?: 'volume' | 'liquidity' | 'newest';
126
- });
127
-
128
- case 'get_market_trades':
129
- return await handleGetMarketTrades(sdk, args as {
130
- conditionId: string;
131
- limit?: number;
132
- });
133
-
134
- // Order Tools
135
- case 'get_orderbook':
136
- return await handleGetOrderbook(sdk, args as {
137
- conditionId: string;
138
- outcome: 'Yes' | 'No';
139
- depth?: number;
140
- });
141
-
142
- case 'get_best_prices':
143
- return await handleGetBestPrices(sdk, args as {
144
- conditionId: string;
145
- });
146
-
147
- case 'estimate_execution':
148
- return await handleEstimateExecution(sdk, args as {
149
- conditionId: string;
150
- outcome: 'Yes' | 'No';
151
- side: 'BUY' | 'SELL';
152
- amount: number;
153
- });
154
-
155
- // Trade Tools
156
- case 'place_limit_order':
157
- return await handlePlaceLimitOrder(sdk, args as {
158
- conditionId: string;
159
- outcome: 'Yes' | 'No';
160
- side: 'BUY' | 'SELL';
161
- price: number;
162
- size: number;
163
- orderType?: 'GTC' | 'GTD';
164
- });
165
-
166
- case 'place_market_order':
167
- return await handlePlaceMarketOrder(sdk, args as {
168
- conditionId: string;
169
- outcome: 'Yes' | 'No';
170
- side: 'BUY' | 'SELL';
171
- amount: number;
172
- maxSlippage?: number;
173
- });
174
-
175
- case 'cancel_order':
176
- return await handleCancelOrder(sdk, args as { orderId: string });
177
-
178
- case 'get_my_orders':
179
- return await handleGetMyOrders(sdk, args as {
180
- status?: 'LIVE' | 'FILLED' | 'CANCELLED';
181
- });
182
-
183
- // Wallet Tools
184
- case 'get_supported_deposit_assets':
185
- return await handleGetSupportedAssets(sdk, args as {
186
- chainId?: number;
187
- });
188
-
189
- case 'get_deposit_addresses':
190
- return await handleGetDepositAddresses(sdk);
191
-
192
- case 'deposit_usdc':
193
- return await handleDepositUsdc(sdk, args as {
194
- amount: number;
195
- token?: 'NATIVE_USDC' | 'USDC_E';
196
- });
197
-
198
- case 'check_allowances':
199
- return await handleCheckAllowances(sdk);
200
-
201
- case 'approve_trading':
202
- return await handleApproveTrading(sdk);
203
-
204
- case 'swap':
205
- return await handleSwap(sdk, args as {
206
- tokenIn: string;
207
- tokenOut: string;
208
- amount: string;
209
- slippage?: number;
210
- });
211
-
212
- case 'swap_and_deposit':
213
- return await handleSwapAndDeposit(sdk, args as {
214
- token: string;
215
- amount: string;
216
- slippage?: number;
217
- });
218
-
219
- case 'get_token_balances':
220
- return await handleGetTokenBalances(sdk);
221
-
222
- case 'get_wallet_balances':
223
- return await handleGetWalletBalances(sdk, args as { address: string });
224
-
225
- case 'get_swap_quote':
226
- return await handleGetSwapQuote(sdk, args as {
227
- tokenIn: string;
228
- tokenOut: string;
229
- amount: string;
230
- });
231
-
232
- case 'get_available_pools':
233
- return await handleGetAvailablePools(sdk);
234
-
235
- default:
236
- throw new McpToolError(
237
- 'INVALID_INPUT' as unknown as import('./errors.js').ErrorCode,
238
- `Unknown tool: ${toolName}`
239
- );
240
- }
241
- } catch (err) {
242
- if (err instanceof McpToolError) {
243
- return err.toResponse();
244
- }
245
- return wrapError(err).toResponse();
246
- }
247
- };
248
- }
249
-
250
- /**
251
- * Get all tool definitions for MCP registration
252
- */
253
- export function getToolDefinitions() {
254
- return allToolDefinitions;
255
- }
256
-
257
- /**
258
- * MCP Server factory (for use with @modelcontextprotocol/sdk)
259
- *
260
- * Example usage with MCP SDK:
261
- * ```typescript
262
- * import { Server } from '@modelcontextprotocol/sdk/server/index.js';
263
- * import { StdioServerTransport } from '@modelcontextprotocol/sdk/server/stdio.js';
264
- * import { PolymarketSDK } from '@prediction-router/poly-sdk';
265
- * import { registerMcpTools } from '@prediction-router/poly-sdk/mcp';
266
- *
267
- * const server = new Server(
268
- * { name: 'poly-mcp', version: '1.0.0' },
269
- * { capabilities: { tools: {} } }
270
- * );
271
- *
272
- * const sdk = new PolymarketSDK();
273
- * registerMcpTools(server, sdk);
274
- *
275
- * const transport = new StdioServerTransport();
276
- * await server.connect(transport);
277
- * ```
278
- */
279
- export function registerMcpTools(
280
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
281
- server: any,
282
- sdk: PolymarketSDK
283
- ): void {
284
- const handler = createMcpHandler(sdk);
285
-
286
- // Register list tools handler
287
- server.setRequestHandler(
288
- { method: 'tools/list' },
289
- async () => ({ tools: allToolDefinitions })
290
- );
291
-
292
- // Register call tool handler
293
- server.setRequestHandler(
294
- { method: 'tools/call' },
295
- async (request: { params: { name: string; arguments?: Record<string, unknown> } }) => {
296
- const { name, arguments: args = {} } = request.params;
297
- const result = await handler(name, args);
298
-
299
- return {
300
- content: [
301
- {
302
- type: 'text',
303
- text: JSON.stringify(result, null, 2),
304
- },
305
- ],
306
- };
307
- }
308
- );
309
- }
package/src/mcp/server.ts DELETED
@@ -1,183 +0,0 @@
1
- #!/usr/bin/env node
2
- /**
3
- * Polymarket MCP Server
4
- *
5
- * A standalone MCP server that exposes Polymarket functionality to AI agents.
6
- *
7
- * Usage:
8
- * npx @prediction-router/poly-sdk-mcp
9
- * # or
10
- * node dist/mcp/server.js
11
- *
12
- * Configuration via environment variables:
13
- * - POLY_PRIVATE_KEY: Wallet private key (required for trading, API credentials are derived automatically)
14
- * - POLY_CHAIN_ID: Chain ID (137 for mainnet, 80002 for testnet, default: 137)
15
- */
16
-
17
- import { Server } from '@modelcontextprotocol/sdk/server/index.js';
18
- import { StdioServerTransport } from '@modelcontextprotocol/sdk/server/stdio.js';
19
- import {
20
- CallToolRequestSchema,
21
- ListToolsRequestSchema,
22
- } from '@modelcontextprotocol/sdk/types.js';
23
- import { Wallet } from 'ethers';
24
-
25
- import { PolymarketSDK } from '../index.js';
26
- import { allToolDefinitions } from './tools/index.js';
27
- import { createMcpHandler } from './index.js';
28
-
29
- /**
30
- * Create a wallet signer from private key if available
31
- */
32
- function createSigner(): Wallet | undefined {
33
- const privateKey = process.env.POLY_PRIVATE_KEY;
34
- if (!privateKey) {
35
- return undefined;
36
- }
37
-
38
- try {
39
- // Ensure private key has 0x prefix
40
- const formattedKey = privateKey.startsWith('0x') ? privateKey : `0x${privateKey}`;
41
- return new Wallet(formattedKey);
42
- } catch (error) {
43
- console.error('Failed to create wallet from POLY_PRIVATE_KEY:', error);
44
- return undefined;
45
- }
46
- }
47
-
48
- // Server metadata
49
- const SERVER_NAME = 'polymarket-mcp';
50
- const SERVER_VERSION = '0.1.0';
51
-
52
- /**
53
- * Create and configure the MCP server
54
- */
55
- function createServer(): Server {
56
- const server = new Server(
57
- {
58
- name: SERVER_NAME,
59
- version: SERVER_VERSION,
60
- },
61
- {
62
- capabilities: {
63
- tools: {},
64
- },
65
- }
66
- );
67
-
68
- // Create signer from private key if available
69
- const signer = createSigner();
70
-
71
- // Initialize SDK with environment configuration
72
- // API credentials are derived automatically from private key via createOrDeriveApiKey()
73
- const sdk = new PolymarketSDK({
74
- chainId: process.env.POLY_CHAIN_ID ? parseInt(process.env.POLY_CHAIN_ID) : 137,
75
- signer,
76
- });
77
-
78
- // Log trading status
79
- if (signer) {
80
- console.error(`Trading enabled for wallet: ${signer.address}`);
81
- } else {
82
- console.error('Trading disabled (set POLY_PRIVATE_KEY to enable)');
83
- }
84
-
85
- // Create the tool handler
86
- const handler = createMcpHandler(sdk);
87
-
88
- // Register list tools handler
89
- server.setRequestHandler(ListToolsRequestSchema, async () => {
90
- return {
91
- tools: allToolDefinitions.map((tool) => ({
92
- name: tool.name,
93
- description: tool.description,
94
- inputSchema: tool.inputSchema,
95
- })),
96
- };
97
- });
98
-
99
- // Register call tool handler
100
- server.setRequestHandler(CallToolRequestSchema, async (request) => {
101
- const { name, arguments: args = {} } = request.params;
102
-
103
- try {
104
- const result = await handler(name, args as Record<string, unknown>);
105
-
106
- // Check if result is an error response
107
- if (result && typeof result === 'object' && 'error' in result) {
108
- return {
109
- content: [
110
- {
111
- type: 'text',
112
- text: JSON.stringify(result, null, 2),
113
- },
114
- ],
115
- isError: true,
116
- };
117
- }
118
-
119
- return {
120
- content: [
121
- {
122
- type: 'text',
123
- text: JSON.stringify(result, null, 2),
124
- },
125
- ],
126
- };
127
- } catch (error) {
128
- const errorMessage = error instanceof Error ? error.message : String(error);
129
- return {
130
- content: [
131
- {
132
- type: 'text',
133
- text: JSON.stringify(
134
- {
135
- error: {
136
- code: 'INTERNAL_ERROR',
137
- message: errorMessage,
138
- },
139
- },
140
- null,
141
- 2
142
- ),
143
- },
144
- ],
145
- isError: true,
146
- };
147
- }
148
- });
149
-
150
- return server;
151
- }
152
-
153
- /**
154
- * Main entry point
155
- */
156
- async function main(): Promise<void> {
157
- const server = createServer();
158
- const transport = new StdioServerTransport();
159
-
160
- // Handle shutdown gracefully
161
- process.on('SIGINT', async () => {
162
- await server.close();
163
- process.exit(0);
164
- });
165
-
166
- process.on('SIGTERM', async () => {
167
- await server.close();
168
- process.exit(0);
169
- });
170
-
171
- // Connect and run
172
- await server.connect(transport);
173
-
174
- // Log to stderr (stdout is reserved for MCP protocol)
175
- console.error(`${SERVER_NAME} v${SERVER_VERSION} started`);
176
- console.error(`Available tools: ${allToolDefinitions.length}`);
177
- }
178
-
179
- // Run the server
180
- main().catch((error) => {
181
- console.error('Failed to start MCP server:', error);
182
- process.exit(1);
183
- });