This guide will walk you through the process of installing and configuring the UpCloud VPS Module for WHMCS.
The UpCloud VPS Module for WHMCS is a versatile tool designed to assist businesses of all sizes in efficiently managing their Cloud Instances. It simplifies the process of configuring and overseeing VM instances, providing users with seamless control and automation capabilities.
-
Deployment: Administrators can manually deploy VMs by clicking 'Create' or set up automatic deployment during product setup, specifying location, region, OS, and custom fields like SSH keys or user data (cloud-init) initialization.
-
Termination: VM termination can be done manually or automated, with the option to set up automatic termination through WHMCS automation settings, which functions based on WHMCS cron jobs.
-
Upgrade/Downgrade: Administrators can manually adjust CPU/RAM/Storage configurations by clicking the 'Change Package' button, or configure automatic upgrades/downgrades.
-
VM Management: Administrators can start, stop, restart, suspend, unsuspend VMs, and view all basic VM information including VPS, VNC, IP addresses, etc.
-
Reverse PTR: Admins can set and view reverse PTR records.
-
Login Credentials: If configured, the system can even send login credentials automatically.
-
Custom Plans: Once set by admin during product setup, users can customize their plans and select them for deployment after making a payment.
-
Cron Job: The administrator must schedule cron jobs to run every 5 minutes to generate bandwidth usage graphs.
-
Pricing Adjustment: While UpCloud has predefined prices for Windows, CPU, RAM, and storage, you have the flexibility to adjust them according to your specific requirements.
-
VM Information: Clients can view basic VM information such as VPS, VNC, IP addresses details.
-
VNC Management: Clients can enable/disable VNC access.
-
Password Management: Clients can change their VNC passwords.
-
Reverse PTR: Clients can view and set reverse PTR records.
-
VM Control: Clients can start, stop, and restart their VMs.
-
Configuration Modification: Clients can modify server configurations to suit their needs.
-
Bandwidth Usage Graph: Clients can view bandwidth usage graphs for intervals spanning 24 hours, a week, a month, and a year.
- Obtain the module from our GitHub repository.
- Unpack the module on your local system and transfer the "upCloudVps" folder to your WHMCS directory named "/path-to-your-WHMCS/modules/servers/" on your WHMCS installation.
- Access the UpCloud Hub at https://hub.upcloud.com and log in using your credentials.
- Navigate to the "People" section from the left sidebar.
- Proceed to create a sub-account by selecting the "Create subaccount" button.
- Enter a username, password, and complete other required details (Personal Information), then click "Create subaccount" at the bottom.
- After creating the user, click on "Edit", then navigate to the Permissions section and click on "Go to permissions".
- Enable all permissions except "Control Panel" and save the changes.
Reference: https://docs.whmcs.com/Servers
- Log in to your WHMCS as an admin user and go to Configuration > System Settings > Servers.
- Select "Add New Server" and choose "UpCloud VPS" from the module dropdown.
- Enter the Hostname or IP Address as: api.upcloud.com (you can assign any name).
- For Username, input your API username created in the previous step.
- For Password, input your API password created in the previous step.
- Proceed by clicking on "Test Connection" or "Continue Anyway".
- Click Create New Group under the Options heading.
- Enter a name for your group.
- Select the servers you want to assign (previously created) to this group in the box on the left.
- Click Add to move them to the box on the right, which contains the servers for this group.
- Click Save Changes to complete the process.
- Navigate to Configuration > System Settings > Product/Services
- Click on Create Product Group
- Provide a Product Group name and adjust all other settings based on your requirements
- Click on Save Changes
- Click on Create a New Product
2. Configure the following details:
- Product Type: Select as "Other"
- Product Group: Select the product group that you created
- Product Name: Provide your product name
- Module: UpCloud VPS
- Create as Hidden: Off
- Click on Save Changes
On the next page:
- Verify the Product Type
- Set Welcome Email to "Dedicated/VPS Server Welcome Email"
- Go to the Module Settings Tab
- Select the required details:
- Module Name
- Server group
- Default Location
- Plan
- Template
- If for Plans you selected "Custom", then users will have the ability to choose their own CPU, RAM, and Storage space based on which VMs will be created.
- Decide whether the product requires manual approval from admins or is automatically deployed upon order.
- Click the Save Changes button.
This will create custom fields named (instanceId
, ssh_key
& userData
) as shown below:
The module will automatically create Configurable Options when you create your first product. You can select option groups that apply to your product.
To adjust these options:
- Go to System Settings -> Configurable Options
- Edit the newly created Options
Through these configurations you can:
- Set custom pricing for backup options
- Configure available locations
- Configure available custom plans
- Adjust prices for available images (such as Windows)
- Backup and Location: set custom pricing for backup options, and configure available locations
If custom plans are utilised:
- Memory: Users can choose the memory of a VPS, ranging from 4GB to 64GB.
- vCPU: Users can choose the vCPU of a VPS, ranging from 2 cores to 24 cores.
- Storage: Users can choose the storage of a VPS, ranging from 50GB to 460GB.
Note that custom plans are a discontinued feature. See the UpCloud product documentation for more information.
To add an existing UpCloud VPS to a user's account:
- Edit the user's product
- Within the custom field named "Instance Id", add your VPS UUID that you can obtain from UpCloud Hub
- User Data/Cloud-init: If provided by the user, these scripts will initiate after VM creation to kickstart the initialization process.
- SSH Key: If supplied by the user during VM creation, it will be utilized for user authentication instead of a password; otherwise, the system will default to using a password for authentication. Note that some templates only support SSH keys.
- Instance Id: This field is used to assign a user with a VPS
The administrator must schedule cron jobs to run every 5 minutes to generate bandwidth usage graphs. This is essential for the bandwidth monitoring feature to work properly.