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

certbot-ui

v1.0.0

Published

Modern web interface for managing Certbot SSL/TLS certificates

Readme

Certbot UI

A modern, secure web interface for managing Certbot SSL/TLS certificates.

Features

  • 🔐 Secure certificate management
  • 🔄 Automatic and manual certificate renewal
  • 📊 Real-time dashboard with certificate status
  • 🎨 Modern, responsive UI with dark mode
  • 🔍 Comprehensive logging and monitoring
  • 🚀 Easy deployment with Docker

Tech Stack

Backend

  • Node.js + Express + TypeScript
  • WebSocket for real-time updates
  • JWT authentication
  • Comprehensive security middleware

Frontend

  • React 18 + TypeScript
  • Vite for fast builds
  • TanStack Query for data management
  • Tailwind CSS + shadcn/ui components
  • Lucide icons

Quick Start

🐳 Production Deployment (Docker - Recommended)

The easiest way to deploy Certbot UI is using Docker:

# Navigate to docker directory
cd docker

# Copy and configure environment
cp .env.example .env
nano .env  # Edit JWT_SECRET and other settings

# Start with pre-built images from GitHub Container Registry
docker-compose up -d

# Or build locally
docker-compose -f docker-compose.local.yml up -d

Access at:

  • Frontend: http://localhost:8080
  • Backend API: http://localhost:5000

For detailed deployment instructions, see Docker Documentation.

💻 Development Setup

Prerequisites

  • Node.js >= 18
  • npm >= 9
  • Certbot installed on the system

Running Locally

# Install dependencies
npm install

# Start development servers (frontend + backend)
npm run dev

# Or start individually
npm run dev:backend
npm run dev:frontend

The frontend will be available at http://localhost:3000 and the backend at http://localhost:5000.

Building

# Build both frontend and backend
npm run build

# Or build individually
npm run build:backend
npm run build:frontend

Testing

# Run all tests
npm test

# Run tests with coverage
npm run test:coverage --workspaces

Project Structure

certbot-ui/
├── backend/           # Express API server
│   ├── src/
│   │   ├── config/    # Configuration files
│   │   ├── controllers/  # Route controllers
│   │   ├── middleware/   # Express middleware
│   │   ├── routes/    # API routes
│   │   ├── services/  # Business logic
│   │   ├── types/     # TypeScript types
│   │   └── utils/     # Utility functions
│   └── package.json
├── frontend/          # React application
│   ├── src/
│   │   ├── components/  # React components
│   │   ├── pages/    # Page components
│   │   ├── hooks/    # Custom React hooks
│   │   ├── services/ # API services
│   │   ├── store/    # State management
│   │   └── types/    # TypeScript types
│   └── package.json
└── package.json       # Root package (workspaces)

Configuration

Copy .env.example to .env in the backend directory and configure:

  • JWT_SECRET: Secure random string for JWT signing
  • CERTBOT_PATH: Path to certbot binary
  • CERTBOT_CONFIG_DIR: Certbot configuration directory
  • Other settings as needed

Security

⚠️ Important Security Notes:

  • This application runs Certbot commands with elevated privileges
  • Always use HTTPS in production
  • Change the default JWT secret
  • Implement proper authentication
  • Use rate limiting and input validation
  • Review the security documentation before deployment

Documentation

Comprehensive documentation is available in the docs/ directory:

Docker Deployment

The application can be deployed using Docker Compose with Cloudflare Tunnels for secure internet access:

# Start all services (backend, frontend, and tunnel)
docker compose up -d

# View logs
docker compose logs -f

# Stop services
docker compose down

See the Cloudflare Tunnel Setup Guide for details on exposing your services to the internet.

License

MIT

Contributing

Contributions are welcome! Please read the Contributing Guide first.