晋太元中,武陵人捕鱼为业。缘溪行,忘路之远近。忽逢桃花林,夹岸数百步,中无杂树,芳草鲜美,落英缤纷。渔人甚异之,复前行,欲穷其林。 林尽水源,便得一山,山有小口,仿佛若有光。便舍船,从口入。初极狭,才通人。复行数十步,豁然开朗。土地平旷,屋舍俨然,有良田、美池、桑竹之属。阡陌交通,鸡犬相闻。其中往来种作,男女衣着,悉如外人。黄发垂髫,并怡然自乐。 见渔人,乃大惊,问所从来。具答之。便要还家,设酒杀鸡作食。村中闻有此人,咸来问讯。自云先世避秦时乱,率妻子邑人来此绝境,不复出焉,遂与外人间隔。问今是何世,乃不知有汉,无论魏晋。此人一一为具言所闻,皆叹惋。余人各复延至其家,皆出酒食。停数日,辞去。此中人语云:“不足为外人道也。”(间隔 一作:隔绝) 既出,得其船,便扶向路,处处志之。及郡下,诣太守,说如此。太守即遣人随其往,寻向所志,遂迷,不复得路。 南阳刘子骥,高尚士也,闻之,欣然规往。未果,寻病终。后遂无问津者。
|
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 'include/database/PearDatabase.php';
require_once 'include/utils/utils.php';
function wsapp_getHandler($appType){
$db = PearDatabase::getInstance();
$result = $db->pquery("SELECT * FROM vtiger_wsapp_handlerdetails WHERE type=?",array($appType));
$handlerResult = array();
if($db->num_rows($result)>0){
$handlerResult['handlerclass'] = $db->query_result($result,0,'handlerclass');
$handlerResult['handlerpath'] = $db->query_result($result,0,'handlerpath');
}
return $handlerResult;
}
function wsapp_getApplicationName($key){
$db = PearDatabase::getInstance();
$result = $db->pquery("SELECT name from vtiger_wsapp WHERE appkey=?",array($key));
$name = false;
if($db->num_rows($result)){
$name = $db->query_result($result,0,'name');
}
return $name;
}
function wsapp_getRecordEntityNameIds($entityNames,$modules,$user){
$entityMetaList = array();
$db = PearDatabase::getInstance();
if(empty($entityNames)) return;
if(!is_array($entityNames))
$entityNames = array($entityNames);
if(empty($modules))
return array();
if(!is_array($modules))
$modules = array($modules);
$entityNameIds = array();
foreach($modules as $moduleName){
if(empty($entityMetaList[$moduleName])){
$handler = vtws_getModuleHandlerFromName($moduleName, $user);
$meta = $handler->getMeta();
$entityMetaList[$moduleName] = $meta;
}
$meta = $entityMetaList[$moduleName];
$nameFieldsArray = explode(",",$meta->getNameFields());
if(count($nameFieldsArray)>1){
$nameFields = "concat(".implode(",' ',",$nameFieldsArray).")";
}
else
$nameFields = $nameFieldsArray[0];
$query = "SELECT ".$meta->getObectIndexColumn()." as id,$nameFields as entityname FROM ".$meta->getEntityBaseTable()." as moduleentity INNER JOIN vtiger_crmentity as crmentity WHERE $nameFields IN(".generateQuestionMarks($entityNames).") AND crmentity.deleted=0 AND crmentity.crmid = moduleentity.".$meta->getObectIndexColumn()."";
$result = $db->pquery($query,$entityNames);
$num_rows = $db->num_rows($result);
for($i=0;$i<$num_rows;$i++){
$id = $db->query_result($result, $i,'id');
$entityName = $db->query_result($result, $i,'entityname');
$entityNameIds[strtolower(decode_html($entityName))] = vtws_getWebserviceEntityId($moduleName, $id);
}
}
return $entityNameIds;
}
/***
* Converts default time zone to specifiedTimeZone
*/
function wsapp_convertDateTimeToTimeZone($dateTime,$toTimeZone){
global $log,$default_timezone;
$time_zone = $default_timezone;
$source_time = date_default_timezone_set($time_zone);
$sourceDate = date("Y-m-d H:i:s");
$dest_time = date_default_timezone_set($toTimeZone);
$destinationDate = date("Y-m-d H:i:s");
$diff = (strtotime($destinationDate)-strtotime($sourceDate));
$givenTimeInSec = strtotime($dateTime);
$modifiedTimeSec = $givenTimeInSec+$diff;
$display_time = date("Y-m-d H:i:s",$modifiedTimeSec);
return $display_time;
}
function wsapp_checkIfRecordsAssignToUser($recordsIds,$userIds){
$assignedRecordIds = array();
if(!is_array($recordsIds))
$recordsIds = array($recordsIds);
if(count($recordsIds)<=0)
return $assignedRecordIds;
if(!is_array($userIds))
$userIds = array($userIds);
$db = PearDatabase::getInstance();
$query = "SELECT * FROM vtiger_crmentity where crmid IN (".generateQuestionMarks($recordsIds).") and smownerid in (".generateQuestionMarks($userIds).")";
$params = array();
foreach($recordsIds as $id){
$params[] = $id;
}
foreach($userIds as $userId){
$params[] = $userId;
}
$queryResult = $db->pquery($query,$params);
$num_rows = $db->num_rows($queryResult);
for($i=0;$i<$num_rows;$i++){
$assignedRecordIds[] = $db->query_result($queryResult,$i,"crmid");
}
return $assignedRecordIds;
}
function wsapp_getAppKey($appName){
$db = PearDatabase::getInstance();
$query = "SELECT * FROM vtiger_wsapp WHERE name=?";
$params = array($appName);
$result = $db->pquery($query,$params);
$appKey="";
if($db->num_rows($result)){
$appKey = $db->query_result($result,0,'appkey');
}
return $appKey;
}
function wsapp_getAppSyncType($appKey){
$db = PearDatabase::getInstance();
$query = "SELECT type FROM vtiger_wsapp WHERE appkey=?";
$params = array($appKey);
$result = $db->pquery($query,$params);
$syncType="";
if($db->num_rows($result)>0){
$syncType = $db->query_result($result,0,'type');
}
return $syncType;
}
function wsapp_RegisterHandler($type,$handlerClass,$handlerPath){
$db = PearDatabase::getInstance();
$query = "SELECT 1 FROM vtiger_wsapp_handlerdetails where type=?";
$result = $db->pquery($query,array($type));
if($db->num_rows($result)>0){
$saveQuery = "UPDATE vtiger_wsapp_handlerdetails SET handlerclass=?,handlerpath=? WHERE type=?";
$parameters = array($handlerClass,$handlerPath,$type);
} else{
$saveQuery = "INSERT INTO vtiger_wsapp_handlerdetails VALUES(?,?,?)";
$parameters = array($type,$handlerClass,$handlerPath);
}
$db->pquery($saveQuery,$parameters);
}
function wsapp_DeleteHandler($type){
if(!is_array($type)) $type = array($type);
$db = PearDatabase::getInstance();
$query = 'DELETE FROM vtiger_wsapp_handlerdetails WHERE type IN('. generateQuestionMarks($type).')';
$db->pquery($query,$type);
}
?>