Server data from the Official MCP Registry
Harbor Registry MCP — projects, repos, artifacts, storage reports, cleanup (with dry-run).
Harbor Registry MCP — projects, repos, artifacts, storage reports, cleanup (with dry-run).
Valid MCP server (1 strong, 3 medium validity signals). 12 known CVEs in dependencies (0 critical, 6 high severity) Package registry verified. Imported from the Official MCP Registry.
5 files analyzed · 13 issues found
Security scores are indicators to help you make informed decisions, not guarantees. Always review permissions before connecting any MCP server.
This plugin requests these system permissions. Most are normal for its category.
Unverified package source
We couldn't verify that the installable package matches the reviewed source code. Proceed with caution.
Set these up before or after installing:
Environment variable: HARBOR_URL
Environment variable: HARBOR_USERNAME
Environment variable: HARBOR_PASSWORD
Environment variable: HARBOR_SSL_VERIFY
Add this to your MCP configuration file:
{
"mcpServers": {
"io-github-mshegolev-harbor-registry-mcp": {
"env": {
"HARBOR_URL": "your-harbor-url-here",
"HARBOR_PASSWORD": "your-harbor-password-here",
"HARBOR_USERNAME": "your-harbor-username-here",
"HARBOR_SSL_VERIFY": "your-harbor-ssl-verify-here"
},
"args": [
"harbor-registry-mcp"
],
"command": "uvx"
}
}
}From the project's GitHub README.
MCP server for Harbor Registry. Lets an LLM agent (Claude Code, Cursor, OpenCode, etc.) list projects, repositories and artifacts, run storage reports, find cleanup candidates, and delete untagged or old artifacts — all with safety rails (dry-run by default for bulk delete).
Python, FastMCP, stdio transport.
Works with any Harbor 2.x instance — SaaS or self-hosted / on-prem.
A couple of community Harbor MCPs exist (nomagicln/mcp-harbor, bupd/harbor-mcp-server) but they expose only the basic list/get endpoints. This one adds storage reports, cleanup candidates, delete untagged, and delete old artifacts with dry-run — the operations DevOps engineers actually need to reclaim disk space.
readOnlyHint: True; destructive ones (harbor_delete_*) carry destructiveHint: True so MCP clients ask for confirmation.harbor_delete_old_artifacts(dry_run=True)) — the agent must flip it to execute.harbor_list_artifacts surfaces scan status and counts if with_scan_overview is enabled.Discovery & inspection
harbor_list_projects — projects with repo counts and visibilityharbor_list_repos — repositories in a projectharbor_list_artifacts — artifacts in a repository with tags/size/scan statusharbor_storage_report — full project storage breakdown (all repos × all artifacts)Cleanup planning
harbor_cleanup_candidates — suggest what to delete (untagged, never-pulled, old versions)Cleanup execution (destructive)
harbor_delete_artifact — delete a single artifact by tag or digestharbor_delete_untagged — delete all untagged artifacts in a project/repoharbor_delete_old_artifacts — keep N latest per repo, delete the rest (dry-run default)Requires Python 3.10+.
# via uvx (recommended)
uvx --from harbor-registry-mcp harbor-registry-mcp
# or via pipx
pipx install harbor-registry-mcp
claude mcp add harbor -s project \
--env HARBOR_URL=https://harbor.example.com \
--env HARBOR_USERNAME='robot$your-robot' \
--env HARBOR_PASSWORD=your-robot-token \
--env HARBOR_SSL_VERIFY=true \
-- uvx --from harbor-registry-mcp harbor-registry-mcp
Or in .mcp.json:
{
"mcpServers": {
"harbor": {
"type": "stdio",
"command": "uvx",
"args": ["--from", "harbor-registry-mcp", "harbor-registry-mcp"],
"env": {
"HARBOR_URL": "https://harbor.example.com",
"HARBOR_USERNAME": "robot$your-robot",
"HARBOR_PASSWORD": "${HARBOR_PASSWORD}",
"HARBOR_SSL_VERIFY": "true"
}
}
}
}
Check:
claude mcp list
# harbor: uvx --from harbor-registry-mcp harbor-registry-mcp - ✓ Connected
| Variable | Required | Description |
|---|---|---|
HARBOR_URL | yes | Harbor URL (no trailing slash) |
HARBOR_USERNAME | yes | Harbor username — robot account recommended |
HARBOR_PASSWORD | yes | Password or robot token |
HARBOR_SSL_VERIFY | no | true/false. Default: true. |
einvy-pub"qa-assistant — keep latest 3"qa-assistant"qa-assistant/pgvector-rag, keep 1 latest"einvy-pub/my-image?"readOnlyHint: True — no confirmation needed.destructiveHint: True — clients should confirm.harbor_delete_old_artifacts defaults to dry_run=True; the agent must explicitly set dry_run=False to actually delete.harbor_cleanup_candidates is read-only — it only suggests candidates, never deletes.git clone https://github.com/mshegolev/harbor-registry-mcp.git
cd harbor-registry-mcp
pip install -e '.[dev]'
pytest
MIT © Mikhail Shchegolev
Be the first to review this server!
by Modelcontextprotocol · Developer Tools
Web content fetching and conversion for efficient LLM usage
by Modelcontextprotocol · Developer Tools
Read, search, and manipulate Git repositories programmatically
by Toleno · Developer Tools
Toleno Network MCP Server — Manage your Toleno mining account with Claude AI using natural language.
by mcp-marketplace · Developer Tools
Create, build, and publish Python MCP servers to PyPI — conversationally.