Skip to content

Commit

Permalink
MDL-40711 blogs: Replace blog_entry_deleted with events2
Browse files Browse the repository at this point in the history
  • Loading branch information
ankitagarwal committed Aug 7, 2013
1 parent d451936 commit 6c66b7f
Show file tree
Hide file tree
Showing 4 changed files with 123 additions and 3 deletions.
11 changes: 9 additions & 2 deletions blog/locallib.php
Original file line number Diff line number Diff line change
Expand Up @@ -316,11 +316,18 @@ public function delete() {
$this->delete_attachments();
$this->remove_associations();

// Get record to pass onto the event.
$record = $DB->get_record('post', array('id' => $this->id));
$DB->delete_records('post', array('id' => $this->id));
tag_set('post', $this->id, array());

add_to_log(SITEID, 'blog', 'delete', 'index.php?userid='. $this->userid, 'deleted blog entry with entry id# '. $this->id);
events_trigger('blog_entry_deleted', $this);
$event = \core\event\blog_entry_deleted::create(array('objectid' => $this->id,
'userid' => $this->userid,
'other' => array("record" => (array)$record)
));
$event->add_record_snapshot("post", $record);
$event->set_custom_data($this);
$event->trigger();
}

/**
Expand Down
18 changes: 17 additions & 1 deletion blog/tests/bloglib_test.php
Original file line number Diff line number Diff line change
Expand Up @@ -155,7 +155,7 @@ public function test_blog_get_headers_case_10() {
* Test various blog related events.
*/
public function test_blog_entry_events() {
global $USER;
global $USER, $DB;

$this->setAdminUser();
$this->resetAfterTest();
Expand All @@ -178,5 +178,21 @@ public function test_blog_entry_events() {
$this->assertEquals($blog->id, $event->objectid);
$this->assertEquals($USER->id, $event->userid);
$this->assertEquals("post", $event->objecttable);

// Delete a blog entry.
$record = $DB->get_record('post', array('id' => $blog->id));
$blog->delete();
$events = $sink->get_events();
$event = array_pop($events);

// Validate event data.
$this->assertInstanceOf('\core\event\blog_entry_deleted', $event);
$this->assertEquals(context_system::instance()->id, $event->contextid);
$this->assertEquals($blog->id, $event->objectid);
$this->assertEquals($USER->id, $event->userid);
$this->assertEquals("post", $event->objecttable);
$this->assertEquals($record, $event->get_record_snapshot("post", $blog->id));
$this->assertSame('blog_entry_deleted', $event->get_legacy_eventname());

}
}
1 change: 1 addition & 0 deletions lang/en/blog.php
Original file line number Diff line number Diff line change
Expand Up @@ -88,6 +88,7 @@
$string['entrytitle'] = 'Entry title';
$string['entryupdated'] = 'Blog entry updated';
$string['evententryadded'] = 'Blog entry added';
$string['evententrydeleted'] = 'Blog entry deleted';
$string['externalblogcrontime'] = 'External blog cron schedule';
$string['externalblogdeleteconfirm'] = 'Unregister this external blog?';
$string['externalblogdeleted'] = 'External blog unregistered';
Expand Down
96 changes: 96 additions & 0 deletions lib/classes/event/blog_entry_deleted.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,96 @@
<?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/>.

namespace core\event;

/**
* Event for when a new blog entry is deleted.
*
* @package core_blog
* @copyright 2013 Ankit Agarwal
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/

class blog_entry_deleted extends \core\event\base {

/** @var \blog_entry A reference to the active blog_entry object. */
protected $customobject;

protected function init() {
$this->context = \context_system::instance();
$this->data['objecttable'] = 'post';
$this->data['crud'] = 'd';
// TODO: MDL-37658 set level.
$this->data['level'] = 50;
}

/**
* Returns localised general event name.
*
* @return \lang_string
*/
public static function get_name() {
return new \lang_string("evententrydeleted", "core_blog");
}

/**
* Set custom data of the event.
*
* @param \blog_entry $data A reference to the active blog_entry object.
*/
public function set_custom_data($data) {
$this->customobject = $data;
}

/**
* Returns localised description of what happened.
*
* @return \lang_string
*/
public function get_description() {
$a = new \stdClass();
$a->subject = $this->other['record']['subject'];
$a->userid = $this->userid;
return new \lang_string("evententrydeleteddesc", "core_blog", $a);
}

/**
* Does this event replace legacy event?
*
* @return string legacy event name
*/
public static function get_legacy_eventname() {
return 'blog_entry_deleted';
}

/**
* Legacy event data if get_legacy_eventname() is not empty.
*
* @return \blog_entry
*/
protected function get_legacy_eventdata() {
return $this->customobject;
}

/**
* replace add_to_log() statement.
*
* @return array of parameters to be passed to legacy add_to_log() function.
*/
protected function get_legacy_logdata() {
return array (SITEID, 'blog', 'delete', 'index.php?userid='.$this->userid, 'deleted blog entry with entry id# '. $this->objectid);
}
}

0 comments on commit 6c66b7f

Please sign in to comment.