/whoishiring.work

Code for the website whoishiring.work

Primary LanguageJavaScriptMIT LicenseMIT

whoishiring.work

Runs the whoishiring.work.

Getting Started for Local Development

docker-compose up

The frontend is served at http://localhost:8000 and the backend is served at http://localhost:8080. The frontend container will live reload as you save your changes in the ./frontend directory.

You'll want to set environment variables DB_ADMIN_PASSWORD and DB_ADMIN using something like direnv.

Limitations

The populate-hn-data function only runs once, whereas it runs every 15 minutes in production. If you need fresher data, re-run the function locally or point your frontend to consume the production API endpoint.

Features

This is the both the present and WIP features list. If there are features you want added or modified, open a feature request issue.

  • Serve HTTPS traffic, and redirect HTTP to HTTPS.
  • Automate populate HN data every 15 minutes.
  • Update URLs for each month.
  • Pagination.
  • Client-side caching.
  • Deploy using terraform or cloudformation.
  • Automate deployments within GitHub.
  • Add search capability.
  • Add filtering capabilities: on-site, new, noted, applied, hidden, etc.
  • Add sorting capabilities: posted date, popularity, view count, company.
  • Add applied capabilities: each user can mark posts as "applied"
  • Add notes capability: users can manage private notes per post.
  • Add Ratings: users can rate each post and sort by rating
  • Users can mark posts as unread and filter posts by read/unread.
  • Users can hide posts, can undo hiding posts, and can filter posts by visibility.
  • Save searches as custom filters.
  • Add support for boolean OR and ANDs in searches.
  • Add ability to only show new posts since the last time the user visited.
  • Integrate with GitHub OAuth.
  • Dark Mode.

The Production Environment

All containers run in lambda functions with a manual trigger, except the populate-hn-data lambda function which runs every 15 minutes. The static assets from the frontend are copied into a S3 bucket with website capabilities turned on. CloudFront for this S3 website is enabled for caching and https services. The backend lambda function sits behind an API Gateway instance.

One key limitation to hosting gatsbyJS projects in S3 buckets, is Cloudfront does not redirect urls with subfolders to the subfolder's index.html. This limitation was resolved using a Lambda@Edge function with a Cloudfront trigger to redirect urls missing the index.html.

Deploying

The infrastructure is deployed via terraform. The ACM certificate for *.whoishiring.work is deployed manually, so that the subdomains can be for different environments/apps.

Deploying the Frontend

cd ./frontend
npm ci
GATSBY_API_URI="https://path.to/api" npm run build
npm run deploy

Note that the environment variable GATSBY_API_URI and your AWS credentials must be set in order to run the deploy script.

Migration to Terraform

Assume the npm ci has already run

  1. One job to zip and deploy the node_modules layers "node upload layers -f SERVICE" The terraform archive_file can create this with the same sha256
  2. One job to zip and deploy lambda code to S3 "node upload code -f SERVICE" The terraform archive_file can create this with the same sha256
  3. One job to deploy the infrastructure (api gateway, lambda, route53, sg, rds) "terraform"
  4. One job to deploy the S3 to lambda functions (or combine with #2?)

CI

  1. run audit in all folders of monorepo
  2. run tests in all folders of monorepo(?)

Containerizing the frontend

docker run -p 8000:8000 --rm -e "GATSBY_API_URI=https://path/to/api/server" whoishiringwork_frontend