📦 NPM Package Scraper avatar

📦 NPM Package Scraper

Pricing

Pay per event

Go to Apify Store
📦 NPM Package Scraper

📦 NPM Package Scraper

Extract NPM package details, dependencies, and license data. Track weekly downloads and deprecation flags using the official registry API.

Pricing

Pay per event

Rating

0.0

(0)

Developer

太郎 山田

太郎 山田

Maintained by Community

Actor stats

0

Bookmarked

2

Total users

1

Monthly active users

2 days ago

Last modified

Categories

Share

NPM Package Intelligence API | Downloads, Dependencies & Licenses

Analyze public npm packages with official npm registry and downloads APIs — no npmjs.com HTML scraping, login, or API key required. Ideal for dependency shortlisting, license audits, maintainer checks, and release-cadence research.

Store Quickstart

  • Start with 3–5 exact package names in packages for the cleanest first run.
  • Add searchTerm only when you need discovery, and keep searchSize around 10–20 until you know the category you want.
  • Use dryRun: true to validate webhook or dataset delivery before a larger audit.
  • After the first useful run, move the account to the recurring watchlist template, then use the webhook handoff template for release alerts or downstream actions.

Key Features

  • 📦 Full package metadata — version, description, author, homepage, repo
  • 📥 Weekly download stats — Usage signal for popularity
  • 🔗 Dependencies tree — Direct deps with version specs
  • ⚖️ License info — MIT, Apache-2.0, GPL-3.0 detection
  • ⚠️ Deprecation detection — Flags deprecated packages
  • 🔑 No API key needed — Uses official npm registry

Use Cases

WhoWhy
DevOps teamsDependency security audits
Engineering leadersTrack tech stack across projects
OSS maintainersCompetitor package analysis
License complianceVerify all deps are commercially usable
Recruiters/foundersResearch packages/maintainers for hiring

Input

FieldTypeDefaultDescription
packagesstring[](required)npm package names (max 100)
includeDownloadsbooleantrueWeekly download stats
includeDeprecatedbooleanfalseInclude deprecated warnings

Input Example

{
"packages": ["express", "react", "axios"],
"includeDownloads": true,
"includeDeprecated": false
}

Output

FieldTypeDescription
namestringPackage name
versionstringLatest version
descriptionstringPackage description
downloadsobjectDownload stats by period (if includeDownloads)
downloads.lastWeekintegerLast 7 days downloads
downloads.lastMonthintegerLast 30 days downloads
vulnerabilitiesobject[]Known CVEs (if includeVulnerabilities)
maintainersstring[]Maintainer usernames
licensestringSPDX license identifier
repositorystringSource repo URL

Output Example

{
"name": "express",
"version": "4.21.2",
"description": "Fast, unopinionated web framework",
"author": "TJ Holowaychuk",
"license": "MIT",
"dependencies": {"body-parser": "~1.20.0"},
"weeklyDownloads": 32000000,
"deprecated": false
}

API Usage

Run this actor programmatically using the Apify API. Replace YOUR_API_TOKEN with your token from Apify Console → Settings → Integrations.

cURL

curl -X POST "https://api.apify.com/v2/acts/taroyamada~npm-package-intelligence/run-sync-get-dataset-items?token=YOUR_API_TOKEN" \
-H "Content-Type: application/json" \
-d '{ "packages": ["express", "react", "axios"], "includeDownloads": true, "includeDeprecated": false }'

Python

from apify_client import ApifyClient
client = ApifyClient("YOUR_API_TOKEN")
run = client.actor("taroyamada/npm-package-intelligence").call(run_input={
"packages": ["express", "react", "axios"],
"includeDownloads": true,
"includeDeprecated": false
})
for item in client.dataset(run["defaultDatasetId"]).iterate_items():
print(item)

JavaScript / Node.js

import { ApifyClient } from 'apify-client';
const client = new ApifyClient({ token: 'YOUR_API_TOKEN' });
const run = await client.actor('taroyamada/npm-package-intelligence').call({
"packages": ["express", "react", "axios"],
"includeDownloads": true,
"includeDeprecated": false
});
const { items } = await client.dataset(run.defaultDatasetId).listItems();
console.log(items);

Tips & Limitations

  • Audit your dependency list monthly to catch new CVEs and abandoned packages.
  • Track competitor packages' download trends for market intel.
  • Combine with GitHub data for full open-source intelligence.
  • Use in CI/CD to fail builds when vulnerabilities are introduced.

FAQ

Where do download stats come from?

npm's official npms.io API. Weekly counts are reliable popularity signals.

Can I get security vulnerability data?

Not directly. Pair with npm audit or Snyk for security scanning.

Does it work with private packages?

No — only public npm registry. Private packages require authentication.

Deprecated packages?

Flagged via the 'deprecated' field. Useful for migration planning.

Where do vulnerabilities come from?

GitHub Advisory Database via the npm audit endpoint.

Are private npm packages supported?

Public packages only. Private registries require authentication that this actor doesn't handle.

Pair this actor with other flagship intelligence APIs in the same portfolio:

Pricing & Cost Control

Apify Store pricing is usage-based, so total cost mainly follows how many packages you process and whether you also run discovery via searchTerm. Check the Store pricing card for the current per-event rates.

  • Start with a short packages list or keep searchSize small for discovery runs.
  • Turn includeDownloads on only when popularity signals matter.
  • Use dryRun: true to validate the input before larger audits.
  • Prefer dataset delivery while iterating; switch to webhooks once the payload shape is stable.