Added: WHMCS => WebsitePanel contact sync - When client edits his / her contact
details within WHMCS, their WebsitePanel based hosting packages also get updated as well
This commit is contained in:
parent
aa3a358e46
commit
61ddba8a23
3 changed files with 187 additions and 0 deletions
107
WebsitePanel.WHMCSModule/includes/hooks/websitepanel_sync.php
Normal file
107
WebsitePanel.WHMCSModule/includes/hooks/websitepanel_sync.php
Normal file
|
@ -0,0 +1,107 @@
|
||||||
|
<?php if (!defined('WHMCS')) exit('ACCESS DENIED');
|
||||||
|
// Copyright (c) 2012, Outercurve Foundation.
|
||||||
|
// All rights reserved.
|
||||||
|
//
|
||||||
|
// Redistribution and use in source and binary forms, with or without modification,
|
||||||
|
// are permitted provided that the following conditions are met:
|
||||||
|
//
|
||||||
|
// - Redistributions of source code must retain the above copyright notice, this
|
||||||
|
// list of conditions and the following disclaimer.
|
||||||
|
//
|
||||||
|
// - Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
// this list of conditions and the following disclaimer in the documentation
|
||||||
|
// and/or other materials provided with the distribution.
|
||||||
|
//
|
||||||
|
// - Neither the name of the Outercurve Foundation nor the names of its
|
||||||
|
// contributors may be used to endorse or promote products derived from this
|
||||||
|
// software without specific prior written permission.
|
||||||
|
//
|
||||||
|
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
||||||
|
// ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||||
|
// WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
// DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
|
||||||
|
// ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||||
|
// (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||||
|
// LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
||||||
|
// ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
|
||||||
|
/**
|
||||||
|
* WebsitePanel Sync Hook
|
||||||
|
*
|
||||||
|
* @author Christopher York
|
||||||
|
* @package WebsitePanel Sync Hook
|
||||||
|
* @version v1.0
|
||||||
|
* @link http://www.websitepanel.net/
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* websitepanel_sync_ClientEdit
|
||||||
|
*
|
||||||
|
* @access public
|
||||||
|
* @param array $params
|
||||||
|
*/
|
||||||
|
function websitepanel_sync_ClientEdit($params)
|
||||||
|
{
|
||||||
|
// Sanity check - Check if client has any active WebsitePanel hosting packages
|
||||||
|
$results = full_query("SELECT h.userid AS `userid` FROM `tblhosting` AS h, `tblservers` AS s WHERE h.userid = {$params['userid']} AND h.server = s.id AND s.type = 'websitepanel'");
|
||||||
|
if (mysql_num_rows($results) > 0)
|
||||||
|
{
|
||||||
|
// Include the WebsitePanel ES Class
|
||||||
|
require_once(ROOTDIR . '/modules/servers/websitepanel/websitepanel.class.php');
|
||||||
|
|
||||||
|
// Retrieve the WebsitePanel Addons module settings
|
||||||
|
$modSettings = websitepanel_sync_GetSettings();
|
||||||
|
|
||||||
|
// Create the WebsitePanel object instance
|
||||||
|
$wsp = new WebsitePanel($modSettings['username'], $modSettings['password'], $modSettings['serverhost'], $modSettings['serverport'], (($modSettings['serversecured']) == 'on' ? TRUE : FALSE));
|
||||||
|
|
||||||
|
// Get all WSP users with the old email
|
||||||
|
$items = (array)$wsp->get_users_paged_recursive(1, 'Email', $params['olddata']['email'], 0, 0, '');
|
||||||
|
|
||||||
|
// Load / parse the XML response
|
||||||
|
$xml = simplexml_load_string($items['any']);
|
||||||
|
$rootPath = $xml->NewDataSet;
|
||||||
|
|
||||||
|
// Total number of elements to update
|
||||||
|
$total = $rootPath->Table->Column1;
|
||||||
|
|
||||||
|
// Begin updating WebsitePanel accounts
|
||||||
|
for ($i = 0; $i < $total; $i++)
|
||||||
|
{
|
||||||
|
// Set the current root element and get the users details from WebsitePanel
|
||||||
|
// We cannot use the details provided by the get_users_paged_recursive method as it does not return all the required elements to fully update the user
|
||||||
|
$currentRoot = $rootPath->Table1->$i;
|
||||||
|
$userDetails = (array)$wsp->get_user_by_username($currentRoot->Username);
|
||||||
|
|
||||||
|
// Update the current user
|
||||||
|
$wsp->update_user_details($userDetails['RoleId'], (($userDetails['RoleId'] == 2) ? 'Reseller' : 'User'), $userDetails['StatusId'], $userDetails['Status'], $userDetails['LoginStatusId'], $userDetails['LoginStatus'], $userDetails['FailedLogins'], $userDetails['UserId'], $userDetails['OwnerId'], $userDetails['Created'], $userDetails['Changed'], $userDetails['IsDemo'], $userDetails['IsPeer'], $currentRoot->Comments, $params['lastname'], $userDetails['Username'], $userDetails['Password'], $params['firstname'], $params['email'], $params['phonenumber'], $params['postcode'], '', '', '', '', $params['country'], $params['address1'] . (!empty($params['address2']) ? " {$params['address2']}" : ''), $params['city'], $params['state'], TRUE, $params['companyname'], (($userDetails['RoleId'] == 2) ? TRUE : FALSE));
|
||||||
|
|
||||||
|
// Add log entry to client log
|
||||||
|
logactivity("WebsitePanel Sync - Account {$currentRoot->Username} contact details updated successfully", $params['userid']);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Update Client Contact Details - WebsitePanel */
|
||||||
|
add_hook('ClientEdit', 1, 'websitepanel_sync_ClientEdit');
|
||||||
|
|
||||||
|
/**
|
||||||
|
* websitepanel_addons_GetSettings
|
||||||
|
*
|
||||||
|
* @access public
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
function websitepanel_sync_GetSettings()
|
||||||
|
{
|
||||||
|
$settings = array();
|
||||||
|
|
||||||
|
// Retrieve the settings from the modules configuration table
|
||||||
|
$results = select_query('tbladdonmodules', 'setting,value', array('module' => 'websitepanel_sync'));
|
||||||
|
while (($row = mysql_fetch_array($results)) != false)
|
||||||
|
{
|
||||||
|
$settings[$row['setting']] = $row['value'];
|
||||||
|
}
|
||||||
|
return $settings;
|
||||||
|
}
|
|
@ -0,0 +1,59 @@
|
||||||
|
<?php if (!defined('WHMCS')) exit('ACCESS DENIED');
|
||||||
|
// Copyright (c) 2012, Outercurve Foundation.
|
||||||
|
// All rights reserved.
|
||||||
|
//
|
||||||
|
// Redistribution and use in source and binary forms, with or without modification,
|
||||||
|
// are permitted provided that the following conditions are met:
|
||||||
|
//
|
||||||
|
// - Redistributions of source code must retain the above copyright notice, this
|
||||||
|
// list of conditions and the following disclaimer.
|
||||||
|
//
|
||||||
|
// - Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
// this list of conditions and the following disclaimer in the documentation
|
||||||
|
// and/or other materials provided with the distribution.
|
||||||
|
//
|
||||||
|
// - Neither the name of the Outercurve Foundation nor the names of its
|
||||||
|
// contributors may be used to endorse or promote products derived from this
|
||||||
|
// software without specific prior written permission.
|
||||||
|
//
|
||||||
|
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
||||||
|
// ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||||
|
// WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
// DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
|
||||||
|
// ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||||
|
// (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||||
|
// LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
||||||
|
// ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
|
||||||
|
/**
|
||||||
|
* WebsitePanel Sync Addon Module
|
||||||
|
*
|
||||||
|
* @author Christopher York
|
||||||
|
* @package WebsitePanel Sync Addon Module
|
||||||
|
* @version v1.0
|
||||||
|
* @link http://www.websitepanel.net/
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* websitepanel_sync_config
|
||||||
|
*
|
||||||
|
* @access public
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
function websitepanel_sync_config()
|
||||||
|
{
|
||||||
|
$configarray = array('name' => 'WebsitePanel Sync Automation',
|
||||||
|
'description' => 'Syncs WHMCS client details / contact changes with WebsitePanel',
|
||||||
|
'version' => '1.0',
|
||||||
|
'author' => 'Christopher York',
|
||||||
|
'fields' => array('serverhost' => array('FriendlyName', 'Enterprise Server Host', 'Type' => 'text', 'Size' => 25, 'Description' => 'Enterprise Server hostname / IP address', 'Default' => '127.0.0.1'),
|
||||||
|
'serverport' => array('FriendlyName', 'Enterprise Server Port', 'Type' => 'text', 'Size' => 4, 'Description' => 'Enterprise Server port', 'Default' => 9002),
|
||||||
|
'serversecured' => array('FriendlyName', 'Use Secured Connection', 'Type' => 'yesno', 'Description' => 'Tick to use SSL secured connection'),
|
||||||
|
'username' => array('FriendlyName', 'Username', 'Type' => 'text', 'Size' => 25, 'Description' => 'Enterprise Server username', 'Default' => 'serveradmin'),
|
||||||
|
'password' => array('FriendlyName', 'Password', 'Type' => 'password', 'Size' => 25, 'Description' => 'Enterprise Server password')
|
||||||
|
)
|
||||||
|
);
|
||||||
|
return $configarray;
|
||||||
|
}
|
|
@ -290,6 +290,27 @@ class WebsitePanel
|
||||||
return (array)$this->execute_server_method(WebsitePanel::SERVICEFILE_PACKAGES, 'GetMyPackages', array('userId' => $userid))->GetMyPackagesResult->PackageInfo;
|
return (array)$this->execute_server_method(WebsitePanel::SERVICEFILE_PACKAGES, 'GetMyPackages', array('userId' => $userid))->GetMyPackagesResult->PackageInfo;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param int $userId User id
|
||||||
|
* @param string $filterColumn Column name to filter on
|
||||||
|
* @param string $filterValue Filter value
|
||||||
|
* @param int $statusId Status id
|
||||||
|
* @param int $roleId Role id
|
||||||
|
* @param string $sortColumn Column name to sort on
|
||||||
|
* @param int $startRow Row to start at
|
||||||
|
* @param int $maximumRows Maximum rows to return
|
||||||
|
*/
|
||||||
|
public function get_users_paged_recursive($userId, $filterColumn, $filterValue, $statusId, $roleId, $sortColumn, $startRow = 0, $maximumRows = 999)
|
||||||
|
{
|
||||||
|
$params = array();
|
||||||
|
foreach (get_defined_vars() as $name => $value)
|
||||||
|
{
|
||||||
|
$params[$name] = $value;
|
||||||
|
}
|
||||||
|
return $this->execute_server_method(WebSitePanel::SERVICEFILE_USERS, 'GetUsersPagedRecursive', $params)->GetUsersPagedRecursiveResult;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* WebsitePanel::UpdatePackageLiteral()
|
* WebsitePanel::UpdatePackageLiteral()
|
||||||
*
|
*
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue