Skip to content

WilliamOuJiatong/pyapi_ou14_branch

 
 

Repository files navigation

ClassTranscribe Python API

Powered by Flask + Connexion + SQLAlchemy

Build Status

Branch Status
Production Production
Staging Staging
Experiment Experiment

Configuration

Environment variables can be used to set the configuration.

Application Config

Environment Variable Description Default Value
DEBUG Enable verbose debug output False
PORT The port to serve the Flask app 5000
SWAGGER_URL local or remote URL to the Swagger spec that this application uses openapi/swagger.json

Database Connection Config

You can choose to connect to a remote postgres instance, or use a local SQLite file (recommended for dev only)

Environment Variable Description Default Value
USE_SQLITE Use a local database file (instead of postgres, for local dev only) True
POSTGRES_HOST Hostname of a remote Postgres to connect to localhost
POSTGRES_PORT Port of a remote Postgres to connect to 5432
POSTGRES_USER Username to use when connecting to remote Postgres ''
POSTGRES_PASS Password to use when connecting to remote Postgres ''
POSTGRES_DB Database to use when connecting to remote Postgres ct2019db

NOTE: By default, a sqlite file will be created.

Getting Started

This project can either be run with Python or as a Docker container.

To run all of ClassTranscribe locally (including the frontend and C# backend) see RunEverything.md

With Python

Install dependencies:

pip install -r requirements.txt

Run the application:

python server.py

Navigate to http://localhost:5000/ui/ to test the API with Swagger UI.

With Docker

Build the Docker image:

docker build -t classtranscribe/pyapi .

Run a Docker container from that image:

docker run -itd --name ct-pyapi -p 5000:5000 classtranscribe/pyapi

Navigate to http://localhost:5000/ui/ to test the API with Swagger UI.

NOTE: In Docker on Mac/Windows, you may need to use your IP address instead of localhost.

With Docker Compose

Build and run the pyapi application, along with postgres and rabbitmq:

docker compose -f docker/docker-compose.yml up -d --build

You can change the code and/or .env files located in the Docker directory to change the behavior of the application.

NOTE: --build will automatically rebuild the Docker image needed for this stack

Navigate to http://localhost:5000/ui/ to test the API with Swagger UI.

NOTE: In Docker on Mac/Windows, you may need to use your IP address instead of localhost.

About

William Ou branch

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 96.6%
  • Jupyter Notebook 2.7%
  • Dockerfile 0.7%