2009-09-04 00:36:43 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
// This file is part of Moodle - http://moodle.org/
|
|
|
|
//
|
|
|
|
// Moodle is free software: you can redistribute it and/or modify
|
|
|
|
// it under the terms of the GNU General Public License as published by
|
|
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
|
|
// (at your option) any later version.
|
|
|
|
//
|
|
|
|
// Moodle is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU General Public License for more details.
|
|
|
|
//
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
|
|
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Core global functions for Blog.
|
|
|
|
*
|
|
|
|
* @package moodlecore
|
|
|
|
* @subpackage blog
|
|
|
|
* @copyright 2009 Nicolas Connault
|
|
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Library of functions and constants for blog
|
|
|
|
*/
|
|
|
|
require_once($CFG->dirroot .'/blog/rsslib.php');
|
|
|
|
require_once($CFG->dirroot.'/tag/lib.php');
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Definition of blogcourse page type (blog page with course id present).
|
|
|
|
*/
|
|
|
|
//not used at the moment, and may not need to be
|
|
|
|
define('PAGE_BLOG_COURSE_VIEW', 'blog_course-view');
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Checks to see if user has visited blogpages before, if not, install 2
|
|
|
|
* default blocks (blog_menu and blog_tags).
|
|
|
|
*/
|
|
|
|
function blog_check_and_install_blocks() {
|
|
|
|
global $USER, $DB;
|
|
|
|
|
|
|
|
if (isloggedin() && !isguest()) {
|
|
|
|
// if this user has not visited this page before
|
|
|
|
if (!get_user_preferences('blogpagesize')) {
|
|
|
|
// find the correct ids for blog_menu and blog_from blocks
|
|
|
|
$menublock = $DB->get_record('block', array('name'=>'blog_menu'));
|
|
|
|
$tagsblock = $DB->get_record('block', array('name'=>'blog_tags'));
|
|
|
|
// add those 2 into block_instance page
|
2006-04-20 06:35:39 +00:00
|
|
|
|
2009-05-07 08:55:10 +00:00
|
|
|
// Commmented out since the block changes broke it. Hopefully nico will fix it ;-)
|
|
|
|
// // add blog_menu block
|
|
|
|
// $newblock = new object();
|
|
|
|
// $newblock->blockid = $menublock->id;
|
|
|
|
// $newblock->pageid = $USER->id;
|
|
|
|
// $newblock->pagetype = 'blog-view';
|
|
|
|
// $newblock->position = 'r';
|
|
|
|
// $newblock->weight = 0;
|
|
|
|
// $newblock->visible = 1;
|
|
|
|
// $DB->insert_record('block_instances', $newblock);
|
|
|
|
//
|
|
|
|
// // add blog_tags menu
|
|
|
|
// $newblock -> blockid = $tagsblock->id;
|
|
|
|
// $newblock -> weight = 1;
|
|
|
|
// $DB->insert_record('block_instances', $newblock);
|
2006-04-20 06:35:39 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
// finally we set the page size pref
|
|
|
|
set_user_preference('blogpagesize', 10);
|
2006-04-20 06:35:39 +00:00
|
|
|
}
|
|
|
|
}
|
2009-09-04 00:36:43 +00:00
|
|
|
}
|
2006-04-20 06:35:39 +00:00
|
|
|
|
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
/**
|
|
|
|
* User can edit a blog entry if this is their own blog entry and they have
|
|
|
|
* the capability moodle/blog:create, or if they have the capability
|
|
|
|
* moodle/blog:manageentries.
|
|
|
|
*
|
|
|
|
* This also applies to deleting of entries.
|
|
|
|
*/
|
|
|
|
function blog_user_can_edit_entry($blog_entry) {
|
|
|
|
global $CFG, $USER, $OUTPUT;
|
2006-04-12 08:58:49 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
$sitecontext = get_context_instance(CONTEXT_SYSTEM);
|
2006-03-10 06:53:01 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
if (has_capability('moodle/blog:manageentries', $sitecontext)) {
|
|
|
|
return true; // can edit any blog entry
|
|
|
|
}
|
2006-04-12 02:05:46 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
if ($blog_entry->userid == $USER->id
|
|
|
|
and has_capability('moodle/blog:create', $sitecontext)) {
|
|
|
|
return true; // can edit own when having blog:create capability
|
|
|
|
}
|
2006-03-10 06:53:01 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
return false;
|
|
|
|
}
|
2007-08-23 14:58:15 +00:00
|
|
|
|
2009-08-07 01:41:27 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
/**
|
|
|
|
* Checks to see if a user can view the blogs of another user.
|
|
|
|
* Only blog level is checked here, the capabilities are enforced
|
|
|
|
* in blog/index.php
|
|
|
|
*/
|
|
|
|
function blog_user_can_view_user_entry($targetuserid, $blog_entry=null) {
|
|
|
|
global $CFG, $USER, $DB;
|
2006-04-12 02:05:46 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
if (empty($CFG->bloglevel)) {
|
|
|
|
return false; // blog system disabled
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!empty($USER->id) and $USER->id == $targetuserid) {
|
|
|
|
return true; // can view own entries in any case
|
|
|
|
}
|
|
|
|
|
|
|
|
$sitecontext = get_context_instance(CONTEXT_SYSTEM);
|
|
|
|
if (has_capability('moodle/blog:manageentries', $sitecontext)) {
|
|
|
|
return true; // can manage all entries
|
|
|
|
}
|
2006-04-12 02:05:46 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
// coming for 1 entry, make sure it's not a draft
|
|
|
|
if ($blog_entry and $blog_entry->publishstate == 'draft') {
|
|
|
|
return false; // can not view draft of others
|
|
|
|
}
|
|
|
|
|
|
|
|
// coming for 1 entry, make sure user is logged in, if not a public blog
|
|
|
|
if ($blog_entry && $blog_entry->publishstate != 'public' && !isloggedin()) {
|
|
|
|
return false;
|
|
|
|
}
|
2007-08-23 14:58:15 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
switch ($CFG->bloglevel) {
|
|
|
|
case BLOG_GLOBAL_LEVEL:
|
|
|
|
return true;
|
|
|
|
break;
|
2006-04-12 02:05:46 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
case BLOG_SITE_LEVEL:
|
|
|
|
if (!empty($USER->id)) { // not logged in viewers forbidden
|
|
|
|
return true;
|
2006-04-12 02:05:46 +00:00
|
|
|
}
|
2009-09-04 00:36:43 +00:00
|
|
|
return false;
|
|
|
|
break;
|
2007-08-23 14:58:15 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
case BLOG_USER_LEVEL:
|
|
|
|
default:
|
|
|
|
$personalcontext = get_context_instance(CONTEXT_USER, $targetuserid);
|
|
|
|
return has_capability('moodle/user:readuserblogs', $personalcontext);
|
|
|
|
break;
|
2006-03-10 06:53:01 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* remove all associations for the blog entries of a particular user
|
|
|
|
* @param int userid - id of user whose blog associations will be deleted
|
|
|
|
*/
|
|
|
|
function blog_remove_associations_for_user($userid) {
|
|
|
|
global $DB;
|
|
|
|
foreach(blog_fetch_entries(array('user' => $userid), 'lasmodified DESC') as $entry) {
|
|
|
|
blog_remove_associations_for_entry($entry->id);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* generates the url of the page displaying entries matching the search criteria
|
|
|
|
* @param array filters an array of filters (filtername => filtervalue) to narrow down results by
|
|
|
|
* available filters:
|
|
|
|
* entry: id field of a specific entry
|
|
|
|
* course: id of a course that the entries must be associated with
|
|
|
|
* mod: id of a course module that the entries must be associated with
|
|
|
|
* user: id of a user who must be the author of an entry
|
|
|
|
* group: id of a group who the author must be a member of, and whose course must be associated with the entry
|
|
|
|
* tag: id of a tag that must be applied to the entry
|
|
|
|
* site: the entire site is searched
|
|
|
|
* @return string the url of the page displaying entries matching the search criteria
|
|
|
|
*/
|
|
|
|
function blog_get_blogs_url($filters) {
|
|
|
|
global $CFG;
|
2009-09-09 03:26:18 +00:00
|
|
|
$blogsurl = new moodle_url($CFG->wwwroot . '/blog/index.php');
|
|
|
|
if (!empty($filters['course'])) {
|
|
|
|
$blogsurl->param('courseid', $filters['course']);
|
|
|
|
}
|
|
|
|
if (!empty($filters['mod'])) {
|
|
|
|
$blogsurl->param('modid', $filters['mod']);
|
|
|
|
}
|
|
|
|
if (!empty($filters['group'])) {
|
|
|
|
$blogsurl->param('groupid', $filters['group']);
|
|
|
|
}
|
|
|
|
if (!empty($filters['user'])) {
|
|
|
|
$blogsurl->param('userid', $filters['user']);
|
|
|
|
}
|
|
|
|
if (!empty($filters['entry'])) {
|
|
|
|
$blogsurl->param('entryid', $filters['entry']);
|
|
|
|
}
|
|
|
|
if (!empty($filters['tag'])) {
|
|
|
|
$blogsurl->param('tagid', $filters['tag']);
|
|
|
|
}
|
|
|
|
if (!empty($filters['tagtext'])) {
|
|
|
|
$blogsurl->param('tag', $filters['tagtext']);
|
|
|
|
}
|
|
|
|
return $blogsurl;
|
2009-09-04 00:36:43 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A simple function for checking if a given URL is valid and resolves
|
|
|
|
* to a proper XML data stream.
|
|
|
|
*
|
|
|
|
* @param string $url
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
function blog_is_valid_url($url) {
|
|
|
|
$url = @parse_url($url);
|
|
|
|
|
|
|
|
if (!$url) {
|
|
|
|
return false;
|
|
|
|
}
|
2006-04-12 06:04:06 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
$url = array_map('trim', $url);
|
2006-03-10 06:53:01 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
if (empty($url['port'])) {
|
|
|
|
$url['port'] = 80;
|
|
|
|
} else {
|
|
|
|
$url['port'] = (int)$url['port'];
|
|
|
|
}
|
2006-03-10 06:53:01 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
$path = '';
|
|
|
|
if (!empty($url['path'])) {
|
|
|
|
$path = $url['path'];
|
|
|
|
}
|
2006-03-10 06:53:01 +00:00
|
|
|
|
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
if ($path == '') {
|
|
|
|
$path = '/';
|
|
|
|
}
|
2006-03-10 06:53:01 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
if (!empty($url['query'])) {
|
|
|
|
$path .= "?{$url['query']}";
|
|
|
|
}
|
2007-08-23 14:58:15 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
if (isset($url['host']) && $url['host'] != gethostbyname($url['host'])) {
|
|
|
|
if (PHP_VERSION >= 5) {
|
|
|
|
$headers = get_headers("{$url['scheme']}://{$url['host']}:{$url['port']}$path");
|
2006-11-20 08:31:48 +00:00
|
|
|
} else {
|
2009-09-04 00:36:43 +00:00
|
|
|
$fp = fsockopen($url['host'], $url['port'], $errno, $errstr, 30);
|
2006-03-10 06:53:01 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
if (!$fp) {
|
|
|
|
return false;
|
|
|
|
}
|
2006-03-10 06:53:01 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
fputs($fp, "HEAD $path HTTP/1.1\r\nHost: {$url['host']}\r\n\r\n");
|
|
|
|
$headers = fread($fp, 128);
|
|
|
|
fclose($fp);
|
2006-03-10 06:53:01 +00:00
|
|
|
}
|
2006-04-12 02:05:46 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
if (is_array($headers)) {
|
|
|
|
$headers = implode("\n", $headers);
|
2008-07-07 03:21:52 +00:00
|
|
|
}
|
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
return (bool) preg_match('#^HTTP/.*\s+[(200|301|302)]+\s#i', $headers);
|
2006-03-10 06:53:01 +00:00
|
|
|
}
|
2009-09-04 00:36:43 +00:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2006-10-06 10:11:52 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
/**
|
|
|
|
* Given a record in the {blog_external} table, checks the blog's URL
|
|
|
|
* for new entries not yet copied into Moodle.
|
|
|
|
*
|
|
|
|
* @param object $external_blog
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
function blog_fetch_external_entries($external_blog) {
|
|
|
|
global $CFG, $DB;
|
2009-09-04 07:09:45 +00:00
|
|
|
require_once($CFG->libdir . '/simplepie/moodle_simplepie.php');
|
2006-03-10 06:53:01 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
if (!blog_is_valid_url($external_blog->url)) {
|
|
|
|
return null;
|
2006-04-12 02:05:46 +00:00
|
|
|
}
|
2006-03-10 06:53:01 +00:00
|
|
|
|
2009-09-04 07:09:45 +00:00
|
|
|
$rss = new moodle_simplepie($external_blog->url);
|
2006-04-12 02:05:46 +00:00
|
|
|
|
2009-09-04 07:09:45 +00:00
|
|
|
if (empty($rss->data)) {
|
2009-09-04 00:36:43 +00:00
|
|
|
return null;
|
|
|
|
}
|
2006-05-01 05:33:47 +00:00
|
|
|
|
2009-09-04 07:09:45 +00:00
|
|
|
foreach ($rss->get_items() as $entry) {
|
2009-09-04 00:36:43 +00:00
|
|
|
$params = array('userid' => $external_blog->userid,
|
|
|
|
'module' => 'blog',
|
2009-09-04 07:09:45 +00:00
|
|
|
'uniquehash' => $entry->get_permalink(),
|
2009-09-04 00:36:43 +00:00
|
|
|
'publishstate' => 'site',
|
|
|
|
'format' => FORMAT_HTML);
|
2006-04-12 02:05:46 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
if (!$DB->record_exists('post', $params)) {
|
2009-09-04 07:09:45 +00:00
|
|
|
$params['subject'] = $entry->get_title();
|
|
|
|
$params['summary'] = $entry->get_description();
|
|
|
|
$params['created'] = $entry->get_date('U');
|
|
|
|
$params['lastmodified'] = $entry->get_date('U');
|
2006-04-12 02:05:46 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
$id = $DB->insert_record('post', $params);
|
2006-10-06 10:11:52 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
// Set tags
|
|
|
|
if ($tags = tag_get_tags_array('blog_external', $external_blog->id)) {
|
|
|
|
tag_set('post', $id, $tags);
|
2006-04-12 02:05:46 +00:00
|
|
|
}
|
|
|
|
}
|
2009-09-04 00:36:43 +00:00
|
|
|
}
|
2006-04-12 02:05:46 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
$DB->update_record('blog_external', array('id' => $external_blog->id, 'timefetched' => mktime()));
|
|
|
|
}
|
2007-08-23 14:58:15 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
/**
|
|
|
|
* Returns a URL based on the context of the current page.
|
|
|
|
* This URL points to blog/index.php and includes filter parameters appropriate for the current page.
|
|
|
|
*
|
|
|
|
* @param stdclass $context
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
function blog_get_context_url($context=null) {
|
|
|
|
global $CFG;
|
2006-04-12 02:05:46 +00:00
|
|
|
|
2009-09-09 03:26:18 +00:00
|
|
|
$viewblogentriesurl = new moodle_url($CFG->wwwroot . '/blog/index.php');
|
2006-04-12 02:05:46 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
if (empty($context)) {
|
|
|
|
global $PAGE;
|
|
|
|
$context = $PAGE->get_context();
|
|
|
|
}
|
2006-04-12 02:05:46 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
// Change contextlevel to SYSTEM if viewing the site course
|
|
|
|
if ($context->contextlevel == CONTEXT_COURSE && $context->instanceid == SITEID) {
|
|
|
|
$context->contextlevel = CONTEXT_SYSTEM;
|
|
|
|
}
|
2006-04-12 02:05:46 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
$filterparam = '';
|
|
|
|
$strlevel = '';
|
2006-04-12 02:05:46 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
switch ($context->contextlevel) {
|
|
|
|
case CONTEXT_SYSTEM:
|
|
|
|
case CONTEXT_BLOCK:
|
|
|
|
case CONTEXT_COURSECAT:
|
2006-04-12 02:05:46 +00:00
|
|
|
break;
|
2009-09-04 00:36:43 +00:00
|
|
|
case CONTEXT_COURSE:
|
|
|
|
$filterparam = 'courseid';
|
|
|
|
$strlevel = get_string('course');
|
2006-04-12 02:05:46 +00:00
|
|
|
break;
|
2009-09-04 00:36:43 +00:00
|
|
|
case CONTEXT_MODULE:
|
|
|
|
$filterparam = 'modid';
|
|
|
|
$strlevel = print_context_name($context);
|
2006-04-12 02:05:46 +00:00
|
|
|
break;
|
2009-09-04 00:36:43 +00:00
|
|
|
case CONTEXT_USER:
|
|
|
|
$filterparam = 'userid';
|
|
|
|
$strlevel = get_string('user');
|
2006-04-12 02:05:46 +00:00
|
|
|
break;
|
2006-03-17 07:38:08 +00:00
|
|
|
}
|
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
if (!empty($filterparam)) {
|
2009-09-09 03:26:18 +00:00
|
|
|
$viewblogentriesurl->param($filterparam, $context->instanceid);
|
2009-09-04 00:36:43 +00:00
|
|
|
}
|
2006-08-08 05:13:06 +00:00
|
|
|
|
2009-09-09 03:26:18 +00:00
|
|
|
return $viewblogentriesurl;
|
2009-09-04 00:36:43 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This function encapsulates all the logic behind the complex
|
|
|
|
* navigation, titles and headings of the blog listing page, depending
|
|
|
|
* on URL params. It builds and returns an array containing:
|
|
|
|
*
|
2009-09-04 03:40:01 +00:00
|
|
|
* 1. The heading displayed above the blog entries
|
|
|
|
* All other variables are set directly in $PAGE
|
2009-09-04 00:36:43 +00:00
|
|
|
*
|
|
|
|
* It uses the current URL to build these variables.
|
|
|
|
* A number of mutually exclusive use cases are used to structure this function.
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
function blog_get_headers() {
|
|
|
|
global $CFG, $PAGE, $DB, $USER;
|
|
|
|
|
2009-09-08 03:05:09 +00:00
|
|
|
$id = optional_param('id', null, PARAM_INT);
|
2009-09-04 00:36:43 +00:00
|
|
|
$tag = optional_param('tag', null, PARAM_NOTAGS);
|
|
|
|
$tagid = optional_param('tagid', null, PARAM_INT);
|
|
|
|
$userid = optional_param('userid', null, PARAM_INT);
|
|
|
|
$modid = optional_param('modid', null, PARAM_INT);
|
|
|
|
$entryid = optional_param('entryid', null, PARAM_INT);
|
|
|
|
$groupid = optional_param('groupid', null, PARAM_INT);
|
|
|
|
$courseid = optional_param('courseid', null, PARAM_INT);
|
|
|
|
$search = optional_param('search', null, PARAM_RAW);
|
|
|
|
$action = optional_param('action', null, PARAM_ALPHA);
|
|
|
|
$confirm = optional_param('confirm', false, PARAM_BOOL);
|
|
|
|
|
2009-09-07 10:01:26 +00:00
|
|
|
$headers = array('title' => '', 'heading' => '', 'cm' => null);
|
2009-09-04 00:36:43 +00:00
|
|
|
|
|
|
|
$blog_url = new moodle_url($CFG->wwwroot . '/blog/index.php');
|
|
|
|
$site = $DB->get_record('course', array('id' => SITEID));
|
|
|
|
|
|
|
|
// Common Lang strings
|
|
|
|
$strparticipants = get_string("participants");
|
|
|
|
$strblogentries = get_string("blogentries", 'blog');
|
|
|
|
|
|
|
|
// Prepare record objects as needed
|
|
|
|
if (!empty($courseid)) {
|
|
|
|
$course = $DB->get_record('course', array('id' => $courseid));
|
|
|
|
}
|
2006-10-06 10:11:52 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
if (!empty($userid)) {
|
|
|
|
$user = $DB->get_record('user', array('id' => $userid));
|
2006-03-17 07:38:08 +00:00
|
|
|
}
|
2006-08-08 05:13:06 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
if (!empty($groupid)) { // groupid always overrides courseid
|
|
|
|
$group = $DB->get_record('groups', array('id' => $groupid));
|
|
|
|
$course = $DB->get_record('course', array('id' => $group->courseid));
|
|
|
|
}
|
2006-08-08 05:13:06 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
if (!empty($modid)) { // modid always overrides courseid, so the $course object may be reset here
|
|
|
|
// A groupid param may conflict with this coursemod's courseid. Ignore groupid in that case
|
|
|
|
$course_id = $DB->get_field('course_modules', 'course', array('id'=>$modid));
|
|
|
|
$course = $DB->get_record('course', array('id' => $course_id));
|
|
|
|
$cm = $DB->get_record('course_modules', array('id' => $modid));
|
|
|
|
$cm->modname = $DB->get_field('modules', 'name', array('id' => $cm->module));
|
|
|
|
$cm->name = $DB->get_field($cm->modname, 'name', array('id' => $cm->instance));
|
2009-09-04 03:40:01 +00:00
|
|
|
$cm->context = get_context_instance(CONTEXT_MODULE, $modid);
|
|
|
|
$PAGE->set_cm($cm, $course);
|
2009-09-04 00:36:43 +00:00
|
|
|
}
|
2009-09-11 07:00:43 +00:00
|
|
|
|
|
|
|
// Case 0: No entry, mod, course or user params: all site entries to be shown (filtered by search and tag/tagid)
|
|
|
|
if (empty($entryid) && empty($modid) && empty($courseid) && empty($userid)) {
|
|
|
|
$PAGE->navbar->add($strblogentries, $blog_url);
|
|
|
|
$PAGE->set_title("$site->shortname: " . get_string('blog', 'blog'));
|
|
|
|
$PAGE->set_heading("$site->shortname: " . get_string('blog', 'blog'));
|
|
|
|
$headers['heading'] = get_string('siteblog', 'blog');
|
|
|
|
}
|
2006-04-12 02:05:46 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
// Case 1: only entryid is requested, ignore all other filters. courseid is used to give more contextual information
|
|
|
|
if (!empty($entryid)) {
|
|
|
|
$sql = 'SELECT u.* FROM {user} u, {post} p WHERE p.id = ? AND p.userid = u.id';
|
|
|
|
$user = $DB->get_record_sql($sql, array($entryid));
|
|
|
|
$entry = $DB->get_record('post', array('id' => $entryid));
|
2006-04-12 02:05:46 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
$blog_url->param('userid', $user->id);
|
2006-04-12 02:05:46 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
if (!empty($course)) {
|
2009-09-08 03:05:09 +00:00
|
|
|
$mycourseid = $course->id;
|
|
|
|
$blog_url->param('courseid', $mycourseid);
|
2006-04-12 02:05:46 +00:00
|
|
|
} else {
|
2009-09-08 03:05:09 +00:00
|
|
|
$mycourseid = $site->id;
|
2006-04-12 02:05:46 +00:00
|
|
|
}
|
2009-09-04 07:09:45 +00:00
|
|
|
|
2009-09-08 03:05:09 +00:00
|
|
|
$PAGE->navbar->add($strparticipants, "$CFG->wwwroot/user/index.php?id=$mycourseid");
|
2009-09-04 03:40:01 +00:00
|
|
|
$PAGE->navbar->add(fullname($user), "$CFG->wwwroot/user/view.php?id=$user->id");
|
2009-09-08 03:05:09 +00:00
|
|
|
$PAGE->navbar->add($strblogentries, $blog_url);
|
|
|
|
$blog_url->param('entryid', $entryid);
|
|
|
|
$blog_url->remove_params('userid');
|
|
|
|
$PAGE->navbar->add($entry->subject, $blog_url);
|
2009-09-04 03:40:01 +00:00
|
|
|
|
|
|
|
$PAGE->set_title("$site->shortname: " . fullname($user) . ": $entry->subject");
|
|
|
|
$PAGE->set_heading("$site->shortname: " . fullname($user) . ": $entry->subject");
|
2009-09-04 00:36:43 +00:00
|
|
|
$headers['heading'] = get_string('blogentrybyuser', 'blog', fullname($user));
|
|
|
|
|
|
|
|
// We ignore tag and search params
|
2009-09-08 03:05:09 +00:00
|
|
|
if (empty($action)) {
|
|
|
|
return $headers;
|
|
|
|
}
|
2006-04-12 02:05:46 +00:00
|
|
|
}
|
2008-04-13 01:17:30 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
// Case 2: A user's blog entries
|
2009-09-08 03:05:09 +00:00
|
|
|
if (!empty($userid) && empty($modid) && empty($courseid) && empty($entryid)) {
|
2009-09-04 00:36:43 +00:00
|
|
|
$blog_url->param('userid', $userid);
|
2009-09-04 03:40:01 +00:00
|
|
|
$PAGE->navbar->add($strparticipants, "$CFG->wwwroot/user/index.php?id=$site->id");
|
|
|
|
$PAGE->navbar->add(fullname($user), "$CFG->wwwroot/user/view.php?id=$user->id");
|
2009-09-08 03:05:09 +00:00
|
|
|
$PAGE->navbar->add($strblogentries, $blog_url);
|
2009-09-04 03:40:01 +00:00
|
|
|
$PAGE->set_title("$site->shortname: " . fullname($user) . ": " . get_string('blog', 'blog'));
|
|
|
|
$PAGE->set_heading("$site->shortname: " . fullname($user) . ": " . get_string('blog', 'blog'));
|
2009-09-04 00:36:43 +00:00
|
|
|
$headers['heading'] = get_string('userblog', 'blog', fullname($user));
|
|
|
|
|
|
|
|
} else
|
|
|
|
|
|
|
|
// Case 3: Blog entries associated with an activity by a specific user (courseid ignored)
|
2009-09-08 03:05:09 +00:00
|
|
|
if (!empty($userid) && !empty($modid) && empty($entryid)) {
|
2009-09-04 00:36:43 +00:00
|
|
|
$blog_url->param('userid', $userid);
|
|
|
|
$blog_url->param('modid', $modid);
|
|
|
|
|
|
|
|
// Course module navigation is handled by build_navigation as the second param
|
|
|
|
$headers['cm'] = $cm;
|
2009-09-04 03:40:01 +00:00
|
|
|
$PAGE->navbar->add(fullname($user), "$CFG->wwwroot/user/view.php?id=$user->id");
|
2009-09-08 03:05:09 +00:00
|
|
|
$PAGE->navbar->add($strblogentries, $blog_url);
|
2009-09-04 00:36:43 +00:00
|
|
|
|
2009-09-04 03:40:01 +00:00
|
|
|
$PAGE->set_title("$site->shortname: $cm->name: " . fullname($user) . ': ' . get_string('blogentries', 'blog'));
|
|
|
|
$PAGE->set_heading("$site->shortname: $cm->name: " . fullname($user) . ': ' . get_string('blogentries', 'blog'));
|
2009-09-04 00:36:43 +00:00
|
|
|
|
|
|
|
$a->user = fullname($user);
|
|
|
|
$a->mod = $cm->name;
|
|
|
|
$headers['heading'] = get_string('blogentriesbyuseraboutmodule', 'blog', $a);
|
|
|
|
} else
|
|
|
|
|
|
|
|
// Case 4: Blog entries associated with a course by a specific user
|
2009-09-08 03:05:09 +00:00
|
|
|
if (!empty($userid) && !empty($courseid) && empty($modid) && empty($entryid)) {
|
2009-09-04 00:36:43 +00:00
|
|
|
$blog_url->param('userid', $userid);
|
|
|
|
$blog_url->param('courseid', $courseid);
|
|
|
|
|
2009-09-04 03:40:01 +00:00
|
|
|
$PAGE->navbar->add($strparticipants, "$CFG->wwwroot/user/index.php?id=$course->id");
|
|
|
|
$PAGE->navbar->add(fullname($user), "$CFG->wwwroot/user/view.php?id=$user->id");
|
2009-09-08 03:05:09 +00:00
|
|
|
$PAGE->navbar->add($strblogentries, $blog_url);
|
2009-09-04 00:36:43 +00:00
|
|
|
|
2009-09-04 03:40:01 +00:00
|
|
|
$PAGE->set_title("$site->shortname: $course->shortname: " . fullname($user) . ': ' . get_string('blogentries', 'blog'));
|
|
|
|
$PAGE->set_heading("$site->shortname: $course->shortname: " . fullname($user) . ': ' . get_string('blogentries', 'blog'));
|
2009-09-04 00:36:43 +00:00
|
|
|
|
|
|
|
$a->user = fullname($user);
|
|
|
|
$a->course = $course->fullname;
|
|
|
|
$headers['heading'] = get_string('blogentriesbyuseraboutcourse', 'blog', $a);
|
|
|
|
} else
|
|
|
|
|
|
|
|
// Case 5: Blog entries by members of a group, associated with that group's course
|
2009-09-08 03:05:09 +00:00
|
|
|
if (!empty($groupid) && empty($modid) && empty($entryid)) {
|
2009-09-04 00:36:43 +00:00
|
|
|
$blog_url->param('courseid', $course->id);
|
2009-09-04 07:09:45 +00:00
|
|
|
|
2009-09-08 03:05:09 +00:00
|
|
|
$PAGE->navbar->add($strblogentries, $blog_url);
|
2009-09-04 00:36:43 +00:00
|
|
|
$blog_url->remove_params(array('courseid'));
|
|
|
|
$blog_url->param('groupid', $groupid);
|
2009-09-08 03:05:09 +00:00
|
|
|
$PAGE->navbar->add($group->name, $blog_url);
|
2009-09-04 00:36:43 +00:00
|
|
|
|
2009-09-04 03:40:01 +00:00
|
|
|
$PAGE->set_title("$site->shortname: $course->shortname: " . get_string('blogentries', 'blog') . ": $group->name");
|
|
|
|
$PAGE->set_heading("$site->shortname: $course->shortname: " . get_string('blogentries', 'blog') . ": $group->name");
|
2009-09-04 00:36:43 +00:00
|
|
|
|
|
|
|
$a->group = $group->name;
|
|
|
|
$a->course = $course->fullname;
|
|
|
|
$headers['heading'] = get_string('blogentriesbygroupaboutcourse', 'blog', $a);
|
|
|
|
} else
|
|
|
|
|
|
|
|
// Case 6: Blog entries by members of a group, associated with an activity in that course
|
2009-09-08 03:05:09 +00:00
|
|
|
if (!empty($groupid) && !empty($modid) && empty($entryid)) {
|
2009-09-04 00:36:43 +00:00
|
|
|
$headers['cm'] = $cm;
|
|
|
|
$blog_url->param('modid', $modid);
|
2009-09-08 03:05:09 +00:00
|
|
|
$PAGE->navbar->add($strblogentries, $blog_url);
|
2009-09-04 00:36:43 +00:00
|
|
|
|
|
|
|
$blog_url->param('groupid', $groupid);
|
2009-09-08 03:05:09 +00:00
|
|
|
$PAGE->navbar->add($group->name, $blog_url);
|
2009-09-04 00:36:43 +00:00
|
|
|
|
2009-09-04 03:40:01 +00:00
|
|
|
$PAGE->set_title("$site->shortname: $course->shortname: $cm->name: " . get_string('blogentries', 'blog') . ": $group->name");
|
|
|
|
$PAGE->set_heading("$site->shortname: $course->shortname: $cm->name: " . get_string('blogentries', 'blog') . ": $group->name");
|
2009-09-04 00:36:43 +00:00
|
|
|
|
|
|
|
$a->group = $group->name;
|
|
|
|
$a->mod = $cm->name;
|
|
|
|
$headers['heading'] = get_string('blogentriesbygroupaboutmodule', 'blog', $a);
|
|
|
|
|
|
|
|
} else
|
|
|
|
|
|
|
|
// Case 7: All blog entries associated with an activity
|
2009-09-08 03:05:09 +00:00
|
|
|
if (!empty($modid) && empty($userid) && empty($groupid) && empty($entryid)) {
|
2009-09-04 03:40:01 +00:00
|
|
|
$PAGE->set_cm($cm, $course);
|
2009-09-04 00:36:43 +00:00
|
|
|
$blog_url->param('modid', $modid);
|
2009-09-08 03:05:09 +00:00
|
|
|
$PAGE->navbar->add($strblogentries, $blog_url);
|
2009-09-04 03:40:01 +00:00
|
|
|
$PAGE->set_title("$site->shortname: $course->shortname: $cm->name: " . get_string('blogentries', 'blog'));
|
|
|
|
$PAGE->set_heading("$site->shortname: $course->shortname: $cm->name: " . get_string('blogentries', 'blog'));
|
2009-09-04 00:36:43 +00:00
|
|
|
$headers['heading'] = get_string('blogentriesabout', 'blog', $cm->name);
|
|
|
|
} else
|
|
|
|
|
|
|
|
// Case 8: All blog entries associated with a course
|
2009-09-08 03:05:09 +00:00
|
|
|
if (!empty($courseid) && empty($userid) && empty($groupid) && empty($modid) && empty($entryid)) {
|
2009-09-04 00:36:43 +00:00
|
|
|
$blog_url->param('courseid', $courseid);
|
2009-09-08 03:05:09 +00:00
|
|
|
$PAGE->navbar->add($strblogentries, $blog_url);
|
2009-09-04 03:40:01 +00:00
|
|
|
$PAGE->set_title("$site->shortname: $course->shortname: " . get_string('blogentries', 'blog'));
|
|
|
|
$PAGE->set_heading("$site->shortname: $course->shortname: " . get_string('blogentries', 'blog'));
|
2009-09-04 00:36:43 +00:00
|
|
|
$headers['heading'] = get_string('blogentriesabout', 'blog', $course->fullname);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Append Tag info
|
|
|
|
if (!empty($tagid)) {
|
|
|
|
$blog_url->param('tagid', $tagid);
|
|
|
|
$tagrec = $DB->get_record('tag', array('id'=>$tagid));
|
2009-09-08 03:05:09 +00:00
|
|
|
$PAGE->navbar->add($tagrec->name, $blog_url);
|
2009-09-04 00:36:43 +00:00
|
|
|
} elseif (!empty($tag)) {
|
|
|
|
$blog_url->param('tag', $tag);
|
2009-09-08 03:05:09 +00:00
|
|
|
$PAGE->navbar->add(get_string('tagparam', 'blog', $tag), $blog_url);
|
2009-09-04 00:36:43 +00:00
|
|
|
}
|
2008-04-13 01:17:30 +00:00
|
|
|
|
2009-09-10 07:05:50 +00:00
|
|
|
// Append Search info
|
|
|
|
if (!empty($search)) {
|
|
|
|
$blog_url->param('search', $search);
|
|
|
|
$PAGE->navbar->add(get_string('searchterm', 'blog', $search), $blog_url->out());
|
|
|
|
}
|
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
// Append edit mode info
|
|
|
|
if (!empty($action) && $action == 'add') {
|
2009-09-08 03:05:09 +00:00
|
|
|
if (empty($modid) && empty($courseid)) {
|
|
|
|
if (empty($user)) {
|
|
|
|
$user = $USER;
|
|
|
|
}
|
|
|
|
$PAGE->navbar->add($strparticipants, "$CFG->wwwroot/user/index.php?id=$site->id");
|
|
|
|
$PAGE->navbar->add(fullname($user), "$CFG->wwwroot/user/view.php?id=$user->id");
|
|
|
|
}
|
2009-09-04 03:40:01 +00:00
|
|
|
$PAGE->navbar->add(get_string('addnewentry', 'blog'));
|
2009-09-04 00:36:43 +00:00
|
|
|
} else if (!empty($action) && $action == 'edit') {
|
2009-09-04 03:40:01 +00:00
|
|
|
$PAGE->navbar->add(get_string('editentry', 'blog'));
|
2008-04-13 01:17:30 +00:00
|
|
|
}
|
2009-09-10 07:05:50 +00:00
|
|
|
|
2009-09-04 00:36:43 +00:00
|
|
|
return $headers;
|
|
|
|
}
|
2009-09-15 07:57:54 +00:00
|
|
|
|
|
|
|
function blog_extend_settings_navigation($settingsnav) {
|
|
|
|
global $USER, $PAGE, $FULLME, $CFG, $DB, $OUTPUT;
|
|
|
|
$blogkey = $settingsnav->add(get_string('blogadministration', 'blog'));
|
|
|
|
$blog = $settingsnav->get($blogkey);
|
|
|
|
$blog->forceopen = true;
|
|
|
|
|
|
|
|
$blog->add(get_string('preferences', 'blog'), new moodle_url('preferences.php'), navigation_node::TYPE_SETTING);
|
|
|
|
if ($CFG->useexternalblogs && $CFG->maxexternalblogsperuser > 0) {
|
|
|
|
$blog->add(get_string('externalblogs', 'blog'), new moodle_url('external.php'), navigation_node::TYPE_SETTING);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $blogkey;
|
|
|
|
}
|