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

@excli/express

v2.10.0

Published

A cli tool for creating Express.js applications, supporting both JavaScript and TypeScript.

Readme

@excli/express — Modern Express.js Project Generator

npm version License: ISC Node.js 20+ TypeScript Ready


What is @excli/express?

@excli/express is a CLI tool that scaffolds production-ready Express.js projects in seconds — with TypeScript, Docker, database integration, ORM, testing, and Git hooks included. No boilerplate. No manual config. Just start building.


Why Not Use express-generator?

| Feature | express-generator | @excli/express | | ------------------- | ------------------- | ------------------------------------------------ | | TypeScript support | ❌ | ✅ Native TS & JS | | Docker integration | ❌ | ✅ One command | | Database setup | ❌ | ✅ MySQL, PostgreSQL, MongoDB, SQLite, MariaDB | | ORM support | ❌ | ✅ Prisma, Drizzle, TypeORM, Sequelize, Mongoose | | Redis / caching | ❌ | ✅ Built-in Redis support | | Hot reload (dev) | ❌ | ✅ Included | | Testing setup | ❌ | ✅ Vitest + Supertest | | Git hooks (Husky) | ❌ | ✅ Pre-commit & pre-push | | Admin DB panels | ❌ | ✅ phpMyAdmin, pgAdmin, Mongo Express | | Authentication | ❌ | ✅ Better Auth (drizzle and prisma only) | | Reverse proxy setup | ❌ | ✅ Nginx & Caddy & Traefik | | Load balancing | ❌ | ✅ Built-in config | | Modern Node.js APIs | ❌ | ✅ No deprecated methods | | Actively maintained | ❌ | ✅ |


Quick Start

No installation required. Just run:

npx @excli/express

Or install globally for repeated use:

npm install -g @excli/express
excli

Requirements

  • Node.js 20 or higher
  • A package manager: npm, yarn, pnpm, or bun
  • Docker (optional — only needed for database features)

Interactive Setup

The CLI walks you through a short, guided setup:

  1. Project Name — Name your application
  2. Language — Choose TypeScript or JavaScript
  3. Project Mode — Development (lightweight) or Production (full Docker + database stack)
  4. Dev Tools — Select from Git, Prettier, Husky, Vitest, Docker
  5. Database Type — SQL or NoSQL
  6. Database — MySQL, MariaDB, SQLite, PostgreSQL, or MongoDB
  7. ORM / ODM — Choose from Prisma, Drizzle, TypeORM, Sequelize, or Mongoose
  8. Authentication (new) — Optionally set up Better Auth (available with Prisma & Drizzle)
  9. Cache — Enable Redis for in-memory caching
  10. Proxy — Choose Nginx, Caddy or Traefik
  11. Proxy Mode — Reverse proxy and load balancing
  12. Package Manager — npm, yarn, pnpm, bun

Running Your Project

cd my-project
pnpm run dev

Visit http://localhost:3000 — your Express server is live.


What's Included

Git Hooks with Husky

When enabled, Husky sets up Git hooks automatically:

  • Pre-commit — Runs linting and formatting before every commit
  • Pre-push — Runs your test suite before pushing to remote
  • Commit message validation — Enforces the Conventional Commits standard

Database Support

All databases come with a pre-configured admin panel at http://localhost:6969 after running pnpm run docker:up.

| Database | Admin Panel | Port | | ---------- | ------------- | ---- | | MySQL | phpMyAdmin | 6969 | | MariaDB | phpMyAdmin | 6969 | | PostgreSQL | pgAdmin | 6969 | | MongoDB | Mongo Express | 6969 | | SQLite | — | — |

Note: Admin panels may take a moment to initialize on first startup.

ORM / ODM Support

| ORM | Supported Databases | TypeScript & JavaScript | | --------- | ---------------------------------- | ----------------------- | | Prisma | PostgreSQL, MySQL, MariaDB, SQLite | ✅ | | Drizzle | PostgreSQL, MySQL, MariaDB, SQLite | ✅ | | TypeORM | PostgreSQL, MySQL, MariaDB, SQLite | ✅ | | Sequelize | PostgreSQL, MySQL, MariaDB, SQLite | ✅ | | Mongoose | MongoDB only | ✅ |

Authentication Support (New)

@excli/express now includes built-in support for Better Auth — a modern, framework-agnostic authentication library.

Note: Currently, Better Auth integration is supported with Prisma and Drizzle adapters only (prisma with mongodb may also contain some clashes because of old prisma mongodb support but still its works)

| Adapter | Status | | ------- | ------------ | | Prisma | ✅ Supported | | Drizzle | ✅ Supported |

Docker Setup

Production mode includes a complete Docker configuration:

  • Dockerfile — Production-optimized container build
  • compose.yaml — Multi-service orchestration with correct volume paths
  • .env files — Separate environment configs for development and production

Reverse Proxy Setup

Choose between two options:

| Feature | Nginx | Caddy | Traefik | | --------------------- | -------------------------- | -------------------- | -------------------- | | Reverse proxy | ✅ | ✅ | ✅ | | Load balancing | ✅ | ✅ | ✅ | | Automatic HTTPS (TLS) | ❌ Manual | ✅ Automatic | ✅ | | Config style | nginx.conf | Caddyfile | traefik.yaml | | Best for | Full control, high-traffic | Simplicity, auto SSL | Simplicity, auto SSL |


Common Commands

pnpm run dev          # Start development server
pnpm run format       # Format code with Prettier
pnpm run build        # Compile TypeScript (TS projects only)
pnpm run docker:up    # Start Docker services
pnpm run docker:down  # Stop all Docker services

Troubleshooting

Port already in use? Update the ports in your .env file to resolve the conflict.

Docker not starting? Make sure Docker Desktop is running before executing pnpm run docker:up.

Husky hooks not triggering? Ensure Git is initialized, then run pnpm run prepare to register the hooks.

Proxy not routing traffic? Make sure your compose.yaml includes the proxy service and that no other process is bound to port 80.


Contributing

Contributions are welcome. Please read the Contributing Guide before opening a pull request.


License

ISC License — see the LICENSE file for details.


Author

Noman


Built with ❤️ for developers who want to skip the setup and start shipping.