Skip to content

A rewrite of my school's web framework in Python Flask

Notifications You must be signed in to change notification settings

ATCS-BCA/bca_web

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

bca_web

My rewrite of the BCA web framework in Python Flask
*Please use a Python 3.x virtual environment to avoid version issues

PyCharm Setup

  1. Install a recent Python 3.x version.
  2. Clone the project from GitHub
  3. Create a Python 3.x virtual environment (do not add to Git!)
  4. From the terminal inside PyCharm run "pip install requirements.txt". Alternatively, open requirements.txt and PyCharm will likely prompt you to install the requirements.
  5. Copy config.py to bca_web direectory but do not add to GitHub. (Ideally we will move this file up a directory soon.)

Running in Pycharm

Windows Instructions

set FLASK_APP=bca_web.py set FLASK_DEBUG=True flask run

Mac Instructions

export FLASK_APP=bca_web.py export FLASK_DEBUG=True flask run

Alternative Command Line Setup / Running

  1. cd bca_web - Navigate to the folder
  2. MAC OSX - brew install mysql
    Windows - https://dev.mysql.com/downloads/windows/installer/8.0.html https://www.lfd.uci.edu/~gohlke/pythonlibs/#mysql-python
  3. python setup.py install OR pip install requirements.txt OR CLICK install dependencies if using PyCharm
  4. MAC OSX - export FLASK_APP=bca_web.py
    Windows - set FLASK_APP=bca_web.py
  5. flask run

Debug Mode

Debug mode makes testing a lot easier and displays errors.
Always make sure to keep debug mode ON during Development and OFF during Production
export FLASK_DEBUG=True

Auth

  1. After successful email/password verification a JWT token is created for the current user and saved under the "bca_token" cookie.

  2. The token has the following payload: bca_token: { usr_id: Int, ip_address: Str, last_used: Int (Seconds), timeout_duration: Int (Seconds)}

  3. Upon every request, the cookie is verified, checked for timeout, and updated.

  4. The current user and their corresponding JWT token can always be accessed with the request context variable, g, under the attributes user and token respectively.

Contributors

  • Kate Kim
  • Eleana Pardo
  • Tara Yu
  • Daun Lee
  • Daniella Calle
  • Anthony Lekan
  • Aidan Glickman

About

A rewrite of my school's web framework in Python Flask

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 56.7%
  • CSS 10.5%
  • SCSS 10.2%
  • Less 9.1%
  • HTML 8.5%
  • Python 5.0%