Skip to main content

Spatio Temporal Asset Tasking with FastAPI

Project description

STAPI FastAPI - Sensor Tasking API with FastAPI

WARNING: The whole STAPI spec is very much a work in progress, so things are guaranteed to be not correct.

Usage

STAPI FastAPI provides an fastapi.APIRouter which must be included in fastapi.FastAPI instance.

Pagination

4 endpoints currently offer pagination: GET: '/orders, /products, /orders/{order_id}/statuses POST: /opportunities.

Pagination is token based and follows recommendations in the STAC API pagination. Limit and token are passed in as query params for GET endpoints, and via the body as separate key/value pairs for POST requests.

If pagination is available and more records remain the response object will contain a next link object that can be used to get the next page of results. No next Link returned indicates there are no further records available.

limit defaults to 10 and maxes at 100.

ADRs

ADRs can be found in in the adrs directory.

Development

It's 2024 and we still need to pick our poison for a 2024 dependency management solution. This project picks poetry for now.

Dev Setup

Setup is managed with poetry and pre-commit. It's recommended to install the project into a virtual environment. Bootstrapping a development environment could look something like this:

python -m venv .venv
source .venv/bin/activate
pip install poetry  # if not already installed to the system
poetry install --with dev
pre-commit install

Test Suite

A pytest based test suite is provided, and can be run simply using the command pytest.

Dev Server

This project cannot be run on its own because it does not have any backend implementations. However, a minimal test implementation is provided in ./tests/application.py. It can be run with uvicorn as a way to interact with the API and to view the OpenAPI documentation. Run it like so from the project root:

uvicorn application:app --app-dir ./tests --reload

With the uvicorn defaults the app should be accessible at http://localhost:8000.

Implementing a backend

  • The test suite assumes the backend can be instantiated without any parameters required by the constructor.

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

stapi_fastapi-0.6.0.tar.gz (14.7 kB view details)

Uploaded Source

Built Distribution

stapi_fastapi-0.6.0-py3-none-any.whl (21.4 kB view details)

Uploaded Python 3

File details

Details for the file stapi_fastapi-0.6.0.tar.gz.

File metadata

  • Download URL: stapi_fastapi-0.6.0.tar.gz
  • Upload date:
  • Size: 14.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for stapi_fastapi-0.6.0.tar.gz
Algorithm Hash digest
SHA256 d443484d746ff158f39a7294915cb5be017499c782dc8c29b23d626c2a757d77
MD5 acced2e917587d99b7868be0f4357b3c
BLAKE2b-256 c4180c4fec19907756beae3532680f16243a8389ac21a6e770e5ac16aea4f1d5

See more details on using hashes here.

Provenance

The following attestation bundles were made for stapi_fastapi-0.6.0.tar.gz:

Publisher: python-publish.yml on stapi-spec/stapi-fastapi

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

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

File metadata

  • Download URL: stapi_fastapi-0.6.0-py3-none-any.whl
  • Upload date:
  • Size: 21.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for stapi_fastapi-0.6.0-py3-none-any.whl
Algorithm Hash digest
SHA256 2554b14df079f81ab092bf84d30335458e217203558c2fd46c21cac1e6647587
MD5 c16a14378d913ebcb5c7ad2aa910efc5
BLAKE2b-256 f25c16b2ab5338b0517fb714ed3799c270e7ee53a6ecf0a7aab0fc06c61ec95c

See more details on using hashes here.

Provenance

The following attestation bundles were made for stapi_fastapi-0.6.0-py3-none-any.whl:

Publisher: python-publish.yml on stapi-spec/stapi-fastapi

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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