stop-spammers-classic/modules/chkreferer.php
2025-09-13 16:55:35 -06:00

50 lines
No EOL
1.6 KiB
PHP

<?php
if ( !defined( 'ABSPATH' ) ) {
status_header( 404 );
exit;
}
class chkreferer extends be_module {
public $searchname = 'HTTP_REFERER check';
public function process( $ip, &$stats = array(), &$options = array(), &$post = array() ) {
// only check this on posts, but we can double check
if ( !isset( $_SERVER['REQUEST_METHOD'] ) || $_SERVER['REQUEST_METHOD'] !== 'POST' ) {
return false;
}
$ref = '';
// made it this far - there is a post
if ( array_key_exists( 'HTTP_REFERER', $_SERVER ) ) {
$ref = sanitize_text_field( wp_unslash( $_SERVER['HTTP_REFERER'] ) );
}
$ua = '';
if ( array_key_exists( 'HTTP_USER_AGENT', $_SERVER ) ) {
$ua = sanitize_text_field( wp_unslash( $_SERVER['HTTP_USER_AGENT'] ) );
}
$a = array( false, '' );
if ( strpos( strtolower( $ua ), 'iphone' ) === false && strpos( strtolower( $ua ), 'ipad' ) === false ) {
return false;
}
// require the referer
// check to see if our domain is found in the referer
$host = isset( $_SERVER['HTTP_HOST'] ) ? sanitize_text_field( wp_unslash( $_SERVER['HTTP_HOST'] ) ) : '';
if ( empty( $ref ) ) {
return 'Missing HTTP_REFERER';
}
if ( empty( $host ) ) {
return 'Missing HTTP_HOST';
}
// some servers have an empty host for some reason
// some servers and links from https to http and back don't send a referer
if ( empty( $ref ) ) {
return false;
} // had to do this because sometimes legit ones are null?
if ( strpos( strtolower( $ref ), strtolower( $host ) ) === false ) {
// bad referer - must be from this site
return 'Invalid HTTP_REFERER';
}
return false;
}
}
?>