- 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.
223 lines
9.6 KiB
PHP
223 lines
9.6 KiB
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.
|
|
*************************************************************************************/
|
|
|
|
class Emails_Module_Model extends Vtiger_Module_Model{
|
|
|
|
/**
|
|
* Function to check whether the module is an entity type module or not
|
|
* @return <Boolean> true/false
|
|
*/
|
|
public function isQuickCreateSupported() {
|
|
//emails module is not enabled for quick create
|
|
return false;
|
|
}
|
|
|
|
public function isWorkflowSupported() {
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* Function to check whether the module is summary view supported
|
|
* @return <Boolean> - true/false
|
|
*/
|
|
public function isSummaryViewSupported() {
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* Function to get emails related modules
|
|
* @return <Array> - list of modules
|
|
*/
|
|
public function getEmailRelatedModules() {
|
|
$userPrivModel = Users_Privileges_Model::getCurrentUserPrivilegesModel();
|
|
|
|
$relatedModules = vtws_listtypes(array('email'), Users_Record_Model::getCurrentUserModel());
|
|
$relatedModules = $relatedModules['types'];
|
|
|
|
foreach ($relatedModules as $key => $moduleName) {
|
|
if ($moduleName === 'Users') {
|
|
unset($relatedModules[$key]);
|
|
}
|
|
}
|
|
foreach ($relatedModules as $moduleName) {
|
|
$moduleModel = Vtiger_Module_Model::getInstance($moduleName);
|
|
if(($userPrivModel->isAdminUser() || $userPrivModel->hasGlobalReadPermission() || $userPrivModel->hasModulePermission($moduleModel->getId())) && !$moduleModel->restrictToListInComposeEmailPopup()) {
|
|
$emailRelatedModules[] = $moduleName;
|
|
}
|
|
}
|
|
$emailRelatedModules[] = 'Users';
|
|
return $emailRelatedModules;
|
|
}
|
|
|
|
/**
|
|
* Function to search emails for send email
|
|
* @param <String> $searchValue
|
|
* @return <Array> Result of searched emails
|
|
*/
|
|
public function searchEmails($searchValue, $moduleName = false) {
|
|
global $current_user;
|
|
$emailsResult = array();
|
|
$params = array();
|
|
$db = PearDatabase::getInstance();
|
|
|
|
$EmailsModuleModel = Vtiger_Module_Model::getInstance('Emails');
|
|
$emailSupportedModulesList = $EmailsModuleModel->getEmailRelatedModules();
|
|
foreach ($emailSupportedModulesList as $module) {
|
|
if ($module != 'Users' && $module != 'ModComments') {
|
|
$activeModules[] = $module;
|
|
$activeModuleModel = Vtiger_Module_Model::getInstance($module);
|
|
$moduleEmailFields = $activeModuleModel->getFieldsByType('email');
|
|
foreach ($moduleEmailFields as $fieldName => $fieldModel) {
|
|
if ($fieldModel->isViewable()) {
|
|
$fieldIds[] = $fieldModel->get('id');
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
if ($moduleName) {
|
|
$activeModules = array($moduleName);
|
|
}
|
|
|
|
$query = "SELECT vtiger_emailslookup.crmid, vtiger_emailslookup.setype, vtiger_emailslookup.value,
|
|
vtiger_crmentity.label FROM vtiger_emailslookup INNER JOIN vtiger_crmentity on
|
|
vtiger_crmentity.crmid = vtiger_emailslookup.crmid AND vtiger_crmentity.deleted=0 WHERE
|
|
vtiger_emailslookup.fieldid in (".generateQuestionMarks($fieldIds).") and
|
|
vtiger_emailslookup.setype in (".generateQuestionMarks($activeModules).")
|
|
and (vtiger_emailslookup.value LIKE ? OR vtiger_crmentity.label LIKE ?)";
|
|
$params = array_merge($params, $fieldIds);
|
|
$params = array_merge($params, $activeModules);
|
|
array_push($params, "%$searchValue%");
|
|
array_push($params, "%$searchValue%");
|
|
$emailOptOutIds = $this->getEmailOptOutRecordIds();
|
|
if (!empty($emailOptOutIds)) {
|
|
$query .= " AND vtiger_emailslookup.crmid NOT IN (". generateQuestionMarks($emailOptOutIds).")";
|
|
$params = array_merge($params, $emailOptOutIds);
|
|
}
|
|
|
|
$result = $db->pquery($query, $params);
|
|
$isAdmin = is_admin($current_user);
|
|
while ($row = $db->fetchByAssoc($result)) {
|
|
if (!$isAdmin) {
|
|
$recordPermission = Users_Privileges_Model::isPermitted($row['setype'], 'DetailView', $row['crmid']);
|
|
if (!$recordPermission) {
|
|
continue;
|
|
}
|
|
}
|
|
$emailsResult[vtranslate($row['setype'], $row['setype'])][$row['crmid']][] = array('value' => $row['value'],
|
|
'label' => decode_html($row['label']).' <b>('.$row['value'].')</b>',
|
|
'name' => decode_html($row['label']),);
|
|
}
|
|
|
|
// For Users we should only search in users table
|
|
$additionalModule = array('Users');
|
|
if(!$moduleName || in_array($moduleName, $additionalModule)){
|
|
foreach($additionalModule as $moduleName){
|
|
$moduleInstance = CRMEntity::getInstance($moduleName);
|
|
$searchFields = array();
|
|
$moduleModel = Vtiger_Module_Model::getInstance($moduleName);
|
|
$emailFieldModels = $moduleModel->getFieldsByType('email');
|
|
|
|
foreach ($emailFieldModels as $fieldName => $fieldModel) {
|
|
if ($fieldModel->isViewable()) {
|
|
$searchFields[] = $fieldName;
|
|
}
|
|
}
|
|
$emailFields = $searchFields;
|
|
|
|
$nameFields = $moduleModel->getNameFields();
|
|
foreach ($nameFields as $fieldName) {
|
|
$fieldModel = Vtiger_Field_Model::getInstance($fieldName, $moduleModel);
|
|
if ($fieldModel->isViewable()) {
|
|
$searchFields[] = $fieldName;
|
|
}
|
|
}
|
|
|
|
if ($emailFields) {
|
|
$userQuery = 'SELECT '.$moduleInstance->table_index.', '.implode(',',$searchFields).' FROM vtiger_users WHERE deleted=0';
|
|
$result = $db->pquery($userQuery, array());
|
|
$numOfRows = $db->num_rows($result);
|
|
for($i=0; $i<$numOfRows; $i++) {
|
|
$row = $db->query_result_rowdata($result, $i);
|
|
foreach ($emailFields as $emailField) {
|
|
$emailFieldValue = $row[$emailField];
|
|
if ($emailFieldValue) {
|
|
$recordLabel = getEntityFieldNameDisplay($moduleName, $nameFields, $row);
|
|
if (strpos($emailFieldValue, $searchValue) !== false || strpos($recordLabel, $searchValue) !== false) {
|
|
$emailsResult[vtranslate($moduleName, $moduleName)][$row[$moduleInstance->table_index]][]
|
|
= array('value' => $emailFieldValue,
|
|
'name' => $recordLabel,
|
|
'label' => $recordLabel . ' <b>('.$emailFieldValue.')</b>');
|
|
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
return $emailsResult;
|
|
}
|
|
|
|
/*
|
|
* Function to get supported utility actions for a module
|
|
*/
|
|
function getUtilityActionsNames() {
|
|
return array();
|
|
}
|
|
|
|
function getEmailOptOutRecordIds() {
|
|
$emailOptOutIds = array();
|
|
$db = PearDatabase::getInstance();
|
|
$contactResult = $db->pquery("SELECT crmid FROM vtiger_crmentity INNER JOIN vtiger_contactdetails ON vtiger_contactdetails.contactid = vtiger_crmentity.crmid WHERE vtiger_crmentity.deleted = ? AND vtiger_contactdetails.emailoptout = ?", array('0', '1'));
|
|
$contactCount = $db->num_rows($contactResult);
|
|
for($i = 0; $i < $contactCount; $i++) {
|
|
$emailOptOutIds[] = $db->query_result($contactResult, $i, 'crmid');
|
|
}
|
|
$accountResult = $db->pquery("SELECT crmid FROM vtiger_crmentity INNER JOIN vtiger_account ON vtiger_account.accountid = vtiger_crmentity.crmid WHERE vtiger_crmentity.deleted = ? AND vtiger_account.emailoptout = ?", array('0', '1'));
|
|
$accountCount = $db->num_rows($accountResult);
|
|
for($i = 0; $i < $accountCount; $i++) {
|
|
$emailOptOutIds[] = $db->query_result($accountResult, $i, 'crmid');
|
|
}
|
|
$leadResult = $db->pquery("SELECT crmid FROM vtiger_crmentity INNER JOIN vtiger_leaddetails ON vtiger_leaddetails.leadid = vtiger_crmentity.crmid WHERE vtiger_crmentity.deleted = ? AND vtiger_leaddetails.emailoptout = ?", array('0', '1'));
|
|
$leadCount = $db->num_rows($leadResult);
|
|
for($i = 0; $i < $leadCount; $i++) {
|
|
$emailOptOutIds[] = $db->query_result($leadResult, $i, 'crmid');
|
|
}
|
|
|
|
return $emailOptOutIds;
|
|
}
|
|
|
|
/**
|
|
* Function to save a given record model of the current module
|
|
* @param Vtiger_Record_Model $recordModel
|
|
*/
|
|
public function saveRecord(Vtiger_Record_Model $recordModel) {
|
|
$moduleName = $this->get('name');
|
|
$focus = $recordModel->getEntity();
|
|
$fields = $focus->column_fields;
|
|
foreach ($fields as $fieldName => $fieldValue) {
|
|
$fieldValue = $recordModel->get($fieldName);
|
|
if (is_array($fieldValue)) {
|
|
$focus->column_fields[$fieldName] = $fieldValue;
|
|
} else if ($fieldValue !== null) {
|
|
$value = is_string($fieldValue) ? decode_emptyspace_html($fieldValue) : $fieldValue;
|
|
$focus->column_fields[$fieldName] = $value;
|
|
}
|
|
}
|
|
$focus->mode = $recordModel->get('mode');
|
|
$focus->id = $recordModel->getId();
|
|
$focus->save($moduleName);
|
|
|
|
return $recordModel->setId($focus->id);
|
|
}
|
|
}
|
|
?>
|