* SPDX-License-Identifier: AGPL-3.0-only ************************************/ class DataTransform { public static $recordString = "record_id"; public static $recordModuleString = 'record_module'; public static function sanitizeDataWithColumn($row,$meta){ $newRow = array(); if(isset($row['count(*)'])){ return DataTransform::sanitizeDataWithCountColumn($row,$meta); } $fieldColumnMapping = $meta->getFieldColumnMapping(); $columnFieldMapping = array_flip($fieldColumnMapping); foreach($row as $col=>$val){ if(array_key_exists($col,$columnFieldMapping)) $newRow[$columnFieldMapping[$col]] = $val; } $newRow = DataTransform::sanitizeData($newRow,$meta,true); return $newRow; } // crmv@48267 // use this function after reading directly from database public static function sanitizeDataReadWithTimezone($row,$meta) { $newRow = array(); if(isset($row['count(*)'])){ return DataTransform::sanitizeDataWithCountColumn($row,$meta); } $fieldColumnMapping = $meta->getFieldColumnMapping(); $columnFieldMapping = array_flip($fieldColumnMapping); foreach($row as $col=>$val){ if(array_key_exists($col,$columnFieldMapping)) $newRow[$columnFieldMapping[$col]] = $val; } $newRow = DataTransform::sanitizeReferences($newRow,$meta); $newRow = DataTransform::sanitizeOwnerFields($newRow,$meta,$t); $newRow = DataTransform::sanitizeReadTimezoneFields($newRow,$meta); $newRow = DataTransform::sanitizeDateFieldsForInsert($newRow,$meta); //crmv@36510 $newRow = DataTransform::sanitizeFields($newRow,$meta); return $newRow; } // TODO: Tasks and standard date fields (uitype 5, 6) public static function sanitizeReadTimezoneFields($row, $meta) { global $current_user; if ($current_user->timezonediff == 0) return $row; if ($meta->getEntityName() == 'Events') { if ($row['date_start'] && $row['time_start']) { $newval = substr($row['date_start'], 0, 10).' '.$row['time_start']; $newval = adjustTimezone($newval, 0, null, false); $row['date_start'] = substr($newval, 0, 10); $row['time_start'] = substr($newval, 11, 5); } if ($row['due_date'] && $row['time_end']) { $newval = substr($row['due_date'], 0, 10).' '.$row['time_end']; $newval = adjustTimezone($newval, 0, null, false); $row['due_date'] = substr($newval, 0, 10); $row['time_end'] = substr($newval, 11, 5); } } return $row; } // crmv@48267e public static function sanitizeDataWithCountColumn($row,$meta){ $newRow = array(); foreach($row as $col=>$val){ $newRow['count'] = $val; } return $newRow; } public static function filterAndSanitize($row,$meta){ $row = DataTransform::filterAllColumns($row,$meta); $row = DataTransform::sanitizeData($row,$meta); return $row; } public static function sanitizeData($newRow,$meta,$t=null){ $newRow = DataTransform::sanitizeReferences($newRow,$meta); $newRow = DataTransform::sanitizeOwnerFields($newRow,$meta,$t); $newRow = DataTransform::sanitizeDateFieldsForInsert($newRow,$meta); //crmv@36510 $newRow = DataTransform::sanitizeFields($newRow,$meta); return $newRow; } public static function sanitizeForInsert($row,$meta){ global $adb; $associatedToUser = false; $parentTypeId = null; if(strtolower($meta->getEntityName()) == "emails"){ if(isset($row['parent_id'])){ $components = vtws_getIdComponents($row['parent_id']); $userObj = VtenextWebserviceObject::fromName($adb,'Users');//crmv@207871 $parentTypeId = $components[0]; if($components[0] == $userObj->getEntityId()){ $associatedToUser = true; } } } // added to handle the setting reminder time if(strtolower($meta->getEntityName()) == "events"){ if(isset($row['reminder_time'])&& $row['reminder_time']!= null && $row['reminder_time'] != 0){ $_REQUEST['set_reminder'] = "Yes"; $_REQUEST['mode'] = 'edit'; $reminder = $row['reminder_time']; $seconds = (int)$reminder%60; $minutes = (int)($reminder/60)%60; $hours = (int)($reminder/(60*60))%24; $days = (int)($reminder/(60*60*24)); //at vte there cant be 0 minutes reminder so we are setting to 1 if($minutes == 0){ $minutes = 1; } $_REQUEST['remmin'] = $minutes; $_REQUEST['remhrs'] = $hours; $_REQUEST['remdays'] = $days; } else { $_REQUEST['set_reminder'] = "No"; } } elseif(strtolower($meta->getEntityName()) == "calendar") { if(empty($row['sendnotification']) || strtolower($row['sendnotificaiton'])=='no' || $row['sendnotificaiton'] == '0' || $row['sendnotificaiton'] == 'false' || strtolower($row['sendnotificaiton']) == 'n') { unset($row['sendnotification']); } } $references = $meta->getReferenceFieldDetails(); foreach($references as $field=>$typeList){ if(strpos($row[$field],'x')!==false){ $row[$field] = vtws_getIdComponents($row[$field]); $row[$field] = $row[$field][1]; } } $ownerFields = $meta->getOwnerFields(); foreach($ownerFields as $index=>$field){ if(isset($row[$field]) && $row[$field]!=null){ $ownerDetails = vtws_getIdComponents($row[$field]); $row[$field] = $ownerDetails[1]; } } if(strtolower($meta->getEntityName()) == "emails"){ if(isset($row['parent_id'])){ if($associatedToUser === true){ $_REQUEST['module'] = 'Emails'; $row['parent_id'] = $row['parent_id']."@-1|"; $_REQUEST['parent_id'] = $row['parent_id']; }else{ $referenceHandler = vtws_getModuleHandlerFromId($parentTypeId, $meta->getUser()); $referenceMeta = $referenceHandler->getMeta(); $fieldId = getEmailFieldId($referenceMeta, $row['parent_id']); $row['parent_id'] .= "@$fieldId|"; } } } if($row["id"]){ unset($row["id"]); } if(isset($row[$meta->getObectIndexColumn()])){ unset($row[$meta->getObectIndexColumn()]); } $row = DataTransform::sanitizeDateFieldsForInsert($row,$meta); $row = DataTransform::sanitizeCurrencyFieldsForInsert($row,$meta); return $row; } public static function filterAllColumns($row,$meta){ $recordString = DataTransform::$recordString; $allFields = $meta->getFieldColumnMapping(); $newRow = array(); foreach($allFields as $field=>$col){ $newRow[$field] = $row[$field]; } if(isset($row[$recordString])){ $newRow[$recordString] = $row[$recordString]; } return $newRow; } public static function sanitizeFields($row,$meta){ $default_charset = VTWS_PreserveGlobal::getGlobal('default_charset'); $recordString = DataTransform::$recordString; $recordModuleString = DataTransform::$recordModuleString; if(isset($row[$recordModuleString])){ unset($row[$recordModuleString]); } $recordId = 0; // crmv@205306 if(isset($row['id'])){ $recordId = intval($row['id']); // crmv@205306 if(strpos($row['id'],'x')===false){ $row['id'] = vtws_getId($meta->getEntityId(),$row['id']); } } if(isset($row[$recordString])){ $row['id'] = vtws_getId($meta->getEntityId(),$row[$recordString]); unset($row[$recordString]); } if(!isset($row['id'])){ if($row[$meta->getObectIndexColumn()] ){ $row['id'] = vtws_getId($meta->getEntityId(),$row[$meta->getObectIndexColumn()]); }else{ //TODO Handle this. //echo 'error id noy set' ; } }else if(isset($row[$meta->getObectIndexColumn()]) && strcmp($meta->getObectIndexColumn(),"id")!==0){ unset($row[$meta->getObectIndexColumn()]); } foreach ($row as $field => $value) { $row[$field] = html_entity_decode($value, ENT_QUOTES, $default_charset); } // crmv@205306 if ($recordId > 0 && isset($row['taxclass'])) { $instance = vtws_getModuleInstance($meta->getWebserviceObject()); if (method_exists($instance, 'retrieveTaxes')) { $row['taxclass'] = Zend_Json::encode($instance->retrieveTaxes($recordId)); } } // crmv@205306e return $row; } public static function sanitizeReferences($row,$meta){ global $adb,$log; $references = $meta->getReferenceFieldDetails(); foreach($references as $field=>$typeList){ if(strtolower($meta->getEntityName()) == "emails"){ if(isset($row['parent_id'])){ list($row['parent_id'], $fieldId) = explode('@', $row['parent_id']); } } if($row[$field]){ $found = false; foreach ($typeList as $entity) { $webserviceObject = VtenextWebserviceObject::fromName($adb,$entity);//crmv@207871 $handlerPath = $webserviceObject->getHandlerPath(); $handlerClass = $webserviceObject->getHandlerClass(); require_once $handlerPath; $handler = new $handlerClass($webserviceObject,$meta->getUser(),$adb,$log); $entityMeta = $handler->getMeta(); if($entityMeta->exists($row[$field])){ $row[$field] = vtws_getId($webserviceObject->getEntityId(),$row[$field]); $found = true; break; } } if($found !== true){ //This is needed as for query operation of the related record is deleted. $row[$field] = null; } //0 is the default for most of the reference fields, so handle the case and return null instead as its the //only valid value, which is not a reference Id. }elseif(isset($row[$field]) && $row[$field]==0){ $row[$field] = null; } } return $row; } public static function sanitizeOwnerFields($row,$meta,$t=null){ global $adb; $ownerFields = $meta->getOwnerFields(); foreach($ownerFields as $index=>$field){ if(isset($row[$field]) && $row[$field]!=null){ $ownerType = vtws_getOwnerType($row[$field]); $webserviceObject = VtenextWebserviceObject::fromName($adb,$ownerType);//crmv@207871 $row[$field] = vtws_getId($webserviceObject->getEntityId(),$row[$field]); } } return $row; } public static function sanitizeDateFieldsForInsert($row,$meta){ global $current_user; $moduleFields = $meta->getModuleFields(); foreach($moduleFields as $fieldName=>$fieldObj){ if($fieldObj->getFieldDataType()=="date"){ if(!empty($row[$fieldName])){ $dateFieldObj = new DateTimeField($row[$fieldName]); $row[$fieldName] = $dateFieldObj->getDisplayDate($current_user); } } } return $row; } public static function sanitizeCurrencyFieldsForInsert($row,$meta){ /* crmv@54808 global $current_user; $moduleFields = $meta->getModuleFields(); foreach($moduleFields as $fieldName=>$fieldObj){ if($fieldObj->getFieldDataType()=="currency"){ if(!empty($row[$fieldName])){ $row[$fieldName] = CurrencyField::convertToUserFormat($row[$fieldName],$current_user,true); } } }*/ return $row; } }