2026-02-17 13:39:47 -06:00
|
|
|
import fs from "node:fs";
|
|
|
|
|
import type { PaperclipConfig } from "../config/schema.js";
|
|
|
|
|
import type { CheckResult } from "./index.js";
|
2026-02-19 15:43:59 -06:00
|
|
|
import { resolveRuntimeLikePath } from "./path-resolver.js";
|
2026-02-18 16:47:15 -06:00
|
|
|
|
|
|
|
|
export function logCheck(config: PaperclipConfig, configPath?: string): CheckResult {
|
2026-02-19 15:43:59 -06:00
|
|
|
const logDir = resolveRuntimeLikePath(config.logging.logDir, configPath);
|
2026-02-18 16:47:15 -06:00
|
|
|
const reportedDir = logDir;
|
2026-02-17 13:39:47 -06:00
|
|
|
|
|
|
|
|
if (!fs.existsSync(logDir)) {
|
2026-03-04 09:58:30 -06:00
|
|
|
fs.mkdirSync(reportedDir, { recursive: true });
|
2026-02-17 13:39:47 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
try {
|
2026-02-18 16:47:15 -06:00
|
|
|
fs.accessSync(reportedDir, fs.constants.W_OK);
|
2026-02-17 13:39:47 -06:00
|
|
|
return {
|
|
|
|
|
name: "Log directory",
|
|
|
|
|
status: "pass",
|
2026-02-18 16:47:15 -06:00
|
|
|
message: `Log directory is writable: ${reportedDir}`,
|
2026-02-17 13:39:47 -06:00
|
|
|
};
|
|
|
|
|
} catch {
|
|
|
|
|
return {
|
|
|
|
|
name: "Log directory",
|
|
|
|
|
status: "fail",
|
|
|
|
|
message: `Log directory is not writable: ${logDir}`,
|
|
|
|
|
canRepair: false,
|
|
|
|
|
repairHint: "Check file permissions on the log directory",
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
}
|