TCQ is quite an old app and for to make it to work on contemporary systems, we are utilizing Docker to run the application in a containerized environment.
Apart from this, it was somewhat tightly coupled to CosmosDB - via the introduction of an adapter layer, this got now runtime configurable, so you can use either CosmosDB or MongoDB as a backend, or you can even write your own adapter for a different database.
Adapters are used to abstract the database layer, so you can use different databases without changing the application code. They are dynamically loaded on runtime, based on filename conventions and passed environment variables.
Currently, there are "things" that need to be adapted:
- db- the database connection and operations
- session-store- the session store for user sessions
Both used to be hardcoded to CosmosDB, but now you can choose between cosmosdb and mongodb as the database adapter.
For configuring the adapters, the following environment variables are used:
- TCQ_DB_ADAPTER- the database adapter to use, either- cosmos-dbor- mongodb, this will load the corresponding db adapter from ./src/server/adapters/db, by convention, the file should be named- <adapter>.db.adapter.ts(e.g.- cosmos-db.db.adapter.tsor- mongodb.db.adapter.ts).
- TCQ_SESSION_STORE_ADAPTER- the session store adapter to use, either- cosmos-dbor- mongodb, this will load the corresponding session store adapter from ./src/server/adapters/session-store, by convention, the file should be named- <adapter>.session-store.adapter.ts(e.g.- cosmos-db.session-store.adapter.tsor- mongodb.session-store.adapter.ts).
Adapters can have their own configuration, which can be set via environment variables, for example, currently the mongodb adapters require the following environment variables to be set:
- TCQ_DB_MONGODB_URIfor connecting to mongodb, e.g.- mongodb://db:27017/
- TCQ_DB_MONGODB_DBfor the db name, e.g.- tcq-reloaded-dev
- TCQ_SESSION_STORE_MONGODB_URIfor connecting to mongodb,- mongodb://db:27017/
- TCQ_SESSION_STORE_MONGODB_DATABASEfor the db name, e.g.- tcq-reloaded-dev
Currently adapters are pretty simple, they just have to export a set of functions that are used by the application, have a look at the existing adapters in ./src/server/adapters/db and ./src/server/adapters/session-store to get an idea of how they work.
You either need a build-enabled Node 10.19.0 or you can use the provided dockerized builder to build the application. The latter is recommended, as it will ensure that the build works in a consistent environment.
For initially building the builder (quis custodiet ipsos custodes), simply run docker compose build builder, this will create tc39/tcq-reloaded-builder that has all the necessary dependencies to build the application and enable the following commands to work:
- npm run docker:npm- runs- npmin the builder container, so you can run any npm command inside the container
- npm run docker:build-frontend- builds the frontend application
- npm run docker:build-backend- builds the backend application
- npm run docker:build-production- builds both the frontend and backend applications for production
For actually building the application, you need to run the following commands:
npm run docker:npm install
npm run docker:npm run postinstall
npm run docker:build-production- You need a GitHub OAuth app with clientIdandclientSecret, these need to be set in.env-developmentthat you can copy over from.env-templateand setTCQ_LOCAL_GH_SECRET,TCQ_LOCAL_GH_IDandTCQ_SESSION_SECRET. ItscallbackUrlshould be set tohttp://localhost:3000/auth/github/callback.
- You can easily provide a local MongoDB instance via docker composeas well, simply uncommentTCQ_SESSION_STORE_*andTCQ_DB_*(see above for adapters)
If you have a proper build and database (e.g. docker compose up db), you can then run a dev container with docker compose up dev and access the application at http://localhost:3000.
You can use AWS Copilot to deploy the application to AWS, this will create a new ECS service with a load balancer and all the necessary resources. You can follow the AWS Copilot documentation for more information on how to set it up. Once setup, some secrets need to be set in the AWS Secrets Manager, these are:
- TCQ_GH_SECRET- the GitHub OAuth client secret
- TCQ_SESSION_SECRET- the session secret for signing cookies
- TCQ_GH_ID- the GitHub OAuth client ID
and because currently the copilot application is configured (in ./copilot/tcq/manifest.yml) to use MongoDB as the database, you also need to set the following secrets:
- TCQ_DB_MONGODB_URI- must be a MongoDB URI for connecting to the database
- TCQ_SESSION_STORE_MONGODB_URI- must be a MongoDB URI for connecting to the session store
They can be set via the AWS Copilot CLI with the following commands:
copilot secret init --name TCQ_GH_SECRET
copilot secret init --name TCQ_SESSION_SECRET
copilot secret init --name TCQ_GH_ID
copilot secret init --name TCQ_DB_MONGODB_URI
copilot secret init --name TCQ_SESSION_STORE_MONGODB_URIN.B. Currently the supplied ./copilot/tcq/manifest.yml is hard-coded to deploy at
tcq.ninja, if you want to deploy it to a different domain, you need to change the manifest file accordingly.