DiscuzX/upload/source/include/spacecp/spacecp_doing.php

245 lines
7.0 KiB
PHP
Raw Normal View History

2016-12-15 08:20:54 -05:00
<?php
/**
* [Discuz!] (C)2001-2099 Comsenz Inc.
* This is NOT a freeware, use is subject to license terms
*
* $Id: spacecp_doing.php 33714 2013-08-07 01:42:26Z andyzheng $
*/
if(!defined('IN_DISCUZ')) {
exit('Access Denied');
}
$doid = empty($_GET['doid'])?0:intval($_GET['doid']);
$id = empty($_GET['id'])?0:intval($_GET['id']);
if(helper_access::check_module('doing')) {
if(submitcheck('addsubmit')) {
if(!checkperm('allowdoing')) {
showmessage('no_privilege_doing');
}
cknewuser();
$waittime = interval_check('post');
if($waittime > 0) {
showmessage('operating_too_fast', '', array('waittime' => $waittime));
}
$message = getstr($_POST['message'], 200, 0, 0, 1);
$message = preg_replace("/\<br.*?\>/i", ' ', $message);
if(strlen($message) < 1) {
showmessage('should_write_that');
}
$message = censor($message, NULL, TRUE);
if(is_array($message) && $message['message']) {
showmessage('do_success', dreferer(), array('message'=>$message['message']));
}
if(censormod($message) || $_G['group']['allowdoingmod']) {
$doing_status = 1;
} else {
$doing_status = 0;
}
$setarr = array(
'uid' => $_G['uid'],
'username' => $_G['username'],
'dateline' => $_G['timestamp'],
'message' => $message,
'ip' => $_G['clientip'],
'port' => $_G['remoteport'],
'status' => $doing_status,
);
$newdoid = C::t('home_doing')->insert($setarr, 1);
$setarr = array('recentnote'=>$message, 'spacenote'=>$message);
$credit = $experience = 0;
$extrasql = array('doings' => 1);
updatecreditbyaction('doing', 0, $extrasql);
C::t('common_member_field_home')->update($_G['uid'], $setarr);
if($_POST['to_signhtml'] && $_G['group']['maxsigsize']) {
if($_G['group']['maxsigsize'] < 200) {
$signhtml = getstr($_POST['message'], $_G['group']['maxsigsize'], 0, 0, 1);
$signhtml = preg_replace("/\<br.*?\>/i", ' ', $signhtml);
} else {
$signhtml = $message;
}
C::t('common_member_field_forum')->update($_G['uid'], array('sightml'=>$signhtml));
}
if(helper_access::check_module('feed') && ckprivacy('doing', 'feed') && $doing_status == '0') {
$feedarr = array(
'appid' => '',
'icon' => 'doing',
'uid' => $_G['uid'],
'username' => $_G['username'],
'dateline' => $_G['timestamp'],
'title_template' => lang('feed', 'feed_doing_title'),
'title_data' => serialize(array('message'=>$message)),
'body_template' => '',
'body_data' => '',
'id' => $newdoid,
'idtype' => 'doid'
);
C::t('home_feed')->insert($feedarr);
}
if($doing_status == '1') {
updatemoderate('doid', $newdoid);
manage_addnotify('verifydoing');
}
require_once libfile('function/stat');
updatestat('doing');
C::t('common_member_status')->update($_G['uid'], array('lastpost' => TIMESTAMP), 'UNBUFFERED');
if(!empty($_GET['fromcard'])) {
showmessage($message.lang('spacecp','card_update_doing'));
} else {
showmessage('do_success', dreferer(), array('doid' => $newdoid), $_GET['spacenote'] ? array('showmsg' => false):array('header' => true));
}
} elseif (submitcheck('commentsubmit')) {
if(!checkperm('allowdoing')) {
showmessage('no_privilege_doing_comment');
}
cknewuser();
$waittime = interval_check('post');
if($waittime > 0) {
showmessage('operating_too_fast', '', array('waittime' => $waittime));
}
$message = getstr($_POST['message'], 200, 0, 0, 1);
$message = preg_replace("/\<br.*?\>/i", ' ', $message);
if(strlen($message) < 1) {
showmessage('should_write_that');
}
$message = censor($message);
$updo = array();
if($id) {
$updo = C::t('home_docomment')->fetch($id);
}
if(empty($updo) && $doid) {
$updo = C::t('home_doing')->fetch($doid);
}
if(empty($updo)) {
showmessage('docomment_error');
} else {
if(isblacklist($updo['uid'])) {
showmessage('is_blacklist');
}
}
$updo['id'] = intval($updo['id']);
$updo['grade'] = intval($updo['grade']);
$setarr = array(
'doid' => $updo['doid'],
'upid' => $updo['id'],
'uid' => $_G['uid'],
'username' => $_G['username'],
'dateline' => $_G['timestamp'],
'message' => $message,
'ip' => $_G['clientip'],
'grade' => $updo['grade']+1
);
if($updo['grade'] >= 3) {
$setarr['upid'] = $updo['upid'];
}
$newid = C::t('home_docomment')->insert($setarr, true);
C::t('home_doing')->update_replynum_by_doid(1, $updo['doid']);
if($updo['uid'] != $_G['uid']) {
notification_add($updo['uid'], 'comment', 'doing_reply', array(
'url'=>"home.php?mod=space&uid=$updo[uid]&do=doing&view=me&doid=$updo[doid]&highlight=$newid",
'from_id'=>$updo['doid'],
'from_idtype'=>'doid'));
updatecreditbyaction('comment', 0, array(), 'doing'.$updo['doid']);
}
include_once libfile('function/stat');
updatestat('docomment');
C::t('common_member_status')->update($_G['uid'], array('lastpost' => TIMESTAMP), 'UNBUFFERED');
showmessage('do_success', dreferer(), array('doid' => $updo['doid']));
}
}
if($_GET['op'] == 'delete') {
if(submitcheck('deletesubmit')) {
if($id) {
$allowmanage = checkperm('managedoing');
if($value = C::t('home_docomment')->fetch($id)) {
$home_doing = C::t('home_doing')->fetch($value['doid']);
$value['duid'] = $home_doing['uid'];
if($allowmanage || $value['uid'] == $_G['uid'] || $value['duid'] == $_G['uid'] ) {
C::t('home_docomment')->update($id, array('uid' => 0, 'username' => '', 'message' => ''));
if($value['uid'] != $_G['uid'] && $value['duid'] != $_G['uid']) {
batchupdatecredit('comment', $value['uid'], array(), -1);
}
C::t('home_doing')->update_replynum_by_doid(-1, $updo['doid']);
}
}
} else {
require_once libfile('function/delete');
deletedoings(array($doid));
}
dheader('location: '.dreferer());
exit();
}
} elseif ($_GET['op'] == 'getcomment') {
include_once(DISCUZ_ROOT.'./source/class/lib/lib_tree.php');
$tree = new lib_tree();
$list = array();
$highlight = 0;
$count = 0;
if(empty($_GET['close'])) {
foreach(C::t('home_docomment')->fetch_all_by_doid($doid) as $value) {
$tree->setNode($value['id'], $value['upid'], $value);
$count++;
if($value['authorid'] == $space['uid']) $highlight = $value['id'];
}
}
if($count) {
$values = $tree->getChilds();
foreach ($values as $key => $vid) {
$one = $tree->getValue($vid);
$one['layer'] = $tree->getLayer($vid) * 2;
$one['style'] = "padding-left:{$one['layer']}em;";
if($one['layer'] > 0){
if($one['layer']%3 == 2) {
$one['class'] = ' dtls';
} else {
$one['class'] = ' dtll';
}
}
if($one['id'] == $highlight && $one['uid'] == $space['uid']) {
$one['style'] .= 'color:#F60;';
}
$list[] = $one;
}
}
} elseif ($_GET['op'] == 'spacenote') {
space_merge($space, 'field_home');
}
include template('home/spacecp_doing');
?>