Personal tools
Namespaces

Variants
Actions

Proxmox VE VPS And Cloud For WHMCS

From ModulesGarden Wiki
(Difference between revisions)
Jump to: navigation, search
(Providing rDNS Management for Proxmox VE VPS)
(Module Upgrade From V3.X to V4.X)
 
(71 intermediate revisions by 2 users not shown)
Line 1: Line 1:
 
<meta name="keywords" content="proxmox ve vps & cloud for whmcs, proxmox ve vps & cloud configuration, whmcs proxmox ve vps & cloud management, whmcs proxmox ve vps & cloud installation, whmcs proxmox ve vps & cloud common problems, about whmcs proxmox ve vps & cloud, whmcs proxmox ve vps & cloud documentation, whmcs proxmox ve vps & cloud faq, whmcs proxmox ve vps & cloud help, whmcs proxmox ve vps & cloud guide, whmcs proxmox ve vps & cloud wiki, whmcs proxmox ve vps & cloud tutorial, whmcs proxmox ve vps & cloud tips, whmcs proxmox ve vps & cloud wiki, proxmox vps & cloud whmcs module, proxmox virtual environment whmcs"></meta>
 
<meta name="keywords" content="proxmox ve vps & cloud for whmcs, proxmox ve vps & cloud configuration, whmcs proxmox ve vps & cloud management, whmcs proxmox ve vps & cloud installation, whmcs proxmox ve vps & cloud common problems, about whmcs proxmox ve vps & cloud, whmcs proxmox ve vps & cloud documentation, whmcs proxmox ve vps & cloud faq, whmcs proxmox ve vps & cloud help, whmcs proxmox ve vps & cloud guide, whmcs proxmox ve vps & cloud wiki, whmcs proxmox ve vps & cloud tutorial, whmcs proxmox ve vps & cloud tips, whmcs proxmox ve vps & cloud wiki, proxmox vps & cloud whmcs module, proxmox virtual environment whmcs"></meta>
 
<meta name="description" content="ModulesGarden Wiki Contains All The Information You Need About The Proxmox VE VPS & Cloud For WHMCS Module."></meta>
 
<meta name="description" content="ModulesGarden Wiki Contains All The Information You Need About The Proxmox VE VPS & Cloud For WHMCS Module."></meta>
 
<h4 style="color: #ff0000; font-weight:bold; text-align:center;">This article is currently being updated - you may encounter broken links, outdated descriptions, or missing images.
 
</h4>
 
  
 
<h4 style="color: orange; font-weight:bold; text-align:center;">
 
<h4 style="color: orange; font-weight:bold; text-align:center;">
Additionally, the product has undergone major changes, including a name change and relocation of the license file to the addon.<br/>
+
Important: Please read the [[#Module_Upgrade_From_V3.X_to_V4.X|upgrade guide]] before updating to the stable 4.0 version.<br/>
Please note: You will need to reissue your license for the changes to take effect.<br/>
+
This release introduces significant changes, including a module name change and a new license file location within the addon.<br/>
We apologize for any inconvenience and appreciate your understanding.
+
Thank you for your understanding!
 
</h4>
 
</h4>
  
=About [https://www.modulesgarden.com/products/whmcs/proxmox-ve-vps-and-cloud Proxmox VE VPS & Cloud For WHMCS  WHMCS]=
+
=About [https://www.modulesgarden.com/products/whmcs/proxmox-ve-vps-and-cloud Proxmox VE VPS & Cloud For WHMCS]=
 
{|
 
{|
 
|style="padding: 10px 0px 10px 0px;"|'''Proxmox VE VPS & Cloud For WHMCS''' is a powerful module that combines the features of Proxmox VE VPS and Proxmox VE Cloud into a single, all-in-one solution.<br/> It allows you to automatically provision virtual servers and give clients the flexibility to create, remove, and resize their instances within defined resource limits.<br/> Your customers can manage backups, firewall settings, and access noVNC, SPICE, or Xterm.js console, directly in WHMCS.<br/>
 
|style="padding: 10px 0px 10px 0px;"|'''Proxmox VE VPS & Cloud For WHMCS''' is a powerful module that combines the features of Proxmox VE VPS and Proxmox VE Cloud into a single, all-in-one solution.<br/> It allows you to automatically provision virtual servers and give clients the flexibility to create, remove, and resize their instances within defined resource limits.<br/> Your customers can manage backups, firewall settings, and access noVNC, SPICE, or Xterm.js console, directly in WHMCS.<br/>
Line 35: Line 32:
 
{|
 
{|
 
|style="padding: 0px 0px 0px 30px;"|✔ Reconfigure Server Network
 
|style="padding: 0px 0px 0px 30px;"|✔ Reconfigure Server Network
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 30px;"|✔ Import/Detach VM Machine To/From WHMCS Product
 
|}
 
|}
 
{|
 
{|
Line 171: Line 171:
 
{|
 
{|
 
|style="padding: 0px 0px 0px 30px;"|✔ Create And Manage Custom Cloud-Init Scripts Per App Template
 
|style="padding: 0px 0px 0px 30px;"|✔ Create And Manage Custom Cloud-Init Scripts Per App Template
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 30px;"|✔ Configure High Availability Settings Per App Template
 
|}
 
|}
 
{|
 
{|
Line 191: Line 194:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Configure Console Proxy
+
|style="padding: 0px 0px 0px 30px;"|✔ Configure Console Proxy For Multiple Or Per-Node Connections
 
|}
 
|}
 
{|
 
{|
Line 212: Line 215:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 10px 30px;"|✔ Manage Media Library With Logotypes For App Templates
+
|style="padding: 0px 0px 0px 30px;"|✔ Manage Media Library With Logotypes For App Templates
 +
|}
 +
{|
 +
|style="padding: 0px 0px 10px 30px;"|✔ View Backup Tasks, Virtual Machine And Resource Usage Statistics
 
|}
 
|}
  
Line 220: Line 226:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ View Failed Tasks
+
|style="padding: 0px 0px 0px 30px;"|✔ View Waiting And Failed Tasks
 
|}
 
|}
 
{|
 
{|
Line 437: Line 443:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Number Of CPU Sockets
+
|style="padding: 0px 0px 0px 45px;"|✔ Additional Disks Space (With Configurable Storage, Units And Size)
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Number Of Cores Per Socket
+
|style="padding: 0px 0px 0px 45px;"|✔ Amount of RAM
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ CPU Limit
+
|style="padding: 0px 0px 0px 45px;"|✔ Application
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ CPU Units For The VM
+
|style="padding: 0px 0px 0px 45px;"|✔ Backup Files
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Amount of RAM
+
|style="padding: 0px 0px 0px 45px;"|✔ Backups Size
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 45px;"|✔ Bandwidth
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 45px;"|✔ CPU Cores
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 45px;"|✔ CPU Sockets
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 45px;"|✔ CPU units for a VM
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 45px;"|✔ Custom Cloud-Init Configuration
 
|}
 
|}
 
{|
 
{|
Line 455: Line 476:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Additional Disk Space (With Configurable Storage, Units And Size)
+
|style="padding: 0px 0px 0px 45px;"|✔ Download Backup Files
 
|}
 
|}
 
{|
 
{|
Line 467: Line 488:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Private Network
+
|style="padding: 0px 0px 0px 45px;"|✔ Limit Of CPU
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Backups Size Limit
+
|style="padding: 0px 0px 0px 45px;"|✔ Managed View
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Backups Files Limit
+
|style="padding: 0px 0px 0px 45px;"|✔ Network Rate
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Protected Backup Files Limit
+
|style="padding: 0px 0px 0px 45px;"|✔ OS Type
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Download Backup Files Option
+
|style="padding: 0px 0px 0px 45px;"|✔ Private Network
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Restore Backup Files Option
+
|style="padding: 0px 0px 0px 45px;"|✔ Protected Backup Files
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Server Monitoring
+
|style="padding: 0px 0px 0px 45px;"|✔ Restore Backup Files
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Snapshots Limit
+
|style="padding: 0px 0px 0px 45px;"|✔ Server Monitoring
 
|}
 
|}
 
{|
 
{|
Line 494: Line 515:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Bandwidth Limit
+
|style="padding: 0px 0px 0px 45px;"|✔ Snapshots
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ VM Template
+
|style="padding: 0px 0px 0px 45px;"|✔ Storage Disk Space
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Archive
+
|style="padding: 0px 0px 0px 45px;"|✔ TPM
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Network Rate
+
|style="padding: 0px 0px 0px 45px;"|✔ Tag
 
|}
 
|}
 
{|
 
{|
Line 509: Line 530:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ ISO Image
+
|style="padding: 5px 0px 0px 30px;"|✔ KVM Limits For "Cloud" Product Type:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ OS Type
+
|style="padding: 0px 0px 0px 45px;"|✔ Additional Disk Space
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Custom Cloud-Init Configuration
+
|style="padding: 0px 0px 0px 45px;"|✔ Backups Files Limit
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Cloud-Init Script
+
|style="padding: 0px 0px 0px 45px;"|✔ Backups Size
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Tag
+
|style="padding: 0px 0px 0px 45px;"|✔ Bandwidth
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ TPM
+
|style="padding: 0px 0px 0px 45px;"|✔ CPU Cores
 
|}
 
|}
 
{|
 
{|
|style="padding: 5px 0px 0px 30px;"|✔ KVM Limits For "Cloud" Product Type:
+
|style="padding: 0px 0px 0px 45px;"|✔ CPU Limit
 
|}
 
|}
 
{|
 
{|
Line 533: Line 554:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ CPU Cores
+
|style="padding: 0px 0px 0px 45px;"|✔ CPU Units Limit
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ CPU Limit
+
|style="padding: 0px 0px 0px 45px;"|✔ IPv4 Addresses
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ CPU Units Limit
+
|style="padding: 0px 0px 0px 45px;"|✔ IPv6 Addresses
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Memory
+
|style="padding: 0px 0px 0px 45px;"|✔ IPv6 Subnets
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Storage
+
|style="padding: 0px 0px 0px 45px;"|✔ Memory
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ IPv4 Addresses
+
|style="padding: 0px 0px 0px 45px;"|✔ Network Rate
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ IPv6 Addresses
+
|style="padding: 0px 0px 0px 45px;"|✔ Network Rate
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ IPv6 Subnets
+
|style="padding: 0px 0px 0px 45px;"|✔ Snapshot Jobs
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Backups Size
+
|style="padding: 0px 0px 0px 45px;"|✔ Snapshots
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Backups Files
+
|style="padding: 0px 0px 0px 45px;"|✔ Storage
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Snapshots
+
|style="padding: 0px 0px 0px 45px;"|✔ Storage Disk Space
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Bandwidth
+
|style="padding: 0px 0px 0px 45px;"|✔ VCPUs
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Network Rate
+
|style="padding: 0px 0px 10px 45px;"|✔ Virtual Networks
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ VCPUs
+
|style="padding: 5px 0px 0px 30px;"|✔ LXC For "VPS" Product Type:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Virtual Networks
+
|style="padding: 0px 0px 0px 45px;"|✔ Additional Disks Space (With Configurable Storage, Units And Size)
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Snapshot Jobs
+
|style="padding: 0px 0px 0px 45px;"|✔ Amount of RAM
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 10px 45px;"|✔ Storage Disk Space
+
|style="padding: 0px 0px 0px 45px;"|✔ Amount of SWAP
 
|}
 
|}
 
{|
 
{|
|style="padding: 5px 0px 0px 30px;"|✔ LXC For "VPS" Product Type:
+
|style="padding: 0px 0px 0px 45px;"|✔ Application
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Number Of CPU Cores
+
|style="padding: 0px 0px 0px 45px;"|✔ Backup Files
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ CPU Limit
+
|style="padding: 0px 0px 0px 45px;"|✔ Backups Size
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ CPU Units For The VM
+
|style="padding: 0px 0px 0px 45px;"|✔ Bandwidth
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Amount of RAM
+
|style="padding: 0px 0px 0px 45px;"|✔ CPU Cores
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Amount of SWAP
+
|style="padding: 0px 0px 0px 45px;"|✔ CPU units for a VM
 
|}
 
|}
 
{|
 
{|
Line 605: Line 626:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Additional Disk Space (With Configurable Storage, Units And Size)
+
|style="padding: 0px 0px 0px 45px;"|✔ Download Backup Files
 
|}
 
|}
 
{|
 
{|
Line 617: Line 638:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Private Network
+
|style="padding: 0px 0px 0px 45px;"|✔ Limit Of CPU
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Backups Size Limit
+
|style="padding: 0px 0px 0px 45px;"|✔ Managed View
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Backups Files Limit
+
|style="padding: 0px 0px 0px 45px;"|✔ Network Rate
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Snapshots Limit
+
|style="padding: 0px 0px 0px 45px;"|✔ Archive
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Snapshot Jobs
+
|style="padding: 0px 0px 0px 45px;"|✔ Network Rate
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Bandwidth Limit
+
|style="padding: 0px 0px 0px 45px;"|✔ Private Network
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ VM Template
+
|style="padding: 0px 0px 0px 45px;"|✔ Protected Backup Files
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Archive
+
|style="padding: 0px 0px 0px 45px;"|✔ Restore Backup Files
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Network Rate
+
|style="padding: 0px 0px 0px 45px;"|✔ Server Monitoring
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Tag
+
|style="padding: 0px 0px 0px 45px;"|✔ Snapshot Jobs
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 45px;"|✔ Snapshots
 
|}
 
|}
 
{|
 
{|
Line 650: Line 674:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 10px 45px;"|✔ Server Monitoring
+
|style="padding: 0px 0px 10px 45px;"|✔ Tag
 
|}
 
|}
 
{|
 
{|
Line 656: Line 680:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ CPU Limit
+
|style="padding: 0px 0px 0px 45px;"|✔ Additional Disk Space
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ CPU Units Limit
+
|style="padding: 0px 0px 0px 45px;"|✔ Backup Files Limit
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Memory
+
|style="padding: 0px 0px 0px 45px;"|✔ Backups Size
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ SWAP
+
|style="padding: 0px 0px 0px 45px;"|✔ Bandwidth
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Storage
+
|style="padding: 0px 0px 0px 45px;"|✔ CPU Limit
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Disk Space
+
|style="padding: 0px 0px 0px 45px;"|✔ CPU Units Limit
 
|}
 
|}
 
{|
 
{|
Line 683: Line 707:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Private Network
+
|style="padding: 0px 0px 0px 45px;"|✔ Memory
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Backups Size
+
|style="padding: 0px 0px 0px 45px;"|✔ Network Rate
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Backups Files Limit
+
|style="padding: 0px 0px 0px 45px;"|✔ SWAP
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Snapshots
+
|style="padding: 0px 0px 0px 45px;"|✔ Snapshot jobs
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Bandwidth
+
|style="padding: 0px 0px 0px 45px;"|✔ Snapshots
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Network Rate
+
|style="padding: 0px 0px 0px 45px;"|✔ Storage
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Archive
+
|style="padding: 0px 0px 0px 45px;"|✔ Storage Disk Space
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Network Rate
+
|style="padding: 0px 0px 0px 45px;"|✔ VCPUs
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Virtual Networks
+
|style="padding: 0px 0px 10px 45px;"|✔ Virtual Networks
|}
+
{|
+
|style="padding: 0px 0px 0px 45px;"|✔ Snapshot Jobs
+
|}
+
{|
+
|style="padding: 0px 0px 10px 45px;"|✔ Storage Disk Space
+
 
|}
 
|}
  
Line 721: Line 739:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Supports PVE And PAM Authentication
+
|style="padding: 0px 0px 0px 30px;"|✔ Supports PVE, PAM And API Token Authentication
 
|}
 
|}
 
{|
 
{|
Line 733: Line 751:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Integrated With [https://www.modulesgarden.com/products/whmcs/ip-manager IP Manager For WHMCS] - Complete Control And Easy Assignment Of IP Subnets (LXC)
+
|style="padding: 0px 0px 0px 30px;"|✔ Integrated With [https://www.modulesgarden.com/products/whmcs/ip-manager IP Manager For WHMCS] - Complete Control And Easy Assignment Of IP Subnets (LXC) ''(temporarily unavailable)''
|}
+
{|
+
|style="padding: 0px 0px 0px 30px;"|✔ Integrated With [https://www.modulesgarden.com/products/whmcs/products-reseller Products Reseller For WHMCS] - End-To-End Solution For Products And Servers Reselling
+
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Integrated With [https://www.modulesgarden.com/products/whmcs/proxmox-ve-cloud-vps Proxmox VE Cloud VPS For WHMCS] - Multiple Servers Provisioning And Management Within Set Resource Limits
+
|style="padding: 0px 0px 0px 30px;"|✔ Integrated With [https://www.modulesgarden.com/products/whmcs/products-reseller Products Reseller For WHMCS] - End-To-End Solution For Products And Servers Reselling ''(temporarily unavailable)''
 
|}
 
|}
 
{|
 
{|
Line 754: Line 769:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Supports Proxmox VE 8.X
+
|style="padding: 0px 0px 0px 30px;"|✔ Supports Proxmox VE 8.X And 9.X
 
|}
 
|}
 
{|
 
{|
Line 760: Line 775:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Supports PHP 8.2 Back To PHP 8.1
+
|style="padding: 0px 0px 0px 30px;"|✔ Supports PHP 8.3 Back To PHP 8.1
 
|}
 
|}
 
{|
 
{|
Line 766: Line 781:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Supports WHMCS V8.12 Back To WHMCS V8.9
+
|style="padding: 0px 0px 0px 30px;"|✔ Supports WHMCS V8.13 Back To WHMCS V8.10
 
|}
 
|}
 
{|
 
{|
Line 780: Line 795:
 
We will guide you step by step through the whole installation and configuration process.
 
We will guide you step by step through the whole installation and configuration process.
 
|}
 
|}
 
<h4 style="color: orange; font-weight:bold; text-align:center;">
 
Important update: This product has undergone several changes, including a name change and relocation of the license file to the addon.<br/>
 
You will need to reissue your license for the changes to take effect.<br/>
 
We apologize for any inconvenience and appreciate your understanding.
 
</h4>
 
  
 
==Installation==
 
==Installation==
Line 814: Line 823:
 
|style="padding: 0px 0px 15px 15px;"|
 
|style="padding: 0px 0px 15px 15px;"|
 
'''''Note 1:''' If the version of the Proxmox server you are using is not available, choose the package with the '''highest version number that is lower than the one you are currently using.'''''  <br/> '''''Note 2:''' If you wish to allow noVNC consoles, you need to configure a product using the PVE realm and set user permissions to 'PVEVMUser.' '''''<br/>
 
'''''Note 1:''' If the version of the Proxmox server you are using is not available, choose the package with the '''highest version number that is lower than the one you are currently using.'''''  <br/> '''''Note 2:''' If you wish to allow noVNC consoles, you need to configure a product using the PVE realm and set user permissions to 'PVEVMUser.' '''''<br/>
'''''Important:''' Open Folder UploadOnProxmoxServer/5.2-10 and upload content on all your proxmox servers. Scripts must be updated on proxmox server v2.6.0 to allow Xterm.js console work.''
+
'''''Important:''' Open folder UploadOnProxmoxServer/5.2-10 and upload content on all your proxmox servers. Scripts must be updated on proxmox server v2.6.0 to allow Xterm.js console work.''
 
|}
 
|}
 
{|
 
{|
Line 826: Line 835:
 
|style="padding: 0px 0px 15px 15px;"|'''5. In order to configure your license key, you have to edit the previously renamed '' 'license.php' '' file.'''<br />
 
|style="padding: 0px 0px 15px 15px;"|'''5. In order to configure your license key, you have to edit the previously renamed '' 'license.php' '' file.'''<br />
 
Enter your license key between the quotation marks as presented on the following screen.<br />
 
Enter your license key between the quotation marks as presented on the following screen.<br />
You can find your license key in our client area → '' 'My Products'. ''
+
You can find your license key in our client area → '' 'My Products'. ''<br/>
 +
'''''Important:''' If you have migrated from Proxmox VE VPS or Proxmox VE Cloud VPS, please ensure that your license file is updated, as the module name has changed.''
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PVC_2_4.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PVC4_2_4.png]]
 
|}
 
|}
 
{|
 
{|
Line 876: Line 886:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|'''10. Next, enter your server name and IP address, you may add any port in the following format: '' "IpAddress:Port" '', that is: ''10.10.10.1:8006'''''.<br />
+
|style="padding: 0px 0px 15px 15px;"|'''10. Next, enter your server name and IP address. You may add any port in the following format: '' "IpAddress:Port" '', that is: ''10.10.10.1:8006'''''.<br />
Enter the and password, choose the authentication type from '' 'Authentication' '' and '' 'Proxmox VE VPS & Cloud' '' from the '' 'Type' '' dropdown menus. Save changes afterward.<br/>
+
Enter the username and password, and choose the authentication type from '' 'Authentication' '' and '' 'Proxmox VE VPS & Cloud' '' from the '' 'Type' '' dropdown menus. Save changes afterward.<br/>
  
'''''Important:''' If you have problems with connection, make sure the WHMCS server can correctly connect to Proxmox. For more details refer to this article [https://pve.proxmox.com/wiki/Proxmox_VE_API#Example:_Get_a_New_Ticket_and_the_CSRF_Prevention_Token|article].''
+
'''Supported authentication methods:'''
 +
* Linux PAM standard authentication
 +
* Proxmox VE authentication server
 +
* API Tokens<br />
 +
 
 +
In the case of '''API Tokens''', after generating a token in the Proxmox panel, you will receive two values: '''Token ID''' and '''Secret'''.<br />
 +
Use the '''Token ID''' as the '''Username''' and the '''Secret''' as the '''Password'''.<br />
 +
 
 +
'''''Important:''' For proper module functionality, use API tokens with full access permissions. Limited scopes may block some API requests required by the module.''
 +
 
 +
'''''Note:''' When using API Tokens, the module cannot change user passwords. This limitation comes from the Proxmox API itself, and while it has minimal impact on functionality, it is worth being aware of.''
 +
 
 +
'''''Important:''' If you encounter connection issues, ensure the WHMCS server can reach your Proxmox host. For more information, refer to this [https://pve.proxmox.com/wiki/Proxmox_VE_API#Example:_Get_a_New_Ticket_and_the_CSRF_Prevention_Token article].''
 
|}
 
|}
 
{|
 
{|
Line 895: Line 917:
 
{|
 
{|
 
|style="padding: 0px 0px 30px 25px;"|[[File:PVC2_10.png]]
 
|style="padding: 0px 0px 30px 25px;"|[[File:PVC2_10.png]]
 +
|}
 +
 +
===Using Proxmox Clusters===
 +
{|
 +
|style="padding: 10px 0px 10px 15px;"|When configuring the connection between Proxmox and WHMCS with the module, and especially when using a Proxmox '''Cluster''' with multiple nodes, there are two recommended approaches to adding servers.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 10px 15px;"|'''Option 1: One WHMCS server entry for the entire cluster.'''
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 15px;"|In this configuration, you create a '''single server in WHMCS''' that connects to one node of the Proxmox cluster.
 +
 +
*'''Advantages:'''
 +
** Full support for the module’s '''[[#Load_Balancer|Load Balancer]]''' feature - the system can select the optimal node automatically.
 +
** Centralized API communication.
 +
** Simpler configuration and product assignment.
 +
 +
*'''Disadvantages:'''
 +
** If the selected node becomes unavailable (due to downtime or upgrade), '''all module operations will fail''', even if the remaining nodes are still functional.
 +
** WHMCS cannot switch to a different node on its own.<br/>
 +
 +
'''''Note:''' Use the '''load balancer''' in front of your Proxmox cluster. Then, enter the proxy IP address as the server IP in WHMCS. <br/>This way, WHMCS always connects to an active node in the cluster. You should also provide the IP addresses of individual nodes under the "Assigned IPs" field in the server configuration.''
 +
|}
 +
{|
 +
|style="padding: 0px 0px 10px 15px;"|'''Option 2: One WHMCS server per cluster node'''
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 15px;"|With this method, each node is added to WHMCS as a separate server. Products are then assigned directly to specific nodes.
 +
 +
*'''Advantages:'''
 +
** Better '''fault isolation''': if a node fails, only products on that node are affected.
 +
** More control for setups where nodes have specific templates or storage access.
 +
 +
*'''Disadvantages:'''
 +
** '''Load Balancer functionality is unavailable''' - the module cannot dynamically select the optimal node.
 +
** Product setup may be limited if a template or storage is not available on the assigned node.
 +
 +
'''''Note:'''  If you are using Cloud-Init scripts or App Templates, be sure that the appropriate storage is accessible on the node the product is assigned to. Otherwise, provisioning may fail.''<br/>
 +
<br/>
 +
Choose the setup that best matches your infrastructure, storage model, and reliability goals.
 
|}
 
|}
  
Line 939: Line 1,001:
 
** '''KVM''' - short form for Kernel-based virtual machines; used for Qemu (Quick Emulator), which is an open source hypervisor that emulates a physical computer
 
** '''KVM''' - short form for Kernel-based virtual machines; used for Qemu (Quick Emulator), which is an open source hypervisor that emulates a physical computer
 
** '''LXC''' - used for Linux Container as a lightweight alternative to fully virtualized virtual machines
 
** '''LXC''' - used for Linux Container as a lightweight alternative to fully virtualized virtual machines
* '''Default Node''' - choose the default node from the dropdown menu. <br/ > '''''Note:''' If you choose the '''Auto-Node''' as your 'Default Node', new virtual servers will be created on the least used node.''<br/ >'''''Note 2:''' An advanced tool is available for you to automatically manage the node selection with the best amount of resources. Read more about [[#Load Balancer|Load Balancer]].'' <br/> Remember that changing the node will always result in the replacement of the current configuration with the default one. Upon selecting the node, the current configuration should be saved automatically.<br/> If, for any reason, this does not happen, please press '' 'Save Changes'.''<br />
+
* '''Default Node''' - choose the default node from the dropdown menu. <br/ > If you choose the '''Auto-Node''' as your 'Default Node', new virtual servers will be created on the least used node.<br/ > An advanced tool is available for you to automatically manage the node selection with the best amount of resources. Read more about [[#Load Balancer|Load Balancer]]. <br/>'''Server-Node''' option assigns the VM to the specific Proxmox node configured in the WHMCS server settings ''(based on the server IP address).'' This means the VM will always be created on that particular node.<br/>'''''Note:''' <br/> Remember that changing the node will always result in the replacement of the current configuration with the default one. Upon selecting the node, the current configuration should be saved automatically.<br/> If, for any reason, this does not happen, please press '' 'Save Changes'.''<br />
  
 
* '''Check Available Resources''' - Enable if you want the available resources to be checked before creating a new machine.
 
* '''Check Available Resources''' - Enable if you want the available resources to be checked before creating a new machine.
Line 962: Line 1,024:
 
Start your product configuration in the '' 'Virtual Machine Configuration' '' panel, where you can set up machine resources and limits or assigned IP addresses. <br/> Note that some fields can be left empty if you want to disable them or set as unlimited - read the tooltips for further guidance. <br/>
 
Start your product configuration in the '' 'Virtual Machine Configuration' '' panel, where you can set up machine resources and limits or assigned IP addresses. <br/> Note that some fields can be left empty if you want to disable them or set as unlimited - read the tooltips for further guidance. <br/>
  
'''App Templates Configuration''' - To create your VM based on a template, archive, or ISO image, you must first configure the App Templates in the module's addon. <br/> Once your applications and groups are set up there, you can select the desired template or archive in the product's Module Settings tab to be used during VM creation. <br/ >Please refer to the [[#App_Templates|App Templates section]] of the documentation for detailed setup instructions.
+
'''App Templates Configuration''' - To create your VM based on a template, archive, or ISO image, '''you must first configure the App Templates in the module's addon'''. <br/> Once your applications and groups are set up there, you can select the desired template or archive in the product's Module Settings tab to be used during VM creation. <br/ >'''Please refer to the [[#App_Templates|App Templates section]] of the documentation for detailed setup instructions.'''
 
|}
 
|}
 
{|
 
{|
Line 1,011: Line 1,073:
  
 
As you can see, there are more options available. Look through them and decide which ones you want to modify and adjust to your and your clients' needs. <br/>
 
As you can see, there are more options available. Look through them and decide which ones you want to modify and adjust to your and your clients' needs. <br/>
Do not forget about the '' 'Network' '' section where you can determine a model, bridge, and rate limits of the network.<br />
+
Do not forget about the '''Network''' section where you can determine a model, bridge, and rate limits of the network.<br />
If you are going to allow your clients to manage their private networks, you have to select '' 'Private Bridge' '' and set up VLAN TAG Range.<br/>
+
If you are going to allow your clients to manage their private networks, you have to select '''Private Bridge''' and set up VLAN TAG Range.<br/>
 +
 
 +
The '''Disk Space''' [GiB] field (and its corresponding configurable option) defines the total storage limit for all disks combined in a Cloud service.<br/>
 +
By default, this limit applies to both the main disk and any additional disks.<br/> Once separate configurable options for extra disks are created, the main "Disk Space" setting applies only to the primary disk, while each additional disk is governed by its own limit.
  
 
Once you make sure that the configuration is completed, click '' 'Save Changes'. ''<br/>
 
Once you make sure that the configuration is completed, click '' 'Save Changes'. ''<br/>
Line 1,028: Line 1,093:
 
===Cloud - LXC Virtualization Type===
 
===Cloud - LXC Virtualization Type===
 
{|
 
{|
|style="padding: 10px 0px 15px 15px;"|'''Settings of the LXC virtualization type of the CLoud-type product.'''<br/>
+
|style="padding: 10px 0px 15px 15px;"|'''Settings of the LXC virtualization type of the Cloud-type product.'''<br/>
 
Firstly, complete the '' 'General' '' configuration and then proceed to the '' 'Main Configuration' '', '' 'LXC Configuration' '' and '' 'Network' '' sections.<br />
 
Firstly, complete the '' 'General' '' configuration and then proceed to the '' 'Main Configuration' '', '' 'LXC Configuration' '' and '' 'Network' '' sections.<br />
  
Line 1,055: Line 1,120:
 
===Finalizing The Configuration===
 
===Finalizing The Configuration===
 
{|
 
{|
|style="padding: 10px 0px 15px 15px;"|'''21. Private Network Management - in order to allow clients to manage their private networks, set up the '' 'Network' '' and '' 'Private Network' '' sections properly.<br/>
+
|style="padding: 10px 0px 15px 15px;"|'''21. 'Hostname Generation' section allows you to configure automatic hostname creation for new virtual machines using a flexible pattern format.'''
 +
 
 +
* '''Hostname Format''' - Define the pattern used to generate hostnames automatically. You can use the following variables:
 +
** <code>{whmcsMainDomain}</code> - the main domain set in WHMCS settings
 +
** <code>{clientId}</code> - the ID of the client who owns the service
 +
** <code>{serviceId}</code> -  the unique WHMCS service ID
 +
** <code>{orderId}</code> - the ID of the order tied to the service
 +
** <code>{rand}</code> - a randomly generated string (controlled below)
 +
** <code>{nextIncrementalValue}</code> -  a numeric value that increases with each generated hostname<br/> '''Example:''' <br/> <code>client-{$clientId}-service-{$serviceId}-{$rand}</code> could generate: <code>client-104-service-312-x9h7kb</code>
 +
 
 +
* '''Next Incremental Value''' - This value is used in the <code>{nextIncrementalValue}</code> variable and automatically increases each time a hostname is generated. <br/> '''Example usage:'''<br/> <code>vm-{nextIncrementalValue}</code> → ''vm-101'', ''vm-102'', etc.
 +
 
 +
* '''Random Character Set''' - Defines the pool of characters used when generating the {rand} value. Leave the field empty to use the default set: <code>abcdefghijklmnopqrstuvwxyz0123456789</code>
 +
 
 +
* '''Random Value Length''' - Sets how many characters will be included in the <code>{rand}</code> value. Leave empty or set to 0 to use the default length.<br/> '''Example:''' <br/>If length is set to '''6''' and format is <code>vm-{rand}</code>, output might be <code>vm-f39b7a</code>.
 +
 
 +
* '''Override Domain''' - Enable this option to force the system to generate a hostname using the defined pattern, even when a domain name has already been set for the service.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PVC_3_0.png]]
 +
|}
 +
{|
 +
|style="padding: 10px 0px 15px 15px;"|'''22. Private Network Management - in order to allow clients to manage their private networks, set up the '' 'Network' '' and '' 'Private Network' '' sections properly.<br/>
 
*Define '' 'Private Network Model' ''
 
*Define '' 'Private Network Model' ''
 
*Select '' 'Bridge' '' as well as '' 'Private Bridge' '' from the dropdown menus.  
 
*Select '' 'Bridge' '' as well as '' 'Private Bridge' '' from the dropdown menus.  
Line 1,068: Line 1,155:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|'''22. The next step is setting up the configuration of backups.'''<br />
+
|style="padding: 0px 0px 15px 15px;"|'''23. The next step is setting up the configuration of backups.'''<br />
 
Define backup settings in the '' 'Backup' '' section through defining'' 'Storage' '' and enabling '' 'Backups Routing' ''.<br />
 
Define backup settings in the '' 'Backup' '' section through defining'' 'Storage' '' and enabling '' 'Backups Routing' ''.<br />
 
Backups routing automatically removes the oldest backup when a new backup is created and the established backup limit is reached.<br />
 
Backups routing automatically removes the oldest backup when a new backup is created and the established backup limit is reached.<br />
Line 1,079: Line 1,166:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 15px;"|'''23. Set up server limits to control the size of created servers (Cloud-type products).'''
+
|style="padding: 0px 0px 20px 15px;"|'''24. Set up server limits to control the size of created servers (Cloud-type products).'''
 
|}
 
|}
 
{|
 
{|
Line 1,085: Line 1,172:
 
|}
 
|}
 
{|
 
{|
|style="padding: 10px 0px 15px 15px;"|'''24. Afterward, you can create configurable options. '''<br/>
+
|style="padding: 10px 0px 15px 15px;"|'''25. Afterward, you can create configurable options. '''<br/>
This step is <u>optional</u> - if you want to take it, start by selecting which of the configurable options listed in [[#List of Configurable Options|this table]] you want to generate.<br/>
+
This step is <u>optional</u> - if you want to take it, start by selecting which of the configurable options you want to generate.<br/>
  
 
'' '''Note:''' It is advisable not to generate options that you do not plan to use, or in case you want their fixed values to be taken from the module settings, rather than being flexible.<br/> Moreover, the configurable options differ between the KVM and LXC virtualization types, so create them separately if needed.''
 
'' '''Note:''' It is advisable not to generate options that you do not plan to use, or in case you want their fixed values to be taken from the module settings, rather than being flexible.<br/> Moreover, the configurable options differ between the KVM and LXC virtualization types, so create them separately if needed.''
Line 1,092: Line 1,179:
 
'''''Note 2:''' There is also an '''Alternative Mode''' available '''(VPS product type only)''', which changes the way the configurable options values are verified and calculated. <br/> Select single configurable options and their values will be summed with the default product configuration values instead of overwriting them.''
 
'''''Note 2:''' There is also an '''Alternative Mode''' available '''(VPS product type only)''', which changes the way the configurable options values are verified and calculated. <br/> Select single configurable options and their values will be summed with the default product configuration values instead of overwriting them.''
  
More information about configurable options and their edition can be found [https://docs.whmcs.com/Addons_and_Configurable_Options here].<br/> A clear division of configurable opinions available per product and virtualization type, please see the comparison [[#List_of_Configurable_Options|table]].
+
More information about configurable options and their edition can be found [https://docs.whmcs.com/Addons_and_Configurable_Options here].<br/> A clear division of configurable opinions available per product and virtualization type, please see the module [[#About_Proxmox_VE_VPS_.26_Cloud_For_WHMCS|features list]].
 
|}
 
|}
 
{|
 
{|
 
|style="padding: 0px 0px 20px 25px;"|[[File:PVC_3_4.png]]
 
|style="padding: 0px 0px 20px 25px;"|[[File:PVC_3_4.png]]
 
|}
 
|}
{|
 
 
{|
 
{|
 
|style="padding: 0px 0px 20px 25px;"|[[File:PVC_3_5.png]]
 
|style="padding: 0px 0px 20px 25px;"|[[File:PVC_3_5.png]]
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|'''25. At the end of the product configuration, you have to add a cron job as shown below (5-minute intervals are recommended).
+
|style="padding: 0px 0px 15px 15px;"|'''26. At the end of the product configuration, you have to add a cron job as shown below (5-minute intervals are recommended).
 
  php -q /your_whmcs/modules/addons/ProxmoxVeVpsCloud/cron/cron.php queue
 
  php -q /your_whmcs/modules/addons/ProxmoxVeVpsCloud/cron/cron.php queue
 
Do not forget to replace '' 'your_whmcs' '' with your WHMCS root location. The cron can be also executed every single minute in order to perform the action more often.<br/>
 
Do not forget to replace '' 'your_whmcs' '' with your WHMCS root location. The cron can be also executed every single minute in order to perform the action more often.<br/>
Line 1,116: Line 1,202:
 
==Configuration of Addon==
 
==Configuration of Addon==
 
{|
 
{|
|style="padding: 10px 0px 15px 15px;"|'''26. Proceed to '''Addons''' → '''Proxmox VE VPS & Cloud''' → '''Settings''' → '''General Settings''' and set up the listed cron job.<br/>
+
|style="padding: 10px 0px 15px 15px;"|'''27. Proceed to 'Addons' → 'Proxmox VE VPS & Cloud' → 'Settings' → 'General Settings' and set up the listed cron job.<br/>
 
The addon offers a convenient tool called '''Cron Scheduler''' that allows you to automate recurring jobs.<br/> Configure the execution frequency for each regularly run cron job, then activate the main schedule job, it will handle the regular execution of all defined tasks.<br/>
 
The addon offers a convenient tool called '''Cron Scheduler''' that allows you to automate recurring jobs.<br/> Configure the execution frequency for each regularly run cron job, then activate the main schedule job, it will handle the regular execution of all defined tasks.<br/>
 
For details, please refer to the [[#Cron_Scheduler|Cron Scheduler]] section of this documentation.
 
For details, please refer to the [[#Cron_Scheduler|Cron Scheduler]] section of this documentation.
Line 1,134: Line 1,220:
 
* VMs migration synchronization ''(every 5 minutes suggested)''
 
* VMs migration synchronization ''(every 5 minutes suggested)''
 
  php -q /your_WHMCS/modules/addons/ProxmoxVeVpsCloud/cron/cron.php migrateSync
 
  php -q /your_WHMCS/modules/addons/ProxmoxVeVpsCloud/cron/cron.php migrateSync
 +
 +
* Module migration from version 3 to version 4
 +
php -q /your_WHMCS/modules/addons/ProxmoxVeVpsCloud/cron/cron.php migration:v3_v4
  
 
* VMs power tasks ''(every 5 minutes suggested)''
 
* VMs power tasks ''(every 5 minutes suggested)''
Line 1,169: Line 1,258:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|'''27. Next, find the '' 'Minimum VMID' '' field under the 'Cron' settings.'''<br/> Fill it in with a number that will be used as an ID of the first VM, the second VM will be assigned the next ID number.<br/> Define the limit of tasks that will be executed with a single cron run, just type in the required number into the '' 'Tasks Limit' '' field.<br/>
+
|style="padding: 0px 0px 15px 15px;"|'''28. Fill in the General Settings configuration:'''
Here, you may also turn on the '' 'Debug Mode' '' if you need to register module logs.
+
*'''Minimum VM ID''' - Fill it in with a number that will be used as an ID of the first VM, the second VM will be assigned the next ID number.<br/>  
 +
*'''VM ID Assignment Mode''' - Select how the VM ID should be assigned:
 +
** '''First Available ID''' -  uses any currently free ID, including previously used, this option is selected by default.
 +
** '''Auto-Incrementing ID''' - assigns the next unused number until the limit is reached.<br/>
 +
*'''Tasks Limit''' - Define the limit of tasks that will be executed with a single cron run, just type in the required number into the field.
 +
*Turn on the '' 'Debug Mode' '' if you need to register module logs.
 
|}
 
|}
 
{|
 
{|
Line 1,176: Line 1,270:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|'''28. Adding a new IP address.<!-- (applicable only if you do not use [https://www.modulesgarden.com/products/whmcs/ip-manager#features IP Manager For WHMCS]).-->'''<br />
+
|style="padding: 0px 0px 15px 15px;"|'''29. Adding a new IP address.<!-- (applicable only if you do not use [https://www.modulesgarden.com/products/whmcs/ip-manager#features IP Manager For WHMCS]).-->'''<br />
 
In order to create a new product with an IP address assigned, you have to add '' 'Dedicated IP'' ' to the '' 'IP Addresses' '' list in '' 'Proxmox VE VPS & Cloud' '' addon module.<br />
 
In order to create a new product with an IP address assigned, you have to add '' 'Dedicated IP'' ' to the '' 'IP Addresses' '' list in '' 'Proxmox VE VPS & Cloud' '' addon module.<br />
 
To do so, go to '' 'IP Management' '' and press '' 'New IP Addresses'. ''<br />
 
To do so, go to '' 'IP Management' '' and press '' 'New IP Addresses'. ''<br />
Line 1,185: Line 1,279:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|'''29. Start with defining the IP address type, choose among: '' 'IPv4', IPv6' '' and '' 'IPv6 subnet'.'' '''<br/>
+
|style="padding: 0px 0px 15px 15px;"|'''30. Start with defining the IP address type, choose among: '' 'IPv4', IPv6' '' and '' 'IPv6 subnet'.'' '''<br/>
 
Then, depending on the selected type, provide:<br/>
 
Then, depending on the selected type, provide:<br/>
 
'''For IPv4 and IPv6 addresses types'''
 
'''For IPv4 and IPv6 addresses types'''
Line 1,217: Line 1,311:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|'''30. You are now able to create a new product using the previously added IP address.'''<br />
+
|style="padding: 0px 0px 15px 15px;"|'''31. You are now able to create a new product using the previously added IP address.'''<br />
 
If you are using the KVM virtualization type, the client area with a successfully created product should look similar to the one on the screen below.<br/>
 
If you are using the KVM virtualization type, the client area with a successfully created product should look similar to the one on the screen below.<br/>
 
The assigned IP addresses should be displayed on the bottom panel according to the way you configured the IP pools. It looks quite similar in the case of the LXC virtualization type product.
 
The assigned IP addresses should be displayed on the bottom panel according to the way you configured the IP pools. It looks quite similar in the case of the LXC virtualization type product.
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 30px 25px;"|[[File:PX3_24.png]]
+
|style="padding: 0px 0px 30px 25px;"|[[File:PX4_24.png]]
 
|}
 
|}
  
Line 1,300: Line 1,394:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|'''12. Configure all the required data in the Proxomox addon in your WHMCS.'''<br/>
+
|style="padding: 0px 0px 15px 15px;"|'''12. Configure the required proxy settings in the Proxmox addon in your WHMCS.'''<br/>
Move to '' 'Addons' 'Proxmox Addon' 'Settings'.'' At the bottom you will find section '' 'Console Proxy' '' with '' 'Host' '' and '' 'API Key' '' fields.<br/>
+
Go to: ''Addons → Proxmox VE VPS & Cloud Addon → Tools → Console Proxy.''<br/>
Note that the '''Host''' field may include either an '''IP address''' or a '''domain'''. It is extremely important that you paste here '''the same data as the ones used in the SSL certificate'''. <br/>The below screen shows an example with an IP address which is not the only correct possible option here.<br/>
+
Create a proxy connection by entering:
 
+
* '''Name''' - any custom label for identification.
Provide the necessary data and confirm the changes.
+
* '''Host''' - full URI of the proxy, including protocol and port. This must match the proxy access details.
 +
* '''API Key''' - the API key generated during installation (see point 10).
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PX4_4_2.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|Next, go to: ''Addons → Proxmox VE VPS & Cloud Addon → Settings → General Settings.''<br/>
 +
At the bottom, locate the ''Console Proxy'' section and select the desired connection from the ''Proxmox Proxy'' dropdown - includes all connections added in step above.<br/> This selection works globally unless a separate proxy is selected per single node.  
 
|}
 
|}
 
{|
 
{|
 
|style="padding: 0px 0px 20px 25px;"|[[File:PX3_4_2.png]]
 
|style="padding: 0px 0px 20px 25px;"|[[File:PX3_4_2.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|You can also assign a separate proxy to each node individually.<br/> To do this, open the server details → ''Cluster'' tab → ''Node Details'' → ''Other'' tab and assign a proxy there in the ''Proxmox Proxy'' dropdown. <br/>
 +
If no proxy is set at the node level, the one selected in General Settings will be used by default.<br/><br/>
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PX4_4_3.png]]
 
|}
 
|}
 
{|
 
{|
Line 1,336: Line 1,445:
 
{|
 
{|
 
|style="padding: 10px 0px 15px 15px;"|If you are having trouble setting up DNS servers using Cloud-Init, this guide will help you resolve this issue quickly.<br/>
 
|style="padding: 10px 0px 15px 15px;"|If you are having trouble setting up DNS servers using Cloud-Init, this guide will help you resolve this issue quickly.<br/>
'''1. Enable the "Service Nameservers" option in your product configuration.'''<br/>
+
'''1. Enable the "Service Nameservers" option in your product configuration ''(Module Settings → Cloud-Init → Service Nameservers)''.'''<br/>
 
This option ensures that the IP addresses entered in the Nameserver fields in the service are correctly applied in Cloud-Init.
 
This option ensures that the IP addresses entered in the Nameserver fields in the service are correctly applied in Cloud-Init.
 
|}
 
|}
Line 1,352: Line 1,461:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|'''2. Use the "Use Server Nameservers" option.'''
+
|style="padding: 0px 0px 15px 15px;"|'''2. Use the "Use Server Nameservers" option ''(Module Settings → Miscellaneous → Use Server Nameservers)''.'''
 
This feature automatically populates the Nameserver fields with values from your server configuration. Only the first two fields from the server will be used.
 
This feature automatically populates the Nameserver fields with values from your server configuration. Only the first two fields from the server will be used.
 
|}
 
|}
Line 1,387: Line 1,496:
 
=Management=
 
=Management=
 
{|
 
{|
|style="padding: 10px 0px 30px 15px;"|''' Proxmox VPS allows your customers to manage their PVE accounts via the client area in your WHMCS system.'''<br />
+
|style="padding: 10px 0px 30px 15px;"|''' Proxmox VE VPS & Cloud allows your customers to manage their PVE accounts via the client area in your WHMCS system.'''<br />
 
At the same time, you can monitor and manage each product from your WHMCS admin area.
 
At the same time, you can monitor and manage each product from your WHMCS admin area.
 
|}
 
|}
Line 1,394: Line 1,503:
 
====Server List====
 
====Server List====
 
{|
 
{|
|style="padding: 10px 0px 15px 15px;"|In '' 'Addons' '' → '' 'Proxmox Addon' '' → '' 'Servers' '' → '' 'Servers List' '' you can find the configured Proxmox servers.<br />
+
|style="padding: 10px 0px 15px 15px;"|In '' 'Addons' '' → '' 'Proxmox VE VPS & Cloud' '' → '' 'Servers' '' → '' 'Server List' '' you can find the configured Proxmox servers.<br />
 
'''RAM''' details:
 
'''RAM''' details:
 
:Assigned - the RAM assigned to the server (hosting services only)
 
:Assigned - the RAM assigned to the server (hosting services only)
Line 1,438: Line 1,547:
 
* Maximum Disk Size - set the top storage size allowed on this node
 
* Maximum Disk Size - set the top storage size allowed on this node
 
* Maximum RAM Size - set the maximum amount of RAM allowed on this node
 
* Maximum RAM Size - set the maximum amount of RAM allowed on this node
* Default Storage - select the default storage for the VM created on this node<br/>
+
* Default Storage - select the default storage for the VM created on this node
 +
* Allowed Application Groups - If you select a group or more than one group here, the applications assigned to these groups will always create a VM on this node.<br/> Note that this option overrides the "Default Node" setting in Module Settings. You may leave this selection empty if you do not want to override the module settings configuration.<br/>
 
Setting node limits is crucial as creating virtual machines is largely based on them, once reached, a new virtual machine cannot be created on that node.
 
Setting node limits is crucial as creating virtual machines is largely based on them, once reached, a new virtual machine cannot be created on that node.
 
|}
 
|}
Line 1,451: Line 1,561:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 15px;"|Please bear in mind that limits placed in the above section overwrite the "Default Limit of Backup Tasks Per Node" value defined in the ''Addon → Settings → Backup Tasks Limitation'' [[#Global_Limitations|section]].  
+
|style="padding: 0px 0px 20px 15px;"|Please bear in mind that limits placed in the above section overwrite the "Default Limit of Backup Tasks Per Node" value defined in the ''Addon → Settings → General Settings → Backup Tasks Limitation'' [[#Global_Limitations|section]].  
 
|}
 
|}
 
{|
 
{|
Line 1,459: Line 1,569:
 
|style="padding: 0px 0px 15px 15px;"|In the last tab you may define the relation between the node and backup storage and their synchronization.
 
|style="padding: 0px 0px 15px 15px;"|In the last tab you may define the relation between the node and backup storage and their synchronization.
 
* '' 'Backup Search Storages' '' -  here you are allowed to define which storages will be searched through while running "backupSynch" cron job for backup creation and restoration purposes.<br/> This setting overwrites the product settings.
 
* '' 'Backup Search Storages' '' -  here you are allowed to define which storages will be searched through while running "backupSynch" cron job for backup creation and restoration purposes.<br/> This setting overwrites the product settings.
* '' 'Alternative Backup Storage' '' - if you run out of space on the storage, an alternative pointed here storage will be used to create and store the backup.<br/> You still can restore backup from the old storage, but only if that is selected in the above "Backup Search Storages" selection.
+
* '' 'Alternative Backup Storage' '' - if you run out of space on the storage, an alternative storage pointed here will be used to create and store the backup.<br/> You still can restore backup from the old storage, but only if that is selected in the above "Backup Search Storages" selection.
 +
* '' 'Proxmox Proxy' '' - it is possible to assign a console proxy connection to this very node ''(every virtual machine created on this node)'' only.<br/> If you leave this field empty, the default proxy connection defined in the ''Addon → Settings → General Settings'' will be used for this node.<br/> [[#Console_Proxy|Read more]] about console proxy connections.
 
|}
 
|}
 
{|
 
{|
Line 1,468: Line 1,579:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 30px 25px;"|[[File:PX4_30_2.png]]
+
|style="padding: 0px 0px 30px 25px;"|[[File:PVC4_30_2.png]]
 
|}
 
|}
  
Line 1,648: Line 1,759:
 
===App Templates===
 
===App Templates===
 
{|
 
{|
|style="padding: 10px 0px 30px 15px;"|'App Templates' allow you to manage and ultimately provide KVM and LXC templates, archives and ISO images to your clients.<br/>
+
|style="padding: 10px 0px 30px 15px;"|'App Templates' allow you to manage and ultimately '''provide KVM and LXC templates, archives and ISO images to your clients'''.<br/>
 
Prepare the templates in the '' 'Applications' '' tab and gather them into groups in the '' 'Groups' '' tab.<br/>
 
Prepare the templates in the '' 'Applications' '' tab and gather them into groups in the '' 'Groups' '' tab.<br/>
 
For clients to be able to install templates on their virtual machines, their product has to include an '' '[[#VPS_-_KVM_Virtualization_Type|Application Group]]' '' and allow '' '[[#Client_Area_Features|App Templates/Reinstallation]]' '' in the client area.
 
For clients to be able to install templates on their virtual machines, their product has to include an '' '[[#VPS_-_KVM_Virtualization_Type|Application Group]]' '' and allow '' '[[#Client_Area_Features|App Templates/Reinstallation]]' '' in the client area.
Line 1,704: Line 1,815:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|For the client to take advantage of the application templates, the product [[#VPS_-_KVM_Virtualization_Type|module settings]] must include a selected group.<br/>
+
|style="padding: 0px 0px 15px 15px;"|For the client to use application templates, you must assign at least one group in the product’s [[#VPS_-_KVM_Virtualization_Type|module settings]].<br/>
Find the '' 'App Templates Configuration' '' section and the '' 'Default Application Group' '' field. Assign the desired group to the product.<br/>
+
Navigate to the ''App Templates Configuration'' section and select the desired group(s) in the ''Default Application Group'' field.<br/>
'''''Note:''' The system will display templates from the group that contains the selected VM image. If the VM image cannot be found within the assigned group, the default group will be used.''
+
 
 +
'''''Note 1:''' You can now select '''multiple''' application groups. During virtual machine creation, the system will display templates from '''all assigned groups'''.''
 +
 
 +
'''''Note 2:''' When reinstalling the VM, only applications from the group that contains the currently used image will be available for selection.''
 
|}
 
|}
 
{|
 
{|
Line 1,808: Line 1,922:
 
{|
 
{|
 
|style="padding: 0px 0px 30px 25px;"|[[File:PVC_7_6.png]]
 
|style="padding: 0px 0px 30px 25px;"|[[File:PVC_7_6.png]]
 +
|}
 +
 +
=====Overriding Proxmox Configuration=====
 +
{|
 +
|style="padding: 10px 0px 30px 15px;"|You can override nearly any Proxmox VM configuration parameter directly through the application settings.<br/>
 +
To use this feature:
 +
* Create a new setting in your application.
 +
* Use the naming format: <code>proxmox_{parameterName}</code> ''(e.g., proxmox_memory, proxmox_ostype).''
 +
* Set its default value just like with other fields.
 +
 +
This setting will be sent to the Proxmox API during VM provisioning and override the equivalent value from the product configuration, if defined. '''Application settings always take precedence.'''<br/>
 +
 +
'''''Important:'''
 +
* You can use any configuration key supported by the [https://pve.proxmox.com/pve-docs/api-viewer/index.html#/nodes/{node}/qemu/{vmid}/config QEMU] or [https://pve.proxmox.com/pve-docs/api-viewer/index.html#/nodes/{node}/lxc/{vmid}/config LXC] Proxmox API.
 +
* Avoid using any parameters that represent '''arrays''' or device lists, i.e. keys that include square brackets or numeric suffixes like: '''net[n]''', '''ide[n]''', '''scsi[n]''', etc. <br/>These multi-entry device options should be managed through the module’s built-in product configuration fields (e.g., disk, network interfaces).
 +
* Avoid passing raw numeric-only keys, as they may not be handled consistently by the override logic.
 +
 +
Use this override system for single-value parameters like <code>memory</code>, <code>cores</code>, <code>ostype</code>, <code>onboot</code>, etc.
 +
|}
 +
 +
=====Setting High Availability (HA) Configuration=====
 +
{|
 +
|style="padding: 10px 0px 15px 15px;"|You can now define High Availability (HA) settings individually for each App Template.<br/>
 +
To do this, manually add the following settings in the template's '''Setting Details''' section. These settings override the corresponding values defined in the product’s main configuration:
 +
 +
'''Supported fields:'''
 +
* <code>ha.state</code> - Field type set to: "Text Area", with the following values accepted:
 +
** <code>started</code>
 +
** <code>stopped</code>
 +
** <code>enabled</code>
 +
** <code>disabled</code>
 +
** <code>ignored</code>
 +
 +
* <code>ha.max_relocate</code> - Field type set to: "Text Area", with numeric values accepted, e.g., <code>1</code>
 +
* <code>ha.max_restart</code> - Field type set to: "Text Area", with numeric values accepted, <code>2</code>
 +
* <code>ha.group</code> - Field type set to: "Text Area", with the name of an HA group created in Proxmox under ''Datacenter → HA → Groups '''(for Proxmox VE 8.x)''''' or
 +
* <code>ha.failback</code> - Field type set to: "Switcher", with default value to enable or disable the feature '' '''(for Proxmox VE 9.x)'''''
 +
 +
These fields must be added manually, as they are not created automatically.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PX2_30_03.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|Each setting will override the related configuration from the module settings. If a field is not defined in the App Template, the default product configuration will be used instead.<br/>
 +
'''Note:''' You do not have to define all fields; you can override just one or two (e.g., <code>ha.state</code> and <code>ha.group</code>), and the rest will fall back to the global product settings.
 +
 +
'''''Note 2:''' For '''Proxmox v9.x''' instead of "Groups", there is a "Failback" setting that, if enabled, forces HA resources to automatically adjust to HA rules. ''
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:PX2_30_3.png]]
 
|}
 
|}
  
Line 1,813: Line 1,978:
 
====Load Balancer====
 
====Load Balancer====
 
{|
 
{|
|style="padding: 10px 0px 15px 15px;"|Load Balancer is an advanced tool that allows smooth rotation between nodes so as to find the most preferable one, and create virtual machine on it.<br/>  
+
|style="padding: 10px 0px 15px 15px;"|Load Balancer is an advanced tool that allows smooth rotation between nodes so as to find the most preferable one, and create a virtual machine on it.<br/>  
Set the weight of the resource that will prioritize its selection when sorting the nodes according to the free resources.<br/>
+
The below-described features can be found in ''' ''Proxmox VE VPS & Cloud'' addon → ''Settings'' → ''General Settings'' → Load Balancer''.''' <br/>
 +
There, set the weight of the resource that will prioritize its selection when sorting the nodes according to the free resources.<br/>
 
'''''Note:''' The lowest possible weight is 1. You cannot set, e.g. 0.5.''<br/>
 
'''''Note:''' The lowest possible weight is 1. You cannot set, e.g. 0.5.''<br/>
  
Line 1,823: Line 1,989:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|In order to use the Load Balancer, you need to enable it in the product's configuration: <br/>
+
|style="padding: 0px 0px 15px 15px;"|In order to use the Load Balancer, you need to enable it in the product's configuration at: '''WHMCS → System settings → Your Product Details → Module Settings→ Load Balancer''' <br/>
 
Define the behavior of the tool:
 
Define the behavior of the tool:
*On Upgrade - select the action to perform:
+
*'''Action On Upgrade''' - select the action to perform:
 
** None - no action will be triggered
 
** None - no action will be triggered
 
** Block - the upgrade process will be blocked as there are insufficient resources on the node
 
** Block - the upgrade process will be blocked as there are insufficient resources on the node
Line 1,831: Line 1,997:
 
*Shutdown VM on Upgrade  
 
*Shutdown VM on Upgrade  
 
*Stop VM If Shutdown Fails  
 
*Stop VM If Shutdown Fails  
*Enable to allow migrating the VM with local disks
+
*Migration With Local Disk - Enable to allow migrating the VM with local disks
 
|}
 
|}
 
{|
 
{|
Line 1,841: Line 2,007:
 
Let's take exemplary weights for each resource just like the ones presented on the screen above.<br/>
 
Let's take exemplary weights for each resource just like the ones presented on the screen above.<br/>
  
  VMs Number Weight: 1,5<br/>
+
  VMs Number Weight: 1.5<br/>
 
  CPU Weight: 2 <br/>
 
  CPU Weight: 2 <br/>
  Disk Weight: 4<br/>
+
  Disk Weight: 4 <br/>
  RAM Weight: 2,5  
+
  RAM Weight: 2.5  
  
"Disk Weight" with the highest weight, which means it has the highest priority, and "VMs Number Weight" as the least crucial factor on a given node.<br/>
+
"Disk Weight" has the highest value, meaning disk space has the greatest impact on node selection. The "VMs Number Weight" is set lowest, making it the least influential factor in prioritization.<br/>
  
In this case, there are four nodes created, named A, B, C, and D, with current resources as shown below: <br/>
+
In this case, there are four nodes created, named A, B, C, and D, with current resource usage as shown below: <br/>
  
  Node A (Free Ram: 60%, Free CPU: 20%, Free Disk Space: 50%, Number of VMs: 5) <br/>
+
  Node A (Ram: 12, CPU: 2, Disk Space: 500, Number of VMs: 5) <br/>
  Node B (Free Ram: 30%, Free CPU: 70%, Free Disk Space: 40%, Number of VMs: 10) <br/>
+
  Node B (Ram: 6, CPU: 7, Disk Space: 400, Number of VMs: 10) <br/>
  Node C (Free Ram: 90%, Free CPU: 50%, Free Disk Space: 20%, Number of VMs: 20) <br/>
+
  Node C (Ram: 16, CPU: 5, Disk Space: 300, Number of VMs: 20) <br/>
  Node D (Free Ram: 80%, Free CPU: 60%, Free Disk Space: 70%, Number of VMs: 15)
+
  Node D (Ram: 20, CPU: 6, Disk Space: 700, Number of VMs: 15)
  
The next step is sorting the nodes according to each resource, it is done by assigning them corresponding priorities from 1 to 4. <br/>The higher the priority, the more free resources available.<br/>
+
'''Note:''' The Load Balancer evaluates raw resource values and selects the node with the lowest actual resource usage based on configuration rules.<br/>
 +
 
 +
The following table ranks each node per resource from 4 (lowest resource usage / highest priority) to 1 (highest resource usage / lowest priority). Higher scores are preferred during node selection.
 
|}
 
|}
 
{| class="wikitable" style="margin-left: 20px; margin-right: auto;"
 
{| class="wikitable" style="margin-left: 20px; margin-right: auto;"
 
! Priority
 
! Priority
! Free Ram
+
! Ram
! Free CPU
+
! CPU
! Free Disk Space
+
! Disk Space
 
! Number of VMs
 
! Number of VMs
 
|-
 
|-
| 4
+
| 4 (best)
| Node C
+
 
| Node B
 
| Node B
| Node D
+
| Node A
 +
| Node C
 
| Node A
 
| Node A
 
|-
 
|-
 
| 3
 
| 3
| Node D
 
| Node D
 
 
| Node A
 
| Node A
 +
| Node C
 +
| Node B
 
| Node B
 
| Node B
 
|-
 
|-
 
| 2
 
| 2
| Node A
 
 
| Node C
 
| Node C
| Node B
+
| Node D
 +
| Node A
 
| Node D
 
| Node D
 
|-
 
|-
| 1
+
| 1 (worst)
 +
| Node D
 
| Node B
 
| Node B
| Node A
+
| Node D
| Node C
+
 
| Node C
 
| Node C
 
|}
 
|}
 
{|
 
{|
|style="padding: 10px 0px 15px 15px;"|Now, the final calculation of sorting nodes according to free resources is performed, taking into account the previously defined weights.<br/>
+
|style="padding: 10px 0px 15px 15px;"|
 
The process of sorting nodes is based on the following calculation method:<br/>
 
The process of sorting nodes is based on the following calculation method:<br/>
  
Final Node Priority = (RAM Priority x RAM Weight) + (CPU Priority x CPU Weight) + (Free Disk Priority x Disk Weight) + (No. VMs Priority x VMs Weight)
+
'''Final Node Priority''' = <code>(RAM Priority x RAM Weight)</code> + <code>(CPU Priority x CPU Weight)</code> + <code>(Disk Priority x Disk Weight)</code> + <code>(VMs Priority x VMs Weight)</code>
  
 
The results for nodes A, B, C and D (with weights and sorting priority) are as follows:
 
The results for nodes A, B, C and D (with weights and sorting priority) are as follows:
  
  Node A: (2 x 2,5) + ( 1 x 2 ) + ( 3 x 4 ) + ( 4 x 1,5 ) = 25
+
  Node A: (3 x 2.5) + ( 4 x 2 ) + ( 2 x 4 ) + ( 4 x 1.5 ) = 29.5
  Node B: (1 x 2,5) + ( 4 x 2 ) + ( 2 x 4 ) + ( 3 x 1,5 ) = 23
+
  Node B: (4 x 2.5) + ( 1 x 2 ) + ( 3 x 4 ) + ( 3 x 1.5 ) = 28.5
  Node C: (4 x 2,5) + ( 2 x 2 ) + ( 1 x 4 ) + ( 1 x 1,5 ) = 19,5
+
  Node C: (2 x 2.5) + ( 3 x 2 ) + ( 4 x 4 ) + ( 1 x 1.5 ) = 28.5
  Node D: (3 x 2,5) + ( 3 x 2 ) + ( 4 x 4 ) + ( 2 x 1,5 ) = 32,5
+
  Node D: (1 x 2.5) + ( 2 x 2 ) + ( 1 x 4 ) + ( 2 x 1.5 ) = 13.5
  
As you can see, Node D has got the highest priority value with the result: 32,5.<br/> It will be selected by Load Balancer to create a new VM on, or to migrate or upgrade an existing VM if its current node does not have sufficient resources.<br/>
+
As you can see, '''Node A''' has the highest calculated score: 29.5.<br/> It will be selected by the Load Balancer to create a new VM on, or to migrate or upgrade an existing VM if its current node does not have sufficient resources.<br/>
  
The above described calculations are performed every time, '' 'Create' '' or '' 'Upgrade' '' actions are executed based on the current usage of resources on available nodes.<br/>
+
These calculations are performed automatically whenever a '''Create''' or '''Upgrade''' action is triggered. The Load Balancer evaluates current resource usage across available nodes to determine the optimal placement.<br/>
  
'''''Important:''' In case a given client already has a VM existing on a node, this very node will NOT be taken into account during the prioritization of resources.<br/>
+
'''''Important:''' If a client already has a VM on a given node, that node will be excluded from prioritization. <br/>
These security measures are taken to ensure that, in case of node failure, the client will still have access to the other VM server, created on another, properly working node.<br/> At the same time, if this client has VMs on every node already, all of them will be taken into account during the prioritization process again.''<br/>
+
This ensures that if a node fails, the client's remaining VMs will still be available on other nodes. <br/>If the client already has VMs on all available nodes, then all nodes will be included in the prioritization process again.<br/>
  
 
If you decide to use the Load Balancer tool, define the resource weights to adjust the prioritization of nodes according to your needs.
 
If you decide to use the Load Balancer tool, define the resource weights to adjust the prioritization of nodes according to your needs.
Line 2,013: Line 2,181:
 
===Firewall Templates===
 
===Firewall Templates===
 
{|
 
{|
|style="padding: 10px 0px 15px 15px;"|Proxmox VE VPS For WHMCS allows you to prepare firewall templates for your clients. Those templates can be added to the product's configuration and will be applied in virtual machine creation.<br/>
+
|style="padding: 10px 0px 15px 15px;"|Proxmox VE VPS & Cloud For WHMCS allows you to prepare firewall templates for your clients. Those templates can be added to the product's configuration and will be applied in virtual machine creation.<br/>
 
Start by clicking on the '' 'Create Template' '' button and naming your new template.
 
Start by clicking on the '' 'Create Template' '' button and naming your new template.
 
|}
 
|}
Line 2,041: Line 2,209:
 
====Logs====
 
====Logs====
 
{|
 
{|
|style="padding: 10px 0px 15px 15px;"|The '' 'Logs' '' section under the '' 'Other' '' tab is where the module logs are stored.<br/> You can filter the module logs by type with the '' 'Show' '' buttons.<br/>
+
|style="padding: 10px 0px 15px 15px;"|The '' 'Logs' '' section under the '' 'Tools' '' tab is where the module logs are stored.<br/> You can filter the module logs by type with the '' 'Show' '' buttons.<br/>
 
For precise details on Logs, please refer to our dedicated documentation article, which you may find [https://www.docs.modulesgarden.com/Logs here].  
 
For precise details on Logs, please refer to our dedicated documentation article, which you may find [https://www.docs.modulesgarden.com/Logs here].  
 
|}
 
|}
 
{|
 
{|
 
|style="padding: 0px 0px 30px 25px;"|[[File:PVC_Logs.png]]
 
|style="padding: 0px 0px 30px 25px;"|[[File:PVC_Logs.png]]
 +
|}
 +
 +
====Console Proxy==== 
 +
{|
 +
|style="padding: 10px 0px 15px 15px;"|In this section (''Addons → Proxmox VE VPS & Cloud Addon → Tools → Console Proxy''), you can manage console proxy settings used by the Proxmox addon in your WHMCS.<br/> 
 +
Here, you can view all configured proxy connections, including their details, as well as edit, delete, or add new ones.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PX4_4_1.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|To create a new proxy connection, provide:
 +
* '''Name''' – any custom label for easier identification.
 +
* '''Host''' – full URI of the proxy, including protocol and port. It must match the proxy's access details.
 +
* '''API Key''' – the key generated during the [[#Proxy_Installation_For_Console_Connection|proxy installation]] (see point 10).<br/>
 +
You can define multiple proxy connections and assign them globally or per node.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PX4_4_2.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|'''Global proxy selection'''<br/>
 +
To set a global proxy for all virtual machines, go to: ''Addons → Proxmox VE VPS & Cloud Addon → Settings → General Settings'' <br/> At the bottom, in the ''Console Proxy'' section, select a connection from the ''Proxmox Proxy'' dropdown.  <br/>
 +
This selection will be used for all nodes unless overridden individually.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PX3_4_2.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|'''Per-node proxy selection'''<br/>
 +
To assign a proxy to a specific node, go to: ''Server Details → Cluster tab → Node Details → Other tab.''  <br/> Use the ''Proxmox Proxy'' dropdown to assign a proxy connection to that node.<br/> 
 +
If no node-level proxy is set, the global selection from General Settings will apply.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:PX4_4_3.png]]
 
|}
 
|}
  
Line 2,081: Line 2,284:
 
|}
 
|}
  
====Queue====
+
====[https://www.docs.modulesgarden.com/Task_Queue_Tool Queue]====
 
{|
 
{|
 
|style="padding: 10px 0px 15px 15px;"|At the top of this section, you will find information regarding the cron job.<br/>
 
|style="padding: 10px 0px 15px 15px;"|At the top of this section, you will find information regarding the cron job.<br/>
Line 2,149: Line 2,352:
 
{|
 
{|
 
|style="padding: 0px 0px 30px 25px;"|[[File:PVC_10_1.png]]
 
|style="padding: 0px 0px 30px 25px;"|[[File:PVC_10_1.png]]
 +
|}
 +
 +
===Dashboard===
 +
{|
 +
|style="padding: 10px 0px 15px 15px;"|The '''Proxmox VE VPS & Cloud For WHMCS''' module includes a dedicated '''Dashboard''' that provides key insights into backup activity, virtual machine count, and resource usage statistics.<br/>
 +
The dashboard displays the following information:
 +
* Backup Overview:
 +
** '''Running Backup Tasks'''
 +
** '''Recently Completed Backup Tasks'''
 +
** '''Backup Task History'''
 +
* '''Virtual Machine Count'''
 +
* Resource Usage Charts:
 +
** '''Total RAM Usage'''
 +
** '''Total Disk Usage'''
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:PX4_32_0.png]]
 
|}
 
|}
  
Line 2,160: Line 2,380:
 
** Related Task
 
** Related Task
 
** Message
 
** Message
* '''Failed Tasks''' - a list of tasks that failed to complete
+
* '''Awaiting & Failed Tasks''' - a list of tasks that are awaiting or have failed to complete
 
** Job ID
 
** Job ID
 
** Related Customer
 
** Related Customer
Line 2,182: Line 2,402:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"| You can change the height of the widget by editing the '' 'widget.tpl' '' file located in '' '/whmcs/modules/widgets/ModulesGardenProxmoxAddon/templates'.''<br/>
+
|style="padding: 0px 0px 15px 15px;"|You can change the height of the widget by editing the '' 'widget.tpl' '' file located in '' '/whmcs/modules/widgets/ModulesGardenProxmoxVeVpsCloud/templates'.''<br/>
 
Find this code fragment:
 
Find this code fragment:
 
<code>
 
<code>
Line 2,203: Line 2,423:
 
Now you will be able to adjust the widget's height by editing the <code>height: value;</code> from the default '' '300px' '' to any value that fits your needs.
 
Now you will be able to adjust the widget's height by editing the <code>height: value;</code> from the default '' '300px' '' to any value that fits your needs.
 
|}
 
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|To '''permanently change the widget's height''', follow these steps:
 +
* Copy the original <code>widget.tpl</code> file.
 +
* Go to: <code>modules/addons/ProxmoxVeVpsCloud/overrides/templates/admin/widget/</code> and create a new file named <code>widget.tpl</code>.
 +
* Paste the content of the original file into this new one and apply your custom changes to adjust the widget height.
 +
* When the override file is present, the module will use it instead of the default one. <br/>Your changes will remain safe after module updates.
 +
|}
 +
 
{|
 
{|
 
|style="padding: 0px 0px 15px 15px;"|To configure the widget's visible options, navigate to '''Settings → General Settings → Proxmox VE Widget Features''' section. <br/> In this section, you can choose which data should be displayed on the WHMCS dashboard. The following features can be enabled or disabled:
 
|style="padding: 0px 0px 15px 15px;"|To configure the widget's visible options, navigate to '''Settings → General Settings → Proxmox VE Widget Features''' section. <br/> In this section, you can choose which data should be displayed on the WHMCS dashboard. The following features can be enabled or disabled:
Line 2,223: Line 2,451:
 
## Access to remote consoles
 
## Access to remote consoles
 
## Migrate the server between nodes. <br/> You may enable '' 'Online' '' migration (no need to shut down the server before migration) and toggle '' 'Migration With Local Disks' '' which might take a while.
 
## Migrate the server between nodes. <br/> You may enable '' 'Online' '' migration (no need to shut down the server before migration) and toggle '' 'Migration With Local Disks' '' which might take a while.
# In this panel you will also find the basic information about the VM.
+
## Reconfigure the network
 +
## Detach the virtual machine from the service
 +
# In this panel, you will also find the basic information about the VM.
 
# Moreover, you can change the VM hostname, ISO image, bootable devices as well as insert the SSH public key.
 
# Moreover, you can change the VM hostname, ISO image, bootable devices as well as insert the SSH public key.
  
Line 2,318: Line 2,548:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC4__38_1.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PCV4__38_1.png]]
 
|}
 
|}
 
{|
 
{|
Line 2,340: Line 2,570:
 
{|
 
{|
 
|style="padding: 10px 0px 20px 15px;"|Move to '' 'Virtual Networks' '' section to add, delete and edit your virtual networks.<br/>
 
|style="padding: 10px 0px 20px 15px;"|Move to '' 'Virtual Networks' '' section to add, delete and edit your virtual networks.<br/>
Please keep in mind that this option must be enabled by administrator in your product's '' 'Module Settings' '' previously and a private IP address must be added in the Proxmox Addon.<br/> Otherwise you will not be able to add any virtual network successfully. <br/> If you have reached the set by the admin limit of allowed networks, the button will not be active either.<br/>
+
Please keep in mind that this option must be enabled by an administrator in your product's '' 'Module Settings' '' previously and a private IP address must be added in the Proxmox Addon.<br/> Otherwise you will not be able to add any virtual network successfully. <br/> If you have reached the set by the admin limit of allowed networks, the button will not be active either.<br/>
 +
 
 
Moreover, you can also '' 'Edit' '' (1) or '' 'Delete' '' (2) existing private networks.
 
Moreover, you can also '' 'Edit' '' (1) or '' 'Delete' '' (2) existing private networks.
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 30px 25px;"|[[File:PXC4_60.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PXC4_60.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|Assign virtual machine to a specific network during creation, select source:
 +
* Add network '''From the Service'''
 +
* Add network '''From All Services'''
 +
* Add '''New Virtaul Network''' - in this case, you have to provide all data to create a new network at this point (Pool, CIDR and Gateway)
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PXC4_60_0.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:PXC4_60_1.png]]
 
|}
 
|}
  
Line 2,370: Line 2,613:
  
 
==Client Area - VM Management==
 
==Client Area - VM Management==
===Actions===
+
===Service Actions===
 
{|
 
{|
 
|style="padding: 10px 0px 15px 15px;"|In the client area, users can easily manage their virtual machines using the following actions:
 
|style="padding: 10px 0px 15px 15px;"|In the client area, users can easily manage their virtual machines using the following actions:
Line 2,376: Line 2,619:
 
* Reboot
 
* Reboot
 
* Stop
 
* Stop
* Shut Down
+
* Shut down
* Delete 
+
* Reconfigure network ''(VPS-type products only)''
Additionally, clients can access their VM through one of the three supported console types.
+
* Delete the virtual machine ''(cloud-type products only)''
 
|}
 
|}
 
{|
 
{|
Line 2,384: Line 2,627:
 
|}
 
|}
  
===noVNC Console===
+
==Client Area - Service Management==
{|
+
|style="padding: 10px 0px 20px 15px;"|The noVNC console provides the most straightforward way for clients to connect to their virtual machines directly through the browser.
+
|}
+
{|
+
|style="padding: 0px 0px 30px 25px;"|[[File:PVC4_39_1.png]]
+
|}
+
 
+
===SPICE Console===
+
{|
+
|style="padding: 10px 0px 15px 15px;"| The SPICE console allows access to the virtual machine using the SPICE protocol.
+
|}
+
{|
+
|style="padding: 0px 0px 30px 25px;"|[[File:PX2_40.png]]
+
|}
+
 
+
===Xterm.js Console===
+
{|
+
|style="padding: 10px 0px 15px 15px;"|The Xterm.js console offers another browser-based method to connect to the VM using Xterm.js.<br />
+
To enable this console in Proxmox v2.6.0 or higher, upload the required scripts from the ''UploadOnProxmoxServer/5.2-10'' directory to all your Proxmox servers.
+
|}
+
{|
+
|style="padding: 0px 0px 30px 25px;"|[[File:PCV4_40_1.png]]
+
|}
+
 
+
==Client Area - Additional Tools==
+
 
+
  
 
===Backups===
 
===Backups===
Line 2,417: Line 2,634:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PX3_41.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PX4_41.png]]
 
|}
 
|}
 
{|
 
{|
Line 2,494: Line 2,711:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PX3_45_1.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PX4_45_1.png]]
 
|}
 
|}
 
{|
 
{|
Line 2,500: Line 2,717:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PX3_45_2.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PX4_45_2.png]]
 
|}
 
|}
 
{|
 
{|
Line 2,516: Line 2,733:
 
|}
 
|}
  
===Disks (KVM only)===
+
===Disks===
 
{|
 
{|
 
|style="padding: 0px 0px 20px 15px;"|View available disks and add new ones.
 
|style="padding: 0px 0px 20px 15px;"|View available disks and add new ones.
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PX3_48_6.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PX4_48_6.png]]
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 15px;"|Define the additional disk size, choose its bus (the available options may be '' 'IDE', 'SATA', 'VIRTIO' '' or '' 'SCSI' ''), as well as define a disk format - you can choose from '' 'Raw disk image (raw)', 'QEMU image format (qcow2)','' or '' 'VM image format (VMDK)' ''.
+
|style="padding: 0px 0px 15px 15px;"|Define the additional disk size, choose its bus (the available options may be '' 'IDE', 'SATA', 'VIRTIO' '' or '' 'SCSI' ''), as well as define a disk format. <br/> You can choose from '' 'Raw disk image (raw)', 'QEMU image format (qcow2)','' or '' 'VM image format (VMDK)' ''.
 
|}
 
|}
 
{|
 
{|
 
|style="padding: 0px 0px 30px 25px;"|[[File:PX3_48_8.png]]
 
|style="padding: 0px 0px 30px 25px;"|[[File:PX3_48_8.png]]
 
|}
 
|}
 +
 
===Firewall===
 
===Firewall===
 
{|
 
{|
Line 2,575: Line 2,793:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PX3_48_7.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PX4_48_7.png]]
 
|}
 
|}
 
{|
 
{|
 
|style="padding: 0px 0px 30px 25px;"|[[File:PX3_48_7_1.png]]
 
|style="padding: 0px 0px 30px 25px;"|[[File:PX3_48_7_1.png]]
 
|}
 
|}
 +
 
===Graphs===
 
===Graphs===
 
{|
 
{|
Line 2,591: Line 2,810:
 
===Network===
 
===Network===
 
{|
 
{|
|style="padding: 10px 0px 20px 15px;"|Your clients are allowed to add and remove only private network interface devices. Additionally, they may assign other virtual machines to the network, enabling communication between them.
+
|style="padding: 10px 0px 20px 15px;"|Your clients are allowed to add and remove only private network interface devices. Additionally, they may attach additional networks to the virtual machine, enabling communication between them.
 
|}
 
|}
 
{|
 
{|
Line 2,603: Line 2,822:
 
|}
 
|}
 
{|
 
{|
|style="padding: 00px 0px 20px 15px;"|The '' 'Assign Virtual Machine' '' button opens another popup window, where virtual machines to be assigned to the network can be selected and optionally restarted.<br/>A restart is necessary for the changes to be applied if the hotplug functionality is not configured for the virtual machine.<br/> You can find an exemplary scenario illustrating a typical use case of this function in the [[#Connecting_Multiple_VPS_Machines_Into_One_Private_Network|'' 'Use Cases' '' section]] of this wiki.  
+
|style="padding: 00px 0px 20px 15px;"|The '' 'Attach Network' '' button opens another popup window, where virtual machines can be selected and optionally restarted.<br/>A restart is necessary for the changes to be applied if the hotplug functionality is not configured for the virtual machine.<br/> You can find an exemplary scenario illustrating a typical use case of this function in the [[#Connecting_Multiple_VPS_Machines_Into_One_Private_Network|'' 'Use Cases' '' section]] of this wiki.  
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PX3_48_1_1.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PX4_48_1_1.png]]
 
|}
 
|}
 
{|
 
{|
Line 2,612: Line 2,831:
  
 
Keep in mind that '' ' Network device' '' options have to be set to '' 'Private'.'' <br/>Also, after the network creation, the button to add another one or delete a newly created private network may not be longer available, depending on your Proxmox configuration.
 
Keep in mind that '' ' Network device' '' options have to be set to '' 'Private'.'' <br/>Also, after the network creation, the button to add another one or delete a newly created private network may not be longer available, depending on your Proxmox configuration.
 +
|}
 +
 +
===noVNC Console===
 +
{|
 +
|style="padding: 10px 0px 20px 15px;"|The noVNC console provides the most straightforward way for clients to connect to their virtual machines directly through the browser.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:PVC4_39_1.png]]
 
|}
 
|}
  
Line 2,639: Line 2,866:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 30px 25px;"|[[File:PX3_48_9.png]]
+
|style="padding: 0px 0px 30px 25px;"|[[File:PX4_48_9.png]]
 
|}
 
|}
 
{|
 
{|
Line 2,662: Line 2,889:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 30px 25px;"|[[File:PX3_48_11.png]]
+
|style="padding: 0px 0px 30px 25px;"|[[File:PX4_48_11.png]]
 
|}
 
|}
 
<!--
 
<!--
Line 2,670: Line 2,897:
 
-->
 
-->
  
===Server Monitoring Integration===
+
===Server Monitoring Integration (Temporarily Suspended)===
 
{|
 
{|
|style="padding: 10px 0px 15px 15px;"|'''''Important:''' This section is only available with [https://www.modulesgarden.com/products/whmcs/server-monitoring Server Monitoring For WHMCS] module active.''
+
|style="padding: 10px 0px 15px 15px;"|Integration with [https://www.modulesgarden.com/products/whmcs/server-monitoring Server Monitoring For WHMCS] is currently unavailable, and will be re-added with the nearest Server Monitoring For WHMCS module update.<br/>
 +
'''''Important:''' This section is only available with [https://www.modulesgarden.com/products/whmcs/server-monitoring Server Monitoring For WHMCS] module active.''
 
Clients can create their own server status checks and monitor its health.
 
Clients can create their own server status checks and monitor its health.
 
New checks can be added by clicking on the '' 'Create Check' '' button.
 
New checks can be added by clicking on the '' 'Create Check' '' button.
Line 2,726: Line 2,954:
 
{|
 
{|
 
|style="padding: 10px 0px 20px 15px;"|Use a snapshot to remember the current contents of the virtual machine memory. You may use them later to restore the VM's settings. <br/> Please remember that it is necessary to run the following cron command for snapshot jobs. <br/> You may set the cron command once a day or every hour. Do not forget to replace 'your_whmcs' with your WHMCS root location.  
 
|style="padding: 10px 0px 20px 15px;"|Use a snapshot to remember the current contents of the virtual machine memory. You may use them later to restore the VM's settings. <br/> Please remember that it is necessary to run the following cron command for snapshot jobs. <br/> You may set the cron command once a day or every hour. Do not forget to replace 'your_whmcs' with your WHMCS root location.  
<pre> php -q /your_whmcs/modules/addons/proxmoxAddon/cron/cron.php snapshots </pre>
+
<pre> php -q /your_whmcs/modules/addons/ProxmoxVeVpsCloud/cron/cron.php snapshots </pre>
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PX3_48_4.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PX4_48_4.png]]
 
|}
 
|}
 
{|
 
{|
Line 2,741: Line 2,969:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PX3_48_5_1.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PX4_48_5_1.png]]
 
|}
 
|}
 
{|
 
{|
Line 2,748: Line 2,976:
 
{|
 
{|
 
|style="padding: 0px 0px 30px 25px;"|[[File:PX3_48_5_2.png]]
 
|style="padding: 0px 0px 30px 25px;"|[[File:PX3_48_5_2.png]]
 +
|}
 +
 +
===SPICE Console===
 +
{|
 +
|style="padding: 10px 0px 15px 15px;"| The SPICE console allows access to the virtual machine using the SPICE protocol.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:PX2_40.png]]
 
|}
 
|}
  
Line 2,756: Line 2,992:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 30px 25px;"|[[File:PX3_47.png]]
+
|style="padding: 0px 0px 30px 25px;"|[[File:PX4_47.png]]
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 30px 25px;"|[[File:PX3_47_1.png]]
+
|style="padding: 0px 0px 30px 25px;"|[[File:PX4_47_1.png]]
 
|}
 
|}
  
Line 2,768: Line 3,004:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PX3_48_12.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PX4_48_12.png]]
 
|}
 
|}
 
{|
 
{|
Line 2,801: Line 3,037:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PX3_48_14.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PX4_48_14.png]]
 
|}
 
|}
 
{|
 
{|
 
|style="padding: 0px 0px 30px 15px;"|'''''Important:''' "VM Powre Tasks" require a dedicated cron job to be set up by the administrator.''
 
|style="padding: 0px 0px 30px 15px;"|'''''Important:''' "VM Powre Tasks" require a dedicated cron job to be set up by the administrator.''
 +
|}
 +
 +
===Xterm.js Console===
 +
{|
 +
|style="padding: 10px 0px 15px 15px;"|The Xterm.js console offers another browser-based method to connect to the VM using Xterm.js.<br />
 +
To enable this console in Proxmox v2.6.0 or higher, upload the required scripts from the ''UploadOnProxmoxServer/5.2-10'' directory to all your Proxmox servers.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:PCV4_40_1.png]]
 
|}
 
|}
  
Line 2,842: Line 3,087:
 
|}
 
|}
  
 +
<!--
 
===List of Configurable Options===
 
===List of Configurable Options===
 
{|
 
{|
Line 3,012: Line 3,258:
 
'''ciscript''' - using the "ciscript" option results in passing the script ID available in Proxmox Addon, which will be uploaded to the snippet storage and passed to the Proxmox VE server during the virtual machine creation.
 
'''ciscript''' - using the "ciscript" option results in passing the script ID available in Proxmox Addon, which will be uploaded to the snippet storage and passed to the Proxmox VE server during the virtual machine creation.
 
|}
 
|}
 
+
-->
 
<!--
 
<!--
 
==Integration with Products Reseller For WHMCS==
 
==Integration with Products Reseller For WHMCS==
Line 3,043: Line 3,289:
 
|}
 
|}
 
-->
 
-->
 
<!--
 
  
 
==Management of Billing==
 
==Management of Billing==
 
{|
 
{|
 
|style="padding: 10px 0px 15px 15px;"|When you combine Proxmox VPS For WHMCS with [https://www.docs.modulesgarden.com/Advanced_Billing_For_WHMCS Advanced Billing For WHMCS], you will be able to set up additional billing options.<br />
 
|style="padding: 10px 0px 15px 15px;"|When you combine Proxmox VPS For WHMCS with [https://www.docs.modulesgarden.com/Advanced_Billing_For_WHMCS Advanced Billing For WHMCS], you will be able to set up additional billing options.<br />
The module allows you to charge your customers based on the server resources they have used.<br/>
+
The module allows you to charge your customers based on the server resources they have used.
'' Note: Advanced Billing supports '''OpenVZ''' (prior to Proxmox v2.3.0), '''KVM''' and the '''LXC''' virtualization type.
+
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PX3_57.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PVC4_57.png]]
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 15px;"|With Advanced Billing For WHMCS module, you can also display the current resource usage of your customer's server, as well as its total cost.
+
|style="padding: 0px 0px 20px 15px;"|With the Advanced Billing For WHMCS module, you can also display the current resource usage of your customer's server, as well as its total cost.
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 30px 25px;"|[[File:PX3_58.png]]
+
|style="padding: 0px 0px 30px 25px;"|[[File:PVC4_58.png]]
|}
+
-->
+
 
+
==Importing Existing Virtual Machines==
+
{|
+
|style="padding: 10px 0px 15px 15px;"|Our module allows you to easily import VM into your product.<br />
+
To do so, press '' 'Import Virtual Machine' '' as shown on the following screen.
+
|}
+
{|
+
|style="padding: 0px 0px 20px 25px;"|[[File:PVC4_45_3.png]]
+
|}
+
{|
+
|style="padding: 0px 0px 15px 15px;"|Afterwards, choose the preferred virtual machine from the dropdown menu and complete the '' 'Password' '' field.<br />
+
Confirm importing through pressing the '' 'Confirm' '' button.
+
|}
+
{|
+
|style="padding: 0px 0px 30px 25px;"|[[File:PXC3_45_4.png]]
+
 
|}
 
|}
  
Line 3,103: Line 3,329:
 
==Selling Predefined Windows Virtual Machines==
 
==Selling Predefined Windows Virtual Machines==
 
{|
 
{|
|style="padding: 10px 0px 5px 15px;"|
+
|style="padding: 10px 0px 5px 15px;"|The '''Proxmox VE VPS & Cloud For WHMCS''' module allows you to offer predefined, ready-to-deploy Windows-based virtual machines to your clients. This setup is applicable to Kernel-based Virtual Machines (KVM) only. <br/ >
'''Proxmox VE VPS & Cloud For WHMCS''' can be used to sell predefined Windows-based virtual machines. Follow the instructions below, to prepare the template for Windows Virtual Machines and configure the module. <br/>
+
Follow the steps below to create a Windows VM template, configure it using the App Templates feature, and link it with your WHMCS product settings.
Keep in mind that the instructions are for Kernel-based Virtual Machines (KVM) only.
+
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 5px 15px;"| '''First, a template virtual machine needs to be prepared in Proxmox:''' <br/>
+
|style="padding: 0px 0px 5px 15px;"|'''1. Prepare a Windows template in Proxmox:'''<br/>
1. Start a new virtual machine with a Windows Installer ISO file mounted. <br/>
+
 
2. Make sure the '' 'OS Type' '' in the virtual machine's options includes '' 'Windows.' '' <br/>
+
* Start a new virtual machine with a Windows Installer ISO file mounted.  
3. Install '' 'Windows Operating System' '' on the virtual machine. <br/>
+
* Make sure the '' 'OS Type' '' in the virtual machine's options is set to '''Windows'''.
4. Install '' 'Qemu Guest Agent.' '' The module will detect and run it if the OS Type is set to Windows. <br/>
+
* Install '' 'Windows Operating System' '' on the virtual machine.  
5. Stop the virtual machine. You can delete the CD Drive (it will not be needed anymore). <br/>
+
* After installation, add the '' 'Qemu Guest Agent.' '' The module will auto-detect it if the OS is correctly set as Windows.
6. Convert the virtual machine to a template. <br/>
+
* Power off the VM and remove the virtual CD drive if no longer needed.
7. If you are using '' 'Shared Storage,' '' upload the template to it. If you do not use '' 'Shared Storage,' '' make sure to upload the template to every node.
+
* Convert this VM into a template directly from the Proxmox interface.  
 +
* If you are using '' 'Shared Storage,' '' upload the template there. If not, manually copy the template to all relevant nodes.
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|'''Next, the Proxmox VE VPS & Cloud For WHMCS module settings need to be correctly configured:''' <br/>
+
|style="padding: 0px 0px 15px 15px;"|'''2. Configure App Templates in the Proxmox VE VPS & Cloud For WHMCS addon.'''<br/> The '''App Templates''' feature simplifies template management and provisioning. To define and use your Windows template:<br/>
1. Enable the '' 'Guest Agent' '' in the product's [[#VPS_-_KVM_Virtualization_Type|module settings]].
+
 
 +
* Access the Proxmox addon and navigate to the ''App Templates → Applications'' section.
 +
* As the template was just added on the server, click '''"Refresh list"''' to fetch the latest available templates.
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PX3_58_1_1.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PVC_UC_1.png]]
 
|}
 
|}
<!--
 
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|2. Define which '' 'OS Templates' '' will be available in the Reinstall section in the client area.  
+
|style="padding: 0px 0px 20px 15px;"|Move to ''App Templates → Groups'', create a group of applications with your template.  
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PX3_58_1_2.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PVC_UC_2.png]]
 
|}
 
|}
-->
 
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|2. Generate [[#Finalizing_The_Configuration|'' 'Configurable Options' '']] responsible for the virtual machine templates. Including only Windows templates in the [[#Configurable_Options|Configurable Options]] is recommended.
+
|style="padding: 0px 0px 15px 15px;"|'''3. Configure the product's module settings:''' <br/>
 +
 
 +
In the ''App Templates Configuration'', choose the ''Default Application Group''' that includes your predefined Windows template.<br/> This group will be used to automatically generate the corresponding configurable options for application selection.  
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 30px 25px;"|[[File:PX3_58_1_5.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PVC_UC_3.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 15px;"|Again in the module settings, enable the '''Guest Agent''' option to ensure proper interaction between the virtual machine and the module.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PVC_UC_4.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 15px;"|Generate a configurable option named '''app|Application''' to allow clients to select from the available app templates ''(including Windows-based ones from the Default Application Group)'' during the ordering process.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PVC_UC_5.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|When placing an order, clients will see a dropdown with applications you have configured. <br/>They can select the Windows template, which will then be used to provision their server accordingly.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:PVC_UC_6.png]]
 
|}
 
|}
  
Line 3,142: Line 3,388:
 
{|
 
{|
 
|style="padding: 10px 0px 5px 15px;"|  
 
|style="padding: 10px 0px 5px 15px;"|  
'''Proxmox VE VPS & Cloud For WHMCS''' can be used to sell predefined Linux-based virtual machines. Follow the instructions below, to prepare the template for Linux Virtual Machines and configure the module. <br/>
+
'''Proxmox VE VPS & Cloud For WHMCS''' can be used to sell predefined Linux-based virtual machines. Follow the instructions below to prepare a Linux virtual machine template and configure the module. <br/>
 
Keep in mind that the instructions are for Kernel-based Virtual Machines (KVM) only.
 
Keep in mind that the instructions are for Kernel-based Virtual Machines (KVM) only.
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 5px 15px;"|'''First, a template virtual machine needs to be prepared in Proxmox:''' <br/>
+
|style="padding: 0px 0px 5px 15px;"|'''1. Prepae a template virtual machine in Proxmox:''' <br/>
1. Create a template Cloud-Init virtual machine based on this [https://pve.proxmox.com/wiki/Cloud-Init_Support documentation]. <br/>
+
Create a Cloud-Init template virtual machine based on the official [https://pve.proxmox.com/wiki/Cloud-Init_Support documentation]. <br/>
2. If you would like to make additional changes in the template (e.g. login with a password, root access via SSH) then: <br/>
+
If you would like to make additional customizations to the template (e.g., enabling login with a password or allowing root access via SSH):
# Create a new virtual machine with the template from step 1. <br/>
+
* Create a new virtual machine based on the template from step 1.  
# Log in to the virtual machine. <br/>
+
* Log in to the virtual machine.
# Introduce any changes you want the new template to have. <br/>
+
* Apply the desired changes.
# Convert the virtual machine to a new template. <br/>
+
* Convert the modified VM into a new template.<br/>
3. If you are using '' 'Shared Storage,' '' upload the template to it. If you are not using '' 'Shared Storage', '' you will need to upload the template to every node.
+
If you are using shared storage, upload the template there. If shared storage is not used, ensure that the template is uploaded to each node manually.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|'''2. Configure App Templates in the Proxmox VE VPS & Cloud For WHMCS addon.'''<br/> The '''App Templates''' feature simplifies the management and provisioning of predefined templates.<br/>
 +
 
 +
* Go to the Proxmox VE VPS & Cloud addon and navigate to the '''App Templates → Applications''' section.
 +
* Since the template was recently added on the server, click '''"Refresh List"''' to load the latest templates.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PVC_UC_7.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 15px;"|Then go to '''App Templates → Groups'''  and create a group of applications that includes your Linux template.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PVC_UC_8.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|'''3. Configure the product's module settings:''' <br/>
 +
 
 +
In the ''App Templates Configuration'', choose the '''Default Application Group''' that contains your predefined Linux template.<br/> This group will automatically generate the corresponding configurable options for application selection.<br/>
 +
These applications will also be available in the "Reinstallation" section of the client area, allowing clients to reinstall their servers at any time.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PVC_UC_9.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|Still in the module settings, enable the '' 'Cloud-Init' '' option to ensure proper integration between the module and the virtual machine.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PVC_UC_10.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 15px;"|Enable the '''"Reinstallation"'''  feature in the '''Client Area Features''' section to give clients access to this functionality.
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|'''Next, the Proxmox VE VPS & Cloud For WHMCS module settings need to be correctly configured:''' <br/>
+
|style="padding: 0px 0px 20px 25px;"|[[File:PVC_UC_11.png]]
1. Make sure '' 'Cloud-Init' '' is enabled in the product's [[#VPS_-_KVM_Virtualization_Type|module settings]].
+
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PX3_58_1_3.png]]
+
|style="padding: 0px 0px 20px 15px;"|Generate a configurable option named '''app|Application''' o allow clients to choose from the available app templates (including those from the Default Application Group) during the ordering process.<br/>
 +
Optionally, set pricing for the '' 'app|Application' '' configurable options via System Settings → Products/Services → [[#Configurable_Options|Configurable Options]].
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 15px;"|2. Define which '' 'OS Templates' '' will be available in the Reinstall section in the client area.
+
|style="padding: 0px 0px 20px 25px;"|[[File:PVC_UC_5.png]]
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PX3_58_1_4.png]]
+
|style="padding: 0px 0px 15px 15px;"|When placing an order, clients will see a dropdown menu with the application templates you've configured.<br/> They can select the desired Linux template, which will then be used to provision their server.
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 15px;"|3. Generate [[#Finalizing_The_Configuration|'' 'Configurable Options' '']] responsible for the virtual machine templates.
+
|style="padding: 0px 0px 20px 25px;"|[[File:PVC_UC_13.png]]
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PX3_58_1_5.png]]
+
|style="padding: 0px 0px 20px 15px;"|Clients can reinstall their virtual machines using any of the templates available in their assigned group.
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 30px 15px;"|Optionally, set prices for '' 'VM Template [[#Configurable_Options|Configurable Options]].' '' Navigate to '' 'System Settings' '' → '' 'Products/Services' '' → '' 'Configurable Options.' '' in order to do so.
+
|style="padding: 0px 0px 30px 25px;"|[[File:PVC_UC_14.png]]
 
|}
 
|}
  
Line 3,181: Line 3,460:
 
{|
 
{|
 
|style="padding: 10px 0px 15px 15px;"|Proxmox VE VPS & Cloud For WHMCS allows connecting multiple VPS machines into one private network.<br/> To do so, you will need at least 2 virtual machines. In our case, the hostname of the first virtual machine is: '' 'virtualmachine1.com' '' and the hostname of the second one is: '' 'virtualmachine2.com.' '' <br/>  
 
|style="padding: 10px 0px 15px 15px;"|Proxmox VE VPS & Cloud For WHMCS allows connecting multiple VPS machines into one private network.<br/> To do so, you will need at least 2 virtual machines. In our case, the hostname of the first virtual machine is: '' 'virtualmachine1.com' '' and the hostname of the second one is: '' 'virtualmachine2.com.' '' <br/>  
First, pick one of the machines and navigate to '' 'Additional Tools' '' → '' 'Network' '' in your client area.
+
First, pick one of the machines and navigate to '' 'Service Management' '' → '' 'Network' '' in your client area.
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PX3_59.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PX4_59.png]]
 
|}
 
|}
 
{|
 
{|
Line 3,202: Line 3,481:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PX3_59_3.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PX4_59_3.png]]
 
|}
 
|}
 
{|
 
{|
Line 3,222: Line 3,501:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PX3_57_1.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PVC_UC_15.png]]
 
|}
 
|}
 
{|
 
{|
Line 3,228: Line 3,507:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PX3_57_2.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PVC_UC_16.png]]
 
|}
 
|}
 
{|
 
{|
Line 3,246: Line 3,525:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PX3_57_5.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PX4_57_5.png]]
 
|}
 
|}
 
{|
 
{|
Line 3,278: Line 3,557:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PX3_57_10.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PX4_57_5.png]]
 
|}
 
|}
 
{|
 
{|
Line 3,371: Line 3,650:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 30px 25px;"|[[File:PX3_59_11.png]]
+
|style="padding: 0px 0px 30px 25px;"|[[File:PX4_57_5.png]]
 
|}
 
|}
  
Line 3,413: Line 3,692:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PX3_61_1.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PVC_UC_17.png]]
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|Next, click on '' 'Create Task Template' '' and define the following details. You can create multiple task templates.
+
|style="padding: 0px 0px 15px 15px;"|Next, edit the just created template, click on '' 'Create Task Template' '' and define the following details. You can create multiple task templates.
 
*'''Start Time''' - The time when the task for a backup will be issued. Make sure the time you input meets the format: 24-hour time notation with the zeroes included. For example, 07:05, 20:30
 
*'''Start Time''' - The time when the task for a backup will be issued. Make sure the time you input meets the format: 24-hour time notation with the zeroes included. For example, 07:05, 20:30
 
*'''Day of the Week''' -  The days the backups should occur each week.
 
*'''Day of the Week''' -  The days the backups should occur each week.
Line 3,432: Line 3,711:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 30px 25px;"|[[File:PX3_61_3.png]]
+
|style="padding: 0px 0px 30px 25px;"|[[File:PVC_UC_18.png]]
 
|}
 
|}
  
Line 3,441: Line 3,720:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PX3_62_1.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PVC_UC_19.png]]
 
|}
 
|}
 
{|
 
{|
Line 3,460: Line 3,739:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 30px 25px;"|[[File:PX3_62_4.png]]
+
|style="padding: 0px 0px 30px 25px;"|[[File:PVC_UC_20.png]]
 
|}
 
|}
  
Line 3,587: Line 3,866:
  
 
=Tips=
 
=Tips=
 +
 +
<h4 style="color: #ff0000; font-weight:bold; text-align:center;">This section is currently being updated, you may encounter broken links or outdated descriptions.<br/>
 +
Please accept our apologies for any inconvenience.
 +
</h4>
 +
 
{|
 
{|
 
|style="padding: 10px 0px 15px 15px;"|1. Operations performed on the virtual servers are not executed immediately. Give your Proxmox Virtual Environment some time to process the request and execute the operation.  
 
|style="padding: 10px 0px 15px 15px;"|1. Operations performed on the virtual servers are not executed immediately. Give your Proxmox Virtual Environment some time to process the request and execute the operation.  
Line 3,619: Line 3,903:
 
{|
 
{|
 
|style="padding: 0px 0px 20px 15px;"|7. As this module supports the templates system, any changes made in the module's template files will be saved after the upgrade process.
 
|style="padding: 0px 0px 20px 15px;"|7. As this module supports the templates system, any changes made in the module's template files will be saved after the upgrade process.
|}
 
{|
 
|style="padding: 0px 0px 15px 15px;"|8. If you are using the module in the 2.3.2 version or any previous one, and would like to migrate to '''Proxmox VE V5.X''', you need to update the files on your Proxmox server to the new version from the ''' 'UploadOnProxmoxServer' ''' folder.
 
 
|}
 
|}
 
{|
 
{|
Line 3,638: Line 3,919:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 5px 15px;"|12. You can use the '' 'IPSet IP Filter' '' option for firewall to prevent IP spoofing. Click [https://pve.proxmox.com/wiki/Firewall#pve_firewall_ip_sets here] to read more about IP Sets.<br/>
+
|style="padding: 0px 0px 5px 15px;"|12. You can use the '' 'IP Set IP Filter' '' option for firewall to prevent IP spoofing. Click [https://pve.proxmox.com/wiki/Firewall#pve_firewall_ip_sets here] to read more about IP Sets.<br/>
 
Inside the admin area, in the product details view, you can preview the current IP Sets on VM:
 
Inside the admin area, in the product details view, you can preview the current IP Sets on VM:
 
|}
 
|}
Line 3,934: Line 4,215:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 15px;"|16. You can easily import and assign any already existing VM from Proxmox to your WHMCS.<br/>
+
|style="padding: 0px 0px 20px 15px;"|16. It is possible to display more information about your VM in Proxmox Environment.<br/> To do so, you need to provide the preferred records in the '' 'Container Notes' '' tab under the ' ''KVM or LXC Configuration' '' section. <br/>The following records can be used:
First, you need order Proxmox VPS product to your client account  without processing the VM creation process. <br/>
+
Next, in the client's '' 'Products/Services' '' management tab of your admin area, fill the '' 'VMID' '' and '' 'Node' '' custom fields with the VMID of the virtual machine you want to import from your Proxmox server  <br/>
+
Afterward, change the product status to '' 'Active' '', save changes and use the '' 'Change User Role' '' module command.
+
|}
+
{|
+
|style="padding: 0px 0px 20px 15px;"|17. It is possible to display more information about your VM in Proxmox Environment.<br/> To do so, you need to provide the preferred records in the '' 'Container Notes' '' tab under the ' ''KVM or LXC Configuration' '' section. <br/>The following records can be used:
+
 
<pre>Client: {$client_name} (ID: {$client_id})  
 
<pre>Client: {$client_name} (ID: {$client_id})  
 
Email: {$client_email} Service ID: {$service_id}  
 
Email: {$client_email} Service ID: {$service_id}  
Line 3,958: Line 4,233:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 15px;"|18. When the interface names on the VM are '''Net\d+''', you need to choose '''Eth\d+''' in the '' 'Firewall' '' section of the product configuration.
+
|style="padding: 0px 0px 20px 15px;"|17. When the interface names on the VM are '''Net\d+''', you need to choose '''Eth\d+''' in the '' 'Firewall' '' section of the product configuration.
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 15px;"|19. If you want your clients to provide their own hostname, you need to add the following custom field in the '' 'Custom Fields' '' tab of the product configuration. <br/>
+
|style="padding: 0px 0px 20px 15px;"|18. If you want your clients to provide their own hostname, you need to add the following custom field in the '' 'Custom Fields' '' tab of the product configuration. <br/>
 
<pre> proxmoxHostname|Hostname </pre>
 
<pre> proxmoxHostname|Hostname </pre>
 
|}
 
|}
 
<div id="create-vm"></div>
 
<div id="create-vm"></div>
 
{|
 
{|
|style="padding: 0px 0px 10px 15px;"|'''20. Create Linux VM:'''<br/>  
+
|style="padding: 0px 0px 10px 15px;"|'''19. Create Linux VM:'''<br/>  
 
* Create a VM template according to descriptions [https://pve.proxmox.com/wiki/Cloud-Init_Support#_preparing_cloud_init_templates here]<br/>
 
* Create a VM template according to descriptions [https://pve.proxmox.com/wiki/Cloud-Init_Support#_preparing_cloud_init_templates here]<br/>
 
* Move to ''Module Settings → Virtual Machine Configuration → OS Template'', select the previously created template (e.g. Ubuntu)<br/>
 
* Move to ''Module Settings → Virtual Machine Configuration → OS Template'', select the previously created template (e.g. Ubuntu)<br/>
Line 3,979: Line 4,254:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 10px 15px;"|'''21. Create Windows VM:'''<br/>
+
|style="padding: 0px 0px 10px 15px;"|'''20. Create Windows VM:'''<br/>
 
* Create a new virtual machine using an ISO image in Proxmox panel<br/>
 
* Create a new virtual machine using an ISO image in Proxmox panel<br/>
 
* Install ''Guest Agent'' on the windows system, read more [https://pve.proxmox.com/wiki/Qemu-guest-agent#Windows here]<br/>
 
* Install ''Guest Agent'' on the windows system, read more [https://pve.proxmox.com/wiki/Qemu-guest-agent#Windows here]<br/>
Line 3,994: Line 4,269:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 10px 15px;"|22. Configuring '' 'Default User' '' per template. Move to '' 'Proxmox Addon' → 'Servers' → 'Server Details' → 'Templates' → 'Create/Edit Template'.''<br/>
+
|style="padding: 0px 0px 10px 15px;"|21. Configuring '' 'Default User' '' per template. Move to '' 'Proxmox Addon' → 'Servers' → 'Server Details' → 'Templates' → 'Create/Edit Template'.''<br/>
 
You may assign a default user to a single template, that user will be automatically assigned to the newly created VM.  
 
You may assign a default user to a single template, that user will be automatically assigned to the newly created VM.  
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 10px 15px;"|23. Configurable option field: '' 'Storage Disc Space' '' - this option allows to define the type and space on disc via a configurable option when placing an order.<br/> It also allows to extend the space as well as change the disc type. This CO overwrites the ordinary '' 'Disc Space' '' field available in the product configuration section.<br/>   
+
|style="padding: 0px 0px 10px 15px;"|22. Configurable option field: '' 'Storage Disc Space' '' - this option allows to define the type and space on disc via a configurable option when placing an order.<br/> It also allows to extend the space as well as change the disc type. This CO overwrites the ordinary '' 'Disc Space' '' field available in the product configuration section.<br/>   
 
'''''Important:''' To migrate the disc, you must previously 'Stop' your VM.''<br/>
 
'''''Important:''' To migrate the disc, you must previously 'Stop' your VM.''<br/>
 
'''''Note:''' Values provided in configurable option must be integers.''
 
'''''Note:''' Values provided in configurable option must be integers.''
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 10px 15px;"|24. Usage of '''VLAN Tags''':<br/>
+
|style="padding: 0px 0px 10px 15px;"|23. Usage of '''VLAN Tags''':<br/>
 
VLAN Tags Range Minimum and Maximum Numbers simply play the role of network separation measures. The minimum and maximum numbers cause the module to select the next free VLAN Tag from this range for each virtual machine it creates.<br/> VLAN Tag is actually a drop-down list, and to select anything in this section, firstly, it is necessary to configure appropriate IP addresses in your ''Proxmox addon → IP Management'' section:  
 
VLAN Tags Range Minimum and Maximum Numbers simply play the role of network separation measures. The minimum and maximum numbers cause the module to select the next free VLAN Tag from this range for each virtual machine it creates.<br/> VLAN Tag is actually a drop-down list, and to select anything in this section, firstly, it is necessary to configure appropriate IP addresses in your ''Proxmox addon → IP Management'' section:  
 
|}
 
|}
Line 4,013: Line 4,288:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 10px 15px;"|25. '''SDN Support''':<br/>
+
|style="padding: 0px 0px 10px 15px;"|24. '''SDN Support''':<br/>
 
The module supports SDN private network type. It is possible to create virtual networks (vnets) at datacenter level thanks to the Software Defined Network (SDN).<br/> To learn all the details on SDN in proxmox, please navigate to the official proxmox [https://pve.proxmox.com/pve-docs/chapter-pvesdn.html documentation]. <br/>
 
The module supports SDN private network type. It is possible to create virtual networks (vnets) at datacenter level thanks to the Software Defined Network (SDN).<br/> To learn all the details on SDN in proxmox, please navigate to the official proxmox [https://pve.proxmox.com/pve-docs/chapter-pvesdn.html documentation]. <br/>
  
Line 4,026: Line 4,301:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 10px 15px;"|26. The "fetchBackupsForArchive" parameter in the "global_options.yml" file allows skipping the backups from being loaded into the "Archive" list in the product configuration.
+
|style="padding: 0px 0px 10px 15px;"|25. The "fetchBackupsForArchive" parameter in the "global_options.yml" file allows skipping the backups from being loaded into the "Archive" list in the product configuration.
 
By default the parameter is set to '' 'true' '' and backups are loaded. You may change it manually to '' 'false' '' and no backups will be loaded in the '' 'Archive' '' dropdown list as on the screens below:
 
By default the parameter is set to '' 'true' '' and backups are loaded. You may change it manually to '' 'false' '' and no backups will be loaded in the '' 'Archive' '' dropdown list as on the screens below:
 
|}
 
|}
Line 4,036: Line 4,311:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 10px 15px;"|27. '''OS Templates and ISO Images' names - translate the names of available templates and images easily.'''<br/> Add extra lines into the module language file ''(e.g. /yourWHMCS/modules/servers/proxmoxVPS/langs/english.php)'' with your desired translations to customize their names.<br/>
+
|style="padding: 0px 0px 10px 15px;"|26. '''OS Templates and ISO Images' names - translate the names of available templates and images easily.'''<br/> Add extra lines into the module language file ''(e.g. /yourWHMCS/modules/servers/proxmoxVPS/langs/english.php)'' with your desired translations to customize their names.<br/>
  
 
Follow the bellow pattern to add new lines:
 
Follow the bellow pattern to add new lines:
Line 4,050: Line 4,325:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 10px 15px;"|28. If you want to use the IP Address, CIDR and Gateway allocated from the IP Management section of the Proxmox Addon module instead of hard coding them, use the following parameter:  
+
|style="padding: 0px 0px 10px 15px;"|27. If you want to use the IP Address, CIDR and Gateway allocated from the IP Management section of the Proxmox Addon module instead of hard coding them, use the following parameter:  
  
 
   {$ipv4Addresses[0].gateway}
 
   {$ipv4Addresses[0].gateway}
Line 4,056: Line 4,331:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 10px 15px;"|29. Select the storage type already while placing the order.<br/>
+
|style="padding: 0px 0px 10px 15px;"|28. Select the storage type already while placing the order.<br/>
 
Create the "Storage Disk Space" configurable option with storage size and name to allow clients to set "Storage Disk Space" during the order. It will be used instead of the provided "Disk Space" value.<br/>  
 
Create the "Storage Disk Space" configurable option with storage size and name to allow clients to set "Storage Disk Space" during the order. It will be used instead of the provided "Disk Space" value.<br/>  
 
For VE VPS '''KVM''' and '''LXC''':
 
For VE VPS '''KVM''' and '''LXC''':
Line 4,068: Line 4,343:
 
|}
 
|}
 
{|  
 
{|  
|style="padding: 0px 0px 15px 15px;"|30. '''Private Network management'''<br/>  
+
|style="padding: 0px 0px 15px 15px;"|29. '''Private Network management'''<br/>  
 
The module allows to create private network skipping the IP Management and firewall settings. Disable the below options if you do not aim to assign the IP address to the private network device.
 
The module allows to create private network skipping the IP Management and firewall settings. Disable the below options if you do not aim to assign the IP address to the private network device.
  
Line 4,078: Line 4,353:
 
|}
 
|}
 
{|  
 
{|  
|style="padding: 0px 0px 15px 15px;"|31. '''Make sure not to swap public and private network bridges during product upgrades.'''<br/>
+
|style="padding: 0px 0px 15px 15px;"|30. '''Make sure not to swap public and private network bridges during product upgrades.'''<br/>
 
Using a bridge previously used for the opposing network type, can lead to several issues. Make sure the upgrade scenario looks like this:
 
Using a bridge previously used for the opposing network type, can lead to several issues. Make sure the upgrade scenario looks like this:
 
  Product 1 (before upgrade):
 
  Product 1 (before upgrade):
Line 4,091: Line 4,366:
 
|}
 
|}
 
{|  
 
{|  
|style="padding: 0px 0px 15px 15px;"|32. '''How to Test Cloud Init in Proxmox Panel'''<br/>
+
|style="padding: 0px 0px 15px 15px;"|31. '''How to Test Cloud Init in Proxmox Panel'''<br/>
 
If a Linux machine does not have a password or network configured, but the data is correctly sent to the Proxmox panel, check if Cloud Init is properly configured on the template.<br/>
 
If a Linux machine does not have a password or network configured, but the data is correctly sent to the Proxmox panel, check if Cloud Init is properly configured on the template.<br/>
 
To test this, set the password and user in the Proxmox panel’s Cloud Init section and clone the template. This will confirm if the password is applied correctly in the system.
 
To test this, set the password and user in the Proxmox panel’s Cloud Init section and clone the template. This will confirm if the password is applied correctly in the system.
 
|}
 
|}
 
{|  
 
{|  
|style="padding: 0px 0px 30px 15px;"|33. '''The Proxmox VE VPS For WHMCS module is fully compatible with all versions of Proxmox VE that are actively supported by Proxmox.''' <br/>Ensure your Proxmox VE version is within its [https://forum.proxmox.com/threads/proxmox-ve-support-lifecycle.35755/ official support lifecycle] to guarantee compatibility.
+
|style="padding: 0px 0px 30px 15px;"|32. '''The Proxmox VE VPS For WHMCS module is fully compatible with all versions of Proxmox VE that are actively supported by Proxmox.''' <br/>Ensure your Proxmox VE version is within its [https://forum.proxmox.com/threads/proxmox-ve-support-lifecycle.35755/ official support lifecycle] to guarantee compatibility.
 
|}
 
|}
<!--
 
{|
 
|style="padding: 0px 0px 20px 15px;"|21. You can allow your clients to provide their own password to the VM when '' 'Cloud-init' '' is used. <br/> Simply, add this custom field in the '' 'Custom Fields' '' tab of the product configuration and remember to tick the '' 'Show on Order Form' '' option. <br/>
 
<pre> cipassword|Password </pre>
 
|}-->
 
  
 
=Update Instructions=
 
=Update Instructions=
Line 4,123: Line 4,393:
 
==Module Upgrade From V3.X to V4.X==
 
==Module Upgrade From V3.X to V4.X==
 
{|
 
{|
|style="padding: 10px 0px 5px 15px;"|'''Upgrading from version 3.X to 4.0? '''<br/>
+
|style="padding: 10px 0px 30px 15px;"|'''Upgrading from version 3.11.1 to 4.0? '''<br/>
Please note that version '''4.0 is currently in the beta phase'''. We highly recommend installing it in a '''development environment''' first, testing the new unified functionality, and sharing your feedback, which is greatly appreciated.<br/> Your input will help us quickly finalize and release a stable version of the module.<br/>
+
  
 
As part of the upgrade, the product has undergone a '''name change''', and the license file has been '''relocated to the addon'''.<br/>
 
As part of the upgrade, the product has undergone a '''name change''', and the license file has been '''relocated to the addon'''.<br/>
'''''Important:''' You will need to '''reissue your license''' for the changes to take effect.''
+
'''''Important:''' You will need to '''reissue your license''' for the changes to take effect.''<br/>
 +
<br/>
 +
'''The migration tool works reliably only if your most recently used version is 3.11.1. ''' <br/>
 +
If you are using an earlier version and plan to upgrade to 4.0, please update to 3.11.1 first.
  
At this stage, '''no automatic migration tool is available'''. This means that '''products and their module settings need to be configured from scratch'''.<br/> However, it is possible to import existing virtual machines of the '''cloud type''' into the module once a new product is created.<br/>
+
'''''Important:'''''<br/>
 +
When updating the module to version 4.1.x and higher, it is highly recommended to first update to the '''4.0 stable release'''. <br/>
 +
As explained in the module [https://www.docs.modulesgarden.com/How_To_Update_WHMCS_Module#Updating_Major_Versions update guide], you should '''never skip major versions''' during the update process.<br/>
 +
Skipping major versions may result in missing updates, installation errors, or compatibility issues.
 
|}
 
|}
 +
===Automatic Migration Tool===
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|To do this, simply open the desired product page in the admin area and click the '''"Import Virtual Machine"''' button, as shown in the screenshot below.
+
|style="padding: 10px 0px 5px 15px;"|Products and their module settings will be migrated from your current installation using the new automated process.<br/>
 +
Follow these steps:<br/>
 +
 
 +
'''1'''. Update the module following our standard procedure described here: [https://www.docs.modulesgarden.com/How_To_Update_WHMCS_Module Update Instructions].<br/>
 +
 
 +
'''''Important:''' Please ensure that your license file is updated, as the module name has changed.''<br/>
 +
 
 +
'''2.''' Before running the migration command, '''make sure that all configured Proxmox nodes are reachable and responsive.''' If any node is unavailable, the migration may fail due to a timeout.<br/>
 +
 
 +
'''3.''' Once all update steps are completed and all nodes are confirmed operational, run the migration cron command. <br/>You can find your personalized command in: ''Addons → Proxmox VE VPS & Cloud → Settings → General Settings → Cron job for module migration from v3 to v4''<br/>
 +
 
 +
'''Command:'''
 +
php -q /yourWHMCS/modules/addons/ProxmoxVeVpsCloud/cron/cron.php migration:v3_v4 
 +
 
 +
'''4.''' Wait for the migration process to complete. Once finished, verify that all data has been transferred correctly.<br/>
 +
 
 +
'''5.''' After migration, go to the product’s module settings and make sure to configure the required fields: '''Default Application Group''' and '''Default Application'''. These fields are new and must be set.<br/>
 +
To create application entries, navigate to the Addon → [[#App_Templates|App Templates]] section.<br/>
 +
 
 +
Once configured, you can start using the new version of the module.<br/>
 +
<br/>
 +
'''''Note:''' If you were testing the 4.0.0 beta version of the module and wish to update to the stable release, please run the migration cron to ensure all data is preserved.''
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC3_45_3.png]]
+
|style="padding: 0px 0px 30px 15px;"|'''Console Steps'''<br/>
 +
 
 +
For your reference, here is a breakdown of the actions performed during the cron job execution:
 +
* Creating database tables
 +
* Migrating database tables
 +
* Updating product configuration
 +
* Transferring existing virtual machine data to ''ProxmoxVeVpsCloud_Vm'' database table
 +
* Updating server types
 +
* Updating product types
 +
* Generating App Templates
 +
* Updating App Templates configurable options ''('Templates' and 'ISO Images)'''
 +
* Adding app templates info to ''ProxmoxVeVpsCloud_Vm'' database table
 +
* Completing the migration
 +
<br/>
 +
'''''Note:''' The migration is performed within a '''database transaction'''.<br/> This means that if any error occurs during the process, all changes will be automatically rolled back to the pre-migration state to ensure your system remains intact.''
 +
|}
 +
 
 +
===Import Existing Virtual Machines===
 +
{|
 +
|style="padding: 10px 0px 15px 15px;"|Import existing virtual machines into the module once a new product is created.
 +
To do this, simply open the desired product page in the admin area and click the '''"Import Virtual Machine"''' button, as shown in the screenshot below. <br/>
 +
 
 +
'''''Note:''' The module allows you to easily import VM into your product; this feature is supported for both VPS and Cloud type products.''
 +
 
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PVC4_45_3.png]]
 
|}
 
|}
 
{|
 
{|
Line 4,146: Line 4,469:
  
 
=Common Problems=
 
=Common Problems=
 +
 +
<h4 style="color: #ff0000; font-weight:bold; text-align:center;">This section is currently being updated, you may encounter broken links or outdated descriptions.<br/>
 +
Please accept our apologies for any inconvenience.
 +
</h4>
 +
 
{|
 
{|
 
|style="padding: 10px 0px 10px 15px;"|'''1. When you have problems with connection, check whether your SELinux or firewall does not block ports.'''
 
|style="padding: 10px 0px 10px 15px;"|'''1. When you have problems with connection, check whether your SELinux or firewall does not block ports.'''
Line 4,155: Line 4,483:
 
Afterward, proceed to the client's hosting and run '' 'Change User Role' '' on it.<br/>
 
Afterward, proceed to the client's hosting and run '' 'Change User Role' '' on it.<br/>
  
To change the user role for all clients, please use the '' 'Cron job users synchronization (run only once)' '' cron command.<br/> You will find it in the '' 'Proxmox Addon' → 'General Settings'.''
+
To change the user role for all clients, please use the '' 'Cron job for users synchronization (run only once)' '' cron command.<br/> You will find it in the '' 'Proxmox VE VPS & Cloud Addon' → 'Settings' → 'General Settings'.''
 
|}
 
|}
 
{|
 
{|
Line 4,179: Line 4,507:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 5px 15px;"|7. Once you have updated your Proxmox VPS For WHMCS to Proxmox VPS For WHMCS V2.0.0, it is always required to save your product configuration<br/> in the module settings again.
+
|style="padding: 0px 0px 5px 15px;"|7. Error: "Only root can set 'serial0' config".<br />
|}
+
{|
+
|style="padding: 0px 0px 5px 15px;"|8. The current disk usage for the KVM virtualization type is not properly displayed.<br/>This is due to API limitations that lead to returning the incorrect value, which is always set to '' '0' ''.
+
|}
+
{|
+
|style="padding: 0px 0px 5px 15px;"|9. If you want to use Cloud-Init on Debian, we recommend using the Cloud-Init's version 18.2 or later to avoid assorted problems occurring in previous versions.
+
|}
+
{|
+
|style="padding: 0px 0px 5px 15px;"|10. Error: "Only root can set 'serial0' config".<br />
+
 
'''Solution:''' Turn off the Xterms.js console in the product configuration.
 
'''Solution:''' Turn off the Xterms.js console in the product configuration.
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 5px 15px;"|11. Error "Parameter verification failed. ([maxfiles] - Only root may set this option.)"<br/>
+
|style="padding: 0px 0px 5px 15px;"|8. Error "Parameter verification failed. ([maxfiles] - Only root may set this option.)"<br/>
 
'''Reason:''' The user is other than "root" or the server authentication is set to Proxmox VE.<br />
 
'''Reason:''' The user is other than "root" or the server authentication is set to Proxmox VE.<br />
 
'''Solution:''' In the server configuration, set the root details, and select PAM as the authentication type.
 
'''Solution:''' In the server configuration, set the root details, and select PAM as the authentication type.
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 5px 15px;"|12. Error "Node for IP Address 10.10.10.10 not found"<br/>
+
|style="padding: 0px 0px 5px 15px;"|9. Error "Node for IP Address 10.10.10.10 not found"<br/>
 
'''Reason:''' An interface with the IP Address 10.10.10.10 cannot be found.<br/>
 
'''Reason:''' An interface with the IP Address 10.10.10.10 cannot be found.<br/>
 
'''Solution:'''  You need to provide your private IP Address node in the '' 'Assigned IP Addresses' '' field in the server configuration in your WHMCS.
 
'''Solution:'''  You need to provide your private IP Address node in the '' 'Assigned IP Addresses' '' field in the server configuration in your WHMCS.
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 10px 15px;"|13. Please remember that the disk size cannot be downgraded. Such a possibility is '''not''' supported.
+
|style="padding: 0px 0px 10px 15px;"|10. Please remember that the disk size cannot be downgraded. Such a possibility is '''not''' supported.
 
|}
 
|}
  
 
{|
 
{|
|style="padding: 0px 0px 10px 15px;"|14. Error: "Cannot clone to non-shared storage 'local"
+
|style="padding: 0px 0px 10px 15px;"|11. Error: "Cannot clone to non-shared storage 'local"
 
'''Reason:''' Option '' 'Search For Templates On All Nodes' '' is enabled in the product configuration under KVM configuration. <br/>
 
'''Reason:''' Option '' 'Search For Templates On All Nodes' '' is enabled in the product configuration under KVM configuration. <br/>
 
'''Solution:''' Keep the above option disabled as shown on the screen. <br/>
 
'''Solution:''' Keep the above option disabled as shown on the screen. <br/>
Line 4,218: Line 4,537:
  
 
It is important  to keep every template named the same on every node, otherwise cloning will not work either, eg.:<br/>
 
It is important  to keep every template named the same on every node, otherwise cloning will not work either, eg.:<br/>
'''''node1:''' Ubuntu, CentOS, Debian''<br/>'''''node2:''' Ubuntu, CentOS, Debian'' <br/>
+
'''''node1:''' Ubuntu, CentOS, Debian''<br/>'''''node2:''' Ubuntu, CentOS, Debian''
 
+
<!--If the '' 'Search For Templates On All Nodes'' ' option is enabled, the module searches for KVM templates from all nodes and lists them during reinstallation. <br/>If the end-user chooses a template that is on a node other than his machine, then he will get an error: ''' '' 'Cannot clone to non-shared storage 'local' '' ''' <br/>
+
 
+
If the templates are set to local storage, their cloning to another node is impossible. The module itself will not detect whether a given template is local or shared. <br/>If the option is off, then the module looks for templates only on the node on which the machine is. -->
+
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 10px 15px;"|15. Error: "Nameserver '%' cannot be resolved"<br/>
+
|style="padding: 0px 0px 10px 15px;"|12. Error: "Nameserver '%' cannot be resolved"<br/>
 
'''Reason:'''  The nameserver IP must be provided for the virtual machine of LXC configuration type.<br/> By default, the module uses the content provided by the client during order, eg. ns1, then WHMCS completes the nameserver with a domain. <br/>If the nameserver field is left empty or the client orders a new domain, the system is not able to process the data correctly and create a full address. <br/>
 
'''Reason:'''  The nameserver IP must be provided for the virtual machine of LXC configuration type.<br/> By default, the module uses the content provided by the client during order, eg. ns1, then WHMCS completes the nameserver with a domain. <br/>If the nameserver field is left empty or the client orders a new domain, the system is not able to process the data correctly and create a full address. <br/>
 
'''Solution:''' Enable the '' 'Use Server Nameservers' '' option in the product's configuration or manually correct the nameserver per the order. <br/>
 
'''Solution:''' Enable the '' 'Use Server Nameservers' '' option in the product's configuration or manually correct the nameserver per the order. <br/>
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 10px 15px;"|16. Error: "SQLSTATE[42S02]: Base table or view not found: Table 'ProxmoxAddon_ServerUsage' doesn't exist"<br/>
+
|style="padding: 0px 0px 10px 15px;"|13. Error: "SQLSTATE[42S02]: Base table or view not found: Table 'ProxmoxAddon_ServerUsage' doesn't exist"<br/>
 
'''Reason:''' The ''ProxmoxAddon_ServerUsage'' table has not been created properly because the ''tblservers'' table is on a different engine than "InnoDB"<br/>
 
'''Reason:''' The ''ProxmoxAddon_ServerUsage'' table has not been created properly because the ''tblservers'' table is on a different engine than "InnoDB"<br/>
 
'''Solution:''' Change the engine to "InnoDB", deactivate the proxmox addon and then activate it again. The missing table will be created.
 
'''Solution:''' Change the engine to "InnoDB", deactivate the proxmox addon and then activate it again. The missing table will be created.
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 10px 15px;"|17. The ''Move Product/Service'' action is not supported by the Proxmox VE VPS For WHMCS module.<br/> This is due to WHMCS limitations, and the fact that there are no hooks that would allow to catch such an event.
+
|style="padding: 0px 0px 10px 15px;"|14. Error: "([boot] - invalid format - format error boot.order: invalid format - invalid boot device 'c')"<br/>
|}
+
{|
+
|style="padding: 0px 0px 10px 15px;"|18. Error: "([boot] - invalid format - format error boot.order: invalid format - invalid boot device 'c')"<br/>
+
 
Solution: Edit the boot order in any of the templates to ensure the boot order is saved in a new format ''(after the change you may go back to the previous order)''  
 
Solution: Edit the boot order in any of the templates to ensure the boot order is saved in a new format ''(after the change you may go back to the previous order)''  
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 10px 15px;"|19. In case you encounter any problems with the '' 'Guest Agent','' please first ensure that the service is active in the machine's operating system. <br/>
+
|style="padding: 0px 0px 10px 15px;"|15. In case you encounter any problems with the '' 'Guest Agent','' please first ensure that the service is active in the machine's operating system. <br/>
 
You may use the following command in PowerShell to check the status:  
 
You may use the following command in PowerShell to check the status:  
 
   Get-Service QEMU-GA
 
   Get-Service QEMU-GA
Line 4,249: Line 4,561:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 30px 15px;"|20. Error: "SQLSTATE[HY000] [2002] php_network_getaddresses: getaddrinfo for proxydb failed: Temporary failure in name resolution"<br/>
+
|style="padding: 0px 0px 10px 15px;"|16. Error: "SQLSTATE[HY000] [2002] php_network_getaddresses: getaddrinfo for proxydb failed: Temporary failure in name resolution"<br/>
 
Solution: Make sure there are no old volumes or duplicate .env files present.''  
 
Solution: Make sure there are no old volumes or duplicate .env files present.''  
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 15px;"|'''17. Module integration notice'''<br/>
 +
The current 4.0.x version is not yet integrated with the following modules. These integrations will be restored in upcoming updates:<br/>
 +
* Products Reseller For WHMCS 
 +
* Server Monitoring For WHMCS
 
|}
 
|}

Latest revision as of 11:02, 15 October 2025

Important: Please read the upgrade guide before updating to the stable 4.0 version.
This release introduces significant changes, including a module name change and a new license file location within the addon.
Thank you for your understanding!

Contents

[edit] About Proxmox VE VPS & Cloud For WHMCS

Proxmox VE VPS & Cloud For WHMCS is a powerful module that combines the features of Proxmox VE VPS and Proxmox VE Cloud into a single, all-in-one solution.
It allows you to automatically provision virtual servers and give clients the flexibility to create, remove, and resize their instances within defined resource limits.
Your customers can manage backups, firewall settings, and access noVNC, SPICE, or Xterm.js console, directly in WHMCS.

ModulesGarden is official Proxmox Solution Partner and this module is recommended by Proxmox Server Solutions GmbH.

  • Admin Area Features:
✔ Create/Suspend/Unsuspend/Terminate Service:
✔ VPS Type Product With Single VM Machine
✔ Cloud Type Product With Multiple VM Machines Created Within Defined Limits
✔ Create/Terminate User Account
✔ Change Package - Supports Configurable Options
✔ Reconfigure Server Network
✔ Import/Detach VM Machine To/From WHMCS Product
✔ Boot/Reboot/Stop/Shutdown Server
✔ Change User Role
✔ Access noVNC, SPICE And Xterm.js Console
✔ Migrate Server Between Nodes In The Same Cluster
✔ Reinstall Server
✔ Change Server Hostname, ISO Image, Boot Devices And SSH Public Key
✔ View Server Status, Details And Statistics
✔ View Graphs - With Option To Change Time Scale of MRTG Graphs
✔ Display Disk And Bandwidth Usage Of Each Product
✔ Display CPU And Memory Usage Of Each Product
✔ Display IP Sets (KVM)
✔ Auto Node - Automatically Create VM On Node With Most Free Space
✔ Configure Client Area Features Per Product
✔ Configure Network And Private Network Settings With SDN Support
✔ Import IP Address To Hosting IP Addresses Table
✔ Return IP Address To IP Addresses Subnet
✔ Add Additional IP Address To VM
✔ Add Additional Disks Storage To VM (KVM)
✔ Enable Qemu Guest Agent (KVM)
✔ Enable Backups Routing
✔ Enable Auto VM Backups Before Reinstallation
✔ Enable Load Balancer
✔ Receive Notifications About VM Upgrades And Creation Failures
  • Proxmox Addon Features:
✔ Display Servers:
✔ List Per VPS And Cloud
✔ VMs List
✔ Clusters List
✔ Cleaner - Manage VM Not Existing In Your WHMCS
✔ Templates - Convert KVM VPS To KVM Template
✔ Settings
✔ Groups
✔ Recovery VM Configurations List With Export To Backup File
✔ Task History
✔ Statuses, Resources Usage, IP Assignments And Details
✔ Manage Public And Private IP Addresses Per Server/VLAN/Tag/Node/Bridge:
✔ IPv4 Addresses
✔ IPv6 Addresses
✔ IPv6 Subnets
✔ View Logs Of IP Assignment Changes
✔ Configure App Templates:
✔ Applications
✔ KVM/LXC Templates
✔ ISO Images
✔ KVM/LXC Archives
✔ Create And Manage Custom Cloud-Init Scripts Per App Template
✔ Configure High Availability Settings Per App Template
✔ Create Application Groups And Assign App Templates
✔ Define VM IDs Ranges Per Server
✔ Set Minimum VM ID For Product Without ID Ranges Defined
✔ Configure Resource Weights For Load Balancer Prioritization
✔ Configure Tasks Repetition Threshold And Email Notifications
✔ Configure Backup Tasks Limitation And File Restoration Settings
✔ Configure Console Proxy For Multiple Or Per-Node Connections
✔ Set Admin Area And Proxmox VE Widget Features
✔ Configure Scheduled Backups And Firewall
✔ View And Manage Logs
✔ View Queue Of Scheduled Tasks
✔ Configure Cron Scheduler Settings
✔ Customize Module Language Files With "Translations" Tool
✔ Manage Media Library With Logotypes For App Templates
✔ View Backup Tasks, Virtual Machine And Resource Usage Statistics
  • Proxmox VE Widget
✔ View Faulty VM Deployments
✔ View Waiting And Failed Tasks
✔ View Cluster Remaining Resources
✔ View Node Resources
  • Client Area Features:
✔ Create/Manage/View Server Status, Details And Statistics:
✔ VPS Type Product With Single VM Machine
✔ Cloud Type Product With Multiple VM Machines Created Within Available Limits:
✔ Define Machine Settings:
✔ Name
✔ Type
✔ Description
✔ Define Machine Parameters:
✔ Location
✔ Sockets (KVM)
✔ Cores (LXC)
✔ vCPU (KVM)
✔ CPU Priority
✔ VM RAM
✔ SWAP (LXC)
✔ Disk Size
✔ Default User (KVM)
✔ Password
✔ SSH Key
✔ Search Domain (KVM)
✔ Name Servers (KVM)
✔ Add Virtual Networks
✔ Add Additional Disks
✔ Start/Reboot/Stop/Shut Down/Delete Server
✔ Reconfigure Server Network
✔ Access noVNC, SPICE And Xterm.js Console
✔ Change Server Hostname, ISO Image, Boot Devices And SSH Public Key
✔ View And Edit Public SSH Key (KVM)
✔ Download Public And Private SSH Keys (LXC)
✔ Create/Restore/Delete Backups Of Current Server
✔ Manage Backups Within Defined Limits (Max Number And Size Of Files)
✔ Restore Backups From:
✔ Any Owned Server
✔ Proxmox Backup Server (PBS)
✔ Restore Backups Of:
✔ Selected Single Files And Directories With Option To Download Them (PBS)
✔ Full Server Backups
✔ Manage Backup Schedules Within Defined Limits (Max Number And Size Of Files)
✔ Protect Selected Backups From Manual Deletion And Backups Routing
✔ Add And Manage Additional Disks
✔ Manage Firewall Rules And Options
✔ View Resources Usage Graphs - With Option To Change Time Scale of MRTG Graphs:
✔ CPU
✔ Memory
✔ Network Traffic
✔ Disk I/O
✔ View Network Devices, Manage Private Interface And Attach Servers
✔ Reinstall Server Using Templates (KVM) And ISO Images
✔ Send Email Notifications When Server Exceeds Resource Thresholds:
✔ Network Traffic
✔ CPU Usage
✔ Memory Usage
✔ Disk Read And Write Speed
✔ Monitor Server Health (Requires Server Monitoring For WHMCS Integration):
✔ Create Server Monitoring Checks
✔ View Check Result Logs
✔ View Successful And Failed Checks Graphs
✔ Create Server Snapshots:
✔ Manually
✔ Automatically:
✔ Every Number Of Hours
✔ Each Specified Day
✔ View Tasks History
✔ Manage VM Power Tasks To Automatically Start/Stop/Reboot Server At Specified Time
✔ Display CPU, Memory, Disk And Bandwidth Usage
✔ Choose Server Resources While Ordering And Upgrade/Downgrade Them Freely
✔ Convert KVM VPS To KVM Template ("Cloud" Type Product)
  • Configurable Options:
✔ KVM For "VPS" Product Type:
✔ Additional Disks Space (With Configurable Storage, Units And Size)
✔ Amount of RAM
✔ Application
✔ Backup Files
✔ Backups Size
✔ Bandwidth
✔ CPU Cores
✔ CPU Sockets
✔ CPU units for a VM
✔ Custom Cloud-Init Configuration
✔ Disk Space
✔ Download Backup Files
✔ IPv4 Addresses
✔ IPv6 Addresses
✔ IPv6 Subnets
✔ Limit Of CPU
✔ Managed View
✔ Network Rate
✔ OS Type
✔ Private Network
✔ Protected Backup Files
✔ Restore Backup Files
✔ Server Monitoring
✔ Snapshot Jobs
✔ Snapshots
✔ Storage Disk Space
✔ TPM
✔ Tag
✔ VCPUs
✔ KVM Limits For "Cloud" Product Type:
✔ Additional Disk Space
✔ Backups Files Limit
✔ Backups Size
✔ Bandwidth
✔ CPU Cores
✔ CPU Limit
✔ CPU Sockets
✔ CPU Units Limit
✔ IPv4 Addresses
✔ IPv6 Addresses
✔ IPv6 Subnets
✔ Memory
✔ Network Rate
✔ Network Rate
✔ Snapshot Jobs
✔ Snapshots
✔ Storage
✔ Storage Disk Space
✔ VCPUs
✔ Virtual Networks
✔ LXC For "VPS" Product Type:
✔ Additional Disks Space (With Configurable Storage, Units And Size)
✔ Amount of RAM
✔ Amount of SWAP
✔ Application
✔ Backup Files
✔ Backups Size
✔ Bandwidth
✔ CPU Cores
✔ CPU units for a VM
✔ Disk Space
✔ Download Backup Files
✔ IPv4 Addresses
✔ IPv6 Addresses
✔ IPv6 Subnets
✔ Limit Of CPU
✔ Managed View
✔ Network Rate
✔ Archive
✔ Network Rate
✔ Private Network
✔ Protected Backup Files
✔ Restore Backup Files
✔ Server Monitoring
✔ Snapshot Jobs
✔ Snapshots
✔ Storage Disk Space
✔ Tag
✔ LXC Limits For "Cloud" Product Type:
✔ Additional Disk Space
✔ Backup Files Limit
✔ Backups Size
✔ Bandwidth
✔ CPU Limit
✔ CPU Units Limit
✔ IPv4 Addresses
✔ IPv6 Addresses
✔ IPv6 Subnets
✔ Memory
✔ Network Rate
✔ SWAP
✔ Snapshot jobs
✔ Snapshots
✔ Storage
✔ Storage Disk Space
✔ VCPUs
✔ Virtual Networks
  • General Info:
✔ Supports Cloud-Init (KVM)
✔ Supports PVE, PAM And API Token Authentication
✔ Supports KVM And LXC Virtualization
✔ Supports Proxy For Proxmox Console Connections
✔ Integrated With Advanced Billing For WHMCS - Actual Server Resource Usage Billing
✔ Integrated With IP Manager For WHMCS - Complete Control And Easy Assignment Of IP Subnets (LXC) (temporarily unavailable)
✔ Integrated With Products Reseller For WHMCS - End-To-End Solution For Products And Servers Reselling (temporarily unavailable)
✔ Integrated With Server Allocator For WHMCS - Automatic Assignment Of Most Suitable Servers To Products
✔ Integrated With Server Monitoring For WHMCS - Monitor Server Health From Dedicated Client Area Section
✔ Fully Integrated With Lagom WHMCS Client Theme
✔ Multi-Language Support
✔ Supports Proxmox VE 8.X And 9.X
✔ Supports IPv4 And IPv6
✔ Supports PHP 8.3 Back To PHP 8.1
✔ Supports WHMCS Themes "Six" And "Twenty-One"
✔ Supports WHMCS V8.13 Back To WHMCS V8.10
✔ Requires ionCube Loader V14 Or Later
✔ Easy Module Upgrade To Open Source Version

[edit] Installation and Configuration

This tutorial will show you how to successfully install and configure Proxmox VE VPS & Cloud For WHMCS.

We will guide you step by step through the whole installation and configuration process.

[edit] Installation

This guide will walk you through the installation and initial setup of the Proxmox VE VPS & Cloud For WHMCS.

Follow the steps below to properly install the module and prepare it for use in your WHMCS system.

1. Log in to our client area and download the module.
PVC 1.png
2. Extract the package and upload the files into the main WHMCS directory.

The content of the package to upload should look like this.

PVC 2.png
Warning: The next step is important, make sure you do not skip it!
3. Open 'UploadOnProxmoxServer' and upload the content of the proper version on all Proxmox Virtual Environment servers into the '/' path.
You should upload these files not only during the first installation of the module but also each time you update it.

Note 1: If the version of the Proxmox server you are using is not available, choose the package with the highest version number that is lower than the one you are currently using.
Note 2: If you wish to allow noVNC consoles, you need to configure a product using the PVE realm and set user permissions to 'PVEVMUser.'
Important: Open folder UploadOnProxmoxServer/5.2-10 and upload content on all your proxmox servers. Scripts must be updated on proxmox server v2.6.0 to allow Xterm.js console work.

4. When you install Proxmox VE VPS & Cloud For WHMCS for the first time, you have to rename the 'license_RENAME.php' file.

The file is located in 'modules/addons/proxmoxVeVpsCloud/license_RENAME.php'. Rename it from 'license_RENAME.php' to 'license.php'.

PVC 2 1.png
5. In order to configure your license key, you have to edit the previously renamed 'license.php' file.

Enter your license key between the quotation marks as presented on the following screen.
You can find your license key in our client area → 'My Products'.
Important: If you have migrated from Proxmox VE VPS or Proxmox VE Cloud VPS, please ensure that your license file is updated, as the module name has changed.

PVC4 2 4.png
6. In the next step, set up the 'storage' folder as recursively writable.

This folder is available at your_whmcs/modules/addons/proxmoxVeVpsCloud/ location.

PVC 2 5.png

[edit] Activation of Proxmox VE VPS & Cloud Addon

7. Firstly, activate the Proxmox VE VPS & Cloud addon.

To do so, log in to your WHMCS and navigate to 'System Settings' 'Addon Modules'. Find 'Proxmox VE VPS & Cloud' and press 'Activate'.

PVC 2 6.png
8. In the next step, you need to permit access to this module.

To do so, click on the 'Configure' button, tick 'Full Administrator' and press 'Save Changes'.

PVC 2 7.png

[edit] Configuration of Server

9. Now, we will show you how to configure a new product.

Go to 'System Settings' 'Servers' and press the 'Add New Server' button.

PX2 7.png
10. Next, enter your server name and IP address. You may add any port in the following format: "IpAddress:Port" , that is: 10.10.10.1:8006.

Enter the username and password, and choose the authentication type from 'Authentication' and 'Proxmox VE VPS & Cloud' from the 'Type' dropdown menus. Save changes afterward.

Supported authentication methods:

  • Linux PAM standard authentication
  • Proxmox VE authentication server
  • API Tokens

In the case of API Tokens, after generating a token in the Proxmox panel, you will receive two values: Token ID and Secret.
Use the Token ID as the Username and the Secret as the Password.

Important: For proper module functionality, use API tokens with full access permissions. Limited scopes may block some API requests required by the module.

Note: When using API Tokens, the module cannot change user passwords. This limitation comes from the Proxmox API itself, and while it has minimal impact on functionality, it is worth being aware of.

Important: If you encounter connection issues, ensure the WHMCS server can reach your Proxmox host. For more information, refer to this article.

PVC2 8.png
11. Time to create a server group. To do so, click on 'Create Server Group'.
PVC2 9.png
12. Enter the name, click on your previously created server, press 'Add' and afterward 'Save Changes'.
PVC2 10.png

[edit] Using Proxmox Clusters

When configuring the connection between Proxmox and WHMCS with the module, and especially when using a Proxmox Cluster with multiple nodes, there are two recommended approaches to adding servers.
Option 1: One WHMCS server entry for the entire cluster.
In this configuration, you create a single server in WHMCS that connects to one node of the Proxmox cluster.
  • Advantages:
    • Full support for the module’s Load Balancer feature - the system can select the optimal node automatically.
    • Centralized API communication.
    • Simpler configuration and product assignment.
  • Disadvantages:
    • If the selected node becomes unavailable (due to downtime or upgrade), all module operations will fail, even if the remaining nodes are still functional.
    • WHMCS cannot switch to a different node on its own.

Note: Use the load balancer in front of your Proxmox cluster. Then, enter the proxy IP address as the server IP in WHMCS.
This way, WHMCS always connects to an active node in the cluster. You should also provide the IP addresses of individual nodes under the "Assigned IPs" field in the server configuration.

Option 2: One WHMCS server per cluster node
With this method, each node is added to WHMCS as a separate server. Products are then assigned directly to specific nodes.
  • Advantages:
    • Better fault isolation: if a node fails, only products on that node are affected.
    • More control for setups where nodes have specific templates or storage access.
  • Disadvantages:
    • Load Balancer functionality is unavailable - the module cannot dynamically select the optimal node.
    • Product setup may be limited if a template or storage is not available on the assigned node.

Note: If you are using Cloud-Init scripts or App Templates, be sure that the appropriate storage is accessible on the node the product is assigned to. Otherwise, provisioning may fail.

Choose the setup that best matches your infrastructure, storage model, and reliability goals.

[edit] Configuration of Product

13. In order to create and configure a product, go to 'System Settings' 'Products/Services' .

Click on 'Create a New Group'.

PXC2 12.png
14. Enter a product group name and press 'Save Changes'.
PX2 13.png
15. When you have a product group, you can assign your product to it.

To create a product, click on 'Create a New Product'.

PX2 14.png
16. Afterward, choose your product group from dropdown menus and point its type, enter your product name and choose Proxmox VE VPS & Cloud as a module name.
Press 'Continue'.

'Product Type' can be set to 'Server/VPS' but nameservers will need to be added later (here you can find instructions on how to remove them from your order template).
'Server/VPS' type can also be useful for a more complex display of IP address assignment. However, if this is not something you need, you can select 'Shared Hosting' .

PVC3 4.png
17. Now, go to the 'Module Settings' section and choose your previously created server group from the dropdown menu.

The page should reload automatically after the selection. If it doesn't, you may need to click 'Save Changes' .

PVC3 5.png
18. In the "General" part of the module settings, pick the most crucial settings that will define your product, these are:
  • Product Type - Select between VPS and Cloud.
  • Virtualization Type - You may choose between:
    • KVM - short form for Kernel-based virtual machines; used for Qemu (Quick Emulator), which is an open source hypervisor that emulates a physical computer
    • LXC - used for Linux Container as a lightweight alternative to fully virtualized virtual machines
  • Default Node - choose the default node from the dropdown menu.
    If you choose the Auto-Node as your 'Default Node', new virtual servers will be created on the least used node.
    An advanced tool is available for you to automatically manage the node selection with the best amount of resources. Read more about Load Balancer.
    Server-Node option assigns the VM to the specific Proxmox node configured in the WHMCS server settings (based on the server IP address). This means the VM will always be created on that particular node.
    Note:
    Remember that changing the node will always result in the replacement of the current configuration with the default one. Upon selecting the node, the current configuration should be saved automatically.
    If, for any reason, this does not happen, please press
    'Save Changes'.
  • Check Available Resources - Enable if you want the available resources to be checked before creating a new machine.
  • Reset Usage First Day of Month - If enabled, the usage will be automatically reset on the first day of the month.
PVC3 6.png
To create a virtual machine using a template, archive, or ISO image, make sure the App Templates are configured in the addon first.

This ensures that the correct image is available during VM creation. For details, see the App Templates section of the documentation.

[edit] VPS - KVM Virtualization Type

19. Setting the KVM virtualization type.

Before you start configuring the KVM virtualization, we highly recommend that you familiarize yourself with the following 'Qemu/KVM Virtual Machines' Proxmox Virtual Environment wiki article.

The basic fields required to create a virtual machine are filled in by default to make the initial setup simpler for you.

Start your product configuration in the 'Virtual Machine Configuration' panel, where you can set up machine resources and limits or assigned IP addresses.
Note that some fields can be left empty if you want to disable them or set as unlimited - read the tooltips for further guidance.

App Templates Configuration - To create your VM based on a template, archive, or ISO image, you must first configure the App Templates in the module's addon.
Once your applications and groups are set up there, you can select the desired template or archive in the product's Module Settings tab to be used during VM creation.
Please refer to the App Templates section of the documentation for detailed setup instructions.

PVC VPSkvm 1.png
Next, configure 'Network', 'Hard Disk', 'Backup' and so on. For KVM virtualization type, there is also the 'Guest Agent' section available.

Guest Agent is used to exchange information between the virtualization server and the operating system of your virtual machine.
Thanks to this, additional commands such as setting IP addresses and the user’s password can be executed in the guest system.
The 'Service Password', 'Service Hostname' and 'Configure Network' options work with Windows OS only.
If enabled, while creating a VM, the Guest Agent will set up the user’s hostname and password and configure the network automatically.

  • 'Guest Trim ' - enable and the guest-trim will be run after moving the disk or migrating the VM
  • 'FileSystems Freeze during Backup' - enable to allow freezing/thawing of guest filesystems during backup for consistency

Remember that you need to install the Guest Agent on your KVM template in order for the function to work properly. For more info, click here

PVC VPSkvm 2.png

[edit] VPS - LXC Virtualization Type

Setting the LXC virtualization type is very similar to KVM.

Before you start configuring the LXC virtualization, we highly recommend that you familiarize yourself with the following 'Linux Container' Proxmox wiki article.

Just as with KVM, the basic fields required to create a virtual machine are filled in by default to make the initial setup simpler for you.

Start your product configuration in the Virtual Machine Configuration panel, where you can set up such features as 'Default Storage', container resources and limits or the number of assigned IP addresses.
Note that some fields can be left empty if you want to disable them or set as unlimited - read the tooltips for more information.

App Templates Configuration - To create your VM based on a template, archive, or ISO image, you must first configure the App Templates in the module's addon.
Once your applications and groups are set up there, you can select the desired template or archive in the product's Module Settings tab to be used during VM creation.
Please refer to the App Templates section of the documentation for detailed setup instructions.

PVC VPSlxc 1.png
Next, configure 'Mount Point', 'Backup', 'Network' and so on.
PVC VPSlxc 2.png

[edit] Cloud - KVM Virtualization Type

Settings of the KVM virtualization type of a Cloud-type product.

There are a few sections underlined that need your attention. Please, complete carefully the 'KVM Configuration' , 'Additional Disks' , 'Client Area Features' sections.

App Templates Configuration - To create your VM based on a template, archive, or ISO image, you must first configure the App Templates in the module's addon.
Once your applications and groups are set up there, you can select the desired application (template, image or archive) in the product's Module Settings tab to be used during VM creation.
Please refer to the App Templates section of the documentation for detailed setup instructions.

As you can see, there are more options available. Look through them and decide which ones you want to modify and adjust to your and your clients' needs.
Do not forget about the Network section where you can determine a model, bridge, and rate limits of the network.
If you are going to allow your clients to manage their private networks, you have to select Private Bridge and set up VLAN TAG Range.

The Disk Space [GiB] field (and its corresponding configurable option) defines the total storage limit for all disks combined in a Cloud service.
By default, this limit applies to both the main disk and any additional disks.
Once separate configurable options for extra disks are created, the main "Disk Space" setting applies only to the primary disk, while each additional disk is governed by its own limit.

Once you make sure that the configuration is completed, click 'Save Changes'.

Important: Keep in mind that the root password is generated automatically for KVM virtualization upon its creation and reset.
If you want to set your own password on KVM virtualization, use the Cloud-Init option.

PVC CoudKVM 1.png
PVC CoudKVM 2.png

[edit] Cloud - LXC Virtualization Type

Settings of the LXC virtualization type of the Cloud-type product.

Firstly, complete the 'General' configuration and then proceed to the 'Main Configuration' , 'LXC Configuration' and 'Network' sections.

App Templates Configuration - To create your VM based on a template, archive, or ISO image, you must first configure the App Templates in the module's addon.
Once your applications and groups are set up there, you can select the desired application (template, image or archive) in the product's Module Settings tab to be used during VM creation.
Please refer to the App Templates section of the documentation for detailed setup instructions.

There are more options available, so you may easily modify the configuration of your products. Once you complete everything, click on the 'Save Changes' button.

PVC CoudLXC 1.png
PVC CoudLXC 2.png
PVC CoudLXC 3.png

[edit] Client Area Features

20. Finally, choose which client area features shall be available in the client area.
Enable the "Managed View" feature to make all virtual machine management options and actions visible to the administrator and hidden from the client.
PVC 3.png

[edit] Finalizing The Configuration

21. 'Hostname Generation' section allows you to configure automatic hostname creation for new virtual machines using a flexible pattern format.
  • Hostname Format - Define the pattern used to generate hostnames automatically. You can use the following variables:
    • {whmcsMainDomain} - the main domain set in WHMCS settings
    • {clientId} - the ID of the client who owns the service
    • {serviceId} - the unique WHMCS service ID
    • {orderId} - the ID of the order tied to the service
    • {rand} - a randomly generated string (controlled below)
    • {nextIncrementalValue} - a numeric value that increases with each generated hostname
      Example:
      client-{$clientId}-service-{$serviceId}-{$rand} could generate: client-104-service-312-x9h7kb
  • Next Incremental Value - This value is used in the {nextIncrementalValue} variable and automatically increases each time a hostname is generated.
    Example usage:
    vm-{nextIncrementalValue}vm-101, vm-102, etc.
  • Random Character Set - Defines the pool of characters used when generating the {rand} value. Leave the field empty to use the default set: abcdefghijklmnopqrstuvwxyz0123456789
  • Random Value Length - Sets how many characters will be included in the {rand} value. Leave empty or set to 0 to use the default length.
    Example:
    If length is set to 6 and format is vm-{rand}, output might be vm-f39b7a.
  • Override Domain - Enable this option to force the system to generate a hostname using the defined pattern, even when a domain name has already been set for the service.
PVC 3 0.png
22. Private Network Management - in order to allow clients to manage their private networks, set up the 'Network' and 'Private Network' sections properly.
  • Define 'Private Network Model'
  • Select 'Bridge' as well as 'Private Bridge' from the dropdown menus.
  • Enter ranges for VLAN TAG

Note: Configure these three options for the KVM and LXC virtualization.
If you skip this step, clients will not be allowed to add private networks.

Note2: For SDN Private Network type please refer to Tips section, point 12.

PVC 3 1.png
23. The next step is setting up the configuration of backups.

Define backup settings in the 'Backup' section through defining 'Storage' and enabling 'Backups Routing' .
Backups routing automatically removes the oldest backup when a new backup is created and the established backup limit is reached.
Additionally, you can limit the time period for storing backups by providing the number of days into the 'Backups Storing Period' field.
Furthermore, you can define the limit of firewall rules and the interface to apply the rules to.
Finish the configuration in the 'Module Settings' tab through pressing 'Save Changes'.

PVC 3 2.png
24. Set up server limits to control the size of created servers (Cloud-type products).
PVC 3 3.png
25. Afterward, you can create configurable options.

This step is optional - if you want to take it, start by selecting which of the configurable options you want to generate.

Note: It is advisable not to generate options that you do not plan to use, or in case you want their fixed values to be taken from the module settings, rather than being flexible.
Moreover, the configurable options differ between the KVM and LXC virtualization types, so create them separately if needed.

Note 2: There is also an Alternative Mode available (VPS product type only), which changes the way the configurable options values are verified and calculated.
Select single configurable options and their values will be summed with the default product configuration values instead of overwriting them.

More information about configurable options and their edition can be found here.
A clear division of configurable opinions available per product and virtualization type, please see the module features list.

PVC 3 4.png
PVC 3 5.png
26. At the end of the product configuration, you have to add a cron job as shown below (5-minute intervals are recommended).
php -q /your_whmcs/modules/addons/ProxmoxVeVpsCloud/cron/cron.php queue

Do not forget to replace 'your_whmcs' with your WHMCS root location. The cron can be also executed every single minute in order to perform the action more often.
In the Configuration of Addon settings, you will find a personalized command for the cron on your server as well as more possible crons to set up for execution.

Note: The queue command is also available in the addon’s Cron Scheduler.
This means you can automate its execution by simply setting up the central schedule cron task, which handles all recurring jobs configured within the scheduler.

For more details, see the Cron Scheduler section of this documentation.

You have just finished the installation and configuration of the product, congratulations! Be sure to follow the below addon configuration as well to learn how to set up additional features.

[edit] Configuration of Addon

27. Proceed to 'Addons' → 'Proxmox VE VPS & Cloud' → 'Settings' → 'General Settings' and set up the listed cron job.

The addon offers a convenient tool called Cron Scheduler that allows you to automate recurring jobs.
Configure the execution frequency for each regularly run cron job, then activate the main schedule job, it will handle the regular execution of all defined tasks.
For details, please refer to the Cron Scheduler section of this documentation.

  • Remove backups (every 24 hours suggested)
php -q /your_WHMCS/modules/addons/ProxmoxVeVpsCloud/cron/cron.php remove-backups
  • Scheduled backups (every 5 minutes suggested)
php -q /your_WHMCS/modules/addons/ProxmoxVeVpsCloud/cron/cron.php backup-schedules
  • Backups synchronization (every 5 minutes suggested)
php -q /your_WHMCS/modules/addons/ProxmoxVeVpsCloud/cron/cron.php backupSync
  • Migrate backup jobs to schedules (run once per product)
php -q /your_WHMCS/modules/addons/ProxmoxVeVpsCloud/cron/cron.php migrate-backup-jobs-to-schedules --product_id=PRODUCT_ID
  • VMs migration synchronization (every 5 minutes suggested)
php -q /your_WHMCS/modules/addons/ProxmoxVeVpsCloud/cron/cron.php migrateSync
  • Module migration from version 3 to version 4
php -q /your_WHMCS/modules/addons/ProxmoxVeVpsCloud/cron/cron.php migration:v3_v4
  • VMs power tasks (every 5 minutes suggested)
php -q /your_WHMCS/modules/addons/ProxmoxVeVpsCloud/cron/cron.php powerTasks
  • VM recovery synchronization (every hour suggested)
php -q /your_WHMCS/modules/addons/ProxmoxVeVpsCloud/cron/cron.php recoveryList
  • Remove snapshots (every 24 hours suggested)
php -q /your_WHMCS/modules/addons/ProxmoxVeVpsCloud/cron/cron.php remove-snapshots
  • Resources notifications (every 5 minutes suggested)
php -q /your_WHMCS/modules/addons/ProxmoxVeVpsCloud/cron/cron.php resourcesNotifications
  • Proxmox cloud-type products (RRD data) (optional, every hour suggested)
php -q /your_WHMCS/modules/addons/ProxmoxVeVpsCloud/cron/cron.php rrddata
  • Snapshot jobs (every 5 minutes suggested)
php -q /your_WHMCS/modules/addons/ProxmoxVeVpsCloud/cron/cron.php snapshots
  • Tasks synchronization (every 5 minutes suggested)
php -q /your_WHMCS/modules/addons/ProxmoxVeVpsCloud/cron/cron.php task
  • Update server usage (every 5 minutes suggested)
php -q /your_WHMCS/modules/addons/ProxmoxVeVpsCloud/cron/cron.php update-server-usage
  • Users synchronization (run once only)
php -q /your_WHMCS/modules/addons/ProxmoxVeVpsCloud/cron/cron.php users
  • VM names synchronization (run once only)
php -q /your_WHMCS/modules/addons/ProxmoxVeVpsCloud/cron/cron.php synchronize-vm-names
PVC 4.png
28. Fill in the General Settings configuration:
  • Minimum VM ID - Fill it in with a number that will be used as an ID of the first VM, the second VM will be assigned the next ID number.
  • VM ID Assignment Mode - Select how the VM ID should be assigned:
    • First Available ID - uses any currently free ID, including previously used, this option is selected by default.
    • Auto-Incrementing ID - assigns the next unused number until the limit is reached.
  • Tasks Limit - Define the limit of tasks that will be executed with a single cron run, just type in the required number into the field.
  • Turn on the 'Debug Mode' if you need to register module logs.
PVC 4 1.png
29. Adding a new IP address.

In order to create a new product with an IP address assigned, you have to add 'Dedicated IP ' to the 'IP Addresses' list in 'Proxmox VE VPS & Cloud' addon module.
To do so, go to 'IP Management' and press 'New IP Addresses'.
Note: You can add IPv4, IPv6 addresses and IPv6 subnets. The process is the same for all types.

PVC 4 2.png
30. Start with defining the IP address type, choose among: 'IPv4', IPv6' and 'IPv6 subnet'.

Then, depending on the selected type, provide:
For IPv4 and IPv6 addresses types

  • "Network Address" (eg: 192.168.1.0/24)
  • "Gateway"
  • "First IP Address" and "Last IP Address" - define the border from which and up to which of the IP address the generation (including the provided addresses)
PX2 23.png

For "IPv6 Subnet" address type

  • "Network Address" (eg: 2a00:1911:5::/64)
  • "Gateway"
  • 'Number of Subnets"
  • "CIDR"
  • "First IP Address" and "Last IP Address" - define the border from which and up to which of the IP address the generation (including the provided addresses)

Decide whether the created addresses will be private or not.

PX2 23 1.png
Move to the 'Details' tab. Choose a server from the 'Server' dropdown menu and define which virtualization it should be applied to through selecting it from the 'Virtualization' dropdown menu.

Remember to press the 'Confirm' button when ready.

PX2 23 2.png
31. You are now able to create a new product using the previously added IP address.

If you are using the KVM virtualization type, the client area with a successfully created product should look similar to the one on the screen below.
The assigned IP addresses should be displayed on the bottom panel according to the way you configured the IP pools. It looks quite similar in the case of the LXC virtualization type product.

PX4 24.png

[edit] Proxy Installation For Console Connection

A comprehensive guide detailing the installation, update instructions, and operational flow for the Proxmox Proxy application can be found in a dedicated article accessible through the following link.

We encourage you to refer to it for further insight into the Proxmox Proxy application.

The proxy feature can be looked on as an added security boost for your infrastructure.

It hides your Proxmox server so that your clients will not get to know its actual address when connecting to the server via the console in your system.
To work properly, the proxy must be accessible from both the public and private net as clients connect with the proxy from the public net, without the need to connect directly to proxmox.

Proxy must be connected with Proxomx server. To verify if the connection between these two is successful, you may run the following command:
 curl -v https://10.10.11.48:8006

where 10.10.11.48:8006 is the node IP address.

Before you begin the process of connecting the console to the server through a proxy, you need to download the proxy application file.

The file can be found under the following link after you have logged in to your ModulesGarden account.

1. Create a new VPS server, which you may run on a Proxmox server.

It is advised to use the KVM virtualization type.

Warning! The used VPS may NOT have any services running, such as: PHP, WebServer (e.g. apache, nginx) or MySQL server.

2. Configure the network on the virtual machine, make sure the network works correctly, to do so you may use the below command:
ping modulesgarden.com

If everything is fine, assure that basic server security settings have been established.
You may turn off login with a password and turn on login with a key, change the SSH port, set up firewalls etc.

3. Log into the machine on which you are going to set up proxy.
4. Install the docker engine and the docker compose:

https://docs.docker.com/engine/install/
https://docs.docker.com/compose/install/

5. Upload the application files into a proper directory, eg: /root/proxmox-proxy (create if needed).

Then unzip the files.

6. Move to the following catalog:
cd /root/proxmox-proxy  

Note that the exact directory depends on the previous step where you uploaded the files.

7. Purchase or generate your own SSL certificate, and then use the certificate to overwrite the following files: 'nginx/localhost.crt' and 'nginx/localhost.key' .
8. Find the 'example.env' file and rename it to '.env'.

Then open the just renamed '.env' file and provide a random set of signs to create the database and root passwords: DB_PASSWORD and MYSQL_ROOT_PASSWORD
These data will be automatically used when creating the database.

9. Run the below command:
docker-compose up --build -d
10. Move to docker container:
docker exec -it proxyphp bash 

and run the installation script:

php -q /var/www/html/installer.php install 

When ready, find the API Key and keep it safe, you will need it later on when pasting the data into the Proxmox Addon, see point 12 for details.

11. Next, copy your machine IP address to WHMCS. You may check the IP address using the below command:
ip a

Note: Remember to check the IP address in your virtual machine, not in the proxyphp container.

12. Configure the required proxy settings in the Proxmox addon in your WHMCS.

Go to: Addons → Proxmox VE VPS & Cloud Addon → Tools → Console Proxy.
Create a proxy connection by entering:

  • Name - any custom label for identification.
  • Host - full URI of the proxy, including protocol and port. This must match the proxy access details.
  • API Key - the API key generated during installation (see point 10).
PX4 4 2.png
Next, go to: Addons → Proxmox VE VPS & Cloud Addon → Settings → General Settings.

At the bottom, locate the Console Proxy section and select the desired connection from the Proxmox Proxy dropdown - includes all connections added in step above.
This selection works globally unless a separate proxy is selected per single node.

PX3 4 2.png
You can also assign a separate proxy to each node individually.
To do this, open the server details → Cluster tab → Node DetailsOther tab and assign a proxy there in the Proxmox Proxy dropdown.

If no proxy is set at the node level, the one selected in General Settings will be used by default.

PX4 4 3.png
13. Make sure the server works. In order to do so, please open the address: https://{vmip}:8443.

Remember to replace {vmip} with a valid virtual machine IP address, for example: https://192.168.8.113:8443/
When you see {"errors":["Invalid API Endpoint"]} it means that the server correctly responds.

14. Finally, try to open the noVNC console on your WHMCS Proxmox product to check if the proxy configuration is working properly.
Important: If your certificate expires in the meantime, you will need to buy/generate a new one and follow the below steps:
  • move to the '/root/proxmox-proxy catalog (the directory may differ depending on your setup)
  • replace the nginx/localhost.crt and nginx/localhost.key files
  • run the following command:
docker-compose up --build -d
Note: If you ever encounter an iconcube error while rerunning the 'docker-compose up' command, delete all local docker images related to your docker file using the following command and try again.
$ docker rmi -f $(docker images -a -q)
For instruction on how to react in case an update is required, please refer to the dedicated article including all details on the Proxmox Proxy application.

[edit] Configuring Servers Using Cloud-Init

If you are having trouble setting up DNS servers using Cloud-Init, this guide will help you resolve this issue quickly.

1. Enable the "Service Nameservers" option in your product configuration (Module Settings → Cloud-Init → Service Nameservers).
This option ensures that the IP addresses entered in the Nameserver fields in the service are correctly applied in Cloud-Init.

PVC 4 3.png
PX3 50 02.png
PX3 50 03.png
Note: The "Service Nameservers" option is only available for Server/VPS product types.
2. Use the "Use Server Nameservers" option (Module Settings → Miscellaneous → Use Server Nameservers).

This feature automatically populates the Nameserver fields with values from your server configuration. Only the first two fields from the server will be used.

PX3 50 04.png
PX3 50 05.png

[edit] Additional Storage Configuration

This is an extra option that allows for specifying additional parameters for additional disk drives.
Check how to set the product to allow clients to add disks with desired space, storage type and speed within configured limits.

Remember that the Additional Disks options in the module settings must be enabled.

1. Start with creating new selections for the "Additional Disk Space" configurable option (additionalDisksSpace|Additional Disk Space), note that you have to do that manually.

To create the configurable options, please remember to follow the below-presented pattern:

local-lvm:3 | Disk Local-LVM Storage: 3GB

Where local-lvm:3 cannot be modified, the name on the right can be freely adjusted and the unit changed.

2. Next, add an appropriate entry in the language file to display the configurable option in a user-friendly manner. Open the english.php file located in modules/servers/ProxmoxVPS/langs/english.php and find an empty string:

$_LANG['storage']['local'] = 'Local';
$_LANG['storage']['local-lvm'] = 'Local-lvm';  

Modify the configurable option name that is on the right from the '=' sign.

3. Consequently, clients are now given the option to add hard disk with the custom storage type.

PX3 60.png

[edit] Management

Proxmox VE VPS & Cloud allows your customers to manage their PVE accounts via the client area in your WHMCS system.

At the same time, you can monitor and manage each product from your WHMCS admin area.

[edit] Management of Addon

[edit] Servers Management

[edit] Server List

In 'Addons' 'Proxmox VE VPS & Cloud' 'Servers' 'Server List' you can find the configured Proxmox servers.

RAM details:

Assigned - the RAM assigned to the server (hosting services only)
Total - the full server RAM
Free - the difference between the Total and Assigned values

Suspended - the number of suspended accounts per size in MB E.g.: (1/500 MB) in case there is only one suspended account that takes up 500MB assigned to the Proxmox VPS server.

PX4 28.png
Through pressing the 'Edit' icon, you will be moved to the server edit page - see point 10 of the Server Configuration.

Press the 'More Details' icon, and you will obtain extended information on the selected server. Look below for more details.

[edit] VMs
The 'VMs' tab includes the list of virtual machines created on this server. Take a quick look at information on the domain, status, bandwidth, and IP addresses.

To view information about the VM, simply press the "More Info" icon located on the right side of the page.

PX4 29.png
Check the node and VMID:
PX2 29 1.png
[edit] Clusters
The next tab contains the list of clusters with information on uptime, VMS and resource limits, as well as CPU, SWAP, memory and disk usage data.

Important: Limits defined in this section are taken into account by the Load Balancer function. The Check Available Resources toggle is not affected by them.

PX4 29 2.png
Press the "Edit" icon to manage the node and its limits.
  • Allow To Create VM - if enabled, a VM can be created on this node
  • Virtual Machines Number - define the maximum number of VM that can be created on this node
  • Maximum Number of CPUs - set the top limit of CPUs on this single node
  • Maximum Disk Size - set the top storage size allowed on this node
  • Maximum RAM Size - set the maximum amount of RAM allowed on this node
  • Default Storage - select the default storage for the VM created on this node
  • Allowed Application Groups - If you select a group or more than one group here, the applications assigned to these groups will always create a VM on this node.
    Note that this option overrides the "Default Node" setting in Module Settings. You may leave this selection empty if you do not want to override the module settings configuration.

Setting node limits is crucial as creating virtual machines is largely based on them, once reached, a new virtual machine cannot be created on that node.

PX3 29 3.png
Specify the 'Tasks Limit' here to set the maximum number of permitted backup tasks for the node you are currently modifying.
PX3 29 4.png
Please bear in mind that limits placed in the above section overwrite the "Default Limit of Backup Tasks Per Node" value defined in the Addon → Settings → General Settings → Backup Tasks Limitation section.
PX3 29 4 0.png
In the last tab you may define the relation between the node and backup storage and their synchronization.
  • 'Backup Search Storages' - here you are allowed to define which storages will be searched through while running "backupSynch" cron job for backup creation and restoration purposes.
    This setting overwrites the product settings.
  • 'Alternative Backup Storage' - if you run out of space on the storage, an alternative storage pointed here will be used to create and store the backup.
    You still can restore backup from the old storage, but only if that is selected in the above "Backup Search Storages" selection.
  • 'Proxmox Proxy' - it is possible to assign a console proxy connection to this very node (every virtual machine created on this node) only.
    If you leave this field empty, the default proxy connection defined in the Addon → Settings → General Settings will be used for this node.
    Read more about console proxy connections.
PX3 29 5.png
Press 'Node Details' , and you will obtain all the summary and usage graphs:
PVC4 30 2.png
[edit] VM Cleaner
VM Cleaner allows you to track VMs existing only on your Proxmox server, and not in your WHMCS.
Consequently, you are allowed to sort and delete only those VMs that cannot be managed in your WHMCS system.
PX4 31 1.png
[edit] Templates
You can view the list of templates on this page. You can easily convert any KVM machine on your server to a template.

In order to convert a VM, press the 'Create Template' button.

PX4 31 3.png
Next, choose a VM that shall be converted.

Fill out the 'Description' field, and press 'confirm'.
Important: The selected VM will be destroyed in the process.

PX2 31 4.png
You may also delete unused templates here. Delete single templates or use the mass action feature to delete templates in bulk.
PX4 31 2.png
[edit] Server Settings
Here you can define the VM IDs range that will be used for newly created machines on this server. Please note that you need to enable the "Use VM Ranges" setting in the product configuration in order to use this feature.
To proceed, define the ID range and save changes.

Note: VM ID range allows you to sort created machines depending on the server they were created on.
SSH Data - fill out the SSH connection details (Host, User, Posrt, Password or Private Key) to allow to locate the IP addresses on the Proxmox server (Cloud-Init)
Snippet Storage - select the catalog where the file will be uploaded (Cloud-Init)

PX4 34.png
[edit] Node Groups
Under the 'Node Groups' subsection, you can create new groups and assign nodes to them.
PX4 34 1.png
Provide a name of your group and allot preferred nodes from the dropdown menu.
PX3 34 2.png
Now, navigate to the 'Module Settings' of your product and find the 'Miscellaneous' and 'Load Balancer' sections.
Firstly, provide the 'Minimum VMID' for a VM and then select one or more of the previously created groups.
PX3 34 3.png

[edit] Service List

In 'Addons' 'Proxmox VE VPS & Cloud' Addon 'Servers' 'Service List' you can find details of any Proxmox product.
PX4 35.png
Press the 'More Details' button to preview the node and VMID information.
PX2 35 1.png

[edit] Recovery VMs List

In 'Addons' 'Proxmox VE VPS & Cloud' Addon 'Servers' 'Recovery VM List' you can view details of the created machine.

Run the 'VM recovery synchronization' cron job to create and store full backups of VM configuration - you can find it in the point 25 of the configuration instructions.
Use the 'Export to File' button to save information in a TXT copy file.

PX4 36.png
Upon pressing the 'Details' icon, you will obtain the information on configuration, status, and DNS:
PX2 36 1.png
PX2 36 2.png
PX2 36 3.png

[edit] Task History

The "Task History" section includes the list of all module tasks with their most crucial details.
You may delete single tasks or use the mass action button to remove them in bulk.

Run the 'Tasks synchronization' cron job to synchronize the tasks, and view all tasks from the server - you can find it in the point 25 of the configuration instructions.

PX4 37.png

[edit] IP Management

[edit] IP Addresses

In the 'IP Management' tab, you can manage the IP addresses of Proxmox products.
You can create both single IP addresses (IPv4 and IPv6 are supported), and IP pools which then can be assigned to created VMs.

Important!: In order to create a virtual machine, you must previously add public IP addresses.
In case you do not own any public IP addresses in the database, you must previously enable the "cloud-init" option, only then it will be possible to create a VM with a private IP address.

PX4 30.png
When you create a new IP address or a pool, you may define:
  • private/public address
  • servers or nodes that will use them
  • virtualization types (different VMs will use different IP pools)

Note: please go back to point 27 of the addon configuration to learn more details about adding IP addresses.

PX2 30 1.png
PX2 30 11.png

[edit] IP Logs

The 'IP Logs' includes the history of the IP addresses that were removed by the admin and which are again available in the proxmox addon IP Management pool.

Keep in mind that only addresses that were automatically added when creating the VM. Removed IP addresses, that were the manually assigned, are not logged here.

PX4 30 0.png


[edit] App Templates

'App Templates' allow you to manage and ultimately provide KVM and LXC templates, archives and ISO images to your clients.

Prepare the templates in the 'Applications' tab and gather them into groups in the 'Groups' tab.
For clients to be able to install templates on their virtual machines, their product has to include an 'Application Group' and allow 'App Templates/Reinstallation' in the client area.

[edit] Applications

Read the guide carefully, as it contains crucial information on how to use "App Templates".

You can change the settings and have the guide collapsed by default. Clicking on the 'Additional Actions' button, select 'Options' and 'Collapse Guide'.

PVC 8.png
You can switch between KVM Templates, LXC Templates, ISO Images, KVM and LXC Archives by clicking on relevant tabs.
PVC 8 1.png
You can use the refresh button to download and later refresh templates from the server.
PVC 8 2.png
Once the items are loaded, you can use the action buttons to edit, duplicate or delete them from the list.

You can also use the mass action buttons to manage multiple templates at once.

PVC 8 3.png

[edit] Groups

With the templates ready, all that is left is to gather them into groups and include said groups into products.

Navigate to 'App Templates' 'Groups' and click on the 'Create' button.

PVC 9 0.png
Read the information, then provide the group with:
  • Name
  • Description
  • Items to include
PVC 9 1.png
You can use the action button and the mass action function to edit and delete groups.
PVC 9 2.png
For the client to use application templates, you must assign at least one group in the product’s module settings.

Navigate to the App Templates Configuration section and select the desired group(s) in the Default Application Group field.

Note 1: You can now select multiple application groups. During virtual machine creation, the system will display templates from all assigned groups.

Note 2: When reinstalling the VM, only applications from the group that contains the currently used image will be available for selection.

PVC 9 3.png
Make sure 'Reinstallation' section is enabled under 'Client Area Features'.
PVC 9 4.png

[edit] Advanced Configuration

App templates allow for even more in-depth management with the ability to create and edit custom applications.

See the examples below to learn about the most important options.

[edit] Adding Applications Manually
Manually add a single application, instead of loading all your applications at once.

1. Navigate to 'App Templates' 'Applications' and click on 'Create'.

PVC 7 0.png
2. To fetch available templates or ISO images, you can use the Proxmox VE API.

List all content on storage (ISO, templates, etc.):

GET /api2/json/nodes/{node}/storage/{storage}/content

Filter results using the content parameter:

  • content=iso – ISO Images
  • content=vztmpl – LXC container templates

List all VMs, containers, and other resources across the cluster:

GET /api2/json/cluster/resources  

You can filter the response by:

  • type: "qemu"
  • template: 1 (this field appears in the result if the VM is a template)

For Example:

  {
   "vmid": 100,
   "type": "qemu",
   "template": 1,
   "name": "ubuntu-template",
   "node": "pve1",
   "status": "stopped"
 },
3. In the 'Name' field, we recommend including the value of the '"name": "$name"' field.

For example 'ubuntu-template' from:

"name": "ubuntu-template",

Note: If you include a 'name' setting detail (see step 4) with the name from the request as its value, you can safely rename the application to something else here.

PVC 7 1.png
4. Edit your newly added application, and under 'Settings Details' edit/create application details outputted by the panel's API.
PVC 7 2.png
Carefully look at the API output and fill out the 'Name' and 'Default Value' fields with you application details.

In our case, it is:

"vmid": 100,
PVC 7 3.png
Add the remaining settings following the same pattern of filling the 'Name' and 'Default Value' fields.

Important: For KVM Template, LXC Template, and ISO Images, the setting must include the 'instances' field.
For KVM Archive and LXC Archive, the settings must include both 'node' and 'volid' fields.

PVC 7 4.png
The application will be available on the list and ready to be included in a group.
[edit] Including Cloud-Init / User-Data Scripts
Enter the user data to run common configuration tasks when the instance starts. You can run cloud-init directives or shell scripts for Linux images. You may use smarty variables, e.g. {$password}.
Note: Please refer to the following article to find a list of supported module parameters and their descriptions.

If an application supports scripts, the responsible setting will always be added automatically.
To include a script, edit the setting by clicking on the 'Edit' button next to it.

PVC 7 5.png
See the list below to learn how to set up the setting.
  • Name - do not change this value, this is the setting identifier.
  • Field Type - if the 'Visibility' setting is toggled on, this field decides the type of field, we recommend leaving it as is.
  • Default Value - this is where you include your script. If 'Visibility' is toggled on, this will be the default value that clients can modify.
    Note: Use the merge field list on the right for reference.
  • Validation - optionally, provide Laravel validation rules like 'required'.
  • Visibility - this will allow the client to modify the script before installation.
PVC 7 6.png
[edit] Overriding Proxmox Configuration
You can override nearly any Proxmox VM configuration parameter directly through the application settings.

To use this feature:

  • Create a new setting in your application.
  • Use the naming format: proxmox_{parameterName} (e.g., proxmox_memory, proxmox_ostype).
  • Set its default value just like with other fields.

This setting will be sent to the Proxmox API during VM provisioning and override the equivalent value from the product configuration, if defined. Application settings always take precedence.

Important:

  • You can use any configuration key supported by the QEMU or LXC Proxmox API.
  • Avoid using any parameters that represent arrays or device lists, i.e. keys that include square brackets or numeric suffixes like: net[n], ide[n], scsi[n], etc.
    These multi-entry device options should be managed through the module’s built-in product configuration fields (e.g., disk, network interfaces).
  • Avoid passing raw numeric-only keys, as they may not be handled consistently by the override logic.

Use this override system for single-value parameters like memory, cores, ostype, onboot, etc.

[edit] Setting High Availability (HA) Configuration
You can now define High Availability (HA) settings individually for each App Template.

To do this, manually add the following settings in the template's Setting Details section. These settings override the corresponding values defined in the product’s main configuration:

Supported fields:

  • ha.state - Field type set to: "Text Area", with the following values accepted:
    • started
    • stopped
    • enabled
    • disabled
    • ignored
  • ha.max_relocate - Field type set to: "Text Area", with numeric values accepted, e.g., 1
  • ha.max_restart - Field type set to: "Text Area", with numeric values accepted, 2
  • ha.group - Field type set to: "Text Area", with the name of an HA group created in Proxmox under Datacenter → HA → Groups (for Proxmox VE 8.x) or
  • ha.failback - Field type set to: "Switcher", with default value to enable or disable the feature (for Proxmox VE 9.x)

These fields must be added manually, as they are not created automatically.

PX2 30 03.png
Each setting will override the related configuration from the module settings. If a field is not defined in the App Template, the default product configuration will be used instead.

Note: You do not have to define all fields; you can override just one or two (e.g., ha.state and ha.group), and the rest will fall back to the global product settings.

Note 2: For Proxmox v9.x instead of "Groups", there is a "Failback" setting that, if enabled, forces HA resources to automatically adjust to HA rules.

PX2 30 3.png

[edit] Settings

[edit] Load Balancer

Load Balancer is an advanced tool that allows smooth rotation between nodes so as to find the most preferable one, and create a virtual machine on it.

The below-described features can be found in Proxmox VE VPS & Cloud addon → SettingsGeneral Settings → Load Balancer.
There, set the weight of the resource that will prioritize its selection when sorting the nodes according to the free resources.
Note: The lowest possible weight is 1. You cannot set, e.g. 0.5.

To learn more about nodes and their allowed limits please go back to the Clusters section of this documentation.

PX2 30 4.png
In order to use the Load Balancer, you need to enable it in the product's configuration at: WHMCS → System settings → Your Product Details → Module Settings→ Load Balancer

Define the behavior of the tool:

  • Action On Upgrade - select the action to perform:
    • None - no action will be triggered
    • Block - the upgrade process will be blocked as there are insufficient resources on the node
    • Migrate - the upgrade process will be performed after the previous migration of the VM to a server with sufficient free space
  • Shutdown VM on Upgrade
  • Stop VM If Shutdown Fails
  • Migration With Local Disk - Enable to allow migrating the VM with local disks
PX3 30 5.png
[edit] Node Prioritization Method
Have a look at how the sorting process works, and the rules that it goes by.

Let's take exemplary weights for each resource just like the ones presented on the screen above.

VMs Number Weight: 1.5
CPU Weight: 2
Disk Weight: 4
RAM Weight: 2.5

"Disk Weight" has the highest value, meaning disk space has the greatest impact on node selection. The "VMs Number Weight" is set lowest, making it the least influential factor in prioritization.

In this case, there are four nodes created, named A, B, C, and D, with current resource usage as shown below:

Node A (Ram: 12, CPU: 2, Disk Space: 500, Number of VMs: 5) 
Node B (Ram: 6, CPU: 7, Disk Space: 400, Number of VMs: 10)
Node C (Ram: 16, CPU: 5, Disk Space: 300, Number of VMs: 20)
Node D (Ram: 20, CPU: 6, Disk Space: 700, Number of VMs: 15)

Note: The Load Balancer evaluates raw resource values and selects the node with the lowest actual resource usage based on configuration rules.

The following table ranks each node per resource from 4 (lowest resource usage / highest priority) to 1 (highest resource usage / lowest priority). Higher scores are preferred during node selection.

Priority Ram CPU Disk Space Number of VMs
4 (best) Node B Node A Node C Node A
3 Node A Node C Node B Node B
2 Node C Node D Node A Node D
1 (worst) Node D Node B Node D Node C

The process of sorting nodes is based on the following calculation method:

Final Node Priority = (RAM Priority x RAM Weight) + (CPU Priority x CPU Weight) + (Disk Priority x Disk Weight) + (VMs Priority x VMs Weight)

The results for nodes A, B, C and D (with weights and sorting priority) are as follows:

Node A: (3 x 2.5) + ( 4 x 2 ) + ( 2 x 4 ) + ( 4 x 1.5 ) = 29.5
Node B: (4 x 2.5) + ( 1 x 2 ) + ( 3 x 4 ) + ( 3 x 1.5 ) = 28.5
Node C: (2 x 2.5) + ( 3 x 2 ) + ( 4 x 4 ) + ( 1 x 1.5 ) = 28.5
Node D: (1 x 2.5) + ( 2 x 2 ) + ( 1 x 4 ) + ( 2 x 1.5 ) = 13.5

As you can see, Node A has the highest calculated score: 29.5.
It will be selected by the Load Balancer to create a new VM on, or to migrate or upgrade an existing VM if its current node does not have sufficient resources.

These calculations are performed automatically whenever a Create or Upgrade action is triggered. The Load Balancer evaluates current resource usage across available nodes to determine the optimal placement.

Important: If a client already has a VM on a given node, that node will be excluded from prioritization.
This ensures that if a node fails, the client's remaining VMs will still be available on other nodes.
If the client already has VMs on all available nodes, then all nodes will be included in the prioritization process again.

If you decide to use the Load Balancer tool, define the resource weights to adjust the prioritization of nodes according to your needs.

[edit] Global Limitations

  • 'VLANs Limit' - enter the maximum number of allowed VLANS per customer
  • 'Default Limit of Backup Tasks Per Node' - put a global limit on the number of allowed tasks to create backups per node.
    This general limit may be overwritten per single node in the cluster settings section at: Addon → Servers → Server Details → Edit Cluster → Tasks Limit
PXC3 30 5 0.png

[edit] Task Settings

This setting can help you stay informed about failed tasks. When a threshold of task retries is reached a notification email message will be sent out.

You can set up a three-tier notification system with separate email contents.

PXC3 30 5 1.png
The default email templates include:
  • Task name
  • Task ID
  • Client ID
  • Service ID
  • Product/Service information
  • Domain
  • Error Message

You can pick different email templates from the dropdown fields in the tasks settings or edit the default templates by navigating to 'System Settings' 'Email Templates'.

PXC3 30 5 2.png

[edit] Admin Area Features

The 'Admin Area Features' section includes a list of all possible features that can be activated and then made available or not for the admin under the product's details:
  • Virtual Machines
  • Start
  • Stop
  • Reboot
  • Shutdown
  • Reinstall
  • Spice Console
  • noVNC console
  • Xterm.js Console
  • Information
  • IP Set
  • Graphs
  • Available Resources
  • IP Addresses
  • Migrate
  • User Details
  • Reconfigure Network
PXC3 30 6.png

[edit] Scheduled Backups Templates

In this section, you can create scheduled backup templates, that can be included in your products by default.

Preparing a template means there will be no need for the clients to set up their own scheduled backups and their virtual machines will be backed up on a predefined schedule from the get-go.
Start by creating and naming a scheduled backups template.

PX4 30 6 1.png
Once the template has been created, backup tasks can be included in it.
Click on the 'Create Task Template' button.
PX4 30 6 2.png
Configure the backup schedule as you see fit, you can create as many task templates in the scheduled backups template as you need.
  • Start Time - The time when the task for a backup will be issued. Make sure the time you input meets the format: 24-hour time notation with the zeroes included. For example, 07:05, 20:30
  • Day of the Week - The days the backups should take place each week.
  • Compression type - Compression method to be used.
  • Backup Mode - Decide on the backup mode.
  • Send Email Message - Decide if an email notification about the backup should be sent always, never, or only on failure.
  • Recipients - include the email addresses you would like the notification to be sent to. Separate each address with a comma.
    You can include the {clientEmail} variable to include the client's default address in the list or leave the field empty to only send the notification to that default address.

Click on 'Confirm' when ready.

PX3 30 6 3.png
You can add more task templates if you wish, edit or delete them.
PX4 30 6 4.png
The scheduled backup template you create can be included as the default backup schedule of your products.

The 'Scheduled Backup template' field can be found in the product's module settings under 'Backup'. You can also select the 'Scheduled Backup Email' under 'Client Notifications'.
Finally, you may allow your clients to change their scheduled backups by enabling the 'Backup Schedule' option under 'Client Area Features'.

PX3 30 6 5.png

[edit] Firewall Templates

Proxmox VE VPS & Cloud For WHMCS allows you to prepare firewall templates for your clients. Those templates can be added to the product's configuration and will be applied in virtual machine creation.

Start by clicking on the 'Create Template' button and naming your new template.

PX4 30 6 6.png
Configure the firewall options according to the needs of your clients. Make sure to click on 'Submit' to save the changes.
PX4 30 6 7.png
Next, click on the 'Add Rule' button and add as many firewall rules as you need.
PX3 30 6 8.png
The last step is to add the firewall template to a product. Navigate to your product's module settings and find the firewall section.
PX3 30 6 9.png

[edit] Tools

[edit] Logs

The 'Logs' section under the 'Tools' tab is where the module logs are stored.
You can filter the module logs by type with the 'Show' buttons.

For precise details on Logs, please refer to our dedicated documentation article, which you may find here.

PVC Logs.png

[edit] Console Proxy

In this section (Addons → Proxmox VE VPS & Cloud Addon → Tools → Console Proxy), you can manage console proxy settings used by the Proxmox addon in your WHMCS.

Here, you can view all configured proxy connections, including their details, as well as edit, delete, or add new ones.

PX4 4 1.png
To create a new proxy connection, provide:
  • Name – any custom label for easier identification.
  • Host – full URI of the proxy, including protocol and port. It must match the proxy's access details.
  • API Key – the key generated during the proxy installation (see point 10).

You can define multiple proxy connections and assign them globally or per node.

PX4 4 2.png
Global proxy selection

To set a global proxy for all virtual machines, go to: Addons → Proxmox VE VPS & Cloud Addon → Settings → General Settings
At the bottom, in the Console Proxy section, select a connection from the Proxmox Proxy dropdown.
This selection will be used for all nodes unless overridden individually.

PX3 4 2.png
Per-node proxy selection

To assign a proxy to a specific node, go to: Server Details → Cluster tab → Node Details → Other tab.
Use the Proxmox Proxy dropdown to assign a proxy connection to that node.
If no node-level proxy is set, the global selection from General Settings will apply.

PX4 4 3.png

[edit] Cron Scheduler

Cron Scheduler allows you to define and automate the execution of module-specific commands at set intervals.
It automatically handles all recurring cron jobs, so there's no need to configure and run each one manually.
PVC 5 0.png
All cron jobs listed in 'General Settings' that are meant to run regularly (excluding one-time tasks) are automatically added to the scheduler when the module is activated.

There is no need to manually add them.

PVC 5 1.png
Set the desired interval for each cron job (e.g., every 5 minutes, hourly).
PVC 5 2.png
Configure and activate the main scheduler cron job, recommended to run every 1 minute.

This cron will handle the execution of all configured tasks. Scheduler cron command:

 php -q /yourWHMCS/modules/addons/ProxmoxVeVpsCloud/cron/cron.php scheduler:run
If needed, you can trigger any cron job manually using the Run Command button.

The command will be queued for immediate execution with the next scheduler run, typically within one minute, ignoring its regular schedule.

PVC 5 3.png

[edit] Queue

At the top of this section, you will find information regarding the cron job.

The task cards can be used to filter the task table underneath.

PVC 11.png
Cron job tasks sent to the server through the module can be viewed and managed here.
The basic information includes:
  • ID - identification number unique to each task.
  • Related Item - the product related to the task. Clicking on it will take you to its product page.
  • Status - the current status of the task (finished, running, pending, waiting or error).
  • Task - specific action that the task attempts to run, these are:
    • Lock Account
    • Suspend Resources
    • Unsuspend Resources
    • Terminate Resources
  • Attempts - the number of times the task was attempted.
  • Created At - the date when the task was first created.
  • Updated At - the date when the status of the task was last updated.
On the right side of the tasks list, you will find the action buttons. These are in order:
  • Details - access more in-depth information about the task, including error logs.
  • Run - attempt to run the task one more time.
  • Delete - remove the task from the queue and the list.
PVC 11 1.png
Moreover, you can change additional settings by clicking on the three dots above the basic actions.
  • Auto Prune - toggle the switch on to enable the task auto prune feature, which will delete the tasks after the specified time has passed.
  • Auto Prune Older Than - specify the number of days that have to pass before a task is automatically pruned.
  • Display 'Cron Job Configuration' Hint - disable to hide the cron job information.

Remember to make use of the search bar when you need to find a specific task, and the mass action feature when you need to delete multiple tasks at once.

PVC 11 2.png

[edit] Translations

Customizing language files is now extremely easy with the "Translations" tool that is now available directly in the addon.
Its user-friendly design makes managing various language file tweaks a smooth and efficient process.

Prepare translations for the original English files with this handy built-in tool. For specific instructions on how to use this tool please refer to its dedicated article, you will find it here.

PVC translations.png

[edit] Media Library

The media library allows you to upload images for use elsewhere in the module by admins and clients.

To upload a new picture, click on the 'Upload Image' button.
Note: The icons used in the Media Library by default are provided by Simple Icons and are licensed under the CC0 1.0 Universal (Public Domain Dedication) license.

PVC 10.png
You can delete images one by one by clicking on them.

To delete all images at once, use the additional action button.

PVC 10 1.png

[edit] Dashboard

The Proxmox VE VPS & Cloud For WHMCS module includes a dedicated Dashboard that provides key insights into backup activity, virtual machine count, and resource usage statistics.

The dashboard displays the following information:

  • Backup Overview:
    • Running Backup Tasks
    • Recently Completed Backup Tasks
    • Backup Task History
  • Virtual Machine Count
  • Resource Usage Charts:
    • Total RAM Usage
    • Total Disk Usage
PX4 32 0.png

[edit] Widget

Proxmox VE VPS & Cloud For WHMCS features a dedicated widget that displays crucial information about the module right in the WHMCS dashboard.

The information displayed includes:

  • Faulty VM Deployments - a list of virtual machines that failed to be created.
    • Related Domain
    • Virtual Machine's ID
    • Related Task
    • Message
  • Awaiting & Failed Tasks - a list of tasks that are awaiting or have failed to complete
    • Job ID
    • Related Customer
    • Related Task
    • Message
  • Cluster Remaining Resources - a list of resources still available
    • Server Name
    • Remaining Virtual Machine slots
    • Remaining IPv4 Addresses
    • Remaining IPv6 Addresses
    • Remaining IPv6 Subnet
  • Node Resources - a list of the nodes available
    • Server Name
    • Node
    • Virtual Machine Limit

Each list can be hidden by disabling it in the addon's general settings.
Make sure to enable the widget in the 'Show/Hide Widgets' menu.

PX3 32 2.png
You can change the height of the widget by editing the 'widget.tpl' file located in '/whmcs/modules/widgets/ModulesGardenProxmoxVeVpsCloud/templates'.

Find this code fragment:

<style>
    #MGProxmoxVeVpsCloudWidget{
        height: 300px;
    }
</style>

and change it to include max-height: none !important;, like this:

<style>
    #MGProxmoxVeVpsCloudWidget{
        height: 300px;
        max-height: none !important;
    }
</style>

Now you will be able to adjust the widget's height by editing the height: value; from the default '300px' to any value that fits your needs.

To permanently change the widget's height, follow these steps:
  • Copy the original widget.tpl file.
  • Go to: modules/addons/ProxmoxVeVpsCloud/overrides/templates/admin/widget/ and create a new file named widget.tpl.
  • Paste the content of the original file into this new one and apply your custom changes to adjust the widget height.
  • When the override file is present, the module will use it instead of the default one.
    Your changes will remain safe after module updates.
To configure the widget's visible options, navigate to Settings → General Settings → Proxmox VE Widget Features section.
In this section, you can choose which data should be displayed on the WHMCS dashboard. The following features can be enabled or disabled:
  • Faulty VM Deployments - Show information about unsuccessful VM provisioning attempts.
  • Failed Tasks - Display a list of recent failed operations within Proxmox VE.
  • Node Resources - View real-time resource usage (CPU, RAM, etc.) for each Proxmox node.
  • Cluster Remaining Resources - Present the remaining available resources across the cluster.
PX3 32 3.png

[edit] Admin Area

In the admin area, you are able to view details and manage your clients' machines, access remote consoles, migrate VMs between nodes, assign IP addresses and view resource usage graphs.
All visible features can be turned on and off in the Proxmox VE Addon → Settings → General Settings → Admin Area Features.
  1. Firstly, there are the standard module commands that you can perform on the VM.
  2. Among them, you will find actions to:
    1. Manage the status of the machine,
    2. Access to remote consoles
    3. Migrate the server between nodes.
      You may enable 'Online' migration (no need to shut down the server before migration) and toggle 'Migration With Local Disks' which might take a while.
    4. Reconfigure the network
    5. Detach the virtual machine from the service
  3. In this panel, you will also find the basic information about the VM.
  4. Moreover, you can change the VM hostname, ISO image, bootable devices as well as insert the SSH public key.

Note: The "Move Product/Service" action is not supported due to WHMCS limitations, and the fact that there are no hooks that would allow to catch such an event.

PVC4 26.png
It is possible to fetch information of network interfaces and OS using the 'Qemu Guest Agent' tool.

This option must be previously enabled in the product configuration, and successfully installed on the VM. Afterward, it should look similar to the image below.

PX3 27 1.png
In the next panel, you can find IPv4 and IPv6 addresses assigned to the VM.
You can either delete or add an IP address to a product. To perform the latter action, press 'Add New IP' as shown on the following screen.
PX3 27.png
Fill in the fields to add a new IP address. At the bottom, there is a switcher 'Create Network' which, when on, forces assigning this IP address via Cloud-Init if that has been enabled and configured properly.

Important: Create Network option works for KVM configuration only.

PX3 27 0.png
Additionally, until the VM has been provisioned, you can manually assign to it the desired IP addresses from the pool by typing them in the 'Assigned IPs' field (available for the 'Dedicated/VPS Server' product type).
This will override the automatic IP address assignment, and the VM will use only the IP addresses you have entered in the mentioned field.

Note: The IP addresses you provide must already exist in the IP Management pool, and cannot be assigned to any other VM. This feature will not work if you already use the IP Manager For WHMCS module.

PX2 27 2.png
In the next two panels, you can view IPSet information as well as reinstall the VM based either on the OS or ISO template.
PVC4 27 3.png
Graphs can be useful to monitor the usage of VM resources. You can change the interval by pressing the 'Edit' button, and simply providing a new one.
PVC4 27 4.png
In the last part of product management, you can view the user details on your Proxmox servers along with the assigned VLAN tag and SSH public key provided before the VM creation.
PVC4 27 5.png

[edit] Client Area - VPS

The client area interface of VPS product type should look like the one on the screen below.

As you can see, the control panel contains assorted options that will prove highly useful in VM management.
The module allows your customers to easily 'start', 'reboot', 'stop' and 'shutdown' their servers through pressing specific buttons.
It is also possible to 'reconfigure the network' without using the "Change Package" tool to easily update the network interfaces (KVM virtualization type only).
Clients can also access the 'noVNC' , 'SPICE' and 'Xterm.js' consoles. Among 'Additional Tools' , you will find options to 'reinstall' a server, create a 'backup' or set up 'backup jobs'.

Your clients are able to access resource usage 'graphs', view the VM 'history', manage the 'network' interface device, and set up the 'firewall' rules. Additionally, clients may take 'snapshots' , and manage 'disks'.
On the main product page in the client area, under the 'Information' headline, your clients can find such details as the current usage of CPU, memory, disk (LXC only) and SWAP (LXC only).
Customers can also view 'DNS' (LXC only) as well as assigned 'IP addresses'.

Note: The bellow example image was taken from the KVM-based VM, but it looks very similar in the case of LXC.

PVC4 24 1.png
By clicking the 'Edit' button next to the 'Information' headline, your clients can additionally change the VM hostname and ISO image, choose boot devices, as well as insert their SSH public key.

Important: If you do not see the Edit icon, it means the option to change hostname has been turned off by the admin.
Note: Information elements included in the below table are managed by the admin in the product's configuration section under Client Area Features.

PVC4 24 2.png
PX3 24 3.png

[edit] Client Area - Cloud

Client area interface of a cloud-type product allows your clients to create their own virtual servers.

They can also view resources used and manage existing virtual machines.

PVC4 24 0.png

[edit] New Virtual Machine

In order to add a new virtual machine, press the 'Add New Virtual Machine' button.
PCV4 38 1.png
Now, provide a name of your new virtual machine and choose a proper type from the dropdown menu.

Moreover, you can add 'New Virtual Network' and 'New Additional Disk' here. Confirm creation through pressing 'Confirm'.
Note: Data to be filled in may differ according to which type LXC or KVM you have chosen.

PVC4 38.png
You can now easily 'Edit' (1) or 'Delete' (2) your virtual machine.

You can find information about managing your virtual servers in next section.

PXC4 39.png

[edit] Virtual Network Management

Move to 'Virtual Networks' section to add, delete and edit your virtual networks.

Please keep in mind that this option must be enabled by an administrator in your product's 'Module Settings' previously and a private IP address must be added in the Proxmox Addon.
Otherwise you will not be able to add any virtual network successfully.
If you have reached the set by the admin limit of allowed networks, the button will not be active either.

Moreover, you can also 'Edit' (1) or 'Delete' (2) existing private networks.

PXC4 60.png
Assign virtual machine to a specific network during creation, select source:
  • Add network From the Service
  • Add network From All Services
  • Add New Virtaul Network - in this case, you have to provide all data to create a new network at this point (Pool, CIDR and Gateway)
PXC4 60 0.png
PXC4 60 1.png

[edit] Templates Management (KVM Only)

Once you press 'Templates', you will be redirected to a site where you will find the list of currently created templates along with their details and access to basic actions.
PVC4 62.png
You may edit or delete existing templates. To add a new one, simply press 'Add Template' button.

OS templates do not consume any resources such as CPU sockets, memory etc.
Important! When you convert server into a template, it is consumed in the process! There is no possibility to revert it back.

PXC4 63.png
Select server from dropdown menu and type in its short description. Save changes when ready.
PXC4 64.png

[edit] Client Area - VM Management

[edit] Service Actions

In the client area, users can easily manage their virtual machines using the following actions:
  • Start
  • Reboot
  • Stop
  • Shut down
  • Reconfigure network (VPS-type products only)
  • Delete the virtual machine (cloud-type products only)
PVC4 39 0.png

[edit] Client Area - Service Management

[edit] Backups

To create a single backup, press the 'Backups' button, and click on 'Create Backup' as shown on the following screen.
PX4 41.png
Now, choose the compression type ( 'None' , 'LZO' or 'GZIP' ) and the backup mode ( 'Snapshot' , 'Suspend' or 'Stop' ) from dropdown menus.
Afterward, press 'Confirm'.
PX3 42.png
Note: Creating a backup is now added to the tasks list, wait a moment until the task is completed. Once ready, your new backup will appear on the list and will be available for future restoration.

Note 2: You may select the storage for created backups either in the module settings globally, or per node in the addon module (this setting overwrites the product settings).

You may mark backups as protected so they will not be unintentionally deleted.

To restore a VM from the backup, press 'Restore', and then click the 'Confirm' button in a popup window.

PX3 43.png
Above the backups list, there is a table with information on 'Available Resources'.
You will find data on limits put on backups:
  • Backup Size: used/allowed
  • Backup Files: used/allowed
  • Protected Backup Files: used/allowed

Next to the statistics, there is a comfortable and easy-to-read progressive chart to illustrate the usage. If the size is set to 'Unlimited', the chart does not show any progress.
Once you have reached the limits, the option to create new backups is blocked.

PX3 43 1.png
If you would like to restore singular files instead of the whole machine, or simply download them you can do that by clicking on the 'Browse Files' button.

Important: Make sure your designated backup catalog has write permissions for file downloads and the deletion task to remove old files.
Additionally, ensure that this directory is not publicly accessible.

PX3 43 10.png

[edit] Backup Collection

Open the backup collection to view all backups created from your virtual machines of the current product type.
For example, if you are using a VPS-type service, the Backup Collection will list backups from all your other VPS-type services. Similarly, for a Cloud-type service, you will see only backups from other Cloud-type services.

You can restore the current service using any backup available in this list.

PX3 43 2.png

[edit] Backup Jobs

Important: 'Backup Jobs' and 'Backup Schedules' are mutually exclusive and should never be used together.
'Backup Schedules' are meant to replace 'Backup Jobs' as a backup solution that involves much less load on Proxmox VE resources.


By pressing 'Backup Jobs' in the client area, you will be moved to the backup jobs management page.
You can easily edit or delete, as well as preview the details of existing backup jobs there.
To add a new backup job, press 'Create Backup Job' as shown on the following screen.

PX3 44.png
Now, define the backup start time, choose the days when to run it, and select 'Compression Type' and 'Backup Mode' from dropdown menus.
Also, select if you want to receive the notification when the backup is ready.

Finally, press the 'Confirm' button.

PX3 45.png

[edit] Backup Schedules

Important: 'Backup Jobs' and 'Backup Schedules' are mutually exclusive and should never be used together.
'Backup Schedules' are meant to replace 'Backup Jobs' as a backup solution that involves much less load on Proxmox VE resources.

If you already have 'Backup Jobs' created and would like to migrate them into Backup Schedules automatically, you should use this cron job task:

php -q /your_whmcs/modules/addons/proxmoxAddon/cron/cron.php migrate-backup-jobs-to-schedules --product_id=YOUR_CONFIGURED_PRODUCT_ID

You will find the cron already personalized for you in the General Settings tab.
Replace 'YOUR_CONFIGURED_PRODUCT_ID' with the ID of the product you want to perform the migration for.
The ID can be found in the URL link after selecting the product in the Products/Services tab in the admin area. Do not confuse this ID with the ID of clients' products.
Run the task for each of the products you want to perform the migration for.

'Backup Schedules' can already be created from a template while creating the virtual machine, but can still be freely customized later.
The main difference between scheduled backups and backup jobs is that the scheduled backups are handled entirely by the module instead of the Proxmox server.
You can edit or delete existing scheduled backups by using the action buttons.

PX4 45 1.png
You may also schedule new backups by clicking on the 'Create Backup Schedule' button.
PX4 45 2.png
Configure the backup schedule as you see fit, you can create as many task templates in the scheduled backups template as you need.
  • Start Time - The time when the task for a backup will be issued. Make sure the time you input meets the format: 24-hour time notation with the zeroes included. For example, 07:05, 20:30
  • Day of the Week - The days the backups should take place each week.
  • Compression type - Compression method to be used.
  • Backup Mode - Decide on the backup mode.
  • Send Email Message - Decide if an email notification about the backup should be sent always, never, or only on failure.
  • Recipients - include the email addresses you would like the notification to be sent to. Separate each address with a comma. Leave the field empty to only send the notification to that default address.

Click on 'Confirm' when ready.

PX3 45 3.png

[edit] Disks

View available disks and add new ones.
PX4 48 6.png
Define the additional disk size, choose its bus (the available options may be 'IDE', 'SATA', 'VIRTIO' or 'SCSI' ), as well as define a disk format.
You can choose from 'Raw disk image (raw)', 'QEMU image format (qcow2)', or 'VM image format (VMDK)' .
PX3 48 8.png

[edit] Firewall

Owing to the 'Firewall' page, your clients can set up firewall rules and enable a security group for their servers from the WHMCS client area.

As you can see, you can easily modify and remove the previously added rules and security groups.
To add a new firewall rule press the 'Confirm' button.

PVC4 48 0.png
You can add a firewall rule in two ways. Both of them require choosing a direction, action, interface, source, and destination.

The first way (orange) is to choose macro from the 'Macro' dropdown field.
The second way (blue) requires you to choose a protocol and fill in both the source and destination ports.
Additionally, you can enable a rule, and add a comment to it.
Press 'Confirm' to create a rule.

PX3 48 2.png
Among 'Additional Actions' you will find three options:
  • Add Security group - choose a security group and an interface on which the group will be used on.
    Additionally, you can enable a security group, and add a comment to it. Click 'Confirm' to use the security group.
PX3 48 3.png
  • Download Rules - use this option to simply create a backup, once pressed, a file will be downloaded
  • Restore Rules - restore any of the previously created backups created. Select one of the previously downloaded files with rules
PX3 48 02.png
You may manage the hierarchy of rules on the list. In front of each rule, you can find its 'Position' marker.
The higher the rule is on the list, the higher priority the rule has assigned. You may change the rule position using the 'Move up/down' arrows.
PVC4 48 01.png

[edit] Firewall Options

Here you can view the current firewall settings. To decide on its options, press the 'Edit' button, and adjust them to your needs.
PX4 48 7.png
PX3 48 7 1.png

[edit] Graphs

Through pressing the 'Graphs' button, clients will be moved to the page with the generated graphs showing the CPU and memory usage, network traffic, and disk I/O.

They can also switch the timeline of graphs by choosing a new one from a dropdown menu indicated on the following screen. Clients can pick between 'Hour', 'Day', 'Week', 'Moth' and 'Year'.

PVC4 46.png

[edit] Network

Your clients are allowed to add and remove only private network interface devices. Additionally, they may attach additional networks to the virtual machine, enabling communication between them.
PX3 48.png
Upon clicking the 'Information' button, the new popup will open with more network details.
PX3 48 1.png
The 'Attach Network' button opens another popup window, where virtual machines can be selected and optionally restarted.
A restart is necessary for the changes to be applied if the hotplug functionality is not configured for the virtual machine.
You can find an exemplary scenario illustrating a typical use case of this function in the 'Use Cases' section of this wiki.
PX4 48 1 1.png
Finally, the 'Delete' button will remove the network.

Keep in mind that ' Network device' options have to be set to 'Private'.
Also, after the network creation, the button to add another one or delete a newly created private network may not be longer available, depending on your Proxmox configuration.

[edit] noVNC Console

The noVNC console provides the most straightforward way for clients to connect to their virtual machines directly through the browser.
PVC4 39 1.png

[edit] Reinstallation

The "Reinstallation" feature can be used to reinstall a new OS on the VM directly by the clients.

You can allow your clients to either select a new OS from the provided KVM/LXS templates to automatically replace the system, use archives, or let them choose the ISO image for manual system installation

PX4 38.png
PX4 38 1.png
Remember to grant your clients access to the selected reinstallation types in the 'Client Area Features'.
Assign wanted 'Default Application Group' and 'Default Application' in the App Templates Configuration.
PVC 10 3.png

[edit] Resource Notifications

Within the "Resource Notifications" section, you can configure personalized notifications regarding your machine's utilization.
By creating "Resource Notifications", you enable the system to automatically send email alerts whenever your server exceeds predefined thresholds for network traffic, disk read and write operations, CPU utilization, and memory usage within a specified time frame.
These notifications serve as indicators, ensuring that you stay informed about any significant deviations from normal resource utilization, enabling you to take timely action and maintain optimal performance.
PX4 48 9.png
To create the first notification rule press the 'Create Notification' button.
A dedicated form will appear, fill in the described below fields to compose the notification requirements:
  • Name - enter the rule name
  • Status - set it to enabled or disabled, can be changed later on
  • Notifications Interval - define the time interval between notifications in hours. Eg. 8 - notifications will be sent in this frequency
  • Data Timeframe - specify the time duration to extract and verify data usage (in minutes, eg. 30)
  • Exceed All - if enabled, all the below setup conditions will have to be met to send the notification
  • Email Address - if you want to send the notification to other addresses than the main customer's address, enter them here separated by a comma
  • Conditions for:
    • Network Traffic [%] - sum of Net In and Net Out expressed in percentage value towards Rate Limit Network
    • CPU Usage [%] - a percentage that represents the overall utilization of CPU. It indicates how much of the CPU's processing capability is being utilized.
    • Memory Usage [%] - percentage of memory usage towards the VM RAM
    • Disk Read [%] and Disk Write [%] - disk usage percentage is calculated based on the Hard Disk Speed limits (respectively: Read Limit and Write Limit).
      If there are no limits set for Hard Disk Speed, the dedicated fields in the client area ('Disk Read [%]' and 'Disk Write [%]') will not be displayed
PX3 48 10.png
A ready notification rule appears on the list, here you may quickly turn it on/off (1) depending on your current needs, change (2) the rules or delete (3) the notification.
PX4 48 11.png

[edit] Server Monitoring Integration (Temporarily Suspended)

Integration with Server Monitoring For WHMCS is currently unavailable, and will be re-added with the nearest Server Monitoring For WHMCS module update.

Important: This section is only available with Server Monitoring For WHMCS module active. Clients can create their own server status checks and monitor its health. New checks can be added by clicking on the 'Create Check' button.

PX3SM 1.png
The following details have to be specified:
  • Name - name the check.
  • Status - select the initial status of the check.
  • Verification Interval - select how often in minutes the check should be added to the queue.
  • Failure Count for Notification - select how many times a check has to fail before a notification is sent.
  • Notification Delay - decide how many minutes have to pass between each notification sent.
  • Type of Performed Check - select the check method from options allowed by the admin.
    • cURL Check - an HTTP GET request is sent to a server to retrieve data and check its availability.
      • Request URL - provide a URL that will return a code upon a GET request.
      • Response Code - include the expected HTTP response code.
    • ICMP Ping Check - an ICMP ping is sent to a specific IP address to test if the server is reachable.
      • IP Address - provide the IP address for the check.
    • Socket Ping Check - a connection attempt is made to a specific IP address and port to check if the service is running and accessible.
      • IP Address - provide the IP address for the check.
    • Port Connect - a connection attempt is made to a specific IP address and port using the TCP protocol to verify if the service on the specified port is running and accessible.
      • Allow Custom IP Address - allow the client to enter a custom IP address instead of selecting from assigned ones.
  • Notification Type - select the notification method from options allowed by the admin.
    • Email Notification - email messages will be sent out after the threshold for failed checks is exceeded.
      • Notification Recipients - select where to send the notification.
    • SMS Notification - enable SMS notifications to keep clients informed of monitoring events.
      • SMS Recipients - Provide the phone numbers to which the notification will be sent.

More detailed information on specific checks and the module can be found on the Server Monitoring Wiki page.

PX3SM 2.png
After the first checks are performed, the logs table will include details such as:
  • Check Name
  • Check Type
  • Check Result
  • Check Date
PX3SM 3.png
The graph displays the check logs in a visual way.
PX3SM 4.png

[edit] Snapshots

Use a snapshot to remember the current contents of the virtual machine memory. You may use them later to restore the VM's settings.
Please remember that it is necessary to run the following cron command for snapshot jobs.
You may set the cron command once a day or every hour. Do not forget to replace 'your_whmcs' with your WHMCS root location.
 php -q /your_whmcs/modules/addons/ProxmoxVeVpsCloud/cron/cron.php snapshots 
PX4 48 4.png
Press the 'Take Snapshot' button and fill out the form to take a snapshot.
Name it (use the alphabetical characters and no spaces), choose whether to include RAM, and add a description.
PX3 48 5.png
It is also possible to set up 'Snapshot Jobs' where snapshots can be created according to your preferences (daily or hourly). Click on 'New Job' in order to add a new snapshot job.
PX4 48 5 1.png
As you complete the form, remember to fill in the 'Name' field without spaces or special characters- only capital letters and numbers are allowed here.
PX3 48 5 2.png

[edit] SPICE Console

The SPICE console allows access to the virtual machine using the SPICE protocol.
PX2 40.png

[edit] Task History

To access the history of a machine, simply press the 'Task History' button. Afterward, the customer can see all the actions performed on the VM, as well as their status.

If an error has occurred during the execution of a task, the client can view the API response error by clicking on the 'Information' icon.

PX4 47.png
PX4 47 1.png

[edit] VM Power Tasks

The "VM Power Tasks" section empowers you to effortlessly create and manage automated power tasks for your virtual machine, all in one convenient location.
With the ability to define task rules, you can automate multiple actions and minimize your manual intervention in VM operations.

To begin configuring your first rule, simply click on "Add Task".

PX4 48 12.png
A new form will appear with the following options to provide:
  • Description - task description or short name
  • Action - select the action the task is to execute:
    • Start the machine
    • Stop the machine
    • Reboot the machine
  • Specify the exact time to keep the task active:
    • Start Date (use the calendar to specify the task beginning date)
    • Start Time - provide the exact hour to activate the task
    • End Date (use the calendar to specify the task ending date)
    • End Time - provide the exact hour to deactivate the task
  • Job Type - choose the task type and define its execution frequency
    • One Time - the job will be executed only once, specify the time to start the task:
      • Job Hour
      • Job Minutes (rounded to 5 minutes)
    • Daily - the job will be executed every day of the week, specify the time to start the task:
      • Job Hour
      • Job Minutes (rounded to 5 minutes)
    • Weekday - the job will be executed on selected days, specify the time to start the task:
      • Job Hour
      • Job Minutes (rounded to 5 minutes)
      • Day of Week - select days when the task will be executed
PX3 48 13.png
The power tasks list provides a comprehensive overview of all the tasks associated with power management on your virtual machine.
You can easily identify active actions tasks, ensuring that your virtual machine operates according to your desired configurations.
Additionally, the flexibility to modify existing rules (1) allows you to adjust the tasks' parameters to align with your needs. If necessary, you can also remove unwanted tasks from the list (2).
PX4 48 14.png
Important: "VM Powre Tasks" require a dedicated cron job to be set up by the administrator.

[edit] Xterm.js Console

The Xterm.js console offers another browser-based method to connect to the VM using Xterm.js.

To enable this console in Proxmox v2.6.0 or higher, upload the required scripts from the UploadOnProxmoxServer/5.2-10 directory to all your Proxmox servers.

PCV4 40 1.png

[edit] Configurable Options

When you successfully set up a product, your client can order it by choosing from the default configurable options.

Important: Storage Disc Space configurable option, when used by the client, overwrites the product configuration 'Disk Space ' option.

PVC4 53.png
In case those options do not suit your needs, you can edit them.

Go to 'System Settings' 'Products/Services' 'Configurable Option' and press the edit button next to the configurable option used by your product.

PVC4 54.png
Here you can view all the products this configurable option group is assigned to.

Now, we will show you how to edit options. Let's say you want to add an option to order a VPS with 4 cores per socket.
To do so, edit 'The number of cores per socket' by pressing the edit button as shown on the screen below.

PVC4 55.png
You will see a popup window, so make sure your browser does not block it.

To add a new option, enter it in the textbox located below all other options. If you want to replace the option you currently have, simply edit the textbox.
Finish by pressing 'Save Changes'.

PVC4 56.png
More information about WHMCS configurable options and their editing can be found here.


[edit] Management of Billing

When you combine Proxmox VPS For WHMCS with Advanced Billing For WHMCS, you will be able to set up additional billing options.

The module allows you to charge your customers based on the server resources they have used.

PVC4 57.png
With the Advanced Billing For WHMCS module, you can also display the current resource usage of your customer's server, as well as its total cost.
PVC4 58.png

[edit] Servers Location Management

Important: Server Allocator For WHMCS is required to allow location management.

In order to allow defining locations for Proxmox VPS, follow the below steps:
1. In your product's 'Module Settings' , set up 'Default Node' to 'Server-Node'.
2. Create a WHMCS server for each Proxmox node.
3. Manually create a configurable option, name it e.g.: 'Location'. Add options for each server within that configurable option.
4. Install our Server Allocator For WHMCS module and configure it properly.

It must assign a server to a product depending on the selected option in 'Location' configurable option.

Keep in mind that all locations need to have exactly the same configuration.

Now, a client may order a VPS, and select 'Location'. Server Allocator For WHMCS will change the server assigned to the product.

The "Create" action is triggered on the assigned server due to the 'Server-Node' option enabled.

[edit] Use Cases

In this section, you will find exemplary scenarios illustrating typical use cases, along with specifics on how the module's functionalities can be applied in practice.

Review the following scenarios for practical examples of the module usage.

[edit] Selling Predefined Windows Virtual Machines

The Proxmox VE VPS & Cloud For WHMCS module allows you to offer predefined, ready-to-deploy Windows-based virtual machines to your clients. This setup is applicable to Kernel-based Virtual Machines (KVM) only.

Follow the steps below to create a Windows VM template, configure it using the App Templates feature, and link it with your WHMCS product settings.

1. Prepare a Windows template in Proxmox:
  • Start a new virtual machine with a Windows Installer ISO file mounted.
  • Make sure the 'OS Type' in the virtual machine's options is set to Windows.
  • Install 'Windows Operating System' on the virtual machine.
  • After installation, add the 'Qemu Guest Agent.' The module will auto-detect it if the OS is correctly set as Windows.
  • Power off the VM and remove the virtual CD drive if no longer needed.
  • Convert this VM into a template directly from the Proxmox interface.
  • If you are using 'Shared Storage,' upload the template there. If not, manually copy the template to all relevant nodes.
2. Configure App Templates in the Proxmox VE VPS & Cloud For WHMCS addon.
The App Templates feature simplifies template management and provisioning. To define and use your Windows template:
  • Access the Proxmox addon and navigate to the App Templates → Applications section.
  • As the template was just added on the server, click "Refresh list" to fetch the latest available templates.
PVC UC 1.png
Move to App Templates → Groups, create a group of applications with your template.
PVC UC 2.png
3. Configure the product's module settings:

In the App Templates Configuration, choose the Default Application Group' that includes your predefined Windows template.
This group will be used to automatically generate the corresponding configurable options for application selection.

PVC UC 3.png
Again in the module settings, enable the Guest Agent option to ensure proper interaction between the virtual machine and the module.
PVC UC 4.png
Generate a configurable option named app|Application to allow clients to select from the available app templates (including Windows-based ones from the Default Application Group) during the ordering process.
PVC UC 5.png
When placing an order, clients will see a dropdown with applications you have configured.
They can select the Windows template, which will then be used to provision their server accordingly.
PVC UC 6.png

[edit] Selling Predefined Linux Virtual Machines

Proxmox VE VPS & Cloud For WHMCS can be used to sell predefined Linux-based virtual machines. Follow the instructions below to prepare a Linux virtual machine template and configure the module.
Keep in mind that the instructions are for Kernel-based Virtual Machines (KVM) only.

1. Prepae a template virtual machine in Proxmox:

Create a Cloud-Init template virtual machine based on the official documentation.
If you would like to make additional customizations to the template (e.g., enabling login with a password or allowing root access via SSH):

  • Create a new virtual machine based on the template from step 1.
  • Log in to the virtual machine.
  • Apply the desired changes.
  • Convert the modified VM into a new template.

If you are using shared storage, upload the template there. If shared storage is not used, ensure that the template is uploaded to each node manually.

2. Configure App Templates in the Proxmox VE VPS & Cloud For WHMCS addon.
The App Templates feature simplifies the management and provisioning of predefined templates.
  • Go to the Proxmox VE VPS & Cloud addon and navigate to the App Templates → Applications section.
  • Since the template was recently added on the server, click "Refresh List" to load the latest templates.
PVC UC 7.png
Then go to App Templates → Groups and create a group of applications that includes your Linux template.
PVC UC 8.png
3. Configure the product's module settings:

In the App Templates Configuration, choose the Default Application Group that contains your predefined Linux template.
This group will automatically generate the corresponding configurable options for application selection.
These applications will also be available in the "Reinstallation" section of the client area, allowing clients to reinstall their servers at any time.

PVC UC 9.png
Still in the module settings, enable the 'Cloud-Init' option to ensure proper integration between the module and the virtual machine.
PVC UC 10.png
Enable the "Reinstallation" feature in the Client Area Features section to give clients access to this functionality.
PVC UC 11.png
Generate a configurable option named app|Application o allow clients to choose from the available app templates (including those from the Default Application Group) during the ordering process.

Optionally, set pricing for the 'app|Application' configurable options via System Settings → Products/Services → Configurable Options.

PVC UC 5.png
When placing an order, clients will see a dropdown menu with the application templates you've configured.
They can select the desired Linux template, which will then be used to provision their server.
PVC UC 13.png
Clients can reinstall their virtual machines using any of the templates available in their assigned group.
PVC UC 14.png

[edit] Connecting Multiple VPS Machines Into One Private Network

Proxmox VE VPS & Cloud For WHMCS allows connecting multiple VPS machines into one private network.
To do so, you will need at least 2 virtual machines. In our case, the hostname of the first virtual machine is: 'virtualmachine1.com' and the hostname of the second one is: 'virtualmachine2.com.'

First, pick one of the machines and navigate to 'Service Management' 'Network' in your client area.

PX4 59.png
Once there, assign a new private network to the virtual machine you have selected by clicking on the 'Create Private Network' button.
If there are any private IP addresses available, a new network will be created and this virtual machine will be assigned to it.
PX3 59 1.png
Now, you can assign other virtual machines you own to this very network. Click on the 'Assign Virtual Machine' button.
PX3 59 2.png
Select the virtual machine that you want to add to the network. You can identify it by its hostname. In our case, we want to add 'virtualmachine2.com.'
Restarting the virtual machine is optional, but recommended, as it will allow it to connect to the network as soon as possible.
Note: The reason for this is that if the virtual machine does not have the hotplug functionality configured, it has to be restarted for the change to be implemented.
PX4 59 3.png
After clicking on 'Confirm' button, you should receive information stating that the virtual machine has been successfully assigned to the private network.

[edit] Selling Virtual Machine Upgrades

Proxmox VE VPS & Cloud For WHMCS integrates WHMCS 'Upgrades' and 'Configurable Options' to enable clients to change their virtual machine's specification.

See the instructions below on how those functions work with the module.
Please note that:

  • When an upgrade is performed and the template of the virtual machine changes, the machine will always be reinstalled.
  • Upgrades can only be performed within the same type of products, i.e. KVM to KVM; LXC to LXC.
  • Disk size downgrading is not supported.
  • For more information regarding the WHMCS product upgrade function, visit this guide.
Upgrading from one product to another.

1. Configure the first product as you normally would. For the sake of an example, in the product's module settings, we will set the limits to 4GiB of disk space, and 512MiB of RAM.

PVC UC 15.png
2. Create another product in the same way, but this time with higher limits. For the second product, we will set the limits to 6GiB of disk space, and 1024MiB of RAM.
Of course, you can change any properties of the products as you see fit.
PVC UC 16.png
3. Open the 'Upgrades' section of the first product and select the products you would like to allow the clients to upgrade it to.
In our case, we will choose the newly created 6GB product.
PX3 57 3.png
4. In the client area, a new option will be visible, and the client will be able to place an order to upgrade their product.
PX3 57 4.png
5. Once the order is accepted, the virtual machine has to be rebooted for the upgrade to take place.
PX4 57 5.png
The changes will immediately be visible in the client area and the admin area.
PX3 57 6.png
Another way for the client to upgrade their virtual machines is to utilize the 'Configurable Options' function instead. In this way, all the changes in the specification will take place within the same product.

1. For the products that have the 'Configurable Options' assigned, you can use those as an upgrade option. Tick the 'Configurable Options' checkbox in the 'Upgrades' section.

PX3 57 7.png
2. In the client area, a new option to upgrade the configurable options will be displayed.
PX3 57 8.png
3. Clients will be able to pick their configuration again, all within the possible range that you have defined in configurable options.
If you prepare configurable options for, say, the number of snapshots, the client will be able to pay for an increased limit of snapshots.
PX3 57 9.png
4. After the order is accepted, the configuration will update once the virtual machine is rebooted.
PX4 57 5.png
The changes will immediately be visible in the client admin areas.
PX3 57 11.png

[edit] Selling Additional Storage

Proxmox VE VPS & Cloud For WHMCS can take advantage of the 'Configurable Options' function to allow admins to sell additional storage space to their clients.
Follow the instructions below, to see how to set up additional storage space options for your clients.
In the product's module settings, at the very bottom, you can find a list of available configurable options. The ones that we are interested in right now are:
additionalDisksSpace|Additional Disks Space

and

additionalDisksSpace_[STORAGE_NAME]|Additional Disk Space (STORAGE_NAME)

The difference between them is that 'additionalDisksSpace' can include any combination of any storage detected on your server, but only one option can be selected.
In the case of 'additionalDisksSpace_[STORAGE_NAME]' only the chosen storage will be included in the options.
Still, you can set multiple configurable options of this type, allowing the client to freely choose how much of which storage they would like to buy.

Click on 'Create Configurable Options' and select relevant options to generate a template that you can edit under 'System Settings' 'Products/Services' 'Configurable Options.'

Note: You can also create them manually if you prefer.

PX3 59 4.png
Here is an example 'additionalDisksSpace' configurable option:
  • Option name - you can change the display name after the '|' symbol.
  • Options - the possible options the client will be able to choose from, the left side has to be specifically '[storage_name]:[size];[another_storage_name]:[size]' while the right side is what the client will see.
    Storage can be combined into one option if you put a semicolon between each storage name. An option to not buy any additional storage is represented with '-1.'
  • Pricing - set an individual price for every option.
PX3 59 5.png
The option to buy additional storage space will now be displayed in the client area while ordering a new product, or upgrading configurable options.

While using the 'additionalDisksSpac' configurable option, only strict storage configurations defined by the administrator are available.

PX3 59 6.png

The 'additionalDisksSpace_[STORAGE_NAME]' configurable option can be used to achieve a different effect.
Set up multiple configurable options like on the screen below.

  • Option name - this time the left side defines the storage type for all options.
  • Options - the left side only includes the number of gigabytes.
  • Pricing - make sure to set a price for each option.
PX3 59 7.png
Once configurable options for every storage are created, the clients will be able to freely choose their own combinations.
PX3 59 8.png
After the order for additional storage is accepted, the user may create additional disks as they see fit, within the limits specified when placing the order and the product's module settings.
PX3 59 9.png
Here is an explanation of each field:
  • Size - the size of the new disk. Limited by the purchased additional storage, limits are unique to each storage type.
  • Storage Type - similarly limited by the purchased additional storage.
    Note: While there is an option to pick a default storage type in the product's module settings, the clients will still need to buy the storage space to create an additional disk on it.
  • Bus - the type of interface the disk uses, the options can be specified in the product's module settings, under 'Additional Disks' 'Additional Disk Type' .
  • Format - the format the disk will use, the options can be specified in the product's module settings, under 'Additional Disks' 'Additional Disk Format' .
PX3 59 10.png
If you would like to change how the storage types are displayed to the client, you can do so.

1. Find and edit the english.php file located in modules/servers/ProxmoxVPS/langs/english.php.
2. Find the line responsible for the display name of your additional storage, it should look like this:

$_LANG['storage']['local-lvm'] = 'Local-lvm'; 

3. The text after the '=' is the display name and can be edited.
4. The string in the second bracket is the storage type. You can add more lines in the same manner, for each of your storage type configurable options, like so:

$_LANG['storage']['local-ssd'] = 'SSD Storage'; 
PX3 59 12.png
The virtual machine has to be rebooted before the new disks are enabled and usable.
PX4 57 5.png

[edit] Scheduling Backups

Proxmox VE VPS & Cloud For WHMCS can be used to plan and handle scheduled backups. This feature in conjunction with limiting backup tasks per node can substantially offload your Proxmox platform.

To start scheduling backups navigate to 'Additional Tools' 'Backup Schedules' and click on 'Create Backup Schedule'.
Alternatively, you can prepare templates to automate this process.
Note: Make sure that backup schedules are enabled in the product's module settings under 'Client Area Features'.

PX3 60 1.png
A configuration window for the first schedule will open. Set up as many schedules as you need.
  • Start Time - The time when the task for a backup will be issued. Make sure the time you input meets the format: 24-hour time notation with the zeroes included. For example, 07:05, 20:30
  • Day of the Week - The days the backups should occur each week.
  • Compression type - Compression method to be used.
  • Backup Mode - Decide on the backup mode.
  • Send Email Message - Decide if an email notification about the backup should be sent always, never, or only on failure.
  • Recipients - include the email addresses you would like the notification to be sent to. Separate each address with a comma. Leave the field empty to only send the notification to the default address.

Click on 'Confirm' when ready.

PX3 60 2.png
Now that the backups are scheduled, they will be mostly handled by the module, but you can further reduce the stress put on your Proxmox platform by limiting backup-related tasks per node.

Open the Proxmox VE VPE & Cloud addon in your admin area and navigate to 'General Settings' . Find the 'Default Limit of Backup Tasks Per Node' and reduce the number, decreasing the load on your Proxmox platform.
Remember to save changes each time you change the limit.

PX3 60 3.png

[edit] Including Predefined Backup Schedules

You can include scheduled backup templates with Proxmox VE VPS & Cloud For WHMCS products. This negates the need to set up backup schedules for each client.
A template only has to be prepared once and will be included with every product you choose.

To set up a template, open the Proxmox VE VPS & Cloud addon and navigate to 'Settings' 'Scheduled Backups Templates', click on 'Create Scheduled Backups Template' and name the template.

PVC UC 17.png
Next, edit the just created template, click on 'Create Task Template' and define the following details. You can create multiple task templates.
  • Start Time - The time when the task for a backup will be issued. Make sure the time you input meets the format: 24-hour time notation with the zeroes included. For example, 07:05, 20:30
  • Day of the Week - The days the backups should occur each week.
  • Compression Type - Compression method to be used.
  • Backup Mode - Decide on the backup mode.
  • Send Email Message - Decide if an email notification about the backup should be sent always, never, or only on failure.
  • Recipients - include the email addresses you would like the notification to be sent to. Separate each address with a comma.
    You can include the {clientEmail} variable to include the client's default address in the list or leave the field empty to only send the notification to that default address.

Click on 'Confirm' when ready.

PX3 61 2.png
Once the template is created, it can be included in the product's module settings.
Each time a new virtual machine is created using this configuration, the scheduled backups will be set up according to the template.
Remember to save changes each time you change module settings.
PVC UC 18.png

[edit] Including Predefined Firewall Settings

You can include firewall templates with Proxmox VE VPS & Cloud For WHMCS products, which eliminates the need to set up firewall settings for each individual client.
A template only needs to be prepared once and will be included with every product.

To set up a template, open the Proxmox VE VPS & Cloud addon, navigate to 'Settings' 'Firewall Templates', click on 'Create Template', and name the template.

PVC UC 19.png
Configure the template's firewall settings as needed for the specific product and click on 'Submit'. You can also add firewall rules to the template, proceed to 'Add Rule'.
PX3 62 2.png
Prepare as many rules as you need for the given template.
PX3 62 3.png
Once a template is created all that remains is to include it in a product's module settings. Remember to save changes.

Every virtual machine created with the firewall template included in the configuration will have its firewall preset, eliminating the need to manually configure the firewall for each machine.

PVC UC 20.png

[edit] Incorporating Operating Systems Groups

In Proxmox VE VPS For WHMCS you may categorize your operating system templates into groups.
When a virtual machine is created for the first time using a specific template, future reinstallations are limited to templates included in the same groups.

To create operating systems groups open the Proxmox Addon and navigate to 'Settings' 'Operating Systems Group'.
Click on 'Create Operating Systems Group' and name your group.

PX3 63 1.png
Click on 'Add Template' and type in the exact name of the operating system template.
If you need a reminder, you can see the list of your operating system templates in, for example, the module settings → 'Virtual Machine Configuration' 'OS Template'.

Add all the templates that you want to include in the group.

PX3 63 2.png
Repeat the process for different operating systems groups.

In this example, we will create a group for free Linux systems and another one for Windows.

PX3 63 3.png
After the groups are created, open a product's module settings and find 'OS Groups' under 'Client Area Features'.
Pick the groups you would like to include from the list.

Keep in mind that if the template used by the virtual machine is featured in more than one group, clients will be able to reinstall their virtual machines using any template included across all of the mentioned groups,
as long as those groups are included in the product's module settings.
Note: Once a product is categorized into a group, the 'OS Templates' field will not be taken into account while displaying available templates.

PX3 63 4.png
Once the client's virtual machine is created, the 'Reinstall' function will be limited by the operating systems groups.

In this example, the client chooses 'Ubuntu' in the order form, so after machine creation, he can only reinstall within the 'Linux systems' group.
If the client chooses 'Windows 11', he will be locked to the 'Windows systems' group.
If we included Ubuntu in the 'Windows systems' group, the client would be able to reinstall to every system included within those two groups.

PX3 63 5.png
With the current configuration, this client can only reinstall to Windows (and change his operating systems group) by upgrading his product.
PX3 63 7.png
Admins can check and manually change the base template, and by extension, the operating systems group.

The information is recorded in the 'Base Template' custom field.

PX3 63 6.png

[edit] Using Load Balancer

Proxmox VE VPS & Cloud For WHMCS includes a load balancer feature that can help you make sure your server resources are used efficiently. Some of the possible setups include:
  • Setting up an equal number of virtual machines on each node.
  • Migrating virtual machines on upgrade when a node runs out of free space.
  • And much more.

The general information can be found in the dedicated section of the wiki. Here are two practical examples of the load balancer working in practical scenarios.

Example 1
If we have two uneven nodes, for example, one with 64 CPU (A) and another with only 32 CPU (B), we can use the load balancer to make sure the smaller one doesn't reach its full load too fast.
Imagine you didn't set up the load balancer to favor the CPU, and the nodes were assigned an equal number of virtual machines. The load could look somewhat like this:

Node A (Number of VMs: 10, Free CPU: 80%, Free Disk Space: 40%, Free RAM: 60%)
Node B (Number of VMs: 10, Free CPU: 20%, Free Disk Space: 40%, Free RAM: 60%)

If the creation of new virtual machines continues, node B will run out of free CPU soon.
If we set up the load balancer in this way:

VMs Number Weight: 1
CPU Weight: 10
Disk Weight: 2
RAM Weight: 3

This is how the calculation will go:

Node A: (1 x 1) + ( 2 x 10 ) + ( 1 x 2 ) + ( 1 x 3 ) = 26
Node B: (1 x 1) + ( 1 x 10 ) + ( 1 x 2 ) + ( 1 x 3 ) = 16

Node A gets the higher number, so virtual machines will be created on node A until the free CPU resource priority changes in favor of node B.
In this way, node B will no longer run out of free CPU any faster than node A.
Note: You can of course use different weights, the important part is that you put emphasis on the CPU Weight, and make it significantly bigger than the rest.

Example 2
Here is another example. Let's say we have 2 nodes with the same specification, but we allow our customers to personalize their virtual machines with bigger disk space, RAM, etc.
If we only use the number of virtual machines in the calculation, the free resources on the nodes will be uneven:

Node A (Number of VMs: 10, Free CPU: 20%, Free Disk Space: 50%, Free RAM: 60%)
Node B (Number of VMs: 10, Free CPU: 50%, Free Disk Space: 12%, Free RAM: 40%)

But if we set up the load balancer to not favor the number of virtual machines, but the resources equality:

VMs Number Weight: 1
CPU Weight: 10
Disk Weight: 10
RAM Weight: 10

The calculation will look like this:

Node A: (1 x 1) + ( 1 x 10 ) + ( 2 x 10 ) + ( 2 x 10 ) = 51
Node B: (1 x 1) + ( 2 x 10 ) + ( 1 x 10 ) + ( 1 x 10 ) = 41

The virtual machines will be placed on node A, as long as it has more free resources, the number of virtual machines hardly matters anymore.
Node B will be used again when it has more free resources than node A.

[edit] Changing Bandwidth Usage Reset Date

By default the bandwidth usage in Proxmox VE VPS & Cloud For WHMCS resets each month, on the day of the product registration.

If the product was first registered 21st of March, the bandwidth will reset on the 21st of each month.

PX3 64.png
There is however, an option to have the bandwidth usage reset on the first day of the month. This can be beneficial for easier billing, easier usage tracking, and reduced confusion in general.
It might also be a good idea if you want all of your customers to have their bandwidth usage reset on the exact same day.

To make this change, navigate to the product's module settings and the 'General' section, where you will find the 'Reset Usage First Day of Month' switch.
Turning the switch on will change the reset day.

PX3 65.png

[edit] Providing rDNS Management for Proxmox VE VPS & Cloud

With DNS Manager For WHMCS, you can offer clients the ability to manage rDNS records for IP addresses allocated to their ordered servers.

Learn more about this feature and how it integrates with Proxmox VE VPS & Cloud in a dedicated section of DNS Manager For WHMCS documentation page.

PX3 66.png

[edit] Tips

This section is currently being updated, you may encounter broken links or outdated descriptions.
Please accept our apologies for any inconvenience.

1. Operations performed on the virtual servers are not executed immediately. Give your Proxmox Virtual Environment some time to process the request and execute the operation.
2. Multiple physical Proxmox servers can be joined into one cluster.

When they are joined into one cluster, you can access all of them by connecting to just one.

  • Auto-node - creates a new VM on the server (node) with the most free resources, so the administrator cannot control it
  • Server-node - creates a VM on the server (node) whose IP address or node host (e.g. node1.yourproxmox.com) was provided during the WHMCS's server configuration,
    allowing the administrator to control the node choice
3. If you set the product type to 'Hosting Account' when adding a new product, you will not need to fill out nameservers as they will be automatically set up.
But if you still want to use the 'Server/VPS' product type, this article might help you in learning how to remove nameservers from your order template.
4. OS Templates are not automatically downloaded while configuring a product.
For each virtualization type, templates are downloaded from the Proxmox server depending on which one they are generated on.
5. OS Templates are loaded from the storage. Make sure the module can access its content by selecting appropriate permissions for the chosen storage.
6. When the PAM authentication is used, it is necessary to create a client first in order to change the password correctly. Read more about it here.
7. As this module supports the templates system, any changes made in the module's template files will be saved after the upgrade process.
9. OS Templates serve only as operating systems for the VM, while VM Templates contain complete configuration of the VM, the amount of resources included.
10. You can use the {$service_assigned_ips} tag in your welcome email template to display automatically assigned IP addresses for the created VM (either the KVM or LXC virtualization type).
Other available tags in the 'Client Notifications' emails:
{$user.username}
{$user.password}
{$user.realm}

If you wish you may add other information, like password, into the email, just refer to e.g. 'VPS Server Welcome Email' email template in your WHMCS to find appropriate merge fields.
Important: Remember that if the client's email address is incorrect or WHMCS is not able to correctly send it because of any reason, the module will not create the VM for that client correctly.

11. 'One User Per VPS' option allows you to either create a new username for each new client's VM, or create only one that will be then used for every new VM owned by your client.
12. You can use the 'IP Set IP Filter' option for firewall to prevent IP spoofing. Click here to read more about IP Sets.

Inside the admin area, in the product details view, you can preview the current IP Sets on VM:

PX3 68.png
13. You can enable 'Admin Notifications' on product configuration to be informed via email about certain actions. These are:
  • Service Creation Failed - if there were any errors that prevented the VM from being successfully created, then the selected email template will be sent to the administrator
  • Upgrade - select the email notification template you want to receive if the client requests the product upgrade.
    This will also block the automatic sending of an upgrade request to the Proxmox API, so the administrator can review it first.
    Note that, if chosen, the product will still be upgraded in the WHMCS itself, but the upgrade request will not be passed to the API.
    To finalize the upgrade, use the "Change Package" module command in your admin area.
  • To-Do List - if checked, in addition to sending any of the above notifications, it will also add them as tasks on the WHMCS To-Do List.
PX3 69.png
Default email templates include basic variables, but you can include more, such as:
  • service_customfields - any custom fields defined for the service, for example:
{$service_customfields.vmid} {$service_customfields.node}
{$service_customfields.userName} {$service_customfields.cipassword}
{$service_customfields.sshkeys} {$service_customfields.baseTemplate}
  • client- client data from WHMCS:
{$client.userid} {$client.client_id} {$client.id}
{$client.owner_user_id} {$client.uuid} {$client.firstname}
{$client.lastname} {$client.fullname} {$client.companyname}
{$client.email} {$client.address1} {$client.address2}
{$client.city} {$client.fullstate} {$client.state}
{$client.postcode} {$client.countrycode} {$client.country}
{$client.phonenumber} {$client.tax_id} {$client.email_preferences}
{$client.statecode} {$client.countryname} {$client.phonecc}
{$client.phonenumberformatted} {$client.telephoneNumber} {$client.billingcid}
{$client.notes} {$client.currency} {$client.defaultgateway}
{$client.cctype} {$client.cclastfour} {$client.gatewayid}
{$client.groupid} {$client.status} {$client.credit}
{$client.taxexempt} {$client.latefeeoveride} {$client.overideduenotices}
{$client.separateinvoices} {$client.disableautocc} {$client.emailoptout}
{$client.marketing_emails_opt_in} {$client.overrideautoclose} {$client.allowSingleSignOn}
{$client.email_verified} {$client.language} {$client.isOptedInToMarketingEmails}
{$client.tax_state} {$client.tax_countrycode} {$client.lastlogin}
{$client.customfields} {$client.customfields1} {$client.customfields2}
{$client.customfields3} {$client.customfields3}
  • vm- virtual machine related data, as long as it is present:
{$vm.digest} {$vm.acpi} {$vm.affinity}
{$vm.agent} {$vm.arch} {$vm.args}
{$vm.audio0} {$vm.autostart} {$vm.balloon}
{$vm.bios} {$vm.boot} {$vm.bootdisk}
{$vm.cdrom} {$vm.cicustom} {$vm.cipassword}
{$vm.citype} {$vm.ciupgrade} {$vm.ciuser}
{$vm.cores} {$vm.cpu} {$vm.cpulimit}
{$vm.cpuunits} {$vm.description} {$vm.efidisk0}
{$vm.freeze} {$vm.hookscript} {$vm.hostpci[n]}
{$vm.hotplug} {$vm.hugepages} {$vm.ide[n]}
{$vm.ipconfig[n]} {$vm.ivshmem} {$vm.keephugepages}
{$vm.keyboard} {$vm.kvm} {$vm.localtime}
{$vm.lock} {$vm.machine} {$vm.memory}
{$vm.migrate_downtime} {$vm.migrate_speed} {$vm.name}
{$vm.nameserver} {$vm.net[n]} {$vm.numa}
{$vm.numa[n]} {$vm.onboot} {$vm.ostype}
{$vm.parallel[n]} {$vm.protection} {$vm.reboot}
{$vm.rng0} {$vm.sata[n]} {$vm.scsi[n]}
{$vm.scsihw} {$vm.searchdomain} {$vm.serial[n]}
{$vm.shares} {$vm.smbios1} {$vm.smp}
{$vm.sockets} {$vm.spice_enhancements} {$vm.sshkeys}
{$vm.startdate} {$vm.startup} {$vm.tablet}
{$vm.tags} {$vm.tdf} {$vm.template}
{$vm.tpmstate0} {$vm.unused[n]} {$vm.usb[n]}
{$vm.vcpus} {$vm.vga} {$vm.virtio[n]}
{$vm.vmgenid} {$vm.vmstatestorage} {$vm.watchdog}
{$vm.ha} {$vm.status} {$vm.vmid}
{$vm.clipboard} {$vm.cpus} {$vm.maxdisk}
{$vm.maxmem} {$vm.pid} {$vm.qmpstatus}
{$vm.running-machine} {$vm.running-qemu} {$vm.spice}
{$vm.uptime}
  • service- additional service data:
{$service.id} {$service.userid} {$service.orderid}
{$service.packageid} {$service.server} {$service.regdate}
{$service.domain} {$service.paymentmethod} {$service.qty}
{$service.firstpaymentamount} {$service.amount} {$service.billingcycle}
{$service.nextduedate} {$service.nextinvoicedate} {$service.termination_date}
{$service.completed_date} {$service.domainstatus} {$service.username}
{$service.notes} {$service.subscriptionid} {$service.promoid}
{$service.promocount} {$service.suspendreason} {$service.overideautosuspend}
{$service.overidesuspenduntill} {$service.dedicatedip} {$service.assignedips}
{$service.ns1} {$service.ns2} {$service.diskusage}
{$service.disklimit} {$service.bwusage} {$service.bwlimit}
{$service.lastupdate} {$service.created_at} {$service.updated_at}
{$service.domainPunycode} {$service.password}
14. The 'Minimum Network Rate Limit' option allows you to change the previously entered 'Network Rate Limit' value to a new one if the current 'Bandwidth Limit' is already reached.
Note that the 'Bandwidth Limit' can also be used for the WHMCS overage billing calculation as described here.
PX3 70.png
15. 'Default Username Prefix' - when filling in this field you may use the {$serviceid} parameter to avoid problems with creating usernames that already exist.
16. It is possible to display more information about your VM in Proxmox Environment.
To do so, you need to provide the preferred records in the 'Container Notes' tab under the ' KVM or LXC Configuration' section.
The following records can be used:
Client: {$client_name} (ID: {$client_id}) 
Email: {$client_email} Service ID: {$service_id} 
Product: {$product_name} (ID: {$product_id})
Hostname: {$service_domain} 
Main IP: {$service_dedicated_ip} {if $service_assigned_ips} 
IP Address Allocation: {$service_assigned_ips} {/if}

You may also use markdown to modify the container notes, for example:

Client: {$client_name} (ID: {$client_id})\ 
Email: {$client_email}\
Service ID: {$service_id}\ 
Hostname: {$service_domain}\ 
Main IP: {$service_dedicated_ip} {if $service_assigned_ips} 

The above notes will be displayed with every item starting in a new line.

17. When the interface names on the VM are Net\d+, you need to choose Eth\d+ in the 'Firewall' section of the product configuration.
18. If you want your clients to provide their own hostname, you need to add the following custom field in the 'Custom Fields' tab of the product configuration.
 proxmoxHostname|Hostname 
19. Create Linux VM:
  • Create a VM template according to descriptions here
  • Move to Module Settings → Virtual Machine Configuration → OS Template, select the previously created template (e.g. Ubuntu)
  • In Module Settings → Cloud-Init: Cloud-Init: On, Service Username: On, Service Password: On
PX3 99.png
  • Place a new order, wait until all tasks in Proxmox Addon → Tasks have 'finished' status.
20. Create Windows VM:
  • Create a new virtual machine using an ISO image in Proxmox panel
  • Install Guest Agent on the windows system, read more here
  • Convert the created machine into a KVM template
  • Move to the product Module Settings → Guest Agent and switch options as below:
PX3 100.png
  • Module Settings → Virtual Machine Configuration: select the previously created Windows template under OS Template
  • Place a new order, wait until all tasks in Proxmox Addon → Tasks have 'finished' status.
21. Configuring 'Default User' per template. Move to 'Proxmox Addon' → 'Servers' → 'Server Details' → 'Templates' → 'Create/Edit Template'.

You may assign a default user to a single template, that user will be automatically assigned to the newly created VM.

22. Configurable option field: 'Storage Disc Space' - this option allows to define the type and space on disc via a configurable option when placing an order.
It also allows to extend the space as well as change the disc type. This CO overwrites the ordinary 'Disc Space' field available in the product configuration section.

Important: To migrate the disc, you must previously 'Stop' your VM.
Note: Values provided in configurable option must be integers.

23. Usage of VLAN Tags:

VLAN Tags Range Minimum and Maximum Numbers simply play the role of network separation measures. The minimum and maximum numbers cause the module to select the next free VLAN Tag from this range for each virtual machine it creates.
VLAN Tag is actually a drop-down list, and to select anything in this section, firstly, it is necessary to configure appropriate IP addresses in your Proxmox addon → IP Management section:

PXC2 30 3.png
PXC2 30 4.png
24. SDN Support:

The module supports SDN private network type. It is possible to create virtual networks (vnets) at datacenter level thanks to the Software Defined Network (SDN).
To learn all the details on SDN in proxmox, please navigate to the official proxmox documentation.

In the module, the whole configuration of SDN is located in 'Module Settings' → 'Private Network' section. There you will find dedicated options, these are:

  • Private Network Type
  • SDN Zone
  • SDN TAG Range Minimum Number
  • SDN TAG Range Maximum Number
PXC2 32.png
25. The "fetchBackupsForArchive" parameter in the "global_options.yml" file allows skipping the backups from being loaded into the "Archive" list in the product configuration.

By default the parameter is set to 'true' and backups are loaded. You may change it manually to 'false' and no backups will be loaded in the 'Archive' dropdown list as on the screens below:

PX2 33 0.png
PX2 33 1.png
26. OS Templates and ISO Images' names - translate the names of available templates and images easily.
Add extra lines into the module language file (e.g. /yourWHMCS/modules/servers/proxmoxVPS/langs/english.php) with your desired translations to customize their names.

Follow the bellow pattern to add new lines:

$_LANG['template']['ISO_name'] = 'My ISO Name';  

For example:

$_LANG['template']['Ubuntu'] = 'Ubuntu - preferred';
$_LANG['template']['Debian Live 9.4.0 Amd64 Cinnamon'] = 'Aktuelles Debian';

Please note that ['ISO_name'] must be replaced with the full template or image name that you are going to change.
As a result, the OS templates and ISO images names will be displayed in the language of your choice or with your custom name.

27. If you want to use the IP Address, CIDR and Gateway allocated from the IP Management section of the Proxmox Addon module instead of hard coding them, use the following parameter:
 {$ipv4Addresses[0].gateway}
28. Select the storage type already while placing the order.

Create the "Storage Disk Space" configurable option with storage size and name to allow clients to set "Storage Disk Space" during the order. It will be used instead of the provided "Disk Space" value.
For VE VPS KVM and LXC:

  • Resource Usage:
    • Available resources
    • Disc size
    • Storage type

Exceptions:

  • if the "Linked Clone" option is selected in "Clone Mode" of the KVM configuration, the storage disk space will not work. (In the case of a linked template the KVM must have the same storage as the machine's main disk)
29. Private Network management

The module allows to create private network skipping the IP Management and firewall settings. Disable the below options if you do not aim to assign the IP address to the private network device.

  • 'Assign IP Address Automatically' - option toggled by default; the IP Address is automatically assigned to a private network device
  • 'Firewall on Private Network' - option toggled by default; the firewall is enabled on a private network device
PX3 22 9.png
30. Make sure not to swap public and private network bridges during product upgrades.

Using a bridge previously used for the opposing network type, can lead to several issues. Make sure the upgrade scenario looks like this:

Product 1 (before upgrade):
Private Bridge: vmbr1
Public Bridge: vmbr0
Product 2 (after upgrade): 
Private Bridge: any, except vmbr0
Public Bridge: any, except vmbr1

You can either keep it in mind when selecting bridges for upgrades or use the 'Reassign Public/Private IP Addresses After Upgrade' toggles, which will safely reassign IP addresses and bridges for you.

31. How to Test Cloud Init in Proxmox Panel

If a Linux machine does not have a password or network configured, but the data is correctly sent to the Proxmox panel, check if Cloud Init is properly configured on the template.
To test this, set the password and user in the Proxmox panel’s Cloud Init section and clone the template. This will confirm if the password is applied correctly in the system.

32. The Proxmox VE VPS For WHMCS module is fully compatible with all versions of Proxmox VE that are actively supported by Proxmox.
Ensure your Proxmox VE version is within its official support lifecycle to guarantee compatibility.

[edit] Update Instructions

Essential guidance through the process of updating the module is offered here.

Please note that each time you update the module, you have to also update the files on the Proxmox server described in the step 4 of the installation guide.

Important: After upgrading the module to the newest version please first enter to the Proxmox VE VPS & Cloud addon in your WHMCS before setting up the product or opening it from admin or client area!
Otherwise, when you try to open the product's module settings, you may get SQLSTATE" "Base table or view not found" errors.

[edit] Upgrade Guide

Seeking a solution that offers greater flexibility, customization tailored to your precise needs, and unrestricted availability?
There is an option that not only proves to be cost-effective in the long run but also includes prioritized support services, making it a truly valuable investment.

Opt for the Open Source version of your Proxmox VE VPS For WHMCS module to unlock these benefits.
Simply click on either the Get Source Code or Upgrade To Lifetime button found on the product's page in our client area to complete the one-step upgrade process, with a dedicated discount already applied.

Follow a comprehensive guide covering the transition process, the advantages it brings, and step-by-step instructions on what to do next after the order has been successfully finalized.

[edit] Module Upgrade From V3.X to V4.X

Upgrading from version 3.11.1 to 4.0?

As part of the upgrade, the product has undergone a name change, and the license file has been relocated to the addon.
Important: You will need to reissue your license for the changes to take effect.

The migration tool works reliably only if your most recently used version is 3.11.1.
If you are using an earlier version and plan to upgrade to 4.0, please update to 3.11.1 first.

Important:
When updating the module to version 4.1.x and higher, it is highly recommended to first update to the 4.0 stable release.
As explained in the module update guide, you should never skip major versions during the update process.
Skipping major versions may result in missing updates, installation errors, or compatibility issues.

[edit] Automatic Migration Tool

Products and their module settings will be migrated from your current installation using the new automated process.

Follow these steps:

1. Update the module following our standard procedure described here: Update Instructions.

Important: Please ensure that your license file is updated, as the module name has changed.

2. Before running the migration command, make sure that all configured Proxmox nodes are reachable and responsive. If any node is unavailable, the migration may fail due to a timeout.

3. Once all update steps are completed and all nodes are confirmed operational, run the migration cron command.
You can find your personalized command in: Addons → Proxmox VE VPS & Cloud → Settings → General Settings → Cron job for module migration from v3 to v4

Command:

php -q /yourWHMCS/modules/addons/ProxmoxVeVpsCloud/cron/cron.php migration:v3_v4   

4. Wait for the migration process to complete. Once finished, verify that all data has been transferred correctly.

5. After migration, go to the product’s module settings and make sure to configure the required fields: Default Application Group and Default Application. These fields are new and must be set.
To create application entries, navigate to the Addon → App Templates section.

Once configured, you can start using the new version of the module.

Note: If you were testing the 4.0.0 beta version of the module and wish to update to the stable release, please run the migration cron to ensure all data is preserved.

Console Steps

For your reference, here is a breakdown of the actions performed during the cron job execution:

  • Creating database tables
  • Migrating database tables
  • Updating product configuration
  • Transferring existing virtual machine data to ProxmoxVeVpsCloud_Vm database table
  • Updating server types
  • Updating product types
  • Generating App Templates
  • Updating App Templates configurable options ('Templates' and 'ISO Images)'
  • Adding app templates info to ProxmoxVeVpsCloud_Vm database table
  • Completing the migration


Note: The migration is performed within a database transaction.
This means that if any error occurs during the process, all changes will be automatically rolled back to the pre-migration state to ensure your system remains intact.

[edit] Import Existing Virtual Machines

Import existing virtual machines into the module once a new product is created.

To do this, simply open the desired product page in the admin area and click the "Import Virtual Machine" button, as shown in the screenshot below.

Note: The module allows you to easily import VM into your product; this feature is supported for both VPS and Cloud type products.

PVC4 45 3.png
Afterward, select the desired virtual machine from the dropdown menu and fill in the Password field.

To complete the process, click the Confirm button.

PXC3 45 4.png

[edit] Common Problems

This section is currently being updated, you may encounter broken links or outdated descriptions.
Please accept our apologies for any inconvenience.

1. When you have problems with connection, check whether your SELinux or firewall does not block ports.
2. Error 'Could not create PVE2_API object' during connecting via the noVNC console.

Reason: The user account does not have permission to access the noVNC console.
Solution: Proceed to the product's 'Module Settings' tab and check whether the selected user's permission grants access to the noVNC console.
Afterward, proceed to the client's hosting and run 'Change User Role' on it.

To change the user role for all clients, please use the 'Cron job for users synchronization (run only once)' cron command.
You will find it in the 'Proxmox VE VPS & Cloud Addon' → 'Settings' → 'General Settings'.

3. Error 'This connection is untrusted' during connecting via the noVNC console.

Reason: Your certificate is not valid.
Quick Solution: Your client needs to add the Proxmox address to the certificate exception list.
Best Solution: Configure a valid certificate.

4. The blank page during connecting via noVNC console, '501 Error' visible in the proxmox panel.

Reason: You have not uploaded the additional files on the Proxmox server.
Solution: Open 'UploadOnProxmoxServer' and upload content of the proper version on all Proxmox servers into the '/' path.

5. Error 'Change password failed: user 'xxx' does not exist'

Reason: You have not created a client yet.
Solution: When the PAM authentication is used, it is necessary to create a client first in order to change the password correctly. Read more about it here.

6. Error 'Function "ssh2_connect" does not exist. Please Install SSH2 PECL before you start using the script.'

Reason: You have not updated the php.ini file.
Solution: After SSH2 PECL installation, make sure that you have updated the php.ini files for CLI and webserver.

7. Error: "Only root can set 'serial0' config".

Solution: Turn off the Xterms.js console in the product configuration.

8. Error "Parameter verification failed. ([maxfiles] - Only root may set this option.)"

Reason: The user is other than "root" or the server authentication is set to Proxmox VE.
Solution: In the server configuration, set the root details, and select PAM as the authentication type.

9. Error "Node for IP Address 10.10.10.10 not found"

Reason: An interface with the IP Address 10.10.10.10 cannot be found.
Solution: You need to provide your private IP Address node in the 'Assigned IP Addresses' field in the server configuration in your WHMCS.

10. Please remember that the disk size cannot be downgraded. Such a possibility is not supported.
11. Error: "Cannot clone to non-shared storage 'local"

Reason: Option 'Search For Templates On All Nodes' is enabled in the product configuration under KVM configuration.
Solution: Keep the above option disabled as shown on the screen.

PX3 101.png

Remember that cloning from node "A" to node "B" does not work on the local storage.
We do recommend using "Shared Storage" or creating the machine on the same node on which the KVM template is located.

It is important to keep every template named the same on every node, otherwise cloning will not work either, eg.:
node1: Ubuntu, CentOS, Debian
node2: Ubuntu, CentOS, Debian

12. Error: "Nameserver '%' cannot be resolved"

Reason: The nameserver IP must be provided for the virtual machine of LXC configuration type.
By default, the module uses the content provided by the client during order, eg. ns1, then WHMCS completes the nameserver with a domain.
If the nameserver field is left empty or the client orders a new domain, the system is not able to process the data correctly and create a full address.
Solution: Enable the 'Use Server Nameservers' option in the product's configuration or manually correct the nameserver per the order.

13. Error: "SQLSTATE[42S02]: Base table or view not found: Table 'ProxmoxAddon_ServerUsage' doesn't exist"

Reason: The ProxmoxAddon_ServerUsage table has not been created properly because the tblservers table is on a different engine than "InnoDB"
Solution: Change the engine to "InnoDB", deactivate the proxmox addon and then activate it again. The missing table will be created.

14. Error: "([boot] - invalid format - format error boot.order: invalid format - invalid boot device 'c')"

Solution: Edit the boot order in any of the templates to ensure the boot order is saved in a new format (after the change you may go back to the previous order)

15. In case you encounter any problems with the 'Guest Agent', please first ensure that the service is active in the machine's operating system.

You may use the following command in PowerShell to check the status:

 Get-Service QEMU-GA

To restart the service (stop and start again) use the following command:

 Restart-Service QEMU-GA
16. Error: "SQLSTATE[HY000] [2002] php_network_getaddresses: getaddrinfo for proxydb failed: Temporary failure in name resolution"

Solution: Make sure there are no old volumes or duplicate .env files present.

17. Module integration notice

The current 4.0.x version is not yet integrated with the following modules. These integrations will be restored in upcoming updates:

  • Products Reseller For WHMCS
  • Server Monitoring For WHMCS
Navigation
WHMCS Modules
WHMCS Module Bundles
WHMCS Widgets
Tools And Applications
Translations
General
FAQ
Community
Proxmox VE VPS And Cloud For WHMCS