Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Dockerized Faculty Tools #22

Open
wants to merge 52 commits into
base: develop
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 18 commits
Commits
Show all changes
52 commits
Select commit Hold shift + click to select a range
cb65910
Dockerized Faculty Tools
ssilverm Mar 30, 2021
b0031a6
Removing settings.py.template
ssilverm Apr 6, 2021
ea97747
Fixes naming confusion
ssilverm Apr 6, 2021
c5bc16e
CI test
ssilverm Apr 6, 2021
1a1532f
CI test
ssilverm Apr 6, 2021
32300df
CI test
ssilverm Apr 6, 2021
5dd2415
CI test
ssilverm Apr 6, 2021
9c1cb3e
flake8
ssilverm Apr 6, 2021
2601e5d
black
ssilverm Apr 6, 2021
0721d34
CI/CD + black
ssilverm Apr 6, 2021
3d1cee5
README MDL
ssilverm Apr 7, 2021
98ee7b9
Trying with nginx and uwsgi files
ssilverm Apr 7, 2021
a5d3d5f
README
ssilverm Apr 7, 2021
71e6278
README
ssilverm Apr 7, 2021
2ec1f22
Load ENV?
ssilverm Apr 7, 2021
58952fd
.env
ssilverm Apr 7, 2021
8d8cf31
Fixing status test
ssilverm Apr 20, 2021
0851770
Key / Secret env template
ssilverm Apr 20, 2021
d916489
Better dockeriziation
ssilverm Mar 29, 2022
db4b2d4
Fixed linting
ssilverm Mar 30, 2022
30b4620
testing github docker image push
ssilverm Mar 31, 2022
9c523bb
req + on needs
ssilverm Mar 31, 2022
1b56e91
CICD
ssilverm Mar 31, 2022
5c8096a
cicd
ssilverm Mar 31, 2022
912864c
requirements?
ssilverm Mar 31, 2022
52da810
Env?
ssilverm Apr 1, 2022
10629f9
Env?
ssilverm Apr 1, 2022
aaef398
Env?
ssilverm Apr 1, 2022
b4902aa
build args
ssilverm Apr 5, 2022
d87cfa6
adding git hash to ci
ssilverm Apr 12, 2022
4af0af2
sha
ssilverm Apr 12, 2022
e3e1865
sha
ssilverm Apr 12, 2022
f7750fe
sha
ssilverm Apr 12, 2022
11ae104
sha
ssilverm Apr 12, 2022
b6ecd9f
sha
ssilverm Apr 12, 2022
3c3f49d
using tags based on branch
ssilverm Apr 13, 2022
e39ee49
Log handler
ssilverm Apr 13, 2022
be52aeb
flake8 linting
ssilverm Apr 13, 2022
fa30299
changed env to remove https for demo
ssilverm Apr 14, 2022
6c2fd0c
Passing tests
ssilverm Apr 18, 2022
6d80d5d
Tests passing
ssilverm Apr 18, 2022
06d3a24
Fixed formatting
ssilverm Apr 18, 2022
6dc0cd3
First fixes
ssilverm Apr 25, 2022
8fd80ee
Linted
ssilverm Apr 26, 2022
e60651b
MDL
ssilverm Apr 26, 2022
dcd0c27
config comment change
ssilverm Apr 26, 2022
af2863a
Testing ARM
ssilverm May 16, 2022
cd8784d
Testing ARM platforms
ssilverm May 16, 2022
e43eb0f
Testing ARM platforms
ssilverm May 16, 2022
6649bed
Testing ARM platforms
ssilverm May 16, 2022
ef62752
Testing ARM platforms
ssilverm May 16, 2022
b2f2f11
Testing ARM platforms
ssilverm May 16, 2022
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
22 changes: 22 additions & 0 deletions .dockerignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
.dockerignore
__pycache__
*.pyc
*.pyo
*.pyd
.Python
env
venv*
pip-log.txt
pip-delete-this-directory.txt
.tox
.coverage
.coverage.*
.cache
nosetests.xml
coverage.xml
*,cover
*.log
.git
*.template
.env*
fake-s3
15 changes: 15 additions & 0 deletions .env.template
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
TOOL_TITLE=Faculty Tools
THEME_DIR=
BASE_CANVAS_SERVER_URL=https://example.com/
SECRET_KEY=CHANGEME
LTI_KEY=key
LTI_SECRET=secret
OAUTH2_URI=https://127.0.0.1:9001/oauthlogin
OAUTH2_ID=CHANGEME
OAUTH2_KEY=CHANGEME
GOOGLE_ANALYTICS=GA-000000
CONFIG=config.DevelopmentConfig
DATABASE_URI=mysql://root:secret@db/faculty_tools

REQUIREMENTS=test_requirements.txt

43 changes: 43 additions & 0 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
name: Run Python Tests
on:
push:
branches:
- issue/21-dockerize
pull_request:
branches:
- issue/21-dockerize

jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- name: Install Python 3
uses: actions/setup-python@v1
with:
python-version: 3.7
- name: Install dependencies
run: |
python -m pip install --upgrade pip
pip install -r test_requirements.txt
pip install coveralls
- name: Setup Repo
run: |
cp whitelist.json.template whitelist.json
cp .env.template .env
mkdir logs; touch logs/faculty-tools.log
- name: Run flake8
run: flake8
- name: Run black
run: black --check .
- name: Lint markdown files
uses: bewuethr/mdl-action@v1
# - name: Load dotenv
# uses: falti/dotenv-action@v0.2.5
- name: Environment Variables from Dotenv
uses: c-py/action-dotenv-to-setenv@v3
- name: Print Repo
run: |
env
- name: Run unittests
run: coverage run -m unittest discover
2 changes: 1 addition & 1 deletion .gitignore
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
# config/settings
logs
settings.py
whitelist.json
.env

# local theming
themes/*
Expand Down
23 changes: 0 additions & 23 deletions .travis.yml

This file was deleted.

12 changes: 12 additions & 0 deletions Dockerfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
FROM tiangolo/uwsgi-nginx-flask:python3.7
ARG REQUIREMENTS
RUN apt-get update && apt-get -y install libffi-dev gcc python3-dev libffi-dev libssl-dev libxml2-dev libxmlsec1-dev libxmlsec1-openssl
RUN apt-get -y install ca-certificates
WORKDIR /app
COPY requirements.txt /app/
COPY test_requirements.txt /app/
COPY devops/nginx.conf /app
COPY devops/uwsgi.ini /app
RUN echo $REQUIREMENTS
RUN pip install -r $REQUIREMENTS
COPY ./ /app/
70 changes: 29 additions & 41 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,15 +4,19 @@

# Documentation for Faculty Tools

## Settings
## Setting up Faculty Tools with Docker & Docker-Compose

Create a new `settings.py` file from the template
First clone and setup the repo.

```sh
cp settings.py.template settings.py
git clone git@github.com:ucfopen/faculty-tools.git
cp whitelist.json.template whitelist.json
ssilverm marked this conversation as resolved.
Show resolved Hide resolved
cp .env.template .env
mkdir logs
touch logs/faculty-tools.log
```

Edit `settings.py` to configure the application. All fields are required,
Edit `.env` to configure the application. All fields are required,
ssilverm marked this conversation as resolved.
Show resolved Hide resolved
unless specifically noted.

## Developer Key
ssilverm marked this conversation as resolved.
Show resolved Hide resolved
Expand Down Expand Up @@ -57,67 +61,51 @@ Add the tools you want instructors and faculty to see to `whitelist.json`.
]
```

## Virtual Environment

Create a new virtual environment.

```sh
virtualenv env
```

Activate the environment.

```sh
source env/bin/activate
```

Install everything:

```sh
pip install -r requirements.txt
```

## Create DB

Change directory into the project folder. Create the database in python shell:
We need to generate the database and tables for faculty tools to run properly.
The MySQL docker image automatically creates the user, password, and database
name set in the `docker-compose.yml` file.

```sh
from lti import db
docker-compose run lti python
ssilverm marked this conversation as resolved.
Show resolved Hide resolved
from main import db
ssilverm marked this conversation as resolved.
Show resolved Hide resolved
db.create_all()
```

If you want to look at your users table in the future, you can do so in the
python shell:

```python
from lti import Users
docker-compose run lti python
from main import Users
ssilverm marked this conversation as resolved.
Show resolved Hide resolved
Users.query.all()
```

## Environment Variables
## Run the App

Set the flask app to `lti.py` and debug to true.
It's time to use docker-compose to bring up the application.

```sh
export FLASK_APP=lti.py
export FLASK_DEBUG=1
docker-compose up -d
```

Alternatively, you can run the setup script to simultaneously setup environment
variables and the virtual environment.
Go to the /xml page, <http://127.0.0.1:9001/facultytools/xml> by default.

```sh
source setup.sh
```
Copy the xml, and install it into a course (Course->Settings->Apps).

## Run the App
## View the Logs

Run the lti script while your virtual environment is active.
To view the logs while the application is running use this docker command:

```sh
flask run
docker-compose logs -f
```

Go to the /xml page, [http://0.0.0.0:5000/xml](http://0.0.0.0:5000/xml) by default
## Stopping the App

To shutdown Faculty Tools

Copy the xml, install it into a course.
```sh
docker-compose down
```
11 changes: 7 additions & 4 deletions config.py
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
import settings
import os


class Config(object):
ssilverm marked this conversation as resolved.
Show resolved Hide resolved
# make the warning shut up until Flask-SQLAlchemy v3 comes out
SQLALCHEMY_TRACK_MODIFICATIONS = True
SQLALCHEMY_DATABASE_URI = settings.select_db("Config")

PYLTI_CONFIG = settings.PYLTI_CONFIG

Expand All @@ -14,14 +14,15 @@ class Config(object):
SESSION_COOKIE_SECURE = True
SESSION_COOKIE_SAMESITE = "None"

SQLALCHEMY_DATABASE_URI = os.environ.get("DATABASE_URI")


class BaseConfig(object):
DEBUG = False
TESTING = False

# make the warning shut up until Flask-SQLAlchemy v3 comes out
SQLALCHEMY_TRACK_MODIFICATIONS = True
SQLALCHEMY_DATABASE_URI = settings.select_db("BaseConfig")

PYLTI_CONFIG = settings.PYLTI_CONFIG

Expand All @@ -31,16 +32,18 @@ class BaseConfig(object):
SESSION_COOKIE_SECURE = True
SESSION_COOKIE_SAMESITE = "None"

SQLALCHEMY_DATABASE_URI = os.environ.get("DATABASE_URI")


class DevelopmentConfig(BaseConfig):
DEBUG = True
TESTING = True

SQLALCHEMY_DATABASE_URI = settings.select_db("DevelopmentConfig")
SQLALCHEMY_DATABASE_URI = os.environ.get("DATABASE_URI")
ssilverm marked this conversation as resolved.
Show resolved Hide resolved


class TestingConfig(BaseConfig):
DEBUG = False
TESTING = True

SQLALCHEMY_DATABASE_URI = settings.select_db("TestingConfig")
SQLALCHEMY_DATABASE_URI = os.environ.get("DATABASE_URI")
44 changes: 44 additions & 0 deletions devops/nginx.conf
Original file line number Diff line number Diff line change
@@ -0,0 +1,44 @@
user nginx;
worker_processes 1;
error_log /var/log/nginx/error.log warn;
pid /var/run/nginx.pid;
events {
worker_connections 1024;
}
http {
include /etc/nginx/mime.types;
default_type application/octet-stream;
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
access_log /var/log/nginx/access.log main;
sendfile on;
keepalive_timeout 65;

server {
listen 80;
location /facultytools/ {
try_files $uri @app;
}

location @app {
include uwsgi_params;
uwsgi_pass unix:///tmp/uwsgi.sock;
uwsgi_param SCRIPT_NAME /facultytools/;
uwsgi_modifier1 30;
uwsgi_read_timeout 300;
uwsgi_connect_timeout 300;
uwsgi_send_timeout 300;
proxy_redirect off;

}

location /facultytools/static {
alias /app/static;
}
}

}
daemon off;


4 changes: 4 additions & 0 deletions devops/uwsgi.ini
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
[uwsgi]
module = lti
callable = app
route-run = fixpathinfo:
35 changes: 35 additions & 0 deletions docker-compose.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
version: '3.1'

services:
lti:
build:
context: .
args:
- "REQUIREMENTS=${REQUIREMENTS}"
ports:
- "9001:80"
env_file:
- .env
environment:
- MODULE_NAME=app
depends_on:
- db

db:
image: mysql:5.7
volumes:
- ft_dbdata:/var/lib/mysql
restart: always
environment:
MYSQL_ROOT_PASSWORD: secret
MYSQL_DATABASE: faculty_tools
MYSQL_USER: root
MYSQL_PASSWORD: secret
ssilverm marked this conversation as resolved.
Show resolved Hide resolved
ports:
- "33061:3306"
volumes:
ft_dbdata: {}




3 changes: 2 additions & 1 deletion lti.py
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@
send_from_directory,
)
from flask_sqlalchemy import SQLAlchemy
from sqlalchemy import text
import jinja2
from pylti.flask import lti
import requests
Expand Down Expand Up @@ -286,7 +287,7 @@ def status():

# Check DB connection
try:
db.session.query("1").all()
db.session.query(text("1")).all()
status["checks"]["db"] = True
except Exception:
app.logger.exception("DB connection failed.")
Expand Down
Loading