harubashi 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +201 -0
- package/README.md +293 -0
- package/README.ru.md +293 -0
- package/dist/agent/agent.module.d.ts +2 -0
- package/dist/agent/agent.module.js +34 -0
- package/dist/agent/agent.module.js.map +1 -0
- package/dist/agent/agent.processor.d.ts +31 -0
- package/dist/agent/agent.processor.js +266 -0
- package/dist/agent/agent.processor.js.map +1 -0
- package/dist/agent/command-guard.service.d.ts +10 -0
- package/dist/agent/command-guard.service.js +48 -0
- package/dist/agent/command-guard.service.js.map +1 -0
- package/dist/agent/interruption.service.d.ts +11 -0
- package/dist/agent/interruption.service.js +52 -0
- package/dist/agent/interruption.service.js.map +1 -0
- package/dist/agent/system-executor.service.d.ts +32 -0
- package/dist/agent/system-executor.service.js +200 -0
- package/dist/agent/system-executor.service.js.map +1 -0
- package/dist/app.module.d.ts +2 -0
- package/dist/app.module.js +38 -0
- package/dist/app.module.js.map +1 -0
- package/dist/bin.d.ts +2 -0
- package/dist/bin.js +137 -0
- package/dist/bin.js.map +1 -0
- package/dist/cli.d.ts +2 -0
- package/dist/cli.js +141 -0
- package/dist/cli.js.map +1 -0
- package/dist/commands/config.command.d.ts +2 -0
- package/dist/commands/config.command.js +83 -0
- package/dist/commands/config.command.js.map +1 -0
- package/dist/commands/logs.command.d.ts +5 -0
- package/dist/commands/logs.command.js +130 -0
- package/dist/commands/logs.command.js.map +1 -0
- package/dist/commands/profile.command.d.ts +5 -0
- package/dist/commands/profile.command.js +293 -0
- package/dist/commands/profile.command.js.map +1 -0
- package/dist/commands/setup.command.d.ts +1 -0
- package/dist/commands/setup.command.js +94 -0
- package/dist/commands/setup.command.js.map +1 -0
- package/dist/commands/setup.helpers.d.ts +34 -0
- package/dist/commands/setup.helpers.js +265 -0
- package/dist/commands/setup.helpers.js.map +1 -0
- package/dist/commands/skills.command.d.ts +2 -0
- package/dist/commands/skills.command.js +111 -0
- package/dist/commands/skills.command.js.map +1 -0
- package/dist/common/adapters/cli-interaction.adapter.d.ts +8 -0
- package/dist/common/adapters/cli-interaction.adapter.js +67 -0
- package/dist/common/adapters/cli-interaction.adapter.js.map +1 -0
- package/dist/common/adapters/interaction-adapter.interface.d.ts +6 -0
- package/dist/common/adapters/interaction-adapter.interface.js +10 -0
- package/dist/common/adapters/interaction-adapter.interface.js.map +1 -0
- package/dist/common/constants.d.ts +3 -0
- package/dist/common/constants.js +7 -0
- package/dist/common/constants.js.map +1 -0
- package/dist/common/index.d.ts +4 -0
- package/dist/common/index.js +21 -0
- package/dist/common/index.js.map +1 -0
- package/dist/common/logger.d.ts +9 -0
- package/dist/common/logger.js +87 -0
- package/dist/common/logger.js.map +1 -0
- package/dist/common/paths.d.ts +12 -0
- package/dist/common/paths.js +28 -0
- package/dist/common/paths.js.map +1 -0
- package/dist/common/types/message.types.d.ts +48 -0
- package/dist/common/types/message.types.js +18 -0
- package/dist/common/types/message.types.js.map +1 -0
- package/dist/common/types/tool.types.d.ts +20 -0
- package/dist/common/types/tool.types.js +3 -0
- package/dist/common/types/tool.types.js.map +1 -0
- package/dist/common/utils/type-guards.d.ts +8 -0
- package/dist/common/utils/type-guards.js +46 -0
- package/dist/common/utils/type-guards.js.map +1 -0
- package/dist/config/config-loader.d.ts +6 -0
- package/dist/config/config-loader.js +90 -0
- package/dist/config/config-loader.js.map +1 -0
- package/dist/config/config.module.d.ts +2 -0
- package/dist/config/config.module.js +28 -0
- package/dist/config/config.module.js.map +1 -0
- package/dist/config/config.types.d.ts +55 -0
- package/dist/config/config.types.js +21 -0
- package/dist/config/config.types.js.map +1 -0
- package/dist/daemon.d.ts +2 -0
- package/dist/daemon.js +28 -0
- package/dist/daemon.js.map +1 -0
- package/dist/llm/anthropic/anthropic.provider.d.ts +15 -0
- package/dist/llm/anthropic/anthropic.provider.js +162 -0
- package/dist/llm/anthropic/anthropic.provider.js.map +1 -0
- package/dist/llm/google/google.provider.d.ts +14 -0
- package/dist/llm/google/google.provider.js +189 -0
- package/dist/llm/google/google.provider.js.map +1 -0
- package/dist/llm/llm-factory.service.d.ts +24 -0
- package/dist/llm/llm-factory.service.js +76 -0
- package/dist/llm/llm-factory.service.js.map +1 -0
- package/dist/llm/llm.interface.d.ts +19 -0
- package/dist/llm/llm.interface.js +5 -0
- package/dist/llm/llm.interface.js.map +1 -0
- package/dist/llm/llm.module.d.ts +2 -0
- package/dist/llm/llm.module.js +34 -0
- package/dist/llm/llm.module.js.map +1 -0
- package/dist/llm/nvidia/nvidia.provider.d.ts +11 -0
- package/dist/llm/nvidia/nvidia.provider.js +49 -0
- package/dist/llm/nvidia/nvidia.provider.js.map +1 -0
- package/dist/llm/openai/openai.provider.d.ts +9 -0
- package/dist/llm/openai/openai.provider.js +35 -0
- package/dist/llm/openai/openai.provider.js.map +1 -0
- package/dist/llm/openai-compatible/openai-compatible.helper.d.ts +4 -0
- package/dist/llm/openai-compatible/openai-compatible.helper.js +155 -0
- package/dist/llm/openai-compatible/openai-compatible.helper.js.map +1 -0
- package/dist/llm/proxy/proxy.provider.d.ts +9 -0
- package/dist/llm/proxy/proxy.provider.js +35 -0
- package/dist/llm/proxy/proxy.provider.js.map +1 -0
- package/dist/main.d.ts +1 -0
- package/dist/main.js +14 -0
- package/dist/main.js.map +1 -0
- package/dist/prisma/prisma.module.d.ts +2 -0
- package/dist/prisma/prisma.module.js +22 -0
- package/dist/prisma/prisma.module.js.map +1 -0
- package/dist/prisma/prisma.service.d.ts +9 -0
- package/dist/prisma/prisma.service.js +40 -0
- package/dist/prisma/prisma.service.js.map +1 -0
- package/dist/sessions/sessions.module.d.ts +2 -0
- package/dist/sessions/sessions.module.js +23 -0
- package/dist/sessions/sessions.module.js.map +1 -0
- package/dist/sessions/sessions.service.d.ts +21 -0
- package/dist/sessions/sessions.service.js +82 -0
- package/dist/sessions/sessions.service.js.map +1 -0
- package/dist/skills/definitions/directory_explorer.md +69 -0
- package/dist/skills/definitions/execute_command.md +27 -0
- package/dist/skills/definitions/git_manager.md +98 -0
- package/dist/skills/definitions/read_file.md +25 -0
- package/dist/skills/skills-bundle.d.ts +7 -0
- package/dist/skills/skills-bundle.js +27 -0
- package/dist/skills/skills-bundle.js.map +1 -0
- package/dist/skills/skills-parser.d.ts +8 -0
- package/dist/skills/skills-parser.js +67 -0
- package/dist/skills/skills-parser.js.map +1 -0
- package/dist/skills/skills.module.d.ts +2 -0
- package/dist/skills/skills.module.js +22 -0
- package/dist/skills/skills.module.js.map +1 -0
- package/dist/skills/skills.service.d.ts +22 -0
- package/dist/skills/skills.service.js +150 -0
- package/dist/skills/skills.service.js.map +1 -0
- package/dist/skills/skills.types.d.ts +16 -0
- package/dist/skills/skills.types.js +3 -0
- package/dist/skills/skills.types.js.map +1 -0
- package/dist/soul/prompts/core.md +28 -0
- package/dist/soul/prompts/rules.md +40 -0
- package/dist/soul/prompts/runtime.md +13 -0
- package/dist/soul/prompts/voice.md +45 -0
- package/dist/soul/soul.module.d.ts +2 -0
- package/dist/soul/soul.module.js +22 -0
- package/dist/soul/soul.module.js.map +1 -0
- package/dist/soul/soul.service.d.ts +22 -0
- package/dist/soul/soul.service.js +89 -0
- package/dist/soul/soul.service.js.map +1 -0
- package/dist/telegram/pairing.service.d.ts +11 -0
- package/dist/telegram/pairing.service.js +81 -0
- package/dist/telegram/pairing.service.js.map +1 -0
- package/dist/telegram/telegram-interaction.adapter.d.ts +16 -0
- package/dist/telegram/telegram-interaction.adapter.js +54 -0
- package/dist/telegram/telegram-interaction.adapter.js.map +1 -0
- package/dist/telegram/telegram.module.d.ts +2 -0
- package/dist/telegram/telegram.module.js +25 -0
- package/dist/telegram/telegram.module.js.map +1 -0
- package/dist/telegram/telegram.service.d.ts +28 -0
- package/dist/telegram/telegram.service.js +255 -0
- package/dist/telegram/telegram.service.js.map +1 -0
- package/dist/tsconfig.build.tsbuildinfo +1 -0
- package/package.json +68 -0
- package/prisma/migrations/20260403134611_init/migration.sql +40 -0
- package/prisma/migrations/migration_lock.toml +3 -0
- package/prisma/schema.prisma +74 -0
package/dist/cli.js
ADDED
|
@@ -0,0 +1,141 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.runCli = runCli;
|
|
4
|
+
require("reflect-metadata");
|
|
5
|
+
const core_1 = require("@nestjs/core");
|
|
6
|
+
const common_1 = require("@nestjs/common");
|
|
7
|
+
const readline = require("readline");
|
|
8
|
+
const app_module_1 = require("./app.module");
|
|
9
|
+
const agent_processor_1 = require("./agent/agent.processor");
|
|
10
|
+
const sessions_service_1 = require("./sessions/sessions.service");
|
|
11
|
+
const cli_interaction_adapter_1 = require("./common/adapters/cli-interaction.adapter");
|
|
12
|
+
const constants_1 = require("./common/constants");
|
|
13
|
+
const logger_1 = require("./common/logger");
|
|
14
|
+
async function runCli() {
|
|
15
|
+
const app = await core_1.NestFactory.createApplicationContext(app_module_1.AppModule, {
|
|
16
|
+
logger: (0, logger_1.createHarubashiLogger)({ appName: 'Harubashi' }),
|
|
17
|
+
});
|
|
18
|
+
const logger = new common_1.Logger('CLI');
|
|
19
|
+
const processor = app.get(agent_processor_1.AgentProcessorService);
|
|
20
|
+
const sessions = app.get(sessions_service_1.SessionsService);
|
|
21
|
+
await sessions.ensureDefaultUser();
|
|
22
|
+
await sessions.ensureDefaultSession();
|
|
23
|
+
let currentSessionId = constants_1.DEFAULT_SESSION_ID;
|
|
24
|
+
logger.log(`Harubashi CLI ready. Session: "${currentSessionId}"\n` +
|
|
25
|
+
` Commands: /new <name> | /switch <name> | /sessions | exit\n`);
|
|
26
|
+
const rl = readline.createInterface({
|
|
27
|
+
input: process.stdin,
|
|
28
|
+
output: process.stdout,
|
|
29
|
+
terminal: true,
|
|
30
|
+
});
|
|
31
|
+
const adapter = new cli_interaction_adapter_1.CliInteractionAdapter(rl);
|
|
32
|
+
async function handleNew(arg) {
|
|
33
|
+
const name = arg.trim();
|
|
34
|
+
if (!name) {
|
|
35
|
+
console.log('\x1b[33mUsage: /new <session-name>\x1b[0m');
|
|
36
|
+
return;
|
|
37
|
+
}
|
|
38
|
+
await sessions.switchOrCreate(constants_1.DEFAULT_USER_ID, name);
|
|
39
|
+
currentSessionId = name;
|
|
40
|
+
console.log(`\x1b[32m[CLI] Switched to session: "${name}". Context is now fresh (or loaded from existing session).\x1b[0m`);
|
|
41
|
+
}
|
|
42
|
+
async function handleSwitch(arg) {
|
|
43
|
+
const name = arg.trim();
|
|
44
|
+
if (!name) {
|
|
45
|
+
console.log('\x1b[33mUsage: /switch <session-name>\x1b[0m');
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
const session = await sessions.getSession(name);
|
|
49
|
+
if (!session) {
|
|
50
|
+
console.log(`\x1b[31m[CLI] No session named "${name}". Use /sessions to list or /new <name> to create.\x1b[0m`);
|
|
51
|
+
return;
|
|
52
|
+
}
|
|
53
|
+
currentSessionId = name;
|
|
54
|
+
const lastActive = session.updatedAt.toLocaleString();
|
|
55
|
+
console.log(`\x1b[32m[CLI] Switched to "${name}". Last active: ${lastActive}\x1b[0m`);
|
|
56
|
+
}
|
|
57
|
+
async function handleSessions() {
|
|
58
|
+
const list = await sessions.listSessions(constants_1.DEFAULT_USER_ID);
|
|
59
|
+
if (list.length === 0) {
|
|
60
|
+
console.log('\x1b[90m(no sessions)\x1b[0m');
|
|
61
|
+
return;
|
|
62
|
+
}
|
|
63
|
+
console.log('\x1b[36m── Sessions ──────────────────────────\x1b[0m');
|
|
64
|
+
for (const s of list) {
|
|
65
|
+
const marker = s.id === currentSessionId ? ' \x1b[32m→ (current)\x1b[0m' : '';
|
|
66
|
+
const date = s.updatedAt.toLocaleString();
|
|
67
|
+
console.log(` ${s.id} \x1b[90m${date}\x1b[0m${marker}`);
|
|
68
|
+
}
|
|
69
|
+
console.log('\x1b[36m──────────────────────────────────────────\x1b[0m');
|
|
70
|
+
}
|
|
71
|
+
const prompt = () => {
|
|
72
|
+
rl.question(`\x1b[36m[${currentSessionId}] >\x1b[0m `, async (input) => {
|
|
73
|
+
const trimmed = input.trim();
|
|
74
|
+
if (!trimmed) {
|
|
75
|
+
prompt();
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
78
|
+
const lower = trimmed.toLowerCase();
|
|
79
|
+
if (lower === 'exit' || lower === 'quit') {
|
|
80
|
+
logger.log('Shutting down...');
|
|
81
|
+
rl.close();
|
|
82
|
+
await app.close();
|
|
83
|
+
process.exit(0);
|
|
84
|
+
}
|
|
85
|
+
if (trimmed.startsWith('/')) {
|
|
86
|
+
const spaceIdx = trimmed.indexOf(' ');
|
|
87
|
+
const cmd = (spaceIdx === -1 ? trimmed : trimmed.slice(0, spaceIdx)).toLowerCase();
|
|
88
|
+
const arg = spaceIdx === -1 ? '' : trimmed.slice(spaceIdx + 1);
|
|
89
|
+
try {
|
|
90
|
+
switch (cmd) {
|
|
91
|
+
case '/new':
|
|
92
|
+
await handleNew(arg);
|
|
93
|
+
break;
|
|
94
|
+
case '/switch':
|
|
95
|
+
await handleSwitch(arg);
|
|
96
|
+
break;
|
|
97
|
+
case '/sessions':
|
|
98
|
+
await handleSessions();
|
|
99
|
+
break;
|
|
100
|
+
default:
|
|
101
|
+
console.log(`\x1b[33mUnknown command: ${cmd}. Available: /new /switch /sessions\x1b[0m`);
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
catch (err) {
|
|
105
|
+
console.error(`\x1b[31m[CLI] Command error: ${err.message}\x1b[0m`);
|
|
106
|
+
}
|
|
107
|
+
prompt();
|
|
108
|
+
return;
|
|
109
|
+
}
|
|
110
|
+
try {
|
|
111
|
+
const result = await processor.process(currentSessionId, trimmed, adapter);
|
|
112
|
+
console.log();
|
|
113
|
+
console.log('\x1b[32m── Agent Response ──────────────────────\x1b[0m');
|
|
114
|
+
console.log(result.finalText || '(no text response)');
|
|
115
|
+
console.log('\x1b[90m───────────────────────────────────────');
|
|
116
|
+
console.log(` iterations: ${result.iterations} | ` +
|
|
117
|
+
`tokens: ${result.totalTokens} | ` +
|
|
118
|
+
`aborted: ${result.aborted} | ` +
|
|
119
|
+
`task: ${result.taskId}`);
|
|
120
|
+
console.log('───────────────────────────────────────\x1b[0m');
|
|
121
|
+
console.log();
|
|
122
|
+
}
|
|
123
|
+
catch (err) {
|
|
124
|
+
console.error();
|
|
125
|
+
console.error('\x1b[31m── Error ──────────────────────────────\x1b[0m');
|
|
126
|
+
console.error(err.message || err);
|
|
127
|
+
console.error('\x1b[31m───────────────────────────────────────\x1b[0m');
|
|
128
|
+
console.error();
|
|
129
|
+
}
|
|
130
|
+
prompt();
|
|
131
|
+
});
|
|
132
|
+
};
|
|
133
|
+
prompt();
|
|
134
|
+
}
|
|
135
|
+
if (require.main === module) {
|
|
136
|
+
runCli().catch((err) => {
|
|
137
|
+
console.error('Fatal error during CLI bootstrap:', err);
|
|
138
|
+
process.exit(1);
|
|
139
|
+
});
|
|
140
|
+
}
|
|
141
|
+
//# sourceMappingURL=cli.js.map
|
package/dist/cli.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cli.js","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.runConfigPath = runConfigPath;
|
|
4
|
+
exports.runConfigEdit = runConfigEdit;
|
|
5
|
+
const child_process_1 = require("child_process");
|
|
6
|
+
const fs = require("fs");
|
|
7
|
+
const paths_1 = require("../common/paths");
|
|
8
|
+
function runConfigPath() {
|
|
9
|
+
console.log(paths_1.HarubashiPaths.configFile);
|
|
10
|
+
}
|
|
11
|
+
async function runConfigEdit() {
|
|
12
|
+
const file = paths_1.HarubashiPaths.configFile;
|
|
13
|
+
if (!fs.existsSync(file)) {
|
|
14
|
+
console.error(`\x1b[31m[harubashi] Config not found at ${file}\x1b[0m`);
|
|
15
|
+
console.error(`\x1b[33mPlease run 'harubashi setup' first to create one.\x1b[0m`);
|
|
16
|
+
process.exit(1);
|
|
17
|
+
}
|
|
18
|
+
const editor = process.env.VISUAL || process.env.EDITOR;
|
|
19
|
+
if (editor) {
|
|
20
|
+
await runTerminalEditor(editor, file);
|
|
21
|
+
return;
|
|
22
|
+
}
|
|
23
|
+
runPlatformDefault(file);
|
|
24
|
+
}
|
|
25
|
+
function runTerminalEditor(editor, file) {
|
|
26
|
+
return new Promise((resolve) => {
|
|
27
|
+
console.log(`\x1b[90m Opening ${file} in '${editor}'...\x1b[0m`);
|
|
28
|
+
const quoted = `"${file.replace(/"/g, '\\"')}"`;
|
|
29
|
+
const child = (0, child_process_1.spawn)(`${editor} ${quoted}`, {
|
|
30
|
+
stdio: 'inherit',
|
|
31
|
+
shell: true,
|
|
32
|
+
});
|
|
33
|
+
child.on('exit', (code) => {
|
|
34
|
+
if (code === 0) {
|
|
35
|
+
console.log(`\x1b[32m✓\x1b[0m Closed editor.`);
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
console.log(`\x1b[33m⚠\x1b[0m Editor exited with code ${code ?? 'unknown'}.`);
|
|
39
|
+
}
|
|
40
|
+
resolve();
|
|
41
|
+
});
|
|
42
|
+
child.on('error', (err) => {
|
|
43
|
+
console.error(`\x1b[31m[harubashi] Failed to launch '${editor}': ${err.message}\x1b[0m`);
|
|
44
|
+
console.log(` Path: \x1b[36m${file}\x1b[0m`);
|
|
45
|
+
resolve();
|
|
46
|
+
});
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
function runPlatformDefault(file) {
|
|
50
|
+
const platform = process.platform;
|
|
51
|
+
let command;
|
|
52
|
+
let args;
|
|
53
|
+
if (platform === 'win32') {
|
|
54
|
+
command = 'notepad.exe';
|
|
55
|
+
args = [file];
|
|
56
|
+
}
|
|
57
|
+
else if (platform === 'darwin') {
|
|
58
|
+
command = 'open';
|
|
59
|
+
args = ['-t', file];
|
|
60
|
+
}
|
|
61
|
+
else {
|
|
62
|
+
command = 'xdg-open';
|
|
63
|
+
args = [file];
|
|
64
|
+
}
|
|
65
|
+
try {
|
|
66
|
+
const child = (0, child_process_1.spawn)(command, args, {
|
|
67
|
+
detached: true,
|
|
68
|
+
stdio: 'ignore',
|
|
69
|
+
});
|
|
70
|
+
child.on('error', (err) => {
|
|
71
|
+
console.error(`\x1b[31m[harubashi] Failed to launch '${command}': ${err.message}\x1b[0m`);
|
|
72
|
+
console.log(` Path: \x1b[36m${file}\x1b[0m`);
|
|
73
|
+
});
|
|
74
|
+
child.unref();
|
|
75
|
+
console.log(`\x1b[32m✓\x1b[0m Opening ${file}`);
|
|
76
|
+
console.log(`\x1b[90m Tip: set $EDITOR (e.g. 'export EDITOR=vim') to control this command.\x1b[0m`);
|
|
77
|
+
}
|
|
78
|
+
catch (err) {
|
|
79
|
+
console.error(`\x1b[31m[harubashi] Failed to spawn editor: ${err.message}\x1b[0m`);
|
|
80
|
+
console.log(` Path: \x1b[36m${file}\x1b[0m`);
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
//# sourceMappingURL=config.command.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"config.command.js","sourceRoot":"","sources":["../../src/commands/config.command.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.runLogs = runLogs;
|
|
4
|
+
const fs = require("fs");
|
|
5
|
+
const path = require("path");
|
|
6
|
+
const chokidar = require("chokidar");
|
|
7
|
+
const paths_1 = require("../common/paths");
|
|
8
|
+
const logger_1 = require("../common/logger");
|
|
9
|
+
async function runLogs(opts = {}) {
|
|
10
|
+
const follow = opts.follow !== false;
|
|
11
|
+
const lines = opts.lines ?? 50;
|
|
12
|
+
let currentFile = (0, logger_1.latestLogFile)();
|
|
13
|
+
if (!currentFile) {
|
|
14
|
+
printEmpty();
|
|
15
|
+
return;
|
|
16
|
+
}
|
|
17
|
+
printHeader(currentFile, follow);
|
|
18
|
+
const trail = readLastLines(currentFile, lines);
|
|
19
|
+
for (const line of trail) {
|
|
20
|
+
printRendered(line);
|
|
21
|
+
}
|
|
22
|
+
if (!follow)
|
|
23
|
+
return;
|
|
24
|
+
let position = fs.statSync(currentFile).size;
|
|
25
|
+
const watcher = chokidar.watch(paths_1.HarubashiPaths.logsDir, {
|
|
26
|
+
ignoreInitial: true,
|
|
27
|
+
awaitWriteFinish: { stabilityThreshold: 100, pollInterval: 50 },
|
|
28
|
+
});
|
|
29
|
+
watcher.on('add', (filePath) => {
|
|
30
|
+
if (!isHarubashiLog(filePath))
|
|
31
|
+
return;
|
|
32
|
+
if (currentFile && filePath > currentFile) {
|
|
33
|
+
console.log(`\x1b[90m── Rotated to ${path.basename(filePath)} ──\x1b[0m`);
|
|
34
|
+
currentFile = filePath;
|
|
35
|
+
position = 0;
|
|
36
|
+
flushNewLines(filePath, position).then((newPos) => {
|
|
37
|
+
position = newPos;
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
});
|
|
41
|
+
watcher.on('change', async (filePath) => {
|
|
42
|
+
if (filePath !== currentFile)
|
|
43
|
+
return;
|
|
44
|
+
position = await flushNewLines(filePath, position);
|
|
45
|
+
});
|
|
46
|
+
process.on('SIGINT', async () => {
|
|
47
|
+
await watcher.close();
|
|
48
|
+
console.log('\n\x1b[90m── tail closed ──\x1b[0m');
|
|
49
|
+
process.exit(0);
|
|
50
|
+
});
|
|
51
|
+
await new Promise(() => {
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
function isHarubashiLog(filePath) {
|
|
55
|
+
return /harubashi-\d{4}-\d{2}-\d{2}\.log$/.test(filePath);
|
|
56
|
+
}
|
|
57
|
+
function readLastLines(filePath, n) {
|
|
58
|
+
const raw = fs.readFileSync(filePath, 'utf-8');
|
|
59
|
+
const all = raw.split(/\r?\n/).filter((l) => l.length > 0);
|
|
60
|
+
return all.slice(-n);
|
|
61
|
+
}
|
|
62
|
+
async function flushNewLines(filePath, fromByte) {
|
|
63
|
+
const stat = fs.statSync(filePath);
|
|
64
|
+
if (stat.size <= fromByte)
|
|
65
|
+
return fromByte;
|
|
66
|
+
const stream = fs.createReadStream(filePath, {
|
|
67
|
+
start: fromByte,
|
|
68
|
+
end: stat.size,
|
|
69
|
+
encoding: 'utf-8',
|
|
70
|
+
});
|
|
71
|
+
let buffer = '';
|
|
72
|
+
for await (const chunk of stream) {
|
|
73
|
+
buffer += chunk;
|
|
74
|
+
}
|
|
75
|
+
const lines = buffer.split(/\r?\n/);
|
|
76
|
+
for (const line of lines) {
|
|
77
|
+
if (line.length > 0)
|
|
78
|
+
printRendered(line);
|
|
79
|
+
}
|
|
80
|
+
return stat.size;
|
|
81
|
+
}
|
|
82
|
+
const LEVEL_COLOR = {
|
|
83
|
+
error: '\x1b[31m',
|
|
84
|
+
warn: '\x1b[33m',
|
|
85
|
+
info: '\x1b[32m',
|
|
86
|
+
debug: '\x1b[34m',
|
|
87
|
+
verbose: '\x1b[35m',
|
|
88
|
+
};
|
|
89
|
+
function printRendered(line) {
|
|
90
|
+
let parsed;
|
|
91
|
+
try {
|
|
92
|
+
parsed = JSON.parse(line);
|
|
93
|
+
}
|
|
94
|
+
catch {
|
|
95
|
+
console.log(line);
|
|
96
|
+
return;
|
|
97
|
+
}
|
|
98
|
+
const ts = parsed.timestamp
|
|
99
|
+
? formatTimestamp(parsed.timestamp)
|
|
100
|
+
: '????-??-?? ??:??:??';
|
|
101
|
+
const lvl = (parsed.level || 'info').toLowerCase();
|
|
102
|
+
const lvlColor = LEVEL_COLOR[lvl] || '\x1b[37m';
|
|
103
|
+
const lvlPad = lvl.toUpperCase().padEnd(5);
|
|
104
|
+
const ctx = parsed.context ? ` \x1b[36m[${parsed.context}]\x1b[0m` : '';
|
|
105
|
+
const msg = parsed.message ?? '';
|
|
106
|
+
console.log(`\x1b[90m${ts}\x1b[0m ${lvlColor}${lvlPad}\x1b[0m${ctx} ${msg}`);
|
|
107
|
+
if (parsed.stack) {
|
|
108
|
+
console.log(`\x1b[31m${parsed.stack}\x1b[0m`);
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
function formatTimestamp(iso) {
|
|
112
|
+
const m = /^(\d{4}-\d{2}-\d{2})T(\d{2}:\d{2}:\d{2})/.exec(iso);
|
|
113
|
+
return m ? `${m[1]} ${m[2]}` : iso;
|
|
114
|
+
}
|
|
115
|
+
function printHeader(file, follow) {
|
|
116
|
+
const name = path.basename(file);
|
|
117
|
+
const mode = follow ? 'tailing' : 'reading';
|
|
118
|
+
console.log(`\x1b[36m── ${mode} ${name} ──\x1b[0m`);
|
|
119
|
+
}
|
|
120
|
+
function printEmpty() {
|
|
121
|
+
console.log();
|
|
122
|
+
console.log('\x1b[33m No logs found yet.\x1b[0m');
|
|
123
|
+
console.log();
|
|
124
|
+
console.log(` \x1b[90mLog directory: ${paths_1.HarubashiPaths.logsDir}\x1b[0m`);
|
|
125
|
+
console.log();
|
|
126
|
+
console.log('\x1b[90m Try starting the daemon first:\x1b[0m');
|
|
127
|
+
console.log(' \x1b[32m$\x1b[0m harubashi daemon');
|
|
128
|
+
console.log();
|
|
129
|
+
}
|
|
130
|
+
//# sourceMappingURL=logs.command.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logs.command.js","sourceRoot":"","sources":["../../src/commands/logs.command.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export declare function runProfileList(): void;
|
|
2
|
+
export declare function runProfileUse(name: string): void;
|
|
3
|
+
export declare function runProfileCreate(nameArg?: string): Promise<void>;
|
|
4
|
+
export declare function runProfileEdit(nameArg?: string): Promise<void>;
|
|
5
|
+
export declare function runProfileDelete(name: string): Promise<void>;
|