2006-12-02 04:36:16 +00:00
|
|
|
<?php
|
|
|
|
/*
|
2008-12-20 20:19:05 +00:00
|
|
|
* e107 website system
|
|
|
|
*
|
2010-08-23 07:28:46 +00:00
|
|
|
* Copyright (C) 2008-2010 e107 Inc (e107.org)
|
2008-12-20 20:19:05 +00:00
|
|
|
* Released under the terms and conditions of the
|
|
|
|
* GNU General Public License (http://www.gnu.org/licenses/gpl.txt)
|
|
|
|
*
|
|
|
|
* User information
|
|
|
|
*
|
2010-08-23 07:28:46 +00:00
|
|
|
* $URL$
|
|
|
|
* $Id$
|
2008-12-20 20:19:05 +00:00
|
|
|
*
|
2010-08-23 07:28:46 +00:00
|
|
|
*/
|
2009-08-28 15:30:25 +00:00
|
|
|
//HCL define('PAGE_NAME', 'Members');
|
2008-12-20 20:19:05 +00:00
|
|
|
|
2006-12-02 04:36:16 +00:00
|
|
|
require_once("class2.php");
|
2009-08-28 15:30:25 +00:00
|
|
|
include_lan(e_LANGUAGEDIR.e_LANGUAGE.'/lan_'.e_PAGE);
|
2007-07-21 09:57:33 +00:00
|
|
|
|
|
|
|
// Next bit is to fool PM plugin into doing things
|
|
|
|
global $user;
|
|
|
|
$user['user_id'] = USERID;
|
|
|
|
|
2015-08-29 15:56:18 -07:00
|
|
|
// BC for v1.x template
|
|
|
|
$bcList = array(
|
|
|
|
'LAN_112' => 'LAN_USER_60',// Email Address
|
|
|
|
'LAN_138' => 'LAN_USER_52', // Registered members
|
|
|
|
'LAN_139' => 'LAN_USER_57', // Order
|
|
|
|
"LAN_142" => "LAN_USER_58", // Member
|
|
|
|
"LAN_145" => "LAN_USER_59", // Joined
|
|
|
|
"LAN_146" => "LAN_USER_66", // Visits since...
|
|
|
|
"LAN_147" => "LAN_USER_67", // Chatbox posts
|
|
|
|
"LAN_148" => "LAN_USER_68", // Comments posted
|
|
|
|
"LAN_149" => "LAN_USER_69", // Forum posts
|
|
|
|
"LAN_308" => "LAN_USER_63", // Real Name
|
|
|
|
"LAN_403" => "LAN_USER_64", // Site Stats
|
|
|
|
"LAN_404" => "LAN_USER_65", // Last visit
|
|
|
|
"LAN_419" => "LAN_USER_70", // Show
|
|
|
|
"LAN_425" => "LAN_USER_62" // Send Private Message
|
|
|
|
);
|
|
|
|
|
|
|
|
e107::getLanguage()->bcDefs($bcList);
|
|
|
|
|
|
|
|
|
|
|
|
|
2013-01-31 19:11:41 -08:00
|
|
|
if(e_AJAX_REQUEST)
|
|
|
|
{
|
2015-05-23 14:49:44 +02:00
|
|
|
if(vartrue($_POST['q']))
|
2013-01-31 19:11:41 -08:00
|
|
|
{
|
2015-05-23 14:49:44 +02:00
|
|
|
$q = filter_var($_POST['q'], FILTER_SANITIZE_STRING);
|
|
|
|
$l = vartrue($_POST['l']) ? intval($_POST['l']) : 10;
|
|
|
|
|
|
|
|
$db = e107::getDb();
|
|
|
|
|
|
|
|
if($db->select("user", "user_id,user_name", "user_name LIKE '". $q."%' ORDER BY user_name LIMIT " . $l))
|
2013-01-31 19:11:41 -08:00
|
|
|
{
|
2015-05-23 14:49:44 +02:00
|
|
|
$data = array();
|
|
|
|
while($row = $db->fetch())
|
2013-01-31 19:11:41 -08:00
|
|
|
{
|
2015-05-23 14:49:44 +02:00
|
|
|
$data[] = array(
|
|
|
|
'value' => $row['user_id'],
|
|
|
|
'label' => $row['user_name'],
|
|
|
|
);
|
2013-01-31 19:11:41 -08:00
|
|
|
}
|
2015-05-23 14:49:44 +02:00
|
|
|
|
2013-01-31 19:11:41 -08:00
|
|
|
if(count($data))
|
|
|
|
{
|
2015-05-23 14:49:44 +02:00
|
|
|
header('Content-type: application/json');
|
|
|
|
echo json_encode($data);
|
2013-01-31 19:11:41 -08:00
|
|
|
}
|
2015-05-23 14:49:44 +02:00
|
|
|
}
|
2013-01-31 19:11:41 -08:00
|
|
|
}
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-06-19 12:53:48 +00:00
|
|
|
// require_once(e_CORE."shortcodes/batch/user_shortcodes.php");
|
2006-12-02 04:36:16 +00:00
|
|
|
require_once(e_HANDLER."form_handler.php");
|
|
|
|
|
|
|
|
if (isset($_POST['delp']))
|
|
|
|
{
|
|
|
|
$tmp = explode(".", e_QUERY);
|
|
|
|
if ($tmp[0]=="self")
|
|
|
|
{
|
|
|
|
$tmp[1]=USERID;
|
|
|
|
}
|
|
|
|
if (USERID == $tmp[1] || (ADMIN && getperms("4")))
|
|
|
|
{
|
2013-04-19 22:50:41 -07:00
|
|
|
$sql->select("user", "user_sess", "user_id='". USERID."'");
|
2008-01-15 22:16:07 +00:00
|
|
|
$row = $sql->db_Fetch();
|
2013-04-19 22:50:41 -07:00
|
|
|
@unlink(e_AVATAR_UPLOAD.$row['user_sess']);
|
|
|
|
$sql->update("user", "user_sess='' WHERE user_id=".intval($tmp[1]));
|
2006-12-02 04:36:16 +00:00
|
|
|
header("location:".e_SELF."?id.".$tmp[1]);
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$qs = explode(".", e_QUERY);
|
|
|
|
$self_page =($qs[0] == 'id' && intval($qs[1]) == USERID);
|
|
|
|
|
2012-06-19 12:53:48 +00:00
|
|
|
|
2014-10-14 02:09:53 -07:00
|
|
|
$USER_TEMPLATE = e107::getCoreTemplate('user');
|
|
|
|
e107::scStyle($sc_style);
|
|
|
|
|
|
|
|
if(empty($USER_TEMPLATE)) // BC Fix for loading old templates.
|
|
|
|
{
|
2015-03-21 20:18:06 -07:00
|
|
|
e107::getMessage()->addDebug( "Using v1.x user template");
|
2016-01-21 16:22:07 -08:00
|
|
|
include(e107::coreTemplatePath('user')); //correct way to load a core template. (don't use 'include_once' in case it has already been loaded).
|
2014-10-14 02:09:53 -07:00
|
|
|
}
|
2015-03-21 20:18:06 -07:00
|
|
|
else
|
|
|
|
{
|
|
|
|
$USER_FULL_TEMPLATE = $USER_TEMPLATE['view'];
|
|
|
|
$USER_SHORT_TEMPLATE_START = $USER_TEMPLATE['list']['start'] ;
|
|
|
|
$USER_SHORT_TEMPLATE = $USER_TEMPLATE['list']['item'] ;
|
|
|
|
$USER_SHORT_TEMPLATE_END = $USER_TEMPLATE['list']['end'];
|
|
|
|
}
|
2012-06-19 12:53:48 +00:00
|
|
|
|
2014-10-14 02:09:53 -07:00
|
|
|
$TEMPLATE = str_replace('{USER_EMBED_USERPROFILE}','{USER_ADDONS}', $TEMPLATE); // BC Fix
|
|
|
|
|
|
|
|
$user_shortcodes = e107::getScBatch('user');
|
|
|
|
$user_shortcodes->wrapper('user/view');
|
|
|
|
|
2012-06-19 12:53:48 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
2006-12-02 04:36:16 +00:00
|
|
|
if (file_exists(THEME."user_template.php"))
|
|
|
|
{
|
|
|
|
require_once(THEME."user_template.php");
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
require_once(e_BASE.$THEMES_DIRECTORY."templates/user_template.php");
|
|
|
|
}
|
2012-06-19 12:53:48 +00:00
|
|
|
*/
|
|
|
|
|
2006-12-02 04:36:16 +00:00
|
|
|
$user_frm = new form;
|
|
|
|
require_once(HEADERF);
|
|
|
|
if (!defined("USER_WIDTH")){ define("USER_WIDTH","width:95%"); }
|
|
|
|
|
2007-12-19 20:34:47 +00:00
|
|
|
$full_perms = getperms("0") || check_class(varset($pref['memberlist_access'], 253)); // Controls display of info from other users
|
|
|
|
if (!$full_perms && !$self_page)
|
2006-12-02 04:36:16 +00:00
|
|
|
{
|
2015-08-29 15:56:18 -07:00
|
|
|
$ns->tablerender(LAN_ERROR, "<div style='text-align:center'>".LAN_USER_55."</div>");
|
2006-12-02 04:36:16 +00:00
|
|
|
require_once(FOOTERF);
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (isset($_POST['records']))
|
|
|
|
{
|
|
|
|
$records = intval($_POST['records']);
|
|
|
|
$order = ($_POST['order'] == 'ASC' ? 'ASC' : 'DESC');
|
|
|
|
$from = 0;
|
|
|
|
}
|
|
|
|
else if(!e_QUERY)
|
|
|
|
{
|
|
|
|
$records = 20;
|
|
|
|
$from = 0;
|
|
|
|
$order = "DESC";
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
if ($qs[0] == "self")
|
|
|
|
{
|
|
|
|
$id = USERID;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
if ($qs[0] == "id")
|
|
|
|
{
|
2008-06-05 19:57:52 +00:00
|
|
|
$id = intval($qs[1]);
|
2006-12-02 04:36:16 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
$qs = explode(".", e_QUERY);
|
|
|
|
$from = intval($qs[0]);
|
|
|
|
$records = intval($qs[1]);
|
|
|
|
$order = ($qs[2] == 'ASC' ? 'ASC' : 'DESC');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2012-12-08 20:22:05 +01:00
|
|
|
if (vartrue($records) > 30)
|
2006-12-02 04:36:16 +00:00
|
|
|
{
|
|
|
|
$records = 30;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (isset($id))
|
|
|
|
{
|
|
|
|
if ($id == 0)
|
|
|
|
{
|
2008-12-20 20:19:05 +00:00
|
|
|
$text = "<div style='text-align:center'>".LAN_USER_49." ".SITENAME."</div>";
|
2015-08-29 15:56:18 -07:00
|
|
|
$ns->tablerender(LAN_ERROR, $text);
|
2006-12-02 04:36:16 +00:00
|
|
|
require_once(FOOTERF);
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
$loop_uid = $id;
|
|
|
|
|
2015-02-15 16:07:27 -08:00
|
|
|
$ret = e107::getEvent()->trigger("showuser", $id);
|
|
|
|
$ret2 = e107::getEvent()->trigger('user_profile_display',$id);
|
|
|
|
|
|
|
|
if (!empty($ret) || !empty($ret2))
|
2006-12-02 04:36:16 +00:00
|
|
|
{
|
|
|
|
$text = "<div style='text-align:center'>".$ret."</div>";
|
2015-08-29 15:56:18 -07:00
|
|
|
$ns->tablerender(LAN_ERROR, $text);
|
2006-12-02 04:36:16 +00:00
|
|
|
require_once(FOOTERF);
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
2012-12-16 12:28:28 +01:00
|
|
|
if(vartrue($pref['profile_comments']))
|
2006-12-02 04:36:16 +00:00
|
|
|
{
|
|
|
|
require_once(e_HANDLER."comment_class.php");
|
2010-08-23 07:28:46 +00:00
|
|
|
$comment_edit_query = 'comment.user.'.$id;
|
2006-12-02 04:36:16 +00:00
|
|
|
}
|
|
|
|
|
2010-08-23 07:28:46 +00:00
|
|
|
if (isset($_POST['commentsubmit']) && $pref['profile_comments'])
|
2006-12-02 04:36:16 +00:00
|
|
|
{
|
2010-08-23 07:28:46 +00:00
|
|
|
$cobj = new comment;
|
|
|
|
$cobj->enter_comment($_POST['author_name'], $_POST['comment'], 'profile', $id, $pid, $_POST['subject']);
|
2006-12-02 04:36:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if($text = renderuser($id))
|
|
|
|
{
|
2008-12-20 20:19:05 +00:00
|
|
|
$ns->tablerender(LAN_USER_50, $text);
|
2006-12-02 04:36:16 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2008-12-20 20:19:05 +00:00
|
|
|
$text = "<div style='text-align:center'>".LAN_USER_51."</div>";
|
2015-08-29 15:56:18 -07:00
|
|
|
$ns->tablerender(LAN_ERROR, $text);
|
2006-12-02 04:36:16 +00:00
|
|
|
}
|
|
|
|
unset($text);
|
|
|
|
require_once(FOOTERF);
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
$users_total = $sql->db_Count("user","(*)", "WHERE user_ban = 0");
|
|
|
|
|
|
|
|
if (!$sql->db_Select("user", "*", "user_ban = 0 ORDER BY user_id $order LIMIT $from,$records"))
|
|
|
|
{
|
2008-12-20 20:19:05 +00:00
|
|
|
echo "<div style='text-align:center'><b>".LAN_USER_53."</b></div>";
|
2006-12-02 04:36:16 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
$userList = $sql->db_getList();
|
|
|
|
|
2008-04-01 19:58:41 +00:00
|
|
|
$text = $tp->parseTemplate($USER_SHORT_TEMPLATE_START, TRUE, $user_shortcodes);
|
2006-12-02 04:36:16 +00:00
|
|
|
foreach ($userList as $row)
|
|
|
|
{
|
2007-12-19 20:34:47 +00:00
|
|
|
$loop_uid = $row['user_id'];
|
2012-06-19 12:53:48 +00:00
|
|
|
|
2006-12-02 04:36:16 +00:00
|
|
|
$text .= renderuser($row, "short");
|
|
|
|
}
|
|
|
|
$text .= $tp->parseTemplate($USER_SHORT_TEMPLATE_END, TRUE, $user_shortcodes);
|
|
|
|
}
|
|
|
|
|
2008-12-20 20:19:05 +00:00
|
|
|
$ns->tablerender(LAN_USER_52, $text);
|
2006-12-02 04:36:16 +00:00
|
|
|
|
|
|
|
$parms = $users_total.",".$records.",".$from.",".e_SELF.'?[FROM].'.$records.".".$order;
|
2015-03-21 20:18:06 -07:00
|
|
|
echo "<div class='nextprev form-inline'> ".$tp->parseTemplate("{NEXTPREV={$parms}}")."</div>";
|
2006-12-02 04:36:16 +00:00
|
|
|
|
|
|
|
|
|
|
|
function renderuser($uid, $mode = "verbose")
|
|
|
|
{
|
2015-03-21 20:18:06 -07:00
|
|
|
global $pref, $sc_style, $user_shortcodes;
|
2014-10-14 02:09:53 -07:00
|
|
|
global $EXTENDED_START, $EXTENDED_TABLE, $EXTENDED_END, $USER_SHORT_TEMPLATE, $USER_FULL_TEMPLATE, $USER_TEMPLATE;
|
2006-12-02 04:36:16 +00:00
|
|
|
global $user;
|
|
|
|
|
2015-03-21 20:18:06 -07:00
|
|
|
$tp = e107::getParser();
|
|
|
|
|
2006-12-02 04:36:16 +00:00
|
|
|
if(is_array($uid))
|
|
|
|
{
|
|
|
|
$user = $uid;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2015-01-26 18:03:14 -08:00
|
|
|
if(!$user = e107::user($uid))
|
2006-12-02 04:36:16 +00:00
|
|
|
{
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
}
|
2012-06-19 12:53:48 +00:00
|
|
|
|
|
|
|
e107::getScBatch('user')->setVars($user);
|
2006-12-02 04:36:16 +00:00
|
|
|
|
|
|
|
if($mode == 'verbose')
|
|
|
|
{
|
2015-03-21 20:18:06 -07:00
|
|
|
return $tp->parseTemplate( $USER_FULL_TEMPLATE, TRUE, $user_shortcodes);
|
2006-12-02 04:36:16 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
return $tp->parseTemplate($USER_SHORT_TEMPLATE, TRUE, $user_shortcodes);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
require_once(FOOTERF);
|
2012-06-19 12:53:48 +00:00
|
|
|
?>
|