claude-ketchup 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +544 -0
- package/bin/cli.ts +6 -0
- package/bin/postinstall.ts +5 -0
- package/bin/preuninstall.ts +5 -0
- package/commands/ketchup.md +107 -0
- package/dist/bin/cli.d.ts +3 -0
- package/dist/bin/cli.d.ts.map +1 -0
- package/dist/bin/cli.js +7 -0
- package/dist/bin/cli.js.map +1 -0
- package/dist/bin/postinstall.d.ts +3 -0
- package/dist/bin/postinstall.d.ts.map +1 -0
- package/dist/bin/postinstall.js +6 -0
- package/dist/bin/postinstall.js.map +1 -0
- package/dist/bin/preuninstall.d.ts +3 -0
- package/dist/bin/preuninstall.d.ts.map +1 -0
- package/dist/bin/preuninstall.js +6 -0
- package/dist/bin/preuninstall.js.map +1 -0
- package/dist/scripts/pre-tool-use.d.ts +3 -0
- package/dist/scripts/pre-tool-use.d.ts.map +1 -0
- package/dist/scripts/pre-tool-use.js +43 -0
- package/dist/scripts/pre-tool-use.js.map +1 -0
- package/dist/scripts/session-start.d.ts +3 -0
- package/dist/scripts/session-start.d.ts.map +1 -0
- package/dist/scripts/session-start.js +42 -0
- package/dist/scripts/session-start.js.map +1 -0
- package/dist/scripts/user-prompt-submit.d.ts +3 -0
- package/dist/scripts/user-prompt-submit.d.ts.map +1 -0
- package/dist/scripts/user-prompt-submit.js +43 -0
- package/dist/scripts/user-prompt-submit.js.map +1 -0
- package/dist/src/clean-logs.d.ts +6 -0
- package/dist/src/clean-logs.d.ts.map +1 -0
- package/dist/src/clean-logs.js +38 -0
- package/dist/src/clean-logs.js.map +1 -0
- package/dist/src/clean-logs.test.d.ts +2 -0
- package/dist/src/clean-logs.test.d.ts.map +1 -0
- package/dist/src/clean-logs.test.js +101 -0
- package/dist/src/clean-logs.test.js.map +1 -0
- package/dist/src/cli/cli.d.ts +3 -0
- package/dist/src/cli/cli.d.ts.map +1 -0
- package/dist/src/cli/cli.js +24 -0
- package/dist/src/cli/cli.js.map +1 -0
- package/dist/src/cli/cli.test.d.ts +2 -0
- package/dist/src/cli/cli.test.d.ts.map +1 -0
- package/dist/src/cli/cli.test.js +20 -0
- package/dist/src/cli/cli.test.js.map +1 -0
- package/dist/src/cli/doctor.d.ts +7 -0
- package/dist/src/cli/doctor.d.ts.map +1 -0
- package/dist/src/cli/doctor.js +52 -0
- package/dist/src/cli/doctor.js.map +1 -0
- package/dist/src/cli/doctor.test.d.ts +2 -0
- package/dist/src/cli/doctor.test.d.ts.map +1 -0
- package/dist/src/cli/doctor.test.js +77 -0
- package/dist/src/cli/doctor.test.js.map +1 -0
- package/dist/src/cli/repair.d.ts +7 -0
- package/dist/src/cli/repair.d.ts.map +1 -0
- package/dist/src/cli/repair.js +67 -0
- package/dist/src/cli/repair.js.map +1 -0
- package/dist/src/cli/repair.test.d.ts +2 -0
- package/dist/src/cli/repair.test.d.ts.map +1 -0
- package/dist/src/cli/repair.test.js +72 -0
- package/dist/src/cli/repair.test.js.map +1 -0
- package/dist/src/cli/skills.d.ts +11 -0
- package/dist/src/cli/skills.d.ts.map +1 -0
- package/dist/src/cli/skills.js +53 -0
- package/dist/src/cli/skills.js.map +1 -0
- package/dist/src/cli/skills.test.d.ts +2 -0
- package/dist/src/cli/skills.test.d.ts.map +1 -0
- package/dist/src/cli/skills.test.js +89 -0
- package/dist/src/cli/skills.test.js.map +1 -0
- package/dist/src/cli/status.d.ts +10 -0
- package/dist/src/cli/status.d.ts.map +1 -0
- package/dist/src/cli/status.js +63 -0
- package/dist/src/cli/status.js.map +1 -0
- package/dist/src/cli/status.test.d.ts +2 -0
- package/dist/src/cli/status.test.d.ts.map +1 -0
- package/dist/src/cli/status.test.js +70 -0
- package/dist/src/cli/status.test.js.map +1 -0
- package/dist/src/clue-collector.d.ts +23 -0
- package/dist/src/clue-collector.d.ts.map +1 -0
- package/dist/src/clue-collector.js +226 -0
- package/dist/src/clue-collector.js.map +1 -0
- package/dist/src/clue-collector.test.d.ts +2 -0
- package/dist/src/clue-collector.test.d.ts.map +1 -0
- package/dist/src/clue-collector.test.js +213 -0
- package/dist/src/clue-collector.test.js.map +1 -0
- package/dist/src/debug-logger.d.ts +2 -0
- package/dist/src/debug-logger.d.ts.map +1 -0
- package/dist/src/debug-logger.js +23 -0
- package/dist/src/debug-logger.js.map +1 -0
- package/dist/src/debug-logger.test.d.ts +2 -0
- package/dist/src/debug-logger.test.d.ts.map +1 -0
- package/dist/src/debug-logger.test.js +63 -0
- package/dist/src/debug-logger.test.js.map +1 -0
- package/dist/src/deny-list.d.ts +3 -0
- package/dist/src/deny-list.d.ts.map +1 -0
- package/dist/src/deny-list.js +62 -0
- package/dist/src/deny-list.js.map +1 -0
- package/dist/src/deny-list.test.d.ts +2 -0
- package/dist/src/deny-list.test.d.ts.map +1 -0
- package/dist/src/deny-list.test.js +93 -0
- package/dist/src/deny-list.test.js.map +1 -0
- package/dist/src/e2e.test.d.ts +2 -0
- package/dist/src/e2e.test.d.ts.map +1 -0
- package/dist/src/e2e.test.js +88 -0
- package/dist/src/e2e.test.js.map +1 -0
- package/dist/src/gitignore-manager.d.ts +2 -0
- package/dist/src/gitignore-manager.d.ts.map +1 -0
- package/dist/src/gitignore-manager.js +45 -0
- package/dist/src/gitignore-manager.js.map +1 -0
- package/dist/src/gitignore-manager.test.d.ts +2 -0
- package/dist/src/gitignore-manager.test.d.ts.map +1 -0
- package/dist/src/gitignore-manager.test.js +70 -0
- package/dist/src/gitignore-manager.test.js.map +1 -0
- package/dist/src/hook-state.d.ts +43 -0
- package/dist/src/hook-state.d.ts.map +1 -0
- package/dist/src/hook-state.js +124 -0
- package/dist/src/hook-state.js.map +1 -0
- package/dist/src/hook-state.test.d.ts +2 -0
- package/dist/src/hook-state.test.d.ts.map +1 -0
- package/dist/src/hook-state.test.js +190 -0
- package/dist/src/hook-state.test.js.map +1 -0
- package/dist/src/hooks/auto-continue.d.ts +9 -0
- package/dist/src/hooks/auto-continue.d.ts.map +1 -0
- package/dist/src/hooks/auto-continue.js +56 -0
- package/dist/src/hooks/auto-continue.js.map +1 -0
- package/dist/src/hooks/auto-continue.test.d.ts +2 -0
- package/dist/src/hooks/auto-continue.test.d.ts.map +1 -0
- package/dist/src/hooks/auto-continue.test.js +141 -0
- package/dist/src/hooks/auto-continue.test.js.map +1 -0
- package/dist/src/hooks/pre-tool-use.d.ts +8 -0
- package/dist/src/hooks/pre-tool-use.d.ts.map +1 -0
- package/dist/src/hooks/pre-tool-use.js +19 -0
- package/dist/src/hooks/pre-tool-use.js.map +1 -0
- package/dist/src/hooks/pre-tool-use.test.d.ts +2 -0
- package/dist/src/hooks/pre-tool-use.test.d.ts.map +1 -0
- package/dist/src/hooks/pre-tool-use.test.js +84 -0
- package/dist/src/hooks/pre-tool-use.test.js.map +1 -0
- package/dist/src/hooks/session-start.d.ts +6 -0
- package/dist/src/hooks/session-start.d.ts.map +1 -0
- package/dist/src/hooks/session-start.js +49 -0
- package/dist/src/hooks/session-start.js.map +1 -0
- package/dist/src/hooks/session-start.test.d.ts +2 -0
- package/dist/src/hooks/session-start.test.d.ts.map +1 -0
- package/dist/src/hooks/session-start.test.js +96 -0
- package/dist/src/hooks/session-start.test.js.map +1 -0
- package/dist/src/hooks/user-prompt-submit.d.ts +6 -0
- package/dist/src/hooks/user-prompt-submit.d.ts.map +1 -0
- package/dist/src/hooks/user-prompt-submit.js +54 -0
- package/dist/src/hooks/user-prompt-submit.js.map +1 -0
- package/dist/src/hooks/user-prompt-submit.test.d.ts +2 -0
- package/dist/src/hooks/user-prompt-submit.test.d.ts.map +1 -0
- package/dist/src/hooks/user-prompt-submit.test.js +92 -0
- package/dist/src/hooks/user-prompt-submit.test.js.map +1 -0
- package/dist/src/hooks/validate-commit.d.ts +12 -0
- package/dist/src/hooks/validate-commit.d.ts.map +1 -0
- package/dist/src/hooks/validate-commit.js +58 -0
- package/dist/src/hooks/validate-commit.js.map +1 -0
- package/dist/src/hooks/validate-commit.test.d.ts +2 -0
- package/dist/src/hooks/validate-commit.test.d.ts.map +1 -0
- package/dist/src/hooks/validate-commit.test.js +150 -0
- package/dist/src/hooks/validate-commit.test.js.map +1 -0
- package/dist/src/index.d.ts +13 -0
- package/dist/src/index.d.ts.map +1 -0
- package/dist/src/index.js +38 -0
- package/dist/src/index.js.map +1 -0
- package/dist/src/linker.d.ts +6 -0
- package/dist/src/linker.d.ts.map +1 -0
- package/dist/src/linker.js +78 -0
- package/dist/src/linker.js.map +1 -0
- package/dist/src/linker.test.d.ts +2 -0
- package/dist/src/linker.test.d.ts.map +1 -0
- package/dist/src/linker.test.js +192 -0
- package/dist/src/linker.test.js.map +1 -0
- package/dist/src/logger.d.ts +21 -0
- package/dist/src/logger.d.ts.map +1 -0
- package/dist/src/logger.js +117 -0
- package/dist/src/logger.js.map +1 -0
- package/dist/src/logger.test.d.ts +2 -0
- package/dist/src/logger.test.d.ts.map +1 -0
- package/dist/src/logger.test.js +159 -0
- package/dist/src/logger.test.js.map +1 -0
- package/dist/src/postinstall.d.ts +7 -0
- package/dist/src/postinstall.d.ts.map +1 -0
- package/dist/src/postinstall.js +81 -0
- package/dist/src/postinstall.js.map +1 -0
- package/dist/src/postinstall.test.d.ts +2 -0
- package/dist/src/postinstall.test.d.ts.map +1 -0
- package/dist/src/postinstall.test.js +125 -0
- package/dist/src/postinstall.test.js.map +1 -0
- package/dist/src/preuninstall.d.ts +2 -0
- package/dist/src/preuninstall.d.ts.map +1 -0
- package/dist/src/preuninstall.js +62 -0
- package/dist/src/preuninstall.js.map +1 -0
- package/dist/src/preuninstall.test.d.ts +2 -0
- package/dist/src/preuninstall.test.d.ts.map +1 -0
- package/dist/src/preuninstall.test.js +97 -0
- package/dist/src/preuninstall.test.js.map +1 -0
- package/dist/src/root-finder.d.ts +2 -0
- package/dist/src/root-finder.d.ts.map +1 -0
- package/dist/src/root-finder.js +71 -0
- package/dist/src/root-finder.js.map +1 -0
- package/dist/src/root-finder.test.d.ts +2 -0
- package/dist/src/root-finder.test.d.ts.map +1 -0
- package/dist/src/root-finder.test.js +111 -0
- package/dist/src/root-finder.test.js.map +1 -0
- package/dist/src/settings-merger.d.ts +2 -0
- package/dist/src/settings-merger.d.ts.map +1 -0
- package/dist/src/settings-merger.js +136 -0
- package/dist/src/settings-merger.js.map +1 -0
- package/dist/src/settings-merger.test.d.ts +2 -0
- package/dist/src/settings-merger.test.d.ts.map +1 -0
- package/dist/src/settings-merger.test.js +387 -0
- package/dist/src/settings-merger.test.js.map +1 -0
- package/dist/src/skills-loader.d.ts +14 -0
- package/dist/src/skills-loader.d.ts.map +1 -0
- package/dist/src/skills-loader.js +90 -0
- package/dist/src/skills-loader.js.map +1 -0
- package/dist/src/skills-loader.test.d.ts +2 -0
- package/dist/src/skills-loader.test.d.ts.map +1 -0
- package/dist/src/skills-loader.test.js +222 -0
- package/dist/src/skills-loader.test.js.map +1 -0
- package/dist/src/state-manager.d.ts +5 -0
- package/dist/src/state-manager.d.ts.map +1 -0
- package/dist/src/state-manager.js +55 -0
- package/dist/src/state-manager.js.map +1 -0
- package/dist/src/state-manager.test.d.ts +2 -0
- package/dist/src/state-manager.test.d.ts.map +1 -0
- package/dist/src/state-manager.test.js +85 -0
- package/dist/src/state-manager.test.js.map +1 -0
- package/dist/src/subagent-classifier.d.ts +4 -0
- package/dist/src/subagent-classifier.d.ts.map +1 -0
- package/dist/src/subagent-classifier.js +53 -0
- package/dist/src/subagent-classifier.js.map +1 -0
- package/dist/src/subagent-classifier.test.d.ts +2 -0
- package/dist/src/subagent-classifier.test.d.ts.map +1 -0
- package/dist/src/subagent-classifier.test.js +88 -0
- package/dist/src/subagent-classifier.test.js.map +1 -0
- package/package.json +59 -0
- package/scripts/pre-tool-use.ts +10 -0
- package/scripts/session-start.ts +9 -0
- package/scripts/tail-logs.sh +17 -0
- package/scripts/test-hooks.sh +910 -0
- package/scripts/user-prompt-submit.ts +10 -0
- package/skills/ketchup.enforced.md +23 -0
- package/templates/settings.json +57 -0
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.getPackageDir = getPackageDir;
|
|
37
|
+
exports.isLinkedMode = isLinkedMode;
|
|
38
|
+
exports.createSymlink = createSymlink;
|
|
39
|
+
exports.removeSymlink = removeSymlink;
|
|
40
|
+
exports.verifySymlink = verifySymlink;
|
|
41
|
+
const fs = __importStar(require("node:fs"));
|
|
42
|
+
const path = __importStar(require("node:path"));
|
|
43
|
+
function getPackageDir() {
|
|
44
|
+
return path.resolve(__dirname, '..');
|
|
45
|
+
}
|
|
46
|
+
function isLinkedMode(packagePath) {
|
|
47
|
+
return fs.lstatSync(packagePath).isSymbolicLink();
|
|
48
|
+
}
|
|
49
|
+
function createSymlink(source, target) {
|
|
50
|
+
if (fs.existsSync(target)) {
|
|
51
|
+
const stats = fs.lstatSync(target);
|
|
52
|
+
if (stats.isSymbolicLink()) {
|
|
53
|
+
if (fs.readlinkSync(target) === source) {
|
|
54
|
+
return;
|
|
55
|
+
}
|
|
56
|
+
fs.unlinkSync(target);
|
|
57
|
+
}
|
|
58
|
+
else {
|
|
59
|
+
fs.renameSync(target, `${target}.backup`);
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
fs.symlinkSync(source, target);
|
|
63
|
+
}
|
|
64
|
+
function removeSymlink(target) {
|
|
65
|
+
if (fs.existsSync(target) && fs.lstatSync(target).isSymbolicLink()) {
|
|
66
|
+
fs.unlinkSync(target);
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
function verifySymlink(target, expectedSource) {
|
|
70
|
+
if (!fs.existsSync(target)) {
|
|
71
|
+
return false;
|
|
72
|
+
}
|
|
73
|
+
if (!fs.lstatSync(target).isSymbolicLink()) {
|
|
74
|
+
return false;
|
|
75
|
+
}
|
|
76
|
+
return fs.readlinkSync(target) === expectedSource;
|
|
77
|
+
}
|
|
78
|
+
//# sourceMappingURL=linker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"linker.js","sourceRoot":"","sources":["../../src/linker.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAGA,sCAEC;AAED,oCAEC;AAED,sCAaC;AAED,sCAIC;AAED,sCAQC;AAxCD,4CAA8B;AAC9B,gDAAkC;AAElC,SAAgB,aAAa;IAC3B,OAAO,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;AACvC,CAAC;AAED,SAAgB,YAAY,CAAC,WAAmB;IAC9C,OAAO,EAAE,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC,cAAc,EAAE,CAAC;AACpD,CAAC;AAED,SAAgB,aAAa,CAAC,MAAc,EAAE,MAAc;IAC1D,IAAI,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC;QAC1B,MAAM,KAAK,GAAG,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QACnC,IAAI,KAAK,CAAC,cAAc,EAAE,EAAE,CAAC;YAC3B,IAAI,EAAE,CAAC,YAAY,CAAC,MAAM,CAAC,KAAK,MAAM,EAAE,CAAC;gBACvC,OAAO;YACT,CAAC;YACD,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;QACxB,CAAC;aAAM,CAAC;YACN,EAAE,CAAC,UAAU,CAAC,MAAM,EAAE,GAAG,MAAM,SAAS,CAAC,CAAC;QAC5C,CAAC;IACH,CAAC;IACD,EAAE,CAAC,WAAW,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;AACjC,CAAC;AAED,SAAgB,aAAa,CAAC,MAAc;IAC1C,IAAI,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,cAAc,EAAE,EAAE,CAAC;QACnE,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;IACxB,CAAC;AACH,CAAC;AAED,SAAgB,aAAa,CAAC,MAAc,EAAE,cAAsB;IAClE,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC;QAC3B,OAAO,KAAK,CAAC;IACf,CAAC;IACD,IAAI,CAAC,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,cAAc,EAAE,EAAE,CAAC;QAC3C,OAAO,KAAK,CAAC;IACf,CAAC;IACD,OAAO,EAAE,CAAC,YAAY,CAAC,MAAM,CAAC,KAAK,cAAc,CAAC;AACpD,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"linker.test.d.ts","sourceRoot":"","sources":["../../src/linker.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,192 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
const fs = __importStar(require("node:fs"));
|
|
37
|
+
const os = __importStar(require("node:os"));
|
|
38
|
+
const path = __importStar(require("node:path"));
|
|
39
|
+
const vitest_1 = require("vitest");
|
|
40
|
+
const linker_js_1 = require("./linker.js");
|
|
41
|
+
(0, vitest_1.describe)('linker', () => {
|
|
42
|
+
(0, vitest_1.describe)('getPackageDir', () => {
|
|
43
|
+
(0, vitest_1.it)('returns the directory containing this package', () => {
|
|
44
|
+
const result = (0, linker_js_1.getPackageDir)();
|
|
45
|
+
(0, vitest_1.expect)(result).toBe(path.resolve(__dirname, '..'));
|
|
46
|
+
});
|
|
47
|
+
});
|
|
48
|
+
(0, vitest_1.describe)('isLinkedMode', () => {
|
|
49
|
+
let tempDir;
|
|
50
|
+
(0, vitest_1.beforeEach)(() => {
|
|
51
|
+
tempDir = fs.mkdtempSync(path.join(os.tmpdir(), 'ketchup-test-'));
|
|
52
|
+
});
|
|
53
|
+
(0, vitest_1.afterEach)(() => {
|
|
54
|
+
fs.rmSync(tempDir, { recursive: true, force: true });
|
|
55
|
+
});
|
|
56
|
+
(0, vitest_1.it)('returns true when package is a symlink in node_modules', () => {
|
|
57
|
+
const projectDir = path.join(tempDir, 'my-project');
|
|
58
|
+
const nodeModules = path.join(projectDir, 'node_modules');
|
|
59
|
+
const packagePath = path.join(nodeModules, 'claude-ketchup');
|
|
60
|
+
const realPackage = path.join(tempDir, 'real-package');
|
|
61
|
+
fs.mkdirSync(realPackage, { recursive: true });
|
|
62
|
+
fs.mkdirSync(nodeModules, { recursive: true });
|
|
63
|
+
fs.symlinkSync(realPackage, packagePath);
|
|
64
|
+
const result = (0, linker_js_1.isLinkedMode)(packagePath);
|
|
65
|
+
(0, vitest_1.expect)(result).toBe(true);
|
|
66
|
+
});
|
|
67
|
+
(0, vitest_1.it)('returns false when package is a regular directory', () => {
|
|
68
|
+
const projectDir = path.join(tempDir, 'my-project');
|
|
69
|
+
const nodeModules = path.join(projectDir, 'node_modules');
|
|
70
|
+
const packagePath = path.join(nodeModules, 'claude-ketchup');
|
|
71
|
+
fs.mkdirSync(packagePath, { recursive: true });
|
|
72
|
+
const result = (0, linker_js_1.isLinkedMode)(packagePath);
|
|
73
|
+
(0, vitest_1.expect)(result).toBe(false);
|
|
74
|
+
});
|
|
75
|
+
});
|
|
76
|
+
(0, vitest_1.describe)('createSymlink', () => {
|
|
77
|
+
let tempDir;
|
|
78
|
+
(0, vitest_1.beforeEach)(() => {
|
|
79
|
+
tempDir = fs.mkdtempSync(path.join(os.tmpdir(), 'ketchup-test-'));
|
|
80
|
+
});
|
|
81
|
+
(0, vitest_1.afterEach)(() => {
|
|
82
|
+
fs.rmSync(tempDir, { recursive: true, force: true });
|
|
83
|
+
});
|
|
84
|
+
(0, vitest_1.it)('creates a symlink to the source file', () => {
|
|
85
|
+
const sourceFile = path.join(tempDir, 'source.txt');
|
|
86
|
+
const targetLink = path.join(tempDir, 'target.txt');
|
|
87
|
+
fs.writeFileSync(sourceFile, 'content');
|
|
88
|
+
(0, linker_js_1.createSymlink)(sourceFile, targetLink);
|
|
89
|
+
(0, vitest_1.expect)(fs.lstatSync(targetLink).isSymbolicLink()).toBe(true);
|
|
90
|
+
(0, vitest_1.expect)(fs.readlinkSync(targetLink)).toBe(sourceFile);
|
|
91
|
+
});
|
|
92
|
+
(0, vitest_1.it)('backs up existing non-symlink file before creating symlink', () => {
|
|
93
|
+
const sourceFile = path.join(tempDir, 'source.txt');
|
|
94
|
+
const targetLink = path.join(tempDir, 'target.txt');
|
|
95
|
+
fs.writeFileSync(sourceFile, 'new content');
|
|
96
|
+
fs.writeFileSync(targetLink, 'existing content');
|
|
97
|
+
(0, linker_js_1.createSymlink)(sourceFile, targetLink);
|
|
98
|
+
(0, vitest_1.expect)(fs.lstatSync(targetLink).isSymbolicLink()).toBe(true);
|
|
99
|
+
(0, vitest_1.expect)(fs.readlinkSync(targetLink)).toBe(sourceFile);
|
|
100
|
+
(0, vitest_1.expect)(fs.readFileSync(`${targetLink}.backup`, 'utf-8')).toBe('existing content');
|
|
101
|
+
});
|
|
102
|
+
(0, vitest_1.it)('replaces existing symlink without backup', () => {
|
|
103
|
+
const source1 = path.join(tempDir, 'source1.txt');
|
|
104
|
+
const source2 = path.join(tempDir, 'source2.txt');
|
|
105
|
+
const targetLink = path.join(tempDir, 'target.txt');
|
|
106
|
+
fs.writeFileSync(source1, 'content1');
|
|
107
|
+
fs.writeFileSync(source2, 'content2');
|
|
108
|
+
fs.symlinkSync(source1, targetLink);
|
|
109
|
+
(0, linker_js_1.createSymlink)(source2, targetLink);
|
|
110
|
+
(0, vitest_1.expect)(fs.lstatSync(targetLink).isSymbolicLink()).toBe(true);
|
|
111
|
+
(0, vitest_1.expect)(fs.readlinkSync(targetLink)).toBe(source2);
|
|
112
|
+
(0, vitest_1.expect)(fs.existsSync(`${targetLink}.backup`)).toBe(false);
|
|
113
|
+
});
|
|
114
|
+
(0, vitest_1.it)('is idempotent when symlink already points to source', () => {
|
|
115
|
+
const sourceFile = path.join(tempDir, 'source.txt');
|
|
116
|
+
const targetLink = path.join(tempDir, 'target.txt');
|
|
117
|
+
fs.writeFileSync(sourceFile, 'content');
|
|
118
|
+
fs.symlinkSync(sourceFile, targetLink);
|
|
119
|
+
const statsBefore = fs.lstatSync(targetLink);
|
|
120
|
+
(0, linker_js_1.createSymlink)(sourceFile, targetLink);
|
|
121
|
+
(0, vitest_1.expect)(fs.lstatSync(targetLink).isSymbolicLink()).toBe(true);
|
|
122
|
+
(0, vitest_1.expect)(fs.readlinkSync(targetLink)).toBe(sourceFile);
|
|
123
|
+
(0, vitest_1.expect)(fs.lstatSync(targetLink).ino).toBe(statsBefore.ino);
|
|
124
|
+
});
|
|
125
|
+
});
|
|
126
|
+
(0, vitest_1.describe)('removeSymlink', () => {
|
|
127
|
+
let tempDir;
|
|
128
|
+
(0, vitest_1.beforeEach)(() => {
|
|
129
|
+
tempDir = fs.mkdtempSync(path.join(os.tmpdir(), 'ketchup-test-'));
|
|
130
|
+
});
|
|
131
|
+
(0, vitest_1.afterEach)(() => {
|
|
132
|
+
fs.rmSync(tempDir, { recursive: true, force: true });
|
|
133
|
+
});
|
|
134
|
+
(0, vitest_1.it)('removes a symlink', () => {
|
|
135
|
+
const sourceFile = path.join(tempDir, 'source.txt');
|
|
136
|
+
const targetLink = path.join(tempDir, 'target.txt');
|
|
137
|
+
fs.writeFileSync(sourceFile, 'content');
|
|
138
|
+
fs.symlinkSync(sourceFile, targetLink);
|
|
139
|
+
(0, linker_js_1.removeSymlink)(targetLink);
|
|
140
|
+
(0, vitest_1.expect)(fs.existsSync(targetLink)).toBe(false);
|
|
141
|
+
(0, vitest_1.expect)(fs.existsSync(sourceFile)).toBe(true);
|
|
142
|
+
});
|
|
143
|
+
(0, vitest_1.it)('does not remove regular files', () => {
|
|
144
|
+
const regularFile = path.join(tempDir, 'regular.txt');
|
|
145
|
+
fs.writeFileSync(regularFile, 'content');
|
|
146
|
+
(0, linker_js_1.removeSymlink)(regularFile);
|
|
147
|
+
(0, vitest_1.expect)(fs.existsSync(regularFile)).toBe(true);
|
|
148
|
+
});
|
|
149
|
+
});
|
|
150
|
+
(0, vitest_1.describe)('verifySymlink', () => {
|
|
151
|
+
let tempDir;
|
|
152
|
+
(0, vitest_1.beforeEach)(() => {
|
|
153
|
+
tempDir = fs.mkdtempSync(path.join(os.tmpdir(), 'ketchup-test-'));
|
|
154
|
+
});
|
|
155
|
+
(0, vitest_1.afterEach)(() => {
|
|
156
|
+
fs.rmSync(tempDir, { recursive: true, force: true });
|
|
157
|
+
});
|
|
158
|
+
(0, vitest_1.it)('returns true when symlink points to expected target', () => {
|
|
159
|
+
const sourceFile = path.join(tempDir, 'source.txt');
|
|
160
|
+
const targetLink = path.join(tempDir, 'target.txt');
|
|
161
|
+
fs.writeFileSync(sourceFile, 'content');
|
|
162
|
+
fs.symlinkSync(sourceFile, targetLink);
|
|
163
|
+
const result = (0, linker_js_1.verifySymlink)(targetLink, sourceFile);
|
|
164
|
+
(0, vitest_1.expect)(result).toBe(true);
|
|
165
|
+
});
|
|
166
|
+
(0, vitest_1.it)('returns false when symlink points to different target', () => {
|
|
167
|
+
const source1 = path.join(tempDir, 'source1.txt');
|
|
168
|
+
const source2 = path.join(tempDir, 'source2.txt');
|
|
169
|
+
const targetLink = path.join(tempDir, 'target.txt');
|
|
170
|
+
fs.writeFileSync(source1, 'content1');
|
|
171
|
+
fs.writeFileSync(source2, 'content2');
|
|
172
|
+
fs.symlinkSync(source1, targetLink);
|
|
173
|
+
const result = (0, linker_js_1.verifySymlink)(targetLink, source2);
|
|
174
|
+
(0, vitest_1.expect)(result).toBe(false);
|
|
175
|
+
});
|
|
176
|
+
(0, vitest_1.it)('returns false when target does not exist', () => {
|
|
177
|
+
const sourceFile = path.join(tempDir, 'source.txt');
|
|
178
|
+
const targetLink = path.join(tempDir, 'target.txt');
|
|
179
|
+
const result = (0, linker_js_1.verifySymlink)(targetLink, sourceFile);
|
|
180
|
+
(0, vitest_1.expect)(result).toBe(false);
|
|
181
|
+
});
|
|
182
|
+
(0, vitest_1.it)('returns false when target is not a symlink', () => {
|
|
183
|
+
const sourceFile = path.join(tempDir, 'source.txt');
|
|
184
|
+
const regularFile = path.join(tempDir, 'regular.txt');
|
|
185
|
+
fs.writeFileSync(sourceFile, 'content');
|
|
186
|
+
fs.writeFileSync(regularFile, 'content');
|
|
187
|
+
const result = (0, linker_js_1.verifySymlink)(regularFile, sourceFile);
|
|
188
|
+
(0, vitest_1.expect)(result).toBe(false);
|
|
189
|
+
});
|
|
190
|
+
});
|
|
191
|
+
});
|
|
192
|
+
//# sourceMappingURL=linker.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"linker.test.js","sourceRoot":"","sources":["../../src/linker.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
export declare const colors: {
|
|
2
|
+
readonly reset: "\u001B[0m";
|
|
3
|
+
readonly dim: "\u001B[2m";
|
|
4
|
+
readonly bold: "\u001B[1m";
|
|
5
|
+
readonly italic: "\u001B[3m";
|
|
6
|
+
readonly red: "\u001B[31m";
|
|
7
|
+
readonly green: "\u001B[32m";
|
|
8
|
+
readonly pink: "\u001B[35m";
|
|
9
|
+
readonly yellow: "\u001B[33m";
|
|
10
|
+
readonly cyan: "\u001B[36m";
|
|
11
|
+
readonly white: "\u001B[97m";
|
|
12
|
+
readonly magenta: "\u001B[35m";
|
|
13
|
+
};
|
|
14
|
+
export type LogLevel = 'ACK' | 'NACK' | 'ERROR' | 'WARN' | 'SKIP' | 'INFO' | 'DENIED' | 'CONTINUE';
|
|
15
|
+
export interface Logger {
|
|
16
|
+
log: (level: LogLevel, message: string) => void;
|
|
17
|
+
logError: (error: unknown, context?: string) => void;
|
|
18
|
+
getLogFile: () => string;
|
|
19
|
+
}
|
|
20
|
+
export declare function createLogger(logDir: string, sessionId?: string): Logger;
|
|
21
|
+
//# sourceMappingURL=logger.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../src/logger.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,MAAM;;;;;;;;;;;;CAYT,CAAC;AAEX,MAAM,MAAM,QAAQ,GAChB,KAAK,GACL,MAAM,GACN,OAAO,GACP,MAAM,GACN,MAAM,GACN,MAAM,GACN,QAAQ,GACR,UAAU,CAAC;AAaf,MAAM,WAAW,MAAM;IACrB,GAAG,EAAE,CAAC,KAAK,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,KAAK,IAAI,CAAC;IAChD,QAAQ,EAAE,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO,CAAC,EAAE,MAAM,KAAK,IAAI,CAAC;IACrD,UAAU,EAAE,MAAM,MAAM,CAAC;CAC1B;AAED,wBAAgB,YAAY,CAAC,MAAM,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,MAAM,GAAG,MAAM,CAmEvE"}
|
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.colors = void 0;
|
|
37
|
+
exports.createLogger = createLogger;
|
|
38
|
+
const fs = __importStar(require("node:fs"));
|
|
39
|
+
const path = __importStar(require("node:path"));
|
|
40
|
+
exports.colors = {
|
|
41
|
+
reset: '\x1b[0m',
|
|
42
|
+
dim: '\x1b[2m',
|
|
43
|
+
bold: '\x1b[1m',
|
|
44
|
+
italic: '\x1b[3m',
|
|
45
|
+
red: '\x1b[31m',
|
|
46
|
+
green: '\x1b[32m',
|
|
47
|
+
pink: '\x1b[35m',
|
|
48
|
+
yellow: '\x1b[33m',
|
|
49
|
+
cyan: '\x1b[36m',
|
|
50
|
+
white: '\x1b[97m',
|
|
51
|
+
magenta: '\x1b[35m',
|
|
52
|
+
};
|
|
53
|
+
const levelColors = {
|
|
54
|
+
ACK: `${exports.colors.bold}${exports.colors.green}`,
|
|
55
|
+
NACK: `${exports.colors.bold}${exports.colors.red}`,
|
|
56
|
+
ERROR: `${exports.colors.red}`,
|
|
57
|
+
SKIP: `${exports.colors.yellow}`,
|
|
58
|
+
WARN: `${exports.colors.pink}`,
|
|
59
|
+
INFO: `${exports.colors.dim}`,
|
|
60
|
+
DENIED: `${exports.colors.bold}${exports.colors.magenta}`,
|
|
61
|
+
CONTINUE: `${exports.colors.bold}${exports.colors.cyan}`,
|
|
62
|
+
};
|
|
63
|
+
function createLogger(logDir, sessionId) {
|
|
64
|
+
const hooksDir = path.join(logDir, 'hooks');
|
|
65
|
+
let logFilePath;
|
|
66
|
+
function ensureLogDir() {
|
|
67
|
+
if (!fs.existsSync(hooksDir)) {
|
|
68
|
+
fs.mkdirSync(hooksDir, { recursive: true });
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
function getLogFile() {
|
|
72
|
+
if (logFilePath) {
|
|
73
|
+
return logFilePath;
|
|
74
|
+
}
|
|
75
|
+
ensureLogDir();
|
|
76
|
+
if (!sessionId) {
|
|
77
|
+
logFilePath = path.join(hooksDir, 'unknown.log');
|
|
78
|
+
return logFilePath;
|
|
79
|
+
}
|
|
80
|
+
const prefix = sessionId.slice(0, 8);
|
|
81
|
+
const files = fs.readdirSync(hooksDir);
|
|
82
|
+
const existing = files.find((f) => f.startsWith(`${prefix}-`) && f.endsWith('.log'));
|
|
83
|
+
if (existing) {
|
|
84
|
+
logFilePath = path.join(hooksDir, existing);
|
|
85
|
+
return logFilePath;
|
|
86
|
+
}
|
|
87
|
+
const timestamp = new Date()
|
|
88
|
+
.toISOString()
|
|
89
|
+
.replace(/:/g, '-')
|
|
90
|
+
.replace(/\.\d{3}Z$/, '');
|
|
91
|
+
const filename = `${prefix}-${timestamp}.log`;
|
|
92
|
+
logFilePath = path.join(hooksDir, filename);
|
|
93
|
+
fs.appendFileSync(logFilePath, `session: ${sessionId}\n\n`);
|
|
94
|
+
return logFilePath;
|
|
95
|
+
}
|
|
96
|
+
function log(level, message) {
|
|
97
|
+
const timestamp = new Date().toISOString();
|
|
98
|
+
const coloredLevel = `${levelColors[level]}${level}${exports.colors.reset}`;
|
|
99
|
+
const dimTimestamp = `${exports.colors.dim}[${timestamp}]${exports.colors.reset}`;
|
|
100
|
+
const logFile = getLogFile();
|
|
101
|
+
fs.appendFileSync(logFile, `${dimTimestamp} ${coloredLevel}: ${message}\n`);
|
|
102
|
+
}
|
|
103
|
+
function logError(error, context) {
|
|
104
|
+
ensureLogDir();
|
|
105
|
+
const timestamp = new Date().toISOString();
|
|
106
|
+
const errorMsg = error instanceof Error ? `${error.message}\n${error.stack}` : String(error);
|
|
107
|
+
const contextStr = context ? ` [${context}]` : '';
|
|
108
|
+
const errLog = path.join(hooksDir, 'err.log');
|
|
109
|
+
fs.appendFileSync(errLog, `[${timestamp}]${contextStr} ${errorMsg}\n\n`);
|
|
110
|
+
}
|
|
111
|
+
return {
|
|
112
|
+
log,
|
|
113
|
+
logError,
|
|
114
|
+
getLogFile,
|
|
115
|
+
};
|
|
116
|
+
}
|
|
117
|
+
//# sourceMappingURL=logger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/logger.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.test.d.ts","sourceRoot":"","sources":["../../src/logger.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,159 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
const fs = __importStar(require("node:fs"));
|
|
37
|
+
const os = __importStar(require("node:os"));
|
|
38
|
+
const path = __importStar(require("node:path"));
|
|
39
|
+
const vitest_1 = require("vitest");
|
|
40
|
+
const logger_js_1 = require("./logger.js");
|
|
41
|
+
(0, vitest_1.describe)('logger', () => {
|
|
42
|
+
let tempDir;
|
|
43
|
+
(0, vitest_1.beforeEach)(() => {
|
|
44
|
+
tempDir = fs.mkdtempSync(path.join(os.tmpdir(), 'ketchup-logger-'));
|
|
45
|
+
});
|
|
46
|
+
(0, vitest_1.afterEach)(() => {
|
|
47
|
+
fs.rmSync(tempDir, { recursive: true, force: true });
|
|
48
|
+
});
|
|
49
|
+
(0, vitest_1.describe)('createLogger', () => {
|
|
50
|
+
(0, vitest_1.it)('creates log file in hooks subdirectory with session prefix', () => {
|
|
51
|
+
const logger = (0, logger_js_1.createLogger)(tempDir, 'abc12345-full-session-id');
|
|
52
|
+
logger.log('INFO', 'test message');
|
|
53
|
+
const hooksDir = path.join(tempDir, 'hooks');
|
|
54
|
+
const files = fs.readdirSync(hooksDir);
|
|
55
|
+
const logFile = files.find((f) => f.startsWith('abc12345-') && f.endsWith('.log'));
|
|
56
|
+
(0, vitest_1.expect)(logFile).toBeDefined();
|
|
57
|
+
});
|
|
58
|
+
(0, vitest_1.it)('creates unknown.log in hooks subdirectory when no session id', () => {
|
|
59
|
+
const logger = (0, logger_js_1.createLogger)(tempDir);
|
|
60
|
+
logger.log('INFO', 'test message');
|
|
61
|
+
(0, vitest_1.expect)(fs.existsSync(path.join(tempDir, 'hooks', 'unknown.log'))).toBe(true);
|
|
62
|
+
});
|
|
63
|
+
(0, vitest_1.it)('reuses existing log file for same session prefix', () => {
|
|
64
|
+
const hooksDir = path.join(tempDir, 'hooks');
|
|
65
|
+
fs.mkdirSync(hooksDir, { recursive: true });
|
|
66
|
+
const existingLog = path.join(hooksDir, 'abc12345-2026-01-01T00-00-00.log');
|
|
67
|
+
fs.writeFileSync(existingLog, 'existing content\n');
|
|
68
|
+
const logger = (0, logger_js_1.createLogger)(tempDir, 'abc12345-full-session-id');
|
|
69
|
+
logger.log('INFO', 'new message');
|
|
70
|
+
const content = fs.readFileSync(existingLog, 'utf8');
|
|
71
|
+
(0, vitest_1.expect)(content).toContain('existing content');
|
|
72
|
+
(0, vitest_1.expect)(content).toContain('new message');
|
|
73
|
+
});
|
|
74
|
+
(0, vitest_1.it)('creates hooks subdirectory if it does not exist', () => {
|
|
75
|
+
const nestedDir = path.join(tempDir, 'nested', 'logs');
|
|
76
|
+
const logger = (0, logger_js_1.createLogger)(nestedDir, 'session123');
|
|
77
|
+
logger.log('INFO', 'test');
|
|
78
|
+
(0, vitest_1.expect)(fs.existsSync(path.join(nestedDir, 'hooks'))).toBe(true);
|
|
79
|
+
});
|
|
80
|
+
});
|
|
81
|
+
(0, vitest_1.describe)('log', () => {
|
|
82
|
+
(0, vitest_1.it)('writes timestamped message with log level', () => {
|
|
83
|
+
const logger = (0, logger_js_1.createLogger)(tempDir, 'test-session');
|
|
84
|
+
logger.log('INFO', 'hello world');
|
|
85
|
+
const hooksDir = path.join(tempDir, 'hooks');
|
|
86
|
+
const files = fs.readdirSync(hooksDir);
|
|
87
|
+
const logFile = files.find((f) => f.endsWith('.log'));
|
|
88
|
+
const content = fs.readFileSync(path.join(hooksDir, logFile), 'utf8');
|
|
89
|
+
(0, vitest_1.expect)(content).toMatch(/\[\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}/);
|
|
90
|
+
(0, vitest_1.expect)(content).toContain('INFO');
|
|
91
|
+
(0, vitest_1.expect)(content).toContain('hello world');
|
|
92
|
+
});
|
|
93
|
+
(0, vitest_1.it)('applies color codes to log level', () => {
|
|
94
|
+
const logger = (0, logger_js_1.createLogger)(tempDir, 'test-session');
|
|
95
|
+
logger.log('ACK', 'success');
|
|
96
|
+
const hooksDir = path.join(tempDir, 'hooks');
|
|
97
|
+
const files = fs.readdirSync(hooksDir);
|
|
98
|
+
const logFile = files.find((f) => f.endsWith('.log'));
|
|
99
|
+
const content = fs.readFileSync(path.join(hooksDir, logFile), 'utf8');
|
|
100
|
+
(0, vitest_1.expect)(content).toContain(logger_js_1.colors.bold);
|
|
101
|
+
(0, vitest_1.expect)(content).toContain(logger_js_1.colors.green);
|
|
102
|
+
});
|
|
103
|
+
(0, vitest_1.it)('supports all log levels', () => {
|
|
104
|
+
const logger = (0, logger_js_1.createLogger)(tempDir, 'test-session');
|
|
105
|
+
const levels = ['ACK', 'NACK', 'ERROR', 'WARN', 'SKIP', 'INFO', 'DENIED', 'CONTINUE'];
|
|
106
|
+
for (const level of levels) {
|
|
107
|
+
logger.log(level, `test ${level}`);
|
|
108
|
+
}
|
|
109
|
+
const hooksDir = path.join(tempDir, 'hooks');
|
|
110
|
+
const files = fs.readdirSync(hooksDir);
|
|
111
|
+
const logFile = files.find((f) => f.endsWith('.log'));
|
|
112
|
+
const content = fs.readFileSync(path.join(hooksDir, logFile), 'utf8');
|
|
113
|
+
for (const level of levels) {
|
|
114
|
+
(0, vitest_1.expect)(content).toContain(level);
|
|
115
|
+
}
|
|
116
|
+
});
|
|
117
|
+
});
|
|
118
|
+
(0, vitest_1.describe)('logError', () => {
|
|
119
|
+
(0, vitest_1.it)('writes error to err.log in hooks subdirectory', () => {
|
|
120
|
+
const logger = (0, logger_js_1.createLogger)(tempDir, 'test-session');
|
|
121
|
+
const error = new Error('test error');
|
|
122
|
+
logger.logError(error, 'validate-commit');
|
|
123
|
+
const errLog = path.join(tempDir, 'hooks', 'err.log');
|
|
124
|
+
(0, vitest_1.expect)(fs.existsSync(errLog)).toBe(true);
|
|
125
|
+
const content = fs.readFileSync(errLog, 'utf8');
|
|
126
|
+
(0, vitest_1.expect)(content).toMatch(/\[\d{4}-\d{2}-\d{2}T/);
|
|
127
|
+
(0, vitest_1.expect)(content).toContain('[validate-commit]');
|
|
128
|
+
(0, vitest_1.expect)(content).toContain('test error');
|
|
129
|
+
});
|
|
130
|
+
(0, vitest_1.it)('writes error without context when not provided', () => {
|
|
131
|
+
const logger = (0, logger_js_1.createLogger)(tempDir, 'test-session');
|
|
132
|
+
logger.logError(new Error('bare error'));
|
|
133
|
+
const errLog = path.join(tempDir, 'hooks', 'err.log');
|
|
134
|
+
const content = fs.readFileSync(errLog, 'utf8');
|
|
135
|
+
(0, vitest_1.expect)(content).toContain('bare error');
|
|
136
|
+
(0, vitest_1.expect)(content).not.toContain('[]');
|
|
137
|
+
});
|
|
138
|
+
(0, vitest_1.it)('handles non-Error objects', () => {
|
|
139
|
+
const logger = (0, logger_js_1.createLogger)(tempDir, 'test-session');
|
|
140
|
+
logger.logError('string error');
|
|
141
|
+
const errLog = path.join(tempDir, 'hooks', 'err.log');
|
|
142
|
+
const content = fs.readFileSync(errLog, 'utf8');
|
|
143
|
+
(0, vitest_1.expect)(content).toContain('string error');
|
|
144
|
+
});
|
|
145
|
+
});
|
|
146
|
+
(0, vitest_1.describe)('colors', () => {
|
|
147
|
+
(0, vitest_1.it)('exports ANSI color codes', () => {
|
|
148
|
+
(0, vitest_1.expect)(logger_js_1.colors.reset).toBe('\x1b[0m');
|
|
149
|
+
(0, vitest_1.expect)(logger_js_1.colors.dim).toBe('\x1b[2m');
|
|
150
|
+
(0, vitest_1.expect)(logger_js_1.colors.bold).toBe('\x1b[1m');
|
|
151
|
+
(0, vitest_1.expect)(logger_js_1.colors.red).toBe('\x1b[31m');
|
|
152
|
+
(0, vitest_1.expect)(logger_js_1.colors.green).toBe('\x1b[32m');
|
|
153
|
+
(0, vitest_1.expect)(logger_js_1.colors.yellow).toBe('\x1b[33m');
|
|
154
|
+
(0, vitest_1.expect)(logger_js_1.colors.cyan).toBe('\x1b[36m');
|
|
155
|
+
(0, vitest_1.expect)(logger_js_1.colors.magenta).toBe('\x1b[35m');
|
|
156
|
+
});
|
|
157
|
+
});
|
|
158
|
+
});
|
|
159
|
+
//# sourceMappingURL=logger.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.test.js","sourceRoot":"","sources":["../../src/logger.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"postinstall.d.ts","sourceRoot":"","sources":["../../src/postinstall.ts"],"names":[],"mappings":"AAUA,MAAM,WAAW,iBAAiB;IAChC,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,MAAM,CAAC;IAClB,cAAc,EAAE,MAAM,EAAE,CAAC;CAC1B;AAgBD,wBAAgB,cAAc,CAAC,UAAU,CAAC,EAAE,MAAM,GAAG,iBAAiB,CA2BrE"}
|