ccpoke 1.4.2 → 1.5.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 (89) hide show
  1. package/README.en.md +26 -11
  2. package/README.md +26 -11
  3. package/dist/agent/agent-handler.d.ts +12 -0
  4. package/dist/agent/agent-handler.js +49 -0
  5. package/dist/agent/agent-handler.js.map +1 -0
  6. package/dist/agent/agent-registry.d.ts +9 -0
  7. package/dist/agent/agent-registry.js +24 -0
  8. package/dist/agent/agent-registry.js.map +1 -0
  9. package/dist/{hook/hook-installer.d.ts → agent/claude-code/claude-code-installer.d.ts} +2 -2
  10. package/dist/agent/claude-code/claude-code-installer.js +82 -0
  11. package/dist/agent/claude-code/claude-code-installer.js.map +1 -0
  12. package/dist/{monitor/transcript-parser.d.ts → agent/claude-code/claude-code-parser.d.ts} +6 -0
  13. package/dist/{monitor/transcript-parser.js → agent/claude-code/claude-code-parser.js} +10 -2
  14. package/dist/agent/claude-code/claude-code-parser.js.map +1 -0
  15. package/dist/agent/claude-code/claude-code-provider.d.ts +12 -0
  16. package/dist/agent/claude-code/claude-code-provider.js +72 -0
  17. package/dist/agent/claude-code/claude-code-provider.js.map +1 -0
  18. package/dist/agent/cursor/cursor-installer.d.ts +9 -0
  19. package/dist/agent/cursor/cursor-installer.js +89 -0
  20. package/dist/agent/cursor/cursor-installer.js.map +1 -0
  21. package/dist/agent/cursor/cursor-parser.d.ts +19 -0
  22. package/dist/agent/cursor/cursor-parser.js +61 -0
  23. package/dist/agent/cursor/cursor-parser.js.map +1 -0
  24. package/dist/agent/cursor/cursor-provider.d.ts +12 -0
  25. package/dist/agent/cursor/cursor-provider.js +72 -0
  26. package/dist/agent/cursor/cursor-provider.js.map +1 -0
  27. package/dist/agent/types.d.ts +27 -0
  28. package/dist/agent/types.js +11 -0
  29. package/dist/agent/types.js.map +1 -0
  30. package/dist/channel/telegram/telegram-channel.js +7 -90
  31. package/dist/channel/telegram/telegram-channel.js.map +1 -1
  32. package/dist/channel/types.d.ts +2 -0
  33. package/dist/commands/setup.js +83 -19
  34. package/dist/commands/setup.js.map +1 -1
  35. package/dist/commands/uninstall.js +12 -9
  36. package/dist/commands/uninstall.js.map +1 -1
  37. package/dist/config-manager.d.ts +2 -1
  38. package/dist/config-manager.js +21 -17
  39. package/dist/config-manager.js.map +1 -1
  40. package/dist/i18n/index.d.ts +7 -2
  41. package/dist/i18n/index.js +10 -5
  42. package/dist/i18n/index.js.map +1 -1
  43. package/dist/i18n/locales/en.js +11 -0
  44. package/dist/i18n/locales/en.js.map +1 -1
  45. package/dist/i18n/locales/vi.js +11 -0
  46. package/dist/i18n/locales/vi.js.map +1 -1
  47. package/dist/i18n/locales/zh.js +11 -0
  48. package/dist/i18n/locales/zh.js.map +1 -1
  49. package/dist/i18n/types.d.ts +11 -0
  50. package/dist/index.js +28 -8
  51. package/dist/index.js.map +1 -1
  52. package/dist/{hook/hook-server.d.ts → server/api-server.d.ts} +3 -3
  53. package/dist/{hook/hook-server.js → server/api-server.js} +6 -4
  54. package/dist/server/api-server.js.map +1 -0
  55. package/dist/utils/git-collector.js.map +1 -0
  56. package/dist/utils/markdown.d.ts +4 -0
  57. package/dist/utils/markdown.js +47 -0
  58. package/dist/utils/markdown.js.map +1 -0
  59. package/dist/utils/paths.d.ts +4 -1
  60. package/dist/utils/paths.js +5 -1
  61. package/dist/utils/paths.js.map +1 -1
  62. package/dist/utils/response-store.d.ts +2 -0
  63. package/dist/utils/response-store.js.map +1 -1
  64. package/dist/utils/stats-format.d.ts +3 -0
  65. package/dist/utils/stats-format.js +44 -0
  66. package/dist/utils/stats-format.js.map +1 -0
  67. package/package.json +4 -1
  68. package/dist/hook/hook-handler.d.ts +0 -10
  69. package/dist/hook/hook-handler.js +0 -76
  70. package/dist/hook/hook-handler.js.map +0 -1
  71. package/dist/hook/hook-installer.js +0 -110
  72. package/dist/hook/hook-installer.js.map +0 -1
  73. package/dist/hook/hook-server.js.map +0 -1
  74. package/dist/hook/response-store.d.ts +0 -8
  75. package/dist/hook/response-store.js +0 -18
  76. package/dist/monitor/git-collector.js.map +0 -1
  77. package/dist/monitor/transcript-parser.js.map +0 -1
  78. package/dist/setup.d.ts +0 -1
  79. package/dist/setup.js +0 -130
  80. package/dist/telegram/bot.d.ts +0 -20
  81. package/dist/telegram/bot.js +0 -130
  82. package/dist/telegram/message-formatter.d.ts +0 -18
  83. package/dist/telegram/message-formatter.js +0 -56
  84. package/dist/telegram/message-sender.d.ts +0 -2
  85. package/dist/telegram/message-sender.js +0 -76
  86. package/dist/utils/error-utils.d.ts +0 -1
  87. package/dist/utils/error-utils.js +0 -3
  88. /package/dist/{monitor → utils}/git-collector.d.ts +0 -0
  89. /package/dist/{monitor → utils}/git-collector.js +0 -0
@@ -1 +1 @@
1
- {"version":3,"file":"response-store.js","sourceRoot":"","sources":["../../src/utils/response-store.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"response-store.js","sourceRoot":"","sources":["../../src/utils/response-store.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ export declare function formatModelName(model: string): string;
2
+ export declare function formatDuration(ms: number): string;
3
+ export declare function formatTokenCount(tokens: number): string;
@@ -0,0 +1,44 @@
1
+ const MODEL_PROVIDER_PREFIXES = {
2
+ "claude-": "",
3
+ "gpt-": "GPT-",
4
+ "gemini-": "Gemini ",
5
+ "deepseek-": "DeepSeek ",
6
+ "mistral-": "Mistral ",
7
+ "codestral-": "Codestral ",
8
+ "grok-": "Grok ",
9
+ "moonshot-": "Moonshot ",
10
+ "qwen-": "Qwen ",
11
+ };
12
+ function prettifyModelSegment(segment) {
13
+ return segment
14
+ .replace(/-/g, " ")
15
+ .replace(/(\d+)\s(\d+)/g, "$1.$2")
16
+ .replace(/(^| )[a-z]/g, (c) => c.toUpperCase());
17
+ }
18
+ export function formatModelName(model) {
19
+ const dashIndex = model.indexOf("-");
20
+ if (dashIndex === -1)
21
+ return prettifyModelSegment(model);
22
+ const prefix = model.slice(0, dashIndex + 1);
23
+ const display = MODEL_PROVIDER_PREFIXES[prefix];
24
+ if (display === undefined)
25
+ return prettifyModelSegment(model);
26
+ const rest = model.slice(dashIndex + 1);
27
+ return rest ? `${display}${prettifyModelSegment(rest)}` : model;
28
+ }
29
+ export function formatDuration(ms) {
30
+ const totalSeconds = Math.floor(ms / 1000);
31
+ if (totalSeconds < 60)
32
+ return `${totalSeconds}s`;
33
+ const minutes = Math.floor(totalSeconds / 60);
34
+ const seconds = totalSeconds % 60;
35
+ return `${minutes}m${seconds}s`;
36
+ }
37
+ export function formatTokenCount(tokens) {
38
+ if (tokens >= 1_000_000)
39
+ return `${(tokens / 1_000_000).toFixed(1)}M`;
40
+ if (tokens >= 1_000)
41
+ return `${(tokens / 1_000).toFixed(1)}k`;
42
+ return `${tokens}`;
43
+ }
44
+ //# sourceMappingURL=stats-format.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stats-format.js","sourceRoot":"","sources":["../../src/utils/stats-format.ts"],"names":[],"mappings":"AAAA,MAAM,uBAAuB,GAA2B;IACtD,SAAS,EAAE,EAAE;IACb,MAAM,EAAE,MAAM;IACd,SAAS,EAAE,SAAS;IACpB,WAAW,EAAE,WAAW;IACxB,UAAU,EAAE,UAAU;IACtB,YAAY,EAAE,YAAY;IAC1B,OAAO,EAAE,OAAO;IAChB,WAAW,EAAE,WAAW;IACxB,OAAO,EAAE,OAAO;CACjB,CAAC;AAEF,SAAS,oBAAoB,CAAC,OAAe;IAC3C,OAAO,OAAO;SACX,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC;SAClB,OAAO,CAAC,eAAe,EAAE,OAAO,CAAC;SACjC,OAAO,CAAC,aAAa,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC;AACpD,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,KAAa;IAC3C,MAAM,SAAS,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;IACrC,IAAI,SAAS,KAAK,CAAC,CAAC;QAAE,OAAO,oBAAoB,CAAC,KAAK,CAAC,CAAC;IAEzD,MAAM,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,SAAS,GAAG,CAAC,CAAC,CAAC;IAC7C,MAAM,OAAO,GAAG,uBAAuB,CAAC,MAAM,CAAC,CAAC;IAChD,IAAI,OAAO,KAAK,SAAS;QAAE,OAAO,oBAAoB,CAAC,KAAK,CAAC,CAAC;IAE9D,MAAM,IAAI,GAAG,KAAK,CAAC,KAAK,CAAC,SAAS,GAAG,CAAC,CAAC,CAAC;IACxC,OAAO,IAAI,CAAC,CAAC,CAAC,GAAG,OAAO,GAAG,oBAAoB,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC;AAClE,CAAC;AAED,MAAM,UAAU,cAAc,CAAC,EAAU;IACvC,MAAM,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,GAAG,IAAI,CAAC,CAAC;IAC3C,IAAI,YAAY,GAAG,EAAE;QAAE,OAAO,GAAG,YAAY,GAAG,CAAC;IACjD,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,GAAG,EAAE,CAAC,CAAC;IAC9C,MAAM,OAAO,GAAG,YAAY,GAAG,EAAE,CAAC;IAClC,OAAO,GAAG,OAAO,IAAI,OAAO,GAAG,CAAC;AAClC,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,MAAc;IAC7C,IAAI,MAAM,IAAI,SAAS;QAAE,OAAO,GAAG,CAAC,MAAM,GAAG,SAAS,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC;IACtE,IAAI,MAAM,IAAI,KAAK;QAAE,OAAO,GAAG,CAAC,MAAM,GAAG,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC;IAC9D,OAAO,GAAG,MAAM,EAAE,CAAC;AACrB,CAAC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "ccpoke",
3
- "version": "1.4.2",
3
+ "version": "1.5.0",
4
4
  "description": "Your AI agent pokes you when it's done — zero-config, one command: npx ccpoke",
5
5
  "type": "module",
6
6
  "license": "MIT",
@@ -19,6 +19,9 @@
19
19
  "keywords": [
20
20
  "claude",
21
21
  "claude-code",
22
+ "cursor",
23
+ "codex",
24
+ "ai-agent",
22
25
  "telegram",
23
26
  "notification",
24
27
  "bot",
@@ -1,10 +0,0 @@
1
- import type { NotificationChannel } from "../channel/types.js";
2
- import type { TunnelManager } from "../utils/tunnel.js";
3
- export declare class HookHandler {
4
- private channel;
5
- private hookPort;
6
- private tunnelManager;
7
- constructor(channel: NotificationChannel, hookPort: number, tunnelManager: TunnelManager);
8
- handleStopEvent(event: unknown): Promise<void>;
9
- private buildResponseUrl;
10
- }
@@ -1,76 +0,0 @@
1
- import { parseTranscript } from "../monitor/transcript-parser.js";
2
- import { collectGitChanges } from "../monitor/git-collector.js";
3
- import { MINI_APP_BASE_URL, TRANSCRIPT_SETTLE_DELAY_MS, DEFAULT_FALLBACK_DURATION_MS, } from "../utils/constants.js";
4
- import { t } from "../i18n/index.js";
5
- import { responseStore } from "../utils/response-store.js";
6
- import { log, logError } from "../utils/log.js";
7
- import { extractProjectName } from "../utils/paths.js";
8
- function isValidStopEvent(data) {
9
- if (typeof data !== "object" || data === null)
10
- return false;
11
- const obj = data;
12
- return (typeof obj.session_id === "string" &&
13
- typeof obj.transcript_path === "string" &&
14
- typeof obj.cwd === "string");
15
- }
16
- export class HookHandler {
17
- channel;
18
- hookPort;
19
- tunnelManager;
20
- constructor(channel, hookPort, tunnelManager) {
21
- this.channel = channel;
22
- this.hookPort = hookPort;
23
- this.tunnelManager = tunnelManager;
24
- }
25
- async handleStopEvent(event) {
26
- if (!isValidStopEvent(event)) {
27
- log(t("hook.invalidPayload"));
28
- return;
29
- }
30
- log(t("hook.stopEventReceived", { sessionId: event.session_id, cwd: event.cwd }));
31
- await new Promise((resolve) => setTimeout(resolve, TRANSCRIPT_SETTLE_DELAY_MS));
32
- let summary = {
33
- lastAssistantMessage: "",
34
- durationMs: 0,
35
- inputTokens: 0,
36
- outputTokens: 0,
37
- model: "",
38
- };
39
- try {
40
- summary = parseTranscript(event.transcript_path);
41
- }
42
- catch (err) {
43
- logError(t("hook.transcriptFailed"), err);
44
- }
45
- const gitChanges = collectGitChanges(event.cwd);
46
- let durationMs = Math.max(0, summary.durationMs);
47
- if (durationMs === 0 && summary.lastAssistantMessage) {
48
- durationMs = DEFAULT_FALLBACK_DURATION_MS;
49
- }
50
- const data = {
51
- projectName: extractProjectName(event.cwd),
52
- responseSummary: summary.lastAssistantMessage,
53
- durationMs,
54
- gitChanges,
55
- inputTokens: summary.inputTokens,
56
- outputTokens: summary.outputTokens,
57
- model: summary.model,
58
- };
59
- const responseUrl = this.buildResponseUrl(data);
60
- this.channel.sendNotification(data, responseUrl).catch((err) => {
61
- logError(t("hook.notificationFailed"), err);
62
- });
63
- }
64
- buildResponseUrl(data) {
65
- const id = responseStore.save(data);
66
- const apiBase = this.tunnelManager.getPublicUrl() || `http://localhost:${this.hookPort}`;
67
- const params = new URLSearchParams({
68
- id,
69
- api: apiBase,
70
- p: data.projectName,
71
- d: String(data.durationMs),
72
- });
73
- return `${MINI_APP_BASE_URL}/response/?${params.toString()}`;
74
- }
75
- }
76
- //# sourceMappingURL=hook-handler.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"hook-handler.js","sourceRoot":"","sources":["../../src/hook/hook-handler.ts"],"names":[],"mappings":"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"}
@@ -1,110 +0,0 @@
1
- import { readFileSync, writeFileSync, mkdirSync, unlinkSync, rmSync } from "node:fs";
2
- import { t } from "../i18n/index.js";
3
- import { paths } from "../utils/paths.js";
4
- import { ApiRoute } from "../utils/constants.js";
5
- export class HookInstaller {
6
- static isInstalled() {
7
- try {
8
- const settings = HookInstaller.readSettings();
9
- const hooks = (settings.hooks ?? {});
10
- const existingStop = (hooks.Stop ?? []);
11
- return existingStop.some((entry) => {
12
- const entryHooks = entry.hooks;
13
- return entryHooks?.some((h) => typeof h.command === "string" && h.command.includes("ccpoke"));
14
- });
15
- }
16
- catch {
17
- return false;
18
- }
19
- }
20
- static install(hookPort, hookSecret) {
21
- if (!Number.isInteger(hookPort) || hookPort < 1 || hookPort > 65535) {
22
- throw new Error(t("config.invalidHookPort", { port: hookPort }));
23
- }
24
- const settings = HookInstaller.readSettings();
25
- const hooks = (settings.hooks ?? {});
26
- const existingStop = (hooks.Stop ?? []);
27
- if (HookInstaller.isInstalled()) {
28
- throw new Error(t("config.hookAlreadyInstalled"));
29
- }
30
- existingStop.push({
31
- hooks: [{ type: "command", command: paths.hookScript, timeout: 10 }],
32
- });
33
- hooks.Stop = existingStop;
34
- settings.hooks = hooks;
35
- mkdirSync(paths.claudeDir, { recursive: true });
36
- writeFileSync(paths.claudeSettings, JSON.stringify(settings, null, 2));
37
- HookInstaller.installScript(hookPort, hookSecret);
38
- }
39
- static uninstall() {
40
- HookInstaller.removeFromSettings();
41
- HookInstaller.removeScript();
42
- }
43
- static installScript(hookPort, hookSecret) {
44
- mkdirSync(paths.hooksDir, { recursive: true });
45
- const isWindows = process.platform === "win32";
46
- const script = isWindows
47
- ? `@echo off\ncurl -s -X POST http://localhost:${hookPort}${ApiRoute.HookStop} -H "Content-Type: application/json" -H "X-CCPoke-Secret: ${hookSecret}" --data-binary @- > nul 2>&1\n`
48
- : `#!/bin/bash\ncurl -s -X POST http://localhost:${hookPort}${ApiRoute.HookStop} \\\n -H "Content-Type: application/json" \\\n -H "X-CCPoke-Secret: ${hookSecret}" \\\n --data-binary @- > /dev/null 2>&1 || true\n`;
49
- writeFileSync(paths.hookScript, script, { mode: isWindows ? 0o644 : 0o755 });
50
- }
51
- static removeScript() {
52
- try {
53
- unlinkSync(paths.hookScript);
54
- }
55
- catch {
56
- // script file may not exist
57
- }
58
- try {
59
- rmSync(paths.hooksDir, { recursive: true, force: true });
60
- }
61
- catch {
62
- // hooks directory may not exist
63
- }
64
- }
65
- static removeFromSettings() {
66
- let data;
67
- try {
68
- data = readFileSync(paths.claudeSettings, "utf-8");
69
- }
70
- catch {
71
- return;
72
- }
73
- const settings = JSON.parse(data);
74
- const hooks = settings.hooks;
75
- if (!hooks)
76
- return;
77
- const existingStop = hooks.Stop;
78
- if (!existingStop)
79
- return;
80
- const filtered = existingStop.filter((entry) => {
81
- const entryHooks = entry.hooks;
82
- return !entryHooks?.some((h) => typeof h.command === "string" && h.command.includes("ccpoke"));
83
- });
84
- if (filtered.length === 0) {
85
- delete hooks.Stop;
86
- }
87
- else {
88
- hooks.Stop = filtered;
89
- }
90
- if (Object.keys(hooks).length === 0) {
91
- delete settings.hooks;
92
- }
93
- writeFileSync(paths.claudeSettings, JSON.stringify(settings, null, 2));
94
- }
95
- static readSettings() {
96
- try {
97
- const data = readFileSync(paths.claudeSettings, "utf-8");
98
- return JSON.parse(data);
99
- }
100
- catch (err) {
101
- if (err instanceof Error &&
102
- "code" in err &&
103
- err.code === "ENOENT") {
104
- return {};
105
- }
106
- throw err;
107
- }
108
- }
109
- }
110
- //# sourceMappingURL=hook-installer.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"hook-installer.js","sourceRoot":"","sources":["../../src/hook/hook-installer.ts"],"names":[],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"hook-server.js","sourceRoot":"","sources":["../../src/hook/hook-server.ts"],"names":[],"mappings":"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"}
@@ -1,8 +0,0 @@
1
- import type { NotificationData } from "../telegram/message-formatter.js";
2
- interface StoredResponse extends NotificationData {
3
- id: string;
4
- timestamp: number;
5
- }
6
- export declare function storeResponse(data: NotificationData): string;
7
- export declare function getResponse(id: string): StoredResponse | undefined;
8
- export {};
@@ -1,18 +0,0 @@
1
- const MAX_RESPONSES = 50;
2
- const responses = new Map();
3
- let counter = 0;
4
- export function storeResponse(data) {
5
- const id = `${Date.now()}-${++counter}`;
6
- const stored = { ...data, id, timestamp: Date.now() };
7
- responses.set(id, stored);
8
- // Evict old entries
9
- if (responses.size > MAX_RESPONSES) {
10
- const oldest = responses.keys().next().value;
11
- if (oldest)
12
- responses.delete(oldest);
13
- }
14
- return id;
15
- }
16
- export function getResponse(id) {
17
- return responses.get(id);
18
- }
@@ -1 +0,0 @@
1
- {"version":3,"file":"git-collector.js","sourceRoot":"","sources":["../../src/monitor/git-collector.ts"],"names":[],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"transcript-parser.js","sourceRoot":"","sources":["../../src/monitor/transcript-parser.ts"],"names":[],"mappings":"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"}
package/dist/setup.d.ts DELETED
@@ -1 +0,0 @@
1
- export declare function runSetup(): Promise<void>;
package/dist/setup.js DELETED
@@ -1,130 +0,0 @@
1
- import { createInterface } from "node:readline";
2
- import { mkdirSync, writeFileSync, readFileSync } from "node:fs";
3
- import { join } from "node:path";
4
- import { homedir } from "node:os";
5
- import { ConfigManager } from "./config-manager.js";
6
- import { HookInstaller } from "./hook/hook-installer.js";
7
- import { formatError } from "./utils/error-utils.js";
8
- export async function runSetup() {
9
- console.log("🤖 ccbot setup");
10
- console.log("━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━");
11
- console.log();
12
- const rl = createInterface({ input: process.stdin, output: process.stdout });
13
- const question = (prompt) => new Promise((resolve) => rl.question(prompt, resolve));
14
- let existing = null;
15
- try {
16
- existing = ConfigManager.load();
17
- }
18
- catch { }
19
- try {
20
- const token = await promptBotToken(question, existing);
21
- const userId = await promptUserID(question, existing);
22
- const hookPort = existing?.hook_port || 9377;
23
- const hookSecret = existing?.hook_secret || ConfigManager.generateSecret();
24
- const cfg = {
25
- telegram_bot_token: token,
26
- user_id: userId,
27
- hook_port: hookPort,
28
- hook_secret: hookSecret,
29
- };
30
- ConfigManager.save(cfg);
31
- console.log("✅ Config saved");
32
- console.log();
33
- console.log("📎 Installing Claude Code hook...");
34
- try {
35
- HookInstaller.install(cfg.hook_port, cfg.hook_secret);
36
- console.log("✅ Hook installed → ~/.claude/settings.json");
37
- }
38
- catch (err) {
39
- const msg = formatError(err);
40
- if (msg.includes("already installed")) {
41
- console.log("✅ Hook already installed");
42
- }
43
- else {
44
- throw new Error(`install hook: ${msg}`);
45
- }
46
- }
47
- registerChatId(userId);
48
- const startCommand = detectStartCommand();
49
- console.log();
50
- console.log("━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━");
51
- console.log("🎉 Setup complete!");
52
- console.log();
53
- console.log("Next steps:");
54
- console.log(` 1. Start bot: ${startCommand}`);
55
- console.log(" 2. Use Claude Code normally → notifications will arrive");
56
- console.log();
57
- }
58
- finally {
59
- rl.close();
60
- }
61
- }
62
- async function promptBotToken(question, existing) {
63
- let hint = "";
64
- if (existing?.telegram_bot_token) {
65
- hint = ` [current: ${maskToken(existing.telegram_bot_token)}]`;
66
- }
67
- console.log(`Telegram Bot Token${hint}`);
68
- console.log(" (Get from @BotFather → /newbot)");
69
- const input = (await question(" → ")).trim();
70
- if (!input && existing?.telegram_bot_token) {
71
- return existing.telegram_bot_token;
72
- }
73
- if (!input) {
74
- throw new Error("bot token is required");
75
- }
76
- if (!input.includes(":")) {
77
- throw new Error("invalid bot token format (expected: 123456:ABC-xxx)");
78
- }
79
- return input;
80
- }
81
- async function promptUserID(question, existing) {
82
- let hint = "";
83
- if (existing?.user_id) {
84
- hint = ` [current: ${existing.user_id}]`;
85
- }
86
- console.log();
87
- console.log(`Your Telegram User ID${hint}`);
88
- console.log(" (Send /start to @userinfobot to get your ID)");
89
- const input = (await question(" → ")).trim();
90
- if (!input && existing?.user_id) {
91
- return existing.user_id;
92
- }
93
- if (!input) {
94
- throw new Error("user ID is required");
95
- }
96
- const id = parseInt(input, 10);
97
- if (isNaN(id)) {
98
- throw new Error("invalid user ID — must be a number");
99
- }
100
- return id;
101
- }
102
- function maskToken(token) {
103
- const parts = token.split(":");
104
- if (parts.length !== 2)
105
- return "***";
106
- const suffix = parts[1].length > 4 ? parts[1].slice(0, 4) + "..." : parts[1];
107
- return `***:${suffix}`;
108
- }
109
- function registerChatId(userId) {
110
- const stateDir = join(homedir(), ".ccbot");
111
- const stateFile = join(stateDir, "state.json");
112
- let state = { chat_id: null };
113
- try {
114
- const data = readFileSync(stateFile, "utf-8");
115
- state = JSON.parse(data);
116
- }
117
- catch { }
118
- if (state.chat_id === userId) {
119
- return;
120
- }
121
- state.chat_id = userId;
122
- mkdirSync(stateDir, { recursive: true });
123
- writeFileSync(stateFile, JSON.stringify(state, null, 2), { mode: 0o600 });
124
- console.log(`✅ Chat ID registered`);
125
- }
126
- function detectStartCommand() {
127
- const execPath = process.argv[1] ?? "";
128
- const isNpx = execPath.includes("npx") || execPath.includes(".npm/_npx");
129
- return isNpx ? "npx ccbot" : "ccbot";
130
- }
@@ -1,20 +0,0 @@
1
- import { type Config } from "../config-manager.js";
2
- export declare class Bot {
3
- private bot;
4
- private cfg;
5
- private chatId;
6
- private isDisconnected;
7
- private tunnelUrl;
8
- private static readonly STATE_DIR;
9
- private static readonly STATE_FILE;
10
- constructor(cfg: Config, tunnelUrl?: string | null);
11
- start(): Promise<void>;
12
- stop(): Promise<void>;
13
- sendNotification(text: string, responseUrl?: string): Promise<void>;
14
- private registerCommands;
15
- private registerMenuButton;
16
- private registerHandlers;
17
- private loadState;
18
- private saveState;
19
- private registerPollingErrorHandler;
20
- }
@@ -1,130 +0,0 @@
1
- import TelegramBot from "node-telegram-bot-api";
2
- import { readFileSync, writeFileSync, mkdirSync } from "node:fs";
3
- import { join } from "node:path";
4
- import { homedir } from "node:os";
5
- import { ConfigManager } from "../config-manager.js";
6
- import { sendMessage } from "./message-sender.js";
7
- import { formatError } from "../utils/error-utils.js";
8
- import { MINI_APP_BASE_URL } from "../utils/constants.js";
9
- import { t, getTranslations } from "../i18n/index.js";
10
- import { log } from "../utils/log.js";
11
- export class Bot {
12
- bot;
13
- cfg;
14
- chatId = null;
15
- isDisconnected = false;
16
- tunnelUrl;
17
- static STATE_DIR = join(homedir(), ".ccbot");
18
- static STATE_FILE = join(Bot.STATE_DIR, "state.json");
19
- constructor(cfg, tunnelUrl) {
20
- this.cfg = cfg;
21
- this.tunnelUrl = tunnelUrl ?? null;
22
- this.bot = new TelegramBot(cfg.telegram_bot_token, { polling: false });
23
- this.loadState();
24
- this.registerHandlers();
25
- this.registerPollingErrorHandler();
26
- }
27
- async start() {
28
- this.bot.startPolling();
29
- await this.registerCommands();
30
- await this.registerMenuButton();
31
- log(t("bot.telegramStarted"));
32
- }
33
- stop() {
34
- return new Promise((resolve) => {
35
- this.bot.stopPolling();
36
- resolve();
37
- });
38
- }
39
- async sendNotification(text, responseUrl) {
40
- if (!this.chatId) {
41
- log(t("bot.noChatId"));
42
- return;
43
- }
44
- try {
45
- await sendMessage(this.bot, this.chatId, text, responseUrl);
46
- }
47
- catch (err) {
48
- log(t("bot.notificationFailed", { error: formatError(err) }));
49
- }
50
- }
51
- async registerCommands() {
52
- const translations = getTranslations();
53
- const commands = [
54
- { command: "start", description: translations.bot.commands.start },
55
- ];
56
- try {
57
- await this.bot.setMyCommands(commands);
58
- log(t("bot.commandsRegistered"));
59
- }
60
- catch (err) {
61
- log(t("bot.commandsRegisterFailed", { error: formatError(err) }));
62
- }
63
- }
64
- async registerMenuButton() {
65
- const url = this.tunnelUrl ? `${this.tunnelUrl}/` : `${MINI_APP_BASE_URL}/`;
66
- try {
67
- await this.bot.setChatMenuButton({
68
- menu_button: JSON.stringify({
69
- type: "web_app",
70
- text: t("bot.dashboard"),
71
- web_app: { url },
72
- }),
73
- });
74
- log(t("bot.menuButtonRegistered"));
75
- }
76
- catch (err) {
77
- log(t("bot.menuButtonFailed", { error: formatError(err) }));
78
- }
79
- }
80
- registerHandlers() {
81
- this.bot.on("message", (msg) => {
82
- if (!ConfigManager.isOwner(this.cfg, msg.from?.id ?? 0)) {
83
- log(t("bot.unauthorizedUser", {
84
- userId: msg.from?.id ?? 0,
85
- username: msg.from?.username ?? "",
86
- }));
87
- return;
88
- }
89
- const text = msg.text ?? "";
90
- if (text === "/start") {
91
- if (this.chatId === msg.chat.id) {
92
- this.bot.sendMessage(msg.chat.id, t("bot.alreadyConnected"));
93
- return;
94
- }
95
- this.chatId = msg.chat.id;
96
- this.saveState();
97
- log(t("bot.registeredChatId", { chatId: msg.chat.id }));
98
- this.bot.sendMessage(msg.chat.id, t("bot.ready"), { parse_mode: "MarkdownV2" });
99
- return;
100
- }
101
- });
102
- }
103
- loadState() {
104
- try {
105
- const data = readFileSync(Bot.STATE_FILE, "utf-8");
106
- const state = JSON.parse(data);
107
- this.chatId = state.chat_id ?? null;
108
- }
109
- catch { }
110
- }
111
- saveState() {
112
- const state = { chat_id: this.chatId };
113
- mkdirSync(Bot.STATE_DIR, { recursive: true });
114
- writeFileSync(Bot.STATE_FILE, JSON.stringify(state, null, 2), { mode: 0o600 });
115
- }
116
- registerPollingErrorHandler() {
117
- this.bot.on("polling_error", (err) => {
118
- if (!this.isDisconnected) {
119
- this.isDisconnected = true;
120
- log(t("bot.connectionLost"));
121
- }
122
- });
123
- this.bot.on("polling", () => {
124
- if (this.isDisconnected) {
125
- this.isDisconnected = false;
126
- log(t("bot.connectionRestored"));
127
- }
128
- });
129
- }
130
- }