Files
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

49 lines
1.9 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.
*************************************************************************************/
/**
* PurchaseOrder Record Model Class
*/
class PurchaseOrder_Record_Model extends Inventory_Record_Model {
/**
* This Function adds the specified product quantity to the Product Quantity in Stock
* @param type $recordId
*/
function addStockToProducts($recordId) {
$db = PearDatabase::getInstance();
$recordModel = Inventory_Record_Model::getInstanceById($recordId);
$relatedProducts = $recordModel->getProducts();
foreach ($relatedProducts as $key => $relatedProduct) {
if($relatedProduct['qty'.$key]){
$productId = $relatedProduct['hdnProductId'.$key];
$result = $db->pquery("SELECT qtyinstock FROM vtiger_products WHERE productid=?", array($productId));
$qty = $db->query_result($result,0,"qtyinstock");
$stock = $qty + $relatedProduct['qty'.$key];
$db->pquery("UPDATE vtiger_products SET qtyinstock=? WHERE productid=?", array($stock, $productId));
}
}
}
/**
* This Function returns the current status of the specified Purchase Order.
* @param type $purchaseOrderId
* @return <String> PurchaseOrderStatus
*/
function getPurchaseOrderStatus($purchaseOrderId){
$db = PearDatabase::getInstance();
$sql = "SELECT postatus FROM vtiger_purchaseorder WHERE purchaseorderid=?";
$result = $db->pquery($sql, array($purchaseOrderId));
$purchaseOrderStatus = $db->query_result($result,0,"postatus");
return $purchaseOrderStatus;
}
}