Proxmox Cloud 2.X For WHMCS
| Contents
 | 
About Proxmox Cloud For WHMCS
| 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. 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. | 
- Admin Area Features:
| ✔ Create/Suspend/Unsuspend/Terminate User Account | 
| ✔ Change User Role | 
| ✔ Create/Suspend/Unsuspend/Terminate Server | 
| ✔ Migrate Server Between Nodes | 
| ✔ Import Server | 
| ✔ 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 | 
| ✔ Configure Client Area Features Per Product | 
| ✔ Import IP Address To Hosting IP Addresses Table | 
| ✔ Return IP Address To IP Addresses Pool | 
| ✔ Add Additional IP Address To VM | 
| ✔ Enable Backups Routing | 
- Proxmox Addon Features:
| ✔ Display Servers List Per VPS And Cloud | 
| ✔ Manage IP Addresses Per Server | 
| ✔ Display Servers Clusters | 
| ✔ Display KVM Templates | 
| ✔ Convert KVM VPS To KVM Template | 
| ✔ Set Minimum VM ID For Product Without ID Ranges Defined | 
| ✔ Synchronize Users Permissions | 
| ✔ VM Cleaner - Manage VM Not Existing In Your WHMCS | 
- Client Area Features:
| ✔ Add/Manage/Delete Servers | 
| ✔ View Available Resources | 
| ✔ Boot/Reboot/Stop/Shutdown Server | 
| ✔ Edit Server | 
| ✔ Access VNC/SPICE/noVNC Console | 
| ✔ Create/Restore Backups | 
| ✔ Manage Backup Jobs | 
| ✔ Manage Backups Within Defined Limits (Max Number Of Files & Max Size Of Files) | 
| ✔ Manage Scheduled Backups Within Defined Limits (Max Number Of Files & Max Size Of Files) | 
| ✔ View Graphs - With Ability To Change Time Scale of MRTG Graphs | 
| ✔ View Task History | 
| ✔ Manage Network Devices | 
| ✔ Create Snapshots | 
| ✔ 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) | 
| ✔ Easy VM Upgrade/Downgrade | 
- General Info:
| ✔ Supports PVE And PAM Authentication | 
| ✔ Server Resources Chosen During Order | 
| ✔ Ability To Upgrade Server Resources | 
| ✔ Integrated With Advanced Billing For WHMCS - Server Resource Usage Billing (read more) | 
| ✔ Integrated With IP Manager For WHMCS - Complete Management of IP Pools (read more) | 
| ✔ Multi-Language Support | 
| ✔ Supports Proxmox VE 3 and Later | 
| ✔ Supports IPv4 and IPv6 | 
| ✔ Supports Custom Hooks | 
| ✔ Supports WHMCS Templates Five and Six | 
| ✔ Supports WHMCS V5 and V6 | 
| ✔ Requires PHP 5.3 and Later | 
- Available Configurable Options:
| ✔ KVM: | 
| ✔ CPU Sockets Limit | 
| ✔ CPU Cores Limit | 
| ✔ CPU Weight Limit | 
| ✔ Memory Limit | 
| ✔ Storage Limit | 
| ✔ Bandwidth Limit | 
| ✔ IPv4 Addresses Limit | 
| ✔ IPv6 Addresses Limit | 
| ✔ Backups Size Limit | 
| ✔ Backups Files Limit | 
| ✔ OpenVZ: | 
| ✔ CPU Cores Limit | 
| ✔ CPU Weight Limit | 
| ✔ SWAP Limit | 
| ✔ Memory Limit | 
| ✔ Storage Limit | 
| ✔ Bandwidth Limit | 
| ✔ IPv4 Addresses Limit | 
| ✔ IPv6 Addresses Limit | 
| ✔ Backups Size Limit | 
| ✔ Backups Files Limit | 
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. | 
Installation
| 1. Log in to your client area and download Proxmox Cloud For WHMCS. | 
|   | 
| 2. Extract the module and upload content of 'UploadOnProxmoxServer' on all Proxmox servers into '/usr/share/novnc-pve/' folder. Note: If you wish to allow noVNC consoles, you need to configure product using PVE realm and user permissions set to 'PVEVMUser'. | 
| 3. Upload and extract the module into the main WHMCS directory. | 
|   | 
| 4. When you install Proxmox Cloud for the first time you have to rename  'license_RENAME.php'  file. File is located in 'modules/servers/proxmoxCloud/license_RENAME.php' . Rename it from 'license_RENAME.php' to 'license.php'. | 
|   | 
| 5. 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. | 
|   | 
Activation of Proxmox Addon
| 6. 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'. | 
|   | 
| 7. In the next step you need to permit access to this module. To do so, click on 'Configure' button. Tick 'Full Administrator' and press 'Save Changes'. | 
|   | 
Configuration of Server
| 8. Now, we will show you how to configure a new product. Go to 'Setup' → 'Products/Services' → 'Servers' and press 'Add New Server' . | 
|   | 
| 9. Next, enter your server name, IP address, username and password. Choose  'ProxmoxCloud'  from a dropdown menu and press  'Save Changes' . | 
|   | 
| 10. After you configure your server correctly, you will see a following screen. You can check connection with Proxmox server. To do so, simply press 'Test Connection' as shown on the screen below. | 
|   | 
| 11. It is time to create a server group. To do so, click on 'Create New Group' . | 
|   | 
| 12. Enter name, click on your previously created server, press 'Add' and afterwards 'Save Changes' . | 
|   | 
Configuration of Product
| 13. In order to create and configure a product go to  'Setup' → 'Products/Services' → 'Products/Services' . Click on 'Create a New Group' . | 
|   | 
| 14. Enter product group name and press 'Save Changes' . | 
|   | 
| 15. When you have a product group, you are able to create your product. To create a product click on 'Create a New Product'. | 
|   | 
| 16.  Afterwards, choose your product group and type from dropdown menus, enter your product name and press  'Continue' . 'Product Type' should be set to 'Dedicated/VPS Server' in order to add nameservers later. | 
|   | 
| 17. Now, go to  'Module Settings'  section, choose both  'ProxmoxCloud'  and your previously created server group from dropdown menus. Next, click on 'Save Changes' . | 
|   | 
| 18. From dropdown menus choose  'Virtualization Type' ,  'Default Node' ,  'Template & ISO Storage'  and  'User Permission' . You can also choose how often bandwidth usage should be counted. | 
|   | 
| 19. Setting of KVM virtualization type (skip, if you have chosen OpenVZ virtualization type). From dropdown menus choose  'KVM OS Type' ,  'Default Storage' ,  'Disk Type'  and  'CD/DVD-ROM Type' . | 
|   | 
| 20. Setting of OpenVZ virtualization type (skip, if you have chosen KVM virtualization type). From dropdown menus choose  'OpenVZ OS Templates' ,  'Default Storage' ,  'Network Mode'  and  'Bridge' . | 
|   | 
| 21. The next step is setting up configuration of backups. Define backup settings in  'Backups'  section through selecting values from  'Storage'  and  'Backups Routing'  dropdown menus. | 
|   | 
| 22. The final step is generating custom fields and deciding whether to set up product with static or configurable resources. Press  'Generate default'  next to  'Custom Fields' . | 
|   | 
| 23. In the end of the product configuration you have to add 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. | 
Configuration of Addon
| 24. Add a new IP address. In order to create a new product you have to add a dedicated IP pool to  'IP Addresses'  list in  'Proxmox'  addon module. | 
| File:PX2 22.png | 
| 25. Type in the desired IP and mask in  'IP Pool'  and choose server from  'Server'  dropdown menu. Afterwards, press  'Add Pool'.  | 
|   | 
| 26. You are now able to create new virtual machines at product. If you used KVM virtualization type, the client area of successfully created product should look similar to the one on the screen below. | 
|   | 
| 27. The client area of product using OpenVZ virtualization type looks quite similar. | 
|   | 
Management
| Proxmox Cloud For WHMCS allows your customers to manage their PVE accounts via client area in your WHMCS system. You can monitor and manage each product from your WHMCS admin area. | 
|   | 
| 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 useful for updating details after migrating VM from Proxmox panel. | 
|   | 
Management of Addon
Server List
| In  'Addons'  →  'Proxmox Addon'  →  'Servers'  →  'Servers List'  you can find configured Proxmox servers. You can quickly devine VM ID ranges for those servers, press  'Manage'  to do so. | 
|   | 
| Define ID range and save changes. | 
|   | 
| Through pressing 'Edit' you will be moved to server edit page. | 
IP Management
| At 'IP Management' tab you can add, edit and remove IP addresses of Proxmox products. | 
| File:PX2 30.png | 
Clusters
| 'Clusters' tab contains the list of clusters. To view information about a cluster simply press its name. | 
|   | 
| Here you can find various information about a cluster, from available resource to usage graphs. | 
|   | 
Templates List
| Under this page you can view the list of templates. You may also delete unused templates here. | 
|   | 
Create Templates
| You can easily convert any VM on your server to a template. In order to convert VM, go to  'Proxmox Addon'  →  'Templates'  →  'Create Template'.  | 
|   | 
| Next, choose node and VM to convert. Fill in 'Template Friendly Name' and press 'Save Changes'. | 
|   | 
General Settings
| 'Minimal VMID'  allows you to define minimal ID of VM created from server, which does not have VMID range defined. Cron job user synchronization - if you change user role in the product settings, this cron job changes role of existing users. | 
|   | 
VM Cleaner
| VM Cleaner allows you to track VM existing only on your Proxmox server and that are not visible in your WHMCS. Consequently, you are allowed here to sort and delete only those VM that are not managed from your WHMCS. | 
|   | 
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. | 
|   | 
| In order to add a new server, press 'Add New Server' button. | 
|   | 
| 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. | 
|   | 
| To manage your virtual server simply press  'Manage'  button next to it. You can find information about managing your virtual servers in next section. | 
|   | 
| If you do not need a particular virtual server anymore, press 'Delete' button to remove it. | 
|   | 
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. | 
|   | 
VNC Console
| VNC console allows your clients to remotely manage the server. To access it, simply press the  'VNC Console'  button. Console requires Java software and you need to accept security risk to run it. | 
|   | 
noVNC Console
| noVNC console allows your clients to connect with their server in the easiest possible way. | 
|   | 
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. | 
|   | 
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. | 
|   | 
Client Area - Additional Tools
Backups
| To create a single backup, proceed to 'Backups' section and click 'New Backup' as shown on the following screen. | 
|   | 
| Now choose  'Compress Dump File'  and  'Backup Mode'  from dropdown menus. Afterwards, press 'Add' button. | 
|   | 
| To restore VM from a backup simply press 'Restore' and then click 'OK' button in a popup window to confirm. | 
|   | 
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. | 
|   | 
| 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. | 
|   | 
Usage Graphs
| Under  'Usage Graphs' (9) 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. | 
|   | 
Task History
| All changes of VM status are listed in  'Task History' . Additionally, each access to the VM through SPICE console is shown here. | 
|   | 
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. | 
|   | 
Snapshots (KVM only)
| Use snapshot to remember the contents of virtual machine memory current state. You may use them later to restore the VM settings. | 
|   | 
| 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. | 
|   | 
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 a previously added rules and security groups. | 
|   | 
| 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. | 
|   | 
| 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. | 
|   | 
Disks (KVM only)
| View and manage hard disk within defined limits, add new one or remove additional disks if you wish. | 
|   | 
Scheduled Task
| Proceed to 'Scheduled Tasks' section to view details on any current task. | 
|   | 
IP Manager Integration
| Owing to integration with IP Manager For WHMCS you are able to easily create pools of IP addresses and assign them to desired products. 1. Proceed to IP Manager For WHMCS → IP Pools tab in order to prepare IP addresses pool for Proxmox Cloud For WHMCS. | 
|   | 
| 3. Afterwards, create a new configuration and assign a previously created pool to it. Note: Multiple IP addresses pools can be assigned to a single configuration. | 
|   | 
| 5. Now, enable integration by proceeding to  '3rd Party Integration'  tab. Press 'Activate' next to 'proxmoxVPS' module type as shown on the following screen. | 
|   | 
| 6. Next, assign a previously created configuration to the submodule. Press 'Configure' , choose the configuration and press 'Save Changes' . | 
|   | 
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. | 
|   | 
| Afterwards, select the node on which the server exists and fill in  'VMID'  field. Confirm importing through pressing 'Save Changes' button. | 
|   | 
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' . 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 | 
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. | 
|   | 
| If you decide to set up pricing per server resource ordered, you can find instruction to proceed here. | 
|   | 
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. | 
|   | 
| With Advanced Billing For WHMCS module, you can also display your customers current server resource usage and their cost. | 
|   | 
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. | 
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. | 
| 3. Error 'This connection is untrusted' during connecting via noVNC console. Reason: Your certificate is not valid. | 
| 4. Blank page during connecting via noVNC console. Reason: You have not uploaded 'mgnovnc.html' on to the Proxmox server. |