diff options
author | Yaco <franco@reevo.org> | 2022-03-08 13:08:34 +0000 |
---|---|---|
committer | Yaco <franco@reevo.org> | 2022-03-08 13:08:34 +0000 |
commit | c985c40d3f3fc6a2be3be3186df3bf2f32189475 (patch) | |
tree | cee11f5e5a7e351ee0fec36d58d72cbee4f7e49b /platform/www/inc/Action/Admin.php |
first commit after acervus codebase
Diffstat (limited to 'platform/www/inc/Action/Admin.php')
-rw-r--r-- | platform/www/inc/Action/Admin.php | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/platform/www/inc/Action/Admin.php b/platform/www/inc/Action/Admin.php new file mode 100644 index 0000000..1c9afd6 --- /dev/null +++ b/platform/www/inc/Action/Admin.php @@ -0,0 +1,45 @@ +<?php + +namespace dokuwiki\Action; + +use dokuwiki\Action\Exception\ActionException; + +/** + * Class Admin + * + * Action to show the admin interface or admin plugins + * + * @package dokuwiki\Action + */ +class Admin extends AbstractUserAction { + + /** @inheritdoc */ + public function minimumPermission() { + return AUTH_READ; // let in check later + } + + public function checkPreconditions() { + parent::checkPreconditions(); + } + + public function preProcess() { + global $INPUT; + global $INFO; + + // retrieve admin plugin name from $_REQUEST['page'] + if(($page = $INPUT->str('page', '', true)) != '') { + /** @var $plugin \dokuwiki\Extension\AdminPlugin */ + if($plugin = plugin_getRequestAdminPlugin()) { // FIXME this method does also permission checking + if(!$plugin->isAccessibleByCurrentUser()) { + throw new ActionException('denied'); + } + $plugin->handle(); + } + } + } + + public function tplContent() { + tpl_admin(); + } + +} |