Skip to content

COVID19Tracking/contentful-image-upload

Repository files navigation

Installation

Credentials

You will need a Contentful OAuth Application to run this program. (Docs here)

Credentials live in app/config.json, which should be structured like:

{
  "contentful-space-id": "<contentful-space-id>",
  "images-directory": "imgs",
  "contentful-environment": "<contentful-environment>",
  "contentful-client-id": "<contentful-client-id>",
  "redirect-uri": "<redirect-uri>"
}

Getting Started

Dependencies

Python requirements live in requirements.txt. Install them with pip3 install -r requirements.txt

Development

  • Run the development server with ./develop. (You may need to chmod +x develop.sh first.)
  • Visit http://localhost:5000

HTTPS Tunneling

Because Contentful requires HTTPS for its URI redirects, you'll need to be use a service like ngrok to run the development server. The development server runs on port 5000: you'll need to forward 5000 over http.

Keep in mind that you'll need to update the URI redirect in your OAuth application to the HTTPS proxy in order for the authentication workflow to work.

Deployment

This project uses docker-compose for containerization. There are three services:

  1. nginx, which runs on ports 80 and 443.
  2. flask_app, the actual Flask application, runs on port 5000. (nginx reverse proxies to 0.0.0.0:5000 via uswgi.)
  3. certbot, which handles HTTPS certificates.

(This configuration is based on wmnnd's boilerplate.)

OK, but how does it run?

sudo docker-compose up should do the trick.

Updates

To update the codebase on the server, run:

  1. git pull origin master
  2. sudo docker-compose build
  3. sudo docker-compose restart Note that restart does not reflect changes made to docker-compose.yml.

todos

Todo items are marked with todo in the comments. Try grep -r "todo" to find outstanding items.

Code formatting

Code is formatted using yapf. To format all files, run yapf . -i --recursive from the root directory.

About

No description or website provided.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •