$db->query("UPDATE {$tablepre}debates SET affirmreplies=affirmreplies+1 WHERE tid='{$tid}'"); } elseif ($stand == 2) { $db->query("UPDATE {$tablepre}debates SET negareplies=negareplies+1 WHERE tid='{$tid}'"); } $db->query("INSERT INTO {$tablepre}debateposts (tid, pid, uid, dateline, stand, voters, voterids) VALUES ('{$tid}', '{$pid}', '{$discuz_uid}', '{$timestamp}', '{$stand}', '0', '')"); } $allowpostattach && ($attachnew || $attachdel || $special == 2 && $tradeaid) && updateattach(); $replymessage = 'post_reply_succeed'; if ($special == 2 && $allowposttrade && $thread['authorid'] == $discuz_uid && !empty($trade) && !empty($item_name)) { if ($tradetypes && $optiondata) { foreach ($optiondata as $optionid => $value) { $db->query("INSERT INTO {$tablepre}tradeoptionvars (sortid, pid, optionid, value)\r\n\t\t\t\t\tVALUES ('{$tradetypeid}', '{$pid}', '{$optionid}', '{$value}')"); } } require_once DISCUZ_ROOT . './include/trade.func.php'; trade_create(array('tid' => $tid, 'pid' => $pid, 'aid' => $tradeaid, 'typeid' => $tradetypeid, 'item_expiration' => $item_expiration, 'thread' => $thread, 'discuz_uid' => $discuz_uid, 'author' => $author, 'seller' => $seller, 'item_name' => $item_name, 'item_price' => $item_price, 'item_number' => $item_number, 'item_quality' => $item_quality, 'item_locus' => $item_locus, 'transport' => $transport, 'postage_mail' => $postage_mail, 'postage_express' => $postage_express, 'postage_ems' => $postage_ems, 'item_type' => $item_type, 'item_costprice' => $item_costprice, 'item_credit' => $item_credit, 'item_costcredit' => $item_costcredit)); $replymessage = 'trade_add_succeed'; } if ($specialextra) { @(include_once DISCUZ_ROOT . './plugins/' . $threadplugins[$specialextra]['module'] . '.class.php'); $classname = 'threadplugin_' . $specialextra; if (method_exists($classname, 'newreply_submit_end')) { $threadpluginclass = new $classname(); $threadpluginclass->newreply_submit_end($fid, $tid); } } $forum['threadcaches'] && deletethreadcaches($tid); if ($modnewreplies) { $db->query("UPDATE {$tablepre}forums SET todayposts=todayposts+1 WHERE fid='{$fid}'", 'UNBUFFERED'); showmessage('post_reply_mod_succeed', "forumdisplay.php?fid={$fid}"); } else {
} $tagarraynew = array(); foreach ($tagarray as $k => $tagname) { if (preg_match('/^([\\x7f-\\xff_-]|\\w){3,20}$/', $tagname)) { $tagarraynew[$k] = trim($tagname); } } $tagarray = $tagarraynew; unset($tagarraynew); } $pinvisible = $modnewreplies ? -2 : 0; $message = preg_replace('/\\[attachimg\\](\\d+)\\[\\/attachimg\\]/is', '[attach]\\1[/attach]', $message); $pid = insertpost(array('fid' => $_G['fid'], 'tid' => $tid, 'first' => '0', 'author' => $_G['username'], 'authorid' => $_G['uid'], 'subject' => $subject, 'dateline' => $_G['timestamp'], 'message' => $message, 'useip' => $_G['clientip'], 'invisible' => $pinvisible, 'anonymous' => $isanonymous, 'usesig' => $_G['gp_usesig'], 'htmlon' => $htmlon, 'bbcodeoff' => $bbcodeoff, 'smileyoff' => $smileyoff, 'parseurloff' => $parseurloff, 'attachment' => $attachment, 'tags' => implode(',', $tagarray))); ($_G['group']['allowpostattach'] || $_G['group']['allowpostimage']) && ($_G['gp_attachnew'] || $_G['gp_attachdel'] || $_G['gp_tradeaid']) && updateattach($postattachcredits, $tid, $pid, $_G['gp_attachnew'], $_G['gp_attachdel']); require_once libfile('function/trade'); trade_create(array('tid' => $tid, 'pid' => $pid, 'aid' => $_G['gp_tradeaid'], 'item_expiration' => $_G['gp_item_expiration'], 'thread' => $thread, 'discuz_uid' => $_G['uid'], 'author' => $author, 'seller' => empty($_G['gp_paymethod']) && $_G['gp_seller'] ? dhtmlspecialchars(trim($_G['gp_seller'])) : '', 'tenpayaccount' => $_G['gp_tenpay_account'], 'item_name' => $_G['gp_item_name'], 'item_price' => $_G['gp_item_price'], 'item_number' => $_G['gp_item_number'], 'item_quality' => $_G['gp_item_quality'], 'item_locus' => $_G['gp_item_locus'], 'transport' => $_G['gp_transport'], 'postage_mail' => $_G['gp_postage_mail'], 'postage_express' => $_G['gp_postage_express'], 'postage_ems' => $_G['gp_postage_ems'], 'item_type' => $_G['gp_item_type'], 'item_costprice' => $_G['gp_item_costprice'], 'item_credit' => $_G['gp_item_credit'], 'item_costcredit' => $_G['gp_item_costcredit'])); if (!empty($_G['gp_tradeaid'])) { DB::query("UPDATE " . DB::table('forum_attachment') . " SET tid='{$tid}', pid='{$pid}' WHERE aid='{$_G['gp_tradeaid']}' AND uid='{$_G['uid']}'"); } $param = array($_G['fid'], $tid, $pid); if ($modnewthreads) { DB::query("UPDATE " . DB::table('forum_forum') . " SET todayposts=todayposts+1 WHERE fid='{$_G['fid']}'", 'UNBUFFERED'); showmessage('post_newthread_mod_succeed', "forum.php?mod=forumdisplay&fid={$_G['fid']}", $param); } else { $feed = array(); if (!empty($_G['gp_addfeed']) && $_G['forum']['allowfeed'] && !$isanonymous) { $feed['icon'] = 'goods'; $feed['title_template'] = 'feed_thread_goods_title'; if ($_G['gp_item_price'] > 0) { if ($_G['setting']['creditstransextra'][5] != -1 && $_G['gp_item_credit']) { $feed['body_template'] = 'feed_thread_goods_message_1';
public function after_newreply() { if (!$this->pid) { return; } if ($this->param['special'] == 2 && $this->group['allowposttrade'] && $this->thread['authorid'] == $this->member['uid'] && !empty($_GET['trade']) && !empty($_GET['item_name'])) { $author = !$this->param['isanonymous'] ? $this->member['username'] : ''; require_once libfile('function/trade'); trade_create(array('tid' => $this->thread['tid'], 'pid' => $this->pid, 'aid' => $_GET['tradeaid'], 'item_expiration' => $_GET['item_expiration'], 'thread' => $this->thread, 'discuz_uid' => $this->member['uid'], 'author' => $author, 'seller' => empty($_GET['paymethod']) && $_GET['seller'] ? dhtmlspecialchars(trim($_GET['seller'])) : '', 'item_name' => $_GET['item_name'], 'item_price' => $_GET['item_price'], 'item_number' => $_GET['item_number'], 'item_quality' => $_GET['item_quality'], 'item_locus' => $_GET['item_locus'], 'transport' => $_GET['transport'], 'postage_mail' => $_GET['postage_mail'], 'postage_express' => $_GET['postage_express'], 'postage_ems' => $_GET['postage_ems'], 'item_type' => $_GET['item_type'], 'item_costprice' => $_GET['item_costprice'], 'item_credit' => $_GET['item_credit'], 'item_costcredit' => $_GET['item_costcredit'])); if (!empty($_GET['tradeaid'])) { convertunusedattach($_GET['tradeaid'], $this->thread['tid'], $this->pid); } } if (!$this->forum['allowfeed'] || !$_GET['addfeed']) { $this->after_replyfeed(); } }
private function replyPost($extract) { global $_G; extract($extract); // 获取主题和帖子要插入的状态信息 $topicStatus = ForumUtils::getPostSendStatus('topic', $_GET['platType']); $postStatus = ForumUtils::getPostSendStatus('post', $_GET['platType']); //$navtitle .= ' - '.$thread['subject'].' - '.$_G['forum']['name']; //copy from dz source/include/post/post_newreply.php require_once libfile('function/forumlist'); $isfirstpost = 0; $showthreadsorts = 0; $quotemessage = ''; if (!$_G['uid'] && !(!$_G['forum']['replyperm'] && $_G['group']['allowreply'] || $_G['forum']['replyperm'] && forumperm($_G['forum']['replyperm']))) { return WebUtils::makeErrorInfo_oldVersion($res, 'replyperm_login_nopermission', array('{login}' => 1)); } elseif (empty($_G['forum']['allowreply'])) { if (!$_G['forum']['replyperm'] && !$_G['group']['allowreply']) { return WebUtils::makeErrorInfo_oldVersion($res, 'replyperm_none_nopermission', array('{login}' => 1)); } elseif ($_G['forum']['replyperm'] && !forumperm($_G['forum']['replyperm'])) { $msg = mobcent_showmessagenoperm('replyperm', $_G['forum']['fid']); return WebUtils::makeErrorInfo_oldVersion($res, $msg['message'], $msg['params']); } } elseif ($_G['forum']['allowreply'] == -1) { return WebUtils::makeErrorInfo_oldVersion($res, 'post_forum_newreply_nopermission'); } if (!$_G['uid'] && ($_G['setting']['need_avatar'] || $_G['setting']['need_email'] || $_G['setting']['need_friendnum'])) { return WebUtils::makeErrorInfo_oldVersion($res, 'replyperm_login_nopermission', array('{login}' => 1)); } if (empty($thread)) { return WebUtils::makeErrorInfo_oldVersion($res, 'thread_nonexistence'); } elseif ($thread['price'] > 0 && $thread['special'] == 0 && !$_G['uid']) { return WebUtils::makeErrorInfo_oldVersion($res, 'group_nopermission', array('{grouptitle}' => $_G['group']['grouptitle'])); } checklowerlimit('reply', 0, 1, $_G['forum']['fid']); if ($_G['setting']['commentnumber'] && !empty($_GET['comment'])) { if (!submitcheck('commentsubmit', 0, $seccodecheck, $secqaacheck)) { return WebUtils::makeErrorInfo_oldVersion($res, 'forum_passwd'); showmessage('submitcheck_error', NULL); } $post = C::t('forum_post')->fetch('tid:' . $_G['tid'], $_GET['pid']); if (!$post) { return WebUtils::makeErrorInfo_oldVersion($res, 'post_nonexistence'); } if ($thread['closed'] && !$_G['forum']['ismoderator'] && !$thread['isgroup']) { return WebUtils::makeErrorInfo_oldVersion($res, 'post_thread_closed'); } elseif (!$thread['isgroup'] && ($post_autoclose = checkautoclose($thread))) { return WebUtils::makeErrorInfo_oldVersion($res, $post_autoclose, array('{autoclose}' => $_G['forum']['autoclose'])); } elseif (checkflood()) { return WebUtils::makeErrorInfo_oldVersion($res, 'post_flood_ctrl', array('{floodctrl}' => $_G['setting']['floodctrl'])); } elseif (checkmaxperhour('pid')) { return WebUtils::makeErrorInfo_oldVersion($res, 'post_flood_ctrl_posts_per_hour', array('posts_per_hour' => $_G['group']['maxpostsperhour'])); } $commentscore = ''; if (!empty($_GET['commentitem']) && !empty($_G['uid']) && $post['authorid'] != $_G['uid']) { foreach ($_GET['commentitem'] as $itemk => $itemv) { if ($itemv !== '') { $commentscore .= strip_tags(trim($itemk)) . ': <i>' . intval($itemv) . '</i> '; } } } $comment = cutstr(($commentscore ? $commentscore . '<br />' : '') . censor(trim(dhtmlspecialchars($_GET['message'])), '***'), 200, ' '); if (!$comment) { return WebUtils::makeErrorInfo_oldVersion($res, 'post_sm_isnull'); } C::t('forum_postcomment')->insert(array('tid' => $post['tid'], 'pid' => $post['pid'], 'author' => $_G['username'], 'authorid' => $_G['uid'], 'dateline' => TIMESTAMP, 'comment' => $comment, 'score' => $commentscore ? 1 : 0, 'useip' => $_G['clientip'])); C::t('forum_post')->update('tid:' . $_G['tid'], $_GET['pid'], array('comment' => 1)); if (!empty($_G['uid'])) { Mobcent::import(MOBCENT_APP_ROOT . '/components/discuz/source/function/function_post.php'); mobcent_updatepostcredits('+', $_G['uid'], 'reply', $_G['fid']); } if (!empty($_G['uid']) && $_G['uid'] != $post['authorid']) { notification_add($post['authorid'], 'pcomment', 'comment_add', array('tid' => $_G['tid'], 'pid' => $_GET['pid'], 'subject' => $thread['subject'], 'from_id' => $_G['tid'], 'from_idtype' => 'pcomment', 'commentmsg' => cutstr(str_replace(array('[b]', '[/b]', '[/color]'), '', preg_replace("/\\[color=([#\\w]+?)\\]/i", "", $comment)), 200))); } update_threadpartake($post['tid']); $pcid = C::t('forum_postcomment')->fetch_standpoint_by_pid($_GET['pid']); $pcid = $pcid['id']; if (!empty($_G['uid']) && $_GET['commentitem']) { $totalcomment = array(); foreach (C::t('forum_postcomment')->fetch_all_by_pid_score($_GET['pid'], 1) as $comment) { $comment['comment'] = addslashes($comment['comment']); if (strexists($comment['comment'], '<br />')) { if (preg_match_all("/([^:]+?):\\s<i>(\\d+)<\\/i>/", $comment['comment'], $a)) { foreach ($a[1] as $k => $itemk) { $totalcomment[trim($itemk)][] = $a[2][$k]; } } } } $totalv = ''; foreach ($totalcomment as $itemk => $itemv) { $totalv .= strip_tags(trim($itemk)) . ': <i>' . floatval(sprintf('%1.1f', array_sum($itemv) / count($itemv))) . '</i> '; } if ($pcid) { C::t('forum_postcomment')->update($pcid, array('comment' => $totalv, 'dateline' => TIMESTAMP + 1)); } else { C::t('forum_postcomment')->insert(array('tid' => $post['tid'], 'pid' => $post['pid'], 'author' => '', 'authorid' => '-1', 'dateline' => TIMESTAMP + 1, 'comment' => $totalv)); } } C::t('forum_postcache')->delete($post['pid']); return WebUtils::makeErrorInfo_oldVersion($res, 'comment_add_succeed'); //showmessage('comment_add_succeed', "forum.php?mod=viewthread&tid=$post[tid]&pid=$post[pid]&page=$_GET[page]&extra=$extra#pid$post[pid]", array('tid' => $post['tid'], 'pid' => $post['pid'])); } if ($special == 127) { $postinfo = C::t('forum_post')->fetch_threadpost_by_tid_invisible($_G['tid']); $sppos = strrpos($postinfo['message'], chr(0) . chr(0) . chr(0)); $specialextra = substr($postinfo['message'], $sppos + 3); } if (getstatus($thread['status'], 3)) { $rushinfo = C::t('forum_threadrush')->fetch($_G['tid']); if ($rushinfo['creditlimit'] != -996) { $checkcreditsvalue = $_G['setting']['creditstransextra'][11] ? getuserprofile('extcredits' . $_G['setting']['creditstransextra'][11]) : $_G['member']['credits']; if ($checkcreditsvalue < $rushinfo['creditlimit']) { $creditlimit_title = $_G['setting']['creditstransextra'][11] ? $_G['setting']['extcredits'][$_G['setting']['creditstransextra'][11]]['title'] : lang('forum/misc', 'credit_total'); return WebUtils::makeErrorInfo_oldVersion($res, 'forum_passwd'); showmessage('post_rushreply_creditlimit', '', array('creditlimit_title' => $creditlimit_title, 'creditlimit' => $rushinfo['creditlimit'])); } } // author:HanPengyu Date:2014/11/20 针对x3版本的抢楼帖回帖限制控制 if (isset($rushinfo['replylimit']) && $rushinfo['replylimit'] > 0) { $replycount = C::t('forum_post')->count_by_tid_invisible_authorid($thread['tid'], $_G['uid']); if ($replycount >= $rushinfo['replylimit']) { return WebUtils::makeErrorInfo_oldVersion($res, lang('message', 'noreply_replynum_error')); } } } if ($thread['closed'] && !$_G['forum']['ismoderator'] && !$thread['isgroup']) { return WebUtils::makeErrorInfo_oldVersion($res, 'post_thread_closed'); } elseif (!$thread['isgroup'] && ($post_autoclose = checkautoclose($thread))) { return WebUtils::makeErrorInfo_oldVersion($res, $post_autoclose, array('{autoclose}' => $_G['forum']['autoclose'])); } if (trim($subject) == '' && trim($message) == '' && $thread['special'] != 2) { return WebUtils::makeErrorInfo_oldVersion($res, 'post_sm_isnull'); } elseif ($post_invalid = checkpost($subject, $message, $special == 2 && $_G['group']['allowposttrade'])) { return WebUtils::makeErrorInfo_oldVersion($res, $post_invalid, array('{minpostsize}' => $_G['setting']['minpostsize']), array('{maxpostsize}' => $_G['setting']['maxpostsize'])); //showmessage($post_invalid, '', array('minpostsize' => $_G['setting']['minpostsize'], 'maxpostsize' => $_G['setting']['maxpostsize'])); } elseif (checkflood()) { return WebUtils::makeErrorInfo_oldVersion($res, 'post_flood_ctrl', array('{floodctrl}' => $_G['setting']['floodctrl'])); //showmessage('post_flood_ctrl', '', array('floodctrl' => $_G['setting']['floodctrl'])); } elseif (checkmaxperhour('pid')) { return WebUtils::makeErrorInfo_oldVersion($res, 'post_flood_ctrl_posts_per_hour', array('{posts_per_hour}' => $_G['group']['maxpostsperhour'])); //showmessage('post_flood_ctrl_posts_per_hour', '', array('posts_per_hour' => $_G['group']['maxpostsperhour'])); } $attentionon = empty($_GET['attention_add']) ? 0 : 1; $attentionoff = empty($attention_remove) ? 0 : 1; $heatthreadset = update_threadpartake($_G['tid'], true); if ($_G['group']['allowat']) { $atlist = $atlist_tmp = $ateduids = array(); preg_match_all("/@([^\r\n]*?)\\s/i", $message . ' ', $atlist_tmp); $atlist_tmp = array_slice(array_unique($atlist_tmp[1]), 0, $_G['group']['allowat']); $atnum = $maxselect = 0; foreach (C::t('home_notification')->fetch_all_by_authorid_fromid($_G['uid'], $_G['tid'], 'at') as $row) { $atnum++; $ateduids[$row[uid]] = $row['uid']; } $maxselect = $_G['group']['allowat'] - $atnum; if ($maxselect > 0 && !empty($atlist_tmp)) { if (empty($_G['setting']['at_anyone'])) { foreach (C::t('home_follow')->fetch_all_by_uid_fusername($_G['uid'], $atlist_tmp) as $row) { if (!in_array($row['followuid'], $ateduids)) { $atlist[$row[followuid]] = $row['fusername']; } if (count($atlist) == $maxselect) { break; } } if (count($atlist) < $maxselect) { $query = C::t('home_friend')->fetch_all_by_uid_username($_G['uid'], $atlist_tmp); foreach ($query as $row) { if (!in_array($row['followuid'], $ateduids)) { $atlist[$row[fuid]] = $row['fusername']; } } } } else { foreach (C::t('common_member')->fetch_all_by_username($atlist_tmp) as $row) { if (!in_array($row['uid'], $ateduids)) { $atlist[$row[uid]] = $row['username']; } if (count($atlist) == $maxselect) { break; } } } } if ($atlist) { foreach ($atlist as $atuid => $atusername) { $atsearch[] = "/@" . str_replace('/', '\\/', preg_quote($atusername)) . " /i"; $atreplace[] = "[url=home.php?mod=space&uid={$atuid}]@{$atusername}[/url] "; } $message = preg_replace($atsearch, $atreplace, $message . ' ', 1); } } $bbcodeoff = checkbbcodes($message, !empty($_GET['bbcodeoff'])); $smileyoff = checksmilies($message, !empty($_GET['smileyoff'])); $parseurloff = !empty($_GET['parseurloff']); $htmlon = $_G['group']['allowhtml'] && !empty($_GET['htmlon']) ? 1 : 0; $usesig = !empty($_GET['usesig']) && $_G['group']['maxsigsize'] ? 1 : 0; $isanonymous = $_G['group']['allowanonymous'] && !empty($_GET['isanonymous']) ? 1 : 0; $author = empty($isanonymous) ? $_G['username'] : ''; if ($thread['displayorder'] == -4) { $modnewreplies = 0; } $pinvisible = $modnewreplies ? -2 : ($thread['displayorder'] == -4 ? -3 : 0); $message = preg_replace('/\\[attachimg\\](\\d+)\\[\\/attachimg\\]/is', '[attach]\\1[/attach]', $message); $postcomment = in_array(2, $_G['setting']['allowpostcomment']) && $_G['group']['allowcommentreply'] && !$pinvisible && !empty($_GET['reppid']) && ($nauthorid != $_G['uid'] || $_G['setting']['commentpostself']) ? messagecutstr($message, 200, ' ') : ''; if (!empty($_GET['noticetrimstr'])) { $message = $_GET['noticetrimstr'] . "\n\n" . $message; $bbcodeoff = false; } $pid = insertpost(array('fid' => $_G['fid'], 'tid' => $_G['tid'], 'first' => '0', 'author' => $_G['username'], 'authorid' => $_G['uid'], 'subject' => $subject, 'dateline' => $_G['timestamp'], 'message' => $message, 'useip' => $_G['clientip'], 'invisible' => $pinvisible, 'anonymous' => $isanonymous, 'usesig' => $usesig, 'htmlon' => $htmlon, 'bbcodeoff' => $bbcodeoff, 'smileyoff' => $smileyoff, 'parseurloff' => $parseurloff, 'attachment' => '0', 'status' => (defined('IN_MOBILE') ? 8 : 0) | $postStatus)); if ($_G['group']['allowat'] && $atlist) { foreach ($atlist as $atuid => $atusername) { notification_add($atuid, 'at', 'at_message', array('from_id' => $_G['tid'], 'from_idtype' => 'at', 'buyerid' => $_G['uid'], 'buyer' => $_G['username'], 'tid' => $_G['tid'], 'subject' => $thread['subject'], 'pid' => $pid, 'message' => messagecutstr($message, 150))); } set_atlist_cookie(array_keys($atlist)); } $updatethreaddata = $heatthreadset ? $heatthreadset : array(); $postionid = C::t('forum_post')->fetch_maxposition_by_tid($thread['posttableid'], $_G['tid']); $updatethreaddata[] = DB::field('maxposition', $postionid); if (getstatus($thread['status'], 3) && $postionid) { $rushstopfloor = $rushinfo['stopfloor']; if ($rushstopfloor > 0 && $thread['closed'] == 0 && $postionid >= $rushstopfloor) { $updatethreaddata[] = 'closed=1'; } } useractionlog($_G['uid'], 'pid'); $nauthorid = 0; if (!empty($_GET['noticeauthor']) && !$isanonymous && !$modnewreplies) { list($ac, $nauthorid) = explode('|', authcode($_GET['noticeauthor'], 'DECODE')); if ($nauthorid != $_G['uid']) { if ($ac == 'q') { notification_add($nauthorid, 'post', 'reppost_noticeauthor', array('tid' => $thread['tid'], 'subject' => $thread['subject'], 'fid' => $_G['fid'], 'pid' => $pid, 'from_id' => $pid, 'from_idtype' => 'quote')); } elseif ($ac == 'r') { notification_add($nauthorid, 'post', 'reppost_noticeauthor', array('tid' => $thread['tid'], 'subject' => $thread['subject'], 'fid' => $_G['fid'], 'pid' => $pid, 'from_id' => $thread['tid'], 'from_idtype' => 'post')); } } if ($postcomment) { $rpid = intval($_GET['reppid']); if ($rpost = C::t('forum_post')->fetch('tid:' . $thread['tid'], $rpid)) { if (!$rpost['first']) { C::t('forum_postcomment')->insert(array('tid' => $thread['tid'], 'pid' => $rpid, 'rpid' => $pid, 'author' => $_G['username'], 'authorid' => $_G['uid'], 'dateline' => TIMESTAMP, 'comment' => $postcomment, 'score' => 0, 'useip' => $_G['clientip'])); C::t('forum_post')->update('tid:' . $thread['tid'], $rpid, array('comment' => 1)); C::t('forum_postcache')->delete($rpid); } } unset($postcomment); } } if ($thread['authorid'] != $_G['uid'] && getstatus($thread['status'], 6) && empty($_GET['noticeauthor']) && !$isanonymous && !$modnewreplies) { $thapost = C::t('forum_post')->fetch_threadpost_by_tid_invisible($_G['tid'], 0); notification_add($thapost['authorid'], 'post', 'reppost_noticeauthor', array('tid' => $thread['tid'], 'subject' => $thread['subject'], 'fid' => $_G['fid'], 'pid' => $pid, 'from_id' => $thread['tid'], 'from_idtype' => 'post')); // ios push UserUtils::pushIOSMessage($thread['authorid'], 'reply', $_G['username'] . WebUtils::t(' 回复了您的帖子 ') . $thread['subject']); } $feedid = 0; if (helper_access::check_module('follow') && !empty($_GET['adddynamic']) && !$isanonymous) { require_once libfile('function/discuzcode'); require_once libfile('function/followcode'); $feedcontent = C::t('forum_threadpreview')->count_by_tid($thread['tid']); $firstpost = C::t('forum_post')->fetch_threadpost_by_tid_invisible($thread['tid']); if (empty($feedcontent)) { $feedcontent = array('tid' => $thread['tid'], 'content' => followcode($firstpost['message'], $thread['tid'], $pid, 1000)); C::t('forum_threadpreview')->insert($feedcontent); C::t('forum_thread')->update_status_by_tid($thread['tid'], '512'); } else { C::t('forum_threadpreview')->update_relay_by_tid($thread['tid'], 1); } $notemsg = cutstr(followcode($message, $thread['tid'], $pid, 0, false), 140); $followfeed = array('uid' => $_G['uid'], 'username' => $_G['username'], 'tid' => $thread['tid'], 'note' => $notemsg, 'dateline' => TIMESTAMP); $feedid = C::t('home_follow_feed')->insert($followfeed, true); C::t('common_member_count')->increase($_G['uid'], array('feeds' => 1)); } if ($thread['replycredit'] > 0 && !$modnewreplies && $thread['authorid'] != $_G['uid'] && $_G['uid']) { $replycredit_rule = C::t('forum_replycredit')->fetch($_G['tid']); if (!empty($replycredit_rule['times'])) { $have_replycredit = C::t('common_credit_log')->count_by_uid_operation_relatedid($_G['uid'], 'RCA', $_G['tid']); if ($replycredit_rule['membertimes'] - $have_replycredit > 0 && $thread['replycredit'] - $replycredit_rule['extcredits'] >= 0) { $replycredit_rule['extcreditstype'] = $replycredit_rule['extcreditstype'] ? $replycredit_rule['extcreditstype'] : $_G['setting']['creditstransextra'][10]; if ($replycredit_rule['random'] > 0) { $rand = rand(1, 100); $rand_replycredit = $rand <= $replycredit_rule['random'] ? true : false; } else { $rand_replycredit = true; } if ($rand_replycredit) { updatemembercount($_G['uid'], array($replycredit_rule['extcreditstype'] => $replycredit_rule['extcredits']), 1, 'RCA', $_G[tid]); C::t('forum_post')->update('tid:' . $_G['tid'], $pid, array('replycredit' => $replycredit_rule['extcredits'])); $updatethreaddata[] = DB::field('replycredit', $thread['replycredit'] - $replycredit_rule['extcredits']); } } } } ($_G['group']['allowpostattach'] || $_G['group']['allowpostimage']) && ($_GET['attachnew'] || $special == 2 && $_GET['tradeaid']) && updateattach($thread['displayorder'] == -4 || $modnewreplies, $_G['tid'], $pid, $_GET['attachnew']); $replymessage = 'post_reply_succeed'; if ($special == 2 && $_G['group']['allowposttrade'] && $thread['authorid'] == $_G['uid'] && !empty($_GET['trade']) && !empty($_GET['item_name'])) { require_once libfile('function/trade'); trade_create(array('tid' => $_G['tid'], 'pid' => $pid, 'aid' => $_GET['tradeaid'], 'item_expiration' => $_GET['item_expiration'], 'thread' => $thread, 'discuz_uid' => $_G['uid'], 'author' => $author, 'seller' => empty($_GET['paymethod']) && $_GET['seller'] ? dhtmlspecialchars(trim($_GET['seller'])) : '', 'item_name' => $_GET['item_name'], 'item_price' => $_GET['item_price'], 'item_number' => $_GET['item_number'], 'item_quality' => $_GET['item_quality'], 'item_locus' => $_GET['item_locus'], 'transport' => $_GET['transport'], 'postage_mail' => $_GET['postage_mail'], 'postage_express' => $_GET['postage_express'], 'postage_ems' => $_GET['postage_ems'], 'item_type' => $_GET['item_type'], 'item_costprice' => $_GET['item_costprice'], 'item_credit' => $_GET['item_credit'], 'item_costcredit' => $_GET['item_costcredit'])); $replymessage = 'trade_add_succeed'; if (!empty($_GET['tradeaid'])) { convertunusedattach($_GET['tradeaid'], $_G['tid'], $pid); } } $_G['forum']['threadcaches'] && deletethreadcaches($_G['tid']); include_once libfile('function/stat'); updatestat($thread['isgroup'] ? 'grouppost' : 'post'); $param = array('fid' => $_G['fid'], 'tid' => $_G['tid'], 'pid' => $pid, 'from' => $_GET['from'], 'sechash' => !empty($_GET['sechash']) ? $_GET['sechash'] : ''); if ($feedid) { $param['feedid'] = $feedid; } dsetcookie('clearUserdata', 'forum'); if ($modnewreplies) { updatemoderate('pid', $pid); unset($param['pid']); if ($updatethreaddata) { C::t('forum_thread')->update($_G['tid'], $updatethreaddata, false, false, 0, true); } C::t('forum_forum')->update_forum_counter($_G['fid'], 0, 0, 1, 1); $url = empty($_POST['portal_referer']) ? "forum.php?mod=viewthread&tid={$thread[tid]}" : $_POST['portal_referer']; manage_addnotify('verifypost'); // if(!isset($inspacecpshare)) { return WebUtils::makeErrorInfo_oldVersion($res, 'post_reply_mod_succeed', array('noError' => 1)); //showmessage('post_reply_mod_succeed', $url, $param); // } } else { $fieldarr = array('lastposter' => array($author), 'replies' => 1); if ($thread['lastpost'] < $_G['timestamp']) { $fieldarr['lastpost'] = array($_G['timestamp']); } $row = C::t('forum_threadaddviews')->fetch($_G['tid']); if (!empty($row)) { C::t('forum_threadaddviews')->update($_G['tid'], array('addviews' => 0)); $fieldarr['views'] = $row['addviews']; } $updatethreaddata = array_merge($updatethreaddata, C::t('forum_thread')->increase($_G['tid'], $fieldarr, false, 0, true)); if ($thread['displayorder'] != -4) { Mobcent::import(MOBCENT_APP_ROOT . '/components/discuz/source/function/function_post.php'); mobcent_updatepostcredits('+', $_G['uid'], 'reply', $_G['fid']); if ($_G['forum']['status'] == 3) { if ($_G['forum']['closed'] > 1) { C::t('forum_thread')->increase($_G['forum']['closed'], $fieldarr, true); } C::t('forum_groupuser')->update_counter_for_user($_G['uid'], $_G['fid'], 0, 1); C::t('forum_forumfield')->update($_G['fid'], array('lastupdate' => TIMESTAMP)); require_once libfile('function/grouplog'); updategroupcreditlog($_G['fid'], $_G['uid']); } $lastpost = "{$thread['tid']}\t{$thread['subject']}\t{$_G['timestamp']}\t{$author}"; C::t('forum_forum')->update($_G['fid'], array('lastpost' => $lastpost)); C::t('forum_forum')->update_forum_counter($_G['fid'], 0, 1, 1); if ($_G['forum']['type'] == 'sub') { C::t('forum_forum')->update($_G['forum']['fup'], array('lastpost' => $lastpost)); } } $page = getstatus($thread['status'], 4) ? 1 : @ceil(($thread['special'] ? $thread['replies'] + 1 : $thread['replies'] + 2) / $_G['ppp']); if ($updatethreaddata) { C::t('forum_thread')->update($_G['tid'], $updatethreaddata, false, false, 0, true); } /* if(!isset($inspacecpshare)) { // showmessage($replymessage, $url, $param); } */ } if ($jsonInfo['isShowPostion']) { $data = DB::query('INSERT INTO %t VALUES(poi_id,%f,%f,%d,%d,%s)', array('home_surrounding_user', $jsonInfo['longitude'], $jsonInfo['latitude'], $pid, 2, (string) $jsonInfo['location'])); } /* //客户端回复帖子积分入库 $temp = DB::fetch_first('SELECT extcredits3 FROM '.DB::table('common_credit_rule').' WHERE rid =%d',array(2)); $extcredits3 = DB::fetch_first('SELECT extcredits3 FROM '.DB::table('common_member_count').' WHERE uid = %d',array($_G['uid'])); $temp = $extcredits3['extcredits3'] + $temp['extcredits3']; DB::query('UPDATE '.DB::table('common_member_count').' set extcredits3 = %d WHERE uid = %d',array($temp,$_G['uid'])); */ // return array('rs'=>1,'errcode'=>WebUtils::t('发贴成功')); return $this->makeErrorInfo($res, 'mobcent_post_reply_succeed', array('noError' => 1)); }
if (!$ec_account) { showmessage('supe_imported_trade_notallowed'); } elseif (!$allowposttrade) { showmessage('supe_imported_trade_forum_notallowed'); } } $displayorder = $modnewthreads ? '-2' : '0'; $db->query("INSERT INTO {$tablepre}threads (fid, readperm, price, iconid, typeid, author, authorid, subject, dateline, lastpost, lastposter, displayorder, digest, blog, special, attachment, moderated, itemid)\r\n\t\tVALUES ('{$fid}', '0', '0', '{$iconid}', '{$typeid}', '{$item['username']}', '{$item['uid']}', '{$subject}', '{$item['dateline']}', '{$timestamp}', '{$item['username']}', '{$displayorder}', '0', '0', '{$special}', '0', '0', '{$itemid}')"); $tid = $db->insert_id(); if ($special == 2) { require_once DISCUZ_ROOT . './api/alipayapi.php'; $trade['tid'] = $tid; $trade['thread'] = $thread; $trade['discuz_uid'] = $discuz_uid; $trade['author'] = $discuz_user; trade_create($trade); } unset($displayorder, $trade); $pinvisible = $modnewthreads ? -2 : 0; $htmlon = $forum['allowhtml'] || $allowhtml ? 1 : 0; $db->query("INSERT INTO {$tablepre}posts (fid, tid, first, author, authorid, subject, dateline, message, useip, invisible, usesig, htmlon, bbcodeoff, smileyoff, parseurloff, attachment)\r\n\t\tVALUES ('{$fid}', '{$tid}', '1', '{$item['username']}', '{$item['uid']}', '{$subject}', '{$item['dateline']}', '{$message}', '{$onlineip}', '{$pinvisible}', '1', '{$htmlon}', '0', '1', '0', '0')"); $pid = $db->insert_id(); $postuids = $lastreply = $reply = array(); $replypost = 0; if ($item['replynum'] == 0) { if (!$modnewthreads) { updatepostcredits('+', $discuz_uid, $postcredits); $lastpost = "{$tid}\t{$subject}\t{$timestamp}\t{$item['username']}"; $db->query("UPDATE {$tablepre}forums SET lastpost='{$lastpost}', threads=threads+1, posts=posts+1, todayposts=todayposts+1 WHERE fid='{$fid}'", 'UNBUFFERED'); if ($forum['type'] == 'sub') { $db->query("UPDATE {$tablepre}forums SET lastpost='{$lastpost}' WHERE fid='{$forum['fup']}'", 'UNBUFFERED');