claude-auto 0.12.4
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/.claude-auto/.claude.hooks.json +25 -0
- package/.claude-auto/reminders/reminder-auto.md +145 -0
- package/.claude-auto/reminders/reminder-documentation.md +30 -0
- package/.claude-auto/reminders/reminder-emergent-design.md +41 -0
- package/.claude-auto/reminders/reminder-extreme-ownership.md +27 -0
- package/.claude-auto/reminders/reminder-ide-diagnostics.md +25 -0
- package/.claude-auto/reminders/reminder-parallelization.md +27 -0
- package/.claude-auto/reminders/reminder-rethink-after-revert.md +25 -0
- package/.claude-auto/reminders/reminder-sub-agent-rules.md +27 -0
- package/.claude-auto/reminders/reminder-test-title-matches-spec.md +37 -0
- package/.claude-auto/validators/appeal-system.md +55 -0
- package/.claude-auto/validators/backwards-compat.md +33 -0
- package/.claude-auto/validators/burst-atomicity.md +37 -0
- package/.claude-auto/validators/coverage-rules.md +34 -0
- package/.claude-auto/validators/dead-code.md +36 -0
- package/.claude-auto/validators/hygiene.md +34 -0
- package/.claude-auto/validators/infra-commit-format.md +37 -0
- package/.claude-auto/validators/ketchup-plan-format.md +42 -0
- package/.claude-auto/validators/new-code-requires-tests.md +36 -0
- package/.claude-auto/validators/no-comments.md +35 -0
- package/.claude-auto/validators/no-dangerous-git.md +35 -0
- package/.claude-auto/validators/tcr-workflow.md +31 -0
- package/.claude-auto/validators/testing-no-state-peeking.md +37 -0
- package/.claude-auto/validators/testing-structure.md +37 -0
- package/.claude-auto/validators/testing-stubs-over-mocks.md +42 -0
- package/.claude-auto/validators/testing-weak-assertions.md +36 -0
- package/.claude-auto/validators/type-organization.md +30 -0
- package/README.md +172 -0
- package/bin/cli.ts +6 -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/bundle/scripts/auto-continue.js +5045 -0
- package/dist/bundle/scripts/pre-tool-use.js +11719 -0
- package/dist/bundle/scripts/session-start.js +8571 -0
- package/dist/bundle/scripts/user-prompt-submit.js +8585 -0
- package/dist/scripts/auto-continue.d.ts +3 -0
- package/dist/scripts/auto-continue.d.ts.map +1 -0
- package/dist/scripts/auto-continue.js +65 -0
- package/dist/scripts/auto-continue.js.map +1 -0
- package/dist/scripts/generate-changeset.d.ts +13 -0
- package/dist/scripts/generate-changeset.d.ts.map +1 -0
- package/dist/scripts/generate-changeset.js +322 -0
- package/dist/scripts/generate-changeset.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 +78 -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 +76 -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 +76 -0
- package/dist/scripts/user-prompt-submit.js.map +1 -0
- package/dist/src/activity-logger.d.ts +2 -0
- package/dist/src/activity-logger.d.ts.map +1 -0
- package/dist/src/activity-logger.js +47 -0
- package/dist/src/activity-logger.js.map +1 -0
- package/dist/src/activity-logger.test.d.ts +2 -0
- package/dist/src/activity-logger.test.d.ts.map +1 -0
- package/dist/src/activity-logger.test.js +121 -0
- package/dist/src/activity-logger.test.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 +32 -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 +27 -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 +67 -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 +87 -0
- package/dist/src/cli/doctor.test.js.map +1 -0
- package/dist/src/cli/install.d.ts +10 -0
- package/dist/src/cli/install.d.ts.map +1 -0
- package/dist/src/cli/install.js +116 -0
- package/dist/src/cli/install.js.map +1 -0
- package/dist/src/cli/install.test.d.ts +2 -0
- package/dist/src/cli/install.test.d.ts.map +1 -0
- package/dist/src/cli/install.test.js +217 -0
- package/dist/src/cli/install.test.js.map +1 -0
- package/dist/src/cli/reminders.d.ts +12 -0
- package/dist/src/cli/reminders.d.ts.map +1 -0
- package/dist/src/cli/reminders.js +52 -0
- package/dist/src/cli/reminders.js.map +1 -0
- package/dist/src/cli/reminders.test.d.ts +2 -0
- package/dist/src/cli/reminders.test.d.ts.map +1 -0
- package/dist/src/cli/reminders.test.js +72 -0
- package/dist/src/cli/reminders.test.js.map +1 -0
- package/dist/src/cli/repair.d.ts +11 -0
- package/dist/src/cli/repair.d.ts.map +1 -0
- package/dist/src/cli/repair.js +91 -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 +95 -0
- package/dist/src/cli/repair.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 +55 -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 +80 -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 +221 -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 +278 -0
- package/dist/src/clue-collector.test.js.map +1 -0
- package/dist/src/commit-validator.d.ts +53 -0
- package/dist/src/commit-validator.d.ts.map +1 -0
- package/dist/src/commit-validator.js +356 -0
- package/dist/src/commit-validator.js.map +1 -0
- package/dist/src/commit-validator.test.d.ts +2 -0
- package/dist/src/commit-validator.test.d.ts.map +1 -0
- package/dist/src/commit-validator.test.js +733 -0
- package/dist/src/commit-validator.test.js.map +1 -0
- package/dist/src/config-loader.d.ts +15 -0
- package/dist/src/config-loader.d.ts.map +1 -0
- package/dist/src/config-loader.js +12 -0
- package/dist/src/config-loader.js.map +1 -0
- package/dist/src/config-loader.test.d.ts +2 -0
- package/dist/src/config-loader.test.d.ts.map +1 -0
- package/dist/src/config-loader.test.js +69 -0
- package/dist/src/config-loader.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/default-validators.test.d.ts +2 -0
- package/dist/src/default-validators.test.d.ts.map +1 -0
- package/dist/src/default-validators.test.js +119 -0
- package/dist/src/default-validators.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 +82 -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 +65 -0
- package/dist/src/gitignore-manager.test.js.map +1 -0
- package/dist/src/hook-input.d.ts +9 -0
- package/dist/src/hook-input.d.ts.map +1 -0
- package/dist/src/hook-input.js +7 -0
- package/dist/src/hook-input.js.map +1 -0
- package/dist/src/hook-input.test.d.ts +2 -0
- package/dist/src/hook-input.test.d.ts.map +1 -0
- package/dist/src/hook-input.test.js +20 -0
- package/dist/src/hook-input.test.js.map +1 -0
- package/dist/src/hook-logger.d.ts +16 -0
- package/dist/src/hook-logger.d.ts.map +1 -0
- package/dist/src/hook-logger.js +90 -0
- package/dist/src/hook-logger.js.map +1 -0
- package/dist/src/hook-logger.test.d.ts +2 -0
- package/dist/src/hook-logger.test.d.ts.map +1 -0
- package/dist/src/hook-logger.test.js +205 -0
- package/dist/src/hook-logger.test.js.map +1 -0
- package/dist/src/hook-state.d.ts +44 -0
- package/dist/src/hook-state.d.ts.map +1 -0
- package/dist/src/hook-state.js +128 -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 +204 -0
- package/dist/src/hook-state.test.js.map +1 -0
- package/dist/src/hooks/auto-continue.d.ts +21 -0
- package/dist/src/hooks/auto-continue.d.ts.map +1 -0
- package/dist/src/hooks/auto-continue.js +70 -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 +171 -0
- package/dist/src/hooks/auto-continue.test.js.map +1 -0
- package/dist/src/hooks/pre-tool-use.d.ts +14 -0
- package/dist/src/hooks/pre-tool-use.d.ts.map +1 -0
- package/dist/src/hooks/pre-tool-use.js +66 -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 +255 -0
- package/dist/src/hooks/pre-tool-use.test.js.map +1 -0
- package/dist/src/hooks/session-start.d.ts +20 -0
- package/dist/src/hooks/session-start.d.ts.map +1 -0
- package/dist/src/hooks/session-start.js +27 -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 +125 -0
- package/dist/src/hooks/session-start.test.js.map +1 -0
- package/dist/src/hooks/user-prompt-submit.d.ts +17 -0
- package/dist/src/hooks/user-prompt-submit.d.ts.map +1 -0
- package/dist/src/hooks/user-prompt-submit.js +28 -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 +119 -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 +18 -0
- package/dist/src/index.d.ts.map +1 -0
- package/dist/src/index.js +42 -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/path-resolver.d.ts +9 -0
- package/dist/src/path-resolver.d.ts.map +1 -0
- package/dist/src/path-resolver.js +52 -0
- package/dist/src/path-resolver.js.map +1 -0
- package/dist/src/reminder-loader.d.ts +24 -0
- package/dist/src/reminder-loader.d.ts.map +1 -0
- package/dist/src/reminder-loader.js +84 -0
- package/dist/src/reminder-loader.js.map +1 -0
- package/dist/src/reminder-loader.test.d.ts +2 -0
- package/dist/src/reminder-loader.test.d.ts.map +1 -0
- package/dist/src/reminder-loader.test.js +152 -0
- package/dist/src/reminder-loader.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 +133 -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 +379 -0
- package/dist/src/settings-merger.test.js.map +1 -0
- package/dist/src/settings-template.test.d.ts +2 -0
- package/dist/src/settings-template.test.d.ts.map +1 -0
- package/dist/src/settings-template.test.js +88 -0
- package/dist/src/settings-template.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 +84 -0
- package/dist/src/subagent-classifier.test.js.map +1 -0
- package/dist/src/validator-loader.d.ts +9 -0
- package/dist/src/validator-loader.d.ts.map +1 -0
- package/dist/src/validator-loader.js +71 -0
- package/dist/src/validator-loader.js.map +1 -0
- package/dist/src/validator-loader.test.d.ts +2 -0
- package/dist/src/validator-loader.test.d.ts.map +1 -0
- package/dist/src/validator-loader.test.js +140 -0
- package/dist/src/validator-loader.test.js.map +1 -0
- package/package.json +91 -0
- package/scripts/auto-continue.ts +39 -0
- package/scripts/generate-changeset.ts +405 -0
- package/scripts/pre-tool-use.ts +44 -0
- package/scripts/session-start.ts +42 -0
- package/scripts/tail-logs.sh +17 -0
- package/scripts/test-hooks.sh +910 -0
- package/scripts/user-prompt-submit.ts +42 -0
- package/templates/settings.json +48 -0
- package/templates/settings.local.json +48 -0
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
#!/usr/bin/env npx tsx
|
|
2
|
+
"use strict";
|
|
3
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
4
|
+
if (k2 === undefined) k2 = k;
|
|
5
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
6
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
7
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
8
|
+
}
|
|
9
|
+
Object.defineProperty(o, k2, desc);
|
|
10
|
+
}) : (function(o, m, k, k2) {
|
|
11
|
+
if (k2 === undefined) k2 = k;
|
|
12
|
+
o[k2] = m[k];
|
|
13
|
+
}));
|
|
14
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
15
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
16
|
+
}) : function(o, v) {
|
|
17
|
+
o["default"] = v;
|
|
18
|
+
});
|
|
19
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
20
|
+
var ownKeys = function(o) {
|
|
21
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
22
|
+
var ar = [];
|
|
23
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
24
|
+
return ar;
|
|
25
|
+
};
|
|
26
|
+
return ownKeys(o);
|
|
27
|
+
};
|
|
28
|
+
return function (mod) {
|
|
29
|
+
if (mod && mod.__esModule) return mod;
|
|
30
|
+
var result = {};
|
|
31
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
32
|
+
__setModuleDefault(result, mod);
|
|
33
|
+
return result;
|
|
34
|
+
};
|
|
35
|
+
})();
|
|
36
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
37
|
+
const fs = __importStar(require("node:fs"));
|
|
38
|
+
const path = __importStar(require("node:path"));
|
|
39
|
+
const hook_input_js_1 = require("../src/hook-input.js");
|
|
40
|
+
const hook_logger_js_1 = require("../src/hook-logger.js");
|
|
41
|
+
const user_prompt_submit_js_1 = require("../src/hooks/user-prompt-submit.js");
|
|
42
|
+
const path_resolver_js_1 = require("../src/path-resolver.js");
|
|
43
|
+
const input = (0, hook_input_js_1.parseHookInput)(fs.readFileSync(0, 'utf-8'));
|
|
44
|
+
const claudeDir = path.resolve(process.cwd(), '.claude');
|
|
45
|
+
const startTime = Date.now();
|
|
46
|
+
(async () => {
|
|
47
|
+
const { autoDir } = await (0, path_resolver_js_1.resolvePaths)(claudeDir);
|
|
48
|
+
try {
|
|
49
|
+
const { diagnostics, ...result } = await (0, user_prompt_submit_js_1.handleUserPromptSubmit)(claudeDir, input.session_id, input.prompt || '');
|
|
50
|
+
(0, hook_logger_js_1.writeHookLog)(autoDir, {
|
|
51
|
+
hookName: 'user-prompt-submit',
|
|
52
|
+
timestamp: new Date().toISOString(),
|
|
53
|
+
input: { ...input, prompt: input.prompt ? `[${input.prompt.length} chars]` : undefined },
|
|
54
|
+
resolvedPaths: diagnostics.resolvedPaths,
|
|
55
|
+
reminderFiles: diagnostics.reminderFiles,
|
|
56
|
+
matchedReminders: diagnostics.matchedReminders,
|
|
57
|
+
output: { resultLength: result.result.length },
|
|
58
|
+
durationMs: Date.now() - startTime,
|
|
59
|
+
});
|
|
60
|
+
console.log(JSON.stringify(result));
|
|
61
|
+
process.exit(0);
|
|
62
|
+
}
|
|
63
|
+
catch (err) {
|
|
64
|
+
(0, hook_logger_js_1.writeHookLog)(autoDir, {
|
|
65
|
+
hookName: 'user-prompt-submit',
|
|
66
|
+
timestamp: new Date().toISOString(),
|
|
67
|
+
input: { ...input, prompt: input.prompt ? `[${input.prompt.length} chars]` : undefined },
|
|
68
|
+
output: null,
|
|
69
|
+
error: String(err),
|
|
70
|
+
durationMs: Date.now() - startTime,
|
|
71
|
+
});
|
|
72
|
+
console.error('user-prompt-submit hook failed:', err);
|
|
73
|
+
process.exit(1);
|
|
74
|
+
}
|
|
75
|
+
})();
|
|
76
|
+
//# sourceMappingURL=user-prompt-submit.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"user-prompt-submit.js","sourceRoot":"","sources":["../../scripts/user-prompt-submit.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AACA,4CAA8B;AAC9B,gDAAkC;AAElC,wDAAsD;AACtD,0DAAqD;AACrD,8EAA4E;AAC5E,8DAAuD;AAEvD,MAAM,KAAK,GAAG,IAAA,8BAAc,EAAC,EAAE,CAAC,YAAY,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC,CAAC;AAC1D,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,SAAS,CAAC,CAAC;AACzD,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;AAE7B,CAAC,KAAK,IAAI,EAAE;IACV,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,IAAA,+BAAY,EAAC,SAAS,CAAC,CAAC;IAClD,IAAI,CAAC;QACH,MAAM,EAAE,WAAW,EAAE,GAAG,MAAM,EAAE,GAAG,MAAM,IAAA,8CAAsB,EAAC,SAAS,EAAE,KAAK,CAAC,UAAU,EAAE,KAAK,CAAC,MAAM,IAAI,EAAE,CAAC,CAAC;QACjH,IAAA,6BAAY,EAAC,OAAO,EAAE;YACpB,QAAQ,EAAE,oBAAoB;YAC9B,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;YACnC,KAAK,EAAE,EAAE,GAAG,KAAK,EAAE,MAAM,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,MAAM,CAAC,MAAM,SAAS,CAAC,CAAC,CAAC,SAAS,EAAE;YACxF,aAAa,EAAE,WAAW,CAAC,aAAa;YACxC,aAAa,EAAE,WAAW,CAAC,aAAa;YACxC,gBAAgB,EAAE,WAAW,CAAC,gBAAgB;YAC9C,MAAM,EAAE,EAAE,YAAY,EAAE,MAAM,CAAC,MAAM,CAAC,MAAM,EAAE;YAC9C,UAAU,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS;SACnC,CAAC,CAAC;QACH,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC;QACpC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,IAAA,6BAAY,EAAC,OAAO,EAAE;YACpB,QAAQ,EAAE,oBAAoB;YAC9B,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;YACnC,KAAK,EAAE,EAAE,GAAG,KAAK,EAAE,MAAM,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,MAAM,CAAC,MAAM,SAAS,CAAC,CAAC,CAAC,SAAS,EAAE;YACxF,MAAM,EAAE,IAAI;YACZ,KAAK,EAAE,MAAM,CAAC,GAAG,CAAC;YAClB,UAAU,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS;SACnC,CAAC,CAAC;QACH,OAAO,CAAC,KAAK,CAAC,iCAAiC,EAAE,GAAG,CAAC,CAAC;QACtD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;AACH,CAAC,CAAC,EAAE,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"activity-logger.d.ts","sourceRoot":"","sources":["../../src/activity-logger.ts"],"names":[],"mappings":"AA0BA,wBAAgB,WAAW,CAAC,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,IAAI,CAqBvG"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.activityLog = activityLog;
|
|
7
|
+
const node_fs_1 = __importDefault(require("node:fs"));
|
|
8
|
+
const node_path_1 = __importDefault(require("node:path"));
|
|
9
|
+
function matchesFilter(hookName, message) {
|
|
10
|
+
const filter = process.env.KETCHUP_LOG;
|
|
11
|
+
if (!filter) {
|
|
12
|
+
return true;
|
|
13
|
+
}
|
|
14
|
+
const patterns = filter.split(',').map((p) => p.trim());
|
|
15
|
+
const includes = patterns.filter((p) => !p.startsWith('-'));
|
|
16
|
+
const excludes = patterns.filter((p) => p.startsWith('-')).map((p) => p.slice(1));
|
|
17
|
+
const searchText = `${hookName}: ${message}`;
|
|
18
|
+
const excluded = excludes.some((pattern) => searchText.includes(pattern));
|
|
19
|
+
if (excluded) {
|
|
20
|
+
return false;
|
|
21
|
+
}
|
|
22
|
+
if (includes.length === 0 || includes.includes('*')) {
|
|
23
|
+
return true;
|
|
24
|
+
}
|
|
25
|
+
return includes.some((pattern) => searchText.includes(pattern));
|
|
26
|
+
}
|
|
27
|
+
function activityLog(autoDir, sessionId, hookName, message) {
|
|
28
|
+
if (!matchesFilter(hookName, message)) {
|
|
29
|
+
return;
|
|
30
|
+
}
|
|
31
|
+
const logsDir = node_path_1.default.join(autoDir, 'logs');
|
|
32
|
+
if (!node_fs_1.default.existsSync(logsDir)) {
|
|
33
|
+
node_fs_1.default.mkdirSync(logsDir, { recursive: true });
|
|
34
|
+
}
|
|
35
|
+
const logPath = node_path_1.default.join(logsDir, 'activity.log');
|
|
36
|
+
const now = new Date();
|
|
37
|
+
const month = String(now.getMonth() + 1).padStart(2, '0');
|
|
38
|
+
const day = String(now.getDate()).padStart(2, '0');
|
|
39
|
+
const hours = String(now.getHours()).padStart(2, '0');
|
|
40
|
+
const minutes = String(now.getMinutes()).padStart(2, '0');
|
|
41
|
+
const seconds = String(now.getSeconds()).padStart(2, '0');
|
|
42
|
+
const timestamp = `${month}-${day} ${hours}:${minutes}:${seconds}`;
|
|
43
|
+
const shortSessionId = sessionId.slice(-8);
|
|
44
|
+
const entry = `${timestamp} [${shortSessionId}] ${hookName}: ${message}\n`;
|
|
45
|
+
node_fs_1.default.appendFileSync(logPath, entry);
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=activity-logger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"activity-logger.js","sourceRoot":"","sources":["../../src/activity-logger.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"activity-logger.test.d.ts","sourceRoot":"","sources":["../../src/activity-logger.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const node_fs_1 = __importDefault(require("node:fs"));
|
|
7
|
+
const node_os_1 = __importDefault(require("node:os"));
|
|
8
|
+
const node_path_1 = __importDefault(require("node:path"));
|
|
9
|
+
const vitest_1 = require("vitest");
|
|
10
|
+
const activity_logger_js_1 = require("./activity-logger.js");
|
|
11
|
+
(0, vitest_1.describe)('activity-logger', () => {
|
|
12
|
+
let tempDir;
|
|
13
|
+
const originalEnv = process.env.KETCHUP_LOG;
|
|
14
|
+
(0, vitest_1.beforeEach)(() => {
|
|
15
|
+
tempDir = node_fs_1.default.mkdtempSync(node_path_1.default.join(node_os_1.default.tmpdir(), 'claude-auto-activity-'));
|
|
16
|
+
delete process.env.KETCHUP_LOG;
|
|
17
|
+
});
|
|
18
|
+
(0, vitest_1.afterEach)(() => {
|
|
19
|
+
node_fs_1.default.rmSync(tempDir, { recursive: true });
|
|
20
|
+
if (originalEnv === undefined) {
|
|
21
|
+
delete process.env.KETCHUP_LOG;
|
|
22
|
+
}
|
|
23
|
+
else {
|
|
24
|
+
process.env.KETCHUP_LOG = originalEnv;
|
|
25
|
+
}
|
|
26
|
+
});
|
|
27
|
+
(0, vitest_1.it)('writes to .claude-auto/logs/activity.log', () => {
|
|
28
|
+
const autoDir = node_path_1.default.join(tempDir, '.claude-auto');
|
|
29
|
+
node_fs_1.default.mkdirSync(autoDir, { recursive: true });
|
|
30
|
+
(0, activity_logger_js_1.activityLog)(autoDir, 'session-123', 'test-hook', 'test message');
|
|
31
|
+
const logPath = node_path_1.default.join(autoDir, 'logs', 'activity.log');
|
|
32
|
+
(0, vitest_1.expect)(node_fs_1.default.existsSync(logPath)).toBe(true);
|
|
33
|
+
const content = node_fs_1.default.readFileSync(logPath, 'utf8');
|
|
34
|
+
(0, vitest_1.expect)(content).toContain('test-hook');
|
|
35
|
+
(0, vitest_1.expect)(content).toContain('test message');
|
|
36
|
+
});
|
|
37
|
+
(0, vitest_1.it)('formats log with short date+time and last 8 chars of session ID', () => {
|
|
38
|
+
const autoDir = node_path_1.default.join(tempDir, '.claude-auto');
|
|
39
|
+
node_fs_1.default.mkdirSync(autoDir, { recursive: true });
|
|
40
|
+
(0, activity_logger_js_1.activityLog)(autoDir, 'abc12345-6789-defg', 'session-start', 'loaded reminders');
|
|
41
|
+
const logPath = node_path_1.default.join(autoDir, 'logs', 'activity.log');
|
|
42
|
+
const content = node_fs_1.default.readFileSync(logPath, 'utf8');
|
|
43
|
+
(0, vitest_1.expect)(content).toMatch(/^\d{2}-\d{2} \d{2}:\d{2}:\d{2}/);
|
|
44
|
+
(0, vitest_1.expect)(content).toContain('[789-defg]');
|
|
45
|
+
(0, vitest_1.expect)(content).toContain('session-start:');
|
|
46
|
+
(0, vitest_1.expect)(content).toContain('loaded reminders');
|
|
47
|
+
});
|
|
48
|
+
(0, vitest_1.it)('appends multiple log entries', () => {
|
|
49
|
+
const autoDir = node_path_1.default.join(tempDir, '.claude-auto');
|
|
50
|
+
node_fs_1.default.mkdirSync(autoDir, { recursive: true });
|
|
51
|
+
(0, activity_logger_js_1.activityLog)(autoDir, 'session-1', 'hook-a', 'message 1');
|
|
52
|
+
(0, activity_logger_js_1.activityLog)(autoDir, 'session-2', 'hook-b', 'message 2');
|
|
53
|
+
const logPath = node_path_1.default.join(autoDir, 'logs', 'activity.log');
|
|
54
|
+
const content = node_fs_1.default.readFileSync(logPath, 'utf8');
|
|
55
|
+
const lines = content.trim().split('\n');
|
|
56
|
+
(0, vitest_1.expect)(lines).toHaveLength(2);
|
|
57
|
+
(0, vitest_1.expect)(lines[0]).toContain('message 1');
|
|
58
|
+
(0, vitest_1.expect)(lines[1]).toContain('message 2');
|
|
59
|
+
});
|
|
60
|
+
(0, vitest_1.it)('filters by KETCHUP_LOG env when set to specific hook', () => {
|
|
61
|
+
process.env.KETCHUP_LOG = 'session-start';
|
|
62
|
+
const autoDir = node_path_1.default.join(tempDir, '.claude-auto');
|
|
63
|
+
node_fs_1.default.mkdirSync(autoDir, { recursive: true });
|
|
64
|
+
(0, activity_logger_js_1.activityLog)(autoDir, 'session-1', 'session-start', 'started');
|
|
65
|
+
(0, activity_logger_js_1.activityLog)(autoDir, 'session-1', 'pre-tool-use', 'allowed: file.ts');
|
|
66
|
+
const logPath = node_path_1.default.join(autoDir, 'logs', 'activity.log');
|
|
67
|
+
const content = node_fs_1.default.readFileSync(logPath, 'utf8');
|
|
68
|
+
(0, vitest_1.expect)(content).toContain('session-start');
|
|
69
|
+
(0, vitest_1.expect)(content).not.toContain('pre-tool-use');
|
|
70
|
+
});
|
|
71
|
+
(0, vitest_1.it)('allows multiple comma-separated patterns in KETCHUP_LOG', () => {
|
|
72
|
+
process.env.KETCHUP_LOG = 'session-start,block';
|
|
73
|
+
const autoDir = node_path_1.default.join(tempDir, '.claude-auto');
|
|
74
|
+
node_fs_1.default.mkdirSync(autoDir, { recursive: true });
|
|
75
|
+
(0, activity_logger_js_1.activityLog)(autoDir, 'session-1', 'session-start', 'started');
|
|
76
|
+
(0, activity_logger_js_1.activityLog)(autoDir, 'session-1', 'pre-tool-use', 'block: denied');
|
|
77
|
+
(0, activity_logger_js_1.activityLog)(autoDir, 'session-1', 'pre-tool-use', 'allowed: file.ts');
|
|
78
|
+
const logPath = node_path_1.default.join(autoDir, 'logs', 'activity.log');
|
|
79
|
+
const content = node_fs_1.default.readFileSync(logPath, 'utf8');
|
|
80
|
+
(0, vitest_1.expect)(content).toContain('session-start');
|
|
81
|
+
(0, vitest_1.expect)(content).toContain('block: denied');
|
|
82
|
+
(0, vitest_1.expect)(content).not.toContain('allowed: file.ts');
|
|
83
|
+
});
|
|
84
|
+
(0, vitest_1.it)('logs everything when KETCHUP_LOG is * or unset', () => {
|
|
85
|
+
const autoDir = node_path_1.default.join(tempDir, '.claude-auto');
|
|
86
|
+
node_fs_1.default.mkdirSync(autoDir, { recursive: true });
|
|
87
|
+
(0, activity_logger_js_1.activityLog)(autoDir, 'session-1', 'session-start', 'started');
|
|
88
|
+
(0, activity_logger_js_1.activityLog)(autoDir, 'session-1', 'pre-tool-use', 'allowed: file.ts');
|
|
89
|
+
const logPath = node_path_1.default.join(autoDir, 'logs', 'activity.log');
|
|
90
|
+
const content = node_fs_1.default.readFileSync(logPath, 'utf8');
|
|
91
|
+
(0, vitest_1.expect)(content).toContain('session-start');
|
|
92
|
+
(0, vitest_1.expect)(content).toContain('pre-tool-use');
|
|
93
|
+
});
|
|
94
|
+
(0, vitest_1.it)('excludes patterns prefixed with -', () => {
|
|
95
|
+
process.env.KETCHUP_LOG = '*,-allowed';
|
|
96
|
+
const autoDir = node_path_1.default.join(tempDir, '.claude-auto');
|
|
97
|
+
node_fs_1.default.mkdirSync(autoDir, { recursive: true });
|
|
98
|
+
(0, activity_logger_js_1.activityLog)(autoDir, 'session-1', 'session-start', 'started');
|
|
99
|
+
(0, activity_logger_js_1.activityLog)(autoDir, 'session-1', 'pre-tool-use', 'blocked: secret.ts');
|
|
100
|
+
(0, activity_logger_js_1.activityLog)(autoDir, 'session-1', 'pre-tool-use', 'allowed: file.ts');
|
|
101
|
+
const logPath = node_path_1.default.join(autoDir, 'logs', 'activity.log');
|
|
102
|
+
const content = node_fs_1.default.readFileSync(logPath, 'utf8');
|
|
103
|
+
(0, vitest_1.expect)(content).toContain('session-start');
|
|
104
|
+
(0, vitest_1.expect)(content).toContain('blocked: secret.ts');
|
|
105
|
+
(0, vitest_1.expect)(content).not.toContain('allowed: file.ts');
|
|
106
|
+
});
|
|
107
|
+
(0, vitest_1.it)('combines includes and excludes', () => {
|
|
108
|
+
process.env.KETCHUP_LOG = 'pre-tool-use,-allowed';
|
|
109
|
+
const autoDir = node_path_1.default.join(tempDir, '.claude-auto');
|
|
110
|
+
node_fs_1.default.mkdirSync(autoDir, { recursive: true });
|
|
111
|
+
(0, activity_logger_js_1.activityLog)(autoDir, 'session-1', 'session-start', 'started');
|
|
112
|
+
(0, activity_logger_js_1.activityLog)(autoDir, 'session-1', 'pre-tool-use', 'blocked: secret.ts');
|
|
113
|
+
(0, activity_logger_js_1.activityLog)(autoDir, 'session-1', 'pre-tool-use', 'allowed: file.ts');
|
|
114
|
+
const logPath = node_path_1.default.join(autoDir, 'logs', 'activity.log');
|
|
115
|
+
const content = node_fs_1.default.readFileSync(logPath, 'utf8');
|
|
116
|
+
(0, vitest_1.expect)(content).not.toContain('session-start');
|
|
117
|
+
(0, vitest_1.expect)(content).toContain('blocked: secret.ts');
|
|
118
|
+
(0, vitest_1.expect)(content).not.toContain('allowed: file.ts');
|
|
119
|
+
});
|
|
120
|
+
});
|
|
121
|
+
//# sourceMappingURL=activity-logger.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"activity-logger.test.js","sourceRoot":"","sources":["../../src/activity-logger.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"clean-logs.d.ts","sourceRoot":"","sources":["../../src/clean-logs.ts"],"names":[],"mappings":"AAKA,MAAM,WAAW,eAAe;IAC9B,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,IAAI,EAAE,MAAM,CAAC;CACd;AAED,wBAAgB,SAAS,CAAC,OAAO,EAAE,MAAM,EAAE,aAAa,GAAE,MAAwB,GAAG,eAAe,CA4BnG"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.cleanLogs = cleanLogs;
|
|
4
|
+
const node_fs_1 = require("node:fs");
|
|
5
|
+
const node_path_1 = require("node:path");
|
|
6
|
+
const DEFAULT_MINUTES = 60;
|
|
7
|
+
function cleanLogs(logsDir, maxAgeMinutes = DEFAULT_MINUTES) {
|
|
8
|
+
const now = Date.now();
|
|
9
|
+
const maxAgeMs = maxAgeMinutes * 60 * 1000;
|
|
10
|
+
const deleted = [];
|
|
11
|
+
let kept = 0;
|
|
12
|
+
try {
|
|
13
|
+
const files = (0, node_fs_1.readdirSync)(logsDir);
|
|
14
|
+
for (const file of files) {
|
|
15
|
+
const filePath = (0, node_path_1.join)(logsDir, file);
|
|
16
|
+
try {
|
|
17
|
+
const stats = (0, node_fs_1.statSync)(filePath);
|
|
18
|
+
if (!stats.isFile())
|
|
19
|
+
continue;
|
|
20
|
+
if (now - stats.mtimeMs > maxAgeMs) {
|
|
21
|
+
(0, node_fs_1.unlinkSync)(filePath);
|
|
22
|
+
deleted.push(file);
|
|
23
|
+
}
|
|
24
|
+
else {
|
|
25
|
+
kept++;
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
catch {
|
|
29
|
+
// Skip files we can't stat or delete
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
catch {
|
|
34
|
+
// Directory doesn't exist or can't be read
|
|
35
|
+
}
|
|
36
|
+
return { deleted, kept };
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=clean-logs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"clean-logs.js","sourceRoot":"","sources":["../../src/clean-logs.ts"],"names":[],"mappings":";;AAUA,8BA4BC;AAtCD,qCAA4D;AAC5D,yCAAiC;AAEjC,MAAM,eAAe,GAAG,EAAE,CAAC;AAO3B,SAAgB,SAAS,CAAC,OAAe,EAAE,gBAAwB,eAAe;IAChF,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;IACvB,MAAM,QAAQ,GAAG,aAAa,GAAG,EAAE,GAAG,IAAI,CAAC;IAC3C,MAAM,OAAO,GAAa,EAAE,CAAC;IAC7B,IAAI,IAAI,GAAG,CAAC,CAAC;IAEb,IAAI,CAAC;QACH,MAAM,KAAK,GAAG,IAAA,qBAAW,EAAC,OAAO,CAAC,CAAC;QACnC,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;YACzB,MAAM,QAAQ,GAAG,IAAA,gBAAI,EAAC,OAAO,EAAE,IAAI,CAAC,CAAC;YACrC,IAAI,CAAC;gBACH,MAAM,KAAK,GAAG,IAAA,kBAAQ,EAAC,QAAQ,CAAC,CAAC;gBACjC,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE;oBAAE,SAAS;gBAC9B,IAAI,GAAG,GAAG,KAAK,CAAC,OAAO,GAAG,QAAQ,EAAE,CAAC;oBACnC,IAAA,oBAAU,EAAC,QAAQ,CAAC,CAAC;oBACrB,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBACrB,CAAC;qBAAM,CAAC;oBACN,IAAI,EAAE,CAAC;gBACT,CAAC;YACH,CAAC;YAAC,MAAM,CAAC;gBACP,qCAAqC;YACvC,CAAC;QACH,CAAC;IACH,CAAC;IAAC,MAAM,CAAC;QACP,2CAA2C;IAC7C,CAAC;IAED,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;AAC3B,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"clean-logs.test.d.ts","sourceRoot":"","sources":["../../src/clean-logs.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,101 @@
|
|
|
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 clean_logs_js_1 = require("./clean-logs.js");
|
|
41
|
+
(0, vitest_1.describe)('clean-logs', () => {
|
|
42
|
+
let tempDir;
|
|
43
|
+
(0, vitest_1.beforeEach)(() => {
|
|
44
|
+
tempDir = fs.mkdtempSync(path.join(os.tmpdir(), 'ketchup-cleanlogs-'));
|
|
45
|
+
});
|
|
46
|
+
(0, vitest_1.afterEach)(() => {
|
|
47
|
+
fs.rmSync(tempDir, { recursive: true, force: true });
|
|
48
|
+
vitest_1.vi.restoreAllMocks();
|
|
49
|
+
});
|
|
50
|
+
(0, vitest_1.it)('deletes log files older than maxAgeMinutes', () => {
|
|
51
|
+
const oldFile = path.join(tempDir, 'old.log');
|
|
52
|
+
const newFile = path.join(tempDir, 'new.log');
|
|
53
|
+
fs.writeFileSync(oldFile, 'old content');
|
|
54
|
+
fs.writeFileSync(newFile, 'new content');
|
|
55
|
+
const oldTime = Date.now() - 120 * 60 * 1000;
|
|
56
|
+
fs.utimesSync(oldFile, new Date(oldTime), new Date(oldTime));
|
|
57
|
+
const result = (0, clean_logs_js_1.cleanLogs)(tempDir, 60);
|
|
58
|
+
(0, vitest_1.expect)(result.deleted).toEqual(['old.log']);
|
|
59
|
+
(0, vitest_1.expect)(result.kept).toBe(1);
|
|
60
|
+
(0, vitest_1.expect)(fs.existsSync(oldFile)).toBe(false);
|
|
61
|
+
(0, vitest_1.expect)(fs.existsSync(newFile)).toBe(true);
|
|
62
|
+
});
|
|
63
|
+
(0, vitest_1.it)('keeps files newer than maxAgeMinutes', () => {
|
|
64
|
+
const newFile = path.join(tempDir, 'recent.log');
|
|
65
|
+
fs.writeFileSync(newFile, 'content');
|
|
66
|
+
const result = (0, clean_logs_js_1.cleanLogs)(tempDir, 60);
|
|
67
|
+
(0, vitest_1.expect)(result.deleted).toEqual([]);
|
|
68
|
+
(0, vitest_1.expect)(result.kept).toBe(1);
|
|
69
|
+
(0, vitest_1.expect)(fs.existsSync(newFile)).toBe(true);
|
|
70
|
+
});
|
|
71
|
+
(0, vitest_1.it)('returns empty results when directory does not exist', () => {
|
|
72
|
+
const result = (0, clean_logs_js_1.cleanLogs)('/nonexistent/path', 60);
|
|
73
|
+
(0, vitest_1.expect)(result.deleted).toEqual([]);
|
|
74
|
+
(0, vitest_1.expect)(result.kept).toBe(0);
|
|
75
|
+
});
|
|
76
|
+
(0, vitest_1.it)('skips subdirectories', () => {
|
|
77
|
+
const subDir = path.join(tempDir, 'subdir');
|
|
78
|
+
fs.mkdirSync(subDir);
|
|
79
|
+
const result = (0, clean_logs_js_1.cleanLogs)(tempDir, 60);
|
|
80
|
+
(0, vitest_1.expect)(result.deleted).toEqual([]);
|
|
81
|
+
(0, vitest_1.expect)(result.kept).toBe(0);
|
|
82
|
+
(0, vitest_1.expect)(fs.existsSync(subDir)).toBe(true);
|
|
83
|
+
});
|
|
84
|
+
(0, vitest_1.it)('uses default age of 60 minutes', () => {
|
|
85
|
+
const oldFile = path.join(tempDir, 'old.log');
|
|
86
|
+
fs.writeFileSync(oldFile, 'content');
|
|
87
|
+
const oldTime = Date.now() - 61 * 60 * 1000;
|
|
88
|
+
fs.utimesSync(oldFile, new Date(oldTime), new Date(oldTime));
|
|
89
|
+
const result = (0, clean_logs_js_1.cleanLogs)(tempDir);
|
|
90
|
+
(0, vitest_1.expect)(result.deleted).toEqual(['old.log']);
|
|
91
|
+
});
|
|
92
|
+
(0, vitest_1.it)('skips files that cannot be stat-ed (broken symlinks)', () => {
|
|
93
|
+
const brokenSymlink = path.join(tempDir, 'broken.log');
|
|
94
|
+
fs.symlinkSync('/nonexistent/target', brokenSymlink);
|
|
95
|
+
const goodFile = path.join(tempDir, 'good.log');
|
|
96
|
+
fs.writeFileSync(goodFile, 'content');
|
|
97
|
+
const result = (0, clean_logs_js_1.cleanLogs)(tempDir);
|
|
98
|
+
(0, vitest_1.expect)(result.kept).toBe(1);
|
|
99
|
+
});
|
|
100
|
+
});
|
|
101
|
+
//# sourceMappingURL=clean-logs.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"clean-logs.test.js","sourceRoot":"","sources":["../../src/clean-logs.test.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,4CAA8B;AAC9B,4CAA8B;AAC9B,gDAAkC;AAElC,mCAAyE;AAEzE,mDAA4C;AAE5C,IAAA,iBAAQ,EAAC,YAAY,EAAE,GAAG,EAAE;IAC1B,IAAI,OAAe,CAAC;IAEpB,IAAA,mBAAU,EAAC,GAAG,EAAE;QACd,OAAO,GAAG,EAAE,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,MAAM,EAAE,EAAE,oBAAoB,CAAC,CAAC,CAAC;IACzE,CAAC,CAAC,CAAC;IAEH,IAAA,kBAAS,EAAC,GAAG,EAAE;QACb,EAAE,CAAC,MAAM,CAAC,OAAO,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;QACrD,WAAE,CAAC,eAAe,EAAE,CAAC;IACvB,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,4CAA4C,EAAE,GAAG,EAAE;QACpD,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;QAC9C,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;QAC9C,EAAE,CAAC,aAAa,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC;QACzC,EAAE,CAAC,aAAa,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC;QAEzC,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC;QAC7C,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,IAAI,IAAI,CAAC,OAAO,CAAC,EAAE,IAAI,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;QAE7D,MAAM,MAAM,GAAG,IAAA,yBAAS,EAAC,OAAO,EAAE,EAAE,CAAC,CAAC;QAEtC,IAAA,eAAM,EAAC,MAAM,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;QAC5C,IAAA,eAAM,EAAC,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC5B,IAAA,eAAM,EAAC,EAAE,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC3C,IAAA,eAAM,EAAC,EAAE,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC5C,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,sCAAsC,EAAE,GAAG,EAAE;QAC9C,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,YAAY,CAAC,CAAC;QACjD,EAAE,CAAC,aAAa,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;QAErC,MAAM,MAAM,GAAG,IAAA,yBAAS,EAAC,OAAO,EAAE,EAAE,CAAC,CAAC;QAEtC,IAAA,eAAM,EAAC,MAAM,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QACnC,IAAA,eAAM,EAAC,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC5B,IAAA,eAAM,EAAC,EAAE,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC5C,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,qDAAqD,EAAE,GAAG,EAAE;QAC7D,MAAM,MAAM,GAAG,IAAA,yBAAS,EAAC,mBAAmB,EAAE,EAAE,CAAC,CAAC;QAElD,IAAA,eAAM,EAAC,MAAM,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QACnC,IAAA,eAAM,EAAC,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC9B,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,sBAAsB,EAAE,GAAG,EAAE;QAC9B,MAAM,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC;QAC5C,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QAErB,MAAM,MAAM,GAAG,IAAA,yBAAS,EAAC,OAAO,EAAE,EAAE,CAAC,CAAC;QAEtC,IAAA,eAAM,EAAC,MAAM,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QACnC,IAAA,eAAM,EAAC,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC5B,IAAA,eAAM,EAAC,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC3C,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,gCAAgC,EAAE,GAAG,EAAE;QACxC,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;QAC9C,EAAE,CAAC,aAAa,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;QACrC,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC;QAC5C,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,IAAI,IAAI,CAAC,OAAO,CAAC,EAAE,IAAI,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;QAE7D,MAAM,MAAM,GAAG,IAAA,yBAAS,EAAC,OAAO,CAAC,CAAC;QAElC,IAAA,eAAM,EAAC,MAAM,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;IAC9C,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,sDAAsD,EAAE,GAAG,EAAE;QAC9D,MAAM,aAAa,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,YAAY,CAAC,CAAC;QACvD,EAAE,CAAC,WAAW,CAAC,qBAAqB,EAAE,aAAa,CAAC,CAAC;QACrD,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC;QAChD,EAAE,CAAC,aAAa,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC;QAEtC,MAAM,MAAM,GAAG,IAAA,yBAAS,EAAC,OAAO,CAAC,CAAC;QAElC,IAAA,eAAM,EAAC,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC9B,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cli.d.ts","sourceRoot":"","sources":["../../../src/cli/cli.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAIpC,wBAAgB,SAAS,IAAI,OAAO,CA+BnC"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createCli = createCli;
|
|
4
|
+
const commander_1 = require("commander");
|
|
5
|
+
const install_js_1 = require("./install.js");
|
|
6
|
+
function createCli() {
|
|
7
|
+
const program = new commander_1.Command();
|
|
8
|
+
program.name('claude-auto').description('Husky-style hooks and skills management for Claude Code');
|
|
9
|
+
program
|
|
10
|
+
.command('install')
|
|
11
|
+
.description('Install claude-auto hooks configuration into a project')
|
|
12
|
+
.argument('[path]', 'target project directory', '.')
|
|
13
|
+
.option('--local', 'install from source using tsx (for local dev)')
|
|
14
|
+
.action(async (targetPath, options) => {
|
|
15
|
+
const result = await (0, install_js_1.install)(targetPath, { local: options.local });
|
|
16
|
+
if (result.status === 'updated') {
|
|
17
|
+
console.log(`claude-auto already installed, updating ${result.targetDir}`);
|
|
18
|
+
}
|
|
19
|
+
else {
|
|
20
|
+
console.log(`Installing claude-auto into ${result.targetDir}`);
|
|
21
|
+
if (result.settingsCreated) {
|
|
22
|
+
console.log(`Created ${result.claudeDir}/settings.json`);
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
});
|
|
26
|
+
program.command('status').description('Show symlink status');
|
|
27
|
+
program.command('doctor').description('Diagnose symlink health');
|
|
28
|
+
program.command('repair').description('Recreate symlinks');
|
|
29
|
+
program.command('reminders').description('List reminders with metadata');
|
|
30
|
+
return program;
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=cli.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cli.js","sourceRoot":"","sources":["../../../src/cli/cli.ts"],"names":[],"mappings":";;AAIA,8BA+BC;AAnCD,yCAAoC;AAEpC,6CAAuC;AAEvC,SAAgB,SAAS;IACvB,MAAM,OAAO,GAAG,IAAI,mBAAO,EAAE,CAAC;IAE9B,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,WAAW,CAAC,yDAAyD,CAAC,CAAC;IAEnG,OAAO;SACJ,OAAO,CAAC,SAAS,CAAC;SAClB,WAAW,CAAC,wDAAwD,CAAC;SACrE,QAAQ,CAAC,QAAQ,EAAE,0BAA0B,EAAE,GAAG,CAAC;SACnD,MAAM,CAAC,SAAS,EAAE,+CAA+C,CAAC;SAClE,MAAM,CAAC,KAAK,EAAE,UAAkB,EAAE,OAA4B,EAAE,EAAE;QACjE,MAAM,MAAM,GAAG,MAAM,IAAA,oBAAO,EAAC,UAAU,EAAE,EAAE,KAAK,EAAE,OAAO,CAAC,KAAK,EAAE,CAAC,CAAC;QACnE,IAAI,MAAM,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;YAChC,OAAO,CAAC,GAAG,CAAC,2CAA2C,MAAM,CAAC,SAAS,EAAE,CAAC,CAAC;QAC7E,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,GAAG,CAAC,+BAA+B,MAAM,CAAC,SAAS,EAAE,CAAC,CAAC;YAC/D,IAAI,MAAM,CAAC,eAAe,EAAE,CAAC;gBAC3B,OAAO,CAAC,GAAG,CAAC,WAAW,MAAM,CAAC,SAAS,gBAAgB,CAAC,CAAC;YAC3D,CAAC;QACH,CAAC;IACH,CAAC,CAAC,CAAC;IAEL,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,WAAW,CAAC,qBAAqB,CAAC,CAAC;IAE7D,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,WAAW,CAAC,yBAAyB,CAAC,CAAC;IAEjE,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,WAAW,CAAC,mBAAmB,CAAC,CAAC;IAE3D,OAAO,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,WAAW,CAAC,8BAA8B,CAAC,CAAC;IAEzE,OAAO,OAAO,CAAC;AACjB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cli.test.d.ts","sourceRoot":"","sources":["../../../src/cli/cli.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const vitest_1 = require("vitest");
|
|
4
|
+
const cli_js_1 = require("./cli.js");
|
|
5
|
+
(0, vitest_1.describe)('createCli', () => {
|
|
6
|
+
(0, vitest_1.it)('creates program with name, description, and all commands', () => {
|
|
7
|
+
const program = (0, cli_js_1.createCli)();
|
|
8
|
+
const commands = program.commands.map((cmd) => cmd.name());
|
|
9
|
+
(0, vitest_1.expect)({
|
|
10
|
+
name: program.name(),
|
|
11
|
+
description: program.description(),
|
|
12
|
+
commands,
|
|
13
|
+
}).toEqual({
|
|
14
|
+
name: 'claude-auto',
|
|
15
|
+
description: 'Husky-style hooks and skills management for Claude Code',
|
|
16
|
+
commands: ['install', 'status', 'doctor', 'repair', 'reminders'],
|
|
17
|
+
});
|
|
18
|
+
});
|
|
19
|
+
(0, vitest_1.it)('install command accepts an optional path argument', () => {
|
|
20
|
+
const program = (0, cli_js_1.createCli)();
|
|
21
|
+
const installCmd = program.commands.find((cmd) => cmd.name() === 'install');
|
|
22
|
+
(0, vitest_1.expect)(installCmd).toBeDefined();
|
|
23
|
+
(0, vitest_1.expect)(installCmd.registeredArguments).toHaveLength(1);
|
|
24
|
+
(0, vitest_1.expect)(installCmd.registeredArguments[0].required).toBe(false);
|
|
25
|
+
});
|
|
26
|
+
});
|
|
27
|
+
//# sourceMappingURL=cli.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cli.test.js","sourceRoot":"","sources":["../../../src/cli/cli.test.ts"],"names":[],"mappings":";;AAAA,mCAA8C;AAE9C,qCAAqC;AAErC,IAAA,iBAAQ,EAAC,WAAW,EAAE,GAAG,EAAE;IACzB,IAAA,WAAE,EAAC,0DAA0D,EAAE,GAAG,EAAE;QAClE,MAAM,OAAO,GAAG,IAAA,kBAAS,GAAE,CAAC;QAC5B,MAAM,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,CAAC;QAE3D,IAAA,eAAM,EAAC;YACL,IAAI,EAAE,OAAO,CAAC,IAAI,EAAE;YACpB,WAAW,EAAE,OAAO,CAAC,WAAW,EAAE;YAClC,QAAQ;SACT,CAAC,CAAC,OAAO,CAAC;YACT,IAAI,EAAE,aAAa;YACnB,WAAW,EAAE,yDAAyD;YACtE,QAAQ,EAAE,CAAC,SAAS,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,WAAW,CAAC;SACjE,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAA,WAAE,EAAC,mDAAmD,EAAE,GAAG,EAAE;QAC3D,MAAM,OAAO,GAAG,IAAA,kBAAS,GAAE,CAAC;QAC5B,MAAM,UAAU,GAAG,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,EAAE,KAAK,SAAS,CAAC,CAAC;QAC5E,IAAA,eAAM,EAAC,UAAU,CAAC,CAAC,WAAW,EAAE,CAAC;QACjC,IAAA,eAAM,EAAC,UAAW,CAAC,mBAAmB,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QACxD,IAAA,eAAM,EAAC,UAAW,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAClE,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"doctor.d.ts","sourceRoot":"","sources":["../../../src/cli/doctor.ts"],"names":[],"mappings":"AAOA,KAAK,YAAY,GAAG;IAClB,OAAO,EAAE,OAAO,CAAC;IACjB,MAAM,EAAE,MAAM,EAAE,CAAC;CAClB,CAAC;AAEF,wBAAsB,MAAM,CAAC,UAAU,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC,CA6BzF"}
|
|
@@ -0,0 +1,67 @@
|
|
|
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.doctor = doctor;
|
|
37
|
+
const path = __importStar(require("node:path"));
|
|
38
|
+
const config_loader_js_1 = require("../config-loader.js");
|
|
39
|
+
const linker_js_1 = require("../linker.js");
|
|
40
|
+
const repair_js_1 = require("./repair.js");
|
|
41
|
+
async function doctor(packageDir, claudeDir) {
|
|
42
|
+
const projectRoot = path.dirname(claudeDir);
|
|
43
|
+
const config = await (0, config_loader_js_1.loadConfig)(projectRoot);
|
|
44
|
+
const autoDirName = config.autoDir ?? config_loader_js_1.DEFAULT_AUTO_DIR;
|
|
45
|
+
const autoDir = path.join(projectRoot, autoDirName);
|
|
46
|
+
const expectedFiles = (0, repair_js_1.getExpectedSymlinks)(packageDir);
|
|
47
|
+
const issues = [];
|
|
48
|
+
for (const file of expectedFiles.claudeFiles) {
|
|
49
|
+
const source = path.join(packageDir, file);
|
|
50
|
+
const target = path.join(claudeDir, file);
|
|
51
|
+
if (!(0, linker_js_1.verifySymlink)(target, source)) {
|
|
52
|
+
issues.push(`Missing or invalid symlink: ${target}`);
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
for (const file of expectedFiles.autoFiles) {
|
|
56
|
+
const source = path.join(packageDir, file);
|
|
57
|
+
const target = path.join(autoDir, file);
|
|
58
|
+
if (!(0, linker_js_1.verifySymlink)(target, source)) {
|
|
59
|
+
issues.push(`Missing or invalid symlink: ${target}`);
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
return {
|
|
63
|
+
healthy: issues.length === 0,
|
|
64
|
+
issues,
|
|
65
|
+
};
|
|
66
|
+
}
|
|
67
|
+
//# sourceMappingURL=doctor.js.map
|