user_permissions.inc.php 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202
  1. <?php
  2. /**
  3. * @package chamilo.permissions
  4. */
  5. /**
  6. * Code
  7. */
  8. $user_id=$userIdViewed;
  9. if ($mainUserInfo['status']==1)
  10. {
  11. $course_admin=1;
  12. }
  13. include_once('permissions_functions.inc.php');
  14. include_once('all_permissions.inc.php');
  15. include_once (api_get_library_path()."/groupmanager.lib.php");
  16. include_once (api_get_library_path()."/blog.lib.php");
  17. // ---------------------------------------------------
  18. // ACTIONS
  19. // ---------------------------------------------------
  20. if ($_POST['StoreUserPermissions'] and $setting_visualisation=='checkbox')
  21. {
  22. $result_message=store_permissions('user', $user_id);
  23. if ($result_message)
  24. {
  25. Display::display_normal_message($result_message);
  26. }
  27. }
  28. if (isset($_GET['action']))
  29. {
  30. if ( isset($_GET['permission']) AND isset($_GET['tool']) AND ($_GET['action']=='grant' OR $_GET['action']=='revoke'))
  31. {
  32. $result_message=store_one_permission('user', $_GET['action'], $user_id, $_GET['tool'], $_GET['permission']);
  33. }
  34. if (isset($_GET['role']) AND ($_GET['action']=='grant' OR $_GET['action']=='revoke'))
  35. {
  36. $result_message=assign_role('user', $_GET['action'], $user_id, $_GET['role'], $_GET['scope']);
  37. }
  38. }
  39. if (isset($result_message))
  40. {
  41. Display::display_normal_message($result_message);
  42. }
  43. // ---------------------------------------------------
  44. // RETRIEVING THE PERMISSIONS OF THE USER
  45. // ---------------------------------------------------
  46. $current_user_permissions=array();
  47. $current_user_permissions=get_permissions('user',$user_id);
  48. // INHERITED PERMISSIONS (group permissions, user roles, group roles)
  49. // RETRIEVING THE PERMISSIONS OF THE GROUPS OF THE USER
  50. $groups_of_user=array();
  51. $groups_of_user=GroupManager::get_group_ids($_course['real_id'],$user_id);
  52. foreach ($groups_of_user as $group)
  53. {
  54. $this_group_permissions=get_permissions('group',$group);
  55. foreach ($this_group_permissions as $tool=>$permissions)
  56. {
  57. foreach ($permissions as $permission)
  58. {
  59. $inherited_group_permissions[$tool][]=$permission;
  60. }
  61. }
  62. }
  63. $inherited_permissions=$inherited_group_permissions;
  64. // RETRIEVING THE PERMISSIONS OF THE ROLES OF THE USER
  65. if (api_get_setting('user_roles')=='true') {
  66. // course roles that are assigned to the user
  67. $current_user_role_permissions_of_user=get_roles_permissions('user',$user_id);
  68. $inherited_permissions=permission_array_merge($inherited_permissions,$current_user_role_permissions_of_user);
  69. // NOTE: deze array moet nog gemerged worden met de $inherited_permissions array
  70. // (heet momenteel nog $current_group_permissions_of_user omdat voorlopig enkel de
  71. // groepsge�rfde permissions in beschouwing worden genomen
  72. // dit moet ook de rol permissies van rollen die toegekend worden aan een gebruiker
  73. // en de rol permissies van rollen die toegekend worden aan de groepen van een gebruiker
  74. // omvatten.
  75. // NOTE: checken als de rollen brol wel degelijk geactiveerd is voordat we dit allemaal
  76. // ophalen.
  77. // platform roles that are assigned to the user
  78. $current_user_role_permissions_of_user=get_roles_permissions('user',$user_id, 'platform');
  79. $inherited_permissions=permission_array_merge($inherited_permissions,$current_user_role_permissions_of_user);
  80. }
  81. // RETRIEVING THE PERMISSIONS OF THE ROLES OF THE GROUPS OF THE USER
  82. if (api_get_setting('group_roles')=='true')
  83. {
  84. // NOTE: DIT MOET NOG VERDER UITGEWERKT WORDEN
  85. foreach ($groups_of_user as $group)
  86. {
  87. $this_current_group_role_permissions_of_user=get_roles_permissions('user',$user_id);
  88. //$inherited_permissions[$tool][]=$permission;
  89. }
  90. }
  91. // ---------------------------------------------------
  92. // LIMITED OR FULL
  93. // ---------------------------------------------------
  94. $current_user_permissions=limited_or_full($current_user_permissions);
  95. $inherited_permissions=limited_or_full($inherited_permissions);
  96. if (api_get_setting('permissions')=='limited')
  97. {
  98. $header_array=$rights_limited;
  99. }
  100. if (api_get_setting('permissions')=='full')
  101. {
  102. $header_array=$rights_full;
  103. }
  104. echo "<form method=\"post\" action=\"".str_replace('&', '&amp;', $_SERVER['REQUEST_URI'])."\">";
  105. // ---------------------------------------------------
  106. // DISPLAYING THE ROLES LIST
  107. // ---------------------------------------------------
  108. if (api_get_setting('user_roles')=='true')
  109. {
  110. // the list of the roles for the user
  111. echo '<strong>'.get_lang('UserRoles').'</strong><br />';
  112. $current_user_course_roles=get_roles('user',$user_id);
  113. $current_user_platform_roles=get_roles('user',$user_id, 'platform');
  114. display_role_list($current_user_course_roles, $current_user_platform_roles);
  115. echo '<br />';
  116. }
  117. // ---------------------------------------------------
  118. // DISPLAYING THE MATRIX (user permissions)
  119. // ---------------------------------------------------
  120. echo '<strong>'.get_lang('UserPermissions').'</strong>';
  121. echo "<table class=\"data_table\">\n";
  122. // the header
  123. echo "\t<tr>\n";
  124. echo "\t\t<th>".get_lang('Module')."</th>\n";
  125. foreach ($header_array as $header_key=>$header_value)
  126. {
  127. echo "\t\t<th>".get_lang($header_value)."</th>\n";
  128. }
  129. echo "\t</tr>\n";
  130. // the main area with the checkboxes or images
  131. foreach ($tool_rights as $tool=>$rights) // $tool_rights contains all the possible tools and their rights
  132. {
  133. echo "\t<tr>\n";
  134. echo "\t\t<td>\n";
  135. if (strstr($tool,'BLOG'))
  136. {
  137. // Not dealing with a real tool here, get name of this blog
  138. // Strip blog id
  139. $tmp = strpos($tool,'_')+1;
  140. $blog_id = substr($tool,$tmp,strlen($tool));
  141. // Get title
  142. echo get_lang('Blog').": ".Blog::get_blog_title($blog_id);
  143. }
  144. else
  145. {
  146. echo get_lang($tool);
  147. }
  148. echo "\t\t</td>\n";
  149. foreach ($header_array as $key=>$value)
  150. {
  151. echo "\t\t<td align='center'>\n";
  152. if (in_array($value,$rights))
  153. {
  154. if ($setting_visualisation=='checkbox')
  155. {
  156. display_checkbox_matrix($current_user_permissions, $tool, $value, $inherited_permissions,$course_admin);
  157. }
  158. if ($setting_visualisation=='image')
  159. {
  160. display_image_matrix($current_user_permissions, $tool, $value,$inherited_permissions, $course_admin);
  161. }
  162. }
  163. // note: in a later stage this part will be replaced by a function
  164. // so that we can easily switch between a checkbox approach or an image approach
  165. // where every click is in fact a change of status. In the checkbox approach you first have to
  166. // do the changes and then store them by clicking the submit button.
  167. echo "\t\t</td>\n";
  168. }
  169. echo "\t</tr>\n";
  170. }
  171. echo "</table>\n";
  172. if ($setting_visualisation=='checkbox')
  173. {
  174. echo "<input type=\"Submit\" name=\"StoreUserPermissions\" value=\"".get_lang('StorePermissions')."\">";
  175. }
  176. echo "</form><br />";
  177. // ---------------------------------------------------
  178. // LEGEND
  179. // ---------------------------------------------------
  180. echo '<strong>'.get_lang('Legend').'</strong><br />';
  181. echo '<img src="../img/wrong.gif" /> '.get_lang('UserHasPermissionNot').'<br />';
  182. echo '<img src="../img/checkbox_on2.gif" /> '.get_lang('UserHasPermission').'<br />';
  183. echo '<img src="../img/checkbox_on3.gif" /> '.get_lang('UserHasPermissionByRoleGroup').'<br />';
  184. ?>