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>
57 lines
2.1 KiB
TypeScript
57 lines
2.1 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 { $, fs, path } from 'zx';
|
|
import chalk from 'chalk';
|
|
import { PentestError } from '../error-handling.js';
|
|
|
|
// Pure function: Setup local repository for testing
|
|
export async function setupLocalRepo(repoPath: string): Promise<string> {
|
|
try {
|
|
const sourceDir = path.resolve(repoPath);
|
|
|
|
// MCP servers are now configured via mcpServers option in claude-executor.js
|
|
// No need for pre-setup with claude CLI
|
|
|
|
// Initialize git repository if not already initialized and create checkpoint
|
|
try {
|
|
// Check if it's already a git repository
|
|
const isGitRepo = await fs.pathExists(path.join(sourceDir, '.git'));
|
|
|
|
if (!isGitRepo) {
|
|
await $`cd ${sourceDir} && git init`;
|
|
console.log(chalk.blue('✅ Git repository initialized'));
|
|
}
|
|
|
|
// Configure git for pentest agent
|
|
await $`cd ${sourceDir} && git config user.name "Pentest Agent"`;
|
|
await $`cd ${sourceDir} && git config user.email "agent@localhost"`;
|
|
|
|
// Create initial checkpoint
|
|
await $`cd ${sourceDir} && git add -A && git commit -m "Initial checkpoint: Local repository setup" --allow-empty`;
|
|
console.log(chalk.green('✅ Initial checkpoint created'));
|
|
} catch (gitError) {
|
|
const errMsg = gitError instanceof Error ? gitError.message : String(gitError);
|
|
console.log(chalk.yellow(`⚠️ Git setup warning: ${errMsg}`));
|
|
// Non-fatal - continue without Git setup
|
|
}
|
|
|
|
// MCP tools (save_deliverable, generate_totp) are now available natively via shannon-helper MCP server
|
|
// No need to copy bash scripts to target repository
|
|
|
|
return sourceDir;
|
|
} catch (error) {
|
|
if (error instanceof PentestError) {
|
|
throw error;
|
|
}
|
|
const errMsg = error instanceof Error ? error.message : String(error);
|
|
throw new PentestError(`Local repository setup failed: ${errMsg}`, 'filesystem', false, {
|
|
repoPath,
|
|
originalError: errMsg,
|
|
});
|
|
}
|
|
}
|