@jsayubi/ccgram 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/.env.example +19 -0
- package/LICENSE +21 -0
- package/README.md +338 -0
- package/ccgram.service +24 -0
- package/config/channels.json +58 -0
- package/config/default.json +27 -0
- package/config/defaults/config.json +16 -0
- package/config/defaults/i18n.json +32 -0
- package/config/email-template.json +31 -0
- package/config/test-with-subagent.json +16 -0
- package/config/user.json +27 -0
- package/dist/claude-hook-notify.d.ts +7 -0
- package/dist/claude-hook-notify.d.ts.map +1 -0
- package/dist/claude-hook-notify.js +154 -0
- package/dist/claude-hook-notify.js.map +1 -0
- package/dist/claude-remote.d.ts +50 -0
- package/dist/claude-remote.d.ts.map +1 -0
- package/dist/claude-remote.js +927 -0
- package/dist/claude-remote.js.map +1 -0
- package/dist/cli.d.ts +3 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +110 -0
- package/dist/cli.js.map +1 -0
- package/dist/enhanced-hook-notify.d.ts +16 -0
- package/dist/enhanced-hook-notify.d.ts.map +1 -0
- package/dist/enhanced-hook-notify.js +288 -0
- package/dist/enhanced-hook-notify.js.map +1 -0
- package/dist/permission-hook.d.ts +15 -0
- package/dist/permission-hook.d.ts.map +1 -0
- package/dist/permission-hook.js +357 -0
- package/dist/permission-hook.js.map +1 -0
- package/dist/prompt-bridge.d.ts +50 -0
- package/dist/prompt-bridge.d.ts.map +1 -0
- package/dist/prompt-bridge.js +173 -0
- package/dist/prompt-bridge.js.map +1 -0
- package/dist/question-notify.d.ts +16 -0
- package/dist/question-notify.d.ts.map +1 -0
- package/dist/question-notify.js +272 -0
- package/dist/question-notify.js.map +1 -0
- package/dist/setup.d.ts +10 -0
- package/dist/setup.d.ts.map +1 -0
- package/dist/setup.js +649 -0
- package/dist/setup.js.map +1 -0
- package/dist/smart-monitor.d.ts +7 -0
- package/dist/smart-monitor.d.ts.map +1 -0
- package/dist/smart-monitor.js +256 -0
- package/dist/smart-monitor.js.map +1 -0
- package/dist/src/automation/claude-automation.d.ts +45 -0
- package/dist/src/automation/claude-automation.d.ts.map +1 -0
- package/dist/src/automation/claude-automation.js +367 -0
- package/dist/src/automation/claude-automation.js.map +1 -0
- package/dist/src/automation/clipboard-automation.d.ts +35 -0
- package/dist/src/automation/clipboard-automation.d.ts.map +1 -0
- package/dist/src/automation/clipboard-automation.js +242 -0
- package/dist/src/automation/clipboard-automation.js.map +1 -0
- package/dist/src/automation/simple-automation.d.ts +56 -0
- package/dist/src/automation/simple-automation.d.ts.map +1 -0
- package/dist/src/automation/simple-automation.js +283 -0
- package/dist/src/automation/simple-automation.js.map +1 -0
- package/dist/src/channels/base/channel.d.ts +60 -0
- package/dist/src/channels/base/channel.d.ts.map +1 -0
- package/dist/src/channels/base/channel.js +96 -0
- package/dist/src/channels/base/channel.js.map +1 -0
- package/dist/src/channels/email/smtp.d.ts +74 -0
- package/dist/src/channels/email/smtp.d.ts.map +1 -0
- package/dist/src/channels/email/smtp.js +605 -0
- package/dist/src/channels/email/smtp.js.map +1 -0
- package/dist/src/channels/line/line.d.ts +36 -0
- package/dist/src/channels/line/line.d.ts.map +1 -0
- package/dist/src/channels/line/line.js +180 -0
- package/dist/src/channels/line/line.js.map +1 -0
- package/dist/src/channels/line/webhook.d.ts +55 -0
- package/dist/src/channels/line/webhook.d.ts.map +1 -0
- package/dist/src/channels/line/webhook.js +191 -0
- package/dist/src/channels/line/webhook.js.map +1 -0
- package/dist/src/channels/local/desktop.d.ts +30 -0
- package/dist/src/channels/local/desktop.d.ts.map +1 -0
- package/dist/src/channels/local/desktop.js +161 -0
- package/dist/src/channels/local/desktop.js.map +1 -0
- package/dist/src/channels/telegram/telegram.d.ts +43 -0
- package/dist/src/channels/telegram/telegram.d.ts.map +1 -0
- package/dist/src/channels/telegram/telegram.js +223 -0
- package/dist/src/channels/telegram/telegram.js.map +1 -0
- package/dist/src/channels/telegram/webhook.d.ts +75 -0
- package/dist/src/channels/telegram/webhook.d.ts.map +1 -0
- package/dist/src/channels/telegram/webhook.js +278 -0
- package/dist/src/channels/telegram/webhook.js.map +1 -0
- package/dist/src/config-manager.d.ts +16 -0
- package/dist/src/config-manager.d.ts.map +1 -0
- package/dist/src/config-manager.js +152 -0
- package/dist/src/config-manager.js.map +1 -0
- package/dist/src/core/config.d.ts +28 -0
- package/dist/src/core/config.d.ts.map +1 -0
- package/dist/src/core/config.js +248 -0
- package/dist/src/core/config.js.map +1 -0
- package/dist/src/core/logger.d.ts +19 -0
- package/dist/src/core/logger.d.ts.map +1 -0
- package/dist/src/core/logger.js +47 -0
- package/dist/src/core/logger.js.map +1 -0
- package/dist/src/core/notifier.d.ts +45 -0
- package/dist/src/core/notifier.d.ts.map +1 -0
- package/dist/src/core/notifier.js +189 -0
- package/dist/src/core/notifier.js.map +1 -0
- package/dist/src/daemon/taskping-daemon.d.ts +38 -0
- package/dist/src/daemon/taskping-daemon.d.ts.map +1 -0
- package/dist/src/daemon/taskping-daemon.js +306 -0
- package/dist/src/daemon/taskping-daemon.js.map +1 -0
- package/dist/src/relay/claude-command-bridge.d.ts +57 -0
- package/dist/src/relay/claude-command-bridge.d.ts.map +1 -0
- package/dist/src/relay/claude-command-bridge.js +188 -0
- package/dist/src/relay/claude-command-bridge.js.map +1 -0
- package/dist/src/relay/command-relay.d.ts +94 -0
- package/dist/src/relay/command-relay.d.ts.map +1 -0
- package/dist/src/relay/command-relay.js +463 -0
- package/dist/src/relay/command-relay.js.map +1 -0
- package/dist/src/relay/email-listener.d.ts +65 -0
- package/dist/src/relay/email-listener.d.ts.map +1 -0
- package/dist/src/relay/email-listener.js +460 -0
- package/dist/src/relay/email-listener.js.map +1 -0
- package/dist/src/relay/relay-pty.d.ts +21 -0
- package/dist/src/relay/relay-pty.d.ts.map +1 -0
- package/dist/src/relay/relay-pty.js +696 -0
- package/dist/src/relay/relay-pty.js.map +1 -0
- package/dist/src/relay/smart-injector.d.ts +30 -0
- package/dist/src/relay/smart-injector.d.ts.map +1 -0
- package/dist/src/relay/smart-injector.js +233 -0
- package/dist/src/relay/smart-injector.js.map +1 -0
- package/dist/src/relay/tmux-injector.d.ts +46 -0
- package/dist/src/relay/tmux-injector.d.ts.map +1 -0
- package/dist/src/relay/tmux-injector.js +413 -0
- package/dist/src/relay/tmux-injector.js.map +1 -0
- package/dist/src/tools/config-manager.d.ts +33 -0
- package/dist/src/tools/config-manager.d.ts.map +1 -0
- package/dist/src/tools/config-manager.js +448 -0
- package/dist/src/tools/config-manager.js.map +1 -0
- package/dist/src/tools/installer.d.ts +38 -0
- package/dist/src/tools/installer.d.ts.map +1 -0
- package/dist/src/tools/installer.js +222 -0
- package/dist/src/tools/installer.js.map +1 -0
- package/dist/src/types/callbacks.d.ts +29 -0
- package/dist/src/types/callbacks.d.ts.map +1 -0
- package/dist/src/types/callbacks.js +7 -0
- package/dist/src/types/callbacks.js.map +1 -0
- package/dist/src/types/config.d.ts +56 -0
- package/dist/src/types/config.d.ts.map +1 -0
- package/dist/src/types/config.js +6 -0
- package/dist/src/types/config.js.map +1 -0
- package/dist/src/types/hooks.d.ts +47 -0
- package/dist/src/types/hooks.d.ts.map +1 -0
- package/dist/src/types/hooks.js +6 -0
- package/dist/src/types/hooks.js.map +1 -0
- package/dist/src/types/index.d.ts +7 -0
- package/dist/src/types/index.d.ts.map +1 -0
- package/dist/src/types/index.js +23 -0
- package/dist/src/types/index.js.map +1 -0
- package/dist/src/types/ipc.d.ts +43 -0
- package/dist/src/types/ipc.d.ts.map +1 -0
- package/dist/src/types/ipc.js +7 -0
- package/dist/src/types/ipc.js.map +1 -0
- package/dist/src/types/session.d.ts +70 -0
- package/dist/src/types/session.d.ts.map +1 -0
- package/dist/src/types/session.js +9 -0
- package/dist/src/types/session.js.map +1 -0
- package/dist/src/types/telegram.d.ts +58 -0
- package/dist/src/types/telegram.d.ts.map +1 -0
- package/dist/src/types/telegram.js +6 -0
- package/dist/src/types/telegram.js.map +1 -0
- package/dist/src/utils/active-check.d.ts +19 -0
- package/dist/src/utils/active-check.d.ts.map +1 -0
- package/dist/src/utils/active-check.js +41 -0
- package/dist/src/utils/active-check.js.map +1 -0
- package/dist/src/utils/callback-parser.d.ts +21 -0
- package/dist/src/utils/callback-parser.d.ts.map +1 -0
- package/dist/src/utils/callback-parser.js +58 -0
- package/dist/src/utils/callback-parser.js.map +1 -0
- package/dist/src/utils/controller-injector.d.ts +21 -0
- package/dist/src/utils/controller-injector.d.ts.map +1 -0
- package/dist/src/utils/controller-injector.js +108 -0
- package/dist/src/utils/controller-injector.js.map +1 -0
- package/dist/src/utils/conversation-tracker.d.ts +32 -0
- package/dist/src/utils/conversation-tracker.d.ts.map +1 -0
- package/dist/src/utils/conversation-tracker.js +119 -0
- package/dist/src/utils/conversation-tracker.js.map +1 -0
- package/dist/src/utils/http-request.d.ts +25 -0
- package/dist/src/utils/http-request.d.ts.map +1 -0
- package/dist/src/utils/http-request.js +66 -0
- package/dist/src/utils/http-request.js.map +1 -0
- package/dist/src/utils/optional-require.d.ts +13 -0
- package/dist/src/utils/optional-require.d.ts.map +1 -0
- package/dist/src/utils/optional-require.js +37 -0
- package/dist/src/utils/optional-require.js.map +1 -0
- package/dist/src/utils/paths.d.ts +11 -0
- package/dist/src/utils/paths.d.ts.map +1 -0
- package/dist/src/utils/paths.js +28 -0
- package/dist/src/utils/paths.js.map +1 -0
- package/dist/src/utils/pty-session-manager.d.ts +42 -0
- package/dist/src/utils/pty-session-manager.d.ts.map +1 -0
- package/dist/src/utils/pty-session-manager.js +182 -0
- package/dist/src/utils/pty-session-manager.js.map +1 -0
- package/dist/src/utils/subagent-tracker.d.ts +64 -0
- package/dist/src/utils/subagent-tracker.d.ts.map +1 -0
- package/dist/src/utils/subagent-tracker.js +191 -0
- package/dist/src/utils/subagent-tracker.js.map +1 -0
- package/dist/src/utils/tmux-monitor.d.ts +102 -0
- package/dist/src/utils/tmux-monitor.d.ts.map +1 -0
- package/dist/src/utils/tmux-monitor.js +642 -0
- package/dist/src/utils/tmux-monitor.js.map +1 -0
- package/dist/src/utils/trace-capture.d.ts +42 -0
- package/dist/src/utils/trace-capture.d.ts.map +1 -0
- package/dist/src/utils/trace-capture.js +102 -0
- package/dist/src/utils/trace-capture.js.map +1 -0
- package/dist/start-all-webhooks.d.ts +7 -0
- package/dist/start-all-webhooks.d.ts.map +1 -0
- package/dist/start-all-webhooks.js +98 -0
- package/dist/start-all-webhooks.js.map +1 -0
- package/dist/start-line-webhook.d.ts +7 -0
- package/dist/start-line-webhook.d.ts.map +1 -0
- package/dist/start-line-webhook.js +59 -0
- package/dist/start-line-webhook.js.map +1 -0
- package/dist/start-relay-pty.d.ts +7 -0
- package/dist/start-relay-pty.d.ts.map +1 -0
- package/dist/start-relay-pty.js +173 -0
- package/dist/start-relay-pty.js.map +1 -0
- package/dist/start-telegram-webhook.d.ts +7 -0
- package/dist/start-telegram-webhook.d.ts.map +1 -0
- package/dist/start-telegram-webhook.js +80 -0
- package/dist/start-telegram-webhook.js.map +1 -0
- package/dist/user-prompt-hook.d.ts +13 -0
- package/dist/user-prompt-hook.d.ts.map +1 -0
- package/dist/user-prompt-hook.js +45 -0
- package/dist/user-prompt-hook.js.map +1 -0
- package/dist/workspace-router.d.ts +78 -0
- package/dist/workspace-router.d.ts.map +1 -0
- package/dist/workspace-router.js +408 -0
- package/dist/workspace-router.js.map +1 -0
- package/dist/workspace-telegram-bot.d.ts +3 -0
- package/dist/workspace-telegram-bot.d.ts.map +1 -0
- package/dist/workspace-telegram-bot.js +1172 -0
- package/dist/workspace-telegram-bot.js.map +1 -0
- package/package.json +80 -0
- package/src/types/callbacks.ts +39 -0
- package/src/types/config.ts +63 -0
- package/src/types/hooks.ts +50 -0
- package/src/types/index.ts +6 -0
- package/src/types/ipc.ts +55 -0
- package/src/types/session.ts +72 -0
- package/src/types/telegram.ts +66 -0
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Command Relay Service
|
|
3
|
+
* Manages email listening and command execution for Claude Code
|
|
4
|
+
*/
|
|
5
|
+
import EventEmitter from 'events';
|
|
6
|
+
import EmailListener from './email-listener';
|
|
7
|
+
import ClaudeCommandBridge from './claude-command-bridge';
|
|
8
|
+
import Logger from '../core/logger';
|
|
9
|
+
interface RelayConfig {
|
|
10
|
+
imap?: {
|
|
11
|
+
auth: {
|
|
12
|
+
user: string;
|
|
13
|
+
pass: string;
|
|
14
|
+
};
|
|
15
|
+
host: string;
|
|
16
|
+
port: number;
|
|
17
|
+
secure: boolean;
|
|
18
|
+
};
|
|
19
|
+
sentMessagesPath?: string;
|
|
20
|
+
template?: {
|
|
21
|
+
checkInterval?: number;
|
|
22
|
+
};
|
|
23
|
+
[key: string]: unknown;
|
|
24
|
+
}
|
|
25
|
+
interface CommandData {
|
|
26
|
+
sessionId: string;
|
|
27
|
+
command: string;
|
|
28
|
+
[key: string]: unknown;
|
|
29
|
+
}
|
|
30
|
+
interface QueueItem extends CommandData {
|
|
31
|
+
id: string;
|
|
32
|
+
queuedAt: string;
|
|
33
|
+
status: string;
|
|
34
|
+
retries: number;
|
|
35
|
+
maxRetries: number;
|
|
36
|
+
executedAt?: string;
|
|
37
|
+
completedAt?: string;
|
|
38
|
+
failedAt?: string;
|
|
39
|
+
error?: string;
|
|
40
|
+
retryAt?: string;
|
|
41
|
+
}
|
|
42
|
+
interface ClaudeProcess {
|
|
43
|
+
pid: number | null;
|
|
44
|
+
command?: string;
|
|
45
|
+
available?: boolean;
|
|
46
|
+
}
|
|
47
|
+
interface RelayStatus {
|
|
48
|
+
isRunning: boolean;
|
|
49
|
+
queueLength: number;
|
|
50
|
+
processing: boolean;
|
|
51
|
+
emailListener: {
|
|
52
|
+
connected: boolean;
|
|
53
|
+
listening: boolean;
|
|
54
|
+
} | null;
|
|
55
|
+
recentCommands: Array<{
|
|
56
|
+
id: string;
|
|
57
|
+
status: string;
|
|
58
|
+
queuedAt: string;
|
|
59
|
+
command: string;
|
|
60
|
+
}>;
|
|
61
|
+
}
|
|
62
|
+
declare class CommandRelayService extends EventEmitter {
|
|
63
|
+
logger: Logger;
|
|
64
|
+
config: RelayConfig;
|
|
65
|
+
emailListener: EmailListener | null;
|
|
66
|
+
commandBridge: ClaudeCommandBridge;
|
|
67
|
+
clipboardAutomation: any;
|
|
68
|
+
simpleAutomation: any;
|
|
69
|
+
claudeAutomation: any;
|
|
70
|
+
isRunning: boolean;
|
|
71
|
+
commandQueue: QueueItem[];
|
|
72
|
+
processingQueue: boolean;
|
|
73
|
+
stateFile: string;
|
|
74
|
+
constructor(config: RelayConfig);
|
|
75
|
+
_ensureDirectories(): void;
|
|
76
|
+
_loadState(): void;
|
|
77
|
+
_saveState(): void;
|
|
78
|
+
start(): Promise<void>;
|
|
79
|
+
stop(): Promise<void>;
|
|
80
|
+
_queueCommand(commandData: CommandData): void;
|
|
81
|
+
_startCommandProcessor(): void;
|
|
82
|
+
_processCommandQueue(): Promise<void>;
|
|
83
|
+
_executeCommand(commandItem: QueueItem): Promise<void>;
|
|
84
|
+
_findClaudeCodeProcess(): Promise<ClaudeProcess>;
|
|
85
|
+
_sendCommandToClaudeCode(command: string, claudeProcess: ClaudeProcess, sessionId: string): Promise<boolean>;
|
|
86
|
+
_sendCommandViaMacOS(command: string): Promise<boolean>;
|
|
87
|
+
_sendCommandViaNotification(command: string): Promise<boolean>;
|
|
88
|
+
_handleCommandError(commandItem: QueueItem, error: Error): void;
|
|
89
|
+
_generateId(): string;
|
|
90
|
+
getStatus(): RelayStatus;
|
|
91
|
+
cleanupCompletedCommands(): void;
|
|
92
|
+
}
|
|
93
|
+
export = CommandRelayService;
|
|
94
|
+
//# sourceMappingURL=command-relay.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"command-relay.d.ts","sourceRoot":"","sources":["../../../src/relay/command-relay.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,YAAY,MAAM,QAAQ,CAAC;AAClC,OAAO,aAAa,MAAM,kBAAkB,CAAC;AAC7C,OAAO,mBAAmB,MAAM,yBAAyB,CAAC;AAC1D,OAAO,MAAM,MAAM,gBAAgB,CAAC;AAUpC,UAAU,WAAW;IACjB,IAAI,CAAC,EAAE;QACH,IAAI,EAAE;YAAE,IAAI,EAAE,MAAM,CAAC;YAAC,IAAI,EAAE,MAAM,CAAA;SAAE,CAAC;QACrC,IAAI,EAAE,MAAM,CAAC;QACb,IAAI,EAAE,MAAM,CAAC;QACb,MAAM,EAAE,OAAO,CAAC;KACnB,CAAC;IACF,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,QAAQ,CAAC,EAAE;QAAE,aAAa,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC;IACtC,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CAC1B;AAED,UAAU,WAAW;IACjB,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;IAChB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CAC1B;AAED,UAAU,SAAU,SAAQ,WAAW;IACnC,EAAE,EAAE,MAAM,CAAC;IACX,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,MAAM,CAAC;IAChB,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,OAAO,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,UAAU,aAAa;IACnB,GAAG,EAAE,MAAM,GAAG,IAAI,CAAC;IACnB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,SAAS,CAAC,EAAE,OAAO,CAAC;CACvB;AAOD,UAAU,WAAW;IACjB,SAAS,EAAE,OAAO,CAAC;IACnB,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,EAAE,OAAO,CAAC;IACpB,aAAa,EAAE;QAAE,SAAS,EAAE,OAAO,CAAC;QAAC,SAAS,EAAE,OAAO,CAAA;KAAE,GAAG,IAAI,CAAC;IACjE,cAAc,EAAE,KAAK,CAAC;QAAE,EAAE,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAC;QAAC,QAAQ,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;CAC5F;AAED,cAAM,mBAAoB,SAAQ,YAAY;IAC1C,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,WAAW,CAAC;IACpB,aAAa,EAAE,aAAa,GAAG,IAAI,CAAC;IACpC,aAAa,EAAE,mBAAmB,CAAC;IACnC,mBAAmB,EAAE,GAAG,CAAC;IACzB,gBAAgB,EAAE,GAAG,CAAC;IACtB,gBAAgB,EAAE,GAAG,CAAC;IACtB,SAAS,EAAE,OAAO,CAAC;IACnB,YAAY,EAAE,SAAS,EAAE,CAAC;IAC1B,eAAe,EAAE,OAAO,CAAC;IACzB,SAAS,EAAE,MAAM,CAAC;gBAEN,MAAM,EAAE,WAAW;IAkB/B,kBAAkB,IAAI,IAAI;IAO1B,UAAU,IAAI,IAAI;IAalB,UAAU,IAAI,IAAI;IAYZ,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAsCtB,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IAoB3B,aAAa,CAAC,WAAW,EAAE,WAAW,GAAG,IAAI;IAsB7C,sBAAsB,IAAI,IAAI;IAYxB,oBAAoB,IAAI,OAAO,CAAC,IAAI,CAAC;IAuBrC,eAAe,CAAC,WAAW,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;IAiDtD,sBAAsB,IAAI,OAAO,CAAC,aAAa,CAAC;IAgDhD,wBAAwB,CAAC,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,aAAa,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IA8D5G,oBAAoB,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAuEvD,2BAA2B,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IA6CpE,mBAAmB,CAAC,WAAW,EAAE,SAAS,EAAE,KAAK,EAAE,KAAK,GAAG,IAAI;IAiB/D,WAAW,IAAI,MAAM;IAIrB,SAAS,IAAI,WAAW;IAmBxB,wBAAwB,IAAI,IAAI;CAanC;AAED,SAAS,mBAAmB,CAAC"}
|
|
@@ -0,0 +1,463 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Command Relay Service
|
|
4
|
+
* Manages email listening and command execution for Claude Code
|
|
5
|
+
*/
|
|
6
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
7
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
8
|
+
};
|
|
9
|
+
const events_1 = __importDefault(require("events"));
|
|
10
|
+
const email_listener_1 = __importDefault(require("./email-listener"));
|
|
11
|
+
const claude_command_bridge_1 = __importDefault(require("./claude-command-bridge"));
|
|
12
|
+
const logger_1 = __importDefault(require("../core/logger"));
|
|
13
|
+
const child_process_1 = require("child_process");
|
|
14
|
+
const fs_1 = __importDefault(require("fs"));
|
|
15
|
+
const path_1 = __importDefault(require("path"));
|
|
16
|
+
// Automation classes are not yet migrated to TypeScript
|
|
17
|
+
const ClipboardAutomation = require('../automation/clipboard-automation');
|
|
18
|
+
const SimpleAutomation = require('../automation/simple-automation');
|
|
19
|
+
const ClaudeAutomation = require('../automation/claude-automation');
|
|
20
|
+
class CommandRelayService extends events_1.default {
|
|
21
|
+
logger;
|
|
22
|
+
config;
|
|
23
|
+
emailListener;
|
|
24
|
+
commandBridge;
|
|
25
|
+
clipboardAutomation;
|
|
26
|
+
simpleAutomation;
|
|
27
|
+
claudeAutomation;
|
|
28
|
+
isRunning;
|
|
29
|
+
commandQueue;
|
|
30
|
+
processingQueue;
|
|
31
|
+
stateFile;
|
|
32
|
+
constructor(config) {
|
|
33
|
+
super();
|
|
34
|
+
this.logger = new logger_1.default('CommandRelay');
|
|
35
|
+
this.config = config;
|
|
36
|
+
this.emailListener = null;
|
|
37
|
+
this.commandBridge = new claude_command_bridge_1.default();
|
|
38
|
+
this.clipboardAutomation = new ClipboardAutomation();
|
|
39
|
+
this.simpleAutomation = new SimpleAutomation();
|
|
40
|
+
this.claudeAutomation = new ClaudeAutomation();
|
|
41
|
+
this.isRunning = false;
|
|
42
|
+
this.commandQueue = [];
|
|
43
|
+
this.processingQueue = false;
|
|
44
|
+
this.stateFile = path_1.default.join(__dirname, '../data/relay-state.json');
|
|
45
|
+
this._ensureDirectories();
|
|
46
|
+
this._loadState();
|
|
47
|
+
}
|
|
48
|
+
_ensureDirectories() {
|
|
49
|
+
const dataDir = path_1.default.join(__dirname, '../data');
|
|
50
|
+
if (!fs_1.default.existsSync(dataDir)) {
|
|
51
|
+
fs_1.default.mkdirSync(dataDir, { recursive: true });
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
_loadState() {
|
|
55
|
+
try {
|
|
56
|
+
if (fs_1.default.existsSync(this.stateFile)) {
|
|
57
|
+
const state = JSON.parse(fs_1.default.readFileSync(this.stateFile, 'utf8'));
|
|
58
|
+
this.commandQueue = state.commandQueue || [];
|
|
59
|
+
this.logger.debug(`Loaded ${this.commandQueue.length} queued commands`);
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
catch (error) {
|
|
63
|
+
this.logger.warn('Failed to load relay state:', error.message);
|
|
64
|
+
this.commandQueue = [];
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
_saveState() {
|
|
68
|
+
try {
|
|
69
|
+
const state = {
|
|
70
|
+
commandQueue: this.commandQueue,
|
|
71
|
+
lastSaved: new Date().toISOString()
|
|
72
|
+
};
|
|
73
|
+
fs_1.default.writeFileSync(this.stateFile, JSON.stringify(state, null, 2));
|
|
74
|
+
}
|
|
75
|
+
catch (error) {
|
|
76
|
+
this.logger.error('Failed to save relay state:', error.message);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
async start() {
|
|
80
|
+
if (this.isRunning) {
|
|
81
|
+
this.logger.warn('Command relay service already running');
|
|
82
|
+
return;
|
|
83
|
+
}
|
|
84
|
+
try {
|
|
85
|
+
// Validate email configuration
|
|
86
|
+
if (!this.config.imap) {
|
|
87
|
+
throw new Error('IMAP configuration required for command relay');
|
|
88
|
+
}
|
|
89
|
+
// Start email listener
|
|
90
|
+
this.emailListener = new email_listener_1.default(this.config);
|
|
91
|
+
// Listen for command events
|
|
92
|
+
this.emailListener.on('command', (commandData) => {
|
|
93
|
+
this._queueCommand(commandData);
|
|
94
|
+
});
|
|
95
|
+
// Start email listening
|
|
96
|
+
await this.emailListener.start();
|
|
97
|
+
// Start command processing
|
|
98
|
+
this._startCommandProcessor();
|
|
99
|
+
this.isRunning = true;
|
|
100
|
+
this.logger.info('Command relay service started successfully');
|
|
101
|
+
// Send startup notification
|
|
102
|
+
this.emit('started');
|
|
103
|
+
}
|
|
104
|
+
catch (error) {
|
|
105
|
+
this.logger.error('Failed to start command relay service:', error.message);
|
|
106
|
+
throw error;
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
async stop() {
|
|
110
|
+
if (!this.isRunning) {
|
|
111
|
+
return;
|
|
112
|
+
}
|
|
113
|
+
this.isRunning = false;
|
|
114
|
+
// Stop email listener
|
|
115
|
+
if (this.emailListener) {
|
|
116
|
+
await this.emailListener.stop();
|
|
117
|
+
this.emailListener = null;
|
|
118
|
+
}
|
|
119
|
+
// Save state
|
|
120
|
+
this._saveState();
|
|
121
|
+
this.logger.info('Command relay service stopped');
|
|
122
|
+
this.emit('stopped');
|
|
123
|
+
}
|
|
124
|
+
_queueCommand(commandData) {
|
|
125
|
+
const queueItem = {
|
|
126
|
+
id: this._generateId(),
|
|
127
|
+
...commandData,
|
|
128
|
+
queuedAt: new Date().toISOString(),
|
|
129
|
+
status: 'queued',
|
|
130
|
+
retries: 0,
|
|
131
|
+
maxRetries: 3
|
|
132
|
+
};
|
|
133
|
+
this.commandQueue.push(queueItem);
|
|
134
|
+
this._saveState();
|
|
135
|
+
this.logger.info(`Command queued:`, {
|
|
136
|
+
id: queueItem.id,
|
|
137
|
+
sessionId: queueItem.sessionId,
|
|
138
|
+
command: queueItem.command.substring(0, 50) + '...'
|
|
139
|
+
});
|
|
140
|
+
this.emit('commandQueued', queueItem);
|
|
141
|
+
}
|
|
142
|
+
_startCommandProcessor() {
|
|
143
|
+
// Process queue immediately
|
|
144
|
+
this._processCommandQueue();
|
|
145
|
+
// Process queue periodically
|
|
146
|
+
setInterval(() => {
|
|
147
|
+
if (this.isRunning) {
|
|
148
|
+
this._processCommandQueue();
|
|
149
|
+
}
|
|
150
|
+
}, 5000); // Check every 5 seconds
|
|
151
|
+
}
|
|
152
|
+
async _processCommandQueue() {
|
|
153
|
+
if (this.processingQueue || this.commandQueue.length === 0) {
|
|
154
|
+
return;
|
|
155
|
+
}
|
|
156
|
+
this.processingQueue = true;
|
|
157
|
+
try {
|
|
158
|
+
const pendingCommands = this.commandQueue.filter(cmd => cmd.status === 'queued');
|
|
159
|
+
for (const command of pendingCommands) {
|
|
160
|
+
try {
|
|
161
|
+
await this._executeCommand(command);
|
|
162
|
+
}
|
|
163
|
+
catch (error) {
|
|
164
|
+
this.logger.error(`Failed to execute command ${command.id}:`, error.message);
|
|
165
|
+
this._handleCommandError(command, error);
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
finally {
|
|
170
|
+
this.processingQueue = false;
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
async _executeCommand(commandItem) {
|
|
174
|
+
this.logger.info(`Executing command ${commandItem.id}:`, {
|
|
175
|
+
sessionId: commandItem.sessionId,
|
|
176
|
+
command: commandItem.command.substring(0, 100)
|
|
177
|
+
});
|
|
178
|
+
commandItem.status = 'executing';
|
|
179
|
+
commandItem.executedAt = new Date().toISOString();
|
|
180
|
+
try {
|
|
181
|
+
// Check if Claude Code process is running
|
|
182
|
+
const claudeProcess = await this._findClaudeCodeProcess();
|
|
183
|
+
if (!claudeProcess || !claudeProcess.available) {
|
|
184
|
+
throw new Error('Claude Code not available');
|
|
185
|
+
}
|
|
186
|
+
// Execute command - try multiple methods
|
|
187
|
+
const success = await this._sendCommandToClaudeCode(commandItem.command, claudeProcess, commandItem.sessionId);
|
|
188
|
+
if (success) {
|
|
189
|
+
commandItem.status = 'completed';
|
|
190
|
+
commandItem.completedAt = new Date().toISOString();
|
|
191
|
+
// Update session command count
|
|
192
|
+
if (this.emailListener) {
|
|
193
|
+
await this.emailListener.updateSessionCommandCount(commandItem.sessionId);
|
|
194
|
+
}
|
|
195
|
+
this.logger.info(`Command ${commandItem.id} executed successfully`);
|
|
196
|
+
this.emit('commandExecuted', commandItem);
|
|
197
|
+
}
|
|
198
|
+
else {
|
|
199
|
+
throw new Error('Failed to send command to Claude Code');
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
catch (error) {
|
|
203
|
+
commandItem.status = 'failed';
|
|
204
|
+
commandItem.error = error.message;
|
|
205
|
+
commandItem.failedAt = new Date().toISOString();
|
|
206
|
+
this.logger.error(`Command ${commandItem.id} failed:`, error.message);
|
|
207
|
+
this.emit('commandFailed', commandItem, error);
|
|
208
|
+
throw error;
|
|
209
|
+
}
|
|
210
|
+
finally {
|
|
211
|
+
this._saveState();
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
async _findClaudeCodeProcess() {
|
|
215
|
+
return new Promise((resolve) => {
|
|
216
|
+
// Find Claude Code related processes
|
|
217
|
+
const ps = (0, child_process_1.spawn)('ps', ['aux']);
|
|
218
|
+
let output = '';
|
|
219
|
+
ps.stdout.on('data', (data) => {
|
|
220
|
+
output += data.toString();
|
|
221
|
+
});
|
|
222
|
+
ps.on('close', (code) => {
|
|
223
|
+
const lines = output.split('\n');
|
|
224
|
+
const claudeProcesses = lines.filter(line => (line.includes('claude') ||
|
|
225
|
+
line.includes('anthropic') ||
|
|
226
|
+
line.includes('Claude') ||
|
|
227
|
+
line.includes('node') && line.includes('claude')) &&
|
|
228
|
+
!line.includes('grep') &&
|
|
229
|
+
!line.includes('taskping') &&
|
|
230
|
+
!line.includes('ps aux'));
|
|
231
|
+
if (claudeProcesses.length > 0) {
|
|
232
|
+
// Parse process ID
|
|
233
|
+
const processLine = claudeProcesses[0];
|
|
234
|
+
const parts = processLine.trim().split(/\s+/);
|
|
235
|
+
const pid = parseInt(parts[1]);
|
|
236
|
+
this.logger.debug('Found Claude Code process:', processLine);
|
|
237
|
+
resolve({
|
|
238
|
+
pid,
|
|
239
|
+
command: processLine
|
|
240
|
+
});
|
|
241
|
+
}
|
|
242
|
+
else {
|
|
243
|
+
// If no process found, assume Claude Code can be accessed via desktop automation
|
|
244
|
+
this.logger.debug('No Claude Code process found, will try desktop automation');
|
|
245
|
+
resolve({ pid: null, available: true });
|
|
246
|
+
}
|
|
247
|
+
});
|
|
248
|
+
ps.on('error', (error) => {
|
|
249
|
+
this.logger.error('Error finding Claude Code process:', error.message);
|
|
250
|
+
// Even if error occurs, try desktop automation
|
|
251
|
+
resolve({ pid: null, available: true });
|
|
252
|
+
});
|
|
253
|
+
});
|
|
254
|
+
}
|
|
255
|
+
async _sendCommandToClaudeCode(command, claudeProcess, sessionId) {
|
|
256
|
+
return new Promise(async (resolve) => {
|
|
257
|
+
try {
|
|
258
|
+
// Method 1: Claude Code dedicated automation (most direct and reliable)
|
|
259
|
+
this.logger.info('Attempting to send command via Claude automation...');
|
|
260
|
+
const claudeSuccess = await this.claudeAutomation.sendCommand(command, sessionId);
|
|
261
|
+
if (claudeSuccess) {
|
|
262
|
+
this.logger.info('Command sent and executed successfully via Claude automation');
|
|
263
|
+
resolve(true);
|
|
264
|
+
return;
|
|
265
|
+
}
|
|
266
|
+
// Method 2: Clipboard automation (requires permissions)
|
|
267
|
+
if (this.clipboardAutomation.isSupported()) {
|
|
268
|
+
this.logger.info('Attempting to send command via clipboard automation...');
|
|
269
|
+
const clipboardSuccess = await this.clipboardAutomation.sendCommand(command);
|
|
270
|
+
if (clipboardSuccess) {
|
|
271
|
+
this.logger.info('Command sent successfully via clipboard automation');
|
|
272
|
+
resolve(true);
|
|
273
|
+
return;
|
|
274
|
+
}
|
|
275
|
+
this.logger.warn('Clipboard automation failed, trying other methods...');
|
|
276
|
+
}
|
|
277
|
+
// Method 3: Simple automation solution (includes multiple fallback options)
|
|
278
|
+
this.logger.info('Attempting to send command via simple automation...');
|
|
279
|
+
const simpleSuccess = await this.simpleAutomation.sendCommand(command, sessionId);
|
|
280
|
+
if (simpleSuccess) {
|
|
281
|
+
this.logger.info('Command sent successfully via simple automation');
|
|
282
|
+
resolve(true);
|
|
283
|
+
return;
|
|
284
|
+
}
|
|
285
|
+
// Method 4: Use command bridge (file-based approach)
|
|
286
|
+
this.logger.info('Attempting to send command via bridge...');
|
|
287
|
+
const bridgeSuccess = await this.commandBridge.sendCommand(command, sessionId);
|
|
288
|
+
if (bridgeSuccess) {
|
|
289
|
+
this.logger.info('Command sent successfully via bridge');
|
|
290
|
+
resolve(true);
|
|
291
|
+
return;
|
|
292
|
+
}
|
|
293
|
+
// Method 5: Send notification as final fallback
|
|
294
|
+
this.logger.info('Using notification as final fallback...');
|
|
295
|
+
this._sendCommandViaNotification(command)
|
|
296
|
+
.then((success) => {
|
|
297
|
+
this.logger.info('Command notification sent as fallback');
|
|
298
|
+
resolve(success);
|
|
299
|
+
})
|
|
300
|
+
.catch(() => resolve(false));
|
|
301
|
+
}
|
|
302
|
+
catch (error) {
|
|
303
|
+
this.logger.error('Error sending command to Claude Code:', error.message);
|
|
304
|
+
resolve(false);
|
|
305
|
+
}
|
|
306
|
+
});
|
|
307
|
+
}
|
|
308
|
+
async _sendCommandViaMacOS(command) {
|
|
309
|
+
return new Promise((resolve, reject) => {
|
|
310
|
+
// Use AppleScript automation to input to active window
|
|
311
|
+
const escapedCommand = command.replace(/\\/g, '\\\\').replace(/"/g, '\\"').replace(/'/g, "\\'");
|
|
312
|
+
const script = `
|
|
313
|
+
tell application "System Events"
|
|
314
|
+
-- Get current active application
|
|
315
|
+
set activeApp to name of first application process whose frontmost is true
|
|
316
|
+
|
|
317
|
+
-- Try to find Claude Code, Terminal or other development tools
|
|
318
|
+
set targetApps to {"Claude Code", "Terminal", "iTerm2", "iTerm", "Visual Studio Code", "Code"}
|
|
319
|
+
set foundApp to null
|
|
320
|
+
|
|
321
|
+
repeat with appName in targetApps
|
|
322
|
+
try
|
|
323
|
+
if application process appName exists then
|
|
324
|
+
set foundApp to application process appName
|
|
325
|
+
exit repeat
|
|
326
|
+
end if
|
|
327
|
+
end try
|
|
328
|
+
end repeat
|
|
329
|
+
|
|
330
|
+
if foundApp is not null then
|
|
331
|
+
-- Switch to target application
|
|
332
|
+
set frontmost of foundApp to true
|
|
333
|
+
delay 1
|
|
334
|
+
|
|
335
|
+
-- Send command
|
|
336
|
+
keystroke "${escapedCommand}"
|
|
337
|
+
delay 0.3
|
|
338
|
+
keystroke return
|
|
339
|
+
|
|
340
|
+
return "success"
|
|
341
|
+
else
|
|
342
|
+
-- If no specific application found, try current active window
|
|
343
|
+
keystroke "${escapedCommand}"
|
|
344
|
+
delay 0.3
|
|
345
|
+
keystroke return
|
|
346
|
+
return "fallback"
|
|
347
|
+
end if
|
|
348
|
+
end tell
|
|
349
|
+
`;
|
|
350
|
+
const osascript = (0, child_process_1.spawn)('osascript', ['-e', script]);
|
|
351
|
+
let output = '';
|
|
352
|
+
let errorOutput = '';
|
|
353
|
+
osascript.stdout.on('data', (data) => {
|
|
354
|
+
output += data.toString().trim();
|
|
355
|
+
});
|
|
356
|
+
osascript.stderr.on('data', (data) => {
|
|
357
|
+
errorOutput += data.toString();
|
|
358
|
+
});
|
|
359
|
+
osascript.on('close', (code) => {
|
|
360
|
+
if (code === 0 && (output === 'success' || output === 'fallback')) {
|
|
361
|
+
this.logger.debug(`Command sent via macOS automation (${output})`);
|
|
362
|
+
resolve(true);
|
|
363
|
+
}
|
|
364
|
+
else {
|
|
365
|
+
this.logger.warn('AppleScript failed:', { code, output, error: errorOutput });
|
|
366
|
+
reject(new Error(`macOS automation failed: ${errorOutput || output}`));
|
|
367
|
+
}
|
|
368
|
+
});
|
|
369
|
+
osascript.on('error', (err) => {
|
|
370
|
+
reject(err);
|
|
371
|
+
});
|
|
372
|
+
});
|
|
373
|
+
}
|
|
374
|
+
async _sendCommandViaNotification(command) {
|
|
375
|
+
// As fallback option, send desktop notification to remind user
|
|
376
|
+
return new Promise((resolve) => {
|
|
377
|
+
try {
|
|
378
|
+
const commandPreview = command.length > 50 ? command.substring(0, 50) + '...' : command;
|
|
379
|
+
if (process.platform === 'darwin') {
|
|
380
|
+
// macOS notification with more information
|
|
381
|
+
const script = `
|
|
382
|
+
display notification "Command: ${commandPreview.replace(/"/g, '\\"')}" with title "TaskPing - Email Command" subtitle "Click Terminal or Claude Code window, then paste command" sound name "default"
|
|
383
|
+
`;
|
|
384
|
+
const notification = (0, child_process_1.spawn)('osascript', ['-e', script]);
|
|
385
|
+
notification.on('close', () => {
|
|
386
|
+
this.logger.info('macOS notification sent to user');
|
|
387
|
+
resolve(true);
|
|
388
|
+
});
|
|
389
|
+
notification.on('error', () => {
|
|
390
|
+
resolve(false);
|
|
391
|
+
});
|
|
392
|
+
}
|
|
393
|
+
else {
|
|
394
|
+
// Linux notification
|
|
395
|
+
const notification = (0, child_process_1.spawn)('notify-send', [
|
|
396
|
+
'TaskPing - Email Command',
|
|
397
|
+
`Command: ${commandPreview}`
|
|
398
|
+
]);
|
|
399
|
+
notification.on('close', () => {
|
|
400
|
+
this.logger.info('Linux notification sent to user');
|
|
401
|
+
resolve(true);
|
|
402
|
+
});
|
|
403
|
+
notification.on('error', () => {
|
|
404
|
+
resolve(false);
|
|
405
|
+
});
|
|
406
|
+
}
|
|
407
|
+
}
|
|
408
|
+
catch (error) {
|
|
409
|
+
this.logger.warn('Failed to send notification:', error.message);
|
|
410
|
+
resolve(false);
|
|
411
|
+
}
|
|
412
|
+
});
|
|
413
|
+
}
|
|
414
|
+
_handleCommandError(commandItem, error) {
|
|
415
|
+
commandItem.retries = (commandItem.retries || 0) + 1;
|
|
416
|
+
if (commandItem.retries < commandItem.maxRetries) {
|
|
417
|
+
// Retry
|
|
418
|
+
commandItem.status = 'queued';
|
|
419
|
+
commandItem.retryAt = new Date(Date.now() + (commandItem.retries * 60000)).toISOString(); // Delayed retry
|
|
420
|
+
this.logger.info(`Command ${commandItem.id} will be retried (attempt ${commandItem.retries + 1})`);
|
|
421
|
+
}
|
|
422
|
+
else {
|
|
423
|
+
// Reached maximum retry count
|
|
424
|
+
commandItem.status = 'failed';
|
|
425
|
+
this.logger.error(`Command ${commandItem.id} failed after ${commandItem.retries} retries`);
|
|
426
|
+
}
|
|
427
|
+
this._saveState();
|
|
428
|
+
}
|
|
429
|
+
_generateId() {
|
|
430
|
+
return Date.now().toString(36) + Math.random().toString(36).substr(2);
|
|
431
|
+
}
|
|
432
|
+
getStatus() {
|
|
433
|
+
return {
|
|
434
|
+
isRunning: this.isRunning,
|
|
435
|
+
queueLength: this.commandQueue.length,
|
|
436
|
+
processing: this.processingQueue,
|
|
437
|
+
emailListener: this.emailListener ? {
|
|
438
|
+
connected: this.emailListener.isConnected,
|
|
439
|
+
listening: this.emailListener.isListening
|
|
440
|
+
} : null,
|
|
441
|
+
recentCommands: this.commandQueue.slice(-5).map(cmd => ({
|
|
442
|
+
id: cmd.id,
|
|
443
|
+
status: cmd.status,
|
|
444
|
+
queuedAt: cmd.queuedAt,
|
|
445
|
+
command: cmd.command.substring(0, 50) + '...'
|
|
446
|
+
}))
|
|
447
|
+
};
|
|
448
|
+
}
|
|
449
|
+
// Manually cleanup completed commands
|
|
450
|
+
cleanupCompletedCommands() {
|
|
451
|
+
const beforeCount = this.commandQueue.length;
|
|
452
|
+
this.commandQueue = this.commandQueue.filter(cmd => cmd.status !== 'completed' ||
|
|
453
|
+
new Date(cmd.completedAt) > new Date(Date.now() - 24 * 60 * 60 * 1000) // Keep records within 24 hours
|
|
454
|
+
);
|
|
455
|
+
const removedCount = beforeCount - this.commandQueue.length;
|
|
456
|
+
if (removedCount > 0) {
|
|
457
|
+
this.logger.info(`Cleaned up ${removedCount} completed commands`);
|
|
458
|
+
this._saveState();
|
|
459
|
+
}
|
|
460
|
+
}
|
|
461
|
+
}
|
|
462
|
+
module.exports = CommandRelayService;
|
|
463
|
+
//# sourceMappingURL=command-relay.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"command-relay.js","sourceRoot":"","sources":["../../../src/relay/command-relay.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Email Listener
|
|
3
|
+
* Monitors IMAP inbox for replies and extracts commands
|
|
4
|
+
*/
|
|
5
|
+
import EventEmitter from 'events';
|
|
6
|
+
import Logger from '../core/logger';
|
|
7
|
+
interface EmailListenerConfig {
|
|
8
|
+
imap?: {
|
|
9
|
+
auth: {
|
|
10
|
+
user: string;
|
|
11
|
+
pass: string;
|
|
12
|
+
};
|
|
13
|
+
host: string;
|
|
14
|
+
port: number;
|
|
15
|
+
secure: boolean;
|
|
16
|
+
};
|
|
17
|
+
sentMessagesPath?: string;
|
|
18
|
+
template?: {
|
|
19
|
+
checkInterval?: number;
|
|
20
|
+
};
|
|
21
|
+
[key: string]: unknown;
|
|
22
|
+
}
|
|
23
|
+
interface SessionData {
|
|
24
|
+
id: string;
|
|
25
|
+
token: string;
|
|
26
|
+
expires: string;
|
|
27
|
+
commandCount: number;
|
|
28
|
+
maxCommands: number;
|
|
29
|
+
lastCommand?: string;
|
|
30
|
+
[key: string]: unknown;
|
|
31
|
+
}
|
|
32
|
+
declare class EmailListener extends EventEmitter {
|
|
33
|
+
logger: Logger;
|
|
34
|
+
config: EmailListenerConfig;
|
|
35
|
+
imap: any;
|
|
36
|
+
isConnected: boolean;
|
|
37
|
+
isListening: boolean;
|
|
38
|
+
sessionsDir: string;
|
|
39
|
+
sentMessagesPath: string;
|
|
40
|
+
checkInterval: number;
|
|
41
|
+
lastCheckTime: Date;
|
|
42
|
+
constructor(config: EmailListenerConfig);
|
|
43
|
+
_ensureDirectories(): void;
|
|
44
|
+
start(): Promise<void>;
|
|
45
|
+
stop(): Promise<void>;
|
|
46
|
+
_connect(): Promise<void>;
|
|
47
|
+
_startListening(): void;
|
|
48
|
+
_checkNewMails(): Promise<void>;
|
|
49
|
+
_openInbox(): Promise<any>;
|
|
50
|
+
_searchAndProcessMails(): Promise<void>;
|
|
51
|
+
_processMessage(msg: any, seqno: number): void;
|
|
52
|
+
_handleParsedEmail(email: any, seqno: number): Promise<void>;
|
|
53
|
+
_isReplyEmail(email: any): boolean;
|
|
54
|
+
_extractSessionId(email: any): string | null;
|
|
55
|
+
_getSessionIdByToken(token: string): string | null;
|
|
56
|
+
_validateSession(sessionId: string): Promise<SessionData | null>;
|
|
57
|
+
_extractCommand(email: any): string;
|
|
58
|
+
_cleanEmailContent(text: string): string;
|
|
59
|
+
_isCommandSafe(command: string): boolean;
|
|
60
|
+
updateSessionCommandCount(sessionId: string): Promise<void>;
|
|
61
|
+
_isSystemSentEmail(messageId: string): Promise<boolean>;
|
|
62
|
+
_removeFromSentMessages(messageId: string): Promise<void>;
|
|
63
|
+
}
|
|
64
|
+
export = EmailListener;
|
|
65
|
+
//# sourceMappingURL=email-listener.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"email-listener.d.ts","sourceRoot":"","sources":["../../../src/relay/email-listener.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAMH,OAAO,YAAY,MAAM,QAAQ,CAAC;AAClC,OAAO,MAAM,MAAM,gBAAgB,CAAC;AAIpC,UAAU,mBAAmB;IACzB,IAAI,CAAC,EAAE;QACH,IAAI,EAAE;YAAE,IAAI,EAAE,MAAM,CAAC;YAAC,IAAI,EAAE,MAAM,CAAA;SAAE,CAAC;QACrC,IAAI,EAAE,MAAM,CAAC;QACb,IAAI,EAAE,MAAM,CAAC;QACb,MAAM,EAAE,OAAO,CAAC;KACnB,CAAC;IACF,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,QAAQ,CAAC,EAAE;QAAE,aAAa,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC;IACtC,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CAC1B;AAED,UAAU,WAAW;IACjB,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,CAAC;IAChB,YAAY,EAAE,MAAM,CAAC;IACrB,WAAW,EAAE,MAAM,CAAC;IACpB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CAC1B;AAMD,cAAM,aAAc,SAAQ,YAAY;IACpC,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,mBAAmB,CAAC;IAC5B,IAAI,EAAE,GAAG,CAAC;IACV,WAAW,EAAE,OAAO,CAAC;IACrB,WAAW,EAAE,OAAO,CAAC;IACrB,WAAW,EAAE,MAAM,CAAC;IACpB,gBAAgB,EAAE,MAAM,CAAC;IACzB,aAAa,EAAE,MAAM,CAAC;IACtB,aAAa,EAAE,IAAI,CAAC;gBAER,MAAM,EAAE,mBAAmB;IAevC,kBAAkB,IAAI,IAAI;IAMpB,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAwBtB,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IAgBrB,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC;IAiC/B,eAAe,IAAI,IAAI;IAUjB,cAAc,IAAI,OAAO,CAAC,IAAI,CAAC;IAmB/B,UAAU,IAAI,OAAO,CAAC,GAAG,CAAC;IAY1B,sBAAsB,IAAI,OAAO,CAAC,IAAI,CAAC;IA2C7C,eAAe,CAAC,GAAG,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI;IA8BxC,kBAAkB,CAAC,KAAK,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAkElE,aAAa,CAAC,KAAK,EAAE,GAAG,GAAG,OAAO;IAkBlC,iBAAiB,CAAC,KAAK,EAAE,GAAG,GAAG,MAAM,GAAG,IAAI;IAiC5C,oBAAoB,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;IAmB5C,gBAAgB,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC;IAkCtE,eAAe,CAAC,KAAK,EAAE,GAAG,GAAG,MAAM;IAYnC,kBAAkB,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM;IA6BxC,cAAc,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO;IA2BlC,yBAAyB,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAiB3D,kBAAkB,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAcvD,uBAAuB,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAqBlE;AAED,SAAS,aAAa,CAAC"}
|