diff options
author | ahriman <ahriman@falte.red> | 2018-12-03 19:22:25 -0500 |
---|---|---|
committer | ahriman <ahriman@falte.red> | 2018-12-03 19:22:25 -0500 |
commit | 0ae8cbf5c0b1a198b963490985b7738392ebcb97 (patch) | |
tree | b2c77ae72c6b717e2b97492065196ac5ffb2d9e2 /wiki/inc/Action/Admin.php | |
parent | f57f6cc5a2d159f90168d292437dc4bd8cd7f934 (diff) | |
download | site-0ae8cbf5c0b1a198b963490985b7738392ebcb97.tar.gz |
installed dokuwiki, added to navbar, updated news
Diffstat (limited to 'wiki/inc/Action/Admin.php')
-rw-r--r-- | wiki/inc/Action/Admin.php | 56 |
1 files changed, 56 insertions, 0 deletions
diff --git a/wiki/inc/Action/Admin.php b/wiki/inc/Action/Admin.php new file mode 100644 index 0000000..8d43057 --- /dev/null +++ b/wiki/inc/Action/Admin.php @@ -0,0 +1,56 @@ +<?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() { + global $INFO; + + if($INFO['ismanager']) { + return AUTH_READ; // let in check later + } else { + return AUTH_ADMIN; + } + } + + public function checkPreconditions() { + parent::checkPreconditions(); + + global $INFO; + if(!$INFO['ismanager']) { + throw new ActionException('denied'); + } + } + + public function preProcess() { + global $INPUT; + global $INFO; + + // retrieve admin plugin name from $_REQUEST['page'] + if(($page = $INPUT->str('page', '', true)) != '') { + /** @var $plugin \DokuWiki_Admin_Plugin */ + if($plugin = plugin_getRequestAdminPlugin()) { // FIXME this method does also permission checking + if($plugin->forAdminOnly() && !$INFO['isadmin']) { + throw new ActionException('denied'); + } + $plugin->handle(); + } + } + } + + public function tplContent() { + tpl_admin(); + } + +} |