Files
CRM/modules/CustomerPortal/apis/DownloadFile.php
BACHIR SOULDI 2794e62571 first commit
2025-09-28 08:49:37 +01:00

125 lines
4.9 KiB
PHP

<?php
/* +**********************************************************************************
* The contents of this file are subject to the vtiger CRM Public License Version 1.1
* ("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 CustomerPortal_DownloadFile extends CustomerPortal_API_Abstract {
function process(CustomerPortal_API_Request $request) {
global $adb;
$current_user = $this->getActiveUser();
$response = new CustomerPortal_API_Response();
if ($current_user) {
$parentId = $request->get('parentId');
$recordId = $request->get('recordId');
$module = $request->get('module');
$parentModule = $request->get('parentModule');
if (!CustomerPortal_Utils::isModuleActive($module)) {
$response->setError(1404, 'Module is disabled.');
return $response;
}
if (!empty($parentId)) {
if ($parentModule === 'Faq') {
if (!($this->isFaqPublished($parentId))) {
throw new Exception("This Faq is not published", 1412);
exit;
}
} else {
if (!$this->isRecordAccessible($parentId)) {
throw new Exception("Parent record not Accessible", 1412);
exit;
}
$relatedRecordIds = $this->relatedRecordIds($module, CustomerPortal_Utils::getRelatedModuleLabel($module, $parentModule), $parentId);
if (!in_array($recordId, $relatedRecordIds)) {
throw new Exception("Record not Accessible", 1412);
exit;
}
}
} else {
if (!$this->isRecordAccessible($recordId, $module) && $module != 'ModComments') {
$response->setError(1404, 'Record not accessible');
return $response;
}
}
$idComponents = vtws_getIdComponents($recordId);
$id = $idComponents[1];
if ($module == 'Documents') {
$query = "SELECT filetype FROM vtiger_notes INNER JOIN vtiger_crmentity ON vtiger_notes.notesid= vtiger_crmentity.crmid
WHERE notesid =? AND vtiger_crmentity.deleted=?";
$res = $adb->pquery($query, array($id, '0'));
$filetype = $adb->query_result($res, 0, "filetype");
$this->updateDownloadCount($id);
$fileidQuery = 'SELECT attachmentsid FROM vtiger_seattachmentsrel WHERE crmid = ?';
$fileres = $adb->pquery($fileidQuery, array($id));
$fileid = $adb->query_result($fileres, 0, 'attachmentsid');
$filepathQuery = 'SELECT path,name FROM vtiger_attachments WHERE attachmentsid = ?';
$fileres = $adb->pquery($filepathQuery, array($fileid));
$filepath = $adb->query_result($fileres, 0, 'path');
$filename = $adb->query_result($fileres, 0, 'name');
$filename = decode_html($filename);
$saved_filename = $fileid."_".$filename;
$filenamewithpath = $filepath.$saved_filename;
$filesize = filesize($filenamewithpath);
$fileDetails = array();
$fileDetails['fileid'] = $fileid;
$fileDetails['filename'] = $filename;
$fileDetails['filetype'] = $filetype;
$fileDetails['filesize'] = $filesize;
$fileDetails['filecontents'] = base64_encode(file_get_contents($filenamewithpath));
$response->setResult($fileDetails);
} else if ($module == 'ModComments') {
$attachmentId = $request->get('attachmentId');
$modCommentsRecordModel = Vtiger_Record_Model::getInstanceById($id, $module);
$rawAttachmentDetails = $modCommentsRecordModel->getFileDetails($attachmentId);
//construct path for attachment and get file size and type details
$attachmentDetails = $rawAttachmentDetails[0];
$fileid = $attachmentDetails['attachmentsid'];
$filename = $attachmentDetails['name'];
$filepath = $attachmentDetails['path'];
$saved_filename = $fileid."_".$filename;
$filenamewithpath = $filepath.$saved_filename;
$filesize = filesize($filenamewithpath);
$filetype = $attachmentDetails['type'];
//Construct array with all attachment details
$fileDetails = array();
$fileDetails['fileid'] = $fileid;
$fileDetails['filename'] = $filename;
$fileDetails['filetype'] = $filetype;
$fileDetails['filesize'] = $filesize;
$fileDetails['filecontents'] = base64_encode(file_get_contents($filenamewithpath));
$response->setResult($fileDetails);
} else {
throw new Exception("Download not supported.", 1412);
exit;
}
return $response;
}
}
/**
* Function to update the download count of a file
*/
function updateDownloadCount($id) {
global $adb, $log;
$log->debug("Entering customer portal function updateDownloadCount");
$updateDownloadCount = "UPDATE vtiger_notes SET filedownloadcount = filedownloadcount+1 WHERE notesid = ?";
$countres = $adb->pquery($updateDownloadCount, array($id));
$log->debug("Entering customer portal function updateDownloadCount");
return true;
}
}