Skip to content

Latest commit

 

History

History
223 lines (171 loc) · 8.99 KB

README.md

File metadata and controls

223 lines (171 loc) · 8.99 KB

HackTJ Portal

wakatime

A project submission platform for participants at HackTJ.

Setup

Google OAuth2

Full instructions can be found here.

Make sure to:

Application

The portal is a Django-based web application that handles project submissions, team management, and judging for HackTJ. It integrates with Google OAuth2 for authentication and uses a whitelist-based access control system.

Dependencies: (see pyproject.toml)

  • django is the web framework used
  • social-auth-app-django handles Google OAuth2 signup/login
  • django-bootstrap5 helps with UI design
  • rules is used to manage user permissions
  • django-extensions adds useful CLI management tools
  • black is a code formatter

To install dependencies, run:

poetry install

Then, set up your project settings:

cd portal/settings
cp dev.secret.py secret.py

Make sure to edit secret.py with your Google OAuth2 client ID and secret.

Finally, create your database and apply migrations with:

poetry run python manage.py migrate

Run

The app can be run in a terminal with:

poetry run python manage.py runserver

Alternatively, a PyCharm run configuration can be found in .run/. This should automatically be detected when opening the project.

Security and Access Control

Email Whitelisting

The portal uses email whitelisting to control access to the application. There are three levels of whitelisting:

  1. User Whitelist (user_email_whitelist.txt): Controls basic access to the portal
  2. Team Whitelist (team_email_whitelist.txt): Identifies HackTJ team members with elevated permissions
  3. Admin Whitelist (admin_email_whitelist.txt): Designates administrative users

Whitelist files should be placed in the secrets/ directory. The system will function without these files, but access will be restricted in production unless whitelisting is explicitly disabled.

Configuration options:

  • SOCIAL_AUTH_FORCE_USE_WHITELIST: Forces whitelist checking even in development
  • SOCIAL_AUTH_FORCE_IGNORE_WHITELIST: Disables whitelist checking (use with caution)

Permissions Model

The portal implements a hierarchical permissions system:

  1. Regular Users (is_participant):

    • Can create one project
    • Can view their own project
    • Cannot modify submitted projects
    • Cannot access admin features
  2. Team Members (is_team):

    • Elevated access to manage the event
    • Can view all projects
    • Can manage categories and locations
    • Identified through team whitelist
  3. Staff (is_staff):

    • Access to Django admin panel
    • Requires explicit staff status
    • Additional permissions needed for specific admin features
  4. Superusers (is_superuser):

    • Full system access
    • Can manage all aspects of the portal
    • Should be limited to technical administrators

Custom permission properties:

  • is_admin: Either a superuser or team member
  • is_admin_admin: Both an admin and staff member

Apps overview

Main

This app handles site-wide functionality, such as the homepage and authentication.

It's mainly composed of the user model, found in portal.apps.main.models.User. Some relevant fields are:

  • is_active: Allows users to be deactivated manually, blocking them from logging in
  • is_staff: Lets users log in to the built-in admin panel (Note: accessing panel features requires additional permissions)
  • is_superuser: Users have all permissions, including those for the admin panel
  • is_participant: The default role given to new accounts
  • is_judge: A special (currently unused) role for judges
  • is_team: A role designating HackTJ members with elevated permissions

Additionally, some custom permission properties are defined:

  • is_admin: is either a superuser (is_superuser) or a team member (is_team)
  • is_admin_admin: is both an admin (is_admin) and staff (is_staff)

Routes:

  • /: The homepage
  • /about/: The about page
  • /auth/complete/<str:backend>/: The OAuth2 callback URL
  • /auth/disconnect/<str:backend>/: Deletes the user account
  • /auth/disconnect/<str:backend>/<int:association_id>/: Disconnects the user from the given OAuth2 association
  • /auth/login/<str:backend>/: Starts the OAuth2 login flow
  • /login/: The login page
  • /logout/: Logs the user out

Categories

This app handles judging categories that projects can submit to. For example, "Best Web App" and "Best Mobile App." These categories are created and managed by the HackTJ team.

Fields:

  • Name (255 characters)
  • Description (4096 characters)
Action Route Permission required
List /categories/ is_admin
Add /categories/create/ is_admin
View /categories/<int:category_id>/ is_admin
Change /categories/<int:category_id>/update/ is_admin
Delete /categories/<int:category_id>/delete/ is_admin

Locations

Locations represent places teams will be at during both competition and judging. A project specifies a location to let judges know where they are located and where they can be judged. Locations will be manually created by the HackTJ team.

Fields:

  • Name (255 characters, optional)
  • Floor (one of 5, 6, 7, 8)
  • Room (a valid 5-character string, optional)
  • Capacity (positive small integer, optional)
Action Route Permission required
List /locations/ is_admin
Add /locations/create/ is_admin
View /locations/<int:location_id>/ is_admin
Change /locations/<int:location_id>/update/ is_admin
Delete /locations/<int:location_id>/delete/ is_admin

Projects

Projects are the main focus of the HackTJ portal, as they represent a team's submission to HackTJ. Each participant can create one project, and projects can have multiple team members.

Fields:

  • Name (255 characters)
  • Description (4096 characters)
  • Created at (automatically set)
  • Modified at (automatically set)
  • Members (list of Users)
  • Created by (a User, optional)
  • Modified by (a User, optional)
  • Categories (list of Categorys)
  • Location (a Location, optional)
  • Location description (1024 characters, optional)
  • Submitted status (boolean, defaults to false)

Project Rules:

  • Users can only create one project unless they are admins
  • Projects require either a location or location description
  • Only unsubmitted projects can be modified
  • Project members can view their project details
  • Admins can view all projects
Action Route Permission required
List /projects/ is_admin
Add /projects/create/ is_admin OR
is not a member of any other project
View /projects/<int:project_id>/ is_admin OR
is a member of the project
Change /projects/<int:project_id>/update/ (is_admin OR
is a member of the project) AND
project is not submitted
Delete /projects/<int:project_id>/delete/ is_admin OR
is a member of the project
Submit /projects/<int:project_id>/submit/ is_admin OR
is a member of the project
Change /projects/<int:project_id>/update/ is_admin OR
is a member of the project
Delete /projects/<int:project_id>/delete/ is_admin OR
is a member of the project
Leave /projects/<int:project_id>/leave/ is a member of the project
Kick from /projects/<int:project_id>/kick/<int:user_id>/ is a member of the project