mcp-security-toolkit
Allows scanning filesystems for vulnerabilities and secrets using Trivy.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@mcp-security-toolkitScan the current directory with trivy and list critical vulnerabilities"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
mcp-security-toolkit
Project #6 of the DevSecOps portfolio: a local, free MCP server that exposes the portfolio's security scanners (Trivy, Gitleaks) as tools an AI agent can call — turning "run a scan" into something an LLM does for you, with zero API cost.
This is project #6. It makes the rest of the portfolio agent-accessible: instead of a human typing trivy fs, an MCP-aware agent calls the trivy_fs_scan tool and reasons over the JSON it gets back.
# | Project | Role |
1 | secure-k8s-lab | Reproducible cluster + GitOps + isolated vulnerable target |
2 | devsecops-pipeline | Scanning in CI (SAST/DAST/deps/IaC) |
3 | supply-chain-security | Image signing, SBOM, admission control |
4 | offensive-writeups | Documented attacks against the lab |
5 | runtime-security | Falco + Cilium detecting those attacks |
6 | mcp-security-toolkit (this repo) | Security scanners exposed as MCP tools for AI agents |
The story this repo tells
"My security tooling isn't just CLI I run by hand — it's an MCP server. Any agent (a local Ollama model, Cline, or Claude) can call
trivy_fs_scanandgitleaks_scanand reason over the findings. And it's all free and reproducible: a local Python server, open-source scanners, no paid API required."
Related MCP server: wrg-mcp-server
Architecture
flowchart LR
subgraph clients["MCP clients"]
I["MCP Inspector<br/>(no AI, free)"]
O["Ollama model<br/>via Cline / ollmcp"]
C["Claude<br/>(1 free connector)"]
end
subgraph server["mcp-security-toolkit (stdio)"]
T1[trivy_fs_scan]
T2[gitleaks_scan]
end
subgraph scanners["open-source scanners"]
TR[(Trivy)]
GL[(Gitleaks)]
end
I --> server
O --> server
C -->|"MCP / JSON-RPC over stdio"| server
T1 --> TR
T2 --> GL
TR -->|JSON report| server
GL -->|JSON report| serverTools
Tool | Wraps | Returns |
|
| Dependency/OS CVEs (+ secrets) found in a local path |
|
| Hard-coded secrets / credentials found in a local path |
Both wrap open-source scanners and return structured JSON, so the agent gets machine-readable findings instead of scraping CLI text. The server speaks MCP over stdio, so it runs anywhere a client can spawn a subprocess — no ports, no daemon, no cloud.
Prerequisites
Python ≥ 3.10
uv —
curl -LsSf https://astral.sh/uv/install.sh | shNode.js (only for
npx, used by the MCP Inspector)Trivy —
brew install trivyGitleaks —
brew install gitleaks
The scanners are looked up on PATH at call time; a clear error is returned if one is missing.
Quick start — no AI, free (MCP Inspector)
The fastest way to see the tools work, with no model and no API key: the MCP Inspector is a browser UI that connects to the server and lets you call tools by hand.
make up # create the venv + install the server (uv sync)
make inspect # launch the Inspector against the server -> http://localhost:6274In the Inspector: open Tools → List Tools, pick trivy_fs_scan, set
path to ., and Run — you'll get the raw Trivy JSON back.
make test # run the smoke tests
make down # remove the venv + cachesAs an agent (free) — a local LLM with Ollama
Drive the tools with a fully local, free model via Ollama. Use a model that supports tool calling:
ollama pull qwen2.5:7b # tool-calling capable, runs on a laptopOption A — ollmcp (a terminal MCP client for Ollama):
pipx install ollmcp
ollmcp --model qwen2.5:7b --mcp-server "uv run mcp-security-toolkit"Option B — Cline (VS Code extension): set the
API provider to Ollama, then add this server to cline_mcp_settings.json:
{
"mcpServers": {
"security-toolkit": {
"command": "uv",
"args": ["run", "mcp-security-toolkit"],
"cwd": "/absolute/path/to/mcp-security-toolkit"
}
}
}Then just ask: "Scan ./ with trivy and summarise the critical findings."
With Claude (free tier = 1 connector)
Claude's free tier allows a single custom connector, which is plenty for this local (stdio) server.
Claude Code:
claude mcp add security-toolkit -- uv run mcp-security-toolkitClaude Desktop — add to claude_desktop_config.json:
{
"mcpServers": {
"security-toolkit": {
"command": "uv",
"args": ["run", "mcp-security-toolkit"],
"cwd": "/absolute/path/to/mcp-security-toolkit"
}
}
}Then ask: "Use trivy_fs_scan on this repo and tell me what to fix first."
Repository layout
mcp-security-toolkit/
├── pyproject.toml # uv project: deps (mcp[cli]) + console script
├── .python-version # pinned interpreter for uv
├── src/
│ └── mcp_security_toolkit/
│ ├── __init__.py
│ └── server.py # FastMCP server: trivy_fs_scan + gitleaks_scan
├── tests/
│ └── test_server.py # smoke tests (no scanners required)
├── Makefile # up / inspect / test / down / help
├── .pre-commit-config.yaml # local gates (ruff, gitleaks, hygiene)
├── .markdownlint.yaml
├── .vscode/ # recommended extensions + format-on-save
├── .github/
│ └── workflows/
│ └── mirror-to-gitlab.yml # GitHub -> GitLab mirror (+ workflow_dispatch)
└── docs/
└── architecture.md # why MCP, server design, the three clients⚠️ Note
The tools run real scanners against whatever path you give them and shell out to local binaries. Only point them at code/paths you own or are authorised to scan, and only connect the server to clients you trust — an agent that can call these tools can read any file under the paths it scans.
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/teodorio95-portofolio/mcp-security-toolkit'
If you have feedback or need assistance with the MCP directory API, please join our Discord server