cuappdev / upload

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

upload

A Python Flask-SQLAlchemy file upload backend microservice for Cornell AppDev's apps. Made by Cornell AppDev.

Installation

Setup

If running for the first time, run:

virtualenv venv
source venv/bin/activate
pip install -r requirements.txt

Make sure to also create your .envrc file by running (we recommend using direnv):

cp envrc.template .envrc

Environment variable values can be found by asking a member of Cornell AppDev.

Run

To run the app, just do:

python app.py

Style

So that the repository agrees upon a style standard, we have opted to use black for Python formatting!

Setting up linter

Simply run

(venv) $ pre-commit

Endpoints

/ • GET

Response Body

{"success": true, "data": "Hello World!"}

/upload/ • POST

There are two ways to send the images:

  1. JSON request body with base64 strings.
  2. Multipart form-data with an image file.

If using base64 encrypted strings, checkout this converter as the format we are using. For both methods, use image key for the image, and bucket key for the bucket name.

Using form-data is the recommended approach since it can handle very large image sizes.

Request Body

{
  "bucket": <bucket_name>,
  "image": ""
}

Response Body

{"success": true, "data": "https://<spaces_name>.<spaces_region_name>.digitaloceanspaces.com/<bucket_name>/<filename>"}

/remove/ • POST

Request Body

{
  "bucket": <bucket_name>,
  "image_url": "https://<spaces_name>.<spaces_region_name>.digitaloceanspaces.com/<bucket_name>/<filename>"
}

Response Body

{
    "success": true,
    "data": "Image successfully deleted!"
}

About


Languages

Language:Python 96.5%Language:Dockerfile 2.7%Language:Shell 0.8%