3 require_once('../../config.php');
5 require_once($CFG->libdir
.'/adminlib.php');
7 admin_externalpage_setup('defineroles');
9 $roleid = optional_param('roleid', 0, PARAM_INT
); // if set, we are editing a role
10 $name = optional_param('name', '', PARAM_MULTILANG
); // new role name
11 $shortname = optional_param('shortname', '', PARAM_RAW
); // new role shortname, special cleaning before storage
12 $description = optional_param('description', '', PARAM_CLEAN
); // new role desc
13 $action = optional_param('action', '', PARAM_ALPHA
);
14 $confirm = optional_param('confirm', 0, PARAM_BOOL
);
15 $cancel = optional_param('cancel', 0, PARAM_BOOL
);
17 $sitecontext = get_context_instance(CONTEXT_SYSTEM
);
19 require_capability('moodle/role:manage', $sitecontext);
22 redirect('manage.php');
28 $roles = get_all_roles();
29 $rolescount = count($roles);
31 /// fix sort order if needed
34 foreach ($roles as $rolex) {
35 $rolesort[$i] = $rolex->id
;
36 if ($rolex->sortorder
!= $i) {
40 update_record('role', $r);
41 $roles[$rolex->id
]->sortorder
= $i;
46 // do not delete these default system roles
47 $defaultroles = array();
48 $defaultroles[] = $CFG->notloggedinroleid
;
49 $defaultroles[] = $CFG->guestroleid
;
50 $defaultroles[] = $CFG->defaultuserroleid
;
51 $defaultroles[] = $CFG->defaultcourseroleid
;
53 /// form processing, editing a role, adding a role, deleting a role etc.
56 if ($data = data_submitted() and confirm_sesskey()) {
58 $shortname = moodle_strtolower(clean_param(clean_filename($shortname), PARAM_SAFEDIR
)); // only lowercase safe ASCII characters
59 $legacytype = required_param('legacytype', PARAM_RAW
);
61 $legacyroles = get_legacy_roles();
62 if (!array_key_exists($legacytype, $legacyroles)) {
67 $errors['name'] = get_string('errorbadrolename', 'role');
68 } else if (count_records('role', 'name', $name)) {
69 $errors['name'] = get_string('errorexistsrolename', 'role');
72 if (empty($shortname)) {
73 $errors['shortname'] = get_string('errorbadroleshortname', 'role');
74 } else if (count_records('role', 'shortname', $shortname)) {
75 $errors['shortname'] = get_string('errorexistsroleshortname', 'role');
79 $newroleid = create_role($name, $shortname, $description);
81 // set proper legacy type
82 if (!empty($legacytype)) {
83 assign_capability($legacyroles[$legacytype], CAP_ALLOW
, $newroleid, $sitecontext->id
);
87 $newrole = new object();
88 $newrole->name
= $name;
89 $newrole->shortname
= $shortname;
90 $newrole->description
= $description;
91 $newrole->legacytype
= $legacytype;
94 $allowed_values = array(CAP_INHERIT
, CAP_ALLOW
, CAP_PREVENT
, CAP_PROHIBIT
);
95 $capabilities = fetch_context_capabilities($sitecontext); // capabilities applicable in this context
97 foreach ($capabilities as $cap) {
98 if (!isset($data->{$cap->name
})) {
102 // legacy caps have their own selector
103 if (islegacy($data->{$cap->name
})) {
107 $capname = $cap->name
;
108 $value = clean_param($data->{$cap->name
}, PARAM_INT
);
109 if (!in_array($value, $allowed_values)) {
113 if (empty($errors)) {
114 assign_capability($capname, $value, $newroleid, $sitecontext->id
);
116 $newrole->$capname = $value;
120 // added a role sitewide...
121 mark_context_dirty($sitecontext->path
);
123 if (empty($errors)) {
124 $rolename = get_field('role', 'name', 'id', $newroleid);
125 add_to_log(SITEID
, 'role', 'add', 'admin/roles/manage.php?action=add', $rolename, '', $USER->id
);
126 redirect('manage.php');
133 if ($data = data_submitted() and confirm_sesskey()) {
135 $shortname = moodle_strtolower(clean_param(clean_filename($shortname), PARAM_SAFEDIR
)); // only lowercase safe ASCII characters
136 $legacytype = required_param('legacytype', PARAM_RAW
);
138 $legacyroles = get_legacy_roles();
139 if (!array_key_exists($legacytype, $legacyroles)) {
144 $errors['name'] = get_string('errorbadrolename', 'role');
145 } else if ($rs = get_records('role', 'name', $name)) {
148 $errors['name'] = get_string('errorexistsrolename', 'role');
152 if (empty($shortname)) {
153 $errors['shortname'] = get_string('errorbadroleshortname', 'role');
154 } else if ($rs = get_records('role', 'shortname', $shortname)) {
157 $errors['shortname'] = get_string('errorexistsroleshortname', 'role');
160 if (!empty($errors)) {
161 $newrole = new object();
162 $newrole->name
= $name;
163 $newrole->shortname
= $shortname;
164 $newrole->description
= $description;
165 $newrole->legacytype
= $legacytype;
168 $allowed_values = array(CAP_INHERIT
, CAP_ALLOW
, CAP_PREVENT
, CAP_PROHIBIT
);
169 $capabilities = fetch_context_capabilities($sitecontext); // capabilities applicable in this context
171 foreach ($capabilities as $cap) {
172 if (!isset($data->{$cap->name
})) {
176 // legacy caps have their own selector
177 if (islegacy($data->{$cap->name
}) === 0 ) {
181 $capname = $cap->name
;
182 $value = clean_param($data->{$cap->name
}, PARAM_INT
);
183 if (!in_array($value, $allowed_values)) {
187 if (!empty($errors)) {
188 $newrole->$capname = $value;
193 $SQL = "SELECT * FROM {$CFG->prefix}role_capabilities
194 WHERE roleid = $roleid AND capability = '$capname'
195 AND contextid = $sitecontext->id";
197 $localoverride = get_record_sql($SQL);
199 if ($localoverride) { // update current overrides
200 if ($value == CAP_INHERIT
) { // inherit = delete
201 unassign_capability($capname, $roleid, $sitecontext->id
);
204 $localoverride->permission
= $value;
205 $localoverride->timemodified
= time();
206 $localoverride->modifierid
= $USER->id
;
207 update_record('role_capabilities', $localoverride);
209 } else { // insert a record
210 if ($value != CAP_INHERIT
) {
211 assign_capability($capname, $value, $roleid, $sitecontext->id
);
217 if (empty($errors)) {
218 // update normal role settings
221 $role->shortname
= $shortname;
222 $role->description
= $description;
224 if (!update_record('role', $role)) {
225 error('Could not update role!');
228 // set proper legacy type
229 foreach($legacyroles as $ltype=>$lcap) {
230 if ($ltype == $legacytype) {
231 assign_capability($lcap, CAP_ALLOW
, $roleid, $sitecontext->id
);
233 unassign_capability($lcap, $roleid);
237 // edited a role sitewide...
238 mark_context_dirty($sitecontext->path
);
239 add_to_log(SITEID
, 'role', 'edit', 'admin/roles/manage.php?action=edit&roleid='.$role->id
, $role->name
, '', $USER->id
);
241 redirect('manage.php');
244 // edited a role sitewide - with errors, but still...
245 mark_context_dirty($sitecontext->path
);
251 if (in_array($roleid, $defaultroles)) {
252 error('This role is used as one of the default system roles, it can not be deleted');
254 if ($confirm and data_submitted() and confirm_sesskey()) {
255 if (!delete_role($roleid)) {
257 // partially deleted a role sitewide...?
258 mark_context_dirty($sitecontext->path
);
260 error('Could not delete role with ID '.$roleid);
262 // deleted a role sitewide...
263 mark_context_dirty($sitecontext->path
);
265 } else if (confirm_sesskey()){
267 admin_externalpage_print_header();
268 $optionsyes = array('action'=>'delete', 'roleid'=>$roleid, 'sesskey'=>sesskey(), 'confirm'=>1);
271 $a->name
= $roles[$roleid]->name
;
272 $a->shortname
= $roles[$roleid]->shortname
;
273 $a->count
= (int)count_records('role_assignments', 'roleid', $roleid);
274 notice_yesno(get_string('deleterolesure', 'role', $a), 'manage.php', 'manage.php', $optionsyes, NULL, 'post', 'get');
275 admin_externalpage_print_footer();
279 redirect('manage.php');
283 if (array_key_exists($roleid, $roles) and confirm_sesskey()) {
284 $role = $roles[$roleid];
285 if ($role->sortorder
> 0) {
286 $above = $roles[$rolesort[$role->sortorder
- 1]];
288 if (!switch_roles($role, $above)) {
289 error("Cannot move role with ID $roleid");
294 redirect('manage.php');
298 if (array_key_exists($roleid, $roles) and confirm_sesskey()) {
299 $role = $roles[$roleid];
300 if ($role->sortorder +
1 < $rolescount) {
301 $below = $roles[$rolesort[$role->sortorder +
1]];
303 if (!switch_roles($role, $below)) {
304 error("Cannot move role with ID $roleid");
309 redirect('manage.php');
313 if (!array_key_exists($roleid, $roles)) {
314 redirect('manage.php');
317 if ($confirm and data_submitted() and confirm_sesskey()) {
318 //ok - lets duplicate!
321 admin_externalpage_print_header();
322 $optionsyes = array('action'=>'duplicate', 'roleid'=>$roleid, 'sesskey'=>sesskey(), 'confirm'=>1);
323 $optionsno = array('action'=>'view', 'roleid'=>$roleid);
326 $a->name
= $roles[$roleid]->name
;
327 $a->shortname
= $roles[$roleid]->shortname
;
328 notice_yesno(get_string('duplicaterolesure', 'role', $a), 'manage.php', 'manage.php', $optionsyes, $optionsno, 'post', 'get');
329 admin_externalpage_print_footer();
333 // duplicate current role
334 $sourcerole = get_record('role','id',$roleid);
336 $fullname = $sourcerole->name
;
337 $shortname = $sourcerole->shortname
;
338 $currentfullname = "";
339 $currentshortname = "";
342 // find a name for the duplicated role
345 $suffixfull = " ".get_string("copyasnoun")." ".$counter;
346 $suffixshort = "_".$counter;
351 $currentfullname = $fullname.$suffixfull;
352 // Limit the size of shortname - database column accepts <= 100 chars
353 $currentshortname = substr($shortname, 0, 100 - strlen($suffixshort)).$suffixshort;
354 $coursefull = get_record("role","name",addslashes($currentfullname));
355 $courseshort = get_record("role","shortname",addslashes($currentshortname));
357 } while ($coursefull ||
$courseshort);
359 $description = 'duplicate of '.$fullname;
360 if ($newrole = create_role($currentfullname, $currentshortname, $description)) {
361 // dupilcate all the capabilities
362 role_cap_duplicate($sourcerole, $newrole);
364 // dup'ed a role sitewide...
365 mark_context_dirty($sitecontext->path
);
368 $rolename = get_field('role', 'name', 'id', $newrole);
369 add_to_log(SITEID
, 'role', 'duplicate', 'admin/roles/manage.php?roleid='.$newrole.'&action=duplicate', $rolename, '', $USER->id
);
370 redirect('manage.php');
374 if (!array_key_exists($roleid, $roles)) {
375 redirect('manage.php');
378 if ($confirm and data_submitted() and confirm_sesskey()) {
379 reset_role_capabilities($roleid);
381 // reset a role sitewide...
382 mark_context_dirty($sitecontext->path
);
384 $rolename = get_field('role', 'name', 'id', $roleid);
385 add_to_log(SITEID
, 'role', 'reset', 'admin/roles/manage.php?roleid='.$roleid.'&action=reset', $rolename, '', $USER->id
);
387 redirect('manage.php?action=view&roleid='.$roleid);
391 admin_externalpage_print_header();
392 $optionsyes = array('action'=>'reset', 'roleid'=>$roleid, 'sesskey'=>sesskey(), 'confirm'=>1);
393 $optionsno = array('action'=>'view', 'roleid'=>$roleid);
396 $a->name
= $roles[$roleid]->name
;
397 $a->shortname
= $roles[$roleid]->shortname
;
398 $a->legacytype
= get_legacy_type($roleid);
399 if (empty($a->legacytype
)) {
400 $warning = get_string('resetrolesurenolegacy', 'role', $a);
402 $warning = get_string('resetrolesure', 'role', $a);
404 notice_yesno($warning, 'manage.php', 'manage.php', $optionsyes, $optionsno, 'post', 'get');
405 admin_externalpage_print_footer();
417 admin_externalpage_print_header();
419 $currenttab = 'manage';
420 include_once('managetabs.php');
422 if (($roleid and ($action == 'view' or $action == 'edit')) or $action == 'add') { // view or edit role details
424 if ($action == 'add') {
426 if (empty($errors) or empty($newrole)) {
427 $role = new object();
429 $role->shortname
= '';
430 $role->description
= '';
431 $role->legacytype
= '';
433 $role = stripslashes_safe($newrole);
435 } else if ($action == 'edit' and !empty($errors) and !empty($newrole)) {
436 $role = stripslashes_safe($newrole);
438 if(!$role = get_record('role', 'id', $roleid)) {
439 error('Incorrect role ID!');
441 $role->legacytype
= get_legacy_type($role->id
);
444 foreach ($roles as $rolex) {
445 $roleoptions[$rolex->id
] = strip_tags(format_string($rolex->name
));
448 // this is the array holding capabilities of this role sorted till this context
449 $r_caps = role_context_capabilities($roleid, $sitecontext);
451 // this is the available capabilities assignable in this context
452 $capabilities = fetch_context_capabilities($sitecontext);
454 $usehtmleditor = can_use_html_editor();
458 print_heading_with_help(get_string('addrole', 'role'), 'roles');
461 print_heading_with_help(get_string('viewrole', 'role'), 'roles');
464 print_heading_with_help(get_string('editrole', 'role'), 'roles');
468 echo '<div class="selector">';
469 if ($action == 'view') {
470 popup_form('manage.php?action=view&roleid=', $roleoptions, 'switchrole', $roleid, '', '', '',
471 false, 'self', get_string('selectrole', 'role'));
473 echo '<div class="buttons">';
475 $legacytype = get_legacy_type($roleid);
477 $options['roleid'] = $roleid;
478 $options['action'] = 'edit';
479 print_single_button('manage.php', $options, get_string('edit'));
480 $options['action'] = 'reset';
481 if (empty($legacytype)) {
482 print_single_button('manage.php', $options, get_string('resetrolenolegacy', 'role'));
484 print_single_button('manage.php', $options, get_string('resetrole', 'role'));
486 $options['action'] = 'duplicate';
487 print_single_button('manage.php', $options, get_string('duplicaterole', 'role'));
488 print_single_button('manage.php', null, get_string('listallroles', 'role'));
493 $lang = str_replace('_utf8', '', current_language());
495 print_simple_box_start('center');
496 include_once('manage.html');
497 print_simple_box_end();
499 if ($usehtmleditor) {
500 use_html_editor('description');
505 print_heading_with_help(get_string('roles', 'role'), 'roles');
509 $table->tablealign
= 'center';
510 $table->align
= array('right', 'left', 'left', 'left');
511 $table->wrap
= array('nowrap', '', 'nowrap','nowrap');
512 $table->cellpadding
= 5;
513 $table->cellspacing
= 0;
514 $table->width
= '90%';
515 $table->data
= array();
517 $table->head
= array(get_string('name'),
518 get_string('description'),
519 get_string('shortname'),
522 /*************************
523 * List all current roles *
524 **************************/
526 foreach ($roles as $role) {
528 $stredit = get_string('edit');
529 $strdelete = get_string('delete');
530 $strmoveup = get_string('moveup');
531 $strmovedown = get_string('movedown');
534 $row[0] = '<a href="manage.php?roleid='.$role->id
.'&action=view">'.format_string($role->name
).'</a>';
535 $row[1] = format_text($role->description
, FORMAT_HTML
);
536 $row[2] = s($role->shortname
);
537 $row[3] = '<a title="'.$stredit.'" href="manage.php?action=edit&roleid='.$role->id
.'">'.
538 '<img src="'.$CFG->pixpath
.'/t/edit.gif" class="iconsmall" alt="'.$stredit.'" /></a> ';
539 if (in_array($role->id
, $defaultroles)) {
540 $row[3] .= '<img src="'.$CFG->wwwroot
.'/pix/spacer.gif" class="iconsmall" alt="" /> ';
542 $row[3] .= '<a title="'.$strdelete.'" href="manage.php?action=delete&roleid='.$role->id
.'&sesskey='.sesskey().'">'.
543 '<img src="'.$CFG->pixpath
.'/t/delete.gif" class="iconsmall" alt="'.$strdelete.'" /></a> ';
545 if ($role->sortorder
!= 0) {
546 $row[3] .= '<a title="'.$strmoveup.'" href="manage.php?action=moveup&roleid='.$role->id
.'&sesskey='.sesskey().'">'.
547 '<img src="'.$CFG->pixpath
.'/t/up.gif" class="iconsmall" alt="'.$strmoveup.'" /></a> ';
549 $row[3] .= '<img src="'.$CFG->wwwroot
.'/pix/spacer.gif" class="iconsmall" alt="" /> ';
551 if ($role->sortorder+
1 < $rolescount) {
552 $row[3] .= '<a title="'.$strmovedown.'" href="manage.php?action=movedown&roleid='.$role->id
.'&sesskey='.sesskey().'">'.
553 '<img src="'.$CFG->pixpath
.'/t/down.gif" class="iconsmall" alt="'.$strmovedown.'" /></a> ';
555 $row[3] .= '<img src="'.$CFG->wwwroot
.'/pix/spacer.gif" class="iconsmall" alt="" /> ';
558 $table->data
[] = $row;
563 $options = new object();
564 $options->action
= 'add';
565 echo '<div class="buttons">';
566 print_single_button('manage.php', $options, get_string('addrole', 'role'), 'get');
570 admin_externalpage_print_footer();