Skip to main content

Reproducible Open Benchmarks - Flask Web API

Project description

https://img.shields.io/badge/License-MIT-yellow.svg https://github.com/scailfin/flowserv-core/workflows/build/badge.svg https://codecov.io/gh/scailfin/rob-webapi-flask/branch/master/graph/badge.svg?token=iE1ZYCA0lS
ROB Web Service Implementation (using Flask)

About

This is the default RESTful Web API implementation for the Reproducible Open Benchmarks for Data Analysis Platform (ROB) using the Flask web framework.

Installation and Configuration

The following installation instructions assume that you install all packages in a local folder ~/projects/rob.

# -- Change the working directory

cd ~/projects/rob

The Reproducible Open Benchmarks platform is implemented in Python. We recommend using a virtual environment for the installation.

# -- Create a new virtual environment
virtualenv venv
# -- Activate the virtual environment
source venv/bin/activate

The Flask Web API for ROB requires the flowserv package. The following steps will install all packages from the respective GitHub repositories:

git clone git@github.com:scailfin/flowserv-core.git
pip install -e flowserv-core
git clone git@github.com:scailfin/rob-webapi-flask.git
pip install -e rob-webapi-flask

The primary configuration parameters are defined in the ROB Configuration documentation. Two additional environment variables are defined by the Web API:

  • ROB_WEBAPI_LOG: Directory path for API logs (default: $FLOWSERV_API_DIR/log)

  • ROB_WEBAPI_CONTENTLENGTH: Maximum size of uploaded files (default: 16MB)

If you run the Flask application from the command line in developer mode using flask run, you also need to set the following environment variables:

export FLASK_APP=robflask.api
export FLASK_ENV=development

There are also more detailed instructions on the Demo Setup site to setup and run the Web API.

Command Line Interface

The robflask package includes a command line tool to setup the ROB database and for creating and manipulating benchmarks.

Initialize the ROB database

Initialize database and base directories for the Reproducible Open Benchmarks (ROB) Web API. The configuration parameters for the database are taken from the respective environment variables. Creates the API base directory if it does not exist.

Usage: flowserv init [OPTIONS]

  Initialize database and base directories for the API.

Options:
  -f, --force  Create database without confirmation
  --help       Show this message and exit.

Create and delete Benchmarks

Create a new benchmark.

Usage: flowserv workflows create [OPTIONS] TEMPLATE

  Create a new workflow.

Options:
  -n, --name TEXT          Unique workflow name.
  -d, --description TEXT   Short workflow description.
  -i, --instructions PATH  File containing instructions for running the
                           workflow.

  -f, --specfile FILE      Optional path to workflow specification file.
  -m, --manifest FILE      Optional path to workflow manifest file.
  --help                   Show this message and exit.

Delete a given benchmark.

Usage: flowserv workflows delete [OPTIONS] IDENTIFIER

  Delete a given workflow.

Options:
  --help  Show this message and exit.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

rob-flask-0.6.0.tar.gz (17.1 kB view details)

Uploaded Source

Built Distribution

rob_flask-0.6.0-py3-none-any.whl (20.9 kB view details)

Uploaded Python 3

File details

Details for the file rob-flask-0.6.0.tar.gz.

File metadata

  • Download URL: rob-flask-0.6.0.tar.gz
  • Upload date:
  • Size: 17.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.56.0 CPython/3.9.1

File hashes

Hashes for rob-flask-0.6.0.tar.gz
Algorithm Hash digest
SHA256 49d47b45302586a4340038aa7076cac6976672a7df34c97e09925cde93f589b9
MD5 92ff923e378233f27aebccac1b39d722
BLAKE2b-256 e2ed5b5bde79af17d52279a808b9e8cdbe8620c5d2a31114e0db0e4a0ba6dc58

See more details on using hashes here.

File details

Details for the file rob_flask-0.6.0-py3-none-any.whl.

File metadata

  • Download URL: rob_flask-0.6.0-py3-none-any.whl
  • Upload date:
  • Size: 20.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.56.0 CPython/3.9.1

File hashes

Hashes for rob_flask-0.6.0-py3-none-any.whl
Algorithm Hash digest
SHA256 23f8acde64bb5c33073b1d4c327a522f831186f96378768f5d74170a3c7c67b4
MD5 88190c31f866869319177622fe328987
BLAKE2b-256 1c41e54d373ce74beddfbd97fe31f0a740749b1d218809b680a9b0953cde811c

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page