1
0
mirror of https://github.com/e107inc/e107.git synced 2025-10-26 11:18:09 +01:00
Files
php-e107/userposts.php
2021-01-19 18:52:56 -08:00

317 lines
9.6 KiB
PHP

<?php
/*
* e107 website system
*
* Copyright (C) 2008-2011 e107 Inc (e107.org)
* Released under the terms and conditions of the
* GNU General Public License (http://www.gnu.org/licenses/gpl.txt)
*
* User posts page
*
* $URL$
* $Id$
*
*/
require_once('class2.php');
e107::coreLan('userposts');
require_once(e_HANDLER.'comment_class.php');
$cobj = new comment();
$e107 = e107::getInstance();
$sql = e107::getDb();
$pref = e107::getPref();
$tp = e107::getParser();
$ns = e107::getRender();
require_once(HEADERF);
$action = 'exit';
if (e_QUERY)
{
$tmp = explode('.', e_QUERY);
$from = intval($tmp[0]); // Always defined
$action = varset($tmp[1],'exit');
if (!isset($tmp[2])) $action = 'exit';
$id = intval(varset($tmp[2],0));
if ($id <= 0) $action = 'exit';
if (($id != USERID) && !check_class(varset($pref['memberlist_access'], 253))) $action = 'exit';
unset($tmp);
}
if(isset($_POST['fsearch']))
{
$action = 'forums';
}
if ($action == 'exit')
{
e107::redirect();
exit;
}
if ($action == "comments")
{
if($id == e107::getUser()->getId())
{
$user_name = USERNAME;
}
else
{
$user_name = e107::getSystemUser($id, false)->getName(LAN_ANONYMOUS);
}
// new template engine - override in THEME/templates/userposts_template.php
$USERPOSTS_TEMPLATE = e107::getCoreTemplate('userposts');
$sql2 = e107::getDb('sql2');
if($user_name)
{
$ccaption = str_replace('[x]', $user_name, UP_LAN_1);
$ctotal = e107::getSystemUser($id, false)->getValue('comments', 0); // user_* getter shorthand
$data = $cobj->getCommentData(10, $from, 'comment_author_id ='.$id);
}
else // posts by IP currently disabled (see Query filtering - top of the page)
{
e107::redirect();
exit;
/*$dip = $id;
if (strlen($dip) == 8)
{ // Legacy decode (IPV4 address as it used to be stored - hex string)
$hexip = explode('.', chunk_split($dip, 2, '.'));
$dip = hexdec($hexip[0]). '.' . hexdec($hexip[1]) . '.' . hexdec($hexip[2]) . '.' . hexdec($hexip[3]);
}
$ccaption = UP_LAN_1.$dip;
$data = $cobj->getCommentData($amount='10', $from, "comment_ip = '".$id."'");
$data = $cobj->getCommentData(10, $from, 'comment_ip ='.$tp->toDB($user_ip));*/
}
$ctext = '';
if(empty($data) || !is_array($data))
{
$ctext = "<span class='mediumtext'>".UP_LAN_7."</span>";
}
else
{
$userposts_comments_table_string = '';
foreach($data as $row)
{
$userposts_comments_table_string .= parse_userposts_comments_table($row, $USERPOSTS_TEMPLATE['comments_table']);
}
$parms = $ctotal.",10,".$from.",".e_REQUEST_SELF."?[FROM].comments.".$id;
$nextprev = $ctotal ? $tp->parseTemplate("{NEXTPREV={$parms}}") : '';
if($nextprev) $nextprev = str_replace('{USERPOSTS_NEXTPREV}', $nextprev, $USERPOSTS_TEMPLATE['np_table']);
$vars = new e_vars(array(
'NEXTPREV' => $nextprev
));
// preg_replace("/\{(.*?)\}/e", '$\1', $USERPOSTS_TEMPLATE['comments_table_start']);
$userposts_comments_table_start = $tp->simpleParse($USERPOSTS_TEMPLATE['comments_table_start'], $vars);
// preg_replace("/\{(.*?)\}/e", '$\1', $USERPOSTS_TEMPLATE['comments_table_end'])
$userposts_comments_table_end = $tp->simpleParse($USERPOSTS_TEMPLATE['comments_table_end'], $vars);
$ctext .= $userposts_comments_table_start.$userposts_comments_table_string.$userposts_comments_table_end;
}
$ns->tablerender($ccaption, $ctext);
}
elseif ($action == 'forums')
{
require_once (e_PLUGIN.'forum/forum_class.php');
$forum = new e107forum();
$forumList = implode(',', $forum->getForumPermList('view'));
/*if(is_numeric($id))
{
$uinfo = e107::user($id);
$fcaption = UP_LAN_0.' '.$uinfo['user_name'];
}
else
{
$user_name = 0;
}*/
if($id == e107::getUser()->getId())
{
$user_name = USERNAME;
}
else
{
$user_name = e107::getSystemUser($id, false)->getName(LAN_ANONYMOUS);
}
if(!$user_name)
{
e107::redirect();
exit;
}
// $fcaption = UP_LAN_0.' '.$user_name;
$fcaption = str_replace('[x]', $user_name, UP_LAN_0);
/*
if (!$USERPOSTS_FORUM_TABLE)
{
if (file_exists(THEME.'userposts_template.php'))
{
require_once(THEME.'userposts_template.php');
}
else
{
require_once(e_BASE.$THEMES_DIRECTORY.'templates/userposts_template.php');
}
}*/
// new template engine - override in THEME/templates/userposts_template.php
$USERPOSTS_TEMPLATE = e107::getCoreTemplate('userposts');
$s_info = '';
$_POST['f_query'] = trim(varset($_POST['f_query']));
if ($_POST['f_query'] !== '')
{
$f_query = $tp->toDB($_POST['f_query']);
$s_info = "AND (t.thread_name REGEXP('".$f_query."') OR p.post_entry REGEXP('".$f_query."'))";
$fcaption = UP_LAN_12.' '.$user_name;
}
$qry = "
SELECT SQL_CALC_FOUND_ROWS p.*, t.*, f.* FROM `#forum_post` AS p
LEFT JOIN `#forum_thread` AS t ON t.thread_id = p.post_thread
LEFT JOIN `#forum` AS f ON f.forum_id = p.post_forum
WHERE p.post_user = {$id}
AND p.post_forum IN ({$forumList})
{$s_info}
ORDER BY p.post_datestamp DESC LIMIT {$from}, 10
";
$debug = deftrue('e_DEBUG');
$sqlp = e107::getDb('posts');
if (!$sqlp->gen($qry))
{
$ftext .= "<span class='mediumtext'>".UP_LAN_8.'</span>';
}
else
{
$gen = e107::getDateConvert();
$vars = new e_vars();
$userposts_forum_table_string = '';
while($row = $sqlp->fetch())
{
if(empty($row))
{
continue;
}
$datestamp = $gen->convert_date($row['post_datestamp'], 'short');
if ($row['thread_datestamp'] == $row['post_datestamp'])
{
$vars->USERPOSTS_FORUM_TOPIC_PRE = UP_LAN_2.': ';
}
else
{
$vars->USERPOSTS_FORUM_TOPIC_PRE = UP_LAN_15.': ';
}
$row['forum_sef'] = $forum->getForumSef($row);
$row['thread_sef'] = $forum->getThreadSef($row);
$forumUrl = e107::url('forum', 'forum', $row);
$postNum = $forum->postGetPostNum($row['post_thread'], $row['post_id']);
$postPage = ceil($postNum / $forum->prefs->get('postspage'));
$postUrl = e107::url('forum', 'topic', $row, array('query' => array('p' => $postPage), 'fragment' => 'post-' . $row['post_id']));
$vars->USERPOSTS_FORUM_ICON = "<img src='".e_PLUGIN."forum/images/".IMODE."/new_small.png' alt='' />";
$vars->USERPOSTS_FORUM_TOPIC_HREF_PRE = "<a href='".$postUrl."'>"; //$e107->url->getUrl('forum', 'thread', "func=post&id={$row['post_id']}")
$vars->USERPOSTS_FORUM_TOPIC = $tp->toHTML($row['thread_name'], true, 'USER_BODY', $id);
$vars->USERPOSTS_FORUM_NAME_HREF_PRE = "<a href='".$forumUrl."'>"; //$e107->url->getUrl('forum', 'forum', "func=view&id={$row['post_forum']}")
$vars->USERPOSTS_FORUM_NAME = $tp->toHTML($row['forum_name'], true, 'USER_BODY', $id);
$vars->USERPOSTS_FORUM_THREAD = $tp->toHTML($row['post_entry'], true, 'USER_BODY', $id);
$vars->USERPOSTS_FORUM_DATESTAMP = UP_LAN_11." ".$datestamp;
//$userposts_forum_table_string .= preg_replace("/\{(.*?)\}/e", '$\1', $USERPOSTS_FORUM_TABLE);
$userposts_forum_table_string .= $tp->simpleParse($USERPOSTS_TEMPLATE['forum_table'], $vars);
}
$vars->emptyVars();
$ftotal = $sqlp->foundRows();
$parms = $ftotal.",10,".$from.",".e_REQUEST_SELF."?[FROM].forums.".$id;
$vars->NEXTPREV = $ftotal ? $tp->parseTemplate("{NEXTPREV={$parms}}") : '';
if($vars->NEXTPREV) $vars->NEXTPREV = str_replace('{USERPOSTS_NEXTPREV}', $vars->NEXTPREV, $USERPOSTS_TEMPLATE['np_table']);
$vars->USERPOSTS_FORUM_SEARCH_VALUE = htmlspecialchars($_POST['f_query'], ENT_QUOTES, CHARSET);
$vars->USERPOSTS_FORUM_SEARCH_FIELD = "<input class='tbox input' type='text' name='f_query' size='20' value='{$vars->USERPOSTS_FORUM_SEARCH_VALUE}' maxlength='50' />";
$vars->USERPOSTS_FORUM_SEARCH_BUTTON = "<input class='btn btn-default btn-secondary button' type='submit' name='fsearch' value='".UP_LAN_12."' />";
$vars->USERPOSTS_FORUM_SEARCH = "<input class='tbox' type='text' name='f_query' size='20' value='{$vars->USERPOSTS_FORUM_SEARCH_VALUE}' maxlength='50' /> <input class='btn btn-default btn-secondary button' type='submit' name='fsearch' value='".UP_LAN_12."' />";
// $userposts_forum_table_start = preg_replace("/\{(.*?)\}/e", '$\1', $USERPOSTS_FORUM_TABLE_START);
$userposts_forum_table_start = $tp->simpleParse($USERPOSTS_TEMPLATE['forum_table_start'], $vars);
//$userposts_forum_table_end = preg_replace("/\{(.*?)\}/e", '$\1', $USERPOSTS_FORUM_TABLE_END);
$userposts_forum_table_end = $tp->simpleParse($USERPOSTS_TEMPLATE['forum_table_end'], $vars);
$ftext = $userposts_forum_table_start.$userposts_forum_table_string.$userposts_forum_table_end;
}
$ns->tablerender($fcaption, $ftext);
/*$ftotal = $e107->sql->total_results;
$parms = $ftotal.",10,".$from.",".e_SELF."?[FROM].forums.".$id;
$USERPOSTS_NEXTPREV = $tp->parseTemplate("{NEXTPREV={$parms}}");
echo preg_replace("/\{(.*?)\}/e", '$\1', $USERPOSTS_NP_TABLE);*/
}
else
{
e107::redirect();
exit;
}
require_once(FOOTERF);
function parse_userposts_comments_table($row, $template)
{
// global $USERPOSTS_COMMENTS_TABLE, $pref, $gen, $tp, $id, $sql2, $comment_files;
$gen = e107::getDateConvert();
$datestamp = $gen->convert_date($row['comment_datestamp'], "short");
$bullet = '';
if(defined('BULLET'))
{
$bullet = '<img src="'.THEME_ABS.'images/'.BULLET.'" alt="" class="icon" />';
}
elseif(file_exists(THEME.'images/bullet2.gif'))
{
$bullet = '<img src="'.THEME_ABS.'images/bullet2.gif" alt="" class="icon" />';
}
$vars = new e_vars();
$vars->USERPOSTS_COMMENTS_ICON = $bullet;
$vars->USERPOSTS_COMMENTS_DATESTAMP = UP_LAN_11." ".$datestamp;
$vars->USERPOSTS_COMMENTS_HEADING = $row['comment_title'];
$vars->USERPOSTS_COMMENTS_COMMENT = $row['comment_comment'];
$vars->USERPOSTS_COMMENTS_HREF_PRE = "<a href='".$row['comment_url']."'>";
$vars->USERPOSTS_COMMENTS_TYPE = $row['comment_type'];
//return(preg_replace("/\{(.*?)\}/e", '$\1', $USERPOSTS_COMMENTS_TABLE));
return e107::getParser()->simpleParse($template, $vars);
}