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
@@ -12,7 +12,7 @@
12
12
  * Do not edit the class manually.
13
13
  */
14
14
  import * as runtime from '../runtime.js';
15
- import { BaseResponseFromJSON, BuildOrder200ResponseFromJSON, BuildOrderRequestToJSON, CancelOrderRequestToJSON, CloseRequestToJSON, CompareMarketPrices200ResponseFromJSON, CompareMarketPricesRequestToJSON, CreateOrder200ResponseFromJSON, CreateOrderRequestToJSON, FetchArbitrage200ResponseFromJSON, FetchBalance200ResponseFromJSON, FetchEvent200ResponseFromJSON, FetchEventMatches200ResponseFromJSON, FetchEvents200ResponseFromJSON, FetchEventsPaginated200ResponseFromJSON, FetchMarket200ResponseFromJSON, FetchMarketMatches200ResponseFromJSON, FetchMarkets200ResponseFromJSON, FetchMarketsPaginated200ResponseFromJSON, FetchMyTrades200ResponseFromJSON, FetchOHLCV200ResponseFromJSON, FetchOpenOrders200ResponseFromJSON, FetchOrderBook200ResponseFromJSON, FetchPositions200ResponseFromJSON, FetchTrades200ResponseFromJSON, FilterEventsRequestToJSON, FilterMarketsRequestToJSON, GetExecutionPrice200ResponseFromJSON, GetExecutionPriceDetailed200ResponseFromJSON, GetExecutionPriceDetailedRequestToJSON, GetExecutionPriceRequestToJSON, HealthCheck200ResponseFromJSON, LoadMarkets200ResponseFromJSON, LoadMarketsRequestToJSON, SubmitOrderRequestToJSON, UnwatchAddressRequestToJSON, UnwatchOrderBookRequestToJSON, WatchAddress200ResponseFromJSON, WatchAddressRequestToJSON, WatchOrderBookRequestToJSON, WatchTradesRequestToJSON, } from '../models/index.js';
15
+ import { BaseResponseFromJSON, BuildOrder200ResponseFromJSON, BuildOrderRequestToJSON, CancelOrderRequestToJSON, CloseRequestToJSON, CompareMarketPrices200ResponseFromJSON, CompareMarketPricesRequestToJSON, CreateOrder200ResponseFromJSON, CreateOrderRequestToJSON, FetchArbitrage200ResponseFromJSON, FetchBalance200ResponseFromJSON, FetchEvent200ResponseFromJSON, FetchEventMatches200ResponseFromJSON, FetchEvents200ResponseFromJSON, FetchEventsPaginated200ResponseFromJSON, FetchMarket200ResponseFromJSON, FetchMarketMatches200ResponseFromJSON, FetchMarkets200ResponseFromJSON, FetchMarketsPaginated200ResponseFromJSON, FetchMatchedMarkets200ResponseFromJSON, FetchMyTrades200ResponseFromJSON, FetchOHLCV200ResponseFromJSON, FetchOpenOrders200ResponseFromJSON, FetchOrderBook200ResponseFromJSON, FetchPositions200ResponseFromJSON, FetchTrades200ResponseFromJSON, FilterEventsRequestToJSON, FilterMarketsRequestToJSON, GetExecutionPrice200ResponseFromJSON, GetExecutionPriceDetailed200ResponseFromJSON, GetExecutionPriceDetailedRequestToJSON, GetExecutionPriceRequestToJSON, HealthCheck200ResponseFromJSON, LoadMarkets200ResponseFromJSON, LoadMarketsRequestToJSON, SubmitOrderRequestToJSON, UnwatchAddressRequestToJSON, UnwatchOrderBookRequestToJSON, WatchAddress200ResponseFromJSON, WatchAddressRequestToJSON, WatchOrderBookRequestToJSON, WatchTradesRequestToJSON, } from '../models/index.js';
16
16
  /**
17
17
  *
18
18
  */
@@ -209,8 +209,8 @@ export class DefaultApi extends runtime.BaseAPI {
209
209
  return await response.value();
210
210
  }
211
211
  /**
212
- * 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.
213
212
  * Find Arbitrage Opportunities
213
+ * @deprecated
214
214
  */
215
215
  async fetchArbitrageRaw(requestParameters, initOverrides) {
216
216
  if (requestParameters['exchange'] == null) {
@@ -241,8 +241,8 @@ export class DefaultApi extends runtime.BaseAPI {
241
241
  return new runtime.JSONApiResponse(response, (jsonValue) => FetchArbitrage200ResponseFromJSON(jsonValue));
242
242
  }
243
243
  /**
244
- * 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.
245
244
  * Find Arbitrage Opportunities
245
+ * @deprecated
246
246
  */
247
247
  async fetchArbitrage(requestParameters, initOverrides) {
248
248
  const response = await this.fetchArbitrageRaw(requestParameters, initOverrides);
@@ -382,14 +382,20 @@ export class DefaultApi extends runtime.BaseAPI {
382
382
  return await response.value();
383
383
  }
384
384
  /**
385
- * 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.
386
- * Find Similar Events
385
+ * 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.
386
+ * Event Matches
387
387
  */
388
388
  async fetchEventMatchesRaw(requestParameters, initOverrides) {
389
389
  if (requestParameters['exchange'] == null) {
390
390
  throw new runtime.RequiredError('exchange', 'Required parameter "exchange" was null or undefined when calling fetchEventMatches().');
391
391
  }
392
392
  const queryParameters = {};
393
+ if (requestParameters['query'] != null) {
394
+ queryParameters['query'] = requestParameters['query'];
395
+ }
396
+ if (requestParameters['category'] != null) {
397
+ queryParameters['category'] = requestParameters['category'];
398
+ }
393
399
  if (requestParameters['event'] != null) {
394
400
  queryParameters['event'] = requestParameters['event'];
395
401
  }
@@ -423,8 +429,8 @@ export class DefaultApi extends runtime.BaseAPI {
423
429
  return new runtime.JSONApiResponse(response, (jsonValue) => FetchEventMatches200ResponseFromJSON(jsonValue));
424
430
  }
425
431
  /**
426
- * 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.
427
- * Find Similar Events
432
+ * 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.
433
+ * Event Matches
428
434
  */
429
435
  async fetchEventMatches(requestParameters, initOverrides) {
430
436
  const response = await this.fetchEventMatchesRaw(requestParameters, initOverrides);
@@ -529,14 +535,20 @@ export class DefaultApi extends runtime.BaseAPI {
529
535
  return await response.value();
530
536
  }
531
537
  /**
532
- * 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.
533
538
  * Find Hedging Opportunities
539
+ * @deprecated
534
540
  */
535
541
  async fetchHedgesRaw(requestParameters, initOverrides) {
536
542
  if (requestParameters['exchange'] == null) {
537
543
  throw new runtime.RequiredError('exchange', 'Required parameter "exchange" was null or undefined when calling fetchHedges().');
538
544
  }
539
545
  const queryParameters = {};
546
+ if (requestParameters['query'] != null) {
547
+ queryParameters['query'] = requestParameters['query'];
548
+ }
549
+ if (requestParameters['category'] != null) {
550
+ queryParameters['category'] = requestParameters['category'];
551
+ }
540
552
  if (requestParameters['market'] != null) {
541
553
  queryParameters['market'] = requestParameters['market'];
542
554
  }
@@ -561,6 +573,12 @@ export class DefaultApi extends runtime.BaseAPI {
561
573
  if (requestParameters['includePrices'] != null) {
562
574
  queryParameters['includePrices'] = requestParameters['includePrices'];
563
575
  }
576
+ if (requestParameters['minDifference'] != null) {
577
+ queryParameters['minDifference'] = requestParameters['minDifference'];
578
+ }
579
+ if (requestParameters['sort'] != null) {
580
+ queryParameters['sort'] = requestParameters['sort'];
581
+ }
564
582
  const headerParameters = {};
565
583
  let urlPath = `/api/{exchange}/fetchHedges`;
566
584
  urlPath = urlPath.replace(`{${"exchange"}}`, encodeURIComponent(String(requestParameters['exchange'])));
@@ -573,8 +591,8 @@ export class DefaultApi extends runtime.BaseAPI {
573
591
  return new runtime.JSONApiResponse(response, (jsonValue) => CompareMarketPrices200ResponseFromJSON(jsonValue));
574
592
  }
575
593
  /**
576
- * 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.
577
594
  * Find Hedging Opportunities
595
+ * @deprecated
578
596
  */
579
597
  async fetchHedges(requestParameters, initOverrides) {
580
598
  const response = await this.fetchHedgesRaw(requestParameters, initOverrides);
@@ -645,14 +663,20 @@ export class DefaultApi extends runtime.BaseAPI {
645
663
  return await response.value();
646
664
  }
647
665
  /**
648
- * 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.
649
- * Find Similar Markets
666
+ * 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.
667
+ * Market Matches
650
668
  */
651
669
  async fetchMarketMatchesRaw(requestParameters, initOverrides) {
652
670
  if (requestParameters['exchange'] == null) {
653
671
  throw new runtime.RequiredError('exchange', 'Required parameter "exchange" was null or undefined when calling fetchMarketMatches().');
654
672
  }
655
673
  const queryParameters = {};
674
+ if (requestParameters['query'] != null) {
675
+ queryParameters['query'] = requestParameters['query'];
676
+ }
677
+ if (requestParameters['category'] != null) {
678
+ queryParameters['category'] = requestParameters['category'];
679
+ }
656
680
  if (requestParameters['market'] != null) {
657
681
  queryParameters['market'] = requestParameters['market'];
658
682
  }
@@ -677,6 +701,12 @@ export class DefaultApi extends runtime.BaseAPI {
677
701
  if (requestParameters['includePrices'] != null) {
678
702
  queryParameters['includePrices'] = requestParameters['includePrices'];
679
703
  }
704
+ if (requestParameters['minDifference'] != null) {
705
+ queryParameters['minDifference'] = requestParameters['minDifference'];
706
+ }
707
+ if (requestParameters['sort'] != null) {
708
+ queryParameters['sort'] = requestParameters['sort'];
709
+ }
680
710
  const headerParameters = {};
681
711
  let urlPath = `/api/{exchange}/fetchMarketMatches`;
682
712
  urlPath = urlPath.replace(`{${"exchange"}}`, encodeURIComponent(String(requestParameters['exchange'])));
@@ -689,8 +719,8 @@ export class DefaultApi extends runtime.BaseAPI {
689
719
  return new runtime.JSONApiResponse(response, (jsonValue) => FetchMarketMatches200ResponseFromJSON(jsonValue));
690
720
  }
691
721
  /**
692
- * 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.
693
- * Find Similar Markets
722
+ * 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.
723
+ * Market Matches
694
724
  */
695
725
  async fetchMarketMatches(requestParameters, initOverrides) {
696
726
  const response = await this.fetchMarketMatchesRaw(requestParameters, initOverrides);
@@ -797,6 +827,86 @@ export class DefaultApi extends runtime.BaseAPI {
797
827
  const response = await this.fetchMarketsPaginatedRaw(requestParameters, initOverrides);
798
828
  return await response.value();
799
829
  }
830
+ /**
831
+ * Matched Markets
832
+ * @deprecated
833
+ */
834
+ async fetchMatchedMarketsRaw(requestParameters, initOverrides) {
835
+ if (requestParameters['exchange'] == null) {
836
+ throw new runtime.RequiredError('exchange', 'Required parameter "exchange" was null or undefined when calling fetchMatchedMarkets().');
837
+ }
838
+ const queryParameters = {};
839
+ if (requestParameters['minDifference'] != null) {
840
+ queryParameters['minDifference'] = requestParameters['minDifference'];
841
+ }
842
+ if (requestParameters['category'] != null) {
843
+ queryParameters['category'] = requestParameters['category'];
844
+ }
845
+ if (requestParameters['limit'] != null) {
846
+ queryParameters['limit'] = requestParameters['limit'];
847
+ }
848
+ if (requestParameters['relations'] != null) {
849
+ queryParameters['relations'] = requestParameters['relations'];
850
+ }
851
+ const headerParameters = {};
852
+ let urlPath = `/api/{exchange}/fetchMatchedMarkets`;
853
+ urlPath = urlPath.replace(`{${"exchange"}}`, encodeURIComponent(String(requestParameters['exchange'])));
854
+ const response = await this.request({
855
+ path: urlPath,
856
+ method: 'GET',
857
+ headers: headerParameters,
858
+ query: queryParameters,
859
+ }, initOverrides);
860
+ return new runtime.JSONApiResponse(response, (jsonValue) => FetchMatchedMarkets200ResponseFromJSON(jsonValue));
861
+ }
862
+ /**
863
+ * Matched Markets
864
+ * @deprecated
865
+ */
866
+ async fetchMatchedMarkets(requestParameters, initOverrides) {
867
+ const response = await this.fetchMatchedMarketsRaw(requestParameters, initOverrides);
868
+ return await response.value();
869
+ }
870
+ /**
871
+ * Compare Matched Market Prices
872
+ * @deprecated
873
+ */
874
+ async fetchMatchedPricesRaw(requestParameters, initOverrides) {
875
+ if (requestParameters['exchange'] == null) {
876
+ throw new runtime.RequiredError('exchange', 'Required parameter "exchange" was null or undefined when calling fetchMatchedPrices().');
877
+ }
878
+ const queryParameters = {};
879
+ if (requestParameters['minDifference'] != null) {
880
+ queryParameters['minDifference'] = requestParameters['minDifference'];
881
+ }
882
+ if (requestParameters['category'] != null) {
883
+ queryParameters['category'] = requestParameters['category'];
884
+ }
885
+ if (requestParameters['limit'] != null) {
886
+ queryParameters['limit'] = requestParameters['limit'];
887
+ }
888
+ if (requestParameters['relations'] != null) {
889
+ queryParameters['relations'] = requestParameters['relations'];
890
+ }
891
+ const headerParameters = {};
892
+ let urlPath = `/api/{exchange}/fetchMatchedPrices`;
893
+ urlPath = urlPath.replace(`{${"exchange"}}`, encodeURIComponent(String(requestParameters['exchange'])));
894
+ const response = await this.request({
895
+ path: urlPath,
896
+ method: 'GET',
897
+ headers: headerParameters,
898
+ query: queryParameters,
899
+ }, initOverrides);
900
+ return new runtime.JSONApiResponse(response, (jsonValue) => FetchMatchedMarkets200ResponseFromJSON(jsonValue));
901
+ }
902
+ /**
903
+ * Compare Matched Market Prices
904
+ * @deprecated
905
+ */
906
+ async fetchMatchedPrices(requestParameters, initOverrides) {
907
+ const response = await this.fetchMatchedPricesRaw(requestParameters, initOverrides);
908
+ return await response.value();
909
+ }
800
910
  /**
801
911
  * Fetch My Trades
802
912
  */
@@ -1017,6 +1127,70 @@ export class DefaultApi extends runtime.BaseAPI {
1017
1127
  const response = await this.fetchPositionsRaw(requestParameters, initOverrides);
1018
1128
  return await response.value();
1019
1129
  }
1130
+ /**
1131
+ * Find related markets across venues. Discovers subset/superset market relationships where one market\'s outcome implies another, with live prices.
1132
+ * Find Related Markets
1133
+ */
1134
+ async fetchRelatedMarketsRaw(requestParameters, initOverrides) {
1135
+ if (requestParameters['exchange'] == null) {
1136
+ throw new runtime.RequiredError('exchange', 'Required parameter "exchange" was null or undefined when calling fetchRelatedMarkets().');
1137
+ }
1138
+ const queryParameters = {};
1139
+ if (requestParameters['query'] != null) {
1140
+ queryParameters['query'] = requestParameters['query'];
1141
+ }
1142
+ if (requestParameters['category'] != null) {
1143
+ queryParameters['category'] = requestParameters['category'];
1144
+ }
1145
+ if (requestParameters['market'] != null) {
1146
+ queryParameters['market'] = requestParameters['market'];
1147
+ }
1148
+ if (requestParameters['marketId'] != null) {
1149
+ queryParameters['marketId'] = requestParameters['marketId'];
1150
+ }
1151
+ if (requestParameters['slug'] != null) {
1152
+ queryParameters['slug'] = requestParameters['slug'];
1153
+ }
1154
+ if (requestParameters['url'] != null) {
1155
+ queryParameters['url'] = requestParameters['url'];
1156
+ }
1157
+ if (requestParameters['relation'] != null) {
1158
+ queryParameters['relation'] = requestParameters['relation'];
1159
+ }
1160
+ if (requestParameters['minConfidence'] != null) {
1161
+ queryParameters['minConfidence'] = requestParameters['minConfidence'];
1162
+ }
1163
+ if (requestParameters['limit'] != null) {
1164
+ queryParameters['limit'] = requestParameters['limit'];
1165
+ }
1166
+ if (requestParameters['includePrices'] != null) {
1167
+ queryParameters['includePrices'] = requestParameters['includePrices'];
1168
+ }
1169
+ if (requestParameters['minDifference'] != null) {
1170
+ queryParameters['minDifference'] = requestParameters['minDifference'];
1171
+ }
1172
+ if (requestParameters['sort'] != null) {
1173
+ queryParameters['sort'] = requestParameters['sort'];
1174
+ }
1175
+ const headerParameters = {};
1176
+ let urlPath = `/api/{exchange}/fetchRelatedMarkets`;
1177
+ urlPath = urlPath.replace(`{${"exchange"}}`, encodeURIComponent(String(requestParameters['exchange'])));
1178
+ const response = await this.request({
1179
+ path: urlPath,
1180
+ method: 'GET',
1181
+ headers: headerParameters,
1182
+ query: queryParameters,
1183
+ }, initOverrides);
1184
+ return new runtime.JSONApiResponse(response, (jsonValue) => CompareMarketPrices200ResponseFromJSON(jsonValue));
1185
+ }
1186
+ /**
1187
+ * Find related markets across venues. Discovers subset/superset market relationships where one market\'s outcome implies another, with live prices.
1188
+ * Find Related Markets
1189
+ */
1190
+ async fetchRelatedMarkets(requestParameters, initOverrides) {
1191
+ const response = await this.fetchRelatedMarketsRaw(requestParameters, initOverrides);
1192
+ return await response.value();
1193
+ }
1020
1194
  /**
1021
1195
  * Fetch raw trade history for a specific outcome.
1022
1196
  * Fetch Trades
@@ -1731,6 +1905,14 @@ export const FetchHedgesRelationEnum = {
1731
1905
  Overlap: 'overlap',
1732
1906
  Disjoint: 'disjoint'
1733
1907
  };
1908
+ /**
1909
+ * @export
1910
+ */
1911
+ export const FetchHedgesSortEnum = {
1912
+ Confidence: 'confidence',
1913
+ Volume: 'volume',
1914
+ PriceDifference: 'priceDifference'
1915
+ };
1734
1916
  /**
1735
1917
  * @export
1736
1918
  */
@@ -1800,6 +1982,14 @@ export const FetchMarketMatchesRelationEnum = {
1800
1982
  Overlap: 'overlap',
1801
1983
  Disjoint: 'disjoint'
1802
1984
  };
1985
+ /**
1986
+ * @export
1987
+ */
1988
+ export const FetchMarketMatchesSortEnum = {
1989
+ Confidence: 'confidence',
1990
+ Volume: 'volume',
1991
+ PriceDifference: 'priceDifference'
1992
+ };
1803
1993
  /**
1804
1994
  * @export
1805
1995
  */
@@ -1859,6 +2049,60 @@ export const FetchMarketsPaginatedExchangeEnum = {
1859
2049
  PolymarketUs: 'polymarket_us',
1860
2050
  Router: 'router'
1861
2051
  };
2052
+ /**
2053
+ * @export
2054
+ */
2055
+ export const FetchMatchedMarketsExchangeEnum = {
2056
+ Polymarket: 'polymarket',
2057
+ Kalshi: 'kalshi',
2058
+ KalshiDemo: 'kalshi-demo',
2059
+ Limitless: 'limitless',
2060
+ Probable: 'probable',
2061
+ Baozi: 'baozi',
2062
+ Myriad: 'myriad',
2063
+ Opinion: 'opinion',
2064
+ Metaculus: 'metaculus',
2065
+ Smarkets: 'smarkets',
2066
+ PolymarketUs: 'polymarket_us',
2067
+ Router: 'router'
2068
+ };
2069
+ /**
2070
+ * @export
2071
+ */
2072
+ export const FetchMatchedMarketsRelationsEnum = {
2073
+ Identity: 'identity',
2074
+ Subset: 'subset',
2075
+ Superset: 'superset',
2076
+ Overlap: 'overlap',
2077
+ Disjoint: 'disjoint'
2078
+ };
2079
+ /**
2080
+ * @export
2081
+ */
2082
+ export const FetchMatchedPricesExchangeEnum = {
2083
+ Polymarket: 'polymarket',
2084
+ Kalshi: 'kalshi',
2085
+ KalshiDemo: 'kalshi-demo',
2086
+ Limitless: 'limitless',
2087
+ Probable: 'probable',
2088
+ Baozi: 'baozi',
2089
+ Myriad: 'myriad',
2090
+ Opinion: 'opinion',
2091
+ Metaculus: 'metaculus',
2092
+ Smarkets: 'smarkets',
2093
+ PolymarketUs: 'polymarket_us',
2094
+ Router: 'router'
2095
+ };
2096
+ /**
2097
+ * @export
2098
+ */
2099
+ export const FetchMatchedPricesRelationsEnum = {
2100
+ Identity: 'identity',
2101
+ Subset: 'subset',
2102
+ Superset: 'superset',
2103
+ Overlap: 'overlap',
2104
+ Disjoint: 'disjoint'
2105
+ };
1862
2106
  /**
1863
2107
  * @export
1864
2108
  */
@@ -1972,6 +2216,41 @@ export const FetchPositionsExchangeEnum = {
1972
2216
  PolymarketUs: 'polymarket_us',
1973
2217
  Router: 'router'
1974
2218
  };
2219
+ /**
2220
+ * @export
2221
+ */
2222
+ export const FetchRelatedMarketsExchangeEnum = {
2223
+ Polymarket: 'polymarket',
2224
+ Kalshi: 'kalshi',
2225
+ KalshiDemo: 'kalshi-demo',
2226
+ Limitless: 'limitless',
2227
+ Probable: 'probable',
2228
+ Baozi: 'baozi',
2229
+ Myriad: 'myriad',
2230
+ Opinion: 'opinion',
2231
+ Metaculus: 'metaculus',
2232
+ Smarkets: 'smarkets',
2233
+ PolymarketUs: 'polymarket_us',
2234
+ Router: 'router'
2235
+ };
2236
+ /**
2237
+ * @export
2238
+ */
2239
+ export const FetchRelatedMarketsRelationEnum = {
2240
+ Identity: 'identity',
2241
+ Subset: 'subset',
2242
+ Superset: 'superset',
2243
+ Overlap: 'overlap',
2244
+ Disjoint: 'disjoint'
2245
+ };
2246
+ /**
2247
+ * @export
2248
+ */
2249
+ export const FetchRelatedMarketsSortEnum = {
2250
+ Confidence: 'confidence',
2251
+ Volume: 'volume',
2252
+ PriceDifference: 'priceDifference'
2253
+ };
1975
2254
  /**
1976
2255
  * @export
1977
2256
  */
@@ -16,6 +16,18 @@ import type { UnifiedEvent } from './UnifiedEvent.js';
16
16
  * @interface FetchEventMatchesParams
17
17
  */
18
18
  export interface FetchEventMatchesParams {
19
+ /**
20
+ * Keyword search across matched event titles.
21
+ * @type {string}
22
+ * @memberof FetchEventMatchesParams
23
+ */
24
+ query?: string;
25
+ /**
26
+ * Filter matches by category.
27
+ * @type {string}
28
+ * @memberof FetchEventMatchesParams
29
+ */
30
+ category?: string;
19
31
  /**
20
32
  * Pass a UnifiedEvent directly instead of eventId/slug.
21
33
  * @type {UnifiedEvent}
@@ -23,7 +35,7 @@ export interface FetchEventMatchesParams {
23
35
  */
24
36
  event?: UnifiedEvent;
25
37
  /**
26
- *
38
+ * Lookup a specific event by ID. Omit for browse mode.
27
39
  * @type {string}
28
40
  * @memberof FetchEventMatchesParams
29
41
  */
@@ -36,6 +36,8 @@ export function FetchEventMatchesParamsFromJSONTyped(json, ignoreDiscriminator)
36
36
  return json;
37
37
  }
38
38
  return {
39
+ 'query': json['query'] == null ? undefined : json['query'],
40
+ 'category': json['category'] == null ? undefined : json['category'],
39
41
  'event': json['event'] == null ? undefined : UnifiedEventFromJSON(json['event']),
40
42
  'eventId': json['eventId'] == null ? undefined : json['eventId'],
41
43
  'slug': json['slug'] == null ? undefined : json['slug'],
@@ -53,6 +55,8 @@ export function FetchEventMatchesParamsToJSONTyped(value, ignoreDiscriminator =
53
55
  return value;
54
56
  }
55
57
  return {
58
+ 'query': value['query'],
59
+ 'category': value['category'],
56
60
  'event': UnifiedEventToJSON(value['event']),
57
61
  'eventId': value['eventId'],
58
62
  'slug': value['slug'],
@@ -16,6 +16,18 @@ import type { UnifiedMarket } from './UnifiedMarket.js';
16
16
  * @interface FetchMarketMatchesParams
17
17
  */
18
18
  export interface FetchMarketMatchesParams {
19
+ /**
20
+ * Keyword search across matched market titles.
21
+ * @type {string}
22
+ * @memberof FetchMarketMatchesParams
23
+ */
24
+ query?: string;
25
+ /**
26
+ * Filter matches by category.
27
+ * @type {string}
28
+ * @memberof FetchMarketMatchesParams
29
+ */
30
+ category?: string;
19
31
  /**
20
32
  * Pass a UnifiedMarket directly instead of marketId/slug/url.
21
33
  * @type {UnifiedMarket}
@@ -23,7 +35,7 @@ export interface FetchMarketMatchesParams {
23
35
  */
24
36
  market?: UnifiedMarket;
25
37
  /**
26
- *
38
+ * Lookup a specific market by ID. Omit for browse mode.
27
39
  * @type {string}
28
40
  * @memberof FetchMarketMatchesParams
29
41
  */
@@ -64,6 +76,18 @@ export interface FetchMarketMatchesParams {
64
76
  * @memberof FetchMarketMatchesParams
65
77
  */
66
78
  includePrices?: boolean;
79
+ /**
80
+ * Minimum price difference between venues. Browse mode only.
81
+ * @type {number}
82
+ * @memberof FetchMarketMatchesParams
83
+ */
84
+ minDifference?: number;
85
+ /**
86
+ * Sort order. Browse mode only.
87
+ * @type {string}
88
+ * @memberof FetchMarketMatchesParams
89
+ */
90
+ sort?: FetchMarketMatchesParamsSortEnum;
67
91
  }
68
92
  /**
69
93
  * @export
@@ -76,6 +100,15 @@ export declare const FetchMarketMatchesParamsRelationEnum: {
76
100
  readonly Disjoint: "disjoint";
77
101
  };
78
102
  export type FetchMarketMatchesParamsRelationEnum = typeof FetchMarketMatchesParamsRelationEnum[keyof typeof FetchMarketMatchesParamsRelationEnum];
103
+ /**
104
+ * @export
105
+ */
106
+ export declare const FetchMarketMatchesParamsSortEnum: {
107
+ readonly Confidence: "confidence";
108
+ readonly Volume: "volume";
109
+ readonly PriceDifference: "priceDifference";
110
+ };
111
+ export type FetchMarketMatchesParamsSortEnum = typeof FetchMarketMatchesParamsSortEnum[keyof typeof FetchMarketMatchesParamsSortEnum];
79
112
  /**
80
113
  * Check if a given object implements the FetchMarketMatchesParams interface.
81
114
  */
@@ -22,6 +22,14 @@ export const FetchMarketMatchesParamsRelationEnum = {
22
22
  Overlap: 'overlap',
23
23
  Disjoint: 'disjoint'
24
24
  };
25
+ /**
26
+ * @export
27
+ */
28
+ export const FetchMarketMatchesParamsSortEnum = {
29
+ Confidence: 'confidence',
30
+ Volume: 'volume',
31
+ PriceDifference: 'priceDifference'
32
+ };
25
33
  /**
26
34
  * Check if a given object implements the FetchMarketMatchesParams interface.
27
35
  */
@@ -36,6 +44,8 @@ export function FetchMarketMatchesParamsFromJSONTyped(json, ignoreDiscriminator)
36
44
  return json;
37
45
  }
38
46
  return {
47
+ 'query': json['query'] == null ? undefined : json['query'],
48
+ 'category': json['category'] == null ? undefined : json['category'],
39
49
  'market': json['market'] == null ? undefined : UnifiedMarketFromJSON(json['market']),
40
50
  'marketId': json['marketId'] == null ? undefined : json['marketId'],
41
51
  'slug': json['slug'] == null ? undefined : json['slug'],
@@ -44,6 +54,8 @@ export function FetchMarketMatchesParamsFromJSONTyped(json, ignoreDiscriminator)
44
54
  'minConfidence': json['minConfidence'] == null ? undefined : json['minConfidence'],
45
55
  'limit': json['limit'] == null ? undefined : json['limit'],
46
56
  'includePrices': json['includePrices'] == null ? undefined : json['includePrices'],
57
+ 'minDifference': json['minDifference'] == null ? undefined : json['minDifference'],
58
+ 'sort': json['sort'] == null ? undefined : json['sort'],
47
59
  };
48
60
  }
49
61
  export function FetchMarketMatchesParamsToJSON(json) {
@@ -54,6 +66,8 @@ export function FetchMarketMatchesParamsToJSONTyped(value, ignoreDiscriminator =
54
66
  return value;
55
67
  }
56
68
  return {
69
+ 'query': value['query'],
70
+ 'category': value['category'],
57
71
  'market': UnifiedMarketToJSON(value['market']),
58
72
  'marketId': value['marketId'],
59
73
  'slug': value['slug'],
@@ -62,5 +76,7 @@ export function FetchMarketMatchesParamsToJSONTyped(value, ignoreDiscriminator =
62
76
  'minConfidence': value['minConfidence'],
63
77
  'limit': value['limit'],
64
78
  'includePrices': value['includePrices'],
79
+ 'minDifference': value['minDifference'],
80
+ 'sort': value['sort'],
65
81
  };
66
82
  }
@@ -0,0 +1,46 @@
1
+ /**
2
+ * PMXT Sidecar API
3
+ * A unified local sidecar API for prediction markets (Polymarket, Kalshi, Limitless). This API acts as a JSON-RPC-style gateway. Each endpoint corresponds to a specific method on the generic exchange implementation.
4
+ *
5
+ * The version of the OpenAPI document: 0.4.4
6
+ *
7
+ *
8
+ * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
9
+ * https://openapi-generator.tech
10
+ * Do not edit the class manually.
11
+ */
12
+ import type { ErrorDetail } from './ErrorDetail.js';
13
+ import type { MatchedMarketPair } from './MatchedMarketPair.js';
14
+ /**
15
+ *
16
+ * @export
17
+ * @interface FetchMatchedMarkets200Response
18
+ */
19
+ export interface FetchMatchedMarkets200Response {
20
+ /**
21
+ *
22
+ * @type {boolean}
23
+ * @memberof FetchMatchedMarkets200Response
24
+ */
25
+ success?: boolean;
26
+ /**
27
+ *
28
+ * @type {ErrorDetail}
29
+ * @memberof FetchMatchedMarkets200Response
30
+ */
31
+ error?: ErrorDetail;
32
+ /**
33
+ *
34
+ * @type {Array<MatchedMarketPair>}
35
+ * @memberof FetchMatchedMarkets200Response
36
+ */
37
+ data?: Array<MatchedMarketPair>;
38
+ }
39
+ /**
40
+ * Check if a given object implements the FetchMatchedMarkets200Response interface.
41
+ */
42
+ export declare function instanceOfFetchMatchedMarkets200Response(value: object): value is FetchMatchedMarkets200Response;
43
+ export declare function FetchMatchedMarkets200ResponseFromJSON(json: any): FetchMatchedMarkets200Response;
44
+ export declare function FetchMatchedMarkets200ResponseFromJSONTyped(json: any, ignoreDiscriminator: boolean): FetchMatchedMarkets200Response;
45
+ export declare function FetchMatchedMarkets200ResponseToJSON(json: any): FetchMatchedMarkets200Response;
46
+ export declare function FetchMatchedMarkets200ResponseToJSONTyped(value?: FetchMatchedMarkets200Response | null, ignoreDiscriminator?: boolean): any;