2016-05-11 10:40:44 +02:00
|
|
|
<?php
|
|
|
|
|
2016-08-01 09:53:37 +02:00
|
|
|
require_once(BASE_PATH . 'server/includes/core/class.encryptionstore.php');
|
2016-12-06 06:52:40 +01:00
|
|
|
require_once('zpushprops.php');
|
2016-05-11 10:40:44 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* PluginMDMModule Module
|
|
|
|
*/
|
|
|
|
class PluginMDMModule extends Module
|
|
|
|
{
|
|
|
|
private $server = '';
|
|
|
|
private $username = '';
|
|
|
|
private $password = '';
|
|
|
|
|
2016-12-06 06:52:40 +01:00
|
|
|
// content data
|
|
|
|
const FOLDERUUID = 1;
|
|
|
|
const FOLDERTYPE = 2;
|
|
|
|
const FOLDERBACKENDID = 5;
|
|
|
|
|
2016-05-11 10:40:44 +02:00
|
|
|
/**
|
|
|
|
* Constructor
|
|
|
|
* @param int $id unique id.
|
|
|
|
* @param array $data list of all actions.
|
|
|
|
*/
|
2016-08-01 09:51:29 +02:00
|
|
|
function __construct($id, $data)
|
2016-05-11 10:40:44 +02:00
|
|
|
{
|
2016-08-01 09:51:29 +02:00
|
|
|
parent::__construct($id, $data);
|
2016-05-11 10:40:44 +02:00
|
|
|
|
|
|
|
$this->server = (PLUGIN_MDM_SERVER_SSL ? 'https://' : 'http://') . PLUGIN_MDM_SERVER;
|
|
|
|
|
2016-08-01 09:53:37 +02:00
|
|
|
// Get the username and password from the Encryption store
|
|
|
|
$encryptionStore = EncryptionStore::getInstance();
|
|
|
|
$this->username = $encryptionStore->get('username');
|
|
|
|
$this->password = $encryptionStore->get('password');
|
2016-05-11 10:40:44 +02:00
|
|
|
|
|
|
|
$this->url = $this->server .'/Microsoft-Server-ActiveSync?Cmd=WebserviceDevice&DeviceId=webservice&DeviceType=webservice&User=' . $this->username;
|
|
|
|
}
|
|
|
|
|
2016-12-07 11:48:14 +01:00
|
|
|
/**
|
|
|
|
* Returns the version of the Z-Push server
|
|
|
|
* @return String
|
|
|
|
*/
|
|
|
|
function getServerVersion()
|
|
|
|
{
|
|
|
|
// Make a call to the service, so we can read the version
|
|
|
|
// from the response headers
|
|
|
|
try {
|
|
|
|
$url = $this->server .'/Microsoft-Server-ActiveSync?Cmd=WebserviceInfo&DeviceId=webservice&DeviceType=webservice&User=' . $this->username;
|
|
|
|
$client = $this->getSoapClient($url);
|
|
|
|
return $client->About();
|
|
|
|
} catch(Exception $e){}
|
|
|
|
|
|
|
|
// If we can't find a version, we will simply return not available
|
|
|
|
return dgettext('plugin_mdm', 'n/a');
|
|
|
|
}
|
|
|
|
|
2016-05-11 10:40:44 +02:00
|
|
|
/**
|
|
|
|
* Helper to setup a client.
|
|
|
|
*/
|
2016-12-07 11:48:14 +01:00
|
|
|
function getSoapClient($url='')
|
2016-05-11 10:40:44 +02:00
|
|
|
{
|
2016-12-07 11:48:14 +01:00
|
|
|
if ( empty($url) ){
|
|
|
|
$url = $this->url;
|
|
|
|
}
|
|
|
|
|
2016-05-11 10:40:44 +02:00
|
|
|
return new SoapClient(null, array(
|
2016-12-07 11:48:14 +01:00
|
|
|
'location' => $url,
|
2016-05-11 10:40:44 +02:00
|
|
|
'uri' => $this->server,
|
|
|
|
'trace' => 1,
|
|
|
|
'login' => $this->username,
|
|
|
|
'password' => $this->password
|
|
|
|
));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function which calls the soap call to do a full resync
|
|
|
|
* @param int $deviceid of phone which has to be resynced
|
|
|
|
* @return json $response object contains the response of the soap request from Z-Push
|
|
|
|
*/
|
|
|
|
function resyncDevice($deviceid)
|
|
|
|
{
|
|
|
|
$client = $this->getSoapClient();
|
|
|
|
return $client->ResyncDevice($deviceid);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function which calls the wipeDevice soap call
|
|
|
|
* @param int $deviceid of phone which has to be wiped
|
|
|
|
* @param string $password user password
|
|
|
|
* @return json $response object contains the response of the soap request from Z-Push
|
|
|
|
*/
|
|
|
|
function wipeDevice($deviceid, $password)
|
|
|
|
{
|
|
|
|
if ($password == $this->password) {
|
|
|
|
$client = $this->getSoapClient();
|
|
|
|
return $client->WipeDevice($deviceid);
|
|
|
|
} else {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* function which calls the ListDeviceDetails soap call
|
|
|
|
* @return array $response array contains a list of devices connected to the users account
|
|
|
|
*/
|
|
|
|
function getDevices()
|
2016-12-07 11:48:14 +01:00
|
|
|
{
|
2016-05-11 10:40:44 +02:00
|
|
|
$client = $this->getSoapClient();
|
|
|
|
return $client->ListDevicesDetails();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
function which calls the wipeDevice soap call
|
|
|
|
* @param int $deviceid of phone which has to be wiped
|
|
|
|
* @return json $response object contains the response of the soap request from Z-Push
|
|
|
|
*/
|
|
|
|
function removeDevice($deviceid)
|
|
|
|
{
|
|
|
|
$client = $this->getSoapClient();
|
|
|
|
return $client->RemoveDevice($deviceid);
|
|
|
|
}
|
2016-12-07 11:48:14 +01:00
|
|
|
|
2016-05-11 10:40:44 +02:00
|
|
|
/**
|
|
|
|
* Executes all the actions in the $data variable.
|
|
|
|
* @return boolean true on success of false on fialure.
|
|
|
|
*/
|
|
|
|
function execute()
|
|
|
|
{
|
|
|
|
foreach($this->data as $actionType => $actionData)
|
|
|
|
{
|
|
|
|
if(isset($actionType)) {
|
|
|
|
try {
|
|
|
|
switch($actionType)
|
|
|
|
{
|
|
|
|
case 'wipe':
|
|
|
|
$this->wipeDevice($actionData['deviceid'], $actionData['password']);
|
|
|
|
$this->addActionData('wipe', array(
|
2016-12-07 11:48:14 +01:00
|
|
|
'type' => 3,
|
2016-05-11 10:40:44 +02:00
|
|
|
'wipe' => $this->wipeDevice($actionData['deviceid'], $actionData['password'])
|
|
|
|
));
|
|
|
|
$GLOBALS['bus']->addData($this->getResponseData());
|
|
|
|
break;
|
|
|
|
case 'resync':
|
|
|
|
$this->addActionData('resync', array(
|
2016-12-07 11:48:14 +01:00
|
|
|
'type' => 3,
|
2016-05-11 10:40:44 +02:00
|
|
|
'resync' => $this->resyncDevice($actionData['deviceid'])
|
|
|
|
));
|
|
|
|
$GLOBALS['bus']->addData($this->getResponseData());
|
|
|
|
break;
|
|
|
|
case 'remove':
|
|
|
|
$this->addActionData('remove', array(
|
2016-12-07 11:48:14 +01:00
|
|
|
'type' => 3,
|
2016-05-11 10:40:44 +02:00
|
|
|
'remove' => $this->removeDevice($actionData['deviceid'])
|
|
|
|
));
|
|
|
|
$GLOBALS['bus']->addData($this->getResponseData());
|
|
|
|
break;
|
|
|
|
case 'list':
|
|
|
|
$items = array();
|
|
|
|
$date['page'] = array();
|
|
|
|
|
|
|
|
$rawData = $this->getDevices();
|
|
|
|
foreach($rawData as $device){
|
2016-12-06 06:52:40 +01:00
|
|
|
array_push($items, array('props' => $this->getDeviceProps($device->data)));
|
2016-05-11 10:40:44 +02:00
|
|
|
}
|
|
|
|
$data['page']['start'] = 0;
|
|
|
|
$data['page']['rowcount'] = count($rawData);
|
|
|
|
$data['page']['totalrowcount'] = $data['page']['rowcount'];
|
|
|
|
$data = array_merge($data, array('item' => $items));
|
|
|
|
|
|
|
|
$this->addActionData('list', $data);
|
|
|
|
$GLOBALS['bus']->addData($this->getResponseData());
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
$this->handleUnknownActionType($actionType);
|
|
|
|
}
|
|
|
|
} catch (SoapFault $fault) {
|
2016-08-11 11:08:54 +02:00
|
|
|
$display_message = dgettext('plugin_mdm', 'Something went wrong.');
|
2016-05-11 10:40:44 +02:00
|
|
|
if ($fault->faultcode === 'HTTP') {
|
|
|
|
if ($fault->getMessage() === "Unauthorized") {
|
2016-08-11 11:08:54 +02:00
|
|
|
$display_message = dgettext('plugin_mdm', 'Unable to connect to Z-Push Server. Unauthorized.');
|
2016-05-11 10:40:44 +02:00
|
|
|
}
|
|
|
|
if ($fault->getMessage() === "Could not connect to host") {
|
2016-08-11 11:08:54 +02:00
|
|
|
$display_message = dgettext('plugin_mdm', 'Unable to connect to Z-Push Server. Could not connect to host.');
|
2016-05-11 10:40:44 +02:00
|
|
|
}
|
|
|
|
if ($fault->getMessage() === "Not Found") {
|
2016-08-11 11:08:54 +02:00
|
|
|
$display_message = dgettext('plugin_mdm', 'Unable to connect to Z-Push Server. Not found.');
|
2016-05-11 10:40:44 +02:00
|
|
|
}
|
|
|
|
} else if ($fault->faultcode === "ERROR") {
|
2016-08-11 11:08:54 +02:00
|
|
|
$display_message = dgettext('plugin_mdm', 'Device ID could not be found');
|
2016-05-11 10:40:44 +02:00
|
|
|
}
|
|
|
|
$this->sendFeedback(false, array("type" => ERROR_GENERAL, "info" => array('display_message' => $display_message)));
|
|
|
|
}
|
|
|
|
catch (Exception $e) {
|
2016-08-11 11:08:54 +02:00
|
|
|
$this->sendFeedback(true, array("type" => ERROR_GENERAL, "info" => array('display_message' => dgettext('plugin_mdm', 'Something went wrong'))));
|
2016-05-11 10:40:44 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2016-12-06 06:52:40 +01:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function which is use to get device properties.
|
|
|
|
*
|
|
|
|
* @param array $device array of device properties
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
function getDeviceProps($device)
|
|
|
|
{
|
|
|
|
$item = array();
|
|
|
|
$propsList = ['devicetype', 'deviceos', 'devicefriendlyname', 'useragent', 'asversion', 'firstsynctime',
|
|
|
|
'lastsynctime', 'lastupdatetime', 'wipestatus', 'policyname', 'koeversion', 'koebuild', 'koebuilddate'];
|
|
|
|
|
|
|
|
$item['entryid'] = $device['deviceid'];
|
|
|
|
foreach ($propsList as $prop) {
|
|
|
|
if (isset($device[$prop])) {
|
|
|
|
$item[$prop] = $device[$prop];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$item = array_merge($item, $this->getSyncFoldersProps($device));
|
|
|
|
return $item;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function which is use to gather some statistics about synchronized folders.
|
|
|
|
* @param array $device array of device props
|
|
|
|
* @return array $syncFoldersProps has list of properties related to synchronized folders
|
|
|
|
*/
|
|
|
|
function getSyncFoldersProps($device)
|
|
|
|
{
|
|
|
|
$contentData = $device['contentdata'];
|
|
|
|
$folders = array_keys($contentData);
|
|
|
|
$synchedFolderTypes = array();
|
|
|
|
$synchronizedData = '';
|
|
|
|
$synchronizedFolders = 0;
|
|
|
|
$hierarchyCache = isset($device['hierarchycache']) ? $device['hierarchycache'] : false;
|
|
|
|
|
|
|
|
foreach ($folders as $folderid) {
|
|
|
|
if (isset($contentData[$folderid][self::FOLDERUUID]) || isset($device['hierarchyuuid'])) {
|
|
|
|
$type = $contentData[$folderid][self::FOLDERTYPE];
|
|
|
|
$name = "unknown";
|
|
|
|
if ($hierarchyCache) {
|
|
|
|
if (array_key_exists($folderid, $hierarchyCache->cacheById)) {
|
|
|
|
$folder = $hierarchyCache->cacheById[$folderid];
|
|
|
|
} else {
|
|
|
|
$folder = $hierarchyCache->cacheByIdOld[$folderid];
|
|
|
|
}
|
|
|
|
if ($folder) {
|
|
|
|
$name = $folder->displayname;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$folderType = $this->getSyncFolderType($type, $name);
|
|
|
|
|
|
|
|
if (!isset($synchedFolderTypes[$folderType])) {
|
|
|
|
$synchedFolderTypes[$folderType] = 0;
|
|
|
|
}
|
|
|
|
$synchedFolderTypes[$folderType]++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
foreach ($synchedFolderTypes as $key => $value) {
|
|
|
|
$synchronizedData = $synchronizedData . $key;
|
|
|
|
$synchronizedFolders += $value;
|
|
|
|
if ($value > 1) {
|
|
|
|
$synchronizedData = $synchronizedData . "(" . $value . ") ";
|
|
|
|
} else {
|
|
|
|
$synchronizedData = $synchronizedData . " ";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$syncFoldersProps = array();
|
|
|
|
$syncFoldersProps["totalfolders"] = count($folders);
|
|
|
|
$syncFoldersProps["shortfolderids"] = $device['hasfolderidmapping'] ? dgettext('plugin_mdm', "Yes") : dgettext('plugin_mdm', "No") ;
|
|
|
|
$syncFoldersProps['synchronizedfolders'] = $synchronizedFolders;
|
|
|
|
$syncFoldersProps['synchronizeddata'] = $synchronizedData;
|
|
|
|
|
|
|
|
return $syncFoldersProps;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function which is use to get general type like Mail,Calendar,Contacts,etc. from folder type.
|
|
|
|
* @param int $type foldertype for a folder already known to the mobile
|
|
|
|
* @param string $name folder name
|
|
|
|
* @return string general folder type
|
|
|
|
*/
|
|
|
|
function getSyncFolderType($type, $name)
|
|
|
|
{
|
|
|
|
$folderType = '';
|
|
|
|
switch ($type) {
|
|
|
|
case SYNC_FOLDER_TYPE_APPOINTMENT:
|
|
|
|
case SYNC_FOLDER_TYPE_USER_APPOINTMENT:
|
|
|
|
if (KOE_GAB_NAME != "" && $name == KOE_GAB_NAME) {
|
|
|
|
$folderType = "GAB";
|
|
|
|
|
|
|
|
} else {
|
|
|
|
$folderType = "Calendars";
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case SYNC_FOLDER_TYPE_CONTACT:
|
|
|
|
case SYNC_FOLDER_TYPE_USER_CONTACT:
|
|
|
|
$folderType = "Contacts";
|
|
|
|
break;
|
|
|
|
case SYNC_FOLDER_TYPE_TASK:
|
|
|
|
case SYNC_FOLDER_TYPE_USER_TASK:
|
|
|
|
$folderType = "Tasks";
|
|
|
|
break;
|
|
|
|
case SYNC_FOLDER_TYPE_NOTE:
|
|
|
|
case SYNC_FOLDER_TYPE_USER_NOTE:
|
|
|
|
$folderType = "Notes";
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
$folderType = "Emails";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
return $folderType;
|
|
|
|
}
|
2016-05-11 10:40:44 +02:00
|
|
|
};
|
|
|
|
?>
|