A modern, web-based nginx management platform for effortless site deployment, SSL certificate management, and file operations
Nginx Site Manager is a powerful, intuitive web interface that transforms nginx administration from complex command-line operations into simple point-and-click actions. Perfect for developers, system administrators, and anyone who wants to manage websites without touching the terminal.
Main dashboard showing site overview, system status, and management tools
- 🌐 Complete Site Management - Create, configure, and manage nginx sites with ease
- 🔒 Automatic SSL Certificates - One-click Let's Encrypt SSL with auto-renewal
- 📁 File Management - Built-in file browser, editor, and upload for static sites
- 📊 Real-time Monitoring - Live logs, site status, and system health monitoring
- 🎨 Professional UI - Clean, responsive interface built with Bootstrap 5
- 🔐 Secure by Design - JWT authentication, input validation, and permission controls
- 🚀 Easy Deployment - One-command installation with automated setup
- Features
- Quick Start
- Installation
- Configuration
- Usage Guide
- API Documentation
- Security
- Contributing
- License
- Three Site Types: Static sites, reverse proxies, and load balancers
- Visual Configuration: Point-and-click configuration with real-time validation
- Enable/Disable Sites: Toggle sites without deleting configurations
- Status Monitoring: Real-time site health checks and performance metrics
- Configuration Templates: Pre-built templates for common use cases
Site management interface with status indicators and quick actions
- Let's Encrypt Integration: Automatic certificate generation and renewal
- One-Click SSL: Enable HTTPS with a single button click
- Certificate Monitoring: Track expiry dates and renewal status
- Auto-Renewal: Automatic renewal with systemd timers
- Staging Support: Test certificates safely before production deployment
- User-Accessible Storage: Certificates stored in user directory (no root required)
SSL certificate dashboard with expiry tracking and auto-renewal status
- Built-in File Browser: Navigate directories with breadcrumb navigation
- File Editor: Edit HTML, CSS, JavaScript with syntax highlighting
- Drag-and-Drop Upload: Upload single files or entire directories
- ZIP Extraction: Bulk upload and extract ZIP archives automatically
- File Operations: Create, rename, delete, move, and download files
- Security: Path validation, file type restrictions, and size limits
Built-in file manager with drag-and-drop upload and inline editing
- Real-time Log Viewer: Filter and search nginx logs in real-time
- System Status: Monitor nginx service health and configuration
- Site Status: Individual site health checks and metrics
- SSL Dashboard: Certificate expiry tracking and renewal status
- Error Handling: Comprehensive error messages and troubleshooting

- Linux server (Ubuntu 18.04+, Debian 10+, CentOS 7+, Rocky Linux 8+)
- Python 3.8 or higher
- Nginx (will be installed if not present)
- Sudo privileges for initial setup
That's it! Your nginx management interface is now running with:
- ✅ Nginx installed and configured
- ✅ SSL directories set up with proper permissions
- ✅ Python dependencies installed in virtual environment
- ✅ Systemd service configured for auto-startup
- ✅ Security permissions properly configured
Clean, professional login interface
The installation script automatically:
- Detects your OS and installs required packages
- Sets up nginx with proper permissions
- Installs Python dependencies in a virtual environment
- Configures SSL certificate directories for user access
- Creates a systemd service for auto-startup
- Sets up proper file permissions and security
- Tests SSL directory permissions
-
Install Dependencies
# Ubuntu/Debian sudo apt update sudo apt install -y nginx python3 python3-pip python3-venv certbot python3-certbot-nginx # CentOS/Rocky Linux/AlmaLinux sudo yum install -y nginx python3 python3-pip certbot python3-certbot-nginx -
Clone and Setup
git clone https://github.com/Adewagold/nginx-server-manager.git cd nginx-server-manager python3 -m venv venv source venv/bin/activate pip install -r requirements.txt -
Setup SSL Directories
mkdir -p ~/.letsencrypt/{live,work,logs,renewal} sudo chown -R $(whoami):www-data ~/.letsencrypt sudo find ~/.letsencrypt -type d -exec chmod 755 {} \; -
Configuration
cp config.yaml.example config.yaml # Edit config.yaml with your settings -
Initialize Database
python -c "from app.models import init_database; init_database()" -
Start the Application
./venv/bin/uvicorn app.main:app --host 0.0.0.0 --port 8080
Edit config.yaml to customize your installation:
The application automatically configures SSL certificates using Let's Encrypt:
- Certificates stored in ~/.letsencrypt/ for user accessibility
- Auto-renewal configured with systemd timers
- Staging server used by default for testing (remove --staging flag for production)
- Proper permissions set for nginx to read user certificates
-
Access the Web Interface
- Open http://your-server:8080 in your browser
- Login with your admin credentials
-
Create a New Site
- Click "New Site" button
- Choose site type (Static, Proxy, or Load Balancer)
- Configure domain, ports, and other settings
- Click "Create Site"
Site creation form with real-time configuration validation
-
Enable the Site
- Click the "Enable" button in the site list
- The site will be activated and nginx reloaded automatically
-
Add SSL Certificate
- Click the SSL shield icon next to your site
- Enter your email for Let's Encrypt
- Certificate will be generated and configured automatically
- Auto-renewal will be set up
-
Manage Files (Static Sites)
- Click the "Manage Files" folder icon
- Upload files via drag-and-drop
- Edit files directly in the browser with syntax highlighting
- Create folders and organize your content
Site configuration overview with status monitoring and quick actions
Perfect for:
- HTML/CSS/JavaScript websites
- React/Vue/Angular build outputs
- Documentation sites
- Landing pages
Features:
- File management with built-in editor
- Automatic caching for static assets
- Security headers and optimizations
- Custom error pages
- ZIP upload and extraction
Perfect for:
- Node.js applications
- Python web apps (Django/Flask)
- API backends
- Microservices
Features:
- Health checks and failover
- Request/response header modification
- SSL termination
- WebSocket support
- Configurable timeouts
Perfect for:
- High-traffic applications
- Multi-server deployments
- Redundancy and scaling
- Performance optimization
Features:
- Multiple load balancing algorithms
- Health monitoring
- Session persistence
- Weighted distribution
- Automatic failover
- Ensure your domain points to your server
- Click the SSL enable button for any site
- Enter your email address
- Certificate is generated and configured automatically
- Auto-renewal is set up with systemd timers
- View certificate expiry dates in the SSL dashboard
- Get warnings for certificates expiring within 30 days
- Monitor renewal status and history
- Manual renewal options available
- Upload: Drag files directly onto the upload area
- Edit: Click any text file to edit with syntax highlighting
- Create: New files and folders with optional templates
- Download: Individual files or entire directories
- Move: Drag and drop between folders
- Rename: Click rename button and enter new name
- ZIP Extract: Upload ZIP files for bulk content deployment
- File type restrictions prevent dangerous uploads
- Path validation prevents directory traversal attacks
- Size limits prevent resource exhaustion
- Permission controls limit access to site directories only
- Live Log Streaming: Watch nginx logs in real-time
- Advanced Filtering: Filter by log level, time range, or search terms
- Site-Specific Logs: View logs for individual sites
- Download Logs: Export filtered logs for analysis
- Error Highlighting: Visual highlighting of errors and warnings
Real-time log viewer with filtering and search capabilities
All API endpoints require JWT authentication:
Success responses:
Error responses:
- Authentication: JWT-based authentication with configurable expiry
- Authorization: Role-based access control and permission validation
- Input Validation: All inputs sanitized and validated
- Path Security: Directory traversal protection for file operations
- Rate Limiting: Configurable rate limits on API endpoints
- CSRF Protection: Cross-site request forgery protection
- Secure Headers: Security headers added to all responses
- File Upload Security: File type validation and size limits
- SSL Management: Secure certificate storage and management
-
Change Default Credentials
# Edit config.yaml admin: username: "your-username" password: "strong-password-here" -
Use Strong Secret Keys
# Generate a secure secret key python -c "import secrets; print(secrets.token_urlsafe(32))" -
Enable HTTPS
- Always use SSL certificates in production
- Redirect HTTP to HTTPS
- Use strong cipher suites
-
Network Security
- Run behind a reverse proxy (nginx/Apache)
- Use firewall rules to restrict access
- Consider VPN access for administration
-
Regular Updates
- Keep the application updated
- Monitor security advisories
- Update SSL certificates before expiry
We welcome contributions! Here's how to get started:
-
Fork and Clone
git clone https://github.com/your-username/nginx-manager.git cd nginx-manager -
Setup Development Environment
python3 -m venv venv source venv/bin/activate pip install -r requirements.txt -
Run Development Server
uvicorn app.main:app --reload --host 0.0.0.0 --port 8080
- Application logs: Check systemd journal with sudo journalctl -u nginx-manager -f
- Nginx logs: /var/log/nginx/error.log and /var/log/nginx/access.log
- SSL logs: ~/.letsencrypt/logs/letsencrypt.log
This project is licensed under the MIT License - see the LICENSE file for details.
- FastAPI - Modern Python web framework
- Bootstrap 5 - UI framework
- Let's Encrypt - Free SSL certificates
- Font Awesome - Icons
- SQLite - Database engine
- Issues: GitHub Issues
- Documentation: Full documentation coming soon
- Community: Join our discussions for tips and best practices
Made with ❤️ for the nginx community
Transform your nginx management experience from complex command-line operations to simple point-and-click actions.
🎯 Perfect for: Web developers, system administrators, DevOps engineers, and anyone who manages nginx sites but prefers visual interfaces over command-line operations.