[ Index ]
 

Code source de XOOPS 2.0.17.1

Accédez au Source d'autres logiciels libres

title

Body

[fermer]

/htdocs/modules/system/admin/users/ -> main.php (source)

   1  <?php
   2  // $Id: main.php 937 2007-08-05 13:52:31Z malanciault $

   3  //  ------------------------------------------------------------------------ //

   4  //                XOOPS - PHP Content Management System                      //

   5  //                    Copyright (c) 2000 XOOPS.org                           //

   6  //                       <http://www.xoops.org/>                             //

   7  //  ------------------------------------------------------------------------ //

   8  //  This program is free software; you can redistribute it and/or modify     //

   9  //  it under the terms of the GNU General Public License as published by     //

  10  //  the Free Software Foundation; either version 2 of the License, or        //

  11  //  (at your option) any later version.                                      //

  12  //                                                                           //

  13  //  You may not change or alter any portion of this comment or credits       //

  14  //  of supporting developers from this source code or any supporting         //

  15  //  source code which is considered copyrighted (c) material of the          //

  16  //  original comment or credit authors.                                      //

  17  //                                                                           //

  18  //  This program is distributed in the hope that it will be useful,          //

  19  //  but WITHOUT ANY WARRANTY; without even the implied warranty of           //

  20  //  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the            //

  21  //  GNU General Public License for more details.                             //

  22  //                                                                           //

  23  //  You should have received a copy of the GNU General Public License        //

  24  //  along with this program; if not, write to the Free Software              //

  25  //  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA //

  26  //  ------------------------------------------------------------------------ //

  27  // Author: Kazumi Ono (AKA onokazu)                                          //

  28  // URL: http://www.myweb.ne.jp/, http://www.xoops.org/, http://jp.xoops.org/ //

  29  // Project: The XOOPS Project                                                //

  30  // ------------------------------------------------------------------------- //

  31  
  32  if ( !is_object($xoopsUser) || !is_object($xoopsModule) || !$xoopsUser->isAdmin($xoopsModule->mid()) ) {
  33      exit("Access Denied");
  34  }
  35  $op = 'mod_users';
  36  include_once XOOPS_ROOT_PATH."/modules/system/admin/users/users.php";
  37  if (isset($_POST)) {
  38      foreach ( $_POST as $k => $v ) {
  39          ${$k} = $v;
  40      }
  41  }
  42  if (isset($_GET['op'])) {
  43      $op = trim($_GET['op']);
  44      if (isset($_GET['uid'])) {
  45          $uid = intval($_GET['uid']);
  46      }
  47  }
  48  switch ($op) {
  49  
  50  case "modifyUser":
  51      modifyUser($uid);
  52      break;
  53  case "updateUser":
  54      if (!$GLOBALS['xoopsSecurity']->check()) {
  55          redirect_header("admin.php?fct=users", 3, implode('<br />', $GLOBALS['xoopsSecurity']->getErrors()));
  56      }
  57      // RMV-NOTIFY

  58      $user_avatar = $theme = null;
  59      if ( !isset( $attachsig ) ) $attachsig = null;
  60      if ( !isset( $user_viewemail ) ) $user_viewemail = null;
  61      updateUser($uid, $username, $name, $url, $email, $user_icq, $user_aim, $user_yim, $user_msnm, $user_from, $user_occ, $user_intrest, $user_viewemail, $user_avatar, $user_sig, $attachsig, $theme, $password, $pass2, $rank, $bio, $uorder, $umode, $notify_method, $notify_mode, $timezone_offset, $user_mailok, $groups);
  62      break;
  63  case "delUser":
  64      xoops_cp_header();
  65      $member_handler =& xoops_gethandler('member');
  66      $userdata =& $member_handler->getUser($uid);
  67      xoops_confirm(array('fct' => 'users', 'op' => 'delUserConf', 'del_uid' => $userdata->getVar('uid')), 'admin.php', sprintf(_AM_AYSYWTDU,$userdata->getVar('uname')));
  68      xoops_cp_footer();
  69      break;
  70  case "delete_many":
  71      xoops_cp_header();
  72      $count = count($memberslist_id);
  73      if ( $count > 0 ) {
  74          $list = "<a href='".XOOPS_URL."/userinfo.php?uid=".$memberslist_id[0]."' target='_blank'>".$memberslist_uname[$memberslist_id[0]]."</a>";
  75          $hidden = "<input type='hidden' name='memberslist_id[]' value='".$memberslist_id[0]."' />\n";
  76          for ( $i = 1; $i < $count; $i++ ) {
  77              $list .= ", <a href='".XOOPS_URL."/userinfo.php?uid=".$memberslist_id[$i]."' target='_blank'>".$memberslist_uname[$memberslist_id[$i]]."</a>";
  78              $hidden .= "<input type='hidden' name='memberslist_id[]' value='".$memberslist_id[$i]."' />\n";
  79          }
  80          echo "<div><h4>".sprintf(_AM_AYSYWTDU," ".$list." ")."</h4>";
  81          echo _AM_BYTHIS."<br /><br />
  82          <form action='admin.php' method='post'>
  83          <input type='hidden' name='fct' value='users' />
  84          <input type='hidden' name='op' value='delete_many_ok' />
  85          ".$GLOBALS['xoopsSecurity']->getTokenHTML()."
  86          <input type='submit' value='"._YES."' />
  87          <input type='button' value='"._NO."' onclick='javascript:location.href=\"admin.php?op=adminMain\"' />";
  88          echo $hidden;
  89          echo "</form></div>";
  90      } else {
  91          echo _AM_NOUSERS;
  92      }
  93      xoops_cp_footer();
  94      break;
  95  case "delete_many_ok":
  96      if (!$GLOBALS['xoopsSecurity']->check()) {
  97          redirect_header("admin.php?fct=users", 3, implode('<br />', $GLOBALS['xoopsSecurity']->getErrors()));
  98      }
  99      $count = count($memberslist_id);
 100      $output = "";
 101      $member_handler =& xoops_gethandler('member');
 102      for ( $i = 0; $i < $count; $i++ ) {
 103          $deluser =& $member_handler->getUser($memberslist_id[$i]);
 104          $delgroups = $deluser->getGroups();
 105          if (in_array(XOOPS_GROUP_ADMIN, $delgroups)) {
 106              $output .= sprintf('Admin user cannot be deleted. (User: %s)', $deluser->getVar("uname"))."<br />";
 107          } else {
 108              if (!$member_handler->deleteUser($deluser)) {
 109                  $output .= "Could not delete ".$deluser->getVar("uname")."<br />";
 110              } else {
 111                  $output .= $deluser->getVar("uname")." deleted<br />";
 112              }
 113              // RMV-NOTIFY

 114              xoops_notification_deletebyuser($deluser->getVar('uid'));
 115          }
 116      }
 117      xoops_cp_header();
 118      echo $output;
 119      xoops_cp_footer();
 120      break;
 121  case "delUserConf":
 122      if (!$GLOBALS['xoopsSecurity']->check()) {
 123          redirect_header("admin.php?fct=users", 3, implode('<br />', $GLOBALS['xoopsSecurity']->getErrors()));
 124      }
 125      $member_handler =& xoops_gethandler('member');
 126      $user =& $member_handler->getUser($del_uid);
 127      $groups = $user->getGroups();
 128      if (in_array(XOOPS_GROUP_ADMIN, $groups)) {
 129          xoops_cp_header();
 130          echo sprintf('Admin user cannot be deleted. (User: %s)', $user->getVar("uname"));
 131          xoops_cp_footer();
 132      } elseif (!$member_handler->deleteUser($user)) {
 133          xoops_cp_header();
 134          echo "Could not delete ".$deluser->getVar("uname");
 135          xoops_cp_footer();
 136      } else {
 137          $online_handler =& xoops_gethandler('online');
 138          $online_handler->destroy($del_uid);
 139          // RMV-NOTIFY

 140          xoops_notification_deletebyuser($del_uid);
 141          redirect_header("admin.php?fct=users",1,_AM_DBUPDATED);
 142      }
 143      break;
 144  case "addUser":
 145      if (!$GLOBALS['xoopsSecurity']->check()) {
 146          redirect_header("admin.php?fct=users", 3, implode('<br />', $GLOBALS['xoopsSecurity']->getErrors()));
 147      }
 148      if (!$username || !$email || !$password) {
 149          $adduser_errormsg = _AM_YMCACF;
 150      } else {
 151          $member_handler =& xoops_gethandler('member');
 152          // make sure the username doesnt exist yet

 153          if ($member_handler->getUserCount(new Criteria('uname', $username)) > 0) {
 154              $adduser_errormsg = 'User name '.$username.' already exists';
 155          } else {
 156              $newuser =& $member_handler->createUser();
 157              if ( isset($user_viewemail) ) {
 158                  $newuser->setVar("user_viewemail",$user_viewemail);
 159              }
 160              if ( isset($attachsig) ) {
 161                  $newuser->setVar("attachsig",$attachsig);
 162              }
 163              $newuser->setVar("name", $name);
 164              $newuser->setVar("uname", $username);
 165              $newuser->setVar("email", $email);
 166              $newuser->setVar("url", formatURL($url));
 167              $newuser->setVar("user_avatar",'blank.gif');
 168              $newuser->setVar("user_icq", $user_icq);
 169              $newuser->setVar("user_from", $user_from);
 170              $newuser->setVar("user_sig", $user_sig);
 171              $newuser->setVar("user_aim", $user_aim);
 172              $newuser->setVar("user_yim", $user_yim);
 173              $newuser->setVar("user_msnm", $user_msnm);
 174              if ($pass2 != "") {
 175                  if ( $password != $pass2 ) {
 176                      xoops_cp_header();
 177                      echo "
 178                      <b>"._AM_STNPDNM."</b>";
 179                      xoops_cp_footer();
 180                      exit();
 181                  }
 182                  $newuser->setVar("pass", md5($password));
 183              }
 184              $newuser->setVar("timezone_offset", $timezone_offset);
 185              $newuser->setVar("uorder", $uorder);
 186              $newuser->setVar("umode", $umode);
 187              // RMV-NOTIFY

 188              $newuser->setVar("notify_method", $notify_method);
 189              $newuser->setVar("notify_mode", $notify_mode);
 190              $newuser->setVar("bio", $bio);
 191              $newuser->setVar("rank", $rank);
 192              $newuser->setVar("level", 1);
 193              $newuser->setVar("user_occ", $user_occ);
 194              $newuser->setVar("user_intrest", $user_intrest);
 195              $newuser->setVar('user_mailok', $user_mailok);
 196              if (!$member_handler->insertUser($newuser)) {
 197                  $adduser_errormsg = _AM_CNRNU;
 198              } else {
 199                  $groups_failed = array();
 200                  foreach ($groups as $group) {
 201                      if (!$member_handler->addUserToGroup($group, $newuser->getVar('uid'))) {
 202                          $groups_failed[] = $group;
 203                      }
 204                  }
 205                  if (!empty($groups_failed)) {
 206                      $group_names = $member_handler->getGroupList(new Criteria('groupid', "(".implode(", ", $groups_failed).")", 'IN'));
 207                      $adduser_errormsg = sprintf(_AM_CNRNU2, implode(", ", $group_names));
 208                  } else {
 209                      redirect_header("admin.php?fct=users",1,_AM_DBUPDATED);
 210                      exit();
 211                  }
 212              }
 213          }
 214      }
 215      xoops_cp_header();
 216      xoops_error($adduser_errormsg);
 217      xoops_cp_footer();
 218      break;
 219  case "synchronize":
 220      if (!$GLOBALS['xoopsSecurity']->check()) {
 221          redirect_header("admin.php?fct=users", 3, implode('<br />', $GLOBALS['xoopsSecurity']->getErrors()));
 222      }
 223      synchronize($id, $type);
 224      break;
 225  case "reactivate":
 226      $result=$xoopsDB->query("UPDATE ".$xoopsDB->prefix("users")." SET level=1 WHERE uid=".$uid);
 227      if(!$result){
 228          exit();
 229      }
 230      redirect_header("admin.php?fct=users&amp;op=modifyUser&amp;uid=".$uid,1,_AM_DBUPDATED);
 231      break;
 232  case "mod_users":
 233  default:
 234      include_once  XOOPS_ROOT_PATH.'/class/pagenav.php';
 235      displayUsers();
 236      break;
 237  }
 238  ?>


Généré le : Sun Nov 25 11:44:32 2007 par Balluche grâce à PHPXref 0.7
  Clicky Web Analytics