forked from anuko/timetracker
-
Notifications
You must be signed in to change notification settings - Fork 1
/
role_edit.php
120 lines (111 loc) · 4.9 KB
/
role_edit.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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
<?php
/* Copyright (c) Anuko International Ltd. https://www.anuko.com
License: See license.txt */
require_once('initialize.php');
import('form.Form');
import('ttRoleHelper');
// Access checks.
if (!ttAccessAllowed('manage_roles')) {
header('Location: access_denied.php');
exit();
}
$cl_role_id = (int)$request->getParameter('id');
$role = ttRoleHelper::get($cl_role_id);
if (!$role) {
header('Location: access_denied.php');
exit();
}
// End of access checks.
$assigned_rights = explode(',', $role['rights']);
$available_rights = array_diff($user->rights, $assigned_rights);
if ($request->isPost()) {
$cl_name = trim($request->getParameter('name'));
$cl_description = trim($request->getParameter('description'));
$cl_rank = $request->getParameter('rank');
$cl_status = $request->getParameter('status');
} else {
$cl_name = $role['name'];
$cl_description = $role['description'];
$cl_rank = $role['rank'];
$cl_status = $role['status'];
}
$form = new Form('roleForm');
$form->addInput(array('type'=>'hidden','name'=>'id','value'=>$cl_role_id));
$form->addInput(array('type'=>'text','maxlength'=>'100','name'=>'name','value'=>$cl_name));
$form->addInput(array('type'=>'textarea','name'=>'description','value'=>$cl_description));
for ($i = 0; $i < $user->rank; $i++) {
$rank_data[] = $i;
}
$form->addInput(array('type'=>'combobox','class'=>'dropdown-field-short','name'=>'rank','data'=>$rank_data,'value'=>$cl_rank));
$form->addInput(array('type'=>'combobox','name'=>'status','value'=>$cl_status,
'data'=>array(ACTIVE=>$i18n->get('dropdown.status_active'),INACTIVE=>$i18n->get('dropdown.status_inactive'))));
$form->addInput(array('type'=>'submit','name'=>'btn_save','value'=>$i18n->get('button.save')));
// Multiple select controls for assigned and available rights.
$form->addInput(array('type'=>'combobox','name'=>'assigned_rights','multiple'=>true,'data'=>$assigned_rights));
$form->addInput(array('type'=>'submit','name'=>'btn_delete','value'=>$i18n->get('button.delete')));
$form->addInput(array('type'=>'combobox','name'=>'available_rights','multiple'=>true,'data'=>$available_rights));
$form->addInput(array('type'=>'submit','name'=>'btn_add','value'=>$i18n->get('button.add')));
if ($request->isPost()) {
if ($request->getParameter('btn_save')) {
// Validate user input.
if (!ttValidString($cl_name)) $err->add($i18n->get('error.field'), $i18n->get('label.thing_name'));
if (!ttValidString($cl_description, true)) $err->add($i18n->get('error.field'), $i18n->get('label.description'));
if ($cl_rank >= $user->rank || $cl_rank < 0) $err->add($i18n->get('error.field'), $i18n->get('form.roles.rank'));
if (!ttValidStatus($cl_status)) $err->add($i18n->get('error.field'), $i18n->get('label.status'));
if ($err->no()) {
$existing_role = ttRoleHelper::getRoleByName($cl_name);
if (!$existing_role || ($cl_role_id == $existing_role['id'])) {
// Update role information.
if (ttRoleHelper::update(array(
'id' => $cl_role_id,
'name' => $cl_name,
'rank' => $cl_rank,
'description' => $cl_description,
'status' => $cl_status))) {
header('Location: roles.php');
exit();
} else
$err->add($i18n->get('error.db'));
} else
$err->add($i18n->get('error.object_exists'));
}
}
if ($request->getParameter('btn_delete') && $request->getParameter('assigned_rights')) {
$rights = $role['rights'];
$to_delete = $request->getParameter('assigned_rights');
foreach($to_delete as $index) {
$right_to_delete = $assigned_rights[$index];
$rights = str_replace($right_to_delete, '', $rights);
$rights = str_replace(',,',',', $rights);
}
$rights = trim($rights, ',');
if (ttRoleHelper::update(array('id' => $cl_role_id,'rights'=> $rights))) {
header('Location: role_edit.php?id='.$role['id']);
exit();
} else
$err->add($i18n->get('error.db'));
}
if ($request->getParameter('btn_add') && $request->getParameter('available_rights')) {
$rights = $role['rights'];
$to_add = $request->getParameter('available_rights');
foreach($to_add as $index) {
$right_to_add = $available_rights[$index];
// Just in case remove it.
$rights = str_replace($right_to_add, '', $rights);
$rights = str_replace(',,',',', $rights);
// Add the right only if we have it ourselves.
if (in_array($right_to_add, $user->rights))
$rights .= ','.$right_to_add;
}
$rights = trim($rights, ',');
if (ttRoleHelper::update(array('id' => $cl_role_id,'rights'=> $rights))) {
header('Location: role_edit.php?id='.$role['id']);
exit();
} else
$err->add($i18n->get('error.db'));
}
} // isPost
$smarty->assign('forms', array($form->getName()=>$form->toArray()));
$smarty->assign('title', $i18n->get('title.edit_role'));
$smarty->assign('content_page_name', 'role_edit.tpl');
$smarty->display('index.tpl');