Accelerate your eCommerce ambitions with adeptCommerce Suite

SEO Egghead Consulting Group is a web development firm dedicated to creating custom, search-engine-optimized web site applications.

We specialize in eCommerce and content management web sites that not only render information beautifully to the human, but also satisfy the "third browser" - the search engine. To us, search engines are people too.

image description image description image description image description

Download WordPress Firewall Plugin

Copy the following program to "wordpress-firewall.

NEED A GREAT WEB SITE? NEED IT TO BE SEARCH-ENGINE-FRIENDLY?

SEO Egghead is a web development firm dedicated to creating custom, search engine optimized web site applications. We specialize in eCommerce and content management web sites that not only render information beautifully to the human, but also satisfy the "third browser" — the search engine. To us, search engines are people too. Click here to talk to us. We'd love to help!
X

Copy the following program to "wordpress-firewall.php" within your "wp-content/plugins/" folder.





<?php
/*
Plugin Name: Wordpress Firewall
Plugin URI: http://www.seoegghead.com/software/wordpress-firewall.seo
Description: Blocks suspicious-looking requests to WordPress.
Author: SEO Egghead, Inc.
Version: 1.25 for WP 2.x
Author URI: http://www.seoegghead.com/
*/ 

if(!function_exists('array_diff_key')){
    if ((@include_once 
'PHP/Compat/Function/array_diff_key.php')) {}
    else{       
    
// Borrowed from PEAR_PHP_Compat.    
    
function php_compat_array_diff_key()
    {
        
$args = func_get_args();
        if (
count($args) < 2) {
            
user_error('Wrong parameter count for array_diff_key()', E_USER_WARNING);
            return;
        }
        
// Check arrays
        
$array_count = count($args);
        for (
$i = 0; $i !== $array_count; $i++) {
            if (!
is_array($args[$i])) {
                
user_error('array_diff_key() Argument #' .
                    (
$i + 1) . ' is not an array', E_USER_WARNING);
                return;
            }
        }
        
$result = $args[0];
        if (
function_exists('array_key_exists')) {
            
// Optimize for >= PHP 4.1.0
            
foreach ($args[0] as $key => $value) {
                for (
$i = 1; $i !== $array_count; $i++) {
                    if (
array_key_exists($key,$args[$i])) {
                        unset(
$result[$key]);
                        break;
                    }
                }
            }
        } else {
            foreach (
$args[0] as $key1 => $value1) {
                for (
$i = 1; $i !== $array_count; $i++) {
                    foreach (
$args[$i] as $key2 => $value2) {
                        if ((string) 
$key1 === (string) $key2) {
                            unset(
$result[$key2]);
                            break 
2;
                        }
                    }
                }
            }
        }
        return 
$result; 
    }        
        function 
array_diff_key()
        {
            
$args = func_get_args();
            return 
call_user_func_array('php_compat_array_diff_key', $args);
        }
    }
}

if(
preg_match("#^wordpress-firewall.php#", basename($_SERVER['PHP_SELF']))) exit();

add_option('WP_firewall_redirect_page', 'homepage');
add_option('WP_firewall_exclude_directory', 'allow');
add_option('WP_firewall_exclude_queries', 'allow');
add_option('WP_firewall_exclude_terms', 'allow');
add_option('WP_firewall_exclude_spaces', 'allow');
add_option('WP_firewall_exclude_file', 'allow');
add_option('WP_firewall_exclude_http', 'disallow');
add_option('WP_firewall_email_enable','enable');
add_option('WP_firewall_email_address', get_option('admin_email'));
add_option('WP_firewall_whitelisted_ip', '');
add_option('WP_firewall_whitelisted_page', '');
add_option('WP_firewall_whitelisted_variable', '');
add_option('WP_firewall_plugin_url', get_option('siteurl') 
.
'/wp-admin/options-general.php?page=' . basename(__FILE__));
add_option('default_WP_firewall_whitelisted_page', 
serialize(array( array('.*/wp-comments-post\.php',array('url', 'comment')),
array(
'.*/wp-admin/.*',array( '_wp_original_http_referer','_wp_http_referer' 
)),
array(
'.*wp-login.php', array('redirect_to')),
array(
'.*', array('comment_author_url_.*', '__utmz', )),
'.*/wp-admin/options-general\.php', '.*/wp-admin/post-new\.php', 
'.*/wp-admin/page-new\.php','.*/wp-admin/link-add\.php', '.*/wp-admin/post\.php',
'.*/wp-admin/page\.php',
'.*/wp-admin/admin-ajax.php')));
add_option('WP_firewall_previous_attack_var', '');
add_option('WP_firewall_previous_attack_ip', '');
add_option('WP_firewall_email_limit', 'off');

WP_firewall_check_exclusions ();

function 
WP_firewall_check_exclusions () {

    
$request_string = WP_firewall_check_whitelisted_variable();
    if(
$request_string == false){
    } else{
        if(
get_option('WP_firewall_exclude_directory') == 'allow'){
            
            
$exclude_terms = array('#etc/passwd#', '#proc/self/environ#', '#\.\./#');
            foreach(
$exclude_terms as $preg){
                foreach(
$request_string as $key=>$value){
                    if(
preg_match($preg, $value)){
                        if(!
WP_firewall_check_ip_whitelist()){    
                            
WP_firewall_send_log_message($key, $value, 
                            
'directory-traversal-attack', 'Directory Traversal');            
                            
WP_firewall_send_redirect();
                        }    
                    }        
                }    
            }
        }
        if(
get_option('WP_firewall_exclude_queries') == 'allow'){    
            
$exclude_terms = array('#concat\s*\(#i', '#group_concat#i',
            
'#union.*select#i');
            foreach(
$exclude_terms as $preg){
                foreach(
$request_string as $key=>$value){    
                    if(
preg_match($preg, $value) ){
                        if(!
WP_firewall_check_ip_whitelist()){    
                            
WP_firewall_send_log_message($key, $value, 
                            
'sql-injection-attack', 'SQL Injection');            
                            
WP_firewall_send_redirect();
                        }
                    }
                }
            }    
        }
        if(
get_option('WP_firewall_exclude_terms') == 'allow'){
            
$exclude_terms = array('#wp_#i', '#user_login#i', 
            
'#user_pass#i', '#0x[0-9a-f][0-9a-f]#i', '#/\*\*/#');
        
            foreach(
$exclude_terms as $preg){
                foreach(
$request_string as $key=>$value){                    
                    if(
preg_match($preg, $value)){
                        if(!
WP_firewall_check_ip_whitelist()){                    
                            
WP_firewall_send_log_message($key, $value, 
                            
'wp-specific-sql-injection-attack', 'WordPress-Specific SQL Injection');
                            
WP_firewall_send_redirect();
                        }
                    }
                }
            }
        }    
        if(
get_option('WP_firewall_exclude_spaces') == 'allow'){    
            
$exclude_terms = array('#\s{49,}#i','#\x00#');
            foreach(
$exclude_terms as $preg){
                foreach(
$request_string as $key=>$value){                    
                    if(
preg_match('#\s{49,}#i', $value) ){
                        if(!
WP_firewall_check_ip_whitelist()){                
                            
WP_firewall_send_log_message($key, $value, 
                            
'field-truncation-attack', 'Field Truncation');
                            
WP_firewall_send_redirect();
                        }        
                    }
                }
            }
        }
        if(
get_option('WP_firewall_exclude_file') == 'allow'){    
            foreach (
$_FILES as $file) {
                
$file_extensions = 
                array(
'#\.dll$#i', '#\.rb$#i', '#\.py$#i',
                
'#\.exe$#i', '#\.php[3-6]?$#i','#\.pl$#i', 
                
'#\.perl$#i', '#\.ph[34]$#i', '#\.phl$#i' ,
                
'#\.phtml$#i', '#\.phtm$#i');
                 foreach(
$file_extensions as $regex){
                    if(
preg_match($regex, $file['name'])){
                         
WP_firewall_send_log_message('$_FILE', $file['name'], 
                         
'executable-file-upload-attack', 'Executable File Upload');
                        
WP_firewall_send_redirect();    
                    }    
                 }
            }            
        }            
        if(
get_option('WP_firewall_exclude_http') == 'allow'){    
            
            
$exclude_terms = array('#^http#i', '#\.shtml#i');
            foreach(
$exclude_terms as $preg){            
            
                foreach(
$request_string as $key=>$value){                
                    if(
preg_match($preg, $value)){
                        if(!
WP_firewall_check_ip_whitelist()){                
                            
WP_firewall_send_log_message($key, $value, 
                            
'remote-file-execution-attack', 'Remote File Execution');
                            
WP_firewall_send_redirect();
                        }        
                    }
                }
            }
        }        
    }
}

function 
WP_firewall_send_redirect(){
    
$home_url = get_option('siteurl');    
    if(
get_option('WP_firewall_redirect_page') == '404page'){
        
// Not clear if just including the 404 template is safe.
        
header ("Location: $home_url/404/");
        exit();
    }
    else {
        
header ("Location: $home_url");
        exit();        
    }
}

function 
WP_firewall_check_whitelisted_variable(){
    
    
preg_match('#([^?]+)?.*$#',$_SERVER['REQUEST_URI'], $url);    
    
$page_name = $url[1];    

    
$_a = array();
    
$new_arr = WP_firewall_array_flatten($_REQUEST, $_a);

    foreach(
    
unserialize(get_option('default_WP_firewall_whitelisted_page'))
    as 
$whitelisted_page){                                            

        if(!
is_array($whitelisted_page)){
            if(
preg_match('#^' . $whitelisted_page . '$#',$page_name)){
                return 
false;
            }
        }else{
            if(
preg_match('#^' . $whitelisted_page[0] . '$#',$page_name)){
                foreach(
$whitelisted_page[1] as $whitelisted_variable){
                    foreach(
array_keys($new_arr) as $var){    
                        if(
preg_match('#^' . $whitelisted_variable 
                        
.'$#',$var)){    
                            
$new_arr = array_diff_key($new_arr,array($var=>''));    
                        }
                    }
                }
            }            
        }
    }
    
    
$pages     = unserialize(
    
get_option('WP_firewall_whitelisted_page'));
    
$variables = unserialize(
    
get_option('WP_firewall_whitelisted_variable'));
    
$count = 0;
    
    while(
$count < sizeof($pages)){
        
        
$page_regex =  preg_quote($pages[$count], '#') ;
        
$page_regex = str_replace('\*', '.*', $page_regex);        
        
        
$var_regex =  preg_quote($variables[$count], '#') ;
        
$var_regex = str_replace('\*', '.*', $var_regex);    
        
        if( 
$variables[$count] != ''){
            if(
$pages[$count] == '' || preg_match('#^' . $page_regex . '$#',
            
$page_name)){
                
$temp_arr = $new_arr;
                foreach(
array_keys($new_arr) as $var){
                    if(
preg_match('#^' . $var_regex . '$#',$var)){
                        
$new_arr = array_diff_key($new_arr,array($var=>''));    
                    }
                }
            }                
        } elseif(
$pages[$count] != ''){
            if(    
preg_match('#^' . $page_regex . '$#',$page_name)){
                return 
false;
            }
        }        
        
$count++;
    }                    
    return 
$new_arr;
}

function 
WP_firewall_send_log_message($bad_variable = '',
$bad_value = '', $attack_type = '', $attack_category = ''){
    
    
$bad_variable = htmlentities($bad_variable);
    
$bad_value = htmlentities($bad_value);
    
    
$offender_ip = $_SERVER['REMOTE_ADDR'] ;

    
$limit_check = (
    
get_option('WP_firewall_email_limit') == 'on' 
    
&&  $offender_ip == get_option('WP_firewall_previous_attack_ip')
    &&  
$bad_variable == get_option('WP_firewall_previous_attack_var')
    );
            
    if( 
$address = get_option('WP_firewall_email_address')&& !$limit_check
    
){
        
$suppress_message = (get_option('WP_firewall_email_limit')=='on')
        ?
        
'Repeated warnings for similar attacks are currently sent via email, 
        <a href="' 
. get_option('WP_firewall_plugin_url')  . 
        
'&suppress=0">click here</a> to suppress them.'
        
: '';
        
        
        
$offending_url = $_SERVER['HTTP_HOST'] .$_SERVER['REQUEST_URI'] ;
        
        
        
$variable_explain_url   = 
        
'http://www.seoegghead.com/software/wordpress-firewall-security-filters.seo#'
        
. $attack_type;

        
$turn_off_email_url     = get_option('WP_firewall_plugin_url') 
        .
'&turn_off_email=1';
        
$whitelist_varibale_url = get_option('WP_firewall_plugin_url') 
        . 
'&set_whitelist_variable=' . $bad_variable ;
            
        
$message =<<<EndMessage
        <h3>WordPress Firewall has <font color="red">detected and blocked</font> 
        a potential attack!</h3>
        <table border="0" cellpadding="5">
        <tr>
        <td align="right"><b>Web Page:&nbsp;&nbsp;</b></td>
        <td>
$offending_url <br />
        <small>Warning:&nbsp;URL may contain dangerous content!</small>
        </td>
        </tr>
        <tr>
        <td align="right"><b>Offending IP:&nbsp;&nbsp;</b></td>
        <td>
$offender_ip
    <a href="http://www.seoegghead.com/tools/where-is-that-ip.php?ip= 
$offender_ip">
        [ Get IP location ]
        </a>
        </td>
        </tr>
        <tr>
        <td align="right">
        <b>Offending Parameter:&nbsp;&nbsp;</b>
        </td>
        <td><font color="red"><b> 
$bad_variable = $bad_value </b></font></td>
        </tr>
        </table>
        <br />
        <table>
        <tr>
        <td align="left"> 
        This may be a "
$attack_category Attack."<br /><br />
        <a href="
$variable_explain_url">Click here</a> for more information
        on this type of attack.<br /><br /> If you suspect this may
        be a false alarm because of something you recently did, try to 
        confirm by repeating those actions. If so, whitelist it via
        the "whitelist this variable" link below.  This will prevent future false
        alarms.
        <br /><br />
        <a href="
$whitelist_varibale_url">Click here</a> to whitelist this 
        variable.
        <br /> 
        <a href="
$turn_off_email_url ">Click here</a> to turn off these emails.
        </td>
        <tr>
        <td>
$suppress_message</td>
        </tr>
        </table>
        <br />
             
        <div style="float:right; position:relative; top:-80px;">
        <a 
    href="http://www.seoegghead.com/software/wordpress-firewall.seo" 
        style="text-decoration:none;" target="_blank">
        <img src=
    "http://www.seoegghead.com/cms_pics/seoegghead_embedded_smaller_faded.png"
        border="0" />
        <br />
        <small>Click here for plugin documentation.</small>
        </a>
        <br />
        <small>Got Questions or Feedback? 
        <a style="text-decoration:none;" href=
        "http://www.seoegghead.com/about/contact-us.seo?subject=
        WP+Firewall+Feedback"
        target="_blank">Click here.</a>
        </small>
        <br />
        <small>By using this plugin you agree to 
        <a style="text-decoration:none;" 
        href="http://www.seoegghead.com/software/free-software-disclaimer.seo"
        target="_blank">this simple disclaimer.
        </a>
        </small>    
        </div>
        
EndMessage;
    
        
$address = get_option('WP_firewall_email_address');
        
$subject = 'Alert from WordPress Firewall on ' 
        
. get_option('siteurl');
        
$header = "Content-Type: text/html\r\n";        
        
$header .= "From: " . $address . "\r\n";        
        
mail($address,$subject,$message, $header);
    }
    
    
update_option('WP_firewall_previous_attack_var', $bad_variable);
    
update_option('WP_firewall_previous_attack_ip', $offender_ip);
}

function 
WP_firewall_check_ip_whitelist(){
    
$current_ip = $_SERVER['REMOTE_ADDR'];
    
$ips = unserialize(get_option('WP_firewall_whitelisted_ip'));
    if(
is_array($ips)){
        foreach(
$ips as $ip){
            if( 
$current_ip == $ip || $current_ip == gethostbyname($ip)){
                return 
true;
            }
        }
    }
    return 
false;
}

function 
WP_firewall_array_flatten($array, &$newArray, 
    
$prefix='',$delimiter='][',  $level = 0) {
    foreach (
$array as $key => $child) {
        if (
is_array($child)) {
            
$newPrefix = $prefix.$key.$delimiter;
            if(
$level==0){$newPrefix=$key.'[';}
            
$newArray =& WP_firewall_array_flatten($child, $newArray, 
            
$newPrefix, $delimiter, $level+1);
        } else {
            (!
$level) ?$post='' : $post=']';
            
$newArray[$prefix.$key. $post] = $child;
        }
    }
    return 
$newArray;
} 

function 
WP_firewall_assert_first(){
    
$active_plugs = (get_option('active_plugins'));
    
$active_plugs = array_diff($active_plugs, array("wordpress-firewall.php"));
    
array_unshift($active_plugs, "wordpress-firewall.php");    
}
add_action('admin_menu', 'WP_firewall_admin_menu');

function 
WP_firewall_admin_menu() {
    
add_submenu_page('options-general.php','Firewall',
    
'Firewall', 10, __FILE__, 'WP_firewall_submenu');
}

function 
WP_firewall_submenu(){
    
    
WP_firewall_assert_first();
    
    
$action_url = $_SERVER['REQUEST_URI'];
    if (
$_REQUEST['set_exclusions']){
        
update_option('WP_firewall_redirect_page',
        
$_REQUEST['redirect_type']);                    
        
update_option('WP_firewall_exclude_directory', 
        
$_REQUEST['block_directory']);
        
update_option('WP_firewall_exclude_queries', 
        
$_REQUEST['block_queries']);
        
update_option('WP_firewall_exclude_terms', 
        
$_REQUEST['block_terms']);
        
update_option('WP_firewall_exclude_spaces', 
        
$_REQUEST['block_spaces']);
        
update_option('WP_firewall_exclude_file', 
        
$_REQUEST['block_file']);        
        
update_option('WP_firewall_exclude_http', 
        
$_REQUEST['block_http']);
        
        echo 
'<div class="updated fade">
        <p>Security Filters and Redirect page updated.</p>
        </div>'
;        
    } elseif(
$_REQUEST['turn_off_email']){
        
        
update_option('WP_firewall_email_address', '');
        
        
$action_url = str_replace('&turn_off_email=1','',
        
$_SERVER['REQUEST_URI']);
        echo 
'<div class="updated fade">
        <p>Emails are now turned off.</p>
        </div>'
;        
    
    } elseif(
$_REQUEST['set_whitelist_variable']){
        echo 
'<div class="updated fade"><p>Whitelisted '
        
. $_REQUEST['set_whitelist_variable'] .'</p></div>';

        
$pages       = unserialize(
        
get_option('WP_firewall_whitelisted_page'));
        
$variables      = unserialize(
        
get_option('WP_firewall_whitelisted_variable'));    
        
$pages[]        = '';
        
$variables[] =    $_REQUEST['set_whitelist_variable'];

        
update_option('WP_firewall_whitelisted_page', serialize($pages));
        
update_option('WP_firewall_whitelisted_variable', 
        
serialize($variables));        
        
        
$action_url = str_replace(('&set_whitelist_variable=' . 
        
$_REQUEST['set_whitelist_variable']),'',$_SERVER['REQUEST_URI']);
        echo 
'<div class="updated fade">
        <p>Whitelisted Variable set.</p>
        </div>'
;
        
    } elseif(
$_REQUEST['set_email']){
        
update_option('WP_firewall_email_address', 
        
$_REQUEST['email_address']);
        
update_option('WP_firewall_email_limit', 
        
$_REQUEST['email_limit']);    
        echo 
'<div class="updated fade">
        <p>Email updated.</p>
        </div>'
;        
    } elseif(
$_REQUEST['set_whitelist_ip']){
        
update_option('WP_firewall_whitelisted_ip', 
        
serialize($_REQUEST['whitelisted_ip']));
        echo 
'<div class="updated fade">
        <p>Whitelisted IP set.</p>
        </div>'
;        
    } elseif(
$_REQUEST['set_whitelist_page']){
        
update_option('WP_firewall_whitelisted_page', 
        
serialize($_REQUEST['whitelist_page']));
        
update_option('WP_firewall_whitelisted_variable',
        
serialize($_REQUEST['whitelist_variable']));
        echo 
'<div class="updated fade">
        <p>Whitelisted Page set.</p>
        </div>'
;        
    } elseif(
$_REQUEST['suppress'] === '0'){
        
        
update_option('WP_firewall_email_limit', 'off');
        echo 
'<div class="updated fade">
        <p>Email limit set.</p>
        </div>'
;        
        
$action_url = str_replace('&suppress=0','',
        
$_SERVER['REQUEST_URI']);        
    }

    
?> 
    <div class="wrap">    
    <h2>Firewall Options:</h2>
    <form name="set-exclusion-options" action="<?php echo $action_url; ?>
    method="post" >
    <h3>Apply Security Filters:</h3>
    <input type="checkbox" value="allow" name="block_directory" 
    <?php echo (get_option('WP_firewall_exclude_directory') == 'allow')
    ?
'checked="checked"':''?>
    > Block directory traversals (../, ../../etc/passwd, etc.) in application 
    parameters.<br />
    <input type="checkbox" value="allow" name="block_queries" 
    <?php echo (get_option('WP_firewall_exclude_queries') == 'allow') 
    ? 
'checked="checked"' :''?>
    > Block SQL queries (union select, concat(, /**/, etc.) in application 
    parameters.<br />
    <input type="checkbox" value="allow" name="block_terms" 
    <?php echo (get_option('WP_firewall_exclude_terms') == 'allow') 
    ? 
'checked="checked"' :''?>
    > Block WordPress specific terms (wp_, user_login, etc.) 
    in application parameters.<br />
    <input type="checkbox" value="allow" name="block_spaces" 
    <?php echo (get_option('WP_firewall_exclude_spaces') == 'allow') 
    ? 
'checked="checked"' :''?>
    > Block field truncation attacks in application parameters.<br />
    
    
    <input type="checkbox" value="allow" name="block_file" 
    <?php echo (get_option('WP_firewall_exclude_file') == 'allow') 
    ? 
'checked="checked"' :''?>
    > Block executable file uploads (.php, .exe, etc.)<br />

    
    
    <input type="checkbox" value="allow" name="block_http" 
    <?php echo (get_option('WP_firewall_exclude_http') == 'allow') 
    ? 
'checked="checked"' :''?>
    > Block leading http:// and https:// in application parameters 
    (<i>off</i> by default; may cause problems with many plugins).<br />
    
    
    <h3>Upon Detecting Attack:</h3>    
    <table class="form-table" border="0" 
    style="width:500px; margin-top:0; margin-bottom:1px;" >
    <tr>
    <td>Show 404 Error Page: </td>
    <td><input type="radio" name="redirect_type" value="404page"  
    <?php echo (get_option('WP_firewall_redirect_page') == '404page') 
    ? 
'checked="checked"' :''?> > 
    </td></tr>
    <tr>
    <td>Redirect To Homepage: </td>
    <td><input type="radio" name="redirect_type" value="homepage"  
    <?php echo (get_option('WP_firewall_redirect_page') == 'homepage') 
    ? 
'checked="checked"' :''?> >
    </td></tr>
    </table>    
    
    <small><b>Note:</b> All filters are subject to "Whitelisted IPs" 
    and "Whitelisted Pages"
    below.</small><br /><br />
    
    <input type="submit" name="set_exclusions" value="Set Security Filters">
    </form>    
    
    <h3>Email:</h3>
    Enter an email address for attack reports:<br /><br />
    <form name="email_address" action="<?php echo $action_url; ?>
    method="post" >
    <input type="text" value="<?php echo get_option('WP_firewall_email_address')?>"
    name="email_address" ><br />
    <small><b>Note:</b> Leave this setting blank to disable emails.</small>
    <br /><br />    
    Suppress similar attack warning emails:
    
    <input type="radio" name="email_limit" value="on"
    <?php echo (get_option('WP_firewall_email_limit') == 'on') ? 
    
'checked="checked"' :''?>>
    On
    
    <input type="radio" name="email_limit" value="off"
    <?php echo (get_option('WP_firewall_email_limit') == 'off') ? 
    
'checked="checked"' :''?>>
    Off

    <br /><br />
    <input type="submit" name="set_email" value="Set Email">
    
    </form>
    
    <h3>Whitelisted IPs:</h3>
    Enter IP(s) that are whitelisted &mdash; and not subject to security rules.
    
    <br /><br />
    <form name="whitelist_ip" action="<?php echo $action_url;?>" method="post">
    <?php
    
if( !get_option('WP_firewall_whitelisted_ip')){
        echo 
'<input type="text" value="" name="whitelisted_ip[]" >
        <br /><br />'
;    
    } else{
        
$ips = array_unique(unserialize(get_option('WP_firewall_whitelisted_ip')));
        foreach(
$ips as $ip){
            if(
$ip != ''){
                echo  
'<input type="text" value="' .$ip 
                
. '" name="whitelisted_ip[]" ><br />';    
            }        
        }
        echo  
'<input type="text" value="" name="whitelisted_ip[]" ><br />';    
    }
    
?>
    <small><b>Note:</b> Set field(s) to blank to disable IP whitelist. 
    Your current IP is: <b><?php echo $_SERVER['REMOTE_ADDR']?></b>.</small>
    <br /><br />
    <input type="submit" name="set_whitelist_ip" value="Set Whitelisted IPs">
    </form>
    
    <h3>Whitelisted Pages:</h3>    
    Enter page and/or form variables that are whitelisted &mdash; and not 
    subject to security rules:
    <form name="whitelist_page_or_variable" action="<?php echo $action_url; ?>
    method="post">    
    
    <table  cellspacing="0">
    <tr><td>Page:</td><td>Form Variable:</td></tr>
    <?php
    
if( !unserialize(get_option('WP_firewall_whitelisted_page')) 
    && !
unserialize(get_option('WP_firewall_whitelisted_variable'))  ){
        echo 
'<tr><td><input type="text" name="whitelist_page[]"></td>
        <td><input type="text" name="whitelist_variable[]"></td></tr><br />'
;    
    } else{
        
$pages     = unserialize(
        
get_option('WP_firewall_whitelisted_page'));
        
$variables = unserialize(
        
get_option('WP_firewall_whitelisted_variable'));
        
$count = 0;
        while(
$count < sizeof($pages)){
            if(
$pages[$count] != '' || $variables[$count] != ''){
                echo 
'<tr><td><input type="text" value="'. $pages[$count] 
                . 
'" name="whitelist_page[]"  ></td>
                <td><input type="text" value="'
. $variables[$count] 
                . 
'"name="whitelist_variable[]"></td></tr>';    
            }        
            
$count++;
        }
        echo 
'<tr><td><input type="text" name="whitelist_page[]"></td>
        <td><input type="text" name="whitelist_variable[]"></td></tr><br />'
;    
    }
    
?>    
    </table>
    <small><b>Note:</b> Set field(s) to blank to disable page whitelist.</small>
    <br />
    <small><b>Note:</b> Use *'s for wildcard characters.</small>    
    <br /><br />
    <input type="submit" name="set_whitelist_page" value="Set Whitelisted Pages">
    </form>
    <?php
    WP_firewall_show_plugin_link
();
    echo 
'</div>';
}

function 
WP_firewall_show_plugin_link(){
    
?>
    <div style="float:right; position:relative; top:-70px;">
    <a href="http://www.seoegghead.com/software/wordpress-firewall.seo"
     style="text-decoration:none;" target="_blank">
    <?php
    
if(preg_match('#MSIE#', $_SERVER['HTTP_USER_AGENT']) == 0) {
    
?>
    <img src="
    BxjAnBAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAADBQTFRFz6Ol
    opmRs21w48/P+Pb218bF9Orr6OTit7CpqVpdqaGZrmJlvYCD0ry769vc////wFM5SwAAAB
    B0Uk5T////////////////////AOAjXRkAAAJLSURBVHjatFXtDiMhCERF3Q/R93/bGxDX
    Xu5Pr2lJNk7pVHQYujS+FImov09Ng75VmM4zvU+V7xVu583vU7sVZo/CG7+kDRcL27qs4J
    VWfJ+N/+GMzdi7cAQVhfm4PEJlcXjUkVf64CHxtogySnN8N64Ppn6erc10Gd3zERQn3DGN
    ZIQGKq5LQ8ITnB+Y6073dK5oTBtDsxWUH3gmXGlF33nytFIFhfkKV68avSpOQDhLwhmk9t
    6vECoKUEpJtHA8bwFWg5T7jHlifZSSsXnBORtwArWWZIEdREUBvYAK/1MJ4bC6aAhumRkQ
    ResRLusW1oKmDJxBj1pMJ3OmCiET36Wdkadxon1XwNcc6+G76tTFfT+ptCWVkVAwGb7qFQ
    5lQYRDm1JdRhTPy8Tz6EPNUvVsaqpoHbh5dqEVW+e5QC9KuY1KnK+nxTKfoCLg8rqTrmkW
    xAZ/FfOjDxWhuxC2RuuI0oXcGTNldKfSGhuVVh8PXNz+iHS1Yj4Ubf+a/ZaquLgQKqd1w8
    cIxSrGFHqR33Q4lbIHJIWsQeYn9fqBVWA3lauRBWNcb6ymOAootnO5jNregu/ipCfQDWIH
    1c2wWk6Ze2oSP/CApx78Mh3McxXzj7cdLa0uo8qpV/KQsoes7Jk0Kh0rEvR98CjiMDMG3w
    MKioFqhqWJo3qoWYtt9TyiD1mw8U7Psfjoj5m9X2Ob5b9fKp+9A1+KiU/zbwvn6ZqozpQH
    958X3j6Ly2c2pj8vXB5/VLyCFi7j9zeWGQSvF/IP6ZMLjz8CDACmemOuUH7ZzQAAAABJRU
    5ErkJggg==" />
    <?php } ?>
    <br />
    <small>Click here for plugin documentation.</small>
    </a>
    <br />
    <small>Got Questions or Feedback? 
    <a style="text-decoration:none;" 
    href=
"http://www.seoegghead.com/about/contact-us.seo?subject=WP+Firewall+Feedback"
    target="_blank">
    Click here.
    </a>
    </small>    
    <br />
    <small>By using this plugin you agree to 
    <a style="text-decoration:none;" 
    href="http://www.seoegghead.com/software/free-software-disclaimer.seo"
    target="_blank">
    this simple disclaimer.
    </a>
    </small>    
    </div>
    <?php
}
?>