forked from Shahiem/frontend-roles-manager
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathPlugin.php
74 lines (63 loc) · 2.36 KB
/
Plugin.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
<?php
namespace ShahiemSeymor\Roles;
use Backend;
use Event;
use RainLab\User\Models\UserGroup as RainLabUserGroup;
use ShahiemSeymor\Roles\Models\UserGroup;
use System\Classes\PluginBase;
class Plugin extends PluginBase
{
public $require = ['RainLab.User'];
public function pluginDetails()
{
return [
'name' => 'Frontend User Roles Manager',
'description' => 'The plugin lets you manage frontend user roles and permissions.',
'author' => 'Shahiem Seymor',
'homepage' => 'http://octobercms.com/plugin/shahiemseymor-roles',
];
}
public function boot()
{
RainLabUserGroup::extend(function ($model) {
$model->belongsToMany['perms'] = ['ShahiemSeymor\Roles\Models\Permission', 'table' => 'shahiemseymor_permission_role', 'key' => 'role_id', 'otherKey' => 'permission_id'];
});
Event::listen('backend.menu.extendItems', function ($manager) {
$manager->addSideMenuItems('RainLab.User', 'user', [
'perms' => [
'label' => 'Permissions',
'icon' => 'icon-key',
'code' => 'perms',
'owner' => 'RainLab.User',
'url' => Backend::url('shahiemseymor/roles/permissions'),
],
]);
});
Event::listen('backend.form.extendFields', function ($widget) {
if (!$widget->getController() instanceof \RainLab\User\Controllers\UserGroups) {
return;
}
if (!$widget->model instanceof \RainLab\User\Models\UserGroup) {
return;
}
$widget->addFields([
'perms' => [
'label' => 'Permissions',
'commentAbove' => 'Specify which groups this person belongs to.',
'span' => 'right',
'type' => 'relation',
'emptyOption' => 'There are no permissions, you should create one first!',
],
], 'primary');
});
}
public function registerMarkupTags()
{
return [
'functions' => [
'can' => function ($can) {return UserGroup::can($can);},
'hasRole' => function ($role, $user = null) {return UserGroup::hasRole($role, $user);},
],
];
}
}