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.2.tar.gz (36.5 kB view details)

Uploaded Source

Built Distributions

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

Uploaded Python 3

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

Uploaded Python 2

File details

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

File metadata

  • Download URL: pacifica-ingest-0.1.2.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.21.0 setuptools/40.6.3 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/3.6.3

File hashes

Hashes for pacifica-ingest-0.1.2.tar.gz
Algorithm Hash digest
SHA256 1ef38f7969156fc2ea28dbf5c36996e1c4e81e4540e265b2d8cc5d845bb5cef1
MD5 0e531cd39908b7164360fa203889e3f8
BLAKE2b-256 f002c67a01f10f20c206ec8257b470baca297c6572a322a965e41c6e2d4dd7ad

See more details on using hashes here.

File details

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

File metadata

  • Download URL: pacifica_ingest-0.1.2-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.21.0 setuptools/40.6.3 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/3.6.3

File hashes

Hashes for pacifica_ingest-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 793f2a0902ea744fcfbc1b8920adae4a430ef1901d70c2c85be253009157115d
MD5 1ff565e3ba8eda4eb54df57bb20c8477
BLAKE2b-256 166142035cbc4e4128fda15fcc6c4a6d1c605303d03e0ac2d1c5e88745445155

See more details on using hashes here.

File details

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

File metadata

  • Download URL: pacifica_ingest-0.1.2-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.21.0 setuptools/40.6.3 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/2.7.14

File hashes

Hashes for pacifica_ingest-0.1.2-py2-none-any.whl
Algorithm Hash digest
SHA256 3513ccd0bb47d7086ee327ff2cc809e863f3fe0e748dfe50c40e9b314cde3dd0
MD5 45438ea6c00266f9ff18483ad72b589b
BLAKE2b-256 13bb168ed0f139457b0a999d9eb21458b3ee6daf2830872ab95312336a3251c9

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