demo_albgarci

Proof of concept with the Haveibeenpwned API

Built on Next.js, with Chakra UI and Chart.js Chart.js, embedded in a Docker container

Live demo

https://poc-haveibeenpwned.vercel.app/

Instructions:

Requirements for deployment:

Deployment with docker:

  • Clone this repo, and in the root folder type make
  • Wait until server is built and running (you can see log trace by typing make logs)
  • Server will be ready in http://localhost:3000

Other useful commands:

  • make up: start container
  • make build: build docker image
  • make down: stop container
  • make clean: remove /node_modules && /.next folders
  • make fclean: purge all docker cache from the computer
  • make logs: print logs from the next.js server

Features

Two pages:

Signup page:

It’s a fake signup form, with real field validations:

  • Email: format (by regex)
  • Password: checks https://haveibeenpwned.com/API/v3#PwnedPasswords to see if the introduced password has been reported as leaked in any hacked website.
  • Once the two fields are valid, the user is redirected to /charts.

Charts: responsive page with two data charts

Responsive page with two data charts:

Components

All components have been created to be as reusable as possible to ease the application growth and maintainability: i.e: AlertBox.js, BoxCharts.js

Enabled endpoints

Endpoint Example query What it serves
http://localhost:3000/api/breachedsites http://localhost:3000/api/breachedsites Simplified version of https://haveibeenpwned.com/api/v3/breaches with the minimum data needed to build the charts
http://localhost:3000/api/exposed?hash= {5 first letter of SHA-1 encoded pass} http://localhost:3000/api/exposed?hash=2BD11 JSON formatted version of https://api.pwnedpasswords.com/range/2BD11
http://localhost:3000/api/breachedtypes http://localhost:3000/api/breachedtypes http://localhost:3000/api/breachedtypes?top=10 Count of data types leaked in breached sites, sorted descending, and with option to filter top N. All data types are from: https://haveibeenpwned.com/api/v3/dataclasses , the hacked sites are taken from https://haveibeenpwned.com/api/v3/breaches , and this endpoint is the join of both