Skip to content

jspolsky/queer-burners

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

This is the source code for the Queerburners website. It includes a simple content management system for editing pages, and an online directory of theme camps that is updated every year.

Here are some notes to future developers that want to modify this project.

Site Architecture

The site is built using Next.JS, a framework for React. This allows us to host it on Vercel. Because we don't get much traffic, the free Hobby Plan from Vercel is sufficient for our needs.

As of 2025, we are still using older versions of Next.JS (12.0), React, Bootstrap, React Bootstrap, and many other libraries. The latest versions of these libraries went through many, many non-backwards-compatible changes and we just don't have the cycles to port to newer versions for what is essentially a perfectly good working website.

The JavaScript website calls our own API which is running on AWS Lambda to save things like camp directory entries and page content. We also use AWS S3 to store user-uploaded pictures.

The Client Side

You'll find this code in the web subdirectory.

Many of the functions of the app require users to be logged on. The only method we provide for logging in users is Google OAuth 2.0 which means they just log on with their Google account; we don't need to secure their passwords or anything and Google sends us back a reliably email address.

When you are trying to develop code on your local machine, if you log on, you will notice that the OAuth flow causes you to be logged on to the production server at queerburners.org, not your local development server, which isn't helpful. To fix this, edit frontendUrl in definitions.js but don't check that change in.

As you develop code on your local machine in the web subdirectory, run

  • npm run build
  • npm run dev

which will launch a web server, and open your browser to http://localhost:3000 to test the changes you've made.

Once you're happy with your changes, commit them to github. That will make them live.

The Server Side (but it's serverless)

There are two major dynamic parts to the website: the content management system, which lets administrators add, edit, and delete individual pages of the site, and the Theme Camp Directory, which lets any LGBTQIA+ theme camp owner submit and edit information about their camp.

To store this data on the server, Queerburners has a RESTful API which is running on AWS. For example, this API supports functions like /camps which returns a JSON list of camps. You will find all the code for the API in the aws subdirectory.

  • Back end functions run on AWS Lambda -- they are all in node.js.
  • Those functions are accessed through a REST API via the AWS API Gateway. This component hooks up a URL to lambda code.
  • The definition of all of the API endpoints is in the file template.yaml which is an input file for the AWS Serverless Application Model (aka "SAM").
  • All the code that runs on the server is in the lambdasrc directory.
  • From the front end, we use the axios library to access the API.

Whenever the API needs to store some data:

  • User-uploaded images are stored in AWS S3. The are served to web browsers via CloudFront, a CDN which is faster at serving images than plain old S3.
  • Other data, like information about theme camps, is in Amazon DynamoDB, a simple NoSQL database that stores JSON objects. We access DynamoDB through the JavaScript DocumentClient library.

Here is a more complete list of technologies, frameworks, and libraries that are used to build Queer Burners Directory, along with links to the documentation.

  • DNS and web hosting for the static front end files is provided by Vercel. Vercel detects commits to this github project and deploys them automatically.
  • All user authentication comes through Google OAuth 2.0.
  • Because users can upload very high resolution images, we also store a thumbnail that is 960 pixels wide using the sharp library.
  • We send email through Amazon SES (Simple Email Service). Rather than talking to their library directory, we use Nodemailer to construct and send the email message via SES.

Some developer tricks

Your editor

I use VS Code with the Prettier code formatter by Esben Petersen. I always format on save which means that this project's indention/formatting style is just whatever Prettier does, which is really good. Don't check in code or submit pull requests that are not formatted according to that style.

The web directory

This is where you work on the front end and the react code.

Install node and npm to work on the website.

  • npm run build invokes the next.js build process, which makes your code ready to run locally.

  • npm run dev will start a local web server for testing, accessible as http://localhost:3000/

Once you have everything working locally:

  • Check it into github. Vercel will automatically pick it up and in a minute or two the new live site will appear at queerburners.org.

GitHub Pro Tip:

  • Always work in the dev branch, locally. When you get it working locally, commit and push your changes to the dev branch. Vercel will build this branch and serve it at a magic URL so you can test it. When you're happy, create a pull request with all the changes in dev and then merge it into master.

The aws directory

Anything that can't be done on the client side, for example, adding a new theme camp to the theme camp directory, is done through the Queerburners API which is implemented with Javascript functions living on AWS Lambda.

The aws directory is where all this server-side code goes.

To develop server-side code locally, you are going to have to install

You need to configure the aws cli. Instructions here. Our region is us-east-2 and the output format should be configured to json. You will need to get an access key and secret access key to do this.

Now:

  • lambdasrc contains the code for the lambda functions.

  • template.yaml is the SAM configuration that defines every function and its API gateway.

Ready to make changes to the server side code? First develop them locally.

  • Almost all the code you might want to modify is in aws/lamdbdasrc/multifunc.js

  • There is a tiny amount of Javascript in shared which is available on both the server and the client.

  • If you add new functions that need to be available through the web API, also add them in aws/template.yaml

  • From the directory aws, the script ./local-sam.sh launches the API on your local machine, in a docker instance, assuming you've set up your local machine according to these instructions. This allows you to test changes to the API or lambda functions without deploying those changes to AWS.

  • The file web/definitions.js lets you specify where the API is running. When you are testing locally with ./local-sam.sh, the api is at localhost:3001.

  • You may want to install Postman to test the API directly before you try to get it to work from the web front end.

  • When you run ./local-sam.sh, and hit the API locally via localhost:3001, you might get a 502 error. In the terminal window where ./local-sam.sh is running, you might see an error "No response from invoke container". This might mean that the version of the lambdalayer on the server is more recent than the one hardcoded in the script local-sam.sh. Log onto the AWS Lamba console, look under Additional Resources > Layers > NodeModulesLayer, then under VersionDetails you'll see a version number. Update local-sam.sh with this newer version number.

Once the server-side code is tested locally, you can deploy it to Amazon.

  • The script ./deploy-sam.sh deploys any changes you have made to the lamdba functions (locally) up to AWS.

  • This will make changes to the lambda functions up on AWS and also to the API Gateway.

  • The one thing that is NOT automatically deployed is a "google secret ID" used for logging on users with Google. So:

    • Log onto the AWS Lambda Console

    • Navigate into the function qb-google-idtoken-from-authcode

    • Scroll down to see the Environment Variables

    • Look at the googleSecretId environment variable. If it is missing, or if it says something like "ItsASecretDumbass", provide the real google secret ID. (This is not checked into the repository).

    • Repeat for the function qb-refresh-expired-token

If you need to modify any of the the shared code that is shared between the server and the client, this is a little bit tricky.

  • lambdalayer contains definitions describing any shared libraries that you need to use on AWS that need to be available for the code in lambdasrc. They are deployed to an AWS Lambda Layer. If you npm list in there you can see what libraries are currently a part of the layer on the server.

    • To add another library and make it available on the server, go into this directory, then npm install your new library. The next time you run deploy-sam.sh it will get deployed as a new version of the lambda library to the server.

    • This will increment the version number of the library on the server. If you are debugging locally with docker and local-sam.sh as described earlier, you will still be seeing the old version of the layer which is not helpful, since the version number of the lambda library is hardcoded. So log onto AWS Lambda console and see what the new version number is, and then update that in the local-sam.sh script.

About

QueerBurners.com theme camp directory

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •