Skip to content

Latest commit

 

History

History
62 lines (52 loc) · 1.57 KB

README.md

File metadata and controls

62 lines (52 loc) · 1.57 KB

magic-link-auth

Authentication proof-of-concept. A "magic link" is sent to one's inbox and a GET request validates the hash and drops a JWT token.

Status

  • POST to /[email protected] sends HTML email to [email protected] containing link to web app
  • Web app authentication page makes GET request to /auth/{hash}, consulting database
  • Cookie is dropped on client, storing authentication info
  • Invalidate used/expired hashes
  • Only store a single hash for each email address
  • Ensure email address exists in user table before generating and storing a hash

Develop

#!/bin/sh

SMTP_SERVER="..."
EMAIL_ADDRESS="[email protected]"
EMAIL_PASS="..."

POSTGRES_HOST="..."
POSTGRES_PORT="5432"
POSTGRES_USER="..."
POSTGRES_PASSWORD="..."
POSTGRES_DBNAME="..."

env \
  SMTP_SERVER=$SMTP_SERVER \
  EMAIL_ADDRESS=$EMAIL_ADDRESS \
  EMAIL_PASS=$EMAIL_PASS \
  POSTGRES_HOST=$POSTGRES_HOST \
  POSTGRES_PORT=$POSTGRES_PORT \
  POSTGRES_USER=$POSTGRES_USER \
  POSTGRES_PASSWORD=$POSTGRES_PASSWORD \
  POSTGRES_DBNAME=$POSTGRES_DBNAME \
  fresh

Deploy

#!/bin/sh

SMTP_SERVER="..."
EMAIL_ADDRESS="[email protected]"
EMAIL_PASS="..."

POSTGRES_HOST="..."
POSTGRES_PORT="5432"
POSTGRES_USER="..."
POSTGRES_PASSWORD="..."
POSTGRES_DBNAME="..."

now \
  -e SMTP_SERVER=$SMTP_SERVER \
  -e EMAIL_ADDRESS=$EMAIL_ADDRESS \
  -e EMAIL_PASS=$EMAIL_PASS \
  -e POSTGRES_HOST=$POSTGRES_HOST \
  -e POSTGRES_PORT=$POSTGRES_PORT \
  -e POSTGRES_USER=$POSTGRES_USER \
  -e POSTGRES_PASSWORD=$POSTGRES_PASSWORD \
  -e POSTGRES_DBNAME=$POSTGRES_DBNAME