codeforge-mcp
Enables MCP-compatible clients to delegate senior software engineering tasks like code generation, review, Jira management, and architecture recommendations to a model with a senior engineer persona.
README
codeforge-mcp
CodeForge — an MCP (Model Context Protocol) server that exposes Senior Software Engineer / Technical Lead capabilities as individual tools. Any MCP-compatible client — Claude Desktop, Cursor, VS Code, Claude Code — can call these tools to delegate engineering tasks to a model playing a senior-engineer persona.
The server is prompt-mediated for reasoning tools: code generation, code review, RCA, etc. each return a structured prompt that locks the host LLM into the senior-engineer persona and a strict output schema. The reasoning happens in the client's LLM, so no second LLM API key is needed.
Jira tools call the Jira REST API directly.
Tools exposed
| Tool | Purpose |
|---|---|
generate_code |
Generate clean, scalable, production-ready code with tests, logging, and docs. |
scaffold_service |
Scaffold a new Comviva Spring Boot microservice (pom, packaging, logging, Kafka, Consul, OpenAPI) per the standards in standards/comviva-springboot.md. |
generate_test_cases |
Generate a JUnit 5 + Mockito test class for one Java class with @DisplayName on every test, @Nested groups per method, AssertJ assertions, and Comviva copyright header. For project-wide tests, the host LLM iterates over source files and calls this per class. |
review_code |
Review a pull request / diff with severity-tagged findings anchored to file:line. |
analyze_bug |
Root-cause a bug from symptoms, stack trace, logs, and source. |
generate_rca |
Produce a publish-ready Root Cause Analysis report for an incident. |
jira_get_issue |
Fetch a Jira issue. |
jira_search_issues |
JQL search. |
jira_create_issue |
File a new issue (bug, story, task, epic). |
jira_update_issue |
Update fields on an issue. |
jira_transition_issue |
Move an issue through workflow states. |
jira_add_comment |
Attach investigation notes, RCA, or implementation updates. |
jira_link_issues |
Link related issues (Blocks, Relates, Caused by, etc.). |
jira_add_remote_link |
Attach a PR / deployment / dashboard URL to an issue. |
recommend_architecture |
Propose a scalable system design for a goal. |
review_architecture |
Review an API / database / microservice / pipeline / cloud infra design. |
identify_tech_debt |
Inventory technical debt and produce a refactor roadmap. |
review_cicd_pipeline |
Validate a CI/CD pipeline config. |
review_infra_config |
Review Kubernetes / Docker / Terraform / Helm / CloudFormation. |
deployment_readiness_check |
Pre-deploy go/no-go review with rollback and observability checks. |
generate_documentation |
Tech design, API reference, runbook, README, or module overview. |
generate_adr |
Architecture Decision Record (MADR style). |
generate_implementation_plan |
Phased implementation plan with risks and definition of done. |
generate_migration_strategy |
Migration strategy with stages, cutover, and rollback. |
Install & build
cd D:/eclipse-workspace/MRTM_7.12/mrtm/codeforge-mcp
npm install
npm run build
This produces dist/index.js.
Configure environment
Jira tools require credentials. Copy .env.example to .env and fill in:
JIRA_HOST=https://your-company.atlassian.net
JIRA_EMAIL=you@company.com
JIRA_API_TOKEN=<API token from id.atlassian.com/manage-profile/security/api-tokens>
JIRA_DEFAULT_PROJECT=MRTM
.env is not loaded automatically — pass these as real environment variables when the MCP client launches the server (see the next section). Tools that don't touch Jira work without these variables.
Register with an MCP client
Claude Desktop
Edit %APPDATA%\Claude\claude_desktop_config.json (Windows) and add:
{
"mcpServers": {
"codeforge": {
"command": "node",
"args": ["D:/eclipse-workspace/MRTM_7.12/mrtm/codeforge-mcp/dist/index.js"],
"env": {
"JIRA_HOST": "https://your-company.atlassian.net",
"JIRA_EMAIL": "you@company.com",
"JIRA_API_TOKEN": "<token>",
"JIRA_DEFAULT_PROJECT": "MRTM"
}
}
}
}
Restart Claude Desktop. The tools will appear in the tool picker.
Claude Code (CLI)
claude mcp add codeforge node "D:/eclipse-workspace/MRTM_7.12/mrtm/codeforge-mcp/dist/index.js" \
-e JIRA_HOST=https://your-company.atlassian.net \
-e JIRA_EMAIL=you@company.com \
-e JIRA_API_TOKEN=... \
-e JIRA_DEFAULT_PROJECT=MRTM
Cursor / VS Code (with MCP extension)
Add an entry in the client's MCP settings pointing to the same node dist/index.js command with the env vars above.
Company standards (used by scaffold_service)
The conventions for new microservices live in standards/comviva-springboot.md — packaging, copyright header, constructor injection, @Slf4j parameterized logging, Spring Kafka config pattern, Consul config layout, error handling, JPA, scheduling, Dockerfile. Edit that file to refine conventions; scaffold_service re-reads it on every call (no rebuild needed).
Example invocation from Claude
Scaffold a new service called
rewardservicethat consumes thereward.eventsKafka topic, persists aRewardLedgerentity to MySQL, and exposesGET /rewards/{customerId}to read balances.
The MCP client picks scaffold_service, fills in the args, and the host LLM produces the full project — pom.xml, RewardserviceApplication.java, config/KafkaConfig.java, service/RewardEventConsumer.java, dao/RewardLedgerRepository.java, model/RewardLedger.java, controller/RewardController.java, application.yml, bootstrap.yml, consul-prop.yml, logback-spring.xml, Dockerfile, and tests — all carrying the Comviva copyright header and following every rule in the standards file.
How the prompt-only tools work
When you call review_code, the server doesn't itself invoke an LLM. It returns a single text block containing:
- A senior-engineer persona prelude (role, tone, standards).
- The supplied inputs (the diff, PR title, etc.) embedded in a task description.
- A strict output contract — the exact sections, severity scale, table columns, and rules the LLM must follow.
The host LLM (Claude Desktop, Cursor, etc.) then executes that prompt as its next reasoning step. Because the contract is strict and the persona is consistent across tools, you get reproducible, high-quality output without standing up a second LLM endpoint.
If you later want the server to call an LLM itself (e.g. for batch jobs without a host UI), wire an Anthropic client into each tool's handler and post the existing prompt body to it. The current architecture is designed to make that swap trivial.
Adding a new tool
-
Create
src/tools/yourTool.tsexporting aToolDefinition:import { z } from "zod"; import { withPersona } from "../prompts/persona.js"; import type { ToolDefinition } from "./types.js"; const Schema = z.object({ /* inputs */ }); export const yourTool: ToolDefinition = { name: "your_tool", description: "What it does, in one sentence.", inputSchema: Schema, handler: async (raw) => { const input = Schema.parse(raw); return { content: [{ type: "text", text: withPersona("...prompt body...") }] }; }, }; -
Register it in
src/tools/index.tsunder the right capability group. -
npm run build. The client picks up the new tool on next restart.
Sharing with the team
Two distribution paths — start with A, promote to B once the standards stabilise.
A. Git clone
Maintainer (one-time): push this folder to GitHub.
Each teammate (one-time):
git clone https://github.com/ThakurAnketPratapSingh/codeforge-mcp.git
cd codeforge-mcp
setup.bat # Windows
./setup.sh # macOS / Linux / Git Bash
setup.bat / setup.sh installs deps, builds, and runs claude mcp add codeforge ... automatically. Teammates add their own Jira creds afterwards (re-register with -e JIRA_* flags — see the setup script output).
Getting updates:
git pull && setup.bat
Standards live in standards/comviva-springboot.md, versioned with the repo, so git pull is how new conventions reach every teammate.
B. Public npm (npmjs.com)
The package is published to the public npm registry as @anketpsingh/codeforge-mcp. Anyone with Node.js installed can grab it — no token needed.
⚠️ Public publication means
standards/comviva-springboot.mdis searchable on npmjs.com. Make sure that's intended.
Maintainer — one-time setup:
- Create a free account at https://www.npmjs.com/signup
- Enable 2FA on the account (npm requires it for publishing).
- Authenticate on this machine:
Enter username, password, email, and the OTP from your authenticator.npm login
Maintainer — each release:
npm run release:patch # 0.1.0 → 0.1.1, builds, publishes
npm run release:minor # 0.1.0 → 0.2.0
npm run release:major # 0.1.0 → 1.0.0
prepublishOnly rebuilds from clean automatically. Only dist/, standards/, README.md, and .env.example ship.
Each teammate — one-time:
npm install -g @anketpsingh/codeforge-mcp
claude mcp add codeforge codeforge-mcp
No .npmrc or token required — it's public.
Getting updates:
npm install -g @anketpsingh/codeforge-mcp@latest
Per-user secrets (both paths)
Jira credentials are per-user. Each teammate adds their own via claude mcp add ... -e JIRA_EMAIL=... -e JIRA_API_TOKEN=... after the base install. Shared values (JIRA_HOST, JIRA_DEFAULT_PROJECT) go in the README so everyone copies them verbatim.
Evolving the standards
standards/comviva-springboot.md is the single source of truth. To change a convention:
- Edit the file
- Path A: commit, push, teammates
git pull && setup.bat - Path B: bump version,
npm run release:minor, teammatesnpm install -g @anketpsingh/codeforge-mcp@latest
Standards changes are visible in git log standards/ — useful when investigating "why does the generator do X now".
Project layout
codeforge-mcp/
├── src/
│ ├── index.ts # stdio entry point
│ ├── server.ts # MCP server wiring
│ ├── prompts/persona.ts # shared senior-engineer persona
│ ├── jira/client.ts # Jira REST client (Cloud v3 / ADF)
│ └── tools/
│ ├── types.ts # ToolDefinition shape, error helper
│ ├── index.ts # tool registry
│ ├── codeGeneration.ts
│ ├── codeReview.ts
│ ├── bugAnalysis.ts
│ ├── rca.ts
│ ├── jira.ts
│ ├── architecture.ts
│ ├── devops.ts
│ └── documentation.ts
├── package.json
├── tsconfig.json
└── .env.example
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.