Proyectos de Subversion Moodle

Rev

Autoría | Ultima modificación | Ver Log |

<?php
// This file is part of the Zoom plugin for 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/>.

/**
 * Define all the restore steps that will be used by the restore_zoom_activity_task
 *
 * @package   mod_zoom
 * @category  backup
 * @copyright 2015 UC Regents
 * @license   http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */

namespace mod_zoom;

defined('MOODLE_INTERNAL') || die();

require_once($CFG->dirroot . '/mod/zoom/locallib.php');

use moodle_exception;
use restore_path_element;

/**
 * Structure step to restore one zoom activity
 */
class restore_activity_structure_step extends \restore_activity_structure_step {
    /**
     * Defines structure of path elements to be processed during the restore
     *
     * @return array of restore_path_element
     */
    protected function define_structure() {
        $paths = [];
        $paths[] = new restore_path_element('zoom', '/activity/zoom');
        $paths[] = new restore_path_element('zoom_tracking_field', '/activity/zoom/trackingfields/trackingfield');

        // Return the paths wrapped into standard activity structure.
        return $this->prepare_activity_structure($paths);
    }

    /**
     * Process the given restore path element data
     *
     * @param array $data parsed element data
     */
    protected function process_zoom($data) {
        global $DB;

        $data = (object) $data;

        // Update start_time before attempting to create a new meeting.
        $data->start_time = $this->apply_date_offset($data->start_time);

        // Either create a new meeting or set meeting as expired.
        try {
            $updateddata = zoom_webservice()->create_meeting($data);
            $data = populate_zoom_from_response($data, $updateddata);
            $data->exists_on_zoom = ZOOM_MEETING_EXISTS;
        } catch (moodle_exception $e) {
            $data->join_url = '';
            $data->meeting_id = 0;
            $data->exists_on_zoom = ZOOM_MEETING_EXPIRED;
        }

        $data->course = $this->get_courseid();

        if (empty($data->timemodified)) {
            $data->timemodified = time();
        }

        if ($data->grade < 0) {
            // Scale found, get mapping.
            $data->grade = -($this->get_mappingid('scale', abs($data->grade)));
        }

        // Create the zoom instance.
        $newitemid = $DB->insert_record('zoom', $data);
        $this->apply_activity_instance($newitemid);

        // Create the calendar events for the new meeting.
        $data->id = $newitemid;
        zoom_calendar_item_update($data);
    }

    /**
     * Process the zoom tracking fields.
     *
     * @param array $data
     */
    protected function process_zoom_tracking_field($data) {
        global $DB;

        $data = (object) $data;
        $oldid = $data->id;

        $data->meeting_id = $this->get_new_parentid('zoom');

        $defaulttrackingfields = zoom_clean_tracking_fields();

        if (isset($defaulttrackingfields[$data->tracking_field])) {
            $newitemid = $DB->insert_record('zoom_meeting_tracking_fields', $data);
            $this->set_mapping('zoom_tracking_field', $oldid, $newitemid);
        }
    }

    /**
     * Post-execution actions
     */
    protected function after_execute() {
        // Add zoom related files, no need to match by itemname (just internally handled context).
        $this->add_related_files('mod_zoom', 'intro', null);
    }
}