NPMLens MCP
NPMLens MCP lets your coding agent (such as Claude, Cursor, Copilot, Gemini or Codex) search the npm registry and fetch package context (README, downloads, GitHub info, usage snippets). It acts as a Model‑Context‑Protocol (MCP) server, giving your AI assistant a structured way to discover libraries and integrate them quickly.
npmlens-mcp lets your coding agent (such as Claude, Cursor, Copilot,
Gemini or Codex) search the npm registry and fetch package context
(README, downloads, GitHub info, usage snippets). It acts as a
Model‑Context‑Protocol (MCP) server, giving your AI assistant a
structured way to discover libraries and integrate them quickly.
Changelog | Contributing | Troubleshooting | Tool reference
Key features
- Structured npm search with optional ranking weights.
- Direct README fetch (optionally truncated).
- Enriched package info (downloads + GitHub details).
- Usage snippet extraction from README.
- Stdio MCP transport, ready for MCP‑compatible clients.
Disclaimers
npmlens-mcp performs network requests to npm and GitHub when tools are
used. Avoid sharing secrets in prompts; set GITHUB_TOKEN only if you
want higher GitHub rate limits.
Requirements
- Node.js v18.17 or newer
- npm (or pnpm)
Getting started
Add the following config to your MCP client:
{
"mcpServers": {
"npmlens": {
"command": "npx",
"args": ["-y", "npmlens-mcp@latest"]
}
}
}
[!NOTE] Using
npmlens-mcp@latestensures your MCP client always runs the latest published version.
MCP Client configuration
amp mcp add npmlens -- npx npmlens-mcp@latest
claude mcp add npmlens npx npmlens-mcp@latest
codex mcp add npmlens -- npx npmlens-mcp@latest
Start Copilot CLI:
copilot
Start the dialog to add a new MCP server by running:
/mcp add
Configure the following fields and press CTRL+S to save:
- Server name:
npmlens - Server Type:
Local - Command:
npx -y npmlens-mcp@latest
code --add-mcp '{"name":"npmlens","command":"npx","args":["-y","npmlens-mcp@latest"]}'
Go to Cursor Settings -> MCP -> New MCP Server. Use the config provided above.
Project wide:
gemini mcp add npmlens npx npmlens-mcp@latest
Globally:
gemini mcp add -s user npmlens npx npmlens-mcp@latest
Alternatively, follow the Gemini CLI MCP guide and use the standard config from above.
Go to Settings | Tools | AI Assistant | Model Context Protocol (MCP)
-> Add. Use the config provided above. Same for Junie under
Settings | Tools | Junie | MCP Settings -> Add.
Go to Settings | AI | Manage MCP Servers -> + Add and use the
config provided above.
Your first prompt
Enter one of the following prompts in your MCP client to check if everything works:
Basic search and info:
Find 5 React debounce hook libraries, include weekly downloads, and
fetch the README for the top result.
Compare packages:
Compare react-query, swr, and apollo-client. Show me their weekly
downloads, GitHub stars, and licenses.
Version history:
Show me all TypeScript versions released in the last 6 months with
their publish dates.
Dependencies:
What are the dependencies of express? Include dev dependencies.
Advanced and Local Usage
Looking for JSON‑RPC examples, tool schemas, the local dev CLI, troubleshooting, or contributor setup?
- See
docs/advanced.mdfor all technical details. - See
CONTRIBUTING.mdfor contributing guidelines.
Tools
Below are the tools exposed by NPMLens MCP. For full JSON schemas, see the Tool reference.
Core Search & Information
-
search_npm- Search the npm registry with optional ranking weights.
- Args:
query(string, required),size(1..250),from(offset),weights(object withquality,popularity,maintenance). - Returns:
{ total, results[] }where each result includesname,version,description,links,score, etc.
-
search_by_keywords- Search npm packages by specific keywords/tags with AND/OR operators.
- Args:
keywords(array of strings, required),operator(AND|OR, defaultAND),size(1..250). - Returns: Same as
search_npm. - Example: Find packages with "react" AND "hooks" AND "typescript".
-
get_readme- Fetch README markdown for a package (optionally by version).
- Args:
name(string, required),version(string),truncateAt(number). - Returns: JSON metadata (
name,version,repository,homepage) and the README as text content.
-
get_package_info- Enriched package info combining registry metadata, npm downloads, and GitHub details.
- Args:
name(string, required),version(string),includeReadme(boolean). - Returns:
name,version,repository,homepage,github{ fullName, url, stars, forks, license },downloadsLastWeek, and optionalreadme.
-
get_usage_snippet- Extract a likely usage snippet from a package README.
- Args:
name(string, required),version(string). - Returns:
{ snippet: { language, code, heading } }.
Version & Dependency Analysis
-
get_package_versions- List all available versions of a package with publish dates and dist tags.
- Args:
name(string, required),limit(number),since(string - ISO date or relative like "6 months"). - Returns:
{ name, versions[] }where each version includesversion,date,tags[]. - Example: "Show me all React versions from the last year".
-
get_package_dependencies- Get the dependency tree for a package.
- Args:
name(string, required),version(string),depth(1-3, default 1),includeDevDependencies(boolean). - Returns:
{ name, version, dependencies[], devDependencies[] }with name and version range for each dependency. - Example: "What dependencies does express have?".
Metrics & Comparison
-
get_downloads- Fetch npm downloads for the last
day/week/month. - Args:
name(string, required),period(day|week|month, defaultweek). - Returns:
{ downloads, start, end, package }.
- Fetch npm downloads for the last
-
compare_packages- Compare multiple npm packages side-by-side.
- Args:
packages(array of 1-10 package names, required). - Returns: Array of comparison data with
name,version,description,downloads,stars,forks,license,repository,homepage, and optionalerror. - Fetches all packages in parallel for performance.
- Example: "Compare react-query, swr, and apollo-client".
Sample usage queries
Below are example queries you can use with your AI assistant to test all 9 NPMLens tools:
search_npm
Search npm for react testing libraries
Find packages related to "typescript validation" and show me the top 5 results
get_readme
Show me the README for express
Get the README for react version 18.0.0
get_package_info
Get detailed information about the lodash package
Tell me about the vite package including GitHub stats and download numbers
get_downloads
How many downloads does react have in the last week?
Show me download statistics for next for the last month
get_usage_snippet
Show me a usage example for axios
How do I use the commander package? Give me a code snippet.
get_package_versions
List all versions of React from the last year
Show me the version history of TypeScript since 6 months ago
get_package_dependencies
What dependencies does express have?
Show me the dependency tree for next with depth 2
compare_packages
Compare react, vue, and angular
Compare the packages axios, fetch, and node-fetch and help me decide which to use
search_by_keywords
Find packages with keywords "react" AND "hooks" AND "typescript"
Search for packages with keywords "cli" OR "terminal"
Combined queries
You can also ask your AI assistant to use multiple tools together:
Compare react-query, swr, and apollo-client, then show me usage examples for the most popular one
Search for typescript validation libraries, then show me the README and dependencies for the top result
Find the package "zod", show me its download stats, version history, and a usage example
License & Contributing
NPMLens MCP is MIT licensed. Contributions are welcome! Please see CONTRIBUTING.md for guidelines.
Found a bug or have a feature request? Open an issue on GitHub.
Made with ❤️ for the vibe coding community. Happy coding!
Related Servers
Kagi Search
Search the web using Kagi's search API
NPI Registry
Search the National Provider Identifier (NPI) registry for healthcare providers and organizations in the United States.
Sci-Hub MCP Server
Search and access academic papers from Sci-Hub by DOI, title, or keyword.
Kluster.ai Verify
Fact-checking and verification tools using the Kluster.ai Verify API.
Naver Search
Search across various Naver services and analyze data trends using the Naver Search and DataLab APIs.
Serper Search
Provides Google search results and AI-powered deep research using the Serper API.
Reexpress
Enable Similarity-Distance-Magnitude statistical verification for your search, software, and data science workflows
Eventbrite
Interact with the Eventbrite API to search for events, get event details, and retrieve venue information.
Chaitin IP Intelligence
Search for IP addresses using Chaitin's IP Intelligence API.
Hunter.io
Find and verify professional email addresses with the Hunter.io API.