@codemieai/code 0.0.35 → 0.0.37
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/README.md +33 -0
- package/dist/agents/codemie-code/agent.d.ts +1 -1
- package/dist/agents/codemie-code/agent.d.ts.map +1 -1
- package/dist/agents/codemie-code/agent.js +2 -2
- package/dist/agents/codemie-code/agent.js.map +1 -1
- package/dist/agents/codemie-code/index.js +1 -1
- package/dist/agents/codemie-code/index.js.map +1 -1
- package/dist/agents/codemie-code/prompts.d.ts +1 -1
- package/dist/agents/codemie-code/prompts.d.ts.map +1 -1
- package/dist/agents/codemie-code/skills/core/SkillDiscovery.d.ts.map +1 -0
- package/dist/{skills → agents/codemie-code/skills}/core/SkillDiscovery.js +1 -1
- package/dist/agents/codemie-code/skills/core/SkillDiscovery.js.map +1 -0
- package/dist/agents/codemie-code/skills/core/SkillManager.d.ts.map +1 -0
- package/dist/{skills → agents/codemie-code/skills}/core/SkillManager.js +1 -1
- package/dist/agents/codemie-code/skills/core/SkillManager.js.map +1 -0
- package/dist/agents/codemie-code/skills/core/types.d.ts.map +1 -0
- package/dist/agents/codemie-code/skills/core/types.js.map +1 -0
- package/dist/agents/codemie-code/skills/index.d.ts.map +1 -0
- package/dist/agents/codemie-code/skills/index.js.map +1 -0
- package/dist/agents/codemie-code/skills/utils/content-loader.d.ts.map +1 -0
- package/dist/{skills → agents/codemie-code/skills}/utils/content-loader.js +1 -1
- package/dist/agents/codemie-code/skills/utils/content-loader.js.map +1 -0
- package/dist/agents/codemie-code/skills/utils/frontmatter.d.ts.map +1 -0
- package/dist/agents/codemie-code/skills/utils/frontmatter.js.map +1 -0
- package/dist/agents/codemie-code/skills/utils/pattern-matcher.d.ts.map +1 -0
- package/dist/agents/codemie-code/skills/utils/pattern-matcher.js.map +1 -0
- package/dist/agents/codemie-code/tools/assistant-invocation.d.ts.map +1 -1
- package/dist/agents/codemie-code/tools/assistant-invocation.js +2 -2
- package/dist/agents/codemie-code/tools/assistant-invocation.js.map +1 -1
- package/dist/agents/codemie-code/types.d.ts +1 -1
- package/dist/agents/codemie-code/types.d.ts.map +1 -1
- package/dist/agents/core/extension/BaseExtensionInstaller.d.ts.map +1 -1
- package/dist/agents/core/extension/BaseExtensionInstaller.js +11 -4
- package/dist/agents/core/extension/BaseExtensionInstaller.js.map +1 -1
- package/dist/agents/core/session/BaseProcessor.d.ts +22 -1
- package/dist/agents/core/session/BaseProcessor.d.ts.map +1 -1
- package/dist/agents/plugins/claude/claude-acp.plugin.d.ts +5 -0
- package/dist/agents/plugins/claude/claude-acp.plugin.d.ts.map +1 -1
- package/dist/agents/plugins/claude/claude-acp.plugin.js +12 -2
- package/dist/agents/plugins/claude/claude-acp.plugin.js.map +1 -1
- package/dist/agents/plugins/claude/claude.plugin.d.ts.map +1 -1
- package/dist/agents/plugins/claude/claude.plugin.js +5 -1
- package/dist/agents/plugins/claude/claude.plugin.js.map +1 -1
- package/dist/agents/plugins/claude/claude.session.d.ts +5 -0
- package/dist/agents/plugins/claude/claude.session.d.ts.map +1 -1
- package/dist/agents/plugins/claude/claude.session.js +101 -2
- package/dist/agents/plugins/claude/claude.session.js.map +1 -1
- package/dist/agents/plugins/claude/plugin/.claude-plugin/plugin.json +1 -1
- package/dist/agents/plugins/claude/session/processors/claude.conversations-processor.d.ts +0 -1
- package/dist/agents/plugins/claude/session/processors/claude.conversations-processor.d.ts.map +1 -1
- package/dist/agents/plugins/claude/session/processors/claude.conversations-processor.js +13 -19
- package/dist/agents/plugins/claude/session/processors/claude.conversations-processor.js.map +1 -1
- package/dist/agents/plugins/claude/session/processors/claude.metrics-processor.d.ts.map +1 -1
- package/dist/agents/plugins/claude/session/processors/claude.metrics-processor.js +29 -4
- package/dist/agents/plugins/claude/session/processors/claude.metrics-processor.js.map +1 -1
- package/dist/cli/commands/assistants/chat.js +9 -6
- package/dist/cli/commands/assistants/chat.js.map +1 -1
- package/dist/cli/commands/assistants/constants.d.ts +2 -6
- package/dist/cli/commands/assistants/constants.d.ts.map +1 -1
- package/dist/cli/commands/assistants/constants.js +2 -5
- package/dist/cli/commands/assistants/constants.js.map +1 -1
- package/dist/cli/commands/assistants/index.d.ts.map +1 -1
- package/dist/cli/commands/assistants/index.js +1 -11
- package/dist/cli/commands/assistants/index.js.map +1 -1
- package/dist/cli/commands/assistants/setup/configuration/actions.d.ts +30 -0
- package/dist/cli/commands/assistants/setup/configuration/actions.d.ts.map +1 -0
- package/dist/cli/commands/assistants/setup/configuration/actions.js +63 -0
- package/dist/cli/commands/assistants/setup/configuration/actions.js.map +1 -0
- package/dist/cli/commands/assistants/setup/configuration/constants.d.ts +49 -0
- package/dist/cli/commands/assistants/setup/configuration/constants.d.ts.map +1 -0
- package/dist/cli/commands/assistants/setup/configuration/constants.js +56 -0
- package/dist/cli/commands/assistants/setup/configuration/constants.js.map +1 -0
- package/dist/cli/commands/assistants/setup/configuration/index.d.ts +9 -0
- package/dist/cli/commands/assistants/setup/configuration/index.d.ts.map +1 -0
- package/dist/cli/commands/assistants/setup/configuration/index.js +8 -0
- package/dist/cli/commands/assistants/setup/configuration/index.js.map +1 -0
- package/dist/cli/commands/assistants/setup/configuration/selection.d.ts +12 -0
- package/dist/cli/commands/assistants/setup/configuration/selection.d.ts.map +1 -0
- package/dist/cli/commands/assistants/setup/configuration/selection.js +94 -0
- package/dist/cli/commands/assistants/setup/configuration/selection.js.map +1 -0
- package/dist/cli/commands/assistants/setup/configuration/types.d.ts +22 -0
- package/dist/cli/commands/assistants/setup/configuration/types.d.ts.map +1 -0
- package/dist/cli/commands/assistants/setup/configuration/types.js +2 -0
- package/dist/cli/commands/assistants/setup/configuration/types.js.map +1 -0
- package/dist/cli/commands/assistants/setup/configuration/ui.d.ts +9 -0
- package/dist/cli/commands/assistants/setup/configuration/ui.d.ts.map +1 -0
- package/dist/cli/commands/assistants/setup/configuration/ui.js +86 -0
- package/dist/cli/commands/assistants/setup/configuration/ui.js.map +1 -0
- package/dist/cli/commands/assistants/setup/constants.d.ts +26 -0
- package/dist/cli/commands/assistants/setup/constants.d.ts.map +1 -0
- package/dist/cli/commands/assistants/setup/constants.js +21 -0
- package/dist/cli/commands/assistants/setup/constants.js.map +1 -0
- package/dist/cli/commands/assistants/setup/data.d.ts +30 -0
- package/dist/cli/commands/assistants/setup/data.d.ts.map +1 -0
- package/dist/cli/commands/assistants/setup/data.js +125 -0
- package/dist/cli/commands/assistants/setup/data.js.map +1 -0
- package/dist/cli/commands/assistants/setup/generators/claude-agent-generator.d.ts.map +1 -0
- package/dist/cli/commands/assistants/{generators → setup/generators}/claude-agent-generator.js +6 -2
- package/dist/cli/commands/assistants/setup/generators/claude-agent-generator.js.map +1 -0
- package/dist/cli/commands/assistants/setup/generators/claude-skill-generator.d.ts +12 -0
- package/dist/cli/commands/assistants/setup/generators/claude-skill-generator.d.ts.map +1 -0
- package/dist/cli/commands/assistants/setup/generators/claude-skill-generator.js +94 -0
- package/dist/cli/commands/assistants/setup/generators/claude-skill-generator.js.map +1 -0
- package/dist/cli/commands/assistants/setup/helpers.d.ts +27 -0
- package/dist/cli/commands/assistants/setup/helpers.d.ts.map +1 -0
- package/dist/cli/commands/assistants/setup/helpers.js +94 -0
- package/dist/cli/commands/assistants/setup/helpers.js.map +1 -0
- package/dist/cli/commands/assistants/setup/index.d.ts +17 -0
- package/dist/cli/commands/assistants/setup/index.d.ts.map +1 -0
- package/dist/cli/commands/assistants/setup/index.js +193 -0
- package/dist/cli/commands/assistants/setup/index.js.map +1 -0
- package/dist/cli/commands/assistants/setup/manualConfiguration/actions.d.ts +47 -0
- package/dist/cli/commands/assistants/setup/manualConfiguration/actions.d.ts.map +1 -0
- package/dist/cli/commands/assistants/setup/manualConfiguration/actions.js +140 -0
- package/dist/cli/commands/assistants/setup/manualConfiguration/actions.js.map +1 -0
- package/dist/cli/commands/assistants/setup/manualConfiguration/constants.d.ts +56 -0
- package/dist/cli/commands/assistants/setup/manualConfiguration/constants.d.ts.map +1 -0
- package/dist/cli/commands/assistants/setup/manualConfiguration/constants.js +61 -0
- package/dist/cli/commands/assistants/setup/manualConfiguration/constants.js.map +1 -0
- package/dist/cli/commands/assistants/setup/manualConfiguration/index.d.ts +12 -0
- package/dist/cli/commands/assistants/setup/manualConfiguration/index.d.ts.map +1 -0
- package/dist/cli/commands/assistants/setup/manualConfiguration/index.js +48 -0
- package/dist/cli/commands/assistants/setup/manualConfiguration/index.js.map +1 -0
- package/dist/cli/commands/assistants/setup/manualConfiguration/interactive-prompt.d.ts +6 -0
- package/dist/cli/commands/assistants/setup/manualConfiguration/interactive-prompt.d.ts.map +1 -0
- package/dist/cli/commands/assistants/setup/manualConfiguration/interactive-prompt.js +90 -0
- package/dist/cli/commands/assistants/setup/manualConfiguration/interactive-prompt.js.map +1 -0
- package/dist/cli/commands/assistants/setup/manualConfiguration/types.d.ts +37 -0
- package/dist/cli/commands/assistants/setup/manualConfiguration/types.d.ts.map +1 -0
- package/dist/cli/commands/assistants/setup/manualConfiguration/types.js +2 -0
- package/dist/cli/commands/assistants/setup/manualConfiguration/types.js.map +1 -0
- package/dist/cli/commands/assistants/setup/manualConfiguration/ui.d.ts +6 -0
- package/dist/cli/commands/assistants/setup/manualConfiguration/ui.d.ts.map +1 -0
- package/dist/cli/commands/assistants/setup/manualConfiguration/ui.js +103 -0
- package/dist/cli/commands/assistants/setup/manualConfiguration/ui.js.map +1 -0
- package/dist/cli/commands/assistants/setup/selection/actions.d.ts +31 -0
- package/dist/cli/commands/assistants/setup/selection/actions.d.ts.map +1 -0
- package/dist/cli/commands/assistants/setup/selection/actions.js +321 -0
- package/dist/cli/commands/assistants/setup/selection/actions.js.map +1 -0
- package/dist/cli/commands/assistants/setup/selection/constants.d.ts +79 -0
- package/dist/cli/commands/assistants/setup/selection/constants.d.ts.map +1 -0
- package/dist/cli/commands/assistants/setup/selection/constants.js +90 -0
- package/dist/cli/commands/assistants/setup/selection/constants.js.map +1 -0
- package/dist/cli/commands/assistants/setup/selection/index.d.ts +25 -0
- package/dist/cli/commands/assistants/setup/selection/index.d.ts.map +1 -0
- package/dist/cli/commands/assistants/setup/selection/index.js +127 -0
- package/dist/cli/commands/assistants/setup/selection/index.js.map +1 -0
- package/dist/cli/commands/assistants/setup/selection/interactive-prompt.d.ts +20 -0
- package/dist/cli/commands/assistants/setup/selection/interactive-prompt.d.ts.map +1 -0
- package/dist/cli/commands/assistants/setup/selection/interactive-prompt.js +328 -0
- package/dist/cli/commands/assistants/setup/selection/interactive-prompt.js.map +1 -0
- package/dist/cli/commands/assistants/setup/selection/types.d.ts +27 -0
- package/dist/cli/commands/assistants/setup/selection/types.d.ts.map +1 -0
- package/dist/cli/commands/assistants/setup/selection/types.js +2 -0
- package/dist/cli/commands/assistants/setup/selection/types.js.map +1 -0
- package/dist/cli/commands/assistants/setup/selection/ui.d.ts +11 -0
- package/dist/cli/commands/assistants/setup/selection/ui.d.ts.map +1 -0
- package/dist/cli/commands/assistants/setup/selection/ui.js +189 -0
- package/dist/cli/commands/assistants/setup/selection/ui.js.map +1 -0
- package/dist/cli/commands/assistants/setup/selection/utils.d.ts +36 -0
- package/dist/cli/commands/assistants/setup/selection/utils.d.ts.map +1 -0
- package/dist/cli/commands/assistants/setup/selection/utils.js +55 -0
- package/dist/cli/commands/assistants/setup/selection/utils.js.map +1 -0
- package/dist/cli/commands/assistants/setup/summary/index.d.ts +16 -0
- package/dist/cli/commands/assistants/setup/summary/index.d.ts.map +1 -0
- package/dist/cli/commands/assistants/setup/summary/index.js +48 -0
- package/dist/cli/commands/assistants/setup/summary/index.js.map +1 -0
- package/dist/cli/commands/install.d.ts.map +1 -1
- package/dist/cli/commands/install.js +8 -0
- package/dist/cli/commands/install.js.map +1 -1
- package/dist/cli/commands/log/cleaner.d.ts +33 -0
- package/dist/cli/commands/log/cleaner.d.ts.map +1 -0
- package/dist/cli/commands/log/cleaner.js +214 -0
- package/dist/cli/commands/log/cleaner.js.map +1 -0
- package/dist/cli/commands/log/filter.d.ts +55 -0
- package/dist/cli/commands/log/filter.d.ts.map +1 -0
- package/dist/cli/commands/log/filter.js +128 -0
- package/dist/cli/commands/log/filter.js.map +1 -0
- package/dist/cli/commands/log/follower.d.ts +36 -0
- package/dist/cli/commands/log/follower.d.ts.map +1 -0
- package/dist/cli/commands/log/follower.js +151 -0
- package/dist/cli/commands/log/follower.js.map +1 -0
- package/dist/cli/commands/log/formatter.d.ts +76 -0
- package/dist/cli/commands/log/formatter.d.ts.map +1 -0
- package/dist/cli/commands/log/formatter.js +261 -0
- package/dist/cli/commands/log/formatter.js.map +1 -0
- package/dist/cli/commands/log/index.d.ts +6 -0
- package/dist/cli/commands/log/index.d.ts.map +1 -0
- package/dist/cli/commands/log/index.js +398 -0
- package/dist/cli/commands/log/index.js.map +1 -0
- package/dist/cli/commands/log/parser.d.ts +20 -0
- package/dist/cli/commands/log/parser.d.ts.map +1 -0
- package/dist/cli/commands/log/parser.js +111 -0
- package/dist/cli/commands/log/parser.js.map +1 -0
- package/dist/cli/commands/log/reader.d.ts +61 -0
- package/dist/cli/commands/log/reader.d.ts.map +1 -0
- package/dist/cli/commands/log/reader.js +327 -0
- package/dist/cli/commands/log/reader.js.map +1 -0
- package/dist/cli/commands/log/types.d.ts +100 -0
- package/dist/cli/commands/log/types.d.ts.map +1 -0
- package/dist/cli/commands/log/types.js +5 -0
- package/dist/cli/commands/log/types.js.map +1 -0
- package/dist/cli/commands/setup.d.ts.map +1 -1
- package/dist/cli/commands/setup.js +2 -0
- package/dist/cli/commands/setup.js.map +1 -1
- package/dist/cli/commands/skill.js +1 -1
- package/dist/cli/commands/skill.js.map +1 -1
- package/dist/cli/commands/update.d.ts.map +1 -1
- package/dist/cli/commands/update.js +8 -0
- package/dist/cli/commands/update.js.map +1 -1
- package/dist/cli/index.js +2 -0
- package/dist/cli/index.js.map +1 -1
- package/dist/env/types.d.ts +1 -0
- package/dist/env/types.d.ts.map +1 -1
- package/dist/env/types.js.map +1 -1
- package/dist/providers/plugins/sso/session/SessionSyncer.d.ts +5 -0
- package/dist/providers/plugins/sso/session/SessionSyncer.d.ts.map +1 -1
- package/dist/providers/plugins/sso/session/SessionSyncer.js +102 -3
- package/dist/providers/plugins/sso/session/SessionSyncer.js.map +1 -1
- package/dist/providers/plugins/sso/session/processors/conversations/conversation-sync-processor.d.ts +0 -1
- package/dist/providers/plugins/sso/session/processors/conversations/conversation-sync-processor.d.ts.map +1 -1
- package/dist/providers/plugins/sso/session/processors/conversations/conversation-sync-processor.js +25 -48
- package/dist/providers/plugins/sso/session/processors/conversations/conversation-sync-processor.js.map +1 -1
- package/dist/providers/plugins/sso/session/processors/metrics/metrics-sync-processor.d.ts.map +1 -1
- package/dist/providers/plugins/sso/session/processors/metrics/metrics-sync-processor.js +8 -34
- package/dist/providers/plugins/sso/session/processors/metrics/metrics-sync-processor.js.map +1 -1
- package/dist/utils/native-installer.d.ts +1 -0
- package/dist/utils/native-installer.d.ts.map +1 -1
- package/dist/utils/native-installer.js +60 -9
- package/dist/utils/native-installer.js.map +1 -1
- package/dist/utils/windows-path.d.ts +54 -0
- package/dist/utils/windows-path.d.ts.map +1 -0
- package/dist/utils/windows-path.js +347 -0
- package/dist/utils/windows-path.js.map +1 -0
- package/package.json +2 -2
- package/dist/cli/commands/assistants/generators/claude-agent-generator.d.ts.map +0 -1
- package/dist/cli/commands/assistants/generators/claude-agent-generator.js.map +0 -1
- package/dist/cli/commands/assistants/list.d.ts +0 -11
- package/dist/cli/commands/assistants/list.d.ts.map +0 -1
- package/dist/cli/commands/assistants/list.js +0 -323
- package/dist/cli/commands/assistants/list.js.map +0 -1
- package/dist/skills/core/SkillDiscovery.d.ts.map +0 -1
- package/dist/skills/core/SkillDiscovery.js.map +0 -1
- package/dist/skills/core/SkillManager.d.ts.map +0 -1
- package/dist/skills/core/SkillManager.js.map +0 -1
- package/dist/skills/core/types.d.ts.map +0 -1
- package/dist/skills/core/types.js.map +0 -1
- package/dist/skills/index.d.ts.map +0 -1
- package/dist/skills/index.js.map +0 -1
- package/dist/skills/utils/content-loader.d.ts.map +0 -1
- package/dist/skills/utils/content-loader.js.map +0 -1
- package/dist/skills/utils/frontmatter.d.ts.map +0 -1
- package/dist/skills/utils/frontmatter.js.map +0 -1
- package/dist/skills/utils/pattern-matcher.d.ts.map +0 -1
- package/dist/skills/utils/pattern-matcher.js.map +0 -1
- /package/dist/{skills → agents/codemie-code/skills}/core/SkillDiscovery.d.ts +0 -0
- /package/dist/{skills → agents/codemie-code/skills}/core/SkillManager.d.ts +0 -0
- /package/dist/{skills → agents/codemie-code/skills}/core/types.d.ts +0 -0
- /package/dist/{skills → agents/codemie-code/skills}/core/types.js +0 -0
- /package/dist/{skills → agents/codemie-code/skills}/index.d.ts +0 -0
- /package/dist/{skills → agents/codemie-code/skills}/index.js +0 -0
- /package/dist/{skills → agents/codemie-code/skills}/utils/content-loader.d.ts +0 -0
- /package/dist/{skills → agents/codemie-code/skills}/utils/frontmatter.d.ts +0 -0
- /package/dist/{skills → agents/codemie-code/skills}/utils/frontmatter.js +0 -0
- /package/dist/{skills → agents/codemie-code/skills}/utils/pattern-matcher.d.ts +0 -0
- /package/dist/{skills → agents/codemie-code/skills}/utils/pattern-matcher.js +0 -0
- /package/dist/cli/commands/assistants/{generators → setup/generators}/claude-agent-generator.d.ts +0 -0
|
@@ -0,0 +1,214 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Log cleaner - Cleanup old logs and sessions
|
|
3
|
+
*/
|
|
4
|
+
import { readdirSync, statSync, unlinkSync, existsSync } from 'fs';
|
|
5
|
+
import { join } from 'path';
|
|
6
|
+
import { getCodemiePath } from '../../../utils/paths.js';
|
|
7
|
+
/**
|
|
8
|
+
* Clean up old log files and sessions
|
|
9
|
+
*/
|
|
10
|
+
export class LogCleaner {
|
|
11
|
+
logsDir;
|
|
12
|
+
sessionsDir;
|
|
13
|
+
constructor(logsDir, sessionsDir) {
|
|
14
|
+
this.logsDir = logsDir || getCodemiePath('logs');
|
|
15
|
+
this.sessionsDir = sessionsDir || getCodemiePath('sessions');
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* Clean old files
|
|
19
|
+
*/
|
|
20
|
+
clean(retentionDays, includeSessions, dryRun) {
|
|
21
|
+
const stats = {
|
|
22
|
+
debugLogsDeleted: 0,
|
|
23
|
+
sessionsDeleted: 0,
|
|
24
|
+
bytesFreed: 0
|
|
25
|
+
};
|
|
26
|
+
const cutoffTime = Date.now() - (retentionDays * 24 * 60 * 60 * 1000);
|
|
27
|
+
// Clean debug logs
|
|
28
|
+
this.cleanDebugLogs(cutoffTime, dryRun, stats);
|
|
29
|
+
// Clean sessions if requested
|
|
30
|
+
if (includeSessions) {
|
|
31
|
+
this.cleanSessions(cutoffTime, dryRun, stats);
|
|
32
|
+
}
|
|
33
|
+
return stats;
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* Clean debug log files
|
|
37
|
+
*/
|
|
38
|
+
cleanDebugLogs(cutoffTime, dryRun, stats) {
|
|
39
|
+
try {
|
|
40
|
+
if (!existsSync(this.logsDir)) {
|
|
41
|
+
return;
|
|
42
|
+
}
|
|
43
|
+
const files = readdirSync(this.logsDir);
|
|
44
|
+
for (const file of files) {
|
|
45
|
+
// Only process debug log files
|
|
46
|
+
if (!file.match(/^debug-\d{4}-\d{2}-\d{2}\.log$/)) {
|
|
47
|
+
continue;
|
|
48
|
+
}
|
|
49
|
+
const filePath = join(this.logsDir, file);
|
|
50
|
+
try {
|
|
51
|
+
const fileStats = statSync(filePath);
|
|
52
|
+
// Track oldest/newest file dates
|
|
53
|
+
if (!stats.oldestFileDate || fileStats.mtimeMs < stats.oldestFileDate.getTime()) {
|
|
54
|
+
stats.oldestFileDate = new Date(fileStats.mtimeMs);
|
|
55
|
+
}
|
|
56
|
+
if (!stats.newestFileDate || fileStats.mtimeMs > stats.newestFileDate.getTime()) {
|
|
57
|
+
stats.newestFileDate = new Date(fileStats.mtimeMs);
|
|
58
|
+
}
|
|
59
|
+
// Check if file is old enough to delete
|
|
60
|
+
if (fileStats.mtimeMs < cutoffTime) {
|
|
61
|
+
stats.bytesFreed += fileStats.size;
|
|
62
|
+
stats.debugLogsDeleted++;
|
|
63
|
+
if (!dryRun) {
|
|
64
|
+
unlinkSync(filePath);
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
catch {
|
|
69
|
+
// Skip files we can't access
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
catch {
|
|
74
|
+
// Logs directory doesn't exist or can't be read
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
/**
|
|
78
|
+
* Clean session files
|
|
79
|
+
*/
|
|
80
|
+
cleanSessions(cutoffTime, dryRun, stats) {
|
|
81
|
+
try {
|
|
82
|
+
if (!existsSync(this.sessionsDir)) {
|
|
83
|
+
return;
|
|
84
|
+
}
|
|
85
|
+
const files = readdirSync(this.sessionsDir);
|
|
86
|
+
// UUID pattern for session IDs
|
|
87
|
+
const uuidPattern = /^[a-f0-9]{8}-[a-f0-9]{4}-[a-f0-9]{4}-[a-f0-9]{4}-[a-f0-9]{12}$/;
|
|
88
|
+
// Group files by session ID
|
|
89
|
+
const sessionFiles = new Map();
|
|
90
|
+
for (const file of files) {
|
|
91
|
+
// Skip non-session files
|
|
92
|
+
if (!file.endsWith('.json') && !file.endsWith('.jsonl'))
|
|
93
|
+
continue;
|
|
94
|
+
// Extract session ID from filename
|
|
95
|
+
// Patterns: <uuid>.json, completed_<uuid>.json, <uuid>_metrics.jsonl, <uuid>_conversation.jsonl
|
|
96
|
+
let sessionId = null;
|
|
97
|
+
if (file.match(/^[a-f0-9]{8}-[a-f0-9]{4}-[a-f0-9]{4}-[a-f0-9]{4}-[a-f0-9]{12}\.json$/)) {
|
|
98
|
+
// UUID.json
|
|
99
|
+
sessionId = file.replace('.json', '');
|
|
100
|
+
}
|
|
101
|
+
else if (file.match(/^completed_[a-f0-9]{8}-[a-f0-9]{4}-[a-f0-9]{4}-[a-f0-9]{4}-[a-f0-9]{12}\.json$/)) {
|
|
102
|
+
// completed_UUID.json
|
|
103
|
+
sessionId = file.replace('completed_', '').replace('.json', '');
|
|
104
|
+
}
|
|
105
|
+
else if (file.match(/^[a-f0-9]{8}-[a-f0-9]{4}-[a-f0-9]{4}-[a-f0-9]{4}-[a-f0-9]{12}_metrics\.jsonl$/)) {
|
|
106
|
+
// UUID_metrics.jsonl
|
|
107
|
+
sessionId = file.replace('_metrics.jsonl', '');
|
|
108
|
+
}
|
|
109
|
+
else if (file.match(/^[a-f0-9]{8}-[a-f0-9]{4}-[a-f0-9]{4}-[a-f0-9]{4}-[a-f0-9]{12}_conversation\.jsonl$/)) {
|
|
110
|
+
// UUID_conversation.jsonl
|
|
111
|
+
sessionId = file.replace('_conversation.jsonl', '');
|
|
112
|
+
}
|
|
113
|
+
// Only process files with valid UUID session IDs
|
|
114
|
+
if (!sessionId || !uuidPattern.test(sessionId))
|
|
115
|
+
continue;
|
|
116
|
+
if (!sessionFiles.has(sessionId)) {
|
|
117
|
+
sessionFiles.set(sessionId, []);
|
|
118
|
+
}
|
|
119
|
+
sessionFiles.get(sessionId).push(file);
|
|
120
|
+
}
|
|
121
|
+
// Check each session
|
|
122
|
+
for (const [sessionId, files] of sessionFiles.entries()) {
|
|
123
|
+
const sessionFile = join(this.sessionsDir, `${sessionId}.json`);
|
|
124
|
+
try {
|
|
125
|
+
const fileStats = statSync(sessionFile);
|
|
126
|
+
// Track oldest/newest session dates
|
|
127
|
+
if (!stats.oldestFileDate || fileStats.mtimeMs < stats.oldestFileDate.getTime()) {
|
|
128
|
+
stats.oldestFileDate = new Date(fileStats.mtimeMs);
|
|
129
|
+
}
|
|
130
|
+
if (!stats.newestFileDate || fileStats.mtimeMs > stats.newestFileDate.getTime()) {
|
|
131
|
+
stats.newestFileDate = new Date(fileStats.mtimeMs);
|
|
132
|
+
}
|
|
133
|
+
// Check if session is old enough to delete
|
|
134
|
+
if (fileStats.mtimeMs < cutoffTime) {
|
|
135
|
+
// Delete all files associated with this session
|
|
136
|
+
for (const file of files) {
|
|
137
|
+
const filePath = join(this.sessionsDir, file);
|
|
138
|
+
try {
|
|
139
|
+
const fileStats = statSync(filePath);
|
|
140
|
+
stats.bytesFreed += fileStats.size;
|
|
141
|
+
if (!dryRun) {
|
|
142
|
+
unlinkSync(filePath);
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
catch {
|
|
146
|
+
// Skip files we can't delete
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
stats.sessionsDeleted++;
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
catch {
|
|
153
|
+
// Session metadata file doesn't exist or can't be read
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
catch {
|
|
158
|
+
// Sessions directory doesn't exist or can't be read
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
/**
|
|
162
|
+
* Get total size of all log files
|
|
163
|
+
*/
|
|
164
|
+
getLogsSize() {
|
|
165
|
+
let totalBytes = 0;
|
|
166
|
+
try {
|
|
167
|
+
if (!existsSync(this.logsDir)) {
|
|
168
|
+
return 0;
|
|
169
|
+
}
|
|
170
|
+
const files = readdirSync(this.logsDir);
|
|
171
|
+
for (const file of files) {
|
|
172
|
+
const filePath = join(this.logsDir, file);
|
|
173
|
+
try {
|
|
174
|
+
const stats = statSync(filePath);
|
|
175
|
+
totalBytes += stats.size;
|
|
176
|
+
}
|
|
177
|
+
catch {
|
|
178
|
+
// Skip files we can't stat
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
catch {
|
|
183
|
+
// Directory doesn't exist
|
|
184
|
+
}
|
|
185
|
+
return totalBytes;
|
|
186
|
+
}
|
|
187
|
+
/**
|
|
188
|
+
* Get total size of all session files
|
|
189
|
+
*/
|
|
190
|
+
getSessionsSize() {
|
|
191
|
+
let totalBytes = 0;
|
|
192
|
+
try {
|
|
193
|
+
if (!existsSync(this.sessionsDir)) {
|
|
194
|
+
return 0;
|
|
195
|
+
}
|
|
196
|
+
const files = readdirSync(this.sessionsDir);
|
|
197
|
+
for (const file of files) {
|
|
198
|
+
const filePath = join(this.sessionsDir, file);
|
|
199
|
+
try {
|
|
200
|
+
const stats = statSync(filePath);
|
|
201
|
+
totalBytes += stats.size;
|
|
202
|
+
}
|
|
203
|
+
catch {
|
|
204
|
+
// Skip files we can't stat
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
catch {
|
|
209
|
+
// Directory doesn't exist
|
|
210
|
+
}
|
|
211
|
+
return totalBytes;
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
//# sourceMappingURL=cleaner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cleaner.js","sourceRoot":"","sources":["../../../../src/cli/commands/log/cleaner.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Log filter engine - Chainable filtering for log entries
|
|
3
|
+
*/
|
|
4
|
+
import type { LogEntry, LogFilter, LogLevel } from './types.js';
|
|
5
|
+
/**
|
|
6
|
+
* Chainable filter engine for log entries
|
|
7
|
+
*/
|
|
8
|
+
export declare class LogFilterEngine {
|
|
9
|
+
private filters;
|
|
10
|
+
/**
|
|
11
|
+
* Filter by session ID
|
|
12
|
+
*/
|
|
13
|
+
bySession(sessionId: string): this;
|
|
14
|
+
/**
|
|
15
|
+
* Filter by agent name
|
|
16
|
+
*/
|
|
17
|
+
byAgent(agent: string): this;
|
|
18
|
+
/**
|
|
19
|
+
* Filter by profile name
|
|
20
|
+
*/
|
|
21
|
+
byProfile(profile: string): this;
|
|
22
|
+
/**
|
|
23
|
+
* Filter by log level (includes specified level and above)
|
|
24
|
+
*/
|
|
25
|
+
byLevel(level: LogLevel): this;
|
|
26
|
+
/**
|
|
27
|
+
* Filter by date range
|
|
28
|
+
*/
|
|
29
|
+
byDateRange(from?: Date, to?: Date): this;
|
|
30
|
+
/**
|
|
31
|
+
* Filter by pattern (string or regex)
|
|
32
|
+
*/
|
|
33
|
+
byPattern(pattern: string, isRegex?: boolean): this;
|
|
34
|
+
/**
|
|
35
|
+
* Apply all filters to an entry
|
|
36
|
+
*/
|
|
37
|
+
apply(entry: LogEntry): boolean;
|
|
38
|
+
/**
|
|
39
|
+
* Apply filters to an array of entries
|
|
40
|
+
*/
|
|
41
|
+
applyAll(entries: LogEntry[]): LogEntry[];
|
|
42
|
+
/**
|
|
43
|
+
* Create filter from LogFilter object
|
|
44
|
+
*/
|
|
45
|
+
static fromFilter(filter?: LogFilter): LogFilterEngine;
|
|
46
|
+
/**
|
|
47
|
+
* Check if filter has any active filters
|
|
48
|
+
*/
|
|
49
|
+
hasFilters(): boolean;
|
|
50
|
+
/**
|
|
51
|
+
* Get count of active filters
|
|
52
|
+
*/
|
|
53
|
+
getFilterCount(): number;
|
|
54
|
+
}
|
|
55
|
+
//# sourceMappingURL=filter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"filter.d.ts","sourceRoot":"","sources":["../../../../src/cli/commands/log/filter.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAK,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAEhE;;GAEG;AACH,qBAAa,eAAe;IAC1B,OAAO,CAAC,OAAO,CAA2C;IAE1D;;OAEG;IACH,SAAS,CAAC,SAAS,EAAE,MAAM,GAAG,IAAI;IAKlC;;OAEG;IACH,OAAO,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAK5B;;OAEG;IACH,SAAS,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI;IAKhC;;OAEG;IACH,OAAO,CAAC,KAAK,EAAE,QAAQ,GAAG,IAAI;IAY9B;;OAEG;IACH,WAAW,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,EAAE,CAAC,EAAE,IAAI,GAAG,IAAI;IAUzC;;OAEG;IACH,SAAS,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,UAAQ,GAAG,IAAI;IAwBjD;;OAEG;IACH,KAAK,CAAC,KAAK,EAAE,QAAQ,GAAG,OAAO;IAI/B;;OAEG;IACH,QAAQ,CAAC,OAAO,EAAE,QAAQ,EAAE,GAAG,QAAQ,EAAE;IAIzC;;OAEG;IACH,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,SAAS,GAAG,eAAe;IAetD;;OAEG;IACH,UAAU,IAAI,OAAO;IAIrB;;OAEG;IACH,cAAc,IAAI,MAAM;CAGzB"}
|
|
@@ -0,0 +1,128 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Log filter engine - Chainable filtering for log entries
|
|
3
|
+
*/
|
|
4
|
+
/**
|
|
5
|
+
* Chainable filter engine for log entries
|
|
6
|
+
*/
|
|
7
|
+
export class LogFilterEngine {
|
|
8
|
+
filters = [];
|
|
9
|
+
/**
|
|
10
|
+
* Filter by session ID
|
|
11
|
+
*/
|
|
12
|
+
bySession(sessionId) {
|
|
13
|
+
this.filters.push(entry => entry.sessionId === sessionId);
|
|
14
|
+
return this;
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* Filter by agent name
|
|
18
|
+
*/
|
|
19
|
+
byAgent(agent) {
|
|
20
|
+
this.filters.push(entry => entry.agent === agent);
|
|
21
|
+
return this;
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* Filter by profile name
|
|
25
|
+
*/
|
|
26
|
+
byProfile(profile) {
|
|
27
|
+
this.filters.push(entry => entry.profile === profile);
|
|
28
|
+
return this;
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* Filter by log level (includes specified level and above)
|
|
32
|
+
*/
|
|
33
|
+
byLevel(level) {
|
|
34
|
+
const levels = { debug: 0, info: 1, warn: 2, error: 3 };
|
|
35
|
+
const filterLevel = levels[level] || 0;
|
|
36
|
+
this.filters.push(entry => {
|
|
37
|
+
const entryLevel = levels[entry.level] || 0;
|
|
38
|
+
return entryLevel >= filterLevel;
|
|
39
|
+
});
|
|
40
|
+
return this;
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* Filter by date range
|
|
44
|
+
*/
|
|
45
|
+
byDateRange(from, to) {
|
|
46
|
+
if (from) {
|
|
47
|
+
this.filters.push(entry => entry.timestamp >= from);
|
|
48
|
+
}
|
|
49
|
+
if (to) {
|
|
50
|
+
this.filters.push(entry => entry.timestamp <= to);
|
|
51
|
+
}
|
|
52
|
+
return this;
|
|
53
|
+
}
|
|
54
|
+
/**
|
|
55
|
+
* Filter by pattern (string or regex)
|
|
56
|
+
*/
|
|
57
|
+
byPattern(pattern, isRegex = false) {
|
|
58
|
+
if (isRegex) {
|
|
59
|
+
try {
|
|
60
|
+
const regex = new RegExp(pattern, 'i');
|
|
61
|
+
this.filters.push(entry => {
|
|
62
|
+
const searchText = `${entry.agent} ${entry.message}`;
|
|
63
|
+
return regex.test(searchText);
|
|
64
|
+
});
|
|
65
|
+
}
|
|
66
|
+
catch {
|
|
67
|
+
// Invalid regex, fallback to string search
|
|
68
|
+
this.filters.push(entry => {
|
|
69
|
+
const searchText = `${entry.agent} ${entry.message}`.toLowerCase();
|
|
70
|
+
return searchText.includes(pattern.toLowerCase());
|
|
71
|
+
});
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
this.filters.push(entry => {
|
|
76
|
+
const searchText = `${entry.agent} ${entry.message}`.toLowerCase();
|
|
77
|
+
return searchText.includes(pattern.toLowerCase());
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
return this;
|
|
81
|
+
}
|
|
82
|
+
/**
|
|
83
|
+
* Apply all filters to an entry
|
|
84
|
+
*/
|
|
85
|
+
apply(entry) {
|
|
86
|
+
return this.filters.every(filter => filter(entry));
|
|
87
|
+
}
|
|
88
|
+
/**
|
|
89
|
+
* Apply filters to an array of entries
|
|
90
|
+
*/
|
|
91
|
+
applyAll(entries) {
|
|
92
|
+
return entries.filter(entry => this.apply(entry));
|
|
93
|
+
}
|
|
94
|
+
/**
|
|
95
|
+
* Create filter from LogFilter object
|
|
96
|
+
*/
|
|
97
|
+
static fromFilter(filter) {
|
|
98
|
+
const engine = new LogFilterEngine();
|
|
99
|
+
if (!filter)
|
|
100
|
+
return engine;
|
|
101
|
+
if (filter.sessionId)
|
|
102
|
+
engine.bySession(filter.sessionId);
|
|
103
|
+
if (filter.agent)
|
|
104
|
+
engine.byAgent(filter.agent);
|
|
105
|
+
if (filter.profile)
|
|
106
|
+
engine.byProfile(filter.profile);
|
|
107
|
+
if (filter.level)
|
|
108
|
+
engine.byLevel(filter.level);
|
|
109
|
+
if (filter.fromDate || filter.toDate)
|
|
110
|
+
engine.byDateRange(filter.fromDate, filter.toDate);
|
|
111
|
+
if (filter.pattern)
|
|
112
|
+
engine.byPattern(filter.pattern, filter.isRegex);
|
|
113
|
+
return engine;
|
|
114
|
+
}
|
|
115
|
+
/**
|
|
116
|
+
* Check if filter has any active filters
|
|
117
|
+
*/
|
|
118
|
+
hasFilters() {
|
|
119
|
+
return this.filters.length > 0;
|
|
120
|
+
}
|
|
121
|
+
/**
|
|
122
|
+
* Get count of active filters
|
|
123
|
+
*/
|
|
124
|
+
getFilterCount() {
|
|
125
|
+
return this.filters.length;
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
//# sourceMappingURL=filter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"filter.js","sourceRoot":"","sources":["../../../../src/cli/commands/log/filter.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Log follower - Real-time log following (tail -f style)
|
|
3
|
+
*/
|
|
4
|
+
import { LogFormatter } from './formatter.js';
|
|
5
|
+
import type { LogFilter } from './types.js';
|
|
6
|
+
/**
|
|
7
|
+
* Follow logs in real-time
|
|
8
|
+
*/
|
|
9
|
+
export declare class LogFollower {
|
|
10
|
+
private watcher;
|
|
11
|
+
private lastPosition;
|
|
12
|
+
private formatter;
|
|
13
|
+
private filter?;
|
|
14
|
+
constructor(formatter: LogFormatter, filter?: LogFilter);
|
|
15
|
+
/**
|
|
16
|
+
* Start following log file
|
|
17
|
+
*/
|
|
18
|
+
follow(logFilePath: string): Promise<void>;
|
|
19
|
+
/**
|
|
20
|
+
* Read new lines from log file
|
|
21
|
+
*/
|
|
22
|
+
private readNewLines;
|
|
23
|
+
/**
|
|
24
|
+
* Read log file from specific position
|
|
25
|
+
*/
|
|
26
|
+
private readFromPosition;
|
|
27
|
+
/**
|
|
28
|
+
* Check if entry matches filter
|
|
29
|
+
*/
|
|
30
|
+
private matchesFilter;
|
|
31
|
+
/**
|
|
32
|
+
* Stop following
|
|
33
|
+
*/
|
|
34
|
+
stop(): void;
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=follower.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"follower.d.ts","sourceRoot":"","sources":["../../../../src/cli/commands/log/follower.ts"],"names":[],"mappings":"AAAA;;GAEG;AAOH,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,KAAK,EAAE,SAAS,EAAY,MAAM,YAAY,CAAC;AAEtD;;GAEG;AACH,qBAAa,WAAW;IACtB,OAAO,CAAC,OAAO,CAA0B;IACzC,OAAO,CAAC,YAAY,CAAK;IACzB,OAAO,CAAC,SAAS,CAAe;IAChC,OAAO,CAAC,MAAM,CAAC,CAAY;gBAEf,SAAS,EAAE,YAAY,EAAE,MAAM,CAAC,EAAE,SAAS;IAKvD;;OAEG;IACG,MAAM,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAwBhD;;OAEG;YACW,YAAY;IA+B1B;;OAEG;YACW,gBAAgB;IAuB9B;;OAEG;IACH,OAAO,CAAC,aAAa;IA+CrB;;OAEG;IACH,IAAI,IAAI,IAAI;CAMb"}
|
|
@@ -0,0 +1,151 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Log follower - Real-time log following (tail -f style)
|
|
3
|
+
*/
|
|
4
|
+
import { watch, statSync } from 'fs';
|
|
5
|
+
import { createInterface } from 'readline';
|
|
6
|
+
import { createReadStream } from 'fs';
|
|
7
|
+
import { parseLogLine } from './parser.js';
|
|
8
|
+
/**
|
|
9
|
+
* Follow logs in real-time
|
|
10
|
+
*/
|
|
11
|
+
export class LogFollower {
|
|
12
|
+
watcher = null;
|
|
13
|
+
lastPosition = 0;
|
|
14
|
+
formatter;
|
|
15
|
+
filter;
|
|
16
|
+
constructor(formatter, filter) {
|
|
17
|
+
this.formatter = formatter;
|
|
18
|
+
this.filter = filter;
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* Start following log file
|
|
22
|
+
*/
|
|
23
|
+
async follow(logFilePath) {
|
|
24
|
+
// Read existing content first
|
|
25
|
+
await this.readNewLines(logFilePath, true);
|
|
26
|
+
// Watch for changes
|
|
27
|
+
this.watcher = watch(logFilePath, async (eventType) => {
|
|
28
|
+
if (eventType === 'change') {
|
|
29
|
+
await this.readNewLines(logFilePath, false);
|
|
30
|
+
}
|
|
31
|
+
});
|
|
32
|
+
// Handle graceful shutdown
|
|
33
|
+
process.on('SIGINT', () => {
|
|
34
|
+
this.stop();
|
|
35
|
+
console.log('\nStopped following logs');
|
|
36
|
+
process.exit(0);
|
|
37
|
+
});
|
|
38
|
+
// Keep process alive
|
|
39
|
+
return new Promise(() => {
|
|
40
|
+
// Never resolves - runs until interrupted
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* Read new lines from log file
|
|
45
|
+
*/
|
|
46
|
+
async readNewLines(logFilePath, _isInitial) {
|
|
47
|
+
try {
|
|
48
|
+
const stats = statSync(logFilePath);
|
|
49
|
+
const currentSize = stats.size;
|
|
50
|
+
// If file was truncated, reset position
|
|
51
|
+
if (currentSize < this.lastPosition) {
|
|
52
|
+
this.lastPosition = 0;
|
|
53
|
+
}
|
|
54
|
+
// Read from last position
|
|
55
|
+
if (currentSize > this.lastPosition) {
|
|
56
|
+
const entries = await this.readFromPosition(logFilePath, this.lastPosition);
|
|
57
|
+
// Apply filter
|
|
58
|
+
const filtered = this.filter
|
|
59
|
+
? entries.filter(entry => this.matchesFilter(entry))
|
|
60
|
+
: entries;
|
|
61
|
+
// Output entries
|
|
62
|
+
for (const entry of filtered) {
|
|
63
|
+
console.log(this.formatter['formatLogEntry'](entry));
|
|
64
|
+
}
|
|
65
|
+
this.lastPosition = currentSize;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
catch {
|
|
69
|
+
// File might not exist yet or can't be read
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
/**
|
|
73
|
+
* Read log file from specific position
|
|
74
|
+
*/
|
|
75
|
+
async readFromPosition(logFilePath, start) {
|
|
76
|
+
const entries = [];
|
|
77
|
+
try {
|
|
78
|
+
const fileStream = createReadStream(logFilePath, { start });
|
|
79
|
+
const rl = createInterface({
|
|
80
|
+
input: fileStream,
|
|
81
|
+
crlfDelay: Infinity
|
|
82
|
+
});
|
|
83
|
+
for await (const line of rl) {
|
|
84
|
+
const entry = parseLogLine(line);
|
|
85
|
+
if (entry) {
|
|
86
|
+
entries.push(entry);
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
catch {
|
|
91
|
+
// Error reading file
|
|
92
|
+
}
|
|
93
|
+
return entries;
|
|
94
|
+
}
|
|
95
|
+
/**
|
|
96
|
+
* Check if entry matches filter
|
|
97
|
+
*/
|
|
98
|
+
matchesFilter(entry) {
|
|
99
|
+
if (!this.filter)
|
|
100
|
+
return true;
|
|
101
|
+
if (this.filter.sessionId && entry.sessionId !== this.filter.sessionId) {
|
|
102
|
+
return false;
|
|
103
|
+
}
|
|
104
|
+
if (this.filter.agent && entry.agent !== this.filter.agent) {
|
|
105
|
+
return false;
|
|
106
|
+
}
|
|
107
|
+
if (this.filter.profile && entry.profile !== this.filter.profile) {
|
|
108
|
+
return false;
|
|
109
|
+
}
|
|
110
|
+
if (this.filter.level) {
|
|
111
|
+
const levels = { debug: 0, info: 1, warn: 2, error: 3 };
|
|
112
|
+
const entryLevel = levels[entry.level] || 0;
|
|
113
|
+
const filterLevel = levels[this.filter.level] || 0;
|
|
114
|
+
if (entryLevel < filterLevel) {
|
|
115
|
+
return false;
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
if (this.filter.pattern) {
|
|
119
|
+
const searchText = `${entry.agent} ${entry.message}`.toLowerCase();
|
|
120
|
+
if (this.filter.isRegex) {
|
|
121
|
+
try {
|
|
122
|
+
const regex = new RegExp(this.filter.pattern, 'i');
|
|
123
|
+
if (!regex.test(searchText)) {
|
|
124
|
+
return false;
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
catch {
|
|
128
|
+
if (!searchText.includes(this.filter.pattern.toLowerCase())) {
|
|
129
|
+
return false;
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
else {
|
|
134
|
+
if (!searchText.includes(this.filter.pattern.toLowerCase())) {
|
|
135
|
+
return false;
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
return true;
|
|
140
|
+
}
|
|
141
|
+
/**
|
|
142
|
+
* Stop following
|
|
143
|
+
*/
|
|
144
|
+
stop() {
|
|
145
|
+
if (this.watcher) {
|
|
146
|
+
this.watcher.close();
|
|
147
|
+
this.watcher = null;
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
//# sourceMappingURL=follower.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"follower.js","sourceRoot":"","sources":["../../../../src/cli/commands/log/follower.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,IAAI,CAAC;AAErC,OAAO,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AAC3C,OAAO,EAAE,gBAAgB,EAAE,MAAM,IAAI,CAAC;AACtC,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAI3C;;GAEG;AACH,MAAM,OAAO,WAAW;IACd,OAAO,GAAqB,IAAI,CAAC;IACjC,YAAY,GAAG,CAAC,CAAC;IACjB,SAAS,CAAe;IACxB,MAAM,CAAa;IAE3B,YAAY,SAAuB,EAAE,MAAkB;QACrD,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;IACvB,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,MAAM,CAAC,WAAmB;QAC9B,8BAA8B;QAC9B,MAAM,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC;QAE3C,oBAAoB;QACpB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,WAAW,EAAE,KAAK,EAAE,SAAS,EAAE,EAAE;YACpD,IAAI,SAAS,KAAK,QAAQ,EAAE,CAAC;gBAC3B,MAAM,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC;YAC9C,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,2BAA2B;QAC3B,OAAO,CAAC,EAAE,CAAC,QAAQ,EAAE,GAAG,EAAE;YACxB,IAAI,CAAC,IAAI,EAAE,CAAC;YACZ,OAAO,CAAC,GAAG,CAAC,0BAA0B,CAAC,CAAC;YACxC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAClB,CAAC,CAAC,CAAC;QAEH,qBAAqB;QACrB,OAAO,IAAI,OAAO,CAAC,GAAG,EAAE;YACtB,0CAA0C;QAC5C,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACK,KAAK,CAAC,YAAY,CAAC,WAAmB,EAAE,UAAmB;QACjE,IAAI,CAAC;YACH,MAAM,KAAK,GAAG,QAAQ,CAAC,WAAW,CAAC,CAAC;YACpC,MAAM,WAAW,GAAG,KAAK,CAAC,IAAI,CAAC;YAE/B,wCAAwC;YACxC,IAAI,WAAW,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;gBACpC,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC;YACxB,CAAC;YAED,0BAA0B;YAC1B,IAAI,WAAW,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;gBACpC,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,gBAAgB,CAAC,WAAW,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;gBAE5E,eAAe;gBACf,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM;oBAC1B,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;oBACpD,CAAC,CAAC,OAAO,CAAC;gBAEZ,iBAAiB;gBACjB,KAAK,MAAM,KAAK,IAAI,QAAQ,EAAE,CAAC;oBAC7B,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,gBAAgB,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;gBACvD,CAAC;gBAED,IAAI,CAAC,YAAY,GAAG,WAAW,CAAC;YAClC,CAAC;QACH,CAAC;QAAC,MAAM,CAAC;YACP,4CAA4C;QAC9C,CAAC;IACH,CAAC;IAED;;OAEG;IACK,KAAK,CAAC,gBAAgB,CAAC,WAAmB,EAAE,KAAa;QAC/D,MAAM,OAAO,GAAe,EAAE,CAAC;QAE/B,IAAI,CAAC;YACH,MAAM,UAAU,GAAG,gBAAgB,CAAC,WAAW,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;YAC5D,MAAM,EAAE,GAAG,eAAe,CAAC;gBACzB,KAAK,EAAE,UAAU;gBACjB,SAAS,EAAE,QAAQ;aACpB,CAAC,CAAC;YAEH,IAAI,KAAK,EAAE,MAAM,IAAI,IAAI,EAAE,EAAE,CAAC;gBAC5B,MAAM,KAAK,GAAG,YAAY,CAAC,IAAI,CAAC,CAAC;gBACjC,IAAI,KAAK,EAAE,CAAC;oBACV,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBACtB,CAAC;YACH,CAAC;QACH,CAAC;QAAC,MAAM,CAAC;YACP,qBAAqB;QACvB,CAAC;QAED,OAAO,OAAO,CAAC;IACjB,CAAC;IAED;;OAEG;IACK,aAAa,CAAC,KAAe;QACnC,IAAI,CAAC,IAAI,CAAC,MAAM;YAAE,OAAO,IAAI,CAAC;QAE9B,IAAI,IAAI,CAAC,MAAM,CAAC,SAAS,IAAI,KAAK,CAAC,SAAS,KAAK,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC;YACvE,OAAO,KAAK,CAAC;QACf,CAAC;QAED,IAAI,IAAI,CAAC,MAAM,CAAC,KAAK,IAAI,KAAK,CAAC,KAAK,KAAK,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;YAC3D,OAAO,KAAK,CAAC;QACf,CAAC;QAED,IAAI,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,KAAK,CAAC,OAAO,KAAK,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YACjE,OAAO,KAAK,CAAC;QACf,CAAC;QAED,IAAI,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;YACtB,MAAM,MAAM,GAA2B,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC;YAChF,MAAM,UAAU,GAAG,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;YAC5C,MAAM,WAAW,GAAG,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;YACnD,IAAI,UAAU,GAAG,WAAW,EAAE,CAAC;gBAC7B,OAAO,KAAK,CAAC;YACf,CAAC;QACH,CAAC;QAED,IAAI,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YACxB,MAAM,UAAU,GAAG,GAAG,KAAK,CAAC,KAAK,IAAI,KAAK,CAAC,OAAO,EAAE,CAAC,WAAW,EAAE,CAAC;YACnE,IAAI,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;gBACxB,IAAI,CAAC;oBACH,MAAM,KAAK,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;oBACnD,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;wBAC5B,OAAO,KAAK,CAAC;oBACf,CAAC;gBACH,CAAC;gBAAC,MAAM,CAAC;oBACP,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC,EAAE,CAAC;wBAC5D,OAAO,KAAK,CAAC;oBACf,CAAC;gBACH,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC,EAAE,CAAC;oBAC5D,OAAO,KAAK,CAAC;gBACf,CAAC;YACH,CAAC;QACH,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;OAEG;IACH,IAAI;QACF,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;YACrB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACtB,CAAC;IACH,CAAC;CACF"}
|