PHP 8.4 or above is required. For PHP 8.1 please use 2.0.0. For PHP 7.4 to 8.0 please use version 1.2.0.
A Have I Been Pwned API key is required. This can be obtained on a monthly subscription basis, or a one-off monthly access charge.
https://haveibeenpwned.com/API/v3#
To install this package via Composer:
composer require elliotjreed/haveibeenpwned
Return a count of all breaches for a specified email address (int
).
$guzzle = new \GuzzleHttp\Client();
$apiKey = 'HIBP-API-KEY';
$count = (new \ElliotJReed\HaveIBeenPwned\BreachedAccount($guzzle, $apiKey))->count('email@example.com');
Return details of all breaches for a specified email address (ElliotJReed\HaveIBeenPwned\Entity\Breach[]
).
$guzzle = new \GuzzleHttp\Client();
$apiKey = 'HIBP-API-KEY';
$breaches = (new \ElliotJReed\HaveIBeenPwned\BreachedAccount($guzzle, $apiKey))->breaches('email@example.com');
Return the names of the breaches for a specified email address (string[]
);
$guzzle = new \GuzzleHttp\Client();
$apiKey = 'HIBP-API-KEY';
$breachNames = (new \ElliotJReed\HaveIBeenPwned\BreachedAccount($guzzle, $apiKey))->breachNames('email@example.com');
Return a count of exposed passwords for a specified password (int
).
Note: This API call DOES NOT send the actual password to the Have I Been Pwned API, see: https://haveibeenpwned.com/API/v3#PwnedPasswords.
$guzzle = new \GuzzleHttp\Client();
$apiKey = 'HIBP-API-KEY';
$count = (new \ElliotJReed\HaveIBeenPwned\Password($guzzle, $apiKey))->count('password123');
Return details of a specified email address appearing on "pastes" online (\ElliotJReed\HaveIBeenPwned\Builder\Paste[]
).
$guzzle = new \GuzzleHttp\Client();
$apiKey = 'HIBP-API-KEY';
$pastes = (new \ElliotJReed\HaveIBeenPwned\PastedAccount($guzzle, $apiKey))->pastes('email@example.com');
Return all breach sources recorded by Have I Been Pwned (\ElliotJReed\HaveIBeenPwned\Entity\Breach[]
).
$guzzle = new \GuzzleHttp\Client();
$apiKey = 'HIBP-API-KEY';
$allBreaches = (new \ElliotJReed\HaveIBeenPwned\Breaches($guzzle, $apiKey))->allSources();
Return breach details by source name (\ElliotJReed\HaveIBeenPwned\Entity\Breach
).
$guzzle = new \GuzzleHttp\Client();
$apiKey = 'HIBP-API-KEY';
$breachesBySource = (new \ElliotJReed\HaveIBeenPwned\Breaches($guzzle, $apiKey))->bySourceName('Adobe');
Return breach details by domain name (\ElliotJReed\HaveIBeenPwned\Entity\Breach
).
$guzzle = new \GuzzleHttp\Client();
$apiKey = 'HIBP-API-KEY';
$breachesBySource = (new \ElliotJReed\HaveIBeenPwned\Breaches($guzzle, $apiKey))->byDomain('adobe.com');
Return the data classes used by Have I Been Pwned (string[]
).
$guzzle = new \GuzzleHttp\Client();
$apiKey = 'HIBP-API-KEY';
$haveIBeenPwnedDataClasses = (new \ElliotJReed\HaveIBeenPwned\DataClasses($guzzle, $apiKey))->all();
PHP 7.4 or 8.0 and Composer is expected to be installed.
For instructions on how to install Composer visit getcomposer.org.
After cloning this repository, change into the newly created directory and run:
composer install
or if you have installed Composer locally in your current directory:
php composer.phar install
This will install all dependencies needed for the project.
Henceforth, the rest of this README will assume composer
is installed globally (ie. if you are using composer.phar
you will need to use composer.phar
instead of composer
in your terminal / command-line).
Unit testing in this project is via PHPUnit.
All unit tests can be run by executing:
composer phpunit
To have PHPUnit stop and report on the first failing test encountered, run:
composer phpunit:debug
Static analysis tools can point to potential "weak spots" in your code, and can be useful in identifying unexpected side-effects.
Psalm is configured at it's highest levels, meaning false positives are quite likely.
All static analysis tests can be run by executing:
composer static-analysis
A standard for code style can be important when working in teams, as it means that less time is spent by developers processing what they are reading (as everything will be consistent).
Code format checking (via PHP Code Sniffer) can be run by executing:
composer phpcs
All of the tests can be run by executing:
composer test
Checking for outdated Composer dependencies can be performed by executing:
composer outdated
Checking that the composer.json is valid can be performed by executing:
composer validate --no-check-publish
If GNU Make is installed, you can replace the above composer
command prefixes with make
.
All of the tests can be run by executing:
make test
To run all the tests and report code coverage in Clover XML format (which many CI platforms can read, including Travis CI), add the following to your CI config (eg. .travis.yml):
script:
- composer ci
PHP coding standards are quite strict and are defined in ruleset.xml.
The rules are PSR-2 and PSR-12 standards with additionally defined rules.
The code formatting checks can be run by executing:
composer phpcs
To automatically fix any issues where possible, run:
composer phpcs:fix
This project is licensed under the MIT License - see the LICENCE.md file for details.