[ Index ]

PHP Cross Reference of MantisBT

title

Body

[close]

/ -> manage_proj_user_remove.php (source)

   1  <?php
   2  # MantisBT - A PHP based bugtracking system
   3  
   4  # MantisBT is free software: you can redistribute it and/or modify
   5  # it under the terms of the GNU General Public License as published by
   6  # the Free Software Foundation, either version 2 of the License, or
   7  # (at your option) any later version.
   8  #
   9  # MantisBT is distributed in the hope that it will be useful,
  10  # but WITHOUT ANY WARRANTY; without even the implied warranty of
  11  # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  12  # GNU General Public License for more details.
  13  #
  14  # You should have received a copy of the GNU General Public License
  15  # along with MantisBT.  If not, see <http://www.gnu.org/licenses/>.
  16  
  17  /**
  18   * @package MantisBT
  19   * @copyright Copyright (C) 2000 - 2002  Kenzaburo Ito - kenito@300baud.org
  20   * @copyright Copyright (C) 2002 - 2011  MantisBT Team - mantisbt-dev@lists.sourceforge.net
  21   * @link http://www.mantisbt.org
  22   *
  23   * @uses core.php
  24   * @uses access_api.php
  25   * @uses authentication_api.php
  26   * @uses config_api.php
  27   * @uses form_api.php
  28   * @uses gpc_api.php
  29   * @uses helper_api.php
  30   * @uses html_api.php
  31   * @uses lang_api.php
  32   * @uses print_api.php
  33   * @uses project_api.php
  34   * @uses user_api.php
  35   */
  36  
  37  /**
  38   * MantisBT Core API's
  39   */
  40  require_once ( 'core.php' );
  41  require_api( 'access_api.php' );
  42  require_api( 'authentication_api.php' );
  43  require_api( 'config_api.php' );
  44  require_api( 'form_api.php' );
  45  require_api( 'gpc_api.php' );
  46  require_api( 'helper_api.php' );
  47  require_api( 'html_api.php' );
  48  require_api( 'lang_api.php' );
  49  require_api( 'print_api.php' );
  50  require_api( 'project_api.php' );
  51  require_api( 'user_api.php' );
  52  
  53  form_security_validate( 'manage_proj_user_remove' );
  54  auth_reauthenticate();
  55  
  56  $f_project_id = gpc_get_int( 'project_id' );
  57  $f_user_id = gpc_get_int( 'user_id', 0 );
  58  
  59  # We should check both since we are in the project section and an
  60  #  admin might raise the first threshold and not realize they need
  61  #  to raise the second
  62  access_ensure_project_level( config_get( 'manage_project_threshold' ), $f_project_id );
  63  access_ensure_project_level( config_get( 'project_user_threshold' ), $f_project_id );
  64  
  65  if ( 0 == $f_user_id ) {
  66      # Confirm with the user
  67      helper_ensure_confirmed( lang_get( 'remove_all_users_sure_msg' ), lang_get( 'remove_all_users_button' ) );
  68  
  69      project_remove_all_users( $f_project_id, access_get_project_level( $f_project_id ) );
  70  } else {
  71      # Don't allow removal of users from the project who have a higher access level than the current user
  72      access_ensure_project_level( access_get_project_level( $f_project_id, $f_user_id ), $f_project_id );
  73  
  74      $t_user = user_get_row( $f_user_id );
  75  
  76      # Confirm with the user
  77      helper_ensure_confirmed( lang_get( 'remove_user_sure_msg' ) .
  78          '<br/>' . lang_get( 'username_label' ) . lang_get( 'word_separator' ) . $t_user['username'],
  79          lang_get( 'remove_user_button' ) );
  80  
  81      project_remove_user( $f_project_id, $f_user_id );
  82  }
  83  
  84  form_security_purge( 'manage_proj_user_remove' );
  85  
  86  $t_redirect_url = 'manage_proj_edit_page.php?project_id=' . $f_project_id;
  87  
  88  html_page_top( null, $t_redirect_url );
  89  ?>
  90  <br />
  91  <div>
  92  <?php
  93  echo lang_get( 'operation_successful' ).'<br />';
  94  print_bracket_link( $t_redirect_url, lang_get( 'proceed' ) );
  95  ?>
  96  </div>
  97  
  98  <?php
  99  html_page_bottom();


Generated: Thu Jul 28 15:48:31 2011 Cross-referenced by PHPXref 0.7