ccbot 1.2.0 → 1.3.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 (63) hide show
  1. package/dist/channel/telegram/telegram-channel.d.ts +18 -0
  2. package/dist/channel/telegram/telegram-channel.js +148 -0
  3. package/dist/channel/telegram/telegram-channel.js.map +1 -0
  4. package/dist/channel/telegram/telegram-sender.d.ts +2 -0
  5. package/dist/channel/telegram/telegram-sender.js +72 -0
  6. package/dist/channel/telegram/telegram-sender.js.map +1 -0
  7. package/dist/channel/types.d.ts +20 -0
  8. package/dist/channel/types.js +2 -0
  9. package/dist/channel/types.js.map +1 -0
  10. package/dist/commands/help.js +1 -0
  11. package/dist/commands/help.js.map +1 -0
  12. package/dist/commands/setup.js +10 -19
  13. package/dist/commands/setup.js.map +1 -0
  14. package/dist/commands/uninstall.js +3 -3
  15. package/dist/commands/uninstall.js.map +1 -0
  16. package/dist/commands/update.js +69 -20
  17. package/dist/commands/update.js.map +1 -0
  18. package/dist/config-manager.d.ts +5 -2
  19. package/dist/config-manager.js +32 -15
  20. package/dist/config-manager.js.map +1 -0
  21. package/dist/hook/hook-handler.d.ts +3 -7
  22. package/dist/hook/hook-handler.js +29 -111
  23. package/dist/hook/hook-handler.js.map +1 -0
  24. package/dist/hook/hook-installer.d.ts +0 -3
  25. package/dist/hook/hook-installer.js +28 -26
  26. package/dist/hook/hook-installer.js.map +1 -0
  27. package/dist/hook/hook-server.js +11 -14
  28. package/dist/hook/hook-server.js.map +1 -0
  29. package/dist/i18n/index.js +1 -0
  30. package/dist/i18n/index.js.map +1 -0
  31. package/dist/i18n/locales/en.js +19 -13
  32. package/dist/i18n/locales/en.js.map +1 -0
  33. package/dist/i18n/locales/vi.js +19 -13
  34. package/dist/i18n/locales/vi.js.map +1 -0
  35. package/dist/i18n/locales/zh.js +19 -13
  36. package/dist/i18n/locales/zh.js.map +1 -0
  37. package/dist/i18n/types.d.ts +10 -5
  38. package/dist/i18n/types.js +1 -0
  39. package/dist/i18n/types.js.map +1 -0
  40. package/dist/index.js +22 -16
  41. package/dist/index.js.map +1 -0
  42. package/dist/monitor/git-collector.d.ts +2 -0
  43. package/dist/monitor/git-collector.js +88 -0
  44. package/dist/monitor/git-collector.js.map +1 -0
  45. package/dist/monitor/transcript-parser.js +6 -11
  46. package/dist/monitor/transcript-parser.js.map +1 -0
  47. package/dist/utils/constants.d.ts +21 -0
  48. package/dist/utils/constants.js +21 -0
  49. package/dist/utils/constants.js.map +1 -0
  50. package/dist/utils/install-detection.js +6 -5
  51. package/dist/utils/install-detection.js.map +1 -0
  52. package/dist/utils/log.d.ts +1 -1
  53. package/dist/utils/log.js +11 -2
  54. package/dist/utils/log.js.map +1 -0
  55. package/dist/utils/paths.d.ts +15 -0
  56. package/dist/utils/paths.js +38 -0
  57. package/dist/utils/paths.js.map +1 -0
  58. package/dist/utils/response-store.d.ts +4 -2
  59. package/dist/utils/response-store.js +34 -18
  60. package/dist/utils/response-store.js.map +1 -0
  61. package/dist/utils/tunnel.js +5 -3
  62. package/dist/utils/tunnel.js.map +1 -0
  63. package/package.json +30 -12
@@ -0,0 +1,38 @@
1
+ import { join, dirname, basename } from "node:path";
2
+ import { homedir } from "node:os";
3
+ import { fileURLToPath } from "node:url";
4
+ import { readFileSync } from "node:fs";
5
+ const MODULE_DIR = dirname(fileURLToPath(import.meta.url));
6
+ const PROJECT_ROOT = join(MODULE_DIR, "..", "..");
7
+ const CCBOT_HOME = join(homedir(), ".ccbot");
8
+ const CLAUDE_HOME = join(homedir(), ".claude");
9
+ export const paths = {
10
+ projectRoot: PROJECT_ROOT,
11
+ packageJson: join(PROJECT_ROOT, "package.json"),
12
+ ccbotDir: CCBOT_HOME,
13
+ configFile: join(CCBOT_HOME, "config.json"),
14
+ stateFile: join(CCBOT_HOME, "state.json"),
15
+ hooksDir: join(CCBOT_HOME, "hooks"),
16
+ hookScript: join(CCBOT_HOME, "hooks", process.platform === "win32" ? "stop-notify.cmd" : "stop-notify.sh"),
17
+ responsesDir: join(CCBOT_HOME, "responses"),
18
+ claudeDir: CLAUDE_HOME,
19
+ claudeSettings: join(CLAUDE_HOME, "settings.json"),
20
+ };
21
+ export function getPackageVersion() {
22
+ try {
23
+ return JSON.parse(readFileSync(paths.packageJson, "utf-8")).version;
24
+ }
25
+ catch {
26
+ return "unknown";
27
+ }
28
+ }
29
+ export function expandHome(filepath) {
30
+ if (filepath.startsWith("~/")) {
31
+ return join(homedir(), filepath.slice(2));
32
+ }
33
+ return filepath;
34
+ }
35
+ export function extractProjectName(cwd) {
36
+ return basename(cwd);
37
+ }
38
+ //# sourceMappingURL=paths.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"paths.js","sourceRoot":"","sources":["../../src/utils/paths.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AACpD,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAClC,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AACzC,OAAO,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAEvC,MAAM,UAAU,GAAG,OAAO,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;AAC3D,MAAM,YAAY,GAAG,IAAI,CAAC,UAAU,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAElD,MAAM,UAAU,GAAG,IAAI,CAAC,OAAO,EAAE,EAAE,QAAQ,CAAC,CAAC;AAC7C,MAAM,WAAW,GAAG,IAAI,CAAC,OAAO,EAAE,EAAE,SAAS,CAAC,CAAC;AAE/C,MAAM,CAAC,MAAM,KAAK,GAAG;IACnB,WAAW,EAAE,YAAY;IAEzB,WAAW,EAAE,IAAI,CAAC,YAAY,EAAE,cAAc,CAAC;IAE/C,QAAQ,EAAE,UAAU;IACpB,UAAU,EAAE,IAAI,CAAC,UAAU,EAAE,aAAa,CAAC;IAC3C,SAAS,EAAE,IAAI,CAAC,UAAU,EAAE,YAAY,CAAC;IACzC,QAAQ,EAAE,IAAI,CAAC,UAAU,EAAE,OAAO,CAAC;IACnC,UAAU,EAAE,IAAI,CACd,UAAU,EACV,OAAO,EACP,OAAO,CAAC,QAAQ,KAAK,OAAO,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,gBAAgB,CACpE;IACD,YAAY,EAAE,IAAI,CAAC,UAAU,EAAE,WAAW,CAAC;IAE3C,SAAS,EAAE,WAAW;IACtB,cAAc,EAAE,IAAI,CAAC,WAAW,EAAE,eAAe,CAAC;CAC1C,CAAC;AAEX,MAAM,UAAU,iBAAiB;IAC/B,IAAI,CAAC;QACH,OAAO,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,KAAK,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC;IACtE,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,SAAS,CAAC;IACnB,CAAC;AACH,CAAC;AAED,MAAM,UAAU,UAAU,CAAC,QAAgB;IACzC,IAAI,QAAQ,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;QAC9B,OAAO,IAAI,CAAC,OAAO,EAAE,EAAE,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;IAC5C,CAAC;IACD,OAAO,QAAQ,CAAC;AAClB,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,GAAW;IAC5C,OAAO,QAAQ,CAAC,GAAG,CAAC,CAAC;AACvB,CAAC"}
@@ -1,3 +1,4 @@
1
+ import { type GitChangeStatus } from "./constants.js";
1
2
  export interface StoredResponse {
2
3
  id: string;
3
4
  projectName: string;
@@ -5,7 +6,7 @@ export interface StoredResponse {
5
6
  durationMs: number;
6
7
  gitChanges: Array<{
7
8
  file: string;
8
- status: string;
9
+ status: GitChangeStatus;
9
10
  }>;
10
11
  inputTokens: number;
11
12
  outputTokens: number;
@@ -15,7 +16,8 @@ export interface StoredResponse {
15
16
  }
16
17
  declare class ResponseStore {
17
18
  private responses;
18
- constructor();
19
+ private initialized;
20
+ private ensureInitialized;
19
21
  save(data: Omit<StoredResponse, "id" | "timestamp">): string;
20
22
  get(id: string): StoredResponse | undefined;
21
23
  private cleanup;
@@ -1,29 +1,37 @@
1
1
  import { randomUUID } from "node:crypto";
2
2
  import { readFileSync, writeFileSync, mkdirSync, readdirSync, unlinkSync } from "node:fs";
3
3
  import { join } from "node:path";
4
- import { homedir } from "node:os";
5
- const STORE_DIR = join(homedir(), ".ccbot", "responses");
6
- const MAX_RESPONSES = 100;
7
- const EXPIRE_MS = 24 * 60 * 60 * 1000;
4
+ import { paths } from "./paths.js";
5
+ import { MAX_STORED_RESPONSES, RESPONSE_EXPIRE_MS } from "./constants.js";
6
+ const STORE_DIR = paths.responsesDir;
8
7
  class ResponseStore {
9
8
  responses = new Map();
10
- constructor() {
9
+ initialized = false;
10
+ ensureInitialized() {
11
+ if (this.initialized)
12
+ return;
13
+ this.initialized = true;
11
14
  mkdirSync(STORE_DIR, { recursive: true });
12
15
  this.loadFromDisk();
13
16
  }
14
17
  save(data) {
18
+ this.ensureInitialized();
15
19
  this.cleanup();
16
- const id = randomUUID().slice(0, 8);
20
+ let id;
21
+ do {
22
+ id = randomUUID().slice(0, 8);
23
+ } while (this.responses.has(id));
17
24
  const entry = { ...data, id, timestamp: Date.now() };
18
25
  this.responses.set(id, entry);
19
26
  this.persistToDisk(id, entry);
20
27
  return id;
21
28
  }
22
29
  get(id) {
30
+ this.ensureInitialized();
23
31
  const entry = this.responses.get(id);
24
32
  if (!entry)
25
33
  return undefined;
26
- if (Date.now() - entry.timestamp > EXPIRE_MS) {
34
+ if (Date.now() - entry.timestamp > RESPONSE_EXPIRE_MS) {
27
35
  this.responses.delete(id);
28
36
  this.removeFromDisk(id);
29
37
  return undefined;
@@ -33,15 +41,14 @@ class ResponseStore {
33
41
  cleanup() {
34
42
  const now = Date.now();
35
43
  for (const [id, entry] of this.responses) {
36
- if (now - entry.timestamp > EXPIRE_MS) {
44
+ if (now - entry.timestamp > RESPONSE_EXPIRE_MS) {
37
45
  this.responses.delete(id);
38
46
  this.removeFromDisk(id);
39
47
  }
40
48
  }
41
- if (this.responses.size >= MAX_RESPONSES) {
42
- const sorted = [...this.responses.entries()]
43
- .sort((a, b) => b[1].timestamp - a[1].timestamp);
44
- const toRemove = sorted.slice(MAX_RESPONSES - 1);
49
+ if (this.responses.size >= MAX_STORED_RESPONSES) {
50
+ const sorted = [...this.responses.entries()].sort((a, b) => b[1].timestamp - a[1].timestamp);
51
+ const toRemove = sorted.slice(MAX_STORED_RESPONSES - 1);
45
52
  for (const [id] of toRemove) {
46
53
  this.responses.delete(id);
47
54
  this.removeFromDisk(id);
@@ -52,33 +59,42 @@ class ResponseStore {
52
59
  try {
53
60
  writeFileSync(join(STORE_DIR, `${id}.json`), JSON.stringify(entry), { mode: 0o600 });
54
61
  }
55
- catch { }
62
+ catch {
63
+ // disk persistence is best-effort
64
+ }
56
65
  }
57
66
  removeFromDisk(id) {
58
67
  try {
59
68
  unlinkSync(join(STORE_DIR, `${id}.json`));
60
69
  }
61
- catch { }
70
+ catch {
71
+ // file may already be removed
72
+ }
62
73
  }
63
74
  loadFromDisk() {
64
75
  try {
65
- const files = readdirSync(STORE_DIR).filter(f => f.endsWith(".json"));
76
+ const files = readdirSync(STORE_DIR).filter((f) => f.endsWith(".json"));
66
77
  const now = Date.now();
67
78
  for (const file of files) {
68
79
  try {
69
80
  const data = readFileSync(join(STORE_DIR, file), "utf-8");
70
81
  const entry = JSON.parse(data);
71
- if (entry.id && now - entry.timestamp < EXPIRE_MS) {
82
+ if (entry.id && now - entry.timestamp < RESPONSE_EXPIRE_MS) {
72
83
  this.responses.set(entry.id, entry);
73
84
  }
74
85
  else {
75
86
  this.removeFromDisk(entry.id || file.replace(".json", ""));
76
87
  }
77
88
  }
78
- catch { }
89
+ catch {
90
+ // skip corrupted entries
91
+ }
79
92
  }
80
93
  }
81
- catch { }
94
+ catch {
95
+ // store directory may not exist yet
96
+ }
82
97
  }
83
98
  }
84
99
  export const responseStore = new ResponseStore();
100
+ //# sourceMappingURL=response-store.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"response-store.js","sourceRoot":"","sources":["../../src/utils/response-store.ts"],"names":[],"mappings":"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"}
@@ -1,6 +1,7 @@
1
1
  import { existsSync } from "node:fs";
2
2
  import { t } from "../i18n/index.js";
3
- import { log } from "../utils/log.js";
3
+ import { log } from "./log.js";
4
+ import { TUNNEL_TIMEOUT_MS } from "./constants.js";
4
5
  export class TunnelManager {
5
6
  tunnel = null;
6
7
  url = null;
@@ -15,8 +16,8 @@ export class TunnelManager {
15
16
  const url = await new Promise((resolve, reject) => {
16
17
  const timeout = setTimeout(() => {
17
18
  tunnel.stop();
18
- reject(new Error("Tunnel connection timeout (30s)"));
19
- }, 30_000);
19
+ reject(new Error(t("tunnel.timeout", { seconds: TUNNEL_TIMEOUT_MS / 1000 })));
20
+ }, TUNNEL_TIMEOUT_MS);
20
21
  tunnel.once("url", (url) => {
21
22
  clearTimeout(timeout);
22
23
  resolve(url);
@@ -49,3 +50,4 @@ export class TunnelManager {
49
50
  }
50
51
  }
51
52
  }
53
+ //# sourceMappingURL=tunnel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tunnel.js","sourceRoot":"","sources":["../../src/utils/tunnel.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AACrC,OAAO,EAAE,CAAC,EAAE,MAAM,kBAAkB,CAAC;AACrC,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAEnD,MAAM,OAAO,aAAa;IAChB,MAAM,GAAmC,IAAI,CAAC;IAC9C,GAAG,GAAkB,IAAI,CAAC;IAElC,KAAK,CAAC,KAAK,CAAC,IAAY;QACtB,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,OAAO,EAAE,GAAG,MAAM,MAAM,CAAC,aAAa,CAAC,CAAC;QAE7D,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC;YACrB,GAAG,CAAC,CAAC,CAAC,mBAAmB,CAAC,CAAC,CAAC;YAC5B,MAAM,OAAO,CAAC,GAAG,CAAC,CAAC;YACnB,GAAG,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC;QAC7B,CAAC;QAED,MAAM,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,oBAAoB,IAAI,EAAE,CAAC,CAAC;QAExD,MAAM,GAAG,GAAG,MAAM,IAAI,OAAO,CAAS,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACxD,MAAM,OAAO,GAAG,UAAU,CAAC,GAAG,EAAE;gBAC9B,MAAM,CAAC,IAAI,EAAE,CAAC;gBACd,MAAM,CAAC,IAAI,KAAK,CAAC,CAAC,CAAC,gBAAgB,EAAE,EAAE,OAAO,EAAE,iBAAiB,GAAG,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;YAChF,CAAC,EAAE,iBAAiB,CAAC,CAAC;YAEtB,MAAM,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,GAAW,EAAE,EAAE;gBACjC,YAAY,CAAC,OAAO,CAAC,CAAC;gBACtB,OAAO,CAAC,GAAG,CAAC,CAAC;YACf,CAAC,CAAC,CAAC;YAEH,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,GAAU,EAAE,EAAE;gBAClC,YAAY,CAAC,OAAO,CAAC,CAAC;gBACtB,MAAM,CAAC,GAAG,CAAC,CAAC;YACd,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,GAAG,GAAG,GAAG,CAAC;QAEf,MAAM,CAAC,EAAE,CAAC,cAAc,EAAE,GAAG,EAAE;YAC7B,GAAG,CAAC,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC;QAChC,CAAC,CAAC,CAAC;QAEH,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,IAAmB,EAAE,EAAE;YACxC,GAAG,CAAC,CAAC,CAAC,eAAe,EAAE,EAAE,IAAI,EAAE,IAAI,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;YAC7C,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;YACnB,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC;QAClB,CAAC,CAAC,CAAC;QAEH,OAAO,GAAG,CAAC;IACb,CAAC;IAED,YAAY;QACV,OAAO,IAAI,CAAC,GAAG,CAAC;IAClB,CAAC;IAED,IAAI;QACF,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;YACnB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;YACnB,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC;QAClB,CAAC;IACH,CAAC;CACF"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "ccbot",
3
- "version": "1.2.0",
3
+ "version": "1.3.0",
4
4
  "description": "Claude Code Telegram Notification Bot — get notified when Claude Code completes a response",
5
5
  "type": "module",
6
6
  "license": "MIT",
@@ -41,15 +41,11 @@
41
41
  "bin": {
42
42
  "ccbot": "dist/index.js"
43
43
  },
44
- "scripts": {
45
- "build": "tsc",
46
- "prepublishOnly": "npm run build",
47
- "start": "node dist/index.js",
48
- "dev": "tsx src/index.ts",
49
- "setup": "tsx src/index.ts setup",
50
- "uninstall": "tsx src/index.ts uninstall",
51
- "help": "tsx src/index.ts help",
52
- "deploy:web": "gh-pages -d public"
44
+ "lint-staged": {
45
+ "src/**/*.ts": [
46
+ "eslint --fix",
47
+ "prettier --write"
48
+ ]
53
49
  },
54
50
  "dependencies": {
55
51
  "@clack/prompts": "^1.0.1",
@@ -58,11 +54,33 @@
58
54
  "node-telegram-bot-api": "^0.66.0"
59
55
  },
60
56
  "devDependencies": {
57
+ "@eslint/js": "^10.0.1",
61
58
  "@types/express": "^5.0.0",
62
59
  "@types/node": "^22.13.4",
63
60
  "@types/node-telegram-bot-api": "^0.64.8",
61
+ "eslint": "^10.0.0",
62
+ "eslint-config-prettier": "^10.1.8",
63
+ "eslint-plugin-prettier": "^5.5.5",
64
64
  "gh-pages": "^6.3.0",
65
+ "husky": "^9.1.7",
66
+ "lint-staged": "^16.2.7",
67
+ "prettier": "^3.8.1",
65
68
  "tsx": "^4.19.3",
66
- "typescript": "^5.7.3"
69
+ "typescript": "^5.7.3",
70
+ "typescript-eslint": "^8.56.0"
71
+ },
72
+ "scripts": {
73
+ "build": "tsc",
74
+ "start": "node dist/index.js",
75
+ "dev": "tsx src/index.ts",
76
+ "setup": "tsx src/index.ts setup",
77
+ "uninstall": "tsx src/index.ts uninstall",
78
+ "help": "tsx src/index.ts help",
79
+ "build:web": "cd web && npx astro build",
80
+ "deploy:web": "npm run build:web && gh-pages -d web/dist",
81
+ "lint": "eslint src/",
82
+ "lint:fix": "eslint src/ --fix",
83
+ "format": "prettier --write 'src/**/*.ts'",
84
+ "format:check": "prettier --check 'src/**/*.ts'"
67
85
  }
68
- }
86
+ }