New Research: Supply Chain Attack on Axios Pulls Malicious Dependency from npm.Details →
Socket
Book a DemoSign in
Socket

certbot-ui

Package Overview
Dependencies
Maintainers
1
Versions
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

certbot-ui

Modern web interface for managing Certbot SSL/TLS certificates

latest
npmnpm
Version
1.0.0
Version published
Maintainers
1
Created
Source

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

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.

FAQs

Package last updated on 09 Nov 2025

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts