mirror of
https://github.com/phpbb/phpbb.git
synced 2025-01-17 22:28:46 +01:00
28f98402f3
PHPBB3-16574
367 lines
14 KiB
PHP
367 lines
14 KiB
PHP
<?php
|
|
/**
|
|
*
|
|
* This file is part of the phpBB Forum Software package.
|
|
*
|
|
* @copyright (c) phpBB Limited <https://www.phpbb.com>
|
|
* @license GNU General Public License, version 2 (GPL-2.0)
|
|
*
|
|
* For full copyright and license information, please see
|
|
* the docs/CREDITS.txt file.
|
|
*
|
|
*/
|
|
|
|
namespace phpbb;
|
|
|
|
class permissions
|
|
{
|
|
/**
|
|
* Event dispatcher object
|
|
* @var \phpbb\event\dispatcher_interface
|
|
*/
|
|
protected $dispatcher;
|
|
|
|
/**
|
|
* User object
|
|
* @var \phpbb\user
|
|
*/
|
|
protected $user;
|
|
|
|
/**
|
|
* Constructor
|
|
*
|
|
* @param \phpbb\event\dispatcher_interface $phpbb_dispatcher Event dispatcher
|
|
* @param \phpbb\user $user User Object
|
|
*/
|
|
public function __construct(\phpbb\event\dispatcher_interface $phpbb_dispatcher, \phpbb\user $user)
|
|
{
|
|
$this->dispatcher = $phpbb_dispatcher;
|
|
$this->user = $user;
|
|
|
|
$categories = $this->categories;
|
|
$types = $this->types;
|
|
$permissions = $this->permissions;
|
|
|
|
/**
|
|
* Allows to specify additional permission categories, types and permissions
|
|
*
|
|
* @event core.permissions
|
|
* @var array types Array with permission types (a_, u_, m_, etc.)
|
|
* @var array categories Array with permission categories (pm, post, settings, misc, etc.)
|
|
* @var array permissions Array with permissions. Each Permission has the following layout:
|
|
* '<type><permission>' => array(
|
|
* 'lang' => 'Language Key with a Short description', // Optional, if not set,
|
|
* // the permissions identifier '<type><permission>' is used with
|
|
* // all uppercase.
|
|
* 'cat' => 'Identifier of the category, the permission should be displayed in',
|
|
* ),
|
|
* Example:
|
|
* 'u_viewprofile' => array(
|
|
* 'lang' => 'ACL_U_VIEWPROFILE',
|
|
* 'cat' => 'profile',
|
|
* ),
|
|
* @since 3.1.0-a1
|
|
*/
|
|
$vars = array('types', 'categories', 'permissions');
|
|
extract($this->dispatcher->trigger_event('core.permissions', compact($vars)));
|
|
|
|
$this->categories = $categories;
|
|
$this->types = $types;
|
|
$this->permissions = $permissions;
|
|
}
|
|
|
|
/**
|
|
* Returns an array with all the permission categories (pm, post, settings, misc, etc.)
|
|
*
|
|
* @return array Layout: cat-identifier => Language key
|
|
*/
|
|
public function get_categories()
|
|
{
|
|
return $this->categories;
|
|
}
|
|
|
|
/**
|
|
* Returns the language string of a permission category
|
|
*
|
|
* @param string $category Identifier of the category
|
|
* @return string Language string
|
|
*/
|
|
public function get_category_lang($category)
|
|
{
|
|
return $this->user->lang($this->categories[$category]);
|
|
}
|
|
|
|
/**
|
|
* Returns an array with all the permission types (a_, u_, m_, etc.)
|
|
*
|
|
* @return array Layout: type-identifier => Language key
|
|
*/
|
|
public function get_types()
|
|
{
|
|
return $this->types;
|
|
}
|
|
|
|
/**
|
|
* Returns the language string of a permission type
|
|
*
|
|
* @param string $type Identifier of the type
|
|
* @param mixed $scope Scope of the type (should be 'global', 'local' or false)
|
|
* @return string Language string
|
|
*/
|
|
public function get_type_lang($type, $scope = false)
|
|
{
|
|
if ($scope && isset($this->types[$scope][$type]))
|
|
{
|
|
$lang_key = $this->types[$scope][$type];
|
|
}
|
|
else if (isset($this->types[$type]))
|
|
{
|
|
$lang_key = $this->types[$type];
|
|
}
|
|
else
|
|
{
|
|
$lang_key = 'ACL_TYPE_' . strtoupper(($scope) ? $scope . '_' . $type : $type);
|
|
}
|
|
|
|
return $this->user->lang($lang_key);
|
|
}
|
|
|
|
/**
|
|
* Returns an array with all the permissions.
|
|
* Each Permission has the following layout:
|
|
* '<type><permission>' => array(
|
|
* 'lang' => 'Language Key with a Short description', // Optional, if not set,
|
|
* // the permissions identifier '<type><permission>' is used with
|
|
* // all uppercase.
|
|
* 'cat' => 'Identifier of the category, the permission should be displayed in',
|
|
* ),
|
|
* Example:
|
|
* 'u_viewprofile' => array(
|
|
* 'lang' => 'ACL_U_VIEWPROFILE',
|
|
* 'cat' => 'profile',
|
|
* ),
|
|
*
|
|
* @return array
|
|
*/
|
|
public function get_permissions()
|
|
{
|
|
return $this->permissions;
|
|
}
|
|
|
|
/**
|
|
* Returns the category of a permission
|
|
*
|
|
* @param string $permission Identifier of the permission
|
|
* @return string Returns the category identifier of the permission
|
|
*/
|
|
public function get_permission_category($permission)
|
|
{
|
|
return (isset($this->permissions[$permission]['cat'])) ? $this->permissions[$permission]['cat'] : 'misc';
|
|
}
|
|
|
|
/**
|
|
* Checks if a category has been defined
|
|
*
|
|
* @param string $category Identifier of the category
|
|
* @return bool True if the category is defined, false otherwise
|
|
*/
|
|
public function category_defined($category)
|
|
{
|
|
return isset($this->categories[$category]);
|
|
}
|
|
|
|
/**
|
|
* Checks if a permission has been defined
|
|
*
|
|
* @param string $permission Identifier of the permission
|
|
* @return bool True if the permission is defined, false otherwise
|
|
*/
|
|
public function permission_defined($permission)
|
|
{
|
|
return isset($this->permissions[$permission]);
|
|
}
|
|
|
|
/**
|
|
* Returns the language string of a permission
|
|
*
|
|
* @param string $permission Identifier of the permission
|
|
* @return string Language string
|
|
*/
|
|
public function get_permission_lang($permission)
|
|
{
|
|
return (isset($this->permissions[$permission]['lang'])) ? $this->user->lang($this->permissions[$permission]['lang']) : $this->user->lang('ACL_' . strtoupper($permission));
|
|
}
|
|
|
|
protected $types = array(
|
|
'u_' => 'ACL_TYPE_U_',
|
|
'a_' => 'ACL_TYPE_A_',
|
|
'm_' => 'ACL_TYPE_M_',
|
|
'f_' => 'ACL_TYPE_F_',
|
|
'global' => array(
|
|
'm_' => 'ACL_TYPE_GLOBAL_M_',
|
|
),
|
|
);
|
|
|
|
protected $categories = array(
|
|
'actions' => 'ACL_CAT_ACTIONS',
|
|
'content' => 'ACL_CAT_CONTENT',
|
|
'forums' => 'ACL_CAT_FORUMS',
|
|
'misc' => 'ACL_CAT_MISC',
|
|
'permissions' => 'ACL_CAT_PERMISSIONS',
|
|
'pm' => 'ACL_CAT_PM',
|
|
'polls' => 'ACL_CAT_POLLS',
|
|
'post' => 'ACL_CAT_POST',
|
|
'post_actions' => 'ACL_CAT_POST_ACTIONS',
|
|
'posting' => 'ACL_CAT_POSTING',
|
|
'profile' => 'ACL_CAT_PROFILE',
|
|
'settings' => 'ACL_CAT_SETTINGS',
|
|
'topic_actions' => 'ACL_CAT_TOPIC_ACTIONS',
|
|
'user_group' => 'ACL_CAT_USER_GROUP',
|
|
);
|
|
|
|
protected $permissions = array(
|
|
// User Permissions
|
|
'u_viewprofile' => array('lang' => 'ACL_U_VIEWPROFILE', 'cat' => 'profile'),
|
|
'u_chgname' => array('lang' => 'ACL_U_CHGNAME', 'cat' => 'profile'),
|
|
'u_chgpasswd' => array('lang' => 'ACL_U_CHGPASSWD', 'cat' => 'profile'),
|
|
'u_chgemail' => array('lang' => 'ACL_U_CHGEMAIL', 'cat' => 'profile'),
|
|
'u_chgavatar' => array('lang' => 'ACL_U_CHGAVATAR', 'cat' => 'profile'),
|
|
'u_chggrp' => array('lang' => 'ACL_U_CHGGRP', 'cat' => 'profile'),
|
|
'u_chgprofileinfo' => array('lang' => 'ACL_U_CHGPROFILEINFO', 'cat' => 'profile'),
|
|
|
|
'u_attach' => array('lang' => 'ACL_U_ATTACH', 'cat' => 'post'),
|
|
'u_download' => array('lang' => 'ACL_U_DOWNLOAD', 'cat' => 'post'),
|
|
'u_mention' => array('lang' => 'ACL_U_MENTION', 'cat' => 'post'),
|
|
'u_savedrafts' => array('lang' => 'ACL_U_SAVEDRAFTS', 'cat' => 'post'),
|
|
'u_chgcensors' => array('lang' => 'ACL_U_CHGCENSORS', 'cat' => 'post'),
|
|
'u_sig' => array('lang' => 'ACL_U_SIG', 'cat' => 'post'),
|
|
'u_emoji' => array('lang' => 'ACL_U_EMOJI', 'cat' => 'post'),
|
|
|
|
'u_sendpm' => array('lang' => 'ACL_U_SENDPM', 'cat' => 'pm'),
|
|
'u_masspm' => array('lang' => 'ACL_U_MASSPM', 'cat' => 'pm'),
|
|
'u_masspm_group'=> array('lang' => 'ACL_U_MASSPM_GROUP', 'cat' => 'pm'),
|
|
'u_readpm' => array('lang' => 'ACL_U_READPM', 'cat' => 'pm'),
|
|
'u_pm_edit' => array('lang' => 'ACL_U_PM_EDIT', 'cat' => 'pm'),
|
|
'u_pm_delete' => array('lang' => 'ACL_U_PM_DELETE', 'cat' => 'pm'),
|
|
'u_pm_forward' => array('lang' => 'ACL_U_PM_FORWARD', 'cat' => 'pm'),
|
|
'u_pm_emailpm' => array('lang' => 'ACL_U_PM_EMAILPM', 'cat' => 'pm'),
|
|
'u_pm_printpm' => array('lang' => 'ACL_U_PM_PRINTPM', 'cat' => 'pm'),
|
|
'u_pm_attach' => array('lang' => 'ACL_U_PM_ATTACH', 'cat' => 'pm'),
|
|
'u_pm_download' => array('lang' => 'ACL_U_PM_DOWNLOAD', 'cat' => 'pm'),
|
|
'u_pm_bbcode' => array('lang' => 'ACL_U_PM_BBCODE', 'cat' => 'pm'),
|
|
'u_pm_smilies' => array('lang' => 'ACL_U_PM_SMILIES', 'cat' => 'pm'),
|
|
'u_pm_img' => array('lang' => 'ACL_U_PM_IMG', 'cat' => 'pm'),
|
|
|
|
'u_sendemail' => array('lang' => 'ACL_U_SENDEMAIL', 'cat' => 'misc'),
|
|
'u_sendim' => array('lang' => 'ACL_U_SENDIM', 'cat' => 'misc'),
|
|
'u_ignoreflood' => array('lang' => 'ACL_U_IGNOREFLOOD', 'cat' => 'misc'),
|
|
'u_hideonline' => array('lang' => 'ACL_U_HIDEONLINE', 'cat' => 'misc'),
|
|
'u_viewonline' => array('lang' => 'ACL_U_VIEWONLINE', 'cat' => 'misc'),
|
|
'u_search' => array('lang' => 'ACL_U_SEARCH', 'cat' => 'misc'),
|
|
|
|
// Forum Permissions
|
|
'f_list' => array('lang' => 'ACL_F_LIST', 'cat' => 'actions'),
|
|
'f_list_topics' => array('lang' => 'ACL_F_LIST_TOPICS', 'cat' => 'actions'),
|
|
'f_read' => array('lang' => 'ACL_F_READ', 'cat' => 'actions'),
|
|
'f_search' => array('lang' => 'ACL_F_SEARCH', 'cat' => 'actions'),
|
|
'f_subscribe' => array('lang' => 'ACL_F_SUBSCRIBE', 'cat' => 'actions'),
|
|
'f_print' => array('lang' => 'ACL_F_PRINT', 'cat' => 'actions'),
|
|
'f_email' => array('lang' => 'ACL_F_EMAIL', 'cat' => 'actions'),
|
|
'f_bump' => array('lang' => 'ACL_F_BUMP', 'cat' => 'actions'),
|
|
'f_user_lock' => array('lang' => 'ACL_F_USER_LOCK', 'cat' => 'actions'),
|
|
'f_download' => array('lang' => 'ACL_F_DOWNLOAD', 'cat' => 'actions'),
|
|
'f_report' => array('lang' => 'ACL_F_REPORT', 'cat' => 'actions'),
|
|
|
|
'f_post' => array('lang' => 'ACL_F_POST', 'cat' => 'post'),
|
|
'f_sticky' => array('lang' => 'ACL_F_STICKY', 'cat' => 'post'),
|
|
'f_announce' => array('lang' => 'ACL_F_ANNOUNCE', 'cat' => 'post'),
|
|
'f_announce_global' => array('lang' => 'ACL_F_ANNOUNCE_GLOBAL', 'cat' => 'post'),
|
|
'f_mention' => array('lang' => 'ACL_F_MENTION', 'cat' => 'post'),
|
|
'f_reply' => array('lang' => 'ACL_F_REPLY', 'cat' => 'post'),
|
|
'f_edit' => array('lang' => 'ACL_F_EDIT', 'cat' => 'post'),
|
|
'f_delete' => array('lang' => 'ACL_F_DELETE', 'cat' => 'post'),
|
|
'f_softdelete' => array('lang' => 'ACL_F_SOFTDELETE', 'cat' => 'post'),
|
|
'f_ignoreflood' => array('lang' => 'ACL_F_IGNOREFLOOD', 'cat' => 'post'),
|
|
'f_postcount' => array('lang' => 'ACL_F_POSTCOUNT', 'cat' => 'post'),
|
|
'f_noapprove' => array('lang' => 'ACL_F_NOAPPROVE', 'cat' => 'post'),
|
|
|
|
'f_attach' => array('lang' => 'ACL_F_ATTACH', 'cat' => 'content'),
|
|
'f_icons' => array('lang' => 'ACL_F_ICONS', 'cat' => 'content'),
|
|
'f_bbcode' => array('lang' => 'ACL_F_BBCODE', 'cat' => 'content'),
|
|
'f_img' => array('lang' => 'ACL_F_IMG', 'cat' => 'content'),
|
|
'f_sigs' => array('lang' => 'ACL_F_SIGS', 'cat' => 'content'),
|
|
'f_smilies' => array('lang' => 'ACL_F_SMILIES', 'cat' => 'content'),
|
|
|
|
'f_poll' => array('lang' => 'ACL_F_POLL', 'cat' => 'polls'),
|
|
'f_vote' => array('lang' => 'ACL_F_VOTE', 'cat' => 'polls'),
|
|
'f_votechg' => array('lang' => 'ACL_F_VOTECHG', 'cat' => 'polls'),
|
|
|
|
// Moderator Permissions
|
|
'm_edit' => array('lang' => 'ACL_M_EDIT', 'cat' => 'post_actions'),
|
|
'm_delete' => array('lang' => 'ACL_M_DELETE', 'cat' => 'post_actions'),
|
|
'm_approve' => array('lang' => 'ACL_M_APPROVE', 'cat' => 'post_actions'),
|
|
'm_report' => array('lang' => 'ACL_M_REPORT', 'cat' => 'post_actions'),
|
|
'm_chgposter' => array('lang' => 'ACL_M_CHGPOSTER', 'cat' => 'post_actions'),
|
|
'm_info' => array('lang' => 'ACL_M_INFO', 'cat' => 'post_actions'),
|
|
'm_softdelete' => array('lang' => 'ACL_M_SOFTDELETE', 'cat' => 'post_actions'),
|
|
|
|
'm_move' => array('lang' => 'ACL_M_MOVE', 'cat' => 'topic_actions'),
|
|
'm_lock' => array('lang' => 'ACL_M_LOCK', 'cat' => 'topic_actions'),
|
|
'm_split' => array('lang' => 'ACL_M_SPLIT', 'cat' => 'topic_actions'),
|
|
'm_merge' => array('lang' => 'ACL_M_MERGE', 'cat' => 'topic_actions'),
|
|
|
|
'm_warn' => array('lang' => 'ACL_M_WARN', 'cat' => 'misc'),
|
|
'm_pm_report' => array('lang' => 'ACL_M_PM_REPORT', 'cat' => 'misc'),
|
|
'm_ban' => array('lang' => 'ACL_M_BAN', 'cat' => 'misc'),
|
|
|
|
// Admin Permissions
|
|
'a_board' => array('lang' => 'ACL_A_BOARD', 'cat' => 'settings'),
|
|
'a_server' => array('lang' => 'ACL_A_SERVER', 'cat' => 'settings'),
|
|
'a_jabber' => array('lang' => 'ACL_A_JABBER', 'cat' => 'settings'),
|
|
'a_phpinfo' => array('lang' => 'ACL_A_PHPINFO', 'cat' => 'settings'),
|
|
|
|
'a_forum' => array('lang' => 'ACL_A_FORUM', 'cat' => 'forums'),
|
|
'a_forumadd' => array('lang' => 'ACL_A_FORUMADD', 'cat' => 'forums'),
|
|
'a_forumdel' => array('lang' => 'ACL_A_FORUMDEL', 'cat' => 'forums'),
|
|
'a_prune' => array('lang' => 'ACL_A_PRUNE', 'cat' => 'forums'),
|
|
|
|
'a_icons' => array('lang' => 'ACL_A_ICONS', 'cat' => 'posting'),
|
|
'a_words' => array('lang' => 'ACL_A_WORDS', 'cat' => 'posting'),
|
|
'a_bbcode' => array('lang' => 'ACL_A_BBCODE', 'cat' => 'posting'),
|
|
'a_attach' => array('lang' => 'ACL_A_ATTACH', 'cat' => 'posting'),
|
|
|
|
'a_user' => array('lang' => 'ACL_A_USER', 'cat' => 'user_group'),
|
|
'a_userdel' => array('lang' => 'ACL_A_USERDEL', 'cat' => 'user_group'),
|
|
'a_group' => array('lang' => 'ACL_A_GROUP', 'cat' => 'user_group'),
|
|
'a_groupadd' => array('lang' => 'ACL_A_GROUPADD', 'cat' => 'user_group'),
|
|
'a_groupdel' => array('lang' => 'ACL_A_GROUPDEL', 'cat' => 'user_group'),
|
|
'a_ranks' => array('lang' => 'ACL_A_RANKS', 'cat' => 'user_group'),
|
|
'a_profile' => array('lang' => 'ACL_A_PROFILE', 'cat' => 'user_group'),
|
|
'a_names' => array('lang' => 'ACL_A_NAMES', 'cat' => 'user_group'),
|
|
'a_ban' => array('lang' => 'ACL_A_BAN', 'cat' => 'user_group'),
|
|
|
|
'a_viewauth' => array('lang' => 'ACL_A_VIEWAUTH', 'cat' => 'permissions'),
|
|
'a_authgroups' => array('lang' => 'ACL_A_AUTHGROUPS', 'cat' => 'permissions'),
|
|
'a_authusers' => array('lang' => 'ACL_A_AUTHUSERS', 'cat' => 'permissions'),
|
|
'a_fauth' => array('lang' => 'ACL_A_FAUTH', 'cat' => 'permissions'),
|
|
'a_mauth' => array('lang' => 'ACL_A_MAUTH', 'cat' => 'permissions'),
|
|
'a_aauth' => array('lang' => 'ACL_A_AAUTH', 'cat' => 'permissions'),
|
|
'a_uauth' => array('lang' => 'ACL_A_UAUTH', 'cat' => 'permissions'),
|
|
'a_roles' => array('lang' => 'ACL_A_ROLES', 'cat' => 'permissions'),
|
|
'a_switchperm' => array('lang' => 'ACL_A_SWITCHPERM', 'cat' => 'permissions'),
|
|
|
|
'a_storage' => array('lang' => 'ACL_A_STORAGE', 'cat' => 'misc'),
|
|
'a_styles' => array('lang' => 'ACL_A_STYLES', 'cat' => 'misc'),
|
|
'a_extensions' => array('lang' => 'ACL_A_EXTENSIONS', 'cat' => 'misc'),
|
|
'a_viewlogs' => array('lang' => 'ACL_A_VIEWLOGS', 'cat' => 'misc'),
|
|
'a_clearlogs' => array('lang' => 'ACL_A_CLEARLOGS', 'cat' => 'misc'),
|
|
'a_modules' => array('lang' => 'ACL_A_MODULES', 'cat' => 'misc'),
|
|
'a_language' => array('lang' => 'ACL_A_LANGUAGE', 'cat' => 'misc'),
|
|
'a_email' => array('lang' => 'ACL_A_EMAIL', 'cat' => 'misc'),
|
|
'a_bots' => array('lang' => 'ACL_A_BOTS', 'cat' => 'misc'),
|
|
'a_reasons' => array('lang' => 'ACL_A_REASONS', 'cat' => 'misc'),
|
|
'a_backup' => array('lang' => 'ACL_A_BACKUP', 'cat' => 'misc'),
|
|
'a_search' => array('lang' => 'ACL_A_SEARCH', 'cat' => 'misc'),
|
|
);
|
|
}
|