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/>.
/**
* Classes for Blogs .
*
* @ package moodlecore
* @ subpackage blog
* @ copyright 2009 Nicolas Connault
* @ license http :// www . gnu . org / copyleft / gpl . html GNU GPL v3 or later
*/
/**
* Blog_entry class . Represents an entry in a user ' s blog . Contains all methods for managing this entry .
* This class does not contain any HTML - generating code . See blog_listing sub - classes for such code .
* This class follows the Object Relational Mapping technique , its member variables being mapped to
2009-10-30 07:25:50 +00:00
* the fields of the post table .
2009-09-04 00:36:43 +00:00
*
* @ package moodlecore
* @ subpackage blog
* @ copyright 2009 Nicolas Connault
* @ license http :// www . gnu . org / copyleft / gpl . html GNU GPL v3 or later
*/
class blog_entry {
// Public Database fields
public $id ;
public $userid ;
public $subject ;
public $summary ;
2009-10-30 07:25:50 +00:00
public $rating = 0 ;
public $attachment ;
2009-09-04 00:36:43 +00:00
public $publishstate ;
// Locked Database fields (Don't touch these)
2009-10-30 07:25:50 +00:00
public $courseid = 0 ;
public $groupid = 0 ;
public $module = 'blog' ;
public $moduleid = 0 ;
public $coursemoduleid = 0 ;
2009-09-04 00:36:43 +00:00
public $content ;
public $format = 1 ;
2009-10-30 07:25:50 +00:00
public $uniquehash = '' ;
2009-09-04 00:36:43 +00:00
public $lastmodified ;
public $created ;
public $usermodified ;
// Other class variables
public $form ;
public $tags = array ();
// Methods
/**
* Constructor . If given an id , will fetch the corresponding record from the DB .
*
2009-09-16 10:05:34 +00:00
* @ param mixed $idorparams A blog entry id if INT , or data for a new entry if array
2009-09-04 00:36:43 +00:00
*/
2009-10-30 07:25:50 +00:00
public function __construct ( $id = null , $params = null , $form = null ) {
2009-09-16 10:05:34 +00:00
global $DB , $PAGE ;
2009-09-04 00:36:43 +00:00
2009-10-30 07:25:50 +00:00
if ( ! empty ( $id )) {
$object = $DB -> get_record ( 'post' , array ( 'id' => $id ));
2009-09-04 00:36:43 +00:00
foreach ( $object as $var => $val ) {
$this -> $var = $val ;
}
2009-10-30 07:25:50 +00:00
} else if ( ! empty ( $params ) && ( is_array ( $params ) || is_object ( $params ))) {
foreach ( $params as $var => $val ) {
2009-09-04 00:36:43 +00:00
$this -> $var = $val ;
}
}
$this -> form = $form ;
}
/**
* Prints or returns the HTML for this blog entry .
*
* @ param bool $return
* @ return string
*/
public function print_html ( $return = false ) {
2009-09-16 10:05:34 +00:00
global $USER , $CFG , $COURSE , $DB , $OUTPUT , $PAGE ;
2009-09-04 00:36:43 +00:00
$user = $DB -> get_record ( 'user' , array ( 'id' => $this -> userid ));
2009-09-16 10:05:34 +00:00
// Comments
$cmt = new stdClass ();
$cmt -> contextid = get_context_instance ( CONTEXT_USER , $user -> id ) -> id ;
$cmt -> area = 'format_blog' ;
$cmt -> itemid = $this -> id ;
$options -> comments = $cmt ;
2009-10-30 07:25:50 +00:00
$this -> summary = file_rewrite_pluginfile_urls ( $this -> summary , 'pluginfile.php' , SYSCONTEXTID , 'blog_post' , $this -> id );
2009-09-04 00:36:43 +00:00
2009-10-30 07:25:50 +00:00
$template [ 'body' ] = format_text ( $this -> summary , $this -> summaryformat , $options );
2009-09-04 00:36:43 +00:00
$template [ 'title' ] = '<a id="b' . s ( $this -> id ) . '" />' ;
$template [ 'title' ] .= '<span class="nolink">' . format_string ( $this -> subject ) . '</span>' ;
$template [ 'userid' ] = $user -> id ;
$template [ 'author' ] = fullname ( $user );
$template [ 'created' ] = userdate ( $this -> created );
if ( $this -> created != $this -> lastmodified ){
$template [ 'lastmod' ] = userdate ( $this -> lastmodified );
}
$template [ 'publishstate' ] = $this -> publishstate ;
$stredit = get_string ( 'edit' );
$strdelete = get_string ( 'delete' );
2009-10-30 07:25:50 +00:00
// Check to see if the entry is unassociated with group/course level access
2009-09-04 00:36:43 +00:00
$unassociatedentry = false ;
if ( ! empty ( $CFG -> useblogassociations ) && ( $this -> publishstate == 'group' || $this -> publishstate == 'course' )) {
if ( ! $DB -> record_exists ( 'blog_association' , array ( 'blogid' => $this -> id ))) {
$unassociatedentry = true ;
}
}
2009-10-30 07:25:50 +00:00
// Start printing of the blog
2009-09-04 00:36:43 +00:00
$table = new html_table ();
$table -> cellspacing = 0 ;
$table -> add_classes ( 'forumpost blog_entry blog' . ( $unassociatedentry ? 'draft' : $template [ 'publishstate' ]));
$table -> width = '100%' ;
$picturecell = new html_table_cell ();
$picturecell -> add_classes ( 'picture left' );
2009-12-27 19:47:21 +00:00
$picturecell -> text = $OUTPUT -> user_picture ( $user );
2009-09-04 00:36:43 +00:00
$table -> head [] = $picturecell ;
$topiccell = new html_table_cell ();
$topiccell -> add_classes ( 'topic starter' );
$topiccell -> text = $OUTPUT -> container ( $template [ 'title' ], 'subject' );
$topiccell -> text .= $OUTPUT -> container_start ( 'author' );
$fullname = fullname ( $user , has_capability ( 'moodle/site:viewfullnames' , get_context_instance ( CONTEXT_COURSE , $COURSE -> id )));
$by = new object ();
$by -> name = $OUTPUT -> link ( html_link :: make ( new moodle_url ( $CFG -> wwwroot . '/user/view.php' , array ( 'id' => $user -> id , 'course' => $COURSE -> id )), $fullname ));
$by -> date = $template [ 'created' ];
$topiccell -> text .= get_string ( 'bynameondate' , 'forum' , $by );
$topiccell -> text .= $OUTPUT -> container_end ();
2009-10-30 07:25:50 +00:00
if ( $this -> uniquehash && $this -> content ) {
if ( $externalblog = $DB -> get_record ( 'blog_external' , array ( 'id' => $this -> content ))) {
$urlparts = parse_url ( $externalblog -> url );
$topiccell -> text .= $OUTPUT -> container ( get_string ( 'retrievedfrom' , 'blog' ) . $OUTPUT -> link ( html_link :: make ( $urlparts [ 'scheme' ] . '://' . $urlparts [ 'host' ], $externalblog -> name )), 'externalblog' );
}
}
2009-09-04 00:36:43 +00:00
$topiccell -> header = false ;
$table -> head [] = $topiccell ;
2009-10-30 07:25:50 +00:00
// Actual content
2009-09-04 00:36:43 +00:00
$mainrow = new html_table_row ();
$leftsidecell = new html_table_cell ();
$leftsidecell -> add_classes ( 'left side' );
$mainrow -> cells [] = $leftsidecell ;
$contentcell = new html_table_cell ();
$contentcell -> add_class ( 'content' );
2009-10-30 07:25:50 +00:00
$attachedimages = $OUTPUT -> container ( $this -> print_attachments (), 'attachments' );
2009-09-04 00:36:43 +00:00
2009-10-30 07:25:50 +00:00
// retrieve associations in case they're needed early
2009-09-11 01:45:16 +00:00
$blogassociations = $DB -> get_records ( 'blog_association' , array ( 'blogid' => $this -> id ));
2009-10-30 07:25:50 +00:00
// determine text for publish state
2009-09-04 00:36:43 +00:00
switch ( $template [ 'publishstate' ]) {
2009-10-30 07:25:50 +00:00
case 'draft' :
2009-09-04 00:36:43 +00:00
$blogtype = get_string ( 'publishtonoone' , 'blog' );
break ;
2009-10-30 07:25:50 +00:00
case 'site' :
2009-09-04 00:36:43 +00:00
$blogtype = get_string ( 'publishtosite' , 'blog' );
break ;
2009-10-30 07:25:50 +00:00
case 'public' :
2009-09-04 00:36:43 +00:00
$blogtype = get_string ( 'publishtoworld' , 'blog' );
break ;
default :
$blogtype = '' ;
break ;
}
$contentcell -> text .= $OUTPUT -> container ( $blogtype , 'audience' );
$contentcell -> text .= $template [ 'body' ];
$contentcell -> text .= $attachedimages ;
2009-10-30 07:25:50 +00:00
// Uniquehash is used as a link to an external blog
if ( ! empty ( $this -> uniquehash )) {
2009-09-04 00:36:43 +00:00
$contentcell -> text .= $OUTPUT -> container_start ( 'externalblog' );
2009-10-30 07:25:50 +00:00
$contentcell -> text .= $OUTPUT -> link ( html_link :: make ( $this -> uniquehash , get_string ( 'linktooriginalentry' , 'blog' )));
2009-09-04 00:36:43 +00:00
$contentcell -> text .= $OUTPUT -> container_end ();
}
// Links to tags
2009-10-30 07:25:50 +00:00
$officialtags = tag_get_tags_csv ( 'post' , $this -> id , TAG_RETURN_HTML , 'official' );
$defaulttags = tag_get_tags_csv ( 'post' , $this -> id , TAG_RETURN_HTML , 'default' );
2009-09-04 00:36:43 +00:00
2009-10-30 07:25:50 +00:00
if ( ! empty ( $CFG -> usetags ) && ( $officialtags || $defaulttags ) ) {
2009-09-04 00:36:43 +00:00
$contentcell -> text .= $OUTPUT -> container_start ( 'tags' );
2009-10-30 07:25:50 +00:00
if ( $officialtags ) {
$contentcell -> text .= get_string ( 'tags' , 'tag' ) . ': ' . $OUTPUT -> container ( $officialtags , 'officialblogtags' );
if ( $defaulttags ) {
$contentcell -> text .= ', ' ;
}
2009-09-04 00:36:43 +00:00
}
2009-10-30 07:25:50 +00:00
$contentcell -> text .= $defaulttags ;
2009-09-04 00:36:43 +00:00
$contentcell -> text .= $OUTPUT -> container_end ();
}
2009-10-30 07:25:50 +00:00
// Add associations
2009-09-11 01:45:16 +00:00
if ( ! empty ( $CFG -> useblogassociations ) && $blogassociations ) {
2009-09-04 00:36:43 +00:00
$contentcell -> text .= $OUTPUT -> container_start ( 'tags' );
2009-09-11 01:45:16 +00:00
$assocstr = '' ;
$hascourseassocs = false ;
2009-10-30 07:25:50 +00:00
$assoctype = '' ;
2009-09-04 00:36:43 +00:00
2009-10-30 07:25:50 +00:00
// First find and show the associated course
foreach ( $blogassociations as $assocrec ) {
$contextrec = $DB -> get_record ( 'context' , array ( 'id' => $assocrec -> contextid ));
if ( $contextrec -> contextlevel == CONTEXT_COURSE ) {
2010-01-02 13:17:54 +00:00
$url = new moodle_url ( $CFG -> wwwroot . '/course/view.php' , array ( 'id' => $contextrec -> instanceid ));
$text = $DB -> get_field ( 'course' , 'shortname' , array ( 'id' => $contextrec -> instanceid )); //TODO: performance!!!!
$assocstr .= $OUTPUT -> action_icon ( $associconurl , $text , 'i/course' );
2009-09-11 01:45:16 +00:00
$hascourseassocs = true ;
2009-10-30 07:25:50 +00:00
$assoctype = get_string ( 'course' );
2009-09-04 00:36:43 +00:00
}
}
2009-10-30 07:25:50 +00:00
// Now show mod association
foreach ( $blogassociations as $assocrec ) {
$contextrec = $DB -> get_record ( 'context' , array ( 'id' => $assocrec -> contextid ));
2009-09-04 00:36:43 +00:00
2009-10-30 07:25:50 +00:00
if ( $contextrec -> contextlevel == CONTEXT_MODULE ) {
2009-09-11 01:45:16 +00:00
if ( $hascourseassocs ) {
$assocstr .= ', ' ;
$hascourseassocs = false ;
}
2009-10-30 07:25:50 +00:00
$modinfo = $DB -> get_record ( 'course_modules' , array ( 'id' => $contextrec -> instanceid ));
2009-09-04 00:36:43 +00:00
$modname = $DB -> get_field ( 'modules' , 'name' , array ( 'id' => $modinfo -> module ));
2010-01-02 13:17:54 +00:00
$url = new moodle_url ( $CFG -> wwwroot . '/mod/' . $modname . '/view.php' , array ( 'id' => $modinfo -> id ));
$text = $DB -> get_field ( $modname , 'name' , array ( 'id' => $modinfo -> instance )); //TODO: performance!!!!
$assocstr .= $OUTPUT -> action_icon ( $associconurl , $text , $OUTPUT -> pix_url ( 'icon' , $modname ));
2009-09-11 01:45:16 +00:00
$assocstr .= ', ' ;
2009-10-30 07:25:50 +00:00
$assoctype = get_string ( 'modulename' , $modname );
2009-09-04 00:36:43 +00:00
}
}
2009-09-11 01:45:16 +00:00
$assocstr = substr ( $assocstr , 0 , - 2 );
2009-10-30 07:25:50 +00:00
$contentcell -> text .= get_string ( 'associated' , 'blog' , $assoctype ) . ': ' . $assocstr ;
2009-09-04 00:36:43 +00:00
$contentcell -> text .= $OUTPUT -> container_end ();
}
if ( $unassociatedentry ) {
$contentcell -> text .= $OUTPUT -> container ( get_string ( 'associationunviewable' , 'blog' ), 'noticebox' );
}
/// Commands
$contentcell -> text .= $OUTPUT -> container_start ( 'commands' );
2009-10-30 07:25:50 +00:00
if ( blog_user_can_edit_entry ( $this ) && empty ( $this -> uniquehash )) {
2009-09-08 03:05:09 +00:00
$contentcell -> text .= $OUTPUT -> link ( html_link :: make ( new moodle_url ( $CFG -> wwwroot . '/blog/edit.php' , array ( 'action' => 'edit' , 'entryid' => $this -> id )), $stredit )) . ' | ' ;
2009-09-11 01:45:16 +00:00
$contentcell -> text .= $OUTPUT -> link ( html_link :: make ( new moodle_url ( $CFG -> wwwroot . '/blog/edit.php' , array ( 'action' => 'delete' , 'entryid' => $this -> id )), $strdelete )) . ' | ' ;
2009-09-04 00:36:43 +00:00
}
$contentcell -> text .= $OUTPUT -> link ( html_link :: make ( new moodle_url ( $CFG -> wwwroot . '/blog/index.php' , array ( 'entryid' => $this -> id )), get_string ( 'permalink' , 'blog' )));
$contentcell -> text .= $OUTPUT -> container_end ();
if ( isset ( $template [ 'lastmod' ]) ){
$contentcell -> text .= '<div style="font-size: 55%;">' ;
$contentcell -> text .= ' [ ' . get_string ( 'modified' ) . ': ' . $template [ 'lastmod' ] . ' ]' ;
$contentcell -> text .= '</div>' ;
}
$mainrow -> cells [] = $contentcell ;
$table -> data = array ( $mainrow );
if ( $return ) {
return $OUTPUT -> table ( $table );
} else {
echo $OUTPUT -> table ( $table );
}
}
/**
* Inserts this entry in the database . Access control checks must be done by calling code .
*
* @ param mform $form Used for attachments
* @ return void
*/
public function process_attachment ( $form ) {
$this -> form = $form ;
}
/**
* Inserts this entry in the database . Access control checks must be done by calling code .
* TODO Set the publishstate correctly
* @ param mform $form Used for attachments
* @ return void
*/
public function add () {
global $CFG , $USER , $DB ;
unset ( $this -> id );
$this -> module = 'blog' ;
$this -> userid = ( empty ( $this -> userid )) ? $USER -> id : $this -> userid ;
$this -> lastmodified = time ();
$this -> created = time ();
// Insert the new blog entry.
2009-10-30 07:25:50 +00:00
if ( $this -> id = $DB -> insert_record ( 'post' , $this )) {
2009-09-04 00:36:43 +00:00
2009-10-30 07:25:50 +00:00
// Update tags.
$this -> add_tags_info ();
2009-09-04 00:36:43 +00:00
2009-10-30 07:25:50 +00:00
if ( ! empty ( $CFG -> useblogassociations )) {
$this -> add_associations ();
add_to_log ( SITEID , 'blog' , 'add' , 'index.php?userid=' . $this -> userid . '&entryid=' . $this -> id , $this -> subject );
}
2009-09-04 00:36:43 +00:00
2009-10-30 07:25:50 +00:00
tag_set ( 'post' , $this -> id , $this -> tags );
2009-09-04 00:36:43 +00:00
}
}
/**
* Updates this entry in the database . Access control checks must be done by calling code .
*
* @ param mform $form Used for attachments
* @ return void
*/
2009-10-30 07:25:50 +00:00
public function edit ( $params = array (), $form = null , $summaryoptions = array (), $attachmentoptions = array ()) {
2009-09-16 10:05:34 +00:00
global $CFG , $USER , $DB , $PAGE ;
2009-09-04 00:36:43 +00:00
2009-10-30 07:25:50 +00:00
$sitecontext = get_context_instance ( CONTEXT_SYSTEM );
$entry = $this ;
2009-09-04 00:36:43 +00:00
$this -> form = $form ;
foreach ( $params as $var => $val ) {
2009-10-30 07:25:50 +00:00
$entry -> $var = $val ;
2009-09-04 00:36:43 +00:00
}
2009-10-30 07:25:50 +00:00
$entry = file_postupdate_standard_editor ( $entry , 'summary' , $summaryoptions , $sitecontext , 'blog_post' , $entry -> id );
$entry = file_postupdate_standard_filemanager ( $entry , 'attachment' , $attachmentoptions , $sitecontext , 'blog_attachment' , $entry -> id );
2009-09-16 10:05:34 +00:00
2009-09-11 01:45:16 +00:00
if ( ! empty ( $CFG -> useblogassociations )) {
2009-10-30 07:25:50 +00:00
$entry -> add_associations ();
2009-09-04 00:36:43 +00:00
}
2009-10-30 07:25:50 +00:00
$entry -> lastmodified = time ();
2009-09-04 00:36:43 +00:00
// Update record
2009-10-30 07:25:50 +00:00
$DB -> update_record ( 'post' , $entry );
tag_set ( 'post' , $entry -> id , $entry -> tags );
2009-09-04 00:36:43 +00:00
2009-10-30 07:25:50 +00:00
add_to_log ( SITEID , 'blog' , 'update' , 'index.php?userid=' . $USER -> id . '&entryid=' . $entry -> id , $entry -> subject );
2009-09-04 00:36:43 +00:00
}
/**
* Deletes this entry from the database . Access control checks must be done by calling code .
*
* @ return void
*/
public function delete () {
global $DB , $USER ;
$returnurl = '' ;
$this -> delete_attachments ();
2009-10-30 07:25:50 +00:00
$DB -> delete_records ( 'post' , array ( 'id' => $this -> id ));
tag_set ( 'post' , $this -> id , array ());
2009-09-04 00:36:43 +00:00
add_to_log ( SITEID , 'blog' , 'delete' , 'index.php?userid=' . $this -> userid , 'deleted blog entry with entry id# ' . $this -> id );
}
/**
* function to add all context associations to an entry
* @ param int entry - data object processed to include all 'entry' fields and extra data from the edit_form object
*/
2009-10-30 07:25:50 +00:00
public function add_associations ( $action = 'add' ) {
2009-09-04 00:36:43 +00:00
global $DB , $USER ;
$this -> remove_associations ();
if ( ! empty ( $this -> courseassoc )) {
2009-10-30 07:25:50 +00:00
$this -> add_association ( $this -> courseassoc , $action );
2009-09-04 00:36:43 +00:00
}
if ( ! empty ( $this -> modassoc )) {
2009-10-30 07:25:50 +00:00
$this -> add_association ( $this -> modassoc , $action );
2009-09-04 00:36:43 +00:00
}
}
/**
* add a single association for a blog entry
* @ param int contextid - id of context to associate with the blog entry
*/
2009-10-30 07:25:50 +00:00
public function add_association ( $contextid , $action = 'add' ) {
global $DB , $USER ;
2009-09-04 00:36:43 +00:00
2009-10-30 07:25:50 +00:00
$assocobject = new StdClass ;
$assocobject -> contextid = $contextid ;
$assocobject -> blogid = $this -> id ;
$DB -> insert_record ( 'blog_association' , $assocobject );
$context = get_context_instance_by_id ( $contextid );
$courseid = null ;
if ( $context -> contextlevel == CONTEXT_COURSE ) {
$courseid = $context -> instanceid ;
add_to_log ( $courseid , 'blog' , $action , 'index.php?userid=' . $this -> userid . '&entryid=' . $this -> id , $this -> subject );
} else if ( $context -> contextlevel == CONTEXT_MODULE ) {
$cm = $DB -> get_record ( 'course_modules' , array ( 'id' => $context -> instanceid ));
$modulename = $DB -> get_field ( 'modules' , 'name' , array ( 'id' => $cm -> module ));
add_to_log ( $cm -> course , 'blog' , $action , 'index.php?userid=' . $this -> userid . '&entryid=' . $this -> id , $this -> subject , $cm -> id , $this -> userid );
}
2009-09-04 00:36:43 +00:00
}
/**
* remove all associations for a blog entry
* @ return voic
*/
public function remove_associations () {
global $DB ;
$DB -> delete_records ( 'blog_association' , array ( 'blogid' => $this -> id ));
}
/**
* Deletes all the user files in the attachments area for an entry
*
* @ return void
*/
public function delete_attachments () {
$fs = get_file_storage ();
2009-10-30 07:25:50 +00:00
$fs -> delete_area_files ( SYSCONTEXTID , 'blog_attachment' , $this -> id );
$fs -> delete_area_files ( SYSCONTEXTID , 'blog_post' , $this -> id );
2009-09-04 00:36:43 +00:00
}
/**
* if return = html , then return a html string .
* if return = text , then return a text - only string .
* otherwise , print HTML for non - images , and return image HTML
*
* @ param bool $return Whether to return or print the generated code
* @ return void
*/
public function print_attachments ( $return = false ) {
2009-10-30 07:25:50 +00:00
global $CFG , $OUTPUT ;
2009-09-04 00:36:43 +00:00
require_once ( $CFG -> libdir . '/filelib.php' );
$fs = get_file_storage ();
$browser = get_file_browser ();
2009-10-30 07:25:50 +00:00
$files = $fs -> get_area_files ( SYSCONTEXTID , 'blog_attachment' , $this -> id );
2009-09-04 00:36:43 +00:00
$imagereturn = " " ;
$output = " " ;
$strattachment = get_string ( " attachment " , " forum " );
foreach ( $files as $file ) {
if ( $file -> is_directory ()) {
continue ;
}
$filename = $file -> get_filename ();
2009-10-30 07:25:50 +00:00
$ffurl = file_encode_url ( $CFG -> wwwroot . '/pluginfile.php' , '/' . SYSCONTEXTID . '/blog_attachment/' . $this -> id . '/' . $filename );
$mimetype = $file -> get_mimetype ();
2009-09-04 00:36:43 +00:00
2009-10-30 07:25:50 +00:00
$icon = substr ( mimeinfo_from_type ( " icon " , $mimetype ), 0 , - 4 );
$type = mimeinfo_from_type ( " type " , $mimetype );
2009-12-31 10:06:56 +00:00
$image = $OUTPUT -> image ( " /f/ $icon " , array ( 'alt' => $filename , 'class' => 'icon' ));
2009-09-04 00:36:43 +00:00
if ( $return == " html " ) {
2009-10-30 07:25:50 +00:00
$output .= $OUTPUT -> link ( html_link :: make ( $ffurl , $OUTPUT -> image ( $image )));
$output .= $OUTPUT -> link ( html_link :: make ( $ffurl , $filename ));
2009-09-04 00:36:43 +00:00
} else if ( $return == " text " ) {
$output .= " $strattachment $filename : \n $ffurl\n " ;
} else {
if ( in_array ( $type , array ( 'image/gif' , 'image/jpeg' , 'image/png' ))) { // Image attachments don't get printed as links
2009-12-31 10:06:56 +00:00
$image = $OUTPUT -> image ( $ffurl , array ( 'alt' => $filename ));
2009-10-30 07:25:50 +00:00
$imagereturn .= " <br /> " . $OUTPUT -> image ( $image );
2009-09-04 00:36:43 +00:00
} else {
2009-12-31 10:06:56 +00:00
$imagereturn .= $OUTPUT -> link ( html_link :: make ( $ffurl , $image ));
2009-10-30 07:25:50 +00:00
$imagereturn .= filter_text ( $OUTPUT -> link ( html_link :: make ( $ffurl , $filename )));
2009-09-04 00:36:43 +00:00
}
}
}
if ( $return ) {
return $output ;
}
return $imagereturn ;
}
/**
* function to attach tags into an entry
* @ return void
*/
public function add_tags_info () {
$tags = array ();
if ( $otags = optional_param ( 'otags' , '' , PARAM_INT )) {
foreach ( $otags as $tagid ) {
// TODO : make this use the tag name in the form
if ( $tag = tag_get ( 'id' , $tagid )) {
$tags [] = $tag -> name ;
}
}
}
2009-10-30 07:25:50 +00:00
tag_set ( 'post' , $this -> id , $tags );
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 .
*
* @ param int $userid Optional . If not given , $USER is used
* @ return boolean
*/
public function can_user_edit ( $userid = null ) {
global $CFG , $USER ;
if ( empty ( $userid )) {
$userid = $USER -> id ;
}
$sitecontext = get_context_instance ( CONTEXT_SYSTEM );
if ( has_capability ( 'moodle/blog:manageentries' , $sitecontext )) {
return true ; // can edit any blog entry
}
if ( $this -> userid == $userid && has_capability ( 'moodle/blog:create' , $sitecontext )) {
return true ; // can edit own when having blog:create capability
}
return false ;
}
/**
* 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
*
* @ param int $targetuserid ID of the user we are checking
*
* @ return bool
*/
public function can_user_view ( $targetuserid ) {
global $CFG , $USER , $DB ;
2009-10-30 07:25:50 +00:00
$sitecontext = get_context_instance ( CONTEXT_SYSTEM );
2009-09-04 00:36:43 +00:00
2009-10-30 07:25:50 +00:00
if ( empty ( $CFG -> bloglevel ) || ! has_capability ( 'moodle/blog:view' , $sitecontext )) {
return false ; // blog system disabled or user has no blog view capability
2009-09-04 00:36:43 +00:00
}
2009-10-30 07:25:50 +00:00
if ( ! empty ( $USER -> id ) && $USER -> id == $targetuserid ) {
2009-09-04 00:36:43 +00:00
return true ; // can view own entries in any case
}
if ( has_capability ( 'moodle/blog:manageentries' , $sitecontext )) {
return true ; // can manage all entries
}
// coming for 1 entry, make sure it's not a draft
2009-10-30 07:25:50 +00:00
if ( $this -> publishstate == 'draft' && ! has_capability ( 'moodle/blog:viewdrafts' , $sitecontext )) {
2009-09-04 00:36:43 +00:00
return false ; // can not view draft of others
}
// coming for 1 entry, make sure user is logged in, if not a public blog
2009-10-30 07:25:50 +00:00
if ( $this -> publishstate != 'public' && ! isloggedin ()) {
2009-09-04 00:36:43 +00:00
return false ;
}
switch ( $CFG -> bloglevel ) {
case BLOG_GLOBAL_LEVEL :
return true ;
break ;
case BLOG_SITE_LEVEL :
if ( ! empty ( $USER -> id )) { // not logged in viewers forbidden
return true ;
}
return false ;
break ;
case BLOG_USER_LEVEL :
default :
$personalcontext = get_context_instance ( CONTEXT_USER , $targetuserid );
return has_capability ( 'moodle/user:readuserblogs' , $personalcontext );
break ;
}
}
/**
* Use this function to retrieve a list of publish states available for
* the currently logged in user .
*
* @ return array This function returns an array ideal for sending to moodles '
* choose_from_menu function .
*/
public static function get_applicable_publish_states () {
global $CFG ;
$options = array ();
// everyone gets draft access
if ( $CFG -> bloglevel >= BLOG_USER_LEVEL ) {
2009-10-30 07:25:50 +00:00
$options [ 'draft' ] = get_string ( 'publishtonoone' , 'blog' );
2009-09-04 00:36:43 +00:00
}
if ( $CFG -> bloglevel > BLOG_USER_LEVEL ) {
2009-10-30 07:25:50 +00:00
$options [ 'site' ] = get_string ( 'publishtosite' , 'blog' );
2009-09-04 00:36:43 +00:00
}
if ( $CFG -> bloglevel >= BLOG_GLOBAL_LEVEL ) {
2009-10-30 07:25:50 +00:00
$options [ 'public' ] = get_string ( 'publishtoworld' , 'blog' );
2009-09-04 00:36:43 +00:00
}
return $options ;
}
}
/**
* Abstract Blog_Listing class : used to gather blog entries and output them as listings . One of the subclasses must be used .
*
* @ package moodlecore
* @ subpackage blog
* @ copyright 2009 Nicolas Connault
* @ license http :// www . gnu . org / copyleft / gpl . html GNU GPL v3 or later
*/
class blog_listing {
/**
* Array of blog_entry objects .
* @ var array $entries
*/
public $entries = array ();
/**
* An array of blog_filter_ * objects
* @ var array $filters
*/
public $filters = array ();
/**
* Constructor
*
* @ param array $filters An associative array of filtername => filterid
*/
public function __construct ( $filters = array ()) {
// Unset filters overridden by more specific filters
foreach ( $filters as $type => $id ) {
if ( ! empty ( $type ) && ! empty ( $id )) {
$this -> filters [ $type ] = blog_filter :: get_instance ( $id , $type );
}
}
foreach ( $this -> filters as $type => $filter ) {
foreach ( $filter -> overrides as $override ) {
if ( array_key_exists ( $override , $this -> filters )) {
unset ( $this -> filters [ $override ]);
}
}
}
}
/**
* Fetches the array of blog entries .
*
* @ return array
*/
public function get_entries ( $start = 0 , $limit = 10 ) {
global $DB ;
if ( empty ( $this -> entries )) {
2009-10-30 07:25:50 +00:00
if ( $sqlarray = $this -> get_entry_fetch_sql ()) {
$this -> entries = $DB -> get_records_sql ( $sqlarray [ 'sql' ] . " LIMIT $start , $limit " , $sqlarray [ 'params' ]);
2009-09-04 00:36:43 +00:00
} else {
return false ;
}
}
return $this -> entries ;
}
public function get_entry_fetch_sql ( $count = false , $sort = 'lastmodified DESC' , $userid = false ) {
global $DB , $USER , $CFG ;
if ( ! $userid ) {
$userid = $USER -> id ;
}
// The query used to locate blog entries is complicated. It will be built from the following components:
2009-10-30 07:25:50 +00:00
$requiredfields = " p.*, u.firstname, u.lastname, u.email " ; // the SELECT clause
$tables = array ( 'p' => 'post' , 'u' => 'user' ); // components of the FROM clause (table_id => table_name)
$conditions = array ( 'u.deleted = 0' , 'p.userid = u.id' , '(p.module = \'blog\' OR p.module = \'blog_external\')' ); // components of the WHERE clause (conjunction)
2009-09-04 00:36:43 +00:00
// build up a clause for permission constraints
$params = array ();
// fix for MDL-9165, use with readuserblogs capability in a user context can read that user's private blogs
// admins can see all blogs regardless of publish states, as described on the help page
if ( has_capability ( 'moodle/user:readuserblogs' , get_context_instance ( CONTEXT_SYSTEM ))) {
// don't add permission constraints
} else if ( ! empty ( $this -> filters [ 'user' ]) && has_capability ( 'moodle/user:readuserblogs' ,
get_context_instance ( CONTEXT_USER , ( empty ( $this -> filters [ 'user' ] -> id ) ? 0 : $this -> filters [ 'user' ] -> id )))) {
// don't add permission constraints
} else {
if ( isloggedin () && ! has_capability ( 'moodle/legacy:guest' , get_context_instance ( CONTEXT_SYSTEM , SITEID ), $userid , false )) {
$assocexists = $DB -> record_exists ( 'blog_association' , array ()); //dont check association records if there aren't any
//begin permission sql clause
2009-10-30 07:25:50 +00:00
$permissionsql = '(p.userid = ? ' ;
2009-09-04 00:36:43 +00:00
$params [] = $userid ;
if ( $CFG -> bloglevel >= BLOG_SITE_LEVEL ) { // add permission to view site-level entries
2009-10-30 07:25:50 +00:00
$permissionsql .= " OR p.publishstate = 'site' " ;
2009-09-04 00:36:43 +00:00
}
if ( $CFG -> bloglevel >= BLOG_GLOBAL_LEVEL ) { // add permission to view global entries
2009-10-30 07:25:50 +00:00
$permissionsql .= " OR p.publishstate = 'public' " ;
2009-09-04 00:36:43 +00:00
}
$permissionsql .= ') ' ; //close permissions sql clause
} else { // default is access to public entries
2009-10-30 07:25:50 +00:00
$permissionsql = " p.publishstate = 'public' " ;
2009-09-04 00:36:43 +00:00
}
$conditions [] = $permissionsql ; //add permission constraints
}
2009-10-30 07:25:50 +00:00
foreach ( $this -> filters as $type => $blogfilter ) {
$conditions = array_merge ( $conditions , $blogfilter -> conditions );
$params = array_merge ( $params , $blogfilter -> params );
$tables = array_merge ( $tables , $blogfilter -> tables );
2009-09-04 00:36:43 +00:00
}
$tablessql = '' ; // build up the FROM clause
foreach ( $tables as $tablename => $table ) {
$tablessql .= ( $tablessql ? ', ' : '' ) . '{' . $table . '} ' . $tablename ;
}
$sql = ( $count ) ? 'SELECT COUNT(*)' : 'SELECT ' . $requiredfields ;
$sql .= " FROM $tablessql WHERE " . implode ( ' AND ' , $conditions );
2009-09-11 08:13:50 +00:00
$sql .= ( $count ) ? '' : " ORDER BY $sort " ;
2009-09-04 00:36:43 +00:00
return array ( 'sql' => $sql , 'params' => $params );
}
/**
* Outputs all the blog entries aggregated by this blog listing .
*
* @ return void
*/
public function print_entries () {
global $CFG , $USER , $DB , $OUTPUT ;
$sitecontext = get_context_instance ( CONTEXT_SYSTEM );
$page = optional_param ( 'blogpage' , 0 , PARAM_INT );
$limit = optional_param ( 'limit' , get_user_preferences ( 'blogpagesize' , 10 ), PARAM_INT );
$start = $page * $limit ;
$morelink = '<br /> ' ;
2009-10-30 07:25:50 +00:00
if ( $sqlarray = $this -> get_entry_fetch_sql ( true )) {
$totalentries = $DB -> count_records_sql ( $sqlarray [ 'sql' ], $sqlarray [ 'params' ]);
2009-09-04 00:36:43 +00:00
} else {
$totalentries = 0 ;
}
$entries = $this -> get_entries ( $start , $limit );
$pagingbar = moodle_paging_bar :: make ( $totalentries , $page , $limit , $this -> get_baseurl ());
$pagingbar -> pagevar = 'blogpage' ;
2009-10-30 07:25:50 +00:00
$blogheaders = blog_get_headers ();
2009-09-04 00:36:43 +00:00
echo $OUTPUT -> paging_bar ( $pagingbar );
/* TODO RSS link
if ( $CFG -> enablerssfeeds ) {
$this -> blog_rss_print_link ( $filtertype , $filterselect , $tag );
}
*/
if ( has_capability ( 'moodle/blog:create' , $sitecontext )) {
//the user's blog is enabled and they are viewing their own blog
$userid = optional_param ( 'userid' , null , PARAM_INT );
if ( empty ( $userid ) || ( ! empty ( $userid ) && $userid == $USER -> id )) {
2009-10-30 07:25:50 +00:00
$addurl = new moodle_url ( " $CFG->wwwroot /blog/edit.php " );
$urlparams = array ( 'action' => 'add' ,
'userid' => $userid ,
'courseid' => optional_param ( 'courseid' , null , PARAM_INT ),
'groupid' => optional_param ( 'groupid' , null , PARAM_INT ),
'modid' => optional_param ( 'modid' , null , PARAM_INT ),
'tagid' => optional_param ( 'tagid' , null , PARAM_INT ),
'tag' => optional_param ( 'tag' , null , PARAM_INT ),
'search' => optional_param ( 'search' , null , PARAM_INT ));
foreach ( $urlparams as $var => $val ) {
2009-09-04 00:36:43 +00:00
if ( empty ( $val )) {
2009-10-30 07:25:50 +00:00
unset ( $urlparams [ $var ]);
2009-09-04 00:36:43 +00:00
}
}
2009-10-30 07:25:50 +00:00
$addurl -> params ( $urlparams );
2009-09-04 00:36:43 +00:00
$addlink = '<div class="addbloglink">' ;
2009-10-30 07:25:50 +00:00
$addlink .= '<a href="' . $addurl -> out () . '">' . $blogheaders [ 'stradd' ] . '</a>' ;
2009-09-04 00:36:43 +00:00
$addlink .= '</div>' ;
echo $addlink ;
}
}
if ( $entries ) {
$count = 0 ;
foreach ( $entries as $entry ) {
2009-10-30 07:25:50 +00:00
$blogentry = new blog_entry ( null , $entry );
$blogentry -> print_html ();
2009-09-04 00:36:43 +00:00
$count ++ ;
}
echo $OUTPUT -> paging_bar ( $pagingbar );
if ( ! $count ) {
print '<br /><div style="text-align:center">' . get_string ( 'noentriesyet' , 'blog' ) . '</div><br />' ;
}
print $morelink . '<br />' . " \n " ;
return ;
}
}
/// Find the base url from $_GET variables, for print_paging_bar
public function get_baseurl () {
$getcopy = $_GET ;
unset ( $getcopy [ 'blogpage' ]);
if ( ! empty ( $getcopy )) {
$first = false ;
$querystring = '' ;
foreach ( $getcopy as $var => $val ) {
if ( ! $first ) {
$first = true ;
$querystring .= " ? $var = $val " ;
} else {
$querystring .= '&' . $var . '=' . $val ;
$hasparam = true ;
}
}
} else {
$querystring = '?' ;
}
return strip_querystring ( qualified_me ()) . $querystring ;
}
}
/**
* Abstract class for blog_filter objects .
* A set of core filters are implemented here . To write new filters , you need to subclass
* blog_filter and give it the name of the type you want ( for example , blog_filter_entry ) .
* The blog_filter abstract class will automatically use it when the filter is added to the
* URL . The first parameter of the constructor is the ID of your filter , but it can be a string
* or have any other meaning you wish it to have . The second parameter is called $type and is
* used as a sub - type for filters that have a very similar implementation ( see blog_filter_context for an example )
*/
abstract class blog_filter {
/**
* An array of strings representing the available filter types for each blog_filter .
2009-10-30 07:25:50 +00:00
* @ var array $availabletypes
2009-09-04 00:36:43 +00:00
*/
2009-10-30 07:25:50 +00:00
public $availabletypes = array ();
2009-09-04 00:36:43 +00:00
/**
* The type of filter ( for example , types of blog_filter_context are site , course and module )
* @ var string $type
*/
public $type ;
/**
* The unique ID for a filter ' s associated record
* @ var int $id
*/
public $id ;
/**
* An array of table aliases that are used in the WHERE conditions
* @ var array $tables
*/
public $tables = array ();
/**
* An array of WHERE conditions
* @ var array $conditions
*/
public $conditions = array ();
/**
* An array of SQL params
* @ var array $params
*/
public $params = array ();
/**
* An array of filter types which this particular filter type overrides : their conditions will not be evaluated
*/
public $overrides = array ();
public function __construct ( $id , $type = null ) {
$this -> id = $id ;
$this -> type = $type ;
}
/**
* TODO This is poor design . A parent class should not know anything about its children .
* The default case helps to resolve this design issue
*/
public static function get_instance ( $id , $type ) {
switch ( $type ) {
case 'site' :
case 'course' :
case 'module' :
return new blog_filter_context ( $id , $type );
break ;
case 'group' :
case 'user' :
return new blog_filter_user ( $id , $type );
break ;
case 'tag' :
return new blog_filter_tag ( $id );
break ;
default :
2009-10-30 07:25:50 +00:00
$classname = " blog_filter_ $type " ;
if ( class_exists ( $classname )) {
return new $classname ( $id , $type );
2009-09-04 00:36:43 +00:00
}
}
}
}
/**
* This filter defines the context level of the blog entries being searched : site , course , module
*/
class blog_filter_context extends blog_filter {
/**
* Constructor
*
* @ param string $type
* @ param int $id
*/
public function __construct ( $id = null , $type = 'site' ) {
global $SITE , $CFG , $DB ;
if ( empty ( $id )) {
$this -> type = 'site' ;
} else {
$this -> id = $id ;
$this -> type = $type ;
}
2009-10-30 07:25:50 +00:00
$this -> availabletypes = array ( 'site' => get_string ( 'site' ), 'course' => get_string ( 'course' ), 'module' => get_string ( 'module' ));
2009-09-04 00:36:43 +00:00
switch ( $this -> type ) {
case 'course' : // Careful of site course!
// Ignore course filter if blog associations are not enabled
if ( $this -> id != $SITE -> id && ! empty ( $CFG -> useblogassociations )) {
$this -> overrides = array ( 'site' );
$context = get_context_instance ( CONTEXT_COURSE , $this -> id );
$this -> tables [ 'ba' ] = 'blog_association' ;
2009-10-30 07:25:50 +00:00
$this -> conditions [] = 'p.id = ba.blogid' ;
2009-09-04 00:36:43 +00:00
$this -> conditions [] = 'ba.contextid = ' . $context -> id ;
break ;
} else {
// We are dealing with the site course, do not break from the current case
}
case 'site' :
// No special constraints
break ;
case 'module' :
if ( ! empty ( $CFG -> useblogassociations )) {
$this -> overrides = array ( 'course' , 'site' );
$context = get_context_instance ( CONTEXT_MODULE , $this -> id );
$this -> tables [ 'ba' ] = 'blog_association' ;
2009-10-30 07:25:50 +00:00
$this -> tables [ 'p' ] = 'post' ;
$this -> conditions = array ( 'p.id = ba.blogid' , 'ba.contextid = ?' );
2009-09-04 00:36:43 +00:00
$this -> params = array ( $context -> id );
}
break ;
}
}
}
/**
* This filter defines the user level of the blog entries being searched : a userid or a groupid .
* It can be combined with a context filter in order to refine the search .
*/
class blog_filter_user extends blog_filter {
public $tables = array ( 'u' => 'user' );
/**
* Constructor
*
* @ param string $type
* @ param int $id
*/
public function __construct ( $id = null , $type = 'user' ) {
2009-09-16 10:05:34 +00:00
global $CFG , $DB ;
2009-10-30 07:25:50 +00:00
$this -> availabletypes = array ( 'user' => get_string ( 'user' ), 'group' => get_string ( 'group' ));
2009-09-04 00:36:43 +00:00
if ( empty ( $id )) {
$this -> id = $USER -> id ;
$this -> type = 'user' ;
} else {
$this -> id = $id ;
$this -> type = $type ;
}
if ( $this -> type == 'user' ) {
$this -> conditions = array ( 'u.id = ?' );
$this -> params = array ( $this -> id );
$this -> overrides = array ( 'group' );
} elseif ( $this -> type == 'group' ) {
$this -> overrides = array ( 'course' , 'site' );
$this -> tables [ 'gm' ] = 'groups_members' ;
2009-10-30 07:25:50 +00:00
$this -> conditions [] = 'p.userid = gm.userid' ;
2009-09-04 00:36:43 +00:00
$this -> conditions [] = 'gm.groupid = ?' ;
$this -> params [] = $this -> id ;
if ( ! empty ( $CFG -> useblogassociations )) { // only show blog entries associated with this course
2009-10-30 07:25:50 +00:00
$coursecontext = get_context_instance ( CONTEXT_COURSE , $DB -> get_field ( 'groups' , 'courseid' , array ( 'id' => $this -> id )));
2009-09-04 00:36:43 +00:00
$this -> tables [ 'ba' ] = 'blog_association' ;
$this -> conditions [] = 'gm.groupid = ?' ;
$this -> conditions [] = 'ba.contextid = ?' ;
2009-10-30 07:25:50 +00:00
$this -> conditions [] = 'ba.blogid = p.id' ;
2009-09-04 00:36:43 +00:00
$this -> params [] = $this -> id ;
2009-10-30 07:25:50 +00:00
$this -> params [] = $coursecontext -> id ;
2009-09-04 00:36:43 +00:00
}
}
2009-09-16 10:05:34 +00:00
2009-09-04 00:36:43 +00:00
}
}
/**
* This filter defines a tag by which blog entries should be searched .
*/
class blog_filter_tag extends blog_filter {
2009-10-30 07:25:50 +00:00
public $tables = array ( 't' => 'tag' , 'ti' => 'tag_instance' , 'p' => 'post' );
2009-09-04 00:36:43 +00:00
/**
* Constructor
*
* @ return void
*/
public function __construct ( $id ) {
global $DB ;
$this -> id = $id ;
$this -> conditions = array ( 'ti.tagid = t.id' ,
2009-10-30 07:25:50 +00:00
" ti.itemtype = 'post' " ,
'ti.itemid = p.id' ,
2009-09-04 00:36:43 +00:00
't.id = ?' );
$this -> params = array ( $this -> id );
}
}
/**
* This filter defines a specific blog entry id .
*/
class blog_filter_entry extends blog_filter {
public $conditions = array ( 'p.id = ?' );
public $overrides = array ( 'site' , 'course' , 'module' , 'group' , 'user' , 'tag' );
public function __construct ( $id ) {
$this -> id = $id ;
$this -> params [] = $this -> id ;
}
}
2009-10-30 07:25:50 +00:00
/**
* This filter restricts the results to a time interval in seconds up to mktime ()
*/
class blog_filter_since extends blog_filter {
public function __construct ( $interval ) {
$this -> conditions [] = 'p.lastmodified >= ? AND p.lastmodified <= ?' ;
$this -> params [] = mktime () - $interval ;
$this -> params [] = mktime ();
}
}
2009-09-04 00:36:43 +00:00
/**
* Filter used to perform full - text search on an entry ' s subject , summary and content
*/
class blog_filter_search extends blog_filter {
2009-10-30 07:25:50 +00:00
public function __construct ( $searchterm ) {
2009-09-04 00:36:43 +00:00
global $DB ;
$ilike = $DB -> sql_ilike ();
2009-10-30 07:25:50 +00:00
$this -> conditions = array ( " (p.summary $ilike ? OR
p . content $ilike ? OR
p . subject $ilike ? ) " );
$this -> params [] = " % $searchterm % " ;
$this -> params [] = " % $searchterm % " ;
$this -> params [] = " % $searchterm % " ;
2009-09-04 00:36:43 +00:00
}
}