openbotgate 1.0.0
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/LICENSE +21 -0
- package/README.md +293 -0
- package/bin/openbotgate.js +31 -0
- package/dist/config/config.d.ts +56 -0
- package/dist/config/config.d.ts.map +1 -0
- package/dist/config/config.js +136 -0
- package/dist/config/config.js.map +1 -0
- package/dist/debug.d.ts +2 -0
- package/dist/debug.d.ts.map +1 -0
- package/dist/debug.js +33 -0
- package/dist/debug.js.map +1 -0
- package/dist/gateway/bluebubbles.d.ts +12 -0
- package/dist/gateway/bluebubbles.d.ts.map +1 -0
- package/dist/gateway/bluebubbles.js +80 -0
- package/dist/gateway/bluebubbles.js.map +1 -0
- package/dist/gateway/catalog.d.ts +10 -0
- package/dist/gateway/catalog.d.ts.map +1 -0
- package/dist/gateway/catalog.js +28 -0
- package/dist/gateway/catalog.js.map +1 -0
- package/dist/gateway/discord.d.ts +12 -0
- package/dist/gateway/discord.d.ts.map +1 -0
- package/dist/gateway/discord.js +83 -0
- package/dist/gateway/discord.js.map +1 -0
- package/dist/gateway/feishu.d.ts +35 -0
- package/dist/gateway/feishu.d.ts.map +1 -0
- package/dist/gateway/feishu.js +290 -0
- package/dist/gateway/feishu.js.map +1 -0
- package/dist/gateway/googlechat.d.ts +11 -0
- package/dist/gateway/googlechat.d.ts.map +1 -0
- package/dist/gateway/googlechat.js +92 -0
- package/dist/gateway/googlechat.js.map +1 -0
- package/dist/gateway/imessage.d.ts +12 -0
- package/dist/gateway/imessage.d.ts.map +1 -0
- package/dist/gateway/imessage.js +84 -0
- package/dist/gateway/imessage.js.map +1 -0
- package/dist/gateway/index.d.ts +9 -0
- package/dist/gateway/index.d.ts.map +1 -0
- package/dist/gateway/index.js +27 -0
- package/dist/gateway/index.js.map +1 -0
- package/dist/gateway/line.d.ts +13 -0
- package/dist/gateway/line.d.ts.map +1 -0
- package/dist/gateway/line.js +80 -0
- package/dist/gateway/line.js.map +1 -0
- package/dist/gateway/matrix.d.ts +12 -0
- package/dist/gateway/matrix.d.ts.map +1 -0
- package/dist/gateway/matrix.js +105 -0
- package/dist/gateway/matrix.js.map +1 -0
- package/dist/gateway/mattermost.d.ts +14 -0
- package/dist/gateway/mattermost.d.ts.map +1 -0
- package/dist/gateway/mattermost.js +92 -0
- package/dist/gateway/mattermost.js.map +1 -0
- package/dist/gateway/msteams.d.ts +12 -0
- package/dist/gateway/msteams.d.ts.map +1 -0
- package/dist/gateway/msteams.js +119 -0
- package/dist/gateway/msteams.js.map +1 -0
- package/dist/gateway/nextcloud-talk.d.ts +11 -0
- package/dist/gateway/nextcloud-talk.d.ts.map +1 -0
- package/dist/gateway/nextcloud-talk.js +93 -0
- package/dist/gateway/nextcloud-talk.js.map +1 -0
- package/dist/gateway/nostr.d.ts +15 -0
- package/dist/gateway/nostr.d.ts.map +1 -0
- package/dist/gateway/nostr.js +95 -0
- package/dist/gateway/nostr.js.map +1 -0
- package/dist/gateway/qq-guild.d.ts +14 -0
- package/dist/gateway/qq-guild.d.ts.map +1 -0
- package/dist/gateway/qq-guild.js +121 -0
- package/dist/gateway/qq-guild.js.map +1 -0
- package/dist/gateway/qq.d.ts +14 -0
- package/dist/gateway/qq.d.ts.map +1 -0
- package/dist/gateway/qq.js +121 -0
- package/dist/gateway/qq.js.map +1 -0
- package/dist/gateway/registry.d.ts +4 -0
- package/dist/gateway/registry.d.ts.map +1 -0
- package/dist/gateway/registry.js +38 -0
- package/dist/gateway/registry.js.map +1 -0
- package/dist/gateway/signal.d.ts +12 -0
- package/dist/gateway/signal.d.ts.map +1 -0
- package/dist/gateway/signal.js +80 -0
- package/dist/gateway/signal.js.map +1 -0
- package/dist/gateway/slack.d.ts +12 -0
- package/dist/gateway/slack.d.ts.map +1 -0
- package/dist/gateway/slack.js +83 -0
- package/dist/gateway/slack.js.map +1 -0
- package/dist/gateway/stub.d.ts +7 -0
- package/dist/gateway/stub.d.ts.map +1 -0
- package/dist/gateway/stub.js +23 -0
- package/dist/gateway/stub.js.map +1 -0
- package/dist/gateway/telegram.d.ts +12 -0
- package/dist/gateway/telegram.d.ts.map +1 -0
- package/dist/gateway/telegram.js +61 -0
- package/dist/gateway/telegram.js.map +1 -0
- package/dist/gateway/tlon.d.ts +12 -0
- package/dist/gateway/tlon.d.ts.map +1 -0
- package/dist/gateway/tlon.js +105 -0
- package/dist/gateway/tlon.js.map +1 -0
- package/dist/gateway/types.d.ts +21 -0
- package/dist/gateway/types.d.ts.map +1 -0
- package/dist/gateway/types.js +3 -0
- package/dist/gateway/types.js.map +1 -0
- package/dist/gateway/whatsapp.d.ts +12 -0
- package/dist/gateway/whatsapp.d.ts.map +1 -0
- package/dist/gateway/whatsapp.js +81 -0
- package/dist/gateway/whatsapp.js.map +1 -0
- package/dist/gateway/zalo.d.ts +12 -0
- package/dist/gateway/zalo.d.ts.map +1 -0
- package/dist/gateway/zalo.js +77 -0
- package/dist/gateway/zalo.js.map +1 -0
- package/dist/gateway/zalouser.d.ts +12 -0
- package/dist/gateway/zalouser.d.ts.map +1 -0
- package/dist/gateway/zalouser.js +85 -0
- package/dist/gateway/zalouser.js.map +1 -0
- package/dist/handler/code/agent.d.ts +10 -0
- package/dist/handler/code/agent.d.ts.map +1 -0
- package/dist/handler/code/agent.js +63 -0
- package/dist/handler/code/agent.js.map +1 -0
- package/dist/handler/code/code.d.ts +15 -0
- package/dist/handler/code/code.d.ts.map +1 -0
- package/dist/handler/code/code.js +129 -0
- package/dist/handler/code/code.js.map +1 -0
- package/dist/handler/code/model.d.ts +10 -0
- package/dist/handler/code/model.d.ts.map +1 -0
- package/dist/handler/code/model.js +63 -0
- package/dist/handler/code/model.js.map +1 -0
- package/dist/handler/code/new.d.ts +7 -0
- package/dist/handler/code/new.d.ts.map +1 -0
- package/dist/handler/code/new.js +27 -0
- package/dist/handler/code/new.js.map +1 -0
- package/dist/handler/code/opencode.d.ts +12 -0
- package/dist/handler/code/opencode.d.ts.map +1 -0
- package/dist/handler/code/opencode.js +88 -0
- package/dist/handler/code/opencode.js.map +1 -0
- package/dist/handler/code/session.d.ts +9 -0
- package/dist/handler/code/session.d.ts.map +1 -0
- package/dist/handler/code/session.js +55 -0
- package/dist/handler/code/session.js.map +1 -0
- package/dist/handler/code/workspace.d.ts +10 -0
- package/dist/handler/code/workspace.d.ts.map +1 -0
- package/dist/handler/code/workspace.js +80 -0
- package/dist/handler/code/workspace.js.map +1 -0
- package/dist/handler/commands/agent.d.ts +10 -0
- package/dist/handler/commands/agent.d.ts.map +1 -0
- package/dist/handler/commands/agent.js +63 -0
- package/dist/handler/commands/agent.js.map +1 -0
- package/dist/handler/commands/async.d.ts +3 -0
- package/dist/handler/commands/async.d.ts.map +1 -0
- package/dist/handler/commands/async.js +30 -0
- package/dist/handler/commands/async.js.map +1 -0
- package/dist/handler/commands/claude.d.ts +3 -0
- package/dist/handler/commands/claude.d.ts.map +1 -0
- package/dist/handler/commands/claude.js +19 -0
- package/dist/handler/commands/claude.js.map +1 -0
- package/dist/handler/commands/code.d.ts +15 -0
- package/dist/handler/commands/code.d.ts.map +1 -0
- package/dist/handler/commands/code.js +133 -0
- package/dist/handler/commands/code.js.map +1 -0
- package/dist/handler/commands/git.d.ts +3 -0
- package/dist/handler/commands/git.d.ts.map +1 -0
- package/dist/handler/commands/git.js +25 -0
- package/dist/handler/commands/git.js.map +1 -0
- package/dist/handler/commands/help.d.ts +3 -0
- package/dist/handler/commands/help.d.ts.map +1 -0
- package/dist/handler/commands/help.js +49 -0
- package/dist/handler/commands/help.js.map +1 -0
- package/dist/handler/commands/index.d.ts +10 -0
- package/dist/handler/commands/index.d.ts.map +1 -0
- package/dist/handler/commands/index.js +43 -0
- package/dist/handler/commands/index.js.map +1 -0
- package/dist/handler/commands/model.d.ts +10 -0
- package/dist/handler/commands/model.d.ts.map +1 -0
- package/dist/handler/commands/model.js +63 -0
- package/dist/handler/commands/model.js.map +1 -0
- package/dist/handler/commands/new.d.ts +3 -0
- package/dist/handler/commands/new.d.ts.map +1 -0
- package/dist/handler/commands/new.js +25 -0
- package/dist/handler/commands/new.js.map +1 -0
- package/dist/handler/commands/opencode.d.ts +12 -0
- package/dist/handler/commands/opencode.d.ts.map +1 -0
- package/dist/handler/commands/opencode.js +131 -0
- package/dist/handler/commands/opencode.js.map +1 -0
- package/dist/handler/commands/session.d.ts +9 -0
- package/dist/handler/commands/session.d.ts.map +1 -0
- package/dist/handler/commands/session.js +55 -0
- package/dist/handler/commands/session.js.map +1 -0
- package/dist/handler/commands/shell.d.ts +11 -0
- package/dist/handler/commands/shell.d.ts.map +1 -0
- package/dist/handler/commands/shell.js +142 -0
- package/dist/handler/commands/shell.js.map +1 -0
- package/dist/handler/commands/status.d.ts +3 -0
- package/dist/handler/commands/status.d.ts.map +1 -0
- package/dist/handler/commands/status.js +21 -0
- package/dist/handler/commands/status.js.map +1 -0
- package/dist/handler/commands/sync.d.ts +3 -0
- package/dist/handler/commands/sync.d.ts.map +1 -0
- package/dist/handler/commands/sync.js +26 -0
- package/dist/handler/commands/sync.js.map +1 -0
- package/dist/handler/commands/tasks.d.ts +10 -0
- package/dist/handler/commands/tasks.d.ts.map +1 -0
- package/dist/handler/commands/tasks.js +58 -0
- package/dist/handler/commands/tasks.js.map +1 -0
- package/dist/handler/commands/utils.d.ts +10 -0
- package/dist/handler/commands/utils.d.ts.map +1 -0
- package/dist/handler/commands/utils.js +63 -0
- package/dist/handler/commands/utils.js.map +1 -0
- package/dist/handler/commands/workspace.d.ts +10 -0
- package/dist/handler/commands/workspace.d.ts.map +1 -0
- package/dist/handler/commands/workspace.js +80 -0
- package/dist/handler/commands/workspace.js.map +1 -0
- package/dist/handler/dedup.d.ts +3 -0
- package/dist/handler/dedup.d.ts.map +1 -0
- package/dist/handler/dedup.js +29 -0
- package/dist/handler/dedup.js.map +1 -0
- package/dist/handler/index.d.ts +21 -0
- package/dist/handler/index.d.ts.map +1 -0
- package/dist/handler/index.js +189 -0
- package/dist/handler/index.js.map +1 -0
- package/dist/handler/parse.d.ts +30 -0
- package/dist/handler/parse.d.ts.map +1 -0
- package/dist/handler/parse.js +57 -0
- package/dist/handler/parse.js.map +1 -0
- package/dist/handler/session/agent.d.ts +10 -0
- package/dist/handler/session/agent.d.ts.map +1 -0
- package/dist/handler/session/agent.js +63 -0
- package/dist/handler/session/agent.js.map +1 -0
- package/dist/handler/session/model.d.ts +10 -0
- package/dist/handler/session/model.d.ts.map +1 -0
- package/dist/handler/session/model.js +63 -0
- package/dist/handler/session/model.js.map +1 -0
- package/dist/handler/session/new.d.ts +3 -0
- package/dist/handler/session/new.d.ts.map +1 -0
- package/dist/handler/session/new.js +25 -0
- package/dist/handler/session/new.js.map +1 -0
- package/dist/handler/session/session.d.ts +9 -0
- package/dist/handler/session/session.d.ts.map +1 -0
- package/dist/handler/session/session.js +55 -0
- package/dist/handler/session/session.js.map +1 -0
- package/dist/handler/session/workspace.d.ts +10 -0
- package/dist/handler/session/workspace.d.ts.map +1 -0
- package/dist/handler/session/workspace.js +80 -0
- package/dist/handler/session/workspace.js.map +1 -0
- package/dist/handler/shell/git.d.ts +3 -0
- package/dist/handler/shell/git.d.ts.map +1 -0
- package/dist/handler/shell/git.js +25 -0
- package/dist/handler/shell/git.js.map +1 -0
- package/dist/handler/shell/runShell.d.ts +7 -0
- package/dist/handler/shell/runShell.d.ts.map +1 -0
- package/dist/handler/shell/runShell.js +42 -0
- package/dist/handler/shell/runShell.js.map +1 -0
- package/dist/handler/shell/utils.d.ts +10 -0
- package/dist/handler/shell/utils.d.ts.map +1 -0
- package/dist/handler/shell/utils.js +63 -0
- package/dist/handler/shell/utils.js.map +1 -0
- package/dist/handler/streamHandler.d.ts +9 -0
- package/dist/handler/streamHandler.d.ts.map +1 -0
- package/dist/handler/streamHandler.js +49 -0
- package/dist/handler/streamHandler.js.map +1 -0
- package/dist/handler/types.d.ts +36 -0
- package/dist/handler/types.d.ts.map +1 -0
- package/dist/handler/types.js +3 -0
- package/dist/handler/types.js.map +1 -0
- package/dist/handlers/messageHandler.d.ts +3 -0
- package/dist/handlers/messageHandler.d.ts.map +1 -0
- package/dist/handlers/messageHandler.js +249 -0
- package/dist/handlers/messageHandler.js.map +1 -0
- package/dist/handlers/messageHandlerOfficial.d.ts +2 -0
- package/dist/handlers/messageHandlerOfficial.d.ts.map +1 -0
- package/dist/handlers/messageHandlerOfficial.js +302 -0
- package/dist/handlers/messageHandlerOfficial.js.map +1 -0
- package/dist/handlers/messageHandlerV2.d.ts +2 -0
- package/dist/handlers/messageHandlerV2.d.ts.map +1 -0
- package/dist/handlers/messageHandlerV2.js +250 -0
- package/dist/handlers/messageHandlerV2.js.map +1 -0
- package/dist/helloWorld.d.ts +5 -0
- package/dist/helloWorld.d.ts.map +1 -0
- package/dist/helloWorld.js +19 -0
- package/dist/helloWorld.js.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +25 -0
- package/dist/index.js.map +1 -0
- package/dist/indexOfficial.d.ts +4 -0
- package/dist/indexOfficial.d.ts.map +1 -0
- package/dist/indexOfficial.js +92 -0
- package/dist/indexOfficial.js.map +1 -0
- package/dist/indexV2.d.ts +4 -0
- package/dist/indexV2.d.ts.map +1 -0
- package/dist/indexV2.js +109 -0
- package/dist/indexV2.js.map +1 -0
- package/dist/runtime/cliTools.d.ts +17 -0
- package/dist/runtime/cliTools.d.ts.map +1 -0
- package/dist/runtime/cliTools.js +97 -0
- package/dist/runtime/cliTools.js.map +1 -0
- package/dist/runtime/executor.d.ts +27 -0
- package/dist/runtime/executor.d.ts.map +1 -0
- package/dist/runtime/executor.js +108 -0
- package/dist/runtime/executor.js.map +1 -0
- package/dist/runtime/sessionManager.d.ts +42 -0
- package/dist/runtime/sessionManager.d.ts.map +1 -0
- package/dist/runtime/sessionManager.js +161 -0
- package/dist/runtime/sessionManager.js.map +1 -0
- package/dist/runtime/streamHandler.d.ts +9 -0
- package/dist/runtime/streamHandler.d.ts.map +1 -0
- package/dist/runtime/streamHandler.js +49 -0
- package/dist/runtime/streamHandler.js.map +1 -0
- package/dist/runtime/taskManager.d.ts +26 -0
- package/dist/runtime/taskManager.d.ts.map +1 -0
- package/dist/runtime/taskManager.js +153 -0
- package/dist/runtime/taskManager.js.map +1 -0
- package/dist/runtime/tools/base.d.ts +81 -0
- package/dist/runtime/tools/base.d.ts.map +1 -0
- package/dist/runtime/tools/base.js +100 -0
- package/dist/runtime/tools/base.js.map +1 -0
- package/dist/runtime/tools/claudecode.d.ts +19 -0
- package/dist/runtime/tools/claudecode.d.ts.map +1 -0
- package/dist/runtime/tools/claudecode.js +59 -0
- package/dist/runtime/tools/claudecode.js.map +1 -0
- package/dist/runtime/tools/codex.d.ts +19 -0
- package/dist/runtime/tools/codex.d.ts.map +1 -0
- package/dist/runtime/tools/codex.js +68 -0
- package/dist/runtime/tools/codex.js.map +1 -0
- package/dist/runtime/tools/cursor.d.ts +15 -0
- package/dist/runtime/tools/cursor.d.ts.map +1 -0
- package/dist/runtime/tools/cursor.js +33 -0
- package/dist/runtime/tools/cursor.js.map +1 -0
- package/dist/runtime/tools/cursorcode.d.ts +20 -0
- package/dist/runtime/tools/cursorcode.d.ts.map +1 -0
- package/dist/runtime/tools/cursorcode.js +99 -0
- package/dist/runtime/tools/cursorcode.js.map +1 -0
- package/dist/runtime/tools/geminicode.d.ts +20 -0
- package/dist/runtime/tools/geminicode.d.ts.map +1 -0
- package/dist/runtime/tools/geminicode.js +65 -0
- package/dist/runtime/tools/geminicode.js.map +1 -0
- package/dist/runtime/tools/index.d.ts +11 -0
- package/dist/runtime/tools/index.d.ts.map +1 -0
- package/dist/runtime/tools/index.js +36 -0
- package/dist/runtime/tools/index.js.map +1 -0
- package/dist/runtime/tools/kimi.d.ts +16 -0
- package/dist/runtime/tools/kimi.d.ts.map +1 -0
- package/dist/runtime/tools/kimi.js +32 -0
- package/dist/runtime/tools/kimi.js.map +1 -0
- package/dist/runtime/tools/kimicode.d.ts +16 -0
- package/dist/runtime/tools/kimicode.d.ts.map +1 -0
- package/dist/runtime/tools/kimicode.js +43 -0
- package/dist/runtime/tools/kimicode.js.map +1 -0
- package/dist/runtime/tools/nanobot.d.ts +19 -0
- package/dist/runtime/tools/nanobot.d.ts.map +1 -0
- package/dist/runtime/tools/nanobot.js +94 -0
- package/dist/runtime/tools/nanobot.js.map +1 -0
- package/dist/runtime/tools/openaicodex.d.ts +17 -0
- package/dist/runtime/tools/openaicodex.d.ts.map +1 -0
- package/dist/runtime/tools/openaicodex.js +54 -0
- package/dist/runtime/tools/openaicodex.js.map +1 -0
- package/dist/runtime/tools/openclaw.d.ts +24 -0
- package/dist/runtime/tools/openclaw.d.ts.map +1 -0
- package/dist/runtime/tools/openclaw.js +88 -0
- package/dist/runtime/tools/openclaw.js.map +1 -0
- package/dist/runtime/tools/opencode.d.ts +23 -0
- package/dist/runtime/tools/opencode.d.ts.map +1 -0
- package/dist/runtime/tools/opencode.js +82 -0
- package/dist/runtime/tools/opencode.js.map +1 -0
- package/dist/runtime/tools/qwencode.d.ts +17 -0
- package/dist/runtime/tools/qwencode.d.ts.map +1 -0
- package/dist/runtime/tools/qwencode.js +49 -0
- package/dist/runtime/tools/qwencode.js.map +1 -0
- package/dist/runtime/tools/registerAll.d.ts +9 -0
- package/dist/runtime/tools/registerAll.d.ts.map +1 -0
- package/dist/runtime/tools/registerAll.js +29 -0
- package/dist/runtime/tools/registerAll.js.map +1 -0
- package/dist/runtime/tools/registry.d.ts +21 -0
- package/dist/runtime/tools/registry.d.ts.map +1 -0
- package/dist/runtime/tools/registry.js +41 -0
- package/dist/runtime/tools/registry.js.map +1 -0
- package/dist/runtime/tools/types.d.ts +67 -0
- package/dist/runtime/tools/types.d.ts.map +1 -0
- package/dist/runtime/tools/types.js +3 -0
- package/dist/runtime/tools/types.js.map +1 -0
- package/dist/services/cliTools.d.ts +32 -0
- package/dist/services/cliTools.d.ts.map +1 -0
- package/dist/services/cliTools.js +149 -0
- package/dist/services/cliTools.js.map +1 -0
- package/dist/services/commandExecutor.d.ts +29 -0
- package/dist/services/commandExecutor.d.ts.map +1 -0
- package/dist/services/commandExecutor.js +125 -0
- package/dist/services/commandExecutor.js.map +1 -0
- package/dist/services/commandExecutor.test.d.ts +2 -0
- package/dist/services/commandExecutor.test.d.ts.map +1 -0
- package/dist/services/commandExecutor.test.js +54 -0
- package/dist/services/commandExecutor.test.js.map +1 -0
- package/dist/services/feishuService.d.ts +14 -0
- package/dist/services/feishuService.d.ts.map +1 -0
- package/dist/services/feishuService.js +103 -0
- package/dist/services/feishuService.js.map +1 -0
- package/dist/services/feishuServiceOfficial.d.ts +15 -0
- package/dist/services/feishuServiceOfficial.d.ts.map +1 -0
- package/dist/services/feishuServiceOfficial.js +167 -0
- package/dist/services/feishuServiceOfficial.js.map +1 -0
- package/dist/services/feishuServiceV2.d.ts +20 -0
- package/dist/services/feishuServiceV2.d.ts.map +1 -0
- package/dist/services/feishuServiceV2.js +222 -0
- package/dist/services/feishuServiceV2.js.map +1 -0
- package/dist/services/taskManager.d.ts +25 -0
- package/dist/services/taskManager.d.ts.map +1 -0
- package/dist/services/taskManager.js +129 -0
- package/dist/services/taskManager.js.map +1 -0
- package/dist/services/taskManagerSimple.d.ts +25 -0
- package/dist/services/taskManagerSimple.d.ts.map +1 -0
- package/dist/services/taskManagerSimple.js +147 -0
- package/dist/services/taskManagerSimple.js.map +1 -0
- package/dist/testHelloWorld.d.ts +2 -0
- package/dist/testHelloWorld.d.ts.map +1 -0
- package/dist/testHelloWorld.js +18 -0
- package/dist/testHelloWorld.js.map +1 -0
- package/dist/utils/encoding.d.ts +3 -0
- package/dist/utils/encoding.d.ts.map +1 -0
- package/dist/utils/encoding.js +110 -0
- package/dist/utils/encoding.js.map +1 -0
- package/dist/utils/logger.d.ts +19 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +192 -0
- package/dist/utils/logger.js.map +1 -0
- package/dist/utils/shellEncoding.d.ts +5 -0
- package/dist/utils/shellEncoding.d.ts.map +1 -0
- package/dist/utils/shellEncoding.js +117 -0
- package/dist/utils/shellEncoding.js.map +1 -0
- package/openbotgate.example.yml +60 -0
- package/package.json +81 -0
|
@@ -0,0 +1,147 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.taskManagerSimple = exports.TaskManagerSimple = void 0;
|
|
7
|
+
const logger_1 = __importDefault(require("../utils/logger"));
|
|
8
|
+
const uuid_1 = require("uuid");
|
|
9
|
+
const cliTools_1 = require("./cliTools");
|
|
10
|
+
class TaskManagerSimple {
|
|
11
|
+
constructor() {
|
|
12
|
+
this.tasks = new Map();
|
|
13
|
+
this.userTasks = new Map();
|
|
14
|
+
this.MAX_TASKS_PER_USER = 10;
|
|
15
|
+
this.TASK_TIMEOUT = 300000; // 5 minutes
|
|
16
|
+
}
|
|
17
|
+
async createTask(userId, command, tool) {
|
|
18
|
+
const userTaskCount = this.userTasks.get(userId)?.size || 0;
|
|
19
|
+
if (userTaskCount >= this.MAX_TASKS_PER_USER) {
|
|
20
|
+
const oldestTask = this.userTasks.get(userId);
|
|
21
|
+
if (oldestTask) {
|
|
22
|
+
const firstTaskId = oldestTask.values().next().value;
|
|
23
|
+
this.cancelTask(firstTaskId);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
const task = {
|
|
27
|
+
id: (0, uuid_1.v4)(),
|
|
28
|
+
userId,
|
|
29
|
+
command,
|
|
30
|
+
tool,
|
|
31
|
+
status: 'pending',
|
|
32
|
+
createdAt: new Date(),
|
|
33
|
+
updatedAt: new Date(),
|
|
34
|
+
};
|
|
35
|
+
this.tasks.set(task.id, task);
|
|
36
|
+
if (!this.userTasks.has(userId)) {
|
|
37
|
+
this.userTasks.set(userId, new Set());
|
|
38
|
+
}
|
|
39
|
+
this.userTasks.get(userId).add(task.id);
|
|
40
|
+
// Auto cleanup after timeout
|
|
41
|
+
setTimeout(() => {
|
|
42
|
+
if (this.tasks.has(task.id) && this.tasks.get(task.id).status !== 'completed') {
|
|
43
|
+
this.cancelTask(task.id);
|
|
44
|
+
}
|
|
45
|
+
}, this.TASK_TIMEOUT);
|
|
46
|
+
return task;
|
|
47
|
+
}
|
|
48
|
+
async executeTask(taskId) {
|
|
49
|
+
const task = this.tasks.get(taskId);
|
|
50
|
+
if (!task) {
|
|
51
|
+
return null;
|
|
52
|
+
}
|
|
53
|
+
task.status = 'running';
|
|
54
|
+
task.updatedAt = new Date();
|
|
55
|
+
let result;
|
|
56
|
+
switch (task.tool) {
|
|
57
|
+
case 'opencode':
|
|
58
|
+
logger_1.default.info(`🤖 Starting OpenCode execution: ${task.command.substring(0, 50)}${task.command.length > 50 ? '...' : ''}`);
|
|
59
|
+
result = await cliTools_1.cliTools.executeOpenCode(task.command);
|
|
60
|
+
logger_1.default.info(`📊 OpenCode execution completed with success: ${result.success}`);
|
|
61
|
+
break;
|
|
62
|
+
case 'claude-code':
|
|
63
|
+
logger_1.default.info(`🤖 Starting Claude Code execution: ${task.command.substring(0, 50)}${task.command.length > 50 ? '...' : ''}`);
|
|
64
|
+
result = await cliTools_1.cliTools.executeClaudeCode(task.command);
|
|
65
|
+
logger_1.default.info(`📊 Claude Code execution completed with success: ${result.success}`);
|
|
66
|
+
break;
|
|
67
|
+
case 'shell':
|
|
68
|
+
logger_1.default.info(`🔧 Starting Shell execution: ${task.command}`);
|
|
69
|
+
result = await cliTools_1.cliTools.executeShell(task.command);
|
|
70
|
+
logger_1.default.info(`📊 Shell execution completed with success: ${result.success}`);
|
|
71
|
+
break;
|
|
72
|
+
case 'git':
|
|
73
|
+
logger_1.default.info(`🔧 Starting Git execution: ${task.command}`);
|
|
74
|
+
result = await cliTools_1.cliTools.executeGit(task.command);
|
|
75
|
+
logger_1.default.info(`📊 Git execution completed with success: ${result.success}`);
|
|
76
|
+
break;
|
|
77
|
+
default:
|
|
78
|
+
result = {
|
|
79
|
+
tool: task.tool,
|
|
80
|
+
success: false,
|
|
81
|
+
output: '',
|
|
82
|
+
error: `Unknown tool: ${task.tool}`,
|
|
83
|
+
duration: 0,
|
|
84
|
+
};
|
|
85
|
+
}
|
|
86
|
+
task.result = result;
|
|
87
|
+
task.status = result.success ? 'completed' : 'failed';
|
|
88
|
+
task.updatedAt = new Date();
|
|
89
|
+
if (result.success) {
|
|
90
|
+
logger_1.default.info(`✅ ${result.tool} completed in ${result.duration}ms`);
|
|
91
|
+
}
|
|
92
|
+
else {
|
|
93
|
+
logger_1.default.error(`❌ ${result.tool} failed in ${result.duration}ms: ${result.error}`);
|
|
94
|
+
}
|
|
95
|
+
return result;
|
|
96
|
+
}
|
|
97
|
+
getTask(taskId) {
|
|
98
|
+
return this.tasks.get(taskId);
|
|
99
|
+
}
|
|
100
|
+
getUserTasks(userId) {
|
|
101
|
+
const taskIds = this.userTasks.get(userId);
|
|
102
|
+
if (!taskIds) {
|
|
103
|
+
return [];
|
|
104
|
+
}
|
|
105
|
+
return Array.from(taskIds)
|
|
106
|
+
.map((id) => this.tasks.get(id))
|
|
107
|
+
.filter((task) => task !== undefined)
|
|
108
|
+
.sort((a, b) => b.createdAt.getTime() - a.createdAt.getTime());
|
|
109
|
+
}
|
|
110
|
+
cancelTask(taskId) {
|
|
111
|
+
const task = this.tasks.get(taskId);
|
|
112
|
+
if (!task) {
|
|
113
|
+
return false;
|
|
114
|
+
}
|
|
115
|
+
if (task.status === 'running') {
|
|
116
|
+
task.status = 'failed';
|
|
117
|
+
task.result = {
|
|
118
|
+
tool: task.tool,
|
|
119
|
+
success: false,
|
|
120
|
+
output: '',
|
|
121
|
+
error: 'Task was cancelled',
|
|
122
|
+
duration: Date.now() - task.createdAt.getTime(),
|
|
123
|
+
};
|
|
124
|
+
}
|
|
125
|
+
else {
|
|
126
|
+
task.status = 'failed';
|
|
127
|
+
}
|
|
128
|
+
task.updatedAt = new Date();
|
|
129
|
+
return true;
|
|
130
|
+
}
|
|
131
|
+
cleanup() {
|
|
132
|
+
const now = Date.now();
|
|
133
|
+
for (const [taskId, task] of this.tasks.entries()) {
|
|
134
|
+
if (now - task.updatedAt.getTime() > this.TASK_TIMEOUT) {
|
|
135
|
+
this.tasks.delete(taskId);
|
|
136
|
+
this.userTasks.get(task.userId)?.delete(taskId);
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
exports.TaskManagerSimple = TaskManagerSimple;
|
|
142
|
+
exports.taskManagerSimple = new TaskManagerSimple();
|
|
143
|
+
// Periodic cleanup every minute
|
|
144
|
+
setInterval(() => {
|
|
145
|
+
exports.taskManagerSimple.cleanup();
|
|
146
|
+
}, 60000);
|
|
147
|
+
//# sourceMappingURL=taskManagerSimple.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"taskManagerSimple.js","sourceRoot":"","sources":["../../src/services/taskManagerSimple.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"testHelloWorld.d.ts","sourceRoot":"","sources":["../src/testHelloWorld.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const helloWorld_1 = require("./helloWorld");
|
|
7
|
+
const helloWorld_2 = __importDefault(require("./helloWorld"));
|
|
8
|
+
console.log("=== 测试 helloWorld 函数 ===");
|
|
9
|
+
const basicHello = (0, helloWorld_1.helloWorld)();
|
|
10
|
+
console.log(`基本函数: ${basicHello}`);
|
|
11
|
+
const namedHello = (0, helloWorld_1.helloWorldWithName)("OpenCode");
|
|
12
|
+
console.log(`带参数函数: ${namedHello}`);
|
|
13
|
+
console.log("控制台输出函数:");
|
|
14
|
+
(0, helloWorld_1.helloWorldConsole)();
|
|
15
|
+
const defaultHello = (0, helloWorld_2.default)();
|
|
16
|
+
console.log(`默认导出函数: ${defaultHello}`);
|
|
17
|
+
console.log("=== 所有测试完成 ===");
|
|
18
|
+
//# sourceMappingURL=testHelloWorld.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"testHelloWorld.js","sourceRoot":"","sources":["../src/testHelloWorld.ts"],"names":[],"mappings":";;;;;AAAA,6CAAiF;AACjF,8DAA6C;AAE7C,OAAO,CAAC,GAAG,CAAC,0BAA0B,CAAC,CAAC;AAExC,MAAM,UAAU,GAAG,IAAA,uBAAU,GAAE,CAAC;AAChC,OAAO,CAAC,GAAG,CAAC,SAAS,UAAU,EAAE,CAAC,CAAC;AAEnC,MAAM,UAAU,GAAG,IAAA,+BAAkB,EAAC,UAAU,CAAC,CAAC;AAClD,OAAO,CAAC,GAAG,CAAC,UAAU,UAAU,EAAE,CAAC,CAAC;AAEpC,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;AACxB,IAAA,8BAAiB,GAAE,CAAC;AAEpB,MAAM,YAAY,GAAG,IAAA,oBAAiB,GAAE,CAAC;AACzC,OAAO,CAAC,GAAG,CAAC,WAAW,YAAY,EAAE,CAAC,CAAC;AAEvC,OAAO,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"encoding.d.ts","sourceRoot":"","sources":["../../src/utils/encoding.ts"],"names":[],"mappings":"AA2DA,2EAA2E;AAC3E,wBAAgB,gBAAgB,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,CASvD"}
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.decodeShellChunk = decodeShellChunk;
|
|
37
|
+
const iconv = __importStar(require("iconv-lite"));
|
|
38
|
+
const config_1 = require("../config/config");
|
|
39
|
+
/**
|
|
40
|
+
* Shell output decoding for globally distributed apps (GitHub, npm).
|
|
41
|
+
* Only used for shell commands (dir, git, etc.). Code tools (opencode, etc.) output UTF-8.
|
|
42
|
+
* Priority: config.execution.shellOutputEncoding (openbotgate.yml) then fallback from
|
|
43
|
+
* system env (LANG / LC_ALL / LC_CTYPE). Set shellOutputEncoding: gbk in config when needed.
|
|
44
|
+
*/
|
|
45
|
+
/** Locale encoding part (e.g. zh_CN.UTF-8 → utf8) → iconv encoding name. */
|
|
46
|
+
function getEncodingFromLocale() {
|
|
47
|
+
const raw = process.env.LANG || process.env.LC_ALL || process.env.LC_CTYPE;
|
|
48
|
+
if (!raw)
|
|
49
|
+
return null;
|
|
50
|
+
const part = raw.split('.').pop()?.toLowerCase().replace(/-/g, '');
|
|
51
|
+
if (!part)
|
|
52
|
+
return null;
|
|
53
|
+
const map = {
|
|
54
|
+
utf8: 'utf8',
|
|
55
|
+
utf8mb4: 'utf8',
|
|
56
|
+
ascii: 'utf8',
|
|
57
|
+
c: 'utf8',
|
|
58
|
+
posix: 'utf8',
|
|
59
|
+
gbk: 'gbk',
|
|
60
|
+
gb2312: 'gb2312',
|
|
61
|
+
gb18030: 'gb18030',
|
|
62
|
+
big5: 'big5',
|
|
63
|
+
shiftjis: 'shift_jis',
|
|
64
|
+
eucjp: 'euc-jp',
|
|
65
|
+
euckr: 'euc-kr',
|
|
66
|
+
iso88591: 'latin1',
|
|
67
|
+
latin1: 'latin1',
|
|
68
|
+
cp936: 'gbk',
|
|
69
|
+
cp932: 'shift_jis',
|
|
70
|
+
cp949: 'euc-kr',
|
|
71
|
+
cp950: 'big5',
|
|
72
|
+
cp1250: 'cp1250',
|
|
73
|
+
cp1251: 'cp1251',
|
|
74
|
+
cp1252: 'cp1252',
|
|
75
|
+
cp1253: 'cp1253',
|
|
76
|
+
cp1254: 'cp1254',
|
|
77
|
+
cp1255: 'cp1255',
|
|
78
|
+
cp1256: 'cp1256',
|
|
79
|
+
cp1257: 'cp1257',
|
|
80
|
+
cp1258: 'cp1258',
|
|
81
|
+
koi8r: 'koi8-r',
|
|
82
|
+
koi8u: 'koi8-u',
|
|
83
|
+
};
|
|
84
|
+
return map[part] ?? (part.startsWith('iso8859') ? `iso-8859-${part.slice(7)}` : null) ?? null;
|
|
85
|
+
}
|
|
86
|
+
/** Resolved encoding for shell output only: config (SHELL_OUTPUT_ENCODING) > LANG/LC_* > utf8. */
|
|
87
|
+
function getShellEncoding() {
|
|
88
|
+
const over = config_1.config.execution.shellOutputEncoding?.toLowerCase();
|
|
89
|
+
if (over && iconv.encodingExists(over))
|
|
90
|
+
return over;
|
|
91
|
+
const fromLocale = getEncodingFromLocale();
|
|
92
|
+
if (fromLocale)
|
|
93
|
+
return fromLocale;
|
|
94
|
+
return 'utf8';
|
|
95
|
+
}
|
|
96
|
+
/** Decode shell stdout/stderr using SHELL_OUTPUT_ENCODING or LANG/LC_*. */
|
|
97
|
+
function decodeShellChunk(buffer) {
|
|
98
|
+
const enc = getShellEncoding();
|
|
99
|
+
if (enc === 'utf8')
|
|
100
|
+
return buffer.toString('utf8');
|
|
101
|
+
if (!iconv.encodingExists(enc))
|
|
102
|
+
return buffer.toString('utf8');
|
|
103
|
+
try {
|
|
104
|
+
return iconv.decode(buffer, enc);
|
|
105
|
+
}
|
|
106
|
+
catch {
|
|
107
|
+
return buffer.toString('utf8');
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
//# sourceMappingURL=encoding.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"encoding.js","sourceRoot":"","sources":["../../src/utils/encoding.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA4DA,4CASC;AArED,kDAAoC;AACpC,6CAA0C;AAE1C;;;;;GAKG;AAEH,4EAA4E;AAC5E,SAAS,qBAAqB;IAC5B,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC,IAAI,IAAI,OAAO,CAAC,GAAG,CAAC,MAAM,IAAI,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC;IAC3E,IAAI,CAAC,GAAG;QAAE,OAAO,IAAI,CAAC;IACtB,MAAM,IAAI,GAAG,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,WAAW,EAAE,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;IACnE,IAAI,CAAC,IAAI;QAAE,OAAO,IAAI,CAAC;IACvB,MAAM,GAAG,GAA2B;QAClC,IAAI,EAAE,MAAM;QACZ,OAAO,EAAE,MAAM;QACf,KAAK,EAAE,MAAM;QACb,CAAC,EAAE,MAAM;QACT,KAAK,EAAE,MAAM;QACb,GAAG,EAAE,KAAK;QACV,MAAM,EAAE,QAAQ;QAChB,OAAO,EAAE,SAAS;QAClB,IAAI,EAAE,MAAM;QACZ,QAAQ,EAAE,WAAW;QACrB,KAAK,EAAE,QAAQ;QACf,KAAK,EAAE,QAAQ;QACf,QAAQ,EAAE,QAAQ;QAClB,MAAM,EAAE,QAAQ;QAChB,KAAK,EAAE,KAAK;QACZ,KAAK,EAAE,WAAW;QAClB,KAAK,EAAE,QAAQ;QACf,KAAK,EAAE,MAAM;QACb,MAAM,EAAE,QAAQ;QAChB,MAAM,EAAE,QAAQ;QAChB,MAAM,EAAE,QAAQ;QAChB,MAAM,EAAE,QAAQ;QAChB,MAAM,EAAE,QAAQ;QAChB,MAAM,EAAE,QAAQ;QAChB,MAAM,EAAE,QAAQ;QAChB,MAAM,EAAE,QAAQ;QAChB,MAAM,EAAE,QAAQ;QAChB,KAAK,EAAE,QAAQ;QACf,KAAK,EAAE,QAAQ;KAChB,CAAC;IACF,OAAO,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,YAAY,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC;AAChG,CAAC;AAED,kGAAkG;AAClG,SAAS,gBAAgB;IACvB,MAAM,IAAI,GAAG,eAAM,CAAC,SAAS,CAAC,mBAAmB,EAAE,WAAW,EAAE,CAAC;IACjE,IAAI,IAAI,IAAI,KAAK,CAAC,cAAc,CAAC,IAAI,CAAC;QAAE,OAAO,IAAI,CAAC;IACpD,MAAM,UAAU,GAAG,qBAAqB,EAAE,CAAC;IAC3C,IAAI,UAAU;QAAE,OAAO,UAAU,CAAC;IAClC,OAAO,MAAM,CAAC;AAChB,CAAC;AAED,2EAA2E;AAC3E,SAAgB,gBAAgB,CAAC,MAAc;IAC7C,MAAM,GAAG,GAAG,gBAAgB,EAAE,CAAC;IAC/B,IAAI,GAAG,KAAK,MAAM;QAAE,OAAO,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;IACnD,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,GAAG,CAAC;QAAE,OAAO,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;IAC/D,IAAI,CAAC;QACH,OAAO,KAAK,CAAC,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IACnC,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;IACjC,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
declare const logger: {
|
|
2
|
+
info: (message: string, ...args: unknown[]) => void;
|
|
3
|
+
warn: (message: string, ...args: unknown[]) => void;
|
|
4
|
+
error: (message: string, ...args: unknown[]) => void;
|
|
5
|
+
debug: (message: string, ...args: unknown[]) => void;
|
|
6
|
+
/** 原样追加到当日日志文件,无时间戳/级别,与控制台 print 一致。用于 code 工具输出。 */
|
|
7
|
+
writeRawToFile: (content: string) => void;
|
|
8
|
+
};
|
|
9
|
+
export default logger;
|
|
10
|
+
/**
|
|
11
|
+
* Format duration to human-readable string
|
|
12
|
+
* Examples: 10ms, 1.3s, 2m, 1.1h, 1.2d
|
|
13
|
+
*/
|
|
14
|
+
export declare function formatDuration(ms: number): string;
|
|
15
|
+
/**
|
|
16
|
+
* Truncate output for logging (first few lines)
|
|
17
|
+
*/
|
|
18
|
+
export declare function truncateOutput(output: string, maxLines?: number, maxChars?: number): string;
|
|
19
|
+
//# sourceMappingURL=logger.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../src/utils/logger.ts"],"names":[],"mappings":"AAmFA,QAAA,MAAM,MAAM;oBACM,MAAM,WAAW,OAAO,EAAE;oBAK1B,MAAM,WAAW,OAAO,EAAE;qBAKzB,MAAM,WAAW,OAAO,EAAE;qBAK1B,MAAM,WAAW,OAAO,EAAE;IAK3C,sDAAsD;8BAC5B,MAAM;CAKjC,CAAC;AAYF,eAAe,MAAM,CAAC;AAiBtB;;;GAGG;AACH,wBAAgB,cAAc,CAAC,EAAE,EAAE,MAAM,GAAG,MAAM,CAMjD;AAED;;GAEG;AACH,wBAAgB,cAAc,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,SAAI,EAAE,QAAQ,SAAM,GAAG,MAAM,CAanF"}
|
|
@@ -0,0 +1,192 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
36
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
37
|
+
};
|
|
38
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
|
+
exports.formatDuration = formatDuration;
|
|
40
|
+
exports.truncateOutput = truncateOutput;
|
|
41
|
+
const winston_1 = __importDefault(require("winston"));
|
|
42
|
+
const winston_daily_rotate_file_1 = __importDefault(require("winston-daily-rotate-file"));
|
|
43
|
+
const fs = __importStar(require("fs"));
|
|
44
|
+
const path = __importStar(require("path"));
|
|
45
|
+
const config_1 = require("../config/config");
|
|
46
|
+
const logDir = path.isAbsolute(config_1.config.log.dir)
|
|
47
|
+
? config_1.config.log.dir
|
|
48
|
+
: path.join(process.cwd(), config_1.config.log.dir);
|
|
49
|
+
if (!fs.existsSync(logDir)) {
|
|
50
|
+
fs.mkdirSync(logDir, { recursive: true });
|
|
51
|
+
}
|
|
52
|
+
/**
|
|
53
|
+
* Get caller location from stack trace with relative path
|
|
54
|
+
* @param skipFrames - Number of stack frames to skip (default 3)
|
|
55
|
+
*/
|
|
56
|
+
function getCallerLocation(skipFrames = 3) {
|
|
57
|
+
const stack = new Error().stack || '';
|
|
58
|
+
const lines = stack.split('\n');
|
|
59
|
+
for (let i = skipFrames; i < lines.length; i++) {
|
|
60
|
+
const line = lines[i];
|
|
61
|
+
if (line.includes('node_modules'))
|
|
62
|
+
continue;
|
|
63
|
+
if (line.includes('logger.ts') || line.includes('logger.js'))
|
|
64
|
+
continue;
|
|
65
|
+
// Extract path with src/ or dist/ prefix and line number
|
|
66
|
+
// Matches: src/handler/index.ts:16 or dist/handler/index.js:16
|
|
67
|
+
const match = line.match(/[/\\](src|dist)[/\\](.+?\.[tj]s):(\d+):\d+/);
|
|
68
|
+
if (match) {
|
|
69
|
+
const dir = match[1] === 'dist' ? 'src' : match[1]; // Always show as src/
|
|
70
|
+
const filePath = match[2]
|
|
71
|
+
.replace(/\\/g, '/') // Normalize path separators
|
|
72
|
+
.replace(/\.js$/, '.ts'); // Show .ts instead of .js
|
|
73
|
+
return `${dir}/${filePath}:${match[3]}`;
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
return '';
|
|
77
|
+
}
|
|
78
|
+
/**
|
|
79
|
+
* Format time as HH:mm:ss
|
|
80
|
+
*/
|
|
81
|
+
function formatTime() {
|
|
82
|
+
return new Date().toTimeString().slice(0, 8);
|
|
83
|
+
}
|
|
84
|
+
const winstonLogger = winston_1.default.createLogger({
|
|
85
|
+
level: config_1.config.log.level,
|
|
86
|
+
format: winston_1.default.format.combine(winston_1.default.format.timestamp({ format: 'YYYY-MM-DD HH:mm:ss' }), winston_1.default.format.errors({ stack: true }), winston_1.default.format.splat(), winston_1.default.format.printf(({ timestamp, level, message }) => {
|
|
87
|
+
return `${timestamp} [${level.toUpperCase()}] ${message}`;
|
|
88
|
+
})),
|
|
89
|
+
transports: [
|
|
90
|
+
new winston_1.default.transports.Console({
|
|
91
|
+
format: winston_1.default.format.combine(winston_1.default.format.colorize(), winston_1.default.format.printf(({ level, message }) => {
|
|
92
|
+
return `${formatTime()} [${level}] ${message}`;
|
|
93
|
+
}))
|
|
94
|
+
}),
|
|
95
|
+
new winston_daily_rotate_file_1.default({
|
|
96
|
+
filename: path.join(logDir, 'openbotgate-%DATE%.log'),
|
|
97
|
+
datePattern: 'YYYY-MM-DD',
|
|
98
|
+
zippedArchive: true,
|
|
99
|
+
maxSize: config_1.config.log.maxSize,
|
|
100
|
+
maxFiles: config_1.config.log.maxFiles,
|
|
101
|
+
}),
|
|
102
|
+
],
|
|
103
|
+
});
|
|
104
|
+
/** 当前日期对应的日志文件名,与 DailyRotateFile 的 %DATE% 一致 */
|
|
105
|
+
function getCurrentLogPath() {
|
|
106
|
+
const date = new Date().toISOString().slice(0, 10); // YYYY-MM-DD
|
|
107
|
+
return path.join(logDir, `openbotgate-${date}.log`);
|
|
108
|
+
}
|
|
109
|
+
// Custom logger wrapper that captures caller location at call time
|
|
110
|
+
const logger = {
|
|
111
|
+
info: (message, ...args) => {
|
|
112
|
+
const loc = getCallerLocation();
|
|
113
|
+
const suffix = loc ? ` (${loc})` : '';
|
|
114
|
+
winstonLogger.info(`${message}${suffix}`, ...args);
|
|
115
|
+
},
|
|
116
|
+
warn: (message, ...args) => {
|
|
117
|
+
const loc = getCallerLocation();
|
|
118
|
+
const suffix = loc ? ` (${loc})` : '';
|
|
119
|
+
winstonLogger.warn(`${message}${suffix}`, ...args);
|
|
120
|
+
},
|
|
121
|
+
error: (message, ...args) => {
|
|
122
|
+
const loc = getCallerLocation();
|
|
123
|
+
const suffix = loc ? ` (${loc})` : '';
|
|
124
|
+
winstonLogger.error(`${message}${suffix}`, ...args);
|
|
125
|
+
},
|
|
126
|
+
debug: (message, ...args) => {
|
|
127
|
+
const loc = getCallerLocation();
|
|
128
|
+
const suffix = loc ? ` (${loc})` : '';
|
|
129
|
+
winstonLogger.debug(`${message}${suffix}`, ...args);
|
|
130
|
+
},
|
|
131
|
+
/** 原样追加到当日日志文件,无时间戳/级别,与控制台 print 一致。用于 code 工具输出。 */
|
|
132
|
+
writeRawToFile: (content) => {
|
|
133
|
+
try {
|
|
134
|
+
fs.appendFileSync(getCurrentLogPath(), content + '\n', 'utf8');
|
|
135
|
+
}
|
|
136
|
+
catch (_) { }
|
|
137
|
+
},
|
|
138
|
+
};
|
|
139
|
+
// Handle unhandled errors
|
|
140
|
+
process.on('unhandledRejection', (reason, promise) => {
|
|
141
|
+
logger.error('Unhandled Rejection at:', promise, 'reason:', reason);
|
|
142
|
+
});
|
|
143
|
+
process.on('uncaughtException', (error) => {
|
|
144
|
+
logger.error('Uncaught Exception:', error);
|
|
145
|
+
process.exit(1);
|
|
146
|
+
});
|
|
147
|
+
exports.default = logger;
|
|
148
|
+
// Redirect console.* to logger for unified format (catches SDK internal logs)
|
|
149
|
+
const originalConsole = {
|
|
150
|
+
log: console.log,
|
|
151
|
+
info: console.info,
|
|
152
|
+
warn: console.warn,
|
|
153
|
+
error: console.error,
|
|
154
|
+
debug: console.debug,
|
|
155
|
+
};
|
|
156
|
+
console.log = (...args) => { logger.info(`[console] ${args.map(a => typeof a === 'object' ? JSON.stringify(a) : a).join(' ')}`); };
|
|
157
|
+
console.info = (...args) => { logger.info(`[console] ${args.map(a => typeof a === 'object' ? JSON.stringify(a) : a).join(' ')}`); };
|
|
158
|
+
console.warn = (...args) => { logger.warn(`[console] ${args.map(a => typeof a === 'object' ? JSON.stringify(a) : a).join(' ')}`); };
|
|
159
|
+
console.error = (...args) => { logger.error(`[console] ${args.map(a => typeof a === 'object' ? JSON.stringify(a) : a).join(' ')}`); };
|
|
160
|
+
console.debug = (...args) => { logger.debug(`[console] ${args.map(a => typeof a === 'object' ? JSON.stringify(a) : a).join(' ')}`); };
|
|
161
|
+
/**
|
|
162
|
+
* Format duration to human-readable string
|
|
163
|
+
* Examples: 10ms, 1.3s, 2m, 1.1h, 1.2d
|
|
164
|
+
*/
|
|
165
|
+
function formatDuration(ms) {
|
|
166
|
+
if (ms < 1000)
|
|
167
|
+
return `${ms}ms`;
|
|
168
|
+
if (ms < 60000)
|
|
169
|
+
return `${(ms / 1000).toFixed(1)}s`;
|
|
170
|
+
if (ms < 3600000)
|
|
171
|
+
return `${(ms / 60000).toFixed(1)}m`;
|
|
172
|
+
if (ms < 86400000)
|
|
173
|
+
return `${(ms / 3600000).toFixed(1)}h`;
|
|
174
|
+
return `${(ms / 86400000).toFixed(1)}d`;
|
|
175
|
+
}
|
|
176
|
+
/**
|
|
177
|
+
* Truncate output for logging (first few lines)
|
|
178
|
+
*/
|
|
179
|
+
function truncateOutput(output, maxLines = 5, maxChars = 500) {
|
|
180
|
+
if (!output)
|
|
181
|
+
return '(empty)';
|
|
182
|
+
const lines = output.split('\n');
|
|
183
|
+
let result = lines.slice(0, maxLines).join('\n');
|
|
184
|
+
if (result.length > maxChars) {
|
|
185
|
+
result = result.substring(0, maxChars) + '...';
|
|
186
|
+
}
|
|
187
|
+
else if (lines.length > maxLines) {
|
|
188
|
+
result += `\n... (${lines.length - maxLines} more lines)`;
|
|
189
|
+
}
|
|
190
|
+
return result;
|
|
191
|
+
}
|
|
192
|
+
//# sourceMappingURL=logger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/utils/logger.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/** On Windows without LANG, read console code page once (chcp) and cache. Does not change system encoding. */
|
|
2
|
+
export declare function ensureShellEncoding(): Promise<void>;
|
|
3
|
+
/** Decode shell output using system encoding (locale or Windows console); no system encoding is modified. */
|
|
4
|
+
export declare function decodeShellChunk(buffer: Buffer): string;
|
|
5
|
+
//# sourceMappingURL=shellEncoding.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shellEncoding.d.ts","sourceRoot":"","sources":["../../src/utils/shellEncoding.ts"],"names":[],"mappings":"AAyCA,8GAA8G;AAC9G,wBAAgB,mBAAmB,IAAI,OAAO,CAAC,IAAI,CAAC,CAoBnD;AAUD,6GAA6G;AAC7G,wBAAgB,gBAAgB,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,CAKvD"}
|