slicksky / spam-blacklist-query
Find out if a domain or IP is blacklisted on the most popular spam listing services.
Installs: 17 716
Dependents: 0
Suggesters: 0
Security: 0
Stars: 11
Watchers: 1
Forks: 0
Open Issues: 1
Requires
- php: >=8.0
Requires (Dev)
- larapack/dd: ^1.1
- mockery/mockery: ^1.5
- phpunit/phpunit: ^9.5
- rector/rector: ^0.15.2
- sempro/phpunit-pretty-print: ^1.4
README
This small package helps you find out if a domain or IP is blacklisted on the most popular spam listing services.
Here's how it works:
- Test the input domain against Domain Spam Blacklist services (DNSBL URI):
- APEWS Level 1 (http://www.apews.org/)
- Scientific Spam URI (https://www.scientificspam.net/)
- SEM URI (https://spameatingmonkey.com/)
- SEM URIed (https://spameatingmonkey.com/)
- SORBS URI (http://www.sorbs.net/)
- SpamHaus Zen (https://www.spamhaus.org/zen/)
- SURBL multi (https://surbl.org/)
- URIBL multi (https://uribl.com/)
- Retrieve mail servers for the given domain (MX records).
- Get the list of IPs for each mail servers (A records).
- Test each IP against these IP Spam Blacklist services (DNSBL IP):
- UCEPROTECT (https://www.uceprotect.net/en/)
- DroneBL (https://dronebl.org/)
- SORBS (http://www.sorbs.net/)
- SpamHaus Zen (https://www.spamhaus.org/zen/)
- SpamCop.net (https://www.spamcop.net/)
- DSBL (https://www.dsbl.org/)
Installation
Run this command in your project's root folder
composer require slicksky/blacklist-spam-query
Usage
require 'vendor/autoload.php'; use SlickSky\SpamBlacklistQuery\Domain; // Test a Domain $sampleDomain = 'google.com'; $domainResults = (new Domain($sampleDomain)) ->query(); // returns Collection // Get the listed records only $listedIps = $domainResults->listed(); // returns Collection // Ask if the domain or any IP records are listed $isListed = $domainResults->isListed(); // returns bool
Customizing blacklist services (DNSBL)
There are 4 sets of Blacklists in the Config class:
- Config::BLACKLISTS_IP - used to test IPs
- Config::BLACKLISTS_URI - used to test domains/subdomains
- Config::BLACKLISTS_EXTENDED - mixed list of most popular blacklists
- Config::BLACKLISTS_FULL - mixed list of all blacklists I've found so far In the Config class, you can customize blacklistsIp and/or blacklistsUri. If you omit any, the internal list will be used. If you want to turn off IP or URI queries, pass an empty array to blacklistsIp or blacklistsUri. Blacklist array template: ['service address' => 'name']
use SlickSky\SpamBlacklistQuery\Config; use SlickSky\SpamBlacklistQuery\Domain; $blacklists = new Config( blacklistsIp: ['dnsbl-1.uceprotect.net' => 'UCEPROTECT'], blacklistsUri: ['zen.spamhaus.org' => 'SpamHaus Zen'], ); $domainResults = (new Domain($sampleDomain, $blacklists)) ->query(); // returns Collection
Further customizations
use SlickSky\SpamBlacklistQuery\Blacklist; use SlickSky\SpamBlacklistQuery\Config; use SlickSky\SpamBlacklistQuery\MxIp; // Test a single IP $ip = new MxIp('8.8.8.8'); // Is this IP valid? $isInvalid = $ip->isInvalid(); // returns bool // Query the IP foreach (Config::BLACKLISTS_IP as $serviceHost => $serviceName) { $isListed = $ip->query( new Blacklist($serviceHost, $serviceName, $ip->reverse()), ); // returns bool } // Get the listed state $isListed = $ip->isListed(); // returns bool // Get the blacklists objects and their results $blacklistsResults = $ip->blacklists; // Collection
Results
SlickSky\SpamBlacklistQuery\Result::__set_state([ 'items' => [ SlickSky\SpamBlacklistQuery\MxRecord::__set_state([ 'host' => 'google.com', 'class' => 'IN', 'ttl' => 377, 'type' => 'MX', 'pri' => 10, 'target' => 'smtp.google.com', 'listed' => false, 'blacklists' => SlickSky\SpamBlacklistQuery\Collection::__set_state([ 'items' => [ SlickSky\SpamBlacklistQuery\Blacklist::__set_state([ 'listed' => false, 'host' => 'dnsbl-1.uceprotect.net', 'name' => 'UCEPROTECT', 'ipReverse' => 'google.com', 'responseTime' => 0.012, ]), ], ]), 'ips' => SlickSky\SpamBlacklistQuery\Collection::__set_state([ 'items' => [ SlickSky\SpamBlacklistQuery\MxIp::__set_state([ 'blacklists' => SlickSky\SpamBlacklistQuery\Collection::__set_state([ 'items' => [ SlickSky\SpamBlacklistQuery\Blacklist::__set_state([ 'listed' => false, 'host' => 'dnsbl-1.uceprotect.net', 'name' => 'UCEPROTECT', 'ipReverse' => '27.2.251.142', 'responseTime' => 0.012, ]), ], ]), 'invalid' => false, 'listed' => false, 'ip' => '142.251.2.27', ]), ], ]), ]), ], ])
License
The Spam Blacklist Query is open-sourced software licensed under the MIT license.