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.
   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   * mod_wiki data generator.
  19   *
  20   * @package    mod_wiki
  21   * @category   test
  22   * @copyright  2013 Marina Glancy
  23   * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
  24   */
  25  
  26  defined('MOODLE_INTERNAL') || die();
  27  
  28  /**
  29   * mod_wiki data generator class.
  30   *
  31   * @package    mod_wiki
  32   * @category   test
  33   * @copyright  2013 Marina Glancy
  34   * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
  35   */
  36  class mod_wiki_generator extends testing_module_generator {
  37  
  38      /**
  39       * @var int keep track of how many pages have been created.
  40       */
  41      protected $pagecount = 0;
  42  
  43      /**
  44       * To be called from data reset code only,
  45       * do not use in tests.
  46       * @return void
  47       */
  48      public function reset() {
  49          $this->pagecount = 0;
  50          parent::reset();
  51      }
  52  
  53      public function create_instance($record = null, array $options = null) {
  54          // Add default values for wiki.
  55          $record = (array)$record + array(
  56              'wikimode' => 'collaborative',
  57              'firstpagetitle' => 'Front page for wiki '.($this->instancecount+1),
  58              'defaultformat' => 'html',
  59              'forceformat' => 0
  60          );
  61  
  62          return parent::create_instance($record, (array)$options);
  63      }
  64  
  65      public function create_content($wiki, $record = array()) {
  66          $record = (array)$record + array(
  67              'wikiid' => $wiki->id
  68          );
  69          return $this->create_page($wiki, $record);
  70      }
  71  
  72      public function create_first_page($wiki, $record = array()) {
  73          $record = (array)$record + array(
  74              'title' => $wiki->firstpagetitle,
  75          );
  76          return $this->create_page($wiki, $record);
  77      }
  78  
  79      /**
  80       * Retrieves or generates a subwiki and returns its id
  81       *
  82       * @param stdClass $wiki
  83       * @param int $subwikiid
  84       * @param int $group
  85       * @param int $userid
  86       * @return int
  87       */
  88      public function get_subwiki($wiki, $subwikiid = null, $group = null, $userid = null) {
  89          global $USER, $DB;
  90  
  91          if ($subwikiid) {
  92              $params = ['id' => $subwikiid, 'wikiid' => $wiki->id];
  93              if ($group !== null) {
  94                  $params['group'] = $group;
  95              }
  96              if ($userid !== null) {
  97                  $params['userid'] = $userid;
  98              }
  99              return $DB->get_field('wiki_subwikis', 'id', $params, MUST_EXIST);
 100          }
 101  
 102          if ($userid === null) {
 103              $userid = ($wiki->wikimode == 'individual') ? $USER->id : 0;
 104          }
 105          if ($group === null) {
 106              $group = 0;
 107          }
 108          if ($subwiki = wiki_get_subwiki_by_group($wiki->id, $group, $userid)) {
 109              return $subwiki->id;
 110          } else {
 111              return wiki_add_subwiki($wiki->id, $group, $userid);
 112          }
 113      }
 114  
 115      /**
 116       * Generates a page in wiki.
 117       *
 118       * @param stdClass wiki object returned from create_instance (if known)
 119       * @param stdClass|array $record data to insert as wiki entry.
 120       * @return stdClass
 121       * @throws coding_exception if neither $record->wikiid nor $wiki->id is specified
 122       */
 123      public function create_page($wiki, $record = array()) {
 124          global $CFG, $USER;
 125          require_once($CFG->dirroot.'/mod/wiki/locallib.php');
 126          $this->pagecount++;
 127          $record = (array)$record + array(
 128              'title' => 'wiki page '.$this->pagecount,
 129              'wikiid' => $wiki->id,
 130              'subwikiid' => 0,
 131              'group' => null,
 132              'userid' => null,
 133              'content' => 'Wiki page content '.$this->pagecount,
 134              'format' => $wiki->defaultformat
 135          );
 136          if (empty($record['wikiid']) && empty($record['subwikiid'])) {
 137              throw new coding_exception('wiki page generator requires either wikiid or subwikiid');
 138          }
 139          $record['subwikiid'] = $this->get_subwiki($wiki, $record['subwikiid'], $record['group'], $record['userid']);
 140  
 141          $wikipage = wiki_get_page_by_title($record['subwikiid'], $record['title']);
 142          if (!$wikipage) {
 143              $pageid = wiki_create_page($record['subwikiid'], $record['title'], $record['format'], $USER->id);
 144              $wikipage = wiki_get_page($pageid);
 145          }
 146          $rv = wiki_save_page($wikipage, $record['content'], $USER->id);
 147  
 148          if (array_key_exists('tags', $record)) {
 149              $tags = is_array($record['tags']) ? $record['tags'] : preg_split('/,/', $record['tags']);
 150              if (empty($wiki->cmid)) {
 151                  $cm = get_coursemodule_from_instance('wiki', $wiki->id, isset($wiki->course) ? $wiki->course : 0);
 152                  $wiki->cmid = $cm->id;
 153              }
 154              core_tag_tag::set_item_tags('mod_wiki', 'wiki_pages', $wikipage->id,
 155                      context_module::instance($wiki->cmid), $tags);
 156          }
 157          return $rv['page'];
 158      }
 159  }