xsist10 / haveibeenpwned
Client for the "Have I Been Pwned" API
Installs: 16 159
Dependents: 0
Suggesters: 0
Security: 0
Stars: 15
Watchers: 3
Forks: 8
Open Issues: 1
Requires
- php: >=5.5
- psr/log: ^1.0
Requires (Dev)
- monolog/monolog: ^1.23
- phpunit/phpunit: ^5.7
This package is auto-updated.
Last update: 2025-01-18 19:46:38 UTC
README
Install
{ "require": { "xsist10/haveibeenpwned": "~1.0" } }
Usage
Create manager instance
use xsist10\HaveIBeenPwned\HaveIBeenPwned; use xsist10\HaveIBeenPwned\Adapter\Curl; use xsist10\HaveIBeenPwned\Adapter\FileGetContents; // By default the $manager will use a Curl adapter $manager = new HaveIBeenPwned(); // You can create a new manager with a specified adapter $manager = new HaveIBeenPwned(new Curl()); // You can also set the adapter after creation $manager->setAdapter(new FileGetContents());
Check if you've been pwned
$manager->checkAccount("your_email_address");
Check if your account has been leaked in a paste
$manager->getPasteAccount("your_email_address");
Check if your password has been leaked before
// Your password is not sent to the remote API. Only a partial of the SHA1 // value is sent and all matching full SHA1 results are returned and compared. $numberOfTimesCompromised = $manager->isPasswordCompromised("your_password");
List all breaches that have are on record
$manager->getBreaches(); $manager->getBreach('specific_breach_by_name');
List the types of data that are covered when describing a leak
$manager->getDataClasses();
Logger Support
The adapters support PSR-3 Logger. I recommend using monolog.
Install Monolog
$ composer require monolog/monolog
Use Monolog with HaveIBeenPwned
use xsist10\HaveIBeenPwned\HaveIBeenPwned; use xsist10\HaveIBeenPwned\Adapter\Curl; use Monolog\Logger; use Monolog\Handler\StreamHandler; $log = new Logger('name'); // Push all logging up to the level of DEBUG to our log file $log->pushHandler(new StreamHandler('[full log filename]', Logger::DEBUG)); $adapter = new Curl(); $adapter->setLogger($log); $manager = new HaveIBeenPwned($adapter); // Calls made to HaveIBeenPwned will be logged to your log file now
Credits
- Troy Hunt for creating https://haveibeenpwned.com/
- Thomas Shone
- Chung-Sheng, Li
License
The MIT License (MIT). Please see License File for more information.