The gallformers site
You must have npm and yarn installed for any of this to work. Go do that. I highly recommend using a node version manager of some kind. Or you can download node and yarn from here
The Easy Way™: Assumes you are on a Mac and have homebrew installed.
brew install nvm
nvm install 20
cd [wherever you cloned the repo]/gallformers
nvm use 20
corepack enable
yarn set version berry
yarn install
npx prisma generate
You will need to run generate
again if the DB schema is changed.
Now you can run the development server:
yarn dev
Open http://localhost:3000 with your browser to see the result.
You can build and run the prod version of the site:
yarn build
yarn start
To run in the docker container:
make build
make run-local
This should now make the site accessible on your local machine at http://localhost:3000
You can also create a tar of the docker image by running:
make save-image
The other commands are meant to be used on the server (at least until we get some deployment automation in place).
The whole site is built using next.js.
The datastore is a sqlite database. The schema can be seen in the initial migration script. There is a copy of the DB committed to the repo for ease of testing etc. The prod database is on a volume attached to the server.
The APIs for accessing the data from the front-end are implemented in Prisma and are all called from the server (either statically rendered at build time or rendered on request if they could not be build statically, e.g., the search results).
All of the images are stored on AWS S3, currently under Jeff's personal account.
The domains (gallformers.org and gallformers.com) are registered using namecheap and are currently in Jeff's personal account.
The SSL certs are generated and auto-renewed via Let's Encrypt. There is a daemon process on the server that runs the auto-renewal process every 3 months.
There is a very simple down detector implemented as an AWS Lambda. The lambda checks the site every 2 minutes to see if it responds with an HTTP 200 response. If the site responds negatively more than once in the span of 5 minutes then an alert is sent out via a message sent from the lambda to AWS SQS to AWS SNS/CloudWatch. The CloudWatch alarm triggers another lambda that posts a message to the site-monitoring Slack channel and then SNS is used to send an email to Jeff.
There are also several alarms configured on the DO Droplet that hosts the server. These are all resource utilization alarms and will send messages to the site-monitoring Slack channel if triggered.
Changes to the schema must involve the following steps:
- Create a new migration script in migrations. It must be named such that it is one larger than the latest.
- Add all schema changes to the script. There is an
Up
andDown
sections. TheUp
section is where all of the changes go and then use theDown
section to undo those changes. This is so that if theUp
part fails the migration can rollback the changes. - Make the schema changes in the schema.prisma file. These need to match the changes in the migration script.
- Test, test, test. It is recommend that that you run your
Up
script against a copy of the database to make sure it works as expected. - Run
yarn migrate
to execute a migration. - Run
yarn generate
to generate a new Prisma client.
Because yarn is a PITA you will have to temporarily add the following to your dev dependencies for migration to work:
"better-sqlite3": "^7.1.1",
"better-sqlite3-helper": "^3.1.1",
"sqlite": "^4.0.15"
If you leave them in you will not be able to build with docker as better-sqlite3
requires python to build and there is no python in the docker container.
TBD. For now manual snapshots of the block volume are all we have. All of the source is on github and the site can be re-created from scratch on a new instance from the files there. The only real back up needed is the database.
The front-end is mostly static pages as we expect most of this data to not change frequently. next.js is built on React so you will need some familiarity with that to work on the site. The look-and-feel is built with react-bootstrap. Custom components are placed in the pages/components directory and global layout components in pages/layouts.
The site is deployed on a Digital Ocean droplet with a mounted volume that contains the database. Details of how to access this etc. are not appropriate for this README.
Currently user management is handled via Auth0. They have a reasonable free-tier that gives us what we need for our current minimal needs. All user management happens via the Auth0 management console. The site is generally meant to be accessed without authentication. Authentication and authorization is only needed for data management/curation features.