fix: implement --force flag for mount-allowlist overwrite

The skip message mentioned --force but parseArgs didn't handle it,
making it a false promise. Now --force is parsed and passed through,
allowing users to regenerate the mount allowlist when needed.

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
Akasha
2026-03-23 16:57:09 -04:00
parent ff16e93713
commit 5f42646598

View File

@@ -10,21 +10,23 @@ import { logger } from '../src/logger.js';
import { isRoot } from './platform.js'; import { isRoot } from './platform.js';
import { emitStatus } from './status.js'; import { emitStatus } from './status.js';
function parseArgs(args: string[]): { empty: boolean; json: string } { function parseArgs(args: string[]): { empty: boolean; json: string; force: boolean } {
let empty = false; let empty = false;
let json = ''; let json = '';
let force = false;
for (let i = 0; i < args.length; i++) { for (let i = 0; i < args.length; i++) {
if (args[i] === '--empty') empty = true; if (args[i] === '--empty') empty = true;
if (args[i] === '--force') force = true;
if (args[i] === '--json' && args[i + 1]) { if (args[i] === '--json' && args[i + 1]) {
json = args[i + 1]; json = args[i + 1];
i++; i++;
} }
} }
return { empty, json }; return { empty, json, force };
} }
export async function run(args: string[]): Promise<void> { export async function run(args: string[]): Promise<void> {
const { empty, json } = parseArgs(args); const { empty, json, force } = parseArgs(args);
const homeDir = os.homedir(); const homeDir = os.homedir();
const configDir = path.join(homeDir, '.config', 'nanoclaw'); const configDir = path.join(homeDir, '.config', 'nanoclaw');
const configFile = path.join(configDir, 'mount-allowlist.json'); const configFile = path.join(configDir, 'mount-allowlist.json');
@@ -37,7 +39,7 @@ export async function run(args: string[]): Promise<void> {
fs.mkdirSync(configDir, { recursive: true }); fs.mkdirSync(configDir, { recursive: true });
if (fs.existsSync(configFile)) { if (fs.existsSync(configFile) && !force) {
logger.info( logger.info(
{ configFile }, { configFile },
'Mount allowlist already exists — skipping (use --force to overwrite)', 'Mount allowlist already exists — skipping (use --force to overwrite)',