contextlevel == CONTEXT_SYSTEM) { if ($filearea === 'blog') { if (empty($CFG->bloglevel)) { print_error('siteblogdisable', 'blog'); } if ($CFG->bloglevel < BLOG_GLOBAL_LEVEL) { require_login(); if (isguestuser()) { print_error('noguest'); } if ($CFG->bloglevel == BLOG_USER_LEVEL) { if ($USER->id != $entry->userid) { send_file_not_found(); } } } $entryid = (int)array_shift($args); if (!$entry = $DB->get_record('post', array('module'=>'blog', 'id'=>$entryid))) { send_file_not_found(); } if ('publishstate' === 'public') { if ($CFG->forcelogin) { require_login(); } } else if ('publishstate' === 'site') { require_login(); //ok } else if ('publishstate' === 'draft') { require_login(); if ($USER->id != $entry->userid) { send_file_not_found(); } } //TODO: implement shared course and shared group access $relativepath = '/'.implode('/', $args); $fullpath = $context->id.'blog'.$entryid.$relativepath; if (!$file = $fs->get_file_by_hash(sha1($fullpath)) or $file->is_directory()) { send_file_not_found(); } send_stored_file($file, 10*60, 0, true); // download MUST be forced - security! } else { send_file_not_found(); } } else if ($context->contextlevel == CONTEXT_USER) { send_file_not_found(); } else if ($context->contextlevel == CONTEXT_COURSECAT) { if ($filearea !== 'coursecat_intro') { send_file_not_found(); } if ($CFG->forcelogin) { // no login necessary - unless login forced everywhere require_login(); } $relativepath = '/'.implode('/', $args); $fullpath = $context->id.'coursecat_intro0'.$relativepath; if (!$file = $fs->get_file_by_hash(sha1($fullpath)) or $file->get_filename() == '.') { send_file_not_found(); } session_write_close(); // unlock session during fileserving send_stored_file($file, 60*60, 0, $forcedownload); } else if ($context->contextlevel == CONTEXT_COURSE) { if (!$course = $DB->get_record('course', array('id'=>$context->instanceid))) { print_error('invalidcourseid'); } if ($filearea === 'course_backup') { require_login($course); require_capability('moodle/site:backupdownload', $context); $relativepath = '/'.implode('/', $args); $fullpath = $context->id.'course_backup0'.$relativepath; if (!$file = $fs->get_file_by_hash(sha1($fullpath)) or $file->is_directory()) { send_file_not_found(); } session_write_close(); // unlock session during fileserving send_stored_file($file, 0, 0, true); } else if ($filearea === 'course_intro') { if ($CFG->forcelogin) { require_login(); } $relativepath = '/'.implode('/', $args); $fullpath = $context->id.'course_intro0'.$relativepath; if (!$file = $fs->get_file_by_hash(sha1($fullpath)) or $file->is_directory()) { send_file_not_found(); } session_write_close(); // unlock session during fileserving send_stored_file($file, 60*60, 0, false); // TODO: change timeout? } else if ($filearea === 'user_profile') { $userid = (int)array_shift($args); $usercontext = get_context_instance(CONTEXT_USER, $userid); if (!empty($CFG->forceloginforprofiles)) { require_login(); if (isguestuser()) { print_error('noguest'); } if (!isteacherinanycourse() and !isteacherinanycourse($userid) and !has_capability('moodle/user:viewdetails', $usercontext)) { print_error('usernotavailable'); } if (!has_capability('moodle/user:viewdetails', $context) && !has_capability('moodle/user:viewdetails', $usercontext)) { print_error('cannotviewprofile'); } if (!has_capability('moodle/course:view', $context, $userid, false)) { print_error('notenrolledprofile'); } if (groups_get_course_groupmode($course) == SEPARATEGROUPS and !has_capability('moodle/site:accessallgroups', $context)) { print_error('groupnotamember'); } } $relativepath = '/'.implode('/', $args); $fullpath = $usercontext->id.'user_profile0'.$relativepath; if (!$file = $fs->get_file_by_hash(sha1($fullpath)) or $file->is_directory()) { send_file_not_found(); } session_write_close(); // unlock session during fileserving send_stored_file($file, 0, 0, true); // must force download - security! } else { send_file_not_found(); } } else if ($context->contextlevel == CONTEXT_MODULE) { if (!$coursecontext = get_context_instance_by_id(get_parent_contextid($context))) { send_file_not_found(); } if (!$course = $DB->get_record('course', array('id'=>$coursecontext->instanceid))) { send_file_not_found(); } $modinfo = get_fast_modinfo($course); if (empty($modinfo->cms[$context->instanceid])) { send_file_not_found(); } $cminfo = $modinfo->cms[$context->instanceid]; $modname = $cminfo->modname; $libfile = "$CFG->dirroot/mod/$modname/lib.php"; if (file_exists($libfile)) { require_once($libfile); $filefunction = $modname.'_pluginfile'; if (function_exists($filefunction)) { if ($filefunction($course, $cminfo, $context, $filearea, $args) !== false) { die; } } } send_file_not_found(); } else if ($context->contextlevel == CONTEXT_BLOCK) { //not supported yet send_file_not_found(); } else { send_file_not_found(); }