acl_check( 'administration', 'manage', 'users', $my->usertype, 'components', 'com_users' )) {
mosRedirect( 'index2.php', T_('You are not authorized to view this resource.') );
}
require_once( $mainframe->getPath( 'admin_html' ) );
$task = trim( mosGetParam( $_REQUEST, 'task', null ) );
$cid = mosGetParam( $_REQUEST, 'cid', array( 0 ) );
if (!is_array( $cid )) {
$cid = array ( 0 );
}
switch ($task) {
case 'new':
editUser( 0, $option);
break;
case 'edit':
editUser( intval( $cid[0] ), $option );
break;
case 'editA':
editUser( $id, $option );
break;
case 'save':
case 'apply':
saveUser( $option, $task );
break;
case 'remove':
removeUsers( $cid, $option );
break;
case 'block':
changeUserBlock( $cid, 1, $option );
break;
case 'unblock':
changeUserBlock( $cid, 0, $option );
break;
case 'logout':
logoutUser( $cid, $option, $task );
break;
case 'flogout':
logoutUser( $id, $option, $task );
break;
case 'cancel':
cancelUser( $option );
break;
case 'contact':
$contact_id = mosGetParam( $_POST, 'contact_id', '' );
mosRedirect( 'index2.php?option=com_contact&task=editA&id='. $contact_id );
break;
default:
showUsers( $option );
break;
}
function showUsers( $option ) {
global $database, $mainframe, $my, $acl, $mosConfig_list_limit;
$filter_type = $mainframe->getUserStateFromRequest( "filter_type{$option}", 'filter_type', 0 );
$filter_logged = $mainframe->getUserStateFromRequest( "filter_logged{$option}", 'filter_logged', 0 );
$limit = $mainframe->getUserStateFromRequest( "viewlistlimit", 'limit', $mosConfig_list_limit );
$limitstart = $mainframe->getUserStateFromRequest( "view{$option}limitstart", 'limitstart', 0 );
$search = $mainframe->getUserStateFromRequest( "search{$option}", 'search', '' );
$search = $database->getEscaped( trim( strtolower( $search ) ) );
$where = array();
if (isset( $search ) && $search!= "") {
$where[] = "(a.username LIKE '%$search%' OR a.email LIKE '%$search%' OR a.name LIKE '%$search%')";
}
if ( $filter_type ) {
if ( $filter_type == 'Public Frontend' ) {
$where[] = "a.usertype = 'Registered' OR a.usertype = 'Author' OR a.usertype = 'Editor' OR a.usertype = 'Publisher'";
} else if ( $filter_type == 'Public Backend' ) {
$where[] = "a.usertype = 'Manager' OR a.usertype = 'Administrator' OR a.usertype = 'Super Administrator'";
} else {
$where[] = "a.usertype = LOWER( '$filter_type' )";
}
}
if ( $filter_logged == 1 ) {
$where[] = "s.userid = a.id";
} else if ($filter_logged == 2) {
$where[] = "s.userid IS NULL";
}
// exclude any child group id's for this user
//$acl->_debug = true;
$pgids = $acl->get_group_children( $my->gid, 'ARO', 'RECURSE' );
if (is_array( $pgids ) && count( $pgids ) > 0) {
$where[] = "(a.gid NOT IN (" . implode( ',', $pgids ) . "))";
}
$query = "SELECT COUNT(a.id)"
. "\n FROM #__users AS a";
if ($filter_logged == 1 || $filter_logged == 2) {
$query .= "\n INNER JOIN #__session AS s ON s.userid = a.id";
}
$query .= ( count( $where ) ? "\n WHERE " . implode( ' AND ', $where ) : '' )
;
$database->setQuery( $query );
$total = $database->loadResult();
require_once( $GLOBALS['mosConfig_absolute_path'] . '/administrator/includes/pageNavigation.php' );
$pageNav = new mosPageNav( $total, $limitstart, $limit );
$query = "SELECT a.*, g.name AS groupname"
. "\n FROM #__users AS a"
. "\n INNER JOIN #__core_acl_aro AS aro ON aro.value = a.id" // map user to aro
. "\n INNER JOIN #__core_acl_groups_aro_map AS gm ON gm.aro_id = aro.aro_id" // map aro to group
. "\n INNER JOIN #__core_acl_aro_groups AS g ON g.group_id = gm.group_id";
if ($filter_logged == 1 || $filter_logged == 2) {
$query .= "\n INNER JOIN #__session AS s ON s.userid = a.id";
}
$query .= (count( $where ) ? "\n WHERE " . implode( ' AND ', $where ) : "")
. "\n GROUP BY a.id"
. "\n LIMIT $pageNav->limitstart, $pageNav->limit"
;
$database->setQuery( $query );
$rows = $database->loadObjectList();
if ($database->getErrorNum()) {
echo $database->stderr();
return false;
}
// @RawSQLUse, trivial_implementation, SELECT, CONCEPT
$template = 'SELECT COUNT(s.userid) FROM #__session AS s WHERE s.userid = %d';
$n = count( $rows );
for ($i = 0; $i < $n; $i++) {
$row = &$rows[$i];
$query = sprintf( $template, intval( $row->id ) );
$database->setQuery( $query );
$row->loggedin = $database->loadResult();
}
// get list of Groups for dropdown filter
// @RawSQLUse, trivial_implementation, SELECT, CONCEPT
$query = "SELECT name AS value, name AS text"
. "\n FROM #__core_acl_aro_groups"
. "\n WHERE name != 'ROOT'"
. "\n AND name != 'USERS'"
;
$types[] = mosHTML::makeOption( '0', T_('- Select Group -') );
$database->setQuery( $query );
$types = array_merge( $types, $database->loadObjectList() );
$lists['type'] = mosHTML::selectList( $types, 'filter_type', 'class="inputbox" size="1" onchange="document.adminForm.submit( );"', 'value', 'text', "$filter_type" );
// get list of Log Status for dropdown filter
$logged[] = mosHTML::makeOption( 0, T_('- Select Log Status - '));
$logged[] = mosHTML::makeOption( 1, T_('Logged In'));
$logged[] = mosHTML::makeOption( 2, T_('Not Logged In'));
$lists['logged'] = mosHTML::selectList( $logged, 'filter_logged', 'class="inputbox" size="1" onchange="document.adminForm.submit( );"', 'value', 'text', "$filter_logged" );
HTML_users::showUsers( $rows, $pageNav, $search, $option, $lists );
}
function editUser( $uid='0', $option='users' ) {
global $database, $my, $acl;
$row = new mosUser( $database );
// load the row from the db table
$row->load( $uid );
if ( $uid ) {
// @RawSQLUse, trivial_implementation, SELECT, CONCEPT
$query = "SELECT * FROM #__contact_details WHERE user_id='". $row->id ."'";
$database->setQuery( $query );
$contact = $database->loadObjectList();
} else {
$contact = NULL;
$row->block = 0;
}
// check to ensure only super admins can edit super admin info
if ( ( $my->gid < 25 ) && ( $row->gid == 25 ) ) {
mosRedirect( 'index2.php?option=com_users', T_('You are not authorized to view this resource.') );
}
$my_group = strtolower( $acl->get_group_name( $row->gid, 'ARO' ) );
if ( $my_group == 'super administrator' ) {
$lists['gid'] = ''.T_('Super Administrator').'';
} else if ( $my->gid == 24 && $row->gid == 24 ) {
$lists['gid'] = ''.T_('Administrator').'';
} else {
// ensure user can't add group higher than themselves
$my_groups = $acl->get_object_groups( 'users', $my->id, 'ARO' );
if (is_array( $my_groups ) && count( $my_groups ) > 0) {
$ex_groups = $acl->get_group_children( $my_groups[0], 'ARO', 'RECURSE' );
if (!$ex_groups) $ex_groups = array();
} else {
$ex_groups = array();
}
$gtree = $acl->get_group_children_tree( null, 'USERS', false );
// remove users 'above' me
$i = 0;
while ($i < count( $gtree )) {
if (in_array( $gtree[$i]->value, $ex_groups )) {
array_splice( $gtree, $i, 1 );
} else {
$i++;
}
}
$lists['gid'] = mosHTML::selectList( $gtree, 'gid', 'size="10"', 'value', 'text', $row->gid );
}
// build the html select list
$lists['block'] = mosHTML::yesnoRadioList( 'block', 'class="inputbox" size="1"', $row->block );
// build the html select list
$lists['sendEmail'] = mosHTML::yesnoRadioList( 'sendEmail', 'class="inputbox" size="1"', $row->sendEmail );
HTML_users::edituser( $row, $contact, $lists, $option, $uid );
}
function saveUser( $option, $task ) {
global $database, $my, $acl;
global $mosConfig_live_site, $mosConfig_mailfrom, $mosConfig_fromname, $mosConfig_sitename;
if (!mosMainframe::validFormId($option,'edit',$my)) {
mosRedirect('index2.php', T_('Failed form hash'));
}
$row = new mosUser( $database );
if (!$row->bind( $_POST )) {
echo "\n";
exit();
}
// sanitize
$row->id = intval($row->id);
$row->gid = intval($row->gid);
$isNew = !$row->id;
$pwd = '';
// disallow super administrator blocking self
$super_gid = $acl->get_group_id('super administrator');
if ( $row->id == $my->id && ($my->gid == $super_gid) ) $row->block = 0;
// MD5 hash convert passwords
if ($isNew) {
// new user stuff
if ($row->password == '') {
$pwd = mosMakePassword();
$row->password = md5( $pwd );
} else {
$pwd = $row->password;
$row->password = md5( $row->password );
}
$row->registerDate = date( 'Y-m-d H:i:s' );
} else {
// existing user stuff
if ($row->password == '') {
// password set to null if empty
$row->password = null;
} else {
$pwd = $row->password;
$row->password = md5( $pwd );
}
}
// save usertype to usetype column
// @RawSQLUse, trivial_implementation, SELECT, CONCEPT
$query = "SELECT name"
. "\n FROM #__core_acl_aro_groups"
. "\n WHERE group_id = $row->gid"
;
$database->setQuery( $query );
$usertype = $database->loadResult();
$row->usertype = $usertype;
if (!$row->check()) {
echo "\n";
exit();
}
if (!$row->store()) {
echo "\n";
exit();
}
$row->checkin();
$loginfo = new mosLoginDetails($row->username, $pwd);
$mambothandler =& mosMambotHandler::getInstance();
$mambothandler->loadBotGroup('authenticator');
// update the ACL
if ( !$isNew ) {
if ($pwd) $mambothandler->trigger('userChange', array($loginfo));
if ($row->block) $mambothandler->trigger('userBlock', array($loginfo));
else $mambothandler->trigger('userUnblock', array($loginfo));
// @RawSQLUse, trivial_implementation, SELECT
$query = "SELECT aro_id FROM #__core_acl_aro WHERE value='$row->id'";
$database->setQuery( $query );
$aro_id = $database->loadResult();
// @RawSQLUse, trivial_implementation, UPDATE
$query = "UPDATE #__core_acl_groups_aro_map"
. "\n SET group_id = '$row->gid'"
. "\n WHERE aro_id = '$aro_id'"
;
$database->setQuery( $query );
$database->query() or die( $database->stderr() );
}
// for new users, email username and password
if ($isNew) {
$mambothandler->trigger('userRegister', array($loginfo));
$mambothandler->trigger('userActivate', array($loginfo));
if ($row->block) $mambothandler->trigger('userBlock', array($loginfo));
// @RawSQLUse, trivial_implementation, SELECT, CONCEPT
$query = "SELECT email FROM #__users WHERE id=$my->id";
$database->setQuery( $query );
$adminEmail = $database->loadResult();
$subject = T_('New User Details');
$message = sprintf ( T_('Hello %s,
You have been added as a user to %s by an Administrator.
This email contains your username and password to log into the %s
Username - %s
Password - %s
Please do not respond to this message as it is automatically generated and is for information purposes only'), $row->name, $mosConfig_sitename, $mosConfig_live_site, $row->username, $pwd );
if ($mosConfig_mailfrom != "" && $mosConfig_fromname != "") {
$adminName = $mosConfig_fromname;
$adminEmail = $mosConfig_mailfrom;
} else {
// @RawSQLUse, trivial_implementation, SELECT
$query = "SELECT name, email FROM #__users WHERE usertype='super administrator'";
$database->setQuery( $query );
$rows = $database->loadObjectList();
$row = $rows[0];
$adminName = $row->name;
$adminEmail = $row->email;
}
mosMail( $adminEmail, $adminName, $row->email, $subject, $message );
}
switch ( $task ) {
case 'apply':
$msg = sprintf(T_('Successfully Saved changes to User: %s'), $row->name);
mosRedirect( 'index2.php?option=com_users&task=editA&hidemainmenu=1&id='. $row->id, $msg );
case 'save':
default:
$msg = sprintf(T_('Successfully Saved User: %s'), $row->name);
mosRedirect( 'index2.php?option=com_users', $msg );
break;
}
}
/**
* Cancels an edit operation
* @param option component option to call
*/
function cancelUser( $option ) {
mosRedirect( 'index2.php?option='. $option .'&task=view' );
}
function removeUsers( $cid, $option ) {
global $database, $acl, $my;
if (!is_array( $cid ) || count( $cid ) < 1) {
$msg = T_("Select an item to delete");
mosRedirect( 'index2.php?option='. $option, $msg );
}
if ( in_array($my->id, $cid) ) {
$msg = T_("You cannot delete yourself!");
mosRedirect( 'index2.php?option='. $option, $msg );
}
// count super/admin gids within $cid
$super_gid = $acl->get_group_id('super administrator');
$admin_gid = $acl->get_group_id('administrator');
$cids = implode( ',', $cid );
$database->setQuery("SELECT COUNT(id) FROM #__users WHERE id IN ($cids) AND gid IN ($super_gid,$admin_gid)");
if ( $database->getErrorMsg() ) {
echo $database->stderr();
return;
}
$admin_count = (int) $database->loadResult();
// disallow deleting administrators / super administrators if not super administrator
if ( $admin_count && ($my->gid !== $super_gid) ) {
$msg = T_("You cannot delete another `Administrator` only `Super Administrators` have this power");
mosRedirect( 'index2.php?option='. $option, $msg );
}
if ( count( $cid ) ) {
$obj = new mosUser( $database );
$deleted = array();
foreach ($cid as $id) {
$obj->delete( $id );
$deleted[] = $id;
$msg = $obj->getError();
}
if (count($deleted)) {
$mambothandler =& mosMambotHandler::getInstance();
$mambothandler->loadBotGroup('authenticator');
$cids = implode(',', $deleted);
// @RawSQLUse, trivial_implementation, SELECT, CONCEPT
$query = "SELECT username FROM #__users WHERE id IN ($cids)";
$database->setQuery($query);
$results = $database->loadResultArray();
if ($results) foreach ($results as $result) {
$loginfo = new mosLoginDetails($result->username);
$mambothandler->trigger('userDelete', array($loginfo));
}
}
}
mosRedirect( 'index2.php?option='. $option, $msg );
}
/**
* Blocks or Unblocks one or more user records
* @param array An array of unique category id numbers
* @param integer 0 if unblock, 1 if blocking
* @param string The current url option
*/
function changeUserBlock( $cid=null, $block=1, $option ) {
global $database, $my, $acl;
if (count( $cid ) < 1) {
$action = $block ? T_('block') : T_('unblock');
echo "\n";
exit;
}
// super administrator can not block self
$super_gid = $acl->get_group_id('super administrator');
if ( in_array($my->id, $cid) && ($my->gid == $super_gid) ) {
$msg = T_("You cannot block yourself!");
mosRedirect( 'index2.php?option='. $option, $msg );
}
$cids = implode( ',', $cid );
// @RawSQLUse, trivial_implementation, SELECT, CONCEPT
$query = "UPDATE #__users SET block='$block' WHERE id IN ($cids)";
$database->setQuery( $query );
if (!$database->query()) {
echo "\n";
exit();
}
$mambothandler =& mosMambotHandler::getInstance();
$mambothandler->loadBotGroup('authenticator');
// @RawSQLUse, trivial_implementation, SELECT, CONCEPT
$query = "SELECT username FROM #__users WHERE id IN ($cids)";
$database->setQuery($query);
$results = $database->loadResultArray();
if ($results) foreach ($results as $result) {
$loginfo = new mosLoginDetails($result->username);
if ($block) $mambothandler->trigger('userBlock', array($loginfo));
else $mambothandler->trigger('userUnblock', array($loginfo));
}
mosRedirect( 'index2.php?option='. $option );
}
/**
* @param array An array of unique user id numbers
* @param string The current url option
*/
function logoutUser( $cid=null, $option, $task ) {
global $database, $my;
$cids = $cid;
if ( is_array( $cid ) ) {
if (count( $cid ) < 1) {
mosRedirect( 'index2.php?option='. $option, T_('Please select a user') );
}
$cids = implode( ',', $cid );
}
// @RawSQLUse, trivial_implementation, SELECT, CONCEPT
$query = "DELETE FROM #__session WHERE userid IN ($cids)";
$database->setQuery( $query );
$database->query();
switch ( $task ) {
case 'flogout':
mosRedirect( 'index2.php', $database->getErrorMsg() );
break;
default:
mosRedirect( 'index2.php?option='. $option, $database->getErrorMsg() );
break;
}
}
function is_email($email){
$rBool=false;
if(preg_match("/[\w\.\-]+@\w+[\w\.\-]*?\.\w{1,4}/", $email)){
$rBool=true;
}
return $rBool;
}
?>