npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

@raghulm/aegis-mcp

v1.0.9

Published

DevSecOps-focused MCP server for AWS, Kubernetes, CI/CD, and security tooling.

Downloads

47

Readme

License: MIT Python version MCP Protocol Docker


Aegis MCP Server empowers AI assistants (like Claude, Cursor, and GitHub Copilot) to perform cloud architecture administration, security scanning, and network analyses directly from their execution environments. It wraps powerful underlying tools and SDKs into secure, audited MCP tool sets.


📸 Demo in Action

AI Agent: "Check if any S3 bucket is publicly accessible"

Tool call → aws_check_s3_public_access
Result → bucket audit report

🌟 Key Features

  • 🚀 FastMCP Server — Exposes domain-specific tools for AWS, Kubernetes, security scanning, Git, network analysis, Jenkins, and CI/CD pipelines.
  • 🔐 Flexible Authorization — JWT-based RBAC for production deployments; automatically disabled for local stdio sessions (Claude Desktop, Agent IDEs).
  • 📜 Structured Audit Logging — Emits clean JSON audit logs for every invocation, suitable for SIEM integrations.
  • 🛠 Expandable Tooling — Easily add new integrations. Includes ready-to-use scanners for dependencies, secrets, SSL/TLS certs, Semgrep, Trivy, and more.
  • 📦 Docker Ready — Containerized deployment using a non-root runtime with built-in health checks.
  • 🌐 ASGI Integration — FastAPI health endpoint alongside MCP streamable-http transport.

📐 Architecture

flowchart TD
    Client[MCP Client / AI Agent] -->|Tool Call| AuthZ[Auth & RBAC Layer]

    subgraph aegis-mcp["Aegis MCP Server"]
        AuthZ --> Audit[Audit Logger]
        Audit --> ToolsLayer[Tool Dispatch Layer]
    end

    ToolsLayer --> AWS[AWS SDK]
    ToolsLayer --> K8s[kubectl / K8s SDK]
    ToolsLayer --> Sec[Trivy / Semgrep]
    ToolsLayer --> Net[Nmap / SSL]
    ToolsLayer --> Git[Git CLI]
    ToolsLayer --> Jenkins[Jenkins API]

The server receives MCP tool-call requests over streamable HTTP or stdio transport. In HTTP mode, each request requires a JWT bearer token for authorization. In stdio mode (local usage), authorization is automatically disabled.


📂 Repository Structure

aegis-mcp/
│
├── server/
│   ├── main.py
│   ├── health.py
│   ├── auth.py
│   └── tools/
│       ├── aws/
│       ├── cicd/          # Jenkins + pipeline tools
│       ├── kubernetes/
│       ├── security/
│       └── network/
│
├── policies/
├── tests/
├── Dockerfile
└── run_stdio.py

🧰 Available Tools

Example Tool Invocation

Tool: security_run_trivy_scan

Input:
image=nginx:latest

Output:
CRITICAL: 2
HIGH: 4
MEDIUM: 7

Cloud & DevOps

| Tool | Description | |------|-------------| | aws_list_ec2_instances | List EC2 instances in a specific AWS region | | aws_check_s3_public_access | Audit S3 buckets for public access settings | | k8s_list_pods | List Kubernetes pods in a given namespace | | cicd_pipeline_status | Fetch CI/CD pipeline execution status | | git_recent_commits | Fetch recent commit history from the active Git repo |

Jenkins CI/CD

| Tool | Description | |------|-------------| | jenkins_list_jobs | List all jobs on a Jenkins server | | jenkins_get_job_info | Get detailed info about a specific job (build history, health) | | jenkins_create_job | Create a new Jenkins job from XML config | | jenkins_trigger_build | Trigger a build with optional parameters (JSON) | | jenkins_get_build_info | Get result, duration, and status of a specific build | | jenkins_get_build_log | Fetch console output of a build | | jenkins_delete_job | Delete a Jenkins job |

[!TIP] Jenkins tools require per-call credentials — pass url, username, and api_token with each call. No global env vars needed.

Application Security & SAST

| Tool | Description | |------|-------------| | security_semgrep_scan | Run Semgrep SAST scan on a local directory or file | | security_run_trivy_scan | Run Trivy vulnerability scan on a container image | | security_scan_secrets | Scan files/directories for exposed secrets | | security_check_dependencies | Check dependency files for known CVEs via OSV.dev |

Network & Infrastructure Security

| Tool | Description | |------|-------------| | k8s_security_audit | Audit Kubernetes clusters (privileged containers, wildcard RBAC, etc.) | | network_port_scan | TCP port scan to detect exposed services | | security_check_ssl_certificate | Validate SSL/TLS certificate details and expiry | | security_check_http_headers | Audit URLs for security headers (HSTS, CSP, etc.) |

[!IMPORTANT] SAST (Semgrep scan) works only on Agent IDEs (e.g., Antigravity, Cursor) or Claude Co-work. It does not work on Claude Desktop due to Windows subprocess pipe limitations with semgrep-core.exe. All other tools (secrets scan, SSL check, port scan, etc.) work on all platforms including Claude Desktop.


🚀 Getting Started

Prerequisites

  • Python 3.12+
  • Node.js 18+ (only if you want to run via npm/npx)
  • Semgreppip install semgrep (for SAST scanning)
  • Optional: AWS CLI / boto3, kubectl, Trivy (for their respective tools)

Installation

git clone https://github.com/raghulvj01/aegis-mcp.git
cd aegis-mcp

# Create virtual environment
python -m venv .venv

# Activate it
# Linux/Mac:
source .venv/bin/activate
# Windows:
.venv\Scripts\activate

# Install dependencies
pip install -r requirements.txt

Install via npm (Public Package)

npm install -g @raghulm/aegis-mcp
# or run without installing globally:
npx -y @raghulm/aegis-mcp

On first run, the npm wrapper creates a local Python virtual environment and installs dependencies from requirements.txt automatically.


🤖 Usage with AI Agents

Agent IDE / Antigravity (Recommended)

Add to your MCP config (e.g., mcp_config.json):

{
  "mcpServers": {
    "aegis": {
      "command": "npx",
      "args": ["-y", "@raghulm/aegis-mcp"]
    }
  }
}

All 19 tools work, including Semgrep SAST and Jenkins integration.

Claude Desktop

Add to claude_desktop_config.json:

  • Windows: %LOCALAPPDATA%\Packages\Claude_...\LocalCache\Roaming\Claude\
  • Mac: ~/Library/Application Support/Claude/
{
  "mcpServers": {
    "aegis": {
      "command": "npx",
      "args": ["-y", "@raghulm/aegis-mcp"]
    }
  }
}

⚠️ 18 of 19 tools work. Semgrep SAST does not work due to Windows pipe limitations.

Cursor / Windsurf (HTTP Mode)

Start the server, then add to .cursor/mcp.json:

uvicorn server.health:app --host 0.0.0.0 --port 8000
{
  "mcpServers": {
    "aegis": {
      "url": "http://localhost:8000/mcp"
    }
  }
}

Docker Deployment

docker build -t aegis-mcp .
docker run -p 8000:8000 aegis-mcp

⚙️ Configuration

| Variable | Description | Default | |----------|-------------|---------| | MCP_AUTH_DISABLED | Disable JWT auth (auto-set for stdio) | false | | MCP_SERVICE_NAME | Name of the MCP service | aegis | | MCP_ENV | Environment (dev, staging, prod) | dev | | MCP_ROLES_FILE | Path to roles policy YAML | policies/roles.yaml | | MCP_SCOPES_FILE | Path to scopes policy YAML | policies/scope_rules.yaml | | OIDC_ISSUER | Expected JWT iss claim | None | | OIDC_AUDIENCE | Expected JWT aud claim | None |


🗝 Access Control

In HTTP mode, every tool requires a token argument containing a JWT. The authorization layer checks roles and scopes defined in policies/roles.yaml and policies/scope_rules.yaml.

In stdio mode (local usage via run_stdio.py), authorization is automatically disabled — no token required.

Policy Example (policies/roles.yaml)

roles:
  viewer:
    - aws_list_ec2_instances
    - k8s_list_pods
  security:
    - security_run_trivy_scan
    - security_semgrep_scan
  admin:
    - aws_list_ec2_instances
    - k8s_list_pods
    - security_run_trivy_scan
    - security_semgrep_scan
    # ... all tools

📝 Audit Logging

The @audit_tool_call decorator emits structured JSON logs for every invocation:

{
  "timestamp": "2026-03-06T08:00:01+00:00",
  "level": "INFO",
  "event": "tool_call_succeeded",
  "tool": "security_run_trivy_scan",
  "duration_ms": 1204
}

🛡️ Security Best Practices

  1. Enforce JWT Signature Validation — Update server/auth.py to verify RS256 JWTs using your IdP's JWKS endpoint for production.
  2. Least-Privilege Credentials — Assign ReadOnly IAM / K8s roles to the server environment.
  3. Monitor Audit Logs — Forward JSON logs to a SIEM. Set up anomaly detection for aggressive looping.

🛣️ Roadmap

  • [x] Jenkins CI/CD integration (list, create, trigger, inspect, delete jobs) ✅
  • [ ] Terraform security scanner
  • [ ] IAM policy risk detection
  • [ ] Kubernetes misconfiguration scanner (Basic k8s_security_audit implemented!)
  • [ ] GitHub Actions security audit
  • [ ] Cloud cost analysis tools

🤝 Contributing

See CONTRIBUTING.md for contribution and maintainer release workflows.


📄 License

Distributed under the MIT License. See LICENSE for more information.