2009-10-31 22:02:05 +00:00
|
|
|
<?PHP
|
2004-05-02 23:08:19 +00:00
|
|
|
//This file returns the required rss feeds
|
|
|
|
//The URL format MUST include:
|
2010-05-02 11:43:57 +00:00
|
|
|
// context: the context id
|
2004-12-14 18:57:51 +00:00
|
|
|
// user: the user id
|
|
|
|
// name: the name of the module (forum...)
|
|
|
|
// id: the id (instance) of the module (forumid...)
|
2004-05-02 23:08:19 +00:00
|
|
|
//If the course has a password or it doesn't
|
2006-03-17 07:37:27 +00:00
|
|
|
//allow guest access then the user field is
|
2004-05-02 23:08:19 +00:00
|
|
|
//required to see that the user is enrolled
|
|
|
|
//in the course, else no check is performed.
|
|
|
|
//This allows to limit a bit the rss access
|
|
|
|
//to correct users. It isn't unbreakable,
|
|
|
|
//obviously, but its the best I've thought!!
|
|
|
|
|
2009-10-31 22:02:05 +00:00
|
|
|
// disable moodle specific debug messages and any errors in output
|
2010-05-02 11:43:57 +00:00
|
|
|
define('NO_DEBUG_DISPLAY', true);//comment this out to see any error messages during RSS generation
|
|
|
|
|
|
|
|
// session not used here
|
2010-05-02 16:48:41 +00:00
|
|
|
define('NO_MOODLE_COOKIES', true);
|
2010-05-02 11:43:57 +00:00
|
|
|
|
|
|
|
require_once('../config.php');
|
|
|
|
require_once($CFG->libdir.'/filelib.php');
|
|
|
|
require_once($CFG->libdir.'/rsslib.php');
|
|
|
|
|
|
|
|
//Check RSS feeds are enabled
|
|
|
|
if (empty($CFG->enablerssfeeds)) {
|
|
|
|
debugging('DISABLED (admin variables)');
|
|
|
|
rss_not_found();
|
|
|
|
}
|
|
|
|
|
|
|
|
$lifetime = 3600; // Seconds for files to remain in caches - 1 hour
|
|
|
|
$filename = 'rss.xml';
|
|
|
|
|
|
|
|
// this is a big one big hack - NO_MOODLE_COOKIES is not compatible with capabilities MDL-7243
|
|
|
|
// it should be replaced once we get to codes in urls
|
|
|
|
|
|
|
|
$relativepath = get_file_argument();
|
|
|
|
if (!$relativepath) {
|
|
|
|
rss_not_found();
|
|
|
|
}
|
|
|
|
|
|
|
|
// extract relative path components
|
|
|
|
$args = explode('/', trim($relativepath, '/'));
|
|
|
|
if (count($args) < 5) {
|
|
|
|
rss_not_found();
|
|
|
|
}
|
|
|
|
|
|
|
|
$contextid = (int)$args[0];
|
|
|
|
$token = $args[1];
|
|
|
|
$modulename = clean_param($args[2], PARAM_FILE);
|
|
|
|
$instance = $args[3];
|
|
|
|
|
|
|
|
$userid = rss_get_userid_from_token($token);
|
|
|
|
if (!$userid) {
|
|
|
|
rss_not_authenticated();
|
|
|
|
}
|
|
|
|
$user = get_complete_user_data('id', $userid);
|
|
|
|
session_set_user($user);
|
|
|
|
|
|
|
|
$context = get_context_instance_by_id($contextid);
|
|
|
|
if (!$context) {
|
|
|
|
rss_not_found();
|
|
|
|
}
|
|
|
|
$PAGE->set_context($context);
|
|
|
|
|
|
|
|
$coursecontext = get_course_context($context);
|
|
|
|
$course = $DB->get_record('course', array('id' => $coursecontext->instanceid), '*', MUST_EXIST);
|
|
|
|
|
|
|
|
$isblog = ($modulename == 'blog');
|
|
|
|
if ($isblog) {
|
|
|
|
$blogid = (int)$args[4]; // could be groupid / courseid / userid depending on $instance
|
|
|
|
if ($args[5] != 'rss.xml') {
|
|
|
|
$tagid = (int)$args[5];
|
|
|
|
} else {
|
|
|
|
$tagid = 0;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$instance = (int)$instance; // we know it's an id number
|
|
|
|
}
|
|
|
|
|
|
|
|
//Check name of module
|
|
|
|
if (!$isblog) {
|
|
|
|
$mods = get_plugin_list('mod');
|
|
|
|
$mods = array_keys($mods);
|
|
|
|
if (!in_array(strtolower($modulename), $mods)) {
|
2006-03-17 08:20:28 +00:00
|
|
|
rss_not_found();
|
2004-05-02 23:08:19 +00:00
|
|
|
}
|
2010-05-02 11:43:57 +00:00
|
|
|
//Get course_module to check it's visible
|
|
|
|
if (!$cm = get_coursemodule_from_instance($modulename,$instance)) {
|
2006-03-17 08:20:28 +00:00
|
|
|
rss_not_found();
|
2004-05-02 23:08:19 +00:00
|
|
|
}
|
2010-05-02 11:43:57 +00:00
|
|
|
$modcontext = get_context_instance(CONTEXT_MODULE, $cm->id);
|
|
|
|
//will $modcontext always be the same object as $context?
|
|
|
|
$isuser = has_capability('moodle/course:participate', $modcontext);
|
|
|
|
} else {
|
|
|
|
$isuser = has_capability('moodle/course:participate', $coursecontext);
|
|
|
|
}
|
|
|
|
|
|
|
|
//Check if course allows guests
|
|
|
|
if ($course->id != SITEID) {
|
|
|
|
if ((!$course->guest || $course->password) && (!$isuser)) {
|
2006-03-17 08:20:28 +00:00
|
|
|
rss_not_found();
|
2004-05-02 23:08:19 +00:00
|
|
|
}
|
2010-05-02 11:43:57 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
//Check for "security" if the course is hidden or the activity is hidden
|
|
|
|
if (!$isblog and (!$course->visible || !$cm->visible) && (!has_capability('moodle/course:viewhiddenactivities', $context))) {
|
|
|
|
rss_not_found();
|
|
|
|
}
|
|
|
|
|
|
|
|
$pathname = null;
|
|
|
|
//Work out the filename of the cached RSS file
|
|
|
|
if ($isblog) {
|
|
|
|
require_once($CFG->dirroot.'/blog/rsslib.php');
|
|
|
|
$pathname = blog_generate_rss_feed($instance, $blogid, $tagid);
|
|
|
|
} else {
|
|
|
|
$functionname = $cm->modname.'_rss_get_feed';
|
|
|
|
require_once($CFG->dirroot."/mod/{$cm->modname}/rsslib.php");
|
|
|
|
if(function_exists($functionname)) {
|
|
|
|
$pathname = $functionname($context, $cm, $instance, $args);
|
2004-05-02 23:08:19 +00:00
|
|
|
}
|
2010-05-02 11:43:57 +00:00
|
|
|
}
|
2009-11-01 16:48:45 +00:00
|
|
|
|
2010-05-02 11:43:57 +00:00
|
|
|
//Check that file exists
|
|
|
|
if (empty($pathname) || !file_exists($pathname)) {
|
|
|
|
rss_not_found();
|
|
|
|
}
|
2004-05-02 23:08:19 +00:00
|
|
|
|
2010-05-02 11:43:57 +00:00
|
|
|
//rss_update_token_last_access($USER->id);
|
2006-03-17 09:48:24 +00:00
|
|
|
|
2010-05-02 11:43:57 +00:00
|
|
|
//Send it to user!
|
|
|
|
send_file($pathname, $filename, $lifetime);
|
2004-05-02 23:08:19 +00:00
|
|
|
|
2010-05-02 11:43:57 +00:00
|
|
|
function rss_not_found() {
|
|
|
|
/// error, send some XML with error message
|
|
|
|
global $lifetime, $filename;
|
|
|
|
send_file(rss_geterrorxmlfile(), $filename, $lifetime, false, true);
|
|
|
|
}
|
2004-12-14 18:57:51 +00:00
|
|
|
|
2010-05-02 11:43:57 +00:00
|
|
|
function rss_not_authenticated() {
|
|
|
|
global $lifetime, $filename;
|
|
|
|
send_file(rss_geterrorxmlfile('rsserrorauth'), $filename, $lifetime, false, true);
|
|
|
|
}
|
2009-10-31 22:02:05 +00:00
|
|
|
|