@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.
Files changed (247) hide show
  1. package/.env.example +19 -0
  2. package/LICENSE +21 -0
  3. package/README.md +338 -0
  4. package/ccgram.service +24 -0
  5. package/config/channels.json +58 -0
  6. package/config/default.json +27 -0
  7. package/config/defaults/config.json +16 -0
  8. package/config/defaults/i18n.json +32 -0
  9. package/config/email-template.json +31 -0
  10. package/config/test-with-subagent.json +16 -0
  11. package/config/user.json +27 -0
  12. package/dist/claude-hook-notify.d.ts +7 -0
  13. package/dist/claude-hook-notify.d.ts.map +1 -0
  14. package/dist/claude-hook-notify.js +154 -0
  15. package/dist/claude-hook-notify.js.map +1 -0
  16. package/dist/claude-remote.d.ts +50 -0
  17. package/dist/claude-remote.d.ts.map +1 -0
  18. package/dist/claude-remote.js +927 -0
  19. package/dist/claude-remote.js.map +1 -0
  20. package/dist/cli.d.ts +3 -0
  21. package/dist/cli.d.ts.map +1 -0
  22. package/dist/cli.js +110 -0
  23. package/dist/cli.js.map +1 -0
  24. package/dist/enhanced-hook-notify.d.ts +16 -0
  25. package/dist/enhanced-hook-notify.d.ts.map +1 -0
  26. package/dist/enhanced-hook-notify.js +288 -0
  27. package/dist/enhanced-hook-notify.js.map +1 -0
  28. package/dist/permission-hook.d.ts +15 -0
  29. package/dist/permission-hook.d.ts.map +1 -0
  30. package/dist/permission-hook.js +357 -0
  31. package/dist/permission-hook.js.map +1 -0
  32. package/dist/prompt-bridge.d.ts +50 -0
  33. package/dist/prompt-bridge.d.ts.map +1 -0
  34. package/dist/prompt-bridge.js +173 -0
  35. package/dist/prompt-bridge.js.map +1 -0
  36. package/dist/question-notify.d.ts +16 -0
  37. package/dist/question-notify.d.ts.map +1 -0
  38. package/dist/question-notify.js +272 -0
  39. package/dist/question-notify.js.map +1 -0
  40. package/dist/setup.d.ts +10 -0
  41. package/dist/setup.d.ts.map +1 -0
  42. package/dist/setup.js +649 -0
  43. package/dist/setup.js.map +1 -0
  44. package/dist/smart-monitor.d.ts +7 -0
  45. package/dist/smart-monitor.d.ts.map +1 -0
  46. package/dist/smart-monitor.js +256 -0
  47. package/dist/smart-monitor.js.map +1 -0
  48. package/dist/src/automation/claude-automation.d.ts +45 -0
  49. package/dist/src/automation/claude-automation.d.ts.map +1 -0
  50. package/dist/src/automation/claude-automation.js +367 -0
  51. package/dist/src/automation/claude-automation.js.map +1 -0
  52. package/dist/src/automation/clipboard-automation.d.ts +35 -0
  53. package/dist/src/automation/clipboard-automation.d.ts.map +1 -0
  54. package/dist/src/automation/clipboard-automation.js +242 -0
  55. package/dist/src/automation/clipboard-automation.js.map +1 -0
  56. package/dist/src/automation/simple-automation.d.ts +56 -0
  57. package/dist/src/automation/simple-automation.d.ts.map +1 -0
  58. package/dist/src/automation/simple-automation.js +283 -0
  59. package/dist/src/automation/simple-automation.js.map +1 -0
  60. package/dist/src/channels/base/channel.d.ts +60 -0
  61. package/dist/src/channels/base/channel.d.ts.map +1 -0
  62. package/dist/src/channels/base/channel.js +96 -0
  63. package/dist/src/channels/base/channel.js.map +1 -0
  64. package/dist/src/channels/email/smtp.d.ts +74 -0
  65. package/dist/src/channels/email/smtp.d.ts.map +1 -0
  66. package/dist/src/channels/email/smtp.js +605 -0
  67. package/dist/src/channels/email/smtp.js.map +1 -0
  68. package/dist/src/channels/line/line.d.ts +36 -0
  69. package/dist/src/channels/line/line.d.ts.map +1 -0
  70. package/dist/src/channels/line/line.js +180 -0
  71. package/dist/src/channels/line/line.js.map +1 -0
  72. package/dist/src/channels/line/webhook.d.ts +55 -0
  73. package/dist/src/channels/line/webhook.d.ts.map +1 -0
  74. package/dist/src/channels/line/webhook.js +191 -0
  75. package/dist/src/channels/line/webhook.js.map +1 -0
  76. package/dist/src/channels/local/desktop.d.ts +30 -0
  77. package/dist/src/channels/local/desktop.d.ts.map +1 -0
  78. package/dist/src/channels/local/desktop.js +161 -0
  79. package/dist/src/channels/local/desktop.js.map +1 -0
  80. package/dist/src/channels/telegram/telegram.d.ts +43 -0
  81. package/dist/src/channels/telegram/telegram.d.ts.map +1 -0
  82. package/dist/src/channels/telegram/telegram.js +223 -0
  83. package/dist/src/channels/telegram/telegram.js.map +1 -0
  84. package/dist/src/channels/telegram/webhook.d.ts +75 -0
  85. package/dist/src/channels/telegram/webhook.d.ts.map +1 -0
  86. package/dist/src/channels/telegram/webhook.js +278 -0
  87. package/dist/src/channels/telegram/webhook.js.map +1 -0
  88. package/dist/src/config-manager.d.ts +16 -0
  89. package/dist/src/config-manager.d.ts.map +1 -0
  90. package/dist/src/config-manager.js +152 -0
  91. package/dist/src/config-manager.js.map +1 -0
  92. package/dist/src/core/config.d.ts +28 -0
  93. package/dist/src/core/config.d.ts.map +1 -0
  94. package/dist/src/core/config.js +248 -0
  95. package/dist/src/core/config.js.map +1 -0
  96. package/dist/src/core/logger.d.ts +19 -0
  97. package/dist/src/core/logger.d.ts.map +1 -0
  98. package/dist/src/core/logger.js +47 -0
  99. package/dist/src/core/logger.js.map +1 -0
  100. package/dist/src/core/notifier.d.ts +45 -0
  101. package/dist/src/core/notifier.d.ts.map +1 -0
  102. package/dist/src/core/notifier.js +189 -0
  103. package/dist/src/core/notifier.js.map +1 -0
  104. package/dist/src/daemon/taskping-daemon.d.ts +38 -0
  105. package/dist/src/daemon/taskping-daemon.d.ts.map +1 -0
  106. package/dist/src/daemon/taskping-daemon.js +306 -0
  107. package/dist/src/daemon/taskping-daemon.js.map +1 -0
  108. package/dist/src/relay/claude-command-bridge.d.ts +57 -0
  109. package/dist/src/relay/claude-command-bridge.d.ts.map +1 -0
  110. package/dist/src/relay/claude-command-bridge.js +188 -0
  111. package/dist/src/relay/claude-command-bridge.js.map +1 -0
  112. package/dist/src/relay/command-relay.d.ts +94 -0
  113. package/dist/src/relay/command-relay.d.ts.map +1 -0
  114. package/dist/src/relay/command-relay.js +463 -0
  115. package/dist/src/relay/command-relay.js.map +1 -0
  116. package/dist/src/relay/email-listener.d.ts +65 -0
  117. package/dist/src/relay/email-listener.d.ts.map +1 -0
  118. package/dist/src/relay/email-listener.js +460 -0
  119. package/dist/src/relay/email-listener.js.map +1 -0
  120. package/dist/src/relay/relay-pty.d.ts +21 -0
  121. package/dist/src/relay/relay-pty.d.ts.map +1 -0
  122. package/dist/src/relay/relay-pty.js +696 -0
  123. package/dist/src/relay/relay-pty.js.map +1 -0
  124. package/dist/src/relay/smart-injector.d.ts +30 -0
  125. package/dist/src/relay/smart-injector.d.ts.map +1 -0
  126. package/dist/src/relay/smart-injector.js +233 -0
  127. package/dist/src/relay/smart-injector.js.map +1 -0
  128. package/dist/src/relay/tmux-injector.d.ts +46 -0
  129. package/dist/src/relay/tmux-injector.d.ts.map +1 -0
  130. package/dist/src/relay/tmux-injector.js +413 -0
  131. package/dist/src/relay/tmux-injector.js.map +1 -0
  132. package/dist/src/tools/config-manager.d.ts +33 -0
  133. package/dist/src/tools/config-manager.d.ts.map +1 -0
  134. package/dist/src/tools/config-manager.js +448 -0
  135. package/dist/src/tools/config-manager.js.map +1 -0
  136. package/dist/src/tools/installer.d.ts +38 -0
  137. package/dist/src/tools/installer.d.ts.map +1 -0
  138. package/dist/src/tools/installer.js +222 -0
  139. package/dist/src/tools/installer.js.map +1 -0
  140. package/dist/src/types/callbacks.d.ts +29 -0
  141. package/dist/src/types/callbacks.d.ts.map +1 -0
  142. package/dist/src/types/callbacks.js +7 -0
  143. package/dist/src/types/callbacks.js.map +1 -0
  144. package/dist/src/types/config.d.ts +56 -0
  145. package/dist/src/types/config.d.ts.map +1 -0
  146. package/dist/src/types/config.js +6 -0
  147. package/dist/src/types/config.js.map +1 -0
  148. package/dist/src/types/hooks.d.ts +47 -0
  149. package/dist/src/types/hooks.d.ts.map +1 -0
  150. package/dist/src/types/hooks.js +6 -0
  151. package/dist/src/types/hooks.js.map +1 -0
  152. package/dist/src/types/index.d.ts +7 -0
  153. package/dist/src/types/index.d.ts.map +1 -0
  154. package/dist/src/types/index.js +23 -0
  155. package/dist/src/types/index.js.map +1 -0
  156. package/dist/src/types/ipc.d.ts +43 -0
  157. package/dist/src/types/ipc.d.ts.map +1 -0
  158. package/dist/src/types/ipc.js +7 -0
  159. package/dist/src/types/ipc.js.map +1 -0
  160. package/dist/src/types/session.d.ts +70 -0
  161. package/dist/src/types/session.d.ts.map +1 -0
  162. package/dist/src/types/session.js +9 -0
  163. package/dist/src/types/session.js.map +1 -0
  164. package/dist/src/types/telegram.d.ts +58 -0
  165. package/dist/src/types/telegram.d.ts.map +1 -0
  166. package/dist/src/types/telegram.js +6 -0
  167. package/dist/src/types/telegram.js.map +1 -0
  168. package/dist/src/utils/active-check.d.ts +19 -0
  169. package/dist/src/utils/active-check.d.ts.map +1 -0
  170. package/dist/src/utils/active-check.js +41 -0
  171. package/dist/src/utils/active-check.js.map +1 -0
  172. package/dist/src/utils/callback-parser.d.ts +21 -0
  173. package/dist/src/utils/callback-parser.d.ts.map +1 -0
  174. package/dist/src/utils/callback-parser.js +58 -0
  175. package/dist/src/utils/callback-parser.js.map +1 -0
  176. package/dist/src/utils/controller-injector.d.ts +21 -0
  177. package/dist/src/utils/controller-injector.d.ts.map +1 -0
  178. package/dist/src/utils/controller-injector.js +108 -0
  179. package/dist/src/utils/controller-injector.js.map +1 -0
  180. package/dist/src/utils/conversation-tracker.d.ts +32 -0
  181. package/dist/src/utils/conversation-tracker.d.ts.map +1 -0
  182. package/dist/src/utils/conversation-tracker.js +119 -0
  183. package/dist/src/utils/conversation-tracker.js.map +1 -0
  184. package/dist/src/utils/http-request.d.ts +25 -0
  185. package/dist/src/utils/http-request.d.ts.map +1 -0
  186. package/dist/src/utils/http-request.js +66 -0
  187. package/dist/src/utils/http-request.js.map +1 -0
  188. package/dist/src/utils/optional-require.d.ts +13 -0
  189. package/dist/src/utils/optional-require.d.ts.map +1 -0
  190. package/dist/src/utils/optional-require.js +37 -0
  191. package/dist/src/utils/optional-require.js.map +1 -0
  192. package/dist/src/utils/paths.d.ts +11 -0
  193. package/dist/src/utils/paths.d.ts.map +1 -0
  194. package/dist/src/utils/paths.js +28 -0
  195. package/dist/src/utils/paths.js.map +1 -0
  196. package/dist/src/utils/pty-session-manager.d.ts +42 -0
  197. package/dist/src/utils/pty-session-manager.d.ts.map +1 -0
  198. package/dist/src/utils/pty-session-manager.js +182 -0
  199. package/dist/src/utils/pty-session-manager.js.map +1 -0
  200. package/dist/src/utils/subagent-tracker.d.ts +64 -0
  201. package/dist/src/utils/subagent-tracker.d.ts.map +1 -0
  202. package/dist/src/utils/subagent-tracker.js +191 -0
  203. package/dist/src/utils/subagent-tracker.js.map +1 -0
  204. package/dist/src/utils/tmux-monitor.d.ts +102 -0
  205. package/dist/src/utils/tmux-monitor.d.ts.map +1 -0
  206. package/dist/src/utils/tmux-monitor.js +642 -0
  207. package/dist/src/utils/tmux-monitor.js.map +1 -0
  208. package/dist/src/utils/trace-capture.d.ts +42 -0
  209. package/dist/src/utils/trace-capture.d.ts.map +1 -0
  210. package/dist/src/utils/trace-capture.js +102 -0
  211. package/dist/src/utils/trace-capture.js.map +1 -0
  212. package/dist/start-all-webhooks.d.ts +7 -0
  213. package/dist/start-all-webhooks.d.ts.map +1 -0
  214. package/dist/start-all-webhooks.js +98 -0
  215. package/dist/start-all-webhooks.js.map +1 -0
  216. package/dist/start-line-webhook.d.ts +7 -0
  217. package/dist/start-line-webhook.d.ts.map +1 -0
  218. package/dist/start-line-webhook.js +59 -0
  219. package/dist/start-line-webhook.js.map +1 -0
  220. package/dist/start-relay-pty.d.ts +7 -0
  221. package/dist/start-relay-pty.d.ts.map +1 -0
  222. package/dist/start-relay-pty.js +173 -0
  223. package/dist/start-relay-pty.js.map +1 -0
  224. package/dist/start-telegram-webhook.d.ts +7 -0
  225. package/dist/start-telegram-webhook.d.ts.map +1 -0
  226. package/dist/start-telegram-webhook.js +80 -0
  227. package/dist/start-telegram-webhook.js.map +1 -0
  228. package/dist/user-prompt-hook.d.ts +13 -0
  229. package/dist/user-prompt-hook.d.ts.map +1 -0
  230. package/dist/user-prompt-hook.js +45 -0
  231. package/dist/user-prompt-hook.js.map +1 -0
  232. package/dist/workspace-router.d.ts +78 -0
  233. package/dist/workspace-router.d.ts.map +1 -0
  234. package/dist/workspace-router.js +408 -0
  235. package/dist/workspace-router.js.map +1 -0
  236. package/dist/workspace-telegram-bot.d.ts +3 -0
  237. package/dist/workspace-telegram-bot.d.ts.map +1 -0
  238. package/dist/workspace-telegram-bot.js +1172 -0
  239. package/dist/workspace-telegram-bot.js.map +1 -0
  240. package/package.json +80 -0
  241. package/src/types/callbacks.ts +39 -0
  242. package/src/types/config.ts +63 -0
  243. package/src/types/hooks.ts +50 -0
  244. package/src/types/index.ts +6 -0
  245. package/src/types/ipc.ts +55 -0
  246. package/src/types/session.ts +72 -0
  247. package/src/types/telegram.ts +66 -0
@@ -0,0 +1,161 @@
1
+ "use strict";
2
+ /**
3
+ * Desktop Notification Channel
4
+ * Sends notifications to the local desktop
5
+ */
6
+ var __importDefault = (this && this.__importDefault) || function (mod) {
7
+ return (mod && mod.__esModule) ? mod : { "default": mod };
8
+ };
9
+ const channel_1 = __importDefault(require("../base/channel"));
10
+ const child_process_1 = require("child_process");
11
+ const path_1 = __importDefault(require("path"));
12
+ const fs_1 = __importDefault(require("fs"));
13
+ class DesktopChannel extends channel_1.default {
14
+ platform;
15
+ soundsDir;
16
+ constructor(config = {}) {
17
+ super('desktop', config);
18
+ this.platform = process.platform;
19
+ this.soundsDir = path_1.default.join(__dirname, '../../assets/sounds');
20
+ }
21
+ async _sendImpl(notification) {
22
+ const { title, message } = notification;
23
+ const sound = this._getSoundForType(notification.type);
24
+ switch (this.platform) {
25
+ case 'darwin':
26
+ return this._sendMacOS(title, message, sound);
27
+ case 'linux':
28
+ return this._sendLinux(title, message, sound);
29
+ case 'win32':
30
+ return this._sendWindows(title, message, sound);
31
+ default:
32
+ this.logger.warn(`Platform ${this.platform} not supported`);
33
+ return false;
34
+ }
35
+ }
36
+ _getSoundForType(type) {
37
+ const config = this.config;
38
+ const soundMap = {
39
+ completed: config.completedSound || 'Glass',
40
+ waiting: config.waitingSound || 'Tink'
41
+ };
42
+ return soundMap[type] || 'Glass';
43
+ }
44
+ _sendMacOS(title, message, sound) {
45
+ try {
46
+ // Try terminal-notifier first
47
+ try {
48
+ const cmd = `terminal-notifier -title "${title}" -message "${message}" -sound "${sound}" -group "ccgram"`;
49
+ (0, child_process_1.execSync)(cmd, { timeout: parseInt(process.env.NOTIFICATION_TIMEOUT) || 3000 });
50
+ return true;
51
+ }
52
+ catch (e) {
53
+ // Fallback to osascript
54
+ const script = `display notification "${message}" with title "${title}"`;
55
+ (0, child_process_1.execSync)(`osascript -e '${script}'`, { timeout: parseInt(process.env.NOTIFICATION_TIMEOUT) || 3000 });
56
+ // Play sound separately
57
+ this._playSound(sound);
58
+ return true;
59
+ }
60
+ }
61
+ catch (error) {
62
+ this.logger.error('macOS notification failed:', error.message);
63
+ return false;
64
+ }
65
+ }
66
+ _sendLinux(title, message, sound) {
67
+ try {
68
+ const notificationTimeout = parseInt(process.env.NOTIFICATION_TIMEOUT) || 3000;
69
+ const displayTime = parseInt(process.env.NOTIFICATION_DISPLAY_TIME) || 10000;
70
+ (0, child_process_1.execSync)(`notify-send "${title}" "${message}" -t ${displayTime}`, { timeout: notificationTimeout });
71
+ this._playSound(sound);
72
+ return true;
73
+ }
74
+ catch (error) {
75
+ this.logger.error('Linux notification failed:', error.message);
76
+ return false;
77
+ }
78
+ }
79
+ _sendWindows(title, message, sound) {
80
+ try {
81
+ const script = `
82
+ [Windows.UI.Notifications.ToastNotificationManager, Windows.UI.Notifications, ContentType = WindowsRuntime] > $null
83
+ $template = [Windows.UI.Notifications.ToastNotificationManager]::GetTemplateContent([Windows.UI.Notifications.ToastTemplateType]::ToastText02)
84
+ $xml = [xml] $template.GetXml()
85
+ $xml.toast.visual.binding.text[0].AppendChild($xml.CreateTextNode("${title}")) > $null
86
+ $xml.toast.visual.binding.text[1].AppendChild($xml.CreateTextNode("${message}")) > $null
87
+ $toast = [Windows.UI.Notifications.ToastNotification]::new($xml)
88
+ [Windows.UI.Notifications.ToastNotificationManager]::CreateToastNotifier("CCGram").Show($toast)
89
+ `;
90
+ (0, child_process_1.execSync)(`powershell -Command "${script}"`, { timeout: 5000 });
91
+ this._playSound(sound);
92
+ return true;
93
+ }
94
+ catch (error) {
95
+ this.logger.error('Windows notification failed:', error.message);
96
+ return false;
97
+ }
98
+ }
99
+ _playSound(soundName) {
100
+ if (!soundName || soundName === 'default')
101
+ return;
102
+ try {
103
+ if (this.platform === 'darwin') {
104
+ const soundPath = `/System/Library/Sounds/${soundName}.aiff`;
105
+ const audioProcess = (0, child_process_1.spawn)('afplay', [soundPath], {
106
+ detached: true,
107
+ stdio: 'ignore'
108
+ });
109
+ audioProcess.unref();
110
+ }
111
+ else if (this.platform === 'linux') {
112
+ const soundPath = `/usr/share/sounds/freedesktop/stereo/${soundName.toLowerCase()}.oga`;
113
+ const audioProcess = (0, child_process_1.spawn)('paplay', [soundPath], {
114
+ detached: true,
115
+ stdio: 'ignore'
116
+ });
117
+ audioProcess.unref();
118
+ }
119
+ else if (this.platform === 'win32') {
120
+ const audioProcess = (0, child_process_1.spawn)('powershell', ['-c', `[console]::beep(800,300)`], {
121
+ detached: true,
122
+ stdio: 'ignore'
123
+ });
124
+ audioProcess.unref();
125
+ }
126
+ }
127
+ catch (error) {
128
+ this.logger.debug('Sound playback failed:', error.message);
129
+ }
130
+ }
131
+ validateConfig() {
132
+ // Desktop notifications don't require configuration
133
+ return true;
134
+ }
135
+ getAvailableSounds() {
136
+ const sounds = {
137
+ 'System Sounds': ['Glass', 'Tink', 'Ping', 'Pop', 'Basso', 'Blow', 'Bottle',
138
+ 'Frog', 'Funk', 'Hero', 'Morse', 'Purr', 'Sosumi', 'Submarine'],
139
+ 'Alert Sounds': ['Beep', 'Boop', 'Sosumi', 'Tink', 'Glass'],
140
+ 'Nature Sounds': ['Frog', 'Submarine'],
141
+ 'Musical Sounds': ['Funk', 'Hero', 'Morse', 'Sosumi']
142
+ };
143
+ // Add custom sounds from assets directory
144
+ try {
145
+ if (fs_1.default.existsSync(this.soundsDir)) {
146
+ const customSounds = fs_1.default.readdirSync(this.soundsDir)
147
+ .filter(file => /\.(wav|mp3|m4a|aiff|ogg)$/i.test(file))
148
+ .map(file => path_1.default.basename(file, path_1.default.extname(file)));
149
+ if (customSounds.length > 0) {
150
+ sounds['Custom Sounds'] = customSounds;
151
+ }
152
+ }
153
+ }
154
+ catch (error) {
155
+ this.logger.debug('Failed to load custom sounds:', error.message);
156
+ }
157
+ return sounds;
158
+ }
159
+ }
160
+ module.exports = DesktopChannel;
161
+ //# sourceMappingURL=desktop.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"desktop.js","sourceRoot":"","sources":["../../../../src/channels/local/desktop.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,43 @@
1
+ /**
2
+ * Telegram Notification Channel
3
+ * Sends notifications via Telegram Bot API with command support
4
+ */
5
+ import NotificationChannel from '../base/channel';
6
+ import TmuxMonitor from '../../utils/tmux-monitor';
7
+ import type { Notification } from '../../types';
8
+ interface TelegramConfig {
9
+ enabled?: boolean;
10
+ botToken?: string;
11
+ chatId?: string;
12
+ groupId?: string;
13
+ forceIPv4?: boolean;
14
+ botUsername?: string;
15
+ [key: string]: unknown;
16
+ }
17
+ interface NetworkOptions {
18
+ family?: 4;
19
+ }
20
+ declare class TelegramChannel extends NotificationChannel {
21
+ sessionsDir: string;
22
+ tmuxMonitor: TmuxMonitor;
23
+ apiBaseUrl: string;
24
+ botUsername: string | null;
25
+ constructor(config?: TelegramConfig);
26
+ _ensureDirectories(): void;
27
+ _validateConfig(): boolean;
28
+ /**
29
+ * Generate network options for HTTP requests
30
+ */
31
+ _getNetworkOptions(): NetworkOptions;
32
+ _generateToken(): string;
33
+ _getCurrentTmuxSession(): string | null;
34
+ _getBotUsername(): Promise<string>;
35
+ _sendImpl(notification: Notification): Promise<boolean>;
36
+ _generateTelegramMessage(notification: Notification, sessionId: string, token: string): string;
37
+ _createSession(sessionId: string, notification: Notification, token: string): Promise<void>;
38
+ _removeSession(sessionId: string): Promise<void>;
39
+ supportsRelay(): boolean;
40
+ validateConfig(): boolean;
41
+ }
42
+ export = TelegramChannel;
43
+ //# sourceMappingURL=telegram.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"telegram.d.ts","sourceRoot":"","sources":["../../../../src/channels/telegram/telegram.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,mBAAmB,MAAM,iBAAiB,CAAC;AAMlD,OAAO,WAAW,MAAM,0BAA0B,CAAC;AAEnD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAEhD,UAAU,cAAc;IACpB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CAC1B;AAED,UAAU,cAAc;IACpB,MAAM,CAAC,EAAE,CAAC,CAAC;CACd;AAwBD,cAAM,eAAgB,SAAQ,mBAAmB;IAC7C,WAAW,EAAE,MAAM,CAAC;IACpB,WAAW,EAAE,WAAW,CAAC;IACzB,UAAU,EAAE,MAAM,CAAC;IACnB,WAAW,EAAE,MAAM,GAAG,IAAI,CAAC;gBAEf,MAAM,GAAE,cAAmB;IAWvC,kBAAkB,IAAI,IAAI;IAM1B,eAAe,IAAI,OAAO;IAa1B;;OAEG;IACH,kBAAkB,IAAI,cAAc;IAQpC,cAAc,IAAI,MAAM;IAUxB,sBAAsB,IAAI,MAAM,GAAG,IAAI;IAejC,eAAe,IAAI,OAAO,CAAC,MAAM,CAAC;IA0BlC,SAAS,CAAC,YAAY,EAAE,YAAY,GAAG,OAAO,CAAC,OAAO,CAAC;IA2E7D,wBAAwB,CAAC,YAAY,EAAE,YAAY,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,MAAM;IAoCxF,cAAc,CAAC,SAAS,EAAE,MAAM,EAAE,YAAY,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAoB3F,cAAc,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAQtD,aAAa,IAAI,OAAO;IAIxB,cAAc,IAAI,OAAO;CAG5B;AAED,SAAS,eAAe,CAAC"}
@@ -0,0 +1,223 @@
1
+ "use strict";
2
+ /**
3
+ * Telegram Notification Channel
4
+ * Sends notifications via Telegram Bot API with command support
5
+ */
6
+ var __importDefault = (this && this.__importDefault) || function (mod) {
7
+ return (mod && mod.__esModule) ? mod : { "default": mod };
8
+ };
9
+ const channel_1 = __importDefault(require("../base/channel"));
10
+ const optional_require_1 = require("../../utils/optional-require");
11
+ const http_request_1 = __importDefault(require("../../utils/http-request"));
12
+ const uuidv4 = (0, optional_require_1.getUUID)();
13
+ const path_1 = __importDefault(require("path"));
14
+ const fs_1 = __importDefault(require("fs"));
15
+ const tmux_monitor_1 = __importDefault(require("../../utils/tmux-monitor"));
16
+ const child_process_1 = require("child_process");
17
+ class TelegramChannel extends channel_1.default {
18
+ sessionsDir;
19
+ tmuxMonitor;
20
+ apiBaseUrl;
21
+ botUsername;
22
+ constructor(config = {}) {
23
+ super('telegram', config);
24
+ this.sessionsDir = path_1.default.join(__dirname, '../../data/sessions');
25
+ this.tmuxMonitor = new tmux_monitor_1.default();
26
+ this.apiBaseUrl = 'https://api.telegram.org';
27
+ this.botUsername = null; // Cache for bot username
28
+ this._ensureDirectories();
29
+ this._validateConfig();
30
+ }
31
+ _ensureDirectories() {
32
+ if (!fs_1.default.existsSync(this.sessionsDir)) {
33
+ fs_1.default.mkdirSync(this.sessionsDir, { recursive: true });
34
+ }
35
+ }
36
+ _validateConfig() {
37
+ const config = this.config;
38
+ if (!config.botToken) {
39
+ this.logger.warn('Telegram Bot Token not found');
40
+ return false;
41
+ }
42
+ if (!config.chatId && !config.groupId) {
43
+ this.logger.warn('Telegram Chat ID or Group ID must be configured');
44
+ return false;
45
+ }
46
+ return true;
47
+ }
48
+ /**
49
+ * Generate network options for HTTP requests
50
+ */
51
+ _getNetworkOptions() {
52
+ const options = {};
53
+ if (this.config.forceIPv4) {
54
+ options.family = 4;
55
+ }
56
+ return options;
57
+ }
58
+ _generateToken() {
59
+ // Generate short Token (uppercase letters + numbers, 8 digits)
60
+ const chars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789';
61
+ let token = '';
62
+ for (let i = 0; i < 8; i++) {
63
+ token += chars.charAt(Math.floor(Math.random() * chars.length));
64
+ }
65
+ return token;
66
+ }
67
+ _getCurrentTmuxSession() {
68
+ try {
69
+ // Try to get current tmux session
70
+ const tmuxSession = (0, child_process_1.execSync)('tmux display-message -p "#S"', {
71
+ encoding: 'utf8',
72
+ stdio: ['ignore', 'pipe', 'ignore']
73
+ }).trim();
74
+ return tmuxSession || null;
75
+ }
76
+ catch (error) {
77
+ // Not in a tmux session or tmux not available
78
+ return null;
79
+ }
80
+ }
81
+ async _getBotUsername() {
82
+ if (this.botUsername) {
83
+ return this.botUsername;
84
+ }
85
+ const config = this.config;
86
+ try {
87
+ const response = await http_request_1.default.get(`${this.apiBaseUrl}/bot${config.botToken}/getMe`, this._getNetworkOptions());
88
+ const data = response.data;
89
+ if (data.ok && data.result.username) {
90
+ this.botUsername = data.result.username;
91
+ return this.botUsername;
92
+ }
93
+ }
94
+ catch (error) {
95
+ this.logger.error('Failed to get bot username:', error.message);
96
+ }
97
+ // Fallback to configured username or default
98
+ return config.botUsername || 'claude_remote_bot';
99
+ }
100
+ async _sendImpl(notification) {
101
+ if (!this._validateConfig()) {
102
+ throw new Error('Telegram channel not properly configured');
103
+ }
104
+ const config = this.config;
105
+ // Generate session ID and Token
106
+ const sessionId = uuidv4();
107
+ const token = this._generateToken();
108
+ // Get current tmux session and conversation content
109
+ const tmuxSession = this._getCurrentTmuxSession();
110
+ if (tmuxSession && !notification.metadata) {
111
+ const conversation = this.tmuxMonitor.getRecentConversation(tmuxSession);
112
+ notification.metadata = {
113
+ userQuestion: conversation.userQuestion || notification.message,
114
+ claudeResponse: conversation.claudeResponse || notification.message,
115
+ tmuxSession: tmuxSession,
116
+ timestamp: new Date().toISOString(),
117
+ language: 'en'
118
+ };
119
+ }
120
+ // Create session record
121
+ await this._createSession(sessionId, notification, token);
122
+ // Generate Telegram message
123
+ const messageText = this._generateTelegramMessage(notification, sessionId, token);
124
+ // Determine recipient (chat or group)
125
+ const chatId = config.groupId || config.chatId;
126
+ const isGroupChat = !!config.groupId;
127
+ // Create buttons using callback_data instead of inline query
128
+ // This avoids the automatic @bot_name addition
129
+ const buttons = [
130
+ [
131
+ {
132
+ text: '\u{1f4dd} Personal Chat',
133
+ callback_data: `personal:${token}`
134
+ },
135
+ {
136
+ text: '\u{1f465} Group Chat',
137
+ callback_data: `group:${token}`
138
+ }
139
+ ]
140
+ ];
141
+ const requestData = {
142
+ chat_id: chatId,
143
+ text: messageText,
144
+ parse_mode: 'Markdown',
145
+ reply_markup: {
146
+ inline_keyboard: buttons
147
+ }
148
+ };
149
+ try {
150
+ await http_request_1.default.post(`${this.apiBaseUrl}/bot${config.botToken}/sendMessage`, requestData, this._getNetworkOptions());
151
+ this.logger.info(`Telegram message sent successfully, Session: ${sessionId}`);
152
+ return true;
153
+ }
154
+ catch (error) {
155
+ this.logger.error('Failed to send Telegram message:', error.message);
156
+ // Clean up failed session
157
+ await this._removeSession(sessionId);
158
+ return false;
159
+ }
160
+ }
161
+ _generateTelegramMessage(notification, sessionId, token) {
162
+ const type = notification.type;
163
+ const emoji = type === 'completed' ? '\u2705' : '\u23f3';
164
+ const status = type === 'completed' ? 'Completed' : 'Waiting for Input';
165
+ let messageText = `${emoji} *Claude Task ${status}*\n`;
166
+ messageText += `*Project:* ${notification.project}\n`;
167
+ messageText += `*Session Token:* \`${token}\`\n\n`;
168
+ if (notification.metadata) {
169
+ if (notification.metadata.userQuestion) {
170
+ const userQuestion = notification.metadata.userQuestion;
171
+ messageText += `\u{1f4dd} *Your Question:*\n${userQuestion.substring(0, 200)}`;
172
+ if (userQuestion.length > 200) {
173
+ messageText += '...';
174
+ }
175
+ messageText += '\n\n';
176
+ }
177
+ if (notification.metadata.claudeResponse) {
178
+ const claudeResponse = notification.metadata.claudeResponse;
179
+ messageText += `\u{1f916} *Claude Response:*\n${claudeResponse.substring(0, 300)}`;
180
+ if (claudeResponse.length > 300) {
181
+ messageText += '...';
182
+ }
183
+ messageText += '\n\n';
184
+ }
185
+ }
186
+ messageText += `\u{1f4ac} *To send a new command:*\n`;
187
+ messageText += `Reply with: \`/cmd ${token} <your command>\`\n`;
188
+ messageText += `Example: \`/cmd ${token} Please analyze this code\``;
189
+ return messageText;
190
+ }
191
+ async _createSession(sessionId, notification, token) {
192
+ const session = {
193
+ id: sessionId,
194
+ token: token,
195
+ type: 'telegram',
196
+ created: new Date().toISOString(),
197
+ expires: new Date(Date.now() + 24 * 60 * 60 * 1000).toISOString(), // Expires after 24 hours
198
+ createdAt: Math.floor(Date.now() / 1000),
199
+ expiresAt: Math.floor((Date.now() + 24 * 60 * 60 * 1000) / 1000),
200
+ tmuxSession: notification.metadata?.tmuxSession || 'default',
201
+ project: notification.project,
202
+ notification: notification
203
+ };
204
+ const sessionFile = path_1.default.join(this.sessionsDir, `${sessionId}.json`);
205
+ fs_1.default.writeFileSync(sessionFile, JSON.stringify(session, null, 2));
206
+ this.logger.debug(`Session created: ${sessionId}`);
207
+ }
208
+ async _removeSession(sessionId) {
209
+ const sessionFile = path_1.default.join(this.sessionsDir, `${sessionId}.json`);
210
+ if (fs_1.default.existsSync(sessionFile)) {
211
+ fs_1.default.unlinkSync(sessionFile);
212
+ this.logger.debug(`Session removed: ${sessionId}`);
213
+ }
214
+ }
215
+ supportsRelay() {
216
+ return true;
217
+ }
218
+ validateConfig() {
219
+ return this._validateConfig();
220
+ }
221
+ }
222
+ module.exports = TelegramChannel;
223
+ //# sourceMappingURL=telegram.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"telegram.js","sourceRoot":"","sources":["../../../../src/channels/telegram/telegram.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,75 @@
1
+ /**
2
+ * Telegram Webhook Handler
3
+ * Handles incoming Telegram messages and commands
4
+ */
5
+ import Logger from '../../core/logger';
6
+ import ControllerInjector from '../../utils/controller-injector';
7
+ interface WebhookConfig {
8
+ botToken?: string;
9
+ botUsername?: string;
10
+ chatId?: string;
11
+ groupId?: string;
12
+ whitelist?: string[];
13
+ forceIPv4?: boolean;
14
+ [key: string]: unknown;
15
+ }
16
+ interface SessionData {
17
+ id: string;
18
+ token: string;
19
+ tmuxSession?: string;
20
+ expiresAt: number;
21
+ [key: string]: unknown;
22
+ }
23
+ interface TelegramMessage {
24
+ chat: {
25
+ id: number;
26
+ };
27
+ from: {
28
+ id: number;
29
+ };
30
+ text?: string;
31
+ }
32
+ interface TelegramCallbackQuery {
33
+ id: string;
34
+ message: {
35
+ chat: {
36
+ id: number;
37
+ };
38
+ };
39
+ data: string;
40
+ }
41
+ interface NetworkOptions {
42
+ family?: number;
43
+ }
44
+ declare class TelegramWebhookHandler {
45
+ config: WebhookConfig;
46
+ logger: Logger;
47
+ sessionsDir: string;
48
+ injector: ControllerInjector;
49
+ app: any;
50
+ apiBaseUrl: string;
51
+ botUsername: string | null;
52
+ constructor(config?: WebhookConfig);
53
+ _setupMiddleware(): void;
54
+ _setupRoutes(): void;
55
+ /**
56
+ * Generate network options for HTTP requests
57
+ */
58
+ _getNetworkOptions(): NetworkOptions;
59
+ _handleWebhook(req: any, res: any): Promise<void>;
60
+ _handleMessage(message: TelegramMessage): Promise<void>;
61
+ _processCommand(chatId: number, token: string, command: string): Promise<void>;
62
+ _handleCallbackQuery(callbackQuery: TelegramCallbackQuery): Promise<void>;
63
+ _sendWelcomeMessage(chatId: number): Promise<void>;
64
+ _sendHelpMessage(chatId: number): Promise<void>;
65
+ _isAuthorized(userId: number, chatId: number): boolean;
66
+ _getBotUsername(): Promise<string>;
67
+ _findSessionByToken(token: string): Promise<SessionData | null>;
68
+ _removeSession(sessionId: string): Promise<void>;
69
+ _sendMessage(chatId: number, text: string, options?: Record<string, unknown>): Promise<void>;
70
+ _answerCallbackQuery(callbackQueryId: string, text?: string): Promise<void>;
71
+ setWebhook(webhookUrl: string): Promise<unknown>;
72
+ start(port?: number): void;
73
+ }
74
+ export = TelegramWebhookHandler;
75
+ //# sourceMappingURL=webhook.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"webhook.d.ts","sourceRoot":"","sources":["../../../../src/channels/telegram/webhook.ts"],"names":[],"mappings":"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"}