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

npmlens-mcp

v0.1.12

Published

NPMLens MCP: a server exposing tools to search npm packages and fetch READMEs.

Readme

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@latest ensures 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.md for all technical details.
  • See CONTRIBUTING.md for 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 with quality, popularity, maintenance).
    • Returns: { total, results[] } where each result includes name, 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, default AND), 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 optional readme.
  • 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 includes version, 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, default week).
    • Returns: { downloads, start, end, package }.
  • 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 optional error.
    • 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!