parent
3d306c23f0
commit
19e163a2bb
@ -1,123 +0,0 @@ |
||||
<?php |
||||
/* For licensing terms, see /license.txt */ |
||||
/** |
||||
* This file is responsible for passing requested documents to the browser. |
||||
* Many functions updated and moved to lib/document.lib.php. |
||||
* |
||||
* @package chamilo.document |
||||
*/ |
||||
session_cache_limiter('none'); |
||||
|
||||
require_once __DIR__.'/../inc/global.inc.php'; |
||||
$this_section = SECTION_COURSES; |
||||
|
||||
// Protection |
||||
api_protect_course_script(); |
||||
|
||||
$_course = api_get_course_info(); |
||||
|
||||
if (!isset($_course)) { |
||||
api_not_allowed(true); |
||||
} |
||||
|
||||
$doc_url = $_GET['doc_url']; |
||||
// Change the '&' that got rewritten to '///' by mod_rewrite back to '&' |
||||
$doc_url = str_replace('///', '&', $doc_url); |
||||
// Still a space present? it must be a '+' (that got replaced by mod_rewrite) |
||||
$doc_url = str_replace(' ', '+', $doc_url); |
||||
|
||||
$docUrlParts = preg_split('/\/|\\\/', $doc_url); |
||||
$doc_url = ''; |
||||
|
||||
foreach ($docUrlParts as $docUrlPart) { |
||||
if (empty($docUrlPart) || in_array($docUrlPart, ['.', '..', '0'])) { |
||||
continue; |
||||
} |
||||
|
||||
$doc_url .= '/'.$docUrlPart; |
||||
} |
||||
|
||||
if (empty($doc_url)) { |
||||
api_not_allowed( |
||||
!empty($_GET['origin']) && $_GET['origin'] === 'learnpath' |
||||
); |
||||
} |
||||
|
||||
// Dealing with image included into survey: when users receive a link towards a |
||||
// survey while not being authenticated on the platform. |
||||
// The administrator should probably be able to disable this code through admin |
||||
// inteface. |
||||
$refer_script = isset($_SERVER["HTTP_REFERER"]) ? strrchr($_SERVER["HTTP_REFERER"], '/') : null; |
||||
|
||||
$sys_course_path = api_get_path(SYS_COURSE_PATH).$_course['path'].'/document'; |
||||
|
||||
if (substr($refer_script, 0, 15) == '/fillsurvey.php') { |
||||
$invitation = substr(strstr($refer_script, 'invitationcode='), 15); |
||||
$course = strstr($refer_script, 'course='); |
||||
$course = substr($course, 7, strpos($course, '&') - 7); |
||||
include '../survey/survey.download.inc.php'; |
||||
$_course = check_download_survey($course, $invitation, $doc_url); |
||||
$_course['path'] = $_course['directory']; |
||||
} else { |
||||
// If the rewrite rule asks for a directory, we redirect to the document explorer |
||||
if (is_dir($sys_course_path.$doc_url)) { |
||||
// Remove last slash if present |
||||
// mod_rewrite can change /some/path/ to /some/path// in some cases, so clean them all off (René) |
||||
while ($doc_url[$dul = strlen($doc_url) - 1] == '/') { |
||||
$doc_url = substr($doc_url, 0, $dul); |
||||
} |
||||
// Group folder? |
||||
$gid_req = ($_GET['gidReq']) ? '&gidReq='.intval($_GET['gidReq']) : ''; |
||||
// Create the path |
||||
$document_explorer = api_get_path(WEB_CODE_PATH).'document/document.php?curdirpath='.urlencode($doc_url).'&'.api_get_cidreq_params(Security::remove_XSS($_GET['cidReq'], 0, $gid_req)); |
||||
// Redirect |
||||
header('Location: '.$document_explorer); |
||||
exit; |
||||
} |
||||
} |
||||
|
||||
//Fixes swf upload problem in chamilo 1.8.x. When uploading a file with |
||||
//the character "-" the filename was changed from "-" to "_" in the DB for no reason |
||||
$path_info = pathinfo($doc_url); |
||||
|
||||
$fix_file_name = false; |
||||
if (isset($path_info['extension']) && $path_info['extension'] == 'swf') { |
||||
$fixed_url = str_replace('-', '_', $doc_url); |
||||
$doc_id = DocumentManager::get_document_id(api_get_course_info(), $doc_url); |
||||
if (!$doc_id) { |
||||
$doc_id = DocumentManager::get_document_id(api_get_course_info(), $doc_url, '0'); |
||||
if (!$doc_id) { |
||||
$fix_file_name = true; |
||||
} |
||||
} |
||||
} |
||||
|
||||
if (Security::check_abs_path($sys_course_path.$doc_url, $sys_course_path.'/')) { |
||||
$fullFileName = $sys_course_path.$doc_url; |
||||
if ($fix_file_name) { |
||||
$doc_url = $fixed_url; |
||||
} |
||||
// Check visibility of document and paths |
||||
$is_visible = DocumentManager::is_visible($doc_url, $_course, api_get_session_id()); |
||||
|
||||
//Document's slideshow thumbnails |
||||
//correct $is_visible used in below and ??. Now the students can view the thumbnails too |
||||
if (preg_match('/\.thumbs\/\./', $doc_url)) { |
||||
$doc_url_thumbs = str_replace('.thumbs/.', '', $doc_url); |
||||
$is_visible = DocumentManager::is_visible($doc_url_thumbs, $_course, api_get_session_id()); |
||||
} |
||||
|
||||
if (!api_is_allowed_to_edit() && !$is_visible) { |
||||
echo Display::return_message(get_lang('Protected Document'), 'error'); //api_not_allowed backbutton won't work. |
||||
exit; // You shouldn't be here anyway. |
||||
} |
||||
// Launch event |
||||
Event::event_download($doc_url); |
||||
$download = !empty($_GET['dl']) ? true : false; |
||||
|
||||
$result = DocumentManager::file_send_for_download($fullFileName, $download); |
||||
if ($result === false) { |
||||
api_not_allowed(true); |
||||
} |
||||
} |
||||
exit; |
Loading…
Reference in new issue