@catalyst-team/poly-sdk 0.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 (244) hide show
  1. package/.env +0 -0
  2. package/README.md +803 -0
  3. package/dist/__tests__/clob-api.test.d.ts +5 -0
  4. package/dist/__tests__/clob-api.test.d.ts.map +1 -0
  5. package/dist/__tests__/clob-api.test.js +240 -0
  6. package/dist/__tests__/clob-api.test.js.map +1 -0
  7. package/dist/__tests__/integration/bridge-client.integration.test.d.ts +11 -0
  8. package/dist/__tests__/integration/bridge-client.integration.test.d.ts.map +1 -0
  9. package/dist/__tests__/integration/bridge-client.integration.test.js +260 -0
  10. package/dist/__tests__/integration/bridge-client.integration.test.js.map +1 -0
  11. package/dist/__tests__/integration/clob-api.integration.test.d.ts +13 -0
  12. package/dist/__tests__/integration/clob-api.integration.test.d.ts.map +1 -0
  13. package/dist/__tests__/integration/clob-api.integration.test.js +170 -0
  14. package/dist/__tests__/integration/clob-api.integration.test.js.map +1 -0
  15. package/dist/__tests__/integration/ctf-client.integration.test.d.ts +17 -0
  16. package/dist/__tests__/integration/ctf-client.integration.test.d.ts.map +1 -0
  17. package/dist/__tests__/integration/ctf-client.integration.test.js +234 -0
  18. package/dist/__tests__/integration/ctf-client.integration.test.js.map +1 -0
  19. package/dist/__tests__/integration/data-api.integration.test.d.ts +9 -0
  20. package/dist/__tests__/integration/data-api.integration.test.d.ts.map +1 -0
  21. package/dist/__tests__/integration/data-api.integration.test.js +161 -0
  22. package/dist/__tests__/integration/data-api.integration.test.js.map +1 -0
  23. package/dist/__tests__/integration/gamma-api.integration.test.d.ts +9 -0
  24. package/dist/__tests__/integration/gamma-api.integration.test.d.ts.map +1 -0
  25. package/dist/__tests__/integration/gamma-api.integration.test.js +170 -0
  26. package/dist/__tests__/integration/gamma-api.integration.test.js.map +1 -0
  27. package/dist/__tests__/test-utils.d.ts +92 -0
  28. package/dist/__tests__/test-utils.d.ts.map +1 -0
  29. package/dist/__tests__/test-utils.js +143 -0
  30. package/dist/__tests__/test-utils.js.map +1 -0
  31. package/dist/clients/bridge-client.d.ts +388 -0
  32. package/dist/clients/bridge-client.d.ts.map +1 -0
  33. package/dist/clients/bridge-client.js +587 -0
  34. package/dist/clients/bridge-client.js.map +1 -0
  35. package/dist/clients/clob-api.d.ts +318 -0
  36. package/dist/clients/clob-api.d.ts.map +1 -0
  37. package/dist/clients/clob-api.js +388 -0
  38. package/dist/clients/clob-api.js.map +1 -0
  39. package/dist/clients/ctf-client.d.ts +473 -0
  40. package/dist/clients/ctf-client.d.ts.map +1 -0
  41. package/dist/clients/ctf-client.js +915 -0
  42. package/dist/clients/ctf-client.js.map +1 -0
  43. package/dist/clients/data-api.d.ts +134 -0
  44. package/dist/clients/data-api.d.ts.map +1 -0
  45. package/dist/clients/data-api.js +265 -0
  46. package/dist/clients/data-api.js.map +1 -0
  47. package/dist/clients/gamma-api.d.ts +401 -0
  48. package/dist/clients/gamma-api.d.ts.map +1 -0
  49. package/dist/clients/gamma-api.js +352 -0
  50. package/dist/clients/gamma-api.js.map +1 -0
  51. package/dist/clients/trading-client.d.ts +252 -0
  52. package/dist/clients/trading-client.d.ts.map +1 -0
  53. package/dist/clients/trading-client.js +543 -0
  54. package/dist/clients/trading-client.js.map +1 -0
  55. package/dist/clients/websocket-manager.d.ts +100 -0
  56. package/dist/clients/websocket-manager.d.ts.map +1 -0
  57. package/dist/clients/websocket-manager.js +193 -0
  58. package/dist/clients/websocket-manager.js.map +1 -0
  59. package/dist/core/cache-adapter-bridge.d.ts +36 -0
  60. package/dist/core/cache-adapter-bridge.d.ts.map +1 -0
  61. package/dist/core/cache-adapter-bridge.js +81 -0
  62. package/dist/core/cache-adapter-bridge.js.map +1 -0
  63. package/dist/core/cache.d.ts +40 -0
  64. package/dist/core/cache.d.ts.map +1 -0
  65. package/dist/core/cache.js +71 -0
  66. package/dist/core/cache.js.map +1 -0
  67. package/dist/core/errors.d.ts +38 -0
  68. package/dist/core/errors.d.ts.map +1 -0
  69. package/dist/core/errors.js +84 -0
  70. package/dist/core/errors.js.map +1 -0
  71. package/dist/core/rate-limiter.d.ts +31 -0
  72. package/dist/core/rate-limiter.d.ts.map +1 -0
  73. package/dist/core/rate-limiter.js +70 -0
  74. package/dist/core/rate-limiter.js.map +1 -0
  75. package/dist/core/types.d.ts +314 -0
  76. package/dist/core/types.d.ts.map +1 -0
  77. package/dist/core/types.js +19 -0
  78. package/dist/core/types.js.map +1 -0
  79. package/dist/core/unified-cache.d.ts +63 -0
  80. package/dist/core/unified-cache.d.ts.map +1 -0
  81. package/dist/core/unified-cache.js +114 -0
  82. package/dist/core/unified-cache.js.map +1 -0
  83. package/dist/index.d.ts +94 -0
  84. package/dist/index.d.ts.map +1 -0
  85. package/dist/index.js +258 -0
  86. package/dist/index.js.map +1 -0
  87. package/dist/mcp/errors.d.ts +33 -0
  88. package/dist/mcp/errors.d.ts.map +1 -0
  89. package/dist/mcp/errors.js +86 -0
  90. package/dist/mcp/errors.js.map +1 -0
  91. package/dist/mcp/index.d.ts +62 -0
  92. package/dist/mcp/index.d.ts.map +1 -0
  93. package/dist/mcp/index.js +173 -0
  94. package/dist/mcp/index.js.map +1 -0
  95. package/dist/mcp/server.d.ts +17 -0
  96. package/dist/mcp/server.d.ts.map +1 -0
  97. package/dist/mcp/server.js +155 -0
  98. package/dist/mcp/server.js.map +1 -0
  99. package/dist/mcp/tools/guide.d.ts +12 -0
  100. package/dist/mcp/tools/guide.d.ts.map +1 -0
  101. package/dist/mcp/tools/guide.js +801 -0
  102. package/dist/mcp/tools/guide.js.map +1 -0
  103. package/dist/mcp/tools/index.d.ts +11 -0
  104. package/dist/mcp/tools/index.d.ts.map +1 -0
  105. package/dist/mcp/tools/index.js +27 -0
  106. package/dist/mcp/tools/index.js.map +1 -0
  107. package/dist/mcp/tools/market.d.ts +11 -0
  108. package/dist/mcp/tools/market.d.ts.map +1 -0
  109. package/dist/mcp/tools/market.js +314 -0
  110. package/dist/mcp/tools/market.js.map +1 -0
  111. package/dist/mcp/tools/order.d.ts +10 -0
  112. package/dist/mcp/tools/order.d.ts.map +1 -0
  113. package/dist/mcp/tools/order.js +258 -0
  114. package/dist/mcp/tools/order.js.map +1 -0
  115. package/dist/mcp/tools/trade.d.ts +38 -0
  116. package/dist/mcp/tools/trade.d.ts.map +1 -0
  117. package/dist/mcp/tools/trade.js +314 -0
  118. package/dist/mcp/tools/trade.js.map +1 -0
  119. package/dist/mcp/tools/trader.d.ts +11 -0
  120. package/dist/mcp/tools/trader.d.ts.map +1 -0
  121. package/dist/mcp/tools/trader.js +277 -0
  122. package/dist/mcp/tools/trader.js.map +1 -0
  123. package/dist/mcp/tools/wallet.d.ts +274 -0
  124. package/dist/mcp/tools/wallet.d.ts.map +1 -0
  125. package/dist/mcp/tools/wallet.js +579 -0
  126. package/dist/mcp/tools/wallet.js.map +1 -0
  127. package/dist/mcp/types.d.ts +413 -0
  128. package/dist/mcp/types.d.ts.map +1 -0
  129. package/dist/mcp/types.js +5 -0
  130. package/dist/mcp/types.js.map +1 -0
  131. package/dist/services/authorization-service.d.ts +97 -0
  132. package/dist/services/authorization-service.d.ts.map +1 -0
  133. package/dist/services/authorization-service.js +279 -0
  134. package/dist/services/authorization-service.js.map +1 -0
  135. package/dist/services/market-service.d.ts +108 -0
  136. package/dist/services/market-service.d.ts.map +1 -0
  137. package/dist/services/market-service.js +458 -0
  138. package/dist/services/market-service.js.map +1 -0
  139. package/dist/services/realtime-service.d.ts +82 -0
  140. package/dist/services/realtime-service.d.ts.map +1 -0
  141. package/dist/services/realtime-service.js +150 -0
  142. package/dist/services/realtime-service.js.map +1 -0
  143. package/dist/services/swap-service.d.ts +217 -0
  144. package/dist/services/swap-service.d.ts.map +1 -0
  145. package/dist/services/swap-service.js +695 -0
  146. package/dist/services/swap-service.js.map +1 -0
  147. package/dist/services/wallet-service.d.ts +94 -0
  148. package/dist/services/wallet-service.d.ts.map +1 -0
  149. package/dist/services/wallet-service.js +173 -0
  150. package/dist/services/wallet-service.js.map +1 -0
  151. package/dist/utils/price-utils.d.ts +153 -0
  152. package/dist/utils/price-utils.d.ts.map +1 -0
  153. package/dist/utils/price-utils.js +236 -0
  154. package/dist/utils/price-utils.js.map +1 -0
  155. package/docs/00-design.md +760 -0
  156. package/docs/01-mcp.md +2041 -0
  157. package/docs/02-API.md +1148 -0
  158. package/docs/e2e/01-trader-tools.md +159 -0
  159. package/docs/e2e/02-market-tools.md +180 -0
  160. package/docs/e2e/03-order-tools.md +166 -0
  161. package/docs/e2e/04-wallet-tools.md +224 -0
  162. package/docs/e2e/05-trading-tools.md +327 -0
  163. package/docs/e2e/06-integration-scenarios.md +481 -0
  164. package/docs/e2e/coordinator.md +376 -0
  165. package/examples/01-basic-usage.ts +68 -0
  166. package/examples/02-smart-money.ts +95 -0
  167. package/examples/03-market-analysis.ts +108 -0
  168. package/examples/04-kline-aggregation.ts +158 -0
  169. package/examples/05-follow-wallet-strategy.ts +156 -0
  170. package/examples/06-services-demo.ts +124 -0
  171. package/examples/07-realtime-websocket.ts +117 -0
  172. package/examples/08-trading-orders.ts +278 -0
  173. package/examples/09-rewards-tracking.ts +187 -0
  174. package/examples/10-ctf-operations.ts +336 -0
  175. package/examples/11-live-arbitrage-scan.ts +221 -0
  176. package/examples/12-trending-arb-monitor.ts +406 -0
  177. package/examples/README.md +179 -0
  178. package/package.json +62 -0
  179. package/scripts/README.md +163 -0
  180. package/scripts/approvals/approve-erc1155.ts +129 -0
  181. package/scripts/approvals/approve-neg-risk-erc1155.ts +149 -0
  182. package/scripts/approvals/approve-neg-risk.ts +102 -0
  183. package/scripts/approvals/check-all-allowances.ts +150 -0
  184. package/scripts/approvals/check-allowance.ts +129 -0
  185. package/scripts/approvals/check-ctf-approval.ts +158 -0
  186. package/scripts/datas/001-report.md +486 -0
  187. package/scripts/datas/clone-modal-screenshot.png +0 -0
  188. package/scripts/deposit/deposit-native-usdc.ts +179 -0
  189. package/scripts/deposit/deposit-usdc.ts +155 -0
  190. package/scripts/deposit/swap-usdc-to-usdce.ts +375 -0
  191. package/scripts/research/research-markets.ts +166 -0
  192. package/scripts/trading/check-orders.ts +50 -0
  193. package/scripts/trading/sell-nvidia-positions.ts +206 -0
  194. package/scripts/trading/test-order.ts +172 -0
  195. package/scripts/truth.md +440 -0
  196. package/scripts/verify/test-approve-trading.ts +98 -0
  197. package/scripts/verify/test-provider-fix.ts +43 -0
  198. package/scripts/verify/test-search-mcp.ts +113 -0
  199. package/scripts/verify/verify-all-apis.ts +160 -0
  200. package/scripts/wallet/check-wallet-balances.ts +75 -0
  201. package/scripts/wallet/test-wallet-operations.ts +191 -0
  202. package/scripts/wallet/verify-wallet-tools.ts +124 -0
  203. package/src/__tests__/clob-api.test.ts +301 -0
  204. package/src/__tests__/integration/bridge-client.integration.test.ts +314 -0
  205. package/src/__tests__/integration/clob-api.integration.test.ts +218 -0
  206. package/src/__tests__/integration/ctf-client.integration.test.ts +331 -0
  207. package/src/__tests__/integration/data-api.integration.test.ts +194 -0
  208. package/src/__tests__/integration/gamma-api.integration.test.ts +206 -0
  209. package/src/__tests__/test-utils.ts +170 -0
  210. package/src/clients/bridge-client.ts +841 -0
  211. package/src/clients/clob-api.ts +629 -0
  212. package/src/clients/ctf-client.ts +1216 -0
  213. package/src/clients/data-api.ts +469 -0
  214. package/src/clients/gamma-api.ts +597 -0
  215. package/src/clients/trading-client.ts +749 -0
  216. package/src/clients/websocket-manager.ts +267 -0
  217. package/src/core/cache-adapter-bridge.ts +94 -0
  218. package/src/core/cache.ts +85 -0
  219. package/src/core/errors.ts +117 -0
  220. package/src/core/rate-limiter.ts +74 -0
  221. package/src/core/types.ts +360 -0
  222. package/src/core/unified-cache.ts +153 -0
  223. package/src/index.ts +455 -0
  224. package/src/mcp/README.md +380 -0
  225. package/src/mcp/errors.ts +124 -0
  226. package/src/mcp/index.ts +309 -0
  227. package/src/mcp/server.ts +183 -0
  228. package/src/mcp/tools/guide.ts +821 -0
  229. package/src/mcp/tools/index.ts +73 -0
  230. package/src/mcp/tools/market.ts +363 -0
  231. package/src/mcp/tools/order.ts +326 -0
  232. package/src/mcp/tools/trade.ts +417 -0
  233. package/src/mcp/tools/trader.ts +322 -0
  234. package/src/mcp/tools/wallet.ts +683 -0
  235. package/src/mcp/types.ts +472 -0
  236. package/src/services/authorization-service.ts +357 -0
  237. package/src/services/market-service.ts +544 -0
  238. package/src/services/realtime-service.ts +196 -0
  239. package/src/services/swap-service.ts +896 -0
  240. package/src/services/wallet-service.ts +259 -0
  241. package/src/utils/price-utils.ts +307 -0
  242. package/tsconfig.json +8 -0
  243. package/vitest.config.ts +19 -0
  244. package/vitest.integration.config.ts +18 -0
@@ -0,0 +1,401 @@
1
+ /**
2
+ * Gamma API Client for Polymarket
3
+ *
4
+ * The Gamma API provides rich market discovery and metadata. Unlike the CLOB API
5
+ * which is focused on trading, Gamma is optimized for browsing, searching, and
6
+ * discovering prediction markets.
7
+ *
8
+ * @remarks
9
+ * - Base URL: https://gamma-api.polymarket.com
10
+ * - Best for: Market discovery, trending markets, event groupings
11
+ * - Rate limits are automatically handled by the RateLimiter
12
+ *
13
+ * @example
14
+ * ```typescript
15
+ * import { GammaApiClient, RateLimiter, Cache } from '@prediction-router/poly-sdk';
16
+ *
17
+ * const client = new GammaApiClient(new RateLimiter(), new Cache());
18
+ *
19
+ * // Get trending markets by 24h volume
20
+ * const trending = await client.getTrendingMarkets(20);
21
+ *
22
+ * // Search for specific markets
23
+ * const btcMarkets = await client.getMarkets({
24
+ * active: true,
25
+ * closed: false,
26
+ * order: 'volume24hr',
27
+ * ascending: false,
28
+ * limit: 10,
29
+ * });
30
+ * ```
31
+ *
32
+ * @see {@link https://docs.polymarket.com/#gamma-api Gamma API Documentation}
33
+ *
34
+ * @module clients/gamma-api
35
+ */
36
+ import { RateLimiter } from '../core/rate-limiter.js';
37
+ import type { UnifiedCache } from '../core/unified-cache.js';
38
+ /**
39
+ * Market information from the Gamma API
40
+ *
41
+ * @remarks
42
+ * Gamma markets include rich metadata like volume statistics, price changes,
43
+ * and liquidity metrics that are useful for market discovery and analysis.
44
+ */
45
+ export interface GammaMarket {
46
+ /**
47
+ * Internal Gamma market ID
48
+ */
49
+ id: string;
50
+ /**
51
+ * Condition ID matching the CLOB API
52
+ * @example "0x82ace55cdcba920112a2b3548f21e6e117730144db4dd580456aaecf1a2ad751"
53
+ */
54
+ conditionId: string;
55
+ /**
56
+ * URL-friendly market slug
57
+ * @example "will-btc-reach-100k-by-end-of-2024"
58
+ */
59
+ slug: string;
60
+ /**
61
+ * The prediction market question
62
+ */
63
+ question: string;
64
+ /**
65
+ * Detailed description and resolution criteria
66
+ */
67
+ description?: string;
68
+ /**
69
+ * Outcome names (typically ["Yes", "No"])
70
+ */
71
+ outcomes: string[];
72
+ /**
73
+ * Current prices for each outcome (0-1 range)
74
+ * @example [0.65, 0.35] for 65% YES probability
75
+ */
76
+ outcomePrices: number[];
77
+ /**
78
+ * Total trading volume (lifetime, in USDC)
79
+ */
80
+ volume: number;
81
+ /**
82
+ * 24-hour trading volume (in USDC)
83
+ */
84
+ volume24hr?: number;
85
+ /**
86
+ * 7-day trading volume (in USDC)
87
+ */
88
+ volume1wk?: number;
89
+ /**
90
+ * Current available liquidity (in USDC)
91
+ */
92
+ liquidity: number;
93
+ /**
94
+ * Bid-ask spread (as decimal, e.g., 0.02 = 2%)
95
+ */
96
+ spread?: number;
97
+ /**
98
+ * 24-hour price change (as decimal, e.g., 0.05 = +5%)
99
+ */
100
+ oneDayPriceChange?: number;
101
+ /**
102
+ * 7-day price change (as decimal)
103
+ */
104
+ oneWeekPriceChange?: number;
105
+ /**
106
+ * Last traded price for the YES outcome
107
+ */
108
+ lastTradePrice?: number;
109
+ /**
110
+ * Best bid price for YES outcome
111
+ */
112
+ bestBid?: number;
113
+ /**
114
+ * Best ask price for YES outcome
115
+ */
116
+ bestAsk?: number;
117
+ /**
118
+ * Market end/resolution date
119
+ */
120
+ endDate: Date;
121
+ /**
122
+ * Whether the market is currently active
123
+ */
124
+ active: boolean;
125
+ /**
126
+ * Whether the market has been resolved
127
+ */
128
+ closed: boolean;
129
+ /**
130
+ * URL to market image
131
+ */
132
+ image?: string;
133
+ /**
134
+ * URL to market icon
135
+ */
136
+ icon?: string;
137
+ /**
138
+ * Category tags (e.g., ["crypto", "bitcoin", "finance"])
139
+ */
140
+ tags?: string[];
141
+ }
142
+ /**
143
+ * Event grouping from the Gamma API
144
+ *
145
+ * @remarks
146
+ * Events group related markets together. For example, a "2024 US Election"
147
+ * event might contain markets for each candidate and related predictions.
148
+ */
149
+ export interface GammaEvent {
150
+ /**
151
+ * Internal Gamma event ID
152
+ */
153
+ id: string;
154
+ /**
155
+ * URL-friendly event slug
156
+ */
157
+ slug: string;
158
+ /**
159
+ * Event title
160
+ * @example "2024 US Presidential Election"
161
+ */
162
+ title: string;
163
+ /**
164
+ * Event description
165
+ */
166
+ description?: string;
167
+ /**
168
+ * Markets belonging to this event
169
+ */
170
+ markets: GammaMarket[];
171
+ /**
172
+ * Event start date
173
+ */
174
+ startDate?: Date;
175
+ /**
176
+ * Event end date
177
+ */
178
+ endDate?: Date;
179
+ /**
180
+ * URL to event image
181
+ */
182
+ image?: string;
183
+ }
184
+ /**
185
+ * Parameters for searching/filtering markets
186
+ */
187
+ export interface MarketSearchParams {
188
+ /**
189
+ * Filter by market slug
190
+ */
191
+ slug?: string;
192
+ /**
193
+ * Filter by condition ID
194
+ */
195
+ conditionId?: string;
196
+ /**
197
+ * Filter by active status
198
+ */
199
+ active?: boolean;
200
+ /**
201
+ * Filter by closed status
202
+ */
203
+ closed?: boolean;
204
+ /**
205
+ * Maximum number of results (default: 100)
206
+ */
207
+ limit?: number;
208
+ /**
209
+ * Offset for pagination
210
+ */
211
+ offset?: number;
212
+ /**
213
+ * Sort field (e.g., "volume24hr", "liquidity", "endDate")
214
+ */
215
+ order?: string;
216
+ /**
217
+ * Sort direction (true = ascending, false = descending)
218
+ */
219
+ ascending?: boolean;
220
+ }
221
+ /**
222
+ * Gamma API client for market discovery and metadata
223
+ *
224
+ * @remarks
225
+ * Use this client for:
226
+ * - Discovering trending markets
227
+ * - Searching for specific topics
228
+ * - Getting market metadata and statistics
229
+ * - Browsing events and market groupings
230
+ *
231
+ * For orderbook data and trading, use {@link ClobApiClient} and {@link TradingClient}.
232
+ *
233
+ * @example
234
+ * ```typescript
235
+ * const client = new GammaApiClient(rateLimiter, cache);
236
+ *
237
+ * // Find top volume markets
238
+ * const trending = await client.getTrendingMarkets(20);
239
+ * for (const market of trending) {
240
+ * console.log(market.question, '$' + market.volume24hr.toLocaleString());
241
+ * }
242
+ * ```
243
+ */
244
+ export declare class GammaApiClient {
245
+ private rateLimiter;
246
+ private cache;
247
+ /**
248
+ * Creates a new Gamma API client
249
+ *
250
+ * @param rateLimiter - Rate limiter instance for API throttling
251
+ * @param cache - Cache instance for storing data (supports both legacy Cache and CacheAdapter)
252
+ */
253
+ constructor(rateLimiter: RateLimiter, cache: UnifiedCache);
254
+ /**
255
+ * Get markets with optional filters and sorting
256
+ *
257
+ * @param params - Search and filter parameters
258
+ * @returns Array of markets matching the criteria
259
+ *
260
+ * @remarks
261
+ * Common sort fields:
262
+ * - `volume24hr` - 24-hour trading volume
263
+ * - `liquidity` - Available liquidity
264
+ * - `endDate` - Market end date
265
+ * - `volume` - Lifetime volume
266
+ *
267
+ * @example
268
+ * ```typescript
269
+ * // Get active markets sorted by 24h volume
270
+ * const markets = await client.getMarkets({
271
+ * active: true,
272
+ * closed: false,
273
+ * order: 'volume24hr',
274
+ * ascending: false,
275
+ * limit: 50,
276
+ * });
277
+ *
278
+ * // Search by slug
279
+ * const market = await client.getMarkets({
280
+ * slug: 'will-btc-reach-100k',
281
+ * limit: 1,
282
+ * });
283
+ * ```
284
+ */
285
+ getMarkets(params?: MarketSearchParams): Promise<GammaMarket[]>;
286
+ /**
287
+ * Get a single market by its URL slug
288
+ *
289
+ * @param slug - The URL-friendly market slug
290
+ * @returns The market if found, null otherwise
291
+ *
292
+ * @example
293
+ * ```typescript
294
+ * const market = await client.getMarketBySlug('will-btc-reach-100k');
295
+ * if (market) {
296
+ * console.log(market.question);
297
+ * }
298
+ * ```
299
+ */
300
+ getMarketBySlug(slug: string): Promise<GammaMarket | null>;
301
+ /**
302
+ * Get a single market by condition ID
303
+ *
304
+ * @param conditionId - The unique condition identifier
305
+ * @returns The market if found, null otherwise
306
+ *
307
+ * @remarks
308
+ * For more reliable market data by condition ID, prefer {@link ClobApiClient.getMarket}.
309
+ *
310
+ * @example
311
+ * ```typescript
312
+ * const market = await client.getMarketByConditionId('0x82ace55...');
313
+ * ```
314
+ */
315
+ getMarketByConditionId(conditionId: string): Promise<GammaMarket | null>;
316
+ /**
317
+ * Get events with optional filters
318
+ *
319
+ * @param params - Filter parameters
320
+ * @param params.slug - Filter by event slug
321
+ * @param params.active - Filter by active status
322
+ * @param params.limit - Maximum results to return
323
+ * @returns Array of events matching the criteria
324
+ *
325
+ * @example
326
+ * ```typescript
327
+ * // Get all active events
328
+ * const events = await client.getEvents({ active: true, limit: 20 });
329
+ *
330
+ * // Get a specific event by slug
331
+ * const election = await client.getEvents({ slug: '2024-us-election' });
332
+ * ```
333
+ */
334
+ getEvents(params?: {
335
+ slug?: string;
336
+ active?: boolean;
337
+ limit?: number;
338
+ }): Promise<GammaEvent[]>;
339
+ /**
340
+ * Get a single event by its URL slug
341
+ *
342
+ * @param slug - The URL-friendly event slug
343
+ * @returns The event if found, null otherwise
344
+ *
345
+ * @example
346
+ * ```typescript
347
+ * const event = await client.getEventBySlug('2024-us-election');
348
+ * if (event) {
349
+ * console.log(`${event.title} has ${event.markets.length} markets`);
350
+ * }
351
+ * ```
352
+ */
353
+ getEventBySlug(slug: string): Promise<GammaEvent | null>;
354
+ /**
355
+ * Get a single event by its ID
356
+ *
357
+ * @param id - The internal event ID
358
+ * @returns The event if found, null otherwise
359
+ *
360
+ * @example
361
+ * ```typescript
362
+ * const event = await client.getEventById('12345');
363
+ * ```
364
+ */
365
+ getEventById(id: string): Promise<GammaEvent | null>;
366
+ /**
367
+ * Get trending markets sorted by 24-hour volume
368
+ *
369
+ * @param limit - Maximum number of markets to return (default: 20)
370
+ * @returns Array of active markets sorted by volume
371
+ *
372
+ * @remarks
373
+ * This is a convenience method equivalent to:
374
+ * ```typescript
375
+ * getMarkets({
376
+ * active: true,
377
+ * closed: false,
378
+ * order: 'volume24hr',
379
+ * ascending: false,
380
+ * limit,
381
+ * })
382
+ * ```
383
+ *
384
+ * @example
385
+ * ```typescript
386
+ * // Get top 10 trending markets
387
+ * const trending = await client.getTrendingMarkets(10);
388
+ *
389
+ * for (const market of trending) {
390
+ * console.log(`${market.question}`);
391
+ * console.log(` 24h Volume: $${market.volume24hr?.toLocaleString()}`);
392
+ * console.log(` YES Price: ${(market.outcomePrices[0] * 100).toFixed(1)}%`);
393
+ * }
394
+ * ```
395
+ */
396
+ getTrendingMarkets(limit?: number): Promise<GammaMarket[]>;
397
+ private normalizeMarket;
398
+ private normalizeEvent;
399
+ private parseJsonArray;
400
+ }
401
+ //# sourceMappingURL=gamma-api.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"gamma-api.d.ts","sourceRoot":"","sources":["../../src/clients/gamma-api.ts"],"names":[],"mappings":"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"}