Location: PHPKode > projects > My little forum > forum/modules/bad-behavior/bad-behavior/blackhole.inc.php
<?php if (!defined('BB2_CORE')) die('I said no cheating!');

// Quick and dirty check for an IPv6 address
function is_ipv6($address) {
	return (strpos($address, ":")) ? TRUE : FALSE;
}

// Look up address on various blackhole lists.
// These should not be used for GET requests under any circumstances!
// FIXME: Note that this code is no longer in use
function bb2_blackhole($package) {
	// Can't use IPv6 addresses yet
	if (@is_ipv6($package['ip'])) return false;

	// Workaround for "MySQL server has gone away"
	bb2_db_query("SET @@session.wait_timeout = 90");

	// Only conservative lists
	$bb2_blackhole_lists = array(
		"sbl-xbl.spamhaus.org",	// All around nasties
//		"dnsbl.sorbs.net",	// Old useless data.
//		"list.dsbl.org",	// Old useless data.
//		"dnsbl.ioerror.us",	// Bad Behavior Blackhole
	);
	
	// Things that shouldn't be blocked, from aggregate lists
	$bb2_blackhole_exceptions = array(
		"sbl-xbl.spamhaus.org" => array("127.0.0.4"),	// CBL is problematic
		"dnsbl.sorbs.net" => array("127.0.0.10",),	// Dynamic IPs only
		"list.dsbl.org" => array(),
		"dnsbl.ioerror.us" => array(),
	);

	// Check the blackhole lists
	$ip = $package['ip'];
	$find = implode('.', array_reverse(explode('.', $ip)));
	foreach ($bb2_blackhole_lists as $dnsbl) {
		$result = gethostbynamel($find . "." . $dnsbl . ".");
		if (!empty($result)) {
			// Got a match and it isn't on the exception list
			$result = @array_diff($result, $bb2_blackhole_exceptions[$dnsbl]);
			if (!empty($result)) {
				return '136673cd';
			}
		}
	}
	return false;
}

function bb2_httpbl($settings, $package) {
	// Can't use IPv6 addresses yet
	if (@is_ipv6($package['ip'])) return false;

	if (@!$settings['httpbl_key']) return false;

	// Workaround for "MySQL server has gone away"
	bb2_db_query("SET @@session.wait_timeout = 90");

	$find = implode('.', array_reverse(explode('.', $package['ip'])));
	$result = gethostbynamel($settings['httpbl_key'].".${find}.dnsbl.httpbl.org.");
	if (!empty($result)) {
		$ip = explode('.', $result[0]);
		// Check if threat
		if ($ip[0] == 127 && ($ip[3] & 7) && $ip[2] >= $settings['httpbl_threat'] && $ip[1] <= $settings['httpbl_maxage']) {
			return '2b021b1f';
		}
		// Check if search engine
		if ($ip[3] == 0) {
			return 1;
		}
	}
	return false;
}
?>
Return current item: My little forum