. /** * Class to abstract information about (category) context for web service export * @package local_treestudyplan * @copyright 2023 P.M. Kuipers * @license https://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ namespace local_treestudyplan; use context; /** * Class to abstract information about (category) context for web service export */ class contextinfo { /** @var context */ public $context; /** * Create new based on context * @param context $context The context to describe */ public function __construct(context $context) { $this->context = $context; $this->ctxpath = array_reverse($this->context->get_parent_context_ids(true)); if (count($this->ctxpath) > 1 && $this->ctxpath[0] == 1) { array_shift($this->ctxpath); } } /** * Describe the result for the webservice model * @param int $value Webservice requirement constant */ public static function structure($value = VALUE_REQUIRED): \external_description { return new \external_single_structure([ "name" => new \external_value(PARAM_TEXT, 'context name'), "shortname" => new \external_value(PARAM_TEXT, 'context short name'), "path" => new \external_multiple_structure( new \external_value(PARAM_TEXT)), "shortpath" => new \external_multiple_structure( new \external_value(PARAM_TEXT)), ], 'context information', $value); } /** * Make the webservice result model * @return array Webservice value */ public function model() { return [ "name" => $this->context->get_context_name(false, false), "shortname" => $this->context->get_context_name(false, true), "path" => $this->path(false), "shortpath" => $this->path(true), ]; } /** * Return context path names * @param bool $short Use short names of contexts in path * @return array of context path names */ public function path($short=false) { if ($short) { return array_map(function($c) { return ((object)\context::instance_by_id($c))->get_context_name(false, true); }, $this->ctxpath); } else { return array_map(function($c) { return ((object)\context::instance_by_id($c))->get_context_name(false, false); }, $this->ctxpath); } } /** * Return full context path name * @param bool $short Use short names of contexts in path * @return string Concatenated string of paths */ public function pathstr($short=false) { return implode(" / ", $this->path($short)); } /** * Make new Contextinfo for context id * @param int $contextid Context id */ public static function by_id($contextid): self { return new self(self::context_by_id($contextid)); } /** * Find context by id, but also return system context for context id 0 * @param int $contextid Context id * @return context The context */ public static function context_by_id($contextid): \context { if ($contextid <= 1) { $contextid = 1; } $ctx = \context::instance_by_id($contextid); if (is_object($ctx)) { return $ctx; } else { return \context_system::instance(); } } }