terminal-love-mcp
Provides tools for querying GitHub repository statistics (stars, forks, issues, language, license, topics, last push) to gauge maturity and popularity of tools.
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., "@terminal-love-mcpsearch for TUI file managers"
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.
terminal-love-mcp
MCP server over Terminal Trove — search the catalog and pull TUI/CLI design references (screenshots, demo GIFs, install commands, metadata) so an agent can study real terminal UIs while building one.
Built for wiring into the Vanta agent, but works with any MCP client.
Why
Terminal Trove curates hundreds of CLI/TUI tools, each page carrying the gold you want when designing a terminal UI: real screenshots + demo GIFs, the GitHub repo, language, license, platform support, and copy-pasteable install commands. There's no public API, so this server scrapes the (clean, stable) HTML and the site's Typesense search endpoint, caches politely to disk, and exposes everything as MCP tools — including returning screenshots as viewable image blocks so the agent can actually see the layout.
Related MCP server: mcp-cli-catalog
Install
npm install
npm run buildWire into Vanta (or any MCP client)
Add to your client's MCP config (e.g. .mcp.json / claude_desktop_config.json):
{
"mcpServers": {
"terminal-love": {
"command": "node",
"args": ["/Users/jasonpoindexter/Documents/GitHub/_tools/terminal love mcp/dist/index.js"]
}
}
}Optional env (all have sane defaults — see .env.example):
TTROVE_CACHE_DIR— where HTML/catalog cache lives (default: OS tmp)TTROVE_CACHE_TTL_MS— cache lifetime (default 6h)TTROVE_LOG_LEVEL— pino level (defaultinfo; logs go to stderr, never stdout)GITHUB_TOKEN— raises the rate limit forget_repo_stats
Tools
Collection-returning tools share one shape:
{ count, items, ...context }(e.g.search_tools→{ query, count, items },browse_category→{ category, count, items }). Single-entity tools (get_tool,get_repo_stats) return the object directly.
Tool | Input | Returns |
|
| Full details: description, GitHub, language, license, platforms, tags, install commands, screenshot URLs |
|
| Live search results (Terminal Trove Typesense) as tool summaries |
|
| Tools sharing the input's primary category |
|
| GitHub stars/forks/issues/language/license/topics/pushedAt |
| — | All 70+ categories (slug, name, url) |
|
| Tools in a category (name + description) |
|
| Recently added tools ( |
| — | Current pick + archive |
|
| Screenshot/GIF URLs + dimensions for a tool |
|
| The image itself as a base64 MCP image block (CDN-host allowlisted, 8 MB cap) |
|
| Build/refresh the full local catalog index from the sitemap |
|
| Offline fuzzy search across the whole catalog (after first sync) |
Typical flow for Vanta
search_tools/search_catalog/browse_category→ find candidate TUIsget_tool→ read structure, install, screenshot URLsview_screenshot→ actually see the layout to learn fromget_repo_stats→ gauge maturity/popularity
Development
npm run dev # run the server via tsx (stdio)
npm test # vitest (parsers tested against saved HTML fixtures)
npm run typecheck
npm run smoke # build + end-to-end stdio smoke test against the live site
npm run demo # build + simulate the full Vanta research flow
npm run verify # build + assert every tool against the LIVE site (drift guard, exits non-zero on failure)
npm run inspect # open the MCP InspectorDesign notes
stdio transport — stdout is the JSON-RPC stream; all logging is forced to stderr.
Polite scraping — 6h disk cache, custom user-agent, retry-with-backoff, 15s timeout.
Pure parsers — all HTML parsing lives in pure functions tested against fixtures in
src/features/*/__fixtures__/, so a Terminal Trove markup change is caught by a failing test.See
DECISIONS.mdfor locked architectural choices andPARKED.mdfor deferred ideas.
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/jpoindexter/terminal-love-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server