You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
232 lines
7.0 KiB
232 lines
7.0 KiB
2 years ago
|
<?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/>.
|
||
|
|
||
|
/**
|
||
|
* Customfield catecory controller class
|
||
|
*
|
||
|
* @package core_customfield
|
||
|
* @copyright 2018 Toni Barbera <toni@moodle.com>
|
||
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
||
|
*/
|
||
|
|
||
|
namespace core_customfield;
|
||
|
|
||
|
defined('MOODLE_INTERNAL') || die;
|
||
|
|
||
|
/**
|
||
|
* Class category
|
||
|
*
|
||
|
* @package core_customfield
|
||
|
* @copyright 2018 Toni Barbera <toni@moodle.com>
|
||
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
||
|
*/
|
||
|
class category_controller {
|
||
|
|
||
|
/**
|
||
|
* Category persistent
|
||
|
*
|
||
|
* @var category
|
||
|
*/
|
||
|
protected $category;
|
||
|
|
||
|
/**
|
||
|
* @var field_controller[]
|
||
|
*/
|
||
|
protected $fields = [];
|
||
|
|
||
|
/** @var handler */
|
||
|
protected $handler;
|
||
|
|
||
|
/**
|
||
|
* category constructor.
|
||
|
*
|
||
|
* This class is not abstract, however the constructor was made protected to be consistent with
|
||
|
* field_controller and data_controller
|
||
|
*
|
||
|
* @param int $id
|
||
|
* @param \stdClass|null $record
|
||
|
*/
|
||
|
protected function __construct(int $id = 0, \stdClass $record = null) {
|
||
|
$this->category = new category($id, $record);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Creates an instance of category_controller
|
||
|
*
|
||
|
* Either $id or $record or $handler need to be specified
|
||
|
* If handler is known pass it to constructor to avoid retrieving it later
|
||
|
* Component, area and itemid must not conflict with the ones in handler
|
||
|
*
|
||
|
* @param int $id
|
||
|
* @param \stdClass|null $record
|
||
|
* @param handler|null $handler
|
||
|
* @return category_controller
|
||
|
* @throws \moodle_exception
|
||
|
* @throws \coding_exception
|
||
|
*/
|
||
|
public static function create(int $id, \stdClass $record = null, handler $handler = null) : category_controller {
|
||
|
global $DB;
|
||
|
if ($id && $record) {
|
||
|
// This warning really should be in persistent as well.
|
||
|
debugging('Too many parameters, either id need to be specified or a record, but not both.',
|
||
|
DEBUG_DEVELOPER);
|
||
|
}
|
||
|
if ($id) {
|
||
|
if (!$record = $DB->get_record(category::TABLE, array('id' => $id), '*', IGNORE_MISSING)) {
|
||
|
throw new \moodle_exception('categorynotfound', 'core_customfield');
|
||
|
}
|
||
|
}
|
||
|
if (empty($record->component)) {
|
||
|
if (!$handler) {
|
||
|
throw new \coding_exception('Not enough parameters to initialise category_controller - unknown component');
|
||
|
}
|
||
|
$record->component = $handler->get_component();
|
||
|
}
|
||
|
if (empty($record->area)) {
|
||
|
if (!$handler) {
|
||
|
throw new \coding_exception('Not enough parameters to initialise category_controller - unknown area');
|
||
|
}
|
||
|
$record->area = $handler->get_area();
|
||
|
}
|
||
|
if (!isset($record->itemid)) {
|
||
|
if (!$handler) {
|
||
|
throw new \coding_exception('Not enough parameters to initialise category_controller - unknown itemid');
|
||
|
}
|
||
|
$record->itemid = $handler->get_itemid();
|
||
|
}
|
||
|
$category = new self(0, $record);
|
||
|
if (!$category->get('contextid')) {
|
||
|
// If contextid was not present in the record we can find it out from the handler.
|
||
|
$handlernew = $handler ?? $category->get_handler();
|
||
|
$category->set('contextid', $handlernew->get_configuration_context()->id);
|
||
|
}
|
||
|
if ($handler) {
|
||
|
$category->set_handler($handler);
|
||
|
}
|
||
|
return $category;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Persistent getter parser.
|
||
|
*
|
||
|
* @param string $property
|
||
|
* @return mixed
|
||
|
*/
|
||
|
final public function get($property) {
|
||
|
return $this->category->get($property);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Persistent setter parser.
|
||
|
*
|
||
|
* @param string $property
|
||
|
* @param mixed $value
|
||
|
*/
|
||
|
final public function set($property, $value) {
|
||
|
return $this->category->set($property, $value);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Persistent delete parser.
|
||
|
*
|
||
|
* @return bool
|
||
|
*/
|
||
|
final public function delete() {
|
||
|
return $this->category->delete();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Persistent save parser.
|
||
|
*
|
||
|
* @return void
|
||
|
*/
|
||
|
final public function save() {
|
||
|
$this->category->save();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Return an array of field objects associated with this category.
|
||
|
*
|
||
|
* @return field_controller[]
|
||
|
*/
|
||
|
public function get_fields() {
|
||
|
return $this->fields;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Adds a child field
|
||
|
*
|
||
|
* @param field_controller $field
|
||
|
*/
|
||
|
public function add_field(field_controller $field) {
|
||
|
$this->fields[$field->get('id')] = $field;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Gets a handler, if not known retrieve it
|
||
|
*
|
||
|
* @return handler
|
||
|
*/
|
||
|
public function get_handler() : handler {
|
||
|
if ($this->handler === null) {
|
||
|
$this->handler = handler::get_handler($this->get('component'), $this->get('area'), $this->get('itemid'));
|
||
|
}
|
||
|
return $this->handler;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Allows to set handler so we don't need to retrieve it later
|
||
|
*
|
||
|
* @param handler $handler
|
||
|
* @throws \coding_exception
|
||
|
*/
|
||
|
public function set_handler(handler $handler) {
|
||
|
// Make sure there are no conflicts.
|
||
|
if ($this->get('component') !== $handler->get_component()) {
|
||
|
throw new \coding_exception('Component of the handler does not match the one from the record');
|
||
|
}
|
||
|
if ($this->get('area') !== $handler->get_area()) {
|
||
|
throw new \coding_exception('Area of the handler does not match the one from the record');
|
||
|
}
|
||
|
if ($this->get('itemid') != $handler->get_itemid()) {
|
||
|
throw new \coding_exception('Itemid of the handler does not match the one from the record');
|
||
|
}
|
||
|
if ($this->get('contextid') != $handler->get_configuration_context()->id) {
|
||
|
throw new \coding_exception('Context of the handler does not match the one from the record');
|
||
|
}
|
||
|
$this->handler = $handler;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Persistent to_record parser.
|
||
|
*
|
||
|
* @return \stdClass
|
||
|
*/
|
||
|
final public function to_record() {
|
||
|
return $this->category->to_record();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns the category name formatted according to configuration context.
|
||
|
*
|
||
|
* @return string
|
||
|
*/
|
||
|
public function get_formatted_name() : string {
|
||
|
$context = $this->get_handler()->get_configuration_context();
|
||
|
return format_string($this->get('name'), true, ['context' => $context]);
|
||
|
}
|
||
|
}
|