mirror of
https://github.com/KeygraphHQ/shannon.git
synced 2026-02-12 17:22:50 +00:00
* 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>
67 lines
2.2 KiB
TypeScript
67 lines
2.2 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 { $ } from 'zx';
|
||
import chalk from 'chalk';
|
||
|
||
type ToolName = 'nmap' | 'subfinder' | 'whatweb' | 'schemathesis';
|
||
|
||
export type ToolAvailability = Record<ToolName, boolean>;
|
||
|
||
// Check availability of required tools
|
||
export const checkToolAvailability = async (): Promise<ToolAvailability> => {
|
||
const tools: ToolName[] = ['nmap', 'subfinder', 'whatweb', 'schemathesis'];
|
||
const availability: ToolAvailability = {
|
||
nmap: false,
|
||
subfinder: false,
|
||
whatweb: false,
|
||
schemathesis: false
|
||
};
|
||
|
||
console.log(chalk.blue('🔧 Checking tool availability...'));
|
||
|
||
for (const tool of tools) {
|
||
try {
|
||
await $`command -v ${tool}`;
|
||
availability[tool] = true;
|
||
console.log(chalk.green(` ✅ ${tool} - available`));
|
||
} catch {
|
||
availability[tool] = false;
|
||
console.log(chalk.yellow(` ⚠️ ${tool} - not found`));
|
||
}
|
||
}
|
||
|
||
return availability;
|
||
};
|
||
|
||
// Handle missing tools with user-friendly messages
|
||
export const handleMissingTools = (toolAvailability: ToolAvailability): ToolName[] => {
|
||
const missing = (Object.entries(toolAvailability) as Array<[ToolName, boolean]>)
|
||
.filter(([, available]) => !available)
|
||
.map(([tool]) => tool);
|
||
|
||
if (missing.length > 0) {
|
||
console.log(chalk.yellow(`\n⚠️ Missing tools: ${missing.join(', ')}`));
|
||
console.log(chalk.gray('Some functionality will be limited. Install missing tools for full capability.'));
|
||
|
||
// Provide installation hints
|
||
const installHints: Record<ToolName, string> = {
|
||
'nmap': 'brew install nmap (macOS) or apt install nmap (Ubuntu)',
|
||
'subfinder': 'go install -v github.com/projectdiscovery/subfinder/v2/cmd/subfinder@latest',
|
||
'whatweb': 'gem install whatweb',
|
||
'schemathesis': 'pip install schemathesis'
|
||
};
|
||
|
||
console.log(chalk.gray('\nInstallation hints:'));
|
||
missing.forEach(tool => {
|
||
console.log(chalk.gray(` ${tool}: ${installHints[tool]}`));
|
||
});
|
||
console.log('');
|
||
}
|
||
|
||
return missing;
|
||
};
|