fix(audit): expand home paths across phase0 CLI scripts

Apply HOME-based ~ expansion to summarize/drift/prune audit scripts for input/output path flags to match capture behavior and avoid literal ~/ path bugs. Architecture/protocol diagrams reviewed; no updates needed for this path-resolution change.
This commit is contained in:
William Valentin
2026-02-27 13:30:08 -08:00
parent c91262ac30
commit 576b11106f
4 changed files with 57 additions and 9 deletions
+15 -4
View File
@@ -176,6 +176,17 @@ function formatFreshnessHours(value: number | null): string {
return `${Math.round(value * 100) / 100}`;
}
function expandHomePath(pathValue: string): string {
if (!pathValue.startsWith('~')) {
return pathValue;
}
const home = process.env.HOME;
if (!home) {
return pathValue;
}
return resolve(home, pathValue.slice(1));
}
async function writeOutput(pathValue: string, output: string): Promise<void> {
await mkdir(dirname(pathValue), { recursive: true });
await writeFile(pathValue, `${output}\n`, 'utf8');
@@ -370,7 +381,7 @@ async function main(): Promise<void> {
return;
}
const artifactsDir = resolve(values['artifacts-dir'] ?? 'docs/plans/artifacts');
const artifactsDir = resolve(expandHomePath(values['artifacts-dir'] ?? 'docs/plans/artifacts'));
const backends = parseBackends(values.backend);
const candidateTag = values.tag
? normalizeArtifactTag(values.tag, '--tag')
@@ -388,12 +399,12 @@ async function main(): Promise<void> {
const defaultBaseName = resolve(artifactsDir, `phase0_baseline_live_backend_drift_${reportTag}`);
const summaryJsonOut = values['summary-json-out']
? resolve(values['summary-json-out'])
? resolve(expandHomePath(values['summary-json-out']))
: writeDefaultArtifacts
? `${defaultBaseName}.json`
: undefined;
const summaryMdOut = values['summary-md-out']
? resolve(values['summary-md-out'])
? resolve(expandHomePath(values['summary-md-out']))
: writeDefaultArtifacts
? `${defaultBaseName}.md`
: undefined;
@@ -497,7 +508,7 @@ async function main(): Promise<void> {
}
if (values.out) {
await writeOutput(resolve(values.out), output);
await writeOutput(resolve(expandHomePath(values.out)), output);
} else {
process.stdout.write(`${output}\n`);
}
+14 -3
View File
@@ -30,6 +30,17 @@ function isoDateTagNow(): string {
return new Date().toISOString().slice(0, 10);
}
function expandHomePath(pathValue: string): string {
if (!pathValue.startsWith('~')) {
return pathValue;
}
const home = process.env.HOME;
if (!home) {
return pathValue;
}
return resolve(home, pathValue.slice(1));
}
function parseOptionalInteger(raw: string | undefined, flag: string): number | undefined {
if (!raw) {
return undefined;
@@ -111,7 +122,7 @@ async function main(): Promise<void> {
return;
}
const artifactsDir = resolve(values['artifacts-dir'] ?? 'docs/plans/artifacts');
const artifactsDir = resolve(expandHomePath(values['artifacts-dir'] ?? 'docs/plans/artifacts'));
const keepPerFamily = parseOptionalInteger(values['keep-per-family'], '--keep-per-family') ?? 8;
const apply = Boolean(values.apply);
const format = values.format ?? 'text';
@@ -124,12 +135,12 @@ async function main(): Promise<void> {
const defaultBaseName = resolve(artifactsDir, `phase0_baseline_live_prune_${reportTag}`);
const summaryJsonOut = values['summary-json-out']
? resolve(values['summary-json-out'])
? resolve(expandHomePath(values['summary-json-out']))
: writeDefaultArtifacts
? `${defaultBaseName}.json`
: undefined;
const summaryMdOut = values['summary-md-out']
? resolve(values['summary-md-out'])
? resolve(expandHomePath(values['summary-md-out']))
: writeDefaultArtifacts
? `${defaultBaseName}.md`
: undefined;
+15 -2
View File
@@ -1,6 +1,7 @@
#!/usr/bin/env node
import { writeFile } from 'node:fs/promises';
import { resolve } from 'node:path';
import { parseArgs } from 'node:util';
import { queryAuditLogs } from '../src/audit/export.js';
import {
@@ -59,6 +60,17 @@ function parseCsv(value: string | undefined): string[] | undefined {
return values.length > 0 ? values : undefined;
}
function expandHomePath(pathValue: string): string {
if (!pathValue.startsWith('~')) {
return pathValue;
}
const home = process.env.HOME;
if (!home) {
return pathValue;
}
return resolve(home, pathValue.slice(1));
}
function parseOptionalNumber(raw: string | undefined, flag: string): number | undefined {
if (!raw) {
return undefined;
@@ -148,7 +160,8 @@ async function main(): Promise<void> {
const startTime = parseTime(values.since, '--since');
const endTime = parseTime(values.until, '--until');
const events = await queryAuditLogs(values.audit, {
const auditPath = expandHomePath(values.audit);
const events = await queryAuditLogs(auditPath, {
start_time: startTime,
end_time: endTime,
event_types: [...DEFAULT_EVENT_TYPES],
@@ -170,7 +183,7 @@ async function main(): Promise<void> {
: renderPhase0BaselineMarkdown(summary, summaryOptions);
if (values.out) {
await writeFile(values.out, `${output}\n`, 'utf-8');
await writeFile(expandHomePath(values.out), `${output}\n`, 'utf-8');
} else {
process.stdout.write(`${output}\n`);
}