2011-03-23 10:51:00 +01:00
|
|
|
<?php
|
2013-10-15 00:26:23 +02:00
|
|
|
|
2016-08-11 01:14:02 +02:00
|
|
|
namespace SilverStripe\Admin;
|
|
|
|
|
2016-06-23 01:37:22 +02:00
|
|
|
use SilverStripe\Security\Security;
|
|
|
|
use SilverStripe\Security\Member;
|
|
|
|
use SilverStripe\Security\Group;
|
|
|
|
use SilverStripe\Security\Permission;
|
|
|
|
use SilverStripe\Security\PermissionRole;
|
|
|
|
use SilverStripe\Security\PermissionProvider;
|
2016-08-11 01:14:02 +02:00
|
|
|
use Requirements;
|
|
|
|
use GridField;
|
|
|
|
use GridFieldConfig_RecordEditor;
|
|
|
|
use GridFieldButtonRow;
|
|
|
|
use GridFieldExportButton;
|
|
|
|
use Convert;
|
|
|
|
use FieldList;
|
|
|
|
use TabSet;
|
|
|
|
use Tab;
|
|
|
|
use LiteralField;
|
|
|
|
use HiddenField;
|
|
|
|
use HeaderField;
|
|
|
|
use Form;
|
|
|
|
use ArrayData;
|
|
|
|
use Deprecation;
|
|
|
|
use Config;
|
|
|
|
|
2016-06-23 01:37:22 +02:00
|
|
|
|
2011-03-23 10:51:00 +01:00
|
|
|
/**
|
|
|
|
* Security section of the CMS
|
2013-10-15 00:26:23 +02:00
|
|
|
*
|
|
|
|
* @package framework
|
|
|
|
* @subpackage admin
|
2011-03-23 10:51:00 +01:00
|
|
|
*/
|
|
|
|
class SecurityAdmin extends LeftAndMain implements PermissionProvider {
|
|
|
|
|
2013-03-21 19:48:54 +01:00
|
|
|
private static $url_segment = 'security';
|
2016-01-06 00:34:58 +01:00
|
|
|
|
2013-03-21 19:48:54 +01:00
|
|
|
private static $url_rule = '/$Action/$ID/$OtherID';
|
2016-01-06 00:34:58 +01:00
|
|
|
|
2013-03-21 19:48:54 +01:00
|
|
|
private static $menu_title = 'Security';
|
2016-01-06 00:34:58 +01:00
|
|
|
|
2016-06-23 01:37:22 +02:00
|
|
|
private static $tree_class = 'SilverStripe\\Security\\Group';
|
2016-01-06 00:34:58 +01:00
|
|
|
|
2016-06-23 01:37:22 +02:00
|
|
|
private static $subitem_class = 'SilverStripe\\Security\\Member';
|
2016-01-06 00:34:58 +01:00
|
|
|
|
2016-08-11 01:40:23 +02:00
|
|
|
private static $required_permission_codes = 'CMS_ACCESS_SecurityAdmin';
|
|
|
|
|
2013-03-21 19:48:54 +01:00
|
|
|
private static $allowed_actions = array(
|
2011-03-23 10:51:00 +01:00
|
|
|
'EditForm',
|
|
|
|
'MemberImportForm',
|
|
|
|
'memberimport',
|
|
|
|
'GroupImportForm',
|
|
|
|
'groupimport',
|
2012-05-08 11:16:16 +02:00
|
|
|
'groups',
|
|
|
|
'users',
|
|
|
|
'roles'
|
2011-03-23 10:51:00 +01:00
|
|
|
);
|
|
|
|
|
2015-02-23 14:46:00 +01:00
|
|
|
protected function init() {
|
2011-03-23 10:51:00 +01:00
|
|
|
parent::init();
|
2016-04-19 11:04:43 +02:00
|
|
|
Requirements::javascript(FRAMEWORK_ADMIN_DIR . '/client/dist/js/SecurityAdmin.js');
|
2011-03-23 10:51:00 +01:00
|
|
|
}
|
2012-05-08 11:16:16 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Shortcut action for setting the correct active tab.
|
2016-06-23 01:37:22 +02:00
|
|
|
*
|
|
|
|
* @param SS_HTTPRequest $request
|
|
|
|
* @return SS_HTTPResponse
|
2012-05-08 11:16:16 +02:00
|
|
|
*/
|
|
|
|
public function users($request) {
|
|
|
|
return $this->index($request);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Shortcut action for setting the correct active tab.
|
2016-06-23 01:37:22 +02:00
|
|
|
*
|
|
|
|
* @param SS_HTTPRequest $request
|
|
|
|
* @return SS_HTTPResponse
|
2012-05-08 11:16:16 +02:00
|
|
|
*/
|
|
|
|
public function groups($request) {
|
|
|
|
return $this->index($request);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Shortcut action for setting the correct active tab.
|
2016-06-23 01:37:22 +02:00
|
|
|
*
|
|
|
|
* @param SS_HTTPRequest $request
|
|
|
|
* @return SS_HTTPResponse
|
2012-05-08 11:16:16 +02:00
|
|
|
*/
|
|
|
|
public function roles($request) {
|
|
|
|
return $this->index($request);
|
|
|
|
}
|
2016-01-06 00:34:58 +01:00
|
|
|
|
2012-01-23 17:12:49 +01:00
|
|
|
public function getEditForm($id = null, $fields = null) {
|
2011-03-23 10:51:00 +01:00
|
|
|
// TODO Duplicate record fetching (see parent implementation)
|
|
|
|
if(!$id) $id = $this->currentPageID();
|
|
|
|
$form = parent::getEditForm($id);
|
2016-01-06 00:34:58 +01:00
|
|
|
|
2011-03-23 10:51:00 +01:00
|
|
|
// TODO Duplicate record fetching (see parent implementation)
|
|
|
|
$record = $this->getRecord($id);
|
2013-10-15 00:26:23 +02:00
|
|
|
|
|
|
|
if($record && !$record->canView()) {
|
|
|
|
return Security::permissionFailure($this);
|
|
|
|
}
|
2016-01-06 00:34:58 +01:00
|
|
|
|
2012-04-04 16:59:30 +02:00
|
|
|
$memberList = GridField::create(
|
2012-05-28 01:43:47 +02:00
|
|
|
'Members',
|
2012-03-26 03:51:40 +02:00
|
|
|
false,
|
2012-05-28 11:13:42 +02:00
|
|
|
Member::get(),
|
2012-03-05 18:31:52 +01:00
|
|
|
$memberListConfig = GridFieldConfig_RecordEditor::create()
|
2013-06-21 15:22:00 +02:00
|
|
|
->addComponent(new GridFieldButtonRow('after'))
|
|
|
|
->addComponent(new GridFieldExportButton('buttons-after-left'))
|
2012-03-05 18:31:52 +01:00
|
|
|
)->addExtraClass("members_grid");
|
2013-10-16 00:29:43 +02:00
|
|
|
|
|
|
|
if($record && method_exists($record, 'getValidator')) {
|
|
|
|
$validator = $record->getValidator();
|
|
|
|
} else {
|
2016-06-23 01:37:22 +02:00
|
|
|
$validator = Member::singleton()->getValidator();
|
2013-10-16 00:29:43 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
$memberListConfig
|
|
|
|
->getComponentByType('GridFieldDetailForm')
|
|
|
|
->setValidator($validator);
|
2012-03-05 18:31:52 +01:00
|
|
|
|
2012-04-19 01:25:37 +02:00
|
|
|
$groupList = GridField::create(
|
2012-05-28 01:43:47 +02:00
|
|
|
'Groups',
|
2012-03-26 03:51:40 +02:00
|
|
|
false,
|
2012-05-28 11:13:42 +02:00
|
|
|
Group::get(),
|
2012-03-05 18:31:52 +01:00
|
|
|
GridFieldConfig_RecordEditor::create()
|
2012-04-19 01:25:37 +02:00
|
|
|
);
|
|
|
|
$columns = $groupList->getConfig()->getComponentByType('GridFieldDataColumns');
|
|
|
|
$columns->setDisplayFields(array(
|
2016-08-11 01:40:23 +02:00
|
|
|
'Breadcrumbs' => Group::singleton()->fieldLabel('Title')
|
2012-03-05 18:31:52 +01:00
|
|
|
));
|
2013-01-21 08:51:16 +01:00
|
|
|
$columns->setFieldFormatting(array(
|
|
|
|
'Breadcrumbs' => function($val, $item) {
|
2013-09-24 10:45:55 +02:00
|
|
|
return Convert::raw2xml($item->getBreadcrumbs(' > '));
|
2013-01-21 08:51:16 +01:00
|
|
|
}
|
|
|
|
));
|
2013-08-30 13:59:05 +02:00
|
|
|
|
2011-05-11 09:51:54 +02:00
|
|
|
$fields = new FieldList(
|
2011-10-29 04:41:40 +02:00
|
|
|
$root = new TabSet(
|
2011-03-23 10:51:00 +01:00
|
|
|
'Root',
|
2012-05-08 11:16:16 +02:00
|
|
|
$usersTab = new Tab('Users', _t('SecurityAdmin.Users', 'Users'),
|
2016-07-01 03:37:29 +02:00
|
|
|
|
2012-03-26 03:51:40 +02:00
|
|
|
new LiteralField('MembersCautionText',
|
2016-07-01 03:37:29 +02:00
|
|
|
sprintf('<div class="alert alert-warning" role="alert">%s</div>',
|
2011-03-23 10:51:00 +01:00
|
|
|
_t(
|
2016-01-06 00:34:58 +01:00
|
|
|
'SecurityAdmin.MemberListCaution',
|
2016-07-01 03:37:29 +02:00
|
|
|
'Caution: Removing members from this list will remove them from all groups and the database'
|
2011-03-23 10:51:00 +01:00
|
|
|
)
|
|
|
|
)
|
2016-07-01 03:37:29 +02:00
|
|
|
),
|
|
|
|
$memberList
|
2011-03-23 10:51:00 +01:00
|
|
|
),
|
2016-06-23 01:37:22 +02:00
|
|
|
$groupsTab = new Tab('Groups', singleton('SilverStripe\\Security\\Group')->i18n_plural_name(),
|
2013-08-30 13:59:05 +02:00
|
|
|
$groupList
|
2011-03-23 10:51:00 +01:00
|
|
|
)
|
|
|
|
),
|
|
|
|
// necessary for tree node selection in LeftAndMain.EditForm.js
|
|
|
|
new HiddenField('ID', false, 0)
|
|
|
|
);
|
2012-10-31 15:57:48 +01:00
|
|
|
|
2013-08-30 13:59:05 +02:00
|
|
|
// Add import capabilities. Limit to admin since the import logic can affect assigned permissions
|
|
|
|
if(Permission::check('ADMIN')) {
|
|
|
|
$fields->addFieldsToTab('Root.Users', array(
|
|
|
|
new HeaderField(_t('SecurityAdmin.IMPORTUSERS', 'Import users'), 3),
|
|
|
|
new LiteralField(
|
|
|
|
'MemberImportFormIframe',
|
|
|
|
sprintf(
|
|
|
|
'<iframe src="%s" id="MemberImportFormIframe" width="100%%" height="250px" frameBorder="0">'
|
|
|
|
. '</iframe>',
|
|
|
|
$this->Link('memberimport')
|
|
|
|
)
|
|
|
|
)
|
|
|
|
));
|
|
|
|
$fields->addFieldsToTab('Root.Groups', array(
|
|
|
|
new HeaderField(_t('SecurityAdmin.IMPORTGROUPS', 'Import groups'), 3),
|
|
|
|
new LiteralField(
|
|
|
|
'GroupImportFormIframe',
|
|
|
|
sprintf(
|
|
|
|
'<iframe src="%s" id="GroupImportFormIframe" width="100%%" height="250px" frameBorder="0">'
|
|
|
|
. '</iframe>',
|
|
|
|
$this->Link('groupimport')
|
|
|
|
)
|
|
|
|
)
|
|
|
|
));
|
|
|
|
}
|
|
|
|
|
2016-01-06 00:34:58 +01:00
|
|
|
// Tab nav in CMS is rendered through separate template
|
2011-10-29 04:41:40 +02:00
|
|
|
$root->setTemplate('CMSTabSet');
|
2016-01-06 00:34:58 +01:00
|
|
|
|
2011-03-23 10:51:00 +01:00
|
|
|
// Add roles editing interface
|
|
|
|
if(Permission::check('APPLY_ROLES')) {
|
2012-05-28 01:46:25 +02:00
|
|
|
$rolesField = GridField::create('Roles',
|
2012-03-05 14:04:19 +01:00
|
|
|
false,
|
2012-05-28 11:13:42 +02:00
|
|
|
PermissionRole::get(),
|
2012-03-05 14:04:19 +01:00
|
|
|
GridFieldConfig_RecordEditor::create()
|
2011-03-23 10:51:00 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
$rolesTab = $fields->findOrMakeTab('Root.Roles', _t('SecurityAdmin.TABROLES', 'Roles'));
|
2012-03-05 14:04:19 +01:00
|
|
|
$rolesTab->push($rolesField);
|
2011-03-23 10:51:00 +01:00
|
|
|
}
|
|
|
|
|
2015-04-30 01:04:08 +02:00
|
|
|
$actionParam = $this->getRequest()->param('Action');
|
2012-05-08 11:16:16 +02:00
|
|
|
if($actionParam == 'groups') {
|
2012-11-06 15:28:09 +01:00
|
|
|
$groupsTab->addExtraClass('ui-state-active');
|
2012-05-08 11:16:16 +02:00
|
|
|
} elseif($actionParam == 'users') {
|
2012-11-06 15:28:09 +01:00
|
|
|
$usersTab->addExtraClass('ui-state-active');
|
2012-05-08 11:16:16 +02:00
|
|
|
} elseif($actionParam == 'roles') {
|
2012-11-06 15:28:09 +01:00
|
|
|
$rolesTab->addExtraClass('ui-state-active');
|
2012-05-08 11:16:16 +02:00
|
|
|
}
|
|
|
|
|
2012-03-01 17:06:30 +01:00
|
|
|
$actions = new FieldList();
|
2016-01-06 00:34:58 +01:00
|
|
|
|
2016-03-01 04:15:15 +01:00
|
|
|
$form = Form::create(
|
2011-03-23 10:51:00 +01:00
|
|
|
$this,
|
|
|
|
'EditForm',
|
|
|
|
$fields,
|
|
|
|
$actions
|
2013-05-10 15:00:13 +02:00
|
|
|
)->setHTMLID('Form_EditForm');
|
2011-03-31 10:52:29 +02:00
|
|
|
$form->addExtraClass('cms-edit-form');
|
2012-03-06 00:59:19 +01:00
|
|
|
$form->setTemplate($this->getTemplatesWithSuffix('_EditForm'));
|
2012-10-31 15:57:48 +01:00
|
|
|
// Tab nav in CMS is rendered through separate template
|
|
|
|
if($form->Fields()->hasTabset()) {
|
|
|
|
$form->Fields()->findOrMakeTab('Root')->setTemplate('CMSTabSet');
|
|
|
|
}
|
2012-05-08 11:16:16 +02:00
|
|
|
$form->addExtraClass('center ss-tabset cms-tabset ' . $this->BaseCSSClasses());
|
2012-04-18 22:11:40 +02:00
|
|
|
$form->setAttribute('data-pjax-fragment', 'CurrentForm');
|
2012-03-08 18:20:11 +01:00
|
|
|
|
|
|
|
$this->extend('updateEditForm', $form);
|
2012-03-26 03:51:40 +02:00
|
|
|
|
2011-04-19 08:04:55 +02:00
|
|
|
return $form;
|
|
|
|
}
|
2016-01-06 00:34:58 +01:00
|
|
|
|
2011-03-23 10:51:00 +01:00
|
|
|
public function memberimport() {
|
|
|
|
Requirements::clear();
|
2016-04-19 11:04:43 +02:00
|
|
|
Requirements::css(FRAMEWORK_ADMIN_DIR . '/client/dist/styles/bundle.css');
|
2011-03-23 10:51:00 +01:00
|
|
|
Requirements::javascript(THIRDPARTY_DIR . '/jquery/jquery.js');
|
2012-03-24 04:38:57 +01:00
|
|
|
Requirements::javascript(FRAMEWORK_DIR . '/thirdparty/jquery-entwine/dist/jquery.entwine-dist.js');
|
2016-04-19 11:04:43 +02:00
|
|
|
Requirements::javascript(FRAMEWORK_ADMIN_DIR . '/client/dist/js/MemberImportForm.js');
|
2011-03-23 10:51:00 +01:00
|
|
|
return $this->renderWith('BlankPage', array(
|
2012-04-13 15:35:46 +02:00
|
|
|
'Form' => $this->MemberImportForm()->forTemplate(),
|
2012-01-07 18:57:14 +01:00
|
|
|
'Content' => ' '
|
2011-03-23 10:51:00 +01:00
|
|
|
));
|
|
|
|
}
|
2016-01-06 00:34:58 +01:00
|
|
|
|
2011-03-23 10:51:00 +01:00
|
|
|
/**
|
|
|
|
* @see SecurityAdmin_MemberImportForm
|
2016-01-06 00:34:58 +01:00
|
|
|
*
|
2011-03-23 10:51:00 +01:00
|
|
|
* @return Form
|
|
|
|
*/
|
|
|
|
public function MemberImportForm() {
|
2013-08-30 13:59:05 +02:00
|
|
|
if(!Permission::check('ADMIN')) return false;
|
|
|
|
|
2011-03-23 10:51:00 +01:00
|
|
|
$group = $this->currentPage();
|
2016-08-11 01:40:23 +02:00
|
|
|
/** @skipUpgrade */
|
2011-03-23 10:51:00 +01:00
|
|
|
$form = new MemberImportForm(
|
|
|
|
$this,
|
2016-08-11 01:40:23 +02:00
|
|
|
'MemberImportForm'
|
2011-03-23 10:51:00 +01:00
|
|
|
);
|
|
|
|
$form->setGroup($group);
|
2016-01-06 00:34:58 +01:00
|
|
|
|
2011-03-23 10:51:00 +01:00
|
|
|
return $form;
|
|
|
|
}
|
2016-01-06 00:34:58 +01:00
|
|
|
|
2011-03-23 10:51:00 +01:00
|
|
|
public function groupimport() {
|
|
|
|
Requirements::clear();
|
2016-04-19 11:04:43 +02:00
|
|
|
Requirements::css(FRAMEWORK_ADMIN_DIR . '/client/dist/styles/bundle.css');
|
2011-03-23 10:51:00 +01:00
|
|
|
Requirements::javascript(THIRDPARTY_DIR . '/jquery/jquery.js');
|
2012-03-24 04:38:57 +01:00
|
|
|
Requirements::javascript(FRAMEWORK_DIR . '/thirdparty/jquery-entwine/dist/jquery.entwine-dist.js');
|
2016-04-19 11:04:43 +02:00
|
|
|
Requirements::javascript(FRAMEWORK_ADMIN_DIR . '/client/dist/js/MemberImportForm.js');
|
2011-03-23 10:51:00 +01:00
|
|
|
return $this->renderWith('BlankPage', array(
|
2011-12-18 18:18:44 +01:00
|
|
|
'Content' => ' ',
|
2012-04-13 15:35:46 +02:00
|
|
|
'Form' => $this->GroupImportForm()->forTemplate()
|
2011-03-23 10:51:00 +01:00
|
|
|
));
|
|
|
|
}
|
2016-01-06 00:34:58 +01:00
|
|
|
|
2011-03-23 10:51:00 +01:00
|
|
|
/**
|
|
|
|
* @see SecurityAdmin_MemberImportForm
|
2016-01-06 00:34:58 +01:00
|
|
|
*
|
2011-03-23 10:51:00 +01:00
|
|
|
* @return Form
|
|
|
|
*/
|
|
|
|
public function GroupImportForm() {
|
2013-08-30 13:59:05 +02:00
|
|
|
if(!Permission::check('ADMIN')) return false;
|
|
|
|
|
2011-03-23 10:51:00 +01:00
|
|
|
$form = new GroupImportForm(
|
|
|
|
$this,
|
2016-08-11 01:14:02 +02:00
|
|
|
'SilverStripe\\Admin\\GroupImportForm'
|
2011-03-23 10:51:00 +01:00
|
|
|
);
|
2016-01-06 00:34:58 +01:00
|
|
|
|
2011-03-23 10:51:00 +01:00
|
|
|
return $form;
|
|
|
|
}
|
|
|
|
|
2012-05-08 11:16:16 +02:00
|
|
|
/**
|
2016-01-06 00:34:58 +01:00
|
|
|
* Disable GridFieldDetailForm backlinks for this view, as its
|
2012-05-08 11:16:16 +02:00
|
|
|
*/
|
|
|
|
public function Backlink() {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2012-03-05 18:31:52 +01:00
|
|
|
public function Breadcrumbs($unlinked = false) {
|
|
|
|
$crumbs = parent::Breadcrumbs($unlinked);
|
|
|
|
|
|
|
|
// Name root breadcrumb based on which record is edited,
|
|
|
|
// which can only be determined by looking for the fieldname of the GridField.
|
|
|
|
// Note: Titles should be same titles as tabs in RootForm().
|
2015-04-30 01:04:08 +02:00
|
|
|
$params = $this->getRequest()->allParams();
|
2012-03-05 18:31:52 +01:00
|
|
|
if(isset($params['FieldName'])) {
|
2012-05-08 11:16:16 +02:00
|
|
|
// TODO FieldName param gets overwritten by nested GridFields,
|
|
|
|
// so shows "Members" rather than "Groups" for the following URL:
|
|
|
|
// admin/security/EditForm/field/Groups/item/2/ItemEditForm/field/Members/item/1/edit
|
|
|
|
$firstCrumb = $crumbs->shift();
|
2012-03-05 18:31:52 +01:00
|
|
|
if($params['FieldName'] == 'Groups') {
|
2012-05-08 11:16:16 +02:00
|
|
|
$crumbs->unshift(new ArrayData(array(
|
2016-06-23 01:37:22 +02:00
|
|
|
'Title' => singleton('SilverStripe\\Security\\Group')->i18n_plural_name(),
|
2012-05-08 11:16:16 +02:00
|
|
|
'Link' => $this->Link('groups')
|
|
|
|
)));
|
2012-03-05 18:31:52 +01:00
|
|
|
} elseif($params['FieldName'] == 'Users') {
|
2012-05-08 11:16:16 +02:00
|
|
|
$crumbs->unshift(new ArrayData(array(
|
|
|
|
'Title' => _t('SecurityAdmin.Users', 'Users'),
|
|
|
|
'Link' => $this->Link('users')
|
|
|
|
)));
|
2012-03-05 18:31:52 +01:00
|
|
|
} elseif($params['FieldName'] == 'Roles') {
|
2012-05-08 11:16:16 +02:00
|
|
|
$crumbs->unshift(new ArrayData(array(
|
|
|
|
'Title' => _t('SecurityAdmin.TABROLES', 'Roles'),
|
|
|
|
'Link' => $this->Link('roles')
|
|
|
|
)));
|
2012-03-05 18:31:52 +01:00
|
|
|
}
|
2012-05-08 11:16:16 +02:00
|
|
|
$crumbs->unshift($firstCrumb);
|
2016-01-06 00:34:58 +01:00
|
|
|
}
|
2011-03-23 10:51:00 +01:00
|
|
|
|
2012-03-05 18:31:52 +01:00
|
|
|
return $crumbs;
|
2011-03-23 10:51:00 +01:00
|
|
|
}
|
|
|
|
|
2012-09-19 12:07:39 +02:00
|
|
|
public function providePermissions() {
|
2016-05-02 10:57:43 +02:00
|
|
|
$title = $this->menu_title();
|
2011-03-23 10:51:00 +01:00
|
|
|
return array(
|
2012-03-05 16:07:20 +01:00
|
|
|
"CMS_ACCESS_SecurityAdmin" => array(
|
2012-05-01 21:44:54 +02:00
|
|
|
'name' => _t('CMSMain.ACCESS', "Access to '{title}' section", array('title' => $title)),
|
2012-03-05 16:07:20 +01:00
|
|
|
'category' => _t('Permission.CMS_ACCESS_CATEGORY', 'CMS Access'),
|
|
|
|
'help' => _t(
|
|
|
|
'SecurityAdmin.ACCESS_HELP',
|
|
|
|
'Allow viewing, adding and editing users, as well as assigning permissions and roles to them.'
|
|
|
|
)
|
|
|
|
),
|
2011-03-23 10:51:00 +01:00
|
|
|
'EDIT_PERMISSIONS' => array(
|
|
|
|
'name' => _t('SecurityAdmin.EDITPERMISSIONS', 'Manage permissions for groups'),
|
|
|
|
'category' => _t('Permissions.PERMISSIONS_CATEGORY', 'Roles and access permissions'),
|
2012-09-26 23:34:00 +02:00
|
|
|
'help' => _t('SecurityAdmin.EDITPERMISSIONS_HELP',
|
|
|
|
'Ability to edit Permissions and IP Addresses for a group.'
|
|
|
|
. ' Requires the "Access to \'Security\' section" permission.'),
|
2011-03-23 10:51:00 +01:00
|
|
|
'sort' => 0
|
|
|
|
),
|
|
|
|
'APPLY_ROLES' => array(
|
|
|
|
'name' => _t('SecurityAdmin.APPLY_ROLES', 'Apply roles to groups'),
|
|
|
|
'category' => _t('Permissions.PERMISSIONS_CATEGORY', 'Roles and access permissions'),
|
2012-09-26 23:34:00 +02:00
|
|
|
'help' => _t('SecurityAdmin.APPLY_ROLES_HELP', 'Ability to edit the roles assigned to a group.'
|
|
|
|
. ' Requires the "Access to \'Users\' section" permission.'),
|
2011-03-23 10:51:00 +01:00
|
|
|
'sort' => 0
|
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
2012-03-24 01:20:19 +01:00
|
|
|
}
|