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

@monodog/backend

v1.5.34

Published

Backend API server for monodog monorepo dashboard

Downloads

2,104

Readme

Monodog: Monorepo Analytics and Health API

🎯 Overview

This is the backend service designed to provide comprehensive analytics, health monitoring, and dependency tracking for a large JavaScript/TypeScript monorepo. It leverages specialized @monodog tools and a database layer (via Prisma) to efficiently manage, persist, and expose data about all packages within the repository.

This service is typically run locally or on a central server to power a dedicated frontend dashboard.


🛠 Technology Stack

| Component | Technology | Description | | -------------- | ------------------------- | -------------------------------------------------------------------- | | Language | TypeScript & Node.js | Core language for runtime execution. | | Framework | Express.js | Handles all API routing and middleware. | | ORM | Prisma | Database layer for managing package and health status records. | | Scanning | @monodog/monorepo-scanner | Core logic for file system scanning and package metadata extraction. | | VCS | GitService | Used to fetch and analyze commit history per package path. | | Networking | cors, body-parser | Essential middleware for API connectivity. |


⚙️ Prerequisites

You must have the following installed to run the service:

  • Node.js: Version 18+ recommended
  • Package Manager: pnpm
  • Database: A running instance of a database supported by Prisma (e.g., PostgreSQL, SQLite, MySQL)

🚀 Getting Started

Installation

Clone the repository and install the dependencies:

# Clone the repository
git clone https://github.com/mindfiredigital/MonoDog.git
cd packages/backend

# Install dependencies
pnpm install

# Database Setup (Prisma)

The application requires the database schema to be set up using **Prisma Migrate**.

pnpm prisma generate

pnpm prisma migrate dev

### Run backend server on port 4000 (default)

pnpm monodog-cli --serve --root .

Key API Endpoints

| Method | Route | Purpose | Persistence | | ------- | --------------------------- | --------------------------------------------------------------------------------------- | ------------------- | | GET | /api/packages | Retrieve all package metadata from the database. | Persistent | | GET | /api/packages/refresh | Trigger a full file scan of the monorepo and update/sync the database. | Triggers write | | GET | /api/packages/:name | Get detailed info, commits, and Health status for a package. | Persistent | | **GET** | /api/health/packages | Fetch the latest health metrics (score, build status) for all packages. | Persistent | | **GET** |/api/health/refresh | Recalculate all package health metrics (tests, lint, security) and update the database. | Triggers write | | **GET** |/api/commits/:packagePath| Fetch Git commit history for a specific package directory. | Persistent | | **GET** |/api/config/files | Scan the monorepo for essential configuration files (e.g.,tsconfig, .eslintrc`). | Generated runtime |