Newer
Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
<?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.
*************************************************************************************/
class VtigerWebserviceObject{
private $id;
private $name;
private $handlerPath;
private $handlerClass;
private function VtigerWebserviceObject($entityId,$entityName,$handler_path,$handler_class){
$this->id = $entityId;
$this->name = $entityName;
// Quick Fix to override default Actor class & path (good to update DB itself)
if ($entityName == 'CompanyDetails') {
$handler_path = 'include/Webservices/Custom/VtigerCompanyDetails.php';
$handler_class= 'VtigerCompanyDetails';
}
// END
$this->handlerPath = $handler_path;
$this->handlerClass = $handler_class;
}
// Cache variables to enable result re-use
private static $_fromNameCache = array();
static function fromName($adb,$entityName){
$rowData = false;
// If the information not available in cache?
if(!isset(self::$_fromNameCache[$entityName])) {
$cacheLength = count(self::$_fromNameCache);
$result = null;
if ($cacheLength == 0) {
$result = $adb->pquery("select * from vtiger_ws_entity where name=?",array($entityName));
} else {
// Could repeat more number of times...so let us pull rest of details into cache.
$result = $adb->pquery("select * from vtiger_ws_entity", array());
}
if($result){
$rowCount = $adb->num_rows($result);
while ($rowCount > 0) {
$rowData = $adb->query_result_rowdata($result,$rowCount-1);
self::$_fromNameCache[$rowData['name']] = $rowData;
--$rowCount;
}
}
}
$rowData = self::$_fromNameCache[$entityName];
if($rowData) {
return new VtigerWebserviceObject($rowData['id'],$rowData['name'],
$rowData['handler_path'],$rowData['handler_class']);
}
throw new WebServiceException(WebServiceErrorCode::$ACCESSDENIED,"Permission to perform the operation is denied for name");
}
// Cache variables to enable result re-use
private static $_fromIdCache = array();
static function fromId($adb,$entityId){
$rowData = false;
// If the information not available in cache?
if(!isset(self::$_fromIdCache[$entityId])) {
$result = $adb->pquery("select * from vtiger_ws_entity where id=?",array($entityId));
if($result){
$rowCount = $adb->num_rows($result);
if($rowCount === 1){
$rowData = $adb->query_result_rowdata($result,0);
self::$_fromIdCache[$entityId] = $rowData;
}
}
}
$rowData = self::$_fromIdCache[$entityId];
if($rowData) {
return new VtigerWebserviceObject($rowData['id'],$rowData['name'],
$rowData['handler_path'],$rowData['handler_class']);
}
throw new WebServiceException(WebServiceErrorCode::$ACCESSDENIED,"Permission to perform the operation is denied for id");
}
static function fromQuery($adb,$query){
$moduleRegex = "/[fF][rR][Oo][Mm]\s+([^\s;]+)/";
$matches = array();
$found = preg_match($moduleRegex,$query,$matches);
if($found === 1){
return VtigerWebserviceObject::fromName($adb,trim($matches[1]));
}
throw new WebServiceException(WebServiceErrorCode::$ACCESSDENIED,"Permission to perform the operation is denied for query");
}
public function getEntityName(){
return $this->name;
}
public function getEntityId(){
return $this->id;
}
public function getHandlerPath(){
return $this->handlerPath;
}
public function getHandlerClass(){
return $this->handlerClass;
}
}
?>