wwwroot; } } //first verify that user is not a guest if (isguest()) { error(get_string('noguestpost', 'blog'), $referrer); } // make sure that the person trying to edit have access right if ($editid = optional_param('editid', 0, PARAM_INT)) { $blogEntry = get_record('post', 'id', $editid); if (!blog_user_can_edit_post($blogEntry)) { error( get_string('notallowedtoedit', 'blog'), $CFG->wwwroot .'/login/index.php'); } } //check to see if there is a requested blog to edit if (isloggedin() && !isguest()) { $userid = $USER->id; } else { error(get_string('noblogspecified', 'blog') .'' .get_string('viewentries', 'blog') .''); } // if we are trying to delete an non-existing blog entry if (isset($act) && ($act == 'del') && (empty($blogEntry))) { error ('the entry you are trying to delete does not exist'); } $pageNavigation = 'edit'; include($CFG->dirroot .'/blog/header.php'); //////////// SECURITY AND SETUP COMPLETE - NOW PAGE LOGIC /////////////////// if (isset($act) && ($act == 'del') && confirm_sesskey()) { $postid = required_param('editid', PARAM_INT); if (optional_param('confirm',0,PARAM_INT)) { do_delete($postid); } else { /// prints blog entry and what confirmation form echo '
'; echo ''; echo ''; echo ''; echo ''; print_string('blogdeleteconfirm', 'blog'); blog_print_entry($blogEntry); echo '
'; echo ' '; echo ' '; echo '
'; print_footer($course); exit; } } if ($usehtmleditor = can_use_richtext_editor()) { $defaultformat = FORMAT_HTML; $onsubmit = ''; } else { $defaultformat = FORMAT_MOODLE; $onsubmit = ''; } if (($post = data_submitted( get_referer() )) && confirm_sesskey()) { if (!empty($post->editform)) { //make sure we're processing the edit form here //print_object($post); //debug if (!$post->etitle or !$post->body) { $post->error = get_string('emptymessage', 'forum'); } if ($post->act == 'save') { do_save($post); } else if ($post->act == 'update') { do_update($post); } else if ($post->act == 'del') { $postid = required_param('postid', PARAM_INT); do_delete($postid); } } } else { //no post data yet, so load up the post array with default information $post->etitle = ''; $post->userid = $USER->id; $post->body = ''; $post->format = $defaultformat; $post->publishstate = 'draft'; } if ($editid) { // User is editing a post // ensure that editing is allowed first - admin users can edit any posts $blogEntry = get_record('post','id',$editid); //using an unformatted entry body here so that extra formatting information is not stored in the db $post->body = $blogEntry->summary; $post->etitle = $blogEntry->subject; $post->postid = $editid; $post->userid = $blogEntry->userid; $post->format = $blogEntry->format; $post->publishstate = $blogEntry->publishstate; } if (isset($post->postid) && ($post->postid != -1) ) { $formHeading = get_string('updateentrywithid', 'blog'); } else { $formHeading = get_string('addnewentry', 'blog'); } if (isset($post->error)) { notify($post->error); } print_simple_box_start("center"); require('edit.html'); print_simple_box_end(); // Janne comment: Let's move this in here // so IE gets more time to load the // Page. if ($usehtmleditor) { // Janne comment: there are two text fields in form // so lets try to replace them both with // HTMLArea editors use_html_editor(); } include($CFG->dirroot .'/blog/footer.php'); /***************************** edit.php functions ***************************/ /* * do_delete * takes $bloginfo_arg argument as reference to a blogInfo object. * also takes the postid - the id of the entry to be removed */ function do_delete($postid) { global $CFG, $USER, $referrer; // make sure this user is authorized to delete this entry. // cannot use $post->pid because it may not have been initialized yet. Also the pid may be in get format rather than post. // check ownership $blogEntry = get_record('post','id',$postid); if (blog_user_can_edit_post($blogEntry)) { if (delete_records('post','id',$postid)) { //echo "bloginfo_arg:"; //debug //print_object($bloginfo_arg); //debug //echo "pid to delete:".$postid; //debug delete_records('blog_tag_instance', 'entryid', $postid); print ''. get_string('entrydeleted', 'blog') .'

'; //record a log message of this entry deletion if ($site = get_site()) { add_to_log($site->id, 'blog', 'delete', 'index.php?userid='. $blogEntry->userid, 'deleted blog entry with entry id# '. $postid); } } } else { error(get_string('entryerrornotyours', 'blog')); } //comment out this redirect to debug the deletion of entries redirect($CFG->wwwroot .'/blog/index.php?userid='. $blogEntry->userid); } /** * do_save * * @param object $post argument is a reference to the post object which is used to store information for the form * @param object $bloginfo_arg argument is reference to a blogInfo object. */ function do_save($post) { global $USER, $CFG, $referrer; // echo 'Debug: Post object in do_save function of edit.php
'; //debug // print_object($post); //debug if ($post->body == '') { $post->error = get_string('nomessagebodyerror', 'blog'); } else { /// Write a blog entry into database $blogEntry = new object; $blogEntry->subject = addslashes($post->etitle); $blogEntry->summary = addslashes($post->body); $blogEntry->module = 'blog'; $blogEntry->userid = $USER->id; $blogEntry->format = $post->format; $blogEntry->publishstate = $post->publishstate; $blogEntry->lastmodified = time(); $blogEntry->created = time(); // Insert the new blog entry. $entryID = insert_record('post',$blogEntry); // print 'Debug: created a new entry - entryId = '.$entryID.'
'; //debug // echo 'Debug: do_save() in edit.php calling blog_do_*back_pings
'."\n"; //debug if ($entryID) { /// Creates a unique hash. I don't know what this is for (Yu) $dataobject = new object; $dataobject->uniquehash = md5($blogEntry->userid.$CFG->wwwroot.$entryID); update_record('post', $dataobject); /// Associate tags with entries $otags = optional_param('otags','', PARAM_INT); $ptags = optional_param('ptags','', PARAM_INT); $tag = NULL; $tag->entryid = $entryID; $tag->userid = $USER->id; $tag->timemodified = time(); /// Add tags information foreach ($otags as $otag) { $tag->tagid = $otag; insert_record('blog_tag_instance',$tag); } foreach ($ptags as $ptag) { $tag->tagid = $ptag; insert_record('blog_tag_instance',$tag); } print ''. get_string('entrysaved', 'blog') .'
'; } //record a log message of this entry addition if ($site = get_site()) { add_to_log($site->id, 'blog', 'add', 'index.php?userid='. $blogEntry->userid .'&postid='. $entryID, 'created new blog entry with entry id# '. $entryID); } redirect($referrer); /* //to debug this save function comment out the following redirect code if ($courseid == SITEID || $courseid == 0 || $courseid == '') { redirect($CFG->wwwroot .'/blog/index.php?userid='. $blogEntry->userid); } else { redirect($CFG->wwwroot .'/course/view.php?id='. $courseid); }*/ } } /** * @param . $post argument is a reference to the post object which is used to store information for the form * @param . $bloginfo_arg argument is reference to a blogInfo object. * @todo complete documenting this function. enable trackback and pingback between entries on the same server */ function do_update($post) { // here post = data_submitted(); global $CFG, $USER, $referrer; $blogEntry = get_record('post','id',$post->postid); // echo "id id ".$post->postid; // print_object($blogentry); //debug $blogEntry->subject = addslashes($post->etitle); $blogEntry->summary = addslashes($post->body); if ($blogEntry->summary == '
') { $blogEntry->summary = ''; } $blogEntry->format = $post->format; $blogEntry->publishstate = $post->publishstate; //we don't care about the return value here if ( update_record('post',$blogEntry)) { delete_records('blog_tag_instance', 'entryid', $blogEntry->id); $otags = optional_param('otags','', PARAM_INT); $ptags = optional_param('ptags','', PARAM_INT); $tag = NULL; $tag->entryid = $blogEntry->id; $tag->userid = $USER->id; $tag->timemodified = time(); /// Add tags information foreach ($otags as $otag) { $tag->tagid = $otag; insert_record('blog_tag_instance',$tag); } foreach ($ptags as $ptag) { $tag->tagid = $ptag; insert_record('blog_tag_instance',$tag); } // only do pings if the entry is published to the world // Daryl Hawes note - eventually should check if it's on the same server // and if so allow pb/tb as well - especially now that moderation is in place print ''. get_string('entryupdated', 'blog') .'

'; //record a log message of this entry update action if ($site = get_site()) { add_to_log($site->id, 'blog', 'update', 'index.php?userid='. $blogEntry->userid .'&postid='. $post->postid, 'updated existing blog entry with entry id# '. $post->postid); } redirect($referrer); //to debug this save function comment out the following redirect code /* if ($courseid == SITEID || $courseid == 0 || $courseid == '') { redirect($CFG->wwwroot .'/blog/index.php?userid='. $blogEntry->userid); } else { redirect($CFG->wwwroot .'/course/view.php?id='. $courseid); }*/ } else { // get_string('', 'blog') //Daryl Hawes note: localize this line $post->error = 'There was an error updating this post in the database: '. $error; } } ?>