Personal tools
Namespaces

Variants
Actions

Resellers Center For WHMCS

From ModulesGarden Wiki
(Difference between revisions)
Jump to: navigation, search
(About Resellers Center For WHMCS)
(Common Problems)
 
(44 intermediate revisions by 2 users not shown)
Line 8: Line 8:
 
{|
 
{|
 
|style="padding: 10px 0px 10px 0px;"|'''Resellers Center For WHMCS''' empowers your resellers with tools to control end clients and their orders through single WHMCS!<br />
 
|style="padding: 10px 0px 10px 0px;"|'''Resellers Center For WHMCS''' empowers your resellers with tools to control end clients and their orders through single WHMCS!<br />
Thanks to Resellers Center For WHMCS, your resellers will be allowed to collect dedicated customers and select for them specific products, services and domains. <br />
+
Thanks to Resellers Center For WHMCS, your resellers will be allowed to collect dedicated customers and select specific products, services, and domains for them. <br />
 
Moreover, the module enables end clients to perform convenient orders of services straight from your WHMCS. <br />
 
Moreover, the module enables end clients to perform convenient orders of services straight from your WHMCS. <br />
What is more, they will be able to log in to their own WHMCS account with regard to handle their services, formulate tickets and pay invoices.
+
What is more, they will be able to log in to their own WHMCS account with regard to handling their services, formulating tickets and paying invoices.
 
|}
 
|}
 
<!-- fixed -->
 
<!-- fixed -->
Line 100: Line 100:
 
{|
 
{|
 
|style="padding: 0px 0px 0px 30px;"|✔ Allow Invoice Branding
 
|style="padding: 0px 0px 0px 30px;"|✔ Allow Invoice Branding
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 30px;"|✔ Enable Reseller Invoice
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 30px;"|✔ Enable Credit Memo Invoicing
 
|}
 
|}
 
{|
 
{|
Line 135: Line 141:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Prevent Resellers From Viewing End Clients Details
+
|style="padding: 0px 0px 0px 30px;"|✔ Prevent Resellers From Viewing End Client Details
 
|}
 
|}
 
{|
 
{|
Line 190: Line 196:
 
{|
 
{|
 
|style="padding: 0px 0px 0px 45px;"|✔ Invoices
 
|style="padding: 0px 0px 0px 45px;"|✔ Invoices
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 45px;"|✔ Credit Memos
 
|}
 
|}
 
{|
 
{|
Line 198: Line 207:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 10px 30px;"|✔ View Resellers Affiliations On WHMCS Clients List
+
|style="padding: 0px 0px 0px 30px;"|✔ View Resellers Affiliations On WHMCS:
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 45px;"|✔ Client List
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 45px;"|✔ Product, Product Addon And Domain List
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 45px;"|✔ Specific Service And Domain View
 +
|}
 +
{|
 +
|style="padding: 0px 0px 10px 45px;"|✔ Administrator Email Messages
 
|}
 
|}
  
Line 212: Line 233:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 45px;"|✔ Invoices
+
|style="padding: 0px 0px 0px 45px;"|✔ Billing:
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 60px;"|✔ Invoices
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 60px;"|✔ Credit Memos
 
|}
 
|}
 
{|
 
{|
Line 255: Line 282:
 
{|
 
{|
 
|style="padding: 0px 0px 0px 45px;"|✔ Invoice Pay To Text
 
|style="padding: 0px 0px 0px 45px;"|✔ Invoice Pay To Text
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 45px;"|✔ Invoice Footer Message
 
|}
 
|}
 
{|
 
{|
Line 294: Line 324:
 
{|
 
{|
 
|style="padding: 0px 0px 0px 45px;"|✔ Stripe
 
|style="padding: 0px 0px 0px 45px;"|✔ Stripe
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 45px;"|✔ Stripe SEPA
 
|}
 
|}
 
{|
 
{|
 
|style="padding: 0px 0px 0px 45px;"|✔ WePay
 
|style="padding: 0px 0px 0px 45px;"|✔ WePay
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 30px;"|✔ Restrict Payment Gateway Availability To Specified Countries
 
|}
 
|}
 
{|
 
{|
Line 350: Line 386:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Receive Email Notifications On End Clients Orders
+
|style="padding: 0px 0px 0px 30px;"|✔ Receive Email Notifications On End Client Orders
 
|}
 
|}
 
{|
 
{|
Line 381: Line 417:
 
{|
 
{|
 
|style="padding: 0px 0px 0px 45px;"|✔ Invoices
 
|style="padding: 0px 0px 0px 45px;"|✔ Invoices
 +
|}
 +
{|
 +
|style="padding: 0px 0px 0px 45px;"|✔ Credit Memos
 
|}
 
|}
 
{|
 
{|
Line 424: Line 463:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Supports PHP 8.1 Back To PHP 7.4
+
|style="padding: 0px 0px 0px 30px;"|✔ Supports PHP 8.3 Back To PHP 8.1
 
|}
 
|}
 
{|
 
{|
Line 430: Line 469:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Supports WHMCS V8.10 Back To WHMCS V8.6
+
|style="padding: 0px 0px 0px 30px;"|✔ Supports WHMCS V8.13 Back To WHMCS V8.10
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 0px 30px;"|✔ Requires ionCube Loader V12 Or Later
+
|style="padding: 0px 0px 0px 30px;"|✔ Requires ionCube Loader V14 Or Later
 
|}
 
|}
 
{|
 
{|
Line 456: Line 495:
 
{|
 
{|
 
|style="padding: 0px 0px 15px 15px;"|'''2. In the downloaded file you might find one or two packages that support different PHP versions.'''<br/>
 
|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.4 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]. -->
+
In the most recent versions of the module, you will find only one package that supports PHP 7.4 and later.<br/>'''''Note''': You can check the current PHP version in your WHMCS. To do so, proceed to 'Utilities' → 'System' → 'PHP Info'.''  <!-- If you need a package for the previous versions of PHP, please [https://www.modulesgarden.com/support/ticket/general-support contact our support]. -->
 
|}
 
|}
 
{|
 
{|
Line 462: Line 501:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|'''Previous updates of the module may contain two packages dedicated to various PHP versions.'''<br/>
+
|style="padding: 0px 0px 10px 15px;"|<!-- '' '''Important''': This situation does not affect [https://www.modulesgarden.com/products/whmcs/resellers-center#open-source-version '''the open source version'''] of this module which can be applied to any PHP from version 5.6 and later.''<br/>'' -->  
The first one supports PHP 5.6 up to PHP 7.3, and the second one addressed to PHP 7.4 up to PHP 8.1.<br/>
+
'''''Note:''' Keep in mind that PHP versions 5.6 up to 7.3 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 20px 25px;"|[[File:PHP56_74_81.png]]
+
|}
+
{|
+
|style="padding: 0px 0px 10px 15px;"|<!-- '' '''Important''': This situation does not affect [https://www.modulesgarden.com/products/whmcs/resellers-center#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'.'''
+
 
|}
 
|}
 
{|
 
{|
Line 495: Line 526:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|'''6. The next step is setting up the '' 'storage' '' and '' 'config' '' folders as writable.'''<br />
+
|style="padding: 0px 0px 15px 15px;"|'''6. The next step is setting up the '' 'storage' '' and '' 'config' '' folders as recursively writable.'''<br />
 
They are located in: '' 'your_whmcs/modules/addons/ResellersCenter/'.''
 
They are located in: '' 'your_whmcs/modules/addons/ResellersCenter/'.''
 
|}
 
|}
Line 576: Line 607:
 
{|
 
{|
 
|style="padding: 10px 0px 30px 15px;"|Management of Resellers Center For WHMCS is very convenient. You can supervise everything from the addon.<br />
 
|style="padding: 10px 0px 30px 15px;"|Management of Resellers Center For WHMCS is very convenient. You can supervise everything from the addon.<br />
What is more, the module extends possibilities of both your resellers and their customers.<br />
+
What is more, the module extends the possibilities of both your resellers and their customers.<br />
 
Let us find out what our product can do!
 
Let us find out what our product can do!
 
|}
 
|}
Line 583: Line 614:
 
|style="padding: 10px 0px 15px 15px;"|In this section you can find more information about a global configuration.<br />
 
|style="padding: 10px 0px 15px 15px;"|In this section you can find more information about a global configuration.<br />
 
Additionally, here you can also read about the details of migration.   
 
Additionally, here you can also read about the details of migration.   
<!-- Additionally, here you can find a direct link to module documentation as well as migration tool. -->
+
<!-- Additionally, here you can find a direct link to module documentation as well as a migration tool. -->
 
|}
 
|}
 
===Global Configuration===
 
===Global Configuration===
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|In the '' 'Configuration' '' tab you can set up global settings of the module. You can define '' 'General', 'Billing' '' and '' 'Email Templates' '' settings.<br/>
+
|style="padding: 0px 0px 15px 15px;"|In the '' 'Configuration' '' tab you can set up the global settings of the module. You can define '' 'General', 'Billing' '' and '' 'Email Templates' '' settings.<br/>
''Please note that these settings are default for all resellers. Read this section through to find the details of configuration per each reseller.''
+
''Please note that these settings are the default for all resellers. Read this section through to find the details of configuration per each reseller.''
 
|}
 
|}
 
====General Settings====
 
====General Settings====
 
{|
 
{|
 
|style="padding: 0px 0px 15px 15px;"|
 
|style="padding: 0px 0px 15px 15px;"|
*'''Store Branding''' - Allows resellers to set up a custom logo, company name and domain.
+
*'''Store Branding''' - Allows resellers to set up a custom logo, company name, and domain.
 
*'''Allow Products''' - If enabled, resellers will be able to sell properly configured products in their own stores.
 
*'''Allow Products''' - If enabled, resellers will be able to sell properly configured products in their own stores.
 
*'''Allow Domains''' - Gives resellers the possibility to sell domains in their own stores.
 
*'''Allow Domains''' - Gives resellers the possibility to sell domains in their own stores.
Line 629: Line 660:
 
*'''Reseller Invoice'''  
 
*'''Reseller Invoice'''  
 
**''When the  'Reseller Invoice'  option is off'':<br/>When end clients place orders in the reseller store, the invoice will be created by WHMCS with the admin details (provided earlier in '' 'General Settings' '').<br/> Once the invoice is paid, the module calculates the profit in accordance with the product configuration in the reseller group.<br/> The calculated amount goes to '' 'Payouts' '' where the admin can transfer it via PayPal or credits to the reseller account.<br/>Find out more about calculation and pricing methods [[#Product_Pricing|here]].<br/>
 
**''When the  'Reseller Invoice'  option is off'':<br/>When end clients place orders in the reseller store, the invoice will be created by WHMCS with the admin details (provided earlier in '' 'General Settings' '').<br/> Once the invoice is paid, the module calculates the profit in accordance with the product configuration in the reseller group.<br/> The calculated amount goes to '' 'Payouts' '' where the admin can transfer it via PayPal or credits to the reseller account.<br/>Find out more about calculation and pricing methods [[#Product_Pricing|here]].<br/>
**''When the  'Reseller Invoice'  option is on'':<br/>There are two invoices generated after placing an order in the reseller store. The first invoice is created by the reseller and sent to the client <br/> while the other one is generated by the admin and delivered to the reseller. The amount invoiced is taken directly from the admin charge for the product (reseller group configuration).<br/> In this case, calculation methods are not included and the reseller earns on price differences between invoices.<br/> Moreover, this option also permits resellers to use their own configuration data in payment gateways settings.<br/>Once they do it, end clients are able to make payments directly to the reseller account and the reseller settles debts with the administrator using prepaid WHMCS credits.<br/> '' '''Important:''' When you enable this option and any invoice is created in the meantime, you will not be able to disable it anymore! ''<br/> '''''Note:''' 'Configurable Option Commissions' option is unavailable if the 'Reseller Invoice' option is on.''
+
**''When the  'Reseller Invoice'  option is on'':<br/>There are two invoices generated after placing an order in the reseller store. The first invoice is created by the reseller and sent to the client <br/> while the other one is generated by the admin and delivered to the reseller. The amount invoiced is taken directly from the admin charge for the product (reseller group configuration).<br/> In this case, calculation methods are not included and the reseller earns on price differences between invoices.<br/> Moreover, this option also permits resellers to use their own configuration data in payment gateways settings.<br/>Once they do it, end clients are able to make payments directly to the reseller account and the reseller settles debts with the administrator using prepaid WHMCS credits.<br/>
*'''Deferred Payments''' - If enabled, your resellers will be allowed to define limits for deferred payments for their clients  
+
'' '''Important:''' Once the first invoice is generated, the option cannot be changed anymore.''<br/>'''''Note:''' 'Configurable Option Commissions' option is unavailable if the 'Reseller Invoice' option is on.''
 +
*'''Credit Memo''' - enables the credit memo system. This will restrict certain invoice options, and generate credit memos to make bookkeeping easier or comply with law restrictions.
 +
*'''Deferred Payments''' - If enabled, your resellers will be allowed to define limits for deferred payments for their clients.
  
 
*'''Gateways''' - Allows you to select gateways that resellers can enable in their own stores. This option is only available if '' 'Reseller Invoice' '' is disabled.  
 
*'''Gateways''' - Allows you to select gateways that resellers can enable in their own stores. This option is only available if '' 'Reseller Invoice' '' is disabled.  
 
*'''Sequential Invoice Number Format''' - Required if '' 'Reseller Invoice' '' is enabled.
 
*'''Sequential Invoice Number Format''' - Required if '' 'Reseller Invoice' '' is enabled.
*'''Deferred Payments Limit''' - Set the limit of deferred payments for your resellers. If you leave 0, the feature will be simply disabled and settings taken from the Pricing Group used.<br/> ''To use this option "Reselelr Invoice" option must be enabled.''
+
*'''Deferred Payments Limit''' - Set the limit of deferred payments for your resellers. If you leave 0, the feature will be simply disabled and settings taken from the Pricing Group used.<br/> ''To use this option the '' 'Reseller Invoice' '' option must be enabled.''
 
|}
 
|}
 
{|
 
{|
Line 674: Line 707:
  
 
There are also features related to the deferred payments and consolidated invoices specific settings:
 
There are also features related to the deferred payments and consolidated invoices specific settings:
*'''Deferred Payments''' - Enable to allow resellers to restrict the placed by end clients orders to the total amount defined in the '' 'Deferred Payments Limit' '' setting ''(defined by the reseller per end client)''. <br/> Keep in mind that the end client will still be allowed to choose if he wants to make instant payments using:
+
*'''Deferred Payments''' - Enable to allow resellers to restrict the orders placed by end clients to the total amount defined in the '' 'Deferred Payments Limit' '' setting ''(defined by the reseller per end client)''. <br/> Keep in mind that the end client will still be allowed to choose if he wants to make instant payments using:
** standard methods ''(gateways, credits, bank transfer, etc)'' or
+
** standard methods ''(gateways, credits, bank transfer, etc.)'' or
 
** postpone the payment ''("Deferred Payments" payment gateway)'' but only if the order amount is lower than the limit<br/>  
 
** postpone the payment ''("Deferred Payments" payment gateway)'' but only if the order amount is lower than the limit<br/>  
 
*'''Verify Reseller Limit''' - When activated, this feature enhances order validation by considering both the end-client's and the reseller's deferred payments limit. If the reseller's credit is insufficient, a notice will suggest contacting them.  
 
*'''Verify Reseller Limit''' - When activated, this feature enhances order validation by considering both the end-client's and the reseller's deferred payments limit. If the reseller's credit is insufficient, a notice will suggest contacting them.  
Line 682: Line 715:
 
In case the consolidated invoices feature is turned on, the client cannot pay the order right after completing it. The consolidated invoices can be paid manually once generated.
 
In case the consolidated invoices feature is turned on, the client cannot pay the order right after completing it. The consolidated invoices can be paid manually once generated.
  
*'''Deferred Payments Limit''' - Define the limit for deferred payments for the reseller. If  "0" is entered, the feature will be disabled. The logic is the same as in described above option for end clients. <br/>  ''("Reseller Invoice" option must be previously enabled)''  
+
*'''Deferred Payments Limit''' - Define the limit for deferred payments for the reseller. If  "0" is entered, the feature will be disabled. The logic is the same as in the described above option for end clients. <br/>  ''("Reseller Invoice" option must be previously enabled)''  
  
 
*'''Consolidated Invoices''' - ''('Reseller Invoice' - enabled)'' All ordered items will be packed into one bundled invoice generated once a month, these include the invoices created for the resellers with purchased by them items ''(Reseller-Admin relation)''. <br/> When consolidated invoices are used, there is no possibility to make payments for ordered services with traditional payment methods right after completing the order.  
 
*'''Consolidated Invoices''' - ''('Reseller Invoice' - enabled)'' All ordered items will be packed into one bundled invoice generated once a month, these include the invoices created for the resellers with purchased by them items ''(Reseller-Admin relation)''. <br/> When consolidated invoices are used, there is no possibility to make payments for ordered services with traditional payment methods right after completing the order.  
Line 713: Line 746:
 
*'''Send Default Emails''' - If enabled and the email template is disabled in the '' 'Emails Templates' '' tab, the standard WHMCS email is sent for it. Otherwise, the email is not sent at all.
 
*'''Send Default Emails''' - If enabled and the email template is disabled in the '' 'Emails Templates' '' tab, the standard WHMCS email is sent for it. Otherwise, the email is not sent at all.
 
*'''Change Mail Settings''' - If enabled, the reseller will be allowed to manage the custom e-mail settings.
 
*'''Change Mail Settings''' - If enabled, the reseller will be allowed to manage the custom e-mail settings.
*'''Change Date Format''' - If enabled, the reseller will be allowed to configure the date format, display on their clients pages, individually.
+
*'''Change Date Format''' - If enabled, the reseller will be allowed to configure the date format, and display on their clients pages, individually.
 
*'''Hide Single Sign-on''' - Enable to hide the Single Sign-on featured from the reseller's store.
 
*'''Hide Single Sign-on''' - Enable to hide the Single Sign-on featured from the reseller's store.
 
|}
 
|}
Line 773: Line 806:
 
|style="padding: 0px 0px 15px 15px;"|It is possible to set pricing (1) for different billing cycles and currencies.
 
|style="padding: 0px 0px 15px 15px;"|It is possible to set pricing (1) for different billing cycles and currencies.
 
You can define pricing using the below options:
 
You can define pricing using the below options:
*'''Admin Price''' - price set for a product (it may be lower than what reseller sets when this difference will be the basis to calculate a profit)
+
*'''Admin Price''' - price set for a product (it may be lower than what the reseller sets when this difference will be the basis to calculate a profit)
 
*'''Highest Price''' - maximum price which can be set for a product
 
*'''Highest Price''' - maximum price which can be set for a product
 
*'''Lowest Price''' - minimum price which can be set for a product
 
*'''Lowest Price''' - minimum price which can be set for a product
Line 842: Line 875:
 
{|
 
{|
 
|style="padding: 10px 0px 15px 15px;"|The '' 'Resellers' '' tab displays all clients from your WHMCS system.<br />
 
|style="padding: 10px 0px 15px 15px;"|The '' 'Resellers' '' tab displays all clients from your WHMCS system.<br />
You can use it to assign any client to a reseller's group, that will activate them as resellers.<br />
+
You can use it to assign any client to a reseller's group, which will activate them as resellers.<br />
 
Click the button as shown below to create a new reseller.
 
Click the button as shown below to create a new reseller.
 
|}
 
|}
Line 864: Line 897:
 
{|
 
{|
 
|style="padding: 0px 0px 20px 15px;"|Here you can obtain more details about your customers and their clients.<br/>
 
|style="padding: 0px 0px 20px 15px;"|Here you can obtain more details about your customers and their clients.<br/>
Apart from clients, you can manage also invoices, transactions and services.
+
Apart from clients, you can manage also invoices, transactions, and services.
 
|}
 
|}
 
{|
 
{|
Line 882: Line 915:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 15px;"|In your WHMCS admin area, you may now quickly check if a client is assigned to a reseller, and to which one exactly (either a company name or first/last name is visible), without the need of opening the Resellers Center addon.
+
|style="padding: 0px 0px 15px 15px;"|In your WHMCS admin area, you may now quickly check if a client, product/service, domain or addon is assigned to a reseller, and to which one exactly (either a company name or first/last name is visible),<br/> without the need of opening the Resellers Center addon.
 
|}
 
|}
 
{|
 
{|
Line 888: Line 921:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 30px 25px;"|[[File:R3_11_10.png]]
+
|style="padding: 0px 0px 20px 25px;"|[[File:R3_11_10.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:R3_11_11.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 15px;"|A reseller label is also displayed on the client, product/service, domain, or addon page. Refer to the [[#Tips|Tips]] section, '''Tip 9''' to learn how to customize the labels.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:R3_11_12.png]]
 
|}
 
|}
 
<!--
 
<!--
Line 895: Line 937:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 15px;"|Click on '' 'Manage' '' to view more information about contact's products and domains.
+
|style="padding: 0px 0px 20px 15px;"|Click on '' 'Manage' '' to view more information about the contact's products and domains.
 
|}
 
|}
 
{|
 
{|
Line 901: Line 943:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|As you can see, all products, services and domains assigned to the reseller account are visible here.<br />
+
|style="padding: 0px 0px 15px 15px;"|As you can see, all products, services, and domains assigned to the reseller account are visible here.<br />
Items assigned to chosen resellers' contact are highlighted in blue, items assigned to other contacts of the reseller are gray, products assigned to the reseller are black.<br />
+
Items assigned to chosen resellers' contacts are highlighted in blue, items assigned to other contacts of the reseller are in gray, and products assigned to the reseller are in black.<br />
 
This is the place to manage items assigned to end-client.
 
This is the place to manage items assigned to end-client.
 
|}
 
|}
Line 941: Line 983:
 
|}
 
|}
  
In the '' 'Payouts' '' section, apart from looking at the details it is also possible to perform the following actions: ''pay by PayPal (1)'' or ''WHMCS Credits (2)'' and ''mark the transaction as completed (3)''.<br/>
+
In the '' 'Payouts' '' section, apart from looking at the details, it is also possible to perform the following actions: ''pay by PayPal (1)'' or ''WHMCS Credits (2)'' and ''mark the transaction as completed (3)''.<br/>
 
The '' 'Mass Payments' '' section enables you to make mass payouts to all selected resellers at once. You can choose from ''PayPal Payment (4), WHMCS Credits Payment (5)'' and set up proper<br/>PayPal ''Configuration'' by providing PayPal Application Key and Secret - both found within your PayPal account.  
 
The '' 'Mass Payments' '' section enables you to make mass payouts to all selected resellers at once. You can choose from ''PayPal Payment (4), WHMCS Credits Payment (5)'' and set up proper<br/>PayPal ''Configuration'' by providing PayPal Application Key and Secret - both found within your PayPal account.  
 
|}
 
|}
Line 998: Line 1,040:
 
{|
 
{|
 
|style="padding: 0px 0px 15px 15px;"|
 
|style="padding: 0px 0px 15px 15px;"|
Choose the resellers to whom the documentation will be visible, enter the name of the documentation and its content.<br/>
+
Choose the resellers to whom the documentation will be visible, and enter the name of the documentation and its content.<br/>
 
You can use HTML tags as well as attach a PDF version of your documentation.<br/>
 
You can use HTML tags as well as attach a PDF version of your documentation.<br/>
 
Once ready, click '' 'Save' '' to save your documentation.
 
Once ready, click '' 'Save' '' to save your documentation.
Line 1,008: Line 1,050:
 
|style="padding: 0px 0px 15px 15px;"|
 
|style="padding: 0px 0px 15px 15px;"|
 
From now on, our resellers will be encouraged to read the documentation from the welcome page, when they enter the '' 'Reseller Area' '' for the first time.<br/>
 
From now on, our resellers will be encouraged to read the documentation from the welcome page, when they enter the '' 'Reseller Area' '' for the first time.<br/>
Reseller can hide the welcome page by pressing "Do not show again". Even then, the documentation is accessible from the menu:
+
Resellers can hide the welcome page by pressing "Do not show again". Even then, the documentation is accessible from the menu:
 
|}
 
|}
 
{|
 
{|
Line 1,016: Line 1,058:
 
==Client Area - Reseller==
 
==Client Area - Reseller==
 
{|
 
{|
|style="padding: 10px 0px 15px 15px;"|In the client area, your clients can add new subclients and access the '' 'Reseller Area' ''.<br />
+
|style="padding: 10px 0px 15px 15px;"|In the client area, your clients can add new sub-clients and access the '' 'Reseller Area' ''.<br />
 
Access to the '' 'Reseller Area' '' is granted only to those clients, to whom reseller's groups are assigned in the Resellers Center For WHMCS module.
 
Access to the '' 'Reseller Area' '' is granted only to those clients, to whom reseller's groups are assigned in the Resellers Center For WHMCS module.
 
|}
 
|}
Line 1,032: Line 1,074:
 
{|
 
{|
 
|style="padding: 0px 0px 15px 15px;"|Fill out contact details and tick '' 'Activate Sub-Account'. ''<br />
 
|style="padding: 0px 0px 15px 15px;"|Fill out contact details and tick '' 'Activate Sub-Account'. ''<br />
Afterwards, fill in a password field for your contact, define account permission and email preferences.
+
Afterwards, fill in a password field for your contact, and define account permission and email preferences.
 
|}
 
|}
 
{|
 
{|
Line 1,041: Line 1,083:
 
===Reseller Area===
 
===Reseller Area===
 
{|
 
{|
|style="padding: 10px 0px 30px 15px;"|In the '' 'Reseller Area' '' you can manage clients, define products prices, set up branding, customize email templates and open tickets.
+
|style="padding: 10px 0px 30px 15px;"|In the '' 'Reseller Area' '' you can manage clients, define product prices, set up branding, customize email templates, and open tickets.
 
|}
 
|}
 
<!--
 
<!--
 
====Balance====
 
====Balance====
 
{|
 
{|
|style="padding: 10px 0px 15px 15px;"|Under this tab, you can view your balance, profit made, credit balance and redeem your profit into credit balance.<br />
+
|style="padding: 10px 0px 15px 15px;"|Under this tab, you can view your balance, profit made, credit balance and redeem your profit into a credit balance.<br />
 
Besides that, it is the place to view the list of profits made by reselling to your contacts.
 
Besides that, it is the place to view the list of profits made by reselling to your contacts.
 
|}
 
|}
Line 1,113: Line 1,155:
 
=====General Configuration=====
 
=====General Configuration=====
 
{|
 
{|
|style="padding: 10px 0px 0px 15px;"|In the '' 'Configuration' '' tab you are allowed to define '' 'General Settings' '' such as your own company name, email signature, invoice and store logos used across client's client area, emails, invoices and date format.<br />
+
|style="padding: 10px 0px 0px 15px;"|In the '' 'Configuration' '' tab you are allowed to define '' 'General Settings' '' such as your own company name, email signature, invoice footer, invoice and store logos used across client's client area, emails, invoices and date format.<br />
 
Please notice, that the available reseller configuration options may vary depending on the options you selected in the addon configuration and whether the '' 'Reseller Invoice' '' option was enabled for the reseller.<br/><br/>
 
Please notice, that the available reseller configuration options may vary depending on the options you selected in the addon configuration and whether the '' 'Reseller Invoice' '' option was enabled for the reseller.<br/><br/>
  
Line 1,160: Line 1,202:
 
=====Payment Gateways=====
 
=====Payment Gateways=====
 
{|
 
{|
|style="padding: 10px 0px 15px 15px;"|'' 'Payment Gateways' '' - this tab is only available if the '' 'Reseller Invoice' '' option in the admin area is set to '' 'Enabled' ''.<br/>
+
|style="padding: 10px 0px 15px 15px;"|This tab is only available if the '' 'Reseller Invoice' '' option in the admin area is set to '' 'Enabled' ''.<br/>
  
In this section, the reseller can set up their own payment gateway ('PayPal', 'Stripe', 'Bank Transfer', '2Checkout, Authorize.Net Aim', 'Checkout.com', 'Payflow Pro', 'Billplz'and 'WePay' gateways are currently available).<br/>  
+
In this section, the reseller can set up their own payment gateway ('PayPal', 'Stripe', 'Stripe SEPA', 'Bank Transfer', '2Checkout, Authorize.Net Aim', 'Checkout.com', 'Payflow Pro', 'Billplz'and 'WePay' gateways are currently available).<br/>  
 
Thanks to this, all payments made by end clients are transferred directly to the reseller's PayPal account or bank institution.<br/>
 
Thanks to this, all payments made by end clients are transferred directly to the reseller's PayPal account or bank institution.<br/>
 +
'''''Note:''' While setting up the the webhook endpoint for the Stripe SEPA gateway token, make sure to include the following events:
 +
charge.failed
 +
charge.succeded
 +
checkout.session.async_payment_failed
 +
checkout.session.async_payment_failed
 +
checkout.session.completed
 +
charge.dispute.closed
  
A payment gateway named '' 'Deferred Payments' '' is dedicated to the module features "Consolidated Invoices" and "Deferred Payments" features. It is available only if at least one of them is enabled.<br/>  
+
In the '' 'Country Limitation' '' field you can select countries users from which will have access to each gateway.<br/> Leave the field empty to allow the gateway for ever country. This restriction is based on WHMCS settings, not geolocation. <br/>
 +
 
 +
The payment gateway named '' 'Deferred Payments' '' is dedicated to the module features "Consolidated Invoices" and "Deferred Payments" features. It is available only if at least one of them is enabled.<br/>  
 
The payments between the reseller and the administrator are settled through the reseller's previously supplied credit balance.
 
The payments between the reseller and the administrator are settled through the reseller's previously supplied credit balance.
 
|}
 
|}
Line 1,186: Line 1,237:
 
*'''Enable Consolidated Invoices''' - enable the option to create one bundled invoice once a month with all ordered by the end client items in your store
 
*'''Enable Consolidated Invoices''' - enable the option to create one bundled invoice once a month with all ordered by the end client items in your store
 
*'''Consolidated Invoices Generation Day''' - choose the day of the month when the consolidated invoice will be generated.<br/> If you set it to, for example, 31, the invoice will be generated on the last day of the month ''(if that is shorter than 31 days).''
 
*'''Consolidated Invoices Generation Day''' - choose the day of the month when the consolidated invoice will be generated.<br/> If you set it to, for example, 31, the invoice will be generated on the last day of the month ''(if that is shorter than 31 days).''
*'''Default Credit Line Limit''' - this value limits total deferred payments per customer, it will be applied by default in cases where the limit is not specified for a given customer manually.
+
*'''Default Deferred Payments Limit''' - this value limits total deferred payments per customer, it will be applied by default in cases where the limit is not specified for a given customer manually.
 
|}
 
|}
 
{|
 
{|
Line 1,201: Line 1,252:
 
*Invoices
 
*Invoices
 
*Transactions
 
*Transactions
 +
*Credit Memos
 
|}
 
|}
 
{|
 
{|
Line 1,206: Line 1,258:
 
|}
 
|}
  
====Invoices====
+
====Billing====
 
{|
 
{|
 
|style="padding: 10px 0px 15px 15px;"|Here is the detailed list of end clients' all invoices together with their status.
 
|style="padding: 10px 0px 15px 15px;"|Here is the detailed list of end clients' all invoices together with their status.
Line 1,240: Line 1,292:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 15px 15px;"|Apart from the general section with all orderes listed, you may view a list of ordered products, addons and domains separately. <br/> Use visible filters to seach for specific orders only.
+
|style="padding: 0px 0px 15px 15px;"|Apart from the general section with all orders listed, you may view a list of ordered products, addons and domains separately. <br/> Use visible filters to search for specific orders only.
 
|}
 
|}
 
{|
 
{|
Line 1,285: Line 1,337:
 
{|
 
{|
 
|style="padding: 0px 0px 15px 25px;"|By toggling the '' 'Upgrades / Downgrades' '' section, you will have a few extra fields to configure.<br />
 
|style="padding: 0px 0px 15px 25px;"|By toggling the '' 'Upgrades / Downgrades' '' section, you will have a few extra fields to configure.<br />
*'''Upgrade Type''' - Select a suitable type of the upgrade the promotion applies to.
+
*'''Upgrade Type''' - Select a suitable type of upgrade the promotion applies to.
 
*'''Discount Type''' - Choose a type of the upgrade promotion.
 
*'''Discount Type''' - Choose a type of the upgrade promotion.
 
*'''Discount Value''' - Enter a rate of the discount.   
 
*'''Discount Value''' - Enter a rate of the discount.   
 
*'''Upgrades Of Configurable Options''' - Provide an amount of the discount.
 
*'''Upgrades Of Configurable Options''' - Provide an amount of the discount.
*'''Notes''' - Any notes will be visible for you and for administrators exclusively.
+
*'''Notes''' - Any notes will be visible to you and to administrators exclusively.
 
|}
 
|}
 
{|
 
{|
Line 1,345: Line 1,397:
 
{|
 
{|
 
|style="padding: 10px 0px 15px 15px;"|If you have not disabled tickets in your addon, your resellers will be able to reply and forward tickets created by their clients.<br />
 
|style="padding: 10px 0px 15px 15px;"|If you have not disabled tickets in your addon, your resellers will be able to reply and forward tickets created by their clients.<br />
It is only available for tickets department set in the Resellers Center For WHMCS configuration.
+
It is only available for the tickets department set in the Resellers Center For WHMCS configuration.
 
|}
 
|}
 
{|
 
{|
Line 1,428: Line 1,480:
 
====Separate Server====
 
====Separate Server====
 
{|
 
{|
|style="padding: 10px 0px 30px 0px;"|A separate server - in this situation the branded domain is added to other DNS server. It might be added to, for example cloudflare, or it is added and used on another server, for example cPanel or DirectAdmin.<br/>
+
|style="padding: 10px 0px 30px 0px;"|A separate server - in this situation, the branded domain is added to another DNS server. It might be added to, for example cloudflare, or it is added and used on another server, for example cPanel or DirectAdmin.<br/>
  
 
Take a look at the exemplary situation. Let's say there are two domains:  
 
Take a look at the exemplary situation. Let's say there are two domains:  
Line 1,443: Line 1,495:
 
<!--
 
<!--
 
{|
 
{|
|style="padding: 10px 0px 15px 0px;"|In this section you will find guides on how to create a ''CNAME'' record in popular control panels.<br />
+
|style="padding: 10px 0px 15px 0px;"|In this section, you will find guides on how to create a ''CNAME'' record in popular control panels.<br />
 
For instance, if a reseller's branded domain is '' 'reseller.com' '' and the domain with your WHMCS is '' 'whmcs.domain.com' '', the ''CNAME'' needs to be '' 'www.reseller.com. CNAME whmcs.domain.com.'.''<br />
 
For instance, if a reseller's branded domain is '' 'reseller.com' '' and the domain with your WHMCS is '' 'whmcs.domain.com' '', the ''CNAME'' needs to be '' 'www.reseller.com. CNAME whmcs.domain.com.'.''<br />
 
'' '''Note 1:''' As you can see above, each domain has to be closed with a full stop.''<br />
 
'' '''Note 1:''' As you can see above, each domain has to be closed with a full stop.''<br />
Line 1,450: Line 1,502:
 
{|
 
{|
 
|style="padding: 0px 0px 30px 0px;"|The domain used by each of brands '''must be parked''' on the main domain.<br/>In case when a domain cannot be parked or it is a subdomain, you must create the ''CNAME'' records that will redirect from the brand domain to the main domain.<br/>
 
|style="padding: 0px 0px 30px 0px;"|The domain used by each of brands '''must be parked''' on the main domain.<br/>In case when a domain cannot be parked or it is a subdomain, you must create the ''CNAME'' records that will redirect from the brand domain to the main domain.<br/>
Only when you have parked your domains can you move to setting the ''CNAME'' records on your panels. See the tips below.
+
Only when you have parked your domains can you move to set the ''CNAME'' records on your panels. See the tips below.
 
|}
 
|}
 
===cPanel===
 
===cPanel===
Line 1,509: Line 1,561:
 
==SSL Certificate==
 
==SSL Certificate==
 
{|
 
{|
|style="padding: 10px 0px 30px 15px;"|If reseller branded domains or your WHMCS main domain use the SSL connection''', they should also support selected certificates.<br />
+
|style="padding: 10px 0px 30px 15px;"|If reseller-branded domains or your WHMCS main domain use the SSL connection''', they should also support selected certificates.<br />
 
The supported types of certificates:
 
The supported types of certificates:
 
*'''Dedicated SSL Certificate''' - handled separately for each domain.
 
*'''Dedicated SSL Certificate''' - handled separately for each domain.
Line 1,535: Line 1,587:
 
|style="padding: 0px 0px 30px 15px;"|You can also consider enabling the '' '''[https://blog.cpanel.com/autossl/ AutoSSL]''' '' solution, which should automatically installs domain-validated SSL certificates. Go [https://documentation.cpanel.net/display/ALD/Manage+AutoSSL here] for more information.<br />
 
|style="padding: 0px 0px 30px 15px;"|You can also consider enabling the '' '''[https://blog.cpanel.com/autossl/ AutoSSL]''' '' solution, which should automatically installs domain-validated SSL certificates. Go [https://documentation.cpanel.net/display/ALD/Manage+AutoSSL here] for more information.<br />
 
'' '''Note:''' AutoSSL function will rather not work for CNAME entries so you should use '''[https://documentation.cpanel.net/display/CKB/How+Your+Server+Handles+Domains+and+Virtual+Hosts virtual hosts (vhosts)]''' instead.''
 
'' '''Note:''' AutoSSL function will rather not work for CNAME entries so you should use '''[https://documentation.cpanel.net/display/CKB/How+Your+Server+Handles+Domains+and+Virtual+Hosts virtual hosts (vhosts)]''' instead.''
 +
|}
 +
 +
=Use Cases=
 +
{|
 +
|style="padding: 10px 0px 30px 15px;"|'''This section features sample scenarios that illustrate common use cases and provide practical guidance on applying the module's functionalities.'''<br/>
 +
Review these scenarios for real-world examples of how to use the module effectively.
 +
|}
 +
==Introducing Credit Memos==
 +
{|
 +
|style="padding: 10px 0px 15px 15px;"|'''Resellers Center For WHMCS includes an optional credit memo billing system.'''<br/> This alternative invoice system can make bookkeeping easier, as it restricts invoice editing and introduces credit memos instead.<br/>This way of invoice management is required by law in some countries, but can also be useful for correcting billing errors, in product returns, or providing special discounts.
 +
The '' 'Reseller Invoice' '' feature must be enabled for the reseller first.<br/>
 +
'''''Note:''' The screens below show both features enabled in individual reseller's configuration, but can be enabled globally in 'Configuration' → 'Billing' as well.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:RCUC_01.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|Now the '' 'Credit Memos' '' feature can be enabled.<br/>
 +
'''''Note:''' If the toggle is still grayed out, try refreshing the page.''
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:RCUC_10.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 15px;"|As you can see the billing documents are now categorized into invoices and credit memos.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:RCUC_11.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|After a new invoice is created and delivered to the client, but not yet paid, a button to create the credit memo will appear.<br/>
 +
It is the only option that can be performed on a delivered invoice, as all data is set to read-only.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:RCUC_12.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 15px;"|The credit memo generated for the invoice is an exact copy of it but with a negative value.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:RCUC_13.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|Both the invoice and the credit memo are cross-labeled with related documents.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:RCUC_14.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 15px;"|As soon as the credit memo is created, both documents are marked as '' 'Closed'.''
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:RCUC_15.png]]
 +
|}
 +
 +
==Allocating Payment Gateways==
 +
{|
 +
|style="padding: 10px 0px 15px 15px;"|'''While using Resellers Center For WHMCS with the '' 'Reseller Invoice' '' function active, resellers can define which payment gateways are available for their clients based on the clients' country.'''<br/> See the instructions below to learn how it works. <br/>
 +
First, make sure that you are using the '' '[[#Billing_Settings|Reseller Invoice]]' '' system, as this feature requires it to function.<br/>
 +
'' '''Important:''' Once the first invoice is generated, the option cannot be changed anymore.''
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:RCUC_01.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 15px;"|In this example, the reseller has set up three payment gateways: Stripe, PayPal, and WePay.'' 'Country Limitation' '' is not set up for any of them.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:RCUC_0.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 15px;"|With no restrictions present, all gateways are visible to everyone.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:RCUC_1.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|Now, the '' 'Country Limitation' '' for Stripe has been changed to include only Afghanistan.<br/>
 +
This means clients from other countries will not be able to use Stripe.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:RCUC_2.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|As you can see, this account is set to the Czech Republic.<br/>
 +
Due to the restriction we have set, the Stripe gateway is not listed.<br/>
 +
Other payment gateways are available because there are no restrictions placed on them, or the account matches the country selected.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:RCUC_3.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|Next, we will log in as a client from the country we restricted Stripe to.<br/>
 +
Since the feature is based on the country in the client's profile, and not geolocation, we will simply change the settings in the '' 'Reseller Area'.''
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:RCUC_4.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|Once we reach checkout, Stripe is available again.<br/>
 +
This is because the country of this client matches the restriction rules we set for the gateway earlier.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:RCUC_5.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|'' 'Country Limitation' '' works for guests as well.<br/>
 +
With Stripe still limited to Afghanistan, the client that selects any other country in the billing address will not be able to use it.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 20px 25px;"|[[File:RCUC_6.png]]
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"| However, clients from Afghanistan will be presented with the Stripe option. <br/>
 +
Resellers can customize each gateway in this way, ensuring they meet their clients' needs and expectations.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:RCUC_7.png]]
 
|}
 
|}
  
Line 1,541: Line 1,711:
 
|style="padding: 10px 0px 5px 15px;"|'''1. If your WHMCS is installed in a subdirectory, your resellers using CNAME record must provide their links with it.'''<br />
 
|style="padding: 10px 0px 5px 15px;"|'''1. If your WHMCS is installed in a subdirectory, your resellers using CNAME record must provide their links with it.'''<br />
 
For example, '''reseller.com/main-whmcs-directory''' instead of '''reseller.com.'''.<br />
 
For example, '''reseller.com/main-whmcs-directory''' instead of '''reseller.com.'''.<br />
You can change that behavior through adding the below code to ''.htaccess'' file:
+
You can change that behavior by adding the below code to ''.htaccess'' file:
 
  RewriteEngine on
 
  RewriteEngine on
 
  RewriteCond %{HTTP_HOST} !^'''main-whmcs-domain.com'''$ [NC]
 
  RewriteCond %{HTTP_HOST} !^'''main-whmcs-domain.com'''$ [NC]
Line 1,582: Line 1,752:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 30px 25px;"|[[File:RC3_Tip_1.png]]
+
|style="padding: 0px 0px 25px 25px;"|[[File:RC3_Tip_1.png]]
 
|}
 
|}
<!--
 
 
{|
 
{|
|style="padding: 0px 0px 30px 15px;"|6. Remember to replace the "upgradesummary.tpl" template with a new one (available since version 3.13.0) to assure '''notifications about insufficient credit limit''' for deferred payments are correctly displayed.<br/>  
+
|style="padding: 0px 0px 15px 15px;"|7. For Stripe SEPA payment gateway the functions '' 'Revert on Dispute Loss' '' and '' 'Failed Transaction Fee' '' can be used together to achieve different behaviors, here are to possible combinations:
 +
* a) Revert on Dispute Loss enabled, Failed Transaction Fee enabled:<br/>The invoice to which the dispute relates returns to the Unpaid status, a negative transaction is added, and another invoice is created (reject invoice) with the amount specified in the settings.
 +
* b) Revert on Dispute Loss enabled, Failed Transaction Fee disabled:<br/>The invoice concerned by the dispute returns to the Unpaid status, a negative transaction is added, but a penalty invoice is not created.
 +
* c) Revert on Dispute Loss disabled, Failed Transaction Fee enabled:<br/>The invoice to which the dispute relates still has the Paid status, only a negative transaction is added to it, but a penalty invoice is created for it.
 +
* d) Revert on Dispute Loss disabled, Failed Transaction Fee disabled:<br/>The only thing that happens is that a negative transaction is added to the invoice.
 +
|}
 +
{|
 +
|style="padding: 0px 0px 15px 15px;"|8. Customize the '''Reseller Area button''' design:<br/>
 +
* Navigate to the configuration file: '' '/your_whmcs/modules/addons/ResellersCenter/config/customs' '' and open the '' 'resellerAreaButton.json' '' file.<br/>
 +
*'''Edit Button Properties'''
 +
** '''Icon:''' Add an icon to your button, e.g.: <code>"icon" : "fa fa-suitcase"</code>
 +
** '''Label:''' Overwrite the language file text, e.g.: <code>"rawLabel": "your_custom_label"</code>
 +
** '''Destination:''' Change the destination URL, e.g.: <code>"uri": "index.php?m=ResellersCenter"</code>
 +
** '''Order:''' Move the button inside the menu, e.g.: <code>"order": "1"</code><br/>
 +
*'''Class Properties'''
 +
** Modify the class properties (note that functionality is limited), e.g.: <code>"class": "bg-warning mg-class-place-holder"</code><br/>
 +
*'''Language File Text:'''
 +
** To have the button text change with the language used, edit the ''$_LANG['addonCA']['resellerarea']'' variable in the language files located under '' '\your_whmcs\modules\addons\ResellersCenter\langs'.'' <br/> You can learn more about language files [https://www.docs.modulesgarden.com/General#How_To_Change_WHMCS_Module_Language| here].
 +
|}
 +
{|
 +
|style="padding: 0px 0px 10px 15px;"|9. Customize the '''[[#Clients|Reseller Label]]''' design:<br/>
 +
You can define custom styles for reseller labels by creating a dedicated CSS stylesheet. Follow these steps to apply your own styles:
 +
* Create a CSS file named <code>reseller-label-style.css</code>.
 +
* Upload it to the following directory: <code>/modules/addons/ResellersCenter/templates/admin/assets/css</code>.
 +
* You can style different types of labels using the following CSS classes:
 +
** <code>reseller-label</code> – General class for all reseller labels.
 +
** <code>reseller-label-reseller-own</code> – Label in the Client Summary when the client is a reseller.
 +
** <code>reseller-label-resellers-client</code> – Label in the Client Summary when the client is a reseller’s client.
 +
** <code>reseller-label-table</code> – Labels displayed within tables.
 +
** <code>resellers-client-service</code> – Labels in the service and domain view of a reseller’s client. <br/ > '''''Important:''' Each class definition in the stylesheet must be prefixed with '''mg-wrapper'''.''
 +
* Below is an '''example ''reseller-label-style.css'' file''' with custom styles: 
 +
 
 +
.mg-wrapper.reseller-label {
 +
    color: #4442a9;
 +
    background-color: #dedef2;
 +
    border-color: #ccd1eb;
 +
}
 +
 +
.mg-wrapper.reseller-label.reseller-label-reseller-own {
 +
    color: #44a942;
 +
    background-color: #def2de;
 +
    border-color: #ccebd1;
 +
}
 +
 +
.mg-wrapper.reseller-label.reseller-label-resellers-client {
 +
    color: #3279c9;
 +
    background-color: #def2ee;
 +
    border-color: #cce0eb;
 +
}
 +
 +
.mg-wrapper.reseller-label.reseller-label-table {
 +
    color: #9232c9;
 +
    background-color: #e7def2;
 +
    border-color: #c6abe7;
 +
}
 +
 +
.mg-wrapper.reseller-label.resellers-client-service {
 +
    color: #c0772c;
 +
    background-color: #d9b899;
 +
    border-color: #bb7f51;
 +
}
  
Find the below-listed files:
 
* '' 'upgradesummary.tpl' '' and rename it to '''upgradesummary_old.tpl''' ''(or delete it)''
 
* '' 'upgradesummary_rename.tpl' '' and rename it to '''upgradesummary.tpl'''
 
From now on, the end-client will see a notification if they have insufficient credit limit to proceed with the order ''(related to deferred payments only)''. <br/>
 
The "Start New Billing Period" feature will be always available regardless of the "Consolidated Invoices" feature status.
 
 
|}
 
|}
-->
+
{|
 +
|style="padding: 0px 0px 30px 25px;"|[[File:R3_11_12.png]]
 +
|}
  
 
=Update Instructions=
 
=Update Instructions=
Line 1,621: Line 1,847:
 
==External API Configuration==
 
==External API Configuration==
 
{|
 
{|
|style="padding: 10px 0px 15px 15px;"|From the 3.9.0 version of Resellers Center For WHMCS, the module uses '''External API''' instead of '''Local API'''. <br/> To begin with the configuration, please navigate to '' 'Configuration → WHMCS API Connection Settings' ''. Now, click on the link as presented below.
+
|style="padding: 10px 0px 15px 15px;"|The '''Resellers Center For WHMCS''' module utilizes '''External API,''' follow the instructions below to learn how to configure and use the API correctly. <br/> To start the configuration process, go to '' 'Configuration → WHMCS API Connection Settings'.'' Next, click on the link as presented below.
 
|}
 
|}
 
{|
 
{|
Line 1,633: Line 1,859:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 15px;"|Enter your '' 'Role Name' '' and decide which API actions will be allowed. Do not forget to save the changes. <br/>
+
|style="padding: 0px 0px 15px 15px;"|Enter your '' 'Role Name' '' and decide which API actions will be allowed. Do not forget to save the changes. <br/>
 
The API requires a minimum set of permissions, which include:   
 
The API requires a minimum set of permissions, which include:   
 
*Orders: ''AcceptOrder''
 
*Orders: ''AcceptOrder''
Line 1,656: Line 1,882:
 
|}
 
|}
 
{|
 
{|
|style="padding: 0px 0px 20px 15px;"|You will find your new '' 'Identifier' '' as well as '' 'Secret' ''. Copy them and paste to a safe place because you will not see them again.  
+
|style="padding: 0px 0px 20px 15px;"|You will find your new '' 'Identifier' '' as well as '' 'Secret' ''. Copy and paste them to a safe place because you will not see them again.  
 
|}
 
|}
 
{|
 
{|
Line 1,716: Line 1,942:
 
* If you experience difficulties with displaying the available billing cycles selection on the review & checkout page, consider either changing the template in use or adjusting the Lagom Theme settings.<br/> To address this, enable the  '' '[https://lagom.rsstudio.net/docs/page-templates/#hide-product-billing-cycle-dropdown Hide product billing cycle dropdown]' '' option. This will utilize the standard WHMCS form, eliminating the need to change your template.  
 
* If you experience difficulties with displaying the available billing cycles selection on the review & checkout page, consider either changing the template in use or adjusting the Lagom Theme settings.<br/> To address this, enable the  '' '[https://lagom.rsstudio.net/docs/page-templates/#hide-product-billing-cycle-dropdown Hide product billing cycle dropdown]' '' option. This will utilize the standard WHMCS form, eliminating the need to change your template.  
 
* Note that unexpected issues may arise when using both the Lagom Client Theme and the Stripe payment gateway. In such cases, it is advisable to switch to another supported template.
 
* Note that unexpected issues may arise when using both the Lagom Client Theme and the Stripe payment gateway. In such cases, it is advisable to switch to another supported template.
 +
* Invoices may not display in the reseller’s store or client area when using the Lagom theme with '''Reseller Invoice''' and '''Invoice Branding''' enabled.<br/> To fix it in Lagom, disable the [https://lagom.rsstudio.net/docs/settings/#enable-dynamic-ajax-loading-for-data-tables Dynamic Ajax Loading for Data Tables] option in the theme settings.<br/> The issue does not occur with the '''Twenty-One''' theme.
 
|}
 
|}
 
{|
 
{|

Latest revision as of 12:29, 24 June 2025

Are you going to upgrade your WHMCS to version 8.9? Be sure to review our tips in "Update Instructions" to prevent any potential issues!
We are sorry for the inconvenience caused.

Contents

[edit] About Resellers Center For WHMCS

Resellers Center For WHMCS empowers your resellers with tools to control end clients and their orders through single WHMCS!

Thanks to Resellers Center For WHMCS, your resellers will be allowed to collect dedicated customers and select specific products, services, and domains for them.
Moreover, the module enables end clients to perform convenient orders of services straight from your WHMCS.
What is more, they will be able to log in to their own WHMCS account with regard to handling their services, formulating tickets and paying invoices.

  • Provider Features:
✔ Define Global Configuration And Reseller Permissions
✔ Manage Assignment Of Clients And Services To Resellers
✔ Create And Manage Pricing Groups
✔ Assign Clients to Pricing Groups To Set Them As Resellers
✔ Assign Products, Addons And Domains To Pricing Groups
✔ Enable Consolidated Invoices Per Reseller Or Pricing Group
✔ Define Pricing Range Per Products, Addons And Domains For Each Billing Cycle
✔ Select Payouts Calculation Method Per Products, Addons, Domains And Configurable Options:
✔ Fixed Rate
✔ Difference
✔ Percent Rate
✔ Percent From Difference Between Admin And Reseller Price
✔ Admin Percent With Fixed Rate
✔ Admin Percent Plus Reseller Margin
✔ Reseller Percent With Fixed Rate
✔ Write Own Class To Calculate Reseller Profit
✔ View Statistics On Resellers Sales, Income And End Clients
✔ View Reseller Profits
✔ Enable Reseller Own CNAME Domain Support
✔ Select Available Store And Order Templates
✔ Choose Email Templates Available For Branding
✔ Choose Payment Gateways Available For End Clients
✔ Choose Ticket Departments Available For End Clients
✔ Choose Whether To Show Products Marked As "Hidden" To End Clients
✔ Choose Whether To Allow Resellers To Delete End Clients
✔ Determine Invoicing Method For Billing End Clients:
✔ Provider As Issuer Of Invoices
✔ Reseller As Issuer Of Invoices
✔ Allow Invoice Branding
✔ Enable Reseller Invoice
✔ Enable Credit Memo Invoicing
✔ Define Default Sequential Invoice Number Format
✔ Remove Invoices With Zero Amounts
✔ Allow Resellers To Receive Commissions From Configurable Options
✔ Allow Resellers To Use Deferred Payments Within Defined Limits
✔ Allow Resellers To Access And Define Their Own Promotions
✔ Allow Resellers To Alter Their Email Templates CSS Styling, Header And Footer
✔ Allow Resellers To Use Their Own SMTP Email Settings
✔ Allow Resellers To Change Date Format
✔ Allow Resellers To Suspend End Client Services
✔ Allow Resellers To Use Global Search Functionality
✔ Prevent Resellers From Logging In As Their End Clients
✔ Prevent Resellers From Viewing End Client Details
✔ Prevent Resellers From Placing Orders On Behalf Of End Clients
✔ Choose Whether To Send Default WHMCS Email If Reseller Template Is Disabled
✔ Make Payouts To PayPal Account Or Credit Balance
✔ Enable Automatic PayPal Payout Transfers
✔ Prepare Documentation For Each Reseller
✔ Disable Access To Knowledgebase For End Clients Of Certain Reseller
✔ Disable Access To Main Store For End Clients Of All Or Certain Resellers
✔ Hide Services Ordered Through Reseller Store In Admin Store View
✔ Hide Single Sign-on Buttons From Reseller Store
✔ Redirect All Email Received By End Clients To Their Resellers
✔ Set Up API Token And Connection Settings
✔ Access Module Logs
✔ Export Resellers Data To CSV File:
✔ Customer Details
✔ Products
✔ Product Addons
✔ Domains
✔ Invoices
✔ Credit Memos
✔ Resellers And WHMCS Invoices
✔ Resellers And WHMCS Transactions
✔ View Resellers Affiliations On WHMCS:
✔ Client List
✔ Product, Product Addon And Domain List
✔ Specific Service And Domain View
✔ Administrator Email Messages
  • Resellers Features:
✔ View, Search And Manage:
✔ End Clients
✔ Orders
✔ Billing:
✔ Invoices
✔ Credit Memos
✔ Products
✔ Addons
✔ Domains
✔ Tickets
✔ Configure Reseller Brand:
✔ Domain
✔ Company Name
✔ Store And Invoice Logo
✔ Store And Order Template
✔ Store Email Address
✔ Terms Of Service URL
✔ Sequential Invoice Number Format
✔ Next Sequential Number
✔ Invoice Pay To Text
✔ Invoice Footer Message
✔ Auto WHMCS Invoice Payment
✔ Tickets Email Signature
✔ Available Ticket Departments
✔ Set Up Independent Payment Gateways Available For End Clients:
✔ 2Checkout
✔ Authorize.Net AIM
✔ Bank Transfer
✔ Billplz
✔ Checkout.com
✔ Deferred Payments
✔ PayPal
✔ Payflow Pro
✔ Stripe
✔ Stripe SEPA
✔ WePay
✔ Restrict Payment Gateway Availability To Specified Countries
✔ Enable Consolidated Invoices Created On Specified Day Of Month
✔ Define Default Credit Line Limit
✔ Define Order Of Payment Gateways
✔ Define Prices Of Products, Addons And Domains Within Defined Limits
✔ Generate Direct URLs To Products And Product Groups
✔ Define Individual Promotions For End Clients
✔ Define Limits Of Deferred Payments For End Clients
✔ Add And Manage End Clients
✔ View And Manage End Clients Orders, Invoices, Products, Addons And Domains
✔ Create Custom Invoice Drafts And Issue Them To End Clients
✔ Place Orders For End Clients Manually
✔ Manually Accept Order Of End Client Before Payment Receipt
✔ Login As End Client
✔ View Statistics On Sales, Income And End Clients
✔ View Generated Profits
✔ Access Documentation
✔ Receive Payouts To PayPal Account Or Credit Balance
✔ Receive Email Notifications On End Client Orders
✔ Reply To Tickets Submitted By End Clients
✔ View Email Templates And Use Editor To Modify Their Content
✔ Modify Email Templates CSS Styling, Header And Footer
✔ Access Store By CNAME Domain Or Default Store URL
✔ Export End Clients Data To CSV File And Via API:
✔ Customer Details
✔ Products
✔ Product Addons
✔ Domains
✔ Invoices
✔ Credit Memos
✔ Transactions
  • End Clients Features:
✔ Order Products, Addons And Domains
✔ Use End Client Details For Registered Domains
✔ View And Pay Invoices With Instant Or Deferred Payments
✔ Pay Using Credit Card And Store Payment Data
✔ Apply Credits To Invoices
✔ Apply Resellers Promo Codes To Orders
✔ View And Manage Products
✔ Receive Branded Email Notifications
✔ Submit Tickets To Reseller
  • General Info:
✔ Migration Tool
✔ Fully Integrated With Lagom WHMCS Client Theme
✔ Multi-Language Support
✔ Supports PHP 8.3 Back To PHP 8.1
✔ Supports WHMCS Themes "Six" And "Twenty-One"
✔ Supports WHMCS V8.13 Back To WHMCS V8.10
✔ Requires ionCube Loader V14 Or Later
✔ Easy Module Upgrade To Open Source Version

[edit] Installation

Installation of Resellers Center For WHMCS requires a few simple modifications of the template files.

No worries, we will guide you step by step through the entire installation process.

Note: If you still use any of Resellers Center For WHMCS previous versions prior to v3.x, read about it here.

Important: If you are updating Resellers Center For WHMCS from the 3.8.0 version (or prior to 3.8.0) to the 3.9.0 version and later, you need to reconfigure your API settings.
Please refer here for the detailed instruction.

[edit] Installation

1. Log in to our client area and download the module.
R3 1 new.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.4 and later.
Note: You can check the current PHP version in your WHMCS. To do so, proceed to 'Utilities' → 'System' → 'PHP Info'.

PHP74 81.png
3. Extract the package and upload its content into the main WHMCS directory.

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

R3 2 1.png
4. When you install Resellers Center For WHMCS for the first time you have to rename the 'license_RENAME.php' file.

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

R 3.png
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'.

R 4.png
6. The next step is setting up the 'storage' and 'config' folders as recursively writable.

They are located in: 'your_whmcs/modules/addons/ResellersCenter/'.

R 5.png

[edit] Activation of Addon

7. Now, you have to activate the module in your WHMCS system.

Log in to your WHMCS admin area. Click 'System Settings' then choose 'Addon Modules'.
Afterward, find 'Resellers Center' and press the 'Activate' button.

R3 6 new.png
8. In the next step, you need to permit access to the module.

To do so, select the admin roles which should have access to the module.
You might as well enable hooks to ensure that all the module's functions work as intended (recommended).
Optionally, choose whether you want to allow your reseller's end-clients to perform orders in your main store or to make them purchase products only through the reseller's store.
Finally, decide whether the services ordered by clients via the reseller's store should be shown or hidden when a client logs in to the administrator's main store instead of to the branded reseller's store.

Press 'Save Changes' when ready.

R3 7 new.png
9. Afterward, go to 'Addons' 'Resellers Center' 'Integration Code' and follow the instructions.

Note: Please keep in mind that WHMCS versions prior to V8.4 are no longer officially supported by the module.

R3 10.png

[edit] Activation of Payment Gateway

10. Now, proceed to 'Apps & Integrations' and find the 'Deferred Payments' gateway and activate it.

Note that this payment gateway is required if you are going to use any of the following module features:

  • Deferred Payments
  • Consolidated Invoices
R3 10 0.png
11. You will be redirected to the payment gateways management page. Find 'Deferred Payments' on the list to configure it.

Select the 'Show on Order Form' option, add your custom display name, or leave the default one. Remember to save the changes when ready.
The gateway will be available to choose as a payment method for end clients and resellers depending on the configuration in the Resellers Center addon.

R3 10 1.png
12. Congratulations, you have just successfully installed Resellers Center For WHMCS!

You can now access your module from 'Addons' → 'Resellers Center '.

[edit] Management and Configuration

Management of Resellers Center For WHMCS is very convenient. You can supervise everything from the addon.

What is more, the module extends the possibilities of both your resellers and their customers.
Let us find out what our product can do!

[edit] Settings

In this section you can find more information about a global configuration.

Additionally, here you can also read about the details of migration.

[edit] Global Configuration

In the 'Configuration' tab you can set up the global settings of the module. You can define 'General', 'Billing' and 'Email Templates' settings.

Please note that these settings are the default for all resellers. Read this section through to find the details of configuration per each reseller.

[edit] General Settings

  • Store Branding - Allows resellers to set up a custom logo, company name, and domain.
  • Allow Products - If enabled, resellers will be able to sell properly configured products in their own stores.
  • Allow Domains - Gives resellers the possibility to sell domains in their own stores.
  • Allow CNAME - It enables the support for CNAME record pointing from the customer's domain. A new field named 'Domain' should appear in the 'Configuration' section of the 'Reseller Area'
  • Log In As Client - If this option is enabled, the resellers can log in as the client.
  • Place Orders - If this option is enabled, the resellers can place orders on behalf of the client.
  • Suspend Services - If this option is enabled, the resellers can suspend the client's services.
  • Allow Promotions - If enabled, the reseller's end-clients will be able to use promo codes in the reseller's store configured by the resellers in the 'Promotions' section.
  • Show Hidden - If enabled, the hidden products and groups will be visible to resellers' clients.
    Thanks to that functionality, there is a chance to configure special products destined for resellers exclusively. These will not be accessible in the main Administrator's store.
  • Hide Delete Client Option - If enabled, the reseller will not be allowed to delete a client from the reseller area.
  • Configurable Options Commissions - If enabled, resellers will receive commissions from configurable options. This feature can be used with the following 'Calculation Methods' :
    • Percent Rate,
    • Administrator Percent With Fixed Rate,
    • Reseller Percent With Fixed Rate.
      Important: 'Configurable Options Commissions' feature is not available if the 'Reseller Invoice' option is enabled in 'Billing Settings'.
  • Redirect Emails - If enabled, all emails received by the client will be also sent to the reseller.
  • Change Mail Settings - If enabled, the reseller can set custom email settings.
  • Change Date Format - If enabled, the reseller can set a custom date format which will be displayed on their clients' pages.
  • Hide Single Sign-on - If enabled, Single Sign-on featured is hidden in the reseller's store.
  • Global Search - If enabled, the "Search" section will be visible in the Reseller Area.
  • Ticket Departments - Allows you to choose ticket departments available for end clients as they will contact resellers.
  • Templates - Allows you to select client area templates of the reseller store.
  • Order Templates - Allows you to select order templates set for a cart view in the reseller store.
  • API Token - Provide an API Token that will be used to authenticate API calls, use at least 32 characters or leave this field empty.
  • Default Reseller Documentation - Select the default documentation to show for new resellers.
R3 11.png

[edit] Billing Settings

  • PayPal Auto Transfer - Enables automatic transfers to a reseller's account.
  • Invoice Branding - If enabled, resellers can brand the number and basic information on the invoice.
  • Reseller Invoice
    • When the 'Reseller Invoice' option is off:
      When end clients place orders in the reseller store, the invoice will be created by WHMCS with the admin details (provided earlier in 'General Settings' ).
      Once the invoice is paid, the module calculates the profit in accordance with the product configuration in the reseller group.
      The calculated amount goes to 'Payouts' where the admin can transfer it via PayPal or credits to the reseller account.
      Find out more about calculation and pricing methods here.
    • When the 'Reseller Invoice' option is on:
      There are two invoices generated after placing an order in the reseller store. The first invoice is created by the reseller and sent to the client
      while the other one is generated by the admin and delivered to the reseller. The amount invoiced is taken directly from the admin charge for the product (reseller group configuration).
      In this case, calculation methods are not included and the reseller earns on price differences between invoices.
      Moreover, this option also permits resellers to use their own configuration data in payment gateways settings.
      Once they do it, end clients are able to make payments directly to the reseller account and the reseller settles debts with the administrator using prepaid WHMCS credits.

Important: Once the first invoice is generated, the option cannot be changed anymore.
Note: 'Configurable Option Commissions' option is unavailable if the 'Reseller Invoice' option is on.

  • Credit Memo - enables the credit memo system. This will restrict certain invoice options, and generate credit memos to make bookkeeping easier or comply with law restrictions.
  • Deferred Payments - If enabled, your resellers will be allowed to define limits for deferred payments for their clients.
  • Gateways - Allows you to select gateways that resellers can enable in their own stores. This option is only available if 'Reseller Invoice' is disabled.
  • Sequential Invoice Number Format - Required if 'Reseller Invoice' is enabled.
  • Deferred Payments Limit - Set the limit of deferred payments for your resellers. If you leave 0, the feature will be simply disabled and settings taken from the Pricing Group used.
    To use this option the 'Reseller Invoice' option must be enabled.
R3 11 1 new.png

[edit] Email Templates Settings

Here you can enable/disable numerous options that a reseller can customize later on.
These templates are related to emails regarding issues like:
  • General
  • Product
  • Domain
  • Support
  • Invoice
  • Invite
  • User
R3 11 2.png

[edit] Single Reseller Configuration

Global configuration settings, enumerated and explained above, can be also defined for particular resellers. You may alter them for a single reseller, the global settings will be overwritten by these ones.
Go to the 'Resellers' tab and press the marked button to continue.
R3 11 3.png
Here you will find the details related to the chosen reseller. In the 'Configuration' section you can select preferred 'General', 'Billing', 'Miscellaneous' and 'Email Template' settings.
Under the first tab, you will find exactly the same options to configure as in the global settings.
R3 11 4 new.png
The 'Billing Settings' section includes global and some additional configuration details per reseller:
  • Turn Off End Client Invoices - If this option is set to enabled, the end client will not receive the created invoices.
  • Credit Payment - This option, when enabled, gives the reseller's clients the possibility to pay using credits.

There are also features related to the deferred payments and consolidated invoices specific settings:

  • Deferred Payments - Enable to allow resellers to restrict the orders placed by end clients to the total amount defined in the 'Deferred Payments Limit' setting (defined by the reseller per end client).
    Keep in mind that the end client will still be allowed to choose if he wants to make instant payments using:
    • standard methods (gateways, credits, bank transfer, etc.) or
    • postpone the payment ("Deferred Payments" payment gateway) but only if the order amount is lower than the limit
  • Verify Reseller Limit - When activated, this feature enhances order validation by considering both the end-client's and the reseller's deferred payments limit. If the reseller's credit is insufficient, a notice will suggest contacting them.

Services ordered with the deferred payment option enabled will be immediately activated. To be allowed to place further orders with deferred payment, the end client has to first pay all the existing invoices.
In case the consolidated invoices feature is turned on, the client cannot pay the order right after completing it. The consolidated invoices can be paid manually once generated.

  • Deferred Payments Limit - Define the limit for deferred payments for the reseller. If "0" is entered, the feature will be disabled. The logic is the same as in the described above option for end clients.
    ("Reseller Invoice" option must be previously enabled)
  • Consolidated Invoices - ('Reseller Invoice' - enabled) All ordered items will be packed into one bundled invoice generated once a month, these include the invoices created for the resellers with purchased by them items (Reseller-Admin relation).
    When consolidated invoices are used, there is no possibility to make payments for ordered services with traditional payment methods right after completing the order.
    • Enabled
    • Disabled
    • Pricing Group Settings - settings defined in the reseller's pricing group are used.
      All resellers who belong to the same group will have the same settings related to consolidated invoices (Enabled/Disabled).
  • Consolidated Invoices Generation Day - Select a day of the month when consolidated invoices (Admin - Reseller relation) will be generated.
    In case the day of generation is set to a greater one than there are days in the month, the invoice will be generated on the last day of the month.
    If you enter "0", the pricing group settings will be used.
  • End Client Consolidated Invoices: - allow your reseller to use the consolidated invoices feature in their stores.
    The end clients will not be allowed to pay the order instantly after placing the order as the dedicated invoice will not generate. Only one bundled payment is allowed once a consolidated invoice is generated.
    • Enabled
    • Disabled
    • Pricing Group Settings - settings defined in the reseller's pricing group are used, all resellers who belong to the same group will have the same settings related to consolidated invoices.
      The generation date of consolidated invoices between the end client and the reseller is defined in the reseller's area.
  • Remove Zero Invoices - if enabled, invoices with zero amount (total amount on the invoice) will not be published.
    Note that already existing invoices will not be removed, only the ones generated after turning on this option will be checked and deleted if they fulfill the requirement.
  • Disable Consolidated Zero Invoices - if enabled, consolidated invoices with zero amount (total amount on the invoice) will not be published.
    Note that already existing invoices will not be verified, only the ones generated after turning on this option will be checked and if the requirements are met, such invoices will not be generated.
R3 11 6.png
Under the 'Miscellaneous' tab you will find these options available per reseller:
  • Turn Off Login To Main Brand - If this option is enabled, the reseller's clients will not be able to log into the main WHMCS store.
  • Turn Off KnowledgeBase - This option allows you to disable access to the KnowledgeBase for the reseller's clients.
  • Allow Promotions - This option enables the promotions in the reseller's store.
  • Allow Mail Wrappers Change - If this option is enabled your resellers will be able to change a global mail header, footer and CSS for their email messages.
    Important: If enabled, please inform the reseller that the fields are obligatory. If left empty the module will use the WHMCS default settings.
    Exemplary settings can be found in 'WHMCS System Settings' → 'General Settings' → 'Mail'.

  • Hide Delete Client Option - If this option is enabled, the reseller has no access to the Delete Client feature in the Reseller Area.
  • Hide Log In As Client Quick Action - If enabled, the reseller has no access to the 'Client Details' page in the Reseller Area.
  • Hide Client Details Action - If enabled, the reseller has no access to the 'Login As Client' feature in the Reseller Area.
  • Send Default Emails - If enabled and the email template is disabled in the 'Emails Templates' tab, the standard WHMCS email is sent for it. Otherwise, the email is not sent at all.
  • Change Mail Settings - If enabled, the reseller will be allowed to manage the custom e-mail settings.
  • Change Date Format - If enabled, the reseller will be allowed to configure the date format, and display on their clients pages, individually.
  • Hide Single Sign-on - Enable to hide the Single Sign-on featured from the reseller's store.
R3 11 5.png
The last 'Email Templates' section contains the same list of email templates to enable/disable as the global configuration.
R3 11 8.png

[edit] Addon Management

In this section you can find more details about the management possibilities.

We will show you how to set up key options to ease the module's handling processes.

[edit] Pricing Groups

In order to grant any of your clients resellers' rights, you need to configure a group first.

To do so, proceed to the 'Pricing Groups' tab and click the button as shown below.

R3 14.png
A popup window appears. Just fill in a group name and press 'Create'.

At this point, you may also define the group setting related to the consolidated invoices feature.
If any of the related options is enabled here, all resellers and their end clients will have these settings applied, you will not have to set the settings for each of them manually.
To learn more about the consolidated invoices feature please proceed to the Single Reseller Configuration "Billing Settings" section.

R3 14 1.png
As you can see, a new group is visible on the list. It does not have any product configured.

To add a new product press the button as presented below.

R3 15.png
Choose a new product from the 'Add Product To Group' dropdown menu and press 'Save'.
R3 16.png
The product needs to be configured. Then, Resellers Center For WHMCS enables you to:
  • Edit Pricing (1)
  • Edit Calculation Method (2)
  • Delete Product (3)
R3 16 1.png

[edit] Product Pricing

It is possible to set pricing (1) for different billing cycles and currencies.

You can define pricing using the below options:

  • Admin Price - price set for a product (it may be lower than what the reseller sets when this difference will be the basis to calculate a profit)
  • Highest Price - maximum price which can be set for a product
  • Lowest Price - minimum price which can be set for a product

To confirm settings, press 'Save' .

R3 17.png

[edit] Calculation Method

Several methods for the calculation (2) are available. Choose the one you want to use from the dropdown menu.
  • Fixed Rate - profit that your reseller always gets
  • Difference - between reseller's and admin's price
  • Percent Rate - percentage of reseller's price
  • Percent From Difference - a sum of reseller's price percentage and a difference between reseller's and admin's price
  • Admin Percent With Fixed Rate - a sum of admin's price percentage and a fixed rate
  • Admin Percent Plus Reseller Margin - percentage of admin's price summed up with reseller's margin
  • Reseller Percent With Fixed Rate - a sum of reseller's price percentage and a fixed rate

To confirm settings press 'Save' next to the product you have configured.

R3 17 1.png
The procedure is quite similar when it comes to adding addons and domains.

Click the right button to add a new addon.

R3 17 2.png
From the dropdown menu choose the one that will be added to the group.
R3 17 2 1.png
Now, you can set 'Pricing' and 'Calculation Method' or delete this addon.
R3 17 3.png
In order to add a new domain, click the right button, as shown below. You may also add all TLDs from WHMCS, just press the button marked with the blue arrow.
R3 17 4.png
From the dropdown menu choose the one that will be added to the group (in case of adding TLDs one by one).
R3 17 4 1.png
Now, you can set 'Pricing', 'Calculation Method', delete this domain and 'Show Details'.
R3 17 5.png

[edit] Resellers

The 'Resellers' tab displays all clients from your WHMCS system.

You can use it to assign any client to a reseller's group, which will activate them as resellers.
Click the button as shown below to create a new reseller.

R3 19.png
Assign a new reseller to the chosen group.
R3 19 1.png

[edit] Clients

To see resellers' clients go to the 'Resellers' tab and click the button next to a selected reseller.
R3 11 3.png
Here you can obtain more details about your customers and their clients.

Apart from clients, you can manage also invoices, transactions, and services.

R3 11 4 1.png
You can also assign a new client to this reseller.
R3 11 4 2.png
Move to 'Services' to obtain more details about the clients' services and add any other products/addons/domains that are not yet assigned to this reseller's store.
R3 11 7.png
In your WHMCS admin area, you may now quickly check if a client, product/service, domain or addon is assigned to a reseller, and to which one exactly (either a company name or first/last name is visible),
without the need of opening the Resellers Center addon.
R3 11 9.png
R3 11 10.png
R3 11 11.png
A reseller label is also displayed on the client, product/service, domain, or addon page. Refer to the Tips section, Tip 9 to learn how to customize the labels.
R3 11 12.png

[edit] Payouts

In the 'Payouts' tab, you can view the list of all resellers' transactions and make profit payouts to them. Moreover, you can accept 'Mass Payments' for selected resellers here.

Please note - this tab is only used if the 'Reseller Invoice' configuration is set to 'Disabled'.
Otherwise, the resellers settle debts with the administrator using prepaid WHMCS credits and payments made by end clients are credited to the reseller's account directly.

R3 41 2.png

In the 'Payouts' section, apart from looking at the details, it is also possible to perform the following actions: pay by PayPal (1) or WHMCS Credits (2) and mark the transaction as completed (3).
The 'Mass Payments' section enables you to make mass payouts to all selected resellers at once. You can choose from PayPal Payment (4), WHMCS Credits Payment (5) and set up proper
PayPal Configuration by providing PayPal Application Key and Secret - both found within your PayPal account.

R3 42.png

[edit] Statistics

The 'Statistics' tab allows you to see the amount of sales and income, and the number of clients assigned to resellers.
R3 18 1.png
Information about sale is also visible in the 'Reseller' tab.
R3 18.png

[edit] Logs

The 'Logs' tab allows you to see the details of the actions that have been already performed.

In case you need more detailed logs related to the consolidated invoices generation process, please move to the Tips section tip number 5 for detailed instructions.

R3 43.png

[edit] Deferred Payments Logs

A dedicated section is available to list actions related to deferred payments. Check the list of events:
R3 43 0.png

[edit] Integration Code

In the 'Integration Code' tab you will find the instructions on how to allow your resellers to modify the client area and invoice logo.

Note: Please keep in mind that WHMCS versions prior to V7.6 are no longer officially supported by the module.

R3 44.png

[edit] Reseller Documentation

The 'Reseller Documentation' tab enables you to create and modify the documentation visible to specified resellers. The documentation provides guidelines to help resellers handle their panels with ease.
You can create the documentation in multiple versions - to add a new one, simply click the '+' button. Press the appropriate button located in the 'Actions' column to manage already formed documentation:

R3 44 2.png

Choose the resellers to whom the documentation will be visible, and enter the name of the documentation and its content.
You can use HTML tags as well as attach a PDF version of your documentation.
Once ready, click 'Save' to save your documentation.

R3 44 3.png

From now on, our resellers will be encouraged to read the documentation from the welcome page, when they enter the 'Reseller Area' for the first time.
Resellers can hide the welcome page by pressing "Do not show again". Even then, the documentation is accessible from the menu:

R3 44 4.png

[edit] Client Area - Reseller

In the client area, your clients can add new sub-clients and access the 'Reseller Area' .

Access to the 'Reseller Area' is granted only to those clients, to whom reseller's groups are assigned in the Resellers Center For WHMCS module.

R3 25.png

[edit] Reseller Area

In the 'Reseller Area' you can manage clients, define product prices, set up branding, customize email templates, and open tickets.

[edit] Clients

Under this tab, you can see a list of reseller's clients and perform various actions.

It is possible to log in as a client (1), make an order for a client (2), view client's details (3) and delete a client (4).

R3 45.png
To add a new client, press the button as presented below.
R3 45 2.png
Fill in all the necessary details in both 'General' and 'Address' sections.

Remember to save changes.

R3 45 2 1.png
At this point, you may also put a limit on allowed deferred payments for a client.

Clients will be allowed to place orders with the maximum amount defined here.
Payments for these orders are postponed and cannot be made instantly when finalizing the order with standard payment methods.
Leave zero if you want to disable this feature. For more details on this feature, please refer to Single Reseller Configuration"Billing Settings" section of this documentation.

R3 45 2 2.png
When you enter the client's details view (3), you will find here not only his personal details but also information about orders, invoices, services, addons and domains.
R3 45 1.png

[edit] Pricing Configuration

The 'Pricing Configuration' tab enables you to define prices for products, addons and domains you wish to offer to your clients.

Remember, you can define prices only within limits shown as placeholders.
If pricing is not provided, product, addon or domain will not be available for your clients.
You can also get here a direct cart URL to products group that you can share directly with your customers.

R3 29.png
R3 29 0.png

[edit] Configuration

[edit] General Configuration
In the 'Configuration' tab you are allowed to define 'General Settings' such as your own company name, email signature, invoice footer, invoice and store logos used across client's client area, emails, invoices and date format.

Please notice, that the available reseller configuration options may vary depending on the options you selected in the addon configuration and whether the 'Reseller Invoice' option was enabled for the reseller.

Note: Once the configuration of your brand is complete, your reseller will still need to set up a CNAME DNS record if domain is used.
This record will point from the branded domain towards the reseller main domain used by WHMCS.

  • For example: if 'Reseller Invoice' is disabled there will be an option to provide reseller PayPal emails but resellers will not be able to configure available payment gateways on their own:
R3 30 new.png
  • However if 'Reseller Invoice' is enabled there will be an option to configure payment gateways by resellers or enable 'Auto WHMCS Invoice Payments' .
R3 30 0.png
  • Should you decide to enter the URL to your 'Terms of Service' page, an additional field will appear during the ordering process.
R3 30 10.png
[edit] Email Templates
'Email Templates' is a place where you can view and edit email templates sent to your clients.

Provided the option 'Allow Mail Wrappers Change' has been enabled for the reseller, empty fields to edit the CSS Styling, Header and Footer will appear.
Important: If this option is available, you must fill in these three fields correctly or otherwise issues with email formatting are sure to occur.
You may use and alter general WHMCS settings available under: 'WHMCS System Settings' → 'General Settings' → 'Mail'.

To edit an email template, press the 'Edit' button next to the template you wish to alter.

R3 30 1 new.png
Finally, edit the email template to suit your needs and press the 'Save Changes' button.

Note: During this step you can easily add merge fields using dropdown menus visible on the following screen.

R3 30 2.png
[edit] Payment Gateways
This tab is only available if the 'Reseller Invoice' option in the admin area is set to 'Enabled' .

In this section, the reseller can set up their own payment gateway ('PayPal', 'Stripe', 'Stripe SEPA', 'Bank Transfer', '2Checkout, Authorize.Net Aim', 'Checkout.com', 'Payflow Pro', 'Billplz'and 'WePay' gateways are currently available).
Thanks to this, all payments made by end clients are transferred directly to the reseller's PayPal account or bank institution.
Note: While setting up the the webhook endpoint for the Stripe SEPA gateway token, make sure to include the following events:

charge.failed
charge.succeded
checkout.session.async_payment_failed
checkout.session.async_payment_failed
checkout.session.completed
charge.dispute.closed

In the 'Country Limitation' field you can select countries users from which will have access to each gateway.
Leave the field empty to allow the gateway for ever country. This restriction is based on WHMCS settings, not geolocation.

The payment gateway named 'Deferred Payments' is dedicated to the module features "Consolidated Invoices" and "Deferred Payments" features. It is available only if at least one of them is enabled.
The payments between the reseller and the administrator are settled through the reseller's previously supplied credit balance.

R3 30 3.png
[edit] Email Settings
The Email Settings section allows the configuration of your own email mailbox. Enter the SMTP details to send messages.
Remember to test the connection and send testing email messaged to ensure everything works correctly before saving the whole configuration.

Important: Please bear in mind that "gmail" mail provided is not supported for reasons that are currently beyond our control.

R3 32.png
[edit] Billing
Consolidated invoices settings:
  • Enable Consolidated Invoices - enable the option to create one bundled invoice once a month with all ordered by the end client items in your store
  • Consolidated Invoices Generation Day - choose the day of the month when the consolidated invoice will be generated.
    If you set it to, for example, 31, the invoice will be generated on the last day of the month (if that is shorter than 31 days).
  • Default Deferred Payments Limit - this value limits total deferred payments per customer, it will be applied by default in cases where the limit is not specified for a given customer manually.
R3 32 0.png
[edit] Data Export
Export data to CSV files and via API:
  • Customer Details
  • Products
  • Product Addons
  • Domains
  • Invoices
  • Transactions
  • Credit Memos
R3 32 1.png

[edit] Billing

Here is the detailed list of end clients' all invoices together with their status.
  • If the 'Reseller Invoice' option in the admin area is 'Disabled' , the listed invoices are generated between the end client and the site administrator.
  • If the 'Reseller Invoice' option in the admin area is 'Enabled' , the listed invoices are issued between the end client and the reseller directly.
R3 46 new.png
Using the 'Action' button on invoices list resellers can also view and manage the invoice details, similarly to how it is done in the admin area.

Press the marked button to download the invoice in a PDF format.

R3 46 2.png
Add a custom invoice. This option is available only for branded invoices between the reseller and the client.
  • Create - press to create the invoice draft, the invoice will not be available for the end client yet
  • Publish - an invoice is created, it is available for the end client instantly
  • Publish and Send Email - an invoice is created and an additional email is sent to the client
R3 46 3.png

[edit] Orders

This section allows you to view all of the orders with their chosen payment method and status.
R3 31.png
Apart from the general section with all orders listed, you may view a list of ordered products, addons and domains separately.
Use visible filters to search for specific orders only.
R3 31 1.png

[edit] Promotions

In the 'Promotions' section resellers can generate fully customizable promo codes in order to apply a promotion for products, addons or domains of your choice.

Note: You must first enable them in your 'Configuration' section of a specific reseller.
Resellers can use the promo codes created only via the module itself, default WHMCS promotions cannot be applied.

R3 498.png
Click on the symbol, marked on the screen below to create one.
R3 461.png
Now you should see all fields required to properly configure a promotion.
  • Promotion Code - You need to create a new code, your customers will need it to receive a discount.
  • Type - Choose one of the available promotion types.
  • Recurring - Once set, a discount will apply to renewal invoices. If the field's value is set to 0, all future renewals will be discounted.
    Enter a different number to specify the exact sum of cycles the discount will last for.
  • Value - Provide the amount of the discount.
  • Start Date - Optional. In case a date is selected, the promotion will start working after the set date.
  • Expiry Date - Optional. The promotion will stop working at the end of the chosen day.
  • Max Uses - Optional. By proving a number you can define the number of allowed uses.
  • Uses - Current usage of the promo code.
  • Applies To - Select what products/addons/domains are eligible for the promotion.
  • Requires - Choose products/addons/domains that are required for the promotion to be applicable.
  • Billing Cycles / Periods - Decide which billing cycles and periods are required for the promotion to apply.
  • Lifetime - In that scenario, a discount will be preserved even if clients upgrades/downgrades their service in future.
  • Apply Once - In case of ordering multiple qualifying products, a discount will be applied once.
  • New Sign Ups - The promotion can be used by new clients only.
  • Once Per Client - When a client has already an existing active order a second use of the code will not be possible.
  • Existing Client - The promotion can be used only by existing clients with 1 or more active orders.
R3 462.png
By toggling the 'Upgrades / Downgrades' section, you will have a few extra fields to configure.
  • Upgrade Type - Select a suitable type of upgrade the promotion applies to.
  • Discount Type - Choose a type of the upgrade promotion.
  • Discount Value - Enter a rate of the discount.
  • Upgrades Of Configurable Options - Provide an amount of the discount.
  • Notes - Any notes will be visible to you and to administrators exclusively.
R3 463.png

[edit] Ordering

There are two ways to add a product to an end client account, we will show you both of them below.

[edit] Assign Product by Reseller

Your resellers can place orders for their own customers as if the orders were for themselves.
R3 34.png
Both your reseller and the end client will receive an order confirmation email.

Afterward, when an end client logs in to the WHMCS client area, he/she will be able to view and manage previously ordered products.
End clients can also list and pay invoices or create tickets (if these options are checked in the addon module).

R3 35.png

[edit] Access Order From The Client Area

Your reseller's clients can view the order form with the list of products configured by their resellers.

Therefore, your reseller's clients can place orders on their own, using order forms in the client area.

R3 37.png
If 'Deferred Payments' is enabled for end clients, a dedicated payment gateway is available to select.
If the client has not reached the imposed limit, the payment can be postponed in time.
R3 37 0.png

[edit] Tickets Management

If you have not disabled tickets in your addon, your resellers will be able to reply and forward tickets created by their clients.

It is only available for the tickets department set in the Resellers Center For WHMCS configuration.

R3 38.png
On the screen below you can see a list of all the tickets created by a reseller's clients from the client area.
R3 39.png
You can easily reply to them.
R3 39 1.png

[edit] Client Area - End Client

An end client sees a branded client area.

Since version 3.x of the module end clients are treated as regular WHMCS clients.

R3 40.png
Start New Billing Period - end clients when upgrading their services are given the possibility to start a new billing cycle for the upgraded service.
Keep in mind that the price for the upgrade is then recalculated adequately to the remaining, unused period of time.

This option is available if the "Consolidated Invoices" feature is enabled in the Reseller Area.

You may also force this feature to be always available for end-clients by replacing the "upgradesummary.tpl" template with a new one (available since version 3.13.0).

Find the below listed files:

  • 'upgradesummary.tpl' and rename it to upgradesummary_old.tpl (or delete it)
  • 'upgradesummary_rename.tpl' and rename it to upgradesummary.tpl

From now on, the "Start New Billing Period" feature will be always available regardless of the "Consolidated Invoices" feature status.
The end client will see a notification if they have an insufficient credit limit to proceed with the order (related to deferred payments only).

Note: "Start New Billing Period" feature is not available in the admin store, resellers upgrading their services are not permitted to use it.

R3 40 0.png

[edit] General Relations

Relations between Provider, Reseller and Client
Payment system:

In general, Reseller receives a product from the Provider and then provides it further to the End Client.
Since the release of v3.0.0 the payment between the Reseller and Provider will be regulated by WHMCS credits but it can be also regulated manually or automatically to the Reseller's PayPal account.

Invoicing system:
  • If the 'Reseller Invoice' option in the admin area is Disabled, the invoices are generated between the end client and the site administrator.
  • If the 'Reseller Invoice' option in the admin area is Enabled, the invoices are issued between the end client and the reseller directly.
    Note: A separate invoice is created directly between the reseller and the provider in this scenario. That is why recurring payment automation is not supported and the generated invoices must by paid manually

[edit] Branded Domains & Aliases Configuration

In this section you will find guides on how to create branded domains and aliases in popular control panels.
Please keep in mind that there are multiple combinations, that may occur. Take a closer look to find a perfect solution for your case.

[edit] Apache2 / NGINX

If there is no cPanel/DirectAdmin/Plesk panel on your server, then all you need to do is modify the current configuration:
  • for NGINX - add the additional domain name in the server_name line (read more)
  • for Apache - add the additional domain name into the ServerAlias line (read more)

[edit] cPanel / DirectAdmin / Plesk Servers

[edit] Same Server + One Account/Subscription

This configuration of Same server + One Account/Subscription assumes that all domains are added within one account/subscription on a given server.
In this case, simply add an additional domain so that it points to the same directory as the WHMCS main domain points to. If a given panel has 'Aliases' option in its offer, you can also use it.

[edit] Same Server + Multiple Accounts/Subscriptions

Such scenario (Same Server + Multiple Accounts/Subscriptions) is not feasible.
This is due to the way web panels work (separation of users), not the module limitations.

[edit] Separate Server

A separate server - in this situation, the branded domain is added to another DNS server. It might be added to, for example cloudflare, or it is added and used on another server, for example cPanel or DirectAdmin.

Take a look at the exemplary situation. Let's say there are two domains:

  • domain whmcs.com on server 'X'
  • domain brand.com on server 'Z' ('Z' can be a 'cPanel' server or a 'DNS' service)

In order to process it correctly, follow the below steps:

  • add an addon domain or an alias with the brand.com domain to server 'X', so that it points to the main domain, that is whmcs.com in our case
  • add a DNS record to the server 'Z' (note it can be e.g. cPanel or DNS service)
    • add a record 'A' pointing to the server 'X' IP address
    • or add a CNAME record pointing to the main domain, that is whmcs.com' in our case


[edit] SSL Certificate

If reseller-branded domains or your WHMCS main domain use the SSL connection, they should also support selected certificates.

The supported types of certificates:

  • Dedicated SSL Certificate - handled separately for each domain.
  • Wildcard - if all brands and main WHMCS use the same domain.
  • SAN - if your brands and main WHMCS use different domains.

This is the way WHMCS works. It is not the limitation of our module which uses the 'WHMCS System URL' scheme.

[edit] cPanel

Installing the SSL certificate for domains managed from cPanel consists of the following steps:
1. Log in to your cPanel and press 'SSL/TSLS Manager' under the 'Security' section.
2. Click on 'Manage SSL sites' under 'Install and Manage SSL for your site (HTTPS)'.
3. (installing the certificate) Select the domain, paste certificate and the private key, and save settings.
4. (using the already installed certificate) Select it from 'Browse Certificates' , and save settings.
You can also consider enabling the AutoSSL solution, which should automatically installs domain-validated SSL certificates. Go here for more information.

Note: AutoSSL function will rather not work for CNAME entries so you should use virtual hosts (vhosts) instead.

[edit] Use Cases

This section features sample scenarios that illustrate common use cases and provide practical guidance on applying the module's functionalities.

Review these scenarios for real-world examples of how to use the module effectively.

[edit] Introducing Credit Memos

Resellers Center For WHMCS includes an optional credit memo billing system.
This alternative invoice system can make bookkeeping easier, as it restricts invoice editing and introduces credit memos instead.
This way of invoice management is required by law in some countries, but can also be useful for correcting billing errors, in product returns, or providing special discounts.

The 'Reseller Invoice' feature must be enabled for the reseller first.
Note: The screens below show both features enabled in individual reseller's configuration, but can be enabled globally in 'Configuration' → 'Billing' as well.

RCUC 01.png
Now the 'Credit Memos' feature can be enabled.

Note: If the toggle is still grayed out, try refreshing the page.

RCUC 10.png
As you can see the billing documents are now categorized into invoices and credit memos.
RCUC 11.png
After a new invoice is created and delivered to the client, but not yet paid, a button to create the credit memo will appear.

It is the only option that can be performed on a delivered invoice, as all data is set to read-only.

RCUC 12.png
The credit memo generated for the invoice is an exact copy of it but with a negative value.
RCUC 13.png
Both the invoice and the credit memo are cross-labeled with related documents.
RCUC 14.png
As soon as the credit memo is created, both documents are marked as 'Closed'.
RCUC 15.png

[edit] Allocating Payment Gateways

While using Resellers Center For WHMCS with the 'Reseller Invoice' function active, resellers can define which payment gateways are available for their clients based on the clients' country.
See the instructions below to learn how it works.

First, make sure that you are using the 'Reseller Invoice' system, as this feature requires it to function.
Important: Once the first invoice is generated, the option cannot be changed anymore.

RCUC 01.png
In this example, the reseller has set up three payment gateways: Stripe, PayPal, and WePay. 'Country Limitation' is not set up for any of them.
RCUC 0.png
With no restrictions present, all gateways are visible to everyone.
RCUC 1.png
Now, the 'Country Limitation' for Stripe has been changed to include only Afghanistan.

This means clients from other countries will not be able to use Stripe.

RCUC 2.png
As you can see, this account is set to the Czech Republic.

Due to the restriction we have set, the Stripe gateway is not listed.
Other payment gateways are available because there are no restrictions placed on them, or the account matches the country selected.

RCUC 3.png
Next, we will log in as a client from the country we restricted Stripe to.

Since the feature is based on the country in the client's profile, and not geolocation, we will simply change the settings in the 'Reseller Area'.

RCUC 4.png
Once we reach checkout, Stripe is available again.

This is because the country of this client matches the restriction rules we set for the gateway earlier.

RCUC 5.png
'Country Limitation' works for guests as well.

With Stripe still limited to Afghanistan, the client that selects any other country in the billing address will not be able to use it.

RCUC 6.png
However, clients from Afghanistan will be presented with the Stripe option.

Resellers can customize each gateway in this way, ensuring they meet their clients' needs and expectations.

RCUC 7.png

[edit] Tips

1. If your WHMCS is installed in a subdirectory, your resellers using CNAME record must provide their links with it.

For example, reseller.com/main-whmcs-directory instead of reseller.com..
You can change that behavior by adding the below code to .htaccess file:

RewriteEngine on
RewriteCond %{HTTP_HOST} !^main-whmcs-domain.com$ [NC]
RewriteCond %{REQUEST_URI} !^/whmcs-directory/
RewriteRule ^(.*)$ /whmcs-directory/$1 [R=301,L]

Result: If hostname is not main-whmcs-domain.com and path is not whmcs-directory', then redirect to resellers domain with /whmcs-directory.

2. When it comes to our Resellers Center For WHMCS and Social Media Login For WHMCS modules, they are compatible and work faultlessly unless your reseller uses a branded domain.
3. If you enable the 'Reseller Invoice' option and any invoice is created in the meantime, you will no longer be able to disable this option.
4. If you would like to use Google reCAPTCHA for brand storefronts, you need to add the domain addresses of those brands to the reCAPTCHA configuration.
To do so, please proceed here.
MB2 41 1.png
5. Consolidated invoices logging system - the module offers the possibility to extend the log entries related to consolidated invoices creation.

If you need additional information to be logged after every cron execution and generating a consolidated invoice, please:

  • find and open file 'config.json' located at: modules/addons/ResellersCenter/config/config.json
  • in the section "consolidated" change the "debug" parameter from false to true

Note: Please bear in mind that this option is not suggested for the production environment as it might significantly slow down the process of generating consolidated invoices and increase the number of logs.

MB2 41 2.png
MB2 41 3.png
6. Hiding gateways for resellers - you may permanently hide single payment gateways for all resellers regardless of their billing settings.

To do so:

  • find and edit file 'config.json' located at: modules/addons/ResellersCenter/config/config.json;
  • include the names of the gateways you would like to remove from your reseller under the "bannedGateways": [ part (see the screen below).

As a result, in the Reseller Area configuration, the reseller will not see these payment gateways, meaning there will be no way to enable them or modify their settings.

RC3 Tip 1.png
7. For Stripe SEPA payment gateway the functions 'Revert on Dispute Loss' and 'Failed Transaction Fee' can be used together to achieve different behaviors, here are to possible combinations:
  • a) Revert on Dispute Loss enabled, Failed Transaction Fee enabled:
    The invoice to which the dispute relates returns to the Unpaid status, a negative transaction is added, and another invoice is created (reject invoice) with the amount specified in the settings.
  • b) Revert on Dispute Loss enabled, Failed Transaction Fee disabled:
    The invoice concerned by the dispute returns to the Unpaid status, a negative transaction is added, but a penalty invoice is not created.
  • c) Revert on Dispute Loss disabled, Failed Transaction Fee enabled:
    The invoice to which the dispute relates still has the Paid status, only a negative transaction is added to it, but a penalty invoice is created for it.
  • d) Revert on Dispute Loss disabled, Failed Transaction Fee disabled:
    The only thing that happens is that a negative transaction is added to the invoice.
8. Customize the Reseller Area button design:
  • Navigate to the configuration file: '/your_whmcs/modules/addons/ResellersCenter/config/customs' and open the 'resellerAreaButton.json' file.
  • Edit Button Properties
    • Icon: Add an icon to your button, e.g.: "icon" : "fa fa-suitcase"
    • Label: Overwrite the language file text, e.g.: "rawLabel": "your_custom_label"
    • Destination: Change the destination URL, e.g.: "uri": "index.php?m=ResellersCenter"
    • Order: Move the button inside the menu, e.g.: "order": "1"
  • Class Properties
    • Modify the class properties (note that functionality is limited), e.g.: "class": "bg-warning mg-class-place-holder"
  • Language File Text:
    • To have the button text change with the language used, edit the $_LANG['addonCA']['resellerarea'] variable in the language files located under '\your_whmcs\modules\addons\ResellersCenter\langs'.
      You can learn more about language files here.
9. Customize the Reseller Label design:

You can define custom styles for reseller labels by creating a dedicated CSS stylesheet. Follow these steps to apply your own styles:

  • Create a CSS file named reseller-label-style.css.
  • Upload it to the following directory: /modules/addons/ResellersCenter/templates/admin/assets/css.
  • You can style different types of labels using the following CSS classes:
    • reseller-label – General class for all reseller labels.
    • reseller-label-reseller-own – Label in the Client Summary when the client is a reseller.
    • reseller-label-resellers-client – Label in the Client Summary when the client is a reseller’s client.
    • reseller-label-table – Labels displayed within tables.
    • resellers-client-service – Labels in the service and domain view of a reseller’s client.
      Important: Each class definition in the stylesheet must be prefixed with mg-wrapper.
  • Below is an example reseller-label-style.css file with custom styles:
.mg-wrapper.reseller-label {
   color: #4442a9;
   background-color: #dedef2;
   border-color: #ccd1eb;
}

.mg-wrapper.reseller-label.reseller-label-reseller-own {
   color: #44a942;
   background-color: #def2de;
   border-color: #ccebd1;
}

.mg-wrapper.reseller-label.reseller-label-resellers-client {
   color: #3279c9;
   background-color: #def2ee;
   border-color: #cce0eb;
}

.mg-wrapper.reseller-label.reseller-label-table {
   color: #9232c9;
   background-color: #e7def2;
   border-color: #c6abe7;
}

.mg-wrapper.reseller-label.resellers-client-service {
   color: #c0772c;
   background-color: #d9b899;
   border-color: #bb7f51;
}
R3 11 12.png

[edit] Update Instructions

An essential manual through the process of updating the module is offered here.

When you upgrade the module from a version older than 3.5.0 to 3.5.0 or newer, please remember to set writable permissions to the 'config' directory, as described in step 6. of the installation guide.

Before upgrading your WHMCS to version 8.9.0, it is strongly recommended to execute the following command, for instance, via phpMyAdmin:

 ALTER TABLE `ResellersCenter_BrandedInvoices` DROP FOREIGN KEY ResellersCenter_BrandedInvoices_ibfk_1;

[edit] Migration

Migration tool allows you to upgrade Resellers Center For WHMCS module to the latest version.

Note: Version 3.x currently supports migration from version 2.5.x of the module and it will only transfer data on resellers, resellers' clients and resellers' groups.
Therefore, the other settings of the module need to be reconfigured manually.

To perform the migration simply overwrite old files to the latest version of the module and refresh the addon page in the admin area.

[edit] External API Configuration

The Resellers Center For WHMCS module utilizes External API, follow the instructions below to learn how to configure and use the API correctly.
To start the configuration process, go to 'Configuration → WHMCS API Connection Settings'. Next, click on the link as presented below.
R3 40 1.png
Once you are in the 'Manage API Credentials' section, go to 'API Roles' and press 'Create API Role' .
R3 40 2.png
Enter your 'Role Name' and decide which API actions will be allowed. Do not forget to save the changes.

The API requires a minimum set of permissions, which include:

  • Orders: AcceptOrder
  • Addons: UpdateClientAddon
  • Domains: UpdateClientDomain
  • Products: UpdateClientProduct
  • Billing: AddCredit, ApplyCredit, UpdateInvoice
  • Service: ModuleTerminate, ModuleSuspend, ModuleUnsuspend
  • Tickets:AddTicketReply
  • System: SendEmail
  • Client: AddClient, UpdateClient
  • User: UpdateUser, ResetPassword
R3 40 3.png
Next, navigate to the 'API Credentials' section and click the 'Generate New API Credential' button.
Provide a description and choose the previously created API role. Finally, press the Generate button.
R3 40 4.png
You will find your new 'Identifier' as well as 'Secret' . Copy and paste them to a safe place because you will not see them again.
R3 40 5.png
Now, come back to the configuration section of the module. Provide your 'Identifier' and 'Secret' .
You also need to complete 'Base Auth Login' and 'Base Auth Password' if your site uses them.
R3 40 6.png
The final step is to navigate to 'General Settings' of your WHMCS admin area. Find the 'Security' section there and scroll down to the 'API IP Access Restriction' feature.
Enter your IP address here to make sure that the configuration will work properly.
R3 40 7.png

[edit] Upgrade Guide

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

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

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

[edit] Common Problems

1. When you have problems with connection, check whether your SELinux or firewall does not block ports.
2. If you use HTTPS, remember to implement a redirect from HTTP to HTTPS on the reseller's domain.

Otherwise, WHMCS will route visitors to the main WHMCS and not the reseller store. Keep in mind that when WHMCS creates the redirection, the domain is changed as well.

3. We do not recommend using Resellers Center For WHMCS with:
  • Multibrand For WHMCS
  • SMS Center For WHMCS (due to e.g. separate email templates used)
  • Discount Center For WHMCS (due to e.g. not branded invoices)
  • Quotes Automation For WHMCS (due to e.g. not branded emails or invoices)
  • Hosting Quota Notifications For WHMCS (due to e.g. not branded emails)
  • Zendesk For WHMCS and Freshdesk For WHMCS (due to e.g. not branded ticket messages)
  • CRM For WHMCS (due to e.g. not branded emails)
  • Payment Gateway Charges For WHMCS (due to e.g. interference in the invoices by both modules which causes conflicts)

Integration between these modules is hampered due to specific features of each one of them and their individual work flow.
That is: separate email templates used or common hooks that override one another (Multibrand and Discount Center), etc.
We are continually working on eliminating these limitations wherever possible.

  • Domain Orders Extended For WHMCS - the module integration is slightly limited for reseller clients who use the Allow CNAME option.
4. Please remember that Resellers Center For WHMCS is guaranteed to work smoothly with 'Six', 'Twenty-One' And 'Lagom' templates.

If you are using some custom template, please be mindful that the module may not combine well with it out of the box, which may result in unexpected errors.
In this case, you can take advantage of our Template Integration service and have all interface elements carefully harmonized by our team.
You can order Template Integration together with the module as well as, at any time later on, in the client area - in the "Services" section of your product's page.

5. The Lagom Client Theme missing integration:
  • If you experience difficulties with displaying the available billing cycles selection on the review & checkout page, consider either changing the template in use or adjusting the Lagom Theme settings.
    To address this, enable the 'Hide product billing cycle dropdown' option. This will utilize the standard WHMCS form, eliminating the need to change your template.
  • Note that unexpected issues may arise when using both the Lagom Client Theme and the Stripe payment gateway. In such cases, it is advisable to switch to another supported template.
  • Invoices may not display in the reseller’s store or client area when using the Lagom theme with Reseller Invoice and Invoice Branding enabled.
    To fix it in Lagom, disable the Dynamic Ajax Loading for Data Tables option in the theme settings.
    The issue does not occur with the Twenty-One theme.
6. If you are using other language than English in the client area, note that some strings might be still in English, e.g. billing cycles or invoice status.
Note that this issue is not related to our module, but to WHMCS itself and we have no influence on these occurrences.
7. The available in the client area option "Add Funds", which allows adding extra cash reserve to the client balance (see: Client Area → Billing → Add Funds), is not supported by the Resellers Center module.
It is highly advised for the administrators to turn this option off to avoid errors: Admin Area → Genera Settings → Credit → Enable/Disable.
Navigation
WHMCS Modules
WHMCS Module Bundles
WHMCS Widgets
Tools And Applications
Translations
General
FAQ
Community
Resellers Center For WHMCS