A comprehensive VPN management solution with multi-zone support, automated account management, and real-time monitoring.
- Distributed server management across multiple zones
- Automatic configuration synchronization
- Load balancing and failover support
- Centralized control panel
- Automated account creation and deployment
- Shopping system integration
- Traffic monitoring and usage tracking
- Flexible subscription management
- X-UI panel synchronization
- Telegram bot interface
- Subscription URL system
- Multiple client support
The system manages VPN services through three main components:
graph TB
%% Main Components
CP((Control<br>Panel))
%% Zones with rounded rectangles
subgraph "Zones"
Z1[Zone A - Europe]
Z2[Zone B - Asia]
end
%% Servers as circles
S1((Server<br>Germany))
S2((Server<br>France))
S3((Server<br>Singapore))
%% User Access as hexagons
U1{VPN Client}
U2{Telegram Bot}
%% Simple Connections
CP --> Z1 & Z2
Z1 --> S1 & S2
Z2 --> S3
U1 & U2 --> CP
%% Clean Modern Colors
classDef panel fill:#6366F1,stroke:#4338CA,stroke-width:2px,color:#fff
classDef zone fill:#34D399,stroke:#059669,stroke-width:2px,color:#fff
classDef server fill:#F472B6,stroke:#DB2777,stroke-width:2px,color:#fff
classDef user fill:#60A5FA,stroke:#2563EB,stroke-width:2px,color:#fff
class CP panel
class Z1,Z2 zone
class S1,S2,S3 server
class U1,U2 user
%% Add Labels
linkStyle default stroke:#6B7280,stroke-width:2px
- Account creation and management
- Traffic monitoring and control
- Server synchronization
- User access management
- SSL certificate
- Domain configuration
- X-UI panel installation
- Database system
- X-ray compatible client
- Telegram account (for bot access)
- Valid subscription URL
- One-click configuration
- Automatic updates
- Multiple client support
- Account management
- Usage monitoring
- Support access
- Instant notifications
- Cross-platform support
- Auto-configuration
- Server selection
-
Account Creation
- Manual or automatic creation
- Zone assignment
- Server configuration
-
Server Sync
- Configuration deployment
- Traffic monitoring
- Status updates
-
User Access
- Subscription URL generation
- Client configuration
- Usage tracking
- Real-time traffic statistics
- Server status monitoring
- User activity tracking
- System health checks
- SSL encryption
- Domain validation
- Access control
- Traffic encryption
- Secure protocols
- Easy account management
- Multiple access methods
- Real-time monitoring
- Automatic configuration
- Centralized management
- Automated operations
- Comprehensive monitoring
- Revenue tracking
- Ubuntu 20.04 LTS (Focal Fossa)
- Ubuntu 22.04 LTS (Jammy Jellyfish)
- Debian 11 (Bullseye)
- Debian 12 (Bookworm)
- CPU: 1 core
- RAM: 2 GB
- Storage: 10 GB
The installation script will automatically install these dependencies, but for reference, the system needs:
- Python 3.9
- PostgreSQL
- systemd
- curl
- Other dependencies will be installed automatically
For full functionality, including subscription URLs and all features:
curl -fsSL https://raw.githubusercontent.com/eloravpn/EloraVPNManager/main/install.sh | sudo bash -s -- \
--domain your-domain.com \
--port 8080
Why use this method?
- Ensures all features work correctly
- Enables subscription URL functionality
- Provides better security through domain validation
- Allows proper SSL certificate setup
- Required for production deployments
Basic installation using auto-detected public IP (Limited functionality):
Auto-detects your public IP address
curl -fsSL https://raw.githubusercontent.com/eloravpn/EloraVPNManager/main/install.sh | sudo bash
- Subscription URLs will not function
- Some features may be restricted
- Not recommended for production use
- SSL certificate setup may be problematic
- Limited security features
Note: For production environments, always use Option 1 with a proper domain name.
curl -fsSL https://raw.githubusercontent.com/eloravpn/EloraVPNManager/main/install.sh | sudo bash -s -- \
--domain your-domain.com \
--port 8080 \
--protocol https \
--db-name custom_db \
--db-user custom_user \
--db-pass your_password \
--jwt-secret your_jwt_secret
Option | Description | Default |
---|---|---|
--domain |
Domain name for the application | localhost |
--port |
Port number for the application | 8080 |
--protocol |
Protocol (http/https) | http |
--db-name |
PostgreSQL database name | elora_db |
--db-user |
PostgreSQL user name | elora |
--db-pass |
PostgreSQL password | Random generated |
--jwt-secret |
JWT secret key | Random generated |
--version |
Specific version to install | Latest version |
To update the application, use one of these commands:
# Update to latest version
curl -fsSL https://raw.githubusercontent.com/eloravpn/EloraVPNManager/main/install.sh | sudo bash -s -- --update
# Update to specific version
curl -fsSL https://raw.githubusercontent.com/eloravpn/EloraVPNManager/main/install.sh | sudo bash -s -- --update --version v1.2.3
- Restart the service
- If no domain is specified, the installer will automatically detect and use your server's public IP
- If public IP detection fails, it will fall back to 'localhost'
- You can always specify a custom domain using the
--domain
option - The detected or specified domain/IP will be used in the configuration for API endpoints
tail -f /var/log/elora-vpn/elora-vpn.log
If your server has IPv6 capability, you can enable IPv6 listening by following these steps:
1. Access Control Panel
Log in to your control panel with administrator credentials Navigate to the Settings menu Select the Basic tab
2. Configure IPv6
Locate the "Uvicorn Host" setting Change the value from 0.0.0.0 to :: Click Save to apply changes
3. Apply Changes
# Restart the panel to activate IPv6 support
sudo systemctl restart elora-vpn
sudo systemctl status elora-vpn
Verify IPv6 Connectivity
# Check if the service is listening on IPv6
sudo netstat -tulpn | grep elora-vpn
curl -6 http://[::1]:8080/
Note: Ensure your firewall rules allow incoming connections on both IPv4 and IPv6 for your configured port.
SSL certificates are essential for:
- To work Subscription URL in all V2ray Clients!
- Secure subscription links for V2Ray clients
- Encrypted API communications
- Secure web interface access
# Install Certbot and Nginx plugin
sudo apt update
sudo apt install -y certbot
# Stop any service using port 80
sudo systemctl stop elora-vpn
# Get certificate
sudo certbot certonly --standalone --agree-tos --register-unsafely-without-email -d your-domain.com
After successful certification, your certificates will be located at:
/etc/letsencrypt/live/your-domain.com/fullchain.pem # Certificate
/etc/letsencrypt/live/your-domain.com/privkey.pem # Private Key
Access your control panel by logging in with your administrator credentials Navigate to the SSL configuration:
Click on "Settings" in the main menu Select the "SSL" tab from the available options
Configure the certificate paths:
In the "SSL Certificate Path" field, enter the full path to your SSL certificate file (e.g., /etc/ssl/certs/your-certificate.crt) In the "Private Key Path" field, enter the full path to your private key file (e.g., /etc/ssl/private/your-private-key.key) Double-check that both paths are correct and the files are readable by the panel
Apply the changes:
Click "Save" or "Apply" to confirm your SSL configuration Restart the panel service to apply the new SSL settings
# Test auto-renewal
sudo certbot renew --dry-run
# Certbot automatically adds a renewal cron job at
# /etc/cron.d/certbot
sudo systemctl restart elora-vpn
# Check service status
sudo systemctl status elora-vpn
# Start service
sudo systemctl start elora-vpn
# Stop service
sudo systemctl stop elora-vpn
# Restart service
sudo systemctl restart elora-vpn
# View logs
sudo journalctl -u elora-vpn -f
The primary configuration settings are stored in the .env file:
nano /opt/elora-vpn/.env
You can customize the panel's behavior through two methods:
1. Web Interface Settings
Access the control panel's Settings menu to configure:
General system preferences User management options Security settings Network configurations
2. Environment File
For advanced configurations, you can directly edit the .env file. This allows you to:
Set environment-specific variables Configure database connections Modify system paths Enable debug modes Set API keys and secrets Define custom service endpoints
Note: After modifying the .env file, restart the panel services to apply changes:
sudo systemctl restart elora-vpn
We recommend using the web interface for routine changes and the .env file for advanced system configurations. Always backup your configuration files before making significant changes.
- Enable SSL and configure domains
- Set up zones and servers
- Monitor system health
- Manage user accounts
- Purchase/activate account
- Get subscription URL
- Configure VPN client
- Monitor usage via bot
-
System Setup
# Install required components # Configure SSL # Set up domains
-
Zone Configuration
# Configure zones # Set up servers # Enable synchronization
-
Account Management
# Create accounts # Monitor usage # Manage subscriptions
- Installation Directory:
/opt/elora-vpn
- Virtual Environment:
/opt/elora-vpn/venv
- Service File:
/etc/systemd/system/elora-vpn.service
- Port Already in Use
# Check if port is already in use
sudo lsof -i :8080
sudo netstat -tulpn | grep 8080
# Test port accessibility
nc -zv localhost 8080
# Configure firewall for port
sudo ufw allow 8080/tcp
sudo ufw status
- Database Connection Issues
# Check PostgreSQL status
sudo systemctl status postgresql
# Check database logs
sudo tail -f /var/log/postgresql/postgresql-*.log
- Service Won't Start
# Check detailed error messages
sudo journalctl -u elora-vpn -n 50 --no-pager
# Verify Python path
sudo systemctl cat elora-vpn
# Check file permissions
sudo ls -la /opt/elora-vpn
sudo ls -la /opt/elora-vpn/venv/bin/python
# Manual start for debugging
cd /opt/elora-vpn
sudo ./venv/bin/python main.py
# Backup database
sudo -u postgres pg_dump elora_db > backup.sql
# Restore database
sudo -u postgres psql elora_db < backup.sql
# Backup configuration
sudo cp /opt/elora-vpn/.env /opt/elora-vpn/.env.backup
sudo cp -r /opt/elora-vpn/static /opt/elora-vpn/static.backup
# Stop service
sudo systemctl stop elora-vpn
# Reset database
sudo -u postgres psql -c "DROP DATABASE elora_db;"
sudo -u postgres psql -c "CREATE DATABASE elora_db OWNER elora;"
# Reinstall application
rm -rf /opt/elora-vpn/*
# Run installation script again...
To enable debug mode for more detailed logging:
- Edit
.env
file:
sudo nano /opt/elora-vpn/.env
# Change these settings:
DEBUG=true
LOG_LEVEL=10
- Restart service:
sudo systemctl restart elora-vpn
- Monitor debug logs:
sudo journalctl -u elora-vpn -f
When reporting issues, include this information:
# System info
uname -a
lsb_release -a
# Installation info
python3.9 --version
pip list
systemctl status elora-vpn
# Logs
journalctl -u elora-vpn --no-pager -n 100
# Database status
sudo -u postgres psql -d elora_db -c "\dx"
If you encounter any issues:
- Check the logs using the commands above
- Verify your system meets the minimum requirements
- Open an issue on GitHub
- The installation script automatically generates secure random passwords for the database and JWT secret
- All configuration files are created with proper permissions
- The
.env
file contains sensitive information and is readable only by root - Default database user has limited permissions to only the necessary database
To completely remove the application:
sudo systemctl stop elora-vpn
sudo systemctl disable elora-vpn
sudo rm -rf /opt/elora-vpn
sudo rm /etc/systemd/system/elora-vpn.service
sudo systemctl daemon-reload
To also remove the database:
sudo -u postgres psql -c "DROP DATABASE elora_db;"
sudo -u postgres psql -c "DROP USER elora;"
Default sudoer username and password is admin
.
The environment varaibles is SUDO_USERNAME and SUDO_PASSWORD
Follow the Readme in Elora VPN Manager Panel
This project is licensed under the MIT License - see the LICENSE file for details.
For support, please:
- Join our Telegram channel
- Check documentation
- Submit issues via GitHub
Made with ❤️ for better VPN management