- 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.
62 lines
2.2 KiB
PHP
62 lines
2.2 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.
|
|
************************************************************************************/
|
|
|
|
include_once 'include/Webservices/DescribeObject.php';
|
|
include_once 'include/Webservices/Query.php';
|
|
|
|
class Mobile_WS_FetchReferenceRecords extends Mobile_WS_Controller {
|
|
|
|
function process(Mobile_API_Request $request) {
|
|
|
|
$response = new Mobile_API_Response();
|
|
$current_user = $this->getActiveUser();
|
|
|
|
//fetch reference records request params
|
|
$referenceModule = $request->get('module');
|
|
$searchKey = $request->get('searchValue');
|
|
|
|
if($referenceModule=='Documents') {
|
|
$labelFields = 'notes_title';
|
|
} else if($referenceModule=='HelpDesk') {
|
|
$labelFields = 'ticket_title';
|
|
} else {
|
|
$describe = vtws_describe($referenceModule, $current_user);
|
|
$labelFields = $describe['labelFields'];
|
|
}
|
|
|
|
$labelFieldsArray = explode(',', $labelFields);
|
|
|
|
$sql = sprintf("SELECT %s FROM %s WHERE ",$labelFields,$referenceModule);
|
|
|
|
foreach($labelFieldsArray as $labelField) {
|
|
|
|
$sql .= $labelField . " LIKE '%" . $searchKey . "%' OR ";
|
|
}
|
|
$sql = rtrim($sql,' OR ') . ';';
|
|
|
|
$wsresult = vtws_query($sql,$current_user);
|
|
|
|
$referenceRecords = array();
|
|
foreach($wsresult as $result) {
|
|
$record = array();
|
|
foreach($labelFieldsArray as $labelField) {
|
|
$record['label'] .= $result[$labelField] . ' ';
|
|
}
|
|
$record['label'] = trim($record['label']);
|
|
$record['value'] = decode_html($result['id']);
|
|
$referenceRecords[] = $record;
|
|
}
|
|
|
|
$response->setResult($referenceRecords);
|
|
return $response;
|
|
}
|
|
|
|
}
|
|
?>
|