/find-peers

This website is meant to help students find peers that are working on the same project

Primary LanguageTypeScript

Find peers --> find-peers.codam.nl

This website is meant to help students to find peers that are working on the same project

Developing

Setup & configuration

  • Create a Oauth application on intra
  • Copy the file ./env/.env-example to ./env/.env and fill out the (secret) data

Also see ./src/env.ts for more configuration

Changing listed projects

  • The projects shown on the front page are listed in ./env/projectIDs.json. Should the curriculum change, you can edit that file. Remember to restart the server and wait for the server to pull all the data from the intra api.
  • A list of all the projects and their corresponding ID in the 42 network (as of march 2022) can be found in ./env/allProjectIDs.json

Updating the secrets / API tokens

cd find-peers
vim env/.env
# make changes
docker compose down
docker compose up -d

# To get logs
docker logs --tail 10000 -f find-peers

Monitoring

At the (unauthenticated) route /status/pull you can see a summary of the pull status of every campus It contains the key hoursAgo for every campus, which is the amount of hours since the last successful pull (syncing the 42 DB of the users' completed projects) of that campus This value should not be higher than 2 * the pull timeout (currently 24 hours)

Configuration files

File path Description Managed by server
./env/projectIDs.json List of all the projects and their corresponding ID to be displayed on the front page no
./env/allProjectIDs.json List of all projects in the 42 network (as of march 2022) no
./env/.env-example Example file for api tokens, rename to .env to activate no
./env/campusIDs.json List of all campuses and their corresponding ID that are fetched from the 42 API no
./database/ All database files, mount this when running in a docker container yes
./database/sessions/ All session files currently active yes
./database/users.json Userdata associated with session yes
./database/<campus_name>/lastpull.txt Unix timestamp when the project users of that campus were last successfully updated yes
./database/<campus_name>/projectUsers.json Status of users for each project yes

Running

The 'database' of this project is a folder called 'database' at the root of the project.

Docker and Docker-compose

This is in production

git clone https://github.com/codam-coding-college/find-peers.git
cd find-peers
docker compose up -d

# To get logs
docker logs --tail 10000 -f find-peers

Locally

  • Install Nodejs >= 18.x
  • Install dependencies
    npm install
  • Start development server
    npm run dev