Chamilo is a learning management system focused on ease of use and accessibility
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
chamilo-lms/main/document/download_uploaded_files.php

35 lines
901 B

<?php
/* For licensing terms, see /license.txt */
session_cache_limiter('none');
require_once __DIR__.'/../inc/global.inc.php';
$this_section = SECTION_COURSES;
// Protection
api_protect_course_script();
$courseCode = isset($_GET['code']) ? $_GET['code'] : '';
$type = isset($_GET['type']) ? $_GET['type'] : '';
$file = isset($_GET['file']) ? $_GET['file'] : '';
$courseInfo = api_get_course_info($courseCode);
if (empty($courseInfo) || empty($type) || empty($file)) {
api_not_allowed(true);
}
$toolPath = api_get_path(SYS_COURSE_PATH).$courseInfo['path'].'/upload/'.$type.'/';
if (!is_dir($toolPath)) {
api_not_allowed(true);
}
if (Security::check_abs_path($toolPath.$file, $toolPath.'/')) {
$fullFilePath = $toolPath.$file;
$result = DocumentManager::file_send_for_download($fullFilePath, false, '');
if ($result === false) {
api_not_allowed(true);
}
}
exit;