@pionex/pionex-trade-mcp 0.2.21 → 0.2.22

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 CHANGED
@@ -42,6 +42,9 @@ Credentials are read from `~/.pionex/config.toml` when the server starts; the cl
42
42
 
43
43
  For `pionex_bot_create_futures_grid_order`:
44
44
  - `keyId` is optional.
45
+ - `exchange` defaults to `pionex.v2` if missing.
46
+ - `quote` defaults to `USDT` if missing.
47
+ - `base` is normalized to `<BASE>.PERP` when the suffix is missing.
45
48
  - If `buOrderData.top`/`bottom` are missing, defaults are computed from current market price (`+5%`/`-5%`).
46
49
  - `buOrderData.openPrice` is optional; if missing, it is not sent.
47
50
  - If `buOrderData.row` is missing, default is `10`.
package/dist/index.js CHANGED
@@ -1289,6 +1289,9 @@ function maybePositiveDecimalString(value) {
1289
1289
  }
1290
1290
  return void 0;
1291
1291
  }
1292
+ function normalizePerpBase(base) {
1293
+ return base.endsWith(".PERP") ? base : `${base}.PERP`;
1294
+ }
1292
1295
  function tryExtractCurrentPrice(payload, symbol) {
1293
1296
  const stacks = [payload];
1294
1297
  while (stacks.length > 0) {
@@ -1365,15 +1368,20 @@ function registerBotTools() {
1365
1368
  description: "CreateFuturesGridOrderData payload from openapi_bot.yaml."
1366
1369
  }
1367
1370
  },
1368
- required: ["exchange", "base", "quote", "buOrderData"]
1371
+ required: ["base", "buOrderData"]
1369
1372
  },
1370
1373
  async handler(args, { client, config }) {
1371
1374
  if (config.readOnly) {
1372
1375
  throw new Error("Server is running in --read-only mode; bot create is disabled.");
1373
1376
  }
1374
- const exchange = asNonEmptyString(args.exchange, "exchange");
1375
- const base = asNonEmptyString(args.base, "base");
1376
- const quote = asNonEmptyString(args.quote, "quote");
1377
+ const defaultsApplied = {};
1378
+ const exchange = asNonEmptyString(args.exchange ?? "pionex.v2", "exchange");
1379
+ if (args.exchange == null) defaultsApplied.exchange = exchange;
1380
+ const rawBase = asNonEmptyString(args.base, "base");
1381
+ const base = normalizePerpBase(rawBase);
1382
+ if (base !== rawBase) defaultsApplied.base = base;
1383
+ const quote = asNonEmptyString(args.quote ?? "USDT", "quote");
1384
+ if (args.quote == null) defaultsApplied.quote = quote;
1377
1385
  const buOrderData = asObject(args.buOrderData, "buOrderData");
1378
1386
  const symbol = `${base}_${quote}`;
1379
1387
  const needsTickerForTopBottom = buOrderData.top == null || buOrderData.bottom == null;
@@ -1389,7 +1397,6 @@ function registerBotTools() {
1389
1397
  if (needsTickerForTopBottom && (currentPrice == null || !Number.isFinite(currentPrice) || currentPrice <= 0)) {
1390
1398
  throw new Error(`Unable to infer current market price for ${symbol} from ticker response. Please provide buOrderData.top and buOrderData.bottom explicitly.`);
1391
1399
  }
1392
- const defaultsApplied = {};
1393
1400
  const top = asPositiveDecimalString(
1394
1401
  buOrderData.top ?? toTrimmedDecimal(currentPrice * 1.05),
1395
1402
  "buOrderData.top"
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/index.ts","../../core/src/config/toml.ts","../../core/src/setup.ts","../../core/src/constants.ts","../../core/src/utils/errors.ts","../../core/src/config.ts","../../core/src/client/rest-client.ts","../../core/src/tools/market.ts","../../core/src/tools/account.ts","../../core/src/tools/orders.ts","../../core/src/tools/bot.ts","../../core/src/tools/index.ts","../../core/src/tools/types.ts","../../../node_modules/smol-toml/dist/error.js","../../../node_modules/smol-toml/dist/util.js","../../../node_modules/smol-toml/dist/date.js","../../../node_modules/smol-toml/dist/primitive.js","../../../node_modules/smol-toml/dist/extract.js","../../../node_modules/smol-toml/dist/struct.js","../../../node_modules/smol-toml/dist/parse.js","../src/server.ts"],"sourcesContent":["#!/usr/bin/env node\n\nimport { parseArgs } from \"node:util\";\nimport { StdioServerTransport } from \"@modelcontextprotocol/sdk/server/stdio.js\";\nimport { loadConfig, toToolErrorPayload } from \"@pionex-ai/core\";\nimport { createServer } from \"./server.js\";\n\nfunction printHelp(): void {\n process.stdout.write(`\nUsage: pionex-trade-mcp [options]\n\nOptions:\n --modules <list> Comma-separated list of modules to load\n Available: market, account, orders, bot\n Special: \"all\" loads all modules\n Default: market,account,orders,bot\n\n --profile <name> Profile to load from ~/.pionex/config.toml\n Falls back to default_profile in config, then \"default\"\n --base-url <url> Override API base URL (otherwise env PIONEX_BASE_URL / toml / default)\n --read-only Expose only read/query tools and disable write operations\n --help Show this help message\n --version Show version\n\nCredentials (priority: env vars > ~/.pionex/config.toml > none):\n PIONEX_API_KEY Pionex API key\n PIONEX_API_SECRET Pionex API secret\n PIONEX_BASE_URL Optional API base URL override\n`);\n}\n\nfunction parseCli(): {\n modules?: string;\n profile?: string;\n baseUrl?: string;\n readOnly: boolean;\n help: boolean;\n version: boolean;\n} {\n const parsed = parseArgs({\n options: {\n modules: { type: \"string\" },\n profile: { type: \"string\" },\n \"base-url\": { type: \"string\" },\n \"read-only\": { type: \"boolean\", default: false },\n help: { type: \"boolean\", default: false },\n version: { type: \"boolean\", default: false },\n },\n allowPositionals: false,\n });\n return {\n modules: parsed.values.modules,\n profile: parsed.values.profile,\n baseUrl: parsed.values[\"base-url\"],\n readOnly: parsed.values[\"read-only\"] ?? false,\n help: parsed.values.help ?? false,\n version: parsed.values.version ?? false,\n };\n}\n\nexport async function main(): Promise<void> {\n const cli = parseCli();\n\n if (cli.help) {\n printHelp();\n return;\n }\n\n if (cli.version) {\n process.stdout.write(`pionex-trade-mcp\\n`);\n return;\n }\n\n const config = loadConfig({\n modules: cli.modules,\n profile: cli.profile,\n baseUrl: cli.baseUrl,\n readOnly: cli.readOnly,\n });\n const server = createServer(config);\n const transport = new StdioServerTransport();\n await server.connect(transport);\n}\n\nmain().catch((error: unknown) => {\n const payload = toToolErrorPayload(error);\n process.stderr.write(`${JSON.stringify(payload, null, 2)}\\n`);\n process.exitCode = 1;\n});\n","import { readFileSync, writeFileSync, mkdirSync, existsSync } from \"node:fs\";\nimport { join, dirname } from \"node:path\";\nimport { homedir } from \"node:os\";\nimport { parse, stringify } from \"smol-toml\";\n\nexport { stringify as tomlStringify };\n\nexport interface PionexProfile {\n api_key?: string;\n secret_key?: string;\n base_url?: string;\n}\n\nexport interface PionexTomlConfig {\n default_profile?: string;\n profiles: Record<string, PionexProfile>;\n}\n\n/** Fixed path: ~/.pionex/config.toml */\nexport function configFilePath(): string {\n return join(homedir(), \".pionex\", \"config.toml\");\n}\n\nexport function readFullConfig(): PionexTomlConfig {\n const path = configFilePath();\n if (!existsSync(path)) return { profiles: {} };\n const raw = readFileSync(path, \"utf-8\");\n return parse(raw) as unknown as PionexTomlConfig;\n}\n\nexport function readTomlProfile(profileName?: string): PionexProfile {\n const config = readFullConfig();\n const name = profileName ?? config.default_profile ?? \"default\";\n return config.profiles?.[name] ?? {};\n}\n\nexport function writeFullConfig(config: PionexTomlConfig): void {\n const path = configFilePath();\n const dir = dirname(path);\n if (!existsSync(dir)) {\n mkdirSync(dir, { recursive: true });\n }\n writeFileSync(path, stringify(config as unknown as Record<string, unknown>), \"utf-8\");\n}\n","import * as fs from \"node:fs\";\nimport * as path from \"node:path\";\nimport * as os from \"node:os\";\nimport { execFileSync } from \"node:child_process\";\nimport { configFilePath } from \"./config/toml.js\";\n\nexport type ClientId = \"claude-desktop\" | \"cursor\" | \"windsurf\" | \"vscode\" | \"claude-code\" | \"openclaw\";\n\nconst CLIENT_NAMES: Record<ClientId, string> = {\n \"claude-desktop\": \"Claude Desktop\",\n cursor: \"Cursor\",\n windsurf: \"Windsurf\",\n vscode: \"VS Code\",\n \"claude-code\": \"Claude Code CLI\",\n openclaw: \"OpenClaw (mcporter)\",\n};\n\nexport const SUPPORTED_CLIENTS = Object.keys(CLIENT_NAMES) as ClientId[];\n\nfunction appData(): string {\n return process.env.APPDATA ?? path.join(os.homedir(), \"AppData\", \"Roaming\");\n}\n\nconst CLAUDE_CONFIG_FILE = \"claude_desktop_config.json\";\n\nfunction findMsStoreClaudePath(): string | null {\n const localAppData = process.env.LOCALAPPDATA ?? path.join(os.homedir(), \"AppData\", \"Local\");\n const packagesDir = path.join(localAppData, \"Packages\");\n try {\n const entries = fs.readdirSync(packagesDir);\n const claudePkg = entries.find((e) => e.startsWith(\"Claude_\"));\n if (claudePkg) {\n const configPath = path.join(\n packagesDir,\n claudePkg,\n \"LocalCache\",\n \"Roaming\",\n \"Claude\",\n CLAUDE_CONFIG_FILE,\n );\n if (fs.existsSync(configPath) || fs.existsSync(path.dirname(configPath))) {\n return configPath;\n }\n }\n } catch {\n // ignore missing or unreadable Packages dir\n }\n return null;\n}\n\nexport function getConfigPath(client: ClientId): string | null {\n const home = os.homedir();\n const platform = process.platform;\n switch (client) {\n case \"claude-desktop\":\n if (platform === \"win32\") {\n return findMsStoreClaudePath() ?? path.join(appData(), \"Claude\", CLAUDE_CONFIG_FILE);\n }\n if (platform === \"darwin\") {\n return path.join(home, \"Library\", \"Application Support\", \"Claude\", CLAUDE_CONFIG_FILE);\n }\n return path.join(process.env.XDG_CONFIG_HOME ?? path.join(home, \".config\"), \"Claude\", CLAUDE_CONFIG_FILE);\n case \"cursor\":\n return path.join(home, \".cursor\", \"mcp.json\");\n case \"windsurf\":\n return path.join(home, \".codeium\", \"windsurf\", \"mcp_config.json\");\n case \"vscode\":\n return path.join(process.cwd(), \".mcp.json\");\n case \"claude-code\":\n return null;\n case \"openclaw\":\n return path.join(home, \".openclaw\", \"workspace\", \"config\", \"mcporter.json\");\n }\n}\n\nconst NPX_PACKAGE = \"@pionex/pionex-trade-mcp\";\n\nfunction buildEntry(client: ClientId): Record<string, unknown> {\n if (client === \"vscode\") {\n // VS Code MCP expects an explicit stdio transport field.\n return { type: \"stdio\", command: \"npx\", args: [\"-y\", NPX_PACKAGE] };\n }\n // Other clients (Cursor, Claude Desktop, Windsurf, OpenClaw, etc.) use npx\n // with the scoped package name so that users do not need to manage PATH.\n return { command: \"npx\", args: [\"-y\", NPX_PACKAGE] };\n}\n\nfunction mergeJsonConfig(\n configPath: string,\n serverName: string,\n entry: Record<string, unknown>\n): void {\n const dir = path.dirname(configPath);\n if (!fs.existsSync(dir)) fs.mkdirSync(dir, { recursive: true });\n\n let data: Record<string, unknown> = {};\n if (fs.existsSync(configPath)) {\n const raw = fs.readFileSync(configPath, \"utf-8\");\n try {\n data = JSON.parse(raw) as Record<string, unknown>;\n } catch {\n throw new Error(`Failed to parse existing config at ${configPath}`);\n }\n }\n\n if (typeof data.mcpServers !== \"object\" || data.mcpServers === null) {\n data.mcpServers = {};\n }\n (data.mcpServers as Record<string, unknown>)[serverName] = entry;\n\n fs.writeFileSync(configPath, JSON.stringify(data, null, 2) + \"\\n\", \"utf-8\");\n}\n\nexport interface SetupOptions {\n client: ClientId;\n}\n\nexport function runSetup(options: SetupOptions): void {\n const { client } = options;\n const name = CLIENT_NAMES[client];\n const serverName = \"pionex-trade-mcp\";\n\n if (client === \"claude-code\") {\n const claudeArgs = [\n \"mcp\",\n \"add\",\n \"--scope\",\n \"user\",\n \"--transport\",\n \"stdio\",\n serverName,\n \"--\",\n \"npx\",\n \"-y\",\n NPX_PACKAGE,\n ];\n process.stdout.write(`Running: claude ${claudeArgs.join(\" \")}\\n`);\n execFileSync(\"claude\", claudeArgs, { stdio: \"inherit\" });\n process.stdout.write(`✓ Configured ${name}\\n`);\n return;\n }\n\n const configPath = getConfigPath(client);\n if (!configPath) {\n throw new Error(`${name} is not supported on this platform`);\n }\n\n const entry = buildEntry(client);\n mergeJsonConfig(configPath, serverName, entry);\n process.stdout.write(\n `✓ Configured ${name}\\n ${configPath}\\n Restart ${name} to apply changes.\\n`\n );\n}\n\nexport function printSetupUsage(): void {\n process.stdout.write(\n `Usage: pionex-trade-mcp setup --client <client>\\n\\n` +\n `Clients:\\n` +\n SUPPORTED_CLIENTS.map((id) => ` ${id.padEnd(16)} ${CLIENT_NAMES[id]}`).join(\"\\n\") +\n `\\n\\nCredentials are read from ${configFilePath()}. Run \"pionex-ai-kit config init\" (from pionex-ai-kit) first.\\n`\n );\n}\n","export const PIONEX_API_DEFAULT_BASE_URL = \"https://api.pionex.com\";\n\nexport const MODULES = [\"market\", \"account\", \"orders\", \"bot\"] as const;\nexport type ModuleId = (typeof MODULES)[number];\n\nexport const DEFAULT_MODULES: ModuleId[] = [\"market\", \"account\", \"orders\", \"bot\"];\n\n","export class ConfigError extends Error {\n public readonly suggestion?: string;\n public constructor(message: string, suggestion?: string) {\n super(message);\n this.name = \"ConfigError\";\n this.suggestion = suggestion;\n }\n}\n\nexport class PionexApiError extends Error {\n public readonly status?: number;\n public readonly endpoint?: string;\n public readonly responseText?: string;\n public constructor(\n message: string,\n opts?: { status?: number; endpoint?: string; responseText?: string },\n ) {\n super(message);\n this.name = \"PionexApiError\";\n this.status = opts?.status;\n this.endpoint = opts?.endpoint;\n this.responseText = opts?.responseText;\n }\n}\n\nexport function toToolErrorPayload(error: unknown): Record<string, unknown> {\n if (error instanceof ConfigError) {\n return {\n error: true,\n type: \"ConfigError\",\n message: error.message,\n suggestion: error.suggestion,\n };\n }\n if (error instanceof PionexApiError) {\n return {\n error: true,\n type: \"PionexApiError\",\n message: error.message,\n status: error.status,\n endpoint: error.endpoint,\n responseText: error.responseText,\n };\n }\n const message = error instanceof Error ? error.message : String(error);\n return { error: true, type: \"Error\", message };\n}\n\n","import { readTomlProfile } from \"./config/toml.js\";\nimport { PIONEX_API_DEFAULT_BASE_URL, DEFAULT_MODULES, MODULES, type ModuleId } from \"./constants.js\";\nimport { ConfigError } from \"./utils/errors.js\";\n\nexport interface CliOptions {\n modules?: string;\n readOnly: boolean;\n profile?: string;\n baseUrl?: string;\n}\n\nexport interface PionexConfig {\n apiKey?: string;\n apiSecret?: string;\n hasAuth: boolean;\n baseUrl: string;\n modules: ModuleId[];\n readOnly: boolean;\n}\n\nfunction parseModuleList(rawModules?: string): ModuleId[] {\n if (!rawModules || rawModules.trim().length === 0) return [...DEFAULT_MODULES];\n const trimmed = rawModules.trim().toLowerCase();\n if (trimmed === \"all\") return [...MODULES];\n\n const requested = trimmed\n .split(\",\")\n .map((x) => x.trim())\n .filter(Boolean);\n if (requested.length === 0) return [...DEFAULT_MODULES];\n\n const out: ModuleId[] = [];\n for (const m of requested) {\n if (!MODULES.includes(m as ModuleId)) {\n throw new ConfigError(`Unknown module \"${m}\".`, `Use one of: ${MODULES.join(\", \")} or \"all\".`);\n }\n out.push(m as ModuleId);\n }\n return Array.from(new Set(out));\n}\n\n/**\n * Credential priority (highest to lowest):\n * 1. Environment variables (PIONEX_API_KEY / PIONEX_API_SECRET)\n * 2. ~/.pionex/config.toml profile values\n */\nexport function loadConfig(cli: CliOptions): PionexConfig {\n const toml = readTomlProfile(cli.profile);\n\n const apiKey = process.env.PIONEX_API_KEY?.trim() || toml.api_key;\n const apiSecret = process.env.PIONEX_API_SECRET?.trim() || toml.secret_key;\n\n const hasAuth = Boolean(apiKey && apiSecret);\n const partialAuth = Boolean(apiKey) || Boolean(apiSecret);\n if (partialAuth && !hasAuth) {\n throw new ConfigError(\n \"Partial Pionex API credentials detected.\",\n \"Set both PIONEX_API_KEY and PIONEX_API_SECRET (env vars or config.toml profile).\",\n );\n }\n\n const baseUrl = (cli.baseUrl?.trim() || process.env.PIONEX_BASE_URL?.trim() || toml.base_url || PIONEX_API_DEFAULT_BASE_URL)\n .replace(/\\/+$/, \"\");\n if (!baseUrl.startsWith(\"http://\") && !baseUrl.startsWith(\"https://\")) {\n throw new ConfigError(`Invalid base URL \"${baseUrl}\".`, \"PIONEX_BASE_URL must start with http:// or https://\");\n }\n\n return {\n apiKey,\n apiSecret,\n hasAuth,\n baseUrl,\n modules: parseModuleList(cli.modules),\n readOnly: cli.readOnly,\n };\n}\n\n","import crypto from \"node:crypto\";\nimport type { PionexConfig } from \"../config.js\";\nimport { PionexApiError, ConfigError } from \"../utils/errors.js\";\nimport type { HttpMethod, QueryParams, RequestResult } from \"./types.js\";\n\nfunction requireAuth(config: PionexConfig): { apiKey: string; apiSecret: string } {\n if (!config.apiKey || !config.apiSecret) {\n throw new ConfigError(\n \"This operation requires authentication, but no Pionex API credentials were found.\",\n \"Run 'pionex-ai-kit onboard' to create ~/.pionex/config.toml, or set PIONEX_API_KEY and PIONEX_API_SECRET.\",\n );\n }\n return { apiKey: config.apiKey, apiSecret: config.apiSecret };\n}\n\nfunction buildQueryString(query?: QueryParams): string {\n if (!query) return \"\";\n const entries = Object.entries(query).filter(([, v]) => v !== undefined && v !== null);\n if (entries.length === 0) return \"\";\n const params = new URLSearchParams();\n for (const [k, v] of entries) params.set(k, String(v));\n return params.toString();\n}\n\nfunction buildSignedRequest(\n config: PionexConfig,\n method: HttpMethod,\n path: string,\n query: QueryParams,\n bodyJson: string | null,\n): { url: string; headers: Record<string, string>; bodyJson: string | null } {\n const { apiKey, apiSecret } = requireAuth(config);\n const timestamp = Date.now().toString();\n const params: Record<string, unknown> = { ...query, timestamp };\n\n const sortedKeys = Object.keys(params).sort();\n const queryString = sortedKeys.map((k) => `${k}=${params[k]}`).join(\"&\");\n const pathUrl = `${path}?${queryString}`;\n\n let payload = `${method}${pathUrl}`;\n if (bodyJson != null) payload += bodyJson;\n const signature = crypto.createHmac(\"sha256\", apiSecret).update(payload).digest(\"hex\");\n\n const url = `${config.baseUrl}${pathUrl}`;\n const headers = {\n \"PIONEX-KEY\": apiKey,\n \"PIONEX-SIGNATURE\": signature,\n \"Content-Type\": \"application/json\",\n };\n return { url, headers, bodyJson };\n}\n\nasync function readTextSafe(res: Response): Promise<string> {\n try {\n return await res.text();\n } catch {\n return \"\";\n }\n}\n\nexport class PionexRestClient {\n private readonly config: PionexConfig;\n public constructor(config: PionexConfig) {\n this.config = config;\n }\n\n public async publicGet<TData = unknown>(path: string, query: QueryParams = {}): Promise<RequestResult<TData>> {\n const qs = buildQueryString(query);\n const endpoint = qs ? `${path}?${qs}` : path;\n const url = `${this.config.baseUrl}${endpoint}`;\n const res = await fetch(url, { method: \"GET\", headers: { \"Content-Type\": \"application/json\" } });\n if (!res.ok) {\n const txt = await readTextSafe(res);\n throw new PionexApiError(`HTTP ${res.status}: ${txt || res.statusText}`, { status: res.status, endpoint, responseText: txt });\n }\n const data = (await res.json()) as TData;\n return { endpoint, requestTime: new Date().toISOString(), data };\n }\n\n public async signedGet<TData = unknown>(path: string, query: QueryParams = {}): Promise<RequestResult<TData>> {\n const { url, headers } = buildSignedRequest(this.config, \"GET\", path, query, null);\n const endpoint = `${path}?${buildQueryString({ ...query, timestamp: \"...\" })}`;\n const res = await fetch(url, { method: \"GET\", headers });\n if (!res.ok) {\n const txt = await readTextSafe(res);\n throw new PionexApiError(`HTTP ${res.status}: ${txt || res.statusText}`, { status: res.status, endpoint: path, responseText: txt });\n }\n const data = (await res.json()) as TData;\n return { endpoint: path, requestTime: new Date().toISOString(), data };\n }\n\n public async signedPost<TData = unknown>(path: string, body: Record<string, unknown>): Promise<RequestResult<TData>> {\n const bodyJson = JSON.stringify(body);\n const { url, headers, bodyJson: bj } = buildSignedRequest(this.config, \"POST\", path, {}, bodyJson);\n const res = await fetch(url, { method: \"POST\", headers, body: bj ?? undefined });\n if (!res.ok) {\n const txt = await readTextSafe(res);\n throw new PionexApiError(`HTTP ${res.status}: ${txt || res.statusText}`, { status: res.status, endpoint: path, responseText: txt });\n }\n const data = (await res.json()) as TData;\n return { endpoint: path, requestTime: new Date().toISOString(), data };\n }\n\n public async signedDelete<TData = unknown>(path: string, body: Record<string, unknown>): Promise<RequestResult<TData>> {\n const bodyJson = JSON.stringify(body);\n const { url, headers, bodyJson: bj } = buildSignedRequest(this.config, \"DELETE\", path, {}, bodyJson);\n const res = await fetch(url, { method: \"DELETE\", headers, body: bj ?? undefined });\n if (!res.ok) {\n const txt = await readTextSafe(res);\n throw new PionexApiError(`HTTP ${res.status}: ${txt || res.statusText}`, { status: res.status, endpoint: path, responseText: txt });\n }\n const data = (await res.json()) as TData;\n return { endpoint: path, requestTime: new Date().toISOString(), data };\n }\n}\n\n","import type { ToolSpec } from \"./types.js\";\n\nexport function registerMarketTools(): ToolSpec[] {\n return [\n {\n name: \"pionex_market_get_depth\",\n module: \"market\",\n isWrite: false,\n description: \"Get order book depth (bids and asks) for a symbol. Use for spread, liquidity, or best bid/ask.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n limit: { type: \"integer\", description: \"Price levels (1-100), default 5\" },\n },\n required: [\"symbol\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const limit = args.limit == null ? undefined : Number(args.limit);\n const q: Record<string, unknown> = { symbol };\n if (limit != null && Number.isFinite(limit)) q.limit = limit;\n return (await client.publicGet(\"/api/v1/market/depth\", q)).data;\n },\n },\n {\n name: \"pionex_market_get_trades\",\n module: \"market\",\n isWrite: false,\n description: \"Get recent trades for a symbol. Use for latest price and volume.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n limit: { type: \"integer\", description: \"Default 5 (1-100)\" },\n },\n required: [\"symbol\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const limit = args.limit == null ? undefined : Number(args.limit);\n const q: Record<string, unknown> = { symbol };\n if (limit != null && Number.isFinite(limit)) q.limit = limit;\n return (await client.publicGet(\"/api/v1/market/trades\", q)).data;\n },\n },\n {\n name: \"pionex_market_get_symbol_info\",\n module: \"market\",\n isWrite: false,\n description:\n \"Get symbol metadata (precision, min size, price limits). Call before placing orders to avoid amount/size filter errors.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbols: {\n type: \"string\",\n description: 'Optional. One or more symbols, comma-separated, e.g. \"BTC_USDT\" or \"BTC_USDT,ADA_USDT\".',\n },\n type: {\n type: \"string\",\n enum: [\"SPOT\", \"PERP\"],\n description: \"Optional. If no symbols are specified, filter by type (default SPOT).\",\n },\n },\n },\n async handler(args, { client }) {\n const q: Record<string, unknown> = {};\n if (args.symbols) q.symbols = String(args.symbols);\n if (!args.symbols && args.type) q.type = String(args.type);\n return (await client.publicGet(\"/api/v1/common/symbols\", q)).data;\n },\n },\n {\n name: \"pionex_market_get_tickers\",\n module: \"market\",\n isWrite: false,\n description: \"Get 24-hour ticker(s): open, close, high, low, volume, amount, count. Optional symbol or type (SPOT/PERP).\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT; if omitted, returns all tickers filtered by type\" },\n type: { type: \"string\", enum: [\"SPOT\", \"PERP\"], description: \"If symbol is not specified, filter by type.\" },\n },\n },\n async handler(args, { client }) {\n const q: Record<string, unknown> = {};\n if (args.symbol) q.symbol = String(args.symbol);\n if (args.type) q.type = String(args.type);\n return (await client.publicGet(\"/api/v1/market/tickers\", q)).data;\n },\n },\n {\n name: \"pionex_market_get_klines\",\n module: \"market\",\n isWrite: false,\n description: \"Get OHLCV klines (candlestick) for a symbol. Use for charts or historical price/volume.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n interval: { type: \"string\", enum: [\"1M\", \"5M\", \"15M\", \"30M\", \"60M\", \"4H\", \"8H\", \"12H\", \"1D\"], description: \"Kline interval.\" },\n endTime: { type: \"integer\", description: \"End time in milliseconds.\" },\n limit: { type: \"integer\", description: \"Default 100 (1-500).\" },\n },\n required: [\"symbol\", \"interval\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const interval = String(args.interval);\n const q: Record<string, unknown> = { symbol, interval };\n if (args.endTime != null) q.endTime = Number(args.endTime);\n if (args.limit != null) q.limit = Number(args.limit);\n return (await client.publicGet(\"/api/v1/market/klines\", q)).data;\n },\n },\n ];\n}\n\n","import type { ToolSpec } from \"./types.js\";\n\nexport function registerAccountTools(): ToolSpec[] {\n return [\n {\n name: \"pionex_account_get_balance\",\n module: \"account\",\n isWrite: false,\n description: \"Query spot account balances for all currencies. Requires API key and secret in ~/.pionex/config.toml or env.\",\n inputSchema: { type: \"object\", additionalProperties: false, properties: {} },\n async handler(_args, { client }) {\n return (await client.signedGet(\"/api/v1/account/balances\")).data;\n },\n },\n ];\n}\n\n","import type { ToolSpec } from \"./types.js\";\n\nexport function registerOrdersTools(): ToolSpec[] {\n return [\n {\n name: \"pionex_orders_new_order\",\n module: \"orders\",\n isWrite: true,\n description:\n \"Create a spot order on Pionex. LIMIT requires symbol/side/type=LIMIT/price/size. MARKET BUY requires amount (quote). MARKET SELL requires size (base).\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n side: { type: \"string\", enum: [\"BUY\", \"SELL\"] },\n type: { type: \"string\", enum: [\"LIMIT\", \"MARKET\"] },\n clientOrderId: { type: \"string\", description: \"Optional client order id (max 64 chars)\" },\n size: { type: \"string\", description: \"Quantity; required for limit and market sell\" },\n price: { type: \"string\", description: \"Required for limit order\" },\n amount: { type: \"string\", description: \"Quote amount; required for market buy\" },\n IOC: { type: \"boolean\", description: \"Immediate-or-cancel, default false\" },\n },\n required: [\"symbol\", \"side\", \"type\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; order placement is disabled.\");\n }\n const body: Record<string, unknown> = {};\n if (args.symbol != null) body.symbol = String(args.symbol);\n if (args.side != null) body.side = String(args.side);\n if (args.type != null) body.type = String(args.type);\n if (args.clientOrderId != null) body.clientOrderId = String(args.clientOrderId);\n if (args.size != null) body.size = String(args.size);\n if (args.price != null) body.price = String(args.price);\n if (args.amount != null) body.amount = String(args.amount);\n if (args.IOC != null) body.IOC = Boolean(args.IOC);\n return (await client.signedPost(\"/api/v1/trade/order\", body)).data;\n },\n },\n {\n name: \"pionex_orders_get_order\",\n module: \"orders\",\n isWrite: false,\n description: \"Get a single order by order ID.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n orderId: { type: \"integer\", description: \"Order id\" },\n },\n required: [\"symbol\", \"orderId\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const orderId = Number(args.orderId);\n return (await client.signedGet(\"/api/v1/trade/order\", { symbol, orderId })).data;\n },\n },\n {\n name: \"pionex_orders_get_order_by_client_order_id\",\n module: \"orders\",\n isWrite: false,\n description: \"Get a single order by client order ID.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n clientOrderId: { type: \"string\", description: \"Client order id\" },\n },\n required: [\"symbol\", \"clientOrderId\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const clientOrderId = String(args.clientOrderId);\n return (await client.signedGet(\"/api/v1/trade/orderByClientOrderId\", { symbol, clientOrderId })).data;\n },\n },\n {\n name: \"pionex_orders_get_open_orders\",\n module: \"orders\",\n isWrite: false,\n description: \"List open (unfilled) orders for a symbol.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: { symbol: { type: \"string\", description: \"e.g. BTC_USDT\" } },\n required: [\"symbol\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n return (await client.signedGet(\"/api/v1/trade/openOrders\", { symbol })).data;\n },\n },\n {\n name: \"pionex_orders_get_all_orders\",\n module: \"orders\",\n isWrite: false,\n description: \"List order history for a symbol (filled and cancelled), with optional limit.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n limit: { type: \"integer\", description: \"Default 1 (1-100)\" },\n },\n required: [\"symbol\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const q: Record<string, unknown> = { symbol };\n if (args.limit != null) q.limit = Number(args.limit);\n return (await client.signedGet(\"/api/v1/trade/allOrders\", q)).data;\n },\n },\n {\n name: \"pionex_orders_cancel_order\",\n module: \"orders\",\n isWrite: true,\n description: \"Cancel an open order by order ID.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n orderId: { type: \"integer\", description: \"Order id\" },\n },\n required: [\"symbol\", \"orderId\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; order cancellation is disabled.\");\n }\n const symbol = String(args.symbol);\n const orderId = Number(args.orderId);\n return (await client.signedDelete(\"/api/v1/trade/order\", { symbol, orderId })).data;\n },\n },\n {\n name: \"pionex_orders_get_fills\",\n module: \"orders\",\n isWrite: false,\n description: \"Get filled trades (fills) for a symbol in a time range. Requires API key. Returns up to 100 latest fills.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n startTime: { type: \"integer\", description: \"Start time in milliseconds.\" },\n endTime: { type: \"integer\", description: \"End time in milliseconds.\" },\n },\n required: [\"symbol\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const q: Record<string, unknown> = { symbol };\n if (args.startTime != null) q.startTime = Number(args.startTime);\n if (args.endTime != null) q.endTime = Number(args.endTime);\n return (await client.signedGet(\"/api/v1/trade/fills\", q)).data;\n },\n },\n {\n name: \"pionex_orders_cancel_all_orders\",\n module: \"orders\",\n isWrite: true,\n description: \"Cancel all open orders for a symbol.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: { symbol: { type: \"string\", description: \"e.g. BTC_USDT\" } },\n required: [\"symbol\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; cancel-all is disabled.\");\n }\n const symbol = String(args.symbol);\n return (await client.signedDelete(\"/api/v1/trade/allOrders\", { symbol })).data;\n },\n },\n ];\n}\n\n","import type { ToolSpec } from \"./types.js\";\n\nfunction asNonEmptyString(value: unknown, field: string): string {\n if (typeof value !== \"string\" || value.trim().length === 0) {\n throw new Error(`Invalid \"${field}\": expected non-empty string.`);\n }\n return value.trim();\n}\n\nfunction asFiniteNumber(value: unknown, field: string): number {\n if (typeof value !== \"number\" || !Number.isFinite(value)) {\n throw new Error(`Invalid \"${field}\": expected finite number.`);\n }\n return value;\n}\n\nfunction asPositiveNumber(value: unknown, field: string): number {\n const n = asFiniteNumber(value, field);\n if (n <= 0) throw new Error(`Invalid \"${field}\": expected number > 0.`);\n return n;\n}\n\nfunction asPositiveInteger(value: unknown, field: string): number {\n const n = asPositiveNumber(value, field);\n if (!Number.isInteger(n)) {\n throw new Error(`Invalid \"${field}\": expected positive integer.`);\n }\n return n;\n}\n\nfunction asBoolean(value: unknown, field: string): boolean {\n if (typeof value !== \"boolean\") {\n throw new Error(`Invalid \"${field}\": expected boolean.`);\n }\n return value;\n}\n\nfunction assertEnum(value: string, field: string, allowed: readonly string[]): void {\n if (!allowed.includes(value)) {\n throw new Error(`Invalid \"${field}\": expected one of ${allowed.join(\", \")}.`);\n }\n}\n\nfunction asObject(value: unknown, field: string): Record<string, unknown> {\n if (!value || typeof value !== \"object\" || Array.isArray(value)) {\n throw new Error(`Invalid \"${field}\": expected JSON object.`);\n }\n return value as Record<string, unknown>;\n}\n\nfunction asPositiveDecimalString(value: unknown, field: string): string {\n const s = asNonEmptyString(value, field);\n if (!/^\\d+(\\.\\d+)?$/.test(s)) {\n throw new Error(`Invalid \"${field}\": expected positive decimal string.`);\n }\n const n = Number(s);\n if (!Number.isFinite(n) || n <= 0) {\n throw new Error(`Invalid \"${field}\": expected positive decimal string.`);\n }\n return s;\n}\n\nfunction asNonNegativeDecimalString(value: unknown, field: string): string {\n const s = asNonEmptyString(value, field);\n if (!/^\\d+(\\.\\d+)?$/.test(s)) {\n throw new Error(`Invalid \"${field}\": expected non-negative decimal string.`);\n }\n const n = Number(s);\n if (!Number.isFinite(n) || n < 0) {\n throw new Error(`Invalid \"${field}\": expected non-negative decimal string.`);\n }\n return s;\n}\n\nfunction toTrimmedDecimal(value: number): string {\n return value.toFixed(8).replace(/\\.?0+$/, \"\");\n}\n\nfunction maybePositiveDecimalString(value: unknown): string | undefined {\n if (typeof value === \"string\" && /^\\d+(\\.\\d+)?$/.test(value)) {\n const n = Number(value);\n if (Number.isFinite(n) && n > 0) return value;\n }\n if (typeof value === \"number\" && Number.isFinite(value) && value > 0) {\n return toTrimmedDecimal(value);\n }\n return undefined;\n}\n\nfunction tryExtractCurrentPrice(payload: unknown, symbol: string): string | undefined {\n const stacks: unknown[] = [payload];\n while (stacks.length > 0) {\n const node = stacks.pop();\n if (!node || typeof node !== \"object\") continue;\n\n const obj = node as Record<string, unknown>;\n const nodeSymbol = typeof obj.symbol === \"string\" ? obj.symbol : undefined;\n const candidateClose =\n maybePositiveDecimalString(obj.close) ??\n maybePositiveDecimalString(obj.last) ??\n maybePositiveDecimalString(obj.lastPrice) ??\n maybePositiveDecimalString(obj.price);\n if (candidateClose && (!nodeSymbol || nodeSymbol === symbol)) {\n return candidateClose;\n }\n\n for (const v of Object.values(obj)) {\n if (Array.isArray(v)) {\n for (const item of v) stacks.push(item);\n } else if (v && typeof v === \"object\") {\n stacks.push(v);\n }\n }\n }\n return undefined;\n}\n\nasync function getCurrentSymbolPrice(client: { publicGet: <TData = unknown>(path: string, query?: Record<string, unknown>) => Promise<{ data: TData }> }, symbol: string): Promise<string> {\n const tickerPayload = (await client.publicGet(\"/api/v1/market/tickers\", { symbol })).data;\n const extracted = tryExtractCurrentPrice(tickerPayload, symbol);\n if (!extracted) {\n throw new Error(`Unable to infer current market price for ${symbol} from ticker response. Please provide buOrderData.top and buOrderData.bottom explicitly.`);\n }\n return extracted;\n}\n\nexport function registerBotTools(): ToolSpec[] {\n return [\n {\n name: \"pionex_bot_get_futures_grid_order\",\n module: \"bot\",\n isWrite: false,\n description: \"Get one futures grid bot order by buOrderId.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n buOrderId: { type: \"string\", description: \"Futures grid bot order id.\" },\n lang: { type: \"string\", description: \"Optional language code.\" },\n },\n required: [\"buOrderId\"],\n },\n async handler(args, { client }) {\n const buOrderId = String(args.buOrderId);\n const q: Record<string, unknown> = { buOrderId };\n if (args.lang != null) q.lang = String(args.lang);\n return (await client.signedGet(\"/api/v1/bot/orders/futuresGrid/order\", q)).data;\n },\n },\n {\n name: \"pionex_bot_create_futures_grid_order\",\n module: \"bot\",\n isWrite: true,\n description: \"Create a futures grid bot order.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n keyId: { type: \"string\" },\n exchange: { type: \"string\", description: \"e.g. pionex.v2\" },\n base: { type: \"string\", description: \"e.g. BTC\" },\n quote: { type: \"string\", description: \"e.g. USDT\" },\n copyFrom: { type: \"string\" },\n copyType: { type: \"string\" },\n groupId: { type: \"string\" },\n copyBotOrderId: { type: \"string\" },\n lang: { type: \"string\" },\n buOrderData: {\n type: \"object\",\n additionalProperties: true,\n description: \"CreateFuturesGridOrderData payload from openapi_bot.yaml.\",\n },\n },\n required: [\"exchange\", \"base\", \"quote\", \"buOrderData\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; bot create is disabled.\");\n }\n const exchange = asNonEmptyString(args.exchange, \"exchange\");\n const base = asNonEmptyString(args.base, \"base\");\n const quote = asNonEmptyString(args.quote, \"quote\");\n const buOrderData = asObject(args.buOrderData, \"buOrderData\");\n const symbol = `${base}_${quote}`;\n const needsTickerForTopBottom = buOrderData.top == null || buOrderData.bottom == null;\n const shouldTryTicker = needsTickerForTopBottom;\n let currentPrice: number | undefined;\n if (shouldTryTicker) {\n try {\n currentPrice = Number(await getCurrentSymbolPrice(client, symbol));\n } catch {\n currentPrice = undefined;\n }\n }\n if (needsTickerForTopBottom && (currentPrice == null || !Number.isFinite(currentPrice) || currentPrice <= 0)) {\n throw new Error(`Unable to infer current market price for ${symbol} from ticker response. Please provide buOrderData.top and buOrderData.bottom explicitly.`);\n }\n const defaultsApplied: Record<string, unknown> = {};\n\n const top = asPositiveDecimalString(\n buOrderData.top ?? toTrimmedDecimal((currentPrice as number) * 1.05),\n \"buOrderData.top\",\n );\n if (buOrderData.top == null) defaultsApplied.top = top;\n const bottom = asPositiveDecimalString(\n buOrderData.bottom ?? toTrimmedDecimal((currentPrice as number) * 0.95),\n \"buOrderData.bottom\",\n );\n if (buOrderData.bottom == null) defaultsApplied.bottom = bottom;\n if (Number(top) <= Number(bottom)) {\n throw new Error('Invalid \"buOrderData.top\": expected top > bottom.');\n }\n const row = asPositiveInteger(buOrderData.row ?? 10, \"buOrderData.row\");\n if (buOrderData.row == null) defaultsApplied.row = row;\n const gridType = asNonEmptyString(buOrderData.grid_type ?? \"arithmetic\", \"buOrderData.grid_type\");\n assertEnum(gridType, \"buOrderData.grid_type\", [\"arithmetic\", \"geometric\"]);\n if (buOrderData.grid_type == null) defaultsApplied.grid_type = gridType;\n const openPrice =\n buOrderData.openPrice == null ? undefined : asPositiveDecimalString(buOrderData.openPrice, \"buOrderData.openPrice\");\n const trend = asNonEmptyString(buOrderData.trend, \"buOrderData.trend\");\n assertEnum(trend, \"buOrderData.trend\", [\"long\", \"short\", \"no_trend\"]);\n const leverage = asPositiveNumber(buOrderData.leverage ?? 2, \"buOrderData.leverage\");\n if (buOrderData.leverage == null) defaultsApplied.leverage = leverage;\n const extraMargin = asNonNegativeDecimalString(buOrderData.extraMargin ?? \"0\", \"buOrderData.extraMargin\");\n if (buOrderData.extraMargin == null) defaultsApplied.extraMargin = extraMargin;\n const quoteInvestment = asPositiveDecimalString(buOrderData.quoteInvestment, \"buOrderData.quoteInvestment\");\n\n const body: Record<string, unknown> = {\n exchange,\n base,\n quote,\n buOrderData: {\n ...buOrderData,\n top,\n bottom,\n row,\n grid_type: gridType,\n trend,\n leverage,\n extraMargin,\n quoteInvestment,\n },\n };\n if (openPrice != null) {\n (body.buOrderData as Record<string, unknown>).openPrice = openPrice;\n }\n if (args.keyId != null) body.keyId = asNonEmptyString(args.keyId, \"keyId\");\n if (args.copyFrom != null) body.copyFrom = String(args.copyFrom);\n if (args.copyType != null) body.copyType = String(args.copyType);\n if (args.groupId != null) body.groupId = String(args.groupId);\n if (args.copyBotOrderId != null) body.copyBotOrderId = String(args.copyBotOrderId);\n if (args.lang != null) body.lang = String(args.lang);\n if (args.__dryRun === true) {\n return {\n dryRun: true,\n note: \"No order was sent. This is the resolved request body after applying defaults.\",\n marketSymbol: symbol,\n marketPriceUsed: currentPrice == null ? undefined : toTrimmedDecimal(currentPrice),\n defaultsApplied,\n resolvedBody: body,\n };\n }\n return (await client.signedPost(\"/api/v1/bot/orders/futuresGrid/create\", body)).data;\n },\n },\n {\n name: \"pionex_bot_adjust_futures_grid_params\",\n module: \"bot\",\n isWrite: true,\n description: \"Adjust futures grid bot params (invest_in / adjust_params / invest_in_trigger).\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n buOrderId: { type: \"string\" },\n type: { type: \"string\", enum: [\"invest_in\", \"adjust_params\", \"invest_in_trigger\"] },\n quoteInvestment: { type: \"number\" },\n extraMargin: { type: \"boolean\" },\n openPrice: { type: \"number\" },\n bottom: { type: \"string\" },\n top: { type: \"string\" },\n row: { type: \"number\" },\n extraMarginAmount: { type: \"number\" },\n isRecommend: { type: \"boolean\" },\n isReinvest: { type: \"boolean\" },\n investCoin: { type: \"string\" },\n investmentFrom: { type: \"string\", enum: [\"USER\", \"LOCK_ACTIVITY\"] },\n condition: { type: \"string\" },\n conditionDirection: { type: \"string\", enum: [\"1\", \"-1\"] },\n slippage: { type: \"string\" },\n adjustParamsSence: { type: \"string\" },\n },\n required: [\"buOrderId\", \"type\", \"extraMargin\", \"openPrice\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; bot adjust is disabled.\");\n }\n const buOrderId = asNonEmptyString(args.buOrderId, \"buOrderId\");\n const type = asNonEmptyString(args.type, \"type\");\n assertEnum(type, \"type\", [\"invest_in\", \"adjust_params\", \"invest_in_trigger\"]);\n const extraMargin = asBoolean(args.extraMargin, \"extraMargin\");\n const openPrice = asFiniteNumber(args.openPrice, \"openPrice\");\n\n if (type === \"invest_in\" && args.quoteInvestment != null) {\n asPositiveNumber(args.quoteInvestment, \"quoteInvestment\");\n }\n if (type === \"adjust_params\") {\n const bottom = asPositiveDecimalString(args.bottom, \"bottom\");\n const top = asPositiveDecimalString(args.top, \"top\");\n if (Number(top) <= Number(bottom)) {\n throw new Error('Invalid \"top\": expected top > bottom.');\n }\n asPositiveInteger(args.row, \"row\");\n }\n if (type === \"invest_in_trigger\") {\n asPositiveDecimalString(args.condition, \"condition\");\n const conditionDirection = asNonEmptyString(args.conditionDirection, \"conditionDirection\");\n assertEnum(conditionDirection, \"conditionDirection\", [\"1\", \"-1\"]);\n }\n\n const body: Record<string, unknown> = {\n buOrderId,\n type,\n extraMargin,\n openPrice,\n };\n if (args.quoteInvestment != null) body.quoteInvestment = asFiniteNumber(args.quoteInvestment, \"quoteInvestment\");\n if (args.bottom != null) body.bottom = asPositiveDecimalString(args.bottom, \"bottom\");\n if (args.top != null) body.top = asPositiveDecimalString(args.top, \"top\");\n if (args.row != null) body.row = asPositiveInteger(args.row, \"row\");\n if (args.extraMarginAmount != null) body.extraMarginAmount = asFiniteNumber(args.extraMarginAmount, \"extraMarginAmount\");\n if (args.isRecommend != null) body.isRecommend = asBoolean(args.isRecommend, \"isRecommend\");\n if (args.isReinvest != null) body.isReinvest = asBoolean(args.isReinvest, \"isReinvest\");\n if (args.investCoin != null) body.investCoin = String(args.investCoin);\n if (args.investmentFrom != null) {\n const investmentFrom = asNonEmptyString(args.investmentFrom, \"investmentFrom\");\n assertEnum(investmentFrom, \"investmentFrom\", [\"USER\", \"LOCK_ACTIVITY\"]);\n body.investmentFrom = investmentFrom;\n }\n if (args.condition != null) body.condition = asPositiveDecimalString(args.condition, \"condition\");\n if (args.conditionDirection != null) {\n const conditionDirection = asNonEmptyString(args.conditionDirection, \"conditionDirection\");\n assertEnum(conditionDirection, \"conditionDirection\", [\"1\", \"-1\"]);\n body.conditionDirection = conditionDirection;\n }\n if (args.slippage != null) body.slippage = String(args.slippage);\n if (args.adjustParamsSence != null) body.adjustParamsSence = String(args.adjustParamsSence);\n return (await client.signedPost(\"/api/v1/bot/orders/futuresGrid/adjustParams\", body)).data;\n },\n },\n {\n name: \"pionex_bot_reduce_futures_grid_position\",\n module: \"bot\",\n isWrite: true,\n description: \"Reduce futures grid bot position.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n buOrderId: { type: \"string\" },\n openPrice: { type: \"string\" },\n reduceNum: { type: \"number\" },\n slippage: { type: \"string\" },\n condition: { type: \"string\" },\n conditionDirection: { type: \"string\", enum: [\"1\", \"-1\"] },\n },\n required: [\"buOrderId\", \"openPrice\", \"reduceNum\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; bot reduce is disabled.\");\n }\n const buOrderId = asNonEmptyString(args.buOrderId, \"buOrderId\");\n const openPrice = asPositiveDecimalString(args.openPrice, \"openPrice\");\n const reduceNum = asPositiveInteger(args.reduceNum, \"reduceNum\");\n const body: Record<string, unknown> = {\n buOrderId,\n openPrice,\n reduceNum,\n };\n if (args.slippage != null) body.slippage = String(args.slippage);\n if (args.condition != null) body.condition = String(args.condition);\n if (args.conditionDirection != null) {\n const conditionDirection = asNonEmptyString(args.conditionDirection, \"conditionDirection\");\n assertEnum(conditionDirection, \"conditionDirection\", [\"1\", \"-1\"]);\n body.conditionDirection = conditionDirection;\n }\n return (await client.signedPost(\"/api/v1/bot/orders/futuresGrid/reduce\", body)).data;\n },\n },\n {\n name: \"pionex_bot_cancel_futures_grid_order\",\n module: \"bot\",\n isWrite: true,\n description: \"Cancel and close a futures grid bot order.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n buOrderId: { type: \"string\" },\n closeNote: { type: \"string\" },\n closeSellModel: { type: \"string\", enum: [\"TO_QUOTE\", \"TO_USDT\"] },\n immediate: { type: \"boolean\" },\n closeSlippage: { type: \"string\" },\n },\n required: [\"buOrderId\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; bot cancel is disabled.\");\n }\n const buOrderId = asNonEmptyString(args.buOrderId, \"buOrderId\");\n const body: Record<string, unknown> = { buOrderId };\n if (args.closeNote != null) body.closeNote = String(args.closeNote);\n if (args.closeSellModel != null) {\n const closeSellModel = asNonEmptyString(args.closeSellModel, \"closeSellModel\");\n assertEnum(closeSellModel, \"closeSellModel\", [\"TO_QUOTE\", \"TO_USDT\"]);\n body.closeSellModel = closeSellModel;\n }\n if (args.immediate != null) body.immediate = asBoolean(args.immediate, \"immediate\");\n if (args.closeSlippage != null) body.closeSlippage = String(args.closeSlippage);\n return (await client.signedPost(\"/api/v1/bot/orders/futuresGrid/cancel\", body)).data;\n },\n },\n ];\n}\n","import type { PionexConfig } from \"../config.js\";\nimport type { PionexRestClient } from \"../client/rest-client.js\";\nimport { MODULES, type ModuleId } from \"../constants.js\";\nimport type { ToolArgs, ToolSpec } from \"./types.js\";\nimport { registerMarketTools } from \"./market.js\";\nimport { registerAccountTools } from \"./account.js\";\nimport { registerOrdersTools } from \"./orders.js\";\nimport { registerBotTools } from \"./bot.js\";\n\nfunction allToolSpecs(): ToolSpec[] {\n return [...registerMarketTools(), ...registerAccountTools(), ...registerOrdersTools(), ...registerBotTools()];\n}\n\nexport function buildTools(config: PionexConfig): ToolSpec[] {\n const enabled = new Set(config.modules);\n const tools = allToolSpecs().filter((t) => enabled.has(t.module));\n if (!config.readOnly) return tools;\n return tools.filter((t) => !t.isWrite);\n}\n\nexport interface ToolResult {\n endpoint: string;\n requestTime: string;\n data: unknown;\n}\n\nexport type ToolRunner = (toolName: string, args: ToolArgs) => Promise<ToolResult>;\n\n/**\n * Create a function that can call any registered tool by name.\n * For CLI usage we keep module filtering at the command routing level,\n * but the runner itself knows all tools.\n */\nexport function createToolRunner(client: PionexRestClient, config: PionexConfig): ToolRunner {\n const fullConfig: PionexConfig = { ...config, modules: [...MODULES] as ModuleId[] };\n const toolMap = new Map<string, ToolSpec>(allToolSpecs().map((t) => [t.name, t]));\n\n return async (toolName: string, args: ToolArgs): Promise<ToolResult> => {\n const tool = toolMap.get(toolName);\n if (!tool) throw new Error(`Unknown tool: ${toolName}`);\n const data = await tool.handler(args, { config: fullConfig, client });\n return { endpoint: toolName, requestTime: new Date().toISOString(), data };\n };\n}\n\n","import type { ModuleId } from \"../constants.js\";\nimport type { PionexConfig } from \"../config.js\";\nimport type { PionexRestClient } from \"../client/rest-client.js\";\n\nexport type JsonSchema =\n | {\n type: \"object\";\n properties?: Record<string, JsonSchema>;\n required?: string[];\n additionalProperties?: boolean;\n description?: string;\n enum?: string[];\n }\n | { type: \"string\"; description?: string; enum?: string[] }\n | { type: \"number\"; description?: string }\n | { type: \"integer\"; description?: string }\n | { type: \"boolean\"; description?: string }\n | { type: \"array\"; items: JsonSchema; description?: string }\n | { type: \"null\" };\n\nexport interface ToolContext {\n config: PionexConfig;\n client: PionexRestClient;\n}\n\nexport type ToolArgs = Record<string, unknown>;\n\nexport interface ToolSpec {\n name: string;\n description: string;\n module: ModuleId;\n isWrite: boolean;\n inputSchema: JsonSchema;\n handler: (args: ToolArgs, ctx: ToolContext) => Promise<unknown>;\n}\n\nexport interface McpTool {\n name: string;\n description: string;\n inputSchema: JsonSchema;\n annotations?: {\n readOnlyHint?: boolean;\n destructiveHint?: boolean;\n idempotentHint?: boolean;\n openWorldHint?: boolean;\n };\n}\n\nexport function toMcpTool(tool: ToolSpec): McpTool {\n return {\n name: tool.name,\n description: tool.description,\n inputSchema: tool.inputSchema,\n annotations: {\n readOnlyHint: !tool.isWrite,\n destructiveHint: tool.isWrite,\n idempotentHint: !tool.isWrite,\n openWorldHint: false,\n },\n };\n}\n\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nfunction getLineColFromPtr(string, ptr) {\n let lines = string.slice(0, ptr).split(/\\r\\n|\\n|\\r/g);\n return [lines.length, lines.pop().length + 1];\n}\nfunction makeCodeBlock(string, line, column) {\n let lines = string.split(/\\r\\n|\\n|\\r/g);\n let codeblock = '';\n let numberLen = (Math.log10(line + 1) | 0) + 1;\n for (let i = line - 1; i <= line + 1; i++) {\n let l = lines[i - 1];\n if (!l)\n continue;\n codeblock += i.toString().padEnd(numberLen, ' ');\n codeblock += ': ';\n codeblock += l;\n codeblock += '\\n';\n if (i === line) {\n codeblock += ' '.repeat(numberLen + column + 2);\n codeblock += '^\\n';\n }\n }\n return codeblock;\n}\nexport class TomlError extends Error {\n line;\n column;\n codeblock;\n constructor(message, options) {\n const [line, column] = getLineColFromPtr(options.toml, options.ptr);\n const codeblock = makeCodeBlock(options.toml, line, column);\n super(`Invalid TOML document: ${message}\\n\\n${codeblock}`, options);\n this.line = line;\n this.column = column;\n this.codeblock = codeblock;\n }\n}\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nimport { TomlError } from './error.js';\nfunction isEscaped(str, ptr) {\n let i = 0;\n while (str[ptr - ++i] === '\\\\')\n ;\n return --i && (i % 2);\n}\nexport function indexOfNewline(str, start = 0, end = str.length) {\n let idx = str.indexOf('\\n', start);\n if (str[idx - 1] === '\\r')\n idx--;\n return idx <= end ? idx : -1;\n}\nexport function skipComment(str, ptr) {\n for (let i = ptr; i < str.length; i++) {\n let c = str[i];\n if (c === '\\n')\n return i;\n if (c === '\\r' && str[i + 1] === '\\n')\n return i + 1;\n if ((c < '\\x20' && c !== '\\t') || c === '\\x7f') {\n throw new TomlError('control characters are not allowed in comments', {\n toml: str,\n ptr: ptr,\n });\n }\n }\n return str.length;\n}\nexport function skipVoid(str, ptr, banNewLines, banComments) {\n let c;\n while ((c = str[ptr]) === ' ' || c === '\\t' || (!banNewLines && (c === '\\n' || c === '\\r' && str[ptr + 1] === '\\n')))\n ptr++;\n return banComments || c !== '#'\n ? ptr\n : skipVoid(str, skipComment(str, ptr), banNewLines);\n}\nexport function skipUntil(str, ptr, sep, end, banNewLines = false) {\n if (!end) {\n ptr = indexOfNewline(str, ptr);\n return ptr < 0 ? str.length : ptr;\n }\n for (let i = ptr; i < str.length; i++) {\n let c = str[i];\n if (c === '#') {\n i = indexOfNewline(str, i);\n }\n else if (c === sep) {\n return i + 1;\n }\n else if (c === end || (banNewLines && (c === '\\n' || (c === '\\r' && str[i + 1] === '\\n')))) {\n return i;\n }\n }\n throw new TomlError('cannot find end of structure', {\n toml: str,\n ptr: ptr\n });\n}\nexport function getStringEnd(str, seek) {\n let first = str[seek];\n let target = first === str[seek + 1] && str[seek + 1] === str[seek + 2]\n ? str.slice(seek, seek + 3)\n : first;\n seek += target.length - 1;\n do\n seek = str.indexOf(target, ++seek);\n while (seek > -1 && first !== \"'\" && isEscaped(str, seek));\n if (seek > -1) {\n seek += target.length;\n if (target.length > 1) {\n if (str[seek] === first)\n seek++;\n if (str[seek] === first)\n seek++;\n }\n }\n return seek;\n}\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nlet DATE_TIME_RE = /^(\\d{4}-\\d{2}-\\d{2})?[T ]?(?:(\\d{2}):\\d{2}(?::\\d{2}(?:\\.\\d+)?)?)?(Z|[-+]\\d{2}:\\d{2})?$/i;\nexport class TomlDate extends Date {\n #hasDate = false;\n #hasTime = false;\n #offset = null;\n constructor(date) {\n let hasDate = true;\n let hasTime = true;\n let offset = 'Z';\n if (typeof date === 'string') {\n let match = date.match(DATE_TIME_RE);\n if (match) {\n if (!match[1]) {\n hasDate = false;\n date = `0000-01-01T${date}`;\n }\n hasTime = !!match[2];\n // Make sure to use T instead of a space. Breaks in case of extreme values otherwise.\n hasTime && date[10] === ' ' && (date = date.replace(' ', 'T'));\n // Do not allow rollover hours.\n if (match[2] && +match[2] > 23) {\n date = '';\n }\n else {\n offset = match[3] || null;\n date = date.toUpperCase();\n if (!offset && hasTime)\n date += 'Z';\n }\n }\n else {\n date = '';\n }\n }\n super(date);\n if (!isNaN(this.getTime())) {\n this.#hasDate = hasDate;\n this.#hasTime = hasTime;\n this.#offset = offset;\n }\n }\n isDateTime() {\n return this.#hasDate && this.#hasTime;\n }\n isLocal() {\n return !this.#hasDate || !this.#hasTime || !this.#offset;\n }\n isDate() {\n return this.#hasDate && !this.#hasTime;\n }\n isTime() {\n return this.#hasTime && !this.#hasDate;\n }\n isValid() {\n return this.#hasDate || this.#hasTime;\n }\n toISOString() {\n let iso = super.toISOString();\n // Local Date\n if (this.isDate())\n return iso.slice(0, 10);\n // Local Time\n if (this.isTime())\n return iso.slice(11, 23);\n // Local DateTime\n if (this.#offset === null)\n return iso.slice(0, -1);\n // Offset DateTime\n if (this.#offset === 'Z')\n return iso;\n // This part is quite annoying: JS strips the original timezone from the ISO string representation\n // Instead of using a \"modified\" date and \"Z\", we restore the representation \"as authored\"\n let offset = (+(this.#offset.slice(1, 3)) * 60) + +(this.#offset.slice(4, 6));\n offset = this.#offset[0] === '-' ? offset : -offset;\n let offsetDate = new Date(this.getTime() - (offset * 60e3));\n return offsetDate.toISOString().slice(0, -1) + this.#offset;\n }\n static wrapAsOffsetDateTime(jsDate, offset = 'Z') {\n let date = new TomlDate(jsDate);\n date.#offset = offset;\n return date;\n }\n static wrapAsLocalDateTime(jsDate) {\n let date = new TomlDate(jsDate);\n date.#offset = null;\n return date;\n }\n static wrapAsLocalDate(jsDate) {\n let date = new TomlDate(jsDate);\n date.#hasTime = false;\n date.#offset = null;\n return date;\n }\n static wrapAsLocalTime(jsDate) {\n let date = new TomlDate(jsDate);\n date.#hasDate = false;\n date.#offset = null;\n return date;\n }\n}\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nimport { skipVoid } from './util.js';\nimport { TomlDate } from './date.js';\nimport { TomlError } from './error.js';\nlet INT_REGEX = /^((0x[0-9a-fA-F](_?[0-9a-fA-F])*)|(([+-]|0[ob])?\\d(_?\\d)*))$/;\nlet FLOAT_REGEX = /^[+-]?\\d(_?\\d)*(\\.\\d(_?\\d)*)?([eE][+-]?\\d(_?\\d)*)?$/;\nlet LEADING_ZERO = /^[+-]?0[0-9_]/;\nlet ESCAPE_REGEX = /^[0-9a-f]{2,8}$/i;\nlet ESC_MAP = {\n b: '\\b',\n t: '\\t',\n n: '\\n',\n f: '\\f',\n r: '\\r',\n e: '\\x1b',\n '\"': '\"',\n '\\\\': '\\\\',\n};\nexport function parseString(str, ptr = 0, endPtr = str.length) {\n let isLiteral = str[ptr] === '\\'';\n let isMultiline = str[ptr++] === str[ptr] && str[ptr] === str[ptr + 1];\n if (isMultiline) {\n endPtr -= 2;\n if (str[ptr += 2] === '\\r')\n ptr++;\n if (str[ptr] === '\\n')\n ptr++;\n }\n let tmp = 0;\n let isEscape;\n let parsed = '';\n let sliceStart = ptr;\n while (ptr < endPtr - 1) {\n let c = str[ptr++];\n if (c === '\\n' || (c === '\\r' && str[ptr] === '\\n')) {\n if (!isMultiline) {\n throw new TomlError('newlines are not allowed in strings', {\n toml: str,\n ptr: ptr - 1,\n });\n }\n }\n else if ((c < '\\x20' && c !== '\\t') || c === '\\x7f') {\n throw new TomlError('control characters are not allowed in strings', {\n toml: str,\n ptr: ptr - 1,\n });\n }\n if (isEscape) {\n isEscape = false;\n if (c === 'x' || c === 'u' || c === 'U') {\n // Unicode escape\n let code = str.slice(ptr, (ptr += (c === 'x' ? 2 : c === 'u' ? 4 : 8)));\n if (!ESCAPE_REGEX.test(code)) {\n throw new TomlError('invalid unicode escape', {\n toml: str,\n ptr: tmp,\n });\n }\n try {\n parsed += String.fromCodePoint(parseInt(code, 16));\n }\n catch {\n throw new TomlError('invalid unicode escape', {\n toml: str,\n ptr: tmp,\n });\n }\n }\n else if (isMultiline && (c === '\\n' || c === ' ' || c === '\\t' || c === '\\r')) {\n // Multiline escape\n ptr = skipVoid(str, ptr - 1, true);\n if (str[ptr] !== '\\n' && str[ptr] !== '\\r') {\n throw new TomlError('invalid escape: only line-ending whitespace may be escaped', {\n toml: str,\n ptr: tmp,\n });\n }\n ptr = skipVoid(str, ptr);\n }\n else if (c in ESC_MAP) {\n // Classic escape\n parsed += ESC_MAP[c];\n }\n else {\n throw new TomlError('unrecognized escape sequence', {\n toml: str,\n ptr: tmp,\n });\n }\n sliceStart = ptr;\n }\n else if (!isLiteral && c === '\\\\') {\n tmp = ptr - 1;\n isEscape = true;\n parsed += str.slice(sliceStart, tmp);\n }\n }\n return parsed + str.slice(sliceStart, endPtr - 1);\n}\nexport function parseValue(value, toml, ptr, integersAsBigInt) {\n // Constant values\n if (value === 'true')\n return true;\n if (value === 'false')\n return false;\n if (value === '-inf')\n return -Infinity;\n if (value === 'inf' || value === '+inf')\n return Infinity;\n if (value === 'nan' || value === '+nan' || value === '-nan')\n return NaN;\n // Avoid FP representation of -0\n if (value === '-0')\n return integersAsBigInt ? 0n : 0;\n // Numbers\n let isInt = INT_REGEX.test(value);\n if (isInt || FLOAT_REGEX.test(value)) {\n if (LEADING_ZERO.test(value)) {\n throw new TomlError('leading zeroes are not allowed', {\n toml: toml,\n ptr: ptr,\n });\n }\n value = value.replace(/_/g, '');\n let numeric = +value;\n if (isNaN(numeric)) {\n throw new TomlError('invalid number', {\n toml: toml,\n ptr: ptr,\n });\n }\n if (isInt) {\n if ((isInt = !Number.isSafeInteger(numeric)) && !integersAsBigInt) {\n throw new TomlError('integer value cannot be represented losslessly', {\n toml: toml,\n ptr: ptr,\n });\n }\n if (isInt || integersAsBigInt === true)\n numeric = BigInt(value);\n }\n return numeric;\n }\n const date = new TomlDate(value);\n if (!date.isValid()) {\n throw new TomlError('invalid value', {\n toml: toml,\n ptr: ptr,\n });\n }\n return date;\n}\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nimport { parseString, parseValue } from './primitive.js';\nimport { parseArray, parseInlineTable } from './struct.js';\nimport { skipVoid, skipUntil, skipComment, getStringEnd } from './util.js';\nimport { TomlError } from './error.js';\nfunction sliceAndTrimEndOf(str, startPtr, endPtr) {\n let value = str.slice(startPtr, endPtr);\n let commentIdx = value.indexOf('#');\n if (commentIdx > -1) {\n // The call to skipComment allows to \"validate\" the comment\n // (absence of control characters)\n skipComment(str, commentIdx);\n value = value.slice(0, commentIdx);\n }\n return [value.trimEnd(), commentIdx];\n}\nexport function extractValue(str, ptr, end, depth, integersAsBigInt) {\n if (depth === 0) {\n throw new TomlError('document contains excessively nested structures. aborting.', {\n toml: str,\n ptr: ptr\n });\n }\n let c = str[ptr];\n if (c === '[' || c === '{') {\n let [value, endPtr] = c === '['\n ? parseArray(str, ptr, depth, integersAsBigInt)\n : parseInlineTable(str, ptr, depth, integersAsBigInt);\n if (end) {\n endPtr = skipVoid(str, endPtr);\n if (str[endPtr] === ',')\n endPtr++;\n else if (str[endPtr] !== end) {\n throw new TomlError('expected comma or end of structure', {\n toml: str,\n ptr: endPtr,\n });\n }\n }\n return [value, endPtr];\n }\n let endPtr;\n if (c === '\"' || c === \"'\") {\n endPtr = getStringEnd(str, ptr);\n let parsed = parseString(str, ptr, endPtr);\n if (end) {\n endPtr = skipVoid(str, endPtr);\n if (str[endPtr] && str[endPtr] !== ',' && str[endPtr] !== end && str[endPtr] !== '\\n' && str[endPtr] !== '\\r') {\n throw new TomlError('unexpected character encountered', {\n toml: str,\n ptr: endPtr,\n });\n }\n endPtr += (+(str[endPtr] === ','));\n }\n return [parsed, endPtr];\n }\n endPtr = skipUntil(str, ptr, ',', end);\n let slice = sliceAndTrimEndOf(str, ptr, endPtr - (+(str[endPtr - 1] === ',')));\n if (!slice[0]) {\n throw new TomlError('incomplete key-value declaration: no value specified', {\n toml: str,\n ptr: ptr\n });\n }\n if (end && slice[1] > -1) {\n endPtr = skipVoid(str, ptr + slice[1]);\n endPtr += +(str[endPtr] === ',');\n }\n return [\n parseValue(slice[0], str, ptr, integersAsBigInt),\n endPtr,\n ];\n}\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nimport { parseString } from './primitive.js';\nimport { extractValue } from './extract.js';\nimport { getStringEnd, indexOfNewline, skipComment, skipVoid } from './util.js';\nimport { TomlError } from './error.js';\nlet KEY_PART_RE = /^[a-zA-Z0-9-_]+[ \\t]*$/;\nexport function parseKey(str, ptr, end = '=') {\n let dot = ptr - 1;\n let parsed = [];\n let endPtr = str.indexOf(end, ptr);\n if (endPtr < 0) {\n throw new TomlError('incomplete key-value: cannot find end of key', {\n toml: str,\n ptr: ptr,\n });\n }\n do {\n let c = str[ptr = ++dot];\n // If it's whitespace, ignore\n if (c !== ' ' && c !== '\\t') {\n // If it's a string\n if (c === '\"' || c === '\\'') {\n if (c === str[ptr + 1] && c === str[ptr + 2]) {\n throw new TomlError('multiline strings are not allowed in keys', {\n toml: str,\n ptr: ptr,\n });\n }\n let eos = getStringEnd(str, ptr);\n if (eos < 0) {\n throw new TomlError('unfinished string encountered', {\n toml: str,\n ptr: ptr,\n });\n }\n dot = str.indexOf('.', eos);\n let strEnd = str.slice(eos, dot < 0 || dot > endPtr ? endPtr : dot);\n let newLine = indexOfNewline(strEnd);\n if (newLine > -1) {\n throw new TomlError('newlines are not allowed in keys', {\n toml: str,\n ptr: ptr + dot + newLine,\n });\n }\n if (strEnd.trimStart()) {\n throw new TomlError('found extra tokens after the string part', {\n toml: str,\n ptr: eos,\n });\n }\n if (endPtr < eos) {\n endPtr = str.indexOf(end, eos);\n if (endPtr < 0) {\n throw new TomlError('incomplete key-value: cannot find end of key', {\n toml: str,\n ptr: ptr,\n });\n }\n }\n parsed.push(parseString(str, ptr, eos));\n }\n else {\n // Normal raw key part consumption and validation\n dot = str.indexOf('.', ptr);\n let part = str.slice(ptr, dot < 0 || dot > endPtr ? endPtr : dot);\n if (!KEY_PART_RE.test(part)) {\n throw new TomlError('only letter, numbers, dashes and underscores are allowed in keys', {\n toml: str,\n ptr: ptr,\n });\n }\n parsed.push(part.trimEnd());\n }\n }\n // Until there's no more dot\n } while (dot + 1 && dot < endPtr);\n return [parsed, skipVoid(str, endPtr + 1, true, true)];\n}\nexport function parseInlineTable(str, ptr, depth, integersAsBigInt) {\n let res = {};\n let seen = new Set();\n let c;\n ptr++;\n while ((c = str[ptr++]) !== '}' && c) {\n if (c === ',') {\n throw new TomlError('expected value, found comma', {\n toml: str,\n ptr: ptr - 1,\n });\n }\n else if (c === '#')\n ptr = skipComment(str, ptr);\n else if (c !== ' ' && c !== '\\t' && c !== '\\n' && c !== '\\r') {\n let k;\n let t = res;\n let hasOwn = false;\n let [key, keyEndPtr] = parseKey(str, ptr - 1);\n for (let i = 0; i < key.length; i++) {\n if (i)\n t = hasOwn ? t[k] : (t[k] = {});\n k = key[i];\n if ((hasOwn = Object.hasOwn(t, k)) && (typeof t[k] !== 'object' || seen.has(t[k]))) {\n throw new TomlError('trying to redefine an already defined value', {\n toml: str,\n ptr: ptr,\n });\n }\n if (!hasOwn && k === '__proto__') {\n Object.defineProperty(t, k, { enumerable: true, configurable: true, writable: true });\n }\n }\n if (hasOwn) {\n throw new TomlError('trying to redefine an already defined value', {\n toml: str,\n ptr: ptr,\n });\n }\n let [value, valueEndPtr] = extractValue(str, keyEndPtr, '}', depth - 1, integersAsBigInt);\n seen.add(value);\n t[k] = value;\n ptr = valueEndPtr;\n }\n }\n if (!c) {\n throw new TomlError('unfinished table encountered', {\n toml: str,\n ptr: ptr,\n });\n }\n return [res, ptr];\n}\nexport function parseArray(str, ptr, depth, integersAsBigInt) {\n let res = [];\n let c;\n ptr++;\n while ((c = str[ptr++]) !== ']' && c) {\n if (c === ',') {\n throw new TomlError('expected value, found comma', {\n toml: str,\n ptr: ptr - 1,\n });\n }\n else if (c === '#')\n ptr = skipComment(str, ptr);\n else if (c !== ' ' && c !== '\\t' && c !== '\\n' && c !== '\\r') {\n let e = extractValue(str, ptr - 1, ']', depth - 1, integersAsBigInt);\n res.push(e[0]);\n ptr = e[1];\n }\n }\n if (!c) {\n throw new TomlError('unfinished array encountered', {\n toml: str,\n ptr: ptr,\n });\n }\n return [res, ptr];\n}\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nimport { parseKey } from './struct.js';\nimport { extractValue } from './extract.js';\nimport { skipVoid } from './util.js';\nimport { TomlError } from './error.js';\nfunction peekTable(key, table, meta, type) {\n let t = table;\n let m = meta;\n let k;\n let hasOwn = false;\n let state;\n for (let i = 0; i < key.length; i++) {\n if (i) {\n t = hasOwn ? t[k] : (t[k] = {});\n m = (state = m[k]).c;\n if (type === 0 /* Type.DOTTED */ && (state.t === 1 /* Type.EXPLICIT */ || state.t === 2 /* Type.ARRAY */)) {\n return null;\n }\n if (state.t === 2 /* Type.ARRAY */) {\n let l = t.length - 1;\n t = t[l];\n m = m[l].c;\n }\n }\n k = key[i];\n if ((hasOwn = Object.hasOwn(t, k)) && m[k]?.t === 0 /* Type.DOTTED */ && m[k]?.d) {\n return null;\n }\n if (!hasOwn) {\n if (k === '__proto__') {\n Object.defineProperty(t, k, { enumerable: true, configurable: true, writable: true });\n Object.defineProperty(m, k, { enumerable: true, configurable: true, writable: true });\n }\n m[k] = {\n t: i < key.length - 1 && type === 2 /* Type.ARRAY */\n ? 3 /* Type.ARRAY_DOTTED */\n : type,\n d: false,\n i: 0,\n c: {},\n };\n }\n }\n state = m[k];\n if (state.t !== type && !(type === 1 /* Type.EXPLICIT */ && state.t === 3 /* Type.ARRAY_DOTTED */)) {\n // Bad key type!\n return null;\n }\n if (type === 2 /* Type.ARRAY */) {\n if (!state.d) {\n state.d = true;\n t[k] = [];\n }\n t[k].push(t = {});\n state.c[state.i++] = (state = { t: 1 /* Type.EXPLICIT */, d: false, i: 0, c: {} });\n }\n if (state.d) {\n // Redefining a table!\n return null;\n }\n state.d = true;\n if (type === 1 /* Type.EXPLICIT */) {\n t = hasOwn ? t[k] : (t[k] = {});\n }\n else if (type === 0 /* Type.DOTTED */ && hasOwn) {\n return null;\n }\n return [k, t, state.c];\n}\nexport function parse(toml, { maxDepth = 1000, integersAsBigInt } = {}) {\n let res = {};\n let meta = {};\n let tbl = res;\n let m = meta;\n for (let ptr = skipVoid(toml, 0); ptr < toml.length;) {\n if (toml[ptr] === '[') {\n let isTableArray = toml[++ptr] === '[';\n let k = parseKey(toml, ptr += +isTableArray, ']');\n if (isTableArray) {\n if (toml[k[1] - 1] !== ']') {\n throw new TomlError('expected end of table declaration', {\n toml: toml,\n ptr: k[1] - 1,\n });\n }\n k[1]++;\n }\n let p = peekTable(k[0], res, meta, isTableArray ? 2 /* Type.ARRAY */ : 1 /* Type.EXPLICIT */);\n if (!p) {\n throw new TomlError('trying to redefine an already defined table or value', {\n toml: toml,\n ptr: ptr,\n });\n }\n m = p[2];\n tbl = p[1];\n ptr = k[1];\n }\n else {\n let k = parseKey(toml, ptr);\n let p = peekTable(k[0], tbl, m, 0 /* Type.DOTTED */);\n if (!p) {\n throw new TomlError('trying to redefine an already defined table or value', {\n toml: toml,\n ptr: ptr,\n });\n }\n let v = extractValue(toml, k[1], void 0, maxDepth, integersAsBigInt);\n p[1][p[0]] = v[0];\n ptr = v[1];\n }\n ptr = skipVoid(toml, ptr, true);\n if (toml[ptr] && toml[ptr] !== '\\n' && toml[ptr] !== '\\r') {\n throw new TomlError('each key-value declaration must be followed by an end-of-line', {\n toml: toml,\n ptr: ptr\n });\n }\n ptr = skipVoid(toml, ptr);\n }\n return res;\n}\n","import { Server } from \"@modelcontextprotocol/sdk/server/index.js\";\nimport { readFileSync } from \"node:fs\";\nimport { fileURLToPath } from \"node:url\";\nimport {\n CallToolRequestSchema,\n ListToolsRequestSchema,\n type CallToolResult,\n type Tool,\n} from \"@modelcontextprotocol/sdk/types.js\";\nimport {\n PionexRestClient,\n buildTools,\n MODULES,\n toToolErrorPayload,\n toMcpTool,\n type PionexConfig,\n type ModuleId,\n type ToolSpec,\n} from \"@pionex-ai/core\";\n\nconst SERVER_NAME = \"pionex-trade-mcp\";\n\nfunction resolveServerVersion(): string {\n try {\n const pkgPath = fileURLToPath(new URL(\"../package.json\", import.meta.url));\n const parsed = JSON.parse(readFileSync(pkgPath, \"utf8\")) as { version?: unknown };\n return typeof parsed.version === \"string\" && parsed.version.length > 0 ? parsed.version : \"0.0.0-unknown\";\n } catch {\n return \"0.0.0-unknown\";\n }\n}\n\nconst SERVER_VERSION = resolveServerVersion();\n\nconst SYSTEM_CAPABILITIES_TOOL_NAME = \"system_get_capabilities\";\nconst SYSTEM_CAPABILITIES_TOOL: Tool = {\n name: SYSTEM_CAPABILITIES_TOOL_NAME,\n description: \"Return machine-readable server capabilities and module availability for agent planning.\",\n inputSchema: { type: \"object\", additionalProperties: false },\n annotations: {\n readOnlyHint: true,\n destructiveHint: false,\n idempotentHint: true,\n openWorldHint: false,\n },\n};\n\ntype ModuleCapabilityStatus = \"enabled\" | \"disabled\" | \"requires_auth\";\n\ninterface CapabilitySnapshot {\n readOnly: boolean;\n hasAuth: boolean;\n moduleAvailability: Record<\n ModuleId,\n {\n status: ModuleCapabilityStatus;\n reasonCode?: string;\n }\n >;\n}\n\nfunction buildCapabilitySnapshot(config: PionexConfig): CapabilitySnapshot {\n const enabledModules = new Set(config.modules);\n const moduleAvailability = {} as CapabilitySnapshot[\"moduleAvailability\"];\n\n for (const moduleId of MODULES) {\n if (!enabledModules.has(moduleId)) {\n moduleAvailability[moduleId] = { status: \"disabled\", reasonCode: \"MODULE_FILTERED\" };\n continue;\n }\n if (moduleId === \"market\") {\n moduleAvailability[moduleId] = { status: \"enabled\" };\n continue;\n }\n if (!config.hasAuth) {\n moduleAvailability[moduleId] = { status: \"requires_auth\", reasonCode: \"AUTH_MISSING\" };\n continue;\n }\n moduleAvailability[moduleId] = { status: \"enabled\" };\n }\n\n return {\n readOnly: config.readOnly,\n hasAuth: config.hasAuth,\n moduleAvailability,\n };\n}\n\nfunction successResult(toolName: string, data: unknown, snapshot: CapabilitySnapshot): CallToolResult {\n const payload: Record<string, unknown> = {\n tool: toolName,\n ok: true,\n data,\n capabilities: snapshot,\n timestamp: new Date().toISOString(),\n };\n return {\n content: [{ type: \"text\", text: JSON.stringify(payload, null, 2) }],\n structuredContent: payload,\n };\n}\n\nfunction errorResult(toolName: string, error: unknown, snapshot: CapabilitySnapshot): CallToolResult {\n const payload = toToolErrorPayload(error);\n const structured: Record<string, unknown> = {\n tool: toolName,\n ...payload,\n serverVersion: SERVER_VERSION,\n capabilities: snapshot,\n };\n return {\n isError: true,\n content: [{ type: \"text\", text: JSON.stringify(structured, null, 2) }],\n structuredContent: structured,\n };\n}\n\nexport function createServer(config: PionexConfig): Server {\n const client = new PionexRestClient(config);\n const tools = buildTools(config);\n const toolMap = new Map<string, ToolSpec>(tools.map((t) => [t.name, t]));\n\n const server = new Server(\n { name: SERVER_NAME, version: SERVER_VERSION },\n { capabilities: { tools: {} } },\n );\n\n server.setRequestHandler(ListToolsRequestSchema, async () => {\n return { tools: [...tools.map(toMcpTool), SYSTEM_CAPABILITIES_TOOL] };\n });\n\n server.setRequestHandler(CallToolRequestSchema, async (request) => {\n const toolName = request.params.name;\n const snapshot = buildCapabilitySnapshot(config);\n\n if (toolName === SYSTEM_CAPABILITIES_TOOL_NAME) {\n return successResult(\n toolName,\n {\n server: { name: SERVER_NAME, version: SERVER_VERSION },\n capabilities: snapshot,\n },\n snapshot,\n );\n }\n\n const tool = toolMap.get(toolName);\n if (!tool) {\n return errorResult(toolName, new Error(`Tool \"${toolName}\" is not available in this server session.`), snapshot);\n }\n\n try {\n const data = await tool.handler(request.params.arguments ?? {}, { config, client });\n return successResult(toolName, data, snapshot);\n } catch (e) {\n return errorResult(toolName, e, snapshot);\n }\n });\n\n return server;\n}\n\n"],"mappings":"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","names":["endPtr","path","path","readFileSync","readFileSync"]}
1
+ {"version":3,"sources":["../src/index.ts","../../core/src/config/toml.ts","../../core/src/setup.ts","../../core/src/constants.ts","../../core/src/utils/errors.ts","../../core/src/config.ts","../../core/src/client/rest-client.ts","../../core/src/tools/market.ts","../../core/src/tools/account.ts","../../core/src/tools/orders.ts","../../core/src/tools/bot.ts","../../core/src/tools/index.ts","../../core/src/tools/types.ts","../../../node_modules/smol-toml/dist/error.js","../../../node_modules/smol-toml/dist/util.js","../../../node_modules/smol-toml/dist/date.js","../../../node_modules/smol-toml/dist/primitive.js","../../../node_modules/smol-toml/dist/extract.js","../../../node_modules/smol-toml/dist/struct.js","../../../node_modules/smol-toml/dist/parse.js","../src/server.ts"],"sourcesContent":["#!/usr/bin/env node\n\nimport { parseArgs } from \"node:util\";\nimport { StdioServerTransport } from \"@modelcontextprotocol/sdk/server/stdio.js\";\nimport { loadConfig, toToolErrorPayload } from \"@pionex-ai/core\";\nimport { createServer } from \"./server.js\";\n\nfunction printHelp(): void {\n process.stdout.write(`\nUsage: pionex-trade-mcp [options]\n\nOptions:\n --modules <list> Comma-separated list of modules to load\n Available: market, account, orders, bot\n Special: \"all\" loads all modules\n Default: market,account,orders,bot\n\n --profile <name> Profile to load from ~/.pionex/config.toml\n Falls back to default_profile in config, then \"default\"\n --base-url <url> Override API base URL (otherwise env PIONEX_BASE_URL / toml / default)\n --read-only Expose only read/query tools and disable write operations\n --help Show this help message\n --version Show version\n\nCredentials (priority: env vars > ~/.pionex/config.toml > none):\n PIONEX_API_KEY Pionex API key\n PIONEX_API_SECRET Pionex API secret\n PIONEX_BASE_URL Optional API base URL override\n`);\n}\n\nfunction parseCli(): {\n modules?: string;\n profile?: string;\n baseUrl?: string;\n readOnly: boolean;\n help: boolean;\n version: boolean;\n} {\n const parsed = parseArgs({\n options: {\n modules: { type: \"string\" },\n profile: { type: \"string\" },\n \"base-url\": { type: \"string\" },\n \"read-only\": { type: \"boolean\", default: false },\n help: { type: \"boolean\", default: false },\n version: { type: \"boolean\", default: false },\n },\n allowPositionals: false,\n });\n return {\n modules: parsed.values.modules,\n profile: parsed.values.profile,\n baseUrl: parsed.values[\"base-url\"],\n readOnly: parsed.values[\"read-only\"] ?? false,\n help: parsed.values.help ?? false,\n version: parsed.values.version ?? false,\n };\n}\n\nexport async function main(): Promise<void> {\n const cli = parseCli();\n\n if (cli.help) {\n printHelp();\n return;\n }\n\n if (cli.version) {\n process.stdout.write(`pionex-trade-mcp\\n`);\n return;\n }\n\n const config = loadConfig({\n modules: cli.modules,\n profile: cli.profile,\n baseUrl: cli.baseUrl,\n readOnly: cli.readOnly,\n });\n const server = createServer(config);\n const transport = new StdioServerTransport();\n await server.connect(transport);\n}\n\nmain().catch((error: unknown) => {\n const payload = toToolErrorPayload(error);\n process.stderr.write(`${JSON.stringify(payload, null, 2)}\\n`);\n process.exitCode = 1;\n});\n","import { readFileSync, writeFileSync, mkdirSync, existsSync } from \"node:fs\";\nimport { join, dirname } from \"node:path\";\nimport { homedir } from \"node:os\";\nimport { parse, stringify } from \"smol-toml\";\n\nexport { stringify as tomlStringify };\n\nexport interface PionexProfile {\n api_key?: string;\n secret_key?: string;\n base_url?: string;\n}\n\nexport interface PionexTomlConfig {\n default_profile?: string;\n profiles: Record<string, PionexProfile>;\n}\n\n/** Fixed path: ~/.pionex/config.toml */\nexport function configFilePath(): string {\n return join(homedir(), \".pionex\", \"config.toml\");\n}\n\nexport function readFullConfig(): PionexTomlConfig {\n const path = configFilePath();\n if (!existsSync(path)) return { profiles: {} };\n const raw = readFileSync(path, \"utf-8\");\n return parse(raw) as unknown as PionexTomlConfig;\n}\n\nexport function readTomlProfile(profileName?: string): PionexProfile {\n const config = readFullConfig();\n const name = profileName ?? config.default_profile ?? \"default\";\n return config.profiles?.[name] ?? {};\n}\n\nexport function writeFullConfig(config: PionexTomlConfig): void {\n const path = configFilePath();\n const dir = dirname(path);\n if (!existsSync(dir)) {\n mkdirSync(dir, { recursive: true });\n }\n writeFileSync(path, stringify(config as unknown as Record<string, unknown>), \"utf-8\");\n}\n","import * as fs from \"node:fs\";\nimport * as path from \"node:path\";\nimport * as os from \"node:os\";\nimport { execFileSync } from \"node:child_process\";\nimport { configFilePath } from \"./config/toml.js\";\n\nexport type ClientId = \"claude-desktop\" | \"cursor\" | \"windsurf\" | \"vscode\" | \"claude-code\" | \"openclaw\";\n\nconst CLIENT_NAMES: Record<ClientId, string> = {\n \"claude-desktop\": \"Claude Desktop\",\n cursor: \"Cursor\",\n windsurf: \"Windsurf\",\n vscode: \"VS Code\",\n \"claude-code\": \"Claude Code CLI\",\n openclaw: \"OpenClaw (mcporter)\",\n};\n\nexport const SUPPORTED_CLIENTS = Object.keys(CLIENT_NAMES) as ClientId[];\n\nfunction appData(): string {\n return process.env.APPDATA ?? path.join(os.homedir(), \"AppData\", \"Roaming\");\n}\n\nconst CLAUDE_CONFIG_FILE = \"claude_desktop_config.json\";\n\nfunction findMsStoreClaudePath(): string | null {\n const localAppData = process.env.LOCALAPPDATA ?? path.join(os.homedir(), \"AppData\", \"Local\");\n const packagesDir = path.join(localAppData, \"Packages\");\n try {\n const entries = fs.readdirSync(packagesDir);\n const claudePkg = entries.find((e) => e.startsWith(\"Claude_\"));\n if (claudePkg) {\n const configPath = path.join(\n packagesDir,\n claudePkg,\n \"LocalCache\",\n \"Roaming\",\n \"Claude\",\n CLAUDE_CONFIG_FILE,\n );\n if (fs.existsSync(configPath) || fs.existsSync(path.dirname(configPath))) {\n return configPath;\n }\n }\n } catch {\n // ignore missing or unreadable Packages dir\n }\n return null;\n}\n\nexport function getConfigPath(client: ClientId): string | null {\n const home = os.homedir();\n const platform = process.platform;\n switch (client) {\n case \"claude-desktop\":\n if (platform === \"win32\") {\n return findMsStoreClaudePath() ?? path.join(appData(), \"Claude\", CLAUDE_CONFIG_FILE);\n }\n if (platform === \"darwin\") {\n return path.join(home, \"Library\", \"Application Support\", \"Claude\", CLAUDE_CONFIG_FILE);\n }\n return path.join(process.env.XDG_CONFIG_HOME ?? path.join(home, \".config\"), \"Claude\", CLAUDE_CONFIG_FILE);\n case \"cursor\":\n return path.join(home, \".cursor\", \"mcp.json\");\n case \"windsurf\":\n return path.join(home, \".codeium\", \"windsurf\", \"mcp_config.json\");\n case \"vscode\":\n return path.join(process.cwd(), \".mcp.json\");\n case \"claude-code\":\n return null;\n case \"openclaw\":\n return path.join(home, \".openclaw\", \"workspace\", \"config\", \"mcporter.json\");\n }\n}\n\nconst NPX_PACKAGE = \"@pionex/pionex-trade-mcp\";\n\nfunction buildEntry(client: ClientId): Record<string, unknown> {\n if (client === \"vscode\") {\n // VS Code MCP expects an explicit stdio transport field.\n return { type: \"stdio\", command: \"npx\", args: [\"-y\", NPX_PACKAGE] };\n }\n // Other clients (Cursor, Claude Desktop, Windsurf, OpenClaw, etc.) use npx\n // with the scoped package name so that users do not need to manage PATH.\n return { command: \"npx\", args: [\"-y\", NPX_PACKAGE] };\n}\n\nfunction mergeJsonConfig(\n configPath: string,\n serverName: string,\n entry: Record<string, unknown>\n): void {\n const dir = path.dirname(configPath);\n if (!fs.existsSync(dir)) fs.mkdirSync(dir, { recursive: true });\n\n let data: Record<string, unknown> = {};\n if (fs.existsSync(configPath)) {\n const raw = fs.readFileSync(configPath, \"utf-8\");\n try {\n data = JSON.parse(raw) as Record<string, unknown>;\n } catch {\n throw new Error(`Failed to parse existing config at ${configPath}`);\n }\n }\n\n if (typeof data.mcpServers !== \"object\" || data.mcpServers === null) {\n data.mcpServers = {};\n }\n (data.mcpServers as Record<string, unknown>)[serverName] = entry;\n\n fs.writeFileSync(configPath, JSON.stringify(data, null, 2) + \"\\n\", \"utf-8\");\n}\n\nexport interface SetupOptions {\n client: ClientId;\n}\n\nexport function runSetup(options: SetupOptions): void {\n const { client } = options;\n const name = CLIENT_NAMES[client];\n const serverName = \"pionex-trade-mcp\";\n\n if (client === \"claude-code\") {\n const claudeArgs = [\n \"mcp\",\n \"add\",\n \"--scope\",\n \"user\",\n \"--transport\",\n \"stdio\",\n serverName,\n \"--\",\n \"npx\",\n \"-y\",\n NPX_PACKAGE,\n ];\n process.stdout.write(`Running: claude ${claudeArgs.join(\" \")}\\n`);\n execFileSync(\"claude\", claudeArgs, { stdio: \"inherit\" });\n process.stdout.write(`✓ Configured ${name}\\n`);\n return;\n }\n\n const configPath = getConfigPath(client);\n if (!configPath) {\n throw new Error(`${name} is not supported on this platform`);\n }\n\n const entry = buildEntry(client);\n mergeJsonConfig(configPath, serverName, entry);\n process.stdout.write(\n `✓ Configured ${name}\\n ${configPath}\\n Restart ${name} to apply changes.\\n`\n );\n}\n\nexport function printSetupUsage(): void {\n process.stdout.write(\n `Usage: pionex-trade-mcp setup --client <client>\\n\\n` +\n `Clients:\\n` +\n SUPPORTED_CLIENTS.map((id) => ` ${id.padEnd(16)} ${CLIENT_NAMES[id]}`).join(\"\\n\") +\n `\\n\\nCredentials are read from ${configFilePath()}. Run \"pionex-ai-kit config init\" (from pionex-ai-kit) first.\\n`\n );\n}\n","export const PIONEX_API_DEFAULT_BASE_URL = \"https://api.pionex.com\";\n\nexport const MODULES = [\"market\", \"account\", \"orders\", \"bot\"] as const;\nexport type ModuleId = (typeof MODULES)[number];\n\nexport const DEFAULT_MODULES: ModuleId[] = [\"market\", \"account\", \"orders\", \"bot\"];\n\n","export class ConfigError extends Error {\n public readonly suggestion?: string;\n public constructor(message: string, suggestion?: string) {\n super(message);\n this.name = \"ConfigError\";\n this.suggestion = suggestion;\n }\n}\n\nexport class PionexApiError extends Error {\n public readonly status?: number;\n public readonly endpoint?: string;\n public readonly responseText?: string;\n public constructor(\n message: string,\n opts?: { status?: number; endpoint?: string; responseText?: string },\n ) {\n super(message);\n this.name = \"PionexApiError\";\n this.status = opts?.status;\n this.endpoint = opts?.endpoint;\n this.responseText = opts?.responseText;\n }\n}\n\nexport function toToolErrorPayload(error: unknown): Record<string, unknown> {\n if (error instanceof ConfigError) {\n return {\n error: true,\n type: \"ConfigError\",\n message: error.message,\n suggestion: error.suggestion,\n };\n }\n if (error instanceof PionexApiError) {\n return {\n error: true,\n type: \"PionexApiError\",\n message: error.message,\n status: error.status,\n endpoint: error.endpoint,\n responseText: error.responseText,\n };\n }\n const message = error instanceof Error ? error.message : String(error);\n return { error: true, type: \"Error\", message };\n}\n\n","import { readTomlProfile } from \"./config/toml.js\";\nimport { PIONEX_API_DEFAULT_BASE_URL, DEFAULT_MODULES, MODULES, type ModuleId } from \"./constants.js\";\nimport { ConfigError } from \"./utils/errors.js\";\n\nexport interface CliOptions {\n modules?: string;\n readOnly: boolean;\n profile?: string;\n baseUrl?: string;\n}\n\nexport interface PionexConfig {\n apiKey?: string;\n apiSecret?: string;\n hasAuth: boolean;\n baseUrl: string;\n modules: ModuleId[];\n readOnly: boolean;\n}\n\nfunction parseModuleList(rawModules?: string): ModuleId[] {\n if (!rawModules || rawModules.trim().length === 0) return [...DEFAULT_MODULES];\n const trimmed = rawModules.trim().toLowerCase();\n if (trimmed === \"all\") return [...MODULES];\n\n const requested = trimmed\n .split(\",\")\n .map((x) => x.trim())\n .filter(Boolean);\n if (requested.length === 0) return [...DEFAULT_MODULES];\n\n const out: ModuleId[] = [];\n for (const m of requested) {\n if (!MODULES.includes(m as ModuleId)) {\n throw new ConfigError(`Unknown module \"${m}\".`, `Use one of: ${MODULES.join(\", \")} or \"all\".`);\n }\n out.push(m as ModuleId);\n }\n return Array.from(new Set(out));\n}\n\n/**\n * Credential priority (highest to lowest):\n * 1. Environment variables (PIONEX_API_KEY / PIONEX_API_SECRET)\n * 2. ~/.pionex/config.toml profile values\n */\nexport function loadConfig(cli: CliOptions): PionexConfig {\n const toml = readTomlProfile(cli.profile);\n\n const apiKey = process.env.PIONEX_API_KEY?.trim() || toml.api_key;\n const apiSecret = process.env.PIONEX_API_SECRET?.trim() || toml.secret_key;\n\n const hasAuth = Boolean(apiKey && apiSecret);\n const partialAuth = Boolean(apiKey) || Boolean(apiSecret);\n if (partialAuth && !hasAuth) {\n throw new ConfigError(\n \"Partial Pionex API credentials detected.\",\n \"Set both PIONEX_API_KEY and PIONEX_API_SECRET (env vars or config.toml profile).\",\n );\n }\n\n const baseUrl = (cli.baseUrl?.trim() || process.env.PIONEX_BASE_URL?.trim() || toml.base_url || PIONEX_API_DEFAULT_BASE_URL)\n .replace(/\\/+$/, \"\");\n if (!baseUrl.startsWith(\"http://\") && !baseUrl.startsWith(\"https://\")) {\n throw new ConfigError(`Invalid base URL \"${baseUrl}\".`, \"PIONEX_BASE_URL must start with http:// or https://\");\n }\n\n return {\n apiKey,\n apiSecret,\n hasAuth,\n baseUrl,\n modules: parseModuleList(cli.modules),\n readOnly: cli.readOnly,\n };\n}\n\n","import crypto from \"node:crypto\";\nimport type { PionexConfig } from \"../config.js\";\nimport { PionexApiError, ConfigError } from \"../utils/errors.js\";\nimport type { HttpMethod, QueryParams, RequestResult } from \"./types.js\";\n\nfunction requireAuth(config: PionexConfig): { apiKey: string; apiSecret: string } {\n if (!config.apiKey || !config.apiSecret) {\n throw new ConfigError(\n \"This operation requires authentication, but no Pionex API credentials were found.\",\n \"Run 'pionex-ai-kit onboard' to create ~/.pionex/config.toml, or set PIONEX_API_KEY and PIONEX_API_SECRET.\",\n );\n }\n return { apiKey: config.apiKey, apiSecret: config.apiSecret };\n}\n\nfunction buildQueryString(query?: QueryParams): string {\n if (!query) return \"\";\n const entries = Object.entries(query).filter(([, v]) => v !== undefined && v !== null);\n if (entries.length === 0) return \"\";\n const params = new URLSearchParams();\n for (const [k, v] of entries) params.set(k, String(v));\n return params.toString();\n}\n\nfunction buildSignedRequest(\n config: PionexConfig,\n method: HttpMethod,\n path: string,\n query: QueryParams,\n bodyJson: string | null,\n): { url: string; headers: Record<string, string>; bodyJson: string | null } {\n const { apiKey, apiSecret } = requireAuth(config);\n const timestamp = Date.now().toString();\n const params: Record<string, unknown> = { ...query, timestamp };\n\n const sortedKeys = Object.keys(params).sort();\n const queryString = sortedKeys.map((k) => `${k}=${params[k]}`).join(\"&\");\n const pathUrl = `${path}?${queryString}`;\n\n let payload = `${method}${pathUrl}`;\n if (bodyJson != null) payload += bodyJson;\n const signature = crypto.createHmac(\"sha256\", apiSecret).update(payload).digest(\"hex\");\n\n const url = `${config.baseUrl}${pathUrl}`;\n const headers = {\n \"PIONEX-KEY\": apiKey,\n \"PIONEX-SIGNATURE\": signature,\n \"Content-Type\": \"application/json\",\n };\n return { url, headers, bodyJson };\n}\n\nasync function readTextSafe(res: Response): Promise<string> {\n try {\n return await res.text();\n } catch {\n return \"\";\n }\n}\n\nexport class PionexRestClient {\n private readonly config: PionexConfig;\n public constructor(config: PionexConfig) {\n this.config = config;\n }\n\n public async publicGet<TData = unknown>(path: string, query: QueryParams = {}): Promise<RequestResult<TData>> {\n const qs = buildQueryString(query);\n const endpoint = qs ? `${path}?${qs}` : path;\n const url = `${this.config.baseUrl}${endpoint}`;\n const res = await fetch(url, { method: \"GET\", headers: { \"Content-Type\": \"application/json\" } });\n if (!res.ok) {\n const txt = await readTextSafe(res);\n throw new PionexApiError(`HTTP ${res.status}: ${txt || res.statusText}`, { status: res.status, endpoint, responseText: txt });\n }\n const data = (await res.json()) as TData;\n return { endpoint, requestTime: new Date().toISOString(), data };\n }\n\n public async signedGet<TData = unknown>(path: string, query: QueryParams = {}): Promise<RequestResult<TData>> {\n const { url, headers } = buildSignedRequest(this.config, \"GET\", path, query, null);\n const endpoint = `${path}?${buildQueryString({ ...query, timestamp: \"...\" })}`;\n const res = await fetch(url, { method: \"GET\", headers });\n if (!res.ok) {\n const txt = await readTextSafe(res);\n throw new PionexApiError(`HTTP ${res.status}: ${txt || res.statusText}`, { status: res.status, endpoint: path, responseText: txt });\n }\n const data = (await res.json()) as TData;\n return { endpoint: path, requestTime: new Date().toISOString(), data };\n }\n\n public async signedPost<TData = unknown>(path: string, body: Record<string, unknown>): Promise<RequestResult<TData>> {\n const bodyJson = JSON.stringify(body);\n const { url, headers, bodyJson: bj } = buildSignedRequest(this.config, \"POST\", path, {}, bodyJson);\n const res = await fetch(url, { method: \"POST\", headers, body: bj ?? undefined });\n if (!res.ok) {\n const txt = await readTextSafe(res);\n throw new PionexApiError(`HTTP ${res.status}: ${txt || res.statusText}`, { status: res.status, endpoint: path, responseText: txt });\n }\n const data = (await res.json()) as TData;\n return { endpoint: path, requestTime: new Date().toISOString(), data };\n }\n\n public async signedDelete<TData = unknown>(path: string, body: Record<string, unknown>): Promise<RequestResult<TData>> {\n const bodyJson = JSON.stringify(body);\n const { url, headers, bodyJson: bj } = buildSignedRequest(this.config, \"DELETE\", path, {}, bodyJson);\n const res = await fetch(url, { method: \"DELETE\", headers, body: bj ?? undefined });\n if (!res.ok) {\n const txt = await readTextSafe(res);\n throw new PionexApiError(`HTTP ${res.status}: ${txt || res.statusText}`, { status: res.status, endpoint: path, responseText: txt });\n }\n const data = (await res.json()) as TData;\n return { endpoint: path, requestTime: new Date().toISOString(), data };\n }\n}\n\n","import type { ToolSpec } from \"./types.js\";\n\nexport function registerMarketTools(): ToolSpec[] {\n return [\n {\n name: \"pionex_market_get_depth\",\n module: \"market\",\n isWrite: false,\n description: \"Get order book depth (bids and asks) for a symbol. Use for spread, liquidity, or best bid/ask.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n limit: { type: \"integer\", description: \"Price levels (1-100), default 5\" },\n },\n required: [\"symbol\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const limit = args.limit == null ? undefined : Number(args.limit);\n const q: Record<string, unknown> = { symbol };\n if (limit != null && Number.isFinite(limit)) q.limit = limit;\n return (await client.publicGet(\"/api/v1/market/depth\", q)).data;\n },\n },\n {\n name: \"pionex_market_get_trades\",\n module: \"market\",\n isWrite: false,\n description: \"Get recent trades for a symbol. Use for latest price and volume.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n limit: { type: \"integer\", description: \"Default 5 (1-100)\" },\n },\n required: [\"symbol\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const limit = args.limit == null ? undefined : Number(args.limit);\n const q: Record<string, unknown> = { symbol };\n if (limit != null && Number.isFinite(limit)) q.limit = limit;\n return (await client.publicGet(\"/api/v1/market/trades\", q)).data;\n },\n },\n {\n name: \"pionex_market_get_symbol_info\",\n module: \"market\",\n isWrite: false,\n description:\n \"Get symbol metadata (precision, min size, price limits). Call before placing orders to avoid amount/size filter errors.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbols: {\n type: \"string\",\n description: 'Optional. One or more symbols, comma-separated, e.g. \"BTC_USDT\" or \"BTC_USDT,ADA_USDT\".',\n },\n type: {\n type: \"string\",\n enum: [\"SPOT\", \"PERP\"],\n description: \"Optional. If no symbols are specified, filter by type (default SPOT).\",\n },\n },\n },\n async handler(args, { client }) {\n const q: Record<string, unknown> = {};\n if (args.symbols) q.symbols = String(args.symbols);\n if (!args.symbols && args.type) q.type = String(args.type);\n return (await client.publicGet(\"/api/v1/common/symbols\", q)).data;\n },\n },\n {\n name: \"pionex_market_get_tickers\",\n module: \"market\",\n isWrite: false,\n description: \"Get 24-hour ticker(s): open, close, high, low, volume, amount, count. Optional symbol or type (SPOT/PERP).\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT; if omitted, returns all tickers filtered by type\" },\n type: { type: \"string\", enum: [\"SPOT\", \"PERP\"], description: \"If symbol is not specified, filter by type.\" },\n },\n },\n async handler(args, { client }) {\n const q: Record<string, unknown> = {};\n if (args.symbol) q.symbol = String(args.symbol);\n if (args.type) q.type = String(args.type);\n return (await client.publicGet(\"/api/v1/market/tickers\", q)).data;\n },\n },\n {\n name: \"pionex_market_get_klines\",\n module: \"market\",\n isWrite: false,\n description: \"Get OHLCV klines (candlestick) for a symbol. Use for charts or historical price/volume.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n interval: { type: \"string\", enum: [\"1M\", \"5M\", \"15M\", \"30M\", \"60M\", \"4H\", \"8H\", \"12H\", \"1D\"], description: \"Kline interval.\" },\n endTime: { type: \"integer\", description: \"End time in milliseconds.\" },\n limit: { type: \"integer\", description: \"Default 100 (1-500).\" },\n },\n required: [\"symbol\", \"interval\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const interval = String(args.interval);\n const q: Record<string, unknown> = { symbol, interval };\n if (args.endTime != null) q.endTime = Number(args.endTime);\n if (args.limit != null) q.limit = Number(args.limit);\n return (await client.publicGet(\"/api/v1/market/klines\", q)).data;\n },\n },\n ];\n}\n\n","import type { ToolSpec } from \"./types.js\";\n\nexport function registerAccountTools(): ToolSpec[] {\n return [\n {\n name: \"pionex_account_get_balance\",\n module: \"account\",\n isWrite: false,\n description: \"Query spot account balances for all currencies. Requires API key and secret in ~/.pionex/config.toml or env.\",\n inputSchema: { type: \"object\", additionalProperties: false, properties: {} },\n async handler(_args, { client }) {\n return (await client.signedGet(\"/api/v1/account/balances\")).data;\n },\n },\n ];\n}\n\n","import type { ToolSpec } from \"./types.js\";\n\nexport function registerOrdersTools(): ToolSpec[] {\n return [\n {\n name: \"pionex_orders_new_order\",\n module: \"orders\",\n isWrite: true,\n description:\n \"Create a spot order on Pionex. LIMIT requires symbol/side/type=LIMIT/price/size. MARKET BUY requires amount (quote). MARKET SELL requires size (base).\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n side: { type: \"string\", enum: [\"BUY\", \"SELL\"] },\n type: { type: \"string\", enum: [\"LIMIT\", \"MARKET\"] },\n clientOrderId: { type: \"string\", description: \"Optional client order id (max 64 chars)\" },\n size: { type: \"string\", description: \"Quantity; required for limit and market sell\" },\n price: { type: \"string\", description: \"Required for limit order\" },\n amount: { type: \"string\", description: \"Quote amount; required for market buy\" },\n IOC: { type: \"boolean\", description: \"Immediate-or-cancel, default false\" },\n },\n required: [\"symbol\", \"side\", \"type\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; order placement is disabled.\");\n }\n const body: Record<string, unknown> = {};\n if (args.symbol != null) body.symbol = String(args.symbol);\n if (args.side != null) body.side = String(args.side);\n if (args.type != null) body.type = String(args.type);\n if (args.clientOrderId != null) body.clientOrderId = String(args.clientOrderId);\n if (args.size != null) body.size = String(args.size);\n if (args.price != null) body.price = String(args.price);\n if (args.amount != null) body.amount = String(args.amount);\n if (args.IOC != null) body.IOC = Boolean(args.IOC);\n return (await client.signedPost(\"/api/v1/trade/order\", body)).data;\n },\n },\n {\n name: \"pionex_orders_get_order\",\n module: \"orders\",\n isWrite: false,\n description: \"Get a single order by order ID.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n orderId: { type: \"integer\", description: \"Order id\" },\n },\n required: [\"symbol\", \"orderId\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const orderId = Number(args.orderId);\n return (await client.signedGet(\"/api/v1/trade/order\", { symbol, orderId })).data;\n },\n },\n {\n name: \"pionex_orders_get_order_by_client_order_id\",\n module: \"orders\",\n isWrite: false,\n description: \"Get a single order by client order ID.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n clientOrderId: { type: \"string\", description: \"Client order id\" },\n },\n required: [\"symbol\", \"clientOrderId\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const clientOrderId = String(args.clientOrderId);\n return (await client.signedGet(\"/api/v1/trade/orderByClientOrderId\", { symbol, clientOrderId })).data;\n },\n },\n {\n name: \"pionex_orders_get_open_orders\",\n module: \"orders\",\n isWrite: false,\n description: \"List open (unfilled) orders for a symbol.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: { symbol: { type: \"string\", description: \"e.g. BTC_USDT\" } },\n required: [\"symbol\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n return (await client.signedGet(\"/api/v1/trade/openOrders\", { symbol })).data;\n },\n },\n {\n name: \"pionex_orders_get_all_orders\",\n module: \"orders\",\n isWrite: false,\n description: \"List order history for a symbol (filled and cancelled), with optional limit.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n limit: { type: \"integer\", description: \"Default 1 (1-100)\" },\n },\n required: [\"symbol\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const q: Record<string, unknown> = { symbol };\n if (args.limit != null) q.limit = Number(args.limit);\n return (await client.signedGet(\"/api/v1/trade/allOrders\", q)).data;\n },\n },\n {\n name: \"pionex_orders_cancel_order\",\n module: \"orders\",\n isWrite: true,\n description: \"Cancel an open order by order ID.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n orderId: { type: \"integer\", description: \"Order id\" },\n },\n required: [\"symbol\", \"orderId\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; order cancellation is disabled.\");\n }\n const symbol = String(args.symbol);\n const orderId = Number(args.orderId);\n return (await client.signedDelete(\"/api/v1/trade/order\", { symbol, orderId })).data;\n },\n },\n {\n name: \"pionex_orders_get_fills\",\n module: \"orders\",\n isWrite: false,\n description: \"Get filled trades (fills) for a symbol in a time range. Requires API key. Returns up to 100 latest fills.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n symbol: { type: \"string\", description: \"e.g. BTC_USDT\" },\n startTime: { type: \"integer\", description: \"Start time in milliseconds.\" },\n endTime: { type: \"integer\", description: \"End time in milliseconds.\" },\n },\n required: [\"symbol\"],\n },\n async handler(args, { client }) {\n const symbol = String(args.symbol);\n const q: Record<string, unknown> = { symbol };\n if (args.startTime != null) q.startTime = Number(args.startTime);\n if (args.endTime != null) q.endTime = Number(args.endTime);\n return (await client.signedGet(\"/api/v1/trade/fills\", q)).data;\n },\n },\n {\n name: \"pionex_orders_cancel_all_orders\",\n module: \"orders\",\n isWrite: true,\n description: \"Cancel all open orders for a symbol.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: { symbol: { type: \"string\", description: \"e.g. BTC_USDT\" } },\n required: [\"symbol\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; cancel-all is disabled.\");\n }\n const symbol = String(args.symbol);\n return (await client.signedDelete(\"/api/v1/trade/allOrders\", { symbol })).data;\n },\n },\n ];\n}\n\n","import type { ToolSpec } from \"./types.js\";\n\nfunction asNonEmptyString(value: unknown, field: string): string {\n if (typeof value !== \"string\" || value.trim().length === 0) {\n throw new Error(`Invalid \"${field}\": expected non-empty string.`);\n }\n return value.trim();\n}\n\nfunction asFiniteNumber(value: unknown, field: string): number {\n if (typeof value !== \"number\" || !Number.isFinite(value)) {\n throw new Error(`Invalid \"${field}\": expected finite number.`);\n }\n return value;\n}\n\nfunction asPositiveNumber(value: unknown, field: string): number {\n const n = asFiniteNumber(value, field);\n if (n <= 0) throw new Error(`Invalid \"${field}\": expected number > 0.`);\n return n;\n}\n\nfunction asPositiveInteger(value: unknown, field: string): number {\n const n = asPositiveNumber(value, field);\n if (!Number.isInteger(n)) {\n throw new Error(`Invalid \"${field}\": expected positive integer.`);\n }\n return n;\n}\n\nfunction asBoolean(value: unknown, field: string): boolean {\n if (typeof value !== \"boolean\") {\n throw new Error(`Invalid \"${field}\": expected boolean.`);\n }\n return value;\n}\n\nfunction assertEnum(value: string, field: string, allowed: readonly string[]): void {\n if (!allowed.includes(value)) {\n throw new Error(`Invalid \"${field}\": expected one of ${allowed.join(\", \")}.`);\n }\n}\n\nfunction asObject(value: unknown, field: string): Record<string, unknown> {\n if (!value || typeof value !== \"object\" || Array.isArray(value)) {\n throw new Error(`Invalid \"${field}\": expected JSON object.`);\n }\n return value as Record<string, unknown>;\n}\n\nfunction asPositiveDecimalString(value: unknown, field: string): string {\n const s = asNonEmptyString(value, field);\n if (!/^\\d+(\\.\\d+)?$/.test(s)) {\n throw new Error(`Invalid \"${field}\": expected positive decimal string.`);\n }\n const n = Number(s);\n if (!Number.isFinite(n) || n <= 0) {\n throw new Error(`Invalid \"${field}\": expected positive decimal string.`);\n }\n return s;\n}\n\nfunction asNonNegativeDecimalString(value: unknown, field: string): string {\n const s = asNonEmptyString(value, field);\n if (!/^\\d+(\\.\\d+)?$/.test(s)) {\n throw new Error(`Invalid \"${field}\": expected non-negative decimal string.`);\n }\n const n = Number(s);\n if (!Number.isFinite(n) || n < 0) {\n throw new Error(`Invalid \"${field}\": expected non-negative decimal string.`);\n }\n return s;\n}\n\nfunction toTrimmedDecimal(value: number): string {\n return value.toFixed(8).replace(/\\.?0+$/, \"\");\n}\n\nfunction maybePositiveDecimalString(value: unknown): string | undefined {\n if (typeof value === \"string\" && /^\\d+(\\.\\d+)?$/.test(value)) {\n const n = Number(value);\n if (Number.isFinite(n) && n > 0) return value;\n }\n if (typeof value === \"number\" && Number.isFinite(value) && value > 0) {\n return toTrimmedDecimal(value);\n }\n return undefined;\n}\n\nfunction normalizePerpBase(base: string): string {\n return base.endsWith(\".PERP\") ? base : `${base}.PERP`;\n}\n\nfunction tryExtractCurrentPrice(payload: unknown, symbol: string): string | undefined {\n const stacks: unknown[] = [payload];\n while (stacks.length > 0) {\n const node = stacks.pop();\n if (!node || typeof node !== \"object\") continue;\n\n const obj = node as Record<string, unknown>;\n const nodeSymbol = typeof obj.symbol === \"string\" ? obj.symbol : undefined;\n const candidateClose =\n maybePositiveDecimalString(obj.close) ??\n maybePositiveDecimalString(obj.last) ??\n maybePositiveDecimalString(obj.lastPrice) ??\n maybePositiveDecimalString(obj.price);\n if (candidateClose && (!nodeSymbol || nodeSymbol === symbol)) {\n return candidateClose;\n }\n\n for (const v of Object.values(obj)) {\n if (Array.isArray(v)) {\n for (const item of v) stacks.push(item);\n } else if (v && typeof v === \"object\") {\n stacks.push(v);\n }\n }\n }\n return undefined;\n}\n\nasync function getCurrentSymbolPrice(client: { publicGet: <TData = unknown>(path: string, query?: Record<string, unknown>) => Promise<{ data: TData }> }, symbol: string): Promise<string> {\n const tickerPayload = (await client.publicGet(\"/api/v1/market/tickers\", { symbol })).data;\n const extracted = tryExtractCurrentPrice(tickerPayload, symbol);\n if (!extracted) {\n throw new Error(`Unable to infer current market price for ${symbol} from ticker response. Please provide buOrderData.top and buOrderData.bottom explicitly.`);\n }\n return extracted;\n}\n\nexport function registerBotTools(): ToolSpec[] {\n return [\n {\n name: \"pionex_bot_get_futures_grid_order\",\n module: \"bot\",\n isWrite: false,\n description: \"Get one futures grid bot order by buOrderId.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n buOrderId: { type: \"string\", description: \"Futures grid bot order id.\" },\n lang: { type: \"string\", description: \"Optional language code.\" },\n },\n required: [\"buOrderId\"],\n },\n async handler(args, { client }) {\n const buOrderId = String(args.buOrderId);\n const q: Record<string, unknown> = { buOrderId };\n if (args.lang != null) q.lang = String(args.lang);\n return (await client.signedGet(\"/api/v1/bot/orders/futuresGrid/order\", q)).data;\n },\n },\n {\n name: \"pionex_bot_create_futures_grid_order\",\n module: \"bot\",\n isWrite: true,\n description: \"Create a futures grid bot order.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n keyId: { type: \"string\" },\n exchange: { type: \"string\", description: \"e.g. pionex.v2\" },\n base: { type: \"string\", description: \"e.g. BTC\" },\n quote: { type: \"string\", description: \"e.g. USDT\" },\n copyFrom: { type: \"string\" },\n copyType: { type: \"string\" },\n groupId: { type: \"string\" },\n copyBotOrderId: { type: \"string\" },\n lang: { type: \"string\" },\n buOrderData: {\n type: \"object\",\n additionalProperties: true,\n description: \"CreateFuturesGridOrderData payload from openapi_bot.yaml.\",\n },\n },\n required: [\"base\", \"buOrderData\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; bot create is disabled.\");\n }\n const defaultsApplied: Record<string, unknown> = {};\n const exchange = asNonEmptyString(args.exchange ?? \"pionex.v2\", \"exchange\");\n if (args.exchange == null) defaultsApplied.exchange = exchange;\n const rawBase = asNonEmptyString(args.base, \"base\");\n const base = normalizePerpBase(rawBase);\n if (base !== rawBase) defaultsApplied.base = base;\n const quote = asNonEmptyString(args.quote ?? \"USDT\", \"quote\");\n if (args.quote == null) defaultsApplied.quote = quote;\n const buOrderData = asObject(args.buOrderData, \"buOrderData\");\n const symbol = `${base}_${quote}`;\n const needsTickerForTopBottom = buOrderData.top == null || buOrderData.bottom == null;\n const shouldTryTicker = needsTickerForTopBottom;\n let currentPrice: number | undefined;\n if (shouldTryTicker) {\n try {\n currentPrice = Number(await getCurrentSymbolPrice(client, symbol));\n } catch {\n currentPrice = undefined;\n }\n }\n if (needsTickerForTopBottom && (currentPrice == null || !Number.isFinite(currentPrice) || currentPrice <= 0)) {\n throw new Error(`Unable to infer current market price for ${symbol} from ticker response. Please provide buOrderData.top and buOrderData.bottom explicitly.`);\n }\n const top = asPositiveDecimalString(\n buOrderData.top ?? toTrimmedDecimal((currentPrice as number) * 1.05),\n \"buOrderData.top\",\n );\n if (buOrderData.top == null) defaultsApplied.top = top;\n const bottom = asPositiveDecimalString(\n buOrderData.bottom ?? toTrimmedDecimal((currentPrice as number) * 0.95),\n \"buOrderData.bottom\",\n );\n if (buOrderData.bottom == null) defaultsApplied.bottom = bottom;\n if (Number(top) <= Number(bottom)) {\n throw new Error('Invalid \"buOrderData.top\": expected top > bottom.');\n }\n const row = asPositiveInteger(buOrderData.row ?? 10, \"buOrderData.row\");\n if (buOrderData.row == null) defaultsApplied.row = row;\n const gridType = asNonEmptyString(buOrderData.grid_type ?? \"arithmetic\", \"buOrderData.grid_type\");\n assertEnum(gridType, \"buOrderData.grid_type\", [\"arithmetic\", \"geometric\"]);\n if (buOrderData.grid_type == null) defaultsApplied.grid_type = gridType;\n const openPrice =\n buOrderData.openPrice == null ? undefined : asPositiveDecimalString(buOrderData.openPrice, \"buOrderData.openPrice\");\n const trend = asNonEmptyString(buOrderData.trend, \"buOrderData.trend\");\n assertEnum(trend, \"buOrderData.trend\", [\"long\", \"short\", \"no_trend\"]);\n const leverage = asPositiveNumber(buOrderData.leverage ?? 2, \"buOrderData.leverage\");\n if (buOrderData.leverage == null) defaultsApplied.leverage = leverage;\n const extraMargin = asNonNegativeDecimalString(buOrderData.extraMargin ?? \"0\", \"buOrderData.extraMargin\");\n if (buOrderData.extraMargin == null) defaultsApplied.extraMargin = extraMargin;\n const quoteInvestment = asPositiveDecimalString(buOrderData.quoteInvestment, \"buOrderData.quoteInvestment\");\n\n const body: Record<string, unknown> = {\n exchange,\n base,\n quote,\n buOrderData: {\n ...buOrderData,\n top,\n bottom,\n row,\n grid_type: gridType,\n trend,\n leverage,\n extraMargin,\n quoteInvestment,\n },\n };\n if (openPrice != null) {\n (body.buOrderData as Record<string, unknown>).openPrice = openPrice;\n }\n if (args.keyId != null) body.keyId = asNonEmptyString(args.keyId, \"keyId\");\n if (args.copyFrom != null) body.copyFrom = String(args.copyFrom);\n if (args.copyType != null) body.copyType = String(args.copyType);\n if (args.groupId != null) body.groupId = String(args.groupId);\n if (args.copyBotOrderId != null) body.copyBotOrderId = String(args.copyBotOrderId);\n if (args.lang != null) body.lang = String(args.lang);\n if (args.__dryRun === true) {\n return {\n dryRun: true,\n note: \"No order was sent. This is the resolved request body after applying defaults.\",\n marketSymbol: symbol,\n marketPriceUsed: currentPrice == null ? undefined : toTrimmedDecimal(currentPrice),\n defaultsApplied,\n resolvedBody: body,\n };\n }\n return (await client.signedPost(\"/api/v1/bot/orders/futuresGrid/create\", body)).data;\n },\n },\n {\n name: \"pionex_bot_adjust_futures_grid_params\",\n module: \"bot\",\n isWrite: true,\n description: \"Adjust futures grid bot params (invest_in / adjust_params / invest_in_trigger).\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n buOrderId: { type: \"string\" },\n type: { type: \"string\", enum: [\"invest_in\", \"adjust_params\", \"invest_in_trigger\"] },\n quoteInvestment: { type: \"number\" },\n extraMargin: { type: \"boolean\" },\n openPrice: { type: \"number\" },\n bottom: { type: \"string\" },\n top: { type: \"string\" },\n row: { type: \"number\" },\n extraMarginAmount: { type: \"number\" },\n isRecommend: { type: \"boolean\" },\n isReinvest: { type: \"boolean\" },\n investCoin: { type: \"string\" },\n investmentFrom: { type: \"string\", enum: [\"USER\", \"LOCK_ACTIVITY\"] },\n condition: { type: \"string\" },\n conditionDirection: { type: \"string\", enum: [\"1\", \"-1\"] },\n slippage: { type: \"string\" },\n adjustParamsSence: { type: \"string\" },\n },\n required: [\"buOrderId\", \"type\", \"extraMargin\", \"openPrice\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; bot adjust is disabled.\");\n }\n const buOrderId = asNonEmptyString(args.buOrderId, \"buOrderId\");\n const type = asNonEmptyString(args.type, \"type\");\n assertEnum(type, \"type\", [\"invest_in\", \"adjust_params\", \"invest_in_trigger\"]);\n const extraMargin = asBoolean(args.extraMargin, \"extraMargin\");\n const openPrice = asFiniteNumber(args.openPrice, \"openPrice\");\n\n if (type === \"invest_in\" && args.quoteInvestment != null) {\n asPositiveNumber(args.quoteInvestment, \"quoteInvestment\");\n }\n if (type === \"adjust_params\") {\n const bottom = asPositiveDecimalString(args.bottom, \"bottom\");\n const top = asPositiveDecimalString(args.top, \"top\");\n if (Number(top) <= Number(bottom)) {\n throw new Error('Invalid \"top\": expected top > bottom.');\n }\n asPositiveInteger(args.row, \"row\");\n }\n if (type === \"invest_in_trigger\") {\n asPositiveDecimalString(args.condition, \"condition\");\n const conditionDirection = asNonEmptyString(args.conditionDirection, \"conditionDirection\");\n assertEnum(conditionDirection, \"conditionDirection\", [\"1\", \"-1\"]);\n }\n\n const body: Record<string, unknown> = {\n buOrderId,\n type,\n extraMargin,\n openPrice,\n };\n if (args.quoteInvestment != null) body.quoteInvestment = asFiniteNumber(args.quoteInvestment, \"quoteInvestment\");\n if (args.bottom != null) body.bottom = asPositiveDecimalString(args.bottom, \"bottom\");\n if (args.top != null) body.top = asPositiveDecimalString(args.top, \"top\");\n if (args.row != null) body.row = asPositiveInteger(args.row, \"row\");\n if (args.extraMarginAmount != null) body.extraMarginAmount = asFiniteNumber(args.extraMarginAmount, \"extraMarginAmount\");\n if (args.isRecommend != null) body.isRecommend = asBoolean(args.isRecommend, \"isRecommend\");\n if (args.isReinvest != null) body.isReinvest = asBoolean(args.isReinvest, \"isReinvest\");\n if (args.investCoin != null) body.investCoin = String(args.investCoin);\n if (args.investmentFrom != null) {\n const investmentFrom = asNonEmptyString(args.investmentFrom, \"investmentFrom\");\n assertEnum(investmentFrom, \"investmentFrom\", [\"USER\", \"LOCK_ACTIVITY\"]);\n body.investmentFrom = investmentFrom;\n }\n if (args.condition != null) body.condition = asPositiveDecimalString(args.condition, \"condition\");\n if (args.conditionDirection != null) {\n const conditionDirection = asNonEmptyString(args.conditionDirection, \"conditionDirection\");\n assertEnum(conditionDirection, \"conditionDirection\", [\"1\", \"-1\"]);\n body.conditionDirection = conditionDirection;\n }\n if (args.slippage != null) body.slippage = String(args.slippage);\n if (args.adjustParamsSence != null) body.adjustParamsSence = String(args.adjustParamsSence);\n return (await client.signedPost(\"/api/v1/bot/orders/futuresGrid/adjustParams\", body)).data;\n },\n },\n {\n name: \"pionex_bot_reduce_futures_grid_position\",\n module: \"bot\",\n isWrite: true,\n description: \"Reduce futures grid bot position.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n buOrderId: { type: \"string\" },\n openPrice: { type: \"string\" },\n reduceNum: { type: \"number\" },\n slippage: { type: \"string\" },\n condition: { type: \"string\" },\n conditionDirection: { type: \"string\", enum: [\"1\", \"-1\"] },\n },\n required: [\"buOrderId\", \"openPrice\", \"reduceNum\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; bot reduce is disabled.\");\n }\n const buOrderId = asNonEmptyString(args.buOrderId, \"buOrderId\");\n const openPrice = asPositiveDecimalString(args.openPrice, \"openPrice\");\n const reduceNum = asPositiveInteger(args.reduceNum, \"reduceNum\");\n const body: Record<string, unknown> = {\n buOrderId,\n openPrice,\n reduceNum,\n };\n if (args.slippage != null) body.slippage = String(args.slippage);\n if (args.condition != null) body.condition = String(args.condition);\n if (args.conditionDirection != null) {\n const conditionDirection = asNonEmptyString(args.conditionDirection, \"conditionDirection\");\n assertEnum(conditionDirection, \"conditionDirection\", [\"1\", \"-1\"]);\n body.conditionDirection = conditionDirection;\n }\n return (await client.signedPost(\"/api/v1/bot/orders/futuresGrid/reduce\", body)).data;\n },\n },\n {\n name: \"pionex_bot_cancel_futures_grid_order\",\n module: \"bot\",\n isWrite: true,\n description: \"Cancel and close a futures grid bot order.\",\n inputSchema: {\n type: \"object\",\n additionalProperties: false,\n properties: {\n buOrderId: { type: \"string\" },\n closeNote: { type: \"string\" },\n closeSellModel: { type: \"string\", enum: [\"TO_QUOTE\", \"TO_USDT\"] },\n immediate: { type: \"boolean\" },\n closeSlippage: { type: \"string\" },\n },\n required: [\"buOrderId\"],\n },\n async handler(args, { client, config }) {\n if (config.readOnly) {\n throw new Error(\"Server is running in --read-only mode; bot cancel is disabled.\");\n }\n const buOrderId = asNonEmptyString(args.buOrderId, \"buOrderId\");\n const body: Record<string, unknown> = { buOrderId };\n if (args.closeNote != null) body.closeNote = String(args.closeNote);\n if (args.closeSellModel != null) {\n const closeSellModel = asNonEmptyString(args.closeSellModel, \"closeSellModel\");\n assertEnum(closeSellModel, \"closeSellModel\", [\"TO_QUOTE\", \"TO_USDT\"]);\n body.closeSellModel = closeSellModel;\n }\n if (args.immediate != null) body.immediate = asBoolean(args.immediate, \"immediate\");\n if (args.closeSlippage != null) body.closeSlippage = String(args.closeSlippage);\n return (await client.signedPost(\"/api/v1/bot/orders/futuresGrid/cancel\", body)).data;\n },\n },\n ];\n}\n","import type { PionexConfig } from \"../config.js\";\nimport type { PionexRestClient } from \"../client/rest-client.js\";\nimport { MODULES, type ModuleId } from \"../constants.js\";\nimport type { ToolArgs, ToolSpec } from \"./types.js\";\nimport { registerMarketTools } from \"./market.js\";\nimport { registerAccountTools } from \"./account.js\";\nimport { registerOrdersTools } from \"./orders.js\";\nimport { registerBotTools } from \"./bot.js\";\n\nfunction allToolSpecs(): ToolSpec[] {\n return [...registerMarketTools(), ...registerAccountTools(), ...registerOrdersTools(), ...registerBotTools()];\n}\n\nexport function buildTools(config: PionexConfig): ToolSpec[] {\n const enabled = new Set(config.modules);\n const tools = allToolSpecs().filter((t) => enabled.has(t.module));\n if (!config.readOnly) return tools;\n return tools.filter((t) => !t.isWrite);\n}\n\nexport interface ToolResult {\n endpoint: string;\n requestTime: string;\n data: unknown;\n}\n\nexport type ToolRunner = (toolName: string, args: ToolArgs) => Promise<ToolResult>;\n\n/**\n * Create a function that can call any registered tool by name.\n * For CLI usage we keep module filtering at the command routing level,\n * but the runner itself knows all tools.\n */\nexport function createToolRunner(client: PionexRestClient, config: PionexConfig): ToolRunner {\n const fullConfig: PionexConfig = { ...config, modules: [...MODULES] as ModuleId[] };\n const toolMap = new Map<string, ToolSpec>(allToolSpecs().map((t) => [t.name, t]));\n\n return async (toolName: string, args: ToolArgs): Promise<ToolResult> => {\n const tool = toolMap.get(toolName);\n if (!tool) throw new Error(`Unknown tool: ${toolName}`);\n const data = await tool.handler(args, { config: fullConfig, client });\n return { endpoint: toolName, requestTime: new Date().toISOString(), data };\n };\n}\n\n","import type { ModuleId } from \"../constants.js\";\nimport type { PionexConfig } from \"../config.js\";\nimport type { PionexRestClient } from \"../client/rest-client.js\";\n\nexport type JsonSchema =\n | {\n type: \"object\";\n properties?: Record<string, JsonSchema>;\n required?: string[];\n additionalProperties?: boolean;\n description?: string;\n enum?: string[];\n }\n | { type: \"string\"; description?: string; enum?: string[] }\n | { type: \"number\"; description?: string }\n | { type: \"integer\"; description?: string }\n | { type: \"boolean\"; description?: string }\n | { type: \"array\"; items: JsonSchema; description?: string }\n | { type: \"null\" };\n\nexport interface ToolContext {\n config: PionexConfig;\n client: PionexRestClient;\n}\n\nexport type ToolArgs = Record<string, unknown>;\n\nexport interface ToolSpec {\n name: string;\n description: string;\n module: ModuleId;\n isWrite: boolean;\n inputSchema: JsonSchema;\n handler: (args: ToolArgs, ctx: ToolContext) => Promise<unknown>;\n}\n\nexport interface McpTool {\n name: string;\n description: string;\n inputSchema: JsonSchema;\n annotations?: {\n readOnlyHint?: boolean;\n destructiveHint?: boolean;\n idempotentHint?: boolean;\n openWorldHint?: boolean;\n };\n}\n\nexport function toMcpTool(tool: ToolSpec): McpTool {\n return {\n name: tool.name,\n description: tool.description,\n inputSchema: tool.inputSchema,\n annotations: {\n readOnlyHint: !tool.isWrite,\n destructiveHint: tool.isWrite,\n idempotentHint: !tool.isWrite,\n openWorldHint: false,\n },\n };\n}\n\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nfunction getLineColFromPtr(string, ptr) {\n let lines = string.slice(0, ptr).split(/\\r\\n|\\n|\\r/g);\n return [lines.length, lines.pop().length + 1];\n}\nfunction makeCodeBlock(string, line, column) {\n let lines = string.split(/\\r\\n|\\n|\\r/g);\n let codeblock = '';\n let numberLen = (Math.log10(line + 1) | 0) + 1;\n for (let i = line - 1; i <= line + 1; i++) {\n let l = lines[i - 1];\n if (!l)\n continue;\n codeblock += i.toString().padEnd(numberLen, ' ');\n codeblock += ': ';\n codeblock += l;\n codeblock += '\\n';\n if (i === line) {\n codeblock += ' '.repeat(numberLen + column + 2);\n codeblock += '^\\n';\n }\n }\n return codeblock;\n}\nexport class TomlError extends Error {\n line;\n column;\n codeblock;\n constructor(message, options) {\n const [line, column] = getLineColFromPtr(options.toml, options.ptr);\n const codeblock = makeCodeBlock(options.toml, line, column);\n super(`Invalid TOML document: ${message}\\n\\n${codeblock}`, options);\n this.line = line;\n this.column = column;\n this.codeblock = codeblock;\n }\n}\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nimport { TomlError } from './error.js';\nfunction isEscaped(str, ptr) {\n let i = 0;\n while (str[ptr - ++i] === '\\\\')\n ;\n return --i && (i % 2);\n}\nexport function indexOfNewline(str, start = 0, end = str.length) {\n let idx = str.indexOf('\\n', start);\n if (str[idx - 1] === '\\r')\n idx--;\n return idx <= end ? idx : -1;\n}\nexport function skipComment(str, ptr) {\n for (let i = ptr; i < str.length; i++) {\n let c = str[i];\n if (c === '\\n')\n return i;\n if (c === '\\r' && str[i + 1] === '\\n')\n return i + 1;\n if ((c < '\\x20' && c !== '\\t') || c === '\\x7f') {\n throw new TomlError('control characters are not allowed in comments', {\n toml: str,\n ptr: ptr,\n });\n }\n }\n return str.length;\n}\nexport function skipVoid(str, ptr, banNewLines, banComments) {\n let c;\n while ((c = str[ptr]) === ' ' || c === '\\t' || (!banNewLines && (c === '\\n' || c === '\\r' && str[ptr + 1] === '\\n')))\n ptr++;\n return banComments || c !== '#'\n ? ptr\n : skipVoid(str, skipComment(str, ptr), banNewLines);\n}\nexport function skipUntil(str, ptr, sep, end, banNewLines = false) {\n if (!end) {\n ptr = indexOfNewline(str, ptr);\n return ptr < 0 ? str.length : ptr;\n }\n for (let i = ptr; i < str.length; i++) {\n let c = str[i];\n if (c === '#') {\n i = indexOfNewline(str, i);\n }\n else if (c === sep) {\n return i + 1;\n }\n else if (c === end || (banNewLines && (c === '\\n' || (c === '\\r' && str[i + 1] === '\\n')))) {\n return i;\n }\n }\n throw new TomlError('cannot find end of structure', {\n toml: str,\n ptr: ptr\n });\n}\nexport function getStringEnd(str, seek) {\n let first = str[seek];\n let target = first === str[seek + 1] && str[seek + 1] === str[seek + 2]\n ? str.slice(seek, seek + 3)\n : first;\n seek += target.length - 1;\n do\n seek = str.indexOf(target, ++seek);\n while (seek > -1 && first !== \"'\" && isEscaped(str, seek));\n if (seek > -1) {\n seek += target.length;\n if (target.length > 1) {\n if (str[seek] === first)\n seek++;\n if (str[seek] === first)\n seek++;\n }\n }\n return seek;\n}\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nlet DATE_TIME_RE = /^(\\d{4}-\\d{2}-\\d{2})?[T ]?(?:(\\d{2}):\\d{2}(?::\\d{2}(?:\\.\\d+)?)?)?(Z|[-+]\\d{2}:\\d{2})?$/i;\nexport class TomlDate extends Date {\n #hasDate = false;\n #hasTime = false;\n #offset = null;\n constructor(date) {\n let hasDate = true;\n let hasTime = true;\n let offset = 'Z';\n if (typeof date === 'string') {\n let match = date.match(DATE_TIME_RE);\n if (match) {\n if (!match[1]) {\n hasDate = false;\n date = `0000-01-01T${date}`;\n }\n hasTime = !!match[2];\n // Make sure to use T instead of a space. Breaks in case of extreme values otherwise.\n hasTime && date[10] === ' ' && (date = date.replace(' ', 'T'));\n // Do not allow rollover hours.\n if (match[2] && +match[2] > 23) {\n date = '';\n }\n else {\n offset = match[3] || null;\n date = date.toUpperCase();\n if (!offset && hasTime)\n date += 'Z';\n }\n }\n else {\n date = '';\n }\n }\n super(date);\n if (!isNaN(this.getTime())) {\n this.#hasDate = hasDate;\n this.#hasTime = hasTime;\n this.#offset = offset;\n }\n }\n isDateTime() {\n return this.#hasDate && this.#hasTime;\n }\n isLocal() {\n return !this.#hasDate || !this.#hasTime || !this.#offset;\n }\n isDate() {\n return this.#hasDate && !this.#hasTime;\n }\n isTime() {\n return this.#hasTime && !this.#hasDate;\n }\n isValid() {\n return this.#hasDate || this.#hasTime;\n }\n toISOString() {\n let iso = super.toISOString();\n // Local Date\n if (this.isDate())\n return iso.slice(0, 10);\n // Local Time\n if (this.isTime())\n return iso.slice(11, 23);\n // Local DateTime\n if (this.#offset === null)\n return iso.slice(0, -1);\n // Offset DateTime\n if (this.#offset === 'Z')\n return iso;\n // This part is quite annoying: JS strips the original timezone from the ISO string representation\n // Instead of using a \"modified\" date and \"Z\", we restore the representation \"as authored\"\n let offset = (+(this.#offset.slice(1, 3)) * 60) + +(this.#offset.slice(4, 6));\n offset = this.#offset[0] === '-' ? offset : -offset;\n let offsetDate = new Date(this.getTime() - (offset * 60e3));\n return offsetDate.toISOString().slice(0, -1) + this.#offset;\n }\n static wrapAsOffsetDateTime(jsDate, offset = 'Z') {\n let date = new TomlDate(jsDate);\n date.#offset = offset;\n return date;\n }\n static wrapAsLocalDateTime(jsDate) {\n let date = new TomlDate(jsDate);\n date.#offset = null;\n return date;\n }\n static wrapAsLocalDate(jsDate) {\n let date = new TomlDate(jsDate);\n date.#hasTime = false;\n date.#offset = null;\n return date;\n }\n static wrapAsLocalTime(jsDate) {\n let date = new TomlDate(jsDate);\n date.#hasDate = false;\n date.#offset = null;\n return date;\n }\n}\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nimport { skipVoid } from './util.js';\nimport { TomlDate } from './date.js';\nimport { TomlError } from './error.js';\nlet INT_REGEX = /^((0x[0-9a-fA-F](_?[0-9a-fA-F])*)|(([+-]|0[ob])?\\d(_?\\d)*))$/;\nlet FLOAT_REGEX = /^[+-]?\\d(_?\\d)*(\\.\\d(_?\\d)*)?([eE][+-]?\\d(_?\\d)*)?$/;\nlet LEADING_ZERO = /^[+-]?0[0-9_]/;\nlet ESCAPE_REGEX = /^[0-9a-f]{2,8}$/i;\nlet ESC_MAP = {\n b: '\\b',\n t: '\\t',\n n: '\\n',\n f: '\\f',\n r: '\\r',\n e: '\\x1b',\n '\"': '\"',\n '\\\\': '\\\\',\n};\nexport function parseString(str, ptr = 0, endPtr = str.length) {\n let isLiteral = str[ptr] === '\\'';\n let isMultiline = str[ptr++] === str[ptr] && str[ptr] === str[ptr + 1];\n if (isMultiline) {\n endPtr -= 2;\n if (str[ptr += 2] === '\\r')\n ptr++;\n if (str[ptr] === '\\n')\n ptr++;\n }\n let tmp = 0;\n let isEscape;\n let parsed = '';\n let sliceStart = ptr;\n while (ptr < endPtr - 1) {\n let c = str[ptr++];\n if (c === '\\n' || (c === '\\r' && str[ptr] === '\\n')) {\n if (!isMultiline) {\n throw new TomlError('newlines are not allowed in strings', {\n toml: str,\n ptr: ptr - 1,\n });\n }\n }\n else if ((c < '\\x20' && c !== '\\t') || c === '\\x7f') {\n throw new TomlError('control characters are not allowed in strings', {\n toml: str,\n ptr: ptr - 1,\n });\n }\n if (isEscape) {\n isEscape = false;\n if (c === 'x' || c === 'u' || c === 'U') {\n // Unicode escape\n let code = str.slice(ptr, (ptr += (c === 'x' ? 2 : c === 'u' ? 4 : 8)));\n if (!ESCAPE_REGEX.test(code)) {\n throw new TomlError('invalid unicode escape', {\n toml: str,\n ptr: tmp,\n });\n }\n try {\n parsed += String.fromCodePoint(parseInt(code, 16));\n }\n catch {\n throw new TomlError('invalid unicode escape', {\n toml: str,\n ptr: tmp,\n });\n }\n }\n else if (isMultiline && (c === '\\n' || c === ' ' || c === '\\t' || c === '\\r')) {\n // Multiline escape\n ptr = skipVoid(str, ptr - 1, true);\n if (str[ptr] !== '\\n' && str[ptr] !== '\\r') {\n throw new TomlError('invalid escape: only line-ending whitespace may be escaped', {\n toml: str,\n ptr: tmp,\n });\n }\n ptr = skipVoid(str, ptr);\n }\n else if (c in ESC_MAP) {\n // Classic escape\n parsed += ESC_MAP[c];\n }\n else {\n throw new TomlError('unrecognized escape sequence', {\n toml: str,\n ptr: tmp,\n });\n }\n sliceStart = ptr;\n }\n else if (!isLiteral && c === '\\\\') {\n tmp = ptr - 1;\n isEscape = true;\n parsed += str.slice(sliceStart, tmp);\n }\n }\n return parsed + str.slice(sliceStart, endPtr - 1);\n}\nexport function parseValue(value, toml, ptr, integersAsBigInt) {\n // Constant values\n if (value === 'true')\n return true;\n if (value === 'false')\n return false;\n if (value === '-inf')\n return -Infinity;\n if (value === 'inf' || value === '+inf')\n return Infinity;\n if (value === 'nan' || value === '+nan' || value === '-nan')\n return NaN;\n // Avoid FP representation of -0\n if (value === '-0')\n return integersAsBigInt ? 0n : 0;\n // Numbers\n let isInt = INT_REGEX.test(value);\n if (isInt || FLOAT_REGEX.test(value)) {\n if (LEADING_ZERO.test(value)) {\n throw new TomlError('leading zeroes are not allowed', {\n toml: toml,\n ptr: ptr,\n });\n }\n value = value.replace(/_/g, '');\n let numeric = +value;\n if (isNaN(numeric)) {\n throw new TomlError('invalid number', {\n toml: toml,\n ptr: ptr,\n });\n }\n if (isInt) {\n if ((isInt = !Number.isSafeInteger(numeric)) && !integersAsBigInt) {\n throw new TomlError('integer value cannot be represented losslessly', {\n toml: toml,\n ptr: ptr,\n });\n }\n if (isInt || integersAsBigInt === true)\n numeric = BigInt(value);\n }\n return numeric;\n }\n const date = new TomlDate(value);\n if (!date.isValid()) {\n throw new TomlError('invalid value', {\n toml: toml,\n ptr: ptr,\n });\n }\n return date;\n}\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nimport { parseString, parseValue } from './primitive.js';\nimport { parseArray, parseInlineTable } from './struct.js';\nimport { skipVoid, skipUntil, skipComment, getStringEnd } from './util.js';\nimport { TomlError } from './error.js';\nfunction sliceAndTrimEndOf(str, startPtr, endPtr) {\n let value = str.slice(startPtr, endPtr);\n let commentIdx = value.indexOf('#');\n if (commentIdx > -1) {\n // The call to skipComment allows to \"validate\" the comment\n // (absence of control characters)\n skipComment(str, commentIdx);\n value = value.slice(0, commentIdx);\n }\n return [value.trimEnd(), commentIdx];\n}\nexport function extractValue(str, ptr, end, depth, integersAsBigInt) {\n if (depth === 0) {\n throw new TomlError('document contains excessively nested structures. aborting.', {\n toml: str,\n ptr: ptr\n });\n }\n let c = str[ptr];\n if (c === '[' || c === '{') {\n let [value, endPtr] = c === '['\n ? parseArray(str, ptr, depth, integersAsBigInt)\n : parseInlineTable(str, ptr, depth, integersAsBigInt);\n if (end) {\n endPtr = skipVoid(str, endPtr);\n if (str[endPtr] === ',')\n endPtr++;\n else if (str[endPtr] !== end) {\n throw new TomlError('expected comma or end of structure', {\n toml: str,\n ptr: endPtr,\n });\n }\n }\n return [value, endPtr];\n }\n let endPtr;\n if (c === '\"' || c === \"'\") {\n endPtr = getStringEnd(str, ptr);\n let parsed = parseString(str, ptr, endPtr);\n if (end) {\n endPtr = skipVoid(str, endPtr);\n if (str[endPtr] && str[endPtr] !== ',' && str[endPtr] !== end && str[endPtr] !== '\\n' && str[endPtr] !== '\\r') {\n throw new TomlError('unexpected character encountered', {\n toml: str,\n ptr: endPtr,\n });\n }\n endPtr += (+(str[endPtr] === ','));\n }\n return [parsed, endPtr];\n }\n endPtr = skipUntil(str, ptr, ',', end);\n let slice = sliceAndTrimEndOf(str, ptr, endPtr - (+(str[endPtr - 1] === ',')));\n if (!slice[0]) {\n throw new TomlError('incomplete key-value declaration: no value specified', {\n toml: str,\n ptr: ptr\n });\n }\n if (end && slice[1] > -1) {\n endPtr = skipVoid(str, ptr + slice[1]);\n endPtr += +(str[endPtr] === ',');\n }\n return [\n parseValue(slice[0], str, ptr, integersAsBigInt),\n endPtr,\n ];\n}\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nimport { parseString } from './primitive.js';\nimport { extractValue } from './extract.js';\nimport { getStringEnd, indexOfNewline, skipComment, skipVoid } from './util.js';\nimport { TomlError } from './error.js';\nlet KEY_PART_RE = /^[a-zA-Z0-9-_]+[ \\t]*$/;\nexport function parseKey(str, ptr, end = '=') {\n let dot = ptr - 1;\n let parsed = [];\n let endPtr = str.indexOf(end, ptr);\n if (endPtr < 0) {\n throw new TomlError('incomplete key-value: cannot find end of key', {\n toml: str,\n ptr: ptr,\n });\n }\n do {\n let c = str[ptr = ++dot];\n // If it's whitespace, ignore\n if (c !== ' ' && c !== '\\t') {\n // If it's a string\n if (c === '\"' || c === '\\'') {\n if (c === str[ptr + 1] && c === str[ptr + 2]) {\n throw new TomlError('multiline strings are not allowed in keys', {\n toml: str,\n ptr: ptr,\n });\n }\n let eos = getStringEnd(str, ptr);\n if (eos < 0) {\n throw new TomlError('unfinished string encountered', {\n toml: str,\n ptr: ptr,\n });\n }\n dot = str.indexOf('.', eos);\n let strEnd = str.slice(eos, dot < 0 || dot > endPtr ? endPtr : dot);\n let newLine = indexOfNewline(strEnd);\n if (newLine > -1) {\n throw new TomlError('newlines are not allowed in keys', {\n toml: str,\n ptr: ptr + dot + newLine,\n });\n }\n if (strEnd.trimStart()) {\n throw new TomlError('found extra tokens after the string part', {\n toml: str,\n ptr: eos,\n });\n }\n if (endPtr < eos) {\n endPtr = str.indexOf(end, eos);\n if (endPtr < 0) {\n throw new TomlError('incomplete key-value: cannot find end of key', {\n toml: str,\n ptr: ptr,\n });\n }\n }\n parsed.push(parseString(str, ptr, eos));\n }\n else {\n // Normal raw key part consumption and validation\n dot = str.indexOf('.', ptr);\n let part = str.slice(ptr, dot < 0 || dot > endPtr ? endPtr : dot);\n if (!KEY_PART_RE.test(part)) {\n throw new TomlError('only letter, numbers, dashes and underscores are allowed in keys', {\n toml: str,\n ptr: ptr,\n });\n }\n parsed.push(part.trimEnd());\n }\n }\n // Until there's no more dot\n } while (dot + 1 && dot < endPtr);\n return [parsed, skipVoid(str, endPtr + 1, true, true)];\n}\nexport function parseInlineTable(str, ptr, depth, integersAsBigInt) {\n let res = {};\n let seen = new Set();\n let c;\n ptr++;\n while ((c = str[ptr++]) !== '}' && c) {\n if (c === ',') {\n throw new TomlError('expected value, found comma', {\n toml: str,\n ptr: ptr - 1,\n });\n }\n else if (c === '#')\n ptr = skipComment(str, ptr);\n else if (c !== ' ' && c !== '\\t' && c !== '\\n' && c !== '\\r') {\n let k;\n let t = res;\n let hasOwn = false;\n let [key, keyEndPtr] = parseKey(str, ptr - 1);\n for (let i = 0; i < key.length; i++) {\n if (i)\n t = hasOwn ? t[k] : (t[k] = {});\n k = key[i];\n if ((hasOwn = Object.hasOwn(t, k)) && (typeof t[k] !== 'object' || seen.has(t[k]))) {\n throw new TomlError('trying to redefine an already defined value', {\n toml: str,\n ptr: ptr,\n });\n }\n if (!hasOwn && k === '__proto__') {\n Object.defineProperty(t, k, { enumerable: true, configurable: true, writable: true });\n }\n }\n if (hasOwn) {\n throw new TomlError('trying to redefine an already defined value', {\n toml: str,\n ptr: ptr,\n });\n }\n let [value, valueEndPtr] = extractValue(str, keyEndPtr, '}', depth - 1, integersAsBigInt);\n seen.add(value);\n t[k] = value;\n ptr = valueEndPtr;\n }\n }\n if (!c) {\n throw new TomlError('unfinished table encountered', {\n toml: str,\n ptr: ptr,\n });\n }\n return [res, ptr];\n}\nexport function parseArray(str, ptr, depth, integersAsBigInt) {\n let res = [];\n let c;\n ptr++;\n while ((c = str[ptr++]) !== ']' && c) {\n if (c === ',') {\n throw new TomlError('expected value, found comma', {\n toml: str,\n ptr: ptr - 1,\n });\n }\n else if (c === '#')\n ptr = skipComment(str, ptr);\n else if (c !== ' ' && c !== '\\t' && c !== '\\n' && c !== '\\r') {\n let e = extractValue(str, ptr - 1, ']', depth - 1, integersAsBigInt);\n res.push(e[0]);\n ptr = e[1];\n }\n }\n if (!c) {\n throw new TomlError('unfinished array encountered', {\n toml: str,\n ptr: ptr,\n });\n }\n return [res, ptr];\n}\n","/*!\n * Copyright (c) Squirrel Chat et al., All rights reserved.\n * SPDX-License-Identifier: BSD-3-Clause\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n * 3. Neither the name of the copyright holder nor the names of its contributors\n * may be used to endorse or promote products derived from this software without\n * specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\n * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\n * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\n * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n */\nimport { parseKey } from './struct.js';\nimport { extractValue } from './extract.js';\nimport { skipVoid } from './util.js';\nimport { TomlError } from './error.js';\nfunction peekTable(key, table, meta, type) {\n let t = table;\n let m = meta;\n let k;\n let hasOwn = false;\n let state;\n for (let i = 0; i < key.length; i++) {\n if (i) {\n t = hasOwn ? t[k] : (t[k] = {});\n m = (state = m[k]).c;\n if (type === 0 /* Type.DOTTED */ && (state.t === 1 /* Type.EXPLICIT */ || state.t === 2 /* Type.ARRAY */)) {\n return null;\n }\n if (state.t === 2 /* Type.ARRAY */) {\n let l = t.length - 1;\n t = t[l];\n m = m[l].c;\n }\n }\n k = key[i];\n if ((hasOwn = Object.hasOwn(t, k)) && m[k]?.t === 0 /* Type.DOTTED */ && m[k]?.d) {\n return null;\n }\n if (!hasOwn) {\n if (k === '__proto__') {\n Object.defineProperty(t, k, { enumerable: true, configurable: true, writable: true });\n Object.defineProperty(m, k, { enumerable: true, configurable: true, writable: true });\n }\n m[k] = {\n t: i < key.length - 1 && type === 2 /* Type.ARRAY */\n ? 3 /* Type.ARRAY_DOTTED */\n : type,\n d: false,\n i: 0,\n c: {},\n };\n }\n }\n state = m[k];\n if (state.t !== type && !(type === 1 /* Type.EXPLICIT */ && state.t === 3 /* Type.ARRAY_DOTTED */)) {\n // Bad key type!\n return null;\n }\n if (type === 2 /* Type.ARRAY */) {\n if (!state.d) {\n state.d = true;\n t[k] = [];\n }\n t[k].push(t = {});\n state.c[state.i++] = (state = { t: 1 /* Type.EXPLICIT */, d: false, i: 0, c: {} });\n }\n if (state.d) {\n // Redefining a table!\n return null;\n }\n state.d = true;\n if (type === 1 /* Type.EXPLICIT */) {\n t = hasOwn ? t[k] : (t[k] = {});\n }\n else if (type === 0 /* Type.DOTTED */ && hasOwn) {\n return null;\n }\n return [k, t, state.c];\n}\nexport function parse(toml, { maxDepth = 1000, integersAsBigInt } = {}) {\n let res = {};\n let meta = {};\n let tbl = res;\n let m = meta;\n for (let ptr = skipVoid(toml, 0); ptr < toml.length;) {\n if (toml[ptr] === '[') {\n let isTableArray = toml[++ptr] === '[';\n let k = parseKey(toml, ptr += +isTableArray, ']');\n if (isTableArray) {\n if (toml[k[1] - 1] !== ']') {\n throw new TomlError('expected end of table declaration', {\n toml: toml,\n ptr: k[1] - 1,\n });\n }\n k[1]++;\n }\n let p = peekTable(k[0], res, meta, isTableArray ? 2 /* Type.ARRAY */ : 1 /* Type.EXPLICIT */);\n if (!p) {\n throw new TomlError('trying to redefine an already defined table or value', {\n toml: toml,\n ptr: ptr,\n });\n }\n m = p[2];\n tbl = p[1];\n ptr = k[1];\n }\n else {\n let k = parseKey(toml, ptr);\n let p = peekTable(k[0], tbl, m, 0 /* Type.DOTTED */);\n if (!p) {\n throw new TomlError('trying to redefine an already defined table or value', {\n toml: toml,\n ptr: ptr,\n });\n }\n let v = extractValue(toml, k[1], void 0, maxDepth, integersAsBigInt);\n p[1][p[0]] = v[0];\n ptr = v[1];\n }\n ptr = skipVoid(toml, ptr, true);\n if (toml[ptr] && toml[ptr] !== '\\n' && toml[ptr] !== '\\r') {\n throw new TomlError('each key-value declaration must be followed by an end-of-line', {\n toml: toml,\n ptr: ptr\n });\n }\n ptr = skipVoid(toml, ptr);\n }\n return res;\n}\n","import { Server } from \"@modelcontextprotocol/sdk/server/index.js\";\nimport { readFileSync } from \"node:fs\";\nimport { fileURLToPath } from \"node:url\";\nimport {\n CallToolRequestSchema,\n ListToolsRequestSchema,\n type CallToolResult,\n type Tool,\n} from \"@modelcontextprotocol/sdk/types.js\";\nimport {\n PionexRestClient,\n buildTools,\n MODULES,\n toToolErrorPayload,\n toMcpTool,\n type PionexConfig,\n type ModuleId,\n type ToolSpec,\n} from \"@pionex-ai/core\";\n\nconst SERVER_NAME = \"pionex-trade-mcp\";\n\nfunction resolveServerVersion(): string {\n try {\n const pkgPath = fileURLToPath(new URL(\"../package.json\", import.meta.url));\n const parsed = JSON.parse(readFileSync(pkgPath, \"utf8\")) as { version?: unknown };\n return typeof parsed.version === \"string\" && parsed.version.length > 0 ? parsed.version : \"0.0.0-unknown\";\n } catch {\n return \"0.0.0-unknown\";\n }\n}\n\nconst SERVER_VERSION = resolveServerVersion();\n\nconst SYSTEM_CAPABILITIES_TOOL_NAME = \"system_get_capabilities\";\nconst SYSTEM_CAPABILITIES_TOOL: Tool = {\n name: SYSTEM_CAPABILITIES_TOOL_NAME,\n description: \"Return machine-readable server capabilities and module availability for agent planning.\",\n inputSchema: { type: \"object\", additionalProperties: false },\n annotations: {\n readOnlyHint: true,\n destructiveHint: false,\n idempotentHint: true,\n openWorldHint: false,\n },\n};\n\ntype ModuleCapabilityStatus = \"enabled\" | \"disabled\" | \"requires_auth\";\n\ninterface CapabilitySnapshot {\n readOnly: boolean;\n hasAuth: boolean;\n moduleAvailability: Record<\n ModuleId,\n {\n status: ModuleCapabilityStatus;\n reasonCode?: string;\n }\n >;\n}\n\nfunction buildCapabilitySnapshot(config: PionexConfig): CapabilitySnapshot {\n const enabledModules = new Set(config.modules);\n const moduleAvailability = {} as CapabilitySnapshot[\"moduleAvailability\"];\n\n for (const moduleId of MODULES) {\n if (!enabledModules.has(moduleId)) {\n moduleAvailability[moduleId] = { status: \"disabled\", reasonCode: \"MODULE_FILTERED\" };\n continue;\n }\n if (moduleId === \"market\") {\n moduleAvailability[moduleId] = { status: \"enabled\" };\n continue;\n }\n if (!config.hasAuth) {\n moduleAvailability[moduleId] = { status: \"requires_auth\", reasonCode: \"AUTH_MISSING\" };\n continue;\n }\n moduleAvailability[moduleId] = { status: \"enabled\" };\n }\n\n return {\n readOnly: config.readOnly,\n hasAuth: config.hasAuth,\n moduleAvailability,\n };\n}\n\nfunction successResult(toolName: string, data: unknown, snapshot: CapabilitySnapshot): CallToolResult {\n const payload: Record<string, unknown> = {\n tool: toolName,\n ok: true,\n data,\n capabilities: snapshot,\n timestamp: new Date().toISOString(),\n };\n return {\n content: [{ type: \"text\", text: JSON.stringify(payload, null, 2) }],\n structuredContent: payload,\n };\n}\n\nfunction errorResult(toolName: string, error: unknown, snapshot: CapabilitySnapshot): CallToolResult {\n const payload = toToolErrorPayload(error);\n const structured: Record<string, unknown> = {\n tool: toolName,\n ...payload,\n serverVersion: SERVER_VERSION,\n capabilities: snapshot,\n };\n return {\n isError: true,\n content: [{ type: \"text\", text: JSON.stringify(structured, null, 2) }],\n structuredContent: structured,\n };\n}\n\nexport function createServer(config: PionexConfig): Server {\n const client = new PionexRestClient(config);\n const tools = buildTools(config);\n const toolMap = new Map<string, ToolSpec>(tools.map((t) => [t.name, t]));\n\n const server = new Server(\n { name: SERVER_NAME, version: SERVER_VERSION },\n { capabilities: { tools: {} } },\n );\n\n server.setRequestHandler(ListToolsRequestSchema, async () => {\n return { tools: [...tools.map(toMcpTool), SYSTEM_CAPABILITIES_TOOL] };\n });\n\n server.setRequestHandler(CallToolRequestSchema, async (request) => {\n const toolName = request.params.name;\n const snapshot = buildCapabilitySnapshot(config);\n\n if (toolName === SYSTEM_CAPABILITIES_TOOL_NAME) {\n return successResult(\n toolName,\n {\n server: { name: SERVER_NAME, version: SERVER_VERSION },\n capabilities: snapshot,\n },\n snapshot,\n );\n }\n\n const tool = toolMap.get(toolName);\n if (!tool) {\n return errorResult(toolName, new Error(`Tool \"${toolName}\" is not available in this server session.`), snapshot);\n }\n\n try {\n const data = await tool.handler(request.params.arguments ?? {}, { config, client });\n return successResult(toolName, data, snapshot);\n } catch (e) {\n return errorResult(toolName, e, snapshot);\n }\n });\n\n return server;\n}\n\n"],"mappings":"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","names":["endPtr","path","path","readFileSync","readFileSync"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@pionex/pionex-trade-mcp",
3
- "version": "0.2.21",
3
+ "version": "0.2.22",
4
4
  "description": "Pionex MCP Server - reads credentials from ~/.pionex/config.toml",
5
5
  "type": "module",
6
6
  "license": "MIT",