diff options
author | Andreas Gohr <andi@splitbrain.org> | 2014-01-19 11:28:29 -0800 |
---|---|---|
committer | Andreas Gohr <andi@splitbrain.org> | 2014-01-19 11:28:29 -0800 |
commit | 0df76c4421bf3fa2c187d25b9409b5225850d1f5 (patch) | |
tree | 95d89ff523d854044838f0aa3a89e18045202087 | |
parent | 7efb3bf876abe912028d117a4ac4a91c36a8f93a (diff) | |
parent | c17acc9f11cd61909a9395b560e759686c7717e6 (diff) | |
download | rpg-0df76c4421bf3fa2c187d25b9409b5225850d1f5.tar.gz rpg-0df76c4421bf3fa2c187d25b9409b5225850d1f5.tar.bz2 |
Merge pull request #493 from splitbrain/aclevent
AUTH_ACL_CHECK event around ACL checking
-rw-r--r-- | inc/auth.php | 28 |
1 files changed, 25 insertions, 3 deletions
diff --git a/inc/auth.php b/inc/auth.php index b793f5d12..6000ea6d7 100644 --- a/inc/auth.php +++ b/inc/auth.php @@ -661,17 +661,39 @@ function auth_quickaclcheck($id) { } /** - * Returns the maximum rights a user has for - * the given ID or its namespace + * Returns the maximum rights a user has for the given ID or its namespace * * @author Andreas Gohr <andi@splitbrain.org> - * + * @triggers AUTH_ACL_CHECK * @param string $id page ID (needs to be resolved and cleaned) * @param string $user Username * @param array|null $groups Array of groups the user is in * @return int permission level */ function auth_aclcheck($id, $user, $groups) { + $data = array( + 'id' => $id, + 'user' => $user, + 'groups' => $groups + ); + + return trigger_event('AUTH_ACL_CHECK', $data, 'auth_aclcheck_cb'); +} + +/** + * default ACL check method + * + * DO NOT CALL DIRECTLY, use auth_aclcheck() instead + * + * @author Andreas Gohr <andi@splitbrain.org> + * @param array $data event data + * @return int permission level + */ +function auth_aclcheck_cb($data) { + $id =& $data['id']; + $user =& $data['user']; + $groups =& $data['groups']; + global $conf; global $AUTH_ACL; /* @var DokuWiki_Auth_Plugin $auth */ |