Personal tools
Namespaces

Variants
Actions

Proxmox Cloud 2.X For WHMCS

From ModulesGarden Wiki
(Difference between revisions)
Jump to: navigation, search
 
(227 intermediate revisions by 8 users not shown)
Line 2: Line 2:
 
<meta name="description" content="ModulesGarden Wiki Contains All The Information You Need About The Proxmox Cloud For WHMCS Module."></meta>
 
<meta name="description" content="ModulesGarden Wiki Contains All The Information You Need About The Proxmox Cloud For WHMCS Module."></meta>
  
=About [http://www.modulesgarden.com/products/whmcs/proxmox_cloud/features Proxmox Cloud For WHMCS]=
+
=About [https://www.modulesgarden.com/products/whmcs/proxmox-cloud Proxmox Cloud For WHMCS]=
<h4 style="color: #ff0000; font-weight:bold; text-align:center;">Article update is ongoing on this page, watch out for broken links and unclear descriptions!<br />
+
We are sorry for the inconvenience caused.</h4>
+
 
{|
 
{|
|style="padding: 10px 0px 10px 0px;"|'''Proxmox Cloud For WHMCS''' offers your clients the possibilities to create, remove and freely resize their own virtual servers within resource limits defined by you.
+
|style="padding: 10px 0px 10px 0px;"|'''Proxmox Cloud For WHMCS''' offers your clients the flexibility to create, remove and freely resize their own virtual servers within resource limits defined by you.
With our module your customers will be able to single-handedly create as many servers as they need and manage aspects like backups, network devices or firewall.<br />
+
Your customers will be able to create as many servers as they need, manage such essential aspects like backups or firewall, and access noVNC, SPICE, or Xterm.js console.<br />
This gorgeous product lets you also conveniently manage servers, IP addresses and clusters owing to the unique Proxmox Addon attached to the module.
+
The module supports Cloud-Init for the KVM virtualization type, and features Proxmox Addon allowing you to easily manage servers, IP addresses and clusters.
 
|}
 
|}
 
<!--comments are awesome -->
 
<!--comments are awesome -->
 
*'''Admin Area Features:'''
 
*'''Admin Area Features:'''
 
{|
 
{|
|style="padding: 10px 0px 0px 30px;"|✔ Create Server/User
+
|style="padding: 10px 0px 0px 30px;"|✔ Create/Suspend/Unsuspend/Terminate User Account
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Suspend/Unsuspend Server/User
+
|style="padding: 0px 0px 0px 30px;"|✔ Change Package
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Terminate Server/User
+
|style="padding: 0px 0px 0px 30px;"|✔ Change User Role
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Migrate Server Between Nodes
+
|style="padding: 0px 0px 0px 30px;"|✔ Reset Bandwidth
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Import Server
+
|style="padding: 0px 0px 0px 30px;"|✔ Migrate/Import/Delete Server
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 30px;"|✔ Edit Server Node
 
|}
 
|}
 
{|
 
{|
Line 31: Line 32:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ View Graphs - With Ability To Change The Time Scale of MRTG Graphs
+
|style="padding: 0px 0px 0px 30px;"|✔ View Graphs - With Ability To Change Time Scale of MRTG Graphs
 
|}
 
|}
 
{|
 
{|
 
|style="padding: 0px 0px 0px 30px;"|✔ Display Disk And Bandwidth Usage Of Each Product
 
|style="padding: 0px 0px 0px 30px;"|✔ Display Disk And Bandwidth Usage Of Each Product
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 30px;"|✔ Display CPU, SWAP and Memory Usage Of Each Product
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 30px;"|✔ Select Server Locations Available For Clients
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 30px;"|✔ Configure Client Area Features Per Product
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 30px;"|✔ Define Static Or Dynamic Resource Limits
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 30px;"|✔ Define Server Minimum And Maximum Resource Values
 
|}
 
|}
 
{|
 
{|
Line 40: Line 56:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Return IP Address To IP Addresses Pool
+
|style="padding: 0px 0px 0px 30px;"|✔ Return IP Address To IP Addresses Subnet
 
|}
 
|}
 
{|
 
{|
Line 46: Line 62:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 10px 30px;"|✔ Configure Functionalities Displayed In The Client Area
+
|style="padding: 0px 0px 0px 30px;"|✔ Enable Qemu Guest Agent (KVM)
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 30px;"|✔ Enable Backups Routing
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 30px;"|✔ Enable Auto VM Backups Before Reinstallation
 +
|}
 +
{|
 +
|style="padding: 0px 0px 10px 30px;"|✔ Enable Load Balancer
 
|}
 
|}
 
*'''Proxmox Addon Features:'''
 
*'''Proxmox Addon Features:'''
 
{|
 
{|
|style="padding: 10px 0px 0px 30px;"|✔ Servers List (VPS And Cloud)
+
|style="padding: 10px 0px 0px 30px;"|✔ Display Servers: List Per VPS And Cloud
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ IP Management (Per Server)
+
|style="padding: 0px 0px 0px 45px;"|✔ List Per VPS And Cloud
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Clusters (Per Server)
+
|style="padding: 0px 0px 0px 45px;"|✔ Clusters List
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ KVM Templates
+
|style="padding: 0px 0px 0px 45px;"|✔ VMs List
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Define VM ID Ranges Per Product
+
|style="padding: 0px 0px 0px 45px;"|✔ KVM Templates
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 10px 30px;"|✔ Set Minimum VM ID For Product Without ID Ranges Defined
+
|style="padding: 0px 0px 0px 45px;"|✔ Recovery VM Configurations List With Export To Backup File
 
|}
 
|}
*'''Client Area Features:'''
 
 
{|
 
{|
|style="padding: 10px 0px 0px 30px;"|✔ Add/Manage/Delete Servers
+
|style="padding: 0px 0px 0px 45px;"|✔ Tasks History
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ View Available Resources
+
|style="padding: 0px 0px 0px 45px;"|✔ Statuses, Resources Usage, IP Assignments And Details
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Create VM
+
|style="padding: 0px 0px 0px 30px;"|✔ Manage  Public & Private IP Addresses Per Server, VLAN, Tag And Node
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Boot/Reboot/Stop Server
+
|style="padding: 0px 0px 0px 30px;"|✔ VM Cleaner - Manage VM Not Existing In Your WHMCS
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Shutdown Server
+
|style="padding: 0px 0px 0px 30px;"|✔ Convert KVM VPS To KVM Template
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Edit Server
+
|style="padding: 0px 0px 0px 30px;"|✔ Define VM IDs Ranges Per Server
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Reinstall Server - OpenVZ Only
+
|style="padding: 0px 0px 0px 30px;"|✔ Set Minimum VM ID For Product Without ID Ranges Defined
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ VNC/SPICE/noVNC Console
+
|style="padding: 0px 0px 0px 30px;"|✔ Configure Resources Weights For Load Balancer Prioritization
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Create/Restore Backups
+
|style="padding: 0px 0px 10px 30px;"|✔ Synchronize Users Permissions
 
|}
 
|}
 +
 +
*'''Client Area Features:'''
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Backup Routing
+
|style="padding: 10px 0px 0px 30px;"|✔ Create/Edit/Delete Servers
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Backup Jobs
+
|style="padding: 0px 0px 0px 30px;"|✔ Boot/Reboot/Stop/Shutdown Server
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Backup Files & Job Limits (Max Number Of Files & Max Size Of Files)
+
|style="padding: 0px 0px 0px 30px;"|✔ Reinstall Server Using Templates (KVM) And ISO Images
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Schedule Backup Limit (Max Number Of Files & Max Size Of Files)
+
|style="padding: 0px 0px 0px 30px;"|✔ Choose Location For New Servers
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ View Graphs - With Ability To Change The Time Scale of MRTG Graphs
+
|style="padding: 0px 0px 0px 30px;"|✔ View Available Resources
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Task History
+
|style="padding: 0px 0px 0px 30px;"|✔ Access noVNC, SPICE And Xterm.js Console
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Manage Network Devices
+
|style="padding: 0px 0px 0px 30px;"|✔ Create/Restore/Delete Backups
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Create Snapshots
+
|style="padding: 0px 0px 0px 30px;"|✔ Manage Backups Within Defined Limits (Max Number Of Files & Max Size Of Files)
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ View Server Status, Details And Statistics
+
|style="padding: 0px 0px 0px 30px;"|✔ Manage Backup Jobs Within Defined Limits (Max Number Of Files & Max Size Of Files)
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Display Disk And Bandwidth Usage
+
|style="padding: 0px 0px 0px 30px;"|✔ View And Edit Public SSH Keys (KVM)
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Change Boot Order (KVM)
+
|style="padding: 0px 0px 0px 30px;"|✔ Create/Upload/Download Public And Private SSH Keys (LXC)
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Change ISO Image (KVM)
+
|style="padding: 0px 0px 0px 30px;"|✔ View Graphs - With Ability To Change Time Scale of MRTG Graphs
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 10px 30px;"|✔ Easy VM Upgrade/Downgrade
+
|style="padding: 0px 0px 0px 30px;"|✔ View Task History
 
|}
 
|}
*'''General Info:'''
 
 
{|
 
{|
|style="padding: 10px 0px 0px 30px;"|✔ Supports PVE And PAM Authentication
+
|style="padding: 0px 0px 0px 30px;"|✔ View Network Devices and Manage Private Interface
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Dynamically Chosen Server Resources While Ordering And Possibility To Upgrade Those Resources
+
|style="padding: 0px 0px 0px 30px;"|✔ Manage Private Networks And Assign Them To Multiple Servers
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Integrated With <u>Advanced Billing For WHMCS</u> - Server Resource Usage Billing [http://www.modulesgarden.com/products/whmcs/advanced_billing/features (read more)]
+
|style="padding: 0px 0px 0px 30px;"|✔ Create Server Snapshots
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Integrated With <u>IP Manager For WHMCS</u> - Complete Management of IP Pools [http://www.modulesgarden.com/products/whmcs/ip_manager/features (read more)]
+
|style="padding: 0px 0px 0px 30px;"|✔ Create VM Template From Server - KVM Virtualization Only
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Multi-Language Support
+
|style="padding: 0px 0px 0px 30px;"|✔ Manage Firewall
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Supports Proxmox VE 3 and Later
+
|style="padding: 0px 0px 0px 30px;"|✔ View Server Status, Details And Statistics
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Supports IPv4 and IPv6
+
|style="padding: 0px 0px 0px 30px;"|✔ Display Disk And Bandwidth Usage
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Custom Hooks
+
|style="padding: 0px 0px 0px 30px;"|✔ Display CPU, SWAP and Memory Usage
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 10px 30px;"|✔ Supports WHMCS V5 and Later
+
|style="padding: 0px 0px 0px 30px;"|✔ Change Boot Order (KVM)
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 30px;"|✔ Change ISO Image (KVM)
 +
|}
 +
{|
 +
|style="padding: 0px 0px 10px 30px;"|✔ Choose Server Resources While Ordering And Upgrade/Downgrade Them Freely
 
|}
 
|}
*'''Available Configurable Options:'''
+
*'''Configurable Options:'''
 
{|
 
{|
 
|style="padding: 10px 0px 0px 30px;"|✔ '''KVM''':
 
|style="padding: 10px 0px 0px 30px;"|✔ '''KVM''':
Line 173: Line 204:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ CPU Weight Limit
+
|style="padding: 0px 0px 0px 45px;"|✔ CPU Limit
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 45px;"|✔ CPU Units Limit
 
|}
 
|}
 
{|
 
{|
Line 179: Line 213:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Storage Limit
+
|style="padding: 0px 0px 0px 45px;"|✔ SWAP Limit
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Bandwidth Limit
+
|style="padding: 0px 0px 0px 45px;"|✔ Storage Limit
 
|}
 
|}
 
{|
 
{|
Line 189: Line 223:
 
{|
 
{|
 
|style="padding: 0px 0px 0px 45px;"|✔ IPv6 Addresses Limit
 
|style="padding: 0px 0px 0px 45px;"|✔ IPv6 Addresses Limit
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 45px;"|✔ Bandwidth Limit
 
|}
 
|}
 
{|
 
{|
Line 194: Line 231:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 10px 45px;"|✔ Backups Files Limit
+
|style="padding: 0px 0px 0px 45px;"|✔ Backups Files Limit
 
|}
 
|}
 
{|
 
{|
|style="padding: 5px 0px 0px 30px;"|✔ '''OpenVZ''':
+
|style="padding: 0px 0px 0px 45px;"|✔ Private Networks Limit
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 45px;"|✔ VCPUs Limit
 +
|}
 +
{|
 +
|style="padding: 0px 0px 10px 45px;"|✔ Network Rate Limit
 +
|}
 +
{|
 +
|style="padding: 5px 0px 0px 30px;"|✔ '''LXC''':
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 45px;"|✔ CPU Sockets Limit
 
|}
 
|}
 
{|
 
{|
Line 203: Line 252:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ CPU Weight Limit
+
|style="padding: 0px 0px 0px 45px;"|✔ CPU Limit
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ SWAP Limit
+
|style="padding: 0px 0px 0px 45px;"|✔ CPU Units Limit
 
|}
 
|}
 
{|
 
{|
Line 212: Line 261:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Storage Limit
+
|style="padding: 0px 0px 0px 45px;"|✔ SWAP Limit
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Bandwidth Limit
+
|style="padding: 0px 0px 0px 45px;"|✔ Storage Limit
 
|}
 
|}
 
{|
 
{|
Line 222: Line 271:
 
{|
 
{|
 
|style="padding: 0px 0px 0px 45px;"|✔ IPv6 Addresses Limit
 
|style="padding: 0px 0px 0px 45px;"|✔ IPv6 Addresses Limit
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 45px;"|✔ Bandwidth Limit
 
|}
 
|}
 
{|
 
{|
Line 227: Line 279:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 30px 45px;"|✔ Backups Files Limit
+
|style="padding: 0px 0px 0px 45px;"|✔ Backups Files Limit
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 45px;"|✔ Private Networks Limit
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 45px;"|✔ VCPUs Limit
 +
|}
 +
{|
 +
|style="padding: 0px 0px 10px 45px;"|✔ Network Rate Limit
 +
|}
 +
 
 +
*'''General Info:'''
 +
{|
 +
|style="padding: 10px 0px 0px 30px;"|✔ Supports Cloud-Init (KVM)
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 30px;"|✔ Supports PVE And PAM Authentication
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 30px;"|✔ Supports KVM and LXC Virtualization
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 30px;"|✔ Integrated With <u>Advanced Billing For WHMCS</u> - Actual Server Resource Usage Billing [https://www.modulesgarden.com/products/whmcs/advanced-billing (read more)]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 30px;"|✔ Integrated With <u>Proxmox Cloud Autoscaling For WHMCS</u> - Automated Servers Resizing [https://www.modulesgarden.com/products/whmcs/proxmox-cloud-autoscaling (read more)]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 30px;"|✔ Integrated With <u>IP Manager For WHMCS</u> - Complete Control And Easy Assignment Of IP Subnets [https://www.modulesgarden.com/products/whmcs/ip-manager (read more)]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 30px;"|✔ Multi-Language Support
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 30px;"|✔ Supports Proxmox VE 6.X And Later
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 30px;"|✔ Supports IPv4 and IPv6
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 30px;"|✔ Supports Custom Hooks
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 30px;"|✔ Supports PHP 7.1 Up To PHP 7.4
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 30px;"|✔ Supports WHMCS Template Six
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 30px;"|✔ Supports WHMCS 7.9 And Later
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 30px;"|✔ Easy Module Upgrade To [https://www.modulesgarden.com/products/whmcs/proxmox-cloud#open-source-version Open Source Version]
 
|}
 
|}
  
 
=Installation and Configuration=
 
=Installation and Configuration=
 
{|
 
{|
|style="padding: 10px 0px 30px 0px;"|'''This tutorial will show you how to successfully install and configure Proxmox Cloud For WHMCS.''' <br />
+
|style="padding: 10px 0px 30px 15px;"|'''This tutorial will show you how to successfully install and configure [https://www.modulesgarden.com/products/whmcs/proxmox-cloud Proxmox Cloud For WHMCS.]''' <br />
 
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.
 
|}
 
|}
 
==Installation==
 
==Installation==
 
{|
 
{|
|style="padding: 10px 0px 20px 15px;"|'''1. Log in to your client area and download Proxmox Cloud For WHMCS.'''
+
|style="padding: 10px 0px 20px 15px;"|'''1. Log in to our client area and download the module.'''
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_1.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2__1.png]]
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 15px;"|'''2. Extract the module and upload 'mgnovnc.html' file located in 'UploadOnProxmoxServer' on all Proxmox servers into '/usr/share/novnc-pve/' folder.'''
+
|style="padding: 0px 0px 15px 15px;"|'''2. In the downloaded file you might find one or two packages that support different PHP versions.'''<br/>
 +
In the most recent versions of the module, you will find only one package that supports PHP 7.1 and later.<br/> <!-- If you need a package for the previous versions of PHP, please [https://www.modulesgarden.com/support/ticket/general-support contact our support]. -->
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 15px;"|'''3. Upload and extract the module into the main WHMCS directory.'''
+
|style="padding: 0px 0px 20px 25px;"|[[File:PHP71_74.png]]
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_2.png]]
+
|style="padding: 0px 0px 15px 15px;"|'''Previous updates of the module may contain two packages dedicated to various PHP versions.'''<br/>
 +
The first one that supports PHP 5.6 up to PHP 7.0, and the second one addressed to PHP 7.1 up to PHP 7.3.<br/>
 +
'''''Note:''' Keep in mind that PHP versions 5.6 up to 7.0 are no longer officially supported and their security issues are not fixed or released any more. Find more info [http://php.net/supported-versions.php here].''
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|'''4. When you install Proxmox Cloud for the first time you have to rename '' 'license_RENAME.php' '' file.'''<br />
+
|style="padding: 0px 0px 20px 25px;"|[[File:PHP56_73.png]]
File is located in '' 'modules/servers/proxmoxCloud/license_RENAME.php' ''. Rename it from '' 'license_RENAME.php' '' to '' 'license.php' ''.
+
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_3.png]]
+
|style="padding: 0px 0px 10px 15px;"|<!-- '' '''Important''': This situation does not affect [https://www.modulesgarden.com/products/whmcs/proxmox-cloud#open-source-version '''the open source version'''] of this module which can be applied to any PHP from version 5.6 and later.''<br/>'' --> '''Note''': You can check the current PHP version in your WHMCS. To do so, proceed to ''' 'Utilities' → 'System' → 'PHP Info'.'''
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|'''5. In order to configure your license key, you have to edit a previously renamed '' 'license.php' '' file.'''<br />
+
|style="padding: 0px 0px 15px 15px;"|'''3. Extract the package and upload its content into the main WHMCS directory.
 +
The content of the package to upload should look like this.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PX2_2_1.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|'''4. Open '' 'UploadOnProxmoxServer' '' and upload content of the proper version on all Proxmox servers into the '' '/' '' path.'''<br />You should upload these files not only during the first installation of the module, but also each time you update it.<br/>
 +
'''''Note:''' 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.''
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|'''5. When you install Proxmox Cloud For WHMCS for the first time, you have to rename the '' 'license_RENAME.php' '' file.'''<br />
 +
This file is located in '' 'modules/servers/proxmoxCloud/license_RENAME.php'. '' Rename it from '' 'license_RENAME.php' '' to '' 'license.php'. ''
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2__3.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|'''6. In order to configure your license key, you have to edit a previously renamed '' 'license.php' '' file.'''<br />
 
Enter your license key between quotation marks as presented on the following screen.<br />
 
Enter your license key between quotation marks as presented on the following screen.<br />
You can find your license key in your client area → '' 'My Products' ''.
+
You can find your license key in our client area → '' 'My Products'. ''
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 30px 25px;"|[[File:PXC_4.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2__4.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|'''7. In the next step, set up the '' 'storage' '' folder as recursively writable.'''<br />
 +
This folder is available at:
 +
'' your_whmcs/modules/addons/proxmoxAddon/ ''
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:PX2_4_1.png]]
 
|}
 
|}
  
 
==Activation of Proxmox Addon==
 
==Activation of Proxmox Addon==
 
{|
 
{|
|style="padding: 10px 0px 15px 15px;"|'''6. Firstly, you should activate Proxmox Addon.''' <br />
+
|style="padding: 10px 0px 15px 15px;"|'''7. Firstly, you should activate Proxmox Addon.''' <br />
To do so, log in into your WHMCS and press '' 'Setup' → 'Addon Modules' ''. Find'' 'Proxmox Addon' ''and press'' 'Activate' ''.
+
To do so, log in into your WHMCS and press '' 'Setup' → 'Addon Modules'. '' Find'' 'Proxmox Addon' ''and press'' 'Activate'. ''<br/><br/>
 +
 
 +
'' '''Note:''' The Proxmox addon version might '''not match''' the current version of the provisioning module itself. This is completely normal due to the specific structure of the product.''
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_5.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2__5.png]]
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|'''7. In next step you need to permit access to this module.'''<br />
+
|style="padding: 0px 0px 15px 15px;"|'''8. In the next step, you need to permit access to this module.'''<br />
To do so, click on '' 'Configure' '' button. Tick '' 'Full Administrator' '' and press '' 'Save Changes' ''.
+
To do so, click on the '' 'Configure' '' button. Tick '' 'Full Administrator' '' and press '' 'Save Changes'. ''
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 30px 25px;"|[[File:PXC_6.png]]
+
|style="padding: 0px 0px 30px 25px;"|[[File:PXC2__6.png]]
 
|}
 
|}
  
 
==Configuration of Server==
 
==Configuration of Server==
 
{|
 
{|
|style="padding: 10px 0px 15px 15px;"|'''8. Now, we will show you how to configure a new product.''' <br />
+
|style="padding: 10px 0px 15px 15px;"|'''9. Now, we will show you how to configure a new product.''' <br />
Go to '' 'Setup' '' → '' 'Products/Services' '' → '' 'Servers' '' and press '' 'Add New Server' ''.
+
Go to '' 'Setup' '' → '' 'Products/Services' '' → '' 'Servers' '' and press '' 'Add New Server'. ''
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_7.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2__7.png]]
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|'''9. Next, enter your server name, IP address, username and password.<br />
+
|style="padding: 0px 0px 15px 15px;"|'''10. Next, enter your server name, IP address, username and password.<br />
Choose '' 'ProxmoxCloud' '' from a dropdown menu and press '' 'Save Changes' ''.'''<br />
+
Choose '' 'ProxmoxCloud' '' from a dropdown menu and press '' 'Save Changes'. '''''<br />
The last step is choosing authentication from the '' 'Authentication' '' dropdown menu.<br />
+
The last step is choosing authentication from the '' 'Authentication' '' dropdown menu.<br />
''Note: Authentication depends on the realm used by user on Proxmox server.''
+
''Note: Authentication depends on the realm used by the user on a Proxmox server.''
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_8.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2__8.png]]
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|'''10. After you configure your server correctly, you will see a following screen.'''<br />
+
|style="padding: 0px 0px 15px 15px;"|'''11. After you have configured your server correctly, you will see the following screen.'''<br />
You can check connection with Proxmox server. To do so, simply press '' 'Test Connection' '' as shown on the screen below.  
+
You can check connection with the Proxmox server. To do so, simply press '' 'Test Connection' '' as shown on the screen below.  
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_9.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2__9.png]]
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 15px;"|'''11. It is time to create a server group. To do so, click on '' 'Create New Group' ''.
+
|style="padding: 0px 0px 20px 15px;"|'''12. It is time to create a server group. To do so, click on '' 'Create New Group'. ''
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_10.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2__10.png]]
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 15px;"|'''12. Enter name, click on your previously created server, press '' 'Add' '' and afterwards '' 'Save Changes' ''.'''
+
|style="padding: 0px 0px 20px 15px;"|'''13. Enter name, click on your previously created server, press '' 'Add' '' and afterwards '' 'Save Changes'. '''''
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 30px 25px;"|[[File:PXC_11.png]]
+
|style="padding: 0px 0px 30px 25px;"|[[File:PXC2__11.png]]
 
|}
 
|}
  
 
==Configuration of Product==
 
==Configuration of Product==
 
{|
 
{|
|style="padding: 10px 0px 15px 15px;"|'''13. In order to create and configure a product go to '' 'Setup' → 'Products/Services' → 'Products/Services' ''.'''<br />
+
|style="padding: 10px 0px 15px 15px;"|'''14. In order to create and configure a product, go to '' 'Setup' → 'Products/Services' → 'Products/Services'. '''''<br />
Click on '' 'Create a New Group' ''.  
+
Click on '' 'Create a New Group'. ''   
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_12.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2__12.png]]
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 15px;"|'''14. Enter product group name and press '' 'Save Changes' ''.'''
+
|style="padding: 0px 0px 20px 15px;"|'''15. Enter the product group name and press '' 'Save Changes'. '''''
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_13.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PX2_13.png]]
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|'''15. When you have a product group, you are able to create your product. '''<br />
+
|style="padding: 0px 0px 15px 15px;"|'''16. When you have a product group, you are able to create your product.'''<br />
To create a product click on '' 'Create a New Product' ''.
+
To create a product, click on '' 'Create a New Product'. ''
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_14.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PX2_14.png]]
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|'''16. Afterwards, choose your product group and type from dropdown menus, enter your product name and press '' 'Continue' ''.'''<br />
+
|style="padding: 0px 0px 15px 15px;"|'''17. Afterward, choose your product group from dropdown menus and poinmt its type, enter your product name and choiose Proxmoix VPS as a module name. <br/> Press '' 'Continue'. '''''<br />
'' 'Product Type' '' should be set to '' 'Dedicated/VPS Server' '' in order to add nameservers later.
+
'' 'Product Type' '' can be set to '' 'Server/VPS' '' but nameservers will need to be added later.<br/>
 +
If you do not want to fill out nameservers, please select '' 'Shared Account' ''.
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_15.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2__15.png]]
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|'''17. Now, go to '' 'Module Settings' '' section, choose both '' 'ProxmoxCloud' '' and your previously created server group from dropdown menus.<br />
+
|style="padding: 0px 0px 15px 15px;"|'''18. Now, go to the '' 'Module Settings' '' section and choose your previously created server group from the dropdown menu.<br />
Next, click on '' 'Save Changes' ''.'''
+
Next, click on '' 'Save Changes'. '''''
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_16.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2__16.png]]
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|'''18. From dropdown menus choose '' 'Virtualization Type' '', '' 'Default Node' '', '' 'Template & ISO Storage' '' and '' 'User Permission' ''.<br />
+
|style="padding: 0px 0px 15px 15px;"|'''19. Choose '' 'Virtualization Type', 'Default Node', 'Template & ISO Storage' '' and '' 'User Permission' from dropdown menus. ''<br />
You can also choose how often bandwidth usage should be counted.<br />
+
Available virtualization types:<br/>
Afterwards, press '' 'Save Changes' ''.<br />
+
*'''KVM'''<br/>
''Note: If you choose 'Auto-Node' as 'Default Note', new virtual servers will be created on the least used node.''
+
*'''LXC''' <br/>
 +
You can also choose how often the bandwidth usage should be calculated.<br />
 +
Afterwards, press '' 'Save Changes'. ''<br />
 +
'''''Note:''' If you choose 'Auto-Node' as '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 a node selection with the best count of resources. Read more about Load Balancer.''
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_17.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2__17.png]]
 
|}
 
|}
 +
===KVM Virtualization Type===
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|'''19. Setting of KVM virtualization type (skip, if you have chosen OpenVZ virtualization type).'''<br />
+
|style="padding: 0px 0px 15px 15px;"|'''20. Setting of the KVM virtualization type (skip this step if you have chosen the LXC virtualization type).'''<br/>
From dropdown menus choose '' 'KVM OS Type' '', '' 'Default Storage' '', '' 'Disk Type' '' and '' 'CD/DVD-ROM Type' ''.<br />
+
From dropdown menus, choose '' 'KVM OS Type', 'Default Storage', 'Disk Type' '' and '' 'CD/DVD-ROM Type'. ''<br />
Additionally, choose ISO images available for your clients by marking them in '' 'ISO Image' ''.<br />
+
Choose ISO images available for your clients by marking them in '' 'ISO Image'. ''<br/><br/>
Set network through selecting from '' 'Network Mode' '', '' 'Network Model' '' and '' 'Bridge' '' dropdown menus.<br />
+
Set the network through selecting from the '' 'Network Mode', 'Network Model', '' and '' 'Bridge' '' dropdown menus.<br />
Type your VM description in '' 'Container Description' '', set backup location in '' 'Storage' '' dropdown menu and click '' 'Save Changes' ''.
+
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/>
 +
Type in your VM description in '' 'Container Description', '' set the backup location in the '' 'Storage' '' dropdown menu and click '' 'Save Changes'. ''<br/>
 +
'''Important: Keep in mind that the root password is generated automatically for KVM virtualization upon its creation and reset.'''<br />
 +
'''If you want to set your own password on KVM virtualization, use the [[#Cloud-Init_.28KVM.29|Cloud-Init]] option.''
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_18.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2__18.png]]
 
|}
 
|}
 +
 +
===LXC Virtualization Type===
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|'''20. Setting of OpenVZ virtualization type (skip, if you have chosen KVM virtualization type).'''<br />
+
|style="padding: 0px 0px 15px 15px;"|'''21. Setting of the LXC virtualization type (skip this step if you have chosen the KVM virtualization type).'''<br/>
From dropdown menus choose '' 'OpenVZ OS Templates' '', '' 'Default Storage' '', '' 'Network Mode' '' and '' 'Bridge' ''.<br />
+
From dropdown menus, choose '' 'Default Storage', 'Template' '' and '' 'Bridge'. ''<br />
Type your virtual servers description in '' 'Container Description' '' and press '' 'Save Changes' ''.
+
Enter your virtual server description in '' 'Container Description' '' and press '' 'Save Changes'. ''<br/><br/>
 +
'''Remember! This virtualization type is supported only by Proxmox VE 4.0. and later.'''<br/>
 +
If you are using the previous version of a Proxmox server, you will not be able to start this virtualization.
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_19.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2__18_1.png]]
 
|}
 
|}
 +
 +
<!--
 +
===OpenVZ Virtualization Type===
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|'''21. The next step is setting up configuration of backups.'''<br />
+
|style="padding: 0px 0px 15px 15px;"|'''22. Setting of the OpenVZ virtualization type (skip this step if you have chosen the KVM virtualization type).'''<br />
Define backup settings in '' 'Backups' '' section through selecting values from '' 'Storage' '' and '' 'Backups Routing' '' dropdown menus.<br />
+
''Please note that only Proxmox versions prior to v.2.3.0 support OpenVZ virtualization.''<br/>
Backups routing automatically removes the oldest backup when a new backup is created and a backup limit is reached.<br />
+
 
Additionally, you can limit the time period for storing backups by providing the number of days into '' 'Store The Backup For N Days' '' field.<br />
+
From dropdown menus, choose '' 'OpenVZ OS Templates', 'Default Storage', 'Network Mode' '' and '' 'Bridge'. ''<br />
Furthermore, you can define firewall rules limit and interface to apply rules to.<br />
+
Type in your virtual server description in '' 'Container Description' '' and press '' 'Save Changes'. ''<br/><br/>
Finish configuration at '' 'Module Settings' '' tab through pressing '' 'Save Changes' ''.<br />
+
'''Remember! This virtualization type is supported only by Proxmox VE 3.4 and previous.'''<br/>
'''Important: Keep in mind that the root password is generated automatically for KVM virtualization upon its creation and reset.'''<br />
+
If you are using the latest version of a Proxmox server, you will not be able to start this virtualization.
'''There is no possibility to set your own password due to Proxmox API limitations to KVM virtualization. '''
+
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2__19.png]]
 +
|}
 +
-->
 +
 
 +
===Finalizing The Configuration===
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|'''23. Private Network Management - in order to allow clients to manage their private networks, set up the '' 'Network Device' '' section properly.<br/>
 +
*Select '' 'Private Bridge' ''
 +
*Select '' 'Private Network Model' ''
 +
*Enter ranges for VLAN TAG<br/>
 +
'''''Note:''' Configure these three options for the KVM and LXC virtualization.''<br/>
 +
If you skip this step, clients will not be allowed to add private networks.<br/>
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2_20_1.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|'''24. The next step is setting up the configuration of backups.'''<br />
 +
Define backup settings in the '' 'Backups' '' section through selecting values from the '' 'Storage' '' and '' 'Backups Routing' '' dropdown menus.<br />
 +
Backups routing automatically removes the oldest backup when a new backup is created and the established backup limit is reached.<br />
 +
Additionally, you can limit the time period for storing backups by providing the number of days into the '' 'Store The Backup For N Days' '' field.<br />
 +
Furthermore, you can define the limit of firewall rules and the interface to apply the rules to.<br />
 +
Finish the configuration in the '' 'Module Settings' '' tab through pressing '' 'Save Changes'. ''
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2__20.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|'''25. Set up server limits to control the size of created servers.'''<br />
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_20.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2_21_1.png]]
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|'''22. The final step is generating custom fields and deciding whether to set up product with static or configurable resources.<br />
+
|style="padding: 0px 0px 15px 15px;"|'''26. The final step is generating custom fields and deciding whether to set up the product with static or configurable resources.<br />
Press '' 'Generate default' '' next to '' 'Custom Fields' ''.<br />
+
Press '' 'Generate default' '' next to '' 'Custom Fields'. ''<br />
'''Static Resources:''' Fill in the fields in '' 'Default Configuration' '' section with desired values.<br />
+
'''Static Resources:''' Fill in the fields in located in the '' 'Default Configuration' '' section with desired values.<br />
'''Configurable Resources:''' Click on '' 'Generate Default' '' next to '' 'Configurable Options' ''.<br />
+
'''Configurable Resources:''' Click on '' 'Generate Default' '' next to '' 'Configurable Options'. ''<br />
Press '' 'Save Changes' '' in the bottom of the page.
+
Press '' 'Save Changes' '' at the bottom of the page.<br/>
 +
''''' Note:''' While generating 'Configurable Options', it is advisable to delete the ones you do not use, e.g. the swap option or IPv6 for the KVM virtualization.''
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_21.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2__21.png]]
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|'''23. In the end of product configuration you have to add cron job shown below (each 5 minutes suggested).<br />
+
|style="padding: 0px 0px 20px 15px;"|'''27. In the end of the product configuration, you have to add a cron job that is shown below (5 minutes interval suggested).
 
  php -q /your_whmcs/modules/servers/proxmoxCloud/cron/cron.php
 
  php -q /your_whmcs/modules/servers/proxmoxCloud/cron/cron.php
 
Do not forget to replace '' 'your_whmcs' '' with your WHMCS root location.
 
Do not forget to replace '' 'your_whmcs' '' with your WHMCS root location.
Line 416: Line 599:
 
==Configuration of Addon==
 
==Configuration of Addon==
 
{|
 
{|
|style="padding: 10px 0px 15px 15px;"|'''24. Adding a new IP address.'''<br />
+
|style="padding: 10px 0px 15px 15px;"|'''26. Proceed to '' 'Addons' '' '' 'Proxmox Addon' '' → '' 'Settings' '' → '' 'General Settings' '' and set up cron jobs listed under the '' 'Cron' '' section.<br/>
In order to create a new product you have to add dedicated IP pool to '' 'IP Addresses' '' list in '' 'Proxmox' '' addon module.<br />
+
Please note that there are separate cron jobs dedicated to Proxmox VPS and Proxmox Cloud modules - these jobs are the most important to assure fluent work of the modules, suggested frequency is 5 minutes.<br/> If you are using only Proxmox VPS, there is no need to set up the second one and the other way round.<br/>
To do so, go to '' 'Addons' '' → '' 'Proxmox Addon' '' → '' 'IP Management' '' and press '' 'New IP Addresses' ''.<br />
+
The other ones are responsible for:
''Note: You can add both IPv4 and IPv6 addresses.''
+
* Users synchronization - ''run only once''
 +
* VM recovery synchronization - ''optionally run every 24 hours''
 +
* VM migration synchronization - ''optionally run every 24 hours or just after the VM migration''
 +
* Tasks synchronization - ''optionally run every one hour''
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_22.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2_35.png]]
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|'''25. Type desired IP and mask in '' 'IP Pool' '' and choose server from a '' 'Server' '' dropdown menu.'''<br />
+
|style="padding: 0px 0px 15px 15px;"|'''27. Next, under the Cron settings, find the '' 'Minimum VMID' '' field.'''<br/> Fill it in with a number that will be used as an ID of the first VM, the second VM will be asigned the next ID number.
Afterwards, press '' 'Add Pool' ''.
+
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_23.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2__35_1.png]]
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|'''26. You are now able to create new virtual machines at product.'''<br />
+
|style="padding: 0px 0px 15px 15px;"|'''28. Adding a new IP address (if you are not using [https://www.modulesgarden.com/products/whmcs/ip-manager#features IP Manager For WHMCS]).'''<br />
If you used KVM virtualization type, the client area of successfully created product should look similar to the one on the screen below.
+
In order to create a new product, you have to add '' 'Dedicated IP'' ' to the '' 'IP Addresses' '' list in '' 'Proxmox' '' addon module.<br />
 +
To do so, go to '' 'IP Management' '' and press '' 'New IP Addresses'. ''<br />
 +
'''''Note:''' You can add both the IPv4 and IPv6 addresses.''
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_24.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2__30.png]]
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 15px;"|'''27. The client area of product using OpenVZ virtualization type looks quite similar.'''
+
|style="padding: 0px 0px 15px 15px;"|'''29. Start by typing a desired IP address and mask into '' 'IP Pool'. '''''<br />
 +
Next, 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.<br />
 +
Afterward, press '' 'Confirm'. ''
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 30px 25px;"|[[File:PXC_25.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PX2__23.png]]
 
|}
 
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|'''30. You are now able to create new virtual machines at the product.'''<br />
 +
If you used the KVM virtualization type, the client area of a successfully created product should look similar to the one presented on the screen below.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2__24_1.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 15px;"|'''31. The client area of a product using the LXC virtualization type looks quite similar.'''
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2__25.png]]
 +
|}
 +
<!--
 +
{|
 +
|style="padding: 0px 0px 20px 15px;"|'''32. This is how an exemplary product details look like in the admin area.'''<br/>
 +
Allowed actions:
 +
*Create
 +
*Suspend/Unsuspend
 +
*Terminate
 +
*Change Package
 +
*Change User Role
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:PXC2__25_1.png]]
 +
|}
 +
-->
 +
<!--
 +
==Configuration of SSH Keys (KVM)==
 +
{|
 +
|style="padding: 10px 0px 15px 15px;"|<span style="color:#ff0000"> '' '''Important!''' Since the 2.5.0 version of the module, if you are using Proxmox VE 5.2 or later, we highly recommended using the [[#Cloud-Init_.28KVM.29|Cloud-Init]] feature instead of following instructions described in this section.''</span>
 +
<br/>
 +
'''SSH keys are required to enable the automatic resizing of a partition upon the disk upgrade as well as the change of passwords for the KVM virtualization type.'''<br />
 +
'' '''Note''' - 'Resize Partition', and 'Change Root Password' will only work for '''newly created VMs with ISC DHCP and Internet access configuration'''.<br/>We recommend using this option only for new products.''
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2_65.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|'''33. First, create a new [https://pve.proxmox.com/wiki/VM_Templates_and_Clones VM Template] that you will use for the KVM image.'''<br />
 +
Then, generate SSH keys and add the ''' public key '''to the root account on the newly created VM image. Moreover, upload both (''' public ''' and ''' private ''') keys on your WHMCS server in a secure location.<br />
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2_66.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 15px;"|'''34. Next, while in your WHMCS, go to the '' 'Proxmox Addon' '' → '' 'Settings' '' → '' 'SSH Keys' '' and press '' 'Add' '' button.'''
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2_67.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 15px;"|'''35. Enter the name and location to the key pairs located on your WHMCS server.'''<br/>
 +
Optionally, you can add a passphrase to increase security.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PX2_64.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|'''36. Next, go back to the product configuration and, in ' ''KVM Configuration' '' → '' 'VM SSH Root Key' '', select the pair of keys you want to use. '''<br /> Enter the SSH communication port and select the preferred features.<br />Make sure '''they match''' the '' 'KVM OS Template' '' that will be used.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2_69.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|'''37. Now, the '' 'Resize Partition' '', '' 'Change Root Password' '' and '' 'Delete VM SSH Root Key' '' options should be available.'''
 +
* ''' Resize Partition ''' - if a customer upgrades a VM by changing the disk size to a larger one, the size of the last partition in that disk will be automatically increased by the newly added value. <br /> The feature deletes a current partition table, then creates a new one, according to a new disk size, and reboots the VM. <br/>These partition types have to be standard, e.g. '' 'Linux Extended' (Ext2/Ext3/Ext4...), 'Linux SWAP' '', '' 'Solaris' '' or '' 'LVM' ''.<br/>'''Important - in case of any failure, all data available on the resized partition might be lost!''' ''
 +
* ''' Change Root Password ''' - this option is responsible for the automatic reset of the password after the VM creation. It also allows users to generate a new root password while using the VM.
 +
* ''' Delete VM SSH Root Key ''' - it will automatically remove the default SSH key after the VM creation. Use this component to increase security or leave unchecked for resizing partition feature.<br/>'' '''Important''' - if a customer decides to remove the public key from the VM on their own or the 'Delete VM SSH Root Key' is enabled, it will make the 'Resize Partition' and 'Change Root Password' options no longer working!''
 +
<br />
 +
From now on, clients will be able to set their own password for newly created VMs.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2_70.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 15px;"|The partition will be also automatically resized during the VM upgrade if a disk size is different than the one set as default in the template.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:PXC2_71.png]]
 +
|}
 +
-->
  
=Management=
+
==Cloud-Init (KVM)==
 +
{|
 +
|style="padding: 10px 0px 30px 15px;"|Use Cloud-Init to configure the system during installation, first-boot and package change.<br/>Cloud-Init was initially developed to provide early initialization of cloud instances.<br/>Click [https://access.redhat.com/documentation/en-us/red_hat_enterprise_linux_atomic_host/7/html/installation_and_configuration_guide/setting_up_cloud_init here] to learn more about Cloud-Init configuration.<br/>
  
 +
|} <!-- Na razie bez tej notki and requires CloudInit version '''17.1 or later'''.'' -->
 +
<!--
 +
===Scripts Configurations===
 
{|
 
{|
|style="padding: 10px 0px 15px 15px;"|''' Proxmox Cloud For WHMCS allows your customers to manage their PVE accounts via client area in your WHMCS system.'''<br />
+
|style="padding: 10px 0px 15px 15px;"|In the '' 'Settings' '' -> '' 'Cloud Init' '' section you will find your scripts configurations which are built by default by accessing the addon configuration.<br/><br/>
You can monitor and manage each product from your WHMCS admin area.<br />
+
'' '''Important:''' These are only '''exemplary''' configuration scripts and may '''not''' work on your Proxmox server configuration!<br/>Before using, please first adjust them to your needs and make sure they are configured correctly.''
To view VM details(1), migrate VM(2) or update VMs node(3), press a specific button.<br />
+
To view details of virtual server created by your client simply press '' 'Load Status' '' button.
+
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_26.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PX2_49.png]]
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|On the following screen you can see loaded details of the VM as well as opened migration popup.<br />
+
|style="padding: 0px 0px 15px 15px;"|You can also add your own configuration or edit existing ones by pressing corresponding buttons.<br/>
Migration is useful when you want to request migration from the WHMCS admin area, while editing node is useful for updating details after migrating VM from Proxmox panel.
+
[http://cloudinit.readthedocs.io/en/latest/topics/examples.html Here] you can find some cloud config examples.
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 30px 25px;"|[[File:PXC_27.png]]
+
|style="padding: 0px 0px 30px 25px;"|[[File:PX2_50.png]]
 +
|}
 +
-->
 +
 
 +
===Configuration Of Product===
 +
{|
 +
|style="padding: 10px 0px 15px 15px;"|To to allow you clients to use cloud-init you need to enable it in the Proxmox product configuration.<br/>
 +
Before you start we recommend to learn the details about cloud-init configuration on your Proxmox server - click [https://pve.proxmox.com/wiki/Cloud-Init_Support here] for more details.<br/>
 +
Once you get familiar with Proxmox cloud-init proceed to Cloud-Init group of your KVM configuration where you can enable it and set the following:
 +
*'''Allow To Set Username''' - if enabled the client can set its own username during VM creation. Otherwise it will remain unchanged and be set by default as in the template or set from the '' 'Default User' '' field if provided.
 +
*'''Allow To Set Password''' - if enabled the client can set its own password during VM creation Otherwise it will remain unchanged and be set by default as in the template.
 +
*'''Allow To Set SSH Public Key''' - if enabled the client can upload its own public SSH key in OpenSSH format during VM creation. This will then allow client to log in to VM using their private key instead of password.
 +
*'''Default User''' - provide the username that will be used for VM instead of using the '' 'Service Username' '' field or image's configured default user. Otherwise leave empty.
 +
*'''Allow To Set DNS Domain''' - if enabled the client can provide its own DNS domain for a container. During VM creation, the provided setting will be automatically used if neither a search domain nor a nameserver is set.
 +
*'''Allow To Set Nameservers''' - if enabled the client can set its own nameservers for the VM. Otherwise they will remain unchanged and be set by default as in the template.
 +
<!--
 +
*'''Cloud Init'''  -  select what scripts will be executed on VM create or change package. If you are using the configurable options you can also define the '' 'cloudInit|Cloud Init' '' option (Proxmox VPS only).<br/>'' '''Important:''' If you use multiple scripts configuration of the same type (e.g. 'Network Config'), remember that they will be connected into '''one script''' before sent to the server.<br/>Therefore, make sure that these scrips can work properly with each other.''
 +
*'''CD/DVD-ROM Type''' - an additional CD-ROM in which the ISO image is mounted with a ready-to-use script for the VM
 +
*'''Storage''' - the directory on which the CD-ROM ISO image is stored
 +
-->
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2_51_new.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 15px;"|This is how the above settings will look like in the client area during VM creation.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:PXC2_55.png]]
 +
|}
 +
<!--
 +
{|
 +
|style="padding: 0px 0px 20px 15px;"|Please also note the server configuration for that product must use the '' 'root' '' account and '' 'Linux PAM standard authentication' ''.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:PX2_52.png]]
 +
|}
 +
-->
 +
 
 +
===Configuration Of Proxmox Server===
 +
<!--
 +
{|
 +
|style="padding: 10px 0px 15px 15px;"|1. 'genisoimage' is required for cloud-init to be installed on your '''Proxmox server'''. To install it execute the in terminal:
 +
apt-get update &&  apt-get install genisoimage
 +
Otherwise you will get '' 'genisoimage: command not found' '' error.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|2. To make KVM virtual machine ready for could-init on a Proxmox server do the following:
 +
*Download and install system ISO image, e.g. [https://www.ubuntu.com/download/alternative-downloads Ubuntu]
 +
*Install cloud-init by executing in the terminal: <pre>apt-get install cloud-init</pre>
 +
*Or module requires cloud-init version '' '''17.1 or higher''' ''. After installation you can validate it version using <pre>cloud-init -v</pre>
 +
*Shutdown the machine and [http://git.mglocal/whmcs-products/Proxmox/uploads/994fd04f9a2a5cf03533c24aacfef0fc/image.png convert it to template.]
 +
*Finally from the product configuration or configurable options chose the created '' 'VM Template' ''.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PX2_57.png]]
 +
|}
 +
-->
 +
{|
 +
|style="padding: 10px 0px 30px 15px;"|The process of setting up Cloud-Init on the Proxmox server is described [https://pve.proxmox.com/wiki/Cloud-Init_Support here].<br/>
 +
Additionally you can use the following commands that can be useful for debugging.
 +
*Re-run cloud init scripts
 +
<pre>rm -rf /var/lib/cloud/sem/* /var/lib/cloud/instance /var/lib/cloud/instances/* &&
 +
cloud-init init  &&
 +
cloud-init modules -m final</pre>
 +
*Logs
 +
<pre>cat /var/log/cloud-init.log
 +
cat /var/log/cloud-init-output.log</pre>
 +
<!--
 +
*If you need more information about cloud-init installation you can follow [https://support.telefonicaopencloud.com/en-us/usermanual/ims/en-us_topic_0030730603.html#EN-US_TOPIC_0030730603__li38478451154018 this guide.]
 +
-->
 +
|}
 +
 
 +
=Management=
 +
{|
 +
|style="padding: 10px 0px 15px 15px;"|''' Proxmox Cloud For WHMCS allows your customers to manage their PVE servers in the WHMCS client area.'''<br />
 +
At the same time, you can monitor and handle each product from your WHMCS admin area.<br />
 +
To view VM details(1), migrate VM(2), update VMs node(3) or delete VM(4), press a specific button.<br />
 +
To view details of a virtual server created by your client, simply press the '' 'Load Status' '' button.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2__26.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|On the following screen, you can see loaded details of the VM as well as opened migration popup.<br />
 +
Migration is useful when you want to request migration from the WHMCS admin area, while editing node is practical for updating details after migrating the virtual machine from the Proxmox panel.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:PXC2__27.png]]
 
|}
 
|}
 
==Management of Addon==
 
==Management of Addon==
 +
===Servers Management===
 +
====Servers List====
 
{|
 
{|
|style="padding: 10px 0px 15px 15px;"|In '' 'Addons' '' → '' 'Proxmox Addon' '' → '' 'Server List' '' you can find servers you have configured.<br />
+
|style="padding: 10px 0px 15px 15px;"|In '' 'Addons' '' → '' 'Proxmox Addon' '' → '' 'Servers' '' → '' 'Servers List' '' you can find the configured Proxmox servers.<br />
To see what product was created and assigned to your Proxmox server simply click on its '' 'Server Name' ''.
+
'''RAM''' details:
 +
:Assigned - RAM assigned to the server (hosting services only)
 +
:Total - full server RAM
 +
:Free - difference between Total Server RAM and Assigned RAM
 +
'''Suspended''' - number of suspended accounts per size in MB ''E.g.: (1/500 MB) when there is only one suspended account (occupying 500MB of that account) assigned to Proxmox VPS server.''
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_28.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PX2_28.png]]
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 15px;"|As you can see on the screen below, you can find a lot of useful information here like e.g. IP Address, VM ID or VM Type.
+
|style="padding: 0px 0px 30px 15px;"|Through pressing '' 'Edit' '' icon you will be moved to the server edit page - see point number 10 of [[#Configuration of Server|Server Configuration]].<br/>
 +
Press '' 'More Details' '' icon and you will get extended information on the selected server. See below for more details.
 
|}
 
|}
 +
=====VMs=====
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_29.png]]
+
|style="padding: 10px 0px 20px 15px;"| The '' 'VMs' '' tab includes a list of created virtual machines on this server. Take a quick look at information on domain, status, bandwidth and IP addresses.<br/>
 +
To view information about a VM, simply press the more info icon.
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 15px;"|At the '' 'IP Management' '' tab you can add, edit and remove IP addresses from Proxmox products.  
+
|style="padding: 0px 0px 20px 25px;"|[[File:PX2_29.png]]
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_30.png]]
+
|style="padding: 0px 0px 20px 15px;"|Check the node and VMID:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 15px;"|'' 'Clusters' '' tab contains clusters list. To view information about a cluster simply press its name.  
+
|style="padding: 0px 0px 30px 25px;"|[[File:PX2_29_1.png]]
 
|}
 
|}
 +
 +
=====Clusters=====
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_31.png]]
+
|style="padding: 10px 0px 20px 15px;"| The next tab contains the list of clusters with information on uptime, CPU as well as CPU, SWAP, memory and disk usage data.
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 15px;"|Here you can find various information about a cluster, from available resource to their usage graphs.
+
|style="padding: 0px 0px 20px 25px;"|[[File:PX2_29_2.png]]
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 30px 25px;"|[[File:PXC_32.png]]
+
|style="padding: 0px 0px 20px 15px;"|Press the Edit icon to manage the node:
 
|}
 
|}
===Templates Management===
 
 
{|
 
{|
|style="padding: 10px 0px 15px 15px;"|You can easily convert any VM on your server to a template.<br />
+
|style="padding: 0px 0px 20px 25px;"|[[File:PX2_29_3.png]]
In order to convert VM, go to '' 'Proxmox Addon' '' → '' 'Templates' '' → '' 'Create Template' ''.<br />
+
Choose server on which VM to convert exist and press '' 'Next Step' ''.<br />
+
'''Important: VM will be destroyed in the process.'''
+
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_33.png]]
+
|style="padding: 0px 0px 20px 15px;"|Press '' 'Node Details' '' and you will get all the summary and usage graphs:  
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|Next, choose node and VM to convert.<br />
+
|style="padding: 0px 0px 30px 25px;"|[[File:PX2_30_2.png]]
Fill '' 'Template Friendly Name' '' and press '' 'Save Changes' ''.
+
 
|}
 
|}
 +
 +
=====VM Cleaner=====
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_34.png]]
+
|style="padding: 10px 0px 20px 15px;"|VM Cleaner allows you to track VMs existing only on your Proxmox server and that are not visible in your WHMCS.<br/> Consequently, you are allowed to sort and delete only those VMs that cannot be managed from your WHMCS.
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 15px;"|To access the list of all available templates go to '' 'Proxmox Addon' '' → '' 'Templates' '' → '' 'Show Templates' ''.
+
|style="padding: 0px 0px 30px 25px;"|[[File:PX2_31_1.png]]
 
|}
 
|}
 +
 +
=====Templates=====
 
{|
 
{|
|style="padding: 0px 0px 30px 25px;"|[[File:PXC_35.png]]
+
|style="padding: 10px 0px 15px 15px;"|Under this page you can view the list of templates. You can easily convert any '''KVM''' VM on your server to a template.<br />
 +
In order to convert a VM, press '' 'Create Template' '' button.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PX2_31_3.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|Next, choose a VM to convert.<br />
 +
Fill out '' 'Description' '' field and press '' 'confirm'. ''<br/>
 +
'''Important: Selected VM will be destroyed in the process.'''
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PX2_31_4.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|You may also delete unused templates here. Delete single templates or use the mass action to delete templates in bulk.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:PX2_31_2.png]]
 +
|}
 +
 
 +
=====Settings=====
 +
{|
 +
|style="padding: 10px 0px 15px 15px;"|Here you can define the VM IDs range that will be used for newly created VMs on this server. Please note that to use this feature, you also need to enable the "Use VM Ranges" setting in the product configuration.<br />Define ID range and save changes. <br/>
 +
'''''Note:''' VM ID range allows you to sort created VMs depending on the server they were created on.''.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:PX2_34.png]]
 +
|}
 +
 
 +
====VMs List====
 +
{|
 +
|style="padding: 10px 0px 15px 15px;"|In '' 'Addons' '' → '' 'Proxmox Addon' '' → '' 'Servers' '' → '' 'VMs List' '' you can find details of any Proxmox product.<br />
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PX2_35.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 15px;"|Press '' 'More Details' '' button to get the node and VMID information.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:PX2_35_1.png]]
 +
|}
 +
 
 +
====Recovery VM Lists====
 +
{|
 +
|style="padding: 10px 0px 15px 15px;"|In '' 'Addons' '' → '' 'Proxmox Addon' '' → '' 'Servers' '' → '' 'Recovery VM List' '' you can details on the created VM. <br />
 +
Run the '' 'VM recovery synchronization' '' cron job to create and store full backups of VMs configuration, you can find it at point no 26 of the [[#Configuration of Addon|configuration]] instructions.<br/>
 +
Use the '' 'Export to File' '' button to save information in a TXT copy file.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PX2_36.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|On pressing the '' 'Details' '' icon, you will get any information on Configuration, Status and DNS:
 +
|}
 +
{|
 +
|style="padding: 0px 0px 10px 25px;"|[[File:PX2_36_1.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 10px 25px;"|[[File:PX2_36_2.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:PX2_36_3.png]]
 +
|}
 +
 
 +
====Tasks History====
 +
{|
 +
|style="padding: 10px 0px 15px 15px;"|Tasks History includes a list o all module tasks with the most crucial details on them.<br/> You may delete single tasks or use mass action button to remove them in bulk.<br/>
 +
 
 +
Run the '' 'Tasks synchronization' '' cron job to synchronize the tasks and view all tasks from the server, you can find it at point no 26 of the [[#Configuration of Addon|configuration]] instructions.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:PX2_37.png]]
 +
|}
 +
 
 +
===IP Management===
 +
{|
 +
|style="padding: 10px 0px 15px 15px;"|In the '' 'IP Management' '' tab you can manage the IP addresses of Proxmox products.<br/> You can create both single IP addresses and IP pools which then can be assigned to created VMs.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2_30.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|When you are creating 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)''
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:PX2_30_1.png]]
 +
|}
 +
 
 +
===IP Manager Integration===
 +
{|
 +
|style="padding: 10px 0px 15px 15px;"|Owing to the integration with [https://www.modulesgarden.com/products/whmcs/ip_manager/features IP Manager For WHMCS], you are able to easily create subnets with IP addresses and assign them to the desired products.<br/>
 +
By activating the IP Manager submodule, settings concerning IP addresses such as 'Configurable Options' and 'Default Options' will be ignored by Proxmox VPS.<br/>
 +
'' '''Note:''' This integration works for '''LXC''' and '''KVM''' virtualization types.''
 +
<br/><br/>
 +
1. Proceed to the IP Manager For WHMCS → [https://www.docs.modulesgarden.com/IP_Manager_For_WHMCS#Subnets Subnets] tab in order to prepare IP addresses subnet for Proxmox VPS For WHMCS.<br/>
 +
2. Edit the previously created IP addresses subnet and create a custom field '' 'MAC Address' '' with a desired MAC address at each IP address in the subnet.<br/>
 +
''' ''Note:'' Setting up MAC address is optional and can be skipped.'''<br/>
 +
More details about creating custom fields can be found [https://www.docs.modulesgarden.com/IP_Manager_For_WHMCS#Default_Custom_Fields here].
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PX_49.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|3. Afterward, create a [https://www.docs.modulesgarden.com/IP_Manager_For_WHMCS#Automatic_IP_Assignment new configuration] and assign the previously created subnet to it.<br />
 +
''Note: Multiple IP addresses subnets can be assigned to a single configuration.''<br />
 +
4. Now, link the configuration with Proxmox VPS product via a product, a server or a configurable option.<br />
 +
On the following screen we have linked them via the configurable option assigned to the Proxmox VPS product.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PX_50.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|5. Now, enable the integration by proceeding to the '' '3rd Party Integration' '' tab.<br />
 +
Press '' 'Activate' '' next to the '' 'proxmoxVPS' '' module type as shown on the following screen.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PX_51.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|6. Next, assign the previously created configuration to the submodule.<br />
 +
Press '' 'Configure' '', choose a configuration and press '' 'Save Changes'. ''
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PX_52.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|If you encounter an error like the one on the below screen while integrating the two products, probably the function '' 'mb_strlen' '' is not enabled by default.<br/> Please read the  manual [http://www.php.net/manual/en/mbstring.installation.php here] for installation instructions.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PX_52_1.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|It is possible to add a '''VLAN Tag Custom Filed''' in the very same way as the MAC Address field.<br/>
 +
Look above for the detailed instruction on how to proceed, follow steps 1-6 to create the new custom field.<br/>
 +
The only thing you need to change is the custom field name, which should be ''' 'Tag' ''' in this case.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:PX_49_1.png]]
 +
|}
 +
 
 +
===Settings===
 +
====Load Balancer====
 +
{|
 +
|style="padding: 10px 0px 15px 15px;"|Load Balancer is an advanced tool that allows smooth rotation between nodes to find the most preferable one and create 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/>
 +
'''''Note:''' The lowest possible weight is 1. You cannot set for example 0,5.''
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PX2_30_4.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|In order to use Load Balancer you must previously enable it in the product's configuration: <br/>
 +
Define the behavior of the tool:
 +
*On Upgrade - select action to perform:
 +
** None - if selected, no action will be triggered
 +
** Block - the upgrade process will blocked as there are insufficient resources on the node
 +
** Migrate - the upgrade process will be performed after previous migration of the VM to a server with sufficient free space
 +
*Shutdown VM on Upgrade
 +
*Stop VM If Shutdown Fails
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:PX2_30_5.png]]
 +
|}
 +
=====Node Prioritization Method=====
 +
{|
 +
|style="padding: 10px 0px 0px 15px;"|Let us take a look at how the sorting process works and the rules that it obeys. <br/>
 +
Let's take exemplary weights for each resource just like presented on the screen above.<br/>
 +
 
 +
VMs Number Weight: 1,5<br/>
 +
CPU Weight: 2 <br/>
 +
Disk Weight: 4<br/>
 +
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/>
 +
 
 +
 
 +
In our situation, there are four nodes created, named A, B, C, D with current resources as shown below: <br/>
 +
 
 +
Node A (Free Ram: 60%, Free CPU: 20%, Free Disk Space: 50%, Number of VMs: 5) <br/>
 +
Node B (Free Ram: 30%, Free CPU: 70%, Free Disk Space: 40%, Number of VMs: 10) <br/>
 +
Node C (Free Ram: 90%, Free CPU: 50%, Free Disk Space: 20%, Number of VMs: 20) <br/>
 +
Node D (Free Ram: 80%, Free CPU: 60%, Free Disk Space: 70%, Number of VMs: 15)
 +
 
 +
The next step is sorting the nodes according to each resource, by assigning them corresponding priorities from 1 to 4. <br/>The higher the priority, the more free resources available.<br/>
 +
|}
 +
{| class="wikitable" style="margin-left: 20px; margin-right: auto;"
 +
! Priority
 +
! Free Ram
 +
! Free CPU
 +
! Free Disk Space
 +
! Number of VMs
 +
|-
 +
| 4
 +
| Node C
 +
| Node B
 +
| Node D
 +
| Node A
 +
|-
 +
| 3
 +
| Node D
 +
| Node D
 +
| Node A
 +
| Node B
 +
|-
 +
| 2
 +
| Node A
 +
| Node C
 +
| Node B
 +
| Node D
 +
|-
 +
| 1
 +
| Node B
 +
| Node A
 +
| Node C
 +
| Node C
 +
|}
 +
{|
 +
|style="padding: 10px 0px 15px 15px;"|Now, the final calculation to sort nodes according to free resources, taking into account previously defined weights, is performed<br/>
 +
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)
 +
 
 +
The results for nodes A, B, C and D (with weights and sorting priority) are following:
 +
 
 +
Node A: (2 x 2,5) + ( 1 x 2 ) + ( 3 x 4 ) + ( 4 x 1,5 ) = 25
 +
Node B: (1 x 2,5) + ( 4 x 2 ) + ( 2 x 4 ) + ( 3 x 1,5 ) = 23
 +
Node C: (4 x 2,5) + ( 2 x 2 ) + ( 1 x 4 ) + ( 1 x 1,5 ) = 19,5
 +
Node D: (3 x 2,5) + ( 3 x 2 ) + ( 4 x 4 ) + ( 2 x 1,5 ) = 32,5
 +
 
 +
As you can see, Node D has got the highest priority value with a result: 32,5.<br/> It will be selected by Load Balancer to create a new VM there, 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, a '' 'Create' '' or '' 'Upgrade' '' actions are executed based on the current usage of resources on available nodes.<br/>
 +
 
 +
'''''Important:''' In case a given client already has an existing VM on a node, this very node will NOT be taken into account during the prioritization of resources process.<br/>
 +
This is due to security measures to make sure, that in case of failure of this node, the client will still have access to the other VM server, created on another, working node.<br/> However, if this client has VMs on every node already, all of them will be taken into account during the selection prioritization process again.''<br/>
 +
 
 +
If you decide to use Load Balancer tool, define the resources weights to adjust their prioritization of nodes according to your needs.
 
|}
 
|}
  
Line 525: Line 1,138:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_36.png]]
+
|style="padding: 0px 0px 30px 25px;"|[[File:PXC2__36.png]]
 
|}
 
|}
 +
===New Server===
 
{|
 
{|
|style="padding: 0px 0px 20px 15px;"|In order to add a new server, press '' 'Add New Server' '' button.
+
|style="padding: 10px 0px 20px 15px;"|In order to add a new server, press '' 'Add New Server' '' button.
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_37.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2__37.png]]
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|Afterwards, enter '' 'Hostname' '', '' 'Nameserver 1' '', '' 'Nameserver 2' '' and '' 'Root Password' ''.<br />
+
|style="padding: 0px 0px 15px 15px;"|Afterwards, enter '' 'Hostname', '' choose '' 'OS Type' '' and select resources for your server by using sliders.<br />
Choose '' 'Template' '' from a dropdown menu and select resources for your server by using sliders.<br />
+
 
Instead of using the sliders you can also enter resources values into textboxes.<br />
 
Instead of using the sliders you can also enter resources values into textboxes.<br />
Confirm creation through pressing '' 'Add New Virtual Server' ''.
+
Confirm creation through pressing '' 'Add New Virtual Server'. ''<br />
 +
''Note! Data to be filled in may differ according to which type LXC or KVM you have chosen.''
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_38.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2__38.png]]
 
|}
 
|}
 
{|
 
{|
 
|style="padding: 0px 0px 15px 15px;"|To manage your virtual server simply press '' 'Manage' '' button next to it.<br />
 
|style="padding: 0px 0px 15px 15px;"|To manage your virtual server simply press '' 'Manage' '' button next to it.<br />
You can find information about managing your virtual servers in [http://www.docs.modulesgarden.com/Proxmox_Cloud_For_WHMCS#Client_Area-VM_Management next section].
+
You can find information about managing your virtual servers in [https://www.docs.modulesgarden.com/Proxmox_Cloud_For_WHMCS#Client_Area-VM_Management next section].
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_39.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2__39.png]]
 
|}
 
|}
 
{|
 
{|
Line 553: Line 1,167:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 30px 25px;"|[[File:PXC_40.png]]
+
|style="padding: 0px 0px 30px 25px;"|[[File:PXC2__40.png]]
 +
|}
 +
===Private Network Management===
 +
{|
 +
|style="padding: 10px 0px 20px 15px;"|Move to '' 'Private Network Management' '' to add, delete and edit your private 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 private network successfully.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2_60.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|In that section you will find all existing private networks with any details such as assigned virtual machines.<br/> To create a new network press '' 'Add Private Network'. ''
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2_61.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|Type in the name and select virtual machines from available that will have the private IP Addresses assigned.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2_61_1.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|New private network automatically appears on the list. You may edit (1) it or delete (2) whenever needed.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:PXC2_61_2.png]]
 +
|}
 +
 
 +
===Templates Management (KVM Only)===
 +
{|
 +
|style="padding: 10px 0px 20px 15px;"|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.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2_62.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|You may edit or delete existing templates. To add a new one, simply press '' 'Add Template' '' button.<br/>
 +
OS templates do not consume any resources such as CPU sockets, memory etc. <br/>
 +
'''Important!''' When you convert server into a template, it is consumed in the process! There is no possibility to revert it back.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2_63.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 15px;"|Select server from dropdown menu and type in its short description. Save changes when ready.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:PXC2_64.png]]
 
|}
 
|}
  
 
==Client Area - VM Management==
 
==Client Area - VM Management==
 
{|
 
{|
|style="padding: 10px 0px 15px 15px;"|Client area interface of virtual server should look like the one on the screen below.<br />
+
|style="padding: 0px 0px 15px 15px;"|Client area interface of virtual server should look like the one on the screen below.<br />
 
As you can see, control panel contains useful options needed for managing VPS.<br />
 
As you can see, control panel contains useful options needed for managing VPS.<br />
The module allows your customers to easily boot(1), stop(2), reboot(3) and shutdown(4) their servers through pressing a specific button.<br />
+
The module allows your customers to easily boot, stop, reboot and shutdown their VM through pressing a specific button.<br />
Clients can also edit(5) server, access VNC(6) and SPICE(7) consoles and view the graphs of resource usage(8).<br />
+
Clients can also upgrade server and access VNC, SPICE and noVNC consoles.<br />
Additionally, they are able to create backup(9), set up backup jobs(10), access task history(11) and manage network devices(12).<br />
+
Any additional tools are described in details in below sections.
They can also find here server details(13) and IP addresses assigned to the server(14).
+
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 30px 25px;"|[[File:PXC_41.png]]
+
|style="padding: 0px 0px 30px 25px;"|[[File:PXC2__41.png]]
 
|}
 
|}
===Edit VM===
+
===noVNC Console===
 
{|
 
{|
|style="padding: 10px 0px 20px 15px;"|Edit feature allows you to change server details and resources except '' 'Template' '' and '' 'Password' ''. To edit your server, click on '' 'Edit VM' ''(5) button.
+
|style="padding: 10px 0px 20px 15px;"|noVNC console allows your clients to connect with their server in the easiest possible way.
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_42.png]]
+
|style="padding: 0px 0px 30px 25px;"|[[File:PX2_39_1.png]]
 
|}
 
|}
 +
===SPICE Console===
 
{|
 
{|
|style="padding: 0px 0px 20px 15px;"|Afterwards, alter options you desire and confirm through pressing '' 'Save Changes' '' button.
+
|style="padding: 10px 0px 15px 15px;"|Spice console enables you to connect with virtual machine using SPICE.<br />
 +
''Note: Your client needs to [https://www.spice-space.org/download.html download] and install client side SPICE application in order to connect with VM.''
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 30px 25px;"|[[File:PXC_43.png]]
+
|style="padding: 0px 0px 30px 25px;"|[[File:PX2_40.png]]
 +
|}
 +
===Xterm.js Console===
 +
{|
 +
|style="padding: 10px 0px 15px 15px;"|Xterm.js console enables you to connect to virtual machine using Xterm.js.<br />
 +
You must update the scripts on Proxmox v2.6.0. To do so open folder: ''UploadOnProxmoxServer/5.2-10'' and upload content on all your proxmox servers.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:PX2_40_1.png]]
 
|}
 
|}
  
===VNC Console===
+
===Upgrade===
 
{|
 
{|
|style="padding: 10px 0px 15px 15px;"|VNC console allows your clients to remotely manage the server. To access it, simply press the '' 'VNC Console' ''(6) button.<br />
+
|style="padding: 10px 0px 15px 15px;"|Upgrade feature allows you to change server details and resources except '' 'Template' '' and '' 'Password' ''. To edit your server, click '' 'Upgrade' '' button. <br />
Console requires Java software and you need to accept security risk to run it.
+
Afterwards, alter options you desire and confirm through pressing '' 'Save Changes' '' button.
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 30px 25px;"|[[File:PXC_44.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2__42.png]]
 
|}
 
|}
  
===SPICE Console===
+
==Client Area - Additional Tools==
 +
===Reinstall===
 
{|
 
{|
|style="padding: 10px 0px 15px 15px;"|Spice console(7) enables you to connect with virtual machine using SPICE.<br />
+
|style="padding: 10px 0px 15px 15px;"|Reinstall feature can be used to reinstall a new OS on the VM by the clients on their own. <br/>
''Note: Your client needs to [http://www.spice-space.org/download.html download] and install client side SPICE application in order to connect with VM.''
+
You can provide your clients to either select a new OS from a provided KVM templates to automatically system replacement, or let them choose the ISO image for manual system installation.
 +
<br/><br/>
 +
'' '''Note:''' The ISO images can only be used for the KVM virtualization type, while VM templates can be used either for KVM or LXC.<br/> Additionally the new OS password for the KVM OS reinstallation will be set based on the previous service password while for the LXC user can define it before the new installation.''
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 30px 25px;"|[[File:PXC_45.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2_38_1.png]]
 
|}
 
|}
===Usage Graphs===
 
 
{|
 
{|
|style="padding: 10px 0px 15px 15px;"|Under '' 'Usage Graphs' ''(8) page, a client can find graph with CPU usage, memory usage, network traffic and disc I/O.<br />
+
|style="padding: 0px 0px 20px 15px;"|You can configure the available '' 'KVM OS Templates' '' for clients in the '' 'KVM Configuration' ''.
They can also switch the timeline of the graphs by choosing it from a dropdown menu pointed on the following screen.
+
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 30px 25px;"|[[File:PXC_46.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2_38_2.png]]
 
|}
 
|}
===Backup===
 
 
{|
 
{|
|style="padding: 10px 0px 20px 15px;"|To create a single backup, press '' 'Backup' ''(9) button and click on '' 'New Backup' '' as shown on the following screen.
+
|style="padding: 0px 0px 20px 15px;"|In the same way choose available '' 'ISO Images' '' from the can configure the '' 'CD/DVD-ROM Drive' ''.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2_38_3.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 15px;"|Remember to also gain your clients access to selected reinstallation types in the  '' 'User's Options' ''.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:PXC2_38_4.png]]
 +
|}
 +
 
 +
===Backups===
 +
{|
 +
|style="padding: 10px 0px 20px 15px;"|To create a single backup, proceed to'' 'Backups' '' section and click '' 'New Backup' '' as shown on the following screen.
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_47.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2__47.png]]
 
|}
 
|}
 
{|
 
{|
 
|style="padding: 0px 0px 15px 15px;"|Now choose '' 'Compress Dump File' '' and '' 'Backup Mode' '' from dropdown menus.<br />
 
|style="padding: 0px 0px 15px 15px;"|Now choose '' 'Compress Dump File' '' and '' 'Backup Mode' '' from dropdown menus.<br />
Afterwards, press '' 'Add Backup' ''.
+
Afterwards, press '' 'Add' '' button.
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_48.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2__48.png]]
 
|}
 
|}
 
{|
 
{|
Line 625: Line 1,310:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 30px 25px;"|[[File:PXC_49.png]]
+
|style="padding: 0px 0px 30px 25px;"|[[File:PXC2__49.png]]
 
|}
 
|}
  
 
===Backup Jobs===
 
===Backup Jobs===
 
{|
 
{|
|style="padding: 10px 0px 15px 15px;"|By pressing '' 'Backup Jobs' ''(10) in the client area, you will be carried to a backup jobs management page.<br />
+
|style="padding: 10px 0px 15px 15px;"|By pressing '' 'Backup Jobs' '' in the client area, you will be carried to a backup jobs management page.<br />
 
To add a new backup job press '' 'New Job' '' as shown on the following screen.
 
To add a new backup job press '' 'New Job' '' as shown on the following screen.
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_50.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2__50.png]]
 
|}
 
|}
 
{|
 
{|
 
|style="padding: 0px 0px 15px 15px;"|Now, define backup time, mark days to run it and choose '' 'Compression Dump File' '' and '' 'Backup Mode' '' from dropdown menus.<br />
 
|style="padding: 0px 0px 15px 15px;"|Now, define backup time, mark days to run it and choose '' 'Compression Dump File' '' and '' 'Backup Mode' '' from dropdown menus.<br />
Next, press '' 'Add' '' button.
+
Next, press '' 'Add' '' button. You may also enable email notifications here.
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 30px 25px;"|[[File:PXC_51.png]]
+
|style="padding: 0px 0px 30px 25px;"|[[File:PXC2__51.png]]
 
|}
 
|}
 +
 +
===Usage Graphs===
 +
{|
 +
|style="padding: 10px 0px 15px 15px;"|Under '' 'Usage Graphs' '' page, a client can find graph with CPU usage, memory usage, network traffic and disc I/O.<br />
 +
They can also switch the timeline of the graphs by choosing it from a dropdown menu pointed on the following screen.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:PXC2__46.png]]
 +
|}
 +
 
===Task History===
 
===Task History===
 
{|
 
{|
|style="padding: 10px 0px 15px 15px;"|All changes of VM status are listed in '' 'Task History' ''(11).<br />
+
|style="padding: 10px 0px 15px 15px;"|All changes of VM status are listed in '' 'Task History'. ''<br />
 
Additionally, each access to the VM through SPICE console is shown here.
 
Additionally, each access to the VM through SPICE console is shown here.
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 30px 25px;"|[[File:PXC_52.png]]
+
|style="padding: 0px 0px 30px 25px;"|[[File:PXC2__52.png]]
 
|}
 
|}
 +
 
===Network===
 
===Network===
 
{|
 
{|
|style="padding: 10px 0px 15px 15px;"|'' 'Network' ''(12) tab allows your clients to view their VM's network interface.<br />
+
|style="padding: 10px 0px 15px 15px;"|'' 'Network' '' section allows your clients to view their VM's network interface.<br />
Depending on the settings of the product, they can also create/remove them.  
+
Depending on the settings of the product (private network is used), they can also create/remove them. This feature is optional.
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 30px 25px;"|[[File:PXC_53.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2__53.png]]
 
|}
 
|}
 +
===Snapshots===
 +
{|
 +
|style="padding: 0px 0px 20px 15px;"|Use snapshot to remember the contents of virtual machine memory current state. You may use them later to restore the VM settings.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2__52_1.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 15px;"|Press '' 'Take Snapshot' '' button and fill out the form to take a snapshot.<br/> Name it (use alphabetical characters only), choose whether to include RAM and add some description.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:PXC2_48_11.png]]
 +
|}
 +
 
===Firewall===
 
===Firewall===
 
{|
 
{|
 
|style="padding: 10px 0px 15px 15px;"|Owing to '' 'Firewall' '' page, your clients can set up firewall rules and enable security group for theirs servers from your WHMCS client area.<br />
 
|style="padding: 10px 0px 15px 15px;"|Owing to '' 'Firewall' '' page, your clients can set up firewall rules and enable security group for theirs servers from your WHMCS client area.<br />
As you can see, you can easily modify and remove a previously added rules and security groups.<br />
+
As you can see, you can easily modify and remove previously added rules and security groups.<br />
To add a new firewall rule (1) or predefined security group(2) use the buttons marked on the following screen.  
+
To add a new firewall rule (1) or predefined security group (2) use the buttons marked on the following screen.  
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_53_1.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2__53_1.png]]
 
|}
 
|}
 
{|
 
{|
Line 676: Line 1,386:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_53_2.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2__53_2.png]]
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|Inserting a security group consists of choosing security group and interface on which group has to be used.
+
|style="padding: 0px 0px 15px 15px;"|Inserting a security group consists of choosing security group and interface on which group has to be used.<br />
 
Additionally, you can enable security group and add a comment to it.<br />
 
Additionally, you can enable security group and add a comment to it.<br />
 
Click '' 'Add' '' to use the security group.
 
Click '' 'Add' '' to use the security group.
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 30px 25px;"|[[File:PXC_53_3.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2__53_3.png]]
 +
|}
 +
 
 +
===Firewall Options===
 +
{|
 +
|style="padding: 0px 0px 20px 15px;"|View and edit firewall options.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:PXC2_53_4.png]]
 +
|}
 +
 
 +
===Disks (KVM only)===
 +
{|
 +
|style="padding: 0px 0px 20px 15px;"|View and manage hard disk within defined limits, add new one or remove additional disks if you wish.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:PXC2__52_2.png]]
 +
|}
 +
 
 +
===Scheduled Task===
 +
{|
 +
|style="padding: 10px 0px 20px 15px;"|Proceed to '' 'Scheduled Tasks' '' section to view details on any current task.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:PXC2__52_3.png]]
 +
|}
 +
 
 +
<!--
 +
==Automatic IP Address Assignment==
 +
{|
 +
|style="padding: 10px 0px 5px 15px;"|Automatic IP address assignment can be applied to your Proxmox module, all you need to do is to install '' 'DHCP' (Dynamic Host Configuration Protocol).''<br/>IP addresses will be then automatically requested from a DHCP server. Consequently, the need to manually configure them will be reduced to a minimum.<br/>
 +
'''''Important! This option is available only for 'KVM' virtualization type.'''''<br/>Read the below section to learn how to properly install and configure DHCP.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 5px 15px;"|1. First of all, you need to install SSH2 package. You will find precise instructions on how to do that [http://php.net/manual/en/ssh2.installation.php here].
 +
|}
 +
{|
 +
|style="padding: 0px 0px 5px 15px;"|2. Now, you may move to ISC DHCP installation and configuration. Follow the steps below:
 +
*Install DHCP server package on your Proxmox Node, execute the below command to do so:
 +
sudo apt-get install isc-dhcp-server
 +
*When ready, configure DHCP server in ''/etc/dhcp/dhcpd.conf'' file, run below command to create the file:
 +
sudo nano  /etc/dhcp/dhcpd.conf
 +
Below there is an exemplary content of properly created file: ''/etc/dhcp/dhcpd.conf''.<br/> Take a look at it to see what data should be inside of it:
 +
 
 +
 
 +
# Sample /etc/dhcpd.conf
 +
# (add your comments here)
 +
default-lease-time 600;
 +
max-lease-time 7200;
 +
option subnet-mask 255.255.255.0;
 +
option broadcast-address 192.168.1.255;
 +
option routers 192.168.1.254;
 +
option domain-name-servers 192.168.1.1, 192.168.1.2;
 +
option domain-name "mydomain.example";
 +
subnet 192.168.1.0 netmask 255.255.255.0 {
 +
#ProxmoxIPv4
 +
host 1 {hardware ethernet 32:62:39:64:33:33;fixed-address 192.168.1.2;}
 +
host 2 {hardware ethernet 32:39:61:31:33:66;fixed-address 192.168.1.3;}
 +
}
 +
 
 +
 
 +
*Key words:  '''''#ProxmoxIPv6 #ProxmoxIPv4''''' suggesting the usage of a specific type of IP address, must be located in the above mentioned file.<br/>
 +
:''Note: Only key word corresponding to a used IP type is required. If you do not use IPv6 then #ProxmoxIPv6 key word is not obligatory.''
 +
*More info about configuring DHCP server can be found [http://askubuntu.com/questions/140126/how-do-i-configure-a-dhcp-server here].
 +
|}
 +
{|
 +
|style="padding: 0px 0px 5px 15px;"|3. Turn on ISC DHCP.
 +
To use automatic IP addresses assignment feature, select '' 'ISC DHCP Server' '' option in '' 'Module Settings' '' under '' 'KVM Configuration' '' section.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:PXC2_48_1.png]]
 
|}
 
|}
 +
-->
  
 
==IP Manager Integration==
 
==IP Manager Integration==
 
{|
 
{|
|style="padding: 10px 0px 15px 15px;"|Owing to integration with [http://www.modulesgarden.com/products/whmcs/ip_manager/features IP Manager For WHMCS] you are able to easily create pools of IP addresses and assign them to desired products.<br />
+
|style="padding: 10px 0px 15px 15px;"|Owing to integration with [https://www.modulesgarden.com/products/whmcs/ip-manager IP Manager For WHMCS] you are able to easily create IP addresses subnets and assign them to desired products.<br/>
1. Proceed to IP Manager For WHMCS → [http://www.docs.modulesgarden.com/IP_Manager_For_WHMCS#IP_Pools IP Pools] tab in order to prepare IP addresses pool for Proxmox Cloud For WHMCS.<br />
+
'' '''Note:''' This integration works for both '''LXC''' and '''KVM''' virtualization types.''
2. Edit a previously created IP addresses pool and create custom field '' 'MAC Address' '' with desired MAC address at each IP address in the pool.<br />
+
<br/><br/>
More about creating custom fields can be found [http://www.docs.modulesgarden.com/IP_Manager_For_WHMCS#Custom_Fields_For_IP_Addresses here].
+
1. Proceed to IP Manager For WHMCS → [https://www.docs.modulesgarden.com/IP_Manager_For_WHMCS#Subnets Subnets] tab in order to prepare IP addresses subnet for Proxmox Cloud For WHMCS.<br />
 +
2. Edit a previously created IP addresses subnet and create custom field '' 'MAC Address' '' with desired MAC address at each IP address in the subnet.<br />
 +
More about creating custom fields can be found [https://www.docs.modulesgarden.com/IP_Manager_For_WHMCS#Default_Custom_Fields here].
 
|}
 
|}
 
{|
 
{|
Line 698: Line 1,481:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|3. Afterwards, create a [http://www.docs.modulesgarden.com/IP_Manager_For_WHMCS#Automatic_IP_Assignment new configuration] and assign a previously created pool to it.<br />
+
|style="padding: 0px 0px 15px 15px;"|3. Afterwards, create a [https://www.docs.modulesgarden.com/IP_Manager_For_WHMCS#Automatic_IP_Assignment new configuration] and assign a previously created subnet to it.<br/>
''Note: Multiple IP addresses pools can be assigned to a single configuration.''<br />
+
''Note: Multiple IP addresses subnets can be assigned to a single configuration.''<br />
 
4. Now, link the configuration with Proxmox Cloud product via product, server or configurable option.<br />
 
4. Now, link the configuration with Proxmox Cloud product via product, server or configurable option.<br />
 
On the following screen we have linked them via a configurable option assigned to the Proxmox Cloud product.
 
On the following screen we have linked them via a configurable option assigned to the Proxmox Cloud product.
Line 708: Line 1,491:
 
{|
 
{|
 
|style="padding: 0px 0px 15px 15px;"|5. Now, enable integration by proceeding to '' '3rd Party Integration' '' tab.<br />
 
|style="padding: 0px 0px 15px 15px;"|5. Now, enable integration by proceeding to '' '3rd Party Integration' '' tab.<br />
Press '' 'Activate' '' next to '' 'proxmoxVPS' '' module type as shown on the following screen.
+
Press '' 'Activate' '' next to '' 'proxmoxCloud' '' module type as shown on the following screen.
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC_54.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PXC__54.png]]
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|5. Next, assign a previously created configuration to the submodule.<br />
+
|style="padding: 0px 0px 15px 15px;"|6. Next, assign a previously created configuration to the submodule.<br />
Press '' 'Configure' '', choose the configuration and press '' 'Save Changes' ''.
+
Press '' 'Configure', '' choose the configuration and press '' 'Save Changes'. ''
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 30px 25px;"|[[File:PXC_55.png]]
+
|style="padding: 0px 0px 30px 25px;"|[[File:PXC__55.png]]
 
|}
 
|}
 +
 
==Importing VM==
 
==Importing VM==
 
{|
 
{|
Line 726: Line 1,510:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PX45_3.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PXC2_45_3.png]]
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|Afterwards, select the node on which the server exists and fill in both '' 'VMID' '' and '' 'Password' '' fields.<br />
+
|style="padding: 0px 0px 15px 15px;"|Afterwards, select the node on which the server exists and fill in '' 'VMID' '' field.<br />
Confirm importing through pressing '' 'Save Changes' '' button.<br />
+
Confirm importing through pressing '' 'Save Changes' '' button.
''Note: If you fill in '' 'Password' '' field with an incorrect value, import will be completed successfully but some features may not work for that VM.''
+
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 30px 25px;"|[[File:PX45_4.png]]
+
|style="padding: 0px 0px 30px 25px;"|[[File:PXC2_45_4.png]]
 
|}
 
|}
 
 
==Custom Hooks==
 
==Custom Hooks==
 
{|
 
{|
 
|style="padding: 10px 0px 30px 15px;"|Our module allows you to use custom hooks, all you need is knowledge of PHP programming language.<br />
 
|style="padding: 10px 0px 30px 15px;"|Our module allows you to use custom hooks, all you need is knowledge of PHP programming language.<br />
 
Custom hooks are placed in '' 'your_whmcs/modules/servers/proxmoxCloud/customhooks.php' ''.<br />
 
Custom hooks are placed in '' 'your_whmcs/modules/servers/proxmoxCloud/customhooks.php' ''.<br />
You can find there all custom hook and basic information about them.<br />
+
You can find there all custom hooks and basic information about them.<br />
Full list of available custom hooks:<br />
+
A full list of available custom hooks:
 
  proxmoxCloud_beforeCreateVM  
 
  proxmoxCloud_beforeCreateVM  
 
  proxmoxCloud_afterCreateVM
 
  proxmoxCloud_afterCreateVM
Line 760: Line 1,542:
 
==Configurable Options==
 
==Configurable Options==
 
{|
 
{|
|style="padding: 10px 0px 20px 15px;"|When you successfully set up a product, your clients can order it by choosing from the default configurable options.
+
|style="padding: 10px 0px 15px 15px;"|When you successfully set up a product, your clients can order it by choosing from the default configurable options.<br/>
 +
''Note! If automatically generated configurable options do not seem to fulfill your clients needs, you can edit them using [https://www.docs.modulesgarden.com/General#Editing_Configurable_Options this guide].''
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC46.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:PXC246.png]]
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 15px;"|If automatically generated configurable options do not seem to fulfill your clients needs, you can edit them using [http://www.docs.modulesgarden.com/General#Editing_Configurable_Options this guide].
+
|style="padding: 0px 0px 20px 15px;"|If you decide to set up pricing per server resource ordered, you can find instruction to proceed [https://www.docs.modulesgarden.com/General#Setting_Up_Pricing_For_Configurable_Options here].
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 25px;"|[[File:PXC47.png]]
+
|style="padding: 0px 0px 30px 25px;"|[[File:PXC248.png]]
|}
+
{|
+
|style="padding: 0px 0px 20px 15px;"|If you decide to set up pricing per server resource ordered, you can find instruction to proceed [http://www.docs.modulesgarden.com/General#Setting_Up_Pricing_For_Configurable_Options here].
+
|}
+
{|
+
|style="padding: 0px 0px 30px 25px;"|[[File:PXC48.png]]
+
 
|}
 
|}
  
 
==Management of Billing==
 
==Management of Billing==
 
{|
 
{|
|style="padding: 10px 0px 15px 15px;"|When you combine Proxmox Cloud For WHMCS with [http://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 Cloud 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 />
 
Module allows you to charge your customers basing on the server resources used by them.
 
Module allows you to charge your customers basing on the server resources used by them.
 
|}
 
|}
Line 791: Line 1,568:
 
{|
 
{|
 
|style="padding: 0px 0px 30px 25px;"|[[File:PXC50.png]]
 
|style="padding: 0px 0px 30px 25px;"|[[File:PXC50.png]]
 +
|}
 +
<!--
 +
==Servers Location Management==
 +
{|
 +
|style="padding: 10px 0px 5px 15px;"|'''In order to allow defining locations for Proxmox Cloud For WHMCS, follow the below steps:'''<br/>
 +
1. In your product's '' 'Module Settings' '' set up '' 'Default Node' '' to '' 'Server-Node'. ''<br/>
 +
2. Create a WHMCS server for each Proxmox node.<br/>
 +
3. Manually create configurable option, name it for example: '' 'Location'. '' Add options for each server within that config option.<br/>
 +
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' '' config option.<br/>
 +
'''Keep in mind that all locations must have exactly the same configuration!'''
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 15px;"|Now, a client may order a server and select '' 'Location'.'' Server Allocator For WHMCS will change the server assigned to the product. <br/>
 +
Create action is triggered on the assigned server due to '' 'Server-Node' '' option enabled.<br/>
 +
''Note: All virtual machines are created on the same Proxmox node.''<br/><br/>
 +
''Important! '''Server Allocator For WHMCS''' is required to allow locations management!''
 +
|}
 +
-->
 +
 +
==Products Autoscaling==
 +
{|
 +
|style="padding: 10px 0px 15px 15px;"|If you want to meet the needs of your clients then give them  the possibility to scale provisioned servers according to their current load automatically.<br/>
 +
To achieve that you need our Proxmox Cloud Autoscaling extension with Advanced Billing For WHMCS product.<br/>Only then, when you have such a combination of products your offer will be full.<br/>
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:PXC52.png]]
 +
|}
 +
{|
 +
 +
|style="padding: 0px 0px 15px 15px;"|With the combination of these three items, you will be able to formulate a set of rules basing on which specified servers will be modified at the right time.<br/>
 +
Advanced Billing For WHMCS will bill your clients for the currently used servers and its extension, Proxmox Cloud Autoscaling, will adjust the size of Cloud product to the current needs.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:PXC51.png]]
 
|}
 
|}
  
 
=Tips=
 
=Tips=
 
{|
 
{|
|style="padding: 10px 0px 30px 15px;"|1. Operations performed on the virtual servers are not executed immediately. Give your Proxmox Virtual Environment some time for processing the request and execution of operation.  
+
|style="padding: 10px 0px 10px 15px;"|1. Operations performed on the virtual servers are not executed immediately. Give your Proxmox Virtual Environment some time for processing the request and execution of operation.  
 
|}
 
|}
 +
{|
 +
|style="padding: 0px 0px 5px 15px;"|2. Multiple '''physical Proxmox servers''' can be joined into one cluster.<br />
 +
When they are joined into one '''cluster''', you can access all of them by connecting to any of them.<br />
 +
While '''auto-node''' creates new VM on the server(node) with the most free resources, '''server-node''' creates VM on the server(node) which IP address it has (WHMCS's server configuration).
 +
|}
 +
{|
 +
|style="padding: 0px 0px 5px 15px;"|3. OS Templates are not automatically downloaded while configuring a product.<br/> For each virtualization type, templates are downloaded from the Proxmox server depending on which one of them they are generated for.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 5px 15px;"|4. To name the location accordingly to your needs, within the module change the lang into:
 +
$_LANG['node_X']='Your friendly name for node_X';
 +
|}
 +
{|
 +
|style="padding: 0px 0px 5px 15px;"|5. When PAM authentication is used it is necessary to create a client first in order to change the password correctly. Read more about it [https://pve.proxmox.com/wiki/User_Management#pveum_authentication_realms here].
 +
|}
 +
{|
 +
|style="padding: 0px 0px 5px 15px;"|6. As this module supports templates system, any changes made in the module's templates files will be saved after the upgrade process.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 5px 15px;"|7. If you currently use the module in the 2.3.2 version or previous, 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.
 +
|}
 +
 +
{|
 +
|style="padding: 0px 0px 5px 15px;"|8. 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.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 5px 15px;"|9. '' 'Minimum Network Rate Limit' '' option allows you to change the previously entered '' 'Default Network Rate Limit' '' value to a new one if the current '' 'Bandwidth Limit' '' is already exhausted.<br/>Note that the '' 'Bandwidth Limit' ''  can also be used for WHMCS overage billing calculation as described [https://docs.whmcs.com/Disk_Space_and_Bandwidth_Overage_Billing here].
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:PXC2_70_1.png]]
 +
|}
 +
 +
=Update Instructions=
 +
{|
 +
|style="padding: 10px 0px 30px 15px;"|Essential guidance through the process of updating the module is offered '''[https://www.docs.modulesgarden.com/How_To_Update_WHMCS_Module here]'''.<br/><br/>
 +
Keep in mind there is a quick and easy option in our client area that will let you upgrade the license of your module to an open source version at any time - and at a lower price!<br/>
 +
To take advantage of it, simply use the '''License Upgrade''' button located on the product's page and a discounted invoice will be generated automatically.<br/>
 +
|}
 +
 
=Common Problems=
 
=Common Problems=
 
{|
 
{|
|style="padding: 10px 0px 30px 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.'''
 +
|}
 +
{|
 +
|style="padding: 0px 0px 5px 15px;"|2. Error 'Could not create PVE2_API object' during connecting via noVNC console.<br />
 +
'''Reason:''' User account does not have permission to access noVNC console.<br />
 +
'''Solution:''' Proceed to product's 'Module Settings' tab and check whether selected user permission grant right for noVNC console.<br />
 +
Afterwards, proceed to client's hosting and run '' 'Change User Role' '' on it.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 5px 15px;"|3. Error 'This connection is untrusted' during connecting via noVNC console.<br />
 +
'''Reason:''' Your certificate is not valid.<br />
 +
'''Quick Solution:''' Your client needs to add Proxmox address to certificate exception list.<br />
 +
'''Best Solution:''' Configure valid certificate.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 5px 15px;"|4. Blank page during connecting via noVNC console.<br />
 +
'''Reason:''' You have not uploaded the additional files on the Proxmox server.<br />
 +
'''Solution:'''  Open 'UploadOnProxmoxServer' and upload content of proper version on all Proxmox servers into the '/' path.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 5px 15px;"|5. Error 'Function "ssh2_connect" does  not exist. Please Install SSH2 PECL before you start using the script.'<br/>
 +
'''Reason:''' You have not updated php.ini file<br />
 +
'''Solution:''' After SSH2 PECL installation be sure that you have updated php.ini files for CLI and webserver.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 5px 15px;"|6. After you have updated your Proxmox Cloud For WHMCS to Proxmox Cloud For WHMCS V2.0.0, it is always required to save your product configuration in module settings again.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 5px 15px;"|7. If you see an error: '' 'Invalid VLAN TAG Range' configuration'' or other when trying to add a new private network, please make sure you have completed all required options in Module Settings.<br/> These are: '' 'Network Device' →  'Private Bridge', 'VLAN TAG Range From' and 'VLAN TAG Range To'.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 5px 15px;"|8. '' 'OS Architecture Type'' ' option for LXC virtualization type is currently not supported as it not implemented in Proxmox itself.<br/>We are sorry for inconvenience.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 5px 15px;"|9. Error: "Only root can set 'serial0' config".<br />
 +
'''Solution:''' Turn off the Xterms.js console in the product configuration.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 15px;"|10. Error "Parameter verification failed. ([maxfiles] - Only root may set this option.)"<br/>
 +
'''Reason:''' User is other than "root" or server authentication is set to Proxmox VE<br />
 +
'''Solution:''' In server configuration, set the root details and select PAM as the authentication type.
 
|}
 
|}

Latest revision as of 15:10, 16 November 2020

Contents

[edit] About Proxmox Cloud For WHMCS

Proxmox Cloud For WHMCS offers your clients the flexibility to create, remove and freely resize their own virtual servers within resource limits defined by you.

Your customers will be able to create as many servers as they need, manage such essential aspects like backups or firewall, and access noVNC, SPICE, or Xterm.js console.
The module supports Cloud-Init for the KVM virtualization type, and features Proxmox Addon allowing you to easily manage servers, IP addresses and clusters.

  • Admin Area Features:
✔ Create/Suspend/Unsuspend/Terminate User Account
✔ Change Package
✔ Change User Role
✔ Reset Bandwidth
✔ Migrate/Import/Delete Server
✔ Edit Server Node
✔ View Server Status, Details And Statistics
✔ View Graphs - With Ability To Change Time Scale of MRTG Graphs
✔ Display Disk And Bandwidth Usage Of Each Product
✔ Display CPU, SWAP and Memory Usage Of Each Product
✔ Select Server Locations Available For Clients
✔ Configure Client Area Features Per Product
✔ Define Static Or Dynamic Resource Limits
✔ Define Server Minimum And Maximum Resource Values
✔ Import IP Address To Hosting IP Addresses Table
✔ Return IP Address To IP Addresses Subnet
✔ Add Additional IP Address To VM
✔ Enable Qemu Guest Agent (KVM)
✔ Enable Backups Routing
✔ Enable Auto VM Backups Before Reinstallation
✔ Enable Load Balancer
  • Proxmox Addon Features:
✔ Display Servers: List Per VPS And Cloud
✔ List Per VPS And Cloud
✔ Clusters List
✔ VMs List
✔ KVM Templates
✔ Recovery VM Configurations List With Export To Backup File
✔ Tasks History
✔ Statuses, Resources Usage, IP Assignments And Details
✔ Manage Public & Private IP Addresses Per Server, VLAN, Tag And Node
✔ VM Cleaner - Manage VM Not Existing In Your WHMCS
✔ Convert KVM VPS To KVM Template
✔ Define VM IDs Ranges Per Server
✔ Set Minimum VM ID For Product Without ID Ranges Defined
✔ Configure Resources Weights For Load Balancer Prioritization
✔ Synchronize Users Permissions
  • Client Area Features:
✔ Create/Edit/Delete Servers
✔ Boot/Reboot/Stop/Shutdown Server
✔ Reinstall Server Using Templates (KVM) And ISO Images
✔ Choose Location For New Servers
✔ View Available Resources
✔ Access noVNC, SPICE And Xterm.js Console
✔ Create/Restore/Delete Backups
✔ Manage Backups Within Defined Limits (Max Number Of Files & Max Size Of Files)
✔ Manage Backup Jobs Within Defined Limits (Max Number Of Files & Max Size Of Files)
✔ View And Edit Public SSH Keys (KVM)
✔ Create/Upload/Download Public And Private SSH Keys (LXC)
✔ View Graphs - With Ability To Change Time Scale of MRTG Graphs
✔ View Task History
✔ View Network Devices and Manage Private Interface
✔ Manage Private Networks And Assign Them To Multiple Servers
✔ Create Server Snapshots
✔ Create VM Template From Server - KVM Virtualization Only
✔ Manage Firewall
✔ View Server Status, Details And Statistics
✔ Display Disk And Bandwidth Usage
✔ Display CPU, SWAP and Memory Usage
✔ Change Boot Order (KVM)
✔ Change ISO Image (KVM)
✔ Choose Server Resources While Ordering And Upgrade/Downgrade Them Freely
  • Configurable Options:
KVM:
✔ CPU Sockets Limit
✔ CPU Cores Limit
✔ CPU Limit
✔ CPU Units Limit
✔ Memory Limit
✔ SWAP Limit
✔ Storage Limit
✔ IPv4 Addresses Limit
✔ IPv6 Addresses Limit
✔ Bandwidth Limit
✔ Backups Size Limit
✔ Backups Files Limit
✔ Private Networks Limit
✔ VCPUs Limit
✔ Network Rate Limit
LXC:
✔ CPU Sockets Limit
✔ CPU Cores Limit
✔ CPU Limit
✔ CPU Units Limit
✔ Memory Limit
✔ SWAP Limit
✔ Storage Limit
✔ IPv4 Addresses Limit
✔ IPv6 Addresses Limit
✔ Bandwidth Limit
✔ Backups Size Limit
✔ Backups Files Limit
✔ Private Networks Limit
✔ VCPUs Limit
✔ Network Rate Limit
  • General Info:
✔ Supports Cloud-Init (KVM)
✔ Supports PVE And PAM Authentication
✔ Supports KVM and LXC Virtualization
✔ Integrated With Advanced Billing For WHMCS - Actual Server Resource Usage Billing (read more)
✔ Integrated With Proxmox Cloud Autoscaling For WHMCS - Automated Servers Resizing (read more)
✔ Integrated With IP Manager For WHMCS - Complete Control And Easy Assignment Of IP Subnets (read more)
✔ Multi-Language Support
✔ Supports Proxmox VE 6.X And Later
✔ Supports IPv4 and IPv6
✔ Supports Custom Hooks
✔ Supports PHP 7.1 Up To PHP 7.4
✔ Supports WHMCS Template Six
✔ Supports WHMCS 7.9 And Later
✔ Easy Module Upgrade To Open Source Version

[edit] Installation and Configuration

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

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

[edit] Installation

1. Log in to our client area and download the module.
PXC2 1.png
2. In the downloaded file you might find one or two packages that support different PHP versions.

In the most recent versions of the module, you will find only one package that supports PHP 7.1 and later.

PHP71 74.png
Previous updates of the module may contain two packages dedicated to various PHP versions.

The first one that supports PHP 5.6 up to PHP 7.0, and the second one addressed to PHP 7.1 up to PHP 7.3.
Note: Keep in mind that PHP versions 5.6 up to 7.0 are no longer officially supported and their security issues are not fixed or released any more. Find more info here.

PHP56 73.png
Note: You can check the current PHP version in your WHMCS. To do so, proceed to 'Utilities' → 'System' → 'PHP Info'.
3. Extract the package and upload its content into the main WHMCS directory.

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

PX2 2 1.png
4. Open 'UploadOnProxmoxServer' and upload content of the proper version on all Proxmox 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: 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.

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

This file is located in 'modules/servers/proxmoxCloud/license_RENAME.php'. Rename it from 'license_RENAME.php' to 'license.php'.

PXC2 3.png
6. In order to configure your license key, you have to edit a previously renamed 'license.php' file.

Enter your license key between quotation marks as presented on the following screen.
You can find your license key in our client area → 'My Products'.

PXC2 4.png
7. In the next step, set up the 'storage' folder as recursively writable.

This folder is available at: your_whmcs/modules/addons/proxmoxAddon/

PX2 4 1.png

[edit] Activation of Proxmox Addon

7. Firstly, you should activate Proxmox Addon.

To do so, log in into your WHMCS and press 'Setup' → 'Addon Modules'. Find 'Proxmox Addon' and press 'Activate'.

Note: The Proxmox addon version might not match the current version of the provisioning module itself. This is completely normal due to the specific structure of the product.

PXC2 5.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'.

PXC2 6.png

[edit] Configuration of Server

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

Go to 'Setup' 'Products/Services' 'Servers' and press 'Add New Server'.

PXC2 7.png
10. Next, enter your server name, IP address, username and password.

Choose 'ProxmoxCloud' from a dropdown menu and press 'Save Changes'.
The last step is choosing authentication from the 'Authentication' dropdown menu.
Note: Authentication depends on the realm used by the user on a Proxmox server.

PXC2 8.png
11. After you have configured your server correctly, you will see the following screen.

You can check connection with the Proxmox server. To do so, simply press 'Test Connection' as shown on the screen below.

PXC2 9.png
12. It is time to create a server group. To do so, click on 'Create New Group'.
PXC2 10.png
13. Enter name, click on your previously created server, press 'Add' and afterwards 'Save Changes'.
PXC2 11.png

[edit] Configuration of Product

14. In order to create and configure a product, go to 'Setup' → 'Products/Services' → 'Products/Services'.

Click on 'Create a New Group'.

PXC2 12.png
15. Enter the product group name and press 'Save Changes'.
PX2 13.png
16. When you have a product group, you are able to create your product.

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

PX2 14.png
17. Afterward, choose your product group from dropdown menus and poinmt its type, enter your product name and choiose Proxmoix VPS as a module name.
Press 'Continue'.

'Product Type' can be set to 'Server/VPS' but nameservers will need to be added later.
If you do not want to fill out nameservers, please select 'Shared Account' .

PXC2 15.png
18. Now, go to the 'Module Settings' section and choose your previously created server group from the dropdown menu.

Next, click on 'Save Changes'.

PXC2 16.png
19. Choose 'Virtualization Type', 'Default Node', 'Template & ISO Storage' and 'User Permission' from dropdown menus.

Available virtualization types:

  • KVM
  • LXC

You can also choose how often the bandwidth usage should be calculated.
Afterwards, press 'Save Changes'.
Note: If you choose 'Auto-Node' as 'Default Node', new virtual servers will be created on the least used node.
Note 2: An advanced tool is available for you to automatically manage a node selection with the best count of resources. Read more about Load Balancer.

PXC2 17.png

[edit] KVM Virtualization Type

20. Setting of the KVM virtualization type (skip this step if you have chosen the LXC virtualization type).

From dropdown menus, choose 'KVM OS Type', 'Default Storage', 'Disk Type' and 'CD/DVD-ROM Type'.
Choose ISO images available for your clients by marking them in 'ISO Image'.

Set the network through selecting from the 'Network Mode', 'Network Model', and 'Bridge' dropdown menus.
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.
Type in your VM description in 'Container Description', set the backup location in the 'Storage' dropdown menu and 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.

PXC2 18.png

[edit] LXC Virtualization Type

21. Setting of the LXC virtualization type (skip this step if you have chosen the KVM virtualization type).

From dropdown menus, choose 'Default Storage', 'Template' and 'Bridge'.
Enter your virtual server description in 'Container Description' and press 'Save Changes'.

Remember! This virtualization type is supported only by Proxmox VE 4.0. and later.
If you are using the previous version of a Proxmox server, you will not be able to start this virtualization.

PXC2 18 1.png


[edit] Finalizing The Configuration

23. Private Network Management - in order to allow clients to manage their private networks, set up the 'Network Device' section properly.
  • Select 'Private Bridge'
  • Select 'Private Network Model'
  • 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.

PXC2 20 1.png
24. The next step is setting up the configuration of backups.

Define backup settings in the 'Backups' section through selecting values from the 'Storage' and 'Backups Routing' dropdown menus.
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 'Store The Backup For N Days' 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'.

PXC2 20.png
25. Set up server limits to control the size of created servers.
PXC2 21 1.png
26. The final step is generating custom fields and deciding whether to set up the product with static or configurable resources.

Press 'Generate default' next to 'Custom Fields'.
Static Resources: Fill in the fields in located in the 'Default Configuration' section with desired values.
Configurable Resources: Click on 'Generate Default' next to 'Configurable Options'.
Press 'Save Changes' at the bottom of the page.
Note: While generating 'Configurable Options', it is advisable to delete the ones you do not use, e.g. the swap option or IPv6 for the KVM virtualization.

PXC2 21.png
27. In the end of the product configuration, you have to add a cron job that is shown below (5 minutes interval suggested).
php -q /your_whmcs/modules/servers/proxmoxCloud/cron/cron.php

Do not forget to replace 'your_whmcs' with your WHMCS root location.

Congratulations! You have just finished the installation and configuration of the module.

[edit] Configuration of Addon

26. Proceed to 'Addons' 'Proxmox Addon' 'Settings' 'General Settings' and set up cron jobs listed under the 'Cron' section.

Please note that there are separate cron jobs dedicated to Proxmox VPS and Proxmox Cloud modules - these jobs are the most important to assure fluent work of the modules, suggested frequency is 5 minutes.
If you are using only Proxmox VPS, there is no need to set up the second one and the other way round.
The other ones are responsible for:

  • Users synchronization - run only once
  • VM recovery synchronization - optionally run every 24 hours
  • VM migration synchronization - optionally run every 24 hours or just after the VM migration
  • Tasks synchronization - optionally run every one hour
PXC2 35.png
27. Next, under the Cron settings, find the 'Minimum VMID' field.
Fill it in with a number that will be used as an ID of the first VM, the second VM will be asigned the next ID number.
PXC2 35 1.png
28. Adding a new IP address (if you are not using IP Manager For WHMCS).

In order to create a new product, you have to add 'Dedicated IP ' to the 'IP Addresses' list in 'Proxmox' addon module.
To do so, go to 'IP Management' and press 'New IP Addresses'.
Note: You can add both the IPv4 and IPv6 addresses.

PXC2 30.png
29. Start by typing a desired IP address and mask into 'IP Pool'.

Next, 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.
Afterward, press 'Confirm'.

PX2 23.png
30. You are now able to create new virtual machines at the product.

If you used the KVM virtualization type, the client area of a successfully created product should look similar to the one presented on the screen below.

PXC2 24 1.png
31. The client area of a product using the LXC virtualization type looks quite similar.
PXC2 25.png

[edit] Cloud-Init (KVM)

Use Cloud-Init to configure the system during installation, first-boot and package change.
Cloud-Init was initially developed to provide early initialization of cloud instances.
Click here to learn more about Cloud-Init configuration.

[edit] Configuration Of Product

To to allow you clients to use cloud-init you need to enable it in the Proxmox product configuration.

Before you start we recommend to learn the details about cloud-init configuration on your Proxmox server - click here for more details.
Once you get familiar with Proxmox cloud-init proceed to Cloud-Init group of your KVM configuration where you can enable it and set the following:

  • Allow To Set Username - if enabled the client can set its own username during VM creation. Otherwise it will remain unchanged and be set by default as in the template or set from the 'Default User' field if provided.
  • Allow To Set Password - if enabled the client can set its own password during VM creation Otherwise it will remain unchanged and be set by default as in the template.
  • Allow To Set SSH Public Key - if enabled the client can upload its own public SSH key in OpenSSH format during VM creation. This will then allow client to log in to VM using their private key instead of password.
  • Default User - provide the username that will be used for VM instead of using the 'Service Username' field or image's configured default user. Otherwise leave empty.
  • Allow To Set DNS Domain - if enabled the client can provide its own DNS domain for a container. During VM creation, the provided setting will be automatically used if neither a search domain nor a nameserver is set.
  • Allow To Set Nameservers - if enabled the client can set its own nameservers for the VM. Otherwise they will remain unchanged and be set by default as in the template.
PXC2 51 new.png
This is how the above settings will look like in the client area during VM creation.
PXC2 55.png

[edit] Configuration Of Proxmox Server

The process of setting up Cloud-Init on the Proxmox server is described here.

Additionally you can use the following commands that can be useful for debugging.

  • Re-run cloud init scripts
rm -rf /var/lib/cloud/sem/* /var/lib/cloud/instance /var/lib/cloud/instances/* &&
cloud-init init  &&
cloud-init modules -m final
  • Logs
cat /var/log/cloud-init.log
cat /var/log/cloud-init-output.log

[edit] Management

Proxmox Cloud For WHMCS allows your customers to manage their PVE servers in the WHMCS client area.

At the same time, you can monitor and handle each product from your WHMCS admin area.
To view VM details(1), migrate VM(2), update VMs node(3) or delete VM(4), press a specific button.
To view details of a virtual server created by your client, simply press the 'Load Status' button.

PXC2 26.png
On the following screen, you can see loaded details of the VM as well as opened migration popup.

Migration is useful when you want to request migration from the WHMCS admin area, while editing node is practical for updating details after migrating the virtual machine from the Proxmox panel.

PXC2 27.png

[edit] Management of Addon

[edit] Servers Management

[edit] Servers List

In 'Addons' 'Proxmox Addon' 'Servers' 'Servers List' you can find the configured Proxmox servers.

RAM details:

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

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

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

Press 'More Details' icon and you will get extended information on the selected server. See below for more details.

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

To view information about a VM, simply press the more info icon.

PX2 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, CPU as well as CPU, SWAP, memory and disk usage data.
PX2 29 2.png
Press the Edit icon to manage the node:
PX2 29 3.png
Press 'Node Details' and you will get all the summary and usage graphs:
PX2 30 2.png
[edit] VM Cleaner
VM Cleaner allows you to track VMs existing only on your Proxmox server and that are not visible in your WHMCS.
Consequently, you are allowed to sort and delete only those VMs that cannot be managed from your WHMCS.
PX2 31 1.png
[edit] Templates
Under this page you can view the list of templates. You can easily convert any KVM VM on your server to a template.

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

PX2 31 3.png
Next, choose a VM to convert.

Fill out 'Description' field and press 'confirm'.
Important: 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 to delete templates in bulk.
PX2 31 2.png
[edit] Settings
Here you can define the VM IDs range that will be used for newly created VMs on this server. Please note that to use this feature, you also need to enable the "Use VM Ranges" setting in the product configuration.
Define ID range and save changes.

Note: VM ID range allows you to sort created VMs depending on the server they were created on..

PX2 34.png

[edit] VMs List

In 'Addons' 'Proxmox Addon' 'Servers' 'VMs List' you can find details of any Proxmox product.
PX2 35.png
Press 'More Details' button to get the node and VMID information.
PX2 35 1.png

[edit] Recovery VM Lists

In 'Addons' 'Proxmox Addon' 'Servers' 'Recovery VM List' you can details on the created VM.

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

PX2 36.png
On pressing the 'Details' icon, you will get any information on Configuration, Status and DNS:
PX2 36 1.png
PX2 36 2.png
PX2 36 3.png

[edit] Tasks History

Tasks History includes a list o all module tasks with the most crucial details on them.
You may delete single tasks or use 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 at point no 26 of the configuration instructions.

PX2 37.png

[edit] IP Management

In the 'IP Management' tab you can manage the IP addresses of Proxmox products.
You can create both single IP addresses and IP pools which then can be assigned to created VMs.
PXC2 30.png
When you are creating 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)
PX2 30 1.png

[edit] IP Manager Integration

Owing to the integration with IP Manager For WHMCS, you are able to easily create subnets with IP addresses and assign them to the desired products.

By activating the IP Manager submodule, settings concerning IP addresses such as 'Configurable Options' and 'Default Options' will be ignored by Proxmox VPS.
Note: This integration works for LXC and KVM virtualization types.

1. Proceed to the IP Manager For WHMCS → Subnets tab in order to prepare IP addresses subnet for Proxmox VPS For WHMCS.
2. Edit the previously created IP addresses subnet and create a custom field 'MAC Address' with a desired MAC address at each IP address in the subnet.
Note: Setting up MAC address is optional and can be skipped.
More details about creating custom fields can be found here.

PX 49.png
3. Afterward, create a new configuration and assign the previously created subnet to it.

Note: Multiple IP addresses subnets can be assigned to a single configuration.
4. Now, link the configuration with Proxmox VPS product via a product, a server or a configurable option.
On the following screen we have linked them via the configurable option assigned to the Proxmox VPS product.

PX 50.png
5. Now, enable the integration by proceeding to the '3rd Party Integration' tab.

Press 'Activate' next to the 'proxmoxVPS' module type as shown on the following screen.

PX 51.png
6. Next, assign the previously created configuration to the submodule.

Press 'Configure' , choose a configuration and press 'Save Changes'.

PX 52.png
If you encounter an error like the one on the below screen while integrating the two products, probably the function 'mb_strlen' is not enabled by default.
Please read the manual here for installation instructions.
PX 52 1.png
It is possible to add a VLAN Tag Custom Filed in the very same way as the MAC Address field.

Look above for the detailed instruction on how to proceed, follow steps 1-6 to create the new custom field.
The only thing you need to change is the custom field name, which should be 'Tag' in this case.

PX 49 1.png

[edit] Settings

[edit] Load Balancer

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

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 for example 0,5.

PX2 30 4.png
In order to use Load Balancer you must previously enable it in the product's configuration:

Define the behavior of the tool:

  • On Upgrade - select action to perform:
    • None - if selected, no action will be triggered
    • Block - the upgrade process will blocked as there are insufficient resources on the node
    • Migrate - the upgrade process will be performed after previous migration of the VM to a server with sufficient free space
  • Shutdown VM on Upgrade
  • Stop VM If Shutdown Fails
PX2 30 5.png
[edit] Node Prioritization Method
Let us take a look at how the sorting process works and the rules that it obeys.

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

VMs Number Weight: 1,5
CPU Weight: 2
Disk Weight: 4
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.


In our situation, there are four nodes created, named A, B, C, D with current resources as shown below:

Node A (Free Ram: 60%, Free CPU: 20%, Free Disk Space: 50%, Number of VMs: 5) 
Node B (Free Ram: 30%, Free CPU: 70%, Free Disk Space: 40%, Number of VMs: 10)
Node C (Free Ram: 90%, Free CPU: 50%, Free Disk Space: 20%, Number of VMs: 20)
Node D (Free Ram: 80%, Free CPU: 60%, Free Disk Space: 70%, Number of VMs: 15)

The next step is sorting the nodes according to each resource, by assigning them corresponding priorities from 1 to 4.
The higher the priority, the more free resources available.

Priority Free Ram Free CPU Free Disk Space Number of VMs
4 Node C Node B Node D Node A
3 Node D Node D Node A Node B
2 Node A Node C Node B Node D
1 Node B Node A Node C Node C
Now, the final calculation to sort nodes according to free resources, taking into account previously defined weights, is performed

Sorting nodes is based on the following calculation method:

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)

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

Node A: (2 x 2,5) + ( 1 x 2 ) + ( 3 x 4 ) + ( 4 x 1,5 ) = 25
Node B: (1 x 2,5) + ( 4 x 2 ) + ( 2 x 4 ) + ( 3 x 1,5 ) = 23
Node C: (4 x 2,5) + ( 2 x 2 ) + ( 1 x 4 ) + ( 1 x 1,5 ) = 19,5
Node D: (3 x 2,5) + ( 3 x 2 ) + ( 4 x 4 ) + ( 2 x 1,5 ) = 32,5

As you can see, Node D has got the highest priority value with a result: 32,5.
It will be selected by Load Balancer to create a new VM there, to migrate or upgrade an existing VM if its current node does not have sufficient resources.

The above described calculations are performed every time, a 'Create' or 'Upgrade' actions are executed based on the current usage of resources on available nodes.

Important: In case a given client already has an existing VM on a node, this very node will NOT be taken into account during the prioritization of resources process.
This is due to security measures to make sure, that in case of failure of this node, the client will still have access to the other VM server, created on another, working node.
However, if this client has VMs on every node already, all of them will be taken into account during the selection prioritization process again.

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

[edit] Client Area

Client area interface of Proxmox Cloud For WHMCS allows your clients to create their own virtual servers.

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

PXC2 36.png

[edit] New Server

In order to add a new server, press 'Add New Server' button.
PXC2 37.png
Afterwards, enter 'Hostname', choose 'OS Type' and select resources for your server by using sliders.

Instead of using the sliders you can also enter resources values into textboxes.
Confirm creation through pressing 'Add New Virtual Server'.
Note! Data to be filled in may differ according to which type LXC or KVM you have chosen.

PXC2 38.png
To manage your virtual server simply press 'Manage' button next to it.

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

PXC2 39.png
If you do not need a particular virtual server anymore, press 'Delete' button to remove it.
PXC2 40.png

[edit] Private Network Management

Move to 'Private Network Management' to add, delete and edit your private networks.

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.
Otherwise you will not be able to add any private network successfully.

PXC2 60.png
In that section you will find all existing private networks with any details such as assigned virtual machines.
To create a new network press 'Add Private Network'.
PXC2 61.png
Type in the name and select virtual machines from available that will have the private IP Addresses assigned.
PXC2 61 1.png
New private network automatically appears on the list. You may edit (1) it or delete (2) whenever needed.
PXC2 61 2.png

[edit] Templates Management (KVM Only)

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.
PXC2 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.

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

[edit] Client Area - VM Management

Client area interface of virtual server should look like the one on the screen below.

As you can see, control panel contains useful options needed for managing VPS.
The module allows your customers to easily boot, stop, reboot and shutdown their VM through pressing a specific button.
Clients can also upgrade server and access VNC, SPICE and noVNC consoles.
Any additional tools are described in details in below sections.

PXC2 41.png

[edit] noVNC Console

noVNC console allows your clients to connect with their server in the easiest possible way.
PX2 39 1.png

[edit] SPICE Console

Spice console enables you to connect with virtual machine using SPICE.

Note: Your client needs to download and install client side SPICE application in order to connect with VM.

PX2 40.png

[edit] Xterm.js Console

Xterm.js console enables you to connect to virtual machine using Xterm.js.

You must update the scripts on Proxmox v2.6.0. To do so open folder: UploadOnProxmoxServer/5.2-10 and upload content on all your proxmox servers.

PX2 40 1.png

[edit] Upgrade

Upgrade feature allows you to change server details and resources except 'Template' and 'Password' . To edit your server, click 'Upgrade' button.

Afterwards, alter options you desire and confirm through pressing 'Save Changes' button.

PXC2 42.png

[edit] Client Area - Additional Tools

[edit] Reinstall

Reinstall feature can be used to reinstall a new OS on the VM by the clients on their own.

You can provide your clients to either select a new OS from a provided KVM templates to automatically system replacement, or let them choose the ISO image for manual system installation.

Note: The ISO images can only be used for the KVM virtualization type, while VM templates can be used either for KVM or LXC.
Additionally the new OS password for the KVM OS reinstallation will be set based on the previous service password while for the LXC user can define it before the new installation.

PXC2 38 1.png
You can configure the available 'KVM OS Templates' for clients in the 'KVM Configuration' .
PXC2 38 2.png
In the same way choose available 'ISO Images' from the can configure the 'CD/DVD-ROM Drive' .
PXC2 38 3.png
Remember to also gain your clients access to selected reinstallation types in the 'User's Options' .
PXC2 38 4.png

[edit] Backups

To create a single backup, proceed to 'Backups' section and click 'New Backup' as shown on the following screen.
PXC2 47.png
Now choose 'Compress Dump File' and 'Backup Mode' from dropdown menus.

Afterwards, press 'Add' button.

PXC2 48.png
To restore VM from a backup simply press 'Restore' and then click 'OK' button in a popup window to confirm.
PXC2 49.png

[edit] Backup Jobs

By pressing 'Backup Jobs' in the client area, you will be carried to a backup jobs management page.

To add a new backup job press 'New Job' as shown on the following screen.

PXC2 50.png
Now, define backup time, mark days to run it and choose 'Compression Dump File' and 'Backup Mode' from dropdown menus.

Next, press 'Add' button. You may also enable email notifications here.

PXC2 51.png

[edit] Usage Graphs

Under 'Usage Graphs' page, a client can find graph with CPU usage, memory usage, network traffic and disc I/O.

They can also switch the timeline of the graphs by choosing it from a dropdown menu pointed on the following screen.

PXC2 46.png

[edit] Task History

All changes of VM status are listed in 'Task History'.

Additionally, each access to the VM through SPICE console is shown here.

PXC2 52.png

[edit] Network

'Network' section allows your clients to view their VM's network interface.

Depending on the settings of the product (private network is used), they can also create/remove them. This feature is optional.

PXC2 53.png

[edit] Snapshots

Use snapshot to remember the contents of virtual machine memory current state. You may use them later to restore the VM settings.
PXC2 52 1.png
Press 'Take Snapshot' button and fill out the form to take a snapshot.
Name it (use alphabetical characters only), choose whether to include RAM and add some description.
PXC2 48 11.png

[edit] Firewall

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

As you can see, you can easily modify and remove previously added rules and security groups.
To add a new firewall rule (1) or predefined security group (2) use the buttons marked on the following screen.

PXC2 53 1.png
You can add a firewall rule in two ways. Both of them require choosing direction, action, interface, source and destination.

The first way (red) is by choosing macro from a 'Macro' dropdown field.
The second way (blue) consist of choosing protocol and filling source and destination ports out.
Additionally, you can enable rule and add a comment to it.
Press 'Add' to create a rule.

PXC2 53 2.png
Inserting a security group consists of choosing security group and interface on which group has to be used.

Additionally, you can enable security group and add a comment to it.
Click 'Add' to use the security group.

PXC2 53 3.png

[edit] Firewall Options

View and edit firewall options.
PXC2 53 4.png

[edit] Disks (KVM only)

View and manage hard disk within defined limits, add new one or remove additional disks if you wish.
PXC2 52 2.png

[edit] Scheduled Task

Proceed to 'Scheduled Tasks' section to view details on any current task.
PXC2 52 3.png


[edit] IP Manager Integration

Owing to integration with IP Manager For WHMCS you are able to easily create IP addresses subnets and assign them to desired products.

Note: This integration works for both LXC and KVM virtualization types.

1. Proceed to IP Manager For WHMCS → Subnets tab in order to prepare IP addresses subnet for Proxmox Cloud For WHMCS.
2. Edit a previously created IP addresses subnet and create custom field 'MAC Address' with desired MAC address at each IP address in the subnet.
More about creating custom fields can be found here.

PX 49.png
3. Afterwards, create a new configuration and assign a previously created subnet to it.

Note: Multiple IP addresses subnets can be assigned to a single configuration.
4. Now, link the configuration with Proxmox Cloud product via product, server or configurable option.
On the following screen we have linked them via a configurable option assigned to the Proxmox Cloud product.

PX 50.png
5. Now, enable integration by proceeding to '3rd Party Integration' tab.

Press 'Activate' next to 'proxmoxCloud' module type as shown on the following screen.

PXC 54.png
6. Next, assign a previously created configuration to the submodule.

Press 'Configure', choose the configuration and press 'Save Changes'.

PXC 55.png

[edit] Importing VM

Our module allows you to easily import VM into your cloud product.

To do so, press 'Import VM' as shown on the following screen.

PXC2 45 3.png
Afterwards, select the node on which the server exists and fill in 'VMID' field.

Confirm importing through pressing 'Save Changes' button.

PXC2 45 4.png

[edit] Custom Hooks

Our module allows you to use custom hooks, all you need is knowledge of PHP programming language.

Custom hooks are placed in 'your_whmcs/modules/servers/proxmoxCloud/customhooks.php' .
You can find there all custom hooks and basic information about them.
A full list of available custom hooks:

proxmoxCloud_beforeCreateVM 
proxmoxCloud_afterCreateVM
proxmoxCloud_beforeTerminateVM
proxmoxCloud_afterTerminateVM
proxmoxCloud_beforeCreate
proxmoxCloud_afterCreate
proxmoxCloud_beforeTerminate
proxmoxCloud_afterTerminate
proxmoxCloud_afterSuspend
proxmoxCloud_afterUnsuspend
proxmoxCloud_afterIPAdditionByAdmin
proxmoxCloud_afterIPDeletionByAdmin
proxmoxCloud_afterIPAdditionByUpgrade

[edit] Configurable Options

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

Note! If automatically generated configurable options do not seem to fulfill your clients needs, you can edit them using this guide.

PXC246.png
If you decide to set up pricing per server resource ordered, you can find instruction to proceed here.
PXC248.png

[edit] Management of Billing

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

Module allows you to charge your customers basing on the server resources used by them.

PXC49.png
With Advanced Billing For WHMCS module, you can also display your customers current server resource usage and their cost.
PXC50.png

[edit] Products Autoscaling

If you want to meet the needs of your clients then give them the possibility to scale provisioned servers according to their current load automatically.

To achieve that you need our Proxmox Cloud Autoscaling extension with Advanced Billing For WHMCS product.
Only then, when you have such a combination of products your offer will be full.

PXC52.png
With the combination of these three items, you will be able to formulate a set of rules basing on which specified servers will be modified at the right time.

Advanced Billing For WHMCS will bill your clients for the currently used servers and its extension, Proxmox Cloud Autoscaling, will adjust the size of Cloud product to the current needs.

PXC51.png

[edit] Tips

1. Operations performed on the virtual servers are not executed immediately. Give your Proxmox Virtual Environment some time for processing the request and execution of 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 any of them.
While auto-node creates new VM on the server(node) with the most free resources, server-node creates VM on the server(node) which IP address it has (WHMCS's server configuration).

3. 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 of them they are generated for.
4. To name the location accordingly to your needs, within the module change the lang into:
$_LANG['node_X']='Your friendly name for node_X';
5. When 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. As this module supports templates system, any changes made in the module's templates files will be saved after the upgrade process.
7. If you currently use the module in the 2.3.2 version or previous, 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.
8. You can use the 'IPSet IP Filter' option for firewall to prevent IP spoofing. Click here to read more about IP Sets.
9. 'Minimum Network Rate Limit' option allows you to change the previously entered 'Default Network Rate Limit' value to a new one if the current 'Bandwidth Limit' is already exhausted.
Note that the 'Bandwidth Limit' can also be used for WHMCS overage billing calculation as described here.
PXC2 70 1.png

[edit] Update Instructions

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

Keep in mind there is a quick and easy option in our client area that will let you upgrade the license of your module to an open source version at any time - and at a lower price!
To take advantage of it, simply use the License Upgrade button located on the product's page and a discounted invoice will be generated automatically.

[edit] Common Problems

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 noVNC console.

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

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

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

4. Blank page during connecting via noVNC console.

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

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

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

6. After you have updated your Proxmox Cloud For WHMCS to Proxmox Cloud For WHMCS V2.0.0, it is always required to save your product configuration in module settings again.
7. If you see an error: 'Invalid VLAN TAG Range' configuration or other when trying to add a new private network, please make sure you have completed all required options in Module Settings.
These are: 'Network Device' → 'Private Bridge', 'VLAN TAG Range From' and 'VLAN TAG Range To'.
8. 'OS Architecture Type ' option for LXC virtualization type is currently not supported as it not implemented in Proxmox itself.
We are sorry for inconvenience.
9. Error: "Only root can set 'serial0' config".

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

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

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

Navigation
WHMCS Modules
WHMCS Module Bundles
WHMCS Widgets
Tools And Applications
Translations
General
FAQ
Community
Proxmox Cloud 2.X For WHMCS