Search moodle.org's
Developer Documentation

See Release Notes

  • Bug fixes for general core bugs in 3.11.x will end 14 Nov 2022 (12 months plus 6 months extension).
  • Bug fixes for security issues in 3.11.x will end 13 Nov 2023 (18 months plus 12 months extension).
  • PHP version: minimum PHP 7.3.0 Note: minimum PHP version has increased since Moodle 3.10. PHP 7.4.x is supported too.

Differences Between: [Versions 311 and 402] [Versions 311 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   * The mod_workshop assessable uploaded event.
  19   *
  20   * @package    mod_workshop
  21   * @copyright  2013 Frédéric Massart
  22   * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
  23   */
  24  
  25  namespace mod_workshop\event;
  26  
  27  defined('MOODLE_INTERNAL') || die();
  28  
  29  /**
  30   * The mod_workshop assessable uploaded event class.
  31   *
  32   * @package    mod_workshop
  33   * @since      Moodle 2.6
  34   * @copyright  2013 Frédéric Massart
  35   * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
  36   */
  37  class assessable_uploaded extends \core\event\assessable_uploaded {
  38  
  39      /**
  40       * Legacy log data.
  41       *
  42       * @var array
  43       */
  44      protected $legacylogdata = null;
  45  
  46      /**
  47       * Returns description of what happened.
  48       *
  49       * @return string
  50       */
  51      public function get_description() {
  52          return "The user with id '$this->userid' has uploaded the submission with id '$this->objectid' " .
  53              "to the workshop activity with course module id '$this->contextinstanceid'.";
  54      }
  55  
  56      /**
  57       * Legacy event data if get_legacy_eventname() is not empty.
  58       *
  59       * @return \stdClass
  60       */
  61      protected function get_legacy_eventdata() {
  62          $eventdata = new \stdClass();
  63          $eventdata->modulename   = 'workshop';
  64          $eventdata->cmid         = $this->contextinstanceid;
  65          $eventdata->itemid       = $this->objectid;
  66          $eventdata->courseid     = $this->courseid;
  67          $eventdata->userid       = $this->userid;
  68          $eventdata->content      = $this->other['content'];
  69          if ($this->other['pathnamehashes']) {
  70              $eventdata->pathnamehashes = $this->other['pathnamehashes'];
  71          }
  72          return $eventdata;
  73      }
  74  
  75      /**
  76       * Return the legacy event name.
  77       *
  78       * @return string
  79       */
  80      public static function get_legacy_eventname() {
  81          return 'assessable_content_uploaded';
  82      }
  83  
  84      /**
  85       * Return the legacy log data.
  86       *
  87       * @return array
  88       */
  89      protected function get_legacy_logdata() {
  90          return $this->legacylogdata;
  91      }
  92  
  93      /**
  94       * Return localised event name.
  95       *
  96       * @return string
  97       */
  98      public static function get_name() {
  99          return get_string('eventassessableuploaded', 'mod_workshop');
 100      }
 101  
 102      /**
 103       * Get URL related to the action.
 104       *
 105       * @return \moodle_url
 106       */
 107      public function get_url() {
 108          return new \moodle_url('/mod/workshop/submission.php',
 109              array('cmid' => $this->contextinstanceid, 'id' => $this->objectid));
 110      }
 111  
 112      /**
 113       * Init method.
 114       *
 115       * @return void
 116       */
 117      protected function init() {
 118          parent::init();
 119          $this->data['objecttable'] = 'workshop_submissions';
 120      }
 121  
 122      /**
 123       * Set the legacy log data.
 124       *
 125       * @param array $legacylogdata
 126       * @return void
 127       */
 128      public function set_legacy_logdata($legacylogdata) {
 129          $this->legacylogdata = $legacylogdata;
 130      }
 131  
 132      public static function get_objectid_mapping() {
 133          return array('db' => 'workshop_submissions', 'restore' => 'workshop_submission');
 134      }
 135  }