Current Path : /var/www/html/clients/rebirth.e-nk.ru/sources/action_admin/ |
Current File : /var/www/html/clients/rebirth.e-nk.ru/sources/action_admin/banandbadword.php |
<?php /* +-------------------------------------------------------------------------- | Invision Power Board | ============================================= | by Matthew Mecham | (c) 2001 - 2006 Invision Power Services, Inc. | Nullified by Terabyte | ============================================= | | +--------------------------------------------------------------------------- | > $Date: 2007-01-09 09:00:55 -0500 (Tue, 09 Jan 2007) $ | > $Revision: 823 $ | > $Author: bfarber $ +--------------------------------------------------------------------------- | | > Administration Module | > Module written by Matt Mecham | > Date started: 27th January 2004 | | > Module Version Number: 1.0.0 | > DBA Checked: Mon 24th May 2004 +-------------------------------------------------------------------------- */ if ( ! defined( 'IN_ACP' ) ) { print "<h1>Incorrect access</h1>You cannot access this file directly. If you have recently upgraded, make sure you upgraded 'admin.php'."; exit(); } class ad_banandbadword { var $functions = ""; var $ipsclass; var $html; /** * Section title name * * @var string */ var $perm_main = "content"; /** * Section title name * * @var string */ var $perm_child = "babw"; function auto_run() { $this->html = $this->ipsclass->acp_load_template('cp_skin_bbcode_badword'); //----------------------------------------- // Require and RUN !! THERES A BOMB //----------------------------------------- $this->ipsclass->admin->page_detail = ""; $this->ipsclass->admin->page_title = "Ban Manager"; //----------------------------------------- // What to do... //----------------------------------------- switch($this->ipsclass->input['code']) { //----------------------------------------- // Badword //----------------------------------------- case 'badword': $this->ipsclass->admin->cp_permission_check( $this->perm_main.'|'.$this->perm_child.':' ); $this->badword_start(); break; case 'badword_add': $this->ipsclass->admin->cp_permission_check( $this->perm_main.'|'.$this->perm_child.':bw-add' ); $this->badword_add(); break; case 'badword_remove': $this->ipsclass->admin->cp_permission_check( $this->perm_main.'|'.$this->perm_child.':bw-remove' ); $this->badword_remove(); break; case 'badword_edit': $this->ipsclass->admin->cp_permission_check( $this->perm_main.'|'.$this->perm_child.':bw-edit' ); $this->badword_edit(); break; case 'badword_doedit': $this->ipsclass->admin->cp_permission_check( $this->perm_main.'|'.$this->perm_child.':bw-edit' ); $this->badword_doedit(); break; case 'badword_export': $this->ipsclass->admin->cp_permission_check( $this->perm_main.'|'.$this->perm_child.':bw-export' ); $this->badword_export(); break; case 'badword_import': $this->ipsclass->admin->cp_permission_check( $this->perm_main.'|'.$this->perm_child.':bw-import' ); $this->badword_import(); break; //----------------------------------------- // BAN (d-aid) //----------------------------------------- case 'ban': $this->ipsclass->admin->cp_permission_check( $this->perm_main.'|'.$this->perm_child.':ban-view' ); $this->ban_start(); break; case 'ban_add': $this->ipsclass->admin->cp_permission_check( $this->perm_main.'|'.$this->perm_child.':ban-add' ); $this->ban_add(); break; case 'ban_delete': $this->ipsclass->admin->cp_permission_check( $this->perm_main.'|'.$this->perm_child.':ban-remove' ); $this->ban_delete(); break; } } //----------------------------------------- // BAN: Rebuild cache //----------------------------------------- function ban_rebuildcache() { require_once ROOT_PATH.'sources/classes/bbcode/class_bbcode_core.php'; $this->ipsclass->cache['banfilters'] = array(); $this->ipsclass->DB->simple_construct( array( 'select' => 'ban_content', 'from' => 'banfilters', 'where' => "ban_type='ip'" ) ); $this->ipsclass->DB->simple_exec(); while ( $r = $this->ipsclass->DB->fetch_row() ) { $this->ipsclass->cache['banfilters'][] = $r['ban_content']; } usort( $this->ipsclass->cache['banfilters'] , array( 'class_bbcode_core', 'word_length_sort' ) ); $this->ipsclass->update_cache( array( 'name' => 'banfilters', 'array' => 1, 'deletefirst' => 1 ) ); } //----------------------------------------- // BAN: DELETE //----------------------------------------- function ban_delete() { $ids = array(); foreach ($this->ipsclass->input as $key => $value) { if ( preg_match( "/^id_(\d+)$/", $key, $match ) ) { if ( $this->ipsclass->input[$match[0]] ) { $ids[] = $match[1]; } } } $ids = $this->ipsclass->clean_int_array( $ids ); if ( count( $ids ) ) { $this->ipsclass->DB->simple_construct( array( 'delete' => 'banfilters', 'where' => 'ban_id IN('.implode( ",",$ids ).')' ) ); $this->ipsclass->DB->simple_exec(); } $this->ban_rebuildcache(); $this->ipsclass->main_msg = "Ban filters removed"; $this->ban_start(); } //----------------------------------------- // BAN: ADD //----------------------------------------- function ban_add() { if ( ! $this->ipsclass->input['bantext'] ) { $this->ipsclass->main_msg = "You must enter something to add to the ban filters!"; $this->ban_start(); } //----------------------------------------- // Check for existing entry //----------------------------------------- $result = $this->ipsclass->DB->simple_exec_query( array( 'select' => '*', 'from' => 'banfilters', 'where' => "ban_content='{$this->ipsclass->input['bantext']}' and ban_type='{$this->ipsclass->input['bantype']}'" ) ); if ( $result['ban_id'] ) { $this->ipsclass->main_msg = "Duplicate entry, entry not added to the ban filters database."; $this->ban_start(); } $this->ipsclass->DB->do_insert( 'banfilters', array( 'ban_type' => $this->ipsclass->input['bantype'], 'ban_content' => trim($this->ipsclass->input['bantext']), 'ban_date' => time() ) ); $this->ban_rebuildcache(); $this->ipsclass->main_msg = "Ban filter added"; $this->ban_start(); } //----------------------------------------- // BAN: START //----------------------------------------- function ban_start() { $this->ipsclass->admin->page_title = "Ban Control"; $this->ipsclass->admin->nav[] = array( $this->ipsclass->form_code.'&code=ban', 'Ban Filters' ); $this->ipsclass->admin->page_detail = "This section allows you to modify, delete or add IP addresses, email addresses and reserved names to the ban filters. <br /><strong>You can use * as a wildcard in any Username, IP or email filter. (Example: 127.0.*, *@yahoo.com, bannedname*)</strong>"; //----------------------------------------- // Get things //----------------------------------------- $ban = array(); $this->ipsclass->DB->simple_construct( array( 'select' => '*', 'from' => 'banfilters', 'order' => 'ban_date desc' ) ); $this->ipsclass->DB->simple_exec(); while ( $r = $this->ipsclass->DB->fetch_row() ) { $ban[ $r['ban_type'] ][ $r['ban_id'] ] = $r; } //----------------------------------------- // SHOW THEM! //----------------------------------------- $this->ipsclass->html .= $this->ipsclass->adskin->start_form( array( 1 => array( 'code' , 'ban_delete'), 2 => array( 'act' , 'babw' ), 4 => array( 'section', $this->ipsclass->section_code ), ) ); $this->ipsclass->adskin->td_header[] = array( " " , "1%" ); $this->ipsclass->adskin->td_header[] = array( "Entry" , "80%" ); $this->ipsclass->adskin->td_header[] = array( "Date Added" , "20%" ); //----------------------------------------- $this->ipsclass->html .= $this->ipsclass->adskin->start_table( "Ban Control" ); //----------------------------------------- // Banned IP Addresses //----------------------------------------- $this->ipsclass->html .= $this->ipsclass->adskin->add_td_basic("Banned IP Addresses", "left", "tablesubheader"); if ( isset($ban['ip']) AND is_array( $ban['ip'] ) AND count( $ban['ip'] ) ) { foreach ( $ban['ip'] as $entry ) { $this->ipsclass->html .= $this->ipsclass->adskin->add_td_row( array( "<input type='checkbox' name='id_{$entry['ban_id']}' value='1' />", $entry['ban_content'], $this->ipsclass->get_date( $entry['ban_date'], 'SHORT' ), ) ); } } else { $this->ipsclass->html .= $this->ipsclass->adskin->add_td_basic("No Entered Banned IP Addresses", "left", "tablerow1"); } //----------------------------------------- // Banned Email Addresses //----------------------------------------- $this->ipsclass->html .= $this->ipsclass->adskin->add_td_basic("Banned Email Addresses", "left", "tablesubheader"); if ( isset($ban['email']) AND is_array( $ban['email'] ) AND count( $ban['email'] ) ) { foreach ( $ban['email'] as $entry ) { $this->ipsclass->html .= $this->ipsclass->adskin->add_td_row( array( "<input type='checkbox' name='id_{$entry['ban_id']}' value='1' />", $entry['ban_content'], $this->ipsclass->get_date( $entry['ban_date'], 'SHORT' ), ) ); } } else { $this->ipsclass->html .= $this->ipsclass->adskin->add_td_basic("No Entered Banned Email Addresses", "left", "tablerow1"); } //----------------------------------------- // Banned Names //----------------------------------------- $this->ipsclass->html .= $this->ipsclass->adskin->add_td_basic("Non-Registerable Names", "left", "tablesubheader"); if ( isset($ban['name']) AND is_array( $ban['name'] ) AND count( $ban['name'] ) ) { foreach ( $ban['name'] as $entry ) { $this->ipsclass->html .= $this->ipsclass->adskin->add_td_row( array( "<input type='checkbox' name='id_{$entry['ban_id']}' value='1' />", $entry['ban_content'], $this->ipsclass->get_date( $entry['ban_date'], 'SHORT' ), ) ); } } else { $this->ipsclass->html .= $this->ipsclass->adskin->add_td_basic("No Entered Names", "left", "tablerow1"); } $end_it_now = "<div align='left' style='float:left;width:auto;'> <input type='submit' value='Delete Selected' class='realdarkbutton' /> </div></form> <div align='center'><form method='post' action='{$this->ipsclass->base_url}&{$this->ipsclass->form_code}&code=ban_add'><input type='hidden' name='_admin_auth_key' value='{$this->ipsclass->_admin_auth_key}' /><input type='text' size='30' class='textinput' value='' name='bantext' /> <select class='dropdown' name='bantype'><option value='ip'>IP Address</option><option value='email'>Email Address</option><option value='name'>Name</option></select> <input type='submit' value='Add New Filter' class='realdarkbutton' /></form></div>"; $this->ipsclass->html .= $this->ipsclass->adskin->add_td_basic( $end_it_now, "center", "tablesubheader"); $this->ipsclass->html .= $this->ipsclass->adskin->end_table(); $this->ipsclass->admin->output(); } //----------------------------------------- // BADWORDS: Import //----------------------------------------- function badword_import() { $content = $this->ipsclass->admin->import_xml( 'ipb_badwords.xml' ); //----------------------------------------- // Got anything? //----------------------------------------- if ( ! $content ) { $this->ipsclass->main_msg = "Upload failed, ipb_badwords.xml was either missing or empty"; $this->badword_start(); return; } //----------------------------------------- // Get xml mah-do-dah //----------------------------------------- require_once( KERNEL_PATH.'class_xml.php' ); $xml = new class_xml(); //----------------------------------------- // Unpack the datafile //----------------------------------------- $xml->xml_parse_document( $content ); if( !is_array($xml->xml_array['badwordexport']['badwordgroup']['badword']) OR !count($xml->xml_array['badwordexport']['badwordgroup']['badword']) ) { $this->ipsclass->main_msg = "XML Import failed: ipb_badwords.xml is either empty or in the wrong format"; $this->badword_start(); return; } //----------------------------------------- // Get current badwords //----------------------------------------- $words = array(); $this->ipsclass->DB->simple_construct( array( 'select' => '*', 'from' => 'badwords', 'order' => 'type' ) ); $this->ipsclass->DB->simple_exec(); while ( $r = $this->ipsclass->DB->fetch_row() ) { $words[ $r['type'] ] = 1; } //----------------------------------------- // pArse //----------------------------------------- foreach( $xml->xml_array['badwordexport']['badwordgroup']['badword'] as $entry ) { $type = $entry['type']['VALUE']; $swop = $entry['swop']['VALUE']; $m_exact = $entry['m_exact']['VALUE']; if ( $words[ $type ] ) { continue; } if ( $type ) { $this->ipsclass->DB->do_insert( 'badwords', array( 'type' => $type, 'swop' => $swop, 'm_exact' => $m_exact ) ); } } $this->badword_rebuildcache(); $this->ipsclass->main_msg = "Badword XML file import completed"; $this->badword_start(); } //----------------------------------------- // BADWORD: Export //----------------------------------------- function badword_export() { //----------------------------------------- // Get xml mah-do-dah //----------------------------------------- require_once( KERNEL_PATH.'class_xml.php' ); $xml = new class_xml(); //----------------------------------------- // Start... //----------------------------------------- $xml->xml_set_root( 'badwordexport', array( 'exported' => time() ) ); //----------------------------------------- // Get emo group //----------------------------------------- $xml->xml_add_group( 'badwordgroup' ); $this->ipsclass->DB->simple_construct( array( 'select' => 'type, swop, m_exact', 'from' => 'badwords', 'order' => 'type' ) ); $this->ipsclass->DB->simple_exec(); while ( $r = $this->ipsclass->DB->fetch_row() ) { $content = array(); foreach ( $r as $k => $v ) { $content[] = $xml->xml_build_simple_tag( $k, $v ); } $entry[] = $xml->xml_build_entry( 'badword', $content ); } $xml->xml_add_entry_to_group( 'badwordgroup', $entry ); $xml->xml_format_document(); //----------------------------------------- // Send to browser. //----------------------------------------- $this->ipsclass->admin->show_download( $xml->xml_document, 'ipb_badwords.xml' ); } //----------------------------------------- // BADWORD: Start //----------------------------------------- function badword_start() { //----------------------------------------- // INIT //----------------------------------------- $badword_html = ""; $this->ipsclass->admin->page_detail = "You can add/edit and remove bad word filters in this section.<br>The badword filter allows you to globally replace words from a members post, signature and topic title.<br><br><b>Loose matching</b>: If you entered 'hell' as a bad word, it will replace 'hell' and 'hello' with either your replacement if entered or 6 hashes (case insensitive)<br><br><b>Exact matching</b>: If you entered 'hell' as a bad word, it will replace 'hell' only with either your replacement if entered or 6 hashes (case insensitive)"; $this->ipsclass->admin->page_title = "Bad Word Filter"; $this->ipsclass->admin->nav[] = array( $this->ipsclass->form_code.'&code=badword', 'Bad Word Filters' ); //----------------------------------------- // Start form //----------------------------------------- $this->ipsclass->html .= $this->ipsclass->adskin->start_form( array( 1 => array( 'code' , 'badword_add' ), 2 => array( 'act' , 'babw' ), 4 => array( 'section', $this->ipsclass->section_code ), ) ); $this->ipsclass->DB->simple_construct( array( 'select' => '*', 'from' => 'badwords', 'order' => 'type' ) ); $this->ipsclass->DB->simple_exec(); if ( $this->ipsclass->DB->get_num_rows() ) { while ( $r = $this->ipsclass->DB->fetch_row() ) { $words[] = $r; } foreach($words as $r) { $r['replace'] = $r['swop'] ? stripslashes($r['swop']) : '######'; $r['method'] = $r['m_exact'] ? 'Exact' : 'Loose'; $r['type'] = stripslashes($r['type']); $badword_html .= $this->html->badword_row( $r ); } } $this->ipsclass->html .= $this->html->badword_wrapper( $badword_html ); //----------------------------------------- // IMPORT: Start table //----------------------------------------- $this->ipsclass->adskin->td_header[] = array( " " , "60%" ); $this->ipsclass->adskin->td_header[] = array( " " , "40%" ); //----------------------------------------- // IMPORT: Start output //----------------------------------------- $this->ipsclass->html .= $this->ipsclass->adskin->start_form( array( 1 => array( 'code' , 'badword_import' ), 2 => array( 'act' , 'babw' ), 3 => array( 'MAX_FILE_SIZE', '10000000000' ), 4 => array( 'section', $this->ipsclass->section_code ), ) , "uploadform", " enctype='multipart/form-data'" ); $this->ipsclass->html .= $this->ipsclass->adskin->start_table( "Import a Badword List" ); $this->ipsclass->html .= $this->ipsclass->adskin->add_td_row( array( "<b>Upload XML Badword List</b><div style='color:gray'>Browse your computer for 'ipb_badwords.xml' or 'ipb_badwords.xml.gz'. Duplicate entries will not be imported.</div>", $this->ipsclass->adskin->form_upload( ) ) ); $this->ipsclass->html .= $this->ipsclass->adskin->end_form("Import"); $this->ipsclass->html .= $this->ipsclass->adskin->end_table(); $this->ipsclass->admin->output(); } //----------------------------------------- // BADWORD: Complete Edit //----------------------------------------- function badword_doedit() { if ($this->ipsclass->input['before'] == "") { $this->ipsclass->admin->error("You must enter a word to replace, silly!"); } if ($this->ipsclass->input['id'] == "") { $this->ipsclass->admin->error("You must pass a valid filter id, silly!"); } $this->ipsclass->input['match'] = $this->ipsclass->input['match'] ? 1 : 0; strlen($this->ipsclass->input['swop']) > 1 ? $this->ipsclass->input['swop'] : ""; $this->ipsclass->DB->do_update( 'badwords', array( 'type' => trim($this->ipsclass->input['before']), 'swop' => trim($this->ipsclass->input['after']), 'm_exact' => $this->ipsclass->input['match'], ), "wid='".$this->ipsclass->input['id']."'" ); $this->badword_rebuildcache(); $this->ipsclass->main_msg = "Filter edited"; $this->badword_start(); } //----------------------------------------- // BADWORD: Edit //----------------------------------------- function badword_edit() { $this->ipsclass->admin->page_detail = "You may edit the chosen filter below"; $this->ipsclass->admin->page_title = "Bad Word Filter"; $this->ipsclass->admin->nav[] = array( $this->ipsclass->form_code.'&code=badword', 'Bad Word Filters' ); $this->ipsclass->admin->nav[] = array( '', 'Edit Bad Word Filter' ); //----------------------------------------- if ($this->ipsclass->input['id'] == "") { $this->ipsclass->admin->error("You must pass a valid filter id, silly!"); } //----------------------------------------- $this->ipsclass->DB->simple_construct( array( 'select' => '*', 'from' => 'badwords', 'where' => "wid='".$this->ipsclass->input['id']."'" ) ); $this->ipsclass->DB->simple_exec(); if ( ! $r = $this->ipsclass->DB->fetch_row() ) { $this->ipsclass->admin->error("We could not find that filter in the database"); } //----------------------------------------- $this->ipsclass->html .= $this->ipsclass->adskin->start_form( array( 1 => array( 'code' , 'badword_doedit' ), 2 => array( 'act' , 'babw' ), 3 => array( 'id' , $this->ipsclass->input['id'] ), 4 => array( 'section', $this->ipsclass->section_code ), ) ); $this->ipsclass->adskin->td_header[] = array( "Before" , "40%" ); $this->ipsclass->adskin->td_header[] = array( "After" , "40%" ); $this->ipsclass->adskin->td_header[] = array( "Method" , "20%" ); //----------------------------------------- $this->ipsclass->html .= $this->ipsclass->adskin->start_table( "Edit a filter" ); $this->ipsclass->html .= $this->ipsclass->adskin->add_td_row( array( $this->ipsclass->adskin->form_input('before', stripslashes($r['type']) ), $this->ipsclass->adskin->form_input('after' , stripslashes($r['swop']) ), $this->ipsclass->adskin->form_dropdown( 'match', array( 0 => array( 1, 'Exact' ), 1 => array( 0, 'Loose' ) ), $r['m_exact'] ) ) ); $this->ipsclass->html .= $this->ipsclass->adskin->end_form('Edit Filter'); $this->ipsclass->html .= $this->ipsclass->adskin->end_table(); $this->ipsclass->admin->output(); } //----------------------------------------- // BADWORD: Remove badowrd //----------------------------------------- function badword_remove() { if ($this->ipsclass->input['id'] == "") { $this->ipsclass->admin->error("You must pass a valid filter id, silly!"); } $this->ipsclass->DB->simple_exec_query( array( 'delete' => 'badwords', 'where' => "wid='".$this->ipsclass->input['id']."'" ) ); $this->badword_rebuildcache(); $this->ipsclass->main_msg = "Filter removed"; $this->badword_start(); return; } //----------------------------------------- // BADWORD: Add badword //----------------------------------------- function badword_add() { if ($this->ipsclass->input['before'] == "") { $this->ipsclass->admin->error("You must enter a word to replace, silly!"); } $this->ipsclass->input['match'] = $this->ipsclass->input['match'] ? 1 : 0; strlen($this->ipsclass->input['swop']) > 1 ? $this->ipsclass->input['swop'] : ""; $this->ipsclass->DB->do_insert( 'badwords', array( 'type' => trim($this->ipsclass->input['before']), 'swop' => trim($this->ipsclass->input['after']), 'm_exact' => $this->ipsclass->input['match'], ) ); $this->badword_rebuildcache(); $this->ipsclass->main_msg = "New filter added"; $this->badword_start(); } //----------------------------------------- // BADWORD Rebuild Cache //----------------------------------------- function badword_rebuildcache() { $this->ipsclass->cache['badwords'] = array(); $this->ipsclass->DB->simple_construct( array( 'select' => 'type,swop,m_exact', 'from' => 'badwords' ) ); $this->ipsclass->DB->simple_exec(); while ( $r = $this->ipsclass->DB->fetch_row() ) { $this->ipsclass->cache['badwords'][] = $r; } $this->ipsclass->update_cache( array( 'name' => 'badwords', 'array' => 1, 'deletefirst' => 1 ) ); } function perly_length_sort($a, $b) { if ( strlen($a['typed']) == strlen($b['typed']) ) { return 0; } return ( strlen($a['typed']) > strlen($b['typed']) ) ? -1 : 1; } function perly_word_sort($a, $b) { if ( strlen($a['type']) == strlen($b['type']) ) { return 0; } return ( strlen($a['type']) > strlen($b['type']) ) ? -1 : 1; } } ?>