晋太元中,武陵人捕鱼为业。缘溪行,忘路之远近。忽逢桃花林,夹岸数百步,中无杂树,芳草鲜美,落英缤纷。渔人甚异之,复前行,欲穷其林。 林尽水源,便得一山,山有小口,仿佛若有光。便舍船,从口入。初极狭,才通人。复行数十步,豁然开朗。土地平旷,屋舍俨然,有良田、美池、桑竹之属。阡陌交通,鸡犬相闻。其中往来种作,男女衣着,悉如外人。黄发垂髫,并怡然自乐。 见渔人,乃大惊,问所从来。具答之。便要还家,设酒杀鸡作食。村中闻有此人,咸来问讯。自云先世避秦时乱,率妻子邑人来此绝境,不复出焉,遂与外人间隔。问今是何世,乃不知有汉,无论魏晋。此人一一为具言所闻,皆叹惋。余人各复延至其家,皆出酒食。停数日,辞去。此中人语云:“不足为外人道也。”(间隔 一作:隔绝) 既出,得其船,便扶向路,处处志之。及郡下,诣太守,说如此。太守即遣人随其往,寻向所志,遂迷,不复得路。 南阳刘子骥,高尚士也,闻之,欣然规往。未果,寻病终。后遂无问津者。
|
Server : Apache System : Linux srv.rainic.com 4.18.0-553.47.1.el8_10.x86_64 #1 SMP Wed Apr 2 05:45:37 EDT 2025 x86_64 User : rainic ( 1014) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/akaindir/public_html/crm/modules/WSAPP/ |
Upload File : |
<?php
/*+***********************************************************************************
* The contents of this file are subject to the vtiger CRM Public License Version 1.0
* ("License"); You may not use this file except in compliance with the License
* The Original Code is: vtiger CRM Open Source
* The Initial Developer of the Original Code is vtiger.
* Portions created by vtiger are Copyright (C) vtiger.
* All Rights Reserved.
*************************************************************************************/
require_once 'modules/WSAPP/Utils.php';
require_once 'include/database/PearDatabase.php';
require_once 'include/Zend/Json.php';
require_once 'include/utils/utils.php';
class OutlookSyncServer extends SyncServer{
private $destHandler;
private $create = "create";
private $update = "update";
private $delete = "delete";
function getDestinationHandleDetails(){
return array('handlerclass' => 'OutlookVtigerCRMHandler',
'handlerpath' => 'modules/WSAPP/Handlers/OutlookVtigerCRMHandler.php');
}
/*
* Function overrided to deal duplication handling
*/
function put($key, $element, $user) {
global $log;
$db = PearDatabase::getInstance();
$appid = parent::appid_with_key($key);
if (empty($appid)) {
throw new WebServiceException('WSAPP04', "Access restricted to app");
}
if (!is_array($element))
$records = array($element);
else
$records = $element;
//hardcoded since the destination handler will be vtigerCRM
$serverKey = wsapp_getAppKey("vtigerCRM");
$serverAppId = parent::appid_with_key($serverKey);
$handlerDetails = $this->getDestinationHandleDetails();
$clientApplicationSyncType = wsapp_getAppSyncType($key);
require_once $handlerDetails['handlerpath'];
$this->destHandler = new $handlerDetails['handlerclass']($serverKey);
$this->destHandler->setClientSyncType($clientApplicationSyncType);
$recordDetails = array();
$createRecords = array();
$updateRecords = array();
$deleteRecords = array();
$clientModifiedTimeList = array();
foreach ($records as $record) {
$recordDetails = array();
$clientRecordId = $record['id'];
// Missing client record id?
if (empty($clientRecordId))
continue;
$lookupRecordId = false;
// Added for Duplication handling
if (!empty($record['crmid'])) {
$crmid = vtws_getIdComponents($record['crmid']);
$lookupResult = $db->pquery("SELECT crmid,modifiedtime FROM vtiger_crmentity WHERE crmid=?", array($crmid[1]));
if ($db->num_rows($lookupResult))
$lookupRecordId = $record['crmid'];
if (!(empty($lookupRecordId))) {
$clientLastModifiedTime = $db->query_result($lookupResult, 0, 'modifiedtime');
$record['values']['id'] = $lookupRecordId;
$record['values']['duplicate'] = true;
$updateRecords[$clientRecordId] = $record['values'];
$updateRecords[$clientRecordId]['module'] = $record['module'];
$clientModifiedTimeList[$clientRecordId] = $record['values']['modifiedtime'];
}
}
// End
else {
$lookupResult = $db->pquery("SELECT serverid,clientmodifiedtime FROM vtiger_wsapp_recordmapping WHERE appid=? AND clientid=?", array($appid, $clientRecordId));
if ($db->num_rows($lookupResult))
$lookupRecordId = $db->query_result($lookupResult, 0, 'serverid');
if (empty($lookupRecordId) && $record['mode'] != "delete") {
$createRecords[$clientRecordId] = $record['values'];
$createRecords[$clientRecordId]['module'] = $record['module'];
$clientModifiedTimeList[$clientRecordId] = $record['values']['modifiedtime'];
} else {
if (empty($record['values']) && !(empty($lookupRecordId))) {
$deleteRecords[$clientRecordId] = $lookupRecordId;
} else if (!(empty($lookupRecordId))) {
$clientLastModifiedTime = $db->query_result($lookupResult, 0, 'clientmodifiedtime');
if ($clientLastModifiedTime >= $record['values']['modifiedtime'])
continue;
$record['values']['id'] = $lookupRecordId;
$updateRecords[$clientRecordId] = $record['values'];
$updateRecords[$clientRecordId]['module'] = $record['module'];
$clientModifiedTimeList[$clientRecordId] = $record['values']['modifiedtime'];
}
}
}
}
$recordDetails['created'] = $createRecords;
$recordDetails['updated'] = $updateRecords;
$recordDetails['deleted'] = $deleteRecords;
$result = $this->destHandler->put($recordDetails, $user);
$response = array();
$response['created'] = array();
$response['updated'] = array();
$response['deleted'] = array();
$log->fatal($result['updated']);
$nextSyncDeleteRecords = $this->destHandler->getAssignToChangedRecords();
foreach ($result['created'] as $clientRecordId => $record) {
parent::idmap_put($appid, $record['id'], $clientRecordId, $clientModifiedTimeList[$clientRecordId], $record['modifiedtime'], $serverAppId, $this->create);
$responseRecord = $record;
$responseRecord['_id'] = $record['id'];
$responseRecord['id'] = $clientRecordId;
$responseRecord['_modifiedtime'] = $record['modifiedtime'];
$responseRecord['modifiedtime'] = $clientModifiedTimeList[$clientRecordId];
$response['created'][] = $responseRecord;
}
foreach ($result['updated'] as $clientRecordId => $record) {
/*
* If record is duplicate then it'll be in updated records. But, we should create a mapping instead of
* updating
*/
if($record['duplicate']){
parent::idmap_put($appid, $record['id'], $clientRecordId, $clientModifiedTimeList[$clientRecordId], $record['modifiedtime'], $serverAppId, $this->create);
}else{
parent::idmap_put($appid, $record['id'], $clientRecordId, $clientModifiedTimeList[$clientRecordId], $record['modifiedtime'], $serverAppId, $this->update);
}
$responseRecord = $record;
$responseRecord['_id'] = $record['id'];
$responseRecord['id'] = $clientRecordId;
$responseRecord['_modifiedtime'] = $record['modifiedtime'];
$responseRecord['modifiedtime'] = $clientModifiedTimeList[$clientRecordId];
$response['updated'][] = $responseRecord;
}
foreach ($result['deleted'] as $clientRecordId => $record) {
parent::idmap_put($appid, $record, $clientRecordId, "", "", $serverAppId, $this->delete);
$response['deleted'][] = $clientRecordId;
}
$queueRecordIds = array();
$queueRecordDetails = array();
foreach ($nextSyncDeleteRecords as $clientRecordId => $record) {
$queueRecordIds[] = $record['id'];
$queueRecordDetails[$record['id']] = parent::convertToQueueRecordFormat($record, $this->delete);
}
if (count($queueRecordIds > 0)) {
$syncServerDetails = parent::idmap_get_clientmap($appid, $queueRecordIds);
foreach ($queueRecordIds as $serverId) {
$syncServerId = $syncServerDetails[$serverId]['id'];
$recordValues = $queueRecordDetails[$serverId];
if (!parent::checkIdExistInQueue($syncServerId)) {
parent::idmap_storeRecordsInQueue($syncServerId, $recordValues, $this->delete, $appid);
}
}
}
return $response;
}
}
?>