Files
crm.clientright.ru/modules/Portal/models/Module.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

112 lines
4.3 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 Portal_Module_Model extends Vtiger_Module_Model {
public function getSideBarLinks($linkParams) {
$quickLink = array(
'linktype' => 'SIDEBARLINK',
'linklabel' => 'LBL_OUR_SITES_LIST',
'linkurl' => $this->getListViewUrl(),
'linkicon' => '',
);
$links['SIDEBARLINK'][] = Vtiger_Link_Model::getInstanceFromValues($quickLink);
return $links;
}
public function saveRecord($recordId, $bookmarkName, $bookmarkUrl) {
$db = PearDatabase::getInstance();
if(empty($recordId)) {
$portalId = $db->getUniqueID('vtiger_portal');
$query = "INSERT INTO vtiger_portal VALUES(?,?,?,?,?,?)";
$params = array($portalId, $bookmarkName, $bookmarkUrl, 0, 0, date('Y-m-d H:i:s'));
}
else {
$query = "UPDATE vtiger_portal SET portalname=?, portalurl=? WHERE portalid=?";
$params = array($bookmarkName, $bookmarkUrl, $recordId);
}
$db->pquery($query, $params);
return true;
}
public function getRecord($recordId) {
$db = PearDatabase::getInstance();
$result = $db->pquery('SELECT portalname, portalurl FROM vtiger_portal WHERE portalid = ?', array($recordId));
$data['bookmarkName'] = $db->query_result($result, 0, 'portalname');
$data['bookmarkUrl'] = $db->query_result($result, 0, 'portalurl');
return $data;
}
public function deleteRecord($recordId) {
$db = PearDatabase::getInstance();
$db->pquery('DELETE FROM vtiger_portal WHERE portalid = ?', array($recordId));
}
public function getWebsiteUrl($recordId) {
$db = PearDatabase::getInstance();
$result = $db->pquery('SELECT portalurl FROM vtiger_portal WHERE portalid=?', array($recordId));
return $db->query_result($result, 0, 'portalurl');
}
public function getAllRecords() {
$db = PearDatabase::getInstance();
$record = array();
$result = $db->pquery('SELECT portalid, portalname FROM vtiger_portal', array());
for($i = 0; $i < $db->num_rows($result); $i++) {
$row = $db->fetch_row($result, $i);
$record[$i]['id'] = $row['portalid'];
$record[$i]['portalname'] = $row['portalname'];
}
return $record;
}
public function deleteRecords(Vtiger_Request $request) {
$searchValue = $request->get('search_value');
$selectedIds = $request->get('selected_ids');
$excludedIds = $request->get('excluded_ids');
$db = PearDatabase::getInstance();
$query = 'DELETE FROM vtiger_portal';
$params = array();
if(!empty($selectedIds) && $selectedIds != 'all' && count($selectedIds) > 0) {
$query .= " WHERE portalid IN (".generateQuestionMarks($selectedIds).")";
$params = $selectedIds;
} else if($selectedIds == 'all') {
if(empty($searchValue) && count($excludedIds) > 0) {
$query .= " WHERE portalid NOT IN (".generateQuestionMarks($excludedIds).")";
$params = $excludedIds;
} else if(!empty($searchValue) && count($excludedIds) < 1) {
$query .= " WHERE portalname LIKE '%".$searchValue."%'";
} else if(!empty($searchValue) && count($excludedIds) > 0) {
$query .= " WHERE portalname LIKE '%".$searchValue."%' AND portalid NOT IN (".generateQuestionMarks($excludedIds).")";
$params = $excludedIds;
}
}
$db->pquery($query, $params);
}
/*
* Function to get supported utility actions for a module
*/
function getUtilityActionsNames() {
return array();
}
}