- 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.
95 lines
3.4 KiB
PHP
95 lines
3.4 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 Settings_PBXManager_Record_Model extends Settings_Vtiger_Record_Model {
|
|
|
|
const tableName = 'vtiger_pbxmanager_gateway';
|
|
|
|
public function getId() {
|
|
return $this->get('id');
|
|
}
|
|
|
|
public function getName() {
|
|
}
|
|
|
|
public function getModule(){
|
|
return new Settings_PBXManager_Module_Model;
|
|
}
|
|
|
|
static function getCleanInstance(){
|
|
return new self;
|
|
}
|
|
|
|
public static function getInstance(){
|
|
$serverModel = new self();
|
|
$db = PearDatabase::getInstance();
|
|
$query = 'SELECT * FROM '.self::tableName;
|
|
$gatewatResult = $db->pquery($query, array());
|
|
$gatewatResultCount = $db->num_rows($gatewatResult);
|
|
|
|
if($gatewatResultCount > 0) {
|
|
$rowData = $db->query_result_rowdata($gatewatResult, 0);
|
|
$serverModel->set('gateway',$rowData['gateway']);
|
|
$serverModel->set('id',$rowData['id']);
|
|
$parameters = Zend_Json::decode(decode_html($rowData['parameters']));
|
|
foreach ($parameters as $fieldName => $fieldValue) {
|
|
$serverModel->set($fieldName,$fieldValue);
|
|
}
|
|
return $serverModel;
|
|
}
|
|
return $serverModel;
|
|
}
|
|
|
|
public static function getInstanceById($recordId, $qualifiedModuleName) {
|
|
$db = PearDatabase::getInstance();
|
|
$result = $db->pquery('SELECT * FROM '.self::tableName.' WHERE id = ?', array($recordId));
|
|
|
|
if ($db->num_rows($result)) {
|
|
$moduleModel = Settings_Vtiger_Module_Model::getInstance($qualifiedModuleName);
|
|
$rowData = $db->query_result_rowdata($result, 0);
|
|
|
|
$recordModel = new self();
|
|
$recordModel->setData($rowData);
|
|
|
|
$parameters = Zend_Json::decode(decode_html($recordModel->get('parameters')));
|
|
foreach ($parameters as $fieldName => $fieldValue) {
|
|
$recordModel->set($fieldName, $fieldValue);
|
|
}
|
|
return $recordModel;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
public function save() {
|
|
$db = PearDatabase::getInstance();
|
|
//SalesPlatform.ru begin
|
|
//$parameters = '';
|
|
$parameters = [];
|
|
//SalesPlatform.ru end
|
|
$selectedGateway = $this->get('gateway');
|
|
$connector = new PBXManager_PBXManager_Connector;
|
|
|
|
foreach ($connector->getSettingsParameters() as $field => $type) {
|
|
$parameters[$field] = $this->get($field);
|
|
}
|
|
$this->set('parameters', Zend_Json::encode($parameters));
|
|
$params = array($selectedGateway,$this->get('parameters'));
|
|
$id = $this->getId();
|
|
|
|
if ($id) {
|
|
$query = 'UPDATE '.self::tableName.' SET gateway=?, parameters = ? WHERE id = ?';
|
|
array_push($params, $id);
|
|
} else {
|
|
$query = 'INSERT INTO '.self::tableName.'(gateway, parameters) VALUES(?, ?)';
|
|
}
|
|
$db->pquery($query, $params);
|
|
}
|
|
}
|