thasmo / honeypot-blacklist
A simple PHP library for querying the Project Honeypot Http:BL API.
v0.1.2
2016-03-21 20:17 UTC
Requires
- php: >=5.5.0
Requires (Dev)
- phpunit/phpunit: 4.7.*
- satooshi/php-coveralls: 0.6.*
This package is auto-updated.
Last update: 2024-11-08 21:34:10 UTC
README
A simple PHP library for querying the Project Honeypot Http:BL API.
Usage
Create a new instance
use Thasmo\ProjectHoneypot\Blacklist; $client = new Blacklist('127.0.0.1', 'api-key');
Create multiple instances
use Thasmo\ProjectHoneypot\Blacklist; # Set default API key. Blacklist::setDefaultKey('api-key'); # Use the default API key. $clientOne = new Blacklist('127.0.0.1'); # Use a specific API key. $clientTwo = new Blacklist('127.0.0.2', 'other-api-key'); # Use the default API key, again. $clientThree = new Blacklist('127.0.0.3');
Check for various types of clients
# Client is a search engine. $client->isSearchEngine(); # Client is suspicious. $client->isSuspicious(); # Client is a harvester. $client->isHarvester() # Client is a spammer. $client->isSpammer(); # Client is blacklisted. # Which means it is suspicious, a harvester or a spammer but not a search engine. $client->isListed();
Get last activity
# Get the last activity for the client in days. $lastActivity = $client->getActivity();
Get threat score
# Get the threat score of the client. $threatScore = $client->getThreat();
Check last activity
# Check if the client was active in the last 10 days. $isActive = $client->isActive(10);
Check threat score
# Check if the threat score is within the limit of 100. $isThreat = $client->isThreat(100);
Get the name for a search engine
# Get the name of the search engine. if($client->isSearchEngine()) { $name = $client->getName(); }
Get the API result
# Return an array holding the result from the API call $result = $client->getResult();
Change the address
use Thasmo\ProjectHoneypot\Blacklist; # Create an instance $client = new Blacklist('127.0.0.1', 'api-key'); # Get the result $result1 = $client->getResult(); # Set a new address which resets the object $client->setAddress('127.0.0.2'); # Get the new result $result2 = $client->getResult();
Query the API
use Thasmo\ProjectHoneypot\Blacklist; # Create an instance $client = new Blacklist('127.0.0.1', 'api-key'); # Query the API immediately $client->query(); # Use other methods if($client->isSearchEngine()) { $name = $client->getName(); }
Implementation Details
- Requests to the API are delayed until you first call a method like
isSearchEngine
etc. orquery
explicitly. - API responses for the same IP address on the same instance will be cached, the API will be queried only once.
- When changing the IP address via
setAddress
the cache is cleared and the API will be queried again.