/**
  * Manage spam requests
  *
  * @access	private
  * @return	void		[Outputs to screen]
  */
 private function _unSpam()
 {
     //-----------------------------------------
     // INIT
     //-----------------------------------------
     $ids = array();
     //-----------------------------------------
     // GET checkboxes
     //-----------------------------------------
     foreach ($this->request as $k => $v) {
         if (preg_match("/^mid_(\\d+)\$/", $k, $match)) {
             if ($v) {
                 $ids[] = $match[1];
             }
         }
     }
     $ids = IPSLib::cleanIntArray($ids);
     //-----------------------------------------
     // Check
     //-----------------------------------------
     if (count($ids) < 1) {
         $this->registry->output->showError($this->lang->words['t_nomemunspammed'], 11248);
     }
     //-----------------------------------------
     // Unspam
     //-----------------------------------------
     if ($this->request['type'] == 'unspam' or $this->request['type'] == 'unspam_posts') {
         try {
             foreach ($ids as $i) {
                 IPSMember::save($i, array('core' => array('bw_is_spammer' => 0, 'restrict_post' => 0, 'members_disable_pm' => 0)));
             }
         } catch (Exception $error) {
             $this->registry->output->showError($error->getMessage(), 11247);
         }
         if ($this->request['type'] == 'unspam_posts') {
             /* Toggle their content */
             require IPSLib::getAppDir('forums') . '/sources/classes/moderate.php';
             $modLibrary = new moderatorLibrary($this->registry);
             foreach ($ids as $id) {
                 $modLibrary->toggleApproveMemberContent($id, TRUE, 'all', intval($this->settings['spm_post_days']) * 24);
             }
         }
         ipsRegistry::getClass('adminFunctions')->saveAdminLog(count($ids) . $this->lang->words['t_memunspammed']);
         $this->registry->output->global_message = count($ids) . $this->lang->words['t_memunspammed'];
         $this->_viewQueue('spam');
         return;
     } else {
         if ($this->request['type'] == 'ban' or $this->request['type'] == 'ban_blacklist') {
             try {
                 foreach ($ids as $i) {
                     IPSMember::save($i, array('core' => array('bw_is_spammer' => 0, 'member_banned' => 1)));
                 }
             } catch (Exception $error) {
                 $this->registry->output->showError($error->getMessage(), 11247);
             }
             if ($this->request['type'] == 'ban_blacklist') {
                 /* Load Members */
                 $members = IPSMember::load($ids);
                 $ips = array();
                 $email = array();
                 $ban = array('ip' => array(), 'email' => array());
                 if (is_array($members) and count($members)) {
                     foreach ($members as $id => $data) {
                         $ips[] = $data['ip_address'];
                         $email[] = $data['email'];
                     }
                     if (count($ips)) {
                         /* IPS: Check for duplicate */
                         $this->DB->build(array('select' => '*', 'from' => 'banfilters', 'where' => "ban_content IN ('" . implode("','", $ips) . "') and ban_type='ip'"));
                         $this->DB->execute();
                         while ($row = $this->DB->fetch()) {
                             $ban['ip'][] = $row['ban_content'];
                         }
                         /* Now insert.. */
                         foreach ($ips as $i) {
                             if (!in_array($i, $ban['ip'])) {
                                 /* Insert the new ban filter */
                                 $this->DB->insert('banfilters', array('ban_type' => 'ip', 'ban_content' => $i, 'ban_date' => time(), 'ban_nocache' => 1));
                             }
                         }
                     }
                     if (count($email)) {
                         /* IPS: Check for duplicate */
                         $this->DB->build(array('select' => '*', 'from' => 'banfilters', 'where' => "ban_content IN ('" . implode("','", $email) . "') and ban_type='email'"));
                         $this->DB->execute();
                         while ($row = $this->DB->fetch()) {
                             $ban['email'][] = $row['ban_content'];
                         }
                         /* Now insert.. */
                         foreach ($email as $e) {
                             if (!in_array($e, $ban['email'])) {
                                 /* Insert the new ban filter */
                                 $this->DB->insert('banfilters', array('ban_type' => 'email', 'ban_content' => $e, 'ban_date' => time(), 'ban_nocache' => 1));
                             }
                         }
                     }
                 }
             }
             ipsRegistry::getClass('adminFunctions')->saveAdminLog(count($ids) . $this->lang->words['t_membanned']);
             $this->registry->output->global_message = count($ids) . $this->lang->words['t_membanned'];
             $this->_viewQueue('spam');
             return;
         }
     }
 }
 /**
  * Add a new arn entry
  *
  * @access	private
  * @return	void		[Outputs to screen/redirects]
  */
 private function _doWarn()
 {
     //-----------------------------------------
     // INIT
     //-----------------------------------------
     $save = array();
     $err = 0;
     $topicPosts_type = trim($this->request['topicPosts_type']);
     $topicPosts_topics = intval($this->request['topicPosts_topics']);
     $topicPosts_replies = intval($this->request['topicPosts_replies']);
     $topicPosts_lastx = intval($this->request['topicPosts_lastx']);
     $topicPosts_lastxunits = trim($this->request['topicPosts_lastxunits']);
     $level_custom = intval($this->request['level_custom']);
     $ban_indef = intval($this->request['ban_indef']);
     $member_banned = intval($this->warn_member['member_banned']);
     $warn_level = intval($this->warn_member['warn_level']);
     //-----------------------------------------
     // Load Mod Squad
     //-----------------------------------------
     require_once IPSLib::getAppDir('forums') . '/sources/classes/moderate.php';
     $moderatorLibrary = new moderatorLibrary($this->registry);
     //-----------------------------------------
     // Security checks
     //-----------------------------------------
     if ($this->type == 'member') {
         $this->registry->output->showError('warn_member_notes', 2028);
     }
     //-----------------------------------------
     // Check security fang
     //-----------------------------------------
     if ($this->request['key'] != $this->member->form_hash) {
         $this->registry->output->showError('warn_bad_key', 3020);
     }
     //-----------------------------------------
     // As Celine Dion once squawked, "Show me the reason"
     //-----------------------------------------
     if (trim($this->request['reason']) == "") {
         $this->_showForm('we_no_reason');
         return;
     }
     //-----------------------------------------
     // Other checks
     //-----------------------------------------
     if (!$this->settings['warn_past_max'] && $this->request['level'] != 'nochange') {
         if ($this->request['level'] == 'custom') {
             if ($level_custom > $this->settings['warn_max']) {
                 $err = 1;
             } else {
                 if ($level_custom < $this->settings['warn_min']) {
                     $err = 2;
                 }
             }
         } else {
             if ($this->request['level'] == 'add') {
                 if ($warn_level >= $this->settings['warn_max']) {
                     $err = 1;
                 }
             } else {
                 if ($warn_level <= $this->settings['warn_min']) {
                     $err = 2;
                 }
             }
         }
         if ($err) {
             $this->registry->output->showError($err == 1 ? 'warn_past_max_high' : 'warn_past_max_low', 10251);
         }
     }
     //-----------------------------------------
     // Plussy - minussy?
     //-----------------------------------------
     if ($this->request['level'] == 'nochange') {
         $save['wlog_type'] = 'nochan';
     } else {
         $save['wlog_type'] = $this->request['level'] == 'custom' ? 'custom' : ($this->request['level'] == 'add' ? 'neg' : 'pos');
     }
     $save['wlog_date'] = time();
     //-----------------------------------------
     // Contacting the member?
     //-----------------------------------------
     $test_content = trim(IPSText::br2nl($_POST['contact']));
     if ($test_content != "") {
         if (trim($this->request['subject']) == "") {
             $this->_showForm('we_no_subject');
             return;
         }
         unset($test_content);
         if (IPSText::getTextClass('editor')->method == 'rte') {
             $this->request['contact'] = IPSText::getTextClass('editor')->processRawPost('contact');
         }
         IPSText::getTextClass('bbcode')->parse_smilies = 1;
         IPSText::getTextClass('bbcode')->parse_html = 0;
         IPSText::getTextClass('bbcode')->parse_bbcode = 1;
         IPSText::getTextClass('bbcode')->parsing_section = 'warn';
         $save['wlog_contact'] = $this->request['contactmethod'];
         $save['wlog_contact_content'] = "<subject>" . $this->request['subject'] . "</subject><content>" . $this->request['contact'] . "</content>";
         $save['wlog_contact_content'] = IPSText::getTextClass('bbcode')->preDbParse($save['wlog_contact_content']);
         if ($this->request['contactmethod'] == 'email') {
             IPSText::getTextClass('bbcode')->parse_smilies = 0;
             IPSText::getTextClass('bbcode')->parse_html = 1;
             IPSText::getTextClass('bbcode')->parse_bbcode = 1;
             IPSText::getTextClass('bbcode')->parsing_section = 'warn';
             IPSText::getTextClass('bbcode')->parsing_mgroup = $this->memberData['member_group_id'];
             IPSText::getTextClass('bbcode')->parsing_mgroup_others = $this->memberData['mgroup_others'];
             $this->request['contact'] = IPSText::getTextClass('bbcode')->preDisplayParse(IPSText::getTextClass('bbcode')->preDbParse($this->request['contact']));
             //-----------------------------------------
             // Send the email
             //-----------------------------------------
             IPSText::getTextClass('email')->getTemplate("email_member");
             IPSText::getTextClass('email')->buildMessage(array('MESSAGE' => IPSText::br2nl($this->request['contact']), 'MEMBER_NAME' => $this->warn_member['members_display_name'], 'FROM_NAME' => $this->memberData['members_display_name']));
             IPSText::getTextClass('email')->subject = $this->request['subject'];
             IPSText::getTextClass('email')->to = $this->warn_member['email'];
             IPSText::getTextClass('email')->from = $this->settings['email_out'];
             IPSText::getTextClass('email')->sendMail();
         } else {
             //-----------------------------------------
             // Grab PM class
             //-----------------------------------------
             require_once IPSLib::getAppDir('members') . '/sources/classes/messaging/messengerFunctions.php';
             $messengerFunctions = new messengerFunctions($this->registry);
             try {
                 $messengerFunctions->sendNewPersonalTopic($this->warn_member['member_id'], $this->memberData['member_id'], array(), $this->request['subject'], IPSText::getTextClass('editor')->method == 'rte' ? nl2br($_POST['contact']) : $_POST['contact'], array('origMsgID' => 0, 'fromMsgID' => 0, 'postKey' => md5(microtime()), 'trackMsg' => 0, 'addToSentFolder' => 0, 'hideCCUser' => 0, 'forcePm' => 1));
             } catch (Exception $error) {
                 $msg = $error->getMessage();
                 $toMember = IPSMember::load($this->warn_member['member_id'], 'core');
                 if (strstr($msg, 'BBCODE_')) {
                     $msg = str_replace('BBCODE_', '', $msg);
                     $this->registry->output->showError($msg, 10252);
                 } else {
                     if (isset($this->lang->words['err_' . $msg])) {
                         $this->lang->words['err_' . $msg] = $this->lang->words['err_' . $msg];
                         $this->lang->words['err_' . $msg] = str_replace('#NAMES#', implode(",", $messengerFunctions->exceptionData), $this->lang->words['err_' . $msg]);
                         $this->lang->words['err_' . $msg] = str_replace('#TONAME#', $toMember['members_display_name'], $this->lang->words['err_' . $msg]);
                         $this->lang->words['err_' . $msg] = str_replace('#FROMNAME#', $this->memberData['members_display_name'], $this->lang->words['err_' . $msg]);
                         $this->registry->output->showError('err_' . $msg, 10253);
                     } else {
                         if ($msg != 'CANT_SEND_TO_SELF') {
                             $_msgString = $this->lang->words['err_UNKNOWN'] . ' ' . $msg;
                             $this->registry->output->showError($_msgString, 10254);
                         }
                     }
                 }
             }
         }
     } else {
         unset($test_content);
     }
     //-----------------------------------------
     // Right - is we banned or wha?
     //-----------------------------------------
     $restrict_post = '';
     $mod_queue = '';
     $susp = '';
     $_notes = array();
     $_notes['content'] = $this->request['reason'];
     $_notes['mod'] = $this->request['mod_value'];
     $_notes['post'] = $this->request['post_value'];
     $_notes['susp'] = $this->request['susp_value'];
     $_notes['ban'] = $ban_indef;
     $_notes['topicPosts_type'] = $topicPosts_type;
     $_notes['topicPosts_topics'] = $topicPosts_topics;
     $_notes['topicPosts_replies'] = $topicPosts_replies;
     $_notes['topicPosts_lastx'] = $topicPosts_lastx;
     $_notes['topicPosts_lastxunits'] = $topicPosts_lastxunits;
     $save['wlog_notes'] = serialize($_notes);
     //-----------------------------------------
     // Member Content
     //-----------------------------------------
     if ($topicPosts_type == 'unapprove' or $topicPosts_type == 'approve') {
         $time = $topicPosts_lastxunits == 'd' ? $topicPosts_lastx * 24 : $topicPosts_lastx;
         $approve = $topicPosts_type == 'approve' ? TRUE : FALSE;
         if ($topicPosts_topics and $this->canApproveTopics and ($topicPosts_replies and $this->canApprovePosts)) {
             $moderatorLibrary->toggleApproveMemberContent($this->warn_member['member_id'], $approve, 'all', $time);
         } else {
             if ($topicPosts_topics and $this->canApproveTopics) {
                 $moderatorLibrary->toggleApproveMemberContent($this->warn_member['member_id'], $approve, 'topics', $time);
             } else {
                 if ($topicPosts_replies and $this->canApprovePosts) {
                     $moderatorLibrary->toggleApproveMemberContent($this->warn_member['member_id'], $approve, 'replies', $time);
                 }
             }
         }
     } else {
         if ($topicPosts_type == 'delete') {
             $time = $topicPosts_lastxunits == 'd' ? $topicPosts_lastx * 24 : $topicPosts_lastx;
             if ($topicPosts_topics and $this->canDeleteTopics and ($topicPosts_replies and $this->canDeletePosts)) {
                 $moderatorLibrary->deleteMemberContent($this->warn_member['member_id'], 'all', $time);
             } else {
                 if ($topicPosts_topics and $this->canDeleteTopics) {
                     $moderatorLibrary->deleteMemberContent($this->warn_member['member_id'], 'topics', $time);
                 } else {
                     if ($topicPosts_replies and $this->canDeletePosts) {
                         $moderatorLibrary->deleteMemberContent($this->warn_member['member_id'], 'replies', $time);
                     }
                 }
             }
         }
     }
     //-----------------------------------------
     // Member Suspension
     //-----------------------------------------
     if ($this->canModQueue) {
         if ($this->request['mod_indef'] == 1) {
             $mod_queue = 1;
         } elseif ($this->request['mod_value'] > 0) {
             $mod_queue = IPSMember::processBanEntry(array('timespan' => intval($this->request['mod_value']), 'unit' => $this->request['mod_unit']));
         }
     }
     if ($this->canRemovePostAbility) {
         if ($this->request['post_indef'] == 1) {
             $restrict_post = 1;
         } elseif ($this->request['post_value'] > 0) {
             $restrict_post = IPSMember::processBanEntry(array('timespan' => intval($this->request['post_value']), 'unit' => $this->request['post_unit']));
         }
     }
     if ($this->canSuspend) {
         if ($ban_indef) {
             $member_banned = 1;
         } else {
             if ($this->request['susp_value'] > 0) {
                 $susp = IPSMember::processBanEntry(array('timespan' => intval($this->request['susp_value']), 'unit' => $this->request['susp_unit']));
             }
         }
         /* Were banned but now unticked? */
         if (!$ban_indef and $member_banned) {
             $member_banned = 0;
         }
     }
     $save['wlog_mid'] = $this->warn_member['member_id'];
     $save['wlog_addedby'] = $this->memberData['member_id'];
     //-----------------------------------------
     // Enter into warn loggy poos (eeew - poo)
     //-----------------------------------------
     $this->DB->insert('warn_logs', $save);
     //-----------------------------------------
     // Update member
     //-----------------------------------------
     if ($this->request['level'] != 'nochange') {
         if ($this->request['level'] == 'custom') {
             $warn_level = $level_custom;
         } else {
             if ($this->request['level'] == 'add') {
                 $warn_level++;
             } else {
                 $warn_level--;
             }
         }
         if ($warn_level > $this->settings['warn_max']) {
             $warn_level = $this->settings['warn_max'];
         }
         if ($warn_level < intval($this->settings['warn_min'])) {
             $warn_level = intval($this->settings['warn_min']);
         }
     }
     IPSMember::save($this->warn_member['member_id'], array('core' => array('mod_posts' => $mod_queue, 'restrict_post' => $restrict_post, 'temp_ban' => $susp, 'member_banned' => $member_banned, 'warn_level' => $warn_level, 'warn_lastwarn' => time())));
     //-----------------------------------------
     // Now what? Show success screen, that's what!!
     //-----------------------------------------
     $this->lang->words['w_done_te'] = sprintf($this->lang->words['w_done_te'], $this->warn_member['members_display_name']);
     $tid = intval($this->request['t']);
     $topic = array();
     if ($tid > 0) {
         $topic = $this->DB->buildAndFetch(array('select' => 't.tid, t.title, t.title_seo', 'from' => array('topics' => 't'), 'where' => "t.tid={$tid}", 'add_join' => array(array('select' => 'f.id, f.name, f.name_seo', 'from' => array('forums' => 'f'), 'where' => 'f.id=t.forum_id', 'type' => 'left'))));
     }
     $this->output .= $this->registry->getClass('output')->getTemplate('mod')->warn_success($topic);
 }