ByteDev.PwnedPasswords
1.1.0
See the version list below for details.
dotnet add package ByteDev.PwnedPasswords --version 1.1.0
NuGet\Install-Package ByteDev.PwnedPasswords -Version 1.1.0
<PackageReference Include="ByteDev.PwnedPasswords" Version="1.1.0" />
<PackageVersion Include="ByteDev.PwnedPasswords" Version="1.1.0" />
<PackageReference Include="ByteDev.PwnedPasswords" />
paket add ByteDev.PwnedPasswords --version 1.1.0
#r "nuget: ByteDev.PwnedPasswords, 1.1.0"
#:package ByteDev.PwnedPasswords@1.1.0
#addin nuget:?package=ByteDev.PwnedPasswords&version=1.1.0
#tool nuget:?package=ByteDev.PwnedPasswords&version=1.1.0
ByteDev.PwnedPasswords
Provides client functionality to talk to the pwnedpasswords API and check whether a particular password has been pwned and if so how many occurrences there have been.
Installation
ByteDev.PwnedPasswords has been written as a .NET Standard 2.0 library, so you can consume it from a .NET Core or .NET Framework 4.6.1 (or greater) application.
ByteDev.PwnedPasswords is hosted as a package on nuget.org. To install from the Package Manager Console in Visual Studio run:
Install-Package ByteDev.PwnedPasswords
Further details can be found on the nuget page.
Code
The repo can be cloned from git bash:
git clone https://github.com/ByteDev/ByteDev.PwnedPasswords
Unit tests and integration tests are also provided in the solution.
Usage
The PwnedPasswordsClient class has (since v1.1) only one public method:
- GetHasBeenPwnedAsync(HashedPassword hashedPassword)
This methods will return a PwnedPasswordResponse object containing details of whether the password has been pwned and a count of how many times.
If the PwnedPasswordsClient class has any problems getting the details for a password it will throw an PwnedPasswordsClientException.
Example
var hashedPassword = new HashedPassword("12345");
var client = new PwnedPasswordsClient();
var result = await client.GetHasBeenPwnedAsync(hashedPassword);
Console.WriteLine($"Has Password been pwned: {result.IsPwned}");
Console.WriteLine($"Password has been pwned {result.Count} times.");
Changes in v1.1
There used to be 3 different ways you could call the API:
- Search with clear text password
- Search with SHA1 hash of password
- Search with partial SHA1 hash of password
However, as of 1st June 2018 the API will be changed to only support option 3 (partial hash). Version 1.1 of this project now only supports partial hash searches.
Further information
See the following for more general information:
See the following to changes to the API to only support partial hash (range) only searches:
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
| .NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
| .NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
| .NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
| MonoAndroid | monoandroid was computed. |
| MonoMac | monomac was computed. |
| MonoTouch | monotouch was computed. |
| Tizen | tizen40 was computed. tizen60 was computed. |
| Xamarin.iOS | xamarinios was computed. |
| Xamarin.Mac | xamarinmac was computed. |
| Xamarin.TVOS | xamarintvos was computed. |
| Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- No dependencies.
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories (1)
Showing the top 1 popular GitHub repositories that depend on ByteDev.PwnedPasswords:
| Repository | Stars |
|---|---|
|
johnstaveley/SecurityEssentials
Raise your baseline in security by using this as your template instead of default Mvc project. Keep your app secure by continuously applying Security rules
|