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.
- package/dist/exchanges/kalshi/api.d.ts +1 -1
- package/dist/exchanges/kalshi/api.js +1 -1
- package/dist/exchanges/kalshi/websocket.js +85 -38
- package/dist/exchanges/limitless/api.d.ts +1 -1
- package/dist/exchanges/limitless/api.js +1 -1
- package/dist/exchanges/myriad/api.d.ts +1 -1
- package/dist/exchanges/myriad/api.js +1 -1
- package/dist/exchanges/opinion/api.d.ts +1 -1
- package/dist/exchanges/opinion/api.js +1 -1
- package/dist/exchanges/polymarket/api-clob.d.ts +1 -1
- package/dist/exchanges/polymarket/api-clob.js +1 -1
- package/dist/exchanges/polymarket/api-data.d.ts +1 -1
- package/dist/exchanges/polymarket/api-data.js +1 -1
- package/dist/exchanges/polymarket/api-gamma.d.ts +1 -1
- package/dist/exchanges/polymarket/api-gamma.js +1 -1
- package/dist/exchanges/probable/api.d.ts +1 -1
- package/dist/exchanges/probable/api.js +1 -1
- package/package.json +3 -3
|
@@ -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-
|
|
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-
|
|
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
|
|
180
|
-
//
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
.
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
.
|
|
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
|
-
//
|
|
220
|
-
//
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
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
|
-
|
|
233
|
-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
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-
|
|
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.
|
|
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.
|
|
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.
|
|
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",
|