2012-10-22 12:15:52 -04:00
|
|
|
<?php
|
2021-01-07 11:40:27 -04:00
|
|
|
|
2012-10-22 12:15:52 -04:00
|
|
|
/**
|
|
|
|
|
* cases_ShowDocument.php
|
|
|
|
|
*
|
2020-01-29 09:54:21 -04:00
|
|
|
* Download documents related to the input document
|
2012-10-22 12:15:52 -04:00
|
|
|
*
|
2020-01-29 09:54:21 -04:00
|
|
|
* @link https://wiki.processmaker.com/3.2/Cases/Documents#Downloading_Files
|
|
|
|
|
* @link https://wiki.processmaker.com/3.3/Cases/Information#Uploaded_Documents
|
2012-10-22 12:15:52 -04:00
|
|
|
*/
|
2017-12-04 13:25:35 +00:00
|
|
|
if (isset($_REQUEST['actionAjax']) && $_REQUEST['actionAjax'] == "verifySession") {
|
2013-10-18 16:54:44 -04:00
|
|
|
if (!isset($_SESSION['USER_LOGGED'])) {
|
2017-12-04 13:25:35 +00:00
|
|
|
if ((isset($_POST['request'])) && ($_POST['request'] == true)) {
|
2013-10-18 16:54:44 -04:00
|
|
|
$response = new stdclass();
|
|
|
|
|
$response->message = G::LoadTranslation('ID_LOGIN_AGAIN');
|
|
|
|
|
$response->lostSession = true;
|
2017-12-04 13:25:35 +00:00
|
|
|
print G::json_encode($response);
|
2013-10-18 16:54:44 -04:00
|
|
|
die();
|
|
|
|
|
} else {
|
2017-12-04 13:25:35 +00:00
|
|
|
G::SendMessageText(G::LoadTranslation('ID_LOGIN_TO_SEE_OUTPUTDOCS'), "WARNING");
|
2013-10-18 16:54:44 -04:00
|
|
|
G::header("location: " . "/");
|
|
|
|
|
die();
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
$response = new stdclass();
|
2017-12-04 13:25:35 +00:00
|
|
|
print G::json_encode($response);
|
2013-10-18 16:54:44 -04:00
|
|
|
die();
|
|
|
|
|
}
|
2013-06-03 18:13:38 -04:00
|
|
|
}
|
2017-12-04 13:25:35 +00:00
|
|
|
require_once("classes/model/AppDocumentPeer.php");
|
2012-10-22 12:15:52 -04:00
|
|
|
$oAppDocument = new AppDocument();
|
2017-03-09 18:09:33 -04:00
|
|
|
|
2017-03-13 13:01:46 -04:00
|
|
|
if (empty($_GET['a'])) {
|
|
|
|
|
G::header('Location: /errors/error403.php');
|
|
|
|
|
die();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (empty($_GET['v'])) {
|
|
|
|
|
//Load last version of the document
|
|
|
|
|
$docVersion = $oAppDocument->getLastAppDocVersion($_GET['a']);
|
|
|
|
|
} else {
|
|
|
|
|
$docVersion = $_GET['v'];
|
|
|
|
|
}
|
|
|
|
|
|
2017-03-10 10:59:49 -04:00
|
|
|
//Check if the user can be download the input Document
|
|
|
|
|
//Send the parameter v = Version
|
|
|
|
|
//Send the parameter a = Case UID
|
2020-06-30 11:23:41 -04:00
|
|
|
$isGuestUser = false;
|
|
|
|
|
if (!empty($_SESSION['GUEST_USER']) && $_SESSION['GUEST_USER'] === RBAC::GUEST_USER_UID) {
|
|
|
|
|
$isGuestUser = true;
|
|
|
|
|
}
|
|
|
|
|
$access = $RBAC->userCanAccess('PM_FOLDERS_ALL') != 1 && defined('DISABLE_DOWNLOAD_DOCUMENTS_SESSION_VALIDATION') && DISABLE_DOWNLOAD_DOCUMENTS_SESSION_VALIDATION == 0;
|
|
|
|
|
if ($access && $isGuestUser === false) {
|
2021-01-12 15:56:01 -04:00
|
|
|
if ((isset($_SESSION['USER_LOGGED']) && !$oAppDocument->canDownloadInput($_SESSION['USER_LOGGED'], $_GET['a'], $docVersion)) || !isset($_SESSION['USER_LOGGED'])) {
|
2020-04-08 15:58:19 -04:00
|
|
|
G::header('Location: /errors/error403.php?url=' . urlencode($_SERVER['REQUEST_URI']));
|
2017-03-10 10:59:49 -04:00
|
|
|
die();
|
|
|
|
|
}
|
2017-03-09 18:09:33 -04:00
|
|
|
}
|
|
|
|
|
|
2017-12-04 13:25:35 +00:00
|
|
|
$oAppDocument->Fields = $oAppDocument->load($_GET['a'], $docVersion);
|
2012-10-22 12:15:52 -04:00
|
|
|
|
|
|
|
|
$sAppDocUid = $oAppDocument->getAppDocUid();
|
|
|
|
|
$iDocVersion = $oAppDocument->getDocVersion();
|
2017-12-04 13:25:35 +00:00
|
|
|
$info = pathinfo($oAppDocument->getAppDocFilename());
|
|
|
|
|
$ext = (isset($info['extension']) ? $info['extension'] : '');//BUG fix: must handle files without any extension
|
2012-10-22 12:15:52 -04:00
|
|
|
|
2017-12-04 13:25:35 +00:00
|
|
|
if (isset($_GET['b'])) {
|
2012-10-22 12:15:52 -04:00
|
|
|
if ($_GET['b'] == '0') {
|
|
|
|
|
$bDownload = false;
|
|
|
|
|
} else {
|
|
|
|
|
$bDownload = true;
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
$bDownload = true;
|
|
|
|
|
}
|
|
|
|
|
|
2013-04-29 16:48:29 -04:00
|
|
|
$app_uid = G::getPathFromUID($oAppDocument->Fields['APP_UID']);
|
|
|
|
|
$file = G::getPathFromFileUID($oAppDocument->Fields['APP_UID'], $sAppDocUid);
|
|
|
|
|
|
2017-12-04 13:25:35 +00:00
|
|
|
$realPath = PATH_DOCUMENT . $app_uid . '/' . $file[0] . $file[1] . '_' . $iDocVersion . '.' . $ext;
|
2013-04-29 16:48:29 -04:00
|
|
|
$realPath1 = PATH_DOCUMENT . $app_uid . '/' . $file[0] . $file[1] . '.' . $ext;
|
2012-10-22 12:15:52 -04:00
|
|
|
$sw_file_exists = false;
|
2017-12-04 13:25:35 +00:00
|
|
|
if (file_exists($realPath)) {
|
2012-10-22 12:15:52 -04:00
|
|
|
$sw_file_exists = true;
|
2017-12-04 13:25:35 +00:00
|
|
|
} elseif (file_exists($realPath1)) {
|
2012-10-22 12:15:52 -04:00
|
|
|
$sw_file_exists = true;
|
|
|
|
|
$realPath = $realPath1;
|
|
|
|
|
}
|
|
|
|
|
|
2017-12-04 13:25:35 +00:00
|
|
|
if (!$sw_file_exists) {
|
|
|
|
|
$error_message = G::LoadTranslation('ID_ERROR_STREAMING_FILE');
|
|
|
|
|
if ((isset($_POST['request'])) && ($_POST['request'] == true)) {
|
2012-10-22 12:15:52 -04:00
|
|
|
$res['success'] = 'failure';
|
|
|
|
|
$res['message'] = $error_message;
|
2017-12-04 13:25:35 +00:00
|
|
|
print G::json_encode($res);
|
2012-10-22 12:15:52 -04:00
|
|
|
} else {
|
2017-12-04 13:25:35 +00:00
|
|
|
G::SendMessageText($error_message, "ERROR");
|
|
|
|
|
$backUrlObj = explode("sys" . config("system.workspace"), $_SERVER['HTTP_REFERER']);
|
|
|
|
|
G::header("location: " . "/sys" . config("system.workspace") . $backUrlObj[1]);
|
2012-10-22 12:15:52 -04:00
|
|
|
die();
|
|
|
|
|
}
|
|
|
|
|
} else {
|
2017-12-04 13:25:35 +00:00
|
|
|
if ((isset($_POST['request'])) && ($_POST['request'] == true)) {
|
2012-10-22 12:15:52 -04:00
|
|
|
$res['success'] = 'success';
|
|
|
|
|
$res['message'] = $oAppDocument->Fields['APP_DOC_FILENAME'];
|
2017-12-04 13:25:35 +00:00
|
|
|
print G::json_encode($res);
|
2012-10-22 12:15:52 -04:00
|
|
|
} else {
|
2015-12-20 10:21:00 -04:00
|
|
|
$nameFile = $oAppDocument->Fields['APP_DOC_FILENAME'];
|
2017-12-04 13:25:35 +00:00
|
|
|
$licensedFeatures = PMLicensedFeatures::getSingleton();
|
2015-12-19 20:23:57 -04:00
|
|
|
$downloadStatus = false;
|
2016-04-21 12:17:13 -04:00
|
|
|
/*----------------------------------********---------------------------------*/
|
2016-01-05 14:52:10 -04:00
|
|
|
if ($licensedFeatures->verifyfeature('AhKNjBEVXZlWUFpWE8wVTREQ0FObmo0aTdhVzhvalFic1M=')) {
|
2015-12-19 20:23:57 -04:00
|
|
|
$drive = new AppDocumentDrive();
|
|
|
|
|
if ($drive->getStatusDrive()) {
|
|
|
|
|
$fieldDrive = $oAppDocument->getAppDocDriveDownload();
|
|
|
|
|
$drive->loadUser($_SESSION['USER_LOGGED']);
|
|
|
|
|
$uidDrive = $drive->changeUrlDrive($oAppDocument->Fields, $oAppDocument->getAppDocType());
|
2015-12-20 10:21:00 -04:00
|
|
|
$fileContent = $drive->download($uidDrive);
|
|
|
|
|
if ($fileContent !== null) {
|
|
|
|
|
$downloadStatus = true;
|
|
|
|
|
header('Content-Description: File Transfer');
|
2017-12-04 13:25:35 +00:00
|
|
|
header('Content-Disposition: attachment; filename=' . $nameFile);
|
2015-12-20 10:21:00 -04:00
|
|
|
header('Content-Transfer-Encoding: binary');
|
|
|
|
|
header('Set-Cookie: fileLoading=true');
|
|
|
|
|
echo $fileContent;
|
|
|
|
|
exit();
|
|
|
|
|
}
|
2015-12-19 20:23:57 -04:00
|
|
|
}
|
|
|
|
|
}
|
2016-04-21 12:17:13 -04:00
|
|
|
/*----------------------------------********---------------------------------*/
|
2015-12-19 20:23:57 -04:00
|
|
|
if (!$downloadStatus) {
|
2017-12-04 13:25:35 +00:00
|
|
|
G::streamFile($realPath, $bDownload, $nameFile); //download
|
2015-12-19 20:23:57 -04:00
|
|
|
}
|
2012-10-22 12:15:52 -04:00
|
|
|
}
|
2021-01-07 11:40:27 -04:00
|
|
|
}
|