The Techie Relationship Management (TRM) project at TechLabs provides a data platform to store & analyze all information we have about our Techies (participants). We want to know who they are and how they're doing throughout their journey to become a Digital Shaper.
This project aims to provide a standardized platform across TechLabs locations. It integrates with existing tools within the TechLabs organization, such as TypeForm, GSuite, and Slack. The TRM Dashboard is a web application for the local journey teams to view, edit, and analyze the data for their Techies to get actionable insights for improving the TechLabs experience.
- Techie Relationship Management page on Notion β used for scope & project planning, to-dos, and meeting notes
- Slack Channel on the TechLabs MGMT Slack workspace
As for the main components, we have Hasura, the TRM Dashboard, and some serverless functions for integrating external providers.
- The Hasura GraphQL engine provides a GraphQL API used by the TRM dashboard and provider integrations.
- The TRM Dashboard is a React single-page web application (SPA) based on the react-admin framework. See
/frontend/
for the dashboard source code. - The serverless functions in
/functions/
integrate the TRM project with external providers, such as for authentification with Google, retrieving form responses from TypeForm, and fetching activity data from edyoucated & Slack. - PostgreSQL is used for data storage & retrieval
We're happy that you want to work with us to make the TRM even more awesome! π
Try to work your way to the documentation & setup steps outlined below. If you have any questions or are stuck with the setup, do not hestitate to call for help on Slack! π
You should familiarize yourself with the architecture as described in the Architecture section. In particular, have a look what Hasura and react-admin are, and how they integrate with the GraphQL API.
This is a list of relevant resources like documentation, books, and conference talks:
-
Introduction to Hasura with React & Apollo
The TRM uses this exact stack in combination with react-admin as a user interface & frontend data management framework.
-
Introduction to GraphQL with Hasura
This introduction to GraphQL and how to use it with Hasura will familiarize yourself with the way React & Hasura play together behind the scenes. You will create a basic todo app and see how Hasura works with foreign key relationships, authorization, authentication and custom business logic.
The TRM uses Google Auth (provided by the
/functions/auth
serverless function) instead of Auth0, but the JSON Web Token (JWT) issuance & verification is the same.We use remote schemas and event triggers to integrate with Google Sheets, Typeform, and edyoucated.
-
React-Admin 30-minute tutorial
Marmelab's 30-minute react-admin tutorial will show you how react-admin works in combination with a simple placeholder data source. You'll see how to map API resources to the frontend, and how to customize the frontend.
The TRM will use Apollo with the Hasura GraphQL API for data storage & retrieval, but working with a simple JSON API first may be an easier way with less moving parts to learn react-admin.
-
YouTube Guides
If you're more into watching intro videos, have a look at these tutorials on YouTube:
If you feel like you have a general understanding how it works together, proceed to setup the development environment on your local machine as explained below.
Must-Have:
- Docker (Desktop) β Docker for Mac / Docker for Windows
May-Have:
Local NodeJS, Yarn and NPM installations are required in case you want to develop on your local machine instead of in a container.
-
Clone repository
-
Build images for Hasura & functions
docker-compose build --parallel
-
Start Postgres, Hasura & functions:
docker-compose up -d hasura
-
Start the frontend development server:
docker-compose up frontend
After 30s or so it should say
You can now view trm-frontend in the browser.
. -
Verify everything is running and healthy:
docker-compose ps
It should say
Up (healthy)
for every service. -
(Only required if developing locally) Setup frontend for development:
-
The following commands are assumed to be run in the
/frontend
directory (cd frontend
) -
yarn install
downloads the dependencies -
Run
cp config.example.js config.js
for an example config which is set up to work with the local database & Hasura instance you brought up withdocker-compose
.
-
-
Generate Sample Data
-
It is not much fun to work with an empty database. This is why there is an included data generator which you can use to populate the database with some near-realistic data. This generator is also used on the staging environment.
-
Generate some techies:
-
Create a Semester in the frontend and copy its UUID (shown in the location bar like
http://localhost:3000/#/semesters/UUID
) -
Run the techie generator:
docker-compose run --rm data-generator -- generate techies 100 --semester UUID --location LOCATION
(location is
BERLIN
, for example)
-
-
-
Frontend Development
-
yarn start
starts a development server on port 3000 with support for live code reloading.Run this in the
/frontend
directory (cd frontend
).It should open the browser at
http://localhost:3000
automatically.
-
-
Hasura Development
-
Run
docker-compose exec hasura hasura-cli console --address 0.0.0.0 --no-browser
and open http://localhost:9695 for the Hasura console. -
You can find the Admin Secret in
docker-compose.yml
(hasura
service, environment variables,HASURA_GRAPHQL_ADMIN_SECRET
) -
Authorization works with the Admin Secret, but you may want to use token authorization (e.g. for testing roles & permissions).
Generate a token with
docker-compose run --rm data-generator -- generate token --location BERLIN --team-member-id ID --functional-team JOURNEY --roles user,hr,journey
.Then add the
Authorization
header in the Hasura GraphQL Explorer withBearer TOKEN
as its value (replaceTOKEN
with the output of thegenerate token
command). -
(Optional, for setup) Generate new JWT Secret Key:
openssl rand 256 | base64
-
The project is deployed on Google Cloud Platform (GCP). Follow the guide for setting up GCP.
The infrastructure (see /infrastructure/
) is managed with Terraform in two projects:
/infrastructure/common
for all shared resources between environments: the Cloud SQL PostgreSQL database and a Google Artifact Registry Repository/infrastructure/app
provides resources for a specific environment: the Hasura instance as a Cloud Run service, and the serverless functions in Cloud Functions
The deployment process runs the GitHub Actions deploy
workflow for every push to the deployment branches:
staging
branch for the staging environmentproduction
branch for the production environment
The TRM Dashboard is deployed on GitHub pages. GitHub Actions builds the frontend and commits the build in the following repositories:
TechLabs-Berlin/trm-frontend-staging
β for the staging environmentTechLabs-Berlin/trm-frontend-production
β for the production environment
We appreciate any contribution and are happy to get in touch. If you see a problem, please open an issue in this repository. For write access to this repository, please send a message on our Slack Channel
To contribute code, we use a Pull Request workflow:
- Create a branch with your proposed changes and open a Pull Request
- We work with you for review and merge your code into the
main
branch.
Gitpod just recently announced they're now supporting Docker in their workspaces. The following guide will guide you through the setup process. It works quite well, though be aware they may be some quirks left.
Watch a Screencast of @Shark setting up the frontend on Gitpod.
Or follow these steps:
-
Go to gitpod.io/settings, login and enable "Feature Preview". Choose "Code" as Default IDE.
-
Go to https://gitpod.io/#https://github.com/TechLabs-Berlin/trm to create a new workspace for the TRM project.
-
Download and install newest docker-compose (https://docs.docker.com/compose/install/) in the workspace.
-
Run
sudo docker-up
. You need to leave the command running, thus open a new terminal by clicking on the plus icon. -
In
docker-compose.yml
, replace the keys underdepends_on:
with an array of the container names.Currently, the healthchecks don't work on Gitpod. This is why you need to tell docker-compose to bring up dependent services even though they are unhealthy. This step probably won't be necessary in the future.
-
Follow normal Setup guide
Ignore warnings about services being unhealthy.
-
In
/frontend
, copyconfig.example.js
toconfig.js
-
Go to Remote Explorer Tab in the Sidebar
- For Port 8000: Allow public access, copy URL & set as
authFnURL
- For Port 8080: Allow public access, copy URL & set as
graphqlApiURL
- For Port 8000: Allow public access, copy URL & set as
-
Open Port 3000 in the browser (click on the globe icon in the Remote Explorer Tab)
The TechLabs-Berlin/trm
project is licensed MIT. Learn more about MIT license on choosealicense.com.