Files
crm.clientright.ru/modules/Settings/Picklist/models/Field.php
Fedor ac7467f0b4 Major CRM updates: AI Assistant, Court Status API, S3 integration improvements, and extensive file storage system
- Added comprehensive AI Assistant system (aiassist/ directory):
  * Vector search and embedding capabilities
  * Typebot proxy integration
  * Elastic search functionality
  * Message classification and chat history
  * MCP proxy for external integrations

- Implemented Court Status API (GetCourtStatus.php):
  * Real-time court document status checking
  * Integration with external court systems
  * Comprehensive error handling and logging

- Enhanced S3 integration:
  * Improved file backup system with metadata
  * Batch processing capabilities
  * Enhanced error logging and recovery
  * Copy operations with URL fixing

- Added Telegram contact creation API
- Improved error logging across all modules
- Enhanced callback system for AI responses
- Extensive backup file storage with timestamps
- Updated documentation and README files

- File storage improvements:
  * Thousands of backup files with proper metadata
  * Fix operations for broken file references
  * Project-specific backup and recovery systems
  * Comprehensive file integrity checking

Total: 26,461+ files added/modified including AWS SDK, vendor dependencies, and extensive backup system.
2025-10-16 11:17:21 +03:00

152 lines
6.3 KiB
PHP

<?php
/*+**********************************************************************************
* The contents of this file are subject to the vtiger CRM Public License Version 1.1
* ("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 Settings_Picklist_Field_Model extends Vtiger_Field_Model {
public function isEditable() {
$nonEditablePickListValues = array( 'campaignrelstatus', 'duration_minutes','email_flag','hdnTaxType',
'payment_duration','recurringtype','recurring_frequency','visibility', 'paymentterms', 'modeofpayment', 'paymentgateway');
if(in_array($this->getName(), $nonEditablePickListValues)) return false;
return true;
}
/**
* Function which will give the picklistvalues for given roleids
* @param type $roleIdList -- array of role ids
* @param type $groupMode -- Intersection/Conjuction , intersection will give only picklist values that exist for all roles
* @return type -- array
*/
public function getPicklistValues($roleIdList, $groupMode='INTERSECTION') {
if(!$this->isRoleBased()) {
return parent::getPicklistValues();
}
$intersectionMode = false;
if($groupMode == 'INTERSECTION') {
$intersectionMode = true;
}
if(Vtiger_Cache::get('PicklistRoleBasedValues',$this->getName().implode('_', $roleIdList))){
return Vtiger_Cache::get('PicklistRoleBasedValues',$this->getName().implode('_', $roleIdList));
}
$db = PearDatabase::getInstance();
$fieldName = $this->getName();
$tableName = 'vtiger_'.$fieldName;
$idColName = $fieldName.'id';
$query = 'SELECT '.$fieldName;
if($intersectionMode) {
$query .= ',count(roleid) as rolecount ';
}
$query .= ' FROM vtiger_role2picklist INNER JOIN '.$tableName.' ON vtiger_role2picklist.picklistvalueid = '.$tableName.'.picklist_valueid'.
' WHERE roleid IN ('.generateQuestionMarks($roleIdList).') order by sortorderid';
if($intersectionMode) {
$query .= ' GROUP BY picklistvalueid';
}
$result = $db->pquery($query, $roleIdList);
$pickListValues = array();
$num_rows = $db->num_rows($result);
for($i=0; $i<$num_rows; $i++) {
$rowData = $db->query_result_rowdata($result, $i);
if($intersectionMode) {
//not equal if specify that the picklistvalue is not present for all the roles
if($rowData['rolecount'] != count($roleIdList)){
continue;
}
}
//Need to decode the picklist values twice which are saved from old ui
$pickListValues[$rowData[$fieldName]] = decode_html(decode_html($rowData[$fieldName]));
}
Vtiger_Cache::set('PicklistRoleBasedValues', $fieldName.implode('_', $roleIdList), $pickListValues);
return $pickListValues;
}
/**
* Function to get instance
* @param <String> $value - fieldname or fieldid
* @param <type> $module - optional - module instance
* @return <Vtiger_Field_Model>
*/
public static function getInstance($value, $module = false) {
$fieldObject = parent::getInstance($value, $module);
if($fieldObject) {
return self::getInstanceFromFieldObject($fieldObject);
}
return false;
}
/**
* Static Function to get the instance fo Vtiger Field Model from a given Vtiger_Field object
* @param Vtiger_Field $fieldObj - vtlib field object
* @return Vtiger_Field_Model instance
*/
public static function getInstanceFromFieldObject(Vtiger_Field $fieldObj) {
$objectProperties = get_object_vars($fieldObj);
$fieldModel = new self();
foreach($objectProperties as $properName=>$propertyValue) {
$fieldModel->$properName = $propertyValue;
}
return $fieldModel;
}
/**
* Function which will give the editable picklist values for a field
* @param type $fieldName -- string
* @return type -- array of values
*/
public function getEditablePicklistValues($fieldName){
$cache = Vtiger_Cache::getInstance();
$EditablePicklistValues = $cache->get('EditablePicklistValues', $fieldName);
if($EditablePicklistValues) {
return $EditablePicklistValues;
}
$db = PearDatabase::getInstance();
$primaryKey = Vtiger_Util_Helper::getPickListId($fieldName);
$query="SELECT $primaryKey ,$fieldName FROM vtiger_$fieldName WHERE presence=1";
$values = array();
$result = $db->pquery($query, array());
$num_rows = $db->num_rows($result);
for($i=0; $i<$num_rows; $i++) {
//Need to decode the picklist values twice which are saved from old ui
$values[$db->query_result($result,$i,$primaryKey)] = decode_html(decode_html($db->query_result($result,$i,$fieldName)));
}
$cache->set('EditablePicklistValues', $fieldName, $values);
return $values;
}
/**
* Function which will give the non editable picklist values for a field
* @param type $fieldName -- string
* @return type -- array of values
*/
public static function getNonEditablePicklistValues($fieldName){
$cache = Vtiger_Cache::getInstance();
$NonEditablePicklistValues = $cache->get('NonEditablePicklistValues', $fieldName);
if($NonEditablePicklistValues) {
return $NonEditablePicklistValues;
}
$db = PearDatabase::getInstance();
$columnIndex = Vtiger_Util_Helper::getPickListId($fieldName);
$query = "select $columnIndex, $fieldName from vtiger_$fieldName where presence=0";
$values = array();
$result = $db->pquery($query, array());
$num_rows = $db->num_rows($result);
for($i=0; $i<$num_rows; $i++) {
//Need to decode the picklist values twice which are saved from old ui
$values[$db->query_result($result,$i,$columnIndex)] = decode_html(decode_html($db->query_result($result,$i,$fieldName)));
}
$cache->set('NonEditablePicklistValues', $fieldName, $values);
return $values;
}
}