@pionex/pionex-ai-kit 0.2.34 → 0.2.35

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/index.js CHANGED
@@ -1257,6 +1257,26 @@ function registerMarketTools() {
1257
1257
  return (await client.publicGet("/api/v1/market/tickers", q)).data;
1258
1258
  }
1259
1259
  },
1260
+ {
1261
+ name: "pionex_market_get_book_tickers",
1262
+ module: "market",
1263
+ isWrite: false,
1264
+ description: "Get best bid/ask ticker(s). Optional symbol or type (SPOT/PERP).",
1265
+ inputSchema: {
1266
+ type: "object",
1267
+ additionalProperties: false,
1268
+ properties: {
1269
+ symbol: { type: "string", description: "e.g. BTC_USDT; if omitted, returns all book tickers filtered by type" },
1270
+ type: { type: "string", enum: ["SPOT", "PERP"], description: "If symbol is not specified, filter by type." }
1271
+ }
1272
+ },
1273
+ async handler(args, { client }) {
1274
+ const q = {};
1275
+ if (args.symbol) q.symbol = String(args.symbol);
1276
+ if (args.type) q.type = String(args.type);
1277
+ return (await client.publicGet("/api/v1/market/bookTickers", q)).data;
1278
+ }
1279
+ },
1260
1280
  {
1261
1281
  name: "pionex_market_get_klines",
1262
1282
  module: "market",
@@ -1459,6 +1479,26 @@ function registerOrdersTools() {
1459
1479
  return (await client.signedGet("/api/v1/trade/fills", q)).data;
1460
1480
  }
1461
1481
  },
1482
+ {
1483
+ name: "pionex_orders_get_fills_by_order_id",
1484
+ module: "orders",
1485
+ isWrite: false,
1486
+ description: "Get fills for a specific order by symbol and orderId.",
1487
+ inputSchema: {
1488
+ type: "object",
1489
+ additionalProperties: false,
1490
+ properties: {
1491
+ symbol: { type: "string", description: "e.g. BTC_USDT" },
1492
+ orderId: { type: "integer", description: "Order id" }
1493
+ },
1494
+ required: ["symbol", "orderId"]
1495
+ },
1496
+ async handler(args, { client }) {
1497
+ const symbol = String(args.symbol);
1498
+ const orderId = Number(args.orderId);
1499
+ return (await client.signedGet("/api/v1/trade/fillsByOrderId", { symbol, orderId })).data;
1500
+ }
1501
+ },
1462
1502
  {
1463
1503
  name: "pionex_orders_cancel_all_orders",
1464
1504
  module: "orders",
@@ -2192,10 +2232,12 @@ Groups:
2192
2232
  Examples:
2193
2233
  pionex-trade-cli market depth BTC_USDT --limit 5
2194
2234
  pionex-trade-cli market tickers --symbol BTC_USDT
2235
+ pionex-trade-cli market book-tickers --symbol BTC_USDT
2195
2236
  pionex-trade-cli market symbols --symbols BTC_USDT
2196
2237
  pionex-trade-cli account balance
2197
2238
  pionex-trade-cli orders new --symbol BTC_USDT --side BUY --type MARKET --amount 10
2198
2239
  pionex-trade-cli orders cancel --symbol BTC_USDT --order-id 123
2240
+ pionex-trade-cli orders fills-by-order-id --symbol BTC_USDT --order-id 123
2199
2241
  pionex-trade-cli bot futures_grid get --bu-order-id <id>
2200
2242
  pionex-trade-cli bot futures_grid create --base BTC --quote USDT --bu-order-data-json '{"top":"110000","bottom":"90000","row":100,"grid_type":"arithmetic","trend":"long","leverage":5,"quoteInvestment":"100"}'
2201
2243
 
@@ -2285,6 +2327,13 @@ async function runPionexCommand(argv) {
2285
2327
  process.stdout.write(JSON.stringify(out.data, null, 2) + "\n");
2286
2328
  return;
2287
2329
  }
2330
+ if (command === "book-tickers" || command === "bookTickers") {
2331
+ const symbol = typeof flags.symbol === "string" ? flags.symbol : void 0;
2332
+ const type = typeof flags.type === "string" ? flags.type : void 0;
2333
+ const out = await runTool("pionex_market_get_book_tickers", { symbol, type });
2334
+ process.stdout.write(JSON.stringify(out.data, null, 2) + "\n");
2335
+ return;
2336
+ }
2288
2337
  if (command === "klines") {
2289
2338
  const symbol = typeof flags.symbol === "string" ? flags.symbol : positionals[2];
2290
2339
  const interval = typeof flags.interval === "string" ? flags.interval : positionals[3];
@@ -2357,6 +2406,14 @@ async function runPionexCommand(argv) {
2357
2406
  process.stdout.write(JSON.stringify(out.data, null, 2) + "\n");
2358
2407
  return;
2359
2408
  }
2409
+ if (command === "fills-by-order-id" || command === "fillsByOrderId") {
2410
+ const symbol = typeof flags.symbol === "string" ? flags.symbol : void 0;
2411
+ const orderId = flags["order-id"] != null ? Number(flags["order-id"]) : void 0;
2412
+ if (!symbol || orderId == null) throw new Error("Missing required flags: --symbol --order-id");
2413
+ const out = await runTool("pionex_orders_get_fills_by_order_id", { symbol, orderId });
2414
+ process.stdout.write(JSON.stringify(out.data, null, 2) + "\n");
2415
+ return;
2416
+ }
2360
2417
  if (command === "cancel") {
2361
2418
  const symbol = typeof flags.symbol === "string" ? flags.symbol : void 0;
2362
2419
  const orderId = flags["order-id"] != null ? Number(flags["order-id"]) : void 0;
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/index.ts","../../core/src/config/toml.ts","../../core/src/setup.ts","../../core/src/constants.ts","../../core/src/utils/errors.ts","../../core/src/config.ts","../../core/src/client/rest-client.ts","../../core/src/tools/market.ts","../../core/src/tools/account.ts","../../core/src/tools/orders.ts","../../core/src/schemas/futures-grid-create.ts","../../core/src/tools/bot.ts","../../core/src/tools/index.ts","../../core/src/tools/types.ts","../../../node_modules/smol-toml/dist/error.js","../../../node_modules/smol-toml/dist/util.js","../../../node_modules/smol-toml/dist/date.js","../../../node_modules/smol-toml/dist/primitive.js","../../../node_modules/smol-toml/dist/extract.js","../../../node_modules/smol-toml/dist/struct.js","../../../node_modules/smol-toml/dist/parse.js","../../../node_modules/smol-toml/dist/stringify.js"],"sourcesContent":["#!/usr/bin/env node\n\nimport { createInterface } from \"node:readline\";\nimport { basename } from \"node:path\";\nimport {\n readFullConfig,\n writeFullConfig,\n configFilePath,\n runSetup,\n SUPPORTED_CLIENTS,\n type PionexTomlConfig,\n type PionexProfile,\n type ClientId,\n loadConfig,\n PionexRestClient,\n createToolRunner,\n toToolErrorPayload,\n parseAndValidateCreateFuturesGridBuOrderData,\n} from \"@pionex-ai/core\";\n\nconst DEFAULT_PROFILE_NAME = \"pionx-prod\";\nconst DEFAULT_BASE_URL = \"https://api.pionex.com\";\n\nfunction ask(rl: ReturnType<typeof createInterface>, question: string, defaultValue = \"\"): Promise<string> {\n const prompt = defaultValue ? `${question} [${defaultValue}]: ` : `${question}: `;\n return new Promise((resolve) => rl.question(prompt, (answer) => resolve((answer ?? \"\").trim() || defaultValue)));\n}\n\nasync function cmdOnboard(): Promise<void> {\n const rl = createInterface({ input: process.stdin, output: process.stdout });\n\n process.stdout.write(\"\\n pionex-ai-kit v0.2.x\\n\");\n process.stdout.write(\" ⚠️ Security Tips: NEVER send API keys in agent chat. Create a dedicated API Key for your agent. Please test thoroughly before connecting to large real-money accounts.\\n\");\n process.stdout.write(\" ⚠️ 安全提示:切勿在 Agent 对话中发送 API Key。请为 Agent 创建专用API Key接入,先用小金额充分验证后再接入实盘。\\n\\n\");\n\n process.stdout.write(\"Pionex CLI — Configuration Wizard\\n\\n\");\n process.stdout.write(\"Go to https://www.pionex.com/zh-CN/my-account/api to create an API Key (trade permission required)\\n\\n\");\n process.stdout.write(\"Credentials will be saved to \" + configFilePath() + \"\\n\\n\");\n\n const apiKey = await ask(rl, \"Pionex API Key\");\n if (!apiKey) {\n process.stderr.write(\" Error: API Key cannot be empty.\\n\");\n rl.close();\n process.exit(1);\n }\n\n const secretKey = await ask(rl, \"Pionex API Secret\");\n if (!secretKey) {\n process.stderr.write(\" Error: API Secret cannot be empty.\\n\");\n rl.close();\n process.exit(1);\n }\n\n rl.close();\n\n let config: PionexTomlConfig = { profiles: {} };\n try {\n config = readFullConfig();\n } catch {\n config = { profiles: {} };\n }\n if (!config.profiles) config.profiles = {};\n\n const profile: PionexProfile = {\n api_key: apiKey,\n secret_key: secretKey,\n base_url: DEFAULT_BASE_URL,\n };\n const profileName = DEFAULT_PROFILE_NAME;\n config.profiles[profileName] = profile;\n config.default_profile = profileName;\n\n try {\n writeFullConfig(config);\n } catch (e) {\n process.stderr.write(\" Failed to write config: \" + (e instanceof Error ? e.message : String(e)) + \"\\n\");\n process.exit(1);\n }\n\n process.stdout.write(\"\\n Config saved to \" + configFilePath() + \"\\n\");\n process.stdout.write(\" Default profile: \" + profileName + \"\\n\");\n process.stdout.write(\" Usage: pionex-ai-kit onboard\\n\");\n process.stdout.write(\n \" Next: run 'pionex-ai-kit setup --mcp=pionex-trade-mcp --client cursor' or \" +\n \"'pionex-trade-mcp setup --client cursor' to register the MCP server.\\n\" +\n \" You can replace 'cursor' with 'claude-desktop', 'windsurf', 'vscode', 'claude-code', 'claude' or 'openclaw' depending on which agent you want to configure.\\n\\n\",\n );\n}\n\nfunction printHelp(): void {\n process.stdout.write(`\nUsage: pionex-ai-kit <command>\n\nCommands:\n onboard Interactive wizard to create ~/.pionex/config.toml (API key, secret)\n help Show this help\n\nThe MCP server (pionex-trade-mcp) reads credentials from ~/.pionex/config.toml.\nUse 'pionex-ai-kit setup --mcp=pionex-trade-mcp --client <client>' to write MCP client config\nthat runs 'npx @pionex/pionex-trade-mcp' (no keys are written to the client config).\n\n`);\n}\n\nfunction parseSetupArgs(argv: string[]): { mcp?: string; client?: string } {\n let mcp: string | undefined;\n let client: string | undefined;\n for (let i = 0; i < argv.length; i++) {\n const arg = argv[i];\n if (arg === \"--mcp\" && argv[i + 1]) {\n mcp = argv[++i];\n } else if (arg.startsWith(\"--mcp=\")) {\n mcp = arg.slice(\"--mcp=\".length);\n } else if (arg === \"--client\" && argv[i + 1]) {\n client = argv[++i];\n } else if (arg.startsWith(\"--client=\")) {\n client = arg.slice(\"--client=\".length);\n }\n }\n return { mcp, client };\n}\n\nfunction cmdSetup(argv: string[]): void {\n const { mcp, client } = parseSetupArgs(argv);\n const targetMcp = mcp ?? \"pionex-trade-mcp\";\n if (targetMcp !== \"pionex-trade-mcp\") {\n process.stderr.write(`Unsupported MCP server: ${targetMcp}. Currently only 'pionex-trade-mcp' is supported.\\n`);\n process.exit(1);\n }\n if (!client) {\n process.stderr.write(\n \"Usage: pionex-ai-kit setup --mcp=pionex-trade-mcp --client <\" +\n SUPPORTED_CLIENTS.join(\"|\") +\n \">\\n\",\n );\n process.exit(1);\n }\n\n // Allow 'claude' as an alias for 'claude-code'\n const normalizedClient = client === \"claude\" ? \"claude-code\" : client;\n\n if (!SUPPORTED_CLIENTS.includes(normalizedClient as ClientId)) {\n process.stderr.write(\n `Unsupported client: ${client}. Supported: ${[...SUPPORTED_CLIENTS, \"claude (alias for claude-code)\"].join(\n \", \",\n )}\\n`,\n );\n process.exit(1);\n }\n\n runSetup({ client: normalizedClient as ClientId });\n}\n\ntype FlagValue = string | boolean;\n\nfunction parseFlags(argv: string[]): { positionals: string[]; flags: Record<string, FlagValue> } {\n const positionals: string[] = [];\n const flags: Record<string, FlagValue> = {};\n\n for (let i = 0; i < argv.length; i++) {\n const a = argv[i];\n if (!a.startsWith(\"--\")) {\n positionals.push(a);\n continue;\n }\n const eq = a.indexOf(\"=\");\n if (eq !== -1) {\n const k = a.slice(2, eq);\n const v = a.slice(eq + 1);\n flags[k] = v === \"true\" ? true : v === \"false\" ? false : v;\n continue;\n }\n const k = a.slice(2);\n const next = argv[i + 1];\n if (!next || next.startsWith(\"--\")) {\n flags[k] = true;\n continue;\n }\n flags[k] = next;\n i++;\n }\n\n return { positionals, flags };\n}\n\nfunction printPionexHelp(): void {\n process.stdout.write(`\nUsage: pionex-trade-cli <group> <command> [args] [--flags]\n\nGroups:\n market Market data (public)\n account Account data (requires auth)\n orders Spot orders (requires auth)\n bot Bot commands (requires auth) — use sub-route futures_grid (more bot types may be added later)\n\nExamples:\n pionex-trade-cli market depth BTC_USDT --limit 5\n pionex-trade-cli market tickers --symbol BTC_USDT\n pionex-trade-cli market symbols --symbols BTC_USDT\n pionex-trade-cli account balance\n pionex-trade-cli orders new --symbol BTC_USDT --side BUY --type MARKET --amount 10\n pionex-trade-cli orders cancel --symbol BTC_USDT --order-id 123\n pionex-trade-cli bot futures_grid get --bu-order-id <id>\n pionex-trade-cli bot futures_grid create --base BTC --quote USDT --bu-order-data-json '{\"top\":\"110000\",\"bottom\":\"90000\",\"row\":100,\"grid_type\":\"arithmetic\",\"trend\":\"long\",\"leverage\":5,\"quoteInvestment\":\"100\"}'\n\nGlobal flags:\n --profile <name> Profile in ~/.pionex/config.toml\n --modules <list> Comma-separated modules (market,account,orders or all)\n --base-url <url> Override API base URL\n --read-only Disable write operations (orders new/cancel)\n --dry-run Print resolved futures-grid create body without executing (bot futures_grid create only)\n\nFutures grid create (pionex-trade-cli bot futures_grid create) — strict OpenAPI (same validation as MCP):\n --base Required; normalized to <BASE>.PERP if suffix missing\n --quote Required (e.g. USDT)\n --bu-order-data-json Required JSON object — ONLY keys from CreateFuturesGridOrderData in openapi_bot.yaml\n Optional: --copy-from, --copy-type, --copy-bot-order-id\n buOrderData required: top, bottom, row, grid_type, trend, leverage, quoteInvestment\n buOrderData optional (names only): extraMargin, condition, conditionDirection, lossStopType, lossStop,\n lossStopDelay, profitStopType, profitStop, profitStopDelay, lossStopHigh, shareRatio, investCoin,\n investmentFrom, uiInvestCoin, lossStopLimitPrice, lossStopLimitHighPrice, profitStopLimitPrice,\n slippage, bonusId, uiExtraData, movingIndicatorType, movingIndicatorInterval, movingIndicatorParam,\n movingTrailingUpParam, cateType, movingTop, movingBottom, enableFollowClosed\n Unknown keys → error\n YAML: https://github.com/pionex-official/pionex-open-api/blob/main/openapi_bot.yaml\n Docs: https://www.pionex.com/docs/api-docs/bot-api/futures-grid\n`);\n}\n\nfunction parseJsonFlag(raw: unknown, flagName: string): Record<string, unknown> {\n if (typeof raw !== \"string\") {\n throw new Error(`Missing required flag: --${flagName}`);\n }\n try {\n const parsed = JSON.parse(raw) as unknown;\n if (!parsed || typeof parsed !== \"object\" || Array.isArray(parsed)) {\n throw new Error(\"must be a JSON object\");\n }\n return parsed as Record<string, unknown>;\n } catch (e) {\n const msg = e instanceof Error ? e.message : String(e);\n throw new Error(`Invalid --${flagName}: ${msg}`);\n }\n}\n\nasync function runPionexCommand(argv: string[]): Promise<void> {\n const { positionals, flags } = parseFlags(argv);\n const group = positionals[0];\n /** For \\`bot\\` group, positionals are: bot <sub-route> <command> ... */\n const command = group === \"bot\" ? positionals[2] : positionals[1];\n\n if (!group || group === \"help\" || group === \"--help\" || group === \"-h\") {\n printPionexHelp();\n return;\n }\n\n const config = loadConfig({\n profile: typeof flags.profile === \"string\" ? flags.profile : undefined,\n modules: typeof flags.modules === \"string\" ? flags.modules : undefined,\n baseUrl: typeof flags[\"base-url\"] === \"string\" ? (flags[\"base-url\"] as string) : typeof flags.baseUrl === \"string\" ? (flags.baseUrl as string) : undefined,\n readOnly: Boolean(flags[\"read-only\"] || flags.readOnly),\n });\n\n const client = new PionexRestClient(config);\n const runTool = createToolRunner(client, config);\n\n const dryRun = Boolean(flags[\"dry-run\"] || flags.dryRun);\n\n // market\n if (group === \"market\") {\n if (command === \"depth\") {\n const symbol = positionals[2];\n if (!symbol) throw new Error(\"Missing symbol. Example: pionex-trade-cli market depth BTC_USDT\");\n const limit = flags.limit != null ? Number(flags.limit) : undefined;\n const out = await runTool(\"pionex_market_get_depth\", { symbol, limit });\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"trades\") {\n const symbol = positionals[2];\n if (!symbol) throw new Error(\"Missing symbol. Example: pionex-trade-cli market trades BTC_USDT\");\n const limit = flags.limit != null ? Number(flags.limit) : undefined;\n const out = await runTool(\"pionex_market_get_trades\", { symbol, limit });\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"symbols\") {\n const symbols = typeof flags.symbols === \"string\" ? flags.symbols : undefined;\n const type = typeof flags.type === \"string\" ? flags.type : undefined;\n const out = await runTool(\"pionex_market_get_symbol_info\", { symbols, type });\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"tickers\") {\n const symbol = typeof flags.symbol === \"string\" ? flags.symbol : undefined;\n const type = typeof flags.type === \"string\" ? flags.type : undefined;\n const out = await runTool(\"pionex_market_get_tickers\", { symbol, type });\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"klines\") {\n const symbol = typeof flags.symbol === \"string\" ? flags.symbol : positionals[2];\n const interval = typeof flags.interval === \"string\" ? flags.interval : positionals[3];\n if (!symbol || !interval) throw new Error(\"Missing symbol/interval. Example: pionex-trade-cli market klines BTC_USDT 60M\");\n const endTime = flags.endTime != null ? Number(flags.endTime) : undefined;\n const limit = flags.limit != null ? Number(flags.limit) : undefined;\n const out = await runTool(\"pionex_market_get_klines\", { symbol, interval, endTime, limit });\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n throw new Error(`Unknown market command: ${command}`);\n }\n\n // account\n if (group === \"account\") {\n if (command === \"balance\") {\n const out = await runTool(\"pionex_account_get_balance\", {});\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n throw new Error(`Unknown account command: ${command}`);\n }\n\n // orders\n if (group === \"orders\") {\n if (command === \"new\") {\n const symbol = typeof flags.symbol === \"string\" ? flags.symbol : undefined;\n const side = typeof flags.side === \"string\" ? flags.side : undefined;\n const type = typeof flags.type === \"string\" ? flags.type : undefined;\n const clientOrderId = typeof flags[\"client-order-id\"] === \"string\" ? (flags[\"client-order-id\"] as string) : typeof flags.clientOrderId === \"string\" ? (flags.clientOrderId as string) : undefined;\n const size = typeof flags.size === \"string\" ? flags.size : undefined;\n const price = typeof flags.price === \"string\" ? flags.price : undefined;\n const amount = typeof flags.amount === \"string\" ? flags.amount : undefined;\n const IOC = typeof flags.IOC === \"boolean\" ? flags.IOC : undefined;\n if (!symbol || !side || !type) throw new Error(\"Missing required flags: --symbol --side --type\");\n const payload = { symbol, side, type, clientOrderId, size, price, amount, IOC };\n if (dryRun) {\n process.stdout.write(JSON.stringify({ tool: \"pionex_orders_new_order\", args: payload }, null, 2) + \"\\n\");\n return;\n }\n const out = await runTool(\"pionex_orders_new_order\", payload);\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"get\") {\n const symbol = typeof flags.symbol === \"string\" ? flags.symbol : undefined;\n const orderId = flags[\"order-id\"] != null ? Number(flags[\"order-id\"]) : undefined;\n if (!symbol || orderId == null) throw new Error(\"Missing required flags: --symbol --order-id\");\n const out = await runTool(\"pionex_orders_get_order\", { symbol, orderId });\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"open\") {\n const symbol = typeof flags.symbol === \"string\" ? flags.symbol : undefined;\n if (!symbol) throw new Error(\"Missing required flag: --symbol\");\n const out = await runTool(\"pionex_orders_get_open_orders\", { symbol });\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"all\") {\n const symbol = typeof flags.symbol === \"string\" ? flags.symbol : undefined;\n const limit = flags.limit != null ? Number(flags.limit) : undefined;\n if (!symbol) throw new Error(\"Missing required flag: --symbol\");\n const out = await runTool(\"pionex_orders_get_all_orders\", { symbol, limit });\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"fills\") {\n const symbol = typeof flags.symbol === \"string\" ? flags.symbol : undefined;\n const startTime = flags.startTime != null ? Number(flags.startTime) : undefined;\n const endTime = flags.endTime != null ? Number(flags.endTime) : undefined;\n if (!symbol) throw new Error(\"Missing required flag: --symbol\");\n const out = await runTool(\"pionex_orders_get_fills\", { symbol, startTime, endTime });\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"cancel\") {\n const symbol = typeof flags.symbol === \"string\" ? flags.symbol : undefined;\n const orderId = flags[\"order-id\"] != null ? Number(flags[\"order-id\"]) : undefined;\n if (!symbol || orderId == null) throw new Error(\"Missing required flags: --symbol --order-id\");\n const payload = { symbol, orderId };\n if (dryRun) {\n process.stdout.write(JSON.stringify({ tool: \"pionex_orders_cancel_order\", args: payload }, null, 2) + \"\\n\");\n return;\n }\n const out = await runTool(\"pionex_orders_cancel_order\", payload);\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"cancel-all\") {\n const symbol = typeof flags.symbol === \"string\" ? flags.symbol : undefined;\n if (!symbol) throw new Error(\"Missing required flag: --symbol\");\n const payload = { symbol };\n if (dryRun) {\n process.stdout.write(JSON.stringify({ tool: \"pionex_orders_cancel_all_orders\", args: payload }, null, 2) + \"\\n\");\n return;\n }\n const out = await runTool(\"pionex_orders_cancel_all_orders\", payload);\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n throw new Error(`Unknown orders command: ${command}`);\n }\n\n // bot\n if (group === \"bot\") {\n const botRoute = positionals[1];\n if (!botRoute || botRoute !== \"futures_grid\") {\n throw new Error(\n `Missing or unknown bot route: ${botRoute ?? \"(none)\"}. Use: pionex-trade-cli bot futures_grid <get|create|adjust_params|reduce|cancel> ...`\n );\n }\n if (!command) {\n throw new Error(\n \"Missing bot command. Example: pionex-trade-cli bot futures_grid create --base BTC --quote USDT --bu-order-data-json '{...}'\"\n );\n }\n if (command === \"get\") {\n const buOrderId =\n typeof flags[\"bu-order-id\"] === \"string\"\n ? (flags[\"bu-order-id\"] as string)\n : typeof flags.buOrderId === \"string\"\n ? (flags.buOrderId as string)\n : undefined;\n const lang = typeof flags.lang === \"string\" ? flags.lang : undefined;\n if (!buOrderId) throw new Error(\"Missing required flag: --bu-order-id\");\n const out = await runTool(\"pionex_bot_futures_grid_get_order\", { buOrderId, lang });\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"create\") {\n const base = typeof flags.base === \"string\" ? flags.base : undefined;\n const quote = typeof flags.quote === \"string\" ? flags.quote : undefined;\n const copyFrom = typeof flags[\"copy-from\"] === \"string\" ? (flags[\"copy-from\"] as string) : typeof flags.copyFrom === \"string\" ? (flags.copyFrom as string) : undefined;\n const copyType = typeof flags[\"copy-type\"] === \"string\" ? (flags[\"copy-type\"] as string) : typeof flags.copyType === \"string\" ? (flags.copyType as string) : undefined;\n const copyBotOrderId =\n typeof flags[\"copy-bot-order-id\"] === \"string\"\n ? (flags[\"copy-bot-order-id\"] as string)\n : typeof flags.copyBotOrderId === \"string\"\n ? (flags.copyBotOrderId as string)\n : undefined;\n const buOrderDataRaw = parseJsonFlag(flags[\"bu-order-data-json\"] ?? flags.buOrderDataJson, \"bu-order-data-json\");\n if (!base || !quote) {\n throw new Error(\"Missing required flags: --base --quote --bu-order-data-json\");\n }\n const buOrderData = parseAndValidateCreateFuturesGridBuOrderData(buOrderDataRaw);\n const payload: Record<string, unknown> = { base, quote, copyFrom, copyType, copyBotOrderId, buOrderData };\n if (dryRun) {\n const out = await runTool(\"pionex_bot_futures_grid_create\", { ...payload, __dryRun: true });\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n const out = await runTool(\"pionex_bot_futures_grid_create\", payload);\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"adjust_params\") {\n const payload = parseJsonFlag(flags[\"body-json\"] ?? flags.bodyJson, \"body-json\");\n if (dryRun) {\n process.stdout.write(JSON.stringify({ tool: \"pionex_bot_futures_grid_adjust_params\", args: payload }, null, 2) + \"\\n\");\n return;\n }\n const out = await runTool(\"pionex_bot_futures_grid_adjust_params\", payload);\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"reduce\") {\n const payload = parseJsonFlag(flags[\"body-json\"] ?? flags.bodyJson, \"body-json\");\n if (dryRun) {\n process.stdout.write(JSON.stringify({ tool: \"pionex_bot_futures_grid_reduce\", args: payload }, null, 2) + \"\\n\");\n return;\n }\n const out = await runTool(\"pionex_bot_futures_grid_reduce\", payload);\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"cancel\") {\n const buOrderId =\n typeof flags[\"bu-order-id\"] === \"string\"\n ? (flags[\"bu-order-id\"] as string)\n : typeof flags.buOrderId === \"string\"\n ? (flags.buOrderId as string)\n : undefined;\n const closeNote = typeof flags[\"close-note\"] === \"string\" ? (flags[\"close-note\"] as string) : typeof flags.closeNote === \"string\" ? (flags.closeNote as string) : undefined;\n const closeSellModel =\n typeof flags[\"close-sell-model\"] === \"string\"\n ? (flags[\"close-sell-model\"] as string)\n : typeof flags.closeSellModel === \"string\"\n ? (flags.closeSellModel as string)\n : undefined;\n const immediate = typeof flags.immediate === \"boolean\" ? flags.immediate : undefined;\n const closeSlippage =\n typeof flags[\"close-slippage\"] === \"string\"\n ? (flags[\"close-slippage\"] as string)\n : typeof flags.closeSlippage === \"string\"\n ? (flags.closeSlippage as string)\n : undefined;\n if (!buOrderId) throw new Error(\"Missing required flag: --bu-order-id\");\n const payload = { buOrderId, closeNote, closeSellModel, immediate, closeSlippage };\n if (dryRun) {\n process.stdout.write(JSON.stringify({ tool: \"pionex_bot_futures_grid_cancel\", args: payload }, null, 2) + \"\\n\");\n return;\n }\n const out = await runTool(\"pionex_bot_futures_grid_cancel\", payload);\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n throw new Error(`Unknown futures_grid command: ${command}`);\n }\n\n throw new Error(`Unknown group: ${group}`);\n}\n\nfunction main(): void {\n const invokedAs = basename(process.argv[1] || \"\");\n const cmd = process.argv[2];\n\n // Backwards-compatible: keep \"pionex-ai-kit onboard/setup/help\"\n if (invokedAs.includes(\"pionex-ai-kit\")) {\n if (cmd === \"onboard\") {\n cmdOnboard().catch((e) => {\n process.stderr.write(String(e) + \"\\n\");\n process.exit(1);\n });\n return;\n }\n if (cmd === \"setup\") {\n cmdSetup(process.argv.slice(3));\n return;\n }\n if (cmd === \"help\" || cmd === \"--help\" || cmd === \"-h\" || !cmd) {\n printHelp();\n return;\n }\n process.stderr.write(\"Unknown command: \" + cmd + \". Run 'pionex-ai-kit help'.\\n\");\n process.exit(1);\n return;\n }\n\n // New: \"pionex-trade-cli <group> <command> ...\"\n runPionexCommand(process.argv.slice(2)).catch((e) => {\n const payload = toToolErrorPayload(e);\n process.stderr.write(JSON.stringify(payload, null, 2) + \"\\n\");\n process.exit(1);\n });\n}\n\nmain();\n","import { readFileSync, writeFileSync, mkdirSync, existsSync } from \"node:fs\";\nimport { join, dirname } from \"node:path\";\nimport { homedir } from \"node:os\";\nimport { parse, stringify } from \"smol-toml\";\n\nexport { stringify as tomlStringify };\n\nexport interface PionexProfile {\n api_key?: string;\n secret_key?: string;\n base_url?: string;\n}\n\nexport interface PionexTomlConfig {\n default_profile?: string;\n profiles: Record<string, PionexProfile>;\n}\n\n/** Fixed path: ~/.pionex/config.toml */\nexport function configFilePath(): string {\n return join(homedir(), \".pionex\", \"config.toml\");\n}\n\nexport function readFullConfig(): PionexTomlConfig {\n const path = configFilePath();\n if (!existsSync(path)) return { profiles: {} };\n const raw = readFileSync(path, \"utf-8\");\n return parse(raw) as unknown as PionexTomlConfig;\n}\n\nexport function readTomlProfile(profileName?: string): PionexProfile {\n const config = readFullConfig();\n const name = profileName ?? config.default_profile ?? \"default\";\n return config.profiles?.[name] ?? {};\n}\n\nexport function writeFullConfig(config: PionexTomlConfig): void {\n const path = configFilePath();\n const dir = dirname(path);\n if (!existsSync(dir)) {\n mkdirSync(dir, { recursive: true });\n }\n writeFileSync(path, stringify(config as unknown as Record<string, unknown>), \"utf-8\");\n}\n","import * as fs from \"node:fs\";\nimport * as path from \"node:path\";\nimport * as os from \"node:os\";\nimport { execFileSync } from \"node:child_process\";\nimport { configFilePath } from \"./config/toml.js\";\n\nexport type ClientId = \"claude-desktop\" | \"cursor\" | \"windsurf\" | \"vscode\" | \"claude-code\" | \"openclaw\";\n\nconst CLIENT_NAMES: Record<ClientId, string> = {\n \"claude-desktop\": \"Claude Desktop\",\n cursor: \"Cursor\",\n windsurf: \"Windsurf\",\n vscode: \"VS Code\",\n \"claude-code\": \"Claude Code CLI\",\n openclaw: \"OpenClaw (mcporter)\",\n};\n\nexport const SUPPORTED_CLIENTS = Object.keys(CLIENT_NAMES) as ClientId[];\n\nfunction appData(): string {\n return process.env.APPDATA ?? path.join(os.homedir(), \"AppData\", \"Roaming\");\n}\n\nconst CLAUDE_CONFIG_FILE = \"claude_desktop_config.json\";\n\nfunction findMsStoreClaudePath(): string | null {\n const localAppData = process.env.LOCALAPPDATA ?? path.join(os.homedir(), \"AppData\", \"Local\");\n const packagesDir = path.join(localAppData, \"Packages\");\n try {\n const entries = fs.readdirSync(packagesDir);\n const claudePkg = entries.find((e) => e.startsWith(\"Claude_\"));\n if (claudePkg) {\n const configPath = path.join(\n packagesDir,\n claudePkg,\n \"LocalCache\",\n \"Roaming\",\n \"Claude\",\n CLAUDE_CONFIG_FILE,\n );\n if (fs.existsSync(configPath) || fs.existsSync(path.dirname(configPath))) {\n return configPath;\n }\n }\n } catch {\n // ignore missing or unreadable Packages dir\n }\n return null;\n}\n\nexport function getConfigPath(client: ClientId): string | null {\n const home = os.homedir();\n const platform = process.platform;\n switch (client) {\n case \"claude-desktop\":\n if (platform === \"win32\") {\n return findMsStoreClaudePath() ?? path.join(appData(), \"Claude\", CLAUDE_CONFIG_FILE);\n }\n if (platform === \"darwin\") {\n return path.join(home, \"Library\", \"Application Support\", \"Claude\", CLAUDE_CONFIG_FILE);\n }\n return path.join(process.env.XDG_CONFIG_HOME ?? path.join(home, \".config\"), \"Claude\", CLAUDE_CONFIG_FILE);\n case \"cursor\":\n return path.join(home, \".cursor\", \"mcp.json\");\n case \"windsurf\":\n return path.join(home, \".codeium\", \"windsurf\", \"mcp_config.json\");\n case \"vscode\":\n return path.join(process.cwd(), \".mcp.json\");\n case \"claude-code\":\n return null;\n case \"openclaw\":\n return path.join(home, \".openclaw\", \"workspace\", \"config\", \"mcporter.json\");\n }\n}\n\nconst NPX_PACKAGE = \"@pionex/pionex-trade-mcp\";\n\nfunction buildEntry(client: ClientId): Record<string, unknown> {\n if (client === \"vscode\") {\n // VS Code MCP expects an explicit stdio transport field.\n return { type: \"stdio\", command: \"npx\", args: [\"-y\", NPX_PACKAGE] };\n }\n // Other clients (Cursor, Claude Desktop, Windsurf, OpenClaw, etc.) use npx\n // with the scoped package name so that users do not need to manage PATH.\n return { command: \"npx\", args: [\"-y\", NPX_PACKAGE] };\n}\n\nfunction mergeJsonConfig(\n configPath: string,\n serverName: string,\n entry: Record<string, unknown>\n): void {\n const dir = path.dirname(configPath);\n if (!fs.existsSync(dir)) fs.mkdirSync(dir, { recursive: true });\n\n let data: Record<string, unknown> = {};\n if (fs.existsSync(configPath)) {\n const raw = fs.readFileSync(configPath, \"utf-8\");\n try {\n data = JSON.parse(raw) as Record<string, unknown>;\n } catch {\n throw new Error(`Failed to parse existing config at ${configPath}`);\n }\n }\n\n if (typeof data.mcpServers !== \"object\" || data.mcpServers === null) {\n data.mcpServers = {};\n }\n (data.mcpServers as Record<string, unknown>)[serverName] = entry;\n\n fs.writeFileSync(configPath, JSON.stringify(data, null, 2) + \"\\n\", \"utf-8\");\n}\n\nexport interface SetupOptions {\n client: ClientId;\n}\n\nexport function runSetup(options: SetupOptions): void {\n const { client } = options;\n const name = CLIENT_NAMES[client];\n const serverName = \"pionex-trade-mcp\";\n\n if (client === \"claude-code\") {\n const claudeArgs = [\n \"mcp\",\n \"add\",\n \"--scope\",\n \"user\",\n \"--transport\",\n \"stdio\",\n serverName,\n \"--\",\n \"npx\",\n \"-y\",\n NPX_PACKAGE,\n ];\n process.stdout.write(`Running: claude ${claudeArgs.join(\" \")}\\n`);\n execFileSync(\"claude\", claudeArgs, { stdio: \"inherit\" });\n process.stdout.write(`✓ Configured ${name}\\n`);\n return;\n }\n\n const configPath = getConfigPath(client);\n if (!configPath) {\n throw new Error(`${name} is not supported on this platform`);\n }\n\n const entry = buildEntry(client);\n mergeJsonConfig(configPath, serverName, entry);\n process.stdout.write(\n `✓ Configured ${name}\\n ${configPath}\\n Restart ${name} to apply changes.\\n`\n );\n}\n\nexport function printSetupUsage(): void {\n process.stdout.write(\n `Usage: pionex-trade-mcp setup --client <client>\\n\\n` +\n `Clients:\\n` +\n SUPPORTED_CLIENTS.map((id) => ` ${id.padEnd(16)} ${CLIENT_NAMES[id]}`).join(\"\\n\") +\n `\\n\\nCredentials are read from ${configFilePath()}. Run \"pionex-ai-kit config init\" (from pionex-ai-kit) first.\\n`\n );\n}\n","export const PIONEX_API_DEFAULT_BASE_URL = \"https://api.pionex.com\";\n\nexport const MODULES = [\"market\", \"account\", \"orders\", \"bot\"] as const;\nexport type ModuleId = (typeof MODULES)[number];\n\nexport const DEFAULT_MODULES: ModuleId[] = [\"market\", \"account\", \"orders\", \"bot\"];\n\n","export class ConfigError extends Error {\n public readonly suggestion?: string;\n public constructor(message: string, suggestion?: string) {\n super(message);\n this.name = \"ConfigError\";\n this.suggestion = suggestion;\n }\n}\n\nexport class PionexApiError extends Error {\n public readonly status?: number;\n public readonly endpoint?: string;\n public readonly responseText?: string;\n public constructor(\n message: string,\n opts?: { status?: number; endpoint?: string; responseText?: string },\n ) {\n super(message);\n this.name = \"PionexApiError\";\n this.status = opts?.status;\n this.endpoint = opts?.endpoint;\n this.responseText = opts?.responseText;\n }\n}\n\nexport function toToolErrorPayload(error: unknown): Record<string, unknown> {\n if (error instanceof ConfigError) {\n return {\n error: true,\n type: \"ConfigError\",\n message: error.message,\n suggestion: error.suggestion,\n };\n }\n if (error instanceof PionexApiError) {\n return {\n error: true,\n type: \"PionexApiError\",\n message: error.message,\n status: error.status,\n endpoint: error.endpoint,\n responseText: error.responseText,\n };\n }\n const message = error instanceof Error ? error.message : String(error);\n return { error: true, type: \"Error\", message };\n}\n\n","import { readTomlProfile } from \"./config/toml.js\";\nimport { PIONEX_API_DEFAULT_BASE_URL, DEFAULT_MODULES, MODULES, type ModuleId } from \"./constants.js\";\nimport { ConfigError } from \"./utils/errors.js\";\n\nexport interface CliOptions {\n modules?: string;\n readOnly: boolean;\n profile?: string;\n baseUrl?: string;\n}\n\nexport interface PionexConfig {\n apiKey?: string;\n apiSecret?: string;\n hasAuth: boolean;\n baseUrl: string;\n modules: ModuleId[];\n readOnly: boolean;\n}\n\nfunction parseModuleList(rawModules?: string): ModuleId[] {\n if (!rawModules || rawModules.trim().length === 0) return [...DEFAULT_MODULES];\n const trimmed = rawModules.trim().toLowerCase();\n if (trimmed === \"all\") return [...MODULES];\n\n const requested = trimmed\n .split(\",\")\n .map((x) => x.trim())\n .filter(Boolean);\n if (requested.length === 0) return [...DEFAULT_MODULES];\n\n const out: ModuleId[] = [];\n for (const m of requested) {\n if (!MODULES.includes(m as ModuleId)) {\n throw new ConfigError(`Unknown module \"${m}\".`, `Use one of: ${MODULES.join(\", \")} or \"all\".`);\n }\n out.push(m as ModuleId);\n }\n return Array.from(new Set(out));\n}\n\n/**\n * Credential priority (highest to lowest):\n * 1. Environment variables (PIONEX_API_KEY / PIONEX_API_SECRET)\n * 2. ~/.pionex/config.toml profile values\n */\nexport function loadConfig(cli: CliOptions): PionexConfig {\n const toml = readTomlProfile(cli.profile);\n\n const apiKey = process.env.PIONEX_API_KEY?.trim() || toml.api_key;\n const apiSecret = process.env.PIONEX_API_SECRET?.trim() || toml.secret_key;\n\n const hasAuth = Boolean(apiKey && apiSecret);\n const partialAuth = Boolean(apiKey) || Boolean(apiSecret);\n if (partialAuth && !hasAuth) {\n throw new ConfigError(\n \"Partial Pionex API credentials detected.\",\n \"Set both PIONEX_API_KEY and PIONEX_API_SECRET (env vars or config.toml profile).\",\n );\n }\n\n const baseUrl = (cli.baseUrl?.trim() || process.env.PIONEX_BASE_URL?.trim() || toml.base_url || PIONEX_API_DEFAULT_BASE_URL)\n .replace(/\\/+$/, \"\");\n if (!baseUrl.startsWith(\"http://\") && !baseUrl.startsWith(\"https://\")) {\n throw new ConfigError(`Invalid base URL \"${baseUrl}\".`, \"PIONEX_BASE_URL must start with http:// or https://\");\n }\n\n return {\n apiKey,\n apiSecret,\n hasAuth,\n baseUrl,\n modules: parseModuleList(cli.modules),\n readOnly: cli.readOnly,\n };\n}\n\n","import crypto from \"node:crypto\";\nimport type { PionexConfig } from \"../config.js\";\nimport { PionexApiError, ConfigError } from \"../utils/errors.js\";\nimport type { HttpMethod, QueryParams, RequestResult } from \"./types.js\";\n\nfunction requireAuth(config: PionexConfig): { apiKey: string; apiSecret: string } {\n if (!config.apiKey || !config.apiSecret) {\n throw new ConfigError(\n \"This operation requires authentication, but no Pionex API credentials were found.\",\n \"Run 'pionex-ai-kit onboard' to create ~/.pionex/config.toml, or set PIONEX_API_KEY and PIONEX_API_SECRET.\",\n );\n }\n return { apiKey: config.apiKey, apiSecret: config.apiSecret };\n}\n\nfunction buildQueryString(query?: QueryParams): string {\n if (!query) return \"\";\n const entries = Object.entries(query).filter(([, v]) => v !== undefined && v !== null);\n if (entries.length === 0) return \"\";\n const params = new URLSearchParams();\n for (const [k, v] of entries) params.set(k, String(v));\n return params.toString();\n}\n\nfunction buildSignedRequest(\n config: PionexConfig,\n method: HttpMethod,\n path: string,\n query: QueryParams,\n bodyJson: string | null,\n): { url: string; headers: Record<string, string>; bodyJson: string | null } {\n const { apiKey, apiSecret } = requireAuth(config);\n const timestamp = Date.now().toString();\n const params: Record<string, unknown> = { ...query, timestamp };\n\n const sortedKeys = Object.keys(params).sort();\n const queryString = sortedKeys.map((k) => `${k}=${params[k]}`).join(\"&\");\n const pathUrl = `${path}?${queryString}`;\n\n let payload = `${method}${pathUrl}`;\n if (bodyJson != null) payload += bodyJson;\n const signature = crypto.createHmac(\"sha256\", apiSecret).update(payload).digest(\"hex\");\n\n const url = `${config.baseUrl}${pathUrl}`;\n const headers = {\n \"PIONEX-KEY\": apiKey,\n \"PIONEX-SIGNATURE\": signature,\n \"Content-Type\": \"application/json\",\n };\n return { url, headers, bodyJson };\n}\n\nasync function readTextSafe(res: Response): Promise<string> {\n try {\n return await res.text();\n } catch {\n return \"\";\n }\n}\n\nexport class PionexRestClient {\n private readonly config: PionexConfig;\n public constructor(config: PionexConfig) {\n this.config = config;\n }\n\n public async publicGet<TData = unknown>(path: string, query: QueryParams = {}): Promise<RequestResult<TData>> {\n const qs = buildQueryString(query);\n const endpoint = qs ? `${path}?${qs}` : path;\n const url = `${this.config.baseUrl}${endpoint}`;\n const res = await fetch(url, { method: \"GET\", headers: { \"Content-Type\": \"application/json\" } });\n if (!res.ok) {\n const txt = await readTextSafe(res);\n throw new PionexApiError(`HTTP ${res.status}: ${txt || res.statusText}`, { status: res.status, endpoint, responseText: txt });\n }\n const data = (await res.json()) as TData;\n return { endpoint, requestTime: new Date().toISOString(), data };\n }\n\n public async signedGet<TData = unknown>(path: string, query: QueryParams = {}): Promise<RequestResult<TData>> {\n const { url, headers } = buildSignedRequest(this.config, \"GET\", path, query, null);\n const endpoint = `${path}?${buildQueryString({ ...query, timestamp: \"...\" })}`;\n const res = await fetch(url, { method: \"GET\", headers });\n if (!res.ok) {\n const txt = await readTextSafe(res);\n throw new PionexApiError(`HTTP ${res.status}: ${txt || res.statusText}`, { status: res.status, endpoint: path, responseText: txt });\n }\n const data = (await res.json()) as TData;\n return { endpoint: path, requestTime: new Date().toISOString(), data };\n }\n\n public async signedPost<TData = unknown>(path: string, body: Record<string, unknown>): Promise<RequestResult<TData>> {\n const bodyJson = JSON.stringify(body);\n const { url, headers, bodyJson: bj } = buildSignedRequest(this.config, \"POST\", path, {}, bodyJson);\n const res = await fetch(url, { method: \"POST\", headers, body: bj ?? undefined });\n if (!res.ok) {\n const txt = await readTextSafe(res);\n throw new PionexApiError(`HTTP ${res.status}: ${txt || res.statusText}`, { status: res.status, endpoint: path, responseText: txt });\n }\n const data = (await res.json()) as TData;\n return { endpoint: path, requestTime: new Date().toISOString(), data };\n }\n\n public async signedDelete<TData = unknown>(path: string, body: Record<string, unknown>): Promise<RequestResult<TData>> {\n const bodyJson = JSON.stringify(body);\n const { url, headers, bodyJson: bj } = buildSignedRequest(this.config, \"DELETE\", path, {}, bodyJson);\n const res = await fetch(url, { method: \"DELETE\", headers, body: bj ?? undefined });\n if (!res.ok) {\n const txt = await readTextSafe(res);\n throw new PionexApiError(`HTTP ${res.status}: ${txt || res.statusText}`, { status: res.status, endpoint: path, responseText: txt });\n }\n const data = (await res.json()) as TData;\n return { endpoint: path, requestTime: new Date().toISOString(), data };\n }\n}\n\n","import type { ToolSpec } from \"./types.js\";\nimport type { QueryParams } from \"../client/types.js\";\n\nexport function registerMarketTools(): ToolSpec[] {\n return [\n {\n name: \"pionex_market_get_depth\",\n module: \"market\",\n isWrite: false,\n description: \"Get order book depth (bids and asks) for a symbol. Use for spread, liquidity, or best bid/ask.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n limit: { type: \"integer\", description: \"Price levels (1-100), default 5\" },\n },\n required: [\"symbol\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const limit = args.limit == null ? undefined : Number(args.limit);\n const q: QueryParams = { symbol };\n if (limit != null && Number.isFinite(limit)) q.limit = limit;\n return (await client.publicGet(\"/api/v1/market/depth\", q)).data;\n },\n },\n {\n name: \"pionex_market_get_trades\",\n module: \"market\",\n isWrite: false,\n description: \"Get recent trades for a symbol. Use for latest price and volume.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n limit: { type: \"integer\", description: \"Default 5 (1-100)\" },\n },\n required: [\"symbol\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const limit = args.limit == null ? undefined : Number(args.limit);\n const q: QueryParams = { symbol };\n if (limit != null && Number.isFinite(limit)) q.limit = limit;\n return (await client.publicGet(\"/api/v1/market/trades\", q)).data;\n },\n },\n {\n name: \"pionex_market_get_symbol_info\",\n module: \"market\",\n isWrite: false,\n description:\n \"Get symbol metadata (precision, min size, price limits). Call before placing orders to avoid amount/size filter errors.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbols: {\n type: \"string\",\n description: 'Optional. One or more symbols, comma-separated, e.g. \"BTC_USDT\" or \"BTC_USDT,ADA_USDT\".',\n },\n type: {\n type: \"string\",\n enum: [\"SPOT\", \"PERP\"],\n description: \"Optional. If no symbols are specified, filter by type (default SPOT).\",\n },\n },\n },\n async handler(args, { client }) {\n const q: QueryParams = {};\n if (args.symbols) q.symbols = String(args.symbols);\n if (!args.symbols && args.type) q.type = String(args.type);\n return (await client.publicGet(\"/api/v1/common/symbols\", q)).data;\n },\n },\n {\n name: \"pionex_market_get_tickers\",\n module: \"market\",\n isWrite: false,\n description: \"Get 24-hour ticker(s): open, close, high, low, volume, amount, count. Optional symbol or type (SPOT/PERP).\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT; if omitted, returns all tickers filtered by type\" },\n type: { type: \"string\", enum: [\"SPOT\", \"PERP\"], description: \"If symbol is not specified, filter by type.\" },\n },\n },\n async handler(args, { client }) {\n const q: QueryParams = {};\n if (args.symbol) q.symbol = String(args.symbol);\n if (args.type) q.type = String(args.type);\n return (await client.publicGet(\"/api/v1/market/tickers\", q)).data;\n },\n },\n {\n name: \"pionex_market_get_klines\",\n module: \"market\",\n isWrite: false,\n description: \"Get OHLCV klines (candlestick) for a symbol. Use for charts or historical price/volume.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n interval: { type: \"string\", enum: [\"1M\", \"5M\", \"15M\", \"30M\", \"60M\", \"4H\", \"8H\", \"12H\", \"1D\"], description: \"Kline interval.\" },\n endTime: { type: \"integer\", description: \"End time in milliseconds.\" },\n limit: { type: \"integer\", description: \"Default 100 (1-500).\" },\n },\n required: [\"symbol\", \"interval\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const interval = String(args.interval);\n const q: QueryParams = { symbol, interval };\n if (args.endTime != null) q.endTime = Number(args.endTime);\n if (args.limit != null) q.limit = Number(args.limit);\n return (await client.publicGet(\"/api/v1/market/klines\", q)).data;\n },\n },\n ];\n}\n\n","import type { ToolSpec } from \"./types.js\";\n\nexport function registerAccountTools(): ToolSpec[] {\n return [\n {\n name: \"pionex_account_get_balance\",\n module: \"account\",\n isWrite: false,\n description: \"Query spot account balances for all currencies. Requires API key and secret in ~/.pionex/config.toml or env.\",\n inputSchema: { type: \"object\", additionalProperties: false, properties: {} },\n async handler(_args, { client }) {\n return (await client.signedGet(\"/api/v1/account/balances\")).data;\n },\n },\n ];\n}\n\n","import type { ToolSpec } from \"./types.js\";\nimport type { QueryParams } from \"../client/types.js\";\n\nexport function registerOrdersTools(): ToolSpec[] {\n return [\n {\n name: \"pionex_orders_new_order\",\n module: \"orders\",\n isWrite: true,\n description:\n \"Create a spot order on Pionex. LIMIT requires symbol/side/type=LIMIT/price/size. MARKET BUY requires amount (quote). MARKET SELL requires size (base).\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n side: { type: \"string\", enum: [\"BUY\", \"SELL\"] },\n type: { type: \"string\", enum: [\"LIMIT\", \"MARKET\"] },\n clientOrderId: { type: \"string\", description: \"Optional client order id (max 64 chars)\" },\n size: { type: \"string\", description: \"Quantity; required for limit and market sell\" },\n price: { type: \"string\", description: \"Required for limit order\" },\n amount: { type: \"string\", description: \"Quote amount; required for market buy\" },\n IOC: { type: \"boolean\", description: \"Immediate-or-cancel, default false\" },\n },\n required: [\"symbol\", \"side\", \"type\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; order placement is disabled.\");\n }\n const body: Record<string, unknown> = {};\n if (args.symbol != null) body.symbol = String(args.symbol);\n if (args.side != null) body.side = String(args.side);\n if (args.type != null) body.type = String(args.type);\n if (args.clientOrderId != null) body.clientOrderId = String(args.clientOrderId);\n if (args.size != null) body.size = String(args.size);\n if (args.price != null) body.price = String(args.price);\n if (args.amount != null) body.amount = String(args.amount);\n if (args.IOC != null) body.IOC = Boolean(args.IOC);\n return (await client.signedPost(\"/api/v1/trade/order\", body)).data;\n },\n },\n {\n name: \"pionex_orders_get_order\",\n module: \"orders\",\n isWrite: false,\n description: \"Get a single order by order ID.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n orderId: { type: \"integer\", description: \"Order id\" },\n },\n required: [\"symbol\", \"orderId\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const orderId = Number(args.orderId);\n return (await client.signedGet(\"/api/v1/trade/order\", { symbol, orderId })).data;\n },\n },\n {\n name: \"pionex_orders_get_order_by_client_order_id\",\n module: \"orders\",\n isWrite: false,\n description: \"Get a single order by client order ID.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n clientOrderId: { type: \"string\", description: \"Client order id\" },\n },\n required: [\"symbol\", \"clientOrderId\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const clientOrderId = String(args.clientOrderId);\n return (await client.signedGet(\"/api/v1/trade/orderByClientOrderId\", { symbol, clientOrderId })).data;\n },\n },\n {\n name: \"pionex_orders_get_open_orders\",\n module: \"orders\",\n isWrite: false,\n description: \"List open (unfilled) orders for a symbol.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: { symbol: { type: \"string\", description: \"e.g. BTC_USDT\" } },\n required: [\"symbol\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n return (await client.signedGet(\"/api/v1/trade/openOrders\", { symbol })).data;\n },\n },\n {\n name: \"pionex_orders_get_all_orders\",\n module: \"orders\",\n isWrite: false,\n description: \"List order history for a symbol (filled and cancelled), with optional limit.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n limit: { type: \"integer\", description: \"Default 1 (1-100)\" },\n },\n required: [\"symbol\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const q: QueryParams = { symbol };\n if (args.limit != null) q.limit = Number(args.limit);\n return (await client.signedGet(\"/api/v1/trade/allOrders\", q)).data;\n },\n },\n {\n name: \"pionex_orders_cancel_order\",\n module: \"orders\",\n isWrite: true,\n description: \"Cancel an open order by order ID.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n orderId: { type: \"integer\", description: \"Order id\" },\n },\n required: [\"symbol\", \"orderId\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; order cancellation is disabled.\");\n }\n const symbol = String(args.symbol);\n const orderId = Number(args.orderId);\n return (await client.signedDelete(\"/api/v1/trade/order\", { symbol, orderId })).data;\n },\n },\n {\n name: \"pionex_orders_get_fills\",\n module: \"orders\",\n isWrite: false,\n description: \"Get filled trades (fills) for a symbol in a time range. Requires API key. Returns up to 100 latest fills.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n startTime: { type: \"integer\", description: \"Start time in milliseconds.\" },\n endTime: { type: \"integer\", description: \"End time in milliseconds.\" },\n },\n required: [\"symbol\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const q: QueryParams = { symbol };\n if (args.startTime != null) q.startTime = Number(args.startTime);\n if (args.endTime != null) q.endTime = Number(args.endTime);\n return (await client.signedGet(\"/api/v1/trade/fills\", q)).data;\n },\n },\n {\n name: \"pionex_orders_cancel_all_orders\",\n module: \"orders\",\n isWrite: true,\n description: \"Cancel all open orders for a symbol.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: { symbol: { type: \"string\", description: \"e.g. BTC_USDT\" } },\n required: [\"symbol\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; cancel-all is disabled.\");\n }\n const symbol = String(args.symbol);\n return (await client.signedDelete(\"/api/v1/trade/allOrders\", { symbol })).data;\n },\n },\n ];\n}\n\n","/**\n * Mirrors openapi_bot.yaml — CreateFuturesGridRequest + CreateFuturesGridOrderData.\n * https://github.com/pionex-official/pionex-open-api/blob/main/openapi_bot.yaml\n */\nimport type { JsonSchema } from \"../tools/types.js\";\n\n/** Every property under CreateFuturesGridOrderData (OpenAPI); no other keys allowed. */\nexport const CREATE_FUTURES_GRID_ORDER_DATA_KEYS = [\n \"top\",\n \"bottom\",\n \"row\",\n \"grid_type\",\n \"trend\",\n \"leverage\",\n \"extraMargin\",\n \"quoteInvestment\",\n \"condition\",\n \"conditionDirection\",\n \"lossStopType\",\n \"lossStop\",\n \"lossStopDelay\",\n \"profitStopType\",\n \"profitStop\",\n \"profitStopDelay\",\n \"lossStopHigh\",\n \"shareRatio\",\n \"investCoin\",\n \"investmentFrom\",\n \"uiInvestCoin\",\n \"lossStopLimitPrice\",\n \"lossStopLimitHighPrice\",\n \"profitStopLimitPrice\",\n \"slippage\",\n \"bonusId\",\n \"uiExtraData\",\n \"movingIndicatorType\",\n \"movingIndicatorInterval\",\n \"movingIndicatorParam\",\n \"movingTrailingUpParam\",\n \"cateType\",\n \"movingTop\",\n \"movingBottom\",\n \"enableFollowClosed\",\n] as const;\n\nconst ORDER_DATA_KEY_SET = new Set<string>(CREATE_FUTURES_GRID_ORDER_DATA_KEYS);\n\nfunction asNonEmptyString(value: unknown, field: string): string {\n if (typeof value !== \"string\" || value.trim().length === 0) {\n throw new Error(`Invalid \"${field}\": expected non-empty string.`);\n }\n return value.trim();\n}\n\nfunction asFiniteNumber(value: unknown, field: string): number {\n if (typeof value !== \"number\" || !Number.isFinite(value)) {\n throw new Error(`Invalid \"${field}\": expected finite number.`);\n }\n return value;\n}\n\nfunction asPositiveNumber(value: unknown, field: string): number {\n const n = asFiniteNumber(value, field);\n if (n <= 0) throw new Error(`Invalid \"${field}\": expected number > 0.`);\n return n;\n}\n\nfunction asPositiveInteger(value: unknown, field: string): number {\n const n = asPositiveNumber(value, field);\n if (!Number.isInteger(n)) {\n throw new Error(`Invalid \"${field}\": expected positive integer.`);\n }\n return n;\n}\n\nfunction asBoolean(value: unknown, field: string): boolean {\n if (typeof value !== \"boolean\") {\n throw new Error(`Invalid \"${field}\": expected boolean.`);\n }\n return value;\n}\n\nfunction assertEnum(value: string, field: string, allowed: readonly string[]): void {\n if (!allowed.includes(value)) {\n throw new Error(`Invalid \"${field}\": expected one of ${allowed.join(\", \")}.`);\n }\n}\n\nfunction asPositiveDecimalString(value: unknown, field: string): string {\n const s = asNonEmptyString(value, field);\n if (!/^\\d+(\\.\\d+)?$/.test(s)) {\n throw new Error(`Invalid \"${field}\": expected positive decimal string.`);\n }\n const n = Number(s);\n if (!Number.isFinite(n) || n <= 0) {\n throw new Error(`Invalid \"${field}\": expected positive decimal string.`);\n }\n return s;\n}\n\nfunction asPositiveDecimalStringLoose(value: unknown, field: string): string {\n if (typeof value === \"number\" && Number.isFinite(value) && value > 0) {\n return String(value);\n }\n return asPositiveDecimalString(value, field);\n}\n\nfunction asNonNegativeDecimalString(value: unknown, field: string): string {\n const s = asNonEmptyString(value, field);\n if (!/^\\d+(\\.\\d+)?$/.test(s)) {\n throw new Error(`Invalid \"${field}\": expected non-negative decimal string.`);\n }\n const n = Number(s);\n if (!Number.isFinite(n) || n < 0) {\n throw new Error(`Invalid \"${field}\": expected non-negative decimal string.`);\n }\n return s;\n}\n\nfunction asOptionalString(value: unknown, field: string): string {\n if (typeof value !== \"string\") {\n throw new Error(`Invalid \"${field}\": expected string.`);\n }\n return value;\n}\n\nfunction asOptionalNonNegativeNumber(value: unknown, field: string): number {\n const n = asFiniteNumber(value, field);\n if (n < 0) throw new Error(`Invalid \"${field}\": expected number >= 0.`);\n return n;\n}\n\n/** Strip + reject unknown keys; validate types per OpenAPI. Returns body-ready buOrderData. */\nexport function parseAndValidateCreateFuturesGridBuOrderData(raw: Record<string, unknown>): Record<string, unknown> {\n const data = { ...raw };\n\n for (const k of Object.keys(data)) {\n if (!ORDER_DATA_KEY_SET.has(k)) {\n throw new Error(`Unknown buOrderData property \"${k}\". Allowed keys: ${CREATE_FUTURES_GRID_ORDER_DATA_KEYS.join(\", \")}.`);\n }\n }\n\n const top = asPositiveDecimalStringLoose(data.top, \"buOrderData.top\");\n const bottom = asPositiveDecimalStringLoose(data.bottom, \"buOrderData.bottom\");\n if (Number(top) <= Number(bottom)) {\n throw new Error('Invalid \"buOrderData.top\": expected top > bottom.');\n }\n const row = asPositiveInteger(data.row, \"buOrderData.row\");\n const gridType = asNonEmptyString(data.grid_type, \"buOrderData.grid_type\");\n assertEnum(gridType, \"buOrderData.grid_type\", [\"arithmetic\", \"geometric\"]);\n const trend = asNonEmptyString(data.trend, \"buOrderData.trend\");\n assertEnum(trend, \"buOrderData.trend\", [\"long\", \"short\", \"no_trend\"]);\n const leverage = asPositiveNumber(data.leverage, \"buOrderData.leverage\");\n const quoteInvestment = asPositiveDecimalStringLoose(data.quoteInvestment, \"buOrderData.quoteInvestment\");\n\n const out: Record<string, unknown> = {\n top,\n bottom,\n row,\n grid_type: gridType,\n trend,\n leverage,\n quoteInvestment,\n };\n\n if (data.extraMargin != null) {\n out.extraMargin = asNonNegativeDecimalString(data.extraMargin, \"buOrderData.extraMargin\");\n }\n if (data.condition != null) out.condition = asOptionalString(data.condition, \"buOrderData.condition\");\n if (data.conditionDirection != null) {\n const v = asNonEmptyString(data.conditionDirection, \"buOrderData.conditionDirection\");\n assertEnum(v, \"buOrderData.conditionDirection\", [\"-1\", \"1\"]);\n out.conditionDirection = v;\n }\n if (data.lossStopType != null) {\n const v = asNonEmptyString(data.lossStopType, \"buOrderData.lossStopType\");\n assertEnum(v, \"buOrderData.lossStopType\", [\"price\", \"profit_amount\", \"profit_ratio\", \"price_limit\"]);\n out.lossStopType = v;\n }\n if (data.lossStop != null) out.lossStop = asOptionalString(data.lossStop, \"buOrderData.lossStop\");\n if (data.lossStopDelay != null) out.lossStopDelay = asOptionalNonNegativeNumber(data.lossStopDelay, \"buOrderData.lossStopDelay\");\n if (data.profitStopType != null) {\n const v = asNonEmptyString(data.profitStopType, \"buOrderData.profitStopType\");\n assertEnum(v, \"buOrderData.profitStopType\", [\"price\", \"profit_amount\", \"profit_ratio\", \"price_limit\"]);\n out.profitStopType = v;\n }\n if (data.profitStop != null) out.profitStop = asOptionalString(data.profitStop, \"buOrderData.profitStop\");\n if (data.profitStopDelay != null) out.profitStopDelay = asOptionalNonNegativeNumber(data.profitStopDelay, \"buOrderData.profitStopDelay\");\n if (data.lossStopHigh != null) out.lossStopHigh = asOptionalString(data.lossStopHigh, \"buOrderData.lossStopHigh\");\n if (data.shareRatio != null) out.shareRatio = asOptionalString(data.shareRatio, \"buOrderData.shareRatio\");\n if (data.investCoin != null) out.investCoin = asOptionalString(data.investCoin, \"buOrderData.investCoin\");\n if (data.investmentFrom != null) {\n const v = asNonEmptyString(data.investmentFrom, \"buOrderData.investmentFrom\");\n assertEnum(v, \"buOrderData.investmentFrom\", [\"USER\", \"LOCK_ACTIVITY\", \"FUTURE_GRID_BONUS\"]);\n out.investmentFrom = v;\n }\n if (data.uiInvestCoin != null) out.uiInvestCoin = asOptionalString(data.uiInvestCoin, \"buOrderData.uiInvestCoin\");\n if (data.lossStopLimitPrice != null) out.lossStopLimitPrice = asOptionalString(data.lossStopLimitPrice, \"buOrderData.lossStopLimitPrice\");\n if (data.lossStopLimitHighPrice != null) out.lossStopLimitHighPrice = asOptionalString(data.lossStopLimitHighPrice, \"buOrderData.lossStopLimitHighPrice\");\n if (data.profitStopLimitPrice != null) out.profitStopLimitPrice = asOptionalString(data.profitStopLimitPrice, \"buOrderData.profitStopLimitPrice\");\n if (data.slippage != null) out.slippage = asOptionalString(data.slippage, \"buOrderData.slippage\");\n if (data.bonusId != null) out.bonusId = asOptionalString(data.bonusId, \"buOrderData.bonusId\");\n if (data.uiExtraData != null) out.uiExtraData = asOptionalString(data.uiExtraData, \"buOrderData.uiExtraData\");\n if (data.movingIndicatorType != null) out.movingIndicatorType = asOptionalString(data.movingIndicatorType, \"buOrderData.movingIndicatorType\");\n if (data.movingIndicatorInterval != null) out.movingIndicatorInterval = asOptionalString(data.movingIndicatorInterval, \"buOrderData.movingIndicatorInterval\");\n if (data.movingIndicatorParam != null) out.movingIndicatorParam = asOptionalString(data.movingIndicatorParam, \"buOrderData.movingIndicatorParam\");\n if (data.movingTrailingUpParam != null) out.movingTrailingUpParam = asOptionalString(data.movingTrailingUpParam, \"buOrderData.movingTrailingUpParam\");\n if (data.cateType != null) {\n const v = asNonEmptyString(data.cateType, \"buOrderData.cateType\");\n assertEnum(v, \"buOrderData.cateType\", [\"FULLY_HEDGING\", \"LOAN_GRID\", \"LEVERAGE_GRID\", \"FUTURE_GRID_COIN_MARGINED\"]);\n out.cateType = v;\n }\n if (data.movingTop != null) out.movingTop = asOptionalString(data.movingTop, \"buOrderData.movingTop\");\n if (data.movingBottom != null) out.movingBottom = asOptionalString(data.movingBottom, \"buOrderData.movingBottom\");\n if (data.enableFollowClosed != null) out.enableFollowClosed = asBoolean(data.enableFollowClosed, \"buOrderData.enableFollowClosed\");\n\n return out;\n}\n\n/** JSON Schema for MCP tool `buOrderData` — matches openapi_bot.yaml CreateFuturesGridOrderData.properties */\nexport const createFuturesGridOrderDataJsonSchema: JsonSchema = {\n type: \"object\",\n additionalProperties: false,\n description: \"CreateFuturesGridOrderData (openapi_bot.yaml). Required: top, bottom, row, grid_type, trend, leverage, quoteInvestment.\",\n required: [\"top\", \"bottom\", \"row\", \"grid_type\", \"trend\", \"leverage\", \"quoteInvestment\"],\n properties: {\n top: { type: \"string\", description: \"Grid upper price\" },\n bottom: { type: \"string\", description: \"Grid lower price\" },\n row: { type: \"number\", description: \"Number of grid levels\" },\n grid_type: {\n type: \"string\",\n enum: [\"arithmetic\", \"geometric\"],\n description: \"Grid spacing: arithmetic (equal difference) or geometric (equal ratio)\",\n },\n trend: {\n type: \"string\",\n enum: [\"long\", \"short\", \"no_trend\"],\n description: \"Grid direction\",\n },\n leverage: { type: \"number\", description: \"Leverage multiplier\" },\n extraMargin: { type: \"string\", description: \"Extra margin amount (optional)\" },\n quoteInvestment: { type: \"string\", description: \"Investment amount\" },\n condition: { type: \"string\", description: \"Trigger price (conditional orders)\" },\n conditionDirection: { type: \"string\", enum: [\"-1\", \"1\"], description: \"Trigger direction\" },\n lossStopType: {\n type: \"string\",\n enum: [\"price\", \"profit_amount\", \"profit_ratio\", \"price_limit\"],\n description: \"Stop loss type\",\n },\n lossStop: { type: \"string\", description: \"Stop loss value\" },\n lossStopDelay: { type: \"number\", description: \"Stop loss delay (seconds)\" },\n profitStopType: {\n type: \"string\",\n enum: [\"price\", \"profit_amount\", \"profit_ratio\", \"price_limit\"],\n description: \"Take profit type\",\n },\n profitStop: { type: \"string\", description: \"Take profit value\" },\n profitStopDelay: { type: \"number\", description: \"Take profit delay (seconds)\" },\n lossStopHigh: { type: \"string\", description: \"Upper stop loss price for neutral grid\" },\n shareRatio: { type: \"string\", description: \"Profit sharing ratio\" },\n investCoin: { type: \"string\", description: \"Investment currency\" },\n investmentFrom: {\n type: \"string\",\n enum: [\"USER\", \"LOCK_ACTIVITY\", \"FUTURE_GRID_BONUS\"],\n description: \"Funding source\",\n },\n uiInvestCoin: { type: \"string\", description: \"Frontend-recorded investment currency\" },\n lossStopLimitPrice: { type: \"string\", description: \"Limit SL price (lossStopType=price_limit)\" },\n lossStopLimitHighPrice: { type: \"string\", description: \"Upper limit SL for neutral grid\" },\n profitStopLimitPrice: { type: \"string\", description: \"Limit TP price (profitStopType=price_limit)\" },\n slippage: { type: \"string\", description: \"Open slippage e.g. 0.01 = 1%\" },\n bonusId: { type: \"string\", description: \"Bonus UUID\" },\n uiExtraData: { type: \"string\", description: \"Frontend extra (coin-margined)\" },\n movingIndicatorType: { type: \"string\", description: \"e.g. sma\" },\n movingIndicatorInterval: { type: \"string\", description: \"e.g. 1m, 15m\" },\n movingIndicatorParam: { type: \"string\", description: \"JSON params e.g. length\" },\n movingTrailingUpParam: { type: \"string\", description: \"SMA trailing up ratio\" },\n cateType: {\n type: \"string\",\n enum: [\"FULLY_HEDGING\", \"LOAN_GRID\", \"LEVERAGE_GRID\", \"FUTURE_GRID_COIN_MARGINED\"],\n description: \"Category type\",\n },\n movingTop: { type: \"string\", description: \"Moving grid upper limit\" },\n movingBottom: { type: \"string\", description: \"Moving grid lower limit\" },\n enableFollowClosed: { type: \"boolean\", description: \"Follow close\" },\n },\n};\n\n/** Full MCP input schema for pionex_bot_futures_grid_create (includes internal __dryRun for CLI). */\nexport const createFuturesGridCreateToolInputSchema: JsonSchema = {\n type: \"object\",\n additionalProperties: false,\n required: [\"base\", \"quote\", \"buOrderData\"],\n properties: {\n base: { type: \"string\", description: \"Base currency (e.g. BTC); *.PERP normalized in handler\" },\n quote: { type: \"string\", description: \"Quote currency (e.g. USDT)\" },\n copyFrom: { type: \"string\", description: \"Optional. Copy source order ID\" },\n copyType: { type: \"string\", description: \"Optional. Copy type\" },\n copyBotOrderId: { type: \"string\", description: \"Optional. Copy bot order ID\" },\n buOrderData: createFuturesGridOrderDataJsonSchema,\n __dryRun: { type: \"boolean\", description: \"Internal: when true, return resolved body without POST\" },\n },\n};\n","import type { ToolSpec } from \"./types.js\";\nimport {\n createFuturesGridCreateToolInputSchema,\n parseAndValidateCreateFuturesGridBuOrderData,\n} from \"../schemas/futures-grid-create.js\";\nimport type { QueryParams } from \"../client/types.js\";\n\nfunction asNonEmptyString(value: unknown, field: string): string {\n if (typeof value !== \"string\" || value.trim().length === 0) {\n throw new Error(`Invalid \"${field}\": expected non-empty string.`);\n }\n return value.trim();\n}\n\nfunction asFiniteNumber(value: unknown, field: string): number {\n if (typeof value !== \"number\" || !Number.isFinite(value)) {\n throw new Error(`Invalid \"${field}\": expected finite number.`);\n }\n return value;\n}\n\nfunction asPositiveNumber(value: unknown, field: string): number {\n const n = asFiniteNumber(value, field);\n if (n <= 0) throw new Error(`Invalid \"${field}\": expected number > 0.`);\n return n;\n}\n\nfunction asPositiveInteger(value: unknown, field: string): number {\n const n = asPositiveNumber(value, field);\n if (!Number.isInteger(n)) {\n throw new Error(`Invalid \"${field}\": expected positive integer.`);\n }\n return n;\n}\n\nfunction asBoolean(value: unknown, field: string): boolean {\n if (typeof value !== \"boolean\") {\n throw new Error(`Invalid \"${field}\": expected boolean.`);\n }\n return value;\n}\n\nfunction assertEnum(value: string, field: string, allowed: readonly string[]): void {\n if (!allowed.includes(value)) {\n throw new Error(`Invalid \"${field}\": expected one of ${allowed.join(\", \")}.`);\n }\n}\n\nfunction asObject(value: unknown, field: string): Record<string, unknown> {\n if (!value || typeof value !== \"object\" || Array.isArray(value)) {\n throw new Error(`Invalid \"${field}\": expected JSON object.`);\n }\n return value as Record<string, unknown>;\n}\n\nfunction asPositiveDecimalString(value: unknown, field: string): string {\n const s = asNonEmptyString(value, field);\n if (!/^\\d+(\\.\\d+)?$/.test(s)) {\n throw new Error(`Invalid \"${field}\": expected positive decimal string.`);\n }\n const n = Number(s);\n if (!Number.isFinite(n) || n <= 0) {\n throw new Error(`Invalid \"${field}\": expected positive decimal string.`);\n }\n return s;\n}\n\nfunction normalizePerpBase(base: string): string {\n return base.endsWith(\".PERP\") ? base : `${base}.PERP`;\n}\n\nexport function registerBotTools(): ToolSpec[] {\n return [\n {\n name: \"pionex_bot_futures_grid_get_order\",\n module: \"bot\",\n isWrite: false,\n description: \"Get one futures grid bot order by buOrderId.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n buOrderId: { type: \"string\", description: \"Futures grid bot order id.\" },\n lang: { type: \"string\", description: \"Optional language code.\" },\n },\n required: [\"buOrderId\"],\n },\n async handler(args, { client }) {\n const buOrderId = String(args.buOrderId);\n const q: QueryParams = { buOrderId };\n if (args.lang != null) q.lang = String(args.lang);\n return (await client.signedGet(\"/api/v1/bot/orders/futuresGrid/order\", q)).data;\n },\n },\n {\n name: \"pionex_bot_futures_grid_create\",\n module: \"bot\",\n isWrite: true,\n description:\n \"Create a futures grid order (openapi_bot.yaml CreateFuturesGridRequest / CreateFuturesGridOrderData). \" +\n \"https://github.com/pionex-official/pionex-open-api/blob/main/openapi_bot.yaml — \" +\n \"Required: base, quote, buOrderData. Optional: copyFrom, copyType, copyBotOrderId. \" +\n \"buOrderData required: top, bottom, row, grid_type, trend, leverage, quoteInvestment; unknown keys rejected.\",\n inputSchema: createFuturesGridCreateToolInputSchema,\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; bot futures_grid create is disabled.\");\n }\n const rawBase = asNonEmptyString(args.base, \"base\");\n const base = normalizePerpBase(rawBase);\n const quote = asNonEmptyString(args.quote, \"quote\");\n const buOrderDataOut = parseAndValidateCreateFuturesGridBuOrderData(asObject(args.buOrderData, \"buOrderData\"));\n const row = buOrderDataOut.row as number;\n const gridType = buOrderDataOut.grid_type as string;\n const leverage = buOrderDataOut.leverage as number;\n\n const body: Record<string, unknown> = {\n base,\n quote,\n buOrderData: buOrderDataOut,\n };\n if (args.copyFrom != null) body.copyFrom = String(args.copyFrom);\n if (args.copyType != null) body.copyType = String(args.copyType);\n if (args.copyBotOrderId != null) body.copyBotOrderId = String(args.copyBotOrderId);\n\n if (args.__dryRun === true) {\n return {\n dryRun: true,\n note: \"No order was sent. Body matches openapi_bot.yaml CreateFuturesGridRequest.\",\n resolvedParams: {\n row,\n grid_type: gridType,\n leverage,\n },\n resolvedBody: body,\n };\n }\n return (await client.signedPost(\"/api/v1/bot/orders/futuresGrid/create\", body)).data;\n },\n },\n {\n name: \"pionex_bot_futures_grid_adjust_params\",\n module: \"bot\",\n isWrite: true,\n description: \"Adjust futures grid bot params (invest_in / adjust_params / invest_in_trigger).\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n buOrderId: { type: \"string\" },\n type: { type: \"string\", enum: [\"invest_in\", \"adjust_params\", \"invest_in_trigger\"] },\n quoteInvestment: { type: \"number\" },\n extraMargin: { type: \"boolean\" },\n bottom: { type: \"string\" },\n top: { type: \"string\" },\n row: { type: \"number\" },\n extraMarginAmount: { type: \"number\" },\n isRecommend: { type: \"boolean\" },\n isReinvest: { type: \"boolean\" },\n investCoin: { type: \"string\" },\n investmentFrom: { type: \"string\", enum: [\"USER\", \"LOCK_ACTIVITY\"] },\n condition: { type: \"string\" },\n conditionDirection: { type: \"string\", enum: [\"1\", \"-1\"] },\n slippage: { type: \"string\" },\n adjustParamsSence: { type: \"string\" },\n },\n required: [\"buOrderId\", \"type\", \"extraMargin\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; bot futures_grid adjust_params is disabled.\");\n }\n const buOrderId = asNonEmptyString(args.buOrderId, \"buOrderId\");\n const type = asNonEmptyString(args.type, \"type\");\n assertEnum(type, \"type\", [\"invest_in\", \"adjust_params\", \"invest_in_trigger\"]);\n const extraMargin = asBoolean(args.extraMargin, \"extraMargin\");\n\n if (type === \"invest_in\" && args.quoteInvestment != null) {\n asPositiveNumber(args.quoteInvestment, \"quoteInvestment\");\n }\n if (type === \"adjust_params\") {\n const bottom = asPositiveDecimalString(args.bottom, \"bottom\");\n const top = asPositiveDecimalString(args.top, \"top\");\n if (Number(top) <= Number(bottom)) {\n throw new Error('Invalid \"top\": expected top > bottom.');\n }\n asPositiveInteger(args.row, \"row\");\n }\n if (type === \"invest_in_trigger\") {\n asPositiveDecimalString(args.condition, \"condition\");\n const conditionDirection = asNonEmptyString(args.conditionDirection, \"conditionDirection\");\n assertEnum(conditionDirection, \"conditionDirection\", [\"1\", \"-1\"]);\n }\n\n const body: Record<string, unknown> = {\n buOrderId,\n type,\n extraMargin,\n };\n if (args.quoteInvestment != null) body.quoteInvestment = asFiniteNumber(args.quoteInvestment, \"quoteInvestment\");\n if (args.bottom != null) body.bottom = asPositiveDecimalString(args.bottom, \"bottom\");\n if (args.top != null) body.top = asPositiveDecimalString(args.top, \"top\");\n if (args.row != null) body.row = asPositiveInteger(args.row, \"row\");\n if (args.extraMarginAmount != null) body.extraMarginAmount = asFiniteNumber(args.extraMarginAmount, \"extraMarginAmount\");\n if (args.isRecommend != null) body.isRecommend = asBoolean(args.isRecommend, \"isRecommend\");\n if (args.isReinvest != null) body.isReinvest = asBoolean(args.isReinvest, \"isReinvest\");\n if (args.investCoin != null) body.investCoin = String(args.investCoin);\n if (args.investmentFrom != null) {\n const investmentFrom = asNonEmptyString(args.investmentFrom, \"investmentFrom\");\n assertEnum(investmentFrom, \"investmentFrom\", [\"USER\", \"LOCK_ACTIVITY\"]);\n body.investmentFrom = investmentFrom;\n }\n if (args.condition != null) body.condition = asPositiveDecimalString(args.condition, \"condition\");\n if (args.conditionDirection != null) {\n const conditionDirection = asNonEmptyString(args.conditionDirection, \"conditionDirection\");\n assertEnum(conditionDirection, \"conditionDirection\", [\"1\", \"-1\"]);\n body.conditionDirection = conditionDirection;\n }\n if (args.slippage != null) body.slippage = String(args.slippage);\n if (args.adjustParamsSence != null) body.adjustParamsSence = String(args.adjustParamsSence);\n return (await client.signedPost(\"/api/v1/bot/orders/futuresGrid/adjustParams\", body)).data;\n },\n },\n {\n name: \"pionex_bot_futures_grid_reduce\",\n module: \"bot\",\n isWrite: true,\n description: \"Reduce futures grid bot position.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n buOrderId: { type: \"string\" },\n reduceNum: { type: \"number\" },\n slippage: { type: \"string\" },\n condition: { type: \"string\" },\n conditionDirection: { type: \"string\", enum: [\"1\", \"-1\"] },\n },\n required: [\"buOrderId\", \"reduceNum\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; bot futures_grid reduce is disabled.\");\n }\n const buOrderId = asNonEmptyString(args.buOrderId, \"buOrderId\");\n const reduceNum = asPositiveInteger(args.reduceNum, \"reduceNum\");\n const body: Record<string, unknown> = {\n buOrderId,\n reduceNum,\n };\n if (args.slippage != null) body.slippage = String(args.slippage);\n if (args.condition != null) body.condition = String(args.condition);\n if (args.conditionDirection != null) {\n const conditionDirection = asNonEmptyString(args.conditionDirection, \"conditionDirection\");\n assertEnum(conditionDirection, \"conditionDirection\", [\"1\", \"-1\"]);\n body.conditionDirection = conditionDirection;\n }\n return (await client.signedPost(\"/api/v1/bot/orders/futuresGrid/reduce\", body)).data;\n },\n },\n {\n name: \"pionex_bot_futures_grid_cancel\",\n module: \"bot\",\n isWrite: true,\n description: \"Cancel and close a futures grid bot order.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n buOrderId: { type: \"string\" },\n closeNote: { type: \"string\" },\n closeSellModel: { type: \"string\", enum: [\"TO_QUOTE\", \"TO_USDT\"] },\n immediate: { type: \"boolean\" },\n closeSlippage: { type: \"string\" },\n },\n required: [\"buOrderId\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; bot futures_grid cancel is disabled.\");\n }\n const buOrderId = asNonEmptyString(args.buOrderId, \"buOrderId\");\n const body: Record<string, unknown> = { buOrderId };\n if (args.closeNote != null) body.closeNote = String(args.closeNote);\n if (args.closeSellModel != null) {\n const closeSellModel = asNonEmptyString(args.closeSellModel, \"closeSellModel\");\n assertEnum(closeSellModel, \"closeSellModel\", [\"TO_QUOTE\", \"TO_USDT\"]);\n body.closeSellModel = closeSellModel;\n }\n if (args.immediate != null) body.immediate = asBoolean(args.immediate, \"immediate\");\n if (args.closeSlippage != null) body.closeSlippage = String(args.closeSlippage);\n return (await client.signedPost(\"/api/v1/bot/orders/futuresGrid/cancel\", body)).data;\n },\n },\n ];\n}\n","import type { PionexConfig } from \"../config.js\";\nimport type { PionexRestClient } from \"../client/rest-client.js\";\nimport { MODULES, type ModuleId } from \"../constants.js\";\nimport type { ToolArgs, ToolSpec } from \"./types.js\";\nimport { registerMarketTools } from \"./market.js\";\nimport { registerAccountTools } from \"./account.js\";\nimport { registerOrdersTools } from \"./orders.js\";\nimport { registerBotTools } from \"./bot.js\";\n\nfunction allToolSpecs(): ToolSpec[] {\n return [...registerMarketTools(), ...registerAccountTools(), ...registerOrdersTools(), ...registerBotTools()];\n}\n\nexport function buildTools(config: PionexConfig): ToolSpec[] {\n const enabled = new Set(config.modules);\n const tools = allToolSpecs().filter((t) => enabled.has(t.module));\n if (!config.readOnly) return tools;\n return tools.filter((t) => !t.isWrite);\n}\n\nexport interface ToolResult {\n endpoint: string;\n requestTime: string;\n data: unknown;\n}\n\nexport type ToolRunner = (toolName: string, args: ToolArgs) => Promise<ToolResult>;\n\n/**\n * Create a function that can call any registered tool by name.\n * For CLI usage we keep module filtering at the command routing level,\n * but the runner itself knows all tools.\n */\nexport function createToolRunner(client: PionexRestClient, config: PionexConfig): ToolRunner {\n const fullConfig: PionexConfig = { ...config, modules: [...MODULES] as ModuleId[] };\n const toolMap = new Map<string, ToolSpec>(allToolSpecs().map((t) => [t.name, t]));\n\n return async (toolName: string, args: ToolArgs): Promise<ToolResult> => {\n const tool = toolMap.get(toolName);\n if (!tool) throw new Error(`Unknown tool: ${toolName}`);\n const data = await tool.handler(args, { config: fullConfig, client });\n return { endpoint: toolName, requestTime: new Date().toISOString(), data };\n };\n}\n\n","import type { ModuleId } from \"../constants.js\";\nimport type { PionexConfig } from \"../config.js\";\nimport type { PionexRestClient } from \"../client/rest-client.js\";\n\nexport type JsonSchema =\n | {\n type: \"object\";\n properties?: Record<string, JsonSchema>;\n required?: string[];\n additionalProperties?: boolean;\n description?: string;\n enum?: string[];\n }\n | { type: \"string\"; description?: string; enum?: string[] }\n | { type: \"number\"; description?: string }\n | { type: \"integer\"; description?: string }\n | { type: \"boolean\"; description?: string }\n | { type: \"array\"; items: JsonSchema; description?: string }\n | { type: \"null\" };\n\nexport interface ToolContext {\n config: PionexConfig;\n client: PionexRestClient;\n}\n\nexport type ToolArgs = Record<string, unknown>;\n\nexport interface ToolSpec {\n name: string;\n description: string;\n module: ModuleId;\n isWrite: boolean;\n inputSchema: JsonSchema;\n handler: (args: ToolArgs, ctx: ToolContext) => Promise<unknown>;\n}\n\nexport interface McpTool {\n name: string;\n description: string;\n inputSchema: JsonSchema;\n annotations?: {\n readOnlyHint?: boolean;\n destructiveHint?: boolean;\n idempotentHint?: boolean;\n openWorldHint?: boolean;\n };\n}\n\nexport function toMcpTool(tool: ToolSpec): McpTool {\n return {\n name: tool.name,\n description: tool.description,\n inputSchema: tool.inputSchema,\n annotations: {\n readOnlyHint: !tool.isWrite,\n destructiveHint: tool.isWrite,\n idempotentHint: !tool.isWrite,\n openWorldHint: false,\n },\n };\n}\n\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nfunction getLineColFromPtr(string, ptr) {\n let lines = string.slice(0, ptr).split(/\\r\\n|\\n|\\r/g);\n return [lines.length, lines.pop().length + 1];\n}\nfunction makeCodeBlock(string, line, column) {\n let lines = string.split(/\\r\\n|\\n|\\r/g);\n let codeblock = '';\n let numberLen = (Math.log10(line + 1) | 0) + 1;\n for (let i = line - 1; i <= line + 1; i++) {\n let l = lines[i - 1];\n if (!l)\n continue;\n codeblock += i.toString().padEnd(numberLen, ' ');\n codeblock += ': ';\n codeblock += l;\n codeblock += '\\n';\n if (i === line) {\n codeblock += ' '.repeat(numberLen + column + 2);\n codeblock += '^\\n';\n }\n }\n return codeblock;\n}\nexport class TomlError extends Error {\n line;\n column;\n codeblock;\n constructor(message, options) {\n const [line, column] = getLineColFromPtr(options.toml, options.ptr);\n const codeblock = makeCodeBlock(options.toml, line, column);\n super(`Invalid TOML document: ${message}\\n\\n${codeblock}`, options);\n this.line = line;\n this.column = column;\n this.codeblock = codeblock;\n }\n}\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nimport { TomlError } from './error.js';\nfunction isEscaped(str, ptr) {\n let i = 0;\n while (str[ptr - ++i] === '\\\\')\n ;\n return --i && (i % 2);\n}\nexport function indexOfNewline(str, start = 0, end = str.length) {\n let idx = str.indexOf('\\n', start);\n if (str[idx - 1] === '\\r')\n idx--;\n return idx <= end ? idx : -1;\n}\nexport function skipComment(str, ptr) {\n for (let i = ptr; i < str.length; i++) {\n let c = str[i];\n if (c === '\\n')\n return i;\n if (c === '\\r' && str[i + 1] === '\\n')\n return i + 1;\n if ((c < '\\x20' && c !== '\\t') || c === '\\x7f') {\n throw new TomlError('control characters are not allowed in comments', {\n toml: str,\n ptr: ptr,\n });\n }\n }\n return str.length;\n}\nexport function skipVoid(str, ptr, banNewLines, banComments) {\n let c;\n while ((c = str[ptr]) === ' ' || c === '\\t' || (!banNewLines && (c === '\\n' || c === '\\r' && str[ptr + 1] === '\\n')))\n ptr++;\n return banComments || c !== '#'\n ? ptr\n : skipVoid(str, skipComment(str, ptr), banNewLines);\n}\nexport function skipUntil(str, ptr, sep, end, banNewLines = false) {\n if (!end) {\n ptr = indexOfNewline(str, ptr);\n return ptr < 0 ? str.length : ptr;\n }\n for (let i = ptr; i < str.length; i++) {\n let c = str[i];\n if (c === '#') {\n i = indexOfNewline(str, i);\n }\n else if (c === sep) {\n return i + 1;\n }\n else if (c === end || (banNewLines && (c === '\\n' || (c === '\\r' && str[i + 1] === '\\n')))) {\n return i;\n }\n }\n throw new TomlError('cannot find end of structure', {\n toml: str,\n ptr: ptr\n });\n}\nexport function getStringEnd(str, seek) {\n let first = str[seek];\n let target = first === str[seek + 1] && str[seek + 1] === str[seek + 2]\n ? str.slice(seek, seek + 3)\n : first;\n seek += target.length - 1;\n do\n seek = str.indexOf(target, ++seek);\n while (seek > -1 && first !== \"'\" && isEscaped(str, seek));\n if (seek > -1) {\n seek += target.length;\n if (target.length > 1) {\n if (str[seek] === first)\n seek++;\n if (str[seek] === first)\n seek++;\n }\n }\n return seek;\n}\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nlet DATE_TIME_RE = /^(\\d{4}-\\d{2}-\\d{2})?[T ]?(?:(\\d{2}):\\d{2}(?::\\d{2}(?:\\.\\d+)?)?)?(Z|[-+]\\d{2}:\\d{2})?$/i;\nexport class TomlDate extends Date {\n #hasDate = false;\n #hasTime = false;\n #offset = null;\n constructor(date) {\n let hasDate = true;\n let hasTime = true;\n let offset = 'Z';\n if (typeof date === 'string') {\n let match = date.match(DATE_TIME_RE);\n if (match) {\n if (!match[1]) {\n hasDate = false;\n date = `0000-01-01T${date}`;\n }\n hasTime = !!match[2];\n // Make sure to use T instead of a space. Breaks in case of extreme values otherwise.\n hasTime && date[10] === ' ' && (date = date.replace(' ', 'T'));\n // Do not allow rollover hours.\n if (match[2] && +match[2] > 23) {\n date = '';\n }\n else {\n offset = match[3] || null;\n date = date.toUpperCase();\n if (!offset && hasTime)\n date += 'Z';\n }\n }\n else {\n date = '';\n }\n }\n super(date);\n if (!isNaN(this.getTime())) {\n this.#hasDate = hasDate;\n this.#hasTime = hasTime;\n this.#offset = offset;\n }\n }\n isDateTime() {\n return this.#hasDate && this.#hasTime;\n }\n isLocal() {\n return !this.#hasDate || !this.#hasTime || !this.#offset;\n }\n isDate() {\n return this.#hasDate && !this.#hasTime;\n }\n isTime() {\n return this.#hasTime && !this.#hasDate;\n }\n isValid() {\n return this.#hasDate || this.#hasTime;\n }\n toISOString() {\n let iso = super.toISOString();\n // Local Date\n if (this.isDate())\n return iso.slice(0, 10);\n // Local Time\n if (this.isTime())\n return iso.slice(11, 23);\n // Local DateTime\n if (this.#offset === null)\n return iso.slice(0, -1);\n // Offset DateTime\n if (this.#offset === 'Z')\n return iso;\n // This part is quite annoying: JS strips the original timezone from the ISO string representation\n // Instead of using a \"modified\" date and \"Z\", we restore the representation \"as authored\"\n let offset = (+(this.#offset.slice(1, 3)) * 60) + +(this.#offset.slice(4, 6));\n offset = this.#offset[0] === '-' ? offset : -offset;\n let offsetDate = new Date(this.getTime() - (offset * 60e3));\n return offsetDate.toISOString().slice(0, -1) + this.#offset;\n }\n static wrapAsOffsetDateTime(jsDate, offset = 'Z') {\n let date = new TomlDate(jsDate);\n date.#offset = offset;\n return date;\n }\n static wrapAsLocalDateTime(jsDate) {\n let date = new TomlDate(jsDate);\n date.#offset = null;\n return date;\n }\n static wrapAsLocalDate(jsDate) {\n let date = new TomlDate(jsDate);\n date.#hasTime = false;\n date.#offset = null;\n return date;\n }\n static wrapAsLocalTime(jsDate) {\n let date = new TomlDate(jsDate);\n date.#hasDate = false;\n date.#offset = null;\n return date;\n }\n}\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nimport { skipVoid } from './util.js';\nimport { TomlDate } from './date.js';\nimport { TomlError } from './error.js';\nlet INT_REGEX = /^((0x[0-9a-fA-F](_?[0-9a-fA-F])*)|(([+-]|0[ob])?\\d(_?\\d)*))$/;\nlet FLOAT_REGEX = /^[+-]?\\d(_?\\d)*(\\.\\d(_?\\d)*)?([eE][+-]?\\d(_?\\d)*)?$/;\nlet LEADING_ZERO = /^[+-]?0[0-9_]/;\nlet ESCAPE_REGEX = /^[0-9a-f]{2,8}$/i;\nlet ESC_MAP = {\n b: '\\b',\n t: '\\t',\n n: '\\n',\n f: '\\f',\n r: '\\r',\n e: '\\x1b',\n '\"': '\"',\n '\\\\': '\\\\',\n};\nexport function parseString(str, ptr = 0, endPtr = str.length) {\n let isLiteral = str[ptr] === '\\'';\n let isMultiline = str[ptr++] === str[ptr] && str[ptr] === str[ptr + 1];\n if (isMultiline) {\n endPtr -= 2;\n if (str[ptr += 2] === '\\r')\n ptr++;\n if (str[ptr] === '\\n')\n ptr++;\n }\n let tmp = 0;\n let isEscape;\n let parsed = '';\n let sliceStart = ptr;\n while (ptr < endPtr - 1) {\n let c = str[ptr++];\n if (c === '\\n' || (c === '\\r' && str[ptr] === '\\n')) {\n if (!isMultiline) {\n throw new TomlError('newlines are not allowed in strings', {\n toml: str,\n ptr: ptr - 1,\n });\n }\n }\n else if ((c < '\\x20' && c !== '\\t') || c === '\\x7f') {\n throw new TomlError('control characters are not allowed in strings', {\n toml: str,\n ptr: ptr - 1,\n });\n }\n if (isEscape) {\n isEscape = false;\n if (c === 'x' || c === 'u' || c === 'U') {\n // Unicode escape\n let code = str.slice(ptr, (ptr += (c === 'x' ? 2 : c === 'u' ? 4 : 8)));\n if (!ESCAPE_REGEX.test(code)) {\n throw new TomlError('invalid unicode escape', {\n toml: str,\n ptr: tmp,\n });\n }\n try {\n parsed += String.fromCodePoint(parseInt(code, 16));\n }\n catch {\n throw new TomlError('invalid unicode escape', {\n toml: str,\n ptr: tmp,\n });\n }\n }\n else if (isMultiline && (c === '\\n' || c === ' ' || c === '\\t' || c === '\\r')) {\n // Multiline escape\n ptr = skipVoid(str, ptr - 1, true);\n if (str[ptr] !== '\\n' && str[ptr] !== '\\r') {\n throw new TomlError('invalid escape: only line-ending whitespace may be escaped', {\n toml: str,\n ptr: tmp,\n });\n }\n ptr = skipVoid(str, ptr);\n }\n else if (c in ESC_MAP) {\n // Classic escape\n parsed += ESC_MAP[c];\n }\n else {\n throw new TomlError('unrecognized escape sequence', {\n toml: str,\n ptr: tmp,\n });\n }\n sliceStart = ptr;\n }\n else if (!isLiteral && c === '\\\\') {\n tmp = ptr - 1;\n isEscape = true;\n parsed += str.slice(sliceStart, tmp);\n }\n }\n return parsed + str.slice(sliceStart, endPtr - 1);\n}\nexport function parseValue(value, toml, ptr, integersAsBigInt) {\n // Constant values\n if (value === 'true')\n return true;\n if (value === 'false')\n return false;\n if (value === '-inf')\n return -Infinity;\n if (value === 'inf' || value === '+inf')\n return Infinity;\n if (value === 'nan' || value === '+nan' || value === '-nan')\n return NaN;\n // Avoid FP representation of -0\n if (value === '-0')\n return integersAsBigInt ? 0n : 0;\n // Numbers\n let isInt = INT_REGEX.test(value);\n if (isInt || FLOAT_REGEX.test(value)) {\n if (LEADING_ZERO.test(value)) {\n throw new TomlError('leading zeroes are not allowed', {\n toml: toml,\n ptr: ptr,\n });\n }\n value = value.replace(/_/g, '');\n let numeric = +value;\n if (isNaN(numeric)) {\n throw new TomlError('invalid number', {\n toml: toml,\n ptr: ptr,\n });\n }\n if (isInt) {\n if ((isInt = !Number.isSafeInteger(numeric)) && !integersAsBigInt) {\n throw new TomlError('integer value cannot be represented losslessly', {\n toml: toml,\n ptr: ptr,\n });\n }\n if (isInt || integersAsBigInt === true)\n numeric = BigInt(value);\n }\n return numeric;\n }\n const date = new TomlDate(value);\n if (!date.isValid()) {\n throw new TomlError('invalid value', {\n toml: toml,\n ptr: ptr,\n });\n }\n return date;\n}\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nimport { parseString, parseValue } from './primitive.js';\nimport { parseArray, parseInlineTable } from './struct.js';\nimport { skipVoid, skipUntil, skipComment, getStringEnd } from './util.js';\nimport { TomlError } from './error.js';\nfunction sliceAndTrimEndOf(str, startPtr, endPtr) {\n let value = str.slice(startPtr, endPtr);\n let commentIdx = value.indexOf('#');\n if (commentIdx > -1) {\n // The call to skipComment allows to \"validate\" the comment\n // (absence of control characters)\n skipComment(str, commentIdx);\n value = value.slice(0, commentIdx);\n }\n return [value.trimEnd(), commentIdx];\n}\nexport function extractValue(str, ptr, end, depth, integersAsBigInt) {\n if (depth === 0) {\n throw new TomlError('document contains excessively nested structures. aborting.', {\n toml: str,\n ptr: ptr\n });\n }\n let c = str[ptr];\n if (c === '[' || c === '{') {\n let [value, endPtr] = c === '['\n ? parseArray(str, ptr, depth, integersAsBigInt)\n : parseInlineTable(str, ptr, depth, integersAsBigInt);\n if (end) {\n endPtr = skipVoid(str, endPtr);\n if (str[endPtr] === ',')\n endPtr++;\n else if (str[endPtr] !== end) {\n throw new TomlError('expected comma or end of structure', {\n toml: str,\n ptr: endPtr,\n });\n }\n }\n return [value, endPtr];\n }\n let endPtr;\n if (c === '\"' || c === \"'\") {\n endPtr = getStringEnd(str, ptr);\n let parsed = parseString(str, ptr, endPtr);\n if (end) {\n endPtr = skipVoid(str, endPtr);\n if (str[endPtr] && str[endPtr] !== ',' && str[endPtr] !== end && str[endPtr] !== '\\n' && str[endPtr] !== '\\r') {\n throw new TomlError('unexpected character encountered', {\n toml: str,\n ptr: endPtr,\n });\n }\n endPtr += (+(str[endPtr] === ','));\n }\n return [parsed, endPtr];\n }\n endPtr = skipUntil(str, ptr, ',', end);\n let slice = sliceAndTrimEndOf(str, ptr, endPtr - (+(str[endPtr - 1] === ',')));\n if (!slice[0]) {\n throw new TomlError('incomplete key-value declaration: no value specified', {\n toml: str,\n ptr: ptr\n });\n }\n if (end && slice[1] > -1) {\n endPtr = skipVoid(str, ptr + slice[1]);\n endPtr += +(str[endPtr] === ',');\n }\n return [\n parseValue(slice[0], str, ptr, integersAsBigInt),\n endPtr,\n ];\n}\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nimport { parseString } from './primitive.js';\nimport { extractValue } from './extract.js';\nimport { getStringEnd, indexOfNewline, skipComment, skipVoid } from './util.js';\nimport { TomlError } from './error.js';\nlet KEY_PART_RE = /^[a-zA-Z0-9-_]+[ \\t]*$/;\nexport function parseKey(str, ptr, end = '=') {\n let dot = ptr - 1;\n let parsed = [];\n let endPtr = str.indexOf(end, ptr);\n if (endPtr < 0) {\n throw new TomlError('incomplete key-value: cannot find end of key', {\n toml: str,\n ptr: ptr,\n });\n }\n do {\n let c = str[ptr = ++dot];\n // If it's whitespace, ignore\n if (c !== ' ' && c !== '\\t') {\n // If it's a string\n if (c === '\"' || c === '\\'') {\n if (c === str[ptr + 1] && c === str[ptr + 2]) {\n throw new TomlError('multiline strings are not allowed in keys', {\n toml: str,\n ptr: ptr,\n });\n }\n let eos = getStringEnd(str, ptr);\n if (eos < 0) {\n throw new TomlError('unfinished string encountered', {\n toml: str,\n ptr: ptr,\n });\n }\n dot = str.indexOf('.', eos);\n let strEnd = str.slice(eos, dot < 0 || dot > endPtr ? endPtr : dot);\n let newLine = indexOfNewline(strEnd);\n if (newLine > -1) {\n throw new TomlError('newlines are not allowed in keys', {\n toml: str,\n ptr: ptr + dot + newLine,\n });\n }\n if (strEnd.trimStart()) {\n throw new TomlError('found extra tokens after the string part', {\n toml: str,\n ptr: eos,\n });\n }\n if (endPtr < eos) {\n endPtr = str.indexOf(end, eos);\n if (endPtr < 0) {\n throw new TomlError('incomplete key-value: cannot find end of key', {\n toml: str,\n ptr: ptr,\n });\n }\n }\n parsed.push(parseString(str, ptr, eos));\n }\n else {\n // Normal raw key part consumption and validation\n dot = str.indexOf('.', ptr);\n let part = str.slice(ptr, dot < 0 || dot > endPtr ? endPtr : dot);\n if (!KEY_PART_RE.test(part)) {\n throw new TomlError('only letter, numbers, dashes and underscores are allowed in keys', {\n toml: str,\n ptr: ptr,\n });\n }\n parsed.push(part.trimEnd());\n }\n }\n // Until there's no more dot\n } while (dot + 1 && dot < endPtr);\n return [parsed, skipVoid(str, endPtr + 1, true, true)];\n}\nexport function parseInlineTable(str, ptr, depth, integersAsBigInt) {\n let res = {};\n let seen = new Set();\n let c;\n ptr++;\n while ((c = str[ptr++]) !== '}' && c) {\n if (c === ',') {\n throw new TomlError('expected value, found comma', {\n toml: str,\n ptr: ptr - 1,\n });\n }\n else if (c === '#')\n ptr = skipComment(str, ptr);\n else if (c !== ' ' && c !== '\\t' && c !== '\\n' && c !== '\\r') {\n let k;\n let t = res;\n let hasOwn = false;\n let [key, keyEndPtr] = parseKey(str, ptr - 1);\n for (let i = 0; i < key.length; i++) {\n if (i)\n t = hasOwn ? t[k] : (t[k] = {});\n k = key[i];\n if ((hasOwn = Object.hasOwn(t, k)) && (typeof t[k] !== 'object' || seen.has(t[k]))) {\n throw new TomlError('trying to redefine an already defined value', {\n toml: str,\n ptr: ptr,\n });\n }\n if (!hasOwn && k === '__proto__') {\n Object.defineProperty(t, k, { enumerable: true, configurable: true, writable: true });\n }\n }\n if (hasOwn) {\n throw new TomlError('trying to redefine an already defined value', {\n toml: str,\n ptr: ptr,\n });\n }\n let [value, valueEndPtr] = extractValue(str, keyEndPtr, '}', depth - 1, integersAsBigInt);\n seen.add(value);\n t[k] = value;\n ptr = valueEndPtr;\n }\n }\n if (!c) {\n throw new TomlError('unfinished table encountered', {\n toml: str,\n ptr: ptr,\n });\n }\n return [res, ptr];\n}\nexport function parseArray(str, ptr, depth, integersAsBigInt) {\n let res = [];\n let c;\n ptr++;\n while ((c = str[ptr++]) !== ']' && c) {\n if (c === ',') {\n throw new TomlError('expected value, found comma', {\n toml: str,\n ptr: ptr - 1,\n });\n }\n else if (c === '#')\n ptr = skipComment(str, ptr);\n else if (c !== ' ' && c !== '\\t' && c !== '\\n' && c !== '\\r') {\n let e = extractValue(str, ptr - 1, ']', depth - 1, integersAsBigInt);\n res.push(e[0]);\n ptr = e[1];\n }\n }\n if (!c) {\n throw new TomlError('unfinished array encountered', {\n toml: str,\n ptr: ptr,\n });\n }\n return [res, ptr];\n}\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nimport { parseKey } from './struct.js';\nimport { extractValue } from './extract.js';\nimport { skipVoid } from './util.js';\nimport { TomlError } from './error.js';\nfunction peekTable(key, table, meta, type) {\n let t = table;\n let m = meta;\n let k;\n let hasOwn = false;\n let state;\n for (let i = 0; i < key.length; i++) {\n if (i) {\n t = hasOwn ? t[k] : (t[k] = {});\n m = (state = m[k]).c;\n if (type === 0 /* Type.DOTTED */ && (state.t === 1 /* Type.EXPLICIT */ || state.t === 2 /* Type.ARRAY */)) {\n return null;\n }\n if (state.t === 2 /* Type.ARRAY */) {\n let l = t.length - 1;\n t = t[l];\n m = m[l].c;\n }\n }\n k = key[i];\n if ((hasOwn = Object.hasOwn(t, k)) && m[k]?.t === 0 /* Type.DOTTED */ && m[k]?.d) {\n return null;\n }\n if (!hasOwn) {\n if (k === '__proto__') {\n Object.defineProperty(t, k, { enumerable: true, configurable: true, writable: true });\n Object.defineProperty(m, k, { enumerable: true, configurable: true, writable: true });\n }\n m[k] = {\n t: i < key.length - 1 && type === 2 /* Type.ARRAY */\n ? 3 /* Type.ARRAY_DOTTED */\n : type,\n d: false,\n i: 0,\n c: {},\n };\n }\n }\n state = m[k];\n if (state.t !== type && !(type === 1 /* Type.EXPLICIT */ && state.t === 3 /* Type.ARRAY_DOTTED */)) {\n // Bad key type!\n return null;\n }\n if (type === 2 /* Type.ARRAY */) {\n if (!state.d) {\n state.d = true;\n t[k] = [];\n }\n t[k].push(t = {});\n state.c[state.i++] = (state = { t: 1 /* Type.EXPLICIT */, d: false, i: 0, c: {} });\n }\n if (state.d) {\n // Redefining a table!\n return null;\n }\n state.d = true;\n if (type === 1 /* Type.EXPLICIT */) {\n t = hasOwn ? t[k] : (t[k] = {});\n }\n else if (type === 0 /* Type.DOTTED */ && hasOwn) {\n return null;\n }\n return [k, t, state.c];\n}\nexport function parse(toml, { maxDepth = 1000, integersAsBigInt } = {}) {\n let res = {};\n let meta = {};\n let tbl = res;\n let m = meta;\n for (let ptr = skipVoid(toml, 0); ptr < toml.length;) {\n if (toml[ptr] === '[') {\n let isTableArray = toml[++ptr] === '[';\n let k = parseKey(toml, ptr += +isTableArray, ']');\n if (isTableArray) {\n if (toml[k[1] - 1] !== ']') {\n throw new TomlError('expected end of table declaration', {\n toml: toml,\n ptr: k[1] - 1,\n });\n }\n k[1]++;\n }\n let p = peekTable(k[0], res, meta, isTableArray ? 2 /* Type.ARRAY */ : 1 /* Type.EXPLICIT */);\n if (!p) {\n throw new TomlError('trying to redefine an already defined table or value', {\n toml: toml,\n ptr: ptr,\n });\n }\n m = p[2];\n tbl = p[1];\n ptr = k[1];\n }\n else {\n let k = parseKey(toml, ptr);\n let p = peekTable(k[0], tbl, m, 0 /* Type.DOTTED */);\n if (!p) {\n throw new TomlError('trying to redefine an already defined table or value', {\n toml: toml,\n ptr: ptr,\n });\n }\n let v = extractValue(toml, k[1], void 0, maxDepth, integersAsBigInt);\n p[1][p[0]] = v[0];\n ptr = v[1];\n }\n ptr = skipVoid(toml, ptr, true);\n if (toml[ptr] && toml[ptr] !== '\\n' && toml[ptr] !== '\\r') {\n throw new TomlError('each key-value declaration must be followed by an end-of-line', {\n toml: toml,\n ptr: ptr\n });\n }\n ptr = skipVoid(toml, ptr);\n }\n return res;\n}\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nlet BARE_KEY = /^[a-z0-9-_]+$/i;\nfunction extendedTypeOf(obj) {\n let type = typeof obj;\n if (type === 'object') {\n if (Array.isArray(obj))\n return 'array';\n if (obj instanceof Date)\n return 'date';\n }\n return type;\n}\nfunction isArrayOfTables(obj) {\n for (let i = 0; i < obj.length; i++) {\n if (extendedTypeOf(obj[i]) !== 'object')\n return false;\n }\n return obj.length != 0;\n}\nfunction formatString(s) {\n return JSON.stringify(s).replace(/\\x7f/g, '\\\\u007f');\n}\nfunction stringifyValue(val, type, depth, numberAsFloat) {\n if (depth === 0) {\n throw new Error('Could not stringify the object: maximum object depth exceeded');\n }\n if (type === 'number') {\n if (isNaN(val))\n return 'nan';\n if (val === Infinity)\n return 'inf';\n if (val === -Infinity)\n return '-inf';\n if (numberAsFloat && Number.isInteger(val))\n return val.toFixed(1);\n return val.toString();\n }\n if (type === 'bigint' || type === 'boolean') {\n return val.toString();\n }\n if (type === 'string') {\n return formatString(val);\n }\n if (type === 'date') {\n if (isNaN(val.getTime())) {\n throw new TypeError('cannot serialize invalid date');\n }\n return val.toISOString();\n }\n if (type === 'object') {\n return stringifyInlineTable(val, depth, numberAsFloat);\n }\n if (type === 'array') {\n return stringifyArray(val, depth, numberAsFloat);\n }\n}\nfunction stringifyInlineTable(obj, depth, numberAsFloat) {\n let keys = Object.keys(obj);\n if (keys.length === 0)\n return '{}';\n let res = '{ ';\n for (let i = 0; i < keys.length; i++) {\n let k = keys[i];\n if (i)\n res += ', ';\n res += BARE_KEY.test(k) ? k : formatString(k);\n res += ' = ';\n res += stringifyValue(obj[k], extendedTypeOf(obj[k]), depth - 1, numberAsFloat);\n }\n return res + ' }';\n}\nfunction stringifyArray(array, depth, numberAsFloat) {\n if (array.length === 0)\n return '[]';\n let res = '[ ';\n for (let i = 0; i < array.length; i++) {\n if (i)\n res += ', ';\n if (array[i] === null || array[i] === void 0) {\n throw new TypeError('arrays cannot contain null or undefined values');\n }\n res += stringifyValue(array[i], extendedTypeOf(array[i]), depth - 1, numberAsFloat);\n }\n return res + ' ]';\n}\nfunction stringifyArrayTable(array, key, depth, numberAsFloat) {\n if (depth === 0) {\n throw new Error('Could not stringify the object: maximum object depth exceeded');\n }\n let res = '';\n for (let i = 0; i < array.length; i++) {\n res += `${res && '\\n'}[[${key}]]\\n`;\n res += stringifyTable(0, array[i], key, depth, numberAsFloat);\n }\n return res;\n}\nfunction stringifyTable(tableKey, obj, prefix, depth, numberAsFloat) {\n if (depth === 0) {\n throw new Error('Could not stringify the object: maximum object depth exceeded');\n }\n let preamble = '';\n let tables = '';\n let keys = Object.keys(obj);\n for (let i = 0; i < keys.length; i++) {\n let k = keys[i];\n if (obj[k] !== null && obj[k] !== void 0) {\n let type = extendedTypeOf(obj[k]);\n if (type === 'symbol' || type === 'function') {\n throw new TypeError(`cannot serialize values of type '${type}'`);\n }\n let key = BARE_KEY.test(k) ? k : formatString(k);\n if (type === 'array' && isArrayOfTables(obj[k])) {\n tables += (tables && '\\n') + stringifyArrayTable(obj[k], prefix ? `${prefix}.${key}` : key, depth - 1, numberAsFloat);\n }\n else if (type === 'object') {\n let tblKey = prefix ? `${prefix}.${key}` : key;\n tables += (tables && '\\n') + stringifyTable(tblKey, obj[k], tblKey, depth - 1, numberAsFloat);\n }\n else {\n preamble += key;\n preamble += ' = ';\n preamble += stringifyValue(obj[k], type, depth, numberAsFloat);\n preamble += '\\n';\n }\n }\n }\n if (tableKey && (preamble || !tables)) // Create table only if necessary\n preamble = preamble ? `[${tableKey}]\\n${preamble}` : `[${tableKey}]`;\n return preamble && tables\n ? `${preamble}\\n${tables}`\n : preamble || tables;\n}\nexport function stringify(obj, { maxDepth = 1000, numbersAsFloat = false } = {}) {\n if (extendedTypeOf(obj) !== 'object') {\n throw new TypeError('stringify can only be called with an object');\n }\n let str = stringifyTable(0, obj, '', maxDepth, numbersAsFloat);\n if (str[str.length - 1] !== '\\n')\n return str + '\\n';\n return str;\n}\n"],"mappings":"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","names":["endPtr","path","path","asNonEmptyString","asFiniteNumber","asPositiveNumber","asPositiveInteger","asBoolean","assertEnum","asPositiveDecimalString","k","out"]}
1
+ {"version":3,"sources":["../src/index.ts","../../core/src/config/toml.ts","../../core/src/setup.ts","../../core/src/constants.ts","../../core/src/utils/errors.ts","../../core/src/config.ts","../../core/src/client/rest-client.ts","../../core/src/tools/market.ts","../../core/src/tools/account.ts","../../core/src/tools/orders.ts","../../core/src/schemas/futures-grid-create.ts","../../core/src/tools/bot.ts","../../core/src/tools/index.ts","../../core/src/tools/types.ts","../../../node_modules/smol-toml/dist/error.js","../../../node_modules/smol-toml/dist/util.js","../../../node_modules/smol-toml/dist/date.js","../../../node_modules/smol-toml/dist/primitive.js","../../../node_modules/smol-toml/dist/extract.js","../../../node_modules/smol-toml/dist/struct.js","../../../node_modules/smol-toml/dist/parse.js","../../../node_modules/smol-toml/dist/stringify.js"],"sourcesContent":["#!/usr/bin/env node\n\nimport { createInterface } from \"node:readline\";\nimport { basename } from \"node:path\";\nimport {\n readFullConfig,\n writeFullConfig,\n configFilePath,\n runSetup,\n SUPPORTED_CLIENTS,\n type PionexTomlConfig,\n type PionexProfile,\n type ClientId,\n loadConfig,\n PionexRestClient,\n createToolRunner,\n toToolErrorPayload,\n parseAndValidateCreateFuturesGridBuOrderData,\n} from \"@pionex-ai/core\";\n\nconst DEFAULT_PROFILE_NAME = \"pionx-prod\";\nconst DEFAULT_BASE_URL = \"https://api.pionex.com\";\n\nfunction ask(rl: ReturnType<typeof createInterface>, question: string, defaultValue = \"\"): Promise<string> {\n const prompt = defaultValue ? `${question} [${defaultValue}]: ` : `${question}: `;\n return new Promise((resolve) => rl.question(prompt, (answer) => resolve((answer ?? \"\").trim() || defaultValue)));\n}\n\nasync function cmdOnboard(): Promise<void> {\n const rl = createInterface({ input: process.stdin, output: process.stdout });\n\n process.stdout.write(\"\\n pionex-ai-kit v0.2.x\\n\");\n process.stdout.write(\" ⚠️ Security Tips: NEVER send API keys in agent chat. Create a dedicated API Key for your agent. Please test thoroughly before connecting to large real-money accounts.\\n\");\n process.stdout.write(\" ⚠️ 安全提示:切勿在 Agent 对话中发送 API Key。请为 Agent 创建专用API Key接入,先用小金额充分验证后再接入实盘。\\n\\n\");\n\n process.stdout.write(\"Pionex CLI — Configuration Wizard\\n\\n\");\n process.stdout.write(\"Go to https://www.pionex.com/zh-CN/my-account/api to create an API Key (trade permission required)\\n\\n\");\n process.stdout.write(\"Credentials will be saved to \" + configFilePath() + \"\\n\\n\");\n\n const apiKey = await ask(rl, \"Pionex API Key\");\n if (!apiKey) {\n process.stderr.write(\" Error: API Key cannot be empty.\\n\");\n rl.close();\n process.exit(1);\n }\n\n const secretKey = await ask(rl, \"Pionex API Secret\");\n if (!secretKey) {\n process.stderr.write(\" Error: API Secret cannot be empty.\\n\");\n rl.close();\n process.exit(1);\n }\n\n rl.close();\n\n let config: PionexTomlConfig = { profiles: {} };\n try {\n config = readFullConfig();\n } catch {\n config = { profiles: {} };\n }\n if (!config.profiles) config.profiles = {};\n\n const profile: PionexProfile = {\n api_key: apiKey,\n secret_key: secretKey,\n base_url: DEFAULT_BASE_URL,\n };\n const profileName = DEFAULT_PROFILE_NAME;\n config.profiles[profileName] = profile;\n config.default_profile = profileName;\n\n try {\n writeFullConfig(config);\n } catch (e) {\n process.stderr.write(\" Failed to write config: \" + (e instanceof Error ? e.message : String(e)) + \"\\n\");\n process.exit(1);\n }\n\n process.stdout.write(\"\\n Config saved to \" + configFilePath() + \"\\n\");\n process.stdout.write(\" Default profile: \" + profileName + \"\\n\");\n process.stdout.write(\" Usage: pionex-ai-kit onboard\\n\");\n process.stdout.write(\n \" Next: run 'pionex-ai-kit setup --mcp=pionex-trade-mcp --client cursor' or \" +\n \"'pionex-trade-mcp setup --client cursor' to register the MCP server.\\n\" +\n \" You can replace 'cursor' with 'claude-desktop', 'windsurf', 'vscode', 'claude-code', 'claude' or 'openclaw' depending on which agent you want to configure.\\n\\n\",\n );\n}\n\nfunction printHelp(): void {\n process.stdout.write(`\nUsage: pionex-ai-kit <command>\n\nCommands:\n onboard Interactive wizard to create ~/.pionex/config.toml (API key, secret)\n help Show this help\n\nThe MCP server (pionex-trade-mcp) reads credentials from ~/.pionex/config.toml.\nUse 'pionex-ai-kit setup --mcp=pionex-trade-mcp --client <client>' to write MCP client config\nthat runs 'npx @pionex/pionex-trade-mcp' (no keys are written to the client config).\n\n`);\n}\n\nfunction parseSetupArgs(argv: string[]): { mcp?: string; client?: string } {\n let mcp: string | undefined;\n let client: string | undefined;\n for (let i = 0; i < argv.length; i++) {\n const arg = argv[i];\n if (arg === \"--mcp\" && argv[i + 1]) {\n mcp = argv[++i];\n } else if (arg.startsWith(\"--mcp=\")) {\n mcp = arg.slice(\"--mcp=\".length);\n } else if (arg === \"--client\" && argv[i + 1]) {\n client = argv[++i];\n } else if (arg.startsWith(\"--client=\")) {\n client = arg.slice(\"--client=\".length);\n }\n }\n return { mcp, client };\n}\n\nfunction cmdSetup(argv: string[]): void {\n const { mcp, client } = parseSetupArgs(argv);\n const targetMcp = mcp ?? \"pionex-trade-mcp\";\n if (targetMcp !== \"pionex-trade-mcp\") {\n process.stderr.write(`Unsupported MCP server: ${targetMcp}. Currently only 'pionex-trade-mcp' is supported.\\n`);\n process.exit(1);\n }\n if (!client) {\n process.stderr.write(\n \"Usage: pionex-ai-kit setup --mcp=pionex-trade-mcp --client <\" +\n SUPPORTED_CLIENTS.join(\"|\") +\n \">\\n\",\n );\n process.exit(1);\n }\n\n // Allow 'claude' as an alias for 'claude-code'\n const normalizedClient = client === \"claude\" ? \"claude-code\" : client;\n\n if (!SUPPORTED_CLIENTS.includes(normalizedClient as ClientId)) {\n process.stderr.write(\n `Unsupported client: ${client}. Supported: ${[...SUPPORTED_CLIENTS, \"claude (alias for claude-code)\"].join(\n \", \",\n )}\\n`,\n );\n process.exit(1);\n }\n\n runSetup({ client: normalizedClient as ClientId });\n}\n\ntype FlagValue = string | boolean;\n\nfunction parseFlags(argv: string[]): { positionals: string[]; flags: Record<string, FlagValue> } {\n const positionals: string[] = [];\n const flags: Record<string, FlagValue> = {};\n\n for (let i = 0; i < argv.length; i++) {\n const a = argv[i];\n if (!a.startsWith(\"--\")) {\n positionals.push(a);\n continue;\n }\n const eq = a.indexOf(\"=\");\n if (eq !== -1) {\n const k = a.slice(2, eq);\n const v = a.slice(eq + 1);\n flags[k] = v === \"true\" ? true : v === \"false\" ? false : v;\n continue;\n }\n const k = a.slice(2);\n const next = argv[i + 1];\n if (!next || next.startsWith(\"--\")) {\n flags[k] = true;\n continue;\n }\n flags[k] = next;\n i++;\n }\n\n return { positionals, flags };\n}\n\nfunction printPionexHelp(): void {\n process.stdout.write(`\nUsage: pionex-trade-cli <group> <command> [args] [--flags]\n\nGroups:\n market Market data (public)\n account Account data (requires auth)\n orders Spot orders (requires auth)\n bot Bot commands (requires auth) — use sub-route futures_grid (more bot types may be added later)\n\nExamples:\n pionex-trade-cli market depth BTC_USDT --limit 5\n pionex-trade-cli market tickers --symbol BTC_USDT\n pionex-trade-cli market book-tickers --symbol BTC_USDT\n pionex-trade-cli market symbols --symbols BTC_USDT\n pionex-trade-cli account balance\n pionex-trade-cli orders new --symbol BTC_USDT --side BUY --type MARKET --amount 10\n pionex-trade-cli orders cancel --symbol BTC_USDT --order-id 123\n pionex-trade-cli orders fills-by-order-id --symbol BTC_USDT --order-id 123\n pionex-trade-cli bot futures_grid get --bu-order-id <id>\n pionex-trade-cli bot futures_grid create --base BTC --quote USDT --bu-order-data-json '{\"top\":\"110000\",\"bottom\":\"90000\",\"row\":100,\"grid_type\":\"arithmetic\",\"trend\":\"long\",\"leverage\":5,\"quoteInvestment\":\"100\"}'\n\nGlobal flags:\n --profile <name> Profile in ~/.pionex/config.toml\n --modules <list> Comma-separated modules (market,account,orders or all)\n --base-url <url> Override API base URL\n --read-only Disable write operations (orders new/cancel)\n --dry-run Print resolved futures-grid create body without executing (bot futures_grid create only)\n\nFutures grid create (pionex-trade-cli bot futures_grid create) — strict OpenAPI (same validation as MCP):\n --base Required; normalized to <BASE>.PERP if suffix missing\n --quote Required (e.g. USDT)\n --bu-order-data-json Required JSON object — ONLY keys from CreateFuturesGridOrderData in openapi_bot.yaml\n Optional: --copy-from, --copy-type, --copy-bot-order-id\n buOrderData required: top, bottom, row, grid_type, trend, leverage, quoteInvestment\n buOrderData optional (names only): extraMargin, condition, conditionDirection, lossStopType, lossStop,\n lossStopDelay, profitStopType, profitStop, profitStopDelay, lossStopHigh, shareRatio, investCoin,\n investmentFrom, uiInvestCoin, lossStopLimitPrice, lossStopLimitHighPrice, profitStopLimitPrice,\n slippage, bonusId, uiExtraData, movingIndicatorType, movingIndicatorInterval, movingIndicatorParam,\n movingTrailingUpParam, cateType, movingTop, movingBottom, enableFollowClosed\n Unknown keys → error\n YAML: https://github.com/pionex-official/pionex-open-api/blob/main/openapi_bot.yaml\n Docs: https://www.pionex.com/docs/api-docs/bot-api/futures-grid\n`);\n}\n\nfunction parseJsonFlag(raw: unknown, flagName: string): Record<string, unknown> {\n if (typeof raw !== \"string\") {\n throw new Error(`Missing required flag: --${flagName}`);\n }\n try {\n const parsed = JSON.parse(raw) as unknown;\n if (!parsed || typeof parsed !== \"object\" || Array.isArray(parsed)) {\n throw new Error(\"must be a JSON object\");\n }\n return parsed as Record<string, unknown>;\n } catch (e) {\n const msg = e instanceof Error ? e.message : String(e);\n throw new Error(`Invalid --${flagName}: ${msg}`);\n }\n}\n\nasync function runPionexCommand(argv: string[]): Promise<void> {\n const { positionals, flags } = parseFlags(argv);\n const group = positionals[0];\n /** For \\`bot\\` group, positionals are: bot <sub-route> <command> ... */\n const command = group === \"bot\" ? positionals[2] : positionals[1];\n\n if (!group || group === \"help\" || group === \"--help\" || group === \"-h\") {\n printPionexHelp();\n return;\n }\n\n const config = loadConfig({\n profile: typeof flags.profile === \"string\" ? flags.profile : undefined,\n modules: typeof flags.modules === \"string\" ? flags.modules : undefined,\n baseUrl: typeof flags[\"base-url\"] === \"string\" ? (flags[\"base-url\"] as string) : typeof flags.baseUrl === \"string\" ? (flags.baseUrl as string) : undefined,\n readOnly: Boolean(flags[\"read-only\"] || flags.readOnly),\n });\n\n const client = new PionexRestClient(config);\n const runTool = createToolRunner(client, config);\n\n const dryRun = Boolean(flags[\"dry-run\"] || flags.dryRun);\n\n // market\n if (group === \"market\") {\n if (command === \"depth\") {\n const symbol = positionals[2];\n if (!symbol) throw new Error(\"Missing symbol. Example: pionex-trade-cli market depth BTC_USDT\");\n const limit = flags.limit != null ? Number(flags.limit) : undefined;\n const out = await runTool(\"pionex_market_get_depth\", { symbol, limit });\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"trades\") {\n const symbol = positionals[2];\n if (!symbol) throw new Error(\"Missing symbol. Example: pionex-trade-cli market trades BTC_USDT\");\n const limit = flags.limit != null ? Number(flags.limit) : undefined;\n const out = await runTool(\"pionex_market_get_trades\", { symbol, limit });\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"symbols\") {\n const symbols = typeof flags.symbols === \"string\" ? flags.symbols : undefined;\n const type = typeof flags.type === \"string\" ? flags.type : undefined;\n const out = await runTool(\"pionex_market_get_symbol_info\", { symbols, type });\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"tickers\") {\n const symbol = typeof flags.symbol === \"string\" ? flags.symbol : undefined;\n const type = typeof flags.type === \"string\" ? flags.type : undefined;\n const out = await runTool(\"pionex_market_get_tickers\", { symbol, type });\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"book-tickers\" || command === \"bookTickers\") {\n const symbol = typeof flags.symbol === \"string\" ? flags.symbol : undefined;\n const type = typeof flags.type === \"string\" ? flags.type : undefined;\n const out = await runTool(\"pionex_market_get_book_tickers\", { symbol, type });\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"klines\") {\n const symbol = typeof flags.symbol === \"string\" ? flags.symbol : positionals[2];\n const interval = typeof flags.interval === \"string\" ? flags.interval : positionals[3];\n if (!symbol || !interval) throw new Error(\"Missing symbol/interval. Example: pionex-trade-cli market klines BTC_USDT 60M\");\n const endTime = flags.endTime != null ? Number(flags.endTime) : undefined;\n const limit = flags.limit != null ? Number(flags.limit) : undefined;\n const out = await runTool(\"pionex_market_get_klines\", { symbol, interval, endTime, limit });\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n throw new Error(`Unknown market command: ${command}`);\n }\n\n // account\n if (group === \"account\") {\n if (command === \"balance\") {\n const out = await runTool(\"pionex_account_get_balance\", {});\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n throw new Error(`Unknown account command: ${command}`);\n }\n\n // orders\n if (group === \"orders\") {\n if (command === \"new\") {\n const symbol = typeof flags.symbol === \"string\" ? flags.symbol : undefined;\n const side = typeof flags.side === \"string\" ? flags.side : undefined;\n const type = typeof flags.type === \"string\" ? flags.type : undefined;\n const clientOrderId = typeof flags[\"client-order-id\"] === \"string\" ? (flags[\"client-order-id\"] as string) : typeof flags.clientOrderId === \"string\" ? (flags.clientOrderId as string) : undefined;\n const size = typeof flags.size === \"string\" ? flags.size : undefined;\n const price = typeof flags.price === \"string\" ? flags.price : undefined;\n const amount = typeof flags.amount === \"string\" ? flags.amount : undefined;\n const IOC = typeof flags.IOC === \"boolean\" ? flags.IOC : undefined;\n if (!symbol || !side || !type) throw new Error(\"Missing required flags: --symbol --side --type\");\n const payload = { symbol, side, type, clientOrderId, size, price, amount, IOC };\n if (dryRun) {\n process.stdout.write(JSON.stringify({ tool: \"pionex_orders_new_order\", args: payload }, null, 2) + \"\\n\");\n return;\n }\n const out = await runTool(\"pionex_orders_new_order\", payload);\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"get\") {\n const symbol = typeof flags.symbol === \"string\" ? flags.symbol : undefined;\n const orderId = flags[\"order-id\"] != null ? Number(flags[\"order-id\"]) : undefined;\n if (!symbol || orderId == null) throw new Error(\"Missing required flags: --symbol --order-id\");\n const out = await runTool(\"pionex_orders_get_order\", { symbol, orderId });\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"open\") {\n const symbol = typeof flags.symbol === \"string\" ? flags.symbol : undefined;\n if (!symbol) throw new Error(\"Missing required flag: --symbol\");\n const out = await runTool(\"pionex_orders_get_open_orders\", { symbol });\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"all\") {\n const symbol = typeof flags.symbol === \"string\" ? flags.symbol : undefined;\n const limit = flags.limit != null ? Number(flags.limit) : undefined;\n if (!symbol) throw new Error(\"Missing required flag: --symbol\");\n const out = await runTool(\"pionex_orders_get_all_orders\", { symbol, limit });\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"fills\") {\n const symbol = typeof flags.symbol === \"string\" ? flags.symbol : undefined;\n const startTime = flags.startTime != null ? Number(flags.startTime) : undefined;\n const endTime = flags.endTime != null ? Number(flags.endTime) : undefined;\n if (!symbol) throw new Error(\"Missing required flag: --symbol\");\n const out = await runTool(\"pionex_orders_get_fills\", { symbol, startTime, endTime });\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"fills-by-order-id\" || command === \"fillsByOrderId\") {\n const symbol = typeof flags.symbol === \"string\" ? flags.symbol : undefined;\n const orderId = flags[\"order-id\"] != null ? Number(flags[\"order-id\"]) : undefined;\n if (!symbol || orderId == null) throw new Error(\"Missing required flags: --symbol --order-id\");\n const out = await runTool(\"pionex_orders_get_fills_by_order_id\", { symbol, orderId });\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"cancel\") {\n const symbol = typeof flags.symbol === \"string\" ? flags.symbol : undefined;\n const orderId = flags[\"order-id\"] != null ? Number(flags[\"order-id\"]) : undefined;\n if (!symbol || orderId == null) throw new Error(\"Missing required flags: --symbol --order-id\");\n const payload = { symbol, orderId };\n if (dryRun) {\n process.stdout.write(JSON.stringify({ tool: \"pionex_orders_cancel_order\", args: payload }, null, 2) + \"\\n\");\n return;\n }\n const out = await runTool(\"pionex_orders_cancel_order\", payload);\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"cancel-all\") {\n const symbol = typeof flags.symbol === \"string\" ? flags.symbol : undefined;\n if (!symbol) throw new Error(\"Missing required flag: --symbol\");\n const payload = { symbol };\n if (dryRun) {\n process.stdout.write(JSON.stringify({ tool: \"pionex_orders_cancel_all_orders\", args: payload }, null, 2) + \"\\n\");\n return;\n }\n const out = await runTool(\"pionex_orders_cancel_all_orders\", payload);\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n throw new Error(`Unknown orders command: ${command}`);\n }\n\n // bot\n if (group === \"bot\") {\n const botRoute = positionals[1];\n if (!botRoute || botRoute !== \"futures_grid\") {\n throw new Error(\n `Missing or unknown bot route: ${botRoute ?? \"(none)\"}. Use: pionex-trade-cli bot futures_grid <get|create|adjust_params|reduce|cancel> ...`\n );\n }\n if (!command) {\n throw new Error(\n \"Missing bot command. Example: pionex-trade-cli bot futures_grid create --base BTC --quote USDT --bu-order-data-json '{...}'\"\n );\n }\n if (command === \"get\") {\n const buOrderId =\n typeof flags[\"bu-order-id\"] === \"string\"\n ? (flags[\"bu-order-id\"] as string)\n : typeof flags.buOrderId === \"string\"\n ? (flags.buOrderId as string)\n : undefined;\n const lang = typeof flags.lang === \"string\" ? flags.lang : undefined;\n if (!buOrderId) throw new Error(\"Missing required flag: --bu-order-id\");\n const out = await runTool(\"pionex_bot_futures_grid_get_order\", { buOrderId, lang });\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"create\") {\n const base = typeof flags.base === \"string\" ? flags.base : undefined;\n const quote = typeof flags.quote === \"string\" ? flags.quote : undefined;\n const copyFrom = typeof flags[\"copy-from\"] === \"string\" ? (flags[\"copy-from\"] as string) : typeof flags.copyFrom === \"string\" ? (flags.copyFrom as string) : undefined;\n const copyType = typeof flags[\"copy-type\"] === \"string\" ? (flags[\"copy-type\"] as string) : typeof flags.copyType === \"string\" ? (flags.copyType as string) : undefined;\n const copyBotOrderId =\n typeof flags[\"copy-bot-order-id\"] === \"string\"\n ? (flags[\"copy-bot-order-id\"] as string)\n : typeof flags.copyBotOrderId === \"string\"\n ? (flags.copyBotOrderId as string)\n : undefined;\n const buOrderDataRaw = parseJsonFlag(flags[\"bu-order-data-json\"] ?? flags.buOrderDataJson, \"bu-order-data-json\");\n if (!base || !quote) {\n throw new Error(\"Missing required flags: --base --quote --bu-order-data-json\");\n }\n const buOrderData = parseAndValidateCreateFuturesGridBuOrderData(buOrderDataRaw);\n const payload: Record<string, unknown> = { base, quote, copyFrom, copyType, copyBotOrderId, buOrderData };\n if (dryRun) {\n const out = await runTool(\"pionex_bot_futures_grid_create\", { ...payload, __dryRun: true });\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n const out = await runTool(\"pionex_bot_futures_grid_create\", payload);\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"adjust_params\") {\n const payload = parseJsonFlag(flags[\"body-json\"] ?? flags.bodyJson, \"body-json\");\n if (dryRun) {\n process.stdout.write(JSON.stringify({ tool: \"pionex_bot_futures_grid_adjust_params\", args: payload }, null, 2) + \"\\n\");\n return;\n }\n const out = await runTool(\"pionex_bot_futures_grid_adjust_params\", payload);\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"reduce\") {\n const payload = parseJsonFlag(flags[\"body-json\"] ?? flags.bodyJson, \"body-json\");\n if (dryRun) {\n process.stdout.write(JSON.stringify({ tool: \"pionex_bot_futures_grid_reduce\", args: payload }, null, 2) + \"\\n\");\n return;\n }\n const out = await runTool(\"pionex_bot_futures_grid_reduce\", payload);\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"cancel\") {\n const buOrderId =\n typeof flags[\"bu-order-id\"] === \"string\"\n ? (flags[\"bu-order-id\"] as string)\n : typeof flags.buOrderId === \"string\"\n ? (flags.buOrderId as string)\n : undefined;\n const closeNote = typeof flags[\"close-note\"] === \"string\" ? (flags[\"close-note\"] as string) : typeof flags.closeNote === \"string\" ? (flags.closeNote as string) : undefined;\n const closeSellModel =\n typeof flags[\"close-sell-model\"] === \"string\"\n ? (flags[\"close-sell-model\"] as string)\n : typeof flags.closeSellModel === \"string\"\n ? (flags.closeSellModel as string)\n : undefined;\n const immediate = typeof flags.immediate === \"boolean\" ? flags.immediate : undefined;\n const closeSlippage =\n typeof flags[\"close-slippage\"] === \"string\"\n ? (flags[\"close-slippage\"] as string)\n : typeof flags.closeSlippage === \"string\"\n ? (flags.closeSlippage as string)\n : undefined;\n if (!buOrderId) throw new Error(\"Missing required flag: --bu-order-id\");\n const payload = { buOrderId, closeNote, closeSellModel, immediate, closeSlippage };\n if (dryRun) {\n process.stdout.write(JSON.stringify({ tool: \"pionex_bot_futures_grid_cancel\", args: payload }, null, 2) + \"\\n\");\n return;\n }\n const out = await runTool(\"pionex_bot_futures_grid_cancel\", payload);\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n throw new Error(`Unknown futures_grid command: ${command}`);\n }\n\n throw new Error(`Unknown group: ${group}`);\n}\n\nfunction main(): void {\n const invokedAs = basename(process.argv[1] || \"\");\n const cmd = process.argv[2];\n\n // Backwards-compatible: keep \"pionex-ai-kit onboard/setup/help\"\n if (invokedAs.includes(\"pionex-ai-kit\")) {\n if (cmd === \"onboard\") {\n cmdOnboard().catch((e) => {\n process.stderr.write(String(e) + \"\\n\");\n process.exit(1);\n });\n return;\n }\n if (cmd === \"setup\") {\n cmdSetup(process.argv.slice(3));\n return;\n }\n if (cmd === \"help\" || cmd === \"--help\" || cmd === \"-h\" || !cmd) {\n printHelp();\n return;\n }\n process.stderr.write(\"Unknown command: \" + cmd + \". Run 'pionex-ai-kit help'.\\n\");\n process.exit(1);\n return;\n }\n\n // New: \"pionex-trade-cli <group> <command> ...\"\n runPionexCommand(process.argv.slice(2)).catch((e) => {\n const payload = toToolErrorPayload(e);\n process.stderr.write(JSON.stringify(payload, null, 2) + \"\\n\");\n process.exit(1);\n });\n}\n\nmain();\n","import { readFileSync, writeFileSync, mkdirSync, existsSync } from \"node:fs\";\nimport { join, dirname } from \"node:path\";\nimport { homedir } from \"node:os\";\nimport { parse, stringify } from \"smol-toml\";\n\nexport { stringify as tomlStringify };\n\nexport interface PionexProfile {\n api_key?: string;\n secret_key?: string;\n base_url?: string;\n}\n\nexport interface PionexTomlConfig {\n default_profile?: string;\n profiles: Record<string, PionexProfile>;\n}\n\n/** Fixed path: ~/.pionex/config.toml */\nexport function configFilePath(): string {\n return join(homedir(), \".pionex\", \"config.toml\");\n}\n\nexport function readFullConfig(): PionexTomlConfig {\n const path = configFilePath();\n if (!existsSync(path)) return { profiles: {} };\n const raw = readFileSync(path, \"utf-8\");\n return parse(raw) as unknown as PionexTomlConfig;\n}\n\nexport function readTomlProfile(profileName?: string): PionexProfile {\n const config = readFullConfig();\n const name = profileName ?? config.default_profile ?? \"default\";\n return config.profiles?.[name] ?? {};\n}\n\nexport function writeFullConfig(config: PionexTomlConfig): void {\n const path = configFilePath();\n const dir = dirname(path);\n if (!existsSync(dir)) {\n mkdirSync(dir, { recursive: true });\n }\n writeFileSync(path, stringify(config as unknown as Record<string, unknown>), \"utf-8\");\n}\n","import * as fs from \"node:fs\";\nimport * as path from \"node:path\";\nimport * as os from \"node:os\";\nimport { execFileSync } from \"node:child_process\";\nimport { configFilePath } from \"./config/toml.js\";\n\nexport type ClientId = \"claude-desktop\" | \"cursor\" | \"windsurf\" | \"vscode\" | \"claude-code\" | \"openclaw\";\n\nconst CLIENT_NAMES: Record<ClientId, string> = {\n \"claude-desktop\": \"Claude Desktop\",\n cursor: \"Cursor\",\n windsurf: \"Windsurf\",\n vscode: \"VS Code\",\n \"claude-code\": \"Claude Code CLI\",\n openclaw: \"OpenClaw (mcporter)\",\n};\n\nexport const SUPPORTED_CLIENTS = Object.keys(CLIENT_NAMES) as ClientId[];\n\nfunction appData(): string {\n return process.env.APPDATA ?? path.join(os.homedir(), \"AppData\", \"Roaming\");\n}\n\nconst CLAUDE_CONFIG_FILE = \"claude_desktop_config.json\";\n\nfunction findMsStoreClaudePath(): string | null {\n const localAppData = process.env.LOCALAPPDATA ?? path.join(os.homedir(), \"AppData\", \"Local\");\n const packagesDir = path.join(localAppData, \"Packages\");\n try {\n const entries = fs.readdirSync(packagesDir);\n const claudePkg = entries.find((e) => e.startsWith(\"Claude_\"));\n if (claudePkg) {\n const configPath = path.join(\n packagesDir,\n claudePkg,\n \"LocalCache\",\n \"Roaming\",\n \"Claude\",\n CLAUDE_CONFIG_FILE,\n );\n if (fs.existsSync(configPath) || fs.existsSync(path.dirname(configPath))) {\n return configPath;\n }\n }\n } catch {\n // ignore missing or unreadable Packages dir\n }\n return null;\n}\n\nexport function getConfigPath(client: ClientId): string | null {\n const home = os.homedir();\n const platform = process.platform;\n switch (client) {\n case \"claude-desktop\":\n if (platform === \"win32\") {\n return findMsStoreClaudePath() ?? path.join(appData(), \"Claude\", CLAUDE_CONFIG_FILE);\n }\n if (platform === \"darwin\") {\n return path.join(home, \"Library\", \"Application Support\", \"Claude\", CLAUDE_CONFIG_FILE);\n }\n return path.join(process.env.XDG_CONFIG_HOME ?? path.join(home, \".config\"), \"Claude\", CLAUDE_CONFIG_FILE);\n case \"cursor\":\n return path.join(home, \".cursor\", \"mcp.json\");\n case \"windsurf\":\n return path.join(home, \".codeium\", \"windsurf\", \"mcp_config.json\");\n case \"vscode\":\n return path.join(process.cwd(), \".mcp.json\");\n case \"claude-code\":\n return null;\n case \"openclaw\":\n return path.join(home, \".openclaw\", \"workspace\", \"config\", \"mcporter.json\");\n }\n}\n\nconst NPX_PACKAGE = \"@pionex/pionex-trade-mcp\";\n\nfunction buildEntry(client: ClientId): Record<string, unknown> {\n if (client === \"vscode\") {\n // VS Code MCP expects an explicit stdio transport field.\n return { type: \"stdio\", command: \"npx\", args: [\"-y\", NPX_PACKAGE] };\n }\n // Other clients (Cursor, Claude Desktop, Windsurf, OpenClaw, etc.) use npx\n // with the scoped package name so that users do not need to manage PATH.\n return { command: \"npx\", args: [\"-y\", NPX_PACKAGE] };\n}\n\nfunction mergeJsonConfig(\n configPath: string,\n serverName: string,\n entry: Record<string, unknown>\n): void {\n const dir = path.dirname(configPath);\n if (!fs.existsSync(dir)) fs.mkdirSync(dir, { recursive: true });\n\n let data: Record<string, unknown> = {};\n if (fs.existsSync(configPath)) {\n const raw = fs.readFileSync(configPath, \"utf-8\");\n try {\n data = JSON.parse(raw) as Record<string, unknown>;\n } catch {\n throw new Error(`Failed to parse existing config at ${configPath}`);\n }\n }\n\n if (typeof data.mcpServers !== \"object\" || data.mcpServers === null) {\n data.mcpServers = {};\n }\n (data.mcpServers as Record<string, unknown>)[serverName] = entry;\n\n fs.writeFileSync(configPath, JSON.stringify(data, null, 2) + \"\\n\", \"utf-8\");\n}\n\nexport interface SetupOptions {\n client: ClientId;\n}\n\nexport function runSetup(options: SetupOptions): void {\n const { client } = options;\n const name = CLIENT_NAMES[client];\n const serverName = \"pionex-trade-mcp\";\n\n if (client === \"claude-code\") {\n const claudeArgs = [\n \"mcp\",\n \"add\",\n \"--scope\",\n \"user\",\n \"--transport\",\n \"stdio\",\n serverName,\n \"--\",\n \"npx\",\n \"-y\",\n NPX_PACKAGE,\n ];\n process.stdout.write(`Running: claude ${claudeArgs.join(\" \")}\\n`);\n execFileSync(\"claude\", claudeArgs, { stdio: \"inherit\" });\n process.stdout.write(`✓ Configured ${name}\\n`);\n return;\n }\n\n const configPath = getConfigPath(client);\n if (!configPath) {\n throw new Error(`${name} is not supported on this platform`);\n }\n\n const entry = buildEntry(client);\n mergeJsonConfig(configPath, serverName, entry);\n process.stdout.write(\n `✓ Configured ${name}\\n ${configPath}\\n Restart ${name} to apply changes.\\n`\n );\n}\n\nexport function printSetupUsage(): void {\n process.stdout.write(\n `Usage: pionex-trade-mcp setup --client <client>\\n\\n` +\n `Clients:\\n` +\n SUPPORTED_CLIENTS.map((id) => ` ${id.padEnd(16)} ${CLIENT_NAMES[id]}`).join(\"\\n\") +\n `\\n\\nCredentials are read from ${configFilePath()}. Run \"pionex-ai-kit config init\" (from pionex-ai-kit) first.\\n`\n );\n}\n","export const PIONEX_API_DEFAULT_BASE_URL = \"https://api.pionex.com\";\n\nexport const MODULES = [\"market\", \"account\", \"orders\", \"bot\"] as const;\nexport type ModuleId = (typeof MODULES)[number];\n\nexport const DEFAULT_MODULES: ModuleId[] = [\"market\", \"account\", \"orders\", \"bot\"];\n\n","export class ConfigError extends Error {\n public readonly suggestion?: string;\n public constructor(message: string, suggestion?: string) {\n super(message);\n this.name = \"ConfigError\";\n this.suggestion = suggestion;\n }\n}\n\nexport class PionexApiError extends Error {\n public readonly status?: number;\n public readonly endpoint?: string;\n public readonly responseText?: string;\n public constructor(\n message: string,\n opts?: { status?: number; endpoint?: string; responseText?: string },\n ) {\n super(message);\n this.name = \"PionexApiError\";\n this.status = opts?.status;\n this.endpoint = opts?.endpoint;\n this.responseText = opts?.responseText;\n }\n}\n\nexport function toToolErrorPayload(error: unknown): Record<string, unknown> {\n if (error instanceof ConfigError) {\n return {\n error: true,\n type: \"ConfigError\",\n message: error.message,\n suggestion: error.suggestion,\n };\n }\n if (error instanceof PionexApiError) {\n return {\n error: true,\n type: \"PionexApiError\",\n message: error.message,\n status: error.status,\n endpoint: error.endpoint,\n responseText: error.responseText,\n };\n }\n const message = error instanceof Error ? error.message : String(error);\n return { error: true, type: \"Error\", message };\n}\n\n","import { readTomlProfile } from \"./config/toml.js\";\nimport { PIONEX_API_DEFAULT_BASE_URL, DEFAULT_MODULES, MODULES, type ModuleId } from \"./constants.js\";\nimport { ConfigError } from \"./utils/errors.js\";\n\nexport interface CliOptions {\n modules?: string;\n readOnly: boolean;\n profile?: string;\n baseUrl?: string;\n}\n\nexport interface PionexConfig {\n apiKey?: string;\n apiSecret?: string;\n hasAuth: boolean;\n baseUrl: string;\n modules: ModuleId[];\n readOnly: boolean;\n}\n\nfunction parseModuleList(rawModules?: string): ModuleId[] {\n if (!rawModules || rawModules.trim().length === 0) return [...DEFAULT_MODULES];\n const trimmed = rawModules.trim().toLowerCase();\n if (trimmed === \"all\") return [...MODULES];\n\n const requested = trimmed\n .split(\",\")\n .map((x) => x.trim())\n .filter(Boolean);\n if (requested.length === 0) return [...DEFAULT_MODULES];\n\n const out: ModuleId[] = [];\n for (const m of requested) {\n if (!MODULES.includes(m as ModuleId)) {\n throw new ConfigError(`Unknown module \"${m}\".`, `Use one of: ${MODULES.join(\", \")} or \"all\".`);\n }\n out.push(m as ModuleId);\n }\n return Array.from(new Set(out));\n}\n\n/**\n * Credential priority (highest to lowest):\n * 1. Environment variables (PIONEX_API_KEY / PIONEX_API_SECRET)\n * 2. ~/.pionex/config.toml profile values\n */\nexport function loadConfig(cli: CliOptions): PionexConfig {\n const toml = readTomlProfile(cli.profile);\n\n const apiKey = process.env.PIONEX_API_KEY?.trim() || toml.api_key;\n const apiSecret = process.env.PIONEX_API_SECRET?.trim() || toml.secret_key;\n\n const hasAuth = Boolean(apiKey && apiSecret);\n const partialAuth = Boolean(apiKey) || Boolean(apiSecret);\n if (partialAuth && !hasAuth) {\n throw new ConfigError(\n \"Partial Pionex API credentials detected.\",\n \"Set both PIONEX_API_KEY and PIONEX_API_SECRET (env vars or config.toml profile).\",\n );\n }\n\n const baseUrl = (cli.baseUrl?.trim() || process.env.PIONEX_BASE_URL?.trim() || toml.base_url || PIONEX_API_DEFAULT_BASE_URL)\n .replace(/\\/+$/, \"\");\n if (!baseUrl.startsWith(\"http://\") && !baseUrl.startsWith(\"https://\")) {\n throw new ConfigError(`Invalid base URL \"${baseUrl}\".`, \"PIONEX_BASE_URL must start with http:// or https://\");\n }\n\n return {\n apiKey,\n apiSecret,\n hasAuth,\n baseUrl,\n modules: parseModuleList(cli.modules),\n readOnly: cli.readOnly,\n };\n}\n\n","import crypto from \"node:crypto\";\nimport type { PionexConfig } from \"../config.js\";\nimport { PionexApiError, ConfigError } from \"../utils/errors.js\";\nimport type { HttpMethod, QueryParams, RequestResult } from \"./types.js\";\n\nfunction requireAuth(config: PionexConfig): { apiKey: string; apiSecret: string } {\n if (!config.apiKey || !config.apiSecret) {\n throw new ConfigError(\n \"This operation requires authentication, but no Pionex API credentials were found.\",\n \"Run 'pionex-ai-kit onboard' to create ~/.pionex/config.toml, or set PIONEX_API_KEY and PIONEX_API_SECRET.\",\n );\n }\n return { apiKey: config.apiKey, apiSecret: config.apiSecret };\n}\n\nfunction buildQueryString(query?: QueryParams): string {\n if (!query) return \"\";\n const entries = Object.entries(query).filter(([, v]) => v !== undefined && v !== null);\n if (entries.length === 0) return \"\";\n const params = new URLSearchParams();\n for (const [k, v] of entries) params.set(k, String(v));\n return params.toString();\n}\n\nfunction buildSignedRequest(\n config: PionexConfig,\n method: HttpMethod,\n path: string,\n query: QueryParams,\n bodyJson: string | null,\n): { url: string; headers: Record<string, string>; bodyJson: string | null } {\n const { apiKey, apiSecret } = requireAuth(config);\n const timestamp = Date.now().toString();\n const params: Record<string, unknown> = { ...query, timestamp };\n\n const sortedKeys = Object.keys(params).sort();\n const queryString = sortedKeys.map((k) => `${k}=${params[k]}`).join(\"&\");\n const pathUrl = `${path}?${queryString}`;\n\n let payload = `${method}${pathUrl}`;\n if (bodyJson != null) payload += bodyJson;\n const signature = crypto.createHmac(\"sha256\", apiSecret).update(payload).digest(\"hex\");\n\n const url = `${config.baseUrl}${pathUrl}`;\n const headers = {\n \"PIONEX-KEY\": apiKey,\n \"PIONEX-SIGNATURE\": signature,\n \"Content-Type\": \"application/json\",\n };\n return { url, headers, bodyJson };\n}\n\nasync function readTextSafe(res: Response): Promise<string> {\n try {\n return await res.text();\n } catch {\n return \"\";\n }\n}\n\nexport class PionexRestClient {\n private readonly config: PionexConfig;\n public constructor(config: PionexConfig) {\n this.config = config;\n }\n\n public async publicGet<TData = unknown>(path: string, query: QueryParams = {}): Promise<RequestResult<TData>> {\n const qs = buildQueryString(query);\n const endpoint = qs ? `${path}?${qs}` : path;\n const url = `${this.config.baseUrl}${endpoint}`;\n const res = await fetch(url, { method: \"GET\", headers: { \"Content-Type\": \"application/json\" } });\n if (!res.ok) {\n const txt = await readTextSafe(res);\n throw new PionexApiError(`HTTP ${res.status}: ${txt || res.statusText}`, { status: res.status, endpoint, responseText: txt });\n }\n const data = (await res.json()) as TData;\n return { endpoint, requestTime: new Date().toISOString(), data };\n }\n\n public async signedGet<TData = unknown>(path: string, query: QueryParams = {}): Promise<RequestResult<TData>> {\n const { url, headers } = buildSignedRequest(this.config, \"GET\", path, query, null);\n const endpoint = `${path}?${buildQueryString({ ...query, timestamp: \"...\" })}`;\n const res = await fetch(url, { method: \"GET\", headers });\n if (!res.ok) {\n const txt = await readTextSafe(res);\n throw new PionexApiError(`HTTP ${res.status}: ${txt || res.statusText}`, { status: res.status, endpoint: path, responseText: txt });\n }\n const data = (await res.json()) as TData;\n return { endpoint: path, requestTime: new Date().toISOString(), data };\n }\n\n public async signedPost<TData = unknown>(path: string, body: Record<string, unknown>): Promise<RequestResult<TData>> {\n const bodyJson = JSON.stringify(body);\n const { url, headers, bodyJson: bj } = buildSignedRequest(this.config, \"POST\", path, {}, bodyJson);\n const res = await fetch(url, { method: \"POST\", headers, body: bj ?? undefined });\n if (!res.ok) {\n const txt = await readTextSafe(res);\n throw new PionexApiError(`HTTP ${res.status}: ${txt || res.statusText}`, { status: res.status, endpoint: path, responseText: txt });\n }\n const data = (await res.json()) as TData;\n return { endpoint: path, requestTime: new Date().toISOString(), data };\n }\n\n public async signedDelete<TData = unknown>(path: string, body: Record<string, unknown>): Promise<RequestResult<TData>> {\n const bodyJson = JSON.stringify(body);\n const { url, headers, bodyJson: bj } = buildSignedRequest(this.config, \"DELETE\", path, {}, bodyJson);\n const res = await fetch(url, { method: \"DELETE\", headers, body: bj ?? undefined });\n if (!res.ok) {\n const txt = await readTextSafe(res);\n throw new PionexApiError(`HTTP ${res.status}: ${txt || res.statusText}`, { status: res.status, endpoint: path, responseText: txt });\n }\n const data = (await res.json()) as TData;\n return { endpoint: path, requestTime: new Date().toISOString(), data };\n }\n}\n\n","import type { ToolSpec } from \"./types.js\";\nimport type { QueryParams } from \"../client/types.js\";\n\nexport function registerMarketTools(): ToolSpec[] {\n return [\n {\n name: \"pionex_market_get_depth\",\n module: \"market\",\n isWrite: false,\n description: \"Get order book depth (bids and asks) for a symbol. Use for spread, liquidity, or best bid/ask.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n limit: { type: \"integer\", description: \"Price levels (1-100), default 5\" },\n },\n required: [\"symbol\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const limit = args.limit == null ? undefined : Number(args.limit);\n const q: QueryParams = { symbol };\n if (limit != null && Number.isFinite(limit)) q.limit = limit;\n return (await client.publicGet(\"/api/v1/market/depth\", q)).data;\n },\n },\n {\n name: \"pionex_market_get_trades\",\n module: \"market\",\n isWrite: false,\n description: \"Get recent trades for a symbol. Use for latest price and volume.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n limit: { type: \"integer\", description: \"Default 5 (1-100)\" },\n },\n required: [\"symbol\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const limit = args.limit == null ? undefined : Number(args.limit);\n const q: QueryParams = { symbol };\n if (limit != null && Number.isFinite(limit)) q.limit = limit;\n return (await client.publicGet(\"/api/v1/market/trades\", q)).data;\n },\n },\n {\n name: \"pionex_market_get_symbol_info\",\n module: \"market\",\n isWrite: false,\n description:\n \"Get symbol metadata (precision, min size, price limits). Call before placing orders to avoid amount/size filter errors.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbols: {\n type: \"string\",\n description: 'Optional. One or more symbols, comma-separated, e.g. \"BTC_USDT\" or \"BTC_USDT,ADA_USDT\".',\n },\n type: {\n type: \"string\",\n enum: [\"SPOT\", \"PERP\"],\n description: \"Optional. If no symbols are specified, filter by type (default SPOT).\",\n },\n },\n },\n async handler(args, { client }) {\n const q: QueryParams = {};\n if (args.symbols) q.symbols = String(args.symbols);\n if (!args.symbols && args.type) q.type = String(args.type);\n return (await client.publicGet(\"/api/v1/common/symbols\", q)).data;\n },\n },\n {\n name: \"pionex_market_get_tickers\",\n module: \"market\",\n isWrite: false,\n description: \"Get 24-hour ticker(s): open, close, high, low, volume, amount, count. Optional symbol or type (SPOT/PERP).\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT; if omitted, returns all tickers filtered by type\" },\n type: { type: \"string\", enum: [\"SPOT\", \"PERP\"], description: \"If symbol is not specified, filter by type.\" },\n },\n },\n async handler(args, { client }) {\n const q: QueryParams = {};\n if (args.symbol) q.symbol = String(args.symbol);\n if (args.type) q.type = String(args.type);\n return (await client.publicGet(\"/api/v1/market/tickers\", q)).data;\n },\n },\n {\n name: \"pionex_market_get_book_tickers\",\n module: \"market\",\n isWrite: false,\n description: \"Get best bid/ask ticker(s). Optional symbol or type (SPOT/PERP).\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT; if omitted, returns all book tickers filtered by type\" },\n type: { type: \"string\", enum: [\"SPOT\", \"PERP\"], description: \"If symbol is not specified, filter by type.\" },\n },\n },\n async handler(args, { client }) {\n const q: QueryParams = {};\n if (args.symbol) q.symbol = String(args.symbol);\n if (args.type) q.type = String(args.type);\n return (await client.publicGet(\"/api/v1/market/bookTickers\", q)).data;\n },\n },\n {\n name: \"pionex_market_get_klines\",\n module: \"market\",\n isWrite: false,\n description: \"Get OHLCV klines (candlestick) for a symbol. Use for charts or historical price/volume.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n interval: { type: \"string\", enum: [\"1M\", \"5M\", \"15M\", \"30M\", \"60M\", \"4H\", \"8H\", \"12H\", \"1D\"], description: \"Kline interval.\" },\n endTime: { type: \"integer\", description: \"End time in milliseconds.\" },\n limit: { type: \"integer\", description: \"Default 100 (1-500).\" },\n },\n required: [\"symbol\", \"interval\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const interval = String(args.interval);\n const q: QueryParams = { symbol, interval };\n if (args.endTime != null) q.endTime = Number(args.endTime);\n if (args.limit != null) q.limit = Number(args.limit);\n return (await client.publicGet(\"/api/v1/market/klines\", q)).data;\n },\n },\n ];\n}\n\n","import type { ToolSpec } from \"./types.js\";\n\nexport function registerAccountTools(): ToolSpec[] {\n return [\n {\n name: \"pionex_account_get_balance\",\n module: \"account\",\n isWrite: false,\n description: \"Query spot account balances for all currencies. Requires API key and secret in ~/.pionex/config.toml or env.\",\n inputSchema: { type: \"object\", additionalProperties: false, properties: {} },\n async handler(_args, { client }) {\n return (await client.signedGet(\"/api/v1/account/balances\")).data;\n },\n },\n ];\n}\n\n","import type { ToolSpec } from \"./types.js\";\nimport type { QueryParams } from \"../client/types.js\";\n\nexport function registerOrdersTools(): ToolSpec[] {\n return [\n {\n name: \"pionex_orders_new_order\",\n module: \"orders\",\n isWrite: true,\n description:\n \"Create a spot order on Pionex. LIMIT requires symbol/side/type=LIMIT/price/size. MARKET BUY requires amount (quote). MARKET SELL requires size (base).\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n side: { type: \"string\", enum: [\"BUY\", \"SELL\"] },\n type: { type: \"string\", enum: [\"LIMIT\", \"MARKET\"] },\n clientOrderId: { type: \"string\", description: \"Optional client order id (max 64 chars)\" },\n size: { type: \"string\", description: \"Quantity; required for limit and market sell\" },\n price: { type: \"string\", description: \"Required for limit order\" },\n amount: { type: \"string\", description: \"Quote amount; required for market buy\" },\n IOC: { type: \"boolean\", description: \"Immediate-or-cancel, default false\" },\n },\n required: [\"symbol\", \"side\", \"type\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; order placement is disabled.\");\n }\n const body: Record<string, unknown> = {};\n if (args.symbol != null) body.symbol = String(args.symbol);\n if (args.side != null) body.side = String(args.side);\n if (args.type != null) body.type = String(args.type);\n if (args.clientOrderId != null) body.clientOrderId = String(args.clientOrderId);\n if (args.size != null) body.size = String(args.size);\n if (args.price != null) body.price = String(args.price);\n if (args.amount != null) body.amount = String(args.amount);\n if (args.IOC != null) body.IOC = Boolean(args.IOC);\n return (await client.signedPost(\"/api/v1/trade/order\", body)).data;\n },\n },\n {\n name: \"pionex_orders_get_order\",\n module: \"orders\",\n isWrite: false,\n description: \"Get a single order by order ID.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n orderId: { type: \"integer\", description: \"Order id\" },\n },\n required: [\"symbol\", \"orderId\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const orderId = Number(args.orderId);\n return (await client.signedGet(\"/api/v1/trade/order\", { symbol, orderId })).data;\n },\n },\n {\n name: \"pionex_orders_get_order_by_client_order_id\",\n module: \"orders\",\n isWrite: false,\n description: \"Get a single order by client order ID.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n clientOrderId: { type: \"string\", description: \"Client order id\" },\n },\n required: [\"symbol\", \"clientOrderId\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const clientOrderId = String(args.clientOrderId);\n return (await client.signedGet(\"/api/v1/trade/orderByClientOrderId\", { symbol, clientOrderId })).data;\n },\n },\n {\n name: \"pionex_orders_get_open_orders\",\n module: \"orders\",\n isWrite: false,\n description: \"List open (unfilled) orders for a symbol.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: { symbol: { type: \"string\", description: \"e.g. BTC_USDT\" } },\n required: [\"symbol\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n return (await client.signedGet(\"/api/v1/trade/openOrders\", { symbol })).data;\n },\n },\n {\n name: \"pionex_orders_get_all_orders\",\n module: \"orders\",\n isWrite: false,\n description: \"List order history for a symbol (filled and cancelled), with optional limit.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n limit: { type: \"integer\", description: \"Default 1 (1-100)\" },\n },\n required: [\"symbol\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const q: QueryParams = { symbol };\n if (args.limit != null) q.limit = Number(args.limit);\n return (await client.signedGet(\"/api/v1/trade/allOrders\", q)).data;\n },\n },\n {\n name: \"pionex_orders_cancel_order\",\n module: \"orders\",\n isWrite: true,\n description: \"Cancel an open order by order ID.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n orderId: { type: \"integer\", description: \"Order id\" },\n },\n required: [\"symbol\", \"orderId\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; order cancellation is disabled.\");\n }\n const symbol = String(args.symbol);\n const orderId = Number(args.orderId);\n return (await client.signedDelete(\"/api/v1/trade/order\", { symbol, orderId })).data;\n },\n },\n {\n name: \"pionex_orders_get_fills\",\n module: \"orders\",\n isWrite: false,\n description: \"Get filled trades (fills) for a symbol in a time range. Requires API key. Returns up to 100 latest fills.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n startTime: { type: \"integer\", description: \"Start time in milliseconds.\" },\n endTime: { type: \"integer\", description: \"End time in milliseconds.\" },\n },\n required: [\"symbol\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const q: QueryParams = { symbol };\n if (args.startTime != null) q.startTime = Number(args.startTime);\n if (args.endTime != null) q.endTime = Number(args.endTime);\n return (await client.signedGet(\"/api/v1/trade/fills\", q)).data;\n },\n },\n {\n name: \"pionex_orders_get_fills_by_order_id\",\n module: \"orders\",\n isWrite: false,\n description: \"Get fills for a specific order by symbol and orderId.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n orderId: { type: \"integer\", description: \"Order id\" },\n },\n required: [\"symbol\", \"orderId\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const orderId = Number(args.orderId);\n return (await client.signedGet(\"/api/v1/trade/fillsByOrderId\", { symbol, orderId })).data;\n },\n },\n {\n name: \"pionex_orders_cancel_all_orders\",\n module: \"orders\",\n isWrite: true,\n description: \"Cancel all open orders for a symbol.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: { symbol: { type: \"string\", description: \"e.g. BTC_USDT\" } },\n required: [\"symbol\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; cancel-all is disabled.\");\n }\n const symbol = String(args.symbol);\n return (await client.signedDelete(\"/api/v1/trade/allOrders\", { symbol })).data;\n },\n },\n ];\n}\n\n","/**\n * Mirrors openapi_bot.yaml — CreateFuturesGridRequest + CreateFuturesGridOrderData.\n * https://github.com/pionex-official/pionex-open-api/blob/main/openapi_bot.yaml\n */\nimport type { JsonSchema } from \"../tools/types.js\";\n\n/** Every property under CreateFuturesGridOrderData (OpenAPI); no other keys allowed. */\nexport const CREATE_FUTURES_GRID_ORDER_DATA_KEYS = [\n \"top\",\n \"bottom\",\n \"row\",\n \"grid_type\",\n \"trend\",\n \"leverage\",\n \"extraMargin\",\n \"quoteInvestment\",\n \"condition\",\n \"conditionDirection\",\n \"lossStopType\",\n \"lossStop\",\n \"lossStopDelay\",\n \"profitStopType\",\n \"profitStop\",\n \"profitStopDelay\",\n \"lossStopHigh\",\n \"shareRatio\",\n \"investCoin\",\n \"investmentFrom\",\n \"uiInvestCoin\",\n \"lossStopLimitPrice\",\n \"lossStopLimitHighPrice\",\n \"profitStopLimitPrice\",\n \"slippage\",\n \"bonusId\",\n \"uiExtraData\",\n \"movingIndicatorType\",\n \"movingIndicatorInterval\",\n \"movingIndicatorParam\",\n \"movingTrailingUpParam\",\n \"cateType\",\n \"movingTop\",\n \"movingBottom\",\n \"enableFollowClosed\",\n] as const;\n\nconst ORDER_DATA_KEY_SET = new Set<string>(CREATE_FUTURES_GRID_ORDER_DATA_KEYS);\n\nfunction asNonEmptyString(value: unknown, field: string): string {\n if (typeof value !== \"string\" || value.trim().length === 0) {\n throw new Error(`Invalid \"${field}\": expected non-empty string.`);\n }\n return value.trim();\n}\n\nfunction asFiniteNumber(value: unknown, field: string): number {\n if (typeof value !== \"number\" || !Number.isFinite(value)) {\n throw new Error(`Invalid \"${field}\": expected finite number.`);\n }\n return value;\n}\n\nfunction asPositiveNumber(value: unknown, field: string): number {\n const n = asFiniteNumber(value, field);\n if (n <= 0) throw new Error(`Invalid \"${field}\": expected number > 0.`);\n return n;\n}\n\nfunction asPositiveInteger(value: unknown, field: string): number {\n const n = asPositiveNumber(value, field);\n if (!Number.isInteger(n)) {\n throw new Error(`Invalid \"${field}\": expected positive integer.`);\n }\n return n;\n}\n\nfunction asBoolean(value: unknown, field: string): boolean {\n if (typeof value !== \"boolean\") {\n throw new Error(`Invalid \"${field}\": expected boolean.`);\n }\n return value;\n}\n\nfunction assertEnum(value: string, field: string, allowed: readonly string[]): void {\n if (!allowed.includes(value)) {\n throw new Error(`Invalid \"${field}\": expected one of ${allowed.join(\", \")}.`);\n }\n}\n\nfunction asPositiveDecimalString(value: unknown, field: string): string {\n const s = asNonEmptyString(value, field);\n if (!/^\\d+(\\.\\d+)?$/.test(s)) {\n throw new Error(`Invalid \"${field}\": expected positive decimal string.`);\n }\n const n = Number(s);\n if (!Number.isFinite(n) || n <= 0) {\n throw new Error(`Invalid \"${field}\": expected positive decimal string.`);\n }\n return s;\n}\n\nfunction asPositiveDecimalStringLoose(value: unknown, field: string): string {\n if (typeof value === \"number\" && Number.isFinite(value) && value > 0) {\n return String(value);\n }\n return asPositiveDecimalString(value, field);\n}\n\nfunction asNonNegativeDecimalString(value: unknown, field: string): string {\n const s = asNonEmptyString(value, field);\n if (!/^\\d+(\\.\\d+)?$/.test(s)) {\n throw new Error(`Invalid \"${field}\": expected non-negative decimal string.`);\n }\n const n = Number(s);\n if (!Number.isFinite(n) || n < 0) {\n throw new Error(`Invalid \"${field}\": expected non-negative decimal string.`);\n }\n return s;\n}\n\nfunction asOptionalString(value: unknown, field: string): string {\n if (typeof value !== \"string\") {\n throw new Error(`Invalid \"${field}\": expected string.`);\n }\n return value;\n}\n\nfunction asOptionalNonNegativeNumber(value: unknown, field: string): number {\n const n = asFiniteNumber(value, field);\n if (n < 0) throw new Error(`Invalid \"${field}\": expected number >= 0.`);\n return n;\n}\n\n/** Strip + reject unknown keys; validate types per OpenAPI. Returns body-ready buOrderData. */\nexport function parseAndValidateCreateFuturesGridBuOrderData(raw: Record<string, unknown>): Record<string, unknown> {\n const data = { ...raw };\n\n for (const k of Object.keys(data)) {\n if (!ORDER_DATA_KEY_SET.has(k)) {\n throw new Error(`Unknown buOrderData property \"${k}\". Allowed keys: ${CREATE_FUTURES_GRID_ORDER_DATA_KEYS.join(\", \")}.`);\n }\n }\n\n const top = asPositiveDecimalStringLoose(data.top, \"buOrderData.top\");\n const bottom = asPositiveDecimalStringLoose(data.bottom, \"buOrderData.bottom\");\n if (Number(top) <= Number(bottom)) {\n throw new Error('Invalid \"buOrderData.top\": expected top > bottom.');\n }\n const row = asPositiveInteger(data.row, \"buOrderData.row\");\n const gridType = asNonEmptyString(data.grid_type, \"buOrderData.grid_type\");\n assertEnum(gridType, \"buOrderData.grid_type\", [\"arithmetic\", \"geometric\"]);\n const trend = asNonEmptyString(data.trend, \"buOrderData.trend\");\n assertEnum(trend, \"buOrderData.trend\", [\"long\", \"short\", \"no_trend\"]);\n const leverage = asPositiveNumber(data.leverage, \"buOrderData.leverage\");\n const quoteInvestment = asPositiveDecimalStringLoose(data.quoteInvestment, \"buOrderData.quoteInvestment\");\n\n const out: Record<string, unknown> = {\n top,\n bottom,\n row,\n grid_type: gridType,\n trend,\n leverage,\n quoteInvestment,\n };\n\n if (data.extraMargin != null) {\n out.extraMargin = asNonNegativeDecimalString(data.extraMargin, \"buOrderData.extraMargin\");\n }\n if (data.condition != null) out.condition = asOptionalString(data.condition, \"buOrderData.condition\");\n if (data.conditionDirection != null) {\n const v = asNonEmptyString(data.conditionDirection, \"buOrderData.conditionDirection\");\n assertEnum(v, \"buOrderData.conditionDirection\", [\"-1\", \"1\"]);\n out.conditionDirection = v;\n }\n if (data.lossStopType != null) {\n const v = asNonEmptyString(data.lossStopType, \"buOrderData.lossStopType\");\n assertEnum(v, \"buOrderData.lossStopType\", [\"price\", \"profit_amount\", \"profit_ratio\", \"price_limit\"]);\n out.lossStopType = v;\n }\n if (data.lossStop != null) out.lossStop = asOptionalString(data.lossStop, \"buOrderData.lossStop\");\n if (data.lossStopDelay != null) out.lossStopDelay = asOptionalNonNegativeNumber(data.lossStopDelay, \"buOrderData.lossStopDelay\");\n if (data.profitStopType != null) {\n const v = asNonEmptyString(data.profitStopType, \"buOrderData.profitStopType\");\n assertEnum(v, \"buOrderData.profitStopType\", [\"price\", \"profit_amount\", \"profit_ratio\", \"price_limit\"]);\n out.profitStopType = v;\n }\n if (data.profitStop != null) out.profitStop = asOptionalString(data.profitStop, \"buOrderData.profitStop\");\n if (data.profitStopDelay != null) out.profitStopDelay = asOptionalNonNegativeNumber(data.profitStopDelay, \"buOrderData.profitStopDelay\");\n if (data.lossStopHigh != null) out.lossStopHigh = asOptionalString(data.lossStopHigh, \"buOrderData.lossStopHigh\");\n if (data.shareRatio != null) out.shareRatio = asOptionalString(data.shareRatio, \"buOrderData.shareRatio\");\n if (data.investCoin != null) out.investCoin = asOptionalString(data.investCoin, \"buOrderData.investCoin\");\n if (data.investmentFrom != null) {\n const v = asNonEmptyString(data.investmentFrom, \"buOrderData.investmentFrom\");\n assertEnum(v, \"buOrderData.investmentFrom\", [\"USER\", \"LOCK_ACTIVITY\", \"FUTURE_GRID_BONUS\"]);\n out.investmentFrom = v;\n }\n if (data.uiInvestCoin != null) out.uiInvestCoin = asOptionalString(data.uiInvestCoin, \"buOrderData.uiInvestCoin\");\n if (data.lossStopLimitPrice != null) out.lossStopLimitPrice = asOptionalString(data.lossStopLimitPrice, \"buOrderData.lossStopLimitPrice\");\n if (data.lossStopLimitHighPrice != null) out.lossStopLimitHighPrice = asOptionalString(data.lossStopLimitHighPrice, \"buOrderData.lossStopLimitHighPrice\");\n if (data.profitStopLimitPrice != null) out.profitStopLimitPrice = asOptionalString(data.profitStopLimitPrice, \"buOrderData.profitStopLimitPrice\");\n if (data.slippage != null) out.slippage = asOptionalString(data.slippage, \"buOrderData.slippage\");\n if (data.bonusId != null) out.bonusId = asOptionalString(data.bonusId, \"buOrderData.bonusId\");\n if (data.uiExtraData != null) out.uiExtraData = asOptionalString(data.uiExtraData, \"buOrderData.uiExtraData\");\n if (data.movingIndicatorType != null) out.movingIndicatorType = asOptionalString(data.movingIndicatorType, \"buOrderData.movingIndicatorType\");\n if (data.movingIndicatorInterval != null) out.movingIndicatorInterval = asOptionalString(data.movingIndicatorInterval, \"buOrderData.movingIndicatorInterval\");\n if (data.movingIndicatorParam != null) out.movingIndicatorParam = asOptionalString(data.movingIndicatorParam, \"buOrderData.movingIndicatorParam\");\n if (data.movingTrailingUpParam != null) out.movingTrailingUpParam = asOptionalString(data.movingTrailingUpParam, \"buOrderData.movingTrailingUpParam\");\n if (data.cateType != null) {\n const v = asNonEmptyString(data.cateType, \"buOrderData.cateType\");\n assertEnum(v, \"buOrderData.cateType\", [\"FULLY_HEDGING\", \"LOAN_GRID\", \"LEVERAGE_GRID\", \"FUTURE_GRID_COIN_MARGINED\"]);\n out.cateType = v;\n }\n if (data.movingTop != null) out.movingTop = asOptionalString(data.movingTop, \"buOrderData.movingTop\");\n if (data.movingBottom != null) out.movingBottom = asOptionalString(data.movingBottom, \"buOrderData.movingBottom\");\n if (data.enableFollowClosed != null) out.enableFollowClosed = asBoolean(data.enableFollowClosed, \"buOrderData.enableFollowClosed\");\n\n return out;\n}\n\n/** JSON Schema for MCP tool `buOrderData` — matches openapi_bot.yaml CreateFuturesGridOrderData.properties */\nexport const createFuturesGridOrderDataJsonSchema: JsonSchema = {\n type: \"object\",\n additionalProperties: false,\n description: \"CreateFuturesGridOrderData (openapi_bot.yaml). Required: top, bottom, row, grid_type, trend, leverage, quoteInvestment.\",\n required: [\"top\", \"bottom\", \"row\", \"grid_type\", \"trend\", \"leverage\", \"quoteInvestment\"],\n properties: {\n top: { type: \"string\", description: \"Grid upper price\" },\n bottom: { type: \"string\", description: \"Grid lower price\" },\n row: { type: \"number\", description: \"Number of grid levels\" },\n grid_type: {\n type: \"string\",\n enum: [\"arithmetic\", \"geometric\"],\n description: \"Grid spacing: arithmetic (equal difference) or geometric (equal ratio)\",\n },\n trend: {\n type: \"string\",\n enum: [\"long\", \"short\", \"no_trend\"],\n description: \"Grid direction\",\n },\n leverage: { type: \"number\", description: \"Leverage multiplier\" },\n extraMargin: { type: \"string\", description: \"Extra margin amount (optional)\" },\n quoteInvestment: { type: \"string\", description: \"Investment amount\" },\n condition: { type: \"string\", description: \"Trigger price (conditional orders)\" },\n conditionDirection: { type: \"string\", enum: [\"-1\", \"1\"], description: \"Trigger direction\" },\n lossStopType: {\n type: \"string\",\n enum: [\"price\", \"profit_amount\", \"profit_ratio\", \"price_limit\"],\n description: \"Stop loss type\",\n },\n lossStop: { type: \"string\", description: \"Stop loss value\" },\n lossStopDelay: { type: \"number\", description: \"Stop loss delay (seconds)\" },\n profitStopType: {\n type: \"string\",\n enum: [\"price\", \"profit_amount\", \"profit_ratio\", \"price_limit\"],\n description: \"Take profit type\",\n },\n profitStop: { type: \"string\", description: \"Take profit value\" },\n profitStopDelay: { type: \"number\", description: \"Take profit delay (seconds)\" },\n lossStopHigh: { type: \"string\", description: \"Upper stop loss price for neutral grid\" },\n shareRatio: { type: \"string\", description: \"Profit sharing ratio\" },\n investCoin: { type: \"string\", description: \"Investment currency\" },\n investmentFrom: {\n type: \"string\",\n enum: [\"USER\", \"LOCK_ACTIVITY\", \"FUTURE_GRID_BONUS\"],\n description: \"Funding source\",\n },\n uiInvestCoin: { type: \"string\", description: \"Frontend-recorded investment currency\" },\n lossStopLimitPrice: { type: \"string\", description: \"Limit SL price (lossStopType=price_limit)\" },\n lossStopLimitHighPrice: { type: \"string\", description: \"Upper limit SL for neutral grid\" },\n profitStopLimitPrice: { type: \"string\", description: \"Limit TP price (profitStopType=price_limit)\" },\n slippage: { type: \"string\", description: \"Open slippage e.g. 0.01 = 1%\" },\n bonusId: { type: \"string\", description: \"Bonus UUID\" },\n uiExtraData: { type: \"string\", description: \"Frontend extra (coin-margined)\" },\n movingIndicatorType: { type: \"string\", description: \"e.g. sma\" },\n movingIndicatorInterval: { type: \"string\", description: \"e.g. 1m, 15m\" },\n movingIndicatorParam: { type: \"string\", description: \"JSON params e.g. length\" },\n movingTrailingUpParam: { type: \"string\", description: \"SMA trailing up ratio\" },\n cateType: {\n type: \"string\",\n enum: [\"FULLY_HEDGING\", \"LOAN_GRID\", \"LEVERAGE_GRID\", \"FUTURE_GRID_COIN_MARGINED\"],\n description: \"Category type\",\n },\n movingTop: { type: \"string\", description: \"Moving grid upper limit\" },\n movingBottom: { type: \"string\", description: \"Moving grid lower limit\" },\n enableFollowClosed: { type: \"boolean\", description: \"Follow close\" },\n },\n};\n\n/** Full MCP input schema for pionex_bot_futures_grid_create (includes internal __dryRun for CLI). */\nexport const createFuturesGridCreateToolInputSchema: JsonSchema = {\n type: \"object\",\n additionalProperties: false,\n required: [\"base\", \"quote\", \"buOrderData\"],\n properties: {\n base: { type: \"string\", description: \"Base currency (e.g. BTC); *.PERP normalized in handler\" },\n quote: { type: \"string\", description: \"Quote currency (e.g. USDT)\" },\n copyFrom: { type: \"string\", description: \"Optional. Copy source order ID\" },\n copyType: { type: \"string\", description: \"Optional. Copy type\" },\n copyBotOrderId: { type: \"string\", description: \"Optional. Copy bot order ID\" },\n buOrderData: createFuturesGridOrderDataJsonSchema,\n __dryRun: { type: \"boolean\", description: \"Internal: when true, return resolved body without POST\" },\n },\n};\n","import type { ToolSpec } from \"./types.js\";\nimport {\n createFuturesGridCreateToolInputSchema,\n parseAndValidateCreateFuturesGridBuOrderData,\n} from \"../schemas/futures-grid-create.js\";\nimport type { QueryParams } from \"../client/types.js\";\n\nfunction asNonEmptyString(value: unknown, field: string): string {\n if (typeof value !== \"string\" || value.trim().length === 0) {\n throw new Error(`Invalid \"${field}\": expected non-empty string.`);\n }\n return value.trim();\n}\n\nfunction asFiniteNumber(value: unknown, field: string): number {\n if (typeof value !== \"number\" || !Number.isFinite(value)) {\n throw new Error(`Invalid \"${field}\": expected finite number.`);\n }\n return value;\n}\n\nfunction asPositiveNumber(value: unknown, field: string): number {\n const n = asFiniteNumber(value, field);\n if (n <= 0) throw new Error(`Invalid \"${field}\": expected number > 0.`);\n return n;\n}\n\nfunction asPositiveInteger(value: unknown, field: string): number {\n const n = asPositiveNumber(value, field);\n if (!Number.isInteger(n)) {\n throw new Error(`Invalid \"${field}\": expected positive integer.`);\n }\n return n;\n}\n\nfunction asBoolean(value: unknown, field: string): boolean {\n if (typeof value !== \"boolean\") {\n throw new Error(`Invalid \"${field}\": expected boolean.`);\n }\n return value;\n}\n\nfunction assertEnum(value: string, field: string, allowed: readonly string[]): void {\n if (!allowed.includes(value)) {\n throw new Error(`Invalid \"${field}\": expected one of ${allowed.join(\", \")}.`);\n }\n}\n\nfunction asObject(value: unknown, field: string): Record<string, unknown> {\n if (!value || typeof value !== \"object\" || Array.isArray(value)) {\n throw new Error(`Invalid \"${field}\": expected JSON object.`);\n }\n return value as Record<string, unknown>;\n}\n\nfunction asPositiveDecimalString(value: unknown, field: string): string {\n const s = asNonEmptyString(value, field);\n if (!/^\\d+(\\.\\d+)?$/.test(s)) {\n throw new Error(`Invalid \"${field}\": expected positive decimal string.`);\n }\n const n = Number(s);\n if (!Number.isFinite(n) || n <= 0) {\n throw new Error(`Invalid \"${field}\": expected positive decimal string.`);\n }\n return s;\n}\n\nfunction normalizePerpBase(base: string): string {\n return base.endsWith(\".PERP\") ? base : `${base}.PERP`;\n}\n\nexport function registerBotTools(): ToolSpec[] {\n return [\n {\n name: \"pionex_bot_futures_grid_get_order\",\n module: \"bot\",\n isWrite: false,\n description: \"Get one futures grid bot order by buOrderId.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n buOrderId: { type: \"string\", description: \"Futures grid bot order id.\" },\n lang: { type: \"string\", description: \"Optional language code.\" },\n },\n required: [\"buOrderId\"],\n },\n async handler(args, { client }) {\n const buOrderId = String(args.buOrderId);\n const q: QueryParams = { buOrderId };\n if (args.lang != null) q.lang = String(args.lang);\n return (await client.signedGet(\"/api/v1/bot/orders/futuresGrid/order\", q)).data;\n },\n },\n {\n name: \"pionex_bot_futures_grid_create\",\n module: \"bot\",\n isWrite: true,\n description:\n \"Create a futures grid order (openapi_bot.yaml CreateFuturesGridRequest / CreateFuturesGridOrderData). \" +\n \"https://github.com/pionex-official/pionex-open-api/blob/main/openapi_bot.yaml — \" +\n \"Required: base, quote, buOrderData. Optional: copyFrom, copyType, copyBotOrderId. \" +\n \"buOrderData required: top, bottom, row, grid_type, trend, leverage, quoteInvestment; unknown keys rejected.\",\n inputSchema: createFuturesGridCreateToolInputSchema,\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; bot futures_grid create is disabled.\");\n }\n const rawBase = asNonEmptyString(args.base, \"base\");\n const base = normalizePerpBase(rawBase);\n const quote = asNonEmptyString(args.quote, \"quote\");\n const buOrderDataOut = parseAndValidateCreateFuturesGridBuOrderData(asObject(args.buOrderData, \"buOrderData\"));\n const row = buOrderDataOut.row as number;\n const gridType = buOrderDataOut.grid_type as string;\n const leverage = buOrderDataOut.leverage as number;\n\n const body: Record<string, unknown> = {\n base,\n quote,\n buOrderData: buOrderDataOut,\n };\n if (args.copyFrom != null) body.copyFrom = String(args.copyFrom);\n if (args.copyType != null) body.copyType = String(args.copyType);\n if (args.copyBotOrderId != null) body.copyBotOrderId = String(args.copyBotOrderId);\n\n if (args.__dryRun === true) {\n return {\n dryRun: true,\n note: \"No order was sent. Body matches openapi_bot.yaml CreateFuturesGridRequest.\",\n resolvedParams: {\n row,\n grid_type: gridType,\n leverage,\n },\n resolvedBody: body,\n };\n }\n return (await client.signedPost(\"/api/v1/bot/orders/futuresGrid/create\", body)).data;\n },\n },\n {\n name: \"pionex_bot_futures_grid_adjust_params\",\n module: \"bot\",\n isWrite: true,\n description: \"Adjust futures grid bot params (invest_in / adjust_params / invest_in_trigger).\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n buOrderId: { type: \"string\" },\n type: { type: \"string\", enum: [\"invest_in\", \"adjust_params\", \"invest_in_trigger\"] },\n quoteInvestment: { type: \"number\" },\n extraMargin: { type: \"boolean\" },\n bottom: { type: \"string\" },\n top: { type: \"string\" },\n row: { type: \"number\" },\n extraMarginAmount: { type: \"number\" },\n isRecommend: { type: \"boolean\" },\n isReinvest: { type: \"boolean\" },\n investCoin: { type: \"string\" },\n investmentFrom: { type: \"string\", enum: [\"USER\", \"LOCK_ACTIVITY\"] },\n condition: { type: \"string\" },\n conditionDirection: { type: \"string\", enum: [\"1\", \"-1\"] },\n slippage: { type: \"string\" },\n adjustParamsSence: { type: \"string\" },\n },\n required: [\"buOrderId\", \"type\", \"extraMargin\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; bot futures_grid adjust_params is disabled.\");\n }\n const buOrderId = asNonEmptyString(args.buOrderId, \"buOrderId\");\n const type = asNonEmptyString(args.type, \"type\");\n assertEnum(type, \"type\", [\"invest_in\", \"adjust_params\", \"invest_in_trigger\"]);\n const extraMargin = asBoolean(args.extraMargin, \"extraMargin\");\n\n if (type === \"invest_in\" && args.quoteInvestment != null) {\n asPositiveNumber(args.quoteInvestment, \"quoteInvestment\");\n }\n if (type === \"adjust_params\") {\n const bottom = asPositiveDecimalString(args.bottom, \"bottom\");\n const top = asPositiveDecimalString(args.top, \"top\");\n if (Number(top) <= Number(bottom)) {\n throw new Error('Invalid \"top\": expected top > bottom.');\n }\n asPositiveInteger(args.row, \"row\");\n }\n if (type === \"invest_in_trigger\") {\n asPositiveDecimalString(args.condition, \"condition\");\n const conditionDirection = asNonEmptyString(args.conditionDirection, \"conditionDirection\");\n assertEnum(conditionDirection, \"conditionDirection\", [\"1\", \"-1\"]);\n }\n\n const body: Record<string, unknown> = {\n buOrderId,\n type,\n extraMargin,\n };\n if (args.quoteInvestment != null) body.quoteInvestment = asFiniteNumber(args.quoteInvestment, \"quoteInvestment\");\n if (args.bottom != null) body.bottom = asPositiveDecimalString(args.bottom, \"bottom\");\n if (args.top != null) body.top = asPositiveDecimalString(args.top, \"top\");\n if (args.row != null) body.row = asPositiveInteger(args.row, \"row\");\n if (args.extraMarginAmount != null) body.extraMarginAmount = asFiniteNumber(args.extraMarginAmount, \"extraMarginAmount\");\n if (args.isRecommend != null) body.isRecommend = asBoolean(args.isRecommend, \"isRecommend\");\n if (args.isReinvest != null) body.isReinvest = asBoolean(args.isReinvest, \"isReinvest\");\n if (args.investCoin != null) body.investCoin = String(args.investCoin);\n if (args.investmentFrom != null) {\n const investmentFrom = asNonEmptyString(args.investmentFrom, \"investmentFrom\");\n assertEnum(investmentFrom, \"investmentFrom\", [\"USER\", \"LOCK_ACTIVITY\"]);\n body.investmentFrom = investmentFrom;\n }\n if (args.condition != null) body.condition = asPositiveDecimalString(args.condition, \"condition\");\n if (args.conditionDirection != null) {\n const conditionDirection = asNonEmptyString(args.conditionDirection, \"conditionDirection\");\n assertEnum(conditionDirection, \"conditionDirection\", [\"1\", \"-1\"]);\n body.conditionDirection = conditionDirection;\n }\n if (args.slippage != null) body.slippage = String(args.slippage);\n if (args.adjustParamsSence != null) body.adjustParamsSence = String(args.adjustParamsSence);\n return (await client.signedPost(\"/api/v1/bot/orders/futuresGrid/adjustParams\", body)).data;\n },\n },\n {\n name: \"pionex_bot_futures_grid_reduce\",\n module: \"bot\",\n isWrite: true,\n description: \"Reduce futures grid bot position.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n buOrderId: { type: \"string\" },\n reduceNum: { type: \"number\" },\n slippage: { type: \"string\" },\n condition: { type: \"string\" },\n conditionDirection: { type: \"string\", enum: [\"1\", \"-1\"] },\n },\n required: [\"buOrderId\", \"reduceNum\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; bot futures_grid reduce is disabled.\");\n }\n const buOrderId = asNonEmptyString(args.buOrderId, \"buOrderId\");\n const reduceNum = asPositiveInteger(args.reduceNum, \"reduceNum\");\n const body: Record<string, unknown> = {\n buOrderId,\n reduceNum,\n };\n if (args.slippage != null) body.slippage = String(args.slippage);\n if (args.condition != null) body.condition = String(args.condition);\n if (args.conditionDirection != null) {\n const conditionDirection = asNonEmptyString(args.conditionDirection, \"conditionDirection\");\n assertEnum(conditionDirection, \"conditionDirection\", [\"1\", \"-1\"]);\n body.conditionDirection = conditionDirection;\n }\n return (await client.signedPost(\"/api/v1/bot/orders/futuresGrid/reduce\", body)).data;\n },\n },\n {\n name: \"pionex_bot_futures_grid_cancel\",\n module: \"bot\",\n isWrite: true,\n description: \"Cancel and close a futures grid bot order.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n buOrderId: { type: \"string\" },\n closeNote: { type: \"string\" },\n closeSellModel: { type: \"string\", enum: [\"TO_QUOTE\", \"TO_USDT\"] },\n immediate: { type: \"boolean\" },\n closeSlippage: { type: \"string\" },\n },\n required: [\"buOrderId\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; bot futures_grid cancel is disabled.\");\n }\n const buOrderId = asNonEmptyString(args.buOrderId, \"buOrderId\");\n const body: Record<string, unknown> = { buOrderId };\n if (args.closeNote != null) body.closeNote = String(args.closeNote);\n if (args.closeSellModel != null) {\n const closeSellModel = asNonEmptyString(args.closeSellModel, \"closeSellModel\");\n assertEnum(closeSellModel, \"closeSellModel\", [\"TO_QUOTE\", \"TO_USDT\"]);\n body.closeSellModel = closeSellModel;\n }\n if (args.immediate != null) body.immediate = asBoolean(args.immediate, \"immediate\");\n if (args.closeSlippage != null) body.closeSlippage = String(args.closeSlippage);\n return (await client.signedPost(\"/api/v1/bot/orders/futuresGrid/cancel\", body)).data;\n },\n },\n ];\n}\n","import type { PionexConfig } from \"../config.js\";\nimport type { PionexRestClient } from \"../client/rest-client.js\";\nimport { MODULES, type ModuleId } from \"../constants.js\";\nimport type { ToolArgs, ToolSpec } from \"./types.js\";\nimport { registerMarketTools } from \"./market.js\";\nimport { registerAccountTools } from \"./account.js\";\nimport { registerOrdersTools } from \"./orders.js\";\nimport { registerBotTools } from \"./bot.js\";\n\nfunction allToolSpecs(): ToolSpec[] {\n return [...registerMarketTools(), ...registerAccountTools(), ...registerOrdersTools(), ...registerBotTools()];\n}\n\nexport function buildTools(config: PionexConfig): ToolSpec[] {\n const enabled = new Set(config.modules);\n const tools = allToolSpecs().filter((t) => enabled.has(t.module));\n if (!config.readOnly) return tools;\n return tools.filter((t) => !t.isWrite);\n}\n\nexport interface ToolResult {\n endpoint: string;\n requestTime: string;\n data: unknown;\n}\n\nexport type ToolRunner = (toolName: string, args: ToolArgs) => Promise<ToolResult>;\n\n/**\n * Create a function that can call any registered tool by name.\n * For CLI usage we keep module filtering at the command routing level,\n * but the runner itself knows all tools.\n */\nexport function createToolRunner(client: PionexRestClient, config: PionexConfig): ToolRunner {\n const fullConfig: PionexConfig = { ...config, modules: [...MODULES] as ModuleId[] };\n const toolMap = new Map<string, ToolSpec>(allToolSpecs().map((t) => [t.name, t]));\n\n return async (toolName: string, args: ToolArgs): Promise<ToolResult> => {\n const tool = toolMap.get(toolName);\n if (!tool) throw new Error(`Unknown tool: ${toolName}`);\n const data = await tool.handler(args, { config: fullConfig, client });\n return { endpoint: toolName, requestTime: new Date().toISOString(), data };\n };\n}\n\n","import type { ModuleId } from \"../constants.js\";\nimport type { PionexConfig } from \"../config.js\";\nimport type { PionexRestClient } from \"../client/rest-client.js\";\n\nexport type JsonSchema =\n | {\n type: \"object\";\n properties?: Record<string, JsonSchema>;\n required?: string[];\n additionalProperties?: boolean;\n description?: string;\n enum?: string[];\n }\n | { type: \"string\"; description?: string; enum?: string[] }\n | { type: \"number\"; description?: string }\n | { type: \"integer\"; description?: string }\n | { type: \"boolean\"; description?: string }\n | { type: \"array\"; items: JsonSchema; description?: string }\n | { type: \"null\" };\n\nexport interface ToolContext {\n config: PionexConfig;\n client: PionexRestClient;\n}\n\nexport type ToolArgs = Record<string, unknown>;\n\nexport interface ToolSpec {\n name: string;\n description: string;\n module: ModuleId;\n isWrite: boolean;\n inputSchema: JsonSchema;\n handler: (args: ToolArgs, ctx: ToolContext) => Promise<unknown>;\n}\n\nexport interface McpTool {\n name: string;\n description: string;\n inputSchema: JsonSchema;\n annotations?: {\n readOnlyHint?: boolean;\n destructiveHint?: boolean;\n idempotentHint?: boolean;\n openWorldHint?: boolean;\n };\n}\n\nexport function toMcpTool(tool: ToolSpec): McpTool {\n return {\n name: tool.name,\n description: tool.description,\n inputSchema: tool.inputSchema,\n annotations: {\n readOnlyHint: !tool.isWrite,\n destructiveHint: tool.isWrite,\n idempotentHint: !tool.isWrite,\n openWorldHint: false,\n },\n };\n}\n\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nfunction getLineColFromPtr(string, ptr) {\n let lines = string.slice(0, ptr).split(/\\r\\n|\\n|\\r/g);\n return [lines.length, lines.pop().length + 1];\n}\nfunction makeCodeBlock(string, line, column) {\n let lines = string.split(/\\r\\n|\\n|\\r/g);\n let codeblock = '';\n let numberLen = (Math.log10(line + 1) | 0) + 1;\n for (let i = line - 1; i <= line + 1; i++) {\n let l = lines[i - 1];\n if (!l)\n continue;\n codeblock += i.toString().padEnd(numberLen, ' ');\n codeblock += ': ';\n codeblock += l;\n codeblock += '\\n';\n if (i === line) {\n codeblock += ' '.repeat(numberLen + column + 2);\n codeblock += '^\\n';\n }\n }\n return codeblock;\n}\nexport class TomlError extends Error {\n line;\n column;\n codeblock;\n constructor(message, options) {\n const [line, column] = getLineColFromPtr(options.toml, options.ptr);\n const codeblock = makeCodeBlock(options.toml, line, column);\n super(`Invalid TOML document: ${message}\\n\\n${codeblock}`, options);\n this.line = line;\n this.column = column;\n this.codeblock = codeblock;\n }\n}\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nimport { TomlError } from './error.js';\nfunction isEscaped(str, ptr) {\n let i = 0;\n while (str[ptr - ++i] === '\\\\')\n ;\n return --i && (i % 2);\n}\nexport function indexOfNewline(str, start = 0, end = str.length) {\n let idx = str.indexOf('\\n', start);\n if (str[idx - 1] === '\\r')\n idx--;\n return idx <= end ? idx : -1;\n}\nexport function skipComment(str, ptr) {\n for (let i = ptr; i < str.length; i++) {\n let c = str[i];\n if (c === '\\n')\n return i;\n if (c === '\\r' && str[i + 1] === '\\n')\n return i + 1;\n if ((c < '\\x20' && c !== '\\t') || c === '\\x7f') {\n throw new TomlError('control characters are not allowed in comments', {\n toml: str,\n ptr: ptr,\n });\n }\n }\n return str.length;\n}\nexport function skipVoid(str, ptr, banNewLines, banComments) {\n let c;\n while ((c = str[ptr]) === ' ' || c === '\\t' || (!banNewLines && (c === '\\n' || c === '\\r' && str[ptr + 1] === '\\n')))\n ptr++;\n return banComments || c !== '#'\n ? ptr\n : skipVoid(str, skipComment(str, ptr), banNewLines);\n}\nexport function skipUntil(str, ptr, sep, end, banNewLines = false) {\n if (!end) {\n ptr = indexOfNewline(str, ptr);\n return ptr < 0 ? str.length : ptr;\n }\n for (let i = ptr; i < str.length; i++) {\n let c = str[i];\n if (c === '#') {\n i = indexOfNewline(str, i);\n }\n else if (c === sep) {\n return i + 1;\n }\n else if (c === end || (banNewLines && (c === '\\n' || (c === '\\r' && str[i + 1] === '\\n')))) {\n return i;\n }\n }\n throw new TomlError('cannot find end of structure', {\n toml: str,\n ptr: ptr\n });\n}\nexport function getStringEnd(str, seek) {\n let first = str[seek];\n let target = first === str[seek + 1] && str[seek + 1] === str[seek + 2]\n ? str.slice(seek, seek + 3)\n : first;\n seek += target.length - 1;\n do\n seek = str.indexOf(target, ++seek);\n while (seek > -1 && first !== \"'\" && isEscaped(str, seek));\n if (seek > -1) {\n seek += target.length;\n if (target.length > 1) {\n if (str[seek] === first)\n seek++;\n if (str[seek] === first)\n seek++;\n }\n }\n return seek;\n}\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nlet DATE_TIME_RE = /^(\\d{4}-\\d{2}-\\d{2})?[T ]?(?:(\\d{2}):\\d{2}(?::\\d{2}(?:\\.\\d+)?)?)?(Z|[-+]\\d{2}:\\d{2})?$/i;\nexport class TomlDate extends Date {\n #hasDate = false;\n #hasTime = false;\n #offset = null;\n constructor(date) {\n let hasDate = true;\n let hasTime = true;\n let offset = 'Z';\n if (typeof date === 'string') {\n let match = date.match(DATE_TIME_RE);\n if (match) {\n if (!match[1]) {\n hasDate = false;\n date = `0000-01-01T${date}`;\n }\n hasTime = !!match[2];\n // Make sure to use T instead of a space. Breaks in case of extreme values otherwise.\n hasTime && date[10] === ' ' && (date = date.replace(' ', 'T'));\n // Do not allow rollover hours.\n if (match[2] && +match[2] > 23) {\n date = '';\n }\n else {\n offset = match[3] || null;\n date = date.toUpperCase();\n if (!offset && hasTime)\n date += 'Z';\n }\n }\n else {\n date = '';\n }\n }\n super(date);\n if (!isNaN(this.getTime())) {\n this.#hasDate = hasDate;\n this.#hasTime = hasTime;\n this.#offset = offset;\n }\n }\n isDateTime() {\n return this.#hasDate && this.#hasTime;\n }\n isLocal() {\n return !this.#hasDate || !this.#hasTime || !this.#offset;\n }\n isDate() {\n return this.#hasDate && !this.#hasTime;\n }\n isTime() {\n return this.#hasTime && !this.#hasDate;\n }\n isValid() {\n return this.#hasDate || this.#hasTime;\n }\n toISOString() {\n let iso = super.toISOString();\n // Local Date\n if (this.isDate())\n return iso.slice(0, 10);\n // Local Time\n if (this.isTime())\n return iso.slice(11, 23);\n // Local DateTime\n if (this.#offset === null)\n return iso.slice(0, -1);\n // Offset DateTime\n if (this.#offset === 'Z')\n return iso;\n // This part is quite annoying: JS strips the original timezone from the ISO string representation\n // Instead of using a \"modified\" date and \"Z\", we restore the representation \"as authored\"\n let offset = (+(this.#offset.slice(1, 3)) * 60) + +(this.#offset.slice(4, 6));\n offset = this.#offset[0] === '-' ? offset : -offset;\n let offsetDate = new Date(this.getTime() - (offset * 60e3));\n return offsetDate.toISOString().slice(0, -1) + this.#offset;\n }\n static wrapAsOffsetDateTime(jsDate, offset = 'Z') {\n let date = new TomlDate(jsDate);\n date.#offset = offset;\n return date;\n }\n static wrapAsLocalDateTime(jsDate) {\n let date = new TomlDate(jsDate);\n date.#offset = null;\n return date;\n }\n static wrapAsLocalDate(jsDate) {\n let date = new TomlDate(jsDate);\n date.#hasTime = false;\n date.#offset = null;\n return date;\n }\n static wrapAsLocalTime(jsDate) {\n let date = new TomlDate(jsDate);\n date.#hasDate = false;\n date.#offset = null;\n return date;\n }\n}\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nimport { skipVoid } from './util.js';\nimport { TomlDate } from './date.js';\nimport { TomlError } from './error.js';\nlet INT_REGEX = /^((0x[0-9a-fA-F](_?[0-9a-fA-F])*)|(([+-]|0[ob])?\\d(_?\\d)*))$/;\nlet FLOAT_REGEX = /^[+-]?\\d(_?\\d)*(\\.\\d(_?\\d)*)?([eE][+-]?\\d(_?\\d)*)?$/;\nlet LEADING_ZERO = /^[+-]?0[0-9_]/;\nlet ESCAPE_REGEX = /^[0-9a-f]{2,8}$/i;\nlet ESC_MAP = {\n b: '\\b',\n t: '\\t',\n n: '\\n',\n f: '\\f',\n r: '\\r',\n e: '\\x1b',\n '\"': '\"',\n '\\\\': '\\\\',\n};\nexport function parseString(str, ptr = 0, endPtr = str.length) {\n let isLiteral = str[ptr] === '\\'';\n let isMultiline = str[ptr++] === str[ptr] && str[ptr] === str[ptr + 1];\n if (isMultiline) {\n endPtr -= 2;\n if (str[ptr += 2] === '\\r')\n ptr++;\n if (str[ptr] === '\\n')\n ptr++;\n }\n let tmp = 0;\n let isEscape;\n let parsed = '';\n let sliceStart = ptr;\n while (ptr < endPtr - 1) {\n let c = str[ptr++];\n if (c === '\\n' || (c === '\\r' && str[ptr] === '\\n')) {\n if (!isMultiline) {\n throw new TomlError('newlines are not allowed in strings', {\n toml: str,\n ptr: ptr - 1,\n });\n }\n }\n else if ((c < '\\x20' && c !== '\\t') || c === '\\x7f') {\n throw new TomlError('control characters are not allowed in strings', {\n toml: str,\n ptr: ptr - 1,\n });\n }\n if (isEscape) {\n isEscape = false;\n if (c === 'x' || c === 'u' || c === 'U') {\n // Unicode escape\n let code = str.slice(ptr, (ptr += (c === 'x' ? 2 : c === 'u' ? 4 : 8)));\n if (!ESCAPE_REGEX.test(code)) {\n throw new TomlError('invalid unicode escape', {\n toml: str,\n ptr: tmp,\n });\n }\n try {\n parsed += String.fromCodePoint(parseInt(code, 16));\n }\n catch {\n throw new TomlError('invalid unicode escape', {\n toml: str,\n ptr: tmp,\n });\n }\n }\n else if (isMultiline && (c === '\\n' || c === ' ' || c === '\\t' || c === '\\r')) {\n // Multiline escape\n ptr = skipVoid(str, ptr - 1, true);\n if (str[ptr] !== '\\n' && str[ptr] !== '\\r') {\n throw new TomlError('invalid escape: only line-ending whitespace may be escaped', {\n toml: str,\n ptr: tmp,\n });\n }\n ptr = skipVoid(str, ptr);\n }\n else if (c in ESC_MAP) {\n // Classic escape\n parsed += ESC_MAP[c];\n }\n else {\n throw new TomlError('unrecognized escape sequence', {\n toml: str,\n ptr: tmp,\n });\n }\n sliceStart = ptr;\n }\n else if (!isLiteral && c === '\\\\') {\n tmp = ptr - 1;\n isEscape = true;\n parsed += str.slice(sliceStart, tmp);\n }\n }\n return parsed + str.slice(sliceStart, endPtr - 1);\n}\nexport function parseValue(value, toml, ptr, integersAsBigInt) {\n // Constant values\n if (value === 'true')\n return true;\n if (value === 'false')\n return false;\n if (value === '-inf')\n return -Infinity;\n if (value === 'inf' || value === '+inf')\n return Infinity;\n if (value === 'nan' || value === '+nan' || value === '-nan')\n return NaN;\n // Avoid FP representation of -0\n if (value === '-0')\n return integersAsBigInt ? 0n : 0;\n // Numbers\n let isInt = INT_REGEX.test(value);\n if (isInt || FLOAT_REGEX.test(value)) {\n if (LEADING_ZERO.test(value)) {\n throw new TomlError('leading zeroes are not allowed', {\n toml: toml,\n ptr: ptr,\n });\n }\n value = value.replace(/_/g, '');\n let numeric = +value;\n if (isNaN(numeric)) {\n throw new TomlError('invalid number', {\n toml: toml,\n ptr: ptr,\n });\n }\n if (isInt) {\n if ((isInt = !Number.isSafeInteger(numeric)) && !integersAsBigInt) {\n throw new TomlError('integer value cannot be represented losslessly', {\n toml: toml,\n ptr: ptr,\n });\n }\n if (isInt || integersAsBigInt === true)\n numeric = BigInt(value);\n }\n return numeric;\n }\n const date = new TomlDate(value);\n if (!date.isValid()) {\n throw new TomlError('invalid value', {\n toml: toml,\n ptr: ptr,\n });\n }\n return date;\n}\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nimport { parseString, parseValue } from './primitive.js';\nimport { parseArray, parseInlineTable } from './struct.js';\nimport { skipVoid, skipUntil, skipComment, getStringEnd } from './util.js';\nimport { TomlError } from './error.js';\nfunction sliceAndTrimEndOf(str, startPtr, endPtr) {\n let value = str.slice(startPtr, endPtr);\n let commentIdx = value.indexOf('#');\n if (commentIdx > -1) {\n // The call to skipComment allows to \"validate\" the comment\n // (absence of control characters)\n skipComment(str, commentIdx);\n value = value.slice(0, commentIdx);\n }\n return [value.trimEnd(), commentIdx];\n}\nexport function extractValue(str, ptr, end, depth, integersAsBigInt) {\n if (depth === 0) {\n throw new TomlError('document contains excessively nested structures. aborting.', {\n toml: str,\n ptr: ptr\n });\n }\n let c = str[ptr];\n if (c === '[' || c === '{') {\n let [value, endPtr] = c === '['\n ? parseArray(str, ptr, depth, integersAsBigInt)\n : parseInlineTable(str, ptr, depth, integersAsBigInt);\n if (end) {\n endPtr = skipVoid(str, endPtr);\n if (str[endPtr] === ',')\n endPtr++;\n else if (str[endPtr] !== end) {\n throw new TomlError('expected comma or end of structure', {\n toml: str,\n ptr: endPtr,\n });\n }\n }\n return [value, endPtr];\n }\n let endPtr;\n if (c === '\"' || c === \"'\") {\n endPtr = getStringEnd(str, ptr);\n let parsed = parseString(str, ptr, endPtr);\n if (end) {\n endPtr = skipVoid(str, endPtr);\n if (str[endPtr] && str[endPtr] !== ',' && str[endPtr] !== end && str[endPtr] !== '\\n' && str[endPtr] !== '\\r') {\n throw new TomlError('unexpected character encountered', {\n toml: str,\n ptr: endPtr,\n });\n }\n endPtr += (+(str[endPtr] === ','));\n }\n return [parsed, endPtr];\n }\n endPtr = skipUntil(str, ptr, ',', end);\n let slice = sliceAndTrimEndOf(str, ptr, endPtr - (+(str[endPtr - 1] === ',')));\n if (!slice[0]) {\n throw new TomlError('incomplete key-value declaration: no value specified', {\n toml: str,\n ptr: ptr\n });\n }\n if (end && slice[1] > -1) {\n endPtr = skipVoid(str, ptr + slice[1]);\n endPtr += +(str[endPtr] === ',');\n }\n return [\n parseValue(slice[0], str, ptr, integersAsBigInt),\n endPtr,\n ];\n}\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nimport { parseString } from './primitive.js';\nimport { extractValue } from './extract.js';\nimport { getStringEnd, indexOfNewline, skipComment, skipVoid } from './util.js';\nimport { TomlError } from './error.js';\nlet KEY_PART_RE = /^[a-zA-Z0-9-_]+[ \\t]*$/;\nexport function parseKey(str, ptr, end = '=') {\n let dot = ptr - 1;\n let parsed = [];\n let endPtr = str.indexOf(end, ptr);\n if (endPtr < 0) {\n throw new TomlError('incomplete key-value: cannot find end of key', {\n toml: str,\n ptr: ptr,\n });\n }\n do {\n let c = str[ptr = ++dot];\n // If it's whitespace, ignore\n if (c !== ' ' && c !== '\\t') {\n // If it's a string\n if (c === '\"' || c === '\\'') {\n if (c === str[ptr + 1] && c === str[ptr + 2]) {\n throw new TomlError('multiline strings are not allowed in keys', {\n toml: str,\n ptr: ptr,\n });\n }\n let eos = getStringEnd(str, ptr);\n if (eos < 0) {\n throw new TomlError('unfinished string encountered', {\n toml: str,\n ptr: ptr,\n });\n }\n dot = str.indexOf('.', eos);\n let strEnd = str.slice(eos, dot < 0 || dot > endPtr ? endPtr : dot);\n let newLine = indexOfNewline(strEnd);\n if (newLine > -1) {\n throw new TomlError('newlines are not allowed in keys', {\n toml: str,\n ptr: ptr + dot + newLine,\n });\n }\n if (strEnd.trimStart()) {\n throw new TomlError('found extra tokens after the string part', {\n toml: str,\n ptr: eos,\n });\n }\n if (endPtr < eos) {\n endPtr = str.indexOf(end, eos);\n if (endPtr < 0) {\n throw new TomlError('incomplete key-value: cannot find end of key', {\n toml: str,\n ptr: ptr,\n });\n }\n }\n parsed.push(parseString(str, ptr, eos));\n }\n else {\n // Normal raw key part consumption and validation\n dot = str.indexOf('.', ptr);\n let part = str.slice(ptr, dot < 0 || dot > endPtr ? endPtr : dot);\n if (!KEY_PART_RE.test(part)) {\n throw new TomlError('only letter, numbers, dashes and underscores are allowed in keys', {\n toml: str,\n ptr: ptr,\n });\n }\n parsed.push(part.trimEnd());\n }\n }\n // Until there's no more dot\n } while (dot + 1 && dot < endPtr);\n return [parsed, skipVoid(str, endPtr + 1, true, true)];\n}\nexport function parseInlineTable(str, ptr, depth, integersAsBigInt) {\n let res = {};\n let seen = new Set();\n let c;\n ptr++;\n while ((c = str[ptr++]) !== '}' && c) {\n if (c === ',') {\n throw new TomlError('expected value, found comma', {\n toml: str,\n ptr: ptr - 1,\n });\n }\n else if (c === '#')\n ptr = skipComment(str, ptr);\n else if (c !== ' ' && c !== '\\t' && c !== '\\n' && c !== '\\r') {\n let k;\n let t = res;\n let hasOwn = false;\n let [key, keyEndPtr] = parseKey(str, ptr - 1);\n for (let i = 0; i < key.length; i++) {\n if (i)\n t = hasOwn ? t[k] : (t[k] = {});\n k = key[i];\n if ((hasOwn = Object.hasOwn(t, k)) && (typeof t[k] !== 'object' || seen.has(t[k]))) {\n throw new TomlError('trying to redefine an already defined value', {\n toml: str,\n ptr: ptr,\n });\n }\n if (!hasOwn && k === '__proto__') {\n Object.defineProperty(t, k, { enumerable: true, configurable: true, writable: true });\n }\n }\n if (hasOwn) {\n throw new TomlError('trying to redefine an already defined value', {\n toml: str,\n ptr: ptr,\n });\n }\n let [value, valueEndPtr] = extractValue(str, keyEndPtr, '}', depth - 1, integersAsBigInt);\n seen.add(value);\n t[k] = value;\n ptr = valueEndPtr;\n }\n }\n if (!c) {\n throw new TomlError('unfinished table encountered', {\n toml: str,\n ptr: ptr,\n });\n }\n return [res, ptr];\n}\nexport function parseArray(str, ptr, depth, integersAsBigInt) {\n let res = [];\n let c;\n ptr++;\n while ((c = str[ptr++]) !== ']' && c) {\n if (c === ',') {\n throw new TomlError('expected value, found comma', {\n toml: str,\n ptr: ptr - 1,\n });\n }\n else if (c === '#')\n ptr = skipComment(str, ptr);\n else if (c !== ' ' && c !== '\\t' && c !== '\\n' && c !== '\\r') {\n let e = extractValue(str, ptr - 1, ']', depth - 1, integersAsBigInt);\n res.push(e[0]);\n ptr = e[1];\n }\n }\n if (!c) {\n throw new TomlError('unfinished array encountered', {\n toml: str,\n ptr: ptr,\n });\n }\n return [res, ptr];\n}\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nimport { parseKey } from './struct.js';\nimport { extractValue } from './extract.js';\nimport { skipVoid } from './util.js';\nimport { TomlError } from './error.js';\nfunction peekTable(key, table, meta, type) {\n let t = table;\n let m = meta;\n let k;\n let hasOwn = false;\n let state;\n for (let i = 0; i < key.length; i++) {\n if (i) {\n t = hasOwn ? t[k] : (t[k] = {});\n m = (state = m[k]).c;\n if (type === 0 /* Type.DOTTED */ && (state.t === 1 /* Type.EXPLICIT */ || state.t === 2 /* Type.ARRAY */)) {\n return null;\n }\n if (state.t === 2 /* Type.ARRAY */) {\n let l = t.length - 1;\n t = t[l];\n m = m[l].c;\n }\n }\n k = key[i];\n if ((hasOwn = Object.hasOwn(t, k)) && m[k]?.t === 0 /* Type.DOTTED */ && m[k]?.d) {\n return null;\n }\n if (!hasOwn) {\n if (k === '__proto__') {\n Object.defineProperty(t, k, { enumerable: true, configurable: true, writable: true });\n Object.defineProperty(m, k, { enumerable: true, configurable: true, writable: true });\n }\n m[k] = {\n t: i < key.length - 1 && type === 2 /* Type.ARRAY */\n ? 3 /* Type.ARRAY_DOTTED */\n : type,\n d: false,\n i: 0,\n c: {},\n };\n }\n }\n state = m[k];\n if (state.t !== type && !(type === 1 /* Type.EXPLICIT */ && state.t === 3 /* Type.ARRAY_DOTTED */)) {\n // Bad key type!\n return null;\n }\n if (type === 2 /* Type.ARRAY */) {\n if (!state.d) {\n state.d = true;\n t[k] = [];\n }\n t[k].push(t = {});\n state.c[state.i++] = (state = { t: 1 /* Type.EXPLICIT */, d: false, i: 0, c: {} });\n }\n if (state.d) {\n // Redefining a table!\n return null;\n }\n state.d = true;\n if (type === 1 /* Type.EXPLICIT */) {\n t = hasOwn ? t[k] : (t[k] = {});\n }\n else if (type === 0 /* Type.DOTTED */ && hasOwn) {\n return null;\n }\n return [k, t, state.c];\n}\nexport function parse(toml, { maxDepth = 1000, integersAsBigInt } = {}) {\n let res = {};\n let meta = {};\n let tbl = res;\n let m = meta;\n for (let ptr = skipVoid(toml, 0); ptr < toml.length;) {\n if (toml[ptr] === '[') {\n let isTableArray = toml[++ptr] === '[';\n let k = parseKey(toml, ptr += +isTableArray, ']');\n if (isTableArray) {\n if (toml[k[1] - 1] !== ']') {\n throw new TomlError('expected end of table declaration', {\n toml: toml,\n ptr: k[1] - 1,\n });\n }\n k[1]++;\n }\n let p = peekTable(k[0], res, meta, isTableArray ? 2 /* Type.ARRAY */ : 1 /* Type.EXPLICIT */);\n if (!p) {\n throw new TomlError('trying to redefine an already defined table or value', {\n toml: toml,\n ptr: ptr,\n });\n }\n m = p[2];\n tbl = p[1];\n ptr = k[1];\n }\n else {\n let k = parseKey(toml, ptr);\n let p = peekTable(k[0], tbl, m, 0 /* Type.DOTTED */);\n if (!p) {\n throw new TomlError('trying to redefine an already defined table or value', {\n toml: toml,\n ptr: ptr,\n });\n }\n let v = extractValue(toml, k[1], void 0, maxDepth, integersAsBigInt);\n p[1][p[0]] = v[0];\n ptr = v[1];\n }\n ptr = skipVoid(toml, ptr, true);\n if (toml[ptr] && toml[ptr] !== '\\n' && toml[ptr] !== '\\r') {\n throw new TomlError('each key-value declaration must be followed by an end-of-line', {\n toml: toml,\n ptr: ptr\n });\n }\n ptr = skipVoid(toml, ptr);\n }\n return res;\n}\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nlet BARE_KEY = /^[a-z0-9-_]+$/i;\nfunction extendedTypeOf(obj) {\n let type = typeof obj;\n if (type === 'object') {\n if (Array.isArray(obj))\n return 'array';\n if (obj instanceof Date)\n return 'date';\n }\n return type;\n}\nfunction isArrayOfTables(obj) {\n for (let i = 0; i < obj.length; i++) {\n if (extendedTypeOf(obj[i]) !== 'object')\n return false;\n }\n return obj.length != 0;\n}\nfunction formatString(s) {\n return JSON.stringify(s).replace(/\\x7f/g, '\\\\u007f');\n}\nfunction stringifyValue(val, type, depth, numberAsFloat) {\n if (depth === 0) {\n throw new Error('Could not stringify the object: maximum object depth exceeded');\n }\n if (type === 'number') {\n if (isNaN(val))\n return 'nan';\n if (val === Infinity)\n return 'inf';\n if (val === -Infinity)\n return '-inf';\n if (numberAsFloat && Number.isInteger(val))\n return val.toFixed(1);\n return val.toString();\n }\n if (type === 'bigint' || type === 'boolean') {\n return val.toString();\n }\n if (type === 'string') {\n return formatString(val);\n }\n if (type === 'date') {\n if (isNaN(val.getTime())) {\n throw new TypeError('cannot serialize invalid date');\n }\n return val.toISOString();\n }\n if (type === 'object') {\n return stringifyInlineTable(val, depth, numberAsFloat);\n }\n if (type === 'array') {\n return stringifyArray(val, depth, numberAsFloat);\n }\n}\nfunction stringifyInlineTable(obj, depth, numberAsFloat) {\n let keys = Object.keys(obj);\n if (keys.length === 0)\n return '{}';\n let res = '{ ';\n for (let i = 0; i < keys.length; i++) {\n let k = keys[i];\n if (i)\n res += ', ';\n res += BARE_KEY.test(k) ? k : formatString(k);\n res += ' = ';\n res += stringifyValue(obj[k], extendedTypeOf(obj[k]), depth - 1, numberAsFloat);\n }\n return res + ' }';\n}\nfunction stringifyArray(array, depth, numberAsFloat) {\n if (array.length === 0)\n return '[]';\n let res = '[ ';\n for (let i = 0; i < array.length; i++) {\n if (i)\n res += ', ';\n if (array[i] === null || array[i] === void 0) {\n throw new TypeError('arrays cannot contain null or undefined values');\n }\n res += stringifyValue(array[i], extendedTypeOf(array[i]), depth - 1, numberAsFloat);\n }\n return res + ' ]';\n}\nfunction stringifyArrayTable(array, key, depth, numberAsFloat) {\n if (depth === 0) {\n throw new Error('Could not stringify the object: maximum object depth exceeded');\n }\n let res = '';\n for (let i = 0; i < array.length; i++) {\n res += `${res && '\\n'}[[${key}]]\\n`;\n res += stringifyTable(0, array[i], key, depth, numberAsFloat);\n }\n return res;\n}\nfunction stringifyTable(tableKey, obj, prefix, depth, numberAsFloat) {\n if (depth === 0) {\n throw new Error('Could not stringify the object: maximum object depth exceeded');\n }\n let preamble = '';\n let tables = '';\n let keys = Object.keys(obj);\n for (let i = 0; i < keys.length; i++) {\n let k = keys[i];\n if (obj[k] !== null && obj[k] !== void 0) {\n let type = extendedTypeOf(obj[k]);\n if (type === 'symbol' || type === 'function') {\n throw new TypeError(`cannot serialize values of type '${type}'`);\n }\n let key = BARE_KEY.test(k) ? k : formatString(k);\n if (type === 'array' && isArrayOfTables(obj[k])) {\n tables += (tables && '\\n') + stringifyArrayTable(obj[k], prefix ? `${prefix}.${key}` : key, depth - 1, numberAsFloat);\n }\n else if (type === 'object') {\n let tblKey = prefix ? `${prefix}.${key}` : key;\n tables += (tables && '\\n') + stringifyTable(tblKey, obj[k], tblKey, depth - 1, numberAsFloat);\n }\n else {\n preamble += key;\n preamble += ' = ';\n preamble += stringifyValue(obj[k], type, depth, numberAsFloat);\n preamble += '\\n';\n }\n }\n }\n if (tableKey && (preamble || !tables)) // Create table only if necessary\n preamble = preamble ? `[${tableKey}]\\n${preamble}` : `[${tableKey}]`;\n return preamble && tables\n ? `${preamble}\\n${tables}`\n : preamble || tables;\n}\nexport function stringify(obj, { maxDepth = 1000, numbersAsFloat = false } = {}) {\n if (extendedTypeOf(obj) !== 'object') {\n throw new TypeError('stringify can only be called with an object');\n }\n let str = stringifyTable(0, obj, '', maxDepth, numbersAsFloat);\n if (str[str.length - 1] !== '\\n')\n return str + '\\n';\n return str;\n}\n"],"mappings":"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","names":["endPtr","path","path","asNonEmptyString","asFiniteNumber","asPositiveNumber","asPositiveInteger","asBoolean","assertEnum","asPositiveDecimalString","k","out"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@pionex/pionex-ai-kit",
3
- "version": "0.2.34",
3
+ "version": "0.2.35",
4
4
  "description": "CLI for Pionex MCP: config init and credentials (writes ~/.pionex/config.toml)",
5
5
  "type": "module",
6
6
  "license": "MIT",