pmxtjs 2.35.8 → 2.35.9

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 (53) hide show
  1. package/dist/esm/generated/src/apis/DefaultApi.d.ts +196 -13
  2. package/dist/esm/generated/src/apis/DefaultApi.js +292 -13
  3. package/dist/esm/generated/src/models/FetchEventMatchesParams.d.ts +13 -1
  4. package/dist/esm/generated/src/models/FetchEventMatchesParams.js +4 -0
  5. package/dist/esm/generated/src/models/FetchMarketMatchesParams.d.ts +34 -1
  6. package/dist/esm/generated/src/models/FetchMarketMatchesParams.js +16 -0
  7. package/dist/esm/generated/src/models/FetchMatchedMarkets200Response.d.ts +46 -0
  8. package/dist/esm/generated/src/models/FetchMatchedMarkets200Response.js +47 -0
  9. package/dist/esm/generated/src/models/FetchMatchedMarketsParams.d.ts +61 -0
  10. package/dist/esm/generated/src/models/FetchMatchedMarketsParams.js +57 -0
  11. package/dist/esm/generated/src/models/MatchResult.d.ts +6 -0
  12. package/dist/esm/generated/src/models/MatchResult.js +2 -0
  13. package/dist/esm/generated/src/models/MatchedMarketPair.d.ts +98 -0
  14. package/dist/esm/generated/src/models/MatchedMarketPair.js +84 -0
  15. package/dist/esm/generated/src/models/index.d.ts +3 -0
  16. package/dist/esm/generated/src/models/index.js +3 -0
  17. package/dist/esm/pmxt/client.js +20 -0
  18. package/dist/generated/src/apis/DefaultApi.d.ts +196 -13
  19. package/dist/generated/src/apis/DefaultApi.js +293 -14
  20. package/dist/generated/src/models/FetchEventMatchesParams.d.ts +13 -1
  21. package/dist/generated/src/models/FetchEventMatchesParams.js +4 -0
  22. package/dist/generated/src/models/FetchMarketMatchesParams.d.ts +34 -1
  23. package/dist/generated/src/models/FetchMarketMatchesParams.js +17 -1
  24. package/dist/generated/src/models/FetchMatchedMarkets200Response.d.ts +46 -0
  25. package/dist/generated/src/models/FetchMatchedMarkets200Response.js +54 -0
  26. package/dist/generated/src/models/FetchMatchedMarketsParams.d.ts +61 -0
  27. package/dist/generated/src/models/FetchMatchedMarketsParams.js +65 -0
  28. package/dist/generated/src/models/MatchResult.d.ts +6 -0
  29. package/dist/generated/src/models/MatchResult.js +2 -0
  30. package/dist/generated/src/models/MatchedMarketPair.d.ts +98 -0
  31. package/dist/generated/src/models/MatchedMarketPair.js +92 -0
  32. package/dist/generated/src/models/index.d.ts +3 -0
  33. package/dist/generated/src/models/index.js +3 -0
  34. package/dist/pmxt/client.js +20 -0
  35. package/generated/.openapi-generator/FILES +6 -0
  36. package/generated/docs/DefaultApi.md +307 -21
  37. package/generated/docs/FetchEventMatchesParams.md +4 -0
  38. package/generated/docs/FetchMarketMatchesParams.md +8 -0
  39. package/generated/docs/FetchMatchedMarkets200Response.md +38 -0
  40. package/generated/docs/FetchMatchedMarketsParams.md +40 -0
  41. package/generated/docs/MatchResult.md +2 -0
  42. package/generated/docs/MatchedMarketPair.md +52 -0
  43. package/generated/package.json +1 -1
  44. package/generated/src/apis/DefaultApi.ts +408 -12
  45. package/generated/src/models/FetchEventMatchesParams.ts +17 -1
  46. package/generated/src/models/FetchMarketMatchesParams.ts +43 -1
  47. package/generated/src/models/FetchMatchedMarkets200Response.ts +96 -0
  48. package/generated/src/models/FetchMatchedMarketsParams.ts +103 -0
  49. package/generated/src/models/MatchResult.ts +8 -0
  50. package/generated/src/models/MatchedMarketPair.ts +166 -0
  51. package/generated/src/models/index.ts +3 -0
  52. package/package.json +2 -2
  53. package/pmxt/client.ts +28 -0
@@ -0,0 +1,52 @@
1
+
2
+ # MatchedMarketPair
3
+
4
+
5
+ ## Properties
6
+
7
+ Name | Type
8
+ ------------ | -------------
9
+ `marketA` | [UnifiedMarket](UnifiedMarket.md)
10
+ `marketB` | [UnifiedMarket](UnifiedMarket.md)
11
+ `priceDifference` | number
12
+ `venueA` | string
13
+ `venueB` | string
14
+ `priceA` | number
15
+ `priceB` | number
16
+ `relation` | string
17
+ `confidence` | number
18
+ `reasoning` | string
19
+
20
+ ## Example
21
+
22
+ ```typescript
23
+ import type { MatchedMarketPair } from 'pmxtjs'
24
+
25
+ // TODO: Update the object below with actual values
26
+ const example = {
27
+ "marketA": null,
28
+ "marketB": null,
29
+ "priceDifference": null,
30
+ "venueA": null,
31
+ "venueB": null,
32
+ "priceA": null,
33
+ "priceB": null,
34
+ "relation": null,
35
+ "confidence": null,
36
+ "reasoning": null,
37
+ } satisfies MatchedMarketPair
38
+
39
+ console.log(example)
40
+
41
+ // Convert the instance to a JSON string
42
+ const exampleJSON: string = JSON.stringify(example)
43
+ console.log(exampleJSON)
44
+
45
+ // Parse the JSON string back to an object
46
+ const exampleParsed = JSON.parse(exampleJSON) as MatchedMarketPair
47
+ console.log(exampleParsed)
48
+ ```
49
+
50
+ [[Back to top]](#) [[Back to API list]](../README.md#api-endpoints) [[Back to Model list]](../README.md#models) [[Back to README]](../README.md)
51
+
52
+
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "pmxtjs",
3
- "version": "2.35.8",
3
+ "version": "2.35.9",
4
4
  "description": "OpenAPI client for pmxtjs",
5
5
  "author": "OpenAPI-Generator",
6
6
  "repository": {
@@ -35,6 +35,7 @@ import type {
35
35
  FetchMarketMatches200Response,
36
36
  FetchMarkets200Response,
37
37
  FetchMarketsPaginated200Response,
38
+ FetchMatchedMarkets200Response,
38
39
  FetchMyTrades200Response,
39
40
  FetchOHLCV200Response,
40
41
  FetchOpenOrders200Response,
@@ -102,6 +103,8 @@ import {
102
103
  FetchMarkets200ResponseToJSON,
103
104
  FetchMarketsPaginated200ResponseFromJSON,
104
105
  FetchMarketsPaginated200ResponseToJSON,
106
+ FetchMatchedMarkets200ResponseFromJSON,
107
+ FetchMatchedMarkets200ResponseToJSON,
105
108
  FetchMyTrades200ResponseFromJSON,
106
109
  FetchMyTrades200ResponseToJSON,
107
110
  FetchOHLCV200ResponseFromJSON,
@@ -227,6 +230,8 @@ export interface FetchEventRequest {
227
230
 
228
231
  export interface FetchEventMatchesRequest {
229
232
  exchange: FetchEventMatchesExchangeEnum;
233
+ query?: string;
234
+ category?: string;
230
235
  event?: UnifiedEvent;
231
236
  eventId?: string;
232
237
  slug?: string;
@@ -260,6 +265,8 @@ export interface FetchEventsPaginatedRequest {
260
265
 
261
266
  export interface FetchHedgesRequest {
262
267
  exchange: FetchHedgesExchangeEnum;
268
+ query?: string;
269
+ category?: string;
263
270
  market?: UnifiedMarket;
264
271
  marketId?: string;
265
272
  slug?: string;
@@ -268,6 +275,8 @@ export interface FetchHedgesRequest {
268
275
  minConfidence?: number;
269
276
  limit?: number;
270
277
  includePrices?: boolean;
278
+ minDifference?: number;
279
+ sort?: FetchHedgesSortEnum;
271
280
  }
272
281
 
273
282
  export interface FetchMarketRequest {
@@ -288,6 +297,8 @@ export interface FetchMarketRequest {
288
297
 
289
298
  export interface FetchMarketMatchesRequest {
290
299
  exchange: FetchMarketMatchesExchangeEnum;
300
+ query?: string;
301
+ category?: string;
291
302
  market?: UnifiedMarket;
292
303
  marketId?: string;
293
304
  slug?: string;
@@ -296,6 +307,8 @@ export interface FetchMarketMatchesRequest {
296
307
  minConfidence?: number;
297
308
  limit?: number;
298
309
  includePrices?: boolean;
310
+ minDifference?: number;
311
+ sort?: FetchMarketMatchesSortEnum;
299
312
  }
300
313
 
301
314
  export interface FetchMarketsRequest {
@@ -321,6 +334,22 @@ export interface FetchMarketsPaginatedRequest {
321
334
  filter?: MarketFilterCriteria;
322
335
  }
323
336
 
337
+ export interface FetchMatchedMarketsRequest {
338
+ exchange: FetchMatchedMarketsExchangeEnum;
339
+ minDifference?: number;
340
+ category?: string;
341
+ limit?: number;
342
+ relations?: Array<FetchMatchedMarketsRelationsEnum>;
343
+ }
344
+
345
+ export interface FetchMatchedPricesRequest {
346
+ exchange: FetchMatchedPricesExchangeEnum;
347
+ minDifference?: number;
348
+ category?: string;
349
+ limit?: number;
350
+ relations?: Array<FetchMatchedPricesRelationsEnum>;
351
+ }
352
+
324
353
  export interface FetchMyTradesRequest {
325
354
  exchange: FetchMyTradesExchangeEnum;
326
355
  outcomeId?: string;
@@ -360,6 +389,22 @@ export interface FetchPositionsRequest {
360
389
  address?: string;
361
390
  }
362
391
 
392
+ export interface FetchRelatedMarketsRequest {
393
+ exchange: FetchRelatedMarketsExchangeEnum;
394
+ query?: string;
395
+ category?: string;
396
+ market?: UnifiedMarket;
397
+ marketId?: string;
398
+ slug?: string;
399
+ url?: string;
400
+ relation?: FetchRelatedMarketsRelationEnum;
401
+ minConfidence?: number;
402
+ limit?: number;
403
+ includePrices?: boolean;
404
+ minDifference?: number;
405
+ sort?: FetchRelatedMarketsSortEnum;
406
+ }
407
+
363
408
  export interface FetchTradesRequest {
364
409
  exchange: FetchTradesExchangeEnum;
365
410
  id: string;
@@ -696,8 +741,8 @@ export class DefaultApi extends runtime.BaseAPI {
696
741
  }
697
742
 
698
743
  /**
699
- * Scan for arbitrage opportunities across venues. Finds identity matches where the same market is priced differently on different venues, returning opportunities sorted by spread size.
700
744
  * Find Arbitrage Opportunities
745
+ * @deprecated
701
746
  */
702
747
  async fetchArbitrageRaw(requestParameters: FetchArbitrageRequest, initOverrides?: RequestInit | runtime.InitOverrideFunction): Promise<runtime.ApiResponse<FetchArbitrage200Response>> {
703
748
  if (requestParameters['exchange'] == null) {
@@ -742,8 +787,8 @@ export class DefaultApi extends runtime.BaseAPI {
742
787
  }
743
788
 
744
789
  /**
745
- * Scan for arbitrage opportunities across venues. Finds identity matches where the same market is priced differently on different venues, returning opportunities sorted by spread size.
746
790
  * Find Arbitrage Opportunities
791
+ * @deprecated
747
792
  */
748
793
  async fetchArbitrage(requestParameters: FetchArbitrageRequest, initOverrides?: RequestInit | runtime.InitOverrideFunction): Promise<FetchArbitrage200Response> {
749
794
  const response = await this.fetchArbitrageRaw(requestParameters, initOverrides);
@@ -934,8 +979,8 @@ export class DefaultApi extends runtime.BaseAPI {
934
979
  }
935
980
 
936
981
  /**
937
- * Find the same or related event on other venues. Given an event on one venue, discover semantically equivalent events across every other venue PMXT ingests including market-level match details for each child market.
938
- * Find Similar Events
982
+ * Find the same or related event on other venues. Two modes: **Lookup mode** (eventId/slug provided): Given an event on one venue, discover semantically equivalent events across every other venue PMXT ingests. **Browse mode** (no identifier): Returns all matched event pairs from the catalog. Supports query and category params for filtering.
983
+ * Event Matches
939
984
  */
940
985
  async fetchEventMatchesRaw(requestParameters: FetchEventMatchesRequest, initOverrides?: RequestInit | runtime.InitOverrideFunction): Promise<runtime.ApiResponse<FetchEventMatches200Response>> {
941
986
  if (requestParameters['exchange'] == null) {
@@ -947,6 +992,14 @@ export class DefaultApi extends runtime.BaseAPI {
947
992
 
948
993
  const queryParameters: any = {};
949
994
 
995
+ if (requestParameters['query'] != null) {
996
+ queryParameters['query'] = requestParameters['query'];
997
+ }
998
+
999
+ if (requestParameters['category'] != null) {
1000
+ queryParameters['category'] = requestParameters['category'];
1001
+ }
1002
+
950
1003
  if (requestParameters['event'] != null) {
951
1004
  queryParameters['event'] = requestParameters['event'];
952
1005
  }
@@ -992,8 +1045,8 @@ export class DefaultApi extends runtime.BaseAPI {
992
1045
  }
993
1046
 
994
1047
  /**
995
- * Find the same or related event on other venues. Given an event on one venue, discover semantically equivalent events across every other venue PMXT ingests including market-level match details for each child market.
996
- * Find Similar Events
1048
+ * Find the same or related event on other venues. Two modes: **Lookup mode** (eventId/slug provided): Given an event on one venue, discover semantically equivalent events across every other venue PMXT ingests. **Browse mode** (no identifier): Returns all matched event pairs from the catalog. Supports query and category params for filtering.
1049
+ * Event Matches
997
1050
  */
998
1051
  async fetchEventMatches(requestParameters: FetchEventMatchesRequest, initOverrides?: RequestInit | runtime.InitOverrideFunction): Promise<FetchEventMatches200Response> {
999
1052
  const response = await this.fetchEventMatchesRaw(requestParameters, initOverrides);
@@ -1135,8 +1188,8 @@ export class DefaultApi extends runtime.BaseAPI {
1135
1188
  }
1136
1189
 
1137
1190
  /**
1138
- * Find hedging opportunities across venues. Discovers subset/superset market relationships where one market\'s outcome implies another, enabling cross-venue hedging strategies with live prices.
1139
1191
  * Find Hedging Opportunities
1192
+ * @deprecated
1140
1193
  */
1141
1194
  async fetchHedgesRaw(requestParameters: FetchHedgesRequest, initOverrides?: RequestInit | runtime.InitOverrideFunction): Promise<runtime.ApiResponse<CompareMarketPrices200Response>> {
1142
1195
  if (requestParameters['exchange'] == null) {
@@ -1148,6 +1201,14 @@ export class DefaultApi extends runtime.BaseAPI {
1148
1201
 
1149
1202
  const queryParameters: any = {};
1150
1203
 
1204
+ if (requestParameters['query'] != null) {
1205
+ queryParameters['query'] = requestParameters['query'];
1206
+ }
1207
+
1208
+ if (requestParameters['category'] != null) {
1209
+ queryParameters['category'] = requestParameters['category'];
1210
+ }
1211
+
1151
1212
  if (requestParameters['market'] != null) {
1152
1213
  queryParameters['market'] = requestParameters['market'];
1153
1214
  }
@@ -1180,6 +1241,14 @@ export class DefaultApi extends runtime.BaseAPI {
1180
1241
  queryParameters['includePrices'] = requestParameters['includePrices'];
1181
1242
  }
1182
1243
 
1244
+ if (requestParameters['minDifference'] != null) {
1245
+ queryParameters['minDifference'] = requestParameters['minDifference'];
1246
+ }
1247
+
1248
+ if (requestParameters['sort'] != null) {
1249
+ queryParameters['sort'] = requestParameters['sort'];
1250
+ }
1251
+
1183
1252
  const headerParameters: runtime.HTTPHeaders = {};
1184
1253
 
1185
1254
 
@@ -1197,8 +1266,8 @@ export class DefaultApi extends runtime.BaseAPI {
1197
1266
  }
1198
1267
 
1199
1268
  /**
1200
- * Find hedging opportunities across venues. Discovers subset/superset market relationships where one market\'s outcome implies another, enabling cross-venue hedging strategies with live prices.
1201
1269
  * Find Hedging Opportunities
1270
+ * @deprecated
1202
1271
  */
1203
1272
  async fetchHedges(requestParameters: FetchHedgesRequest, initOverrides?: RequestInit | runtime.InitOverrideFunction): Promise<CompareMarketPrices200Response> {
1204
1273
  const response = await this.fetchHedgesRaw(requestParameters, initOverrides);
@@ -1293,8 +1362,8 @@ export class DefaultApi extends runtime.BaseAPI {
1293
1362
  }
1294
1363
 
1295
1364
  /**
1296
- * Find the same or related market on other venues. Given a market on one venue, discover semantically equivalent markets across every other venue PMXT ingests each with a relation type (identity, subset, superset, overlap, disjoint), confidence score, and reasoning.
1297
- * Find Similar Markets
1365
+ * Find the same or related market on other venues. Two modes: **Lookup mode** (marketId/slug/url provided): Given a market on one venue, discover semantically equivalent markets across every other venue PMXT ingests. **Browse mode** (no identifier): Returns all matched market pairs from the catalog. Supports query, category, minDifference, and sort params for filtering.
1366
+ * Market Matches
1298
1367
  */
1299
1368
  async fetchMarketMatchesRaw(requestParameters: FetchMarketMatchesRequest, initOverrides?: RequestInit | runtime.InitOverrideFunction): Promise<runtime.ApiResponse<FetchMarketMatches200Response>> {
1300
1369
  if (requestParameters['exchange'] == null) {
@@ -1306,6 +1375,14 @@ export class DefaultApi extends runtime.BaseAPI {
1306
1375
 
1307
1376
  const queryParameters: any = {};
1308
1377
 
1378
+ if (requestParameters['query'] != null) {
1379
+ queryParameters['query'] = requestParameters['query'];
1380
+ }
1381
+
1382
+ if (requestParameters['category'] != null) {
1383
+ queryParameters['category'] = requestParameters['category'];
1384
+ }
1385
+
1309
1386
  if (requestParameters['market'] != null) {
1310
1387
  queryParameters['market'] = requestParameters['market'];
1311
1388
  }
@@ -1338,6 +1415,14 @@ export class DefaultApi extends runtime.BaseAPI {
1338
1415
  queryParameters['includePrices'] = requestParameters['includePrices'];
1339
1416
  }
1340
1417
 
1418
+ if (requestParameters['minDifference'] != null) {
1419
+ queryParameters['minDifference'] = requestParameters['minDifference'];
1420
+ }
1421
+
1422
+ if (requestParameters['sort'] != null) {
1423
+ queryParameters['sort'] = requestParameters['sort'];
1424
+ }
1425
+
1341
1426
  const headerParameters: runtime.HTTPHeaders = {};
1342
1427
 
1343
1428
 
@@ -1355,8 +1440,8 @@ export class DefaultApi extends runtime.BaseAPI {
1355
1440
  }
1356
1441
 
1357
1442
  /**
1358
- * Find the same or related market on other venues. Given a market on one venue, discover semantically equivalent markets across every other venue PMXT ingests each with a relation type (identity, subset, superset, overlap, disjoint), confidence score, and reasoning.
1359
- * Find Similar Markets
1443
+ * Find the same or related market on other venues. Two modes: **Lookup mode** (marketId/slug/url provided): Given a market on one venue, discover semantically equivalent markets across every other venue PMXT ingests. **Browse mode** (no identifier): Returns all matched market pairs from the catalog. Supports query, category, minDifference, and sort params for filtering.
1444
+ * Market Matches
1360
1445
  */
1361
1446
  async fetchMarketMatches(requestParameters: FetchMarketMatchesRequest, initOverrides?: RequestInit | runtime.InitOverrideFunction): Promise<FetchMarketMatches200Response> {
1362
1447
  const response = await this.fetchMarketMatchesRaw(requestParameters, initOverrides);
@@ -1501,6 +1586,116 @@ export class DefaultApi extends runtime.BaseAPI {
1501
1586
  return await response.value();
1502
1587
  }
1503
1588
 
1589
+ /**
1590
+ * Matched Markets
1591
+ * @deprecated
1592
+ */
1593
+ async fetchMatchedMarketsRaw(requestParameters: FetchMatchedMarketsRequest, initOverrides?: RequestInit | runtime.InitOverrideFunction): Promise<runtime.ApiResponse<FetchMatchedMarkets200Response>> {
1594
+ if (requestParameters['exchange'] == null) {
1595
+ throw new runtime.RequiredError(
1596
+ 'exchange',
1597
+ 'Required parameter "exchange" was null or undefined when calling fetchMatchedMarkets().'
1598
+ );
1599
+ }
1600
+
1601
+ const queryParameters: any = {};
1602
+
1603
+ if (requestParameters['minDifference'] != null) {
1604
+ queryParameters['minDifference'] = requestParameters['minDifference'];
1605
+ }
1606
+
1607
+ if (requestParameters['category'] != null) {
1608
+ queryParameters['category'] = requestParameters['category'];
1609
+ }
1610
+
1611
+ if (requestParameters['limit'] != null) {
1612
+ queryParameters['limit'] = requestParameters['limit'];
1613
+ }
1614
+
1615
+ if (requestParameters['relations'] != null) {
1616
+ queryParameters['relations'] = requestParameters['relations'];
1617
+ }
1618
+
1619
+ const headerParameters: runtime.HTTPHeaders = {};
1620
+
1621
+
1622
+ let urlPath = `/api/{exchange}/fetchMatchedMarkets`;
1623
+ urlPath = urlPath.replace(`{${"exchange"}}`, encodeURIComponent(String(requestParameters['exchange'])));
1624
+
1625
+ const response = await this.request({
1626
+ path: urlPath,
1627
+ method: 'GET',
1628
+ headers: headerParameters,
1629
+ query: queryParameters,
1630
+ }, initOverrides);
1631
+
1632
+ return new runtime.JSONApiResponse(response, (jsonValue) => FetchMatchedMarkets200ResponseFromJSON(jsonValue));
1633
+ }
1634
+
1635
+ /**
1636
+ * Matched Markets
1637
+ * @deprecated
1638
+ */
1639
+ async fetchMatchedMarkets(requestParameters: FetchMatchedMarketsRequest, initOverrides?: RequestInit | runtime.InitOverrideFunction): Promise<FetchMatchedMarkets200Response> {
1640
+ const response = await this.fetchMatchedMarketsRaw(requestParameters, initOverrides);
1641
+ return await response.value();
1642
+ }
1643
+
1644
+ /**
1645
+ * Compare Matched Market Prices
1646
+ * @deprecated
1647
+ */
1648
+ async fetchMatchedPricesRaw(requestParameters: FetchMatchedPricesRequest, initOverrides?: RequestInit | runtime.InitOverrideFunction): Promise<runtime.ApiResponse<FetchMatchedMarkets200Response>> {
1649
+ if (requestParameters['exchange'] == null) {
1650
+ throw new runtime.RequiredError(
1651
+ 'exchange',
1652
+ 'Required parameter "exchange" was null or undefined when calling fetchMatchedPrices().'
1653
+ );
1654
+ }
1655
+
1656
+ const queryParameters: any = {};
1657
+
1658
+ if (requestParameters['minDifference'] != null) {
1659
+ queryParameters['minDifference'] = requestParameters['minDifference'];
1660
+ }
1661
+
1662
+ if (requestParameters['category'] != null) {
1663
+ queryParameters['category'] = requestParameters['category'];
1664
+ }
1665
+
1666
+ if (requestParameters['limit'] != null) {
1667
+ queryParameters['limit'] = requestParameters['limit'];
1668
+ }
1669
+
1670
+ if (requestParameters['relations'] != null) {
1671
+ queryParameters['relations'] = requestParameters['relations'];
1672
+ }
1673
+
1674
+ const headerParameters: runtime.HTTPHeaders = {};
1675
+
1676
+
1677
+ let urlPath = `/api/{exchange}/fetchMatchedPrices`;
1678
+ urlPath = urlPath.replace(`{${"exchange"}}`, encodeURIComponent(String(requestParameters['exchange'])));
1679
+
1680
+ const response = await this.request({
1681
+ path: urlPath,
1682
+ method: 'GET',
1683
+ headers: headerParameters,
1684
+ query: queryParameters,
1685
+ }, initOverrides);
1686
+
1687
+ return new runtime.JSONApiResponse(response, (jsonValue) => FetchMatchedMarkets200ResponseFromJSON(jsonValue));
1688
+ }
1689
+
1690
+ /**
1691
+ * Compare Matched Market Prices
1692
+ * @deprecated
1693
+ */
1694
+ async fetchMatchedPrices(requestParameters: FetchMatchedPricesRequest, initOverrides?: RequestInit | runtime.InitOverrideFunction): Promise<FetchMatchedMarkets200Response> {
1695
+ const response = await this.fetchMatchedPricesRaw(requestParameters, initOverrides);
1696
+ return await response.value();
1697
+ }
1698
+
1504
1699
  /**
1505
1700
  * Fetch My Trades
1506
1701
  */
@@ -1814,6 +2009,93 @@ export class DefaultApi extends runtime.BaseAPI {
1814
2009
  return await response.value();
1815
2010
  }
1816
2011
 
2012
+ /**
2013
+ * Find related markets across venues. Discovers subset/superset market relationships where one market\'s outcome implies another, with live prices.
2014
+ * Find Related Markets
2015
+ */
2016
+ async fetchRelatedMarketsRaw(requestParameters: FetchRelatedMarketsRequest, initOverrides?: RequestInit | runtime.InitOverrideFunction): Promise<runtime.ApiResponse<CompareMarketPrices200Response>> {
2017
+ if (requestParameters['exchange'] == null) {
2018
+ throw new runtime.RequiredError(
2019
+ 'exchange',
2020
+ 'Required parameter "exchange" was null or undefined when calling fetchRelatedMarkets().'
2021
+ );
2022
+ }
2023
+
2024
+ const queryParameters: any = {};
2025
+
2026
+ if (requestParameters['query'] != null) {
2027
+ queryParameters['query'] = requestParameters['query'];
2028
+ }
2029
+
2030
+ if (requestParameters['category'] != null) {
2031
+ queryParameters['category'] = requestParameters['category'];
2032
+ }
2033
+
2034
+ if (requestParameters['market'] != null) {
2035
+ queryParameters['market'] = requestParameters['market'];
2036
+ }
2037
+
2038
+ if (requestParameters['marketId'] != null) {
2039
+ queryParameters['marketId'] = requestParameters['marketId'];
2040
+ }
2041
+
2042
+ if (requestParameters['slug'] != null) {
2043
+ queryParameters['slug'] = requestParameters['slug'];
2044
+ }
2045
+
2046
+ if (requestParameters['url'] != null) {
2047
+ queryParameters['url'] = requestParameters['url'];
2048
+ }
2049
+
2050
+ if (requestParameters['relation'] != null) {
2051
+ queryParameters['relation'] = requestParameters['relation'];
2052
+ }
2053
+
2054
+ if (requestParameters['minConfidence'] != null) {
2055
+ queryParameters['minConfidence'] = requestParameters['minConfidence'];
2056
+ }
2057
+
2058
+ if (requestParameters['limit'] != null) {
2059
+ queryParameters['limit'] = requestParameters['limit'];
2060
+ }
2061
+
2062
+ if (requestParameters['includePrices'] != null) {
2063
+ queryParameters['includePrices'] = requestParameters['includePrices'];
2064
+ }
2065
+
2066
+ if (requestParameters['minDifference'] != null) {
2067
+ queryParameters['minDifference'] = requestParameters['minDifference'];
2068
+ }
2069
+
2070
+ if (requestParameters['sort'] != null) {
2071
+ queryParameters['sort'] = requestParameters['sort'];
2072
+ }
2073
+
2074
+ const headerParameters: runtime.HTTPHeaders = {};
2075
+
2076
+
2077
+ let urlPath = `/api/{exchange}/fetchRelatedMarkets`;
2078
+ urlPath = urlPath.replace(`{${"exchange"}}`, encodeURIComponent(String(requestParameters['exchange'])));
2079
+
2080
+ const response = await this.request({
2081
+ path: urlPath,
2082
+ method: 'GET',
2083
+ headers: headerParameters,
2084
+ query: queryParameters,
2085
+ }, initOverrides);
2086
+
2087
+ return new runtime.JSONApiResponse(response, (jsonValue) => CompareMarketPrices200ResponseFromJSON(jsonValue));
2088
+ }
2089
+
2090
+ /**
2091
+ * Find related markets across venues. Discovers subset/superset market relationships where one market\'s outcome implies another, with live prices.
2092
+ * Find Related Markets
2093
+ */
2094
+ async fetchRelatedMarkets(requestParameters: FetchRelatedMarketsRequest, initOverrides?: RequestInit | runtime.InitOverrideFunction): Promise<CompareMarketPrices200Response> {
2095
+ const response = await this.fetchRelatedMarketsRaw(requestParameters, initOverrides);
2096
+ return await response.value();
2097
+ }
2098
+
1817
2099
  /**
1818
2100
  * Fetch raw trade history for a specific outcome.
1819
2101
  * Fetch Trades
@@ -2710,6 +2992,15 @@ export const FetchHedgesRelationEnum = {
2710
2992
  Disjoint: 'disjoint'
2711
2993
  } as const;
2712
2994
  export type FetchHedgesRelationEnum = typeof FetchHedgesRelationEnum[keyof typeof FetchHedgesRelationEnum];
2995
+ /**
2996
+ * @export
2997
+ */
2998
+ export const FetchHedgesSortEnum = {
2999
+ Confidence: 'confidence',
3000
+ Volume: 'volume',
3001
+ PriceDifference: 'priceDifference'
3002
+ } as const;
3003
+ export type FetchHedgesSortEnum = typeof FetchHedgesSortEnum[keyof typeof FetchHedgesSortEnum];
2713
3004
  /**
2714
3005
  * @export
2715
3006
  */
@@ -2785,6 +3076,15 @@ export const FetchMarketMatchesRelationEnum = {
2785
3076
  Disjoint: 'disjoint'
2786
3077
  } as const;
2787
3078
  export type FetchMarketMatchesRelationEnum = typeof FetchMarketMatchesRelationEnum[keyof typeof FetchMarketMatchesRelationEnum];
3079
+ /**
3080
+ * @export
3081
+ */
3082
+ export const FetchMarketMatchesSortEnum = {
3083
+ Confidence: 'confidence',
3084
+ Volume: 'volume',
3085
+ PriceDifference: 'priceDifference'
3086
+ } as const;
3087
+ export type FetchMarketMatchesSortEnum = typeof FetchMarketMatchesSortEnum[keyof typeof FetchMarketMatchesSortEnum];
2788
3088
  /**
2789
3089
  * @export
2790
3090
  */
@@ -2849,6 +3149,64 @@ export const FetchMarketsPaginatedExchangeEnum = {
2849
3149
  Router: 'router'
2850
3150
  } as const;
2851
3151
  export type FetchMarketsPaginatedExchangeEnum = typeof FetchMarketsPaginatedExchangeEnum[keyof typeof FetchMarketsPaginatedExchangeEnum];
3152
+ /**
3153
+ * @export
3154
+ */
3155
+ export const FetchMatchedMarketsExchangeEnum = {
3156
+ Polymarket: 'polymarket',
3157
+ Kalshi: 'kalshi',
3158
+ KalshiDemo: 'kalshi-demo',
3159
+ Limitless: 'limitless',
3160
+ Probable: 'probable',
3161
+ Baozi: 'baozi',
3162
+ Myriad: 'myriad',
3163
+ Opinion: 'opinion',
3164
+ Metaculus: 'metaculus',
3165
+ Smarkets: 'smarkets',
3166
+ PolymarketUs: 'polymarket_us',
3167
+ Router: 'router'
3168
+ } as const;
3169
+ export type FetchMatchedMarketsExchangeEnum = typeof FetchMatchedMarketsExchangeEnum[keyof typeof FetchMatchedMarketsExchangeEnum];
3170
+ /**
3171
+ * @export
3172
+ */
3173
+ export const FetchMatchedMarketsRelationsEnum = {
3174
+ Identity: 'identity',
3175
+ Subset: 'subset',
3176
+ Superset: 'superset',
3177
+ Overlap: 'overlap',
3178
+ Disjoint: 'disjoint'
3179
+ } as const;
3180
+ export type FetchMatchedMarketsRelationsEnum = typeof FetchMatchedMarketsRelationsEnum[keyof typeof FetchMatchedMarketsRelationsEnum];
3181
+ /**
3182
+ * @export
3183
+ */
3184
+ export const FetchMatchedPricesExchangeEnum = {
3185
+ Polymarket: 'polymarket',
3186
+ Kalshi: 'kalshi',
3187
+ KalshiDemo: 'kalshi-demo',
3188
+ Limitless: 'limitless',
3189
+ Probable: 'probable',
3190
+ Baozi: 'baozi',
3191
+ Myriad: 'myriad',
3192
+ Opinion: 'opinion',
3193
+ Metaculus: 'metaculus',
3194
+ Smarkets: 'smarkets',
3195
+ PolymarketUs: 'polymarket_us',
3196
+ Router: 'router'
3197
+ } as const;
3198
+ export type FetchMatchedPricesExchangeEnum = typeof FetchMatchedPricesExchangeEnum[keyof typeof FetchMatchedPricesExchangeEnum];
3199
+ /**
3200
+ * @export
3201
+ */
3202
+ export const FetchMatchedPricesRelationsEnum = {
3203
+ Identity: 'identity',
3204
+ Subset: 'subset',
3205
+ Superset: 'superset',
3206
+ Overlap: 'overlap',
3207
+ Disjoint: 'disjoint'
3208
+ } as const;
3209
+ export type FetchMatchedPricesRelationsEnum = typeof FetchMatchedPricesRelationsEnum[keyof typeof FetchMatchedPricesRelationsEnum];
2852
3210
  /**
2853
3211
  * @export
2854
3212
  */
@@ -2969,6 +3327,44 @@ export const FetchPositionsExchangeEnum = {
2969
3327
  Router: 'router'
2970
3328
  } as const;
2971
3329
  export type FetchPositionsExchangeEnum = typeof FetchPositionsExchangeEnum[keyof typeof FetchPositionsExchangeEnum];
3330
+ /**
3331
+ * @export
3332
+ */
3333
+ export const FetchRelatedMarketsExchangeEnum = {
3334
+ Polymarket: 'polymarket',
3335
+ Kalshi: 'kalshi',
3336
+ KalshiDemo: 'kalshi-demo',
3337
+ Limitless: 'limitless',
3338
+ Probable: 'probable',
3339
+ Baozi: 'baozi',
3340
+ Myriad: 'myriad',
3341
+ Opinion: 'opinion',
3342
+ Metaculus: 'metaculus',
3343
+ Smarkets: 'smarkets',
3344
+ PolymarketUs: 'polymarket_us',
3345
+ Router: 'router'
3346
+ } as const;
3347
+ export type FetchRelatedMarketsExchangeEnum = typeof FetchRelatedMarketsExchangeEnum[keyof typeof FetchRelatedMarketsExchangeEnum];
3348
+ /**
3349
+ * @export
3350
+ */
3351
+ export const FetchRelatedMarketsRelationEnum = {
3352
+ Identity: 'identity',
3353
+ Subset: 'subset',
3354
+ Superset: 'superset',
3355
+ Overlap: 'overlap',
3356
+ Disjoint: 'disjoint'
3357
+ } as const;
3358
+ export type FetchRelatedMarketsRelationEnum = typeof FetchRelatedMarketsRelationEnum[keyof typeof FetchRelatedMarketsRelationEnum];
3359
+ /**
3360
+ * @export
3361
+ */
3362
+ export const FetchRelatedMarketsSortEnum = {
3363
+ Confidence: 'confidence',
3364
+ Volume: 'volume',
3365
+ PriceDifference: 'priceDifference'
3366
+ } as const;
3367
+ export type FetchRelatedMarketsSortEnum = typeof FetchRelatedMarketsSortEnum[keyof typeof FetchRelatedMarketsSortEnum];
2972
3368
  /**
2973
3369
  * @export
2974
3370
  */