- The prod branch has a CI/CD deployment available at: https://hackthechangeyyc.ca/
- The main branch has a CI/CD deployment available at: https://staging.hackthechangeyyc.ca/
Ensure you run npm i
in the root of the repo before continuing. Please respond 'y' to and prompts such as installing Husky, etc
-
All code should be written in React TypeScript v18.
-
VSCode Extensions: Recommended to get the
ESLint
for fast linting andPretty TypeScript Errors
for easier to debug TypeScript message -
It is recommended to use Node v20 or higher. All deployed code is run in environments using Node version 20. Run
node -v
to see your current version. -
Note: The Hackathon Management Tool's officialy-supported package manager shall be
npm
. Although you can use others, please be advised there will be limited support if you encounter issues.
https://docs.amplify.aws/gen2/start/account-setup/
npx ampx sandbox
It will take around 2-3 minutes for the backend to deploy. The sandbox is up when you see the given message in the console:
✨ Total time: 17.27s
After updating a data model, deploy a sandbox so that amplify_outputs.json is updated. This should automatically update the graphql files: mutations.ts, queries.ts, subscriptions.ts
.
npm run dev -- -- <profile name>
# or
yarn dev -- -- <profile name>
Open http://localhost:3000 with your browser to see the result.
TypeScript Practices https://docs.aws.amazon.com/prescriptive-guidance/latest/best-practices-cdk-typescript-iac/typescript-best-practices.html
Understanding AWS Amplify: https://docs.amplify.aws/react/start/
Note that we are using AWS Amplify gen 2 v1.0
Common Troubleshooting
- If you have a
HTTP error 431
and cannot load onto the frontend, try clearing your header cookies.
Make sure to set these variables in your local dev sandbox and the production environment.
npx ampx sandbox secret set <secret name> --profile <profile name>
Check the docs for more information
Key | value | Description |
---|---|---|
USER_VERIFICATION_KEY | [any string value you want] | Used for creating the MAC address for user UUID (used in food tickets) |
GOOGLE_CLIENT_ID | [any string value you want] | Used for the Google OAuth Client ID |
GOOGLE_CLIENT_SECRET | [any string value you want] | Used for the Google OAuth Client Secret |
Note: The 3rd party providers will not work locally even though the secret is set. This is because the actual value for these fields is not given out to local devs for security purposes. They will however work automatically on main since the actual values are set in the production/staging build environments
Make sure to set these variables in your local dev sandbox and the production environment.
In your local dev environment, create a file: .env.local
Check the docs for more information
Variable | value | Description |
---|---|---|
TIME_ZONE | "America/Edmonton" | For consistent timezones in the application |
Copy the file .env.local.example
and rename the file to .env.local
Food Ticket Generation: admins can make a food event, example: breakfast, lunch, dinner. Filling in details such as the name, description, start and end times, and the number of groups. Groups are how the food event will be split into multiple sections/intervals of people to ensure not everyone rushes for food at once. Groups are defined by the team ID of a user, so users in the same team are in the same food groups.
Food Ticket Code: clients, (or hackathoners), will call a url to get their authentication code. The code is as follows: [their uuid]:[the MAC of their user ID]. MAC Stands for Message Authentication Code. We use the SHA-256 Hash function with a secret key set in secrets, called "USER_VERIFICATION_KEY". This code serves the purpose of providing their uuid to us admins when we scan their QR code, and we use the MAC to ensure that the user ID is not tampered with.
Food Ticket Scanning: Admins will scan the usercode, and check the MAC to make sure it is not tampered with. They will check for other conditions to make sure that they can eat: the foodevent id being valid, the user not having attended the food event before, and they are in the right time slot. If they are in the wrong timeslot, they can still eat, but will notify the scanner of this. The scanned user will automatically be marked as having eaten at the event.
Different things that need to be initialized for judging panel to show:
- Room must exist where Room room id matches the TeamRoom room id
- TeamRoom must exist with roomId where the TeamRoom room id matches the Room room id, and Teams TeamId matches the Team id
- User with Judge role and JUDGERoomId where the Room id matches the JUDGERoomId
- Team must exist where id matches the teamroom team id
- Hackathon must be created as well through admin page or appsync