- 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.
157 lines
3.8 KiB
PHP
157 lines
3.8 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 'vtlib/thirdparty/network/Request.php';
|
|
|
|
/**
|
|
* Provides API to work with HTTP Connection.
|
|
* @package vtlib
|
|
*/
|
|
class Vtiger_Net_Client {
|
|
var $client;
|
|
var $url;
|
|
var $response;
|
|
|
|
/**
|
|
* Constructor
|
|
* @param String URL of the site
|
|
* Example:
|
|
* $client = new Vtiger_New_Client('http://www.vtiger.com');
|
|
*/
|
|
function __construct($url) {
|
|
$this->setURL($url);
|
|
}
|
|
|
|
/**
|
|
* Set another url for this instance
|
|
* @param String URL to use go forward
|
|
*/
|
|
function setURL($url) {
|
|
$this->url = $url;
|
|
$this->client = new HTTP_Request();
|
|
$this->response = false;
|
|
$this->setDefaultHeaders();
|
|
}
|
|
|
|
function setDefaultHeaders() {
|
|
$headers = array();
|
|
if (isset($_SERVER)) {
|
|
global $site_URL;
|
|
$headers['referer'] = isset($_SERVER['HTTP_REFERER'])? $_SERVER['HTTP_REFERER'] : ($site_URL . "?noreferer");
|
|
|
|
if (isset($_SERVER['HTTP_USER_AGENT'])) {
|
|
$headers['user-agent'] = $_SERVER['HTTP_USER_AGENT'];
|
|
}
|
|
|
|
} else {
|
|
global $site_URL;
|
|
$headers['referer'] = ($site_URL . "?noreferer");
|
|
}
|
|
|
|
$this->setHeaders($headers);
|
|
}
|
|
|
|
/**
|
|
* Set custom HTTP Headers
|
|
* @param Map HTTP Header and Value Pairs
|
|
*/
|
|
function setHeaders($values) {
|
|
foreach($values as $key=>$value) {
|
|
$this->client->addHeader($key, $value);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Perform a GET request
|
|
* @param Map key-value pair or false
|
|
* @param Integer timeout value
|
|
*/
|
|
function doGet($params=false, $timeout=null) {
|
|
if($timeout) $this->client->_timeout = $timeout;
|
|
$this->client->setURL($this->url);
|
|
$this->client->setMethod(HTTP_REQUEST_METHOD_GET);
|
|
|
|
if($params) {
|
|
foreach($params as $key=>$value)
|
|
$this->client->addQueryString($key, $value);
|
|
}
|
|
$this->response = $this->client->sendRequest();
|
|
|
|
$content = false;
|
|
if(!$this->wasError()) {
|
|
$content = $this->client->getResponseBody();
|
|
}
|
|
$this->disconnect();
|
|
return $content;
|
|
}
|
|
|
|
/**
|
|
* Perform a POST request
|
|
* @param Map key-value pair or false
|
|
* @param Integer timeout value
|
|
*/
|
|
function doPost($params=false, $timeout=null) {
|
|
if($timeout) $this->client->_timeout = $timeout;
|
|
$this->client->setURL($this->url);
|
|
$this->client->setMethod(HTTP_REQUEST_METHOD_POST);
|
|
|
|
if($params) {
|
|
if(is_string($params)) $this->client->addRawPostData($params);
|
|
else {
|
|
foreach($params as $key=>$value)
|
|
$this->client->addPostData($key, $value);
|
|
}
|
|
}
|
|
$this->response = $this->client->sendRequest();
|
|
|
|
$content = false;
|
|
if(!$this->wasError()) {
|
|
$content = $this->client->getResponseBody();
|
|
}
|
|
$this->disconnect();
|
|
|
|
return $content;
|
|
}
|
|
|
|
/**
|
|
* Add File to Send with a post
|
|
* @param String file upload fieldname
|
|
* @param Mixed path of file to add
|
|
* @param Mixed file content type of file being uploaded(default : application/octet-stream)
|
|
*/
|
|
function addFiles($inputName, $filePath, $fileContentType = 'application/octet-stream') {
|
|
$this->client->addFile($inputName, $filePath, $fileContentType);
|
|
}
|
|
|
|
/**
|
|
* Did last request resulted in error?
|
|
*/
|
|
function wasError() {
|
|
// calling non-static method statically is throwing error while Cron run
|
|
return $this->_isError();
|
|
}
|
|
|
|
/**
|
|
* Tell whether a value is a PEAR error.
|
|
* @return type
|
|
*/
|
|
function _isError() {
|
|
$pear = new PEAR();
|
|
return $pear->isError($this->response);
|
|
}
|
|
|
|
/**
|
|
* Disconnect this instance
|
|
*/
|
|
function disconnect() {
|
|
$this->client->disconnect();
|
|
}
|
|
}
|
|
?>
|