pmxt-core 2.37.5 → 2.37.7

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.
@@ -1,6 +1,6 @@
1
1
  /**
2
2
  * Auto-generated from /home/runner/work/pmxt/pmxt/core/specs/kalshi/Kalshi.yaml
3
- * Generated at: 2026-05-04T20:05:35.330Z
3
+ * Generated at: 2026-05-05T12:19:53.152Z
4
4
  * Do not edit manually -- run "npm run fetch:openapi" to regenerate.
5
5
  */
6
6
  export declare const kalshiApiSpec: {
@@ -3,7 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.kalshiApiSpec = void 0;
4
4
  /**
5
5
  * Auto-generated from /home/runner/work/pmxt/pmxt/core/specs/kalshi/Kalshi.yaml
6
- * Generated at: 2026-05-04T20:05:35.330Z
6
+ * Generated at: 2026-05-05T12:19:53.152Z
7
7
  * Do not edit manually -- run "npm run fetch:openapi" to regenerate.
8
8
  */
9
9
  exports.kalshiApiSpec = {
@@ -176,31 +176,57 @@ class KalshiWebSocket {
176
176
  }
177
177
  handleOrderbookSnapshot(data) {
178
178
  const ticker = data.market_ticker;
179
- // Kalshi orderbook structure:
180
- // yes: [{ price: number (cents), quantity: number }, ...]
181
- // no: [{ price: number (cents), quantity: number }, ...]
182
- const bids = (data.yes || [])
183
- .map((level) => {
184
- const price = (level.price || level[0]) / 100;
185
- const size = (level.quantity !== undefined
186
- ? level.quantity
187
- : level.size !== undefined
188
- ? level.size
189
- : level[1]) || 0;
190
- return { price, size };
191
- })
192
- .sort((a, b) => b.price - a.price);
193
- const asks = (data.no || [])
194
- .map((level) => {
195
- const price = (100 - (level.price || level[0])) / 100;
196
- const size = (level.quantity !== undefined
197
- ? level.quantity
198
- : level.size !== undefined
199
- ? level.size
200
- : level[1]) || 0;
201
- return { price, size };
202
- })
203
- .sort((a, b) => a.price - b.price);
179
+ // Kalshi returns market_id: "" for non-existing markets — reject instead
180
+ // of resolving with an empty orderbook.
181
+ if (!data.market_id) {
182
+ const resolvers = this.orderBookResolvers.get(ticker);
183
+ if (resolvers && resolvers.length > 0) {
184
+ const err = new Error(`watchOrderBook('${ticker}'): market not found on this exchange.`);
185
+ resolvers.forEach((r) => r.reject(err));
186
+ this.orderBookResolvers.set(ticker, []);
187
+ }
188
+ this.subscribedOrderBookTickers.delete(ticker);
189
+ return;
190
+ }
191
+ // Kalshi V2 WebSocket uses dollar-denominated string pairs:
192
+ // yes_dollars_fp / no_dollars_fp: [["0.55", "100.00"], ...]
193
+ // Older format used cent-denominated objects:
194
+ // yes / no: [{ price: 55, quantity: 100 }, ...]
195
+ const usesDollarsFp = data.yes_dollars_fp !== undefined || data.no_dollars_fp !== undefined;
196
+ let bids;
197
+ let asks;
198
+ if (usesDollarsFp) {
199
+ bids = (data.yes_dollars_fp || []).map((level) => ({
200
+ price: parseFloat(level[0]),
201
+ size: parseFloat(level[1]),
202
+ }));
203
+ asks = (data.no_dollars_fp || []).map((level) => ({
204
+ price: Math.round((1 - parseFloat(level[0])) * 10000) / 10000,
205
+ size: parseFloat(level[1]),
206
+ }));
207
+ }
208
+ else {
209
+ bids = (data.yes || []).map((level) => {
210
+ const price = (level.price || level[0]) / 100;
211
+ const size = (level.quantity !== undefined
212
+ ? level.quantity
213
+ : level.size !== undefined
214
+ ? level.size
215
+ : level[1]) || 0;
216
+ return { price, size };
217
+ });
218
+ asks = (data.no || []).map((level) => {
219
+ const price = (100 - (level.price || level[0])) / 100;
220
+ const size = (level.quantity !== undefined
221
+ ? level.quantity
222
+ : level.size !== undefined
223
+ ? level.size
224
+ : level[1]) || 0;
225
+ return { price, size };
226
+ });
227
+ }
228
+ bids.sort((a, b) => b.price - a.price);
229
+ asks.sort((a, b) => a.price - b.price);
204
230
  const orderBook = {
205
231
  bids,
206
232
  asks,
@@ -216,21 +242,42 @@ class KalshiWebSocket {
216
242
  // No snapshot yet, skip delta
217
243
  return;
218
244
  }
219
- // Apply delta updates
220
- // Kalshi sends: { price: number, delta: number, side: 'yes' | 'no' }
221
- const price = data.price / 100;
222
- const delta = data.delta !== undefined
223
- ? data.delta
224
- : data.quantity !== undefined
225
- ? data.quantity
226
- : 0;
227
- const side = data.side;
228
- if (side === "yes") {
229
- this.applyDelta(existing.bids, price, delta, "desc");
245
+ // Kalshi V2 uses dollar-denominated string values:
246
+ // { price_dollars_fp: "0.55", delta_dollars_fp: "10.00", side: "yes"|"no" }
247
+ // Older format used cent-denominated integers:
248
+ // { price: 55, delta: 10, side: "yes"|"no" }
249
+ const usesDollarsFp = data.price_dollars_fp !== undefined;
250
+ let price;
251
+ let delta;
252
+ if (usesDollarsFp) {
253
+ const rawPrice = parseFloat(data.price_dollars_fp);
254
+ delta = parseFloat(data.delta_dollars_fp || "0");
255
+ const side = data.side;
256
+ if (side === "yes") {
257
+ price = rawPrice;
258
+ this.applyDelta(existing.bids, price, delta, "desc");
259
+ }
260
+ else {
261
+ price = Math.round((1 - rawPrice) * 10000) / 10000;
262
+ this.applyDelta(existing.asks, price, delta, "asc");
263
+ }
230
264
  }
231
265
  else {
232
- const yesPrice = (100 - data.price) / 100;
233
- this.applyDelta(existing.asks, yesPrice, delta, "asc");
266
+ price = data.price / 100;
267
+ delta =
268
+ data.delta !== undefined
269
+ ? data.delta
270
+ : data.quantity !== undefined
271
+ ? data.quantity
272
+ : 0;
273
+ const side = data.side;
274
+ if (side === "yes") {
275
+ this.applyDelta(existing.bids, price, delta, "desc");
276
+ }
277
+ else {
278
+ const yesPrice = (100 - data.price) / 100;
279
+ this.applyDelta(existing.asks, yesPrice, delta, "asc");
280
+ }
234
281
  }
235
282
  existing.timestamp = Date.now();
236
283
  this.resolveOrderBook(ticker, existing);
@@ -1,6 +1,6 @@
1
1
  /**
2
2
  * Auto-generated from /home/runner/work/pmxt/pmxt/core/specs/limitless/Limitless.yaml
3
- * Generated at: 2026-05-04T20:05:35.365Z
3
+ * Generated at: 2026-05-05T12:19:53.192Z
4
4
  * Do not edit manually -- run "npm run fetch:openapi" to regenerate.
5
5
  */
6
6
  export declare const limitlessApiSpec: {
@@ -3,7 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.limitlessApiSpec = void 0;
4
4
  /**
5
5
  * Auto-generated from /home/runner/work/pmxt/pmxt/core/specs/limitless/Limitless.yaml
6
- * Generated at: 2026-05-04T20:05:35.365Z
6
+ * Generated at: 2026-05-05T12:19:53.192Z
7
7
  * Do not edit manually -- run "npm run fetch:openapi" to regenerate.
8
8
  */
9
9
  exports.limitlessApiSpec = {
@@ -1,6 +1,6 @@
1
1
  /**
2
2
  * Auto-generated from /home/runner/work/pmxt/pmxt/core/specs/myriad/myriad.yaml
3
- * Generated at: 2026-05-04T20:05:35.376Z
3
+ * Generated at: 2026-05-05T12:19:53.204Z
4
4
  * Do not edit manually -- run "npm run fetch:openapi" to regenerate.
5
5
  */
6
6
  export declare const myriadApiSpec: {
@@ -3,7 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.myriadApiSpec = void 0;
4
4
  /**
5
5
  * Auto-generated from /home/runner/work/pmxt/pmxt/core/specs/myriad/myriad.yaml
6
- * Generated at: 2026-05-04T20:05:35.376Z
6
+ * Generated at: 2026-05-05T12:19:53.204Z
7
7
  * Do not edit manually -- run "npm run fetch:openapi" to regenerate.
8
8
  */
9
9
  exports.myriadApiSpec = {
@@ -1,6 +1,6 @@
1
1
  /**
2
2
  * Auto-generated from /home/runner/work/pmxt/pmxt/core/specs/opinion/opinion-openapi.yaml
3
- * Generated at: 2026-05-04T20:05:35.381Z
3
+ * Generated at: 2026-05-05T12:19:53.207Z
4
4
  * Do not edit manually -- run "npm run fetch:openapi" to regenerate.
5
5
  */
6
6
  export declare const opinionApiSpec: {
@@ -3,7 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.opinionApiSpec = void 0;
4
4
  /**
5
5
  * Auto-generated from /home/runner/work/pmxt/pmxt/core/specs/opinion/opinion-openapi.yaml
6
- * Generated at: 2026-05-04T20:05:35.381Z
6
+ * Generated at: 2026-05-05T12:19:53.207Z
7
7
  * Do not edit manually -- run "npm run fetch:openapi" to regenerate.
8
8
  */
9
9
  exports.opinionApiSpec = {
@@ -1,6 +1,6 @@
1
1
  /**
2
2
  * Auto-generated from /home/runner/work/pmxt/pmxt/core/specs/polymarket/PolymarketClobAPI.yaml
3
- * Generated at: 2026-05-04T20:05:35.335Z
3
+ * Generated at: 2026-05-05T12:19:53.160Z
4
4
  * Do not edit manually -- run "npm run fetch:openapi" to regenerate.
5
5
  */
6
6
  export declare const polymarketClobSpec: {
@@ -3,7 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.polymarketClobSpec = void 0;
4
4
  /**
5
5
  * Auto-generated from /home/runner/work/pmxt/pmxt/core/specs/polymarket/PolymarketClobAPI.yaml
6
- * Generated at: 2026-05-04T20:05:35.335Z
6
+ * Generated at: 2026-05-05T12:19:53.160Z
7
7
  * Do not edit manually -- run "npm run fetch:openapi" to regenerate.
8
8
  */
9
9
  exports.polymarketClobSpec = {
@@ -1,6 +1,6 @@
1
1
  /**
2
2
  * Auto-generated from /home/runner/work/pmxt/pmxt/core/specs/polymarket/Polymarket_Data_API.yaml
3
- * Generated at: 2026-05-04T20:05:35.347Z
3
+ * Generated at: 2026-05-05T12:19:53.171Z
4
4
  * Do not edit manually -- run "npm run fetch:openapi" to regenerate.
5
5
  */
6
6
  export declare const polymarketDataSpec: {
@@ -3,7 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.polymarketDataSpec = void 0;
4
4
  /**
5
5
  * Auto-generated from /home/runner/work/pmxt/pmxt/core/specs/polymarket/Polymarket_Data_API.yaml
6
- * Generated at: 2026-05-04T20:05:35.347Z
6
+ * Generated at: 2026-05-05T12:19:53.171Z
7
7
  * Do not edit manually -- run "npm run fetch:openapi" to regenerate.
8
8
  */
9
9
  exports.polymarketDataSpec = {
@@ -1,6 +1,6 @@
1
1
  /**
2
2
  * Auto-generated from /home/runner/work/pmxt/pmxt/core/specs/polymarket/PolymarketGammaAPI.yaml
3
- * Generated at: 2026-05-04T20:05:35.344Z
3
+ * Generated at: 2026-05-05T12:19:53.169Z
4
4
  * Do not edit manually -- run "npm run fetch:openapi" to regenerate.
5
5
  */
6
6
  export declare const polymarketGammaSpec: {
@@ -3,7 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.polymarketGammaSpec = void 0;
4
4
  /**
5
5
  * Auto-generated from /home/runner/work/pmxt/pmxt/core/specs/polymarket/PolymarketGammaAPI.yaml
6
- * Generated at: 2026-05-04T20:05:35.344Z
6
+ * Generated at: 2026-05-05T12:19:53.169Z
7
7
  * Do not edit manually -- run "npm run fetch:openapi" to regenerate.
8
8
  */
9
9
  exports.polymarketGammaSpec = {
@@ -1,6 +1,6 @@
1
1
  /**
2
2
  * Auto-generated from /home/runner/work/pmxt/pmxt/core/specs/probable/probable.yaml
3
- * Generated at: 2026-05-04T20:05:35.369Z
3
+ * Generated at: 2026-05-05T12:19:53.198Z
4
4
  * Do not edit manually -- run "npm run fetch:openapi" to regenerate.
5
5
  */
6
6
  export declare const probableApiSpec: {
@@ -3,7 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.probableApiSpec = void 0;
4
4
  /**
5
5
  * Auto-generated from /home/runner/work/pmxt/pmxt/core/specs/probable/probable.yaml
6
- * Generated at: 2026-05-04T20:05:35.369Z
6
+ * Generated at: 2026-05-05T12:19:53.198Z
7
7
  * Do not edit manually -- run "npm run fetch:openapi" to regenerate.
8
8
  */
9
9
  exports.probableApiSpec = {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "pmxt-core",
3
- "version": "2.37.5",
3
+ "version": "2.37.7",
4
4
  "description": "pmxt is a unified prediction market data API. The ccxt for prediction markets.",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",
@@ -29,8 +29,8 @@
29
29
  "test": "jest -c jest.config.js",
30
30
  "server": "tsx watch src/server/index.ts",
31
31
  "server:prod": "node dist/server/index.js",
32
- "generate:sdk:python": "npx @openapitools/openapi-generator-cli generate -i src/server/openapi.yaml -g python -o ../sdks/python/generated --package-name pmxt_internal --additional-properties=projectName=pmxt-internal,packageVersion=2.37.5,library=urllib3",
33
- "generate:sdk:typescript": "npx @openapitools/openapi-generator-cli generate -i src/server/openapi.yaml -g typescript-fetch -o ../sdks/typescript/generated --additional-properties=npmName=pmxtjs,npmVersion=2.37.5,supportsES6=true,typescriptThreePlus=true && node ../sdks/typescript/scripts/fix-generated.js",
32
+ "generate:sdk:python": "npx @openapitools/openapi-generator-cli generate -i src/server/openapi.yaml -g python -o ../sdks/python/generated --package-name pmxt_internal --additional-properties=projectName=pmxt-internal,packageVersion=2.37.7,library=urllib3",
33
+ "generate:sdk:typescript": "npx @openapitools/openapi-generator-cli generate -i src/server/openapi.yaml -g typescript-fetch -o ../sdks/typescript/generated --additional-properties=npmName=pmxtjs,npmVersion=2.37.7,supportsES6=true,typescriptThreePlus=true && node ../sdks/typescript/scripts/fix-generated.js",
34
34
  "fetch:openapi": "node scripts/fetch-openapi-specs.js",
35
35
  "extract:jsdoc": "node ../scripts/extract-jsdoc.js",
36
36
  "generate:docs": "npm run extract:jsdoc && node ../scripts/generate-api-docs.js",