mirror of
https://github.com/KeygraphHQ/shannon.git
synced 2026-04-29 15:47:48 +02:00
dd18f4629b
* chore: initialize TypeScript configuration and build setup - Add tsconfig.json for root and mcp-server with strict type checking - Install typescript and @types/node as devDependencies - Add npm build script for TypeScript compilation - Update main entrypoint to compiled dist/shannon.js - Update Dockerfile to build TypeScript before running - Configure output directory and module resolution for Node.js * refactor: migrate codebase from JavaScript to TypeScript - Convert all 37 JavaScript files to TypeScript (.js -> .ts) - Add type definitions in src/types/ for agents, config, errors, session - Update mcp-server with proper TypeScript types - Move entry point from shannon.mjs to src/shannon.ts - Update tsconfig.json with rootDir: "./src" for cleaner dist output - Update Dockerfile to build TypeScript before runtime - Update package.json paths to use compiled dist/shannon.js No runtime behavior changes - pure type safety migration. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * docs: update CLI references from ./shannon.mjs to shannon - Update help text in src/cli/ui.ts - Update usage examples in src/cli/command-handler.ts - Update setup message in src/shannon.ts - Update CLAUDE.md documentation with TypeScript file structure - Replace all ./shannon.mjs references with shannon command 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> * chore: remove unnecessary eslint-disable comments ESLint is not configured in this project, making these comments redundant. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> --------- Co-authored-by: Claude Opus 4.5 <noreply@anthropic.com>
61 lines
1.7 KiB
TypeScript
61 lines
1.7 KiB
TypeScript
// Copyright (C) 2025 Keygraph, Inc.
|
|
//
|
|
// This program is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU Affero General Public License version 3
|
|
// as published by the Free Software Foundation.
|
|
|
|
import { createInterface } from 'readline';
|
|
import { PentestError } from '../error-handling.js';
|
|
|
|
/**
|
|
* Prompt user for yes/no confirmation
|
|
*/
|
|
export async function promptConfirmation(message: string): Promise<boolean> {
|
|
const readline = createInterface({
|
|
input: process.stdin,
|
|
output: process.stdout,
|
|
});
|
|
|
|
return new Promise((resolve) => {
|
|
readline.question(message + ' ', (answer) => {
|
|
readline.close();
|
|
const confirmed = answer.toLowerCase() === 'y' || answer.toLowerCase() === 'yes';
|
|
resolve(confirmed);
|
|
});
|
|
});
|
|
}
|
|
|
|
/**
|
|
* Prompt user to select from numbered list
|
|
*/
|
|
export async function promptSelection<T>(message: string, items: T[]): Promise<T> {
|
|
if (!items || items.length === 0) {
|
|
throw new PentestError('No items available for selection', 'validation', false);
|
|
}
|
|
|
|
const readline = createInterface({
|
|
input: process.stdin,
|
|
output: process.stdout,
|
|
});
|
|
|
|
return new Promise((resolve, reject) => {
|
|
readline.question(message + ' ', (answer) => {
|
|
readline.close();
|
|
|
|
const choice = parseInt(answer);
|
|
if (isNaN(choice) || choice < 1 || choice > items.length) {
|
|
reject(
|
|
new PentestError(
|
|
`Invalid selection. Please enter a number between 1 and ${items.length}`,
|
|
'validation',
|
|
false,
|
|
{ choice: answer }
|
|
)
|
|
);
|
|
} else {
|
|
resolve(items[choice - 1]!);
|
|
}
|
|
});
|
|
});
|
|
}
|