Skip to main content

Pacifica Ingest

Project description

Pacifica Ingest Services

Build Status Build status Code Climate Test Coverage Issue Count

Frontend Stars Backend Stars Frontend Pulls Backend Pulls Frontend Automated build Backend Automated build

This is the Pacifica Ingest Services API.

This service receives, validates and processes data that is provided by a Pacifica Uploader service.

Installing the Service

Prerequisites

To run the code, the following commands are required:

The Manual Way

Install the dependencies using the pip command:

pip install -r requirements.txt

Build and install the code using the setup.py script:

python setup.py build
python setup.py install

Running the Service

Start and run a new instance using the docker-compose command:

docker-compose up

Bundle Format

The bundle format is parsed using the tarfile package from the Python standard library.

Both data and metadata are stored in a bundle. Metadata is stored in the metadata.txt file (JSON format). Data is stored in the data/ directory.

To display the contents of a bundle using the tar command:

tar -tf mybundle.tar

For example, the contents of mybundle.tar is:

data/mywork/project/proposal.doc
data/mywork/experiment/results.csv
data/mywork/experiment/results.doc
metadata.txt

API Examples

The endpoints that define the ingest process are as follows. The assumption is that the installer knows the IP address and port the WSGI service is listening on.

Ingest (Single HTTP Request)

Post a bundle (defined above) to the endpoint.

POST /ingest
... tar bundle as body ...

The response will be the job ID information as if you requested it directly.

{
  "job_id": 1234,
  "state": "OK",
  "task": "UPLOADING",
  "task_percent": "0.0",
  "updated": "2018-01-25 16:54:50",
  "created": "2018-01-25 16:54:50",
  "exception": ""
}

Failures that exist with this endpoint are during the course of uploading the bundle. Sending data to this endpoint should consider long drawn out HTTP posts that maybe longer than clients are used to handling.

Move (Single HTTP Request)

Post a metadata document to the endpoint.

POST /move
... content of move-md.json ...

The response will be the job ID information as if you requested it directly.

{
  "job_id": 1234,
  "state": "OK",
  "task": "UPLOADING",
  "task_percent": "0.0",
  "updated": "2018-01-25 16:54:50",
  "created": "2018-01-25 16:54:50",
  "exception": ""
}

Get State for Job

Using the job_id field from the HTTP response from an ingest.

GET /get_state?job_id=1234
{
  "job_id": 1234,
  "state": "OK",
  "task": "ingest files",
  "task_percent": "0.0",
  "updated": "2018-01-25 17:00:32",
  "created": "2018-01-25 16:54:50",
  "exception": ""
}

As the bundle of data is being processed errors may occure, if that happens the following will be returned. It is useful when consuming this endpoint to plan for failures. Consider logging or showing a message visable to the user that shows the ingest failed.

GET /get_state?job_id=1234
{
  "job_id": 1234,
  "state": "FAILED",
  "task": "ingest files",
  "task_percent": "0.0",
  "updated": "2018-01-25 17:01:02",
  "created": "2018-01-25 16:54:50",
  "exception": "... some crazy python back trace ..."
}

CLI Tools

There is an admin tool that consists of subcommands for manipulating ingest processes.

Job Subcommand

The job subcommand allows administrators to directly manipulate the state of a job. Due to complex computing environments some jobs may get "stuck" and get to a state where they aren't failed and aren't progressing. This may happen for any number of reasons but the solution is to manually fail the job.

IngestCMD job \
    --job-id 1234 \
    --state FAILED \
    --task 'ingest files' \
    --task-percent 0.0 \
    --exception 'Failed by adminstrator'

Contributions

Contributions are accepted on GitHub via the fork and pull request workflow. GitHub has a good help article if you are unfamiliar with this method of contributing.

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

pacifica-ingest-0.1.0.tar.gz (36.5 kB view details)

Uploaded Source

Built Distributions

pacifica_ingest-0.1.0-py3-none-any.whl (21.8 kB view details)

Uploaded Python 3

pacifica_ingest-0.1.0-py2-none-any.whl (21.8 kB view details)

Uploaded Python 2

File details

Details for the file pacifica-ingest-0.1.0.tar.gz.

File metadata

  • Download URL: pacifica-ingest-0.1.0.tar.gz
  • Upload date:
  • Size: 36.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.20.0 setuptools/40.5.0 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/3.6.3

File hashes

Hashes for pacifica-ingest-0.1.0.tar.gz
Algorithm Hash digest
SHA256 78c6e67d29285445af02ed9cbe9f6395ebb540f45893d3ceaa6ef5f18d8a41d7
MD5 c7e6cb66a423bbc26d2fc0184423253f
BLAKE2b-256 ce875d30e1aadc604fa1b79708727451d3d4796e46fa0c40f38d609f56944818

See more details on using hashes here.

File details

Details for the file pacifica_ingest-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: pacifica_ingest-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 21.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.20.0 setuptools/40.5.0 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/3.6.3

File hashes

Hashes for pacifica_ingest-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 2d86b6795826f90cf7646a370d4c5c04dafec98fe66502cd07b1ae6d5bcc7e5c
MD5 18434fceb67a07dacc57c2110d3cb8b0
BLAKE2b-256 765c1fdccfdc95c08ed4bf394eeb75e2c7bbdbc69323a6e6ee4146ee2905a593

See more details on using hashes here.

File details

Details for the file pacifica_ingest-0.1.0-py2-none-any.whl.

File metadata

  • Download URL: pacifica_ingest-0.1.0-py2-none-any.whl
  • Upload date:
  • Size: 21.8 kB
  • Tags: Python 2
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.20.0 setuptools/40.5.0 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/2.7.14

File hashes

Hashes for pacifica_ingest-0.1.0-py2-none-any.whl
Algorithm Hash digest
SHA256 1175fadc0392e90594b1bcea90701a8ca17cb4ce3d6d44186cd9d187fd90ddfa
MD5 e3aa40053618e979c0ac373a901d3618
BLAKE2b-256 22d7e393046b71cd615bf05c7838f54d7a036df91914192f6d532cfe48d8f15e

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