MDL-22151, backup for chat module
authorDongsheng Cai <unoter@gmail.com>
Thu, 6 May 2010 09:30:42 +0000 (09:30 +0000)
committerDongsheng Cai <unoter@gmail.com>
Thu, 6 May 2010 09:30:42 +0000 (09:30 +0000)
mod/chat/backup/moodle2/backup_chat_activity_task.class.php [new file with mode: 0644]
mod/chat/backup/moodle2/backup_chat_stepslib.php [new file with mode: 0644]
mod/chat/lib.php

diff --git a/mod/chat/backup/moodle2/backup_chat_activity_task.class.php b/mod/chat/backup/moodle2/backup_chat_activity_task.class.php
new file mode 100644 (file)
index 0000000..99703ce
--- /dev/null
@@ -0,0 +1,85 @@
+<?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/>.
+
+/**
+ * This is the "graphical" structure of the chat mod:
+ *
+ *                        chat
+ *                     (CL,pk->id)
+ *                         |
+ *                         |
+ *                         |
+ *                    chat_messages
+ *                (UL,pk->id, fk->chatid)
+ *
+ *  Meaning: pk->primary key field of the table
+ *           fk->foreign key to link with parent
+ *           nt->nested field (recursive data)
+ *           CL->course level info
+ *           UL->user level info
+ *
+ * @package moodlecore
+ * @subpackage backup-moodle2
+ * @copyright 2010 onwards Dongsheng Cai <dongsheng@moodle.com>
+ * @license   http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
+ */
+require_once($CFG->dirroot . '/mod/chat/backup/moodle2/backup_chat_stepslib.php'); // Because it exists (must)
+
+/**
+ * chat backup task that provides all the settings and steps to perform one
+ * complete backup of the activity
+ */
+class backup_chat_activity_task extends backup_activity_task {
+
+    /**
+     * Define (add) particular settings this activity can have
+     */
+    protected function define_my_settings() {
+        // No particular settings for this activity
+    }
+
+    /**
+     * Define (add) particular steps this activity can have
+     */
+    protected function define_my_steps() {
+        // chat only has one structure step
+        $this->add_step(new backup_chat_activity_structure_step('chat_structure', 'chat.xml'));
+    }
+
+    /**
+     * Code the transformations to perform in the chat activity in
+     * order to get transportable (encoded) links
+     *
+     * @param string $content
+     * @return string
+     */
+    static public function encode_content_links($content) {
+        global $CFG;
+
+        $base = preg_quote($CFG->wwwroot.'/mod/chat','#');
+
+        //Link to the list of chats
+        $pattern = "#(".$base."\/index.php\?id\=)([0-9]+)#";
+        $content = preg_replace($pattern, '$@CHATINDEX*$2@$', $content);
+
+        //Link to chat view by moduleid
+        $pattern = "#(".$base."\/view.php\?id\=)([0-9]+)#";
+        $content = preg_replace($pattern, '$@CHATVIEWBYID*$2@$', $content);
+
+        return $content;
+    }
+}
diff --git a/mod/chat/backup/moodle2/backup_chat_stepslib.php b/mod/chat/backup/moodle2/backup_chat_stepslib.php
new file mode 100644 (file)
index 0000000..09f358e
--- /dev/null
@@ -0,0 +1,65 @@
+<?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/>.
+
+/**
+ * @package moodlecore
+ * @subpackage backup-moodle2
+ * @copyright 2010 onwards Dongsheng Cai <dongsheng@moodle.com>
+ * @license   http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
+ */
+
+/**
+ * Define all the backup steps that will be used by the backup_chat_activity_task
+ */
+class backup_chat_activity_structure_step extends backup_activity_structure_step {
+    protected function define_structure() {
+        $userinfo = $this->get_setting_value('userinfo');
+
+        // Define each element separated
+        $chat = new backup_nested_element('chat', array('id'), array(
+            'name', 'intro', 'introformat', 'keepdays', 'studentlogs',
+            'chattime', 'schedule', 'timemodified'));
+        $messages = new backup_nested_element('messages');
+
+        $message = new backup_nested_element('message', array('id'), array('userid', 'groupid', 'system', 'message_text', 'timestamp'));
+
+        // it is not cool to have two tags with same name, so we need to rename message field to message_text
+        $message->set_source_alias('message', 'message_text');
+
+        // Build the tree
+        $chat->add_child($messages);
+            $messages->add_child($message);
+
+        // Define sources
+        $chat->set_source_table('chat', array('id' => backup::VAR_ACTIVITYID));
+
+        // User related messages only happen if we are including user info
+        if ($userinfo) {
+            $message->set_source_table('chat_messages', array('chatid'=>backup::VAR_PARENTID));
+        }
+
+        // Define id annotations
+        $message->annotate_ids('user', 'userid');
+        $message->annotate_ids('group', 'groupid');
+
+        // Annotate the file areas in chat module
+        $chat->annotate_files(array('chat_intro'), null); // chat_intro area don't use itemid
+
+        // Return the root element (chat), wrapped into standard activity structure
+        return $this->prepare_activity_structure($chat);
+    }
+}
index 49fb965..ed9b6ce 100644 (file)
@@ -1221,6 +1221,7 @@ function chat_supports($feature) {
         case FEATURE_GROUPINGS:               return true;
         case FEATURE_GROUPMEMBERSONLY:        return true;
         case FEATURE_MOD_INTRO:               return true;
+        case FEATURE_BACKUP_MOODLE2:          return true;
         case FEATURE_COMPLETION_TRACKS_VIEWS: return false;
         case FEATURE_GRADE_HAS_GRADE:         return false;
         case FEATURE_GRADE_OUTCOMES:          return true;