- After downloading the repo, you need to set the following environmental variables:
- ACM_HSCC_DEBUG
- ACM_HSCC_DB_USERNAME
- ACM_HSCC_DB_PASSWORD
- ACM_HSCC_DB_HOST
- ACM_HSCC_DB_PORT
- ACM_HSCC_DB_NAME
- ACM_HSCC_MAIL_SERVER
- ACM_HSCC_MAIL_PORT
- ACM_HSCC_MAIL_USERNAME
- ACM_HSCC_MAIL_PASSWORD
- ACM_HSCC_MAIL_DEFAULT_SENDER
- ACM_HSCC_MAIL_USE_TLS
- ACM_HSCC_MAIL_USE_SSL
- ACM_HSCC_SITE_URL
- ACM_HSCC_APPLICATION_ROOT
- ACM_HSCC_THREADS_PER_PAGE
- ACM_HSCC_CSRF_SESSION_KEY
- ACM_HSCC_SECRET_KEY
- ACM_HSCC_SERVER_HOST
- ACM_HSCC_SERVER_PORT
- ACM_HSCC_ADMIN_PASSWORD
It helps to add these to a file (e.g. '~/.env_setup') and sourcing this from your .bashrc.
- Start the virtual environment:
source venv/bin/activate
- Install the required modules:
pip install -r .requirements
- Install MySQL and the python wrapper
- Create the user in MySQL defined in the environmental variables
- Launch
python
and run
from hscc import db
db.create_all()
Launch the server by running python run.py
- Install the previous on a server where you have admin privileges, I suggest DigitalOcean.
- Install nginx
- Run
uwsgi_start
- Add a new server location to nginx which points to 127.0.0.1:3205
- The following adds the website on the '/hscc' subdirectory. It can be accessed by visiting IP/hscc
server {
location = /hscc{ rewrite ^ /hscc/; }
location /hscc { try_files $uri @hscc; }
location @hscc {
include uwsgi_params;
uwsgi_pass 127.0.0.1:3205;
}
}
- If you want to have acm.cs.purdue.edu/hscc link to the website, set up a reverse proxy on the acm website.
Before making the site public, be sure to register yourself as an admin. To do this, go through the registration procedure on the website. Then, modify the database to grant yourself admin abilities. Ideally have another member also register themselves to the same team. This will prevent students from joining the admin team on accident.
Future Improvement: Add the ability to make teams/schools admin only, restricting who can join them. (Issue: #58)