Search moodle.org's
Developer Documentation

See Release Notes

  • Bug fixes for general core bugs in 4.0.x will end 8 May 2023 (12 months).
  • Bug fixes for security issues in 4.0.x will end 13 November 2023 (18 months).
  • PHP version: minimum PHP 7.3.0 Note: the minimum PHP version has increased since Moodle 3.10. PHP 7.4.x is also supported.

Differences Between: [Versions 400 and 403]

   1  <?php
   2  // This file is part of Moodle - http://moodle.org/
   3  //
   4  // Moodle is free software: you can redistribute it and/or modify
   5  // it under the terms of the GNU General Public License as published by
   6  // the Free Software Foundation, either version 3 of the License, or
   7  // (at your option) any later version.
   8  //
   9  // Moodle is distributed in the hope that it will be useful,
  10  // but WITHOUT ANY WARRANTY; without even the implied warranty of
  11  // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  12  // GNU General Public License for more details.
  13  //
  14  // You should have received a copy of the GNU General Public License
  15  // along with Moodle.  If not, see <http://www.gnu.org/licenses/>.
  16  
  17  /**
  18   * Class for the structure used for restore BigBlueButtonBN.
  19   *
  20   * @package   mod_bigbluebuttonbn
  21   * @copyright 2010 onwards, Blindside Networks Inc
  22   * @license   http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
  23   * @author    Fred Dixon  (ffdixon [at] blindsidenetworks [dt] com)
  24   * @author    Jesus Federico  (jesus [at] blindsidenetworks [dt] com)
  25   */
  26  
  27  /**
  28   * Define all the restore steps that will be used by the restore_url_activity_task.
  29   *
  30   * @package   mod_bigbluebuttonbn
  31   * @copyright 2010 onwards, Blindside Networks Inc
  32   * @license   http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
  33   */
  34  class restore_bigbluebuttonbn_activity_structure_step extends restore_activity_structure_step {
  35      /**
  36       * Structure step to restore one bigbluebuttonbn activity.
  37       *
  38       * @return array
  39       */
  40      protected function define_structure() {
  41          $paths = [];
  42          $paths[] = new restore_path_element('bigbluebuttonbn', '/activity/bigbluebuttonbn');
  43          $paths[] = new restore_path_element('bigbluebuttonbn_logs', '/activity/bigbluebuttonbn/logs/log');
  44          $paths[] = new restore_path_element('bigbluebuttonbn_recordings', '/activity/bigbluebuttonbn/recordings/recording');
  45          // Return the paths wrapped into standard activity structure.
  46          return $this->prepare_activity_structure($paths);
  47      }
  48  
  49      /**
  50       * Process a bigbluebuttonbn restore.
  51       *
  52       * @param array $data The data in object form
  53       * @return void
  54       */
  55      protected function process_bigbluebuttonbn(array $data) {
  56          global $DB;
  57          $data = (object) $data;
  58          $data->course = $this->get_courseid();
  59          $data->timemodified = $this->apply_date_offset($data->timemodified);
  60          // Check if we are in backup::MODE_IMPORT (we set a new meetingid) or backup::MODE_GENERAL (we keep the same meetingid).
  61          if ($this->get_task()->get_info()->mode == backup::MODE_IMPORT || empty($data->meetingid)) {
  62              // We are in backup::MODE_IMPORT, we need to renew the meetingid.
  63              $data->meetingid = \mod_bigbluebuttonbn\meeting::get_unique_meetingid_seed();
  64          }
  65          // Insert the bigbluebuttonbn record.
  66          $newitemid = $DB->insert_record('bigbluebuttonbn', $data);
  67          // Immediately after inserting "activity" record, call this.
  68          $this->apply_activity_instance($newitemid);
  69      }
  70  
  71      /**
  72       * Process a bigbluebuttonbn_logs restore (additional table).
  73       *
  74       * @param array $data The data in object form
  75       * @return void
  76       */
  77      protected function process_bigbluebuttonbn_logs(array $data) {
  78          global $DB;
  79          $data = (object) $data;
  80          // Apply modifications.
  81          $data->courseid = $this->get_mappingid('course', $data->courseid);
  82          $data->bigbluebuttonbnid = $this->get_new_parentid('bigbluebuttonbn');
  83          $data->userid = $this->get_mappingid('user', $data->userid);
  84          $data->timecreated = $this->apply_date_offset($data->timecreated);
  85          // Insert the bigbluebuttonbn_logs record.
  86          $newitemid = $DB->insert_record('bigbluebuttonbn_logs', $data);
  87          // Immediately after inserting associated record, call this.
  88          $this->set_mapping('bigbluebuttonbn_logs', $data->id, $newitemid);
  89      }
  90  
  91      /**
  92       * Process a bigbluebuttonbn_recordings restore (additional table).
  93       *
  94       * @param array $data The data in object form
  95       * @return void
  96       */
  97      protected function process_bigbluebuttonbn_recordings(array $data) {
  98          global $DB;
  99          $data = (object) $data;
 100          // Apply modifications.
 101          $data->courseid = $this->get_mappingid('course', $data->courseid);
 102          $data->bigbluebuttonbnid = $this->get_new_parentid('bigbluebuttonbn');
 103          $data->timecreated = $this->apply_date_offset($data->timecreated);
 104          // Insert the bigbluebuttonbn_recordings record.
 105          $newitemid = $DB->insert_record('bigbluebuttonbn_recordings', $data);
 106          // Immediately after inserting associated record, call this.
 107          $this->set_mapping('bigbluebuttonbn_recordings', $data->id, $newitemid);
 108      }
 109  
 110      /**
 111       * Actions to be executed after the restore is completed
 112       *
 113       * @return void
 114       */
 115      protected function after_execute() {
 116          // Add bigbluebuttonbn related files, no need to match by itemname (just internally handled context).
 117          $this->add_related_files('mod_bigbluebuttonbn', 'intro', null);
 118      }
 119  }