mirror of
https://github.com/moodle/moodle.git
synced 2025-08-05 17:06:53 +02:00
MDL-62491 core_privacy: Add html files to the user data export.
This adds html to the data export that allows for easier navigation and reading of data.
This commit is contained in:
parent
129783b98c
commit
e90a0a7415
12 changed files with 1321 additions and 11 deletions
87
privacy/classes/output/exported_html_page.php
Normal file
87
privacy/classes/output/exported_html_page.php
Normal file
|
@ -0,0 +1,87 @@
|
|||
<?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/>.
|
||||
|
||||
/**
|
||||
* Contains the navigation renderable for user data exports.
|
||||
*
|
||||
* @package core_privacy
|
||||
* @copyright 2018 Adrian Greeve
|
||||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
||||
*/
|
||||
namespace core_privacy\output;
|
||||
defined('MOODLE_INTERNAL') || die();
|
||||
|
||||
use renderable;
|
||||
use renderer_base;
|
||||
use templatable;
|
||||
|
||||
/**
|
||||
* Class containing the navigation renderable
|
||||
*
|
||||
* @copyright 2018 Adrian Greeve
|
||||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
||||
*/
|
||||
class exported_html_page implements renderable, templatable {
|
||||
|
||||
/** @var string $navigationdata navigation html to be displayed about the system. */
|
||||
protected $navigationdata;
|
||||
|
||||
/** @var string $systemname systemname for the page. */
|
||||
protected $systemname;
|
||||
|
||||
/** @var string $username The full name of the user. */
|
||||
protected $username;
|
||||
|
||||
/** @var bool $rtl The direction to show the page (right to left) */
|
||||
protected $rtl;
|
||||
|
||||
/** @var string $siteurl The url back to the site that created this export. */
|
||||
protected $siteurl;
|
||||
|
||||
/**
|
||||
* Constructor.
|
||||
*
|
||||
* @param string $navigationdata Navigation html to be displayed about the system.
|
||||
* @param string $systemname systemname for the page.
|
||||
* @param string $username The full name of the user.
|
||||
* @param bool $righttoleft Is the language used right to left?
|
||||
* @param string $siteurl The url to the site that created this export.
|
||||
*/
|
||||
public function __construct(string $navigationdata, string $systemname, string $username, bool $righttoleft, string $siteurl) {
|
||||
$this->navigationdata = $navigationdata;
|
||||
$this->systemname = $systemname;
|
||||
$this->username = $username;
|
||||
$this->rtl = $righttoleft;
|
||||
$this->siteurl = $siteurl;
|
||||
}
|
||||
|
||||
/**
|
||||
* Export this data so it can be used as the context for a mustache template.
|
||||
*
|
||||
* @param renderer_base $output
|
||||
* @return array
|
||||
*/
|
||||
public function export_for_template(renderer_base $output) : Array {
|
||||
return [
|
||||
'navigation' => $this->navigationdata,
|
||||
'systemname' => $this->systemname,
|
||||
'timegenerated' => time(),
|
||||
'username' => $this->username,
|
||||
'righttoleft' => $this->rtl,
|
||||
'siteurl' => $this->siteurl
|
||||
];
|
||||
}
|
||||
}
|
98
privacy/classes/output/exported_navigation_page.php
Normal file
98
privacy/classes/output/exported_navigation_page.php
Normal file
|
@ -0,0 +1,98 @@
|
|||
<?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/>.
|
||||
|
||||
/**
|
||||
* Contains the navigation renderable for user data exports.
|
||||
*
|
||||
* @package core_privacy
|
||||
* @copyright 2018 Adrian Greeve
|
||||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
||||
*/
|
||||
namespace core_privacy\output;
|
||||
defined('MOODLE_INTERNAL') || die();
|
||||
|
||||
use renderable;
|
||||
use renderer_base;
|
||||
use templatable;
|
||||
|
||||
/**
|
||||
* Class containing the navigation renderable
|
||||
*
|
||||
* @copyright 2018 Adrian Greeve
|
||||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
||||
*/
|
||||
class exported_navigation_page implements renderable, templatable {
|
||||
|
||||
/** @var array $tree Full tree in multidimensional form. */
|
||||
protected $tree;
|
||||
|
||||
/** @var boolean $firstelement This is used to create unique classes for the first elements in the navigation tree. */
|
||||
protected $firstelement = true;
|
||||
|
||||
/**
|
||||
* Constructor
|
||||
*
|
||||
* @param \stdClass $tree Full tree to create navigation out of.
|
||||
*/
|
||||
public function __construct(\stdClass $tree) {
|
||||
$this->tree = $tree;
|
||||
}
|
||||
|
||||
/**
|
||||
* Creates the navigation list html. Why this and not a template? My attempts at trying to get a recursive template
|
||||
* working failed.
|
||||
*
|
||||
* @param \stdClass $tree Full tree to create navigation out of.
|
||||
* @return string navigation html.
|
||||
*/
|
||||
protected function create_navigation(\stdClass $tree) {
|
||||
if ($this->firstelement) {
|
||||
$html = \html_writer::start_tag('ul', ['class' => 'treeview parent block_tree list', 'id' => 'my-tree']);
|
||||
$this->firstelement = false;
|
||||
} else {
|
||||
$html = \html_writer::start_tag('ul', ['class' => 'parent', 'role' => 'group']);
|
||||
}
|
||||
foreach ($tree->children as $child) {
|
||||
if (isset($child->children)) {
|
||||
$html .= \html_writer::start_tag('li', ['class' => 'menu-item', 'role' => 'treeitem', 'aria-expanded' => 'false']);
|
||||
$html .= $child->name;
|
||||
$html .= $this->create_navigation($child);
|
||||
} else {
|
||||
$html .= \html_writer::start_tag('li', ['class' => 'item', 'role' => 'treeitem', 'aria-expanded' => 'false']);
|
||||
// Normal display.
|
||||
if (isset($child->datavar)) {
|
||||
$html .= \html_writer::link('#', $child->name, ['data-var' => $child->datavar]);
|
||||
} else {
|
||||
$html .= \html_writer::link($child->url, $child->name, ['target' => '_blank']);
|
||||
}
|
||||
}
|
||||
$html .= \html_writer::end_tag('li');
|
||||
}
|
||||
$html .= \html_writer::end_tag('ul');
|
||||
return $html;
|
||||
}
|
||||
|
||||
/**
|
||||
* Export this data so it can be used as the context for a mustache template.
|
||||
*
|
||||
* @param renderer_base $output
|
||||
* @return array navigation data for the template.
|
||||
*/
|
||||
public function export_for_template(renderer_base $output) : Array {
|
||||
$data = $this->create_navigation($this->tree);
|
||||
return ['navigation' => $data];
|
||||
}
|
||||
}
|
58
privacy/classes/output/renderer.php
Normal file
58
privacy/classes/output/renderer.php
Normal file
|
@ -0,0 +1,58 @@
|
|||
<?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/>.
|
||||
|
||||
/**
|
||||
* Privacy renderer.
|
||||
*
|
||||
* @package core_privacy
|
||||
* @copyright 2018 Adrian Greeve <adrian@moodle.com>
|
||||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
||||
*/
|
||||
|
||||
namespace core_privacy\output;
|
||||
defined('MOODLE_INTERNAL') || die;
|
||||
/**
|
||||
* Privacy renderer's for privacy stuff.
|
||||
*
|
||||
* @since Moodle 3.6
|
||||
* @package core_privacy
|
||||
* @copyright 2018 Adrian Greeve <adrian@moodle.com>
|
||||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
||||
*/
|
||||
class renderer extends \plugin_renderer_base {
|
||||
|
||||
/**
|
||||
* Render the whole tree.
|
||||
*
|
||||
* @param navigation_page $page
|
||||
* @return string
|
||||
*/
|
||||
public function render_navigation(exported_navigation_page $page) {
|
||||
$data = $page->export_for_template($this);
|
||||
return parent::render_from_template('core_privacy/navigation', $data);
|
||||
}
|
||||
|
||||
/**
|
||||
* Render the html page.
|
||||
*
|
||||
* @param html_page $page
|
||||
* @return string
|
||||
*/
|
||||
public function render_html_page(exported_html_page $page) {
|
||||
$data = $page->export_for_template($this);
|
||||
return parent::render_from_template('core_privacy/htmlpage', $data);
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue