dokeos
[ class tree: dokeos ] [ index: dokeos ] [ all elements ]

Source for file blog_permissions.inc.php

Documentation is available at blog_permissions.inc.php

  1. <?php
  2.  
  3. /**
  4. * smartBlogs add-on: it must be possible to change rights for every single blog
  5. * in a course.
  6. @author Toon Keppens
  7. */
  8. // Init
  9. $rights_full=array("article_add","article_delete","article_edit","article_rate","article_comments_add","article_comments_delete","article_comments_rate","task_management","member_management","role_management");
  10. $rights_limited=array("Add","Edit","Delete");
  11. $rights_blog=array("article_add","article_delete","article_edit","article_rate","article_comments_add","article_comments_delete","article_comments_rate","task_management","member_management","role_management");
  12. $course_tool_table Database::get_course_table(TABLE_TOOL_LIST);
  13.  
  14. // Get all user
  15. $blog_users Blog::get_blog_users(mysql_escape_string($_GET['blog_id']));
  16.  
  17. // Remove the blog creater because he has all the rights automatically
  18. // and we want to keep it that way.
  19. $tbl_course_rel_user $table=Database::get_main_table(TABLE_MAIN_COURSE_USER);
  20. $sql "SELECT user_id FROM $tbl_course_rel_user WHERE status = '1' AND course_code = '".$_SESSION['_cid']."'";
  21. $result api_sql_query($sql,__FILE__,__LINE__);
  22. while ($user mysql_fetch_assoc($result)) {
  23.     unset($blog_users[$user['user_id']]);    
  24. }
  25.  
  26. //$user_id=$userIdViewed;
  27. if ($mainUserInfo['status']==1)
  28. {
  29.     $course_admin=1;
  30. }
  31.  
  32. include_once('permissions_functions.inc.php');
  33. include_once(api_get_path(LIBRARY_PATH"/groupmanager.lib.php");
  34. // ---------------------------------------------------
  35. //             ACTIONS
  36. // ---------------------------------------------------
  37. if (isset($_GET['do']))
  38. {
  39.     if isset($_GET['permission']AND isset($_GET['tool']AND ($_GET['do']=='grant' OR $_GET['do']=='revoke'))
  40.     {
  41.         $result_message=store_one_permission('user'$_GET['do']$_GET['user_id']$_GET['tool']$_GET['permission']);
  42.     }
  43.     if (isset($_GET['role']AND ($_GET['do']=='grant' OR $_GET['do']=='revoke'))
  44.     {
  45.         $result_message=assign_role('user'$_GET['do']$user_id$_GET['role']$_GET['scope']);
  46.     }
  47. }
  48. /*
  49. if (isset($result_message))
  50. {
  51.     Display::display_normal_message($result_message);
  52. }
  53. */
  54.  
  55.  
  56. // ------------------------------------------------------------------
  57. //             RETRIEVING THE PERMISSIONS OF THE ROLES OF THE USER
  58. // ------------------------------------------------------------------
  59. if (api_get_setting('user_roles')=='true')
  60. {
  61.     // course roles that are assigned to the user
  62.     $current_user_role_permissions_of_user=get_roles_permissions('user',$user_id);
  63.     $inherited_permissions=permission_array_merge($inherited_permissions,$current_user_role_permissions_of_user);
  64.     // NOTE: deze array moet nog gemerged worden met de $inherited_permissions array
  65.     // (heet momenteel nog $current_group_permissions_of_user omdat voorlopig enkel de 
  66.     // groepsgeërfde permissions in beschouwing worden genomen
  67.     // dit moet ook de rol permissies van rollen die toegekend worden aan een gebruiker
  68.     // en de rol permissies van rollen die toegekend worden aan de groepen van een gebruiker
  69.     // omvatten.
  70.     // NOTE: checken als de rollen brol wel degelijk geactiveerd is voordat we dit allemaal 
  71.     // ophalen.
  72.     // platform roles that are assigned to the user
  73.     $current_user_role_permissions_of_user=get_roles_permissions('user',$user_id'platform');
  74.     $inherited_permissions=permission_array_merge($inherited_permissions,$current_user_role_permissions_of_user);
  75. }
  76. // ------------------------------------------------------------------
  77. //    RETRIEVING THE PERMISSIONS OF THE ROLES OF THE GROUPS OF THE USER
  78. // ------------------------------------------------------------------
  79. if (api_get_setting('group_roles')=='true')
  80. {
  81.     // NOTE: DIT MOET NOG VERDER UITGEWERKT WORDEN
  82.     foreach ($groups_of_user as $group)
  83.     {
  84.         $this_current_group_role_permissions_of_user=get_roles_permissions('user',$user_id);
  85.         //$inherited_permissions[$tool][]=$permission;
  86.     }
  87. }
  88.  
  89.  
  90. echo "<form method=\"post\" action=\"".str_replace('&''&amp;'$_SERVER['REQUEST_URI'])."\">";
  91.  
  92. // ---------------------------------------------------
  93. //         DISPLAYING THE ROLES LIST
  94. // ---------------------------------------------------
  95. if (api_get_setting('user_roles')=='true')
  96. {
  97.     // the list of the roles for the user
  98.     echo '<strong>'.get_lang('UserRoles').'</strong><br />';
  99.     $current_user_course_roles=get_roles('user',$user_id);
  100.     $current_user_platform_roles=get_roles('user',$user_id'platform');
  101.     display_role_list($current_user_course_roles$current_user_platform_roles);
  102.     echo '<br />';
  103. }
  104.  
  105. // ---------------------------------------------------
  106. //             DISPLAYING THE MATRIX (user permissions)
  107. // ---------------------------------------------------
  108. echo "<table class=\"data_table\">\n";
  109.  
  110. // the header
  111. echo "\t<tr>\n";    
  112.     echo "\t\t<th rowspan=\"2\">".get_lang('Module')."</th>\n";
  113.     echo "\t\t<th colspan=\"4\">".get_lang('ArticleManager')."</th>\n";
  114.     echo "\t\t<th colspan=\"3\">".get_lang('CommentManager')."</th>\n";
  115.     echo "\t\t<th colspan=\"3\">".get_lang('BlogManager')."</th>\n";
  116. echo "\t</tr>\n";
  117.  
  118. // Subheader
  119. echo "\t<tr>\n";
  120.     echo "\t\t<th align='center'>".get_lang('Add')."</th>\n";
  121.     echo "\t\t<th align='center'>".get_lang('Delete')."</th>\n";
  122.     echo "\t\t<th align='center'>".get_lang('Edit')."</th>\n";
  123.     echo "\t\t<th align='center'>".get_lang('Rate')."</th>\n";
  124.     echo "\t\t<th align='center'>".get_lang('Add')."</th>\n";
  125.     echo "\t\t<th align='center'>".get_lang('Delete')."</th>\n";
  126.     echo "\t\t<th align='center'>".get_lang('Rate')."</th>\n";
  127.     echo "\t\t<th align='center'>".get_lang('Tasks')."</th>\n";
  128.     echo "\t\t<th align='center'>".get_lang('Members')."</th>\n";
  129.     echo "\t\t<th align='center'>".get_lang('Roles')."</th>\n";
  130. echo "\t</tr>\n";
  131.  
  132. // the main area with the checkboxes or images
  133. foreach ($blog_users as $user_id => $user_name// $blog_users contains all the users in this blog
  134. {
  135.     // ---------------------------------------------------
  136.     //             RETRIEVING THE PERMISSIONS OF THE USER
  137.     // ---------------------------------------------------
  138.     $current_user_permissions array();
  139.     $current_user_permissions get_permissions('user'$user_id);
  140.     
  141.     echo "\t<tr>\n";    
  142.     echo "\t\t<td>\n";
  143.         echo $user_name;
  144.     echo "\t\t</td>\n"
  145.     
  146.     foreach ($rights_full as $key => $value)
  147.     {
  148.         
  149.         echo "\t\t<td align='center'>\n";
  150.         if (in_array($value,$rights_blog))
  151.         {
  152.             display_image_matrix_for_blogs($current_user_permissions$user_id'BLOG_'.$blog_id$value,$inherited_permissions$course_admin);
  153.         }        
  154.         // note: in a later stage this part will be replaced by a function
  155.         // so that we can easily switch between a checkbox approach or an image approach
  156.         // where every click is in fact a change of status. In the checkbox approach you first have to 
  157.         // do the changes and then store them by clicking the submit button. 
  158.         echo "\t\t</td>\n";
  159.     }
  160.     echo "\t</tr>\n";
  161. }
  162.  
  163. echo "</table>\n";
  164. echo "</form><br />";
  165.  
  166. // ---------------------------------------------------
  167. //             LEGEND
  168. // ---------------------------------------------------
  169. echo '<strong>'.get_lang('Legend').'</strong><br />';
  170. echo '<img src="../img/wrong.gif" /> '.get_lang('UserHasPermissionNot').'<br />';
  171. echo '<img src="../img/checkbox_on2.gif" /> '.get_lang('UserHasPermission').'<br />';
  172. echo '<img src="../img/checkbox_on3.gif" /> '.get_lang('UserHasPermissionByRoleGroup').'<br />';
  173.  
  174. ?>

Documentation generated on Thu, 12 Jun 2008 13:01:34 -0500 by phpDocumentor 1.4.1