hack4impact-upenn / next-gen-scholars

(Next Generation Scholars Fall 2017): A portal for counselors and students to manage college application deadlines and tasks
MIT License
7 stars 1 forks source link
flask python3

Next Generation Scholars

Team Members

UPenn

University of Richmond

Setting up for Python 3

Must use Python3

Clone the repo
$ git clone https://github.com/hack4impact/next-gen-scholars.git
$ cd next-gen-scholars
Initialize a virtualenv
$ pip install venv
$ python3 -m venv env
$ source env/bin/activate

Note: you must use python3+

(If you're on a mac) Make sure xcode tools are installed
$ xcode-select --install
Add Environment Variables

Create a file called config.env that contains environment variables in the following syntax: ENVIRONMENT_VARIABLE=value. For example, the mailing environment variables can be set as the following. We recommend using Sendgrid for a mailing SMTP server. But anything else will work as well. You must have PLOTLY_USERNAME and PLOTLY_API_KEY set in order to run the application. Make an account on Plotly for more details.

PLOTLY_USERNAME=MyPlotlyUsername
PLOTLY_API_KEY=XXXXXXXXXXXX
MAIL_USERNAME=MySendgridUsername
MAIL_PASSWORD=MySendgridPassword
SECRET_KEY=SuperRandomStringToBeUsedForEncryption
CLIENT_SECRETS_FILE=NameOfFileWithClientSecret

Other Key value pairs:

Note: do not include the config.env file in any commits. This should remain private.

Install the dependencies
$ pip install -r requirements.txt
Other dependencies for running locally

You need Redis, and Sass. Chances are, these commands will work:

Sass:

$ gem install sass

Redis:

Mac (using homebrew):

$ brew install redis

Linux:

$ sudo apt-get install redis-server

You will also need to install PostgresQL

Mac (using homebrew):

$ brew install postgresql

Linux:

$ sudo apt-get install libpq-dev
Create the database
$ python3 manage.py recreate_db
Other setup (e.g. creating roles in database)
$ python3 manage.py setup_dev

Note that this will create an admin user with email and password specified by the ADMIN_EMAIL and ADMIN_PASSWORD config variables. If not specified, they are both flask-base-admin@example.com and password respectively.

[Optional] Add fake data to the database
$ python3 manage.py add_fake_data

Running the app

$ source env/bin/activate
$ honcho start -f Local

Formatting code

Before you submit changes to next-gen-scholars, you may want to autoformat your code with python manage.py format.

License

MIT License