@pionex/pionex-ai-kit 0.2.25 → 0.2.27

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
@@ -1546,6 +1546,38 @@ function asNonNegativeDecimalString(value, field) {
1546
1546
  function toTrimmedDecimal(value) {
1547
1547
  return value.toFixed(8).replace(/\.?0+$/, "");
1548
1548
  }
1549
+ function decimalPlaces(value) {
1550
+ const idx = value.indexOf(".");
1551
+ return idx === -1 ? 0 : value.length - idx - 1;
1552
+ }
1553
+ function tenPow(exp) {
1554
+ let out = 1n;
1555
+ for (let i = 0; i < exp; i++) out *= 10n;
1556
+ return out;
1557
+ }
1558
+ function decimalStringToInt(value) {
1559
+ const [whole, frac = ""] = value.split(".");
1560
+ return { intVal: BigInt(`${whole}${frac}`), scale: frac.length };
1561
+ }
1562
+ function intToDecimalString(value, scale) {
1563
+ const negative = value < 0n;
1564
+ const abs = negative ? -value : value;
1565
+ const digits = abs.toString().padStart(scale + 1, "0");
1566
+ const whole = digits.slice(0, digits.length - scale);
1567
+ const frac = scale > 0 ? digits.slice(digits.length - scale) : "";
1568
+ const merged = scale > 0 ? `${whole}.${frac}` : whole;
1569
+ const trimmed = merged.replace(/\.?0+$/, "");
1570
+ return negative ? `-${trimmed}` : trimmed;
1571
+ }
1572
+ function multiplyDecimalByRatio(value, numerator, denominator, outScale) {
1573
+ const { intVal, scale } = decimalStringToInt(value);
1574
+ const n = BigInt(numerator);
1575
+ const d = BigInt(denominator);
1576
+ const scaledNumerator = intVal * n * tenPow(outScale);
1577
+ const scaledDenominator = d * tenPow(scale);
1578
+ const rounded = (scaledNumerator + scaledDenominator / 2n) / scaledDenominator;
1579
+ return intToDecimalString(rounded, outScale);
1580
+ }
1549
1581
  function maybePositiveDecimalString(value) {
1550
1582
  if (typeof value === "string" && /^\d+(\.\d+)?$/.test(value)) {
1551
1583
  const n = Number(value);
@@ -1556,6 +1588,9 @@ function maybePositiveDecimalString(value) {
1556
1588
  }
1557
1589
  return void 0;
1558
1590
  }
1591
+ function normalizePerpBase(base) {
1592
+ return base.endsWith(".PERP") ? base : `${base}.PERP`;
1593
+ }
1559
1594
  function tryExtractCurrentPrice(payload, symbol) {
1560
1595
  const stacks = [payload];
1561
1596
  while (stacks.length > 0) {
@@ -1632,15 +1667,20 @@ function registerBotTools() {
1632
1667
  description: "CreateFuturesGridOrderData payload from openapi_bot.yaml."
1633
1668
  }
1634
1669
  },
1635
- required: ["exchange", "base", "quote", "buOrderData"]
1670
+ required: ["base", "buOrderData"]
1636
1671
  },
1637
1672
  async handler(args, { client, config }) {
1638
1673
  if (config.readOnly) {
1639
1674
  throw new Error("Server is running in --read-only mode; bot create is disabled.");
1640
1675
  }
1641
- const exchange = asNonEmptyString(args.exchange, "exchange");
1642
- const base = asNonEmptyString(args.base, "base");
1643
- const quote = asNonEmptyString(args.quote, "quote");
1676
+ const defaultsApplied = {};
1677
+ const exchange = asNonEmptyString(args.exchange ?? "pionex.v2", "exchange");
1678
+ if (args.exchange == null) defaultsApplied.exchange = exchange;
1679
+ const rawBase = asNonEmptyString(args.base, "base");
1680
+ const base = normalizePerpBase(rawBase);
1681
+ if (base !== rawBase) defaultsApplied.base = base;
1682
+ const quote = asNonEmptyString(args.quote ?? "USDT", "quote");
1683
+ if (args.quote == null) defaultsApplied.quote = quote;
1644
1684
  const buOrderData = asObject(args.buOrderData, "buOrderData");
1645
1685
  const symbol = `${base}_${quote}`;
1646
1686
  const needsTickerForTopBottom = buOrderData.top == null || buOrderData.bottom == null;
@@ -1648,22 +1688,22 @@ function registerBotTools() {
1648
1688
  let currentPrice;
1649
1689
  if (shouldTryTicker) {
1650
1690
  try {
1651
- currentPrice = Number(await getCurrentSymbolPrice(client, symbol));
1691
+ currentPrice = asPositiveDecimalString(await getCurrentSymbolPrice(client, symbol), "currentPrice");
1652
1692
  } catch {
1653
1693
  currentPrice = void 0;
1654
1694
  }
1655
1695
  }
1656
- if (needsTickerForTopBottom && (currentPrice == null || !Number.isFinite(currentPrice) || currentPrice <= 0)) {
1696
+ if (needsTickerForTopBottom && currentPrice == null) {
1657
1697
  throw new Error(`Unable to infer current market price for ${symbol} from ticker response. Please provide buOrderData.top and buOrderData.bottom explicitly.`);
1658
1698
  }
1659
- const defaultsApplied = {};
1699
+ const autoPriceScale = currentPrice == null ? void 0 : Math.min(8, Math.max(2, decimalPlaces(currentPrice) + 2));
1660
1700
  const top = asPositiveDecimalString(
1661
- buOrderData.top ?? toTrimmedDecimal(currentPrice * 1.05),
1701
+ buOrderData.top ?? multiplyDecimalByRatio(currentPrice, 105, 100, autoPriceScale),
1662
1702
  "buOrderData.top"
1663
1703
  );
1664
1704
  if (buOrderData.top == null) defaultsApplied.top = top;
1665
1705
  const bottom = asPositiveDecimalString(
1666
- buOrderData.bottom ?? toTrimmedDecimal(currentPrice * 0.95),
1706
+ buOrderData.bottom ?? multiplyDecimalByRatio(currentPrice, 95, 100, autoPriceScale),
1667
1707
  "buOrderData.bottom"
1668
1708
  );
1669
1709
  if (buOrderData.bottom == null) defaultsApplied.bottom = bottom;
@@ -1709,11 +1749,18 @@ function registerBotTools() {
1709
1749
  if (args.copyBotOrderId != null) body.copyBotOrderId = String(args.copyBotOrderId);
1710
1750
  if (args.lang != null) body.lang = String(args.lang);
1711
1751
  if (args.__dryRun === true) {
1752
+ const rowSource = buOrderData.row == null ? "default" : "user";
1712
1753
  return {
1713
1754
  dryRun: true,
1714
1755
  note: "No order was sent. This is the resolved request body after applying defaults.",
1715
1756
  marketSymbol: symbol,
1716
- marketPriceUsed: currentPrice == null ? void 0 : toTrimmedDecimal(currentPrice),
1757
+ marketPriceUsed: currentPrice,
1758
+ resolvedParams: {
1759
+ row,
1760
+ rowSource,
1761
+ grid_type: gridType,
1762
+ leverage
1763
+ },
1717
1764
  defaultsApplied,
1718
1765
  resolvedBody: body
1719
1766
  };
@@ -2053,7 +2100,7 @@ Examples:
2053
2100
  pionex orders new --symbol BTC_USDT --side BUY --type MARKET --amount 10
2054
2101
  pionex orders cancel --symbol BTC_USDT --order-id 123
2055
2102
  pionex bot get --bu-order-id <id>
2056
- pionex bot create --exchange pionex.v2 --base BTC --quote USDT --bu-order-data-json '{"top":"110000","bottom":"90000","row":100,"grid_type":"arithmetic","openPrice":"100000","trend":"long","leverage":5,"extraMargin":"0","quoteInvestment":"100"}'
2103
+ pionex bot create --base BTC --bu-order-data-json '{"top":"110000","bottom":"90000","row":100,"grid_type":"arithmetic","openPrice":"100000","trend":"long","leverage":5,"extraMargin":"0","quoteInvestment":"100"}'
2057
2104
 
2058
2105
  Global flags:
2059
2106
  --profile <name> Profile in ~/.pionex/config.toml
@@ -2063,6 +2110,9 @@ Global flags:
2063
2110
  --dry-run Print the tool call payload without executing (write ops only)
2064
2111
 
2065
2112
  Bot create defaults:
2113
+ exchange Defaults to pionex.v2 when missing
2114
+ quote Defaults to USDT when missing
2115
+ base Auto-normalized to <BASE>.PERP when missing suffix
2066
2116
  --key-id Optional
2067
2117
  buOrderData.top Defaults to current price * 1.05 when missing
2068
2118
  buOrderData.bottom Defaults to current price * 0.95 when missing
@@ -2255,8 +2305,8 @@ async function runPionexCommand(argv) {
2255
2305
  const copyBotOrderId = typeof flags["copy-bot-order-id"] === "string" ? flags["copy-bot-order-id"] : typeof flags.copyBotOrderId === "string" ? flags.copyBotOrderId : void 0;
2256
2306
  const lang = typeof flags.lang === "string" ? flags.lang : void 0;
2257
2307
  const buOrderData = parseJsonFlag(flags["bu-order-data-json"] ?? flags.buOrderDataJson, "bu-order-data-json");
2258
- if (!exchange || !base || !quote) {
2259
- throw new Error("Missing required flags: --exchange --base --quote --bu-order-data-json");
2308
+ if (!base) {
2309
+ throw new Error("Missing required flags: --base --bu-order-data-json");
2260
2310
  }
2261
2311
  const payload = { exchange, base, quote, copyFrom, copyType, groupId, copyBotOrderId, lang, buOrderData };
2262
2312
  if (keyId) payload.keyId = keyId;
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/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} 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 <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 Futures grid bot (requires auth)\n\nExamples:\n pionex market depth BTC_USDT --limit 5\n pionex market tickers --symbol BTC_USDT\n pionex market symbols --symbols BTC_USDT\n pionex account balance\n pionex orders new --symbol BTC_USDT --side BUY --type MARKET --amount 10\n pionex orders cancel --symbol BTC_USDT --order-id 123\n pionex bot get --bu-order-id <id>\n pionex bot create --exchange pionex.v2 --base BTC --quote USDT --bu-order-data-json '{\"top\":\"110000\",\"bottom\":\"90000\",\"row\":100,\"grid_type\":\"arithmetic\",\"openPrice\":\"100000\",\"trend\":\"long\",\"leverage\":5,\"extraMargin\":\"0\",\"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 the tool call payload without executing (write ops only)\n\nBot create defaults:\n --key-id Optional\n buOrderData.top Defaults to current price * 1.05 when missing\n buOrderData.bottom Defaults to current price * 0.95 when missing\n buOrderData.row Defaults to 10 when missing\n buOrderData.grid_type Defaults to arithmetic when missing\n buOrderData.leverage Defaults to 2 when missing\n buOrderData.openPrice Optional. If omitted, it is not sent\n buOrderData.extraMargin Defaults to \"0\" when missing\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 const command = 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 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 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 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 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_get_futures_grid_order\", { buOrderId, lang });\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"create\") {\n const keyId = typeof flags[\"key-id\"] === \"string\" ? (flags[\"key-id\"] as string) : typeof flags.keyId === \"string\" ? (flags.keyId as string) : undefined;\n const exchange = typeof flags.exchange === \"string\" ? flags.exchange : undefined;\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 groupId = typeof flags[\"group-id\"] === \"string\" ? (flags[\"group-id\"] as string) : typeof flags.groupId === \"string\" ? (flags.groupId 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 lang = typeof flags.lang === \"string\" ? flags.lang : undefined;\n const buOrderData = parseJsonFlag(flags[\"bu-order-data-json\"] ?? flags.buOrderDataJson, \"bu-order-data-json\");\n if (!exchange || !base || !quote) {\n throw new Error(\"Missing required flags: --exchange --base --quote --bu-order-data-json\");\n }\n const payload: Record<string, unknown> = { exchange, base, quote, copyFrom, copyType, groupId, copyBotOrderId, lang, buOrderData };\n if (keyId) payload.keyId = keyId;\n if (dryRun) {\n const out = await runTool(\"pionex_bot_create_futures_grid_order\", { ...payload, __dryRun: true });\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n const out = await runTool(\"pionex_bot_create_futures_grid_order\", payload);\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"adjust\") {\n const payload = parseJsonFlag(flags[\"body-json\"] ?? flags.bodyJson, \"body-json\");\n if (dryRun) {\n process.stdout.write(JSON.stringify({ tool: \"pionex_bot_adjust_futures_grid_params\", args: payload }, null, 2) + \"\\n\");\n return;\n }\n const out = await runTool(\"pionex_bot_adjust_futures_grid_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_reduce_futures_grid_position\", args: payload }, null, 2) + \"\\n\");\n return;\n }\n const out = await runTool(\"pionex_bot_reduce_futures_grid_position\", 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_cancel_futures_grid_order\", args: payload }, null, 2) + \"\\n\");\n return;\n }\n const out = await runTool(\"pionex_bot_cancel_futures_grid_order\", payload);\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n throw new Error(`Unknown bot 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 <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\";\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: Record<string, unknown> = { 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: Record<string, unknown> = { 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: Record<string, unknown> = {};\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: Record<string, unknown> = {};\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: Record<string, unknown> = { 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\";\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: Record<string, unknown> = { 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: Record<string, unknown> = { 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","import type { ToolSpec } from \"./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 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 toTrimmedDecimal(value: number): string {\n return value.toFixed(8).replace(/\\.?0+$/, \"\");\n}\n\nfunction maybePositiveDecimalString(value: unknown): string | undefined {\n if (typeof value === \"string\" && /^\\d+(\\.\\d+)?$/.test(value)) {\n const n = Number(value);\n if (Number.isFinite(n) && n > 0) return value;\n }\n if (typeof value === \"number\" && Number.isFinite(value) && value > 0) {\n return toTrimmedDecimal(value);\n }\n return undefined;\n}\n\nfunction tryExtractCurrentPrice(payload: unknown, symbol: string): string | undefined {\n const stacks: unknown[] = [payload];\n while (stacks.length > 0) {\n const node = stacks.pop();\n if (!node || typeof node !== \"object\") continue;\n\n const obj = node as Record<string, unknown>;\n const nodeSymbol = typeof obj.symbol === \"string\" ? obj.symbol : undefined;\n const candidateClose =\n maybePositiveDecimalString(obj.close) ??\n maybePositiveDecimalString(obj.last) ??\n maybePositiveDecimalString(obj.lastPrice) ??\n maybePositiveDecimalString(obj.price);\n if (candidateClose && (!nodeSymbol || nodeSymbol === symbol)) {\n return candidateClose;\n }\n\n for (const v of Object.values(obj)) {\n if (Array.isArray(v)) {\n for (const item of v) stacks.push(item);\n } else if (v && typeof v === \"object\") {\n stacks.push(v);\n }\n }\n }\n return undefined;\n}\n\nasync function getCurrentSymbolPrice(client: { publicGet: <TData = unknown>(path: string, query?: Record<string, unknown>) => Promise<{ data: TData }> }, symbol: string): Promise<string> {\n const tickerPayload = (await client.publicGet(\"/api/v1/market/tickers\", { symbol })).data;\n const extracted = tryExtractCurrentPrice(tickerPayload, symbol);\n if (!extracted) {\n throw new Error(`Unable to infer current market price for ${symbol} from ticker response. Please provide buOrderData.top and buOrderData.bottom explicitly.`);\n }\n return extracted;\n}\n\nexport function registerBotTools(): ToolSpec[] {\n return [\n {\n name: \"pionex_bot_get_futures_grid_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: Record<string, unknown> = { 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_create_futures_grid_order\",\n module: \"bot\",\n isWrite: true,\n description: \"Create a futures grid bot order.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n keyId: { type: \"string\" },\n exchange: { type: \"string\", description: \"e.g. pionex.v2\" },\n base: { type: \"string\", description: \"e.g. BTC\" },\n quote: { type: \"string\", description: \"e.g. USDT\" },\n copyFrom: { type: \"string\" },\n copyType: { type: \"string\" },\n groupId: { type: \"string\" },\n copyBotOrderId: { type: \"string\" },\n lang: { type: \"string\" },\n buOrderData: {\n type: \"object\",\n additionalProperties: true,\n description: \"CreateFuturesGridOrderData payload from openapi_bot.yaml.\",\n },\n },\n required: [\"exchange\", \"base\", \"quote\", \"buOrderData\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; bot create is disabled.\");\n }\n const exchange = asNonEmptyString(args.exchange, \"exchange\");\n const base = asNonEmptyString(args.base, \"base\");\n const quote = asNonEmptyString(args.quote, \"quote\");\n const buOrderData = asObject(args.buOrderData, \"buOrderData\");\n const symbol = `${base}_${quote}`;\n const needsTickerForTopBottom = buOrderData.top == null || buOrderData.bottom == null;\n const shouldTryTicker = needsTickerForTopBottom;\n let currentPrice: number | undefined;\n if (shouldTryTicker) {\n try {\n currentPrice = Number(await getCurrentSymbolPrice(client, symbol));\n } catch {\n currentPrice = undefined;\n }\n }\n if (needsTickerForTopBottom && (currentPrice == null || !Number.isFinite(currentPrice) || currentPrice <= 0)) {\n throw new Error(`Unable to infer current market price for ${symbol} from ticker response. Please provide buOrderData.top and buOrderData.bottom explicitly.`);\n }\n const defaultsApplied: Record<string, unknown> = {};\n\n const top = asPositiveDecimalString(\n buOrderData.top ?? toTrimmedDecimal((currentPrice as number) * 1.05),\n \"buOrderData.top\",\n );\n if (buOrderData.top == null) defaultsApplied.top = top;\n const bottom = asPositiveDecimalString(\n buOrderData.bottom ?? toTrimmedDecimal((currentPrice as number) * 0.95),\n \"buOrderData.bottom\",\n );\n if (buOrderData.bottom == null) defaultsApplied.bottom = bottom;\n if (Number(top) <= Number(bottom)) {\n throw new Error('Invalid \"buOrderData.top\": expected top > bottom.');\n }\n const row = asPositiveInteger(buOrderData.row ?? 10, \"buOrderData.row\");\n if (buOrderData.row == null) defaultsApplied.row = row;\n const gridType = asNonEmptyString(buOrderData.grid_type ?? \"arithmetic\", \"buOrderData.grid_type\");\n assertEnum(gridType, \"buOrderData.grid_type\", [\"arithmetic\", \"geometric\"]);\n if (buOrderData.grid_type == null) defaultsApplied.grid_type = gridType;\n const openPrice =\n buOrderData.openPrice == null ? undefined : asPositiveDecimalString(buOrderData.openPrice, \"buOrderData.openPrice\");\n const trend = asNonEmptyString(buOrderData.trend, \"buOrderData.trend\");\n assertEnum(trend, \"buOrderData.trend\", [\"long\", \"short\", \"no_trend\"]);\n const leverage = asPositiveNumber(buOrderData.leverage ?? 2, \"buOrderData.leverage\");\n if (buOrderData.leverage == null) defaultsApplied.leverage = leverage;\n const extraMargin = asNonNegativeDecimalString(buOrderData.extraMargin ?? \"0\", \"buOrderData.extraMargin\");\n if (buOrderData.extraMargin == null) defaultsApplied.extraMargin = extraMargin;\n const quoteInvestment = asPositiveDecimalString(buOrderData.quoteInvestment, \"buOrderData.quoteInvestment\");\n\n const body: Record<string, unknown> = {\n exchange,\n base,\n quote,\n buOrderData: {\n ...buOrderData,\n top,\n bottom,\n row,\n grid_type: gridType,\n trend,\n leverage,\n extraMargin,\n quoteInvestment,\n },\n };\n if (openPrice != null) {\n (body.buOrderData as Record<string, unknown>).openPrice = openPrice;\n }\n if (args.keyId != null) body.keyId = asNonEmptyString(args.keyId, \"keyId\");\n if (args.copyFrom != null) body.copyFrom = String(args.copyFrom);\n if (args.copyType != null) body.copyType = String(args.copyType);\n if (args.groupId != null) body.groupId = String(args.groupId);\n if (args.copyBotOrderId != null) body.copyBotOrderId = String(args.copyBotOrderId);\n if (args.lang != null) body.lang = String(args.lang);\n if (args.__dryRun === true) {\n return {\n dryRun: true,\n note: \"No order was sent. This is the resolved request body after applying defaults.\",\n marketSymbol: symbol,\n marketPriceUsed: currentPrice == null ? undefined : toTrimmedDecimal(currentPrice),\n defaultsApplied,\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_adjust_futures_grid_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 openPrice: { type: \"number\" },\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\", \"openPrice\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; bot adjust 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 const openPrice = asFiniteNumber(args.openPrice, \"openPrice\");\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 openPrice,\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_reduce_futures_grid_position\",\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 openPrice: { 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\", \"openPrice\", \"reduceNum\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; bot reduce is disabled.\");\n }\n const buOrderId = asNonEmptyString(args.buOrderId, \"buOrderId\");\n const openPrice = asPositiveDecimalString(args.openPrice, \"openPrice\");\n const reduceNum = asPositiveInteger(args.reduceNum, \"reduceNum\");\n const body: Record<string, unknown> = {\n buOrderId,\n openPrice,\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_cancel_futures_grid_order\",\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 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","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/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} 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 <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 Futures grid bot (requires auth)\n\nExamples:\n pionex market depth BTC_USDT --limit 5\n pionex market tickers --symbol BTC_USDT\n pionex market symbols --symbols BTC_USDT\n pionex account balance\n pionex orders new --symbol BTC_USDT --side BUY --type MARKET --amount 10\n pionex orders cancel --symbol BTC_USDT --order-id 123\n pionex bot get --bu-order-id <id>\n pionex bot create --base BTC --bu-order-data-json '{\"top\":\"110000\",\"bottom\":\"90000\",\"row\":100,\"grid_type\":\"arithmetic\",\"openPrice\":\"100000\",\"trend\":\"long\",\"leverage\":5,\"extraMargin\":\"0\",\"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 the tool call payload without executing (write ops only)\n\nBot create defaults:\n exchange Defaults to pionex.v2 when missing\n quote Defaults to USDT when missing\n base Auto-normalized to <BASE>.PERP when missing suffix\n --key-id Optional\n buOrderData.top Defaults to current price * 1.05 when missing\n buOrderData.bottom Defaults to current price * 0.95 when missing\n buOrderData.row Defaults to 10 when missing\n buOrderData.grid_type Defaults to arithmetic when missing\n buOrderData.leverage Defaults to 2 when missing\n buOrderData.openPrice Optional. If omitted, it is not sent\n buOrderData.extraMargin Defaults to \"0\" when missing\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 const command = 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 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 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 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 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_get_futures_grid_order\", { buOrderId, lang });\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"create\") {\n const keyId = typeof flags[\"key-id\"] === \"string\" ? (flags[\"key-id\"] as string) : typeof flags.keyId === \"string\" ? (flags.keyId as string) : undefined;\n const exchange = typeof flags.exchange === \"string\" ? flags.exchange : undefined;\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 groupId = typeof flags[\"group-id\"] === \"string\" ? (flags[\"group-id\"] as string) : typeof flags.groupId === \"string\" ? (flags.groupId 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 lang = typeof flags.lang === \"string\" ? flags.lang : undefined;\n const buOrderData = parseJsonFlag(flags[\"bu-order-data-json\"] ?? flags.buOrderDataJson, \"bu-order-data-json\");\n if (!base) {\n throw new Error(\"Missing required flags: --base --bu-order-data-json\");\n }\n const payload: Record<string, unknown> = { exchange, base, quote, copyFrom, copyType, groupId, copyBotOrderId, lang, buOrderData };\n if (keyId) payload.keyId = keyId;\n if (dryRun) {\n const out = await runTool(\"pionex_bot_create_futures_grid_order\", { ...payload, __dryRun: true });\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n const out = await runTool(\"pionex_bot_create_futures_grid_order\", payload);\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"adjust\") {\n const payload = parseJsonFlag(flags[\"body-json\"] ?? flags.bodyJson, \"body-json\");\n if (dryRun) {\n process.stdout.write(JSON.stringify({ tool: \"pionex_bot_adjust_futures_grid_params\", args: payload }, null, 2) + \"\\n\");\n return;\n }\n const out = await runTool(\"pionex_bot_adjust_futures_grid_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_reduce_futures_grid_position\", args: payload }, null, 2) + \"\\n\");\n return;\n }\n const out = await runTool(\"pionex_bot_reduce_futures_grid_position\", 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_cancel_futures_grid_order\", args: payload }, null, 2) + \"\\n\");\n return;\n }\n const out = await runTool(\"pionex_bot_cancel_futures_grid_order\", payload);\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n throw new Error(`Unknown bot 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 <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\";\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: Record<string, unknown> = { 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: Record<string, unknown> = { 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: Record<string, unknown> = {};\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: Record<string, unknown> = {};\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: Record<string, unknown> = { 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\";\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: Record<string, unknown> = { 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: Record<string, unknown> = { 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","import type { ToolSpec } from \"./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 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 toTrimmedDecimal(value: number): string {\n return value.toFixed(8).replace(/\\.?0+$/, \"\");\n}\n\nfunction decimalPlaces(value: string): number {\n const idx = value.indexOf(\".\");\n return idx === -1 ? 0 : value.length - idx - 1;\n}\n\nfunction tenPow(exp: number): bigint {\n let out = 1n;\n for (let i = 0; i < exp; i++) out *= 10n;\n return out;\n}\n\nfunction decimalStringToInt(value: string): { intVal: bigint; scale: number } {\n const [whole, frac = \"\"] = value.split(\".\");\n return { intVal: BigInt(`${whole}${frac}`), scale: frac.length };\n}\n\nfunction intToDecimalString(value: bigint, scale: number): string {\n const negative = value < 0n;\n const abs = negative ? -value : value;\n const digits = abs.toString().padStart(scale + 1, \"0\");\n const whole = digits.slice(0, digits.length - scale);\n const frac = scale > 0 ? digits.slice(digits.length - scale) : \"\";\n const merged = scale > 0 ? `${whole}.${frac}` : whole;\n const trimmed = merged.replace(/\\.?0+$/, \"\");\n return negative ? `-${trimmed}` : trimmed;\n}\n\nfunction multiplyDecimalByRatio(value: string, numerator: number, denominator: number, outScale: number): string {\n const { intVal, scale } = decimalStringToInt(value);\n const n = BigInt(numerator);\n const d = BigInt(denominator);\n const scaledNumerator = intVal * n * tenPow(outScale);\n const scaledDenominator = d * tenPow(scale);\n // Half-up rounding to reduce systematic bias.\n const rounded = (scaledNumerator + scaledDenominator / 2n) / scaledDenominator;\n return intToDecimalString(rounded, outScale);\n}\n\nfunction maybePositiveDecimalString(value: unknown): string | undefined {\n if (typeof value === \"string\" && /^\\d+(\\.\\d+)?$/.test(value)) {\n const n = Number(value);\n if (Number.isFinite(n) && n > 0) return value;\n }\n if (typeof value === \"number\" && Number.isFinite(value) && value > 0) {\n return toTrimmedDecimal(value);\n }\n return undefined;\n}\n\nfunction normalizePerpBase(base: string): string {\n return base.endsWith(\".PERP\") ? base : `${base}.PERP`;\n}\n\nfunction tryExtractCurrentPrice(payload: unknown, symbol: string): string | undefined {\n const stacks: unknown[] = [payload];\n while (stacks.length > 0) {\n const node = stacks.pop();\n if (!node || typeof node !== \"object\") continue;\n\n const obj = node as Record<string, unknown>;\n const nodeSymbol = typeof obj.symbol === \"string\" ? obj.symbol : undefined;\n const candidateClose =\n maybePositiveDecimalString(obj.close) ??\n maybePositiveDecimalString(obj.last) ??\n maybePositiveDecimalString(obj.lastPrice) ??\n maybePositiveDecimalString(obj.price);\n if (candidateClose && (!nodeSymbol || nodeSymbol === symbol)) {\n return candidateClose;\n }\n\n for (const v of Object.values(obj)) {\n if (Array.isArray(v)) {\n for (const item of v) stacks.push(item);\n } else if (v && typeof v === \"object\") {\n stacks.push(v);\n }\n }\n }\n return undefined;\n}\n\nasync function getCurrentSymbolPrice(client: { publicGet: <TData = unknown>(path: string, query?: Record<string, unknown>) => Promise<{ data: TData }> }, symbol: string): Promise<string> {\n const tickerPayload = (await client.publicGet(\"/api/v1/market/tickers\", { symbol })).data;\n const extracted = tryExtractCurrentPrice(tickerPayload, symbol);\n if (!extracted) {\n throw new Error(`Unable to infer current market price for ${symbol} from ticker response. Please provide buOrderData.top and buOrderData.bottom explicitly.`);\n }\n return extracted;\n}\n\nexport function registerBotTools(): ToolSpec[] {\n return [\n {\n name: \"pionex_bot_get_futures_grid_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: Record<string, unknown> = { 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_create_futures_grid_order\",\n module: \"bot\",\n isWrite: true,\n description: \"Create a futures grid bot order.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n keyId: { type: \"string\" },\n exchange: { type: \"string\", description: \"e.g. pionex.v2\" },\n base: { type: \"string\", description: \"e.g. BTC\" },\n quote: { type: \"string\", description: \"e.g. USDT\" },\n copyFrom: { type: \"string\" },\n copyType: { type: \"string\" },\n groupId: { type: \"string\" },\n copyBotOrderId: { type: \"string\" },\n lang: { type: \"string\" },\n buOrderData: {\n type: \"object\",\n additionalProperties: true,\n description: \"CreateFuturesGridOrderData payload from openapi_bot.yaml.\",\n },\n },\n required: [\"base\", \"buOrderData\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; bot create is disabled.\");\n }\n const defaultsApplied: Record<string, unknown> = {};\n const exchange = asNonEmptyString(args.exchange ?? \"pionex.v2\", \"exchange\");\n if (args.exchange == null) defaultsApplied.exchange = exchange;\n const rawBase = asNonEmptyString(args.base, \"base\");\n const base = normalizePerpBase(rawBase);\n if (base !== rawBase) defaultsApplied.base = base;\n const quote = asNonEmptyString(args.quote ?? \"USDT\", \"quote\");\n if (args.quote == null) defaultsApplied.quote = quote;\n const buOrderData = asObject(args.buOrderData, \"buOrderData\");\n const symbol = `${base}_${quote}`;\n const needsTickerForTopBottom = buOrderData.top == null || buOrderData.bottom == null;\n const shouldTryTicker = needsTickerForTopBottom;\n let currentPrice: string | undefined;\n if (shouldTryTicker) {\n try {\n currentPrice = asPositiveDecimalString(await getCurrentSymbolPrice(client, symbol), \"currentPrice\");\n } catch {\n currentPrice = undefined;\n }\n }\n if (needsTickerForTopBottom && currentPrice == null) {\n throw new Error(`Unable to infer current market price for ${symbol} from ticker response. Please provide buOrderData.top and buOrderData.bottom explicitly.`);\n }\n const autoPriceScale = currentPrice == null ? undefined : Math.min(8, Math.max(2, decimalPlaces(currentPrice) + 2));\n const top = asPositiveDecimalString(\n buOrderData.top ??\n multiplyDecimalByRatio(currentPrice as string, 105, 100, autoPriceScale as number),\n \"buOrderData.top\",\n );\n if (buOrderData.top == null) defaultsApplied.top = top;\n const bottom = asPositiveDecimalString(\n buOrderData.bottom ??\n multiplyDecimalByRatio(currentPrice as string, 95, 100, autoPriceScale as number),\n \"buOrderData.bottom\",\n );\n if (buOrderData.bottom == null) defaultsApplied.bottom = bottom;\n if (Number(top) <= Number(bottom)) {\n throw new Error('Invalid \"buOrderData.top\": expected top > bottom.');\n }\n const row = asPositiveInteger(buOrderData.row ?? 10, \"buOrderData.row\");\n if (buOrderData.row == null) defaultsApplied.row = row;\n const gridType = asNonEmptyString(buOrderData.grid_type ?? \"arithmetic\", \"buOrderData.grid_type\");\n assertEnum(gridType, \"buOrderData.grid_type\", [\"arithmetic\", \"geometric\"]);\n if (buOrderData.grid_type == null) defaultsApplied.grid_type = gridType;\n const openPrice =\n buOrderData.openPrice == null ? undefined : asPositiveDecimalString(buOrderData.openPrice, \"buOrderData.openPrice\");\n const trend = asNonEmptyString(buOrderData.trend, \"buOrderData.trend\");\n assertEnum(trend, \"buOrderData.trend\", [\"long\", \"short\", \"no_trend\"]);\n const leverage = asPositiveNumber(buOrderData.leverage ?? 2, \"buOrderData.leverage\");\n if (buOrderData.leverage == null) defaultsApplied.leverage = leverage;\n const extraMargin = asNonNegativeDecimalString(buOrderData.extraMargin ?? \"0\", \"buOrderData.extraMargin\");\n if (buOrderData.extraMargin == null) defaultsApplied.extraMargin = extraMargin;\n const quoteInvestment = asPositiveDecimalString(buOrderData.quoteInvestment, \"buOrderData.quoteInvestment\");\n\n const body: Record<string, unknown> = {\n exchange,\n base,\n quote,\n buOrderData: {\n ...buOrderData,\n top,\n bottom,\n row,\n grid_type: gridType,\n trend,\n leverage,\n extraMargin,\n quoteInvestment,\n },\n };\n if (openPrice != null) {\n (body.buOrderData as Record<string, unknown>).openPrice = openPrice;\n }\n if (args.keyId != null) body.keyId = asNonEmptyString(args.keyId, \"keyId\");\n if (args.copyFrom != null) body.copyFrom = String(args.copyFrom);\n if (args.copyType != null) body.copyType = String(args.copyType);\n if (args.groupId != null) body.groupId = String(args.groupId);\n if (args.copyBotOrderId != null) body.copyBotOrderId = String(args.copyBotOrderId);\n if (args.lang != null) body.lang = String(args.lang);\n if (args.__dryRun === true) {\n const rowSource = buOrderData.row == null ? \"default\" : \"user\";\n return {\n dryRun: true,\n note: \"No order was sent. This is the resolved request body after applying defaults.\",\n marketSymbol: symbol,\n marketPriceUsed: currentPrice,\n resolvedParams: {\n row,\n rowSource,\n grid_type: gridType,\n leverage,\n },\n defaultsApplied,\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_adjust_futures_grid_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 openPrice: { type: \"number\" },\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\", \"openPrice\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; bot adjust 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 const openPrice = asFiniteNumber(args.openPrice, \"openPrice\");\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 openPrice,\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_reduce_futures_grid_position\",\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 openPrice: { 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\", \"openPrice\", \"reduceNum\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; bot reduce is disabled.\");\n }\n const buOrderId = asNonEmptyString(args.buOrderId, \"buOrderId\");\n const openPrice = asPositiveDecimalString(args.openPrice, \"openPrice\");\n const reduceNum = asPositiveInteger(args.reduceNum, \"reduceNum\");\n const body: Record<string, unknown> = {\n buOrderId,\n openPrice,\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_cancel_futures_grid_order\",\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 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","k","out"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@pionex/pionex-ai-kit",
3
- "version": "0.2.25",
3
+ "version": "0.2.27",
4
4
  "description": "CLI for Pionex MCP: config init and credentials (writes ~/.pionex/config.toml)",
5
5
  "type": "module",
6
6
  "license": "MIT",