Library for easily interfacing with Have I Been Pwned API v2.
Project description
pwnedapi
(Have I Been Pwned)
A small utility class to leverage Troy Hunt's Have I Been Pwned API v2 and the k-Anonymity model. Inspired by Phil Nash's Ruby gem pwned.
Installation
# From repository
pipenv install pwnedapi
# Locally after cloning
python setup.py install
Usage
In its simplest form you'll only need to use two methods. Will probably add more if and when the API grows.
>>> from pwnedapi import Password
>>> password = Password("mysupersecretpassword")
>>>
>>> if password.is_pwned():
... print(f"Your password has been pwned {password.pwned_count} times.")
...
Your password has been pwned 2 times.
>>>
You can also scan a file of passwords, and export results in any format supported by the tablib
library.
>>> from pwnedapi import Scanner
>>> scanner = Scanner()
>>> scanner.scan("passwords.txt")
>>> scanner.export_as("leaked.json")
>>> open("leaked.json").read()
'[{"Password": "dog", "Leak Count": 28348}, {"Password": "cat", "Leak Count": 26354}, {"Password": "somepass", "Leak Count": 657}]'
Contributing
Check the source code and issues from this repository, and should anything interesting pop out feel free to open a pull request. Before your changes will be merged make sure that Travis CI pipeline is green and code coverage is on acceptable level. GitHub takes care of these eventually but to save time always consider running the tests locally before pushing.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for pwnedapi-0.5.0-py2.py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | b2ff93d39ea2f0660a34f65b35a4de0981065cf4f069b3d261fac6cad87b3519 |
|
MD5 | 908d4dac42799a6bd6ef2540d0688ecf |
|
BLAKE2b-256 | e2efe1960a48ca3645246b49dd540e681576fa69da3863f5f2af3ce855f676ad |