@pionex/pionex-ai-kit 0.2.29 → 0.2.31
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/README.md +1 -1
- package/dist/index.js +20 -30
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -16,7 +16,7 @@ npm install -g @pionex/pionex-ai-kit
|
|
|
16
16
|
- **pionex market ...** — Public market data commands.
|
|
17
17
|
- **pionex account ...** — Account balance command.
|
|
18
18
|
- **pionex orders ...** — Spot order lifecycle commands.
|
|
19
|
-
- **pionex bot ...** — Futures grid bot lifecycle commands (`get/create/
|
|
19
|
+
- **pionex bot ...** — Futures grid bot lifecycle commands (`get/create/adjust_params/reduce/cancel`).
|
|
20
20
|
|
|
21
21
|
The MCP server (**@pionex/pionex-trade-mcp**) reads from the same file. After init, run:
|
|
22
22
|
|
package/dist/index.js
CHANGED
|
@@ -1749,7 +1749,6 @@ var createFuturesGridCreateToolInputSchema = {
|
|
|
1749
1749
|
properties: {
|
|
1750
1750
|
base: { type: "string", description: "Base currency (e.g. BTC); *.PERP normalized in handler" },
|
|
1751
1751
|
quote: { type: "string", description: "Quote currency (e.g. USDT)" },
|
|
1752
|
-
exchange: { type: "string", description: "Optional. Futures exchange identifier (temporary compatibility)." },
|
|
1753
1752
|
copyFrom: { type: "string", description: "Optional. Copy source order ID" },
|
|
1754
1753
|
copyType: { type: "string", description: "Optional. Copy type" },
|
|
1755
1754
|
copyBotOrderId: { type: "string", description: "Optional. Copy bot order ID" },
|
|
@@ -1815,7 +1814,7 @@ function normalizePerpBase(base) {
|
|
|
1815
1814
|
function registerBotTools() {
|
|
1816
1815
|
return [
|
|
1817
1816
|
{
|
|
1818
|
-
name: "
|
|
1817
|
+
name: "pionex_bot_futures_grid_get_order",
|
|
1819
1818
|
module: "bot",
|
|
1820
1819
|
isWrite: false,
|
|
1821
1820
|
description: "Get one futures grid bot order by buOrderId.",
|
|
@@ -1836,7 +1835,7 @@ function registerBotTools() {
|
|
|
1836
1835
|
}
|
|
1837
1836
|
},
|
|
1838
1837
|
{
|
|
1839
|
-
name: "
|
|
1838
|
+
name: "pionex_bot_futures_grid_create",
|
|
1840
1839
|
module: "bot",
|
|
1841
1840
|
isWrite: true,
|
|
1842
1841
|
description: "Create a futures grid order (openapi_bot.yaml CreateFuturesGridRequest / CreateFuturesGridOrderData). https://github.com/pionex-official/pionex-open-api/blob/main/openapi_bot.yaml \u2014 Required: base, quote, buOrderData. Optional: copyFrom, copyType, copyBotOrderId. buOrderData required: top, bottom, row, grid_type, trend, leverage, quoteInvestment; unknown keys rejected.",
|
|
@@ -1848,7 +1847,6 @@ function registerBotTools() {
|
|
|
1848
1847
|
const rawBase = asNonEmptyString2(args.base, "base");
|
|
1849
1848
|
const base = normalizePerpBase(rawBase);
|
|
1850
1849
|
const quote = asNonEmptyString2(args.quote, "quote");
|
|
1851
|
-
const exchange = args.exchange != null ? asNonEmptyString2(args.exchange, "exchange") : void 0;
|
|
1852
1850
|
const buOrderDataOut = parseAndValidateCreateFuturesGridBuOrderData(asObject(args.buOrderData, "buOrderData"));
|
|
1853
1851
|
const row = buOrderDataOut.row;
|
|
1854
1852
|
const gridType = buOrderDataOut.grid_type;
|
|
@@ -1858,7 +1856,6 @@ function registerBotTools() {
|
|
|
1858
1856
|
quote,
|
|
1859
1857
|
buOrderData: buOrderDataOut
|
|
1860
1858
|
};
|
|
1861
|
-
if (exchange != null) body.exchange = exchange;
|
|
1862
1859
|
if (args.copyFrom != null) body.copyFrom = String(args.copyFrom);
|
|
1863
1860
|
if (args.copyType != null) body.copyType = String(args.copyType);
|
|
1864
1861
|
if (args.copyBotOrderId != null) body.copyBotOrderId = String(args.copyBotOrderId);
|
|
@@ -1878,7 +1875,7 @@ function registerBotTools() {
|
|
|
1878
1875
|
}
|
|
1879
1876
|
},
|
|
1880
1877
|
{
|
|
1881
|
-
name: "
|
|
1878
|
+
name: "pionex_bot_futures_grid_adjust_params",
|
|
1882
1879
|
module: "bot",
|
|
1883
1880
|
isWrite: true,
|
|
1884
1881
|
description: "Adjust futures grid bot params (invest_in / adjust_params / invest_in_trigger).",
|
|
@@ -1890,7 +1887,6 @@ function registerBotTools() {
|
|
|
1890
1887
|
type: { type: "string", enum: ["invest_in", "adjust_params", "invest_in_trigger"] },
|
|
1891
1888
|
quoteInvestment: { type: "number" },
|
|
1892
1889
|
extraMargin: { type: "boolean" },
|
|
1893
|
-
openPrice: { type: "number" },
|
|
1894
1890
|
bottom: { type: "string" },
|
|
1895
1891
|
top: { type: "string" },
|
|
1896
1892
|
row: { type: "number" },
|
|
@@ -1904,17 +1900,16 @@ function registerBotTools() {
|
|
|
1904
1900
|
slippage: { type: "string" },
|
|
1905
1901
|
adjustParamsSence: { type: "string" }
|
|
1906
1902
|
},
|
|
1907
|
-
required: ["buOrderId", "type", "extraMargin"
|
|
1903
|
+
required: ["buOrderId", "type", "extraMargin"]
|
|
1908
1904
|
},
|
|
1909
1905
|
async handler(args, { client, config }) {
|
|
1910
1906
|
if (config.readOnly) {
|
|
1911
|
-
throw new Error("Server is running in --read-only mode; bot
|
|
1907
|
+
throw new Error("Server is running in --read-only mode; bot adjust_params is disabled.");
|
|
1912
1908
|
}
|
|
1913
1909
|
const buOrderId = asNonEmptyString2(args.buOrderId, "buOrderId");
|
|
1914
1910
|
const type = asNonEmptyString2(args.type, "type");
|
|
1915
1911
|
assertEnum2(type, "type", ["invest_in", "adjust_params", "invest_in_trigger"]);
|
|
1916
1912
|
const extraMargin = asBoolean2(args.extraMargin, "extraMargin");
|
|
1917
|
-
const openPrice = asFiniteNumber2(args.openPrice, "openPrice");
|
|
1918
1913
|
if (type === "invest_in" && args.quoteInvestment != null) {
|
|
1919
1914
|
asPositiveNumber2(args.quoteInvestment, "quoteInvestment");
|
|
1920
1915
|
}
|
|
@@ -1934,8 +1929,7 @@ function registerBotTools() {
|
|
|
1934
1929
|
const body = {
|
|
1935
1930
|
buOrderId,
|
|
1936
1931
|
type,
|
|
1937
|
-
extraMargin
|
|
1938
|
-
openPrice
|
|
1932
|
+
extraMargin
|
|
1939
1933
|
};
|
|
1940
1934
|
if (args.quoteInvestment != null) body.quoteInvestment = asFiniteNumber2(args.quoteInvestment, "quoteInvestment");
|
|
1941
1935
|
if (args.bottom != null) body.bottom = asPositiveDecimalString2(args.bottom, "bottom");
|
|
@@ -1962,7 +1956,7 @@ function registerBotTools() {
|
|
|
1962
1956
|
}
|
|
1963
1957
|
},
|
|
1964
1958
|
{
|
|
1965
|
-
name: "
|
|
1959
|
+
name: "pionex_bot_futures_grid_reduce",
|
|
1966
1960
|
module: "bot",
|
|
1967
1961
|
isWrite: true,
|
|
1968
1962
|
description: "Reduce futures grid bot position.",
|
|
@@ -1971,24 +1965,21 @@ function registerBotTools() {
|
|
|
1971
1965
|
additionalProperties: false,
|
|
1972
1966
|
properties: {
|
|
1973
1967
|
buOrderId: { type: "string" },
|
|
1974
|
-
openPrice: { type: "string" },
|
|
1975
1968
|
reduceNum: { type: "number" },
|
|
1976
1969
|
slippage: { type: "string" },
|
|
1977
1970
|
condition: { type: "string" },
|
|
1978
1971
|
conditionDirection: { type: "string", enum: ["1", "-1"] }
|
|
1979
1972
|
},
|
|
1980
|
-
required: ["buOrderId", "
|
|
1973
|
+
required: ["buOrderId", "reduceNum"]
|
|
1981
1974
|
},
|
|
1982
1975
|
async handler(args, { client, config }) {
|
|
1983
1976
|
if (config.readOnly) {
|
|
1984
1977
|
throw new Error("Server is running in --read-only mode; bot reduce is disabled.");
|
|
1985
1978
|
}
|
|
1986
1979
|
const buOrderId = asNonEmptyString2(args.buOrderId, "buOrderId");
|
|
1987
|
-
const openPrice = asPositiveDecimalString2(args.openPrice, "openPrice");
|
|
1988
1980
|
const reduceNum = asPositiveInteger2(args.reduceNum, "reduceNum");
|
|
1989
1981
|
const body = {
|
|
1990
1982
|
buOrderId,
|
|
1991
|
-
openPrice,
|
|
1992
1983
|
reduceNum
|
|
1993
1984
|
};
|
|
1994
1985
|
if (args.slippage != null) body.slippage = String(args.slippage);
|
|
@@ -2002,7 +1993,7 @@ function registerBotTools() {
|
|
|
2002
1993
|
}
|
|
2003
1994
|
},
|
|
2004
1995
|
{
|
|
2005
|
-
name: "
|
|
1996
|
+
name: "pionex_bot_futures_grid_cancel",
|
|
2006
1997
|
module: "bot",
|
|
2007
1998
|
isWrite: true,
|
|
2008
1999
|
description: "Cancel and close a futures grid bot order.",
|
|
@@ -2401,14 +2392,13 @@ async function runPionexCommand(argv) {
|
|
|
2401
2392
|
const buOrderId = typeof flags["bu-order-id"] === "string" ? flags["bu-order-id"] : typeof flags.buOrderId === "string" ? flags.buOrderId : void 0;
|
|
2402
2393
|
const lang = typeof flags.lang === "string" ? flags.lang : void 0;
|
|
2403
2394
|
if (!buOrderId) throw new Error("Missing required flag: --bu-order-id");
|
|
2404
|
-
const out = await runTool("
|
|
2395
|
+
const out = await runTool("pionex_bot_futures_grid_get_order", { buOrderId, lang });
|
|
2405
2396
|
process.stdout.write(JSON.stringify(out.data, null, 2) + "\n");
|
|
2406
2397
|
return;
|
|
2407
2398
|
}
|
|
2408
2399
|
if (command === "create") {
|
|
2409
2400
|
const base = typeof flags.base === "string" ? flags.base : void 0;
|
|
2410
2401
|
const quote = typeof flags.quote === "string" ? flags.quote : void 0;
|
|
2411
|
-
const exchange = typeof flags.exchange === "string" ? flags.exchange : void 0;
|
|
2412
2402
|
const copyFrom = typeof flags["copy-from"] === "string" ? flags["copy-from"] : typeof flags.copyFrom === "string" ? flags.copyFrom : void 0;
|
|
2413
2403
|
const copyType = typeof flags["copy-type"] === "string" ? flags["copy-type"] : typeof flags.copyType === "string" ? flags.copyType : void 0;
|
|
2414
2404
|
const copyBotOrderId = typeof flags["copy-bot-order-id"] === "string" ? flags["copy-bot-order-id"] : typeof flags.copyBotOrderId === "string" ? flags.copyBotOrderId : void 0;
|
|
@@ -2417,33 +2407,33 @@ async function runPionexCommand(argv) {
|
|
|
2417
2407
|
throw new Error("Missing required flags: --base --quote --bu-order-data-json");
|
|
2418
2408
|
}
|
|
2419
2409
|
const buOrderData = parseAndValidateCreateFuturesGridBuOrderData(buOrderDataRaw);
|
|
2420
|
-
const payload = { base, quote,
|
|
2410
|
+
const payload = { base, quote, copyFrom, copyType, copyBotOrderId, buOrderData };
|
|
2421
2411
|
if (dryRun) {
|
|
2422
|
-
const out2 = await runTool("
|
|
2412
|
+
const out2 = await runTool("pionex_bot_futures_grid_create", { ...payload, __dryRun: true });
|
|
2423
2413
|
process.stdout.write(JSON.stringify(out2.data, null, 2) + "\n");
|
|
2424
2414
|
return;
|
|
2425
2415
|
}
|
|
2426
|
-
const out = await runTool("
|
|
2416
|
+
const out = await runTool("pionex_bot_futures_grid_create", payload);
|
|
2427
2417
|
process.stdout.write(JSON.stringify(out.data, null, 2) + "\n");
|
|
2428
2418
|
return;
|
|
2429
2419
|
}
|
|
2430
|
-
if (command === "
|
|
2420
|
+
if (command === "adjust_params") {
|
|
2431
2421
|
const payload = parseJsonFlag(flags["body-json"] ?? flags.bodyJson, "body-json");
|
|
2432
2422
|
if (dryRun) {
|
|
2433
|
-
process.stdout.write(JSON.stringify({ tool: "
|
|
2423
|
+
process.stdout.write(JSON.stringify({ tool: "pionex_bot_futures_grid_adjust_params", args: payload }, null, 2) + "\n");
|
|
2434
2424
|
return;
|
|
2435
2425
|
}
|
|
2436
|
-
const out = await runTool("
|
|
2426
|
+
const out = await runTool("pionex_bot_futures_grid_adjust_params", payload);
|
|
2437
2427
|
process.stdout.write(JSON.stringify(out.data, null, 2) + "\n");
|
|
2438
2428
|
return;
|
|
2439
2429
|
}
|
|
2440
2430
|
if (command === "reduce") {
|
|
2441
2431
|
const payload = parseJsonFlag(flags["body-json"] ?? flags.bodyJson, "body-json");
|
|
2442
2432
|
if (dryRun) {
|
|
2443
|
-
process.stdout.write(JSON.stringify({ tool: "
|
|
2433
|
+
process.stdout.write(JSON.stringify({ tool: "pionex_bot_futures_grid_reduce", args: payload }, null, 2) + "\n");
|
|
2444
2434
|
return;
|
|
2445
2435
|
}
|
|
2446
|
-
const out = await runTool("
|
|
2436
|
+
const out = await runTool("pionex_bot_futures_grid_reduce", payload);
|
|
2447
2437
|
process.stdout.write(JSON.stringify(out.data, null, 2) + "\n");
|
|
2448
2438
|
return;
|
|
2449
2439
|
}
|
|
@@ -2456,10 +2446,10 @@ async function runPionexCommand(argv) {
|
|
|
2456
2446
|
if (!buOrderId) throw new Error("Missing required flag: --bu-order-id");
|
|
2457
2447
|
const payload = { buOrderId, closeNote, closeSellModel, immediate, closeSlippage };
|
|
2458
2448
|
if (dryRun) {
|
|
2459
|
-
process.stdout.write(JSON.stringify({ tool: "
|
|
2449
|
+
process.stdout.write(JSON.stringify({ tool: "pionex_bot_futures_grid_cancel", args: payload }, null, 2) + "\n");
|
|
2460
2450
|
return;
|
|
2461
2451
|
}
|
|
2462
|
-
const out = await runTool("
|
|
2452
|
+
const out = await runTool("pionex_bot_futures_grid_cancel", payload);
|
|
2463
2453
|
process.stdout.write(JSON.stringify(out.data, null, 2) + "\n");
|
|
2464
2454
|
return;
|
|
2465
2455
|
}
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/index.ts","../../core/src/config/toml.ts","../../core/src/setup.ts","../../core/src/constants.ts","../../core/src/utils/errors.ts","../../core/src/config.ts","../../core/src/client/rest-client.ts","../../core/src/tools/market.ts","../../core/src/tools/account.ts","../../core/src/tools/orders.ts","../../core/src/schemas/futures-grid-create.ts","../../core/src/tools/bot.ts","../../core/src/tools/index.ts","../../core/src/tools/types.ts","../../../node_modules/smol-toml/dist/error.js","../../../node_modules/smol-toml/dist/util.js","../../../node_modules/smol-toml/dist/date.js","../../../node_modules/smol-toml/dist/primitive.js","../../../node_modules/smol-toml/dist/extract.js","../../../node_modules/smol-toml/dist/struct.js","../../../node_modules/smol-toml/dist/parse.js","../../../node_modules/smol-toml/dist/stringify.js"],"sourcesContent":["#!/usr/bin/env node\n\nimport { createInterface } from \"node:readline\";\nimport { basename } from \"node:path\";\nimport {\n readFullConfig,\n writeFullConfig,\n configFilePath,\n runSetup,\n SUPPORTED_CLIENTS,\n type PionexTomlConfig,\n type PionexProfile,\n type ClientId,\n loadConfig,\n PionexRestClient,\n createToolRunner,\n toToolErrorPayload,\n parseAndValidateCreateFuturesGridBuOrderData,\n} from \"@pionex-ai/core\";\n\nconst DEFAULT_PROFILE_NAME = \"pionx-prod\";\nconst DEFAULT_BASE_URL = \"https://api.pionex.com\";\n\nfunction ask(rl: ReturnType<typeof createInterface>, question: string, defaultValue = \"\"): Promise<string> {\n const prompt = defaultValue ? `${question} [${defaultValue}]: ` : `${question}: `;\n return new Promise((resolve) => rl.question(prompt, (answer) => resolve((answer ?? \"\").trim() || defaultValue)));\n}\n\nasync function cmdOnboard(): Promise<void> {\n const rl = createInterface({ input: process.stdin, output: process.stdout });\n\n process.stdout.write(\"\\n pionex-ai-kit v0.2.x\\n\");\n process.stdout.write(\" ⚠️ Security Tips: NEVER send API keys in agent chat. Create a dedicated API Key for your agent. Please test thoroughly before connecting to large real-money accounts.\\n\");\n process.stdout.write(\" ⚠️ 安全提示:切勿在 Agent 对话中发送 API Key。请为 Agent 创建专用API Key接入,先用小金额充分验证后再接入实盘。\\n\\n\");\n\n process.stdout.write(\"Pionex CLI — Configuration Wizard\\n\\n\");\n process.stdout.write(\"Go to https://www.pionex.com/zh-CN/my-account/api to create an API Key (trade permission required)\\n\\n\");\n process.stdout.write(\"Credentials will be saved to \" + configFilePath() + \"\\n\\n\");\n\n const apiKey = await ask(rl, \"Pionex API Key\");\n if (!apiKey) {\n process.stderr.write(\" Error: API Key cannot be empty.\\n\");\n rl.close();\n process.exit(1);\n }\n\n const secretKey = await ask(rl, \"Pionex API Secret\");\n if (!secretKey) {\n process.stderr.write(\" Error: API Secret cannot be empty.\\n\");\n rl.close();\n process.exit(1);\n }\n\n rl.close();\n\n let config: PionexTomlConfig = { profiles: {} };\n try {\n config = readFullConfig();\n } catch {\n config = { profiles: {} };\n }\n if (!config.profiles) config.profiles = {};\n\n const profile: PionexProfile = {\n api_key: apiKey,\n secret_key: secretKey,\n base_url: DEFAULT_BASE_URL,\n };\n const profileName = DEFAULT_PROFILE_NAME;\n config.profiles[profileName] = profile;\n config.default_profile = profileName;\n\n try {\n writeFullConfig(config);\n } catch (e) {\n process.stderr.write(\" Failed to write config: \" + (e instanceof Error ? e.message : String(e)) + \"\\n\");\n process.exit(1);\n }\n\n process.stdout.write(\"\\n Config saved to \" + configFilePath() + \"\\n\");\n process.stdout.write(\" Default profile: \" + profileName + \"\\n\");\n process.stdout.write(\" Usage: pionex-ai-kit onboard\\n\");\n process.stdout.write(\n \" Next: run 'pionex-ai-kit setup --mcp=pionex-trade-mcp --client cursor' or \" +\n \"'pionex-trade-mcp setup --client cursor' to register the MCP server.\\n\" +\n \" You can replace 'cursor' with 'claude-desktop', 'windsurf', 'vscode', 'claude-code', 'claude' or 'openclaw' depending on which agent you want to configure.\\n\\n\",\n );\n}\n\nfunction printHelp(): void {\n process.stdout.write(`\nUsage: pionex-ai-kit <command>\n\nCommands:\n onboard Interactive wizard to create ~/.pionex/config.toml (API key, secret)\n help Show this help\n\nThe MCP server (pionex-trade-mcp) reads credentials from ~/.pionex/config.toml.\nUse 'pionex-ai-kit setup --mcp=pionex-trade-mcp --client <client>' to write MCP client config\nthat runs 'npx @pionex/pionex-trade-mcp' (no keys are written to the client config).\n\n`);\n}\n\nfunction parseSetupArgs(argv: string[]): { mcp?: string; client?: string } {\n let mcp: string | undefined;\n let client: string | undefined;\n for (let i = 0; i < argv.length; i++) {\n const arg = argv[i];\n if (arg === \"--mcp\" && argv[i + 1]) {\n mcp = argv[++i];\n } else if (arg.startsWith(\"--mcp=\")) {\n mcp = arg.slice(\"--mcp=\".length);\n } else if (arg === \"--client\" && argv[i + 1]) {\n client = argv[++i];\n } else if (arg.startsWith(\"--client=\")) {\n client = arg.slice(\"--client=\".length);\n }\n }\n return { mcp, client };\n}\n\nfunction cmdSetup(argv: string[]): void {\n const { mcp, client } = parseSetupArgs(argv);\n const targetMcp = mcp ?? \"pionex-trade-mcp\";\n if (targetMcp !== \"pionex-trade-mcp\") {\n process.stderr.write(`Unsupported MCP server: ${targetMcp}. Currently only 'pionex-trade-mcp' is supported.\\n`);\n process.exit(1);\n }\n if (!client) {\n process.stderr.write(\n \"Usage: pionex-ai-kit setup --mcp=pionex-trade-mcp --client <\" +\n SUPPORTED_CLIENTS.join(\"|\") +\n \">\\n\",\n );\n process.exit(1);\n }\n\n // Allow 'claude' as an alias for 'claude-code'\n const normalizedClient = client === \"claude\" ? \"claude-code\" : client;\n\n if (!SUPPORTED_CLIENTS.includes(normalizedClient as ClientId)) {\n process.stderr.write(\n `Unsupported client: ${client}. Supported: ${[...SUPPORTED_CLIENTS, \"claude (alias for claude-code)\"].join(\n \", \",\n )}\\n`,\n );\n process.exit(1);\n }\n\n runSetup({ client: normalizedClient as ClientId });\n}\n\ntype FlagValue = string | boolean;\n\nfunction parseFlags(argv: string[]): { positionals: string[]; flags: Record<string, FlagValue> } {\n const positionals: string[] = [];\n const flags: Record<string, FlagValue> = {};\n\n for (let i = 0; i < argv.length; i++) {\n const a = argv[i];\n if (!a.startsWith(\"--\")) {\n positionals.push(a);\n continue;\n }\n const eq = a.indexOf(\"=\");\n if (eq !== -1) {\n const k = a.slice(2, eq);\n const v = a.slice(eq + 1);\n flags[k] = v === \"true\" ? true : v === \"false\" ? false : v;\n continue;\n }\n const k = a.slice(2);\n const next = argv[i + 1];\n if (!next || next.startsWith(\"--\")) {\n flags[k] = true;\n continue;\n }\n flags[k] = next;\n i++;\n }\n\n return { positionals, flags };\n}\n\nfunction printPionexHelp(): void {\n process.stdout.write(`\nUsage: pionex <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 --quote USDT --bu-order-data-json '{\"top\":\"110000\",\"bottom\":\"90000\",\"row\":100,\"grid_type\":\"arithmetic\",\"trend\":\"long\",\"leverage\":5,\"quoteInvestment\":\"100\"}'\n\nGlobal flags:\n --profile <name> Profile in ~/.pionex/config.toml\n --modules <list> Comma-separated modules (market,account,orders or all)\n --base-url <url> Override API base URL\n --read-only Disable write operations (orders new/cancel)\n --dry-run Print resolved futures-grid create body without executing (bot create only)\n\nFutures grid create (pionex bot create) — strict OpenAPI (same validation as MCP):\n --base Required; normalized to <BASE>.PERP if suffix missing\n --quote Required (e.g. USDT)\n --bu-order-data-json Required JSON object — ONLY keys from CreateFuturesGridOrderData in openapi_bot.yaml\n Optional: --copy-from, --copy-type, --copy-bot-order-id\n buOrderData required: top, bottom, row, grid_type, trend, leverage, quoteInvestment\n buOrderData optional (names only): extraMargin, condition, conditionDirection, lossStopType, lossStop,\n lossStopDelay, profitStopType, profitStop, profitStopDelay, lossStopHigh, shareRatio, investCoin,\n investmentFrom, uiInvestCoin, lossStopLimitPrice, lossStopLimitHighPrice, profitStopLimitPrice,\n slippage, bonusId, uiExtraData, movingIndicatorType, movingIndicatorInterval, movingIndicatorParam,\n movingTrailingUpParam, cateType, movingTop, movingBottom, enableFollowClosed\n Unknown keys → error\n YAML: https://github.com/pionex-official/pionex-open-api/blob/main/openapi_bot.yaml\n Docs: https://www.pionex.com/docs/api-docs/bot-api/futures-grid\n`);\n}\n\nfunction parseJsonFlag(raw: unknown, flagName: string): Record<string, unknown> {\n if (typeof raw !== \"string\") {\n throw new Error(`Missing required flag: --${flagName}`);\n }\n try {\n const parsed = JSON.parse(raw) as unknown;\n if (!parsed || typeof parsed !== \"object\" || Array.isArray(parsed)) {\n throw new Error(\"must be a JSON object\");\n }\n return parsed as Record<string, unknown>;\n } catch (e) {\n const msg = e instanceof Error ? e.message : String(e);\n throw new Error(`Invalid --${flagName}: ${msg}`);\n }\n}\n\nasync function runPionexCommand(argv: string[]): Promise<void> {\n const { positionals, flags } = parseFlags(argv);\n const group = positionals[0];\n 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 base = typeof flags.base === \"string\" ? flags.base : undefined;\n const quote = typeof flags.quote === \"string\" ? flags.quote : undefined;\n const exchange = typeof flags.exchange === \"string\" ? flags.exchange : undefined;\n const copyFrom = typeof flags[\"copy-from\"] === \"string\" ? (flags[\"copy-from\"] as string) : typeof flags.copyFrom === \"string\" ? (flags.copyFrom as string) : undefined;\n const copyType = typeof flags[\"copy-type\"] === \"string\" ? (flags[\"copy-type\"] as string) : typeof flags.copyType === \"string\" ? (flags.copyType as string) : undefined;\n const copyBotOrderId =\n typeof flags[\"copy-bot-order-id\"] === \"string\"\n ? (flags[\"copy-bot-order-id\"] as string)\n : typeof flags.copyBotOrderId === \"string\"\n ? (flags.copyBotOrderId as string)\n : undefined;\n const buOrderDataRaw = parseJsonFlag(flags[\"bu-order-data-json\"] ?? flags.buOrderDataJson, \"bu-order-data-json\");\n if (!base || !quote) {\n throw new Error(\"Missing required flags: --base --quote --bu-order-data-json\");\n }\n const buOrderData = parseAndValidateCreateFuturesGridBuOrderData(buOrderDataRaw);\n const payload: Record<string, unknown> = { base, quote, exchange, copyFrom, copyType, copyBotOrderId, buOrderData };\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\";\nimport type { QueryParams } from \"../client/types.js\";\n\nexport function registerMarketTools(): ToolSpec[] {\n return [\n {\n name: \"pionex_market_get_depth\",\n module: \"market\",\n isWrite: false,\n description: \"Get order book depth (bids and asks) for a symbol. Use for spread, liquidity, or best bid/ask.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n limit: { type: \"integer\", description: \"Price levels (1-100), default 5\" },\n },\n required: [\"symbol\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const limit = args.limit == null ? undefined : Number(args.limit);\n const q: QueryParams = { symbol };\n if (limit != null && Number.isFinite(limit)) q.limit = limit;\n return (await client.publicGet(\"/api/v1/market/depth\", q)).data;\n },\n },\n {\n name: \"pionex_market_get_trades\",\n module: \"market\",\n isWrite: false,\n description: \"Get recent trades for a symbol. Use for latest price and volume.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n limit: { type: \"integer\", description: \"Default 5 (1-100)\" },\n },\n required: [\"symbol\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const limit = args.limit == null ? undefined : Number(args.limit);\n const q: QueryParams = { symbol };\n if (limit != null && Number.isFinite(limit)) q.limit = limit;\n return (await client.publicGet(\"/api/v1/market/trades\", q)).data;\n },\n },\n {\n name: \"pionex_market_get_symbol_info\",\n module: \"market\",\n isWrite: false,\n description:\n \"Get symbol metadata (precision, min size, price limits). Call before placing orders to avoid amount/size filter errors.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbols: {\n type: \"string\",\n description: 'Optional. One or more symbols, comma-separated, e.g. \"BTC_USDT\" or \"BTC_USDT,ADA_USDT\".',\n },\n type: {\n type: \"string\",\n enum: [\"SPOT\", \"PERP\"],\n description: \"Optional. If no symbols are specified, filter by type (default SPOT).\",\n },\n },\n },\n async handler(args, { client }) {\n const q: QueryParams = {};\n if (args.symbols) q.symbols = String(args.symbols);\n if (!args.symbols && args.type) q.type = String(args.type);\n return (await client.publicGet(\"/api/v1/common/symbols\", q)).data;\n },\n },\n {\n name: \"pionex_market_get_tickers\",\n module: \"market\",\n isWrite: false,\n description: \"Get 24-hour ticker(s): open, close, high, low, volume, amount, count. Optional symbol or type (SPOT/PERP).\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT; if omitted, returns all tickers filtered by type\" },\n type: { type: \"string\", enum: [\"SPOT\", \"PERP\"], description: \"If symbol is not specified, filter by type.\" },\n },\n },\n async handler(args, { client }) {\n const q: QueryParams = {};\n if (args.symbol) q.symbol = String(args.symbol);\n if (args.type) q.type = String(args.type);\n return (await client.publicGet(\"/api/v1/market/tickers\", q)).data;\n },\n },\n {\n name: \"pionex_market_get_klines\",\n module: \"market\",\n isWrite: false,\n description: \"Get OHLCV klines (candlestick) for a symbol. Use for charts or historical price/volume.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n interval: { type: \"string\", enum: [\"1M\", \"5M\", \"15M\", \"30M\", \"60M\", \"4H\", \"8H\", \"12H\", \"1D\"], description: \"Kline interval.\" },\n endTime: { type: \"integer\", description: \"End time in milliseconds.\" },\n limit: { type: \"integer\", description: \"Default 100 (1-500).\" },\n },\n required: [\"symbol\", \"interval\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const interval = String(args.interval);\n const q: QueryParams = { symbol, interval };\n if (args.endTime != null) q.endTime = Number(args.endTime);\n if (args.limit != null) q.limit = Number(args.limit);\n return (await client.publicGet(\"/api/v1/market/klines\", q)).data;\n },\n },\n ];\n}\n\n","import type { ToolSpec } from \"./types.js\";\n\nexport function registerAccountTools(): ToolSpec[] {\n return [\n {\n name: \"pionex_account_get_balance\",\n module: \"account\",\n isWrite: false,\n description: \"Query spot account balances for all currencies. Requires API key and secret in ~/.pionex/config.toml or env.\",\n inputSchema: { type: \"object\", additionalProperties: false, properties: {} },\n async handler(_args, { client }) {\n return (await client.signedGet(\"/api/v1/account/balances\")).data;\n },\n },\n ];\n}\n\n","import type { ToolSpec } from \"./types.js\";\nimport type { QueryParams } from \"../client/types.js\";\n\nexport function registerOrdersTools(): ToolSpec[] {\n return [\n {\n name: \"pionex_orders_new_order\",\n module: \"orders\",\n isWrite: true,\n description:\n \"Create a spot order on Pionex. LIMIT requires symbol/side/type=LIMIT/price/size. MARKET BUY requires amount (quote). MARKET SELL requires size (base).\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n side: { type: \"string\", enum: [\"BUY\", \"SELL\"] },\n type: { type: \"string\", enum: [\"LIMIT\", \"MARKET\"] },\n clientOrderId: { type: \"string\", description: \"Optional client order id (max 64 chars)\" },\n size: { type: \"string\", description: \"Quantity; required for limit and market sell\" },\n price: { type: \"string\", description: \"Required for limit order\" },\n amount: { type: \"string\", description: \"Quote amount; required for market buy\" },\n IOC: { type: \"boolean\", description: \"Immediate-or-cancel, default false\" },\n },\n required: [\"symbol\", \"side\", \"type\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; order placement is disabled.\");\n }\n const body: Record<string, unknown> = {};\n if (args.symbol != null) body.symbol = String(args.symbol);\n if (args.side != null) body.side = String(args.side);\n if (args.type != null) body.type = String(args.type);\n if (args.clientOrderId != null) body.clientOrderId = String(args.clientOrderId);\n if (args.size != null) body.size = String(args.size);\n if (args.price != null) body.price = String(args.price);\n if (args.amount != null) body.amount = String(args.amount);\n if (args.IOC != null) body.IOC = Boolean(args.IOC);\n return (await client.signedPost(\"/api/v1/trade/order\", body)).data;\n },\n },\n {\n name: \"pionex_orders_get_order\",\n module: \"orders\",\n isWrite: false,\n description: \"Get a single order by order ID.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n orderId: { type: \"integer\", description: \"Order id\" },\n },\n required: [\"symbol\", \"orderId\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const orderId = Number(args.orderId);\n return (await client.signedGet(\"/api/v1/trade/order\", { symbol, orderId })).data;\n },\n },\n {\n name: \"pionex_orders_get_order_by_client_order_id\",\n module: \"orders\",\n isWrite: false,\n description: \"Get a single order by client order ID.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n clientOrderId: { type: \"string\", description: \"Client order id\" },\n },\n required: [\"symbol\", \"clientOrderId\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const clientOrderId = String(args.clientOrderId);\n return (await client.signedGet(\"/api/v1/trade/orderByClientOrderId\", { symbol, clientOrderId })).data;\n },\n },\n {\n name: \"pionex_orders_get_open_orders\",\n module: \"orders\",\n isWrite: false,\n description: \"List open (unfilled) orders for a symbol.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: { symbol: { type: \"string\", description: \"e.g. BTC_USDT\" } },\n required: [\"symbol\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n return (await client.signedGet(\"/api/v1/trade/openOrders\", { symbol })).data;\n },\n },\n {\n name: \"pionex_orders_get_all_orders\",\n module: \"orders\",\n isWrite: false,\n description: \"List order history for a symbol (filled and cancelled), with optional limit.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n limit: { type: \"integer\", description: \"Default 1 (1-100)\" },\n },\n required: [\"symbol\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const q: QueryParams = { symbol };\n if (args.limit != null) q.limit = Number(args.limit);\n return (await client.signedGet(\"/api/v1/trade/allOrders\", q)).data;\n },\n },\n {\n name: \"pionex_orders_cancel_order\",\n module: \"orders\",\n isWrite: true,\n description: \"Cancel an open order by order ID.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n orderId: { type: \"integer\", description: \"Order id\" },\n },\n required: [\"symbol\", \"orderId\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; order cancellation is disabled.\");\n }\n const symbol = String(args.symbol);\n const orderId = Number(args.orderId);\n return (await client.signedDelete(\"/api/v1/trade/order\", { symbol, orderId })).data;\n },\n },\n {\n name: \"pionex_orders_get_fills\",\n module: \"orders\",\n isWrite: false,\n description: \"Get filled trades (fills) for a symbol in a time range. Requires API key. Returns up to 100 latest fills.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n startTime: { type: \"integer\", description: \"Start time in milliseconds.\" },\n endTime: { type: \"integer\", description: \"End time in milliseconds.\" },\n },\n required: [\"symbol\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const q: QueryParams = { symbol };\n if (args.startTime != null) q.startTime = Number(args.startTime);\n if (args.endTime != null) q.endTime = Number(args.endTime);\n return (await client.signedGet(\"/api/v1/trade/fills\", q)).data;\n },\n },\n {\n name: \"pionex_orders_cancel_all_orders\",\n module: \"orders\",\n isWrite: true,\n description: \"Cancel all open orders for a symbol.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: { symbol: { type: \"string\", description: \"e.g. BTC_USDT\" } },\n required: [\"symbol\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; cancel-all is disabled.\");\n }\n const symbol = String(args.symbol);\n return (await client.signedDelete(\"/api/v1/trade/allOrders\", { symbol })).data;\n },\n },\n ];\n}\n\n","/**\n * Mirrors openapi_bot.yaml — CreateFuturesGridRequest + CreateFuturesGridOrderData.\n * https://github.com/pionex-official/pionex-open-api/blob/main/openapi_bot.yaml\n */\nimport type { JsonSchema } from \"../tools/types.js\";\n\n/** Every property under CreateFuturesGridOrderData (OpenAPI); no other keys allowed. */\nexport const CREATE_FUTURES_GRID_ORDER_DATA_KEYS = [\n \"top\",\n \"bottom\",\n \"row\",\n \"grid_type\",\n \"trend\",\n \"leverage\",\n \"extraMargin\",\n \"quoteInvestment\",\n \"condition\",\n \"conditionDirection\",\n \"lossStopType\",\n \"lossStop\",\n \"lossStopDelay\",\n \"profitStopType\",\n \"profitStop\",\n \"profitStopDelay\",\n \"lossStopHigh\",\n \"shareRatio\",\n \"investCoin\",\n \"investmentFrom\",\n \"uiInvestCoin\",\n \"lossStopLimitPrice\",\n \"lossStopLimitHighPrice\",\n \"profitStopLimitPrice\",\n \"slippage\",\n \"bonusId\",\n \"uiExtraData\",\n \"movingIndicatorType\",\n \"movingIndicatorInterval\",\n \"movingIndicatorParam\",\n \"movingTrailingUpParam\",\n \"cateType\",\n \"movingTop\",\n \"movingBottom\",\n \"enableFollowClosed\",\n] as const;\n\nconst ORDER_DATA_KEY_SET = new Set<string>(CREATE_FUTURES_GRID_ORDER_DATA_KEYS);\n\nfunction asNonEmptyString(value: unknown, field: string): string {\n if (typeof value !== \"string\" || value.trim().length === 0) {\n throw new Error(`Invalid \"${field}\": expected non-empty string.`);\n }\n return value.trim();\n}\n\nfunction asFiniteNumber(value: unknown, field: string): number {\n if (typeof value !== \"number\" || !Number.isFinite(value)) {\n throw new Error(`Invalid \"${field}\": expected finite number.`);\n }\n return value;\n}\n\nfunction asPositiveNumber(value: unknown, field: string): number {\n const n = asFiniteNumber(value, field);\n if (n <= 0) throw new Error(`Invalid \"${field}\": expected number > 0.`);\n return n;\n}\n\nfunction asPositiveInteger(value: unknown, field: string): number {\n const n = asPositiveNumber(value, field);\n if (!Number.isInteger(n)) {\n throw new Error(`Invalid \"${field}\": expected positive integer.`);\n }\n return n;\n}\n\nfunction asBoolean(value: unknown, field: string): boolean {\n if (typeof value !== \"boolean\") {\n throw new Error(`Invalid \"${field}\": expected boolean.`);\n }\n return value;\n}\n\nfunction assertEnum(value: string, field: string, allowed: readonly string[]): void {\n if (!allowed.includes(value)) {\n throw new Error(`Invalid \"${field}\": expected one of ${allowed.join(\", \")}.`);\n }\n}\n\nfunction asPositiveDecimalString(value: unknown, field: string): string {\n const s = asNonEmptyString(value, field);\n if (!/^\\d+(\\.\\d+)?$/.test(s)) {\n throw new Error(`Invalid \"${field}\": expected positive decimal string.`);\n }\n const n = Number(s);\n if (!Number.isFinite(n) || n <= 0) {\n throw new Error(`Invalid \"${field}\": expected positive decimal string.`);\n }\n return s;\n}\n\nfunction asPositiveDecimalStringLoose(value: unknown, field: string): string {\n if (typeof value === \"number\" && Number.isFinite(value) && value > 0) {\n return String(value);\n }\n return asPositiveDecimalString(value, field);\n}\n\nfunction asNonNegativeDecimalString(value: unknown, field: string): string {\n const s = asNonEmptyString(value, field);\n if (!/^\\d+(\\.\\d+)?$/.test(s)) {\n throw new Error(`Invalid \"${field}\": expected non-negative decimal string.`);\n }\n const n = Number(s);\n if (!Number.isFinite(n) || n < 0) {\n throw new Error(`Invalid \"${field}\": expected non-negative decimal string.`);\n }\n return s;\n}\n\nfunction asOptionalString(value: unknown, field: string): string {\n if (typeof value !== \"string\") {\n throw new Error(`Invalid \"${field}\": expected string.`);\n }\n return value;\n}\n\nfunction asOptionalNonNegativeNumber(value: unknown, field: string): number {\n const n = asFiniteNumber(value, field);\n if (n < 0) throw new Error(`Invalid \"${field}\": expected number >= 0.`);\n return n;\n}\n\n/** Strip + reject unknown keys; validate types per OpenAPI. Returns body-ready buOrderData. */\nexport function parseAndValidateCreateFuturesGridBuOrderData(raw: Record<string, unknown>): Record<string, unknown> {\n const data = { ...raw };\n delete data.openPrice;\n delete data.keyId;\n delete data.key_id;\n\n for (const k of Object.keys(data)) {\n if (!ORDER_DATA_KEY_SET.has(k)) {\n throw new Error(`Unknown buOrderData property \"${k}\". Allowed keys: ${CREATE_FUTURES_GRID_ORDER_DATA_KEYS.join(\", \")}.`);\n }\n }\n\n const top = asPositiveDecimalStringLoose(data.top, \"buOrderData.top\");\n const bottom = asPositiveDecimalStringLoose(data.bottom, \"buOrderData.bottom\");\n if (Number(top) <= Number(bottom)) {\n throw new Error('Invalid \"buOrderData.top\": expected top > bottom.');\n }\n const row = asPositiveInteger(data.row, \"buOrderData.row\");\n const gridType = asNonEmptyString(data.grid_type, \"buOrderData.grid_type\");\n assertEnum(gridType, \"buOrderData.grid_type\", [\"arithmetic\", \"geometric\"]);\n const trend = asNonEmptyString(data.trend, \"buOrderData.trend\");\n assertEnum(trend, \"buOrderData.trend\", [\"long\", \"short\", \"no_trend\"]);\n const leverage = asPositiveNumber(data.leverage, \"buOrderData.leverage\");\n const quoteInvestment = asPositiveDecimalStringLoose(data.quoteInvestment, \"buOrderData.quoteInvestment\");\n\n const out: Record<string, unknown> = {\n top,\n bottom,\n row,\n grid_type: gridType,\n trend,\n leverage,\n quoteInvestment,\n };\n\n if (data.extraMargin != null) {\n out.extraMargin = asNonNegativeDecimalString(data.extraMargin, \"buOrderData.extraMargin\");\n }\n if (data.condition != null) out.condition = asOptionalString(data.condition, \"buOrderData.condition\");\n if (data.conditionDirection != null) {\n const v = asNonEmptyString(data.conditionDirection, \"buOrderData.conditionDirection\");\n assertEnum(v, \"buOrderData.conditionDirection\", [\"-1\", \"1\"]);\n out.conditionDirection = v;\n }\n if (data.lossStopType != null) {\n const v = asNonEmptyString(data.lossStopType, \"buOrderData.lossStopType\");\n assertEnum(v, \"buOrderData.lossStopType\", [\"price\", \"profit_amount\", \"profit_ratio\", \"price_limit\"]);\n out.lossStopType = v;\n }\n if (data.lossStop != null) out.lossStop = asOptionalString(data.lossStop, \"buOrderData.lossStop\");\n if (data.lossStopDelay != null) out.lossStopDelay = asOptionalNonNegativeNumber(data.lossStopDelay, \"buOrderData.lossStopDelay\");\n if (data.profitStopType != null) {\n const v = asNonEmptyString(data.profitStopType, \"buOrderData.profitStopType\");\n assertEnum(v, \"buOrderData.profitStopType\", [\"price\", \"profit_amount\", \"profit_ratio\", \"price_limit\"]);\n out.profitStopType = v;\n }\n if (data.profitStop != null) out.profitStop = asOptionalString(data.profitStop, \"buOrderData.profitStop\");\n if (data.profitStopDelay != null) out.profitStopDelay = asOptionalNonNegativeNumber(data.profitStopDelay, \"buOrderData.profitStopDelay\");\n if (data.lossStopHigh != null) out.lossStopHigh = asOptionalString(data.lossStopHigh, \"buOrderData.lossStopHigh\");\n if (data.shareRatio != null) out.shareRatio = asOptionalString(data.shareRatio, \"buOrderData.shareRatio\");\n if (data.investCoin != null) out.investCoin = asOptionalString(data.investCoin, \"buOrderData.investCoin\");\n if (data.investmentFrom != null) {\n const v = asNonEmptyString(data.investmentFrom, \"buOrderData.investmentFrom\");\n assertEnum(v, \"buOrderData.investmentFrom\", [\"USER\", \"LOCK_ACTIVITY\", \"FUTURE_GRID_BONUS\"]);\n out.investmentFrom = v;\n }\n if (data.uiInvestCoin != null) out.uiInvestCoin = asOptionalString(data.uiInvestCoin, \"buOrderData.uiInvestCoin\");\n if (data.lossStopLimitPrice != null) out.lossStopLimitPrice = asOptionalString(data.lossStopLimitPrice, \"buOrderData.lossStopLimitPrice\");\n if (data.lossStopLimitHighPrice != null) out.lossStopLimitHighPrice = asOptionalString(data.lossStopLimitHighPrice, \"buOrderData.lossStopLimitHighPrice\");\n if (data.profitStopLimitPrice != null) out.profitStopLimitPrice = asOptionalString(data.profitStopLimitPrice, \"buOrderData.profitStopLimitPrice\");\n if (data.slippage != null) out.slippage = asOptionalString(data.slippage, \"buOrderData.slippage\");\n if (data.bonusId != null) out.bonusId = asOptionalString(data.bonusId, \"buOrderData.bonusId\");\n if (data.uiExtraData != null) out.uiExtraData = asOptionalString(data.uiExtraData, \"buOrderData.uiExtraData\");\n if (data.movingIndicatorType != null) out.movingIndicatorType = asOptionalString(data.movingIndicatorType, \"buOrderData.movingIndicatorType\");\n if (data.movingIndicatorInterval != null) out.movingIndicatorInterval = asOptionalString(data.movingIndicatorInterval, \"buOrderData.movingIndicatorInterval\");\n if (data.movingIndicatorParam != null) out.movingIndicatorParam = asOptionalString(data.movingIndicatorParam, \"buOrderData.movingIndicatorParam\");\n if (data.movingTrailingUpParam != null) out.movingTrailingUpParam = asOptionalString(data.movingTrailingUpParam, \"buOrderData.movingTrailingUpParam\");\n if (data.cateType != null) {\n const v = asNonEmptyString(data.cateType, \"buOrderData.cateType\");\n assertEnum(v, \"buOrderData.cateType\", [\"FULLY_HEDGING\", \"LOAN_GRID\", \"LEVERAGE_GRID\", \"FUTURE_GRID_COIN_MARGINED\"]);\n out.cateType = v;\n }\n if (data.movingTop != null) out.movingTop = asOptionalString(data.movingTop, \"buOrderData.movingTop\");\n if (data.movingBottom != null) out.movingBottom = asOptionalString(data.movingBottom, \"buOrderData.movingBottom\");\n if (data.enableFollowClosed != null) out.enableFollowClosed = asBoolean(data.enableFollowClosed, \"buOrderData.enableFollowClosed\");\n\n return out;\n}\n\n/** JSON Schema for MCP tool `buOrderData` — matches openapi_bot.yaml CreateFuturesGridOrderData.properties */\nexport const createFuturesGridOrderDataJsonSchema: JsonSchema = {\n type: \"object\",\n additionalProperties: false,\n description: \"CreateFuturesGridOrderData (openapi_bot.yaml). Required: top, bottom, row, grid_type, trend, leverage, quoteInvestment.\",\n required: [\"top\", \"bottom\", \"row\", \"grid_type\", \"trend\", \"leverage\", \"quoteInvestment\"],\n properties: {\n top: { type: \"string\", description: \"Grid upper price\" },\n bottom: { type: \"string\", description: \"Grid lower price\" },\n row: { type: \"number\", description: \"Number of grid levels\" },\n grid_type: {\n type: \"string\",\n enum: [\"arithmetic\", \"geometric\"],\n description: \"Grid spacing: arithmetic (equal difference) or geometric (equal ratio)\",\n },\n trend: {\n type: \"string\",\n enum: [\"long\", \"short\", \"no_trend\"],\n description: \"Grid direction\",\n },\n leverage: { type: \"number\", description: \"Leverage multiplier\" },\n extraMargin: { type: \"string\", description: \"Extra margin amount (optional)\" },\n quoteInvestment: { type: \"string\", description: \"Investment amount\" },\n condition: { type: \"string\", description: \"Trigger price (conditional orders)\" },\n conditionDirection: { type: \"string\", enum: [\"-1\", \"1\"], description: \"Trigger direction\" },\n lossStopType: {\n type: \"string\",\n enum: [\"price\", \"profit_amount\", \"profit_ratio\", \"price_limit\"],\n description: \"Stop loss type\",\n },\n lossStop: { type: \"string\", description: \"Stop loss value\" },\n lossStopDelay: { type: \"number\", description: \"Stop loss delay (seconds)\" },\n profitStopType: {\n type: \"string\",\n enum: [\"price\", \"profit_amount\", \"profit_ratio\", \"price_limit\"],\n description: \"Take profit type\",\n },\n profitStop: { type: \"string\", description: \"Take profit value\" },\n profitStopDelay: { type: \"number\", description: \"Take profit delay (seconds)\" },\n lossStopHigh: { type: \"string\", description: \"Upper stop loss price for neutral grid\" },\n shareRatio: { type: \"string\", description: \"Profit sharing ratio\" },\n investCoin: { type: \"string\", description: \"Investment currency\" },\n investmentFrom: {\n type: \"string\",\n enum: [\"USER\", \"LOCK_ACTIVITY\", \"FUTURE_GRID_BONUS\"],\n description: \"Funding source\",\n },\n uiInvestCoin: { type: \"string\", description: \"Frontend-recorded investment currency\" },\n lossStopLimitPrice: { type: \"string\", description: \"Limit SL price (lossStopType=price_limit)\" },\n lossStopLimitHighPrice: { type: \"string\", description: \"Upper limit SL for neutral grid\" },\n profitStopLimitPrice: { type: \"string\", description: \"Limit TP price (profitStopType=price_limit)\" },\n slippage: { type: \"string\", description: \"Open slippage e.g. 0.01 = 1%\" },\n bonusId: { type: \"string\", description: \"Bonus UUID\" },\n uiExtraData: { type: \"string\", description: \"Frontend extra (coin-margined)\" },\n movingIndicatorType: { type: \"string\", description: \"e.g. sma\" },\n movingIndicatorInterval: { type: \"string\", description: \"e.g. 1m, 15m\" },\n movingIndicatorParam: { type: \"string\", description: \"JSON params e.g. length\" },\n movingTrailingUpParam: { type: \"string\", description: \"SMA trailing up ratio\" },\n cateType: {\n type: \"string\",\n enum: [\"FULLY_HEDGING\", \"LOAN_GRID\", \"LEVERAGE_GRID\", \"FUTURE_GRID_COIN_MARGINED\"],\n description: \"Category type\",\n },\n movingTop: { type: \"string\", description: \"Moving grid upper limit\" },\n movingBottom: { type: \"string\", description: \"Moving grid lower limit\" },\n enableFollowClosed: { type: \"boolean\", description: \"Follow close\" },\n },\n};\n\n/** Full MCP input schema for pionex_bot_create_futures_grid_order (includes internal __dryRun for CLI). */\nexport const createFuturesGridCreateToolInputSchema: JsonSchema = {\n type: \"object\",\n additionalProperties: false,\n required: [\"base\", \"quote\", \"buOrderData\"],\n properties: {\n base: { type: \"string\", description: \"Base currency (e.g. BTC); *.PERP normalized in handler\" },\n quote: { type: \"string\", description: \"Quote currency (e.g. USDT)\" },\n exchange: { type: \"string\", description: \"Optional. Futures exchange identifier (temporary compatibility).\" },\n copyFrom: { type: \"string\", description: \"Optional. Copy source order ID\" },\n copyType: { type: \"string\", description: \"Optional. Copy type\" },\n copyBotOrderId: { type: \"string\", description: \"Optional. Copy bot order ID\" },\n buOrderData: createFuturesGridOrderDataJsonSchema,\n __dryRun: { type: \"boolean\", description: \"Internal: when true, return resolved body without POST\" },\n },\n};\n","import type { ToolSpec } from \"./types.js\";\nimport {\n createFuturesGridCreateToolInputSchema,\n parseAndValidateCreateFuturesGridBuOrderData,\n} from \"../schemas/futures-grid-create.js\";\nimport type { QueryParams } from \"../client/types.js\";\n\nfunction asNonEmptyString(value: unknown, field: string): string {\n if (typeof value !== \"string\" || value.trim().length === 0) {\n throw new Error(`Invalid \"${field}\": expected non-empty string.`);\n }\n return value.trim();\n}\n\nfunction asFiniteNumber(value: unknown, field: string): number {\n if (typeof value !== \"number\" || !Number.isFinite(value)) {\n throw new Error(`Invalid \"${field}\": expected finite number.`);\n }\n return value;\n}\n\nfunction asPositiveNumber(value: unknown, field: string): number {\n const n = asFiniteNumber(value, field);\n if (n <= 0) throw new Error(`Invalid \"${field}\": expected number > 0.`);\n return n;\n}\n\nfunction asPositiveInteger(value: unknown, field: string): number {\n const n = asPositiveNumber(value, field);\n if (!Number.isInteger(n)) {\n throw new Error(`Invalid \"${field}\": expected positive integer.`);\n }\n return n;\n}\n\nfunction asBoolean(value: unknown, field: string): boolean {\n if (typeof value !== \"boolean\") {\n throw new Error(`Invalid \"${field}\": expected boolean.`);\n }\n return value;\n}\n\nfunction assertEnum(value: string, field: string, allowed: readonly string[]): void {\n if (!allowed.includes(value)) {\n throw new Error(`Invalid \"${field}\": expected one of ${allowed.join(\", \")}.`);\n }\n}\n\nfunction asObject(value: unknown, field: string): Record<string, unknown> {\n if (!value || typeof value !== \"object\" || Array.isArray(value)) {\n throw new Error(`Invalid \"${field}\": expected JSON object.`);\n }\n return value as Record<string, unknown>;\n}\n\nfunction asPositiveDecimalString(value: unknown, field: string): string {\n const s = asNonEmptyString(value, field);\n if (!/^\\d+(\\.\\d+)?$/.test(s)) {\n throw new Error(`Invalid \"${field}\": expected positive decimal string.`);\n }\n const n = Number(s);\n if (!Number.isFinite(n) || n <= 0) {\n throw new Error(`Invalid \"${field}\": expected positive decimal string.`);\n }\n return s;\n}\n\nfunction normalizePerpBase(base: string): string {\n return base.endsWith(\".PERP\") ? base : `${base}.PERP`;\n}\n\nexport function registerBotTools(): ToolSpec[] {\n return [\n {\n name: \"pionex_bot_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: QueryParams = { buOrderId };\n if (args.lang != null) q.lang = String(args.lang);\n return (await client.signedGet(\"/api/v1/bot/orders/futuresGrid/order\", q)).data;\n },\n },\n {\n name: \"pionex_bot_create_futures_grid_order\",\n module: \"bot\",\n isWrite: true,\n description:\n \"Create a futures grid order (openapi_bot.yaml CreateFuturesGridRequest / CreateFuturesGridOrderData). \" +\n \"https://github.com/pionex-official/pionex-open-api/blob/main/openapi_bot.yaml — \" +\n \"Required: base, quote, buOrderData. Optional: copyFrom, copyType, copyBotOrderId. \" +\n \"buOrderData required: top, bottom, row, grid_type, trend, leverage, quoteInvestment; unknown keys rejected.\",\n inputSchema: createFuturesGridCreateToolInputSchema,\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; bot create is disabled.\");\n }\n const rawBase = asNonEmptyString(args.base, \"base\");\n const base = normalizePerpBase(rawBase);\n const quote = asNonEmptyString(args.quote, \"quote\");\n const exchange = args.exchange != null ? asNonEmptyString(args.exchange, \"exchange\") : undefined;\n const buOrderDataOut = parseAndValidateCreateFuturesGridBuOrderData(asObject(args.buOrderData, \"buOrderData\"));\n const row = buOrderDataOut.row as number;\n const gridType = buOrderDataOut.grid_type as string;\n const leverage = buOrderDataOut.leverage as number;\n\n const body: Record<string, unknown> = {\n base,\n quote,\n buOrderData: buOrderDataOut,\n };\n if (exchange != null) body.exchange = exchange;\n if (args.copyFrom != null) body.copyFrom = String(args.copyFrom);\n if (args.copyType != null) body.copyType = String(args.copyType);\n if (args.copyBotOrderId != null) body.copyBotOrderId = String(args.copyBotOrderId);\n\n if (args.__dryRun === true) {\n return {\n dryRun: true,\n note: \"No order was sent. Body matches openapi_bot.yaml CreateFuturesGridRequest.\",\n resolvedParams: {\n row,\n grid_type: gridType,\n leverage,\n },\n resolvedBody: body,\n };\n }\n return (await client.signedPost(\"/api/v1/bot/orders/futuresGrid/create\", body)).data;\n },\n },\n {\n name: \"pionex_bot_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":";;;AAEA,SAAS,uBAAuB;AAChC,SAAS,gBAAgB;;;ACHzB,SAAS,cAAc,eAAe,WAAW,kBAAkB;AACnE,SAAS,MAAM,eAAe;AAC9B,SAAS,eAAe;;;AayBxB,SAAS,kBAAkB,QAAQ,KAAK;AACpC,MAAI,QAAQ,OAAO,MAAM,GAAG,GAAG,EAAE,MAAM,aAAa;AACpD,SAAO,CAAC,MAAM,QAAQ,MAAM,IAAI,EAAE,SAAS,CAAC;AAChD;AACA,SAAS,cAAc,QAAQ,MAAM,QAAQ;AACzC,MAAI,QAAQ,OAAO,MAAM,aAAa;AACtC,MAAI,YAAY;AAChB,MAAI,aAAa,KAAK,MAAM,OAAO,CAAC,IAAI,KAAK;AAC7C,WAAS,IAAI,OAAO,GAAG,KAAK,OAAO,GAAG,KAAK;AACvC,QAAI,IAAI,MAAM,IAAI,CAAC;AACnB,QAAI,CAAC;AACD;AACJ,iBAAa,EAAE,SAAS,EAAE,OAAO,WAAW,GAAG;AAC/C,iBAAa;AACb,iBAAa;AACb,iBAAa;AACb,QAAI,MAAM,MAAM;AACZ,mBAAa,IAAI,OAAO,YAAY,SAAS,CAAC;AAC9C,mBAAa;AAAA,IACjB;AAAA,EACJ;AACA,SAAO;AACX;AACO,IAAM,YAAN,cAAwB,MAAM;AAAA,EACjC;AAAA,EACA;AAAA,EACA;AAAA,EACA,YAAY,SAAS,SAAS;AAC1B,UAAM,CAAC,MAAM,MAAM,IAAI,kBAAkB,QAAQ,MAAM,QAAQ,GAAG;AAClE,UAAM,YAAY,cAAc,QAAQ,MAAM,MAAM,MAAM;AAC1D,UAAM,0BAA0B,OAAO;AAAA;AAAA,EAAO,SAAS,IAAI,OAAO;AAClE,SAAK,OAAO;AACZ,SAAK,SAAS;AACd,SAAK,YAAY;AAAA,EACrB;AACJ;;;AClCA,SAAS,UAAU,KAAK,KAAK;AACzB,MAAI,IAAI;AACR,SAAO,IAAI,MAAM,EAAE,CAAC,MAAM;AACtB;AACJ,SAAO,EAAE,KAAM,IAAI;AACvB;AACO,SAAS,eAAe,KAAK,QAAQ,GAAG,MAAM,IAAI,QAAQ;AAC7D,MAAI,MAAM,IAAI,QAAQ,MAAM,KAAK;AACjC,MAAI,IAAI,MAAM,CAAC,MAAM;AACjB;AACJ,SAAO,OAAO,MAAM,MAAM;AAC9B;AACO,SAAS,YAAY,KAAK,KAAK;AAClC,WAAS,IAAI,KAAK,IAAI,IAAI,QAAQ,KAAK;AACnC,QAAI,IAAI,IAAI,CAAC;AACb,QAAI,MAAM;AACN,aAAO;AACX,QAAI,MAAM,QAAQ,IAAI,IAAI,CAAC,MAAM;AAC7B,aAAO,IAAI;AACf,QAAK,IAAI,OAAU,MAAM,OAAS,MAAM,QAAQ;AAC5C,YAAM,IAAI,UAAU,kDAAkD;AAAA,QAClE,MAAM;AAAA,QACN;AAAA,MACJ,CAAC;AAAA,IACL;AAAA,EACJ;AACA,SAAO,IAAI;AACf;AACO,SAAS,SAAS,KAAK,KAAK,aAAa,aAAa;AACzD,MAAI;AACJ,UAAQ,IAAI,IAAI,GAAG,OAAO,OAAO,MAAM,OAAS,CAAC,gBAAgB,MAAM,QAAQ,MAAM,QAAQ,IAAI,MAAM,CAAC,MAAM;AAC1G;AACJ,SAAO,eAAe,MAAM,MACtB,MACA,SAAS,KAAK,YAAY,KAAK,GAAG,GAAG,WAAW;AAC1D;AACO,SAAS,UAAU,KAAK,KAAK,KAAK,KAAK,cAAc,OAAO;AAC/D,MAAI,CAAC,KAAK;AACN,UAAM,eAAe,KAAK,GAAG;AAC7B,WAAO,MAAM,IAAI,IAAI,SAAS;AAAA,EAClC;AACA,WAAS,IAAI,KAAK,IAAI,IAAI,QAAQ,KAAK;AACnC,QAAI,IAAI,IAAI,CAAC;AACb,QAAI,MAAM,KAAK;AACX,UAAI,eAAe,KAAK,CAAC;AAAA,IAC7B,WACS,MAAM,KAAK;AAChB,aAAO,IAAI;AAAA,IACf,WACS,MAAM,OAAQ,gBAAgB,MAAM,QAAS,MAAM,QAAQ,IAAI,IAAI,CAAC,MAAM,OAAS;AACxF,aAAO;AAAA,IACX;AAAA,EACJ;AACA,QAAM,IAAI,UAAU,gCAAgC;AAAA,IAChD,MAAM;AAAA,IACN;AAAA,EACJ,CAAC;AACL;AACO,SAAS,aAAa,KAAK,MAAM;AACpC,MAAI,QAAQ,IAAI,IAAI;AACpB,MAAI,SAAS,UAAU,IAAI,OAAO,CAAC,KAAK,IAAI,OAAO,CAAC,MAAM,IAAI,OAAO,CAAC,IAChE,IAAI,MAAM,MAAM,OAAO,CAAC,IACxB;AACN,UAAQ,OAAO,SAAS;AACxB;AACI,WAAO,IAAI,QAAQ,QAAQ,EAAE,IAAI;AAAA,SAC9B,OAAO,MAAM,UAAU,OAAO,UAAU,KAAK,IAAI;AACxD,MAAI,OAAO,IAAI;AACX,YAAQ,OAAO;AACf,QAAI,OAAO,SAAS,GAAG;AACnB,UAAI,IAAI,IAAI,MAAM;AACd;AACJ,UAAI,IAAI,IAAI,MAAM;AACd;AAAA,IACR;AAAA,EACJ;AACA,SAAO;AACX;;;AC9EA,IAAI,eAAe;AACZ,IAAM,WAAN,MAAM,kBAAiB,KAAK;AAAA,EAC/B,WAAW;AAAA,EACX,WAAW;AAAA,EACX,UAAU;AAAA,EACV,YAAY,MAAM;AACd,QAAI,UAAU;AACd,QAAI,UAAU;AACd,QAAI,SAAS;AACb,QAAI,OAAO,SAAS,UAAU;AAC1B,UAAI,QAAQ,KAAK,MAAM,YAAY;AACnC,UAAI,OAAO;AACP,YAAI,CAAC,MAAM,CAAC,GAAG;AACX,oBAAU;AACV,iBAAO,cAAc,IAAI;AAAA,QAC7B;AACA,kBAAU,CAAC,CAAC,MAAM,CAAC;AAEnB,mBAAW,KAAK,EAAE,MAAM,QAAQ,OAAO,KAAK,QAAQ,KAAK,GAAG;AAE5D,YAAI,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,IAAI;AAC5B,iBAAO;AAAA,QACX,OACK;AACD,mBAAS,MAAM,CAAC,KAAK;AACrB,iBAAO,KAAK,YAAY;AACxB,cAAI,CAAC,UAAU;AACX,oBAAQ;AAAA,QAChB;AAAA,MACJ,OACK;AACD,eAAO;AAAA,MACX;AAAA,IACJ;AACA,UAAM,IAAI;AACV,QAAI,CAAC,MAAM,KAAK,QAAQ,CAAC,GAAG;AACxB,WAAK,WAAW;AAChB,WAAK,WAAW;AAChB,WAAK,UAAU;AAAA,IACnB;AAAA,EACJ;AAAA,EACA,aAAa;AACT,WAAO,KAAK,YAAY,KAAK;AAAA,EACjC;AAAA,EACA,UAAU;AACN,WAAO,CAAC,KAAK,YAAY,CAAC,KAAK,YAAY,CAAC,KAAK;AAAA,EACrD;AAAA,EACA,SAAS;AACL,WAAO,KAAK,YAAY,CAAC,KAAK;AAAA,EAClC;AAAA,EACA,SAAS;AACL,WAAO,KAAK,YAAY,CAAC,KAAK;AAAA,EAClC;AAAA,EACA,UAAU;AACN,WAAO,KAAK,YAAY,KAAK;AAAA,EACjC;AAAA,EACA,cAAc;AACV,QAAI,MAAM,MAAM,YAAY;AAE5B,QAAI,KAAK,OAAO;AACZ,aAAO,IAAI,MAAM,GAAG,EAAE;AAE1B,QAAI,KAAK,OAAO;AACZ,aAAO,IAAI,MAAM,IAAI,EAAE;AAE3B,QAAI,KAAK,YAAY;AACjB,aAAO,IAAI,MAAM,GAAG,EAAE;AAE1B,QAAI,KAAK,YAAY;AACjB,aAAO;AAGX,QAAI,SAAU,CAAE,KAAK,QAAQ,MAAM,GAAG,CAAC,IAAK,KAAM,CAAE,KAAK,QAAQ,MAAM,GAAG,CAAC;AAC3E,aAAS,KAAK,QAAQ,CAAC,MAAM,MAAM,SAAS,CAAC;AAC7C,QAAI,aAAa,IAAI,KAAK,KAAK,QAAQ,IAAK,SAAS,GAAK;AAC1D,WAAO,WAAW,YAAY,EAAE,MAAM,GAAG,EAAE,IAAI,KAAK;AAAA,EACxD;AAAA,EACA,OAAO,qBAAqB,QAAQ,SAAS,KAAK;AAC9C,QAAI,OAAO,IAAI,UAAS,MAAM;AAC9B,SAAK,UAAU;AACf,WAAO;AAAA,EACX;AAAA,EACA,OAAO,oBAAoB,QAAQ;AAC/B,QAAI,OAAO,IAAI,UAAS,MAAM;AAC9B,SAAK,UAAU;AACf,WAAO;AAAA,EACX;AAAA,EACA,OAAO,gBAAgB,QAAQ;AAC3B,QAAI,OAAO,IAAI,UAAS,MAAM;AAC9B,SAAK,WAAW;AAChB,SAAK,UAAU;AACf,WAAO;AAAA,EACX;AAAA,EACA,OAAO,gBAAgB,QAAQ;AAC3B,QAAI,OAAO,IAAI,UAAS,MAAM;AAC9B,SAAK,WAAW;AAChB,SAAK,UAAU;AACf,WAAO;AAAA,EACX;AACJ;;;AChGA,IAAI,YAAY;AAChB,IAAI,cAAc;AAClB,IAAI,eAAe;AACnB,IAAI,eAAe;AACnB,IAAI,UAAU;AAAA,EACV,GAAG;AAAA,EACH,GAAG;AAAA,EACH,GAAG;AAAA,EACH,GAAG;AAAA,EACH,GAAG;AAAA,EACH,GAAG;AAAA,EACH,KAAK;AAAA,EACL,MAAM;AACV;AACO,SAAS,YAAY,KAAK,MAAM,GAAG,SAAS,IAAI,QAAQ;AAC3D,MAAI,YAAY,IAAI,GAAG,MAAM;AAC7B,MAAI,cAAc,IAAI,KAAK,MAAM,IAAI,GAAG,KAAK,IAAI,GAAG,MAAM,IAAI,MAAM,CAAC;AACrE,MAAI,aAAa;AACb,cAAU;AACV,QAAI,IAAI,OAAO,CAAC,MAAM;AAClB;AACJ,QAAI,IAAI,GAAG,MAAM;AACb;AAAA,EACR;AACA,MAAI,MAAM;AACV,MAAI;AACJ,MAAI,SAAS;AACb,MAAI,aAAa;AACjB,SAAO,MAAM,SAAS,GAAG;AACrB,QAAI,IAAI,IAAI,KAAK;AACjB,QAAI,MAAM,QAAS,MAAM,QAAQ,IAAI,GAAG,MAAM,MAAO;AACjD,UAAI,CAAC,aAAa;AACd,cAAM,IAAI,UAAU,uCAAuC;AAAA,UACvD,MAAM;AAAA,UACN,KAAK,MAAM;AAAA,QACf,CAAC;AAAA,MACL;AAAA,IACJ,WACU,IAAI,OAAU,MAAM,OAAS,MAAM,QAAQ;AACjD,YAAM,IAAI,UAAU,iDAAiD;AAAA,QACjE,MAAM;AAAA,QACN,KAAK,MAAM;AAAA,MACf,CAAC;AAAA,IACL;AACA,QAAI,UAAU;AACV,iBAAW;AACX,UAAI,MAAM,OAAO,MAAM,OAAO,MAAM,KAAK;AAErC,YAAI,OAAO,IAAI,MAAM,KAAM,OAAQ,MAAM,MAAM,IAAI,MAAM,MAAM,IAAI,CAAG;AACtE,YAAI,CAAC,aAAa,KAAK,IAAI,GAAG;AAC1B,gBAAM,IAAI,UAAU,0BAA0B;AAAA,YAC1C,MAAM;AAAA,YACN,KAAK;AAAA,UACT,CAAC;AAAA,QACL;AACA,YAAI;AACA,oBAAU,OAAO,cAAc,SAAS,MAAM,EAAE,CAAC;AAAA,QACrD,QACM;AACF,gBAAM,IAAI,UAAU,0BAA0B;AAAA,YAC1C,MAAM;AAAA,YACN,KAAK;AAAA,UACT,CAAC;AAAA,QACL;AAAA,MACJ,WACS,gBAAgB,MAAM,QAAQ,MAAM,OAAO,MAAM,OAAQ,MAAM,OAAO;AAE3E,cAAM,SAAS,KAAK,MAAM,GAAG,IAAI;AACjC,YAAI,IAAI,GAAG,MAAM,QAAQ,IAAI,GAAG,MAAM,MAAM;AACxC,gBAAM,IAAI,UAAU,8DAA8D;AAAA,YAC9E,MAAM;AAAA,YACN,KAAK;AAAA,UACT,CAAC;AAAA,QACL;AACA,cAAM,SAAS,KAAK,GAAG;AAAA,MAC3B,WACS,KAAK,SAAS;AAEnB,kBAAU,QAAQ,CAAC;AAAA,MACvB,OACK;AACD,cAAM,IAAI,UAAU,gCAAgC;AAAA,UAChD,MAAM;AAAA,UACN,KAAK;AAAA,QACT,CAAC;AAAA,MACL;AACA,mBAAa;AAAA,IACjB,WACS,CAAC,aAAa,MAAM,MAAM;AAC/B,YAAM,MAAM;AACZ,iBAAW;AACX,gBAAU,IAAI,MAAM,YAAY,GAAG;AAAA,IACvC;AAAA,EACJ;AACA,SAAO,SAAS,IAAI,MAAM,YAAY,SAAS,CAAC;AACpD;AACO,SAAS,WAAW,OAAO,MAAM,KAAK,kBAAkB;AAE3D,MAAI,UAAU;AACV,WAAO;AACX,MAAI,UAAU;AACV,WAAO;AACX,MAAI,UAAU;AACV,WAAO;AACX,MAAI,UAAU,SAAS,UAAU;AAC7B,WAAO;AACX,MAAI,UAAU,SAAS,UAAU,UAAU,UAAU;AACjD,WAAO;AAEX,MAAI,UAAU;AACV,WAAO,mBAAmB,KAAK;AAEnC,MAAI,QAAQ,UAAU,KAAK,KAAK;AAChC,MAAI,SAAS,YAAY,KAAK,KAAK,GAAG;AAClC,QAAI,aAAa,KAAK,KAAK,GAAG;AAC1B,YAAM,IAAI,UAAU,kCAAkC;AAAA,QAClD;AAAA,QACA;AAAA,MACJ,CAAC;AAAA,IACL;AACA,YAAQ,MAAM,QAAQ,MAAM,EAAE;AAC9B,QAAI,UAAU,CAAC;AACf,QAAI,MAAM,OAAO,GAAG;AAChB,YAAM,IAAI,UAAU,kBAAkB;AAAA,QAClC;AAAA,QACA;AAAA,MACJ,CAAC;AAAA,IACL;AACA,QAAI,OAAO;AACP,WAAK,QAAQ,CAAC,OAAO,cAAc,OAAO,MAAM,CAAC,kBAAkB;AAC/D,cAAM,IAAI,UAAU,kDAAkD;AAAA,UAClE;AAAA,UACA;AAAA,QACJ,CAAC;AAAA,MACL;AACA,UAAI,SAAS,qBAAqB;AAC9B,kBAAU,OAAO,KAAK;AAAA,IAC9B;AACA,WAAO;AAAA,EACX;AACA,QAAM,OAAO,IAAI,SAAS,KAAK;AAC/B,MAAI,CAAC,KAAK,QAAQ,GAAG;AACjB,UAAM,IAAI,UAAU,iBAAiB;AAAA,MACjC;AAAA,MACA;AAAA,IACJ,CAAC;AAAA,EACL;AACA,SAAO;AACX;;;ACnJA,SAAS,kBAAkB,KAAK,UAAU,QAAQ;AAC9C,MAAI,QAAQ,IAAI,MAAM,UAAU,MAAM;AACtC,MAAI,aAAa,MAAM,QAAQ,GAAG;AAClC,MAAI,aAAa,IAAI;AAGjB,gBAAY,KAAK,UAAU;AAC3B,YAAQ,MAAM,MAAM,GAAG,UAAU;AAAA,EACrC;AACA,SAAO,CAAC,MAAM,QAAQ,GAAG,UAAU;AACvC;AACO,SAAS,aAAa,KAAK,KAAK,KAAK,OAAO,kBAAkB;AACjE,MAAI,UAAU,GAAG;AACb,UAAM,IAAI,UAAU,8DAA8D;AAAA,MAC9E,MAAM;AAAA,MACN;AAAA,IACJ,CAAC;AAAA,EACL;AACA,MAAI,IAAI,IAAI,GAAG;AACf,MAAI,MAAM,OAAO,MAAM,KAAK;AACxB,QAAI,CAAC,OAAOA,OAAM,IAAI,MAAM,MACtB,WAAW,KAAK,KAAK,OAAO,gBAAgB,IAC5C,iBAAiB,KAAK,KAAK,OAAO,gBAAgB;AACxD,QAAI,KAAK;AACL,MAAAA,UAAS,SAAS,KAAKA,OAAM;AAC7B,UAAI,IAAIA,OAAM,MAAM;AAChB,QAAAA;AAAA,eACK,IAAIA,OAAM,MAAM,KAAK;AAC1B,cAAM,IAAI,UAAU,sCAAsC;AAAA,UACtD,MAAM;AAAA,UACN,KAAKA;AAAA,QACT,CAAC;AAAA,MACL;AAAA,IACJ;AACA,WAAO,CAAC,OAAOA,OAAM;AAAA,EACzB;AACA,MAAI;AACJ,MAAI,MAAM,OAAO,MAAM,KAAK;AACxB,aAAS,aAAa,KAAK,GAAG;AAC9B,QAAI,SAAS,YAAY,KAAK,KAAK,MAAM;AACzC,QAAI,KAAK;AACL,eAAS,SAAS,KAAK,MAAM;AAC7B,UAAI,IAAI,MAAM,KAAK,IAAI,MAAM,MAAM,OAAO,IAAI,MAAM,MAAM,OAAO,IAAI,MAAM,MAAM,QAAQ,IAAI,MAAM,MAAM,MAAM;AAC3G,cAAM,IAAI,UAAU,oCAAoC;AAAA,UACpD,MAAM;AAAA,UACN,KAAK;AAAA,QACT,CAAC;AAAA,MACL;AACA,gBAAW,EAAE,IAAI,MAAM,MAAM;AAAA,IACjC;AACA,WAAO,CAAC,QAAQ,MAAM;AAAA,EAC1B;AACA,WAAS,UAAU,KAAK,KAAK,KAAK,GAAG;AACrC,MAAI,QAAQ,kBAAkB,KAAK,KAAK,SAAU,EAAE,IAAI,SAAS,CAAC,MAAM,IAAK;AAC7E,MAAI,CAAC,MAAM,CAAC,GAAG;AACX,UAAM,IAAI,UAAU,wDAAwD;AAAA,MACxE,MAAM;AAAA,MACN;AAAA,IACJ,CAAC;AAAA,EACL;AACA,MAAI,OAAO,MAAM,CAAC,IAAI,IAAI;AACtB,aAAS,SAAS,KAAK,MAAM,MAAM,CAAC,CAAC;AACrC,cAAU,EAAE,IAAI,MAAM,MAAM;AAAA,EAChC;AACA,SAAO;AAAA,IACH,WAAW,MAAM,CAAC,GAAG,KAAK,KAAK,gBAAgB;AAAA,IAC/C;AAAA,EACJ;AACJ;;;ACpEA,IAAI,cAAc;AACX,SAAS,SAAS,KAAK,KAAK,MAAM,KAAK;AAC1C,MAAI,MAAM,MAAM;AAChB,MAAI,SAAS,CAAC;AACd,MAAI,SAAS,IAAI,QAAQ,KAAK,GAAG;AACjC,MAAI,SAAS,GAAG;AACZ,UAAM,IAAI,UAAU,gDAAgD;AAAA,MAChE,MAAM;AAAA,MACN;AAAA,IACJ,CAAC;AAAA,EACL;AACA,KAAG;AACC,QAAI,IAAI,IAAI,MAAM,EAAE,GAAG;AAEvB,QAAI,MAAM,OAAO,MAAM,KAAM;AAEzB,UAAI,MAAM,OAAO,MAAM,KAAM;AACzB,YAAI,MAAM,IAAI,MAAM,CAAC,KAAK,MAAM,IAAI,MAAM,CAAC,GAAG;AAC1C,gBAAM,IAAI,UAAU,6CAA6C;AAAA,YAC7D,MAAM;AAAA,YACN;AAAA,UACJ,CAAC;AAAA,QACL;AACA,YAAI,MAAM,aAAa,KAAK,GAAG;AAC/B,YAAI,MAAM,GAAG;AACT,gBAAM,IAAI,UAAU,iCAAiC;AAAA,YACjD,MAAM;AAAA,YACN;AAAA,UACJ,CAAC;AAAA,QACL;AACA,cAAM,IAAI,QAAQ,KAAK,GAAG;AAC1B,YAAI,SAAS,IAAI,MAAM,KAAK,MAAM,KAAK,MAAM,SAAS,SAAS,GAAG;AAClE,YAAI,UAAU,eAAe,MAAM;AACnC,YAAI,UAAU,IAAI;AACd,gBAAM,IAAI,UAAU,oCAAoC;AAAA,YACpD,MAAM;AAAA,YACN,KAAK,MAAM,MAAM;AAAA,UACrB,CAAC;AAAA,QACL;AACA,YAAI,OAAO,UAAU,GAAG;AACpB,gBAAM,IAAI,UAAU,4CAA4C;AAAA,YAC5D,MAAM;AAAA,YACN,KAAK;AAAA,UACT,CAAC;AAAA,QACL;AACA,YAAI,SAAS,KAAK;AACd,mBAAS,IAAI,QAAQ,KAAK,GAAG;AAC7B,cAAI,SAAS,GAAG;AACZ,kBAAM,IAAI,UAAU,gDAAgD;AAAA,cAChE,MAAM;AAAA,cACN;AAAA,YACJ,CAAC;AAAA,UACL;AAAA,QACJ;AACA,eAAO,KAAK,YAAY,KAAK,KAAK,GAAG,CAAC;AAAA,MAC1C,OACK;AAED,cAAM,IAAI,QAAQ,KAAK,GAAG;AAC1B,YAAI,OAAO,IAAI,MAAM,KAAK,MAAM,KAAK,MAAM,SAAS,SAAS,GAAG;AAChE,YAAI,CAAC,YAAY,KAAK,IAAI,GAAG;AACzB,gBAAM,IAAI,UAAU,oEAAoE;AAAA,YACpF,MAAM;AAAA,YACN;AAAA,UACJ,CAAC;AAAA,QACL;AACA,eAAO,KAAK,KAAK,QAAQ,CAAC;AAAA,MAC9B;AAAA,IACJ;AAAA,EAEJ,SAAS,MAAM,KAAK,MAAM;AAC1B,SAAO,CAAC,QAAQ,SAAS,KAAK,SAAS,GAAG,MAAM,IAAI,CAAC;AACzD;AACO,SAAS,iBAAiB,KAAK,KAAK,OAAO,kBAAkB;AAChE,MAAI,MAAM,CAAC;AACX,MAAI,OAAO,oBAAI,IAAI;AACnB,MAAI;AACJ;AACA,UAAQ,IAAI,IAAI,KAAK,OAAO,OAAO,GAAG;AAClC,QAAI,MAAM,KAAK;AACX,YAAM,IAAI,UAAU,+BAA+B;AAAA,QAC/C,MAAM;AAAA,QACN,KAAK,MAAM;AAAA,MACf,CAAC;AAAA,IACL,WACS,MAAM;AACX,YAAM,YAAY,KAAK,GAAG;AAAA,aACrB,MAAM,OAAO,MAAM,OAAQ,MAAM,QAAQ,MAAM,MAAM;AAC1D,UAAI;AACJ,UAAI,IAAI;AACR,UAAI,SAAS;AACb,UAAI,CAAC,KAAK,SAAS,IAAI,SAAS,KAAK,MAAM,CAAC;AAC5C,eAAS,IAAI,GAAG,IAAI,IAAI,QAAQ,KAAK;AACjC,YAAI;AACA,cAAI,SAAS,EAAE,CAAC,IAAK,EAAE,CAAC,IAAI,CAAC;AACjC,YAAI,IAAI,CAAC;AACT,aAAK,SAAS,OAAO,OAAO,GAAG,CAAC,OAAO,OAAO,EAAE,CAAC,MAAM,YAAY,KAAK,IAAI,EAAE,CAAC,CAAC,IAAI;AAChF,gBAAM,IAAI,UAAU,+CAA+C;AAAA,YAC/D,MAAM;AAAA,YACN;AAAA,UACJ,CAAC;AAAA,QACL;AACA,YAAI,CAAC,UAAU,MAAM,aAAa;AAC9B,iBAAO,eAAe,GAAG,GAAG,EAAE,YAAY,MAAM,cAAc,MAAM,UAAU,KAAK,CAAC;AAAA,QACxF;AAAA,MACJ;AACA,UAAI,QAAQ;AACR,cAAM,IAAI,UAAU,+CAA+C;AAAA,UAC/D,MAAM;AAAA,UACN;AAAA,QACJ,CAAC;AAAA,MACL;AACA,UAAI,CAAC,OAAO,WAAW,IAAI,aAAa,KAAK,WAAW,KAAK,QAAQ,GAAG,gBAAgB;AACxF,WAAK,IAAI,KAAK;AACd,QAAE,CAAC,IAAI;AACP,YAAM;AAAA,IACV;AAAA,EACJ;AACA,MAAI,CAAC,GAAG;AACJ,UAAM,IAAI,UAAU,gCAAgC;AAAA,MAChD,MAAM;AAAA,MACN;AAAA,IACJ,CAAC;AAAA,EACL;AACA,SAAO,CAAC,KAAK,GAAG;AACpB;AACO,SAAS,WAAW,KAAK,KAAK,OAAO,kBAAkB;AAC1D,MAAI,MAAM,CAAC;AACX,MAAI;AACJ;AACA,UAAQ,IAAI,IAAI,KAAK,OAAO,OAAO,GAAG;AAClC,QAAI,MAAM,KAAK;AACX,YAAM,IAAI,UAAU,+BAA+B;AAAA,QAC/C,MAAM;AAAA,QACN,KAAK,MAAM;AAAA,MACf,CAAC;AAAA,IACL,WACS,MAAM;AACX,YAAM,YAAY,KAAK,GAAG;AAAA,aACrB,MAAM,OAAO,MAAM,OAAQ,MAAM,QAAQ,MAAM,MAAM;AAC1D,UAAI,IAAI,aAAa,KAAK,MAAM,GAAG,KAAK,QAAQ,GAAG,gBAAgB;AACnE,UAAI,KAAK,EAAE,CAAC,CAAC;AACb,YAAM,EAAE,CAAC;AAAA,IACb;AAAA,EACJ;AACA,MAAI,CAAC,GAAG;AACJ,UAAM,IAAI,UAAU,gCAAgC;AAAA,MAChD,MAAM;AAAA,MACN;AAAA,IACJ,CAAC;AAAA,EACL;AACA,SAAO,CAAC,KAAK,GAAG;AACpB;;;ACxJA,SAAS,UAAU,KAAK,OAAO,MAAM,MAAM;AACvC,MAAI,IAAI;AACR,MAAI,IAAI;AACR,MAAI;AACJ,MAAI,SAAS;AACb,MAAI;AACJ,WAAS,IAAI,GAAG,IAAI,IAAI,QAAQ,KAAK;AACjC,QAAI,GAAG;AACH,UAAI,SAAS,EAAE,CAAC,IAAK,EAAE,CAAC,IAAI,CAAC;AAC7B,WAAK,QAAQ,EAAE,CAAC,GAAG;AACnB,UAAI,SAAS,MAAwB,MAAM,MAAM,KAAyB,MAAM,MAAM,IAAqB;AACvG,eAAO;AAAA,MACX;AACA,UAAI,MAAM,MAAM,GAAoB;AAChC,YAAI,IAAI,EAAE,SAAS;AACnB,YAAI,EAAE,CAAC;AACP,YAAI,EAAE,CAAC,EAAE;AAAA,MACb;AAAA,IACJ;AACA,QAAI,IAAI,CAAC;AACT,SAAK,SAAS,OAAO,OAAO,GAAG,CAAC,MAAM,EAAE,CAAC,GAAG,MAAM,KAAuB,EAAE,CAAC,GAAG,GAAG;AAC9E,aAAO;AAAA,IACX;AACA,QAAI,CAAC,QAAQ;AACT,UAAI,MAAM,aAAa;AACnB,eAAO,eAAe,GAAG,GAAG,EAAE,YAAY,MAAM,cAAc,MAAM,UAAU,KAAK,CAAC;AACpF,eAAO,eAAe,GAAG,GAAG,EAAE,YAAY,MAAM,cAAc,MAAM,UAAU,KAAK,CAAC;AAAA,MACxF;AACA,QAAE,CAAC,IAAI;AAAA,QACH,GAAG,IAAI,IAAI,SAAS,KAAK,SAAS,IAC5B,IACA;AAAA,QACN,GAAG;AAAA,QACH,GAAG;AAAA,QACH,GAAG,CAAC;AAAA,MACR;AAAA,IACJ;AAAA,EACJ;AACA,UAAQ,EAAE,CAAC;AACX,MAAI,MAAM,MAAM,QAAQ,EAAE,SAAS,KAAyB,MAAM,MAAM,IAA4B;AAEhG,WAAO;AAAA,EACX;AACA,MAAI,SAAS,GAAoB;AAC7B,QAAI,CAAC,MAAM,GAAG;AACV,YAAM,IAAI;AACV,QAAE,CAAC,IAAI,CAAC;AAAA,IACZ;AACA,MAAE,CAAC,EAAE,KAAK,IAAI,CAAC,CAAC;AAChB,UAAM,EAAE,MAAM,GAAG,IAAK,QAAQ,EAAE,GAAG,GAAuB,GAAG,OAAO,GAAG,GAAG,GAAG,CAAC,EAAE;AAAA,EACpF;AACA,MAAI,MAAM,GAAG;AAET,WAAO;AAAA,EACX;AACA,QAAM,IAAI;AACV,MAAI,SAAS,GAAuB;AAChC,QAAI,SAAS,EAAE,CAAC,IAAK,EAAE,CAAC,IAAI,CAAC;AAAA,EACjC,WACS,SAAS,KAAuB,QAAQ;AAC7C,WAAO;AAAA,EACX;AACA,SAAO,CAAC,GAAG,GAAG,MAAM,CAAC;AACzB;AACO,SAAS,MAAM,MAAM,EAAE,WAAW,KAAM,iBAAiB,IAAI,CAAC,GAAG;AACpE,MAAI,MAAM,CAAC;AACX,MAAI,OAAO,CAAC;AACZ,MAAI,MAAM;AACV,MAAI,IAAI;AACR,WAAS,MAAM,SAAS,MAAM,CAAC,GAAG,MAAM,KAAK,UAAS;AAClD,QAAI,KAAK,GAAG,MAAM,KAAK;AACnB,UAAI,eAAe,KAAK,EAAE,GAAG,MAAM;AACnC,UAAI,IAAI,SAAS,MAAM,OAAO,CAAC,cAAc,GAAG;AAChD,UAAI,cAAc;AACd,YAAI,KAAK,EAAE,CAAC,IAAI,CAAC,MAAM,KAAK;AACxB,gBAAM,IAAI,UAAU,qCAAqC;AAAA,YACrD;AAAA,YACA,KAAK,EAAE,CAAC,IAAI;AAAA,UAChB,CAAC;AAAA,QACL;AACA,UAAE,CAAC;AAAA,MACP;AACA,UAAI,IAAI;AAAA,QAAU,EAAE,CAAC;AAAA,QAAG;AAAA,QAAK;AAAA,QAAM,eAAe,IAAqB;AAAA;AAAA,MAAqB;AAC5F,UAAI,CAAC,GAAG;AACJ,cAAM,IAAI,UAAU,wDAAwD;AAAA,UACxE;AAAA,UACA;AAAA,QACJ,CAAC;AAAA,MACL;AACA,UAAI,EAAE,CAAC;AACP,YAAM,EAAE,CAAC;AACT,YAAM,EAAE,CAAC;AAAA,IACb,OACK;AACD,UAAI,IAAI,SAAS,MAAM,GAAG;AAC1B,UAAI,IAAI;AAAA,QAAU,EAAE,CAAC;AAAA,QAAG;AAAA,QAAK;AAAA,QAAG;AAAA;AAAA,MAAmB;AACnD,UAAI,CAAC,GAAG;AACJ,cAAM,IAAI,UAAU,wDAAwD;AAAA,UACxE;AAAA,UACA;AAAA,QACJ,CAAC;AAAA,MACL;AACA,UAAI,IAAI,aAAa,MAAM,EAAE,CAAC,GAAG,QAAQ,UAAU,gBAAgB;AACnE,QAAE,CAAC,EAAE,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC;AAChB,YAAM,EAAE,CAAC;AAAA,IACb;AACA,UAAM,SAAS,MAAM,KAAK,IAAI;AAC9B,QAAI,KAAK,GAAG,KAAK,KAAK,GAAG,MAAM,QAAQ,KAAK,GAAG,MAAM,MAAM;AACvD,YAAM,IAAI,UAAU,iEAAiE;AAAA,QACjF;AAAA,QACA;AAAA,MACJ,CAAC;AAAA,IACL;AACA,UAAM,SAAS,MAAM,GAAG;AAAA,EAC5B;AACA,SAAO;AACX;;;ACxHA,IAAI,WAAW;AACf,SAAS,eAAe,KAAK;AACzB,MAAI,OAAO,OAAO;AAClB,MAAI,SAAS,UAAU;AACnB,QAAI,MAAM,QAAQ,GAAG;AACjB,aAAO;AACX,QAAI,eAAe;AACf,aAAO;AAAA,EACf;AACA,SAAO;AACX;AACA,SAAS,gBAAgB,KAAK;AAC1B,WAAS,IAAI,GAAG,IAAI,IAAI,QAAQ,KAAK;AACjC,QAAI,eAAe,IAAI,CAAC,CAAC,MAAM;AAC3B,aAAO;AAAA,EACf;AACA,SAAO,IAAI,UAAU;AACzB;AACA,SAAS,aAAa,GAAG;AACrB,SAAO,KAAK,UAAU,CAAC,EAAE,QAAQ,SAAS,SAAS;AACvD;AACA,SAAS,eAAe,KAAK,MAAM,OAAO,eAAe;AACrD,MAAI,UAAU,GAAG;AACb,UAAM,IAAI,MAAM,+DAA+D;AAAA,EACnF;AACA,MAAI,SAAS,UAAU;AACnB,QAAI,MAAM,GAAG;AACT,aAAO;AACX,QAAI,QAAQ;AACR,aAAO;AACX,QAAI,QAAQ;AACR,aAAO;AACX,QAAI,iBAAiB,OAAO,UAAU,GAAG;AACrC,aAAO,IAAI,QAAQ,CAAC;AACxB,WAAO,IAAI,SAAS;AAAA,EACxB;AACA,MAAI,SAAS,YAAY,SAAS,WAAW;AACzC,WAAO,IAAI,SAAS;AAAA,EACxB;AACA,MAAI,SAAS,UAAU;AACnB,WAAO,aAAa,GAAG;AAAA,EAC3B;AACA,MAAI,SAAS,QAAQ;AACjB,QAAI,MAAM,IAAI,QAAQ,CAAC,GAAG;AACtB,YAAM,IAAI,UAAU,+BAA+B;AAAA,IACvD;AACA,WAAO,IAAI,YAAY;AAAA,EAC3B;AACA,MAAI,SAAS,UAAU;AACnB,WAAO,qBAAqB,KAAK,OAAO,aAAa;AAAA,EACzD;AACA,MAAI,SAAS,SAAS;AAClB,WAAO,eAAe,KAAK,OAAO,aAAa;AAAA,EACnD;AACJ;AACA,SAAS,qBAAqB,KAAK,OAAO,eAAe;AACrD,MAAI,OAAO,OAAO,KAAK,GAAG;AAC1B,MAAI,KAAK,WAAW;AAChB,WAAO;AACX,MAAI,MAAM;AACV,WAAS,IAAI,GAAG,IAAI,KAAK,QAAQ,KAAK;AAClC,QAAI,IAAI,KAAK,CAAC;AACd,QAAI;AACA,aAAO;AACX,WAAO,SAAS,KAAK,CAAC,IAAI,IAAI,aAAa,CAAC;AAC5C,WAAO;AACP,WAAO,eAAe,IAAI,CAAC,GAAG,eAAe,IAAI,CAAC,CAAC,GAAG,QAAQ,GAAG,aAAa;AAAA,EAClF;AACA,SAAO,MAAM;AACjB;AACA,SAAS,eAAe,OAAO,OAAO,eAAe;AACjD,MAAI,MAAM,WAAW;AACjB,WAAO;AACX,MAAI,MAAM;AACV,WAAS,IAAI,GAAG,IAAI,MAAM,QAAQ,KAAK;AACnC,QAAI;AACA,aAAO;AACX,QAAI,MAAM,CAAC,MAAM,QAAQ,MAAM,CAAC,MAAM,QAAQ;AAC1C,YAAM,IAAI,UAAU,gDAAgD;AAAA,IACxE;AACA,WAAO,eAAe,MAAM,CAAC,GAAG,eAAe,MAAM,CAAC,CAAC,GAAG,QAAQ,GAAG,aAAa;AAAA,EACtF;AACA,SAAO,MAAM;AACjB;AACA,SAAS,oBAAoB,OAAO,KAAK,OAAO,eAAe;AAC3D,MAAI,UAAU,GAAG;AACb,UAAM,IAAI,MAAM,+DAA+D;AAAA,EACnF;AACA,MAAI,MAAM;AACV,WAAS,IAAI,GAAG,IAAI,MAAM,QAAQ,KAAK;AACnC,WAAO,GAAG,OAAO,IAAI,KAAK,GAAG;AAAA;AAC7B,WAAO,eAAe,GAAG,MAAM,CAAC,GAAG,KAAK,OAAO,aAAa;AAAA,EAChE;AACA,SAAO;AACX;AACA,SAAS,eAAe,UAAU,KAAK,QAAQ,OAAO,eAAe;AACjE,MAAI,UAAU,GAAG;AACb,UAAM,IAAI,MAAM,+DAA+D;AAAA,EACnF;AACA,MAAI,WAAW;AACf,MAAI,SAAS;AACb,MAAI,OAAO,OAAO,KAAK,GAAG;AAC1B,WAAS,IAAI,GAAG,IAAI,KAAK,QAAQ,KAAK;AAClC,QAAI,IAAI,KAAK,CAAC;AACd,QAAI,IAAI,CAAC,MAAM,QAAQ,IAAI,CAAC,MAAM,QAAQ;AACtC,UAAI,OAAO,eAAe,IAAI,CAAC,CAAC;AAChC,UAAI,SAAS,YAAY,SAAS,YAAY;AAC1C,cAAM,IAAI,UAAU,oCAAoC,IAAI,GAAG;AAAA,MACnE;AACA,UAAI,MAAM,SAAS,KAAK,CAAC,IAAI,IAAI,aAAa,CAAC;AAC/C,UAAI,SAAS,WAAW,gBAAgB,IAAI,CAAC,CAAC,GAAG;AAC7C,mBAAW,UAAU,QAAQ,oBAAoB,IAAI,CAAC,GAAG,SAAS,GAAG,MAAM,IAAI,GAAG,KAAK,KAAK,QAAQ,GAAG,aAAa;AAAA,MACxH,WACS,SAAS,UAAU;AACxB,YAAI,SAAS,SAAS,GAAG,MAAM,IAAI,GAAG,KAAK;AAC3C,mBAAW,UAAU,QAAQ,eAAe,QAAQ,IAAI,CAAC,GAAG,QAAQ,QAAQ,GAAG,aAAa;AAAA,MAChG,OACK;AACD,oBAAY;AACZ,oBAAY;AACZ,oBAAY,eAAe,IAAI,CAAC,GAAG,MAAM,OAAO,aAAa;AAC7D,oBAAY;AAAA,MAChB;AAAA,IACJ;AAAA,EACJ;AACA,MAAI,aAAa,YAAY,CAAC;AAC1B,eAAW,WAAW,IAAI,QAAQ;AAAA,EAAM,QAAQ,KAAK,IAAI,QAAQ;AACrE,SAAO,YAAY,SACb,GAAG,QAAQ;AAAA,EAAK,MAAM,KACtB,YAAY;AACtB;AACO,SAAS,UAAU,KAAK,EAAE,WAAW,KAAM,iBAAiB,MAAM,IAAI,CAAC,GAAG;AAC7E,MAAI,eAAe,GAAG,MAAM,UAAU;AAClC,UAAM,IAAI,UAAU,6CAA6C;AAAA,EACrE;AACA,MAAI,MAAM,eAAe,GAAG,KAAK,IAAI,UAAU,cAAc;AAC7D,MAAI,IAAI,IAAI,SAAS,CAAC,MAAM;AACxB,WAAO,MAAM;AACjB,SAAO;AACX;;;AnBtKA,YAAY,QAAQ;AACpB,YAAY,UAAU;AACtB,YAAY,QAAQ;AACpB,SAAS,oBAAoB;AIH7B,OAAO,YAAY;ALmBZ,SAAS,iBAAyB;AACvC,SAAO,KAAK,QAAQ,GAAG,WAAW,aAAa;AACjD;AAEO,SAAS,iBAAmC;AACjD,QAAMC,QAAO,eAAe;AAC5B,MAAI,CAAC,WAAWA,KAAI,EAAG,QAAO,EAAE,UAAU,CAAC,EAAE;AAC7C,QAAM,MAAM,aAAaA,OAAM,OAAO;AACtC,SAAO,MAAM,GAAG;AAClB;AAEO,SAAS,gBAAgB,aAAqC;AACnE,QAAM,SAAS,eAAe;AAC9B,QAAM,OAAO,eAAe,OAAO,mBAAmB;AACtD,SAAO,OAAO,WAAW,IAAI,KAAK,CAAC;AACrC;AAEO,SAAS,gBAAgB,QAAgC;AAC9D,QAAMA,QAAO,eAAe;AAC5B,QAAM,MAAM,QAAQA,KAAI;AACxB,MAAI,CAAC,WAAW,GAAG,GAAG;AACpB,cAAU,KAAK,EAAE,WAAW,KAAK,CAAC;EACpC;AACA,gBAAcA,OAAM,UAAU,MAA4C,GAAG,OAAO;AACtF;ACnCA,IAAM,eAAyC;EAC7C,kBAAkB;EAClB,QAAQ;EACR,UAAU;EACV,QAAQ;EACR,eAAe;EACf,UAAU;AACZ;AAEO,IAAM,oBAAoB,OAAO,KAAK,YAAY;AAEzD,SAAS,UAAkB;AACzB,SAAO,QAAQ,IAAI,WAAgB,UAAQ,WAAQ,GAAG,WAAW,SAAS;AAC5E;AAEA,IAAM,qBAAqB;AAE3B,SAAS,wBAAuC;AAC9C,QAAM,eAAe,QAAQ,IAAI,gBAAqB,UAAQ,WAAQ,GAAG,WAAW,OAAO;AAC3F,QAAM,cAAmB,UAAK,cAAc,UAAU;AACtD,MAAI;AACF,UAAM,UAAa,eAAY,WAAW;AAC1C,UAAM,YAAY,QAAQ,KAAK,CAAC,MAAM,EAAE,WAAW,SAAS,CAAC;AAC7D,QAAI,WAAW;AACb,YAAM,aAAkB;QACtB;QACA;QACA;QACA;QACA;QACA;MACF;AACA,UAAO,cAAW,UAAU,KAAQ,cAAgB,aAAQ,UAAU,CAAC,GAAG;AACxE,eAAO;MACT;IACF;EACF,QAAQ;EAER;AACA,SAAO;AACT;AAEO,SAAS,cAAc,QAAiC;AAC7D,QAAM,OAAU,WAAQ;AACxB,QAAM,WAAW,QAAQ;AACzB,UAAQ,QAAQ;IACd,KAAK;AACH,UAAI,aAAa,SAAS;AACxB,eAAO,sBAAsB,KAAU,UAAK,QAAQ,GAAG,UAAU,kBAAkB;MACrF;AACA,UAAI,aAAa,UAAU;AACzB,eAAY,UAAK,MAAM,WAAW,uBAAuB,UAAU,kBAAkB;MACvF;AACA,aAAY,UAAK,QAAQ,IAAI,mBAAwB,UAAK,MAAM,SAAS,GAAG,UAAU,kBAAkB;IAC1G,KAAK;AACH,aAAY,UAAK,MAAM,WAAW,UAAU;IAC9C,KAAK;AACH,aAAY,UAAK,MAAM,YAAY,YAAY,iBAAiB;IAClE,KAAK;AACH,aAAY,UAAK,QAAQ,IAAI,GAAG,WAAW;IAC7C,KAAK;AACH,aAAO;IACT,KAAK;AACH,aAAY,UAAK,MAAM,aAAa,aAAa,UAAU,eAAe;EAC9E;AACF;AAEA,IAAM,cAAc;AAEpB,SAAS,WAAW,QAA2C;AAC7D,MAAI,WAAW,UAAU;AAEvB,WAAO,EAAE,MAAM,SAAS,SAAS,OAAO,MAAM,CAAC,MAAM,WAAW,EAAE;EACpE;AAGA,SAAO,EAAE,SAAS,OAAO,MAAM,CAAC,MAAM,WAAW,EAAE;AACrD;AAEA,SAAS,gBACP,YACA,YACA,OACM;AACN,QAAM,MAAW,aAAQ,UAAU;AACnC,MAAI,CAAI,cAAW,GAAG,EAAM,CAAA,aAAU,KAAK,EAAE,WAAW,KAAK,CAAC;AAE9D,MAAI,OAAgC,CAAC;AACrC,MAAO,cAAW,UAAU,GAAG;AAC7B,UAAM,MAAS,gBAAa,YAAY,OAAO;AAC/C,QAAI;AACF,aAAO,KAAK,MAAM,GAAG;IACvB,QAAQ;AACN,YAAM,IAAI,MAAM,sCAAsC,UAAU,EAAE;IACpE;EACF;AAEA,MAAI,OAAO,KAAK,eAAe,YAAY,KAAK,eAAe,MAAM;AACnE,SAAK,aAAa,CAAC;EACrB;AACC,OAAK,WAAuC,UAAU,IAAI;AAExD,EAAA,iBAAc,YAAY,KAAK,UAAU,MAAM,MAAM,CAAC,IAAI,MAAM,OAAO;AAC5E;AAMO,SAAS,SAAS,SAA6B;AACpD,QAAM,EAAE,OAAO,IAAI;AACnB,QAAM,OAAO,aAAa,MAAM;AAChC,QAAM,aAAa;AAEnB,MAAI,WAAW,eAAe;AAC5B,UAAM,aAAa;MACjB;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;MACA;IACF;AACA,YAAQ,OAAO,MAAM,mBAAmB,WAAW,KAAK,GAAG,CAAC;CAAI;AAChE,iBAAa,UAAU,YAAY,EAAE,OAAO,UAAU,CAAC;AACvD,YAAQ,OAAO,MAAM,qBAAgB,IAAI;CAAI;AAC7C;EACF;AAEA,QAAM,aAAa,cAAc,MAAM;AACvC,MAAI,CAAC,YAAY;AACf,UAAM,IAAI,MAAM,GAAG,IAAI,oCAAoC;EAC7D;AAEA,QAAM,QAAQ,WAAW,MAAM;AAC/B,kBAAgB,YAAY,YAAY,KAAK;AAC7C,UAAQ,OAAO;IACb,qBAAgB,IAAI;IAAO,UAAU;YAAe,IAAI;;EAC1D;AACF;ACxJO,IAAM,8BAA8B;AAEpC,IAAM,UAAU,CAAC,UAAU,WAAW,UAAU,KAAK;AAGrD,IAAM,kBAA8B,CAAC,UAAU,WAAW,UAAU,KAAK;ACLzE,IAAM,cAAN,cAA0B,MAAM;EACrB;EACT,YAAY,SAAiB,YAAqB;AACvD,UAAM,OAAO;AACb,SAAK,OAAO;AACZ,SAAK,aAAa;EACpB;AACF;AAEO,IAAM,iBAAN,cAA6B,MAAM;EACxB;EACA;EACA;EACT,YACL,SACA,MACA;AACA,UAAM,OAAO;AACb,SAAK,OAAO;AACZ,SAAK,SAAS,MAAM;AACpB,SAAK,WAAW,MAAM;AACtB,SAAK,eAAe,MAAM;EAC5B;AACF;AAEO,SAAS,mBAAmB,OAAyC;AAC1E,MAAI,iBAAiB,aAAa;AAChC,WAAO;MACL,OAAO;MACP,MAAM;MACN,SAAS,MAAM;MACf,YAAY,MAAM;IACpB;EACF;AACA,MAAI,iBAAiB,gBAAgB;AACnC,WAAO;MACL,OAAO;MACP,MAAM;MACN,SAAS,MAAM;MACf,QAAQ,MAAM;MACd,UAAU,MAAM;MAChB,cAAc,MAAM;IACtB;EACF;AACA,QAAM,UAAU,iBAAiB,QAAQ,MAAM,UAAU,OAAO,KAAK;AACrE,SAAO,EAAE,OAAO,MAAM,MAAM,SAAS,QAAQ;AAC/C;AC1BA,SAAS,gBAAgB,YAAiC;AACxD,MAAI,CAAC,cAAc,WAAW,KAAK,EAAE,WAAW,EAAG,QAAO,CAAC,GAAG,eAAe;AAC7E,QAAM,UAAU,WAAW,KAAK,EAAE,YAAY;AAC9C,MAAI,YAAY,MAAO,QAAO,CAAC,GAAG,OAAO;AAEzC,QAAM,YAAY,QACf,MAAM,GAAG,EACT,IAAI,CAAC,MAAM,EAAE,KAAK,CAAC,EACnB,OAAO,OAAO;AACjB,MAAI,UAAU,WAAW,EAAG,QAAO,CAAC,GAAG,eAAe;AAEtD,QAAM,MAAkB,CAAC;AACzB,aAAW,KAAK,WAAW;AACzB,QAAI,CAAC,QAAQ,SAAS,CAAa,GAAG;AACpC,YAAM,IAAI,YAAY,mBAAmB,CAAC,MAAM,eAAe,QAAQ,KAAK,IAAI,CAAC,YAAY;IAC/F;AACA,QAAI,KAAK,CAAa;EACxB;AACA,SAAO,MAAM,KAAK,IAAI,IAAI,GAAG,CAAC;AAChC;AAOO,SAAS,WAAW,KAA+B;AACxD,QAAM,OAAO,gBAAgB,IAAI,OAAO;AAExC,QAAM,SAAS,QAAQ,IAAI,gBAAgB,KAAK,KAAK,KAAK;AAC1D,QAAM,YAAY,QAAQ,IAAI,mBAAmB,KAAK,KAAK,KAAK;AAEhE,QAAM,UAAU,QAAQ,UAAU,SAAS;AAC3C,QAAM,cAAc,QAAQ,MAAM,KAAK,QAAQ,SAAS;AACxD,MAAI,eAAe,CAAC,SAAS;AAC3B,UAAM,IAAI;MACR;MACA;IACF;EACF;AAEA,QAAM,WAAW,IAAI,SAAS,KAAK,KAAK,QAAQ,IAAI,iBAAiB,KAAK,KAAK,KAAK,YAAY,6BAC7F,QAAQ,QAAQ,EAAE;AACrB,MAAI,CAAC,QAAQ,WAAW,SAAS,KAAK,CAAC,QAAQ,WAAW,UAAU,GAAG;AACrE,UAAM,IAAI,YAAY,qBAAqB,OAAO,MAAM,qDAAqD;EAC/G;AAEA,SAAO;IACL;IACA;IACA;IACA;IACA,SAAS,gBAAgB,IAAI,OAAO;IACpC,UAAU,IAAI;EAChB;AACF;ACtEA,SAAS,YAAY,QAA6D;AAChF,MAAI,CAAC,OAAO,UAAU,CAAC,OAAO,WAAW;AACvC,UAAM,IAAI;MACR;MACA;IACF;EACF;AACA,SAAO,EAAE,QAAQ,OAAO,QAAQ,WAAW,OAAO,UAAU;AAC9D;AAEA,SAAS,iBAAiB,OAA6B;AACrD,MAAI,CAAC,MAAO,QAAO;AACnB,QAAM,UAAU,OAAO,QAAQ,KAAK,EAAE,OAAO,CAAC,CAAC,EAAE,CAAC,MAAM,MAAM,UAAa,MAAM,IAAI;AACrF,MAAI,QAAQ,WAAW,EAAG,QAAO;AACjC,QAAM,SAAS,IAAI,gBAAgB;AACnC,aAAW,CAAC,GAAG,CAAC,KAAK,QAAS,QAAO,IAAI,GAAG,OAAO,CAAC,CAAC;AACrD,SAAO,OAAO,SAAS;AACzB;AAEA,SAAS,mBACP,QACA,QACAC,OACA,OACA,UAC2E;AAC3E,QAAM,EAAE,QAAQ,UAAU,IAAI,YAAY,MAAM;AAChD,QAAM,YAAY,KAAK,IAAI,EAAE,SAAS;AACtC,QAAM,SAAkC,EAAE,GAAG,OAAO,UAAU;AAE9D,QAAM,aAAa,OAAO,KAAK,MAAM,EAAE,KAAK;AAC5C,QAAM,cAAc,WAAW,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,OAAO,CAAC,CAAC,EAAE,EAAE,KAAK,GAAG;AACvE,QAAM,UAAU,GAAGA,KAAI,IAAI,WAAW;AAEtC,MAAI,UAAU,GAAG,MAAM,GAAG,OAAO;AACjC,MAAI,YAAY,KAAM,YAAW;AACjC,QAAM,YAAY,OAAO,WAAW,UAAU,SAAS,EAAE,OAAO,OAAO,EAAE,OAAO,KAAK;AAErF,QAAM,MAAM,GAAG,OAAO,OAAO,GAAG,OAAO;AACvC,QAAM,UAAU;IACd,cAAc;IACd,oBAAoB;IACpB,gBAAgB;EAClB;AACA,SAAO,EAAE,KAAK,SAAS,SAAS;AAClC;AAEA,eAAe,aAAa,KAAgC;AAC1D,MAAI;AACF,WAAO,MAAM,IAAI,KAAK;EACxB,QAAQ;AACN,WAAO;EACT;AACF;AAEO,IAAM,mBAAN,MAAuB;EACX;EACV,YAAY,QAAsB;AACvC,SAAK,SAAS;EAChB;EAEA,MAAa,UAA2BA,OAAc,QAAqB,CAAC,GAAkC;AAC5G,UAAM,KAAK,iBAAiB,KAAK;AACjC,UAAM,WAAW,KAAK,GAAGA,KAAI,IAAI,EAAE,KAAKA;AACxC,UAAM,MAAM,GAAG,KAAK,OAAO,OAAO,GAAG,QAAQ;AAC7C,UAAM,MAAM,MAAM,MAAM,KAAK,EAAE,QAAQ,OAAO,SAAS,EAAE,gBAAgB,mBAAmB,EAAE,CAAC;AAC/F,QAAI,CAAC,IAAI,IAAI;AACX,YAAM,MAAM,MAAM,aAAa,GAAG;AAClC,YAAM,IAAI,eAAe,QAAQ,IAAI,MAAM,KAAK,OAAO,IAAI,UAAU,IAAI,EAAE,QAAQ,IAAI,QAAQ,UAAU,cAAc,IAAI,CAAC;IAC9H;AACA,UAAM,OAAQ,MAAM,IAAI,KAAK;AAC7B,WAAO,EAAE,UAAU,cAAa,oBAAI,KAAK,GAAE,YAAY,GAAG,KAAK;EACjE;EAEA,MAAa,UAA2BA,OAAc,QAAqB,CAAC,GAAkC;AAC5G,UAAM,EAAE,KAAK,QAAQ,IAAI,mBAAmB,KAAK,QAAQ,OAAOA,OAAM,OAAO,IAAI;AACjF,UAAM,WAAW,GAAGA,KAAI,IAAI,iBAAiB,EAAE,GAAG,OAAO,WAAW,MAAM,CAAC,CAAC;AAC5E,UAAM,MAAM,MAAM,MAAM,KAAK,EAAE,QAAQ,OAAO,QAAQ,CAAC;AACvD,QAAI,CAAC,IAAI,IAAI;AACX,YAAM,MAAM,MAAM,aAAa,GAAG;AAClC,YAAM,IAAI,eAAe,QAAQ,IAAI,MAAM,KAAK,OAAO,IAAI,UAAU,IAAI,EAAE,QAAQ,IAAI,QAAQ,UAAUA,OAAM,cAAc,IAAI,CAAC;IACpI;AACA,UAAM,OAAQ,MAAM,IAAI,KAAK;AAC7B,WAAO,EAAE,UAAUA,OAAM,cAAa,oBAAI,KAAK,GAAE,YAAY,GAAG,KAAK;EACvE;EAEA,MAAa,WAA4BA,OAAc,MAA8D;AACnH,UAAM,WAAW,KAAK,UAAU,IAAI;AACpC,UAAM,EAAE,KAAK,SAAS,UAAU,GAAG,IAAI,mBAAmB,KAAK,QAAQ,QAAQA,OAAM,CAAC,GAAG,QAAQ;AACjG,UAAM,MAAM,MAAM,MAAM,KAAK,EAAE,QAAQ,QAAQ,SAAS,MAAM,MAAM,OAAU,CAAC;AAC/E,QAAI,CAAC,IAAI,IAAI;AACX,YAAM,MAAM,MAAM,aAAa,GAAG;AAClC,YAAM,IAAI,eAAe,QAAQ,IAAI,MAAM,KAAK,OAAO,IAAI,UAAU,IAAI,EAAE,QAAQ,IAAI,QAAQ,UAAUA,OAAM,cAAc,IAAI,CAAC;IACpI;AACA,UAAM,OAAQ,MAAM,IAAI,KAAK;AAC7B,WAAO,EAAE,UAAUA,OAAM,cAAa,oBAAI,KAAK,GAAE,YAAY,GAAG,KAAK;EACvE;EAEA,MAAa,aAA8BA,OAAc,MAA8D;AACrH,UAAM,WAAW,KAAK,UAAU,IAAI;AACpC,UAAM,EAAE,KAAK,SAAS,UAAU,GAAG,IAAI,mBAAmB,KAAK,QAAQ,UAAUA,OAAM,CAAC,GAAG,QAAQ;AACnG,UAAM,MAAM,MAAM,MAAM,KAAK,EAAE,QAAQ,UAAU,SAAS,MAAM,MAAM,OAAU,CAAC;AACjF,QAAI,CAAC,IAAI,IAAI;AACX,YAAM,MAAM,MAAM,aAAa,GAAG;AAClC,YAAM,IAAI,eAAe,QAAQ,IAAI,MAAM,KAAK,OAAO,IAAI,UAAU,IAAI,EAAE,QAAQ,IAAI,QAAQ,UAAUA,OAAM,cAAc,IAAI,CAAC;IACpI;AACA,UAAM,OAAQ,MAAM,IAAI,KAAK;AAC7B,WAAO,EAAE,UAAUA,OAAM,cAAa,oBAAI,KAAK,GAAE,YAAY,GAAG,KAAK;EACvE;AACF;AC/GO,SAAS,sBAAkC;AAChD,SAAO;IACL;MACE,MAAM;MACN,QAAQ;MACR,SAAS;MACT,aAAa;MACb,aAAa;QACX,MAAM;QACN,sBAAsB;QACtB,YAAY;UACV,QAAQ,EAAE,MAAM,UAAU,aAAa,gBAAgB;UACvD,OAAO,EAAE,MAAM,WAAW,aAAa,kCAAkC;QAC3E;QACA,UAAU,CAAC,QAAQ;MACrB;MACA,MAAM,QAAQ,MAAM,EAAE,OAAO,GAAG;AAC9B,cAAM,SAAS,OAAO,KAAK,MAAM;AACjC,cAAM,QAAQ,KAAK,SAAS,OAAO,SAAY,OAAO,KAAK,KAAK;AAChE,cAAM,IAAiB,EAAE,OAAO;AAChC,YAAI,SAAS,QAAQ,OAAO,SAAS,KAAK,EAAG,GAAE,QAAQ;AACvD,gBAAQ,MAAM,OAAO,UAAU,wBAAwB,CAAC,GAAG;MAC7D;IACF;IACA;MACE,MAAM;MACN,QAAQ;MACR,SAAS;MACT,aAAa;MACb,aAAa;QACX,MAAM;QACN,sBAAsB;QACtB,YAAY;UACV,QAAQ,EAAE,MAAM,UAAU,aAAa,gBAAgB;UACvD,OAAO,EAAE,MAAM,WAAW,aAAa,oBAAoB;QAC7D;QACA,UAAU,CAAC,QAAQ;MACrB;MACA,MAAM,QAAQ,MAAM,EAAE,OAAO,GAAG;AAC9B,cAAM,SAAS,OAAO,KAAK,MAAM;AACjC,cAAM,QAAQ,KAAK,SAAS,OAAO,SAAY,OAAO,KAAK,KAAK;AAChE,cAAM,IAAiB,EAAE,OAAO;AAChC,YAAI,SAAS,QAAQ,OAAO,SAAS,KAAK,EAAG,GAAE,QAAQ;AACvD,gBAAQ,MAAM,OAAO,UAAU,yBAAyB,CAAC,GAAG;MAC9D;IACF;IACA;MACE,MAAM;MACN,QAAQ;MACR,SAAS;MACT,aACE;MACF,aAAa;QACX,MAAM;QACN,sBAAsB;QACtB,YAAY;UACV,SAAS;YACP,MAAM;YACN,aAAa;UACf;UACA,MAAM;YACJ,MAAM;YACN,MAAM,CAAC,QAAQ,MAAM;YACrB,aAAa;UACf;QACF;MACF;MACA,MAAM,QAAQ,MAAM,EAAE,OAAO,GAAG;AAC9B,cAAM,IAAiB,CAAC;AACxB,YAAI,KAAK,QAAS,GAAE,UAAU,OAAO,KAAK,OAAO;AACjD,YAAI,CAAC,KAAK,WAAW,KAAK,KAAM,GAAE,OAAO,OAAO,KAAK,IAAI;AACzD,gBAAQ,MAAM,OAAO,UAAU,0BAA0B,CAAC,GAAG;MAC/D;IACF;IACA;MACE,MAAM;MACN,QAAQ;MACR,SAAS;MACT,aAAa;MACb,aAAa;QACX,MAAM;QACN,sBAAsB;QACtB,YAAY;UACV,QAAQ,EAAE,MAAM,UAAU,aAAa,kEAAkE;UACzG,MAAM,EAAE,MAAM,UAAU,MAAM,CAAC,QAAQ,MAAM,GAAG,aAAa,8CAA8C;QAC7G;MACF;MACA,MAAM,QAAQ,MAAM,EAAE,OAAO,GAAG;AAC9B,cAAM,IAAiB,CAAC;AACxB,YAAI,KAAK,OAAQ,GAAE,SAAS,OAAO,KAAK,MAAM;AAC9C,YAAI,KAAK,KAAM,GAAE,OAAO,OAAO,KAAK,IAAI;AACxC,gBAAQ,MAAM,OAAO,UAAU,0BAA0B,CAAC,GAAG;MAC/D;IACF;IACA;MACE,MAAM;MACN,QAAQ;MACR,SAAS;MACT,aAAa;MACb,aAAa;QACX,MAAM;QACN,sBAAsB;QACtB,YAAY;UACV,QAAQ,EAAE,MAAM,UAAU,aAAa,gBAAgB;UACvD,UAAU,EAAE,MAAM,UAAU,MAAM,CAAC,MAAM,MAAM,OAAO,OAAO,OAAO,MAAM,MAAM,OAAO,IAAI,GAAG,aAAa,kBAAkB;UAC7H,SAAS,EAAE,MAAM,WAAW,aAAa,4BAA4B;UACrE,OAAO,EAAE,MAAM,WAAW,aAAa,uBAAuB;QAChE;QACA,UAAU,CAAC,UAAU,UAAU;MACjC;MACA,MAAM,QAAQ,MAAM,EAAE,OAAO,GAAG;AAC9B,cAAM,SAAS,OAAO,KAAK,MAAM;AACjC,cAAM,WAAW,OAAO,KAAK,QAAQ;AACrC,cAAM,IAAiB,EAAE,QAAQ,SAAS;AAC1C,YAAI,KAAK,WAAW,KAAM,GAAE,UAAU,OAAO,KAAK,OAAO;AACzD,YAAI,KAAK,SAAS,KAAM,GAAE,QAAQ,OAAO,KAAK,KAAK;AACnD,gBAAQ,MAAM,OAAO,UAAU,yBAAyB,CAAC,GAAG;MAC9D;IACF;EACF;AACF;ACzHO,SAAS,uBAAmC;AACjD,SAAO;IACL;MACE,MAAM;MACN,QAAQ;MACR,SAAS;MACT,aAAa;MACb,aAAa,EAAE,MAAM,UAAU,sBAAsB,OAAO,YAAY,CAAC,EAAE;MAC3E,MAAM,QAAQ,OAAO,EAAE,OAAO,GAAG;AAC/B,gBAAQ,MAAM,OAAO,UAAU,0BAA0B,GAAG;MAC9D;IACF;EACF;AACF;ACZO,SAAS,sBAAkC;AAChD,SAAO;IACL;MACE,MAAM;MACN,QAAQ;MACR,SAAS;MACT,aACE;MACF,aAAa;QACX,MAAM;QACN,sBAAsB;QACtB,YAAY;UACV,QAAQ,EAAE,MAAM,UAAU,aAAa,gBAAgB;UACvD,MAAM,EAAE,MAAM,UAAU,MAAM,CAAC,OAAO,MAAM,EAAE;UAC9C,MAAM,EAAE,MAAM,UAAU,MAAM,CAAC,SAAS,QAAQ,EAAE;UAClD,eAAe,EAAE,MAAM,UAAU,aAAa,0CAA0C;UACxF,MAAM,EAAE,MAAM,UAAU,aAAa,+CAA+C;UACpF,OAAO,EAAE,MAAM,UAAU,aAAa,2BAA2B;UACjE,QAAQ,EAAE,MAAM,UAAU,aAAa,wCAAwC;UAC/E,KAAK,EAAE,MAAM,WAAW,aAAa,qCAAqC;QAC5E;QACA,UAAU,CAAC,UAAU,QAAQ,MAAM;MACrC;MACA,MAAM,QAAQ,MAAM,EAAE,QAAQ,OAAO,GAAG;AACtC,YAAI,OAAO,UAAU;AACnB,gBAAM,IAAI,MAAM,qEAAqE;QACvF;AACA,cAAM,OAAgC,CAAC;AACvC,YAAI,KAAK,UAAU,KAAM,MAAK,SAAS,OAAO,KAAK,MAAM;AACzD,YAAI,KAAK,QAAQ,KAAM,MAAK,OAAO,OAAO,KAAK,IAAI;AACnD,YAAI,KAAK,QAAQ,KAAM,MAAK,OAAO,OAAO,KAAK,IAAI;AACnD,YAAI,KAAK,iBAAiB,KAAM,MAAK,gBAAgB,OAAO,KAAK,aAAa;AAC9E,YAAI,KAAK,QAAQ,KAAM,MAAK,OAAO,OAAO,KAAK,IAAI;AACnD,YAAI,KAAK,SAAS,KAAM,MAAK,QAAQ,OAAO,KAAK,KAAK;AACtD,YAAI,KAAK,UAAU,KAAM,MAAK,SAAS,OAAO,KAAK,MAAM;AACzD,YAAI,KAAK,OAAO,KAAM,MAAK,MAAM,QAAQ,KAAK,GAAG;AACjD,gBAAQ,MAAM,OAAO,WAAW,uBAAuB,IAAI,GAAG;MAChE;IACF;IACA;MACE,MAAM;MACN,QAAQ;MACR,SAAS;MACT,aAAa;MACb,aAAa;QACX,MAAM;QACN,sBAAsB;QACtB,YAAY;UACV,QAAQ,EAAE,MAAM,UAAU,aAAa,gBAAgB;UACvD,SAAS,EAAE,MAAM,WAAW,aAAa,WAAW;QACtD;QACA,UAAU,CAAC,UAAU,SAAS;MAChC;MACA,MAAM,QAAQ,MAAM,EAAE,OAAO,GAAG;AAC9B,cAAM,SAAS,OAAO,KAAK,MAAM;AACjC,cAAM,UAAU,OAAO,KAAK,OAAO;AACnC,gBAAQ,MAAM,OAAO,UAAU,uBAAuB,EAAE,QAAQ,QAAQ,CAAC,GAAG;MAC9E;IACF;IACA;MACE,MAAM;MACN,QAAQ;MACR,SAAS;MACT,aAAa;MACb,aAAa;QACX,MAAM;QACN,sBAAsB;QACtB,YAAY;UACV,QAAQ,EAAE,MAAM,UAAU,aAAa,gBAAgB;UACvD,eAAe,EAAE,MAAM,UAAU,aAAa,kBAAkB;QAClE;QACA,UAAU,CAAC,UAAU,eAAe;MACtC;MACA,MAAM,QAAQ,MAAM,EAAE,OAAO,GAAG;AAC9B,cAAM,SAAS,OAAO,KAAK,MAAM;AACjC,cAAM,gBAAgB,OAAO,KAAK,aAAa;AAC/C,gBAAQ,MAAM,OAAO,UAAU,sCAAsC,EAAE,QAAQ,cAAc,CAAC,GAAG;MACnG;IACF;IACA;MACE,MAAM;MACN,QAAQ;MACR,SAAS;MACT,aAAa;MACb,aAAa;QACX,MAAM;QACN,sBAAsB;QACtB,YAAY,EAAE,QAAQ,EAAE,MAAM,UAAU,aAAa,gBAAgB,EAAE;QACvE,UAAU,CAAC,QAAQ;MACrB;MACA,MAAM,QAAQ,MAAM,EAAE,OAAO,GAAG;AAC9B,cAAM,SAAS,OAAO,KAAK,MAAM;AACjC,gBAAQ,MAAM,OAAO,UAAU,4BAA4B,EAAE,OAAO,CAAC,GAAG;MAC1E;IACF;IACA;MACE,MAAM;MACN,QAAQ;MACR,SAAS;MACT,aAAa;MACb,aAAa;QACX,MAAM;QACN,sBAAsB;QACtB,YAAY;UACV,QAAQ,EAAE,MAAM,UAAU,aAAa,gBAAgB;UACvD,OAAO,EAAE,MAAM,WAAW,aAAa,oBAAoB;QAC7D;QACA,UAAU,CAAC,QAAQ;MACrB;MACA,MAAM,QAAQ,MAAM,EAAE,OAAO,GAAG;AAC9B,cAAM,SAAS,OAAO,KAAK,MAAM;AACjC,cAAM,IAAiB,EAAE,OAAO;AAChC,YAAI,KAAK,SAAS,KAAM,GAAE,QAAQ,OAAO,KAAK,KAAK;AACnD,gBAAQ,MAAM,OAAO,UAAU,2BAA2B,CAAC,GAAG;MAChE;IACF;IACA;MACE,MAAM;MACN,QAAQ;MACR,SAAS;MACT,aAAa;MACb,aAAa;QACX,MAAM;QACN,sBAAsB;QACtB,YAAY;UACV,QAAQ,EAAE,MAAM,UAAU,aAAa,gBAAgB;UACvD,SAAS,EAAE,MAAM,WAAW,aAAa,WAAW;QACtD;QACA,UAAU,CAAC,UAAU,SAAS;MAChC;MACA,MAAM,QAAQ,MAAM,EAAE,QAAQ,OAAO,GAAG;AACtC,YAAI,OAAO,UAAU;AACnB,gBAAM,IAAI,MAAM,wEAAwE;QAC1F;AACA,cAAM,SAAS,OAAO,KAAK,MAAM;AACjC,cAAM,UAAU,OAAO,KAAK,OAAO;AACnC,gBAAQ,MAAM,OAAO,aAAa,uBAAuB,EAAE,QAAQ,QAAQ,CAAC,GAAG;MACjF;IACF;IACA;MACE,MAAM;MACN,QAAQ;MACR,SAAS;MACT,aAAa;MACb,aAAa;QACX,MAAM;QACN,sBAAsB;QACtB,YAAY;UACV,QAAQ,EAAE,MAAM,UAAU,aAAa,gBAAgB;UACvD,WAAW,EAAE,MAAM,WAAW,aAAa,8BAA8B;UACzE,SAAS,EAAE,MAAM,WAAW,aAAa,4BAA4B;QACvE;QACA,UAAU,CAAC,QAAQ;MACrB;MACA,MAAM,QAAQ,MAAM,EAAE,OAAO,GAAG;AAC9B,cAAM,SAAS,OAAO,KAAK,MAAM;AACjC,cAAM,IAAiB,EAAE,OAAO;AAChC,YAAI,KAAK,aAAa,KAAM,GAAE,YAAY,OAAO,KAAK,SAAS;AAC/D,YAAI,KAAK,WAAW,KAAM,GAAE,UAAU,OAAO,KAAK,OAAO;AACzD,gBAAQ,MAAM,OAAO,UAAU,uBAAuB,CAAC,GAAG;MAC5D;IACF;IACA;MACE,MAAM;MACN,QAAQ;MACR,SAAS;MACT,aAAa;MACb,aAAa;QACX,MAAM;QACN,sBAAsB;QACtB,YAAY,EAAE,QAAQ,EAAE,MAAM,UAAU,aAAa,gBAAgB,EAAE;QACvE,UAAU,CAAC,QAAQ;MACrB;MACA,MAAM,QAAQ,MAAM,EAAE,QAAQ,OAAO,GAAG;AACtC,YAAI,OAAO,UAAU;AACnB,gBAAM,IAAI,MAAM,gEAAgE;QAClF;AACA,cAAM,SAAS,OAAO,KAAK,MAAM;AACjC,gBAAQ,MAAM,OAAO,aAAa,2BAA2B,EAAE,OAAO,CAAC,GAAG;MAC5E;IACF;EACF;AACF;AClLO,IAAM,sCAAsC;EACjD;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACF;AAEA,IAAM,qBAAqB,IAAI,IAAY,mCAAmC;AAE9E,SAAS,iBAAiB,OAAgB,OAAuB;AAC/D,MAAI,OAAO,UAAU,YAAY,MAAM,KAAK,EAAE,WAAW,GAAG;AAC1D,UAAM,IAAI,MAAM,YAAY,KAAK,+BAA+B;EAClE;AACA,SAAO,MAAM,KAAK;AACpB;AAEA,SAAS,eAAe,OAAgB,OAAuB;AAC7D,MAAI,OAAO,UAAU,YAAY,CAAC,OAAO,SAAS,KAAK,GAAG;AACxD,UAAM,IAAI,MAAM,YAAY,KAAK,4BAA4B;EAC/D;AACA,SAAO;AACT;AAEA,SAAS,iBAAiB,OAAgB,OAAuB;AAC/D,QAAM,IAAI,eAAe,OAAO,KAAK;AACrC,MAAI,KAAK,EAAG,OAAM,IAAI,MAAM,YAAY,KAAK,yBAAyB;AACtE,SAAO;AACT;AAEA,SAAS,kBAAkB,OAAgB,OAAuB;AAChE,QAAM,IAAI,iBAAiB,OAAO,KAAK;AACvC,MAAI,CAAC,OAAO,UAAU,CAAC,GAAG;AACxB,UAAM,IAAI,MAAM,YAAY,KAAK,+BAA+B;EAClE;AACA,SAAO;AACT;AAEA,SAAS,UAAU,OAAgB,OAAwB;AACzD,MAAI,OAAO,UAAU,WAAW;AAC9B,UAAM,IAAI,MAAM,YAAY,KAAK,sBAAsB;EACzD;AACA,SAAO;AACT;AAEA,SAAS,WAAW,OAAe,OAAe,SAAkC;AAClF,MAAI,CAAC,QAAQ,SAAS,KAAK,GAAG;AAC5B,UAAM,IAAI,MAAM,YAAY,KAAK,sBAAsB,QAAQ,KAAK,IAAI,CAAC,GAAG;EAC9E;AACF;AAEA,SAAS,wBAAwB,OAAgB,OAAuB;AACtE,QAAM,IAAI,iBAAiB,OAAO,KAAK;AACvC,MAAI,CAAC,gBAAgB,KAAK,CAAC,GAAG;AAC5B,UAAM,IAAI,MAAM,YAAY,KAAK,sCAAsC;EACzE;AACA,QAAM,IAAI,OAAO,CAAC;AAClB,MAAI,CAAC,OAAO,SAAS,CAAC,KAAK,KAAK,GAAG;AACjC,UAAM,IAAI,MAAM,YAAY,KAAK,sCAAsC;EACzE;AACA,SAAO;AACT;AAEA,SAAS,6BAA6B,OAAgB,OAAuB;AAC3E,MAAI,OAAO,UAAU,YAAY,OAAO,SAAS,KAAK,KAAK,QAAQ,GAAG;AACpE,WAAO,OAAO,KAAK;EACrB;AACA,SAAO,wBAAwB,OAAO,KAAK;AAC7C;AAEA,SAAS,2BAA2B,OAAgB,OAAuB;AACzE,QAAM,IAAI,iBAAiB,OAAO,KAAK;AACvC,MAAI,CAAC,gBAAgB,KAAK,CAAC,GAAG;AAC5B,UAAM,IAAI,MAAM,YAAY,KAAK,0CAA0C;EAC7E;AACA,QAAM,IAAI,OAAO,CAAC;AAClB,MAAI,CAAC,OAAO,SAAS,CAAC,KAAK,IAAI,GAAG;AAChC,UAAM,IAAI,MAAM,YAAY,KAAK,0CAA0C;EAC7E;AACA,SAAO;AACT;AAEA,SAAS,iBAAiB,OAAgB,OAAuB;AAC/D,MAAI,OAAO,UAAU,UAAU;AAC7B,UAAM,IAAI,MAAM,YAAY,KAAK,qBAAqB;EACxD;AACA,SAAO;AACT;AAEA,SAAS,4BAA4B,OAAgB,OAAuB;AAC1E,QAAM,IAAI,eAAe,OAAO,KAAK;AACrC,MAAI,IAAI,EAAG,OAAM,IAAI,MAAM,YAAY,KAAK,0BAA0B;AACtE,SAAO;AACT;AAGO,SAAS,6CAA6C,KAAuD;AAClH,QAAM,OAAO,EAAE,GAAG,IAAI;AACtB,SAAO,KAAK;AACZ,SAAO,KAAK;AACZ,SAAO,KAAK;AAEZ,aAAW,KAAK,OAAO,KAAK,IAAI,GAAG;AACjC,QAAI,CAAC,mBAAmB,IAAI,CAAC,GAAG;AAC9B,YAAM,IAAI,MAAM,iCAAiC,CAAC,oBAAoB,oCAAoC,KAAK,IAAI,CAAC,GAAG;IACzH;EACF;AAEA,QAAM,MAAM,6BAA6B,KAAK,KAAK,iBAAiB;AACpE,QAAM,SAAS,6BAA6B,KAAK,QAAQ,oBAAoB;AAC7E,MAAI,OAAO,GAAG,KAAK,OAAO,MAAM,GAAG;AACjC,UAAM,IAAI,MAAM,mDAAmD;EACrE;AACA,QAAM,MAAM,kBAAkB,KAAK,KAAK,iBAAiB;AACzD,QAAM,WAAW,iBAAiB,KAAK,WAAW,uBAAuB;AACzE,aAAW,UAAU,yBAAyB,CAAC,cAAc,WAAW,CAAC;AACzE,QAAM,QAAQ,iBAAiB,KAAK,OAAO,mBAAmB;AAC9D,aAAW,OAAO,qBAAqB,CAAC,QAAQ,SAAS,UAAU,CAAC;AACpE,QAAM,WAAW,iBAAiB,KAAK,UAAU,sBAAsB;AACvE,QAAM,kBAAkB,6BAA6B,KAAK,iBAAiB,6BAA6B;AAExG,QAAM,MAA+B;IACnC;IACA;IACA;IACA,WAAW;IACX;IACA;IACA;EACF;AAEA,MAAI,KAAK,eAAe,MAAM;AAC5B,QAAI,cAAc,2BAA2B,KAAK,aAAa,yBAAyB;EAC1F;AACA,MAAI,KAAK,aAAa,KAAM,KAAI,YAAY,iBAAiB,KAAK,WAAW,uBAAuB;AACpG,MAAI,KAAK,sBAAsB,MAAM;AACnC,UAAM,IAAI,iBAAiB,KAAK,oBAAoB,gCAAgC;AACpF,eAAW,GAAG,kCAAkC,CAAC,MAAM,GAAG,CAAC;AAC3D,QAAI,qBAAqB;EAC3B;AACA,MAAI,KAAK,gBAAgB,MAAM;AAC7B,UAAM,IAAI,iBAAiB,KAAK,cAAc,0BAA0B;AACxE,eAAW,GAAG,4BAA4B,CAAC,SAAS,iBAAiB,gBAAgB,aAAa,CAAC;AACnG,QAAI,eAAe;EACrB;AACA,MAAI,KAAK,YAAY,KAAM,KAAI,WAAW,iBAAiB,KAAK,UAAU,sBAAsB;AAChG,MAAI,KAAK,iBAAiB,KAAM,KAAI,gBAAgB,4BAA4B,KAAK,eAAe,2BAA2B;AAC/H,MAAI,KAAK,kBAAkB,MAAM;AAC/B,UAAM,IAAI,iBAAiB,KAAK,gBAAgB,4BAA4B;AAC5E,eAAW,GAAG,8BAA8B,CAAC,SAAS,iBAAiB,gBAAgB,aAAa,CAAC;AACrG,QAAI,iBAAiB;EACvB;AACA,MAAI,KAAK,cAAc,KAAM,KAAI,aAAa,iBAAiB,KAAK,YAAY,wBAAwB;AACxG,MAAI,KAAK,mBAAmB,KAAM,KAAI,kBAAkB,4BAA4B,KAAK,iBAAiB,6BAA6B;AACvI,MAAI,KAAK,gBAAgB,KAAM,KAAI,eAAe,iBAAiB,KAAK,cAAc,0BAA0B;AAChH,MAAI,KAAK,cAAc,KAAM,KAAI,aAAa,iBAAiB,KAAK,YAAY,wBAAwB;AACxG,MAAI,KAAK,cAAc,KAAM,KAAI,aAAa,iBAAiB,KAAK,YAAY,wBAAwB;AACxG,MAAI,KAAK,kBAAkB,MAAM;AAC/B,UAAM,IAAI,iBAAiB,KAAK,gBAAgB,4BAA4B;AAC5E,eAAW,GAAG,8BAA8B,CAAC,QAAQ,iBAAiB,mBAAmB,CAAC;AAC1F,QAAI,iBAAiB;EACvB;AACA,MAAI,KAAK,gBAAgB,KAAM,KAAI,eAAe,iBAAiB,KAAK,cAAc,0BAA0B;AAChH,MAAI,KAAK,sBAAsB,KAAM,KAAI,qBAAqB,iBAAiB,KAAK,oBAAoB,gCAAgC;AACxI,MAAI,KAAK,0BAA0B,KAAM,KAAI,yBAAyB,iBAAiB,KAAK,wBAAwB,oCAAoC;AACxJ,MAAI,KAAK,wBAAwB,KAAM,KAAI,uBAAuB,iBAAiB,KAAK,sBAAsB,kCAAkC;AAChJ,MAAI,KAAK,YAAY,KAAM,KAAI,WAAW,iBAAiB,KAAK,UAAU,sBAAsB;AAChG,MAAI,KAAK,WAAW,KAAM,KAAI,UAAU,iBAAiB,KAAK,SAAS,qBAAqB;AAC5F,MAAI,KAAK,eAAe,KAAM,KAAI,cAAc,iBAAiB,KAAK,aAAa,yBAAyB;AAC5G,MAAI,KAAK,uBAAuB,KAAM,KAAI,sBAAsB,iBAAiB,KAAK,qBAAqB,iCAAiC;AAC5I,MAAI,KAAK,2BAA2B,KAAM,KAAI,0BAA0B,iBAAiB,KAAK,yBAAyB,qCAAqC;AAC5J,MAAI,KAAK,wBAAwB,KAAM,KAAI,uBAAuB,iBAAiB,KAAK,sBAAsB,kCAAkC;AAChJ,MAAI,KAAK,yBAAyB,KAAM,KAAI,wBAAwB,iBAAiB,KAAK,uBAAuB,mCAAmC;AACpJ,MAAI,KAAK,YAAY,MAAM;AACzB,UAAM,IAAI,iBAAiB,KAAK,UAAU,sBAAsB;AAChE,eAAW,GAAG,wBAAwB,CAAC,iBAAiB,aAAa,iBAAiB,2BAA2B,CAAC;AAClH,QAAI,WAAW;EACjB;AACA,MAAI,KAAK,aAAa,KAAM,KAAI,YAAY,iBAAiB,KAAK,WAAW,uBAAuB;AACpG,MAAI,KAAK,gBAAgB,KAAM,KAAI,eAAe,iBAAiB,KAAK,cAAc,0BAA0B;AAChH,MAAI,KAAK,sBAAsB,KAAM,KAAI,qBAAqB,UAAU,KAAK,oBAAoB,gCAAgC;AAEjI,SAAO;AACT;AAGO,IAAM,uCAAmD;EAC9D,MAAM;EACN,sBAAsB;EACtB,aAAa;EACb,UAAU,CAAC,OAAO,UAAU,OAAO,aAAa,SAAS,YAAY,iBAAiB;EACtF,YAAY;IACV,KAAK,EAAE,MAAM,UAAU,aAAa,mBAAmB;IACvD,QAAQ,EAAE,MAAM,UAAU,aAAa,mBAAmB;IAC1D,KAAK,EAAE,MAAM,UAAU,aAAa,wBAAwB;IAC5D,WAAW;MACT,MAAM;MACN,MAAM,CAAC,cAAc,WAAW;MAChC,aAAa;IACf;IACA,OAAO;MACL,MAAM;MACN,MAAM,CAAC,QAAQ,SAAS,UAAU;MAClC,aAAa;IACf;IACA,UAAU,EAAE,MAAM,UAAU,aAAa,sBAAsB;IAC/D,aAAa,EAAE,MAAM,UAAU,aAAa,iCAAiC;IAC7E,iBAAiB,EAAE,MAAM,UAAU,aAAa,oBAAoB;IACpE,WAAW,EAAE,MAAM,UAAU,aAAa,qCAAqC;IAC/E,oBAAoB,EAAE,MAAM,UAAU,MAAM,CAAC,MAAM,GAAG,GAAG,aAAa,oBAAoB;IAC1F,cAAc;MACZ,MAAM;MACN,MAAM,CAAC,SAAS,iBAAiB,gBAAgB,aAAa;MAC9D,aAAa;IACf;IACA,UAAU,EAAE,MAAM,UAAU,aAAa,kBAAkB;IAC3D,eAAe,EAAE,MAAM,UAAU,aAAa,4BAA4B;IAC1E,gBAAgB;MACd,MAAM;MACN,MAAM,CAAC,SAAS,iBAAiB,gBAAgB,aAAa;MAC9D,aAAa;IACf;IACA,YAAY,EAAE,MAAM,UAAU,aAAa,oBAAoB;IAC/D,iBAAiB,EAAE,MAAM,UAAU,aAAa,8BAA8B;IAC9E,cAAc,EAAE,MAAM,UAAU,aAAa,yCAAyC;IACtF,YAAY,EAAE,MAAM,UAAU,aAAa,uBAAuB;IAClE,YAAY,EAAE,MAAM,UAAU,aAAa,sBAAsB;IACjE,gBAAgB;MACd,MAAM;MACN,MAAM,CAAC,QAAQ,iBAAiB,mBAAmB;MACnD,aAAa;IACf;IACA,cAAc,EAAE,MAAM,UAAU,aAAa,wCAAwC;IACrF,oBAAoB,EAAE,MAAM,UAAU,aAAa,4CAA4C;IAC/F,wBAAwB,EAAE,MAAM,UAAU,aAAa,kCAAkC;IACzF,sBAAsB,EAAE,MAAM,UAAU,aAAa,8CAA8C;IACnG,UAAU,EAAE,MAAM,UAAU,aAAa,+BAA+B;IACxE,SAAS,EAAE,MAAM,UAAU,aAAa,aAAa;IACrD,aAAa,EAAE,MAAM,UAAU,aAAa,iCAAiC;IAC7E,qBAAqB,EAAE,MAAM,UAAU,aAAa,WAAW;IAC/D,yBAAyB,EAAE,MAAM,UAAU,aAAa,eAAe;IACvE,sBAAsB,EAAE,MAAM,UAAU,aAAa,0BAA0B;IAC/E,uBAAuB,EAAE,MAAM,UAAU,aAAa,wBAAwB;IAC9E,UAAU;MACR,MAAM;MACN,MAAM,CAAC,iBAAiB,aAAa,iBAAiB,2BAA2B;MACjF,aAAa;IACf;IACA,WAAW,EAAE,MAAM,UAAU,aAAa,0BAA0B;IACpE,cAAc,EAAE,MAAM,UAAU,aAAa,0BAA0B;IACvE,oBAAoB,EAAE,MAAM,WAAW,aAAa,eAAe;EACrE;AACF;AAGO,IAAM,yCAAqD;EAChE,MAAM;EACN,sBAAsB;EACtB,UAAU,CAAC,QAAQ,SAAS,aAAa;EACzC,YAAY;IACV,MAAM,EAAE,MAAM,UAAU,aAAa,yDAAyD;IAC9F,OAAO,EAAE,MAAM,UAAU,aAAa,6BAA6B;IACnE,UAAU,EAAE,MAAM,UAAU,aAAa,mEAAmE;IAC5G,UAAU,EAAE,MAAM,UAAU,aAAa,iCAAiC;IAC1E,UAAU,EAAE,MAAM,UAAU,aAAa,sBAAsB;IAC/D,gBAAgB,EAAE,MAAM,UAAU,aAAa,8BAA8B;IAC7E,aAAa;IACb,UAAU,EAAE,MAAM,WAAW,aAAa,yDAAyD;EACrG;AACF;AC3SA,SAASC,kBAAiB,OAAgB,OAAuB;AAC/D,MAAI,OAAO,UAAU,YAAY,MAAM,KAAK,EAAE,WAAW,GAAG;AAC1D,UAAM,IAAI,MAAM,YAAY,KAAK,+BAA+B;EAClE;AACA,SAAO,MAAM,KAAK;AACpB;AAEA,SAASC,gBAAe,OAAgB,OAAuB;AAC7D,MAAI,OAAO,UAAU,YAAY,CAAC,OAAO,SAAS,KAAK,GAAG;AACxD,UAAM,IAAI,MAAM,YAAY,KAAK,4BAA4B;EAC/D;AACA,SAAO;AACT;AAEA,SAASC,kBAAiB,OAAgB,OAAuB;AAC/D,QAAM,IAAID,gBAAe,OAAO,KAAK;AACrC,MAAI,KAAK,EAAG,OAAM,IAAI,MAAM,YAAY,KAAK,yBAAyB;AACtE,SAAO;AACT;AAEA,SAASE,mBAAkB,OAAgB,OAAuB;AAChE,QAAM,IAAID,kBAAiB,OAAO,KAAK;AACvC,MAAI,CAAC,OAAO,UAAU,CAAC,GAAG;AACxB,UAAM,IAAI,MAAM,YAAY,KAAK,+BAA+B;EAClE;AACA,SAAO;AACT;AAEA,SAASE,WAAU,OAAgB,OAAwB;AACzD,MAAI,OAAO,UAAU,WAAW;AAC9B,UAAM,IAAI,MAAM,YAAY,KAAK,sBAAsB;EACzD;AACA,SAAO;AACT;AAEA,SAASC,YAAW,OAAe,OAAe,SAAkC;AAClF,MAAI,CAAC,QAAQ,SAAS,KAAK,GAAG;AAC5B,UAAM,IAAI,MAAM,YAAY,KAAK,sBAAsB,QAAQ,KAAK,IAAI,CAAC,GAAG;EAC9E;AACF;AAEA,SAAS,SAAS,OAAgB,OAAwC;AACxE,MAAI,CAAC,SAAS,OAAO,UAAU,YAAY,MAAM,QAAQ,KAAK,GAAG;AAC/D,UAAM,IAAI,MAAM,YAAY,KAAK,0BAA0B;EAC7D;AACA,SAAO;AACT;AAEA,SAASC,yBAAwB,OAAgB,OAAuB;AACtE,QAAM,IAAIN,kBAAiB,OAAO,KAAK;AACvC,MAAI,CAAC,gBAAgB,KAAK,CAAC,GAAG;AAC5B,UAAM,IAAI,MAAM,YAAY,KAAK,sCAAsC;EACzE;AACA,QAAM,IAAI,OAAO,CAAC;AAClB,MAAI,CAAC,OAAO,SAAS,CAAC,KAAK,KAAK,GAAG;AACjC,UAAM,IAAI,MAAM,YAAY,KAAK,sCAAsC;EACzE;AACA,SAAO;AACT;AAEA,SAAS,kBAAkB,MAAsB;AAC/C,SAAO,KAAK,SAAS,OAAO,IAAI,OAAO,GAAG,IAAI;AAChD;AAEO,SAAS,mBAA+B;AAC7C,SAAO;IACL;MACE,MAAM;MACN,QAAQ;MACR,SAAS;MACT,aAAa;MACb,aAAa;QACX,MAAM;QACN,sBAAsB;QACtB,YAAY;UACV,WAAW,EAAE,MAAM,UAAU,aAAa,6BAA6B;UACvE,MAAM,EAAE,MAAM,UAAU,aAAa,0BAA0B;QACjE;QACA,UAAU,CAAC,WAAW;MACxB;MACA,MAAM,QAAQ,MAAM,EAAE,OAAO,GAAG;AAC9B,cAAM,YAAY,OAAO,KAAK,SAAS;AACvC,cAAM,IAAiB,EAAE,UAAU;AACnC,YAAI,KAAK,QAAQ,KAAM,GAAE,OAAO,OAAO,KAAK,IAAI;AAChD,gBAAQ,MAAM,OAAO,UAAU,wCAAwC,CAAC,GAAG;MAC7E;IACF;IACA;MACE,MAAM;MACN,QAAQ;MACR,SAAS;MACT,aACE;MAIF,aAAa;MACb,MAAM,QAAQ,MAAM,EAAE,QAAQ,OAAO,GAAG;AACtC,YAAI,OAAO,UAAU;AACnB,gBAAM,IAAI,MAAM,gEAAgE;QAClF;AACA,cAAM,UAAUA,kBAAiB,KAAK,MAAM,MAAM;AAClD,cAAM,OAAO,kBAAkB,OAAO;AACtC,cAAM,QAAQA,kBAAiB,KAAK,OAAO,OAAO;AAClD,cAAM,WAAW,KAAK,YAAY,OAAOA,kBAAiB,KAAK,UAAU,UAAU,IAAI;AACvF,cAAM,iBAAiB,6CAA6C,SAAS,KAAK,aAAa,aAAa,CAAC;AAC7G,cAAM,MAAM,eAAe;AAC3B,cAAM,WAAW,eAAe;AAChC,cAAM,WAAW,eAAe;AAEhC,cAAM,OAAgC;UACpC;UACA;UACA,aAAa;QACf;AACA,YAAI,YAAY,KAAM,MAAK,WAAW;AACtC,YAAI,KAAK,YAAY,KAAM,MAAK,WAAW,OAAO,KAAK,QAAQ;AAC/D,YAAI,KAAK,YAAY,KAAM,MAAK,WAAW,OAAO,KAAK,QAAQ;AAC/D,YAAI,KAAK,kBAAkB,KAAM,MAAK,iBAAiB,OAAO,KAAK,cAAc;AAEjF,YAAI,KAAK,aAAa,MAAM;AAC1B,iBAAO;YACL,QAAQ;YACR,MAAM;YACN,gBAAgB;cACd;cACA,WAAW;cACX;YACF;YACA,cAAc;UAChB;QACF;AACA,gBAAQ,MAAM,OAAO,WAAW,yCAAyC,IAAI,GAAG;MAClF;IACF;IACA;MACE,MAAM;MACN,QAAQ;MACR,SAAS;MACT,aAAa;MACb,aAAa;QACX,MAAM;QACN,sBAAsB;QACtB,YAAY;UACV,WAAW,EAAE,MAAM,SAAS;UAC5B,MAAM,EAAE,MAAM,UAAU,MAAM,CAAC,aAAa,iBAAiB,mBAAmB,EAAE;UAClF,iBAAiB,EAAE,MAAM,SAAS;UAClC,aAAa,EAAE,MAAM,UAAU;UAC/B,WAAW,EAAE,MAAM,SAAS;UAC5B,QAAQ,EAAE,MAAM,SAAS;UACzB,KAAK,EAAE,MAAM,SAAS;UACtB,KAAK,EAAE,MAAM,SAAS;UACtB,mBAAmB,EAAE,MAAM,SAAS;UACpC,aAAa,EAAE,MAAM,UAAU;UAC/B,YAAY,EAAE,MAAM,UAAU;UAC9B,YAAY,EAAE,MAAM,SAAS;UAC7B,gBAAgB,EAAE,MAAM,UAAU,MAAM,CAAC,QAAQ,eAAe,EAAE;UAClE,WAAW,EAAE,MAAM,SAAS;UAC5B,oBAAoB,EAAE,MAAM,UAAU,MAAM,CAAC,KAAK,IAAI,EAAE;UACxD,UAAU,EAAE,MAAM,SAAS;UAC3B,mBAAmB,EAAE,MAAM,SAAS;QACtC;QACA,UAAU,CAAC,aAAa,QAAQ,eAAe,WAAW;MAC5D;MACA,MAAM,QAAQ,MAAM,EAAE,QAAQ,OAAO,GAAG;AACtC,YAAI,OAAO,UAAU;AACnB,gBAAM,IAAI,MAAM,gEAAgE;QAClF;AACA,cAAM,YAAYA,kBAAiB,KAAK,WAAW,WAAW;AAC9D,cAAM,OAAOA,kBAAiB,KAAK,MAAM,MAAM;AAC/CK,oBAAW,MAAM,QAAQ,CAAC,aAAa,iBAAiB,mBAAmB,CAAC;AAC5E,cAAM,cAAcD,WAAU,KAAK,aAAa,aAAa;AAC7D,cAAM,YAAYH,gBAAe,KAAK,WAAW,WAAW;AAE5D,YAAI,SAAS,eAAe,KAAK,mBAAmB,MAAM;AACxDC,4BAAiB,KAAK,iBAAiB,iBAAiB;QAC1D;AACA,YAAI,SAAS,iBAAiB;AAC5B,gBAAM,SAASI,yBAAwB,KAAK,QAAQ,QAAQ;AAC5D,gBAAM,MAAMA,yBAAwB,KAAK,KAAK,KAAK;AACnD,cAAI,OAAO,GAAG,KAAK,OAAO,MAAM,GAAG;AACjC,kBAAM,IAAI,MAAM,uCAAuC;UACzD;AACAH,6BAAkB,KAAK,KAAK,KAAK;QACnC;AACA,YAAI,SAAS,qBAAqB;AAChCG,mCAAwB,KAAK,WAAW,WAAW;AACnD,gBAAM,qBAAqBN,kBAAiB,KAAK,oBAAoB,oBAAoB;AACzFK,sBAAW,oBAAoB,sBAAsB,CAAC,KAAK,IAAI,CAAC;QAClE;AAEA,cAAM,OAAgC;UACpC;UACA;UACA;UACA;QACF;AACA,YAAI,KAAK,mBAAmB,KAAM,MAAK,kBAAkBJ,gBAAe,KAAK,iBAAiB,iBAAiB;AAC/G,YAAI,KAAK,UAAU,KAAM,MAAK,SAASK,yBAAwB,KAAK,QAAQ,QAAQ;AACpF,YAAI,KAAK,OAAO,KAAM,MAAK,MAAMA,yBAAwB,KAAK,KAAK,KAAK;AACxE,YAAI,KAAK,OAAO,KAAM,MAAK,MAAMH,mBAAkB,KAAK,KAAK,KAAK;AAClE,YAAI,KAAK,qBAAqB,KAAM,MAAK,oBAAoBF,gBAAe,KAAK,mBAAmB,mBAAmB;AACvH,YAAI,KAAK,eAAe,KAAM,MAAK,cAAcG,WAAU,KAAK,aAAa,aAAa;AAC1F,YAAI,KAAK,cAAc,KAAM,MAAK,aAAaA,WAAU,KAAK,YAAY,YAAY;AACtF,YAAI,KAAK,cAAc,KAAM,MAAK,aAAa,OAAO,KAAK,UAAU;AACrE,YAAI,KAAK,kBAAkB,MAAM;AAC/B,gBAAM,iBAAiBJ,kBAAiB,KAAK,gBAAgB,gBAAgB;AAC7EK,sBAAW,gBAAgB,kBAAkB,CAAC,QAAQ,eAAe,CAAC;AACtE,eAAK,iBAAiB;QACxB;AACA,YAAI,KAAK,aAAa,KAAM,MAAK,YAAYC,yBAAwB,KAAK,WAAW,WAAW;AAChG,YAAI,KAAK,sBAAsB,MAAM;AACnC,gBAAM,qBAAqBN,kBAAiB,KAAK,oBAAoB,oBAAoB;AACzFK,sBAAW,oBAAoB,sBAAsB,CAAC,KAAK,IAAI,CAAC;AAChE,eAAK,qBAAqB;QAC5B;AACA,YAAI,KAAK,YAAY,KAAM,MAAK,WAAW,OAAO,KAAK,QAAQ;AAC/D,YAAI,KAAK,qBAAqB,KAAM,MAAK,oBAAoB,OAAO,KAAK,iBAAiB;AAC1F,gBAAQ,MAAM,OAAO,WAAW,+CAA+C,IAAI,GAAG;MACxF;IACF;IACA;MACE,MAAM;MACN,QAAQ;MACR,SAAS;MACT,aAAa;MACb,aAAa;QACX,MAAM;QACN,sBAAsB;QACtB,YAAY;UACV,WAAW,EAAE,MAAM,SAAS;UAC5B,WAAW,EAAE,MAAM,SAAS;UAC5B,WAAW,EAAE,MAAM,SAAS;UAC5B,UAAU,EAAE,MAAM,SAAS;UAC3B,WAAW,EAAE,MAAM,SAAS;UAC5B,oBAAoB,EAAE,MAAM,UAAU,MAAM,CAAC,KAAK,IAAI,EAAE;QAC1D;QACA,UAAU,CAAC,aAAa,aAAa,WAAW;MAClD;MACA,MAAM,QAAQ,MAAM,EAAE,QAAQ,OAAO,GAAG;AACtC,YAAI,OAAO,UAAU;AACnB,gBAAM,IAAI,MAAM,gEAAgE;QAClF;AACA,cAAM,YAAYL,kBAAiB,KAAK,WAAW,WAAW;AAC9D,cAAM,YAAYM,yBAAwB,KAAK,WAAW,WAAW;AACrE,cAAM,YAAYH,mBAAkB,KAAK,WAAW,WAAW;AAC/D,cAAM,OAAgC;UACpC;UACA;UACA;QACF;AACA,YAAI,KAAK,YAAY,KAAM,MAAK,WAAW,OAAO,KAAK,QAAQ;AAC/D,YAAI,KAAK,aAAa,KAAM,MAAK,YAAY,OAAO,KAAK,SAAS;AAClE,YAAI,KAAK,sBAAsB,MAAM;AACnC,gBAAM,qBAAqBH,kBAAiB,KAAK,oBAAoB,oBAAoB;AACzFK,sBAAW,oBAAoB,sBAAsB,CAAC,KAAK,IAAI,CAAC;AAChE,eAAK,qBAAqB;QAC5B;AACA,gBAAQ,MAAM,OAAO,WAAW,yCAAyC,IAAI,GAAG;MAClF;IACF;IACA;MACE,MAAM;MACN,QAAQ;MACR,SAAS;MACT,aAAa;MACb,aAAa;QACX,MAAM;QACN,sBAAsB;QACtB,YAAY;UACV,WAAW,EAAE,MAAM,SAAS;UAC5B,WAAW,EAAE,MAAM,SAAS;UAC5B,gBAAgB,EAAE,MAAM,UAAU,MAAM,CAAC,YAAY,SAAS,EAAE;UAChE,WAAW,EAAE,MAAM,UAAU;UAC7B,eAAe,EAAE,MAAM,SAAS;QAClC;QACA,UAAU,CAAC,WAAW;MACxB;MACA,MAAM,QAAQ,MAAM,EAAE,QAAQ,OAAO,GAAG;AACtC,YAAI,OAAO,UAAU;AACnB,gBAAM,IAAI,MAAM,gEAAgE;QAClF;AACA,cAAM,YAAYL,kBAAiB,KAAK,WAAW,WAAW;AAC9D,cAAM,OAAgC,EAAE,UAAU;AAClD,YAAI,KAAK,aAAa,KAAM,MAAK,YAAY,OAAO,KAAK,SAAS;AAClE,YAAI,KAAK,kBAAkB,MAAM;AAC/B,gBAAM,iBAAiBA,kBAAiB,KAAK,gBAAgB,gBAAgB;AAC7EK,sBAAW,gBAAgB,kBAAkB,CAAC,YAAY,SAAS,CAAC;AACpE,eAAK,iBAAiB;QACxB;AACA,YAAI,KAAK,aAAa,KAAM,MAAK,YAAYD,WAAU,KAAK,WAAW,WAAW;AAClF,YAAI,KAAK,iBAAiB,KAAM,MAAK,gBAAgB,OAAO,KAAK,aAAa;AAC9E,gBAAQ,MAAM,OAAO,WAAW,yCAAyC,IAAI,GAAG;MAClF;IACF;EACF;AACF;ACtSA,SAAS,eAA2B;AAClC,SAAO,CAAC,GAAG,oBAAoB,GAAG,GAAG,qBAAqB,GAAG,GAAG,oBAAoB,GAAG,GAAG,iBAAiB,CAAC;AAC9G;AAsBO,SAAS,iBAAiB,QAA0B,QAAkC;AAC3F,QAAM,aAA2B,EAAE,GAAG,QAAQ,SAAS,CAAC,GAAG,OAAO,EAAgB;AAClF,QAAM,UAAU,IAAI,IAAsB,aAAa,EAAE,IAAI,CAAC,MAAM,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC;AAEhF,SAAO,OAAO,UAAkB,SAAwC;AACtE,UAAM,OAAO,QAAQ,IAAI,QAAQ;AACjC,QAAI,CAAC,KAAM,OAAM,IAAI,MAAM,iBAAiB,QAAQ,EAAE;AACtD,UAAM,OAAO,MAAM,KAAK,QAAQ,MAAM,EAAE,QAAQ,YAAY,OAAO,CAAC;AACpE,WAAO,EAAE,UAAU,UAAU,cAAa,oBAAI,KAAK,GAAE,YAAY,GAAG,KAAK;EAC3E;AACF;;;AZvBA,IAAM,uBAAuB;AAC7B,IAAM,mBAAmB;AAEzB,SAAS,IAAI,IAAwC,UAAkB,eAAe,IAAqB;AACzG,QAAM,SAAS,eAAe,GAAG,QAAQ,KAAK,YAAY,QAAQ,GAAG,QAAQ;AAC7E,SAAO,IAAI,QAAQ,CAAC,YAAY,GAAG,SAAS,QAAQ,CAAC,WAAW,SAAS,UAAU,IAAI,KAAK,KAAK,YAAY,CAAC,CAAC;AACjH;AAEA,eAAe,aAA4B;AACzC,QAAM,KAAK,gBAAgB,EAAE,OAAO,QAAQ,OAAO,QAAQ,QAAQ,OAAO,CAAC;AAE3E,UAAQ,OAAO,MAAM,4BAA4B;AACjD,UAAQ,OAAO,MAAM,uLAA6K;AAClM,UAAQ,OAAO,MAAM,6RAAgF;AAErG,UAAQ,OAAO,MAAM,4CAAuC;AAC5D,UAAQ,OAAO,MAAM,wGAAwG;AAC7H,UAAQ,OAAO,MAAM,kCAAkC,eAAe,IAAI,MAAM;AAEhF,QAAM,SAAS,MAAM,IAAI,IAAI,gBAAgB;AAC7C,MAAI,CAAC,QAAQ;AACX,YAAQ,OAAO,MAAM,qCAAqC;AAC1D,OAAG,MAAM;AACT,YAAQ,KAAK,CAAC;AAAA,EAChB;AAEA,QAAM,YAAY,MAAM,IAAI,IAAI,mBAAmB;AACnD,MAAI,CAAC,WAAW;AACd,YAAQ,OAAO,MAAM,wCAAwC;AAC7D,OAAG,MAAM;AACT,YAAQ,KAAK,CAAC;AAAA,EAChB;AAEA,KAAG,MAAM;AAET,MAAI,SAA2B,EAAE,UAAU,CAAC,EAAE;AAC9C,MAAI;AACF,aAAS,eAAe;AAAA,EAC1B,QAAQ;AACN,aAAS,EAAE,UAAU,CAAC,EAAE;AAAA,EAC1B;AACA,MAAI,CAAC,OAAO,SAAU,QAAO,WAAW,CAAC;AAEzC,QAAM,UAAyB;AAAA,IAC7B,SAAS;AAAA,IACT,YAAY;AAAA,IACZ,UAAU;AAAA,EACZ;AACA,QAAM,cAAc;AACpB,SAAO,SAAS,WAAW,IAAI;AAC/B,SAAO,kBAAkB;AAEzB,MAAI;AACF,oBAAgB,MAAM;AAAA,EACxB,SAAS,GAAG;AACV,YAAQ,OAAO,MAAM,gCAAgC,aAAa,QAAQ,EAAE,UAAU,OAAO,CAAC,KAAK,IAAI;AACvG,YAAQ,KAAK,CAAC;AAAA,EAChB;AAEA,UAAQ,OAAO,MAAM,yBAAyB,eAAe,IAAI,IAAI;AACrE,UAAQ,OAAO,MAAM,wBAAwB,cAAc,IAAI;AAC/D,UAAQ,OAAO,MAAM,kCAAkC;AACvD,UAAQ,OAAO;AAAA,IACb;AAAA,EAGF;AACF;AAEA,SAAS,YAAkB;AACzB,UAAQ,OAAO,MAAM;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,CAWtB;AACD;AAEA,SAAS,eAAe,MAAmD;AACzE,MAAI;AACJ,MAAI;AACJ,WAAS,IAAI,GAAG,IAAI,KAAK,QAAQ,KAAK;AACpC,UAAM,MAAM,KAAK,CAAC;AAClB,QAAI,QAAQ,WAAW,KAAK,IAAI,CAAC,GAAG;AAClC,YAAM,KAAK,EAAE,CAAC;AAAA,IAChB,WAAW,IAAI,WAAW,QAAQ,GAAG;AACnC,YAAM,IAAI,MAAM,SAAS,MAAM;AAAA,IACjC,WAAW,QAAQ,cAAc,KAAK,IAAI,CAAC,GAAG;AAC5C,eAAS,KAAK,EAAE,CAAC;AAAA,IACnB,WAAW,IAAI,WAAW,WAAW,GAAG;AACtC,eAAS,IAAI,MAAM,YAAY,MAAM;AAAA,IACvC;AAAA,EACF;AACA,SAAO,EAAE,KAAK,OAAO;AACvB;AAEA,SAAS,SAAS,MAAsB;AACtC,QAAM,EAAE,KAAK,OAAO,IAAI,eAAe,IAAI;AAC3C,QAAM,YAAY,OAAO;AACzB,MAAI,cAAc,oBAAoB;AACpC,YAAQ,OAAO,MAAM,2BAA2B,SAAS;AAAA,CAAqD;AAC9G,YAAQ,KAAK,CAAC;AAAA,EAChB;AACA,MAAI,CAAC,QAAQ;AACX,YAAQ,OAAO;AAAA,MACb,iEACE,kBAAkB,KAAK,GAAG,IAC1B;AAAA,IACJ;AACA,YAAQ,KAAK,CAAC;AAAA,EAChB;AAGA,QAAM,mBAAmB,WAAW,WAAW,gBAAgB;AAE/D,MAAI,CAAC,kBAAkB,SAAS,gBAA4B,GAAG;AAC7D,YAAQ,OAAO;AAAA,MACb,uBAAuB,MAAM,gBAAgB,CAAC,GAAG,mBAAmB,gCAAgC,EAAE;AAAA,QACpG;AAAA,MACF,CAAC;AAAA;AAAA,IACH;AACA,YAAQ,KAAK,CAAC;AAAA,EAChB;AAEA,WAAS,EAAE,QAAQ,iBAA6B,CAAC;AACnD;AAIA,SAAS,WAAW,MAA6E;AAC/F,QAAM,cAAwB,CAAC;AAC/B,QAAM,QAAmC,CAAC;AAE1C,WAAS,IAAI,GAAG,IAAI,KAAK,QAAQ,KAAK;AACpC,UAAM,IAAI,KAAK,CAAC;AAChB,QAAI,CAAC,EAAE,WAAW,IAAI,GAAG;AACvB,kBAAY,KAAK,CAAC;AAClB;AAAA,IACF;AACA,UAAM,KAAK,EAAE,QAAQ,GAAG;AACxB,QAAI,OAAO,IAAI;AACb,YAAMG,KAAI,EAAE,MAAM,GAAG,EAAE;AACvB,YAAM,IAAI,EAAE,MAAM,KAAK,CAAC;AACxB,YAAMA,EAAC,IAAI,MAAM,SAAS,OAAO,MAAM,UAAU,QAAQ;AACzD;AAAA,IACF;AACA,UAAM,IAAI,EAAE,MAAM,CAAC;AACnB,UAAM,OAAO,KAAK,IAAI,CAAC;AACvB,QAAI,CAAC,QAAQ,KAAK,WAAW,IAAI,GAAG;AAClC,YAAM,CAAC,IAAI;AACX;AAAA,IACF;AACA,UAAM,CAAC,IAAI;AACX;AAAA,EACF;AAEA,SAAO,EAAE,aAAa,MAAM;AAC9B;AAEA,SAAS,kBAAwB;AAC/B,UAAQ,OAAO,MAAM;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,CAwCtB;AACD;AAEA,SAAS,cAAc,KAAc,UAA2C;AAC9E,MAAI,OAAO,QAAQ,UAAU;AAC3B,UAAM,IAAI,MAAM,4BAA4B,QAAQ,EAAE;AAAA,EACxD;AACA,MAAI;AACF,UAAM,SAAS,KAAK,MAAM,GAAG;AAC7B,QAAI,CAAC,UAAU,OAAO,WAAW,YAAY,MAAM,QAAQ,MAAM,GAAG;AAClE,YAAM,IAAI,MAAM,uBAAuB;AAAA,IACzC;AACA,WAAO;AAAA,EACT,SAAS,GAAG;AACV,UAAM,MAAM,aAAa,QAAQ,EAAE,UAAU,OAAO,CAAC;AACrD,UAAM,IAAI,MAAM,aAAa,QAAQ,KAAK,GAAG,EAAE;AAAA,EACjD;AACF;AAEA,eAAe,iBAAiB,MAA+B;AAC7D,QAAM,EAAE,aAAa,MAAM,IAAI,WAAW,IAAI;AAC9C,QAAM,QAAQ,YAAY,CAAC;AAC3B,QAAM,UAAU,YAAY,CAAC;AAE7B,MAAI,CAAC,SAAS,UAAU,UAAU,UAAU,YAAY,UAAU,MAAM;AACtE,oBAAgB;AAChB;AAAA,EACF;AAEA,QAAM,SAAS,WAAW;AAAA,IACxB,SAAS,OAAO,MAAM,YAAY,WAAW,MAAM,UAAU;AAAA,IAC7D,SAAS,OAAO,MAAM,YAAY,WAAW,MAAM,UAAU;AAAA,IAC7D,SAAS,OAAO,MAAM,UAAU,MAAM,WAAY,MAAM,UAAU,IAAe,OAAO,MAAM,YAAY,WAAY,MAAM,UAAqB;AAAA,IACjJ,UAAU,QAAQ,MAAM,WAAW,KAAK,MAAM,QAAQ;AAAA,EACxD,CAAC;AAED,QAAM,SAAS,IAAI,iBAAiB,MAAM;AAC1C,QAAM,UAAU,iBAAiB,QAAQ,MAAM;AAE/C,QAAM,SAAS,QAAQ,MAAM,SAAS,KAAK,MAAM,MAAM;AAGvD,MAAI,UAAU,UAAU;AACtB,QAAI,YAAY,SAAS;AACvB,YAAM,SAAS,YAAY,CAAC;AAC5B,UAAI,CAAC,OAAQ,OAAM,IAAI,MAAM,uDAAuD;AACpF,YAAM,QAAQ,MAAM,SAAS,OAAO,OAAO,MAAM,KAAK,IAAI;AAC1D,YAAM,MAAM,MAAM,QAAQ,2BAA2B,EAAE,QAAQ,MAAM,CAAC;AACtE,cAAQ,OAAO,MAAM,KAAK,UAAU,IAAI,MAAM,MAAM,CAAC,IAAI,IAAI;AAC7D;AAAA,IACF;AACA,QAAI,YAAY,UAAU;AACxB,YAAM,SAAS,YAAY,CAAC;AAC5B,UAAI,CAAC,OAAQ,OAAM,IAAI,MAAM,wDAAwD;AACrF,YAAM,QAAQ,MAAM,SAAS,OAAO,OAAO,MAAM,KAAK,IAAI;AAC1D,YAAM,MAAM,MAAM,QAAQ,4BAA4B,EAAE,QAAQ,MAAM,CAAC;AACvE,cAAQ,OAAO,MAAM,KAAK,UAAU,IAAI,MAAM,MAAM,CAAC,IAAI,IAAI;AAC7D;AAAA,IACF;AACA,QAAI,YAAY,WAAW;AACzB,YAAM,UAAU,OAAO,MAAM,YAAY,WAAW,MAAM,UAAU;AACpE,YAAM,OAAO,OAAO,MAAM,SAAS,WAAW,MAAM,OAAO;AAC3D,YAAM,MAAM,MAAM,QAAQ,iCAAiC,EAAE,SAAS,KAAK,CAAC;AAC5E,cAAQ,OAAO,MAAM,KAAK,UAAU,IAAI,MAAM,MAAM,CAAC,IAAI,IAAI;AAC7D;AAAA,IACF;AACA,QAAI,YAAY,WAAW;AACzB,YAAM,SAAS,OAAO,MAAM,WAAW,WAAW,MAAM,SAAS;AACjE,YAAM,OAAO,OAAO,MAAM,SAAS,WAAW,MAAM,OAAO;AAC3D,YAAM,MAAM,MAAM,QAAQ,6BAA6B,EAAE,QAAQ,KAAK,CAAC;AACvE,cAAQ,OAAO,MAAM,KAAK,UAAU,IAAI,MAAM,MAAM,CAAC,IAAI,IAAI;AAC7D;AAAA,IACF;AACA,QAAI,YAAY,UAAU;AACxB,YAAM,SAAS,OAAO,MAAM,WAAW,WAAW,MAAM,SAAS,YAAY,CAAC;AAC9E,YAAM,WAAW,OAAO,MAAM,aAAa,WAAW,MAAM,WAAW,YAAY,CAAC;AACpF,UAAI,CAAC,UAAU,CAAC,SAAU,OAAM,IAAI,MAAM,qEAAqE;AAC/G,YAAM,UAAU,MAAM,WAAW,OAAO,OAAO,MAAM,OAAO,IAAI;AAChE,YAAM,QAAQ,MAAM,SAAS,OAAO,OAAO,MAAM,KAAK,IAAI;AAC1D,YAAM,MAAM,MAAM,QAAQ,4BAA4B,EAAE,QAAQ,UAAU,SAAS,MAAM,CAAC;AAC1F,cAAQ,OAAO,MAAM,KAAK,UAAU,IAAI,MAAM,MAAM,CAAC,IAAI,IAAI;AAC7D;AAAA,IACF;AACA,UAAM,IAAI,MAAM,2BAA2B,OAAO,EAAE;AAAA,EACtD;AAGA,MAAI,UAAU,WAAW;AACvB,QAAI,YAAY,WAAW;AACzB,YAAM,MAAM,MAAM,QAAQ,8BAA8B,CAAC,CAAC;AAC1D,cAAQ,OAAO,MAAM,KAAK,UAAU,IAAI,MAAM,MAAM,CAAC,IAAI,IAAI;AAC7D;AAAA,IACF;AACA,UAAM,IAAI,MAAM,4BAA4B,OAAO,EAAE;AAAA,EACvD;AAGA,MAAI,UAAU,UAAU;AACtB,QAAI,YAAY,OAAO;AACrB,YAAM,SAAS,OAAO,MAAM,WAAW,WAAW,MAAM,SAAS;AACjE,YAAM,OAAO,OAAO,MAAM,SAAS,WAAW,MAAM,OAAO;AAC3D,YAAM,OAAO,OAAO,MAAM,SAAS,WAAW,MAAM,OAAO;AAC3D,YAAM,gBAAgB,OAAO,MAAM,iBAAiB,MAAM,WAAY,MAAM,iBAAiB,IAAe,OAAO,MAAM,kBAAkB,WAAY,MAAM,gBAA2B;AACxL,YAAM,OAAO,OAAO,MAAM,SAAS,WAAW,MAAM,OAAO;AAC3D,YAAM,QAAQ,OAAO,MAAM,UAAU,WAAW,MAAM,QAAQ;AAC9D,YAAM,SAAS,OAAO,MAAM,WAAW,WAAW,MAAM,SAAS;AACjE,YAAM,MAAM,OAAO,MAAM,QAAQ,YAAY,MAAM,MAAM;AACzD,UAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,KAAM,OAAM,IAAI,MAAM,gDAAgD;AAC/F,YAAM,UAAU,EAAE,QAAQ,MAAM,MAAM,eAAe,MAAM,OAAO,QAAQ,IAAI;AAC9E,UAAI,QAAQ;AACV,gBAAQ,OAAO,MAAM,KAAK,UAAU,EAAE,MAAM,2BAA2B,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,IAAI;AACvG;AAAA,MACF;AACA,YAAM,MAAM,MAAM,QAAQ,2BAA2B,OAAO;AAC5D,cAAQ,OAAO,MAAM,KAAK,UAAU,IAAI,MAAM,MAAM,CAAC,IAAI,IAAI;AAC7D;AAAA,IACF;AACA,QAAI,YAAY,OAAO;AACrB,YAAM,SAAS,OAAO,MAAM,WAAW,WAAW,MAAM,SAAS;AACjE,YAAM,UAAU,MAAM,UAAU,KAAK,OAAO,OAAO,MAAM,UAAU,CAAC,IAAI;AACxE,UAAI,CAAC,UAAU,WAAW,KAAM,OAAM,IAAI,MAAM,6CAA6C;AAC7F,YAAM,MAAM,MAAM,QAAQ,2BAA2B,EAAE,QAAQ,QAAQ,CAAC;AACxE,cAAQ,OAAO,MAAM,KAAK,UAAU,IAAI,MAAM,MAAM,CAAC,IAAI,IAAI;AAC7D;AAAA,IACF;AACA,QAAI,YAAY,QAAQ;AACtB,YAAM,SAAS,OAAO,MAAM,WAAW,WAAW,MAAM,SAAS;AACjE,UAAI,CAAC,OAAQ,OAAM,IAAI,MAAM,iCAAiC;AAC9D,YAAM,MAAM,MAAM,QAAQ,iCAAiC,EAAE,OAAO,CAAC;AACrE,cAAQ,OAAO,MAAM,KAAK,UAAU,IAAI,MAAM,MAAM,CAAC,IAAI,IAAI;AAC7D;AAAA,IACF;AACA,QAAI,YAAY,OAAO;AACrB,YAAM,SAAS,OAAO,MAAM,WAAW,WAAW,MAAM,SAAS;AACjE,YAAM,QAAQ,MAAM,SAAS,OAAO,OAAO,MAAM,KAAK,IAAI;AAC1D,UAAI,CAAC,OAAQ,OAAM,IAAI,MAAM,iCAAiC;AAC9D,YAAM,MAAM,MAAM,QAAQ,gCAAgC,EAAE,QAAQ,MAAM,CAAC;AAC3E,cAAQ,OAAO,MAAM,KAAK,UAAU,IAAI,MAAM,MAAM,CAAC,IAAI,IAAI;AAC7D;AAAA,IACF;AACA,QAAI,YAAY,SAAS;AACvB,YAAM,SAAS,OAAO,MAAM,WAAW,WAAW,MAAM,SAAS;AACjE,YAAM,YAAY,MAAM,aAAa,OAAO,OAAO,MAAM,SAAS,IAAI;AACtE,YAAM,UAAU,MAAM,WAAW,OAAO,OAAO,MAAM,OAAO,IAAI;AAChE,UAAI,CAAC,OAAQ,OAAM,IAAI,MAAM,iCAAiC;AAC9D,YAAM,MAAM,MAAM,QAAQ,2BAA2B,EAAE,QAAQ,WAAW,QAAQ,CAAC;AACnF,cAAQ,OAAO,MAAM,KAAK,UAAU,IAAI,MAAM,MAAM,CAAC,IAAI,IAAI;AAC7D;AAAA,IACF;AACA,QAAI,YAAY,UAAU;AACxB,YAAM,SAAS,OAAO,MAAM,WAAW,WAAW,MAAM,SAAS;AACjE,YAAM,UAAU,MAAM,UAAU,KAAK,OAAO,OAAO,MAAM,UAAU,CAAC,IAAI;AACxE,UAAI,CAAC,UAAU,WAAW,KAAM,OAAM,IAAI,MAAM,6CAA6C;AAC7F,YAAM,UAAU,EAAE,QAAQ,QAAQ;AAClC,UAAI,QAAQ;AACV,gBAAQ,OAAO,MAAM,KAAK,UAAU,EAAE,MAAM,8BAA8B,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,IAAI;AAC1G;AAAA,MACF;AACA,YAAM,MAAM,MAAM,QAAQ,8BAA8B,OAAO;AAC/D,cAAQ,OAAO,MAAM,KAAK,UAAU,IAAI,MAAM,MAAM,CAAC,IAAI,IAAI;AAC7D;AAAA,IACF;AACA,QAAI,YAAY,cAAc;AAC5B,YAAM,SAAS,OAAO,MAAM,WAAW,WAAW,MAAM,SAAS;AACjE,UAAI,CAAC,OAAQ,OAAM,IAAI,MAAM,iCAAiC;AAC9D,YAAM,UAAU,EAAE,OAAO;AACzB,UAAI,QAAQ;AACV,gBAAQ,OAAO,MAAM,KAAK,UAAU,EAAE,MAAM,mCAAmC,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,IAAI;AAC/G;AAAA,MACF;AACA,YAAM,MAAM,MAAM,QAAQ,mCAAmC,OAAO;AACpE,cAAQ,OAAO,MAAM,KAAK,UAAU,IAAI,MAAM,MAAM,CAAC,IAAI,IAAI;AAC7D;AAAA,IACF;AACA,UAAM,IAAI,MAAM,2BAA2B,OAAO,EAAE;AAAA,EACtD;AAGA,MAAI,UAAU,OAAO;AACnB,QAAI,YAAY,OAAO;AACrB,YAAM,YACJ,OAAO,MAAM,aAAa,MAAM,WAC3B,MAAM,aAAa,IACpB,OAAO,MAAM,cAAc,WACxB,MAAM,YACP;AACR,YAAM,OAAO,OAAO,MAAM,SAAS,WAAW,MAAM,OAAO;AAC3D,UAAI,CAAC,UAAW,OAAM,IAAI,MAAM,sCAAsC;AACtE,YAAM,MAAM,MAAM,QAAQ,qCAAqC,EAAE,WAAW,KAAK,CAAC;AAClF,cAAQ,OAAO,MAAM,KAAK,UAAU,IAAI,MAAM,MAAM,CAAC,IAAI,IAAI;AAC7D;AAAA,IACF;AACA,QAAI,YAAY,UAAU;AACxB,YAAM,OAAO,OAAO,MAAM,SAAS,WAAW,MAAM,OAAO;AAC3D,YAAM,QAAQ,OAAO,MAAM,UAAU,WAAW,MAAM,QAAQ;AAC9D,YAAM,WAAW,OAAO,MAAM,aAAa,WAAW,MAAM,WAAW;AACvE,YAAM,WAAW,OAAO,MAAM,WAAW,MAAM,WAAY,MAAM,WAAW,IAAe,OAAO,MAAM,aAAa,WAAY,MAAM,WAAsB;AAC7J,YAAM,WAAW,OAAO,MAAM,WAAW,MAAM,WAAY,MAAM,WAAW,IAAe,OAAO,MAAM,aAAa,WAAY,MAAM,WAAsB;AAC7J,YAAM,iBACJ,OAAO,MAAM,mBAAmB,MAAM,WACjC,MAAM,mBAAmB,IAC1B,OAAO,MAAM,mBAAmB,WAC7B,MAAM,iBACP;AACR,YAAM,iBAAiB,cAAc,MAAM,oBAAoB,KAAK,MAAM,iBAAiB,oBAAoB;AAC/G,UAAI,CAAC,QAAQ,CAAC,OAAO;AACnB,cAAM,IAAI,MAAM,6DAA6D;AAAA,MAC/E;AACA,YAAM,cAAc,6CAA6C,cAAc;AAC/E,YAAM,UAAmC,EAAE,MAAM,OAAO,UAAU,UAAU,UAAU,gBAAgB,YAAY;AAClH,UAAI,QAAQ;AACV,cAAMC,OAAM,MAAM,QAAQ,wCAAwC,EAAE,GAAG,SAAS,UAAU,KAAK,CAAC;AAChG,gBAAQ,OAAO,MAAM,KAAK,UAAUA,KAAI,MAAM,MAAM,CAAC,IAAI,IAAI;AAC7D;AAAA,MACF;AACA,YAAM,MAAM,MAAM,QAAQ,wCAAwC,OAAO;AACzE,cAAQ,OAAO,MAAM,KAAK,UAAU,IAAI,MAAM,MAAM,CAAC,IAAI,IAAI;AAC7D;AAAA,IACF;AACA,QAAI,YAAY,UAAU;AACxB,YAAM,UAAU,cAAc,MAAM,WAAW,KAAK,MAAM,UAAU,WAAW;AAC/E,UAAI,QAAQ;AACV,gBAAQ,OAAO,MAAM,KAAK,UAAU,EAAE,MAAM,yCAAyC,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,IAAI;AACrH;AAAA,MACF;AACA,YAAM,MAAM,MAAM,QAAQ,yCAAyC,OAAO;AAC1E,cAAQ,OAAO,MAAM,KAAK,UAAU,IAAI,MAAM,MAAM,CAAC,IAAI,IAAI;AAC7D;AAAA,IACF;AACA,QAAI,YAAY,UAAU;AACxB,YAAM,UAAU,cAAc,MAAM,WAAW,KAAK,MAAM,UAAU,WAAW;AAC/E,UAAI,QAAQ;AACV,gBAAQ,OAAO,MAAM,KAAK,UAAU,EAAE,MAAM,2CAA2C,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,IAAI;AACvH;AAAA,MACF;AACA,YAAM,MAAM,MAAM,QAAQ,2CAA2C,OAAO;AAC5E,cAAQ,OAAO,MAAM,KAAK,UAAU,IAAI,MAAM,MAAM,CAAC,IAAI,IAAI;AAC7D;AAAA,IACF;AACA,QAAI,YAAY,UAAU;AACxB,YAAM,YACJ,OAAO,MAAM,aAAa,MAAM,WAC3B,MAAM,aAAa,IACpB,OAAO,MAAM,cAAc,WACxB,MAAM,YACP;AACR,YAAM,YAAY,OAAO,MAAM,YAAY,MAAM,WAAY,MAAM,YAAY,IAAe,OAAO,MAAM,cAAc,WAAY,MAAM,YAAuB;AAClK,YAAM,iBACJ,OAAO,MAAM,kBAAkB,MAAM,WAChC,MAAM,kBAAkB,IACzB,OAAO,MAAM,mBAAmB,WAC7B,MAAM,iBACP;AACR,YAAM,YAAY,OAAO,MAAM,cAAc,YAAY,MAAM,YAAY;AAC3E,YAAM,gBACJ,OAAO,MAAM,gBAAgB,MAAM,WAC9B,MAAM,gBAAgB,IACvB,OAAO,MAAM,kBAAkB,WAC5B,MAAM,gBACP;AACR,UAAI,CAAC,UAAW,OAAM,IAAI,MAAM,sCAAsC;AACtE,YAAM,UAAU,EAAE,WAAW,WAAW,gBAAgB,WAAW,cAAc;AACjF,UAAI,QAAQ;AACV,gBAAQ,OAAO,MAAM,KAAK,UAAU,EAAE,MAAM,wCAAwC,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,IAAI;AACpH;AAAA,MACF;AACA,YAAM,MAAM,MAAM,QAAQ,wCAAwC,OAAO;AACzE,cAAQ,OAAO,MAAM,KAAK,UAAU,IAAI,MAAM,MAAM,CAAC,IAAI,IAAI;AAC7D;AAAA,IACF;AACA,UAAM,IAAI,MAAM,wBAAwB,OAAO,EAAE;AAAA,EACnD;AAEA,QAAM,IAAI,MAAM,kBAAkB,KAAK,EAAE;AAC3C;AAEA,SAAS,OAAa;AACpB,QAAM,YAAY,SAAS,QAAQ,KAAK,CAAC,KAAK,EAAE;AAChD,QAAM,MAAM,QAAQ,KAAK,CAAC;AAG1B,MAAI,UAAU,SAAS,eAAe,GAAG;AACvC,QAAI,QAAQ,WAAW;AACrB,iBAAW,EAAE,MAAM,CAAC,MAAM;AACxB,gBAAQ,OAAO,MAAM,OAAO,CAAC,IAAI,IAAI;AACrC,gBAAQ,KAAK,CAAC;AAAA,MAChB,CAAC;AACD;AAAA,IACF;AACA,QAAI,QAAQ,SAAS;AACnB,eAAS,QAAQ,KAAK,MAAM,CAAC,CAAC;AAC9B;AAAA,IACF;AACA,QAAI,QAAQ,UAAU,QAAQ,YAAY,QAAQ,QAAQ,CAAC,KAAK;AAC9D,gBAAU;AACV;AAAA,IACF;AACA,YAAQ,OAAO,MAAM,sBAAsB,MAAM,+BAA+B;AAChF,YAAQ,KAAK,CAAC;AACd;AAAA,EACF;AAGA,mBAAiB,QAAQ,KAAK,MAAM,CAAC,CAAC,EAAE,MAAM,CAAC,MAAM;AACnD,UAAM,UAAU,mBAAmB,CAAC;AACpC,YAAQ,OAAO,MAAM,KAAK,UAAU,SAAS,MAAM,CAAC,IAAI,IAAI;AAC5D,YAAQ,KAAK,CAAC;AAAA,EAChB,CAAC;AACH;AAEA,KAAK;","names":["endPtr","path","path","asNonEmptyString","asFiniteNumber","asPositiveNumber","asPositiveInteger","asBoolean","assertEnum","asPositiveDecimalString","k","out"]}
|
|
1
|
+
{"version":3,"sources":["../src/index.ts","../../core/src/config/toml.ts","../../core/src/setup.ts","../../core/src/constants.ts","../../core/src/utils/errors.ts","../../core/src/config.ts","../../core/src/client/rest-client.ts","../../core/src/tools/market.ts","../../core/src/tools/account.ts","../../core/src/tools/orders.ts","../../core/src/schemas/futures-grid-create.ts","../../core/src/tools/bot.ts","../../core/src/tools/index.ts","../../core/src/tools/types.ts","../../../node_modules/smol-toml/dist/error.js","../../../node_modules/smol-toml/dist/util.js","../../../node_modules/smol-toml/dist/date.js","../../../node_modules/smol-toml/dist/primitive.js","../../../node_modules/smol-toml/dist/extract.js","../../../node_modules/smol-toml/dist/struct.js","../../../node_modules/smol-toml/dist/parse.js","../../../node_modules/smol-toml/dist/stringify.js"],"sourcesContent":["#!/usr/bin/env node\n\nimport { createInterface } from \"node:readline\";\nimport { basename } from \"node:path\";\nimport {\n readFullConfig,\n writeFullConfig,\n configFilePath,\n runSetup,\n SUPPORTED_CLIENTS,\n type PionexTomlConfig,\n type PionexProfile,\n type ClientId,\n loadConfig,\n PionexRestClient,\n createToolRunner,\n toToolErrorPayload,\n parseAndValidateCreateFuturesGridBuOrderData,\n} from \"@pionex-ai/core\";\n\nconst DEFAULT_PROFILE_NAME = \"pionx-prod\";\nconst DEFAULT_BASE_URL = \"https://api.pionex.com\";\n\nfunction ask(rl: ReturnType<typeof createInterface>, question: string, defaultValue = \"\"): Promise<string> {\n const prompt = defaultValue ? `${question} [${defaultValue}]: ` : `${question}: `;\n return new Promise((resolve) => rl.question(prompt, (answer) => resolve((answer ?? \"\").trim() || defaultValue)));\n}\n\nasync function cmdOnboard(): Promise<void> {\n const rl = createInterface({ input: process.stdin, output: process.stdout });\n\n process.stdout.write(\"\\n pionex-ai-kit v0.2.x\\n\");\n process.stdout.write(\" ⚠️ Security Tips: NEVER send API keys in agent chat. Create a dedicated API Key for your agent. Please test thoroughly before connecting to large real-money accounts.\\n\");\n process.stdout.write(\" ⚠️ 安全提示:切勿在 Agent 对话中发送 API Key。请为 Agent 创建专用API Key接入,先用小金额充分验证后再接入实盘。\\n\\n\");\n\n process.stdout.write(\"Pionex CLI — Configuration Wizard\\n\\n\");\n process.stdout.write(\"Go to https://www.pionex.com/zh-CN/my-account/api to create an API Key (trade permission required)\\n\\n\");\n process.stdout.write(\"Credentials will be saved to \" + configFilePath() + \"\\n\\n\");\n\n const apiKey = await ask(rl, \"Pionex API Key\");\n if (!apiKey) {\n process.stderr.write(\" Error: API Key cannot be empty.\\n\");\n rl.close();\n process.exit(1);\n }\n\n const secretKey = await ask(rl, \"Pionex API Secret\");\n if (!secretKey) {\n process.stderr.write(\" Error: API Secret cannot be empty.\\n\");\n rl.close();\n process.exit(1);\n }\n\n rl.close();\n\n let config: PionexTomlConfig = { profiles: {} };\n try {\n config = readFullConfig();\n } catch {\n config = { profiles: {} };\n }\n if (!config.profiles) config.profiles = {};\n\n const profile: PionexProfile = {\n api_key: apiKey,\n secret_key: secretKey,\n base_url: DEFAULT_BASE_URL,\n };\n const profileName = DEFAULT_PROFILE_NAME;\n config.profiles[profileName] = profile;\n config.default_profile = profileName;\n\n try {\n writeFullConfig(config);\n } catch (e) {\n process.stderr.write(\" Failed to write config: \" + (e instanceof Error ? e.message : String(e)) + \"\\n\");\n process.exit(1);\n }\n\n process.stdout.write(\"\\n Config saved to \" + configFilePath() + \"\\n\");\n process.stdout.write(\" Default profile: \" + profileName + \"\\n\");\n process.stdout.write(\" Usage: pionex-ai-kit onboard\\n\");\n process.stdout.write(\n \" Next: run 'pionex-ai-kit setup --mcp=pionex-trade-mcp --client cursor' or \" +\n \"'pionex-trade-mcp setup --client cursor' to register the MCP server.\\n\" +\n \" You can replace 'cursor' with 'claude-desktop', 'windsurf', 'vscode', 'claude-code', 'claude' or 'openclaw' depending on which agent you want to configure.\\n\\n\",\n );\n}\n\nfunction printHelp(): void {\n process.stdout.write(`\nUsage: pionex-ai-kit <command>\n\nCommands:\n onboard Interactive wizard to create ~/.pionex/config.toml (API key, secret)\n help Show this help\n\nThe MCP server (pionex-trade-mcp) reads credentials from ~/.pionex/config.toml.\nUse 'pionex-ai-kit setup --mcp=pionex-trade-mcp --client <client>' to write MCP client config\nthat runs 'npx @pionex/pionex-trade-mcp' (no keys are written to the client config).\n\n`);\n}\n\nfunction parseSetupArgs(argv: string[]): { mcp?: string; client?: string } {\n let mcp: string | undefined;\n let client: string | undefined;\n for (let i = 0; i < argv.length; i++) {\n const arg = argv[i];\n if (arg === \"--mcp\" && argv[i + 1]) {\n mcp = argv[++i];\n } else if (arg.startsWith(\"--mcp=\")) {\n mcp = arg.slice(\"--mcp=\".length);\n } else if (arg === \"--client\" && argv[i + 1]) {\n client = argv[++i];\n } else if (arg.startsWith(\"--client=\")) {\n client = arg.slice(\"--client=\".length);\n }\n }\n return { mcp, client };\n}\n\nfunction cmdSetup(argv: string[]): void {\n const { mcp, client } = parseSetupArgs(argv);\n const targetMcp = mcp ?? \"pionex-trade-mcp\";\n if (targetMcp !== \"pionex-trade-mcp\") {\n process.stderr.write(`Unsupported MCP server: ${targetMcp}. Currently only 'pionex-trade-mcp' is supported.\\n`);\n process.exit(1);\n }\n if (!client) {\n process.stderr.write(\n \"Usage: pionex-ai-kit setup --mcp=pionex-trade-mcp --client <\" +\n SUPPORTED_CLIENTS.join(\"|\") +\n \">\\n\",\n );\n process.exit(1);\n }\n\n // Allow 'claude' as an alias for 'claude-code'\n const normalizedClient = client === \"claude\" ? \"claude-code\" : client;\n\n if (!SUPPORTED_CLIENTS.includes(normalizedClient as ClientId)) {\n process.stderr.write(\n `Unsupported client: ${client}. Supported: ${[...SUPPORTED_CLIENTS, \"claude (alias for claude-code)\"].join(\n \", \",\n )}\\n`,\n );\n process.exit(1);\n }\n\n runSetup({ client: normalizedClient as ClientId });\n}\n\ntype FlagValue = string | boolean;\n\nfunction parseFlags(argv: string[]): { positionals: string[]; flags: Record<string, FlagValue> } {\n const positionals: string[] = [];\n const flags: Record<string, FlagValue> = {};\n\n for (let i = 0; i < argv.length; i++) {\n const a = argv[i];\n if (!a.startsWith(\"--\")) {\n positionals.push(a);\n continue;\n }\n const eq = a.indexOf(\"=\");\n if (eq !== -1) {\n const k = a.slice(2, eq);\n const v = a.slice(eq + 1);\n flags[k] = v === \"true\" ? true : v === \"false\" ? false : v;\n continue;\n }\n const k = a.slice(2);\n const next = argv[i + 1];\n if (!next || next.startsWith(\"--\")) {\n flags[k] = true;\n continue;\n }\n flags[k] = next;\n i++;\n }\n\n return { positionals, flags };\n}\n\nfunction printPionexHelp(): void {\n process.stdout.write(`\nUsage: pionex <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 --quote USDT --bu-order-data-json '{\"top\":\"110000\",\"bottom\":\"90000\",\"row\":100,\"grid_type\":\"arithmetic\",\"trend\":\"long\",\"leverage\":5,\"quoteInvestment\":\"100\"}'\n\nGlobal flags:\n --profile <name> Profile in ~/.pionex/config.toml\n --modules <list> Comma-separated modules (market,account,orders or all)\n --base-url <url> Override API base URL\n --read-only Disable write operations (orders new/cancel)\n --dry-run Print resolved futures-grid create body without executing (bot create only)\n\nFutures grid create (pionex bot create) — strict OpenAPI (same validation as MCP):\n --base Required; normalized to <BASE>.PERP if suffix missing\n --quote Required (e.g. USDT)\n --bu-order-data-json Required JSON object — ONLY keys from CreateFuturesGridOrderData in openapi_bot.yaml\n Optional: --copy-from, --copy-type, --copy-bot-order-id\n buOrderData required: top, bottom, row, grid_type, trend, leverage, quoteInvestment\n buOrderData optional (names only): extraMargin, condition, conditionDirection, lossStopType, lossStop,\n lossStopDelay, profitStopType, profitStop, profitStopDelay, lossStopHigh, shareRatio, investCoin,\n investmentFrom, uiInvestCoin, lossStopLimitPrice, lossStopLimitHighPrice, profitStopLimitPrice,\n slippage, bonusId, uiExtraData, movingIndicatorType, movingIndicatorInterval, movingIndicatorParam,\n movingTrailingUpParam, cateType, movingTop, movingBottom, enableFollowClosed\n Unknown keys → error\n YAML: https://github.com/pionex-official/pionex-open-api/blob/main/openapi_bot.yaml\n Docs: https://www.pionex.com/docs/api-docs/bot-api/futures-grid\n`);\n}\n\nfunction parseJsonFlag(raw: unknown, flagName: string): Record<string, unknown> {\n if (typeof raw !== \"string\") {\n throw new Error(`Missing required flag: --${flagName}`);\n }\n try {\n const parsed = JSON.parse(raw) as unknown;\n if (!parsed || typeof parsed !== \"object\" || Array.isArray(parsed)) {\n throw new Error(\"must be a JSON object\");\n }\n return parsed as Record<string, unknown>;\n } catch (e) {\n const msg = e instanceof Error ? e.message : String(e);\n throw new Error(`Invalid --${flagName}: ${msg}`);\n }\n}\n\nasync function runPionexCommand(argv: string[]): Promise<void> {\n const { positionals, flags } = parseFlags(argv);\n const group = positionals[0];\n 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_futures_grid_get_order\", { buOrderId, lang });\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"create\") {\n const base = typeof flags.base === \"string\" ? flags.base : undefined;\n const quote = typeof flags.quote === \"string\" ? flags.quote : undefined;\n const copyFrom = typeof flags[\"copy-from\"] === \"string\" ? (flags[\"copy-from\"] as string) : typeof flags.copyFrom === \"string\" ? (flags.copyFrom as string) : undefined;\n const copyType = typeof flags[\"copy-type\"] === \"string\" ? (flags[\"copy-type\"] as string) : typeof flags.copyType === \"string\" ? (flags.copyType as string) : undefined;\n const copyBotOrderId =\n typeof flags[\"copy-bot-order-id\"] === \"string\"\n ? (flags[\"copy-bot-order-id\"] as string)\n : typeof flags.copyBotOrderId === \"string\"\n ? (flags.copyBotOrderId as string)\n : undefined;\n const buOrderDataRaw = parseJsonFlag(flags[\"bu-order-data-json\"] ?? flags.buOrderDataJson, \"bu-order-data-json\");\n if (!base || !quote) {\n throw new Error(\"Missing required flags: --base --quote --bu-order-data-json\");\n }\n const buOrderData = parseAndValidateCreateFuturesGridBuOrderData(buOrderDataRaw);\n const payload: Record<string, unknown> = { base, quote, copyFrom, copyType, copyBotOrderId, buOrderData };\n if (dryRun) {\n const out = await runTool(\"pionex_bot_futures_grid_create\", { ...payload, __dryRun: true });\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n const out = await runTool(\"pionex_bot_futures_grid_create\", payload);\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"adjust_params\") {\n const payload = parseJsonFlag(flags[\"body-json\"] ?? flags.bodyJson, \"body-json\");\n if (dryRun) {\n process.stdout.write(JSON.stringify({ tool: \"pionex_bot_futures_grid_adjust_params\", args: payload }, null, 2) + \"\\n\");\n return;\n }\n const out = await runTool(\"pionex_bot_futures_grid_adjust_params\", payload);\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"reduce\") {\n const payload = parseJsonFlag(flags[\"body-json\"] ?? flags.bodyJson, \"body-json\");\n if (dryRun) {\n process.stdout.write(JSON.stringify({ tool: \"pionex_bot_futures_grid_reduce\", args: payload }, null, 2) + \"\\n\");\n return;\n }\n const out = await runTool(\"pionex_bot_futures_grid_reduce\", payload);\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n if (command === \"cancel\") {\n const buOrderId =\n typeof flags[\"bu-order-id\"] === \"string\"\n ? (flags[\"bu-order-id\"] as string)\n : typeof flags.buOrderId === \"string\"\n ? (flags.buOrderId as string)\n : undefined;\n const closeNote = typeof flags[\"close-note\"] === \"string\" ? (flags[\"close-note\"] as string) : typeof flags.closeNote === \"string\" ? (flags.closeNote as string) : undefined;\n const closeSellModel =\n typeof flags[\"close-sell-model\"] === \"string\"\n ? (flags[\"close-sell-model\"] as string)\n : typeof flags.closeSellModel === \"string\"\n ? (flags.closeSellModel as string)\n : undefined;\n const immediate = typeof flags.immediate === \"boolean\" ? flags.immediate : undefined;\n const closeSlippage =\n typeof flags[\"close-slippage\"] === \"string\"\n ? (flags[\"close-slippage\"] as string)\n : typeof flags.closeSlippage === \"string\"\n ? (flags.closeSlippage as string)\n : undefined;\n if (!buOrderId) throw new Error(\"Missing required flag: --bu-order-id\");\n const payload = { buOrderId, closeNote, closeSellModel, immediate, closeSlippage };\n if (dryRun) {\n process.stdout.write(JSON.stringify({ tool: \"pionex_bot_futures_grid_cancel\", args: payload }, null, 2) + \"\\n\");\n return;\n }\n const out = await runTool(\"pionex_bot_futures_grid_cancel\", payload);\n process.stdout.write(JSON.stringify(out.data, null, 2) + \"\\n\");\n return;\n }\n throw new Error(`Unknown 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\";\nimport type { QueryParams } from \"../client/types.js\";\n\nexport function registerMarketTools(): ToolSpec[] {\n return [\n {\n name: \"pionex_market_get_depth\",\n module: \"market\",\n isWrite: false,\n description: \"Get order book depth (bids and asks) for a symbol. Use for spread, liquidity, or best bid/ask.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n limit: { type: \"integer\", description: \"Price levels (1-100), default 5\" },\n },\n required: [\"symbol\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const limit = args.limit == null ? undefined : Number(args.limit);\n const q: QueryParams = { symbol };\n if (limit != null && Number.isFinite(limit)) q.limit = limit;\n return (await client.publicGet(\"/api/v1/market/depth\", q)).data;\n },\n },\n {\n name: \"pionex_market_get_trades\",\n module: \"market\",\n isWrite: false,\n description: \"Get recent trades for a symbol. Use for latest price and volume.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n limit: { type: \"integer\", description: \"Default 5 (1-100)\" },\n },\n required: [\"symbol\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const limit = args.limit == null ? undefined : Number(args.limit);\n const q: QueryParams = { symbol };\n if (limit != null && Number.isFinite(limit)) q.limit = limit;\n return (await client.publicGet(\"/api/v1/market/trades\", q)).data;\n },\n },\n {\n name: \"pionex_market_get_symbol_info\",\n module: \"market\",\n isWrite: false,\n description:\n \"Get symbol metadata (precision, min size, price limits). Call before placing orders to avoid amount/size filter errors.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbols: {\n type: \"string\",\n description: 'Optional. One or more symbols, comma-separated, e.g. \"BTC_USDT\" or \"BTC_USDT,ADA_USDT\".',\n },\n type: {\n type: \"string\",\n enum: [\"SPOT\", \"PERP\"],\n description: \"Optional. If no symbols are specified, filter by type (default SPOT).\",\n },\n },\n },\n async handler(args, { client }) {\n const q: QueryParams = {};\n if (args.symbols) q.symbols = String(args.symbols);\n if (!args.symbols && args.type) q.type = String(args.type);\n return (await client.publicGet(\"/api/v1/common/symbols\", q)).data;\n },\n },\n {\n name: \"pionex_market_get_tickers\",\n module: \"market\",\n isWrite: false,\n description: \"Get 24-hour ticker(s): open, close, high, low, volume, amount, count. Optional symbol or type (SPOT/PERP).\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT; if omitted, returns all tickers filtered by type\" },\n type: { type: \"string\", enum: [\"SPOT\", \"PERP\"], description: \"If symbol is not specified, filter by type.\" },\n },\n },\n async handler(args, { client }) {\n const q: QueryParams = {};\n if (args.symbol) q.symbol = String(args.symbol);\n if (args.type) q.type = String(args.type);\n return (await client.publicGet(\"/api/v1/market/tickers\", q)).data;\n },\n },\n {\n name: \"pionex_market_get_klines\",\n module: \"market\",\n isWrite: false,\n description: \"Get OHLCV klines (candlestick) for a symbol. Use for charts or historical price/volume.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n interval: { type: \"string\", enum: [\"1M\", \"5M\", \"15M\", \"30M\", \"60M\", \"4H\", \"8H\", \"12H\", \"1D\"], description: \"Kline interval.\" },\n endTime: { type: \"integer\", description: \"End time in milliseconds.\" },\n limit: { type: \"integer\", description: \"Default 100 (1-500).\" },\n },\n required: [\"symbol\", \"interval\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const interval = String(args.interval);\n const q: QueryParams = { symbol, interval };\n if (args.endTime != null) q.endTime = Number(args.endTime);\n if (args.limit != null) q.limit = Number(args.limit);\n return (await client.publicGet(\"/api/v1/market/klines\", q)).data;\n },\n },\n ];\n}\n\n","import type { ToolSpec } from \"./types.js\";\n\nexport function registerAccountTools(): ToolSpec[] {\n return [\n {\n name: \"pionex_account_get_balance\",\n module: \"account\",\n isWrite: false,\n description: \"Query spot account balances for all currencies. Requires API key and secret in ~/.pionex/config.toml or env.\",\n inputSchema: { type: \"object\", additionalProperties: false, properties: {} },\n async handler(_args, { client }) {\n return (await client.signedGet(\"/api/v1/account/balances\")).data;\n },\n },\n ];\n}\n\n","import type { ToolSpec } from \"./types.js\";\nimport type { QueryParams } from \"../client/types.js\";\n\nexport function registerOrdersTools(): ToolSpec[] {\n return [\n {\n name: \"pionex_orders_new_order\",\n module: \"orders\",\n isWrite: true,\n description:\n \"Create a spot order on Pionex. LIMIT requires symbol/side/type=LIMIT/price/size. MARKET BUY requires amount (quote). MARKET SELL requires size (base).\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n side: { type: \"string\", enum: [\"BUY\", \"SELL\"] },\n type: { type: \"string\", enum: [\"LIMIT\", \"MARKET\"] },\n clientOrderId: { type: \"string\", description: \"Optional client order id (max 64 chars)\" },\n size: { type: \"string\", description: \"Quantity; required for limit and market sell\" },\n price: { type: \"string\", description: \"Required for limit order\" },\n amount: { type: \"string\", description: \"Quote amount; required for market buy\" },\n IOC: { type: \"boolean\", description: \"Immediate-or-cancel, default false\" },\n },\n required: [\"symbol\", \"side\", \"type\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; order placement is disabled.\");\n }\n const body: Record<string, unknown> = {};\n if (args.symbol != null) body.symbol = String(args.symbol);\n if (args.side != null) body.side = String(args.side);\n if (args.type != null) body.type = String(args.type);\n if (args.clientOrderId != null) body.clientOrderId = String(args.clientOrderId);\n if (args.size != null) body.size = String(args.size);\n if (args.price != null) body.price = String(args.price);\n if (args.amount != null) body.amount = String(args.amount);\n if (args.IOC != null) body.IOC = Boolean(args.IOC);\n return (await client.signedPost(\"/api/v1/trade/order\", body)).data;\n },\n },\n {\n name: \"pionex_orders_get_order\",\n module: \"orders\",\n isWrite: false,\n description: \"Get a single order by order ID.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n orderId: { type: \"integer\", description: \"Order id\" },\n },\n required: [\"symbol\", \"orderId\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const orderId = Number(args.orderId);\n return (await client.signedGet(\"/api/v1/trade/order\", { symbol, orderId })).data;\n },\n },\n {\n name: \"pionex_orders_get_order_by_client_order_id\",\n module: \"orders\",\n isWrite: false,\n description: \"Get a single order by client order ID.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n clientOrderId: { type: \"string\", description: \"Client order id\" },\n },\n required: [\"symbol\", \"clientOrderId\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const clientOrderId = String(args.clientOrderId);\n return (await client.signedGet(\"/api/v1/trade/orderByClientOrderId\", { symbol, clientOrderId })).data;\n },\n },\n {\n name: \"pionex_orders_get_open_orders\",\n module: \"orders\",\n isWrite: false,\n description: \"List open (unfilled) orders for a symbol.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: { symbol: { type: \"string\", description: \"e.g. BTC_USDT\" } },\n required: [\"symbol\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n return (await client.signedGet(\"/api/v1/trade/openOrders\", { symbol })).data;\n },\n },\n {\n name: \"pionex_orders_get_all_orders\",\n module: \"orders\",\n isWrite: false,\n description: \"List order history for a symbol (filled and cancelled), with optional limit.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n limit: { type: \"integer\", description: \"Default 1 (1-100)\" },\n },\n required: [\"symbol\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const q: QueryParams = { symbol };\n if (args.limit != null) q.limit = Number(args.limit);\n return (await client.signedGet(\"/api/v1/trade/allOrders\", q)).data;\n },\n },\n {\n name: \"pionex_orders_cancel_order\",\n module: \"orders\",\n isWrite: true,\n description: \"Cancel an open order by order ID.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n orderId: { type: \"integer\", description: \"Order id\" },\n },\n required: [\"symbol\", \"orderId\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; order cancellation is disabled.\");\n }\n const symbol = String(args.symbol);\n const orderId = Number(args.orderId);\n return (await client.signedDelete(\"/api/v1/trade/order\", { symbol, orderId })).data;\n },\n },\n {\n name: \"pionex_orders_get_fills\",\n module: \"orders\",\n isWrite: false,\n description: \"Get filled trades (fills) for a symbol in a time range. Requires API key. Returns up to 100 latest fills.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n startTime: { type: \"integer\", description: \"Start time in milliseconds.\" },\n endTime: { type: \"integer\", description: \"End time in milliseconds.\" },\n },\n required: [\"symbol\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const q: QueryParams = { symbol };\n if (args.startTime != null) q.startTime = Number(args.startTime);\n if (args.endTime != null) q.endTime = Number(args.endTime);\n return (await client.signedGet(\"/api/v1/trade/fills\", q)).data;\n },\n },\n {\n name: \"pionex_orders_cancel_all_orders\",\n module: \"orders\",\n isWrite: true,\n description: \"Cancel all open orders for a symbol.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: { symbol: { type: \"string\", description: \"e.g. BTC_USDT\" } },\n required: [\"symbol\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; cancel-all is disabled.\");\n }\n const symbol = String(args.symbol);\n return (await client.signedDelete(\"/api/v1/trade/allOrders\", { symbol })).data;\n },\n },\n ];\n}\n\n","/**\n * Mirrors openapi_bot.yaml — CreateFuturesGridRequest + CreateFuturesGridOrderData.\n * https://github.com/pionex-official/pionex-open-api/blob/main/openapi_bot.yaml\n */\nimport type { JsonSchema } from \"../tools/types.js\";\n\n/** Every property under CreateFuturesGridOrderData (OpenAPI); no other keys allowed. */\nexport const CREATE_FUTURES_GRID_ORDER_DATA_KEYS = [\n \"top\",\n \"bottom\",\n \"row\",\n \"grid_type\",\n \"trend\",\n \"leverage\",\n \"extraMargin\",\n \"quoteInvestment\",\n \"condition\",\n \"conditionDirection\",\n \"lossStopType\",\n \"lossStop\",\n \"lossStopDelay\",\n \"profitStopType\",\n \"profitStop\",\n \"profitStopDelay\",\n \"lossStopHigh\",\n \"shareRatio\",\n \"investCoin\",\n \"investmentFrom\",\n \"uiInvestCoin\",\n \"lossStopLimitPrice\",\n \"lossStopLimitHighPrice\",\n \"profitStopLimitPrice\",\n \"slippage\",\n \"bonusId\",\n \"uiExtraData\",\n \"movingIndicatorType\",\n \"movingIndicatorInterval\",\n \"movingIndicatorParam\",\n \"movingTrailingUpParam\",\n \"cateType\",\n \"movingTop\",\n \"movingBottom\",\n \"enableFollowClosed\",\n] as const;\n\nconst ORDER_DATA_KEY_SET = new Set<string>(CREATE_FUTURES_GRID_ORDER_DATA_KEYS);\n\nfunction asNonEmptyString(value: unknown, field: string): string {\n if (typeof value !== \"string\" || value.trim().length === 0) {\n throw new Error(`Invalid \"${field}\": expected non-empty string.`);\n }\n return value.trim();\n}\n\nfunction asFiniteNumber(value: unknown, field: string): number {\n if (typeof value !== \"number\" || !Number.isFinite(value)) {\n throw new Error(`Invalid \"${field}\": expected finite number.`);\n }\n return value;\n}\n\nfunction asPositiveNumber(value: unknown, field: string): number {\n const n = asFiniteNumber(value, field);\n if (n <= 0) throw new Error(`Invalid \"${field}\": expected number > 0.`);\n return n;\n}\n\nfunction asPositiveInteger(value: unknown, field: string): number {\n const n = asPositiveNumber(value, field);\n if (!Number.isInteger(n)) {\n throw new Error(`Invalid \"${field}\": expected positive integer.`);\n }\n return n;\n}\n\nfunction asBoolean(value: unknown, field: string): boolean {\n if (typeof value !== \"boolean\") {\n throw new Error(`Invalid \"${field}\": expected boolean.`);\n }\n return value;\n}\n\nfunction assertEnum(value: string, field: string, allowed: readonly string[]): void {\n if (!allowed.includes(value)) {\n throw new Error(`Invalid \"${field}\": expected one of ${allowed.join(\", \")}.`);\n }\n}\n\nfunction asPositiveDecimalString(value: unknown, field: string): string {\n const s = asNonEmptyString(value, field);\n if (!/^\\d+(\\.\\d+)?$/.test(s)) {\n throw new Error(`Invalid \"${field}\": expected positive decimal string.`);\n }\n const n = Number(s);\n if (!Number.isFinite(n) || n <= 0) {\n throw new Error(`Invalid \"${field}\": expected positive decimal string.`);\n }\n return s;\n}\n\nfunction asPositiveDecimalStringLoose(value: unknown, field: string): string {\n if (typeof value === \"number\" && Number.isFinite(value) && value > 0) {\n return String(value);\n }\n return asPositiveDecimalString(value, field);\n}\n\nfunction asNonNegativeDecimalString(value: unknown, field: string): string {\n const s = asNonEmptyString(value, field);\n if (!/^\\d+(\\.\\d+)?$/.test(s)) {\n throw new Error(`Invalid \"${field}\": expected non-negative decimal string.`);\n }\n const n = Number(s);\n if (!Number.isFinite(n) || n < 0) {\n throw new Error(`Invalid \"${field}\": expected non-negative decimal string.`);\n }\n return s;\n}\n\nfunction asOptionalString(value: unknown, field: string): string {\n if (typeof value !== \"string\") {\n throw new Error(`Invalid \"${field}\": expected string.`);\n }\n return value;\n}\n\nfunction asOptionalNonNegativeNumber(value: unknown, field: string): number {\n const n = asFiniteNumber(value, field);\n if (n < 0) throw new Error(`Invalid \"${field}\": expected number >= 0.`);\n return n;\n}\n\n/** Strip + reject unknown keys; validate types per OpenAPI. Returns body-ready buOrderData. */\nexport function parseAndValidateCreateFuturesGridBuOrderData(raw: Record<string, unknown>): Record<string, unknown> {\n const data = { ...raw };\n delete data.openPrice;\n delete data.keyId;\n delete data.key_id;\n\n for (const k of Object.keys(data)) {\n if (!ORDER_DATA_KEY_SET.has(k)) {\n throw new Error(`Unknown buOrderData property \"${k}\". Allowed keys: ${CREATE_FUTURES_GRID_ORDER_DATA_KEYS.join(\", \")}.`);\n }\n }\n\n const top = asPositiveDecimalStringLoose(data.top, \"buOrderData.top\");\n const bottom = asPositiveDecimalStringLoose(data.bottom, \"buOrderData.bottom\");\n if (Number(top) <= Number(bottom)) {\n throw new Error('Invalid \"buOrderData.top\": expected top > bottom.');\n }\n const row = asPositiveInteger(data.row, \"buOrderData.row\");\n const gridType = asNonEmptyString(data.grid_type, \"buOrderData.grid_type\");\n assertEnum(gridType, \"buOrderData.grid_type\", [\"arithmetic\", \"geometric\"]);\n const trend = asNonEmptyString(data.trend, \"buOrderData.trend\");\n assertEnum(trend, \"buOrderData.trend\", [\"long\", \"short\", \"no_trend\"]);\n const leverage = asPositiveNumber(data.leverage, \"buOrderData.leverage\");\n const quoteInvestment = asPositiveDecimalStringLoose(data.quoteInvestment, \"buOrderData.quoteInvestment\");\n\n const out: Record<string, unknown> = {\n top,\n bottom,\n row,\n grid_type: gridType,\n trend,\n leverage,\n quoteInvestment,\n };\n\n if (data.extraMargin != null) {\n out.extraMargin = asNonNegativeDecimalString(data.extraMargin, \"buOrderData.extraMargin\");\n }\n if (data.condition != null) out.condition = asOptionalString(data.condition, \"buOrderData.condition\");\n if (data.conditionDirection != null) {\n const v = asNonEmptyString(data.conditionDirection, \"buOrderData.conditionDirection\");\n assertEnum(v, \"buOrderData.conditionDirection\", [\"-1\", \"1\"]);\n out.conditionDirection = v;\n }\n if (data.lossStopType != null) {\n const v = asNonEmptyString(data.lossStopType, \"buOrderData.lossStopType\");\n assertEnum(v, \"buOrderData.lossStopType\", [\"price\", \"profit_amount\", \"profit_ratio\", \"price_limit\"]);\n out.lossStopType = v;\n }\n if (data.lossStop != null) out.lossStop = asOptionalString(data.lossStop, \"buOrderData.lossStop\");\n if (data.lossStopDelay != null) out.lossStopDelay = asOptionalNonNegativeNumber(data.lossStopDelay, \"buOrderData.lossStopDelay\");\n if (data.profitStopType != null) {\n const v = asNonEmptyString(data.profitStopType, \"buOrderData.profitStopType\");\n assertEnum(v, \"buOrderData.profitStopType\", [\"price\", \"profit_amount\", \"profit_ratio\", \"price_limit\"]);\n out.profitStopType = v;\n }\n if (data.profitStop != null) out.profitStop = asOptionalString(data.profitStop, \"buOrderData.profitStop\");\n if (data.profitStopDelay != null) out.profitStopDelay = asOptionalNonNegativeNumber(data.profitStopDelay, \"buOrderData.profitStopDelay\");\n if (data.lossStopHigh != null) out.lossStopHigh = asOptionalString(data.lossStopHigh, \"buOrderData.lossStopHigh\");\n if (data.shareRatio != null) out.shareRatio = asOptionalString(data.shareRatio, \"buOrderData.shareRatio\");\n if (data.investCoin != null) out.investCoin = asOptionalString(data.investCoin, \"buOrderData.investCoin\");\n if (data.investmentFrom != null) {\n const v = asNonEmptyString(data.investmentFrom, \"buOrderData.investmentFrom\");\n assertEnum(v, \"buOrderData.investmentFrom\", [\"USER\", \"LOCK_ACTIVITY\", \"FUTURE_GRID_BONUS\"]);\n out.investmentFrom = v;\n }\n if (data.uiInvestCoin != null) out.uiInvestCoin = asOptionalString(data.uiInvestCoin, \"buOrderData.uiInvestCoin\");\n if (data.lossStopLimitPrice != null) out.lossStopLimitPrice = asOptionalString(data.lossStopLimitPrice, \"buOrderData.lossStopLimitPrice\");\n if (data.lossStopLimitHighPrice != null) out.lossStopLimitHighPrice = asOptionalString(data.lossStopLimitHighPrice, \"buOrderData.lossStopLimitHighPrice\");\n if (data.profitStopLimitPrice != null) out.profitStopLimitPrice = asOptionalString(data.profitStopLimitPrice, \"buOrderData.profitStopLimitPrice\");\n if (data.slippage != null) out.slippage = asOptionalString(data.slippage, \"buOrderData.slippage\");\n if (data.bonusId != null) out.bonusId = asOptionalString(data.bonusId, \"buOrderData.bonusId\");\n if (data.uiExtraData != null) out.uiExtraData = asOptionalString(data.uiExtraData, \"buOrderData.uiExtraData\");\n if (data.movingIndicatorType != null) out.movingIndicatorType = asOptionalString(data.movingIndicatorType, \"buOrderData.movingIndicatorType\");\n if (data.movingIndicatorInterval != null) out.movingIndicatorInterval = asOptionalString(data.movingIndicatorInterval, \"buOrderData.movingIndicatorInterval\");\n if (data.movingIndicatorParam != null) out.movingIndicatorParam = asOptionalString(data.movingIndicatorParam, \"buOrderData.movingIndicatorParam\");\n if (data.movingTrailingUpParam != null) out.movingTrailingUpParam = asOptionalString(data.movingTrailingUpParam, \"buOrderData.movingTrailingUpParam\");\n if (data.cateType != null) {\n const v = asNonEmptyString(data.cateType, \"buOrderData.cateType\");\n assertEnum(v, \"buOrderData.cateType\", [\"FULLY_HEDGING\", \"LOAN_GRID\", \"LEVERAGE_GRID\", \"FUTURE_GRID_COIN_MARGINED\"]);\n out.cateType = v;\n }\n if (data.movingTop != null) out.movingTop = asOptionalString(data.movingTop, \"buOrderData.movingTop\");\n if (data.movingBottom != null) out.movingBottom = asOptionalString(data.movingBottom, \"buOrderData.movingBottom\");\n if (data.enableFollowClosed != null) out.enableFollowClosed = asBoolean(data.enableFollowClosed, \"buOrderData.enableFollowClosed\");\n\n return out;\n}\n\n/** JSON Schema for MCP tool `buOrderData` — matches openapi_bot.yaml CreateFuturesGridOrderData.properties */\nexport const createFuturesGridOrderDataJsonSchema: JsonSchema = {\n type: \"object\",\n additionalProperties: false,\n description: \"CreateFuturesGridOrderData (openapi_bot.yaml). Required: top, bottom, row, grid_type, trend, leverage, quoteInvestment.\",\n required: [\"top\", \"bottom\", \"row\", \"grid_type\", \"trend\", \"leverage\", \"quoteInvestment\"],\n properties: {\n top: { type: \"string\", description: \"Grid upper price\" },\n bottom: { type: \"string\", description: \"Grid lower price\" },\n row: { type: \"number\", description: \"Number of grid levels\" },\n grid_type: {\n type: \"string\",\n enum: [\"arithmetic\", \"geometric\"],\n description: \"Grid spacing: arithmetic (equal difference) or geometric (equal ratio)\",\n },\n trend: {\n type: \"string\",\n enum: [\"long\", \"short\", \"no_trend\"],\n description: \"Grid direction\",\n },\n leverage: { type: \"number\", description: \"Leverage multiplier\" },\n extraMargin: { type: \"string\", description: \"Extra margin amount (optional)\" },\n quoteInvestment: { type: \"string\", description: \"Investment amount\" },\n condition: { type: \"string\", description: \"Trigger price (conditional orders)\" },\n conditionDirection: { type: \"string\", enum: [\"-1\", \"1\"], description: \"Trigger direction\" },\n lossStopType: {\n type: \"string\",\n enum: [\"price\", \"profit_amount\", \"profit_ratio\", \"price_limit\"],\n description: \"Stop loss type\",\n },\n lossStop: { type: \"string\", description: \"Stop loss value\" },\n lossStopDelay: { type: \"number\", description: \"Stop loss delay (seconds)\" },\n profitStopType: {\n type: \"string\",\n enum: [\"price\", \"profit_amount\", \"profit_ratio\", \"price_limit\"],\n description: \"Take profit type\",\n },\n profitStop: { type: \"string\", description: \"Take profit value\" },\n profitStopDelay: { type: \"number\", description: \"Take profit delay (seconds)\" },\n lossStopHigh: { type: \"string\", description: \"Upper stop loss price for neutral grid\" },\n shareRatio: { type: \"string\", description: \"Profit sharing ratio\" },\n investCoin: { type: \"string\", description: \"Investment currency\" },\n investmentFrom: {\n type: \"string\",\n enum: [\"USER\", \"LOCK_ACTIVITY\", \"FUTURE_GRID_BONUS\"],\n description: \"Funding source\",\n },\n uiInvestCoin: { type: \"string\", description: \"Frontend-recorded investment currency\" },\n lossStopLimitPrice: { type: \"string\", description: \"Limit SL price (lossStopType=price_limit)\" },\n lossStopLimitHighPrice: { type: \"string\", description: \"Upper limit SL for neutral grid\" },\n profitStopLimitPrice: { type: \"string\", description: \"Limit TP price (profitStopType=price_limit)\" },\n slippage: { type: \"string\", description: \"Open slippage e.g. 0.01 = 1%\" },\n bonusId: { type: \"string\", description: \"Bonus UUID\" },\n uiExtraData: { type: \"string\", description: \"Frontend extra (coin-margined)\" },\n movingIndicatorType: { type: \"string\", description: \"e.g. sma\" },\n movingIndicatorInterval: { type: \"string\", description: \"e.g. 1m, 15m\" },\n movingIndicatorParam: { type: \"string\", description: \"JSON params e.g. length\" },\n movingTrailingUpParam: { type: \"string\", description: \"SMA trailing up ratio\" },\n cateType: {\n type: \"string\",\n enum: [\"FULLY_HEDGING\", \"LOAN_GRID\", \"LEVERAGE_GRID\", \"FUTURE_GRID_COIN_MARGINED\"],\n description: \"Category type\",\n },\n movingTop: { type: \"string\", description: \"Moving grid upper limit\" },\n movingBottom: { type: \"string\", description: \"Moving grid lower limit\" },\n enableFollowClosed: { type: \"boolean\", description: \"Follow close\" },\n },\n};\n\n/** Full MCP input schema for pionex_bot_futures_grid_create (includes internal __dryRun for CLI). */\nexport const createFuturesGridCreateToolInputSchema: JsonSchema = {\n type: \"object\",\n additionalProperties: false,\n required: [\"base\", \"quote\", \"buOrderData\"],\n properties: {\n base: { type: \"string\", description: \"Base currency (e.g. BTC); *.PERP normalized in handler\" },\n quote: { type: \"string\", description: \"Quote currency (e.g. USDT)\" },\n copyFrom: { type: \"string\", description: \"Optional. Copy source order ID\" },\n copyType: { type: \"string\", description: \"Optional. Copy type\" },\n copyBotOrderId: { type: \"string\", description: \"Optional. Copy bot order ID\" },\n buOrderData: createFuturesGridOrderDataJsonSchema,\n __dryRun: { type: \"boolean\", description: \"Internal: when true, return resolved body without POST\" },\n },\n};\n","import type { ToolSpec } from \"./types.js\";\nimport {\n createFuturesGridCreateToolInputSchema,\n parseAndValidateCreateFuturesGridBuOrderData,\n} from \"../schemas/futures-grid-create.js\";\nimport type { QueryParams } from \"../client/types.js\";\n\nfunction asNonEmptyString(value: unknown, field: string): string {\n if (typeof value !== \"string\" || value.trim().length === 0) {\n throw new Error(`Invalid \"${field}\": expected non-empty string.`);\n }\n return value.trim();\n}\n\nfunction asFiniteNumber(value: unknown, field: string): number {\n if (typeof value !== \"number\" || !Number.isFinite(value)) {\n throw new Error(`Invalid \"${field}\": expected finite number.`);\n }\n return value;\n}\n\nfunction asPositiveNumber(value: unknown, field: string): number {\n const n = asFiniteNumber(value, field);\n if (n <= 0) throw new Error(`Invalid \"${field}\": expected number > 0.`);\n return n;\n}\n\nfunction asPositiveInteger(value: unknown, field: string): number {\n const n = asPositiveNumber(value, field);\n if (!Number.isInteger(n)) {\n throw new Error(`Invalid \"${field}\": expected positive integer.`);\n }\n return n;\n}\n\nfunction asBoolean(value: unknown, field: string): boolean {\n if (typeof value !== \"boolean\") {\n throw new Error(`Invalid \"${field}\": expected boolean.`);\n }\n return value;\n}\n\nfunction assertEnum(value: string, field: string, allowed: readonly string[]): void {\n if (!allowed.includes(value)) {\n throw new Error(`Invalid \"${field}\": expected one of ${allowed.join(\", \")}.`);\n }\n}\n\nfunction asObject(value: unknown, field: string): Record<string, unknown> {\n if (!value || typeof value !== \"object\" || Array.isArray(value)) {\n throw new Error(`Invalid \"${field}\": expected JSON object.`);\n }\n return value as Record<string, unknown>;\n}\n\nfunction asPositiveDecimalString(value: unknown, field: string): string {\n const s = asNonEmptyString(value, field);\n if (!/^\\d+(\\.\\d+)?$/.test(s)) {\n throw new Error(`Invalid \"${field}\": expected positive decimal string.`);\n }\n const n = Number(s);\n if (!Number.isFinite(n) || n <= 0) {\n throw new Error(`Invalid \"${field}\": expected positive decimal string.`);\n }\n return s;\n}\n\nfunction normalizePerpBase(base: string): string {\n return base.endsWith(\".PERP\") ? base : `${base}.PERP`;\n}\n\nexport function registerBotTools(): ToolSpec[] {\n return [\n {\n name: \"pionex_bot_futures_grid_get_order\",\n module: \"bot\",\n isWrite: false,\n description: \"Get one futures grid bot order by buOrderId.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n buOrderId: { type: \"string\", description: \"Futures grid bot order id.\" },\n lang: { type: \"string\", description: \"Optional language code.\" },\n },\n required: [\"buOrderId\"],\n },\n async handler(args, { client }) {\n const buOrderId = String(args.buOrderId);\n const q: QueryParams = { buOrderId };\n if (args.lang != null) q.lang = String(args.lang);\n return (await client.signedGet(\"/api/v1/bot/orders/futuresGrid/order\", q)).data;\n },\n },\n {\n name: \"pionex_bot_futures_grid_create\",\n module: \"bot\",\n isWrite: true,\n description:\n \"Create a futures grid order (openapi_bot.yaml CreateFuturesGridRequest / CreateFuturesGridOrderData). \" +\n \"https://github.com/pionex-official/pionex-open-api/blob/main/openapi_bot.yaml — \" +\n \"Required: base, quote, buOrderData. Optional: copyFrom, copyType, copyBotOrderId. \" +\n \"buOrderData required: top, bottom, row, grid_type, trend, leverage, quoteInvestment; unknown keys rejected.\",\n inputSchema: createFuturesGridCreateToolInputSchema,\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; bot create is disabled.\");\n }\n const rawBase = asNonEmptyString(args.base, \"base\");\n const base = normalizePerpBase(rawBase);\n const quote = asNonEmptyString(args.quote, \"quote\");\n const buOrderDataOut = parseAndValidateCreateFuturesGridBuOrderData(asObject(args.buOrderData, \"buOrderData\"));\n const row = buOrderDataOut.row as number;\n const gridType = buOrderDataOut.grid_type as string;\n const leverage = buOrderDataOut.leverage as number;\n\n const body: Record<string, unknown> = {\n base,\n quote,\n buOrderData: buOrderDataOut,\n };\n if (args.copyFrom != null) body.copyFrom = String(args.copyFrom);\n if (args.copyType != null) body.copyType = String(args.copyType);\n if (args.copyBotOrderId != null) body.copyBotOrderId = String(args.copyBotOrderId);\n\n if (args.__dryRun === true) {\n return {\n dryRun: true,\n note: \"No order was sent. Body matches openapi_bot.yaml CreateFuturesGridRequest.\",\n resolvedParams: {\n row,\n grid_type: gridType,\n leverage,\n },\n resolvedBody: body,\n };\n }\n return (await client.signedPost(\"/api/v1/bot/orders/futuresGrid/create\", body)).data;\n },\n },\n {\n name: \"pionex_bot_futures_grid_adjust_params\",\n module: \"bot\",\n isWrite: true,\n description: \"Adjust futures grid bot params (invest_in / adjust_params / invest_in_trigger).\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n buOrderId: { type: \"string\" },\n type: { type: \"string\", enum: [\"invest_in\", \"adjust_params\", \"invest_in_trigger\"] },\n quoteInvestment: { type: \"number\" },\n extraMargin: { type: \"boolean\" },\n bottom: { type: \"string\" },\n top: { type: \"string\" },\n row: { type: \"number\" },\n extraMarginAmount: { type: \"number\" },\n isRecommend: { type: \"boolean\" },\n isReinvest: { type: \"boolean\" },\n investCoin: { type: \"string\" },\n investmentFrom: { type: \"string\", enum: [\"USER\", \"LOCK_ACTIVITY\"] },\n condition: { type: \"string\" },\n conditionDirection: { type: \"string\", enum: [\"1\", \"-1\"] },\n slippage: { type: \"string\" },\n adjustParamsSence: { type: \"string\" },\n },\n required: [\"buOrderId\", \"type\", \"extraMargin\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; bot adjust_params is disabled.\");\n }\n const buOrderId = asNonEmptyString(args.buOrderId, \"buOrderId\");\n const type = asNonEmptyString(args.type, \"type\");\n assertEnum(type, \"type\", [\"invest_in\", \"adjust_params\", \"invest_in_trigger\"]);\n const extraMargin = asBoolean(args.extraMargin, \"extraMargin\");\n\n if (type === \"invest_in\" && args.quoteInvestment != null) {\n asPositiveNumber(args.quoteInvestment, \"quoteInvestment\");\n }\n if (type === \"adjust_params\") {\n const bottom = asPositiveDecimalString(args.bottom, \"bottom\");\n const top = asPositiveDecimalString(args.top, \"top\");\n if (Number(top) <= Number(bottom)) {\n throw new Error('Invalid \"top\": expected top > bottom.');\n }\n asPositiveInteger(args.row, \"row\");\n }\n if (type === \"invest_in_trigger\") {\n asPositiveDecimalString(args.condition, \"condition\");\n const conditionDirection = asNonEmptyString(args.conditionDirection, \"conditionDirection\");\n assertEnum(conditionDirection, \"conditionDirection\", [\"1\", \"-1\"]);\n }\n\n const body: Record<string, unknown> = {\n buOrderId,\n type,\n extraMargin,\n };\n if (args.quoteInvestment != null) body.quoteInvestment = asFiniteNumber(args.quoteInvestment, \"quoteInvestment\");\n if (args.bottom != null) body.bottom = asPositiveDecimalString(args.bottom, \"bottom\");\n if (args.top != null) body.top = asPositiveDecimalString(args.top, \"top\");\n if (args.row != null) body.row = asPositiveInteger(args.row, \"row\");\n if (args.extraMarginAmount != null) body.extraMarginAmount = asFiniteNumber(args.extraMarginAmount, \"extraMarginAmount\");\n if (args.isRecommend != null) body.isRecommend = asBoolean(args.isRecommend, \"isRecommend\");\n if (args.isReinvest != null) body.isReinvest = asBoolean(args.isReinvest, \"isReinvest\");\n if (args.investCoin != null) body.investCoin = String(args.investCoin);\n if (args.investmentFrom != null) {\n const investmentFrom = asNonEmptyString(args.investmentFrom, \"investmentFrom\");\n assertEnum(investmentFrom, \"investmentFrom\", [\"USER\", \"LOCK_ACTIVITY\"]);\n body.investmentFrom = investmentFrom;\n }\n if (args.condition != null) body.condition = asPositiveDecimalString(args.condition, \"condition\");\n if (args.conditionDirection != null) {\n const conditionDirection = asNonEmptyString(args.conditionDirection, \"conditionDirection\");\n assertEnum(conditionDirection, \"conditionDirection\", [\"1\", \"-1\"]);\n body.conditionDirection = conditionDirection;\n }\n if (args.slippage != null) body.slippage = String(args.slippage);\n if (args.adjustParamsSence != null) body.adjustParamsSence = String(args.adjustParamsSence);\n return (await client.signedPost(\"/api/v1/bot/orders/futuresGrid/adjustParams\", body)).data;\n },\n },\n {\n name: \"pionex_bot_futures_grid_reduce\",\n module: \"bot\",\n isWrite: true,\n description: \"Reduce futures grid bot position.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n buOrderId: { type: \"string\" },\n reduceNum: { type: \"number\" },\n slippage: { type: \"string\" },\n condition: { type: \"string\" },\n conditionDirection: { type: \"string\", enum: [\"1\", \"-1\"] },\n },\n required: [\"buOrderId\", \"reduceNum\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; bot reduce is disabled.\");\n }\n const buOrderId = asNonEmptyString(args.buOrderId, \"buOrderId\");\n const reduceNum = asPositiveInteger(args.reduceNum, \"reduceNum\");\n const body: Record<string, unknown> = {\n buOrderId,\n reduceNum,\n };\n if (args.slippage != null) body.slippage = String(args.slippage);\n if (args.condition != null) body.condition = String(args.condition);\n if (args.conditionDirection != null) {\n const conditionDirection = asNonEmptyString(args.conditionDirection, \"conditionDirection\");\n assertEnum(conditionDirection, \"conditionDirection\", [\"1\", \"-1\"]);\n body.conditionDirection = conditionDirection;\n }\n return (await client.signedPost(\"/api/v1/bot/orders/futuresGrid/reduce\", body)).data;\n },\n },\n {\n name: \"pionex_bot_futures_grid_cancel\",\n module: \"bot\",\n isWrite: true,\n description: \"Cancel and close a futures grid bot order.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n buOrderId: { type: \"string\" },\n closeNote: { type: \"string\" },\n closeSellModel: { type: \"string\", enum: [\"TO_QUOTE\", \"TO_USDT\"] },\n immediate: { type: \"boolean\" },\n closeSlippage: { type: \"string\" },\n },\n required: [\"buOrderId\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; bot cancel is disabled.\");\n }\n const buOrderId = asNonEmptyString(args.buOrderId, \"buOrderId\");\n const body: Record<string, unknown> = { buOrderId };\n if (args.closeNote != null) body.closeNote = String(args.closeNote);\n if (args.closeSellModel != null) {\n const closeSellModel = asNonEmptyString(args.closeSellModel, \"closeSellModel\");\n assertEnum(closeSellModel, \"closeSellModel\", [\"TO_QUOTE\", \"TO_USDT\"]);\n body.closeSellModel = closeSellModel;\n }\n if (args.immediate != null) body.immediate = asBoolean(args.immediate, \"immediate\");\n if (args.closeSlippage != null) body.closeSlippage = String(args.closeSlippage);\n return (await client.signedPost(\"/api/v1/bot/orders/futuresGrid/cancel\", body)).data;\n },\n },\n ];\n}\n","import type { PionexConfig } from \"../config.js\";\nimport type { PionexRestClient } from \"../client/rest-client.js\";\nimport { MODULES, type ModuleId } from \"../constants.js\";\nimport type { ToolArgs, ToolSpec } from \"./types.js\";\nimport { registerMarketTools } from \"./market.js\";\nimport { registerAccountTools } from \"./account.js\";\nimport { registerOrdersTools } from \"./orders.js\";\nimport { registerBotTools } from \"./bot.js\";\n\nfunction allToolSpecs(): ToolSpec[] {\n return [...registerMarketTools(), ...registerAccountTools(), ...registerOrdersTools(), ...registerBotTools()];\n}\n\nexport function buildTools(config: PionexConfig): ToolSpec[] {\n const enabled = new Set(config.modules);\n const tools = allToolSpecs().filter((t) => enabled.has(t.module));\n if (!config.readOnly) return tools;\n return tools.filter((t) => !t.isWrite);\n}\n\nexport interface ToolResult {\n endpoint: string;\n requestTime: string;\n data: unknown;\n}\n\nexport type ToolRunner = (toolName: string, args: ToolArgs) => Promise<ToolResult>;\n\n/**\n * Create a function that can call any registered tool by name.\n * For CLI usage we keep module filtering at the command routing level,\n * but the runner itself knows all tools.\n */\nexport function createToolRunner(client: PionexRestClient, config: PionexConfig): ToolRunner {\n const fullConfig: PionexConfig = { ...config, modules: [...MODULES] as ModuleId[] };\n const toolMap = new Map<string, ToolSpec>(allToolSpecs().map((t) => [t.name, t]));\n\n return async (toolName: string, args: ToolArgs): Promise<ToolResult> => {\n const tool = toolMap.get(toolName);\n if (!tool) throw new Error(`Unknown tool: ${toolName}`);\n const data = await tool.handler(args, { config: fullConfig, client });\n return { endpoint: toolName, requestTime: new Date().toISOString(), data };\n };\n}\n\n","import type { ModuleId } from \"../constants.js\";\nimport type { PionexConfig } from \"../config.js\";\nimport type { PionexRestClient } from \"../client/rest-client.js\";\n\nexport type JsonSchema =\n | {\n type: \"object\";\n properties?: Record<string, JsonSchema>;\n required?: string[];\n additionalProperties?: boolean;\n description?: string;\n enum?: string[];\n }\n | { type: \"string\"; description?: string; enum?: string[] }\n | { type: \"number\"; description?: string }\n | { type: \"integer\"; description?: string }\n | { type: \"boolean\"; description?: string }\n | { type: \"array\"; items: JsonSchema; description?: string }\n | { type: \"null\" };\n\nexport interface ToolContext {\n config: PionexConfig;\n client: PionexRestClient;\n}\n\nexport type ToolArgs = Record<string, unknown>;\n\nexport interface ToolSpec {\n name: string;\n description: string;\n module: ModuleId;\n isWrite: boolean;\n inputSchema: JsonSchema;\n handler: (args: ToolArgs, ctx: ToolContext) => Promise<unknown>;\n}\n\nexport interface McpTool {\n name: string;\n description: string;\n inputSchema: JsonSchema;\n annotations?: {\n readOnlyHint?: boolean;\n destructiveHint?: boolean;\n idempotentHint?: boolean;\n openWorldHint?: boolean;\n };\n}\n\nexport function toMcpTool(tool: ToolSpec): McpTool {\n return {\n name: tool.name,\n description: tool.description,\n inputSchema: tool.inputSchema,\n annotations: {\n readOnlyHint: !tool.isWrite,\n destructiveHint: tool.isWrite,\n idempotentHint: !tool.isWrite,\n openWorldHint: false,\n },\n };\n}\n\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nfunction getLineColFromPtr(string, ptr) {\n let lines = string.slice(0, ptr).split(/\\r\\n|\\n|\\r/g);\n return [lines.length, lines.pop().length + 1];\n}\nfunction makeCodeBlock(string, line, column) {\n let lines = string.split(/\\r\\n|\\n|\\r/g);\n let codeblock = '';\n let numberLen = (Math.log10(line + 1) | 0) + 1;\n for (let i = line - 1; i <= line + 1; i++) {\n let l = lines[i - 1];\n if (!l)\n continue;\n codeblock += i.toString().padEnd(numberLen, ' ');\n codeblock += ': ';\n codeblock += l;\n codeblock += '\\n';\n if (i === line) {\n codeblock += ' '.repeat(numberLen + column + 2);\n codeblock += '^\\n';\n }\n }\n return codeblock;\n}\nexport class TomlError extends Error {\n line;\n column;\n codeblock;\n constructor(message, options) {\n const [line, column] = getLineColFromPtr(options.toml, options.ptr);\n const codeblock = makeCodeBlock(options.toml, line, column);\n super(`Invalid TOML document: ${message}\\n\\n${codeblock}`, options);\n this.line = line;\n this.column = column;\n this.codeblock = codeblock;\n }\n}\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nimport { TomlError } from './error.js';\nfunction isEscaped(str, ptr) {\n let i = 0;\n while (str[ptr - ++i] === '\\\\')\n ;\n return --i && (i % 2);\n}\nexport function indexOfNewline(str, start = 0, end = str.length) {\n let idx = str.indexOf('\\n', start);\n if (str[idx - 1] === '\\r')\n idx--;\n return idx <= end ? idx : -1;\n}\nexport function skipComment(str, ptr) {\n for (let i = ptr; i < str.length; i++) {\n let c = str[i];\n if (c === '\\n')\n return i;\n if (c === '\\r' && str[i + 1] === '\\n')\n return i + 1;\n if ((c < '\\x20' && c !== '\\t') || c === '\\x7f') {\n throw new TomlError('control characters are not allowed in comments', {\n toml: str,\n ptr: ptr,\n });\n }\n }\n return str.length;\n}\nexport function skipVoid(str, ptr, banNewLines, banComments) {\n let c;\n while ((c = str[ptr]) === ' ' || c === '\\t' || (!banNewLines && (c === '\\n' || c === '\\r' && str[ptr + 1] === '\\n')))\n ptr++;\n return banComments || c !== '#'\n ? ptr\n : skipVoid(str, skipComment(str, ptr), banNewLines);\n}\nexport function skipUntil(str, ptr, sep, end, banNewLines = false) {\n if (!end) {\n ptr = indexOfNewline(str, ptr);\n return ptr < 0 ? str.length : ptr;\n }\n for (let i = ptr; i < str.length; i++) {\n let c = str[i];\n if (c === '#') {\n i = indexOfNewline(str, i);\n }\n else if (c === sep) {\n return i + 1;\n }\n else if (c === end || (banNewLines && (c === '\\n' || (c === '\\r' && str[i + 1] === '\\n')))) {\n return i;\n }\n }\n throw new TomlError('cannot find end of structure', {\n toml: str,\n ptr: ptr\n });\n}\nexport function getStringEnd(str, seek) {\n let first = str[seek];\n let target = first === str[seek + 1] && str[seek + 1] === str[seek + 2]\n ? str.slice(seek, seek + 3)\n : first;\n seek += target.length - 1;\n do\n seek = str.indexOf(target, ++seek);\n while (seek > -1 && first !== \"'\" && isEscaped(str, seek));\n if (seek > -1) {\n seek += target.length;\n if (target.length > 1) {\n if (str[seek] === first)\n seek++;\n if (str[seek] === first)\n seek++;\n }\n }\n return seek;\n}\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nlet DATE_TIME_RE = /^(\\d{4}-\\d{2}-\\d{2})?[T ]?(?:(\\d{2}):\\d{2}(?::\\d{2}(?:\\.\\d+)?)?)?(Z|[-+]\\d{2}:\\d{2})?$/i;\nexport class TomlDate extends Date {\n #hasDate = false;\n #hasTime = false;\n #offset = null;\n constructor(date) {\n let hasDate = true;\n let hasTime = true;\n let offset = 'Z';\n if (typeof date === 'string') {\n let match = date.match(DATE_TIME_RE);\n if (match) {\n if (!match[1]) {\n hasDate = false;\n date = `0000-01-01T${date}`;\n }\n hasTime = !!match[2];\n // Make sure to use T instead of a space. Breaks in case of extreme values otherwise.\n hasTime && date[10] === ' ' && (date = date.replace(' ', 'T'));\n // Do not allow rollover hours.\n if (match[2] && +match[2] > 23) {\n date = '';\n }\n else {\n offset = match[3] || null;\n date = date.toUpperCase();\n if (!offset && hasTime)\n date += 'Z';\n }\n }\n else {\n date = '';\n }\n }\n super(date);\n if (!isNaN(this.getTime())) {\n this.#hasDate = hasDate;\n this.#hasTime = hasTime;\n this.#offset = offset;\n }\n }\n isDateTime() {\n return this.#hasDate && this.#hasTime;\n }\n isLocal() {\n return !this.#hasDate || !this.#hasTime || !this.#offset;\n }\n isDate() {\n return this.#hasDate && !this.#hasTime;\n }\n isTime() {\n return this.#hasTime && !this.#hasDate;\n }\n isValid() {\n return this.#hasDate || this.#hasTime;\n }\n toISOString() {\n let iso = super.toISOString();\n // Local Date\n if (this.isDate())\n return iso.slice(0, 10);\n // Local Time\n if (this.isTime())\n return iso.slice(11, 23);\n // Local DateTime\n if (this.#offset === null)\n return iso.slice(0, -1);\n // Offset DateTime\n if (this.#offset === 'Z')\n return iso;\n // This part is quite annoying: JS strips the original timezone from the ISO string representation\n // Instead of using a \"modified\" date and \"Z\", we restore the representation \"as authored\"\n let offset = (+(this.#offset.slice(1, 3)) * 60) + +(this.#offset.slice(4, 6));\n offset = this.#offset[0] === '-' ? offset : -offset;\n let offsetDate = new Date(this.getTime() - (offset * 60e3));\n return offsetDate.toISOString().slice(0, -1) + this.#offset;\n }\n static wrapAsOffsetDateTime(jsDate, offset = 'Z') {\n let date = new TomlDate(jsDate);\n date.#offset = offset;\n return date;\n }\n static wrapAsLocalDateTime(jsDate) {\n let date = new TomlDate(jsDate);\n date.#offset = null;\n return date;\n }\n static wrapAsLocalDate(jsDate) {\n let date = new TomlDate(jsDate);\n date.#hasTime = false;\n date.#offset = null;\n return date;\n }\n static wrapAsLocalTime(jsDate) {\n let date = new TomlDate(jsDate);\n date.#hasDate = false;\n date.#offset = null;\n return date;\n }\n}\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nimport { skipVoid } from './util.js';\nimport { TomlDate } from './date.js';\nimport { TomlError } from './error.js';\nlet INT_REGEX = /^((0x[0-9a-fA-F](_?[0-9a-fA-F])*)|(([+-]|0[ob])?\\d(_?\\d)*))$/;\nlet FLOAT_REGEX = /^[+-]?\\d(_?\\d)*(\\.\\d(_?\\d)*)?([eE][+-]?\\d(_?\\d)*)?$/;\nlet LEADING_ZERO = /^[+-]?0[0-9_]/;\nlet ESCAPE_REGEX = /^[0-9a-f]{2,8}$/i;\nlet ESC_MAP = {\n b: '\\b',\n t: '\\t',\n n: '\\n',\n f: '\\f',\n r: '\\r',\n e: '\\x1b',\n '\"': '\"',\n '\\\\': '\\\\',\n};\nexport function parseString(str, ptr = 0, endPtr = str.length) {\n let isLiteral = str[ptr] === '\\'';\n let isMultiline = str[ptr++] === str[ptr] && str[ptr] === str[ptr + 1];\n if (isMultiline) {\n endPtr -= 2;\n if (str[ptr += 2] === '\\r')\n ptr++;\n if (str[ptr] === '\\n')\n ptr++;\n }\n let tmp = 0;\n let isEscape;\n let parsed = '';\n let sliceStart = ptr;\n while (ptr < endPtr - 1) {\n let c = str[ptr++];\n if (c === '\\n' || (c === '\\r' && str[ptr] === '\\n')) {\n if (!isMultiline) {\n throw new TomlError('newlines are not allowed in strings', {\n toml: str,\n ptr: ptr - 1,\n });\n }\n }\n else if ((c < '\\x20' && c !== '\\t') || c === '\\x7f') {\n throw new TomlError('control characters are not allowed in strings', {\n toml: str,\n ptr: ptr - 1,\n });\n }\n if (isEscape) {\n isEscape = false;\n if (c === 'x' || c === 'u' || c === 'U') {\n // Unicode escape\n let code = str.slice(ptr, (ptr += (c === 'x' ? 2 : c === 'u' ? 4 : 8)));\n if (!ESCAPE_REGEX.test(code)) {\n throw new TomlError('invalid unicode escape', {\n toml: str,\n ptr: tmp,\n });\n }\n try {\n parsed += String.fromCodePoint(parseInt(code, 16));\n }\n catch {\n throw new TomlError('invalid unicode escape', {\n toml: str,\n ptr: tmp,\n });\n }\n }\n else if (isMultiline && (c === '\\n' || c === ' ' || c === '\\t' || c === '\\r')) {\n // Multiline escape\n ptr = skipVoid(str, ptr - 1, true);\n if (str[ptr] !== '\\n' && str[ptr] !== '\\r') {\n throw new TomlError('invalid escape: only line-ending whitespace may be escaped', {\n toml: str,\n ptr: tmp,\n });\n }\n ptr = skipVoid(str, ptr);\n }\n else if (c in ESC_MAP) {\n // Classic escape\n parsed += ESC_MAP[c];\n }\n else {\n throw new TomlError('unrecognized escape sequence', {\n toml: str,\n ptr: tmp,\n });\n }\n sliceStart = ptr;\n }\n else if (!isLiteral && c === '\\\\') {\n tmp = ptr - 1;\n isEscape = true;\n parsed += str.slice(sliceStart, tmp);\n }\n }\n return parsed + str.slice(sliceStart, endPtr - 1);\n}\nexport function parseValue(value, toml, ptr, integersAsBigInt) {\n // Constant values\n if (value === 'true')\n return true;\n if (value === 'false')\n return false;\n if (value === '-inf')\n return -Infinity;\n if (value === 'inf' || value === '+inf')\n return Infinity;\n if (value === 'nan' || value === '+nan' || value === '-nan')\n return NaN;\n // Avoid FP representation of -0\n if (value === '-0')\n return integersAsBigInt ? 0n : 0;\n // Numbers\n let isInt = INT_REGEX.test(value);\n if (isInt || FLOAT_REGEX.test(value)) {\n if (LEADING_ZERO.test(value)) {\n throw new TomlError('leading zeroes are not allowed', {\n toml: toml,\n ptr: ptr,\n });\n }\n value = value.replace(/_/g, '');\n let numeric = +value;\n if (isNaN(numeric)) {\n throw new TomlError('invalid number', {\n toml: toml,\n ptr: ptr,\n });\n }\n if (isInt) {\n if ((isInt = !Number.isSafeInteger(numeric)) && !integersAsBigInt) {\n throw new TomlError('integer value cannot be represented losslessly', {\n toml: toml,\n ptr: ptr,\n });\n }\n if (isInt || integersAsBigInt === true)\n numeric = BigInt(value);\n }\n return numeric;\n }\n const date = new TomlDate(value);\n if (!date.isValid()) {\n throw new TomlError('invalid value', {\n toml: toml,\n ptr: ptr,\n });\n }\n return date;\n}\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nimport { parseString, parseValue } from './primitive.js';\nimport { parseArray, parseInlineTable } from './struct.js';\nimport { skipVoid, skipUntil, skipComment, getStringEnd } from './util.js';\nimport { TomlError } from './error.js';\nfunction sliceAndTrimEndOf(str, startPtr, endPtr) {\n let value = str.slice(startPtr, endPtr);\n let commentIdx = value.indexOf('#');\n if (commentIdx > -1) {\n // The call to skipComment allows to \"validate\" the comment\n // (absence of control characters)\n skipComment(str, commentIdx);\n value = value.slice(0, commentIdx);\n }\n return [value.trimEnd(), commentIdx];\n}\nexport function extractValue(str, ptr, end, depth, integersAsBigInt) {\n if (depth === 0) {\n throw new TomlError('document contains excessively nested structures. aborting.', {\n toml: str,\n ptr: ptr\n });\n }\n let c = str[ptr];\n if (c === '[' || c === '{') {\n let [value, endPtr] = c === '['\n ? parseArray(str, ptr, depth, integersAsBigInt)\n : parseInlineTable(str, ptr, depth, integersAsBigInt);\n if (end) {\n endPtr = skipVoid(str, endPtr);\n if (str[endPtr] === ',')\n endPtr++;\n else if (str[endPtr] !== end) {\n throw new TomlError('expected comma or end of structure', {\n toml: str,\n ptr: endPtr,\n });\n }\n }\n return [value, endPtr];\n }\n let endPtr;\n if (c === '\"' || c === \"'\") {\n endPtr = getStringEnd(str, ptr);\n let parsed = parseString(str, ptr, endPtr);\n if (end) {\n endPtr = skipVoid(str, endPtr);\n if (str[endPtr] && str[endPtr] !== ',' && str[endPtr] !== end && str[endPtr] !== '\\n' && str[endPtr] !== '\\r') {\n throw new TomlError('unexpected character encountered', {\n toml: str,\n ptr: endPtr,\n });\n }\n endPtr += (+(str[endPtr] === ','));\n }\n return [parsed, endPtr];\n }\n endPtr = skipUntil(str, ptr, ',', end);\n let slice = sliceAndTrimEndOf(str, ptr, endPtr - (+(str[endPtr - 1] === ',')));\n if (!slice[0]) {\n throw new TomlError('incomplete key-value declaration: no value specified', {\n toml: str,\n ptr: ptr\n });\n }\n if (end && slice[1] > -1) {\n endPtr = skipVoid(str, ptr + slice[1]);\n endPtr += +(str[endPtr] === ',');\n }\n return [\n parseValue(slice[0], str, ptr, integersAsBigInt),\n endPtr,\n ];\n}\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nimport { parseString } from './primitive.js';\nimport { extractValue } from './extract.js';\nimport { getStringEnd, indexOfNewline, skipComment, skipVoid } from './util.js';\nimport { TomlError } from './error.js';\nlet KEY_PART_RE = /^[a-zA-Z0-9-_]+[ \\t]*$/;\nexport function parseKey(str, ptr, end = '=') {\n let dot = ptr - 1;\n let parsed = [];\n let endPtr = str.indexOf(end, ptr);\n if (endPtr < 0) {\n throw new TomlError('incomplete key-value: cannot find end of key', {\n toml: str,\n ptr: ptr,\n });\n }\n do {\n let c = str[ptr = ++dot];\n // If it's whitespace, ignore\n if (c !== ' ' && c !== '\\t') {\n // If it's a string\n if (c === '\"' || c === '\\'') {\n if (c === str[ptr + 1] && c === str[ptr + 2]) {\n throw new TomlError('multiline strings are not allowed in keys', {\n toml: str,\n ptr: ptr,\n });\n }\n let eos = getStringEnd(str, ptr);\n if (eos < 0) {\n throw new TomlError('unfinished string encountered', {\n toml: str,\n ptr: ptr,\n });\n }\n dot = str.indexOf('.', eos);\n let strEnd = str.slice(eos, dot < 0 || dot > endPtr ? endPtr : dot);\n let newLine = indexOfNewline(strEnd);\n if (newLine > -1) {\n throw new TomlError('newlines are not allowed in keys', {\n toml: str,\n ptr: ptr + dot + newLine,\n });\n }\n if (strEnd.trimStart()) {\n throw new TomlError('found extra tokens after the string part', {\n toml: str,\n ptr: eos,\n });\n }\n if (endPtr < eos) {\n endPtr = str.indexOf(end, eos);\n if (endPtr < 0) {\n throw new TomlError('incomplete key-value: cannot find end of key', {\n toml: str,\n ptr: ptr,\n });\n }\n }\n parsed.push(parseString(str, ptr, eos));\n }\n else {\n // Normal raw key part consumption and validation\n dot = str.indexOf('.', ptr);\n let part = str.slice(ptr, dot < 0 || dot > endPtr ? endPtr : dot);\n if (!KEY_PART_RE.test(part)) {\n throw new TomlError('only letter, numbers, dashes and underscores are allowed in keys', {\n toml: str,\n ptr: ptr,\n });\n }\n parsed.push(part.trimEnd());\n }\n }\n // Until there's no more dot\n } while (dot + 1 && dot < endPtr);\n return [parsed, skipVoid(str, endPtr + 1, true, true)];\n}\nexport function parseInlineTable(str, ptr, depth, integersAsBigInt) {\n let res = {};\n let seen = new Set();\n let c;\n ptr++;\n while ((c = str[ptr++]) !== '}' && c) {\n if (c === ',') {\n throw new TomlError('expected value, found comma', {\n toml: str,\n ptr: ptr - 1,\n });\n }\n else if (c === '#')\n ptr = skipComment(str, ptr);\n else if (c !== ' ' && c !== '\\t' && c !== '\\n' && c !== '\\r') {\n let k;\n let t = res;\n let hasOwn = false;\n let [key, keyEndPtr] = parseKey(str, ptr - 1);\n for (let i = 0; i < key.length; i++) {\n if (i)\n t = hasOwn ? t[k] : (t[k] = {});\n k = key[i];\n if ((hasOwn = Object.hasOwn(t, k)) && (typeof t[k] !== 'object' || seen.has(t[k]))) {\n throw new TomlError('trying to redefine an already defined value', {\n toml: str,\n ptr: ptr,\n });\n }\n if (!hasOwn && k === '__proto__') {\n Object.defineProperty(t, k, { enumerable: true, configurable: true, writable: true });\n }\n }\n if (hasOwn) {\n throw new TomlError('trying to redefine an already defined value', {\n toml: str,\n ptr: ptr,\n });\n }\n let [value, valueEndPtr] = extractValue(str, keyEndPtr, '}', depth - 1, integersAsBigInt);\n seen.add(value);\n t[k] = value;\n ptr = valueEndPtr;\n }\n }\n if (!c) {\n throw new TomlError('unfinished table encountered', {\n toml: str,\n ptr: ptr,\n });\n }\n return [res, ptr];\n}\nexport function parseArray(str, ptr, depth, integersAsBigInt) {\n let res = [];\n let c;\n ptr++;\n while ((c = str[ptr++]) !== ']' && c) {\n if (c === ',') {\n throw new TomlError('expected value, found comma', {\n toml: str,\n ptr: ptr - 1,\n });\n }\n else if (c === '#')\n ptr = skipComment(str, ptr);\n else if (c !== ' ' && c !== '\\t' && c !== '\\n' && c !== '\\r') {\n let e = extractValue(str, ptr - 1, ']', depth - 1, integersAsBigInt);\n res.push(e[0]);\n ptr = e[1];\n }\n }\n if (!c) {\n throw new TomlError('unfinished array encountered', {\n toml: str,\n ptr: ptr,\n });\n }\n return [res, ptr];\n}\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nimport { parseKey } from './struct.js';\nimport { extractValue } from './extract.js';\nimport { skipVoid } from './util.js';\nimport { TomlError } from './error.js';\nfunction peekTable(key, table, meta, type) {\n let t = table;\n let m = meta;\n let k;\n let hasOwn = false;\n let state;\n for (let i = 0; i < key.length; i++) {\n if (i) {\n t = hasOwn ? t[k] : (t[k] = {});\n m = (state = m[k]).c;\n if (type === 0 /* Type.DOTTED */ && (state.t === 1 /* Type.EXPLICIT */ || state.t === 2 /* Type.ARRAY */)) {\n return null;\n }\n if (state.t === 2 /* Type.ARRAY */) {\n let l = t.length - 1;\n t = t[l];\n m = m[l].c;\n }\n }\n k = key[i];\n if ((hasOwn = Object.hasOwn(t, k)) && m[k]?.t === 0 /* Type.DOTTED */ && m[k]?.d) {\n return null;\n }\n if (!hasOwn) {\n if (k === '__proto__') {\n Object.defineProperty(t, k, { enumerable: true, configurable: true, writable: true });\n Object.defineProperty(m, k, { enumerable: true, configurable: true, writable: true });\n }\n m[k] = {\n t: i < key.length - 1 && type === 2 /* Type.ARRAY */\n ? 3 /* Type.ARRAY_DOTTED */\n : type,\n d: false,\n i: 0,\n c: {},\n };\n }\n }\n state = m[k];\n if (state.t !== type && !(type === 1 /* Type.EXPLICIT */ && state.t === 3 /* Type.ARRAY_DOTTED */)) {\n // Bad key type!\n return null;\n }\n if (type === 2 /* Type.ARRAY */) {\n if (!state.d) {\n state.d = true;\n t[k] = [];\n }\n t[k].push(t = {});\n state.c[state.i++] = (state = { t: 1 /* Type.EXPLICIT */, d: false, i: 0, c: {} });\n }\n if (state.d) {\n // Redefining a table!\n return null;\n }\n state.d = true;\n if (type === 1 /* Type.EXPLICIT */) {\n t = hasOwn ? t[k] : (t[k] = {});\n }\n else if (type === 0 /* Type.DOTTED */ && hasOwn) {\n return null;\n }\n return [k, t, state.c];\n}\nexport function parse(toml, { maxDepth = 1000, integersAsBigInt } = {}) {\n let res = {};\n let meta = {};\n let tbl = res;\n let m = meta;\n for (let ptr = skipVoid(toml, 0); ptr < toml.length;) {\n if (toml[ptr] === '[') {\n let isTableArray = toml[++ptr] === '[';\n let k = parseKey(toml, ptr += +isTableArray, ']');\n if (isTableArray) {\n if (toml[k[1] - 1] !== ']') {\n throw new TomlError('expected end of table declaration', {\n toml: toml,\n ptr: k[1] - 1,\n });\n }\n k[1]++;\n }\n let p = peekTable(k[0], res, meta, isTableArray ? 2 /* Type.ARRAY */ : 1 /* Type.EXPLICIT */);\n if (!p) {\n throw new TomlError('trying to redefine an already defined table or value', {\n toml: toml,\n ptr: ptr,\n });\n }\n m = p[2];\n tbl = p[1];\n ptr = k[1];\n }\n else {\n let k = parseKey(toml, ptr);\n let p = peekTable(k[0], tbl, m, 0 /* Type.DOTTED */);\n if (!p) {\n throw new TomlError('trying to redefine an already defined table or value', {\n toml: toml,\n ptr: ptr,\n });\n }\n let v = extractValue(toml, k[1], void 0, maxDepth, integersAsBigInt);\n p[1][p[0]] = v[0];\n ptr = v[1];\n }\n ptr = skipVoid(toml, ptr, true);\n if (toml[ptr] && toml[ptr] !== '\\n' && toml[ptr] !== '\\r') {\n throw new TomlError('each key-value declaration must be followed by an end-of-line', {\n toml: toml,\n ptr: ptr\n });\n }\n ptr = skipVoid(toml, ptr);\n }\n return res;\n}\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nlet BARE_KEY = /^[a-z0-9-_]+$/i;\nfunction extendedTypeOf(obj) {\n let type = typeof obj;\n if (type === 'object') {\n if (Array.isArray(obj))\n return 'array';\n if (obj instanceof Date)\n return 'date';\n }\n return type;\n}\nfunction isArrayOfTables(obj) {\n for (let i = 0; i < obj.length; i++) {\n if (extendedTypeOf(obj[i]) !== 'object')\n return false;\n }\n return obj.length != 0;\n}\nfunction formatString(s) {\n return JSON.stringify(s).replace(/\\x7f/g, '\\\\u007f');\n}\nfunction stringifyValue(val, type, depth, numberAsFloat) {\n if (depth === 0) {\n throw new Error('Could not stringify the object: maximum object depth exceeded');\n }\n if (type === 'number') {\n if (isNaN(val))\n return 'nan';\n if (val === Infinity)\n return 'inf';\n if (val === -Infinity)\n return '-inf';\n if (numberAsFloat && Number.isInteger(val))\n return val.toFixed(1);\n return val.toString();\n }\n if (type === 'bigint' || type === 'boolean') {\n return val.toString();\n }\n if (type === 'string') {\n return formatString(val);\n }\n if (type === 'date') {\n if (isNaN(val.getTime())) {\n throw new TypeError('cannot serialize invalid date');\n }\n return val.toISOString();\n }\n if (type === 'object') {\n return stringifyInlineTable(val, depth, numberAsFloat);\n }\n if (type === 'array') {\n return stringifyArray(val, depth, numberAsFloat);\n }\n}\nfunction stringifyInlineTable(obj, depth, numberAsFloat) {\n let keys = Object.keys(obj);\n if (keys.length === 0)\n return '{}';\n let res = '{ ';\n for (let i = 0; i < keys.length; i++) {\n let k = keys[i];\n if (i)\n res += ', ';\n res += BARE_KEY.test(k) ? k : formatString(k);\n res += ' = ';\n res += stringifyValue(obj[k], extendedTypeOf(obj[k]), depth - 1, numberAsFloat);\n }\n return res + ' }';\n}\nfunction stringifyArray(array, depth, numberAsFloat) {\n if (array.length === 0)\n return '[]';\n let res = '[ ';\n for (let i = 0; i < array.length; i++) {\n if (i)\n res += ', ';\n if (array[i] === null || array[i] === void 0) {\n throw new TypeError('arrays cannot contain null or undefined values');\n }\n res += stringifyValue(array[i], extendedTypeOf(array[i]), depth - 1, numberAsFloat);\n }\n return res + ' ]';\n}\nfunction stringifyArrayTable(array, key, depth, numberAsFloat) {\n if (depth === 0) {\n throw new Error('Could not stringify the object: maximum object depth exceeded');\n }\n let res = '';\n for (let i = 0; i < array.length; i++) {\n res += `${res && '\\n'}[[${key}]]\\n`;\n res += stringifyTable(0, array[i], key, depth, numberAsFloat);\n }\n return res;\n}\nfunction stringifyTable(tableKey, obj, prefix, depth, numberAsFloat) {\n if (depth === 0) {\n throw new Error('Could not stringify the object: maximum object depth exceeded');\n }\n let preamble = '';\n let tables = '';\n let keys = Object.keys(obj);\n for (let i = 0; i < keys.length; i++) {\n let k = keys[i];\n if (obj[k] !== null && obj[k] !== void 0) {\n let type = extendedTypeOf(obj[k]);\n if (type === 'symbol' || type === 'function') {\n throw new TypeError(`cannot serialize values of type '${type}'`);\n }\n let key = BARE_KEY.test(k) ? k : formatString(k);\n if (type === 'array' && isArrayOfTables(obj[k])) {\n tables += (tables && '\\n') + stringifyArrayTable(obj[k], prefix ? `${prefix}.${key}` : key, depth - 1, numberAsFloat);\n }\n else if (type === 'object') {\n let tblKey = prefix ? `${prefix}.${key}` : key;\n tables += (tables && '\\n') + stringifyTable(tblKey, obj[k], tblKey, depth - 1, numberAsFloat);\n }\n else {\n preamble += key;\n preamble += ' = ';\n preamble += stringifyValue(obj[k], type, depth, numberAsFloat);\n preamble += '\\n';\n }\n }\n }\n if (tableKey && (preamble || !tables)) // Create table only if necessary\n preamble = preamble ? `[${tableKey}]\\n${preamble}` : `[${tableKey}]`;\n return preamble && tables\n ? `${preamble}\\n${tables}`\n : preamble || tables;\n}\nexport function stringify(obj, { maxDepth = 1000, numbersAsFloat = false } = {}) {\n if (extendedTypeOf(obj) !== 'object') {\n throw new TypeError('stringify can only be called with an object');\n }\n let str = stringifyTable(0, obj, '', maxDepth, numbersAsFloat);\n if (str[str.length - 1] !== '\\n')\n return str + '\\n';\n return str;\n}\n"],"mappings":"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","names":["endPtr","path","path","asNonEmptyString","asFiniteNumber","asPositiveNumber","asPositiveInteger","asBoolean","assertEnum","asPositiveDecimalString","k","out"]}
|