Office 365 For WHMCS
About Office 365 For WHMCS
|Office 365 For WHMCS has been designed to let you automatically provision Microsoft Office 365 plans and remotely manage their key features.|
With this module, you will easily supervise all subscriptions, perform switches and suspensions as well as password changes right in your WHMCS.
- Admin Area Features:
|✔ Create/Suspend/Unsuspend Office 365 Subscriptions|
|✔ Choose Standard/Extended Provisioning Type|
|✔ Create/Suspend/Unsuspend Addon Services For Standard Provisioning Type|
|✔ Create Office 365 Customer During First Or Every Order|
|✔ Create Office 365 Client During First Or Every Order|
|✔ Define Number Of Subscriptions Available For Order|
|✔ Change Package|
|✔ Change Password|
- Client Area Features:
|✔ Standard Provisioning Type:|
|✔ Automatically Create Office 365 Customer/User/Subscription|
|✔ Upgrade/Downgrade Office 365 Subscriptions|
|✔ Extended Provisioning Type:|
|✔ Order Chosen Number Of Subscriptions|
|✔ View/Create/Delete Office 365 Users|
|✔ Assign Available Subscriptions To Users|
|✔ View Subscriptions Usage, Status And Commitment End Date|
|✔ Upgrade/Downgrade Number Of Office 365 Subscriptions|
|✔ Change Password|
- Supported Services:
|✔ Office 365 Education/Education E5|
|✔ Office 365 Business/Business Essentials/Business Premium|
|✔ Office 365 ProPlus/Enterprise E1/E3/E5/K1|
|✔ Standalone Services:|
|✔ Business Intelligence Service|
|✔ Exchange Online|
|✔ Information Rights Management|
|✔ Office Applications|
|✔ OneDrive For Business|
|✔ Online Diagram Software|
|✔ Project Portfolio Management|
|✔ SharePoint Online|
|✔ Skype For Business Online|
- General Info:
|✔ Requires Microsoft Partner Network|
|✔ Requires Microsoft Cloud Solution Provider - Tier 1|
|✔ Supports PHP 5.6 Up To PHP 7.2|
|✔ Supports WHMCS Template Six|
|✔ Supports WHMCS V7.2 And Later|
Please be informed that Office 365 For WHMCS 2.0 is not compatible with its 1.0 version due to the changes introduced to the creation process of subscriptions and users.
If the mechanism available in the 1.0 version suits your requirements, do not update your module to the latest version.
|This tutorial will show you how to successfully install and authenticate Office 365 For WHMCS.|
We will guide you step by step through the whole installation and configuration process.
Note: If you are still using Office 365 For WHMCS version 1.0.0, read about it here.
|1. Log in to our client area and download the module.|
|2. In the downloaded file you will find two packages that support different PHP versions.|
As presented on the screen below, the first one is dedicated to PHP 5.6 up to PHP 7.0, while the second one is aimed at PHP 7.1 up to PHP 7.2.
It does not apply to open source versions.
Note: You can check the current PHP version in your WHMCS. To do so, proceed to 'Utilities' › 'System' › 'PHP Info'.
|3. Extract the downloaded file and choose the one with the right PHP version. Upload and extract the PHP file into the main WHMCS directory.|
The content of PHP version files should look like this.
|4. When you install Office 365 For WHMCS for the first time, you have to rename the 'license_RENAME.php' file.|
The file is located in 'modules/servers/office365/license_RENAME.php'. Rename it from 'license_RENAME.php' to 'license.php'.
|5. In order to configure your license key, you have to edit the previously renamed 'license.php' file.|
Enter your license key between quotation marks as presented on the following screen. You can find your license key in our client area → 'My Products'.
|6. Now, set up the 'storage' folder as recursively writable.|
This folder is located in 'your_whmcs/modules/servers/office365'.
Configuration of Server
|7. To begin, you must add a new server.|
Go to 'Setup' → 'Products/Services' → 'Servers' and press 'Add New Server'.
|8. Enter your server name. Choose 'Office365' from the dropdown menu.|
Now, enter your Microsoft Partner username, password, API URL, Native APP ID and Domain (see steps below how to obtain them).
|In order to create full 'API URL' , go to 'Microsoft Partner Center' panel → 'Account Settings' → 'Organization profile' and copy 'Default domain' from the section marked on the screen below.|
Next, put it in 'https://api.YourDefaultDomain/v1/' address and paste to server configuration as your 'API URL' .
|To find your 'Native APP ID' and 'Domain' , go to 'Microsoft Partner Center' panel → 'Account Settings' → 'App Management' and copy 'App ID' and 'Domain' from the 'Native App' section:|
|9. Once your server has been configured correctly, you will see the following screen.|
Create a new group for your server. Press 'Create New Group' to follow.
|10. Enter a name, click on your previously created server, press 'Add' , then 'Save Changes'.|
Configuration of Product
|11. In order to create a product, go to 'Setup' → 'Products/Services' → 'Products/Services' .|
If you do not have a product group, click on 'Create a New Group' . If you do, simply move to the 12th step.
|12. Fill in a product group name and press 'Save Changes'.|
|13. When you have a product group added, you can create your product and assign it to the Office 365 module.|
|14. Afterwards, choose your product type and product group from dropdown menus, enter your product name and press 'Continue' .|
|15. Now, go to the 'Module Settings' section, choose both 'Office365' and the previously created server group from the dropdown menu, and press 'Save Changes' .|
| 16. Then, go to the 'Custom Fields' tab and make sure that it displays the three created 'text box' custom fields.|
These are: userid|User ID, orderid|Order ID and customerid|Customer ID. If they were not automatically created, then add them manually as shown on the following screen.
Configuration and Management
|Configuration and management of Office 365 For WHMCS is very intuitive. |
Before you start, please note that there are two provisioning types you can offer to your clients.
Standard Provisioning Type
|Let's start the module configuration by choosing 'Standard' provisioning type.|
Now, choose 'Country'. that you will offer your Office 365 services from.
Note: Available subscription offers and additional services depend on your Microsoft membership coverage and may be limited by the location.
In order to offer additional services for a standard product plan, you need to create a new addon first.
Important: addons are applicable only to standard provisioning type, not for extended one.
|Enter a name of the addon, choose the addon to be visible during the ordering process and configure the rest of the desired options.|
|Go to the 'Applicable Products' tab and select the product that you want to offer this addon for. Then press 'Save Changes' .|
|Important! Please leave both: 'Module Name' and 'Server Group' set to NONE in the addon module settings.|
Selecting any server or module here will surely end up with an error!
|Go back to your product and connect the created addon with one of the available additional services in the 'Module Settings' tab.|
|Finally, 'Save Changes' . Remember that you can also add more addons for services.|
|Once the product configuration is complete, clients will be able to order the selected subscription and addons.|
Standard provisioning type does not support any additional features in the client area.
Extended Provisioning Type
|Extended provisioning type allows your client to order the chosen number of licenses using configurable options and then manually redistribute them in their client area among the created Office 365 users.|
Enable this configuration type by choosing the 'Extended' provisioning type in the module settings of the product.
Now, choose 'Country' that you will offer your Office 365 services from.
|To allow your clients to purchase multiple licenses at a single order, you must create configurable options for a product .|
Start by going to 'Setup' → 'Products/Services' → 'Configurable Options' and press the 'Create a New Group' button.
|Enter a group name for the addon and select products that you want to offer this option for. Then press the 'Save Changes' option.|
|Now, press 'Add New Configurable Option' and the new popup window should open.|
|Name this configurable option as 'office365licenseQty' with the desired friendly name. Next, chose the 'Option Type' you want to use and add pricing for the desired quantity.|
Note: More information about setting up configurable options can be found here.
|Once the product configuration is complete, clients will be able to order the selected number of subscriptions.|
|After order your clients will be able to manage Office 365 users and subscriptions by themselves.|
The menu also displays information about the current number of used subscriptions.
| Before you start assign subscriptions, you have to create new users.|
By default there is already one Office 365 user created based on the customer account.
|Fill in the required data to create a new user.|
|Then, after successfully creating a new user, you can view their account details.|
|In the user profile you can view account details as well as assigned subscriptions. |
Press the 'Add Subscriptions' button to assign a new license to this account.
|You can assign multiple licenses to one account, provided that the number of used subscriptions is not exceeded already.|
|After successfully adding licenses to user account you will see their number, status and validity in the user's 'Subscriptions' box.|
|The 'Subscriptions' section displays all product licenses that are currently assigned to a user.|
For your convenience, if product settings have been configured to create only one Office 365 customer per WHMCS client, then all other purchased subscription types will also be displayed here.
|If you are using the module, we do not recommend assigning subscription directly from the Microsoft panel.|
However, if such a situation occurrs, the subscription will be fetched to the WHMCS list, but then you will have to assign it to the user manually.
|In the newly opened window select the user to whom the subscription will be assigned and press the 'Assign' button.|
|Let's check your new product in the product page in admin area . After a successful creation, it should look exactly like presented on the screen below.|
Note The admin area for both standard and extended provisioning types looks basically the same.
|The 'Username' and 'Password' are used to sign up to the Office 365 panel.|
The 'User ID' , 'Order ID' , 'Customer ID' and 'Subscription ID' are custom fields used to connect the product with the created subscription in your Microsoft Partner Center.
|Due to API limitations, ordered subscriptions can only be suspended or unsuspended. For this reason, the 'Terminate' command will work in the same way as the 'Suspend' option.|
In case of standard product suspension, all addons that belong to the product will also be suspended. If the product is unsuspended, its addons will remain suspended.
The 'Change Password' option will change the password for all services assigned to the user. To change it into a new one, you need to:
|Note that the password must also meet the following requirements:
|By using upgrade/downgrade feature you can change subscription type for the standard provisioning type.|
However, for the extended provisioning type you can only change the number of assigned licenses by configurable options, not the subscription type itself.
|Information about addons will depend on their status and will be shown in the 'Admin Notes' field. By default, the 'Subscription ID' service should be provided.|
Note that the addon can only be used for the standard provisioning type.
|For example, if the addon is suspended, the information will also appear in this field.|
|1. For more information on how the Microsoft Partner program works, see here.|
|2. API responses can be translated in the module's language file. To do this, add a new record in the file with the received API message and your translation.|
See below to find an exemplary entry:
$_LANG['ApiResponse']['Can\'t contain username paramName: User.Password, paramValue: , objectType: System.String'] = 'Password field cannot contain a username.';
|Essential guidance through the process of updating the module is offered here.|
Keep in mind there is a quick and easy option in our client area that will let you upgrade the license of your module to an open source version at any time - and at a lower price!
| While using the 2.X version of our module, note that no data can be migrated from the Office 365 For WHMCS version 1.0.0, so the module needs to be configured from scratch.|
This also means that previously placed orders for subscriptions will not work on the new version, even after module reconfiguration.
|1. When you have problems with connection, make sure that SELinux or firewall does not block ports.|
|2. The list of users and their subscriptions assigned to the customer directly in the Microsoft panel are not automatically assign to the WHMCS client and their users.|
This is due to the API limitations, so this list is only kept locally on the WHMCS server.
|3. Error encountered in the module:|
Use limit is exceeded for Offer Id
indicates that a single customer may purchase only one license (Office 365 Business, Office 365 Business Essentials, Office 365 Business Premium license etc).