Product Linker For WHMCS
            
            
            
            
                                    
                    From ModulesGarden Wiki
                    
                                
                (Difference between revisions)
                
                                                                    
                    
                    
                                
                
				
				
				
				
			
			|   |   | 
| Line 586: | Line 586: | 
|  | |} |  | |} | 
|  | {| |  | {| | 
| − | |style="padding: 0px 0px 30px 15px;"|4. Keep in mind that the second product, linked by the module, is never visible in the cart. It is automatically added once the first one is activated. | + | |style="padding: 0px 0px 30px 15px;"|4. Keep in mind that the second product, linked by the module, is never visible in the cart. It is automatically added once the first one is ordered. | 
|  | |} |  | |} | 
|  |  |  |  | 
		Revision as of 13:54, 13 August 2024
| Product Linker For WHMCS allows you to create relations between your products, addons and configurable options. 
 Consequently, clients may buy products in bundles along with flexible promo codes.Module will also allow you to view, filter and delete existing connections used by your customers.
 | 
| ✔ Handle Dependencies Between Module Actions - Each Create/Terminate/Suspend/Unsuspend Action Called On Main Product Triggers Such Action On Child Products | 
| ✔ Enable Product Updates With Automatic Email Notifications Sent To Administrators | 
| ✔ Copy Configurable Options From Parent To Child Product | 
| ✔ Define Relations Between Chosen Products, Addons, Configurable Options, And Linked Products | 
| ✔ Define If Addon Price Should Be Switched With Linked Product Price | 
| ✔ Assign Custom Promo Codes To Relations | 
| ✔ View, Filter And Delete Existing Connections | 
| ✔ Buy Multiple Products, Addons And Configurable Options By Ordering At Least One Of Them | 
| ✔ View Linked Product Added To Order By Triggering Relation | 
| ✔ Supports PHP 8.1 Back To PHP 7.4 | 
| ✔ Supports WHMCS Themes "Six" And "Twenty-One" | 
| ✔ Supports WHMCS V8.10 Back To WHMCS V8.8 | 
| ✔ Requires ionCube Loader V12 Or Later | 
 Installation
| This tutorial will show you how to successfully install Product Linker For WHMCS. 
 We will guide you step by step through the whole installation and configuration process. 
 | 
| 1. Log in to our client area and download the module. | 
| 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.2 and later.
 | 
| Previous updates of the module may contain two packages dedicated to various PHP versions. 
 The first one supports PHP 5.6 up to PHP 7.1, and the second one addresses PHP 7.2 up to PHP 7.4.Note: Keep in mind that PHP versions 5.6 up to 7.1 are no longer officially supported and their security issues are not fixed or released anymore. Find more info here.
 | 
| 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. 
 | 
| 4. When you install Product Linker For WHMCS for the first time you have to rename  'license_RENAME.php'  file. 
 File is located in  'modules/addons/productlinker/license_RENAME.php'.  Rename it from  'license_RENAME.php'  to  'license.php'. 
 | 
| 5. In order to configure your license key, you have to edit the 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'.  
 | 
| 6. Now you have to activate the module in your WHMCS system. 
 Log in to your WHMCS admin area. Go to  'Setup'  →  'Addon Modules'.  Afterward, find  'Product Linker'  and press the  'Activate'  button.
 | 
| 7. In the next step, you need to permit access to this module. 
 To do so, click on the  'Configure'  button, select administrator groups that should have access to this addon, and press  'Save Changes'. 
 | 
| 8. To enable logs from failed actions, go to  'Utilities'  →  'Logs'  →  'Module Log'. 
 There, press  'Enable Debug Logging'. 
 | 
| 9. You have just successfully installed Product Linker For WHMCS! 
 You can access your module at  'Addons'  →  'Product Linker'. 
 | 
 Configuration and Management
| Product Linker For WHMCS allows to sell bundles of products through ordering one product with specific product addons and configurable options. 
 It also automatically forwards basic commands from the main product to all child products.You can define the relation between products through a product addon or configurable option. You will find more information about it in the  'Add Relation'  section.
 
 | 
 Basic Relations
| At the  'Basic Relations'  tab you can define links between products through product addons and configurable options. 
 They will be triggered once your client makes an order for a product, with the product addon/configurable option chosen at the relation, and runs the Create command for that product.Additionally, you can define a promo code added to the order by triggering the relation.
 | 
 Add Relation
| To add a new relation, go to  'Product Linker'  →  'Basic Relations'. Now, select a relation type from the  'Type'  dropdown menu, you can choose between a relation triggered by a product addon or a configurable option.
 
 Note: For  'Addon'  type there is also the  'Swap Price'  option available. If you select it, the price of the linked hosting/product will be overwritten with the addon price.
 | 
| Next, select a product addon or a configurable option name from the  'Product Addon/Configurable Option'  dropdown menu. 
 If you have chosen the  'Configurable option'  relation type, additionally you have to select a configurable option value.
 | 
| Finish by selecting a child product that will be linked after triggering the relation. 
 Choose a promo code that will be added to the order and save the relation by pressing the  'Add Relation'  button.Note: Only one promo code can be assigned to the order, you can specify the assignment of promo code at the  'Settings'  page.
 | 
 Edit Relation
| Editing relations is quite easy, go to the  'Basic Relations'  tab and start making changes. 
 You can alter one relation or multiple relations simultaneously, the only difference is the button used to save changes.If you are making changes in only one relation, press the  'Save Changes'  button next to it, otherwise use  'Save Changes'  at the bottom of the page (pointed with a green arrow).
 | 
 Product Relations
| At the  'Product Relations'  tab you can set up a relation linking one product with another. 
 To create a new configuration simply choose a product that will trigger the relation from the  'Product'  dropdown menu. Next, select a product that will be added from the  'Linked Product' dropdown menu.
Optionally, assign a promo code and enable configurable option copying (if possible). Press  'Add Relation'  to save the relation.
 | 
| Our module allows you to enable copying the parent's product configurable options to the child product upon ordering them. 
 To enable copying, mark the checkbox next to configurable options and press  'Save Changes'  as shown on the screen below.Note: You can enable configurable option copying only if the configurable option is assigned to both products.
 | 
 Existing Connections
| 'Existing Connections'  tab allows you to view the list of all products ordered by your clients for which relations exist. 
 You can find all the information about a relation, like the main product, linked product, their owner, or domain used by both products.You can quickly move to the customer or any of their products by simply clicking on a client/product name.
 | 
| Module also allows you to order records on the list by selecting a column by pressing on its headline. 
 For example, to order by client name, press on the  'Client Name'  column header as shown on the following screen.
 | 
| You can use filters to display only specific records. 
 To open the filters form, press  'Toggle Filters'. 
 | 
| You are able to set up filtering by client name, both main and linked products and domain. 
 When you select values you desire, click the  'Filter Results'  button (red arrow).If you decide to clear the filters you have set up earlier, open the filters form and press  'Clear Filter'  (green arrow).
 | 
 Module Logs
| If there is any trouble with linked products, the error information will be displayed on the  'Module Logs'  page. 
 Error messages can be found at the  'Clean Response'  and  'Parsed Response'  columns.To locate products for which an error occurred, you can use data in the  'Request Parameters'  column.
 For example,  '[accountid]'  and  '[domain]'  should be enough to quickly localize products.
 Note: Module also checks if the module log is turned on and provides a link to it.
 | 
| You can look for the product with details you found in the previous step, but a way faster method is to use a link. 
 All you have to do is enter the value of  '[accountid]'  in place of account_id in the link below.
 your_whmcs/admin/clientsservices.php?id=account_id
 To confirm if you are looking at the right product, check if a domain in the product matches the domain you found in the error log.
 | 
 Settings
| In the  'Settings'  section you may manage the promo codes assignment to linked products and add some information to the order form. 
 Due to the assignment of promo codes to the relation, it may happen that multiple promo codes will be assigned to one order form. WHMCS does not support such actions, therefore only one promo code has to be chosen.
 1.  'Highest Discount Available'  - if checked, the promo code giving the highest discount to your clients will be chosen at the order form.
 2.  'Discount Limit'  - if  'Highest Discount Available'  is disabled, the promo code giving the closest discount to the value provided will be chosen.
 The discount has to be greater than the value provided.
 
 | 
| 3. Display Product Info - if this option is selected in the  'Settings'  section, there is information visible on the linked product on the order form. | 
 Exemplary Connections
| At the  'Exemplary Connections'  section we will show you how to set up relations between specific products. 
 One of the many possibilities is connecting cPanel Manage2 For WHMCS, DirectAdmin Licenses For WHMCS and Odin Key Administrator For WHMCS with other products.This will allow you to automatically provision ready-to-use licenses for clients once they order a product of your choice, e.g. a VPS server.
 Note: Before following any of the exemplary configurations below, make sure that both products you will be using in the configuration are set up correctly.
 Additionally, products linked to the main product should be set to hidden and free. You will be able to set its price at the product addon.
 | 
 cPanel Extended + cPanel Manage2
| In these steps, we will show you how to link cPanel Manage2 with cPanel Extended through the product addon. 
 Note: You can also link them using configurable options.1. Start by creating the  'IP'  custom field at the main product visible on the order form.
 To do so, go to  'Setup'  →  'Products/Services'  →  'Products/Services'  and edit your cPanel Extended product.
 | 
| 2. Open the  'Custom Fields'  tab, enter  'IP'  into  'Field Name'  and mark the  'Show on Order Form'  checkbox. 
 Confirm changes by pressing  'Save Changes'. 
 | 
| 3. It is time to create the product addon which will trigger the relation. 
 Go to  'Setup'  →  'Products/Services'  →  'Products Addons'  and press  'Add New Addon'. 
 | 
| 4. Enter the addon name, its description, and recurring price. Choose the billing cycle from the  'Billing Cycle'  dropdown menu. 
 It is advised to set up the same billing cycle as in the main product. Additionally, you have to mark the 'Show on Order'  checkbox and the checkbox next to the main product.In this example it will be  'cPanel - cPanel Extended'.
 Next, press  'Save Changes'.
 | 
| 5. Now, create a relation at your  'Product Linker'  →  'Basic Relations'. | 
| To check if the relation works as it should, place an order from the admin area for the main product with the product addon triggering the relation. 
 Do not forget to type the domain and IP address. Afterward, press  'Submit Order'. 
 | 
| Select  'Run Module Create'  and press  'Accept Order'. | 
| If a new entry appeared as the one marked on the following screen, you have successfully configured both products and linked them through the addon. | 
 DirectAdmin Extended + DirectAdmin Licenses
| In these steps, we will show you how to link DirectAdmin Licenses to DirectAdmin Extended through the product addon. 
 Note: You can also link them using configurable options.1. Start by creating the  'IP'  custom field at the main product visible on the order form.
 To do so, go to  'Setup'  →  'Products/Services'  →  'Products/Services'  and edit your DirectAdmin Extended product.
 | 
| 2. Open the  'Custom Fields'  tab, enter  'IP'  into  'Field Name'  and mark the  'Show on Order Form'  checkbox. 
 Confirm changes by pressing  'Save Changes'. 
 | 
| 3. It is time to create the product addon which will trigger the relation. 
 Go to  'Setup'  →  'Products/Services'  →  'Products Addons'  and press  'Add New Addon'. 
 | 
| 4. Enter the addon name, its description, and a recurring price. Choose a billing cycle from the  'Billing Cycle'  dropdown menu. 
 It is advised to set up the same billing cycle as in the main product. You also have to mark the  'Show on Order'  checkbox and the checkbox next to the main product.In this example, it will be  'DirectAdmin - DirectAdmin Extended'.
 Next, press  'Save Changes'.
 | 
| 5. Now, create a relation at your  'Product Linker'  →  'Basic Relations'. Note that the  'Swap Price'  option has been also marked here. Consequently, the price for the addon will be changed with the price for the linked product/hosting.
 | 
| To check if the relation works as it should, place an order from the admin area for the main product with the product addon triggering the relation. 
 Do not forget to type in the domain and IP address. Afterward, press  'Submit Order'. 
 | 
| Select  'Run Module Create'  and press  'Accept Order'. | 
| If a new entry appeared as the one marked on the following screen, you have successfully configured both products and linked them through the product addon. | 
 Plesk Extended + Plesk Key Administrator
| In these steps, we will show you how to link Plesk Key Administrator with Plesk Extended through a product addon. 
 There are a few key types in your Plesk Key Administrator that are licenses for Plesk Extended.In this example we will use  'PLESK_10_AND_LATER'  key type.
 Note 1: You can also link these products using configurable options.
 
 | 
| 1. Start by creating the  'IP'  custom field at the main product which will be visible on the order form. 
 Go to  'Setup'  →  'Products/Services'  →  'Products/Services'  and edit your Plesk Extended product.
 | 
| 2. Open the  'Custom Fields'  tab, enter  'IP'  into  'Field Name'  and mark the  'Show on Order Form'  checkbox. 
 Additionally, you can enter a description of this custom field and set up field validation (it is a one-line validation, do not split it into two lines):
 /\b(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\b/
 
 Confirm changes by pressing  'Save Changes'. 
 | 
| 3. It is time to create the product addon which will trigger the relation. 
 Go to  'Setup'  →  'Products/Services'  →  'Products Addons'  and press  'Add New Addon'. 
 | 
| 4. Enter an addon name, its description, and a recurring price. 
 Choose the billing cycle from the  'Billing Cycle'  dropdown menu. It is advised to set up the same billing cycle as in the main product.You also have to mark the  'Show on Order'  checkbox and the checkbox next to the main product. In this example, it will be  'Odin Group - Plesk Extended'.
 Next, press  'Save Changes'.
 | 
| 5. Now, create a relation at your  'Product Linker'  →  'Basic Relations'. | 
| To check if the relation works as it should, place an order from the admin area for the main product with the addon triggering the relation. 
 Do not forget to type an IP address. Afterward, press  'Submit Order'. 
 | 
| Select  'Run Module Create'  and press  'Accept Order'. | 
| If a new entry appeared as the one marked on the following screen, you have successfully configured both products and linked them through the product addon. | 
 Client Area
| In this section, we will try to visualize how a client may benefit from the connections made between certain products. 
 Let's take a look at an exemplary situation.
 | 
| Administrator has created a connection between a VPS product: VPS 2x2.4GHz 16 GB RAM, 1TB HDD 
 and allowed to purchase two add-ons along with it:- cPanel License
 - Direct Admin License
 Our Test Tester client decided to add a cPanel License to the cart next to the VPS product.
 Thanks to the connection created in the Product Linker addon, the final price is lower than as if the two items were ordered separately.
 | 
| When items are activated, the client may see their pricing on the products list. | 
 Tips
| 1. If your client orders a product with settings triggering two relations with the same product, only one product will be created. | 
| 2. If your client orders a product configurable options upgrade/downgrade, the old linked product bound by a previous configurable option will stay active. You need to remove the link between the old linked product and the main product in the addon and terminate the old linked product manually.
 | 
| 3. If a child product is at the same time a parent product in the other relation, changes made on its parent will be also commanded on its child. | 
| 4. Keep in mind that the second product, linked by the module, is never visible in the cart. It is automatically added once the first one is ordered. | 
 Update Instructions
| An essential guidance through the process of updating the module is offered here. 
 Ensure successful completion of the module update by carefully following each step, thereby preventing data loss or any unforeseen issues.Additionally, you will find a current list of supplementary actions necessary for a smooth update process there.
 | 
 Upgrade Guide
| Seeking a solution that offers greater flexibility, customization tailored to your precise needs, and unrestricted availability? There is an option that not only proves to be cost-effective in the long run but also includes prioritized support services, making it a truly valuable investment.
 
 Opt for the Open Source version of your Product Linker For WHMCS module to unlock these benefits.Simply click on either the Get Source Code or Upgrade To Lifetime button found on the product's page in our client area to complete the one-step upgrade process, with a dedicated discount already applied.
 
 Follow a comprehensive guide covering the transition process, the advantages it brings, and step-by-step instructions on what to do next after the order has been successfully finalized. 
 | 
 Common Problems
| 1. When you have problems with connection, check whether your SELinux or firewall does not block ports. |