MDL-19676 MDL-14408 MDL-8776 Blog improvements
[moodle.git] / blog / index.php
1 <?php // $Id$
3 /**
4  * file index.php
5  * index page to view blogs. if no blog is specified then site wide entries are shown
6  * if a blog id is specified then the latest entries from that blog are shown
7  */
9 require_once(dirname(dirname(__FILE__)).'/config.php');
10 require_once($CFG->dirroot .'/blog/lib.php');
11 require_once($CFG->dirroot .'/blog/locallib.php');
12 require_once($CFG->dirroot .'/course/lib.php');
13 require_once($CFG->dirroot .'/tag/lib.php');
14 require_once($CFG->libdir .'/commentlib.php');
16 $id       = optional_param('id', null, PARAM_INT);
17 $start    = optional_param('formstart', 0, PARAM_INT);
18 $tag      = optional_param('tag', '', PARAM_NOTAGS);
19 $userid   = optional_param('userid', null, PARAM_INT);
20 $tagid    = optional_param('tagid', null, PARAM_INT);
21 $modid    = optional_param('modid', null, PARAM_INT);
22 $entryid  = optional_param('entryid', null, PARAM_INT);
23 $groupid  = optional_param('groupid', null, PARAM_INT);
24 $courseid = optional_param('courseid', null, PARAM_INT);
25 $search   = optional_param('search', null, PARAM_RAW);
27 comment::js();
29 $url_params = compact('id', 'start', 'tag', 'userid', 'tagid', 'modid', 'entryid', 'groupid', 'courseid', 'search');
30 foreach ($url_params as $var => $val) {
31     if (empty($val)) {
32         unset($url_params[$var]);
33     }
34 }
35 $PAGE->set_url('blog/index.php', $url_params);
37 //correct tagid if a text tag is provided as a param
38 if (!empty($tag)) {
39     $ILIKE = $DB->sql_ilike();
40     if ($tagrec = $DB->get_record_sql("SELECT * FROM {tag} WHERE name $ILIKE ?", array("%$tag%"))) {
41         $tagid = $tagrec->id;
42     } else {
43         unset($tagid);
44     }
45 }
47 // add courseid if modid or groupid is specified: This is used for navigation and title
48 if (!empty($modid) && empty($courseid)) {
49     $courseid = $DB->get_field('course_modules', 'course', array('id'=>$modid));
50 }
52 if (!empty($groupid) && empty($courseid)) {
53     $courseid = $DB->get_field('groups', 'courseid', array('id'=>$groupid));
54 }
56 if (empty($CFG->bloglevel)) {
57     print_error('blogdisable', 'blog');
58 }
60 $sitecontext = get_context_instance(CONTEXT_SYSTEM);
61 $tabsfile = null;
63 if (!$userid && has_capability('moodle/blog:view', $sitecontext) && $CFG->bloglevel > BLOG_USER_LEVEL) {
64     if ($entryid) {
65         if (!$entryobject = $DB->get_record('post', array('id'=>$entryid))) {
66             print_error('nosuchentry', 'blog');
67         }
68         $userid = $entryobject->userid;
69     }
70 } else if (!$userid) {
71     $userid = $USER->id;
72 }
74 if (!empty($modid)) {
75     if ($CFG->bloglevel < BLOG_SITE_LEVEL) {
76         print_error(get_string('nocourseblogs', 'blog'));
77     }
78     if (!$mod = $DB->get_record('course_modules', array('id' => $modid))) {
79         print_error(get_string('invalidmodid', 'blog'));
80     }
81     $courseid = $mod->course;
82 }
84 if ((empty($courseid) ? true : $courseid == SITEID) && empty($userid)) {
85     if ($CFG->bloglevel < BLOG_SITE_LEVEL) {
86         print_error('siteblogdisable', 'blog');
87     }
88     if ($CFG->bloglevel < BLOG_GLOBAL_LEVEL) {
89         require_login();
90     }
91     if (!has_capability('moodle/blog:view', $sitecontext)) {
92         print_error('cannotviewsiteblog', 'blog');
93     }
95     $COURSE = $DB->get_record('course', array('format'=>'site'));
96     $courseid = $COURSE->id;
97 }
99 if (!empty($courseid)) {
100     if (!$course = $DB->get_record('course', array('id'=>$courseid))) {
101         print_error('invalidcourseid');
102     }
104     $courseid = $course->id;
105     $coursecontext = get_context_instance(CONTEXT_COURSE, $course->id);
107     require_login($course);
109     if (!has_capability('moodle/blog:view', $coursecontext)) {
110         print_error('cannotviewcourseblog', 'blog');
111     }
112 } else {
113     $coursecontext = get_context_instance(CONTEXT_COURSE, SITEID);
116 if (!empty($groupid)) {
117     if ($CFG->bloglevel < BLOG_SITE_LEVEL) {
118         print_error('groupblogdisable', 'blog');
119     }
121     if (! $group = groups_get_group($groupid)) {
122         print_error(get_string('invalidgroupid', 'blog'));
123     }
125     if (!$course = $DB->get_record('course', array('id'=>$group->courseid))) {
126         print_error(get_string('invalidcourseid', 'blog'));
127     }
129     $coursecontext = get_context_instance(CONTEXT_COURSE, $course->id);
130     $courseid = $course->id;
131     require_login($course);
133     if (!has_capability('moodle/blog:view', $coursecontext)) {
134         print_error(get_string('cannotviewcourseorgroupblog', 'blog'));
135     }
137     if (groups_get_course_groupmode($course) == SEPARATEGROUPS && !has_capability('moodle/site:accessallgroups', $coursecontext)) {
138         if (!groups_is_member($groupid)) {
139             print_error('notmemberofgroup');
140         }
141     }
144 if (!empty($user)) {
145     if ($CFG->bloglevel < BLOG_USER_LEVEL) {
146         print_error('blogdisable', 'blog');
147     }
149     if (!$user = $DB->get_record('user', array('id'=>$userid))) {
150         print_error('invaliduserid');
151     }
153     if ($user->deleted) {
154         echo $OUTPUT->header();
155         echo $OUTPUT->heading(get_string('userdeleted'));
156         echo $OUTPUT->footer();
157         die;
158     }
160     if ($USER->id == $userid) {
161         if (!has_capability('moodle/blog:create', $sitecontext)
162           && !has_capability('moodle/blog:view', $sitecontext)) {
163             print_error('donothaveblog', 'blog');
164         }
165     } else {
166         $personalcontext = get_context_instance(CONTEXT_USER, $userid);
168         if (!has_capability('moodle/blog:view', $sitecontext) && !has_capability('moodle/user:readuserblogs', $personalcontext)) {
169             print_error('cannotviewuserblog', 'blog');
170         }
172         if (!blog_user_can_view_user_entry($userid)) {
173             print_error('cannotviewcourseblog', 'blog');
174         }
175     }
176     $tabsfile = $CFG->dirroot . '/user/tabs.php';
179 $courseid = (empty($courseid)) ? SITEID : $courseid;
181 if (!empty($courseid)) {
182     $PAGE->set_context(get_context_instance(CONTEXT_COURSE, $courseid));
185 if (!empty($modid)) {
186     $PAGE->set_context(get_context_instance(CONTEXT_MODULE, $modid));
189 $blogheaders = blog_get_headers();
190 blog_extend_settings_navigation($PAGE->settingsnav);
192 if (empty($entryid) && empty($modid) && empty($groupid)) {
193     $PAGE->set_context(get_context_instance(CONTEXT_USER, $USER->id));
196 echo $OUTPUT->header();
198 if (!empty($tabsfile)) {
199     require_once($tabsfile);
202 echo $OUTPUT->heading($blogheaders['heading'], 2);
204 $bloglisting = new blog_listing($blogheaders['filters']);
205 $bloglisting->print_entries();
207 echo $OUTPUT->footer();
209 add_to_log($courseid, 'blog', 'view', 'index.php?entryid='.$entryid.'&amp;tagid='.@$tagid.'&amp;tag='.$tag, 'view blog entry');