Merge pull request #60 from AikidoSec/setup-check-if-dir-exists

Check if directory exists before creating a new shell startup file, improve setup error reporting
This commit is contained in:
Sander Declerck 2025-09-18 10:29:37 +02:00 committed by GitHub
commit 43a0c77a54
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
2 changed files with 26 additions and 5 deletions

View file

@ -1,6 +1,7 @@
import { spawnSync } from "child_process"; import { spawnSync } from "child_process";
import * as os from "os"; import * as os from "os";
import fs from "fs"; import fs from "fs";
import path from "path";
export const knownAikidoTools = [ export const knownAikidoTools = [
{ tool: "npm", aikidoCommand: "aikido-npm" }, { tool: "npm", aikidoCommand: "aikido-npm" },
@ -65,13 +66,24 @@ function shouldRemoveLine(line, pattern) {
} }
export function addLineToFile(filePath, line, eol) { export function addLineToFile(filePath, line, eol) {
if (!fs.existsSync(filePath)) { createFileIfNotExists(filePath);
fs.writeFileSync(filePath, "", "utf-8");
}
eol = eol || os.EOL; eol = eol || os.EOL;
const fileContent = fs.readFileSync(filePath, "utf-8"); const fileContent = fs.readFileSync(filePath, "utf-8");
const updatedContent = fileContent + eol + line; const updatedContent = fileContent + eol + line + eol;
fs.writeFileSync(filePath, updatedContent, "utf-8"); fs.writeFileSync(filePath, updatedContent, "utf-8");
} }
function createFileIfNotExists(filePath) {
if (fs.existsSync(filePath)) {
return;
}
const dir = path.dirname(filePath);
if (!fs.existsSync(dir)) {
fs.mkdirSync(dir, { recursive: true });
}
fs.writeFileSync(filePath, "", "utf-8");
}

View file

@ -56,11 +56,13 @@ export async function setup() {
*/ */
function setupShell(shell) { function setupShell(shell) {
let success = false; let success = false;
let error;
try { try {
shell.teardown(knownAikidoTools); // First, tear down to prevent duplicate aliases shell.teardown(knownAikidoTools); // First, tear down to prevent duplicate aliases
success = shell.setup(knownAikidoTools); success = shell.setup(knownAikidoTools);
} catch { } catch (err) {
success = false; success = false;
error = err;
} }
if (success) { if (success) {
@ -75,6 +77,13 @@ function setupShell(shell) {
"Setup failed" "Setup failed"
)}. Please check your ${shell.name} configuration.` )}. Please check your ${shell.name} configuration.`
); );
if (error) {
let message = ` Error: ${error.message}`;
if (error.code) {
message += ` (code: ${error.code})`;
}
ui.writeError(message);
}
} }
return success; return success;