bloglevel)) { error('Blogging is disabled!'); } if (isguest()) { error(get_string('noguestpost', 'blog')); } $sitecontext = get_context_instance(CONTEXT_SYSTEM, SITEID); if (!has_capability('moodle/blog:create', $sitecontext) and !has_capability('moodle/blog:manageentries', $sitecontext)) { error('You can not post or edit blogs.'); } // Make sure that the person trying to edit have access right if ($id) { if (!$existing = get_record('post', 'id', $id)) { error('Wrong blog post id'); } if (!blog_user_can_edit_post($existing)) { error(get_string('notallowedtoedit', 'blog')); } $userid = $existing->userid; $returnurl = $CFG->wwwroot.'/blog/index.php?userid='.$existing->userid; } else { if (!has_capability('moodle/blog:create', $sitecontext)) { error(get_string('nopost', 'blog')); // manageentries is not enough for adding } $existing = false; $userid = $USER->id; $returnurl = 'index.php?userid='.$USER->id; } if (!empty($courseid)) { $returnurl .= '&courseid='.$courseid; } $errors = array(); $post = new object(); // editing form data $usehtmleditor = can_use_richtext_editor(); $strblogs = get_string('blogs','blog'); switch ($action) { case 'add': if (data_submitted() and confirm_sesskey()) { do_add($post, $errors); if (empty($errors)) { redirect($returnurl); } $post = stripslashes_safe($post); // no db access after this!! // print form again } else { // prepare new empty form $post->subject = ''; $post->summary = ''; $post->publishstate = 'draft'; $post->format = $usehtmleditor ? FORMAT_HTML : FORMAT_MOODLE; } $strformheading = get_string('addnewentry', 'blog'); break; case 'edit': if (!$existing) { error('Incorrect blog post id'); } if (data_submitted() and confirm_sesskey()) { do_edit($post, $errors); if (empty($errors)) { redirect($returnurl); } $post = stripslashes_safe($post); // no db access after this!! // print form again } else { $post->id = $existing->id; $post->subject = $existing->subject; $post->summary = $existing->summary; $post->publishstate = $existing->publishstate; $post->format = $existing->format; } $strformheading = get_string('updateentrywithid', 'blog'); break; case 'delete': if (!$existing) { error('Incorrect blog post id'); } if (data_submitted() and $confirm and confirm_sesskey()) { do_delete($existing); redirect($returnurl); } else { $optionsyes = array('id'=>$id, 'action'=>'delete', 'confirm'=>1, 'sesskey'=>sesskey(), 'courseid'=>$courseid); $optionsno = array('userid'=>$existing->userid, 'courseid'=>$courseid); print_header("$SITE->shortname: $strblogs", $SITE->fullname); blog_print_entry($existing); echo '
'; notice_yesno(get_string('blogdeleteconfirm', 'blog'), 'edit.php', 'index.php', $optionsyes, $optionsno, 'post', 'get'); print_footer(); die; } break; default: error('Unknown action!'); break; } // gui setup // done here in order to allow deleting of posts with wrong user id above if (!$user = get_record('user', 'id', $userid)) { error('Incorrect user id'); } print_header("$SITE->shortname: $strblogs", $SITE->fullname, ''.fullname($user).' -> '.$strblogs.' -> '.$strformheading,'','',true); echo '
'; print_simple_box_start('center'); require('edit.html'); print_simple_box_end(); if ($usehtmleditor) { use_html_editor(); } print_footer(); die; /***************************** edit.php functions ***************************/ /* * Delete blog post from database */ function do_delete($post) { global $returnurl; $status = delete_records('post', 'id', $post->id); $status = delete_records('blog_tag_instance', 'entryid', $post->id) and $status; add_to_log(SITEID, 'blog', 'delete', 'index.php?userid='. $post->userid, 'deleted blog entry with entry id# '. $post->id); if (!$status) { error('Error occured while deleting post', $returnurl); } } /** * Write a new blog entry into database */ function do_add(&$post, &$errors) { global $CFG, $USER, $returnurl; $post->subject = required_param('subject', PARAM_MULTILANG); $post->summary = required_param('summary', PARAM_RAW); $post->format = required_param('format', PARAM_INT); $post->publishstate = required_param('publishstate', PARAM_ALPHA);; if ($post->summary == '
') { $post->summary = ''; } if ($post->subject == '') { $errors['subject'] = get_string('emptytitle', 'blog'); } if ($post->summary == '') { $errors['summary'] = get_string('emptybody', 'blog'); } if (!empty($errors)) { return; // no saving } $post->module = 'blog'; $post->userid = $USER->id; $post->lastmodified = time(); $post->created = time(); // Insert the new blog entry. if ($id = insert_record('post', $post)) { $post->id = $id; add_tags_info($post->id); add_to_log(SITEID, 'blog', 'add', 'index.php?userid='.$post->userid.'&postid='.$posz->id, $post->subject); } else { error('There was an error adding this post in the database', $returnurl); } } /** * @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_edit(&$post, &$errors) { global $CFG, $USER, $returnurl; $post->id = required_param('id', PARAM_INT); $post->subject = required_param('subject', PARAM_MULTILANG); $post->summary = required_param('summary', PARAM_RAW); $post->format = required_param('format', PARAM_INT); $post->publishstate = required_param('publishstate', PARAM_ALPHA);; if ($post->summary == '
') { $post->summary = ''; } if ($post->subject == '') { $errors['subject'] = get_string('emptytitle', 'blog'); } if ($post->summary == '') { $errors['summary'] = get_string('emptybody', 'blog'); } if (!empty($errors)) { return; // no saving } $post->lastmodified = time(); // update record if (update_record('post', $post)) { delete_records('blog_tag_instance', 'entryid', $post->id); add_tags_info($post->id); add_to_log(SITEID, 'blog', 'update', 'index.php?userid='.$post->userid.'&postid='.$post->id, $post->subject); } else { error('There was an error updating this post in the database', $returnurl); } } function add_tags_info($postid) { $post = get_record('post', 'id', $postid); $tag = new object(); $tag->entryid = $post->id; $tag->userid = $post->userid; $tag->timemodified = time(); /// Add tags information if ($otags = optional_param('otags','', PARAM_INT)) { foreach ($otags as $otag) { $tag->tagid = $otag; insert_record('blog_tag_instance', $tag); } } if ($ptags = optional_param('ptags','', PARAM_INT)) { foreach ($ptags as $ptag) { $tag->tagid = $ptag; insert_record('blog_tag_instance', $tag); } } } ?>