Skip to main content

No project description provided

Project description

xpublish-edr

PyPI Conda Version

Tests codecov pre-commit.ci status

Xpublish routers for the OGC EDR API.

Documentation and code

URLs for the docs and code.

Installation

For conda users you can

conda install --channel conda-forge xpublish_edr

or, if you are a pip users

pip install xpublish_edr

Example

import xarray as xr
import xpublish
from xpublish.routers import base_router, zarr_router
from xpublish_edr.cf_edr_router import cf_edr_router

ds = xr.open_dataset("dataset.nc")

rest = xpublish.Rest(
    datasets,
    routers=[
        (base_router, {"tags": ["info"]}),
        (cf_edr_router, {"tags": ["edr"], "prefix": "/edr"}),
        (zarr_router, {"tags": ["zarr"], "prefix": "/zarr"}),
    ],
)

OGC EDR Spec Compliance

This package attempts to follow the spec where reasonable, adding functionality where the value is demonstrable.

collections and Resource Paths Support

xpublish-edr does not currently support the /collections/{collectionId}/query path template described in the spec. Instead the path resource appears as /{dataset_id}/edr/{query}. This is because of the path structure of xpublish. In the future, if xpublish supports DataTree it could provide a path to supporting the spec compliant collections resource path.

However, despite the collections resource not existing, this implementation supports collection metadata at the dataset level through the /{dataset_id}/edr/ resource.

Supported Queries

8.2.1 Position query

Query Compliant Comments
coords
z
datetime
parameter-name
crs Requires a CF compliant grid mapping on the target dataset. Default is EPSG:4326
f Supports cf_covjson, csv, geojson netcdf, parquet
method Optional: controls data selection. Use "nearest" for nearest neighbor selection, or "linear" for interpolated selection. Uses nearest if not specified

Any additional query parameters are assumed to be additional selections to make on the dimensions/coordinates. These queries will use the specified selections method.

8.2.3 Area query

Query Compliant Comments
coords Only POLYGON supported currently
z
datetime
parameter-name
crs Requires a CF compliant grid mapping on the target dataset. Default is EPSG:4326
f Supports cf_covjson, csv, geojson netcdf, parquet
method Optional: controls data selection. Use "nearest" for nearest neighbor selection, or "linear" for interpolated selection. Uses nearest if not specified

method is not applicable for the coordinates of area queries, only for selecting datetime, z, or additional dimensions.

For POLYGON coordinates, points that are located within OR on the polygons boundary are included in the response.

8.2.4 Cube query

Query Compliant Comments
bbox Bounding box in minx,miny,maxx,maxy format
z
datetime
parameter-name
crs Requires a CF compliant grid mapping on the target dataset. Default is EPSG:4326
f Supports cf_covjson, csv, geojson netcdf, parquet, geotiff
method Optional: controls data selection. Use "nearest" for nearest neighbor selection, or "linear" for interpolated selection. Uses nearest if not specified

method is not applicable for the coordinates of cube queries, only for selecting datetime, z, or additional dimensions.

Cube queries are not flattened like area queries, so the response is returned as sliced by xarray. This is particularly useful for subsetting regular grids.

Get in touch

Report bugs, suggest features or view the source code on GitHub.

License and copyright

xpublish-edr is licensed under BSD 3-Clause "New" or "Revised" License (BSD-3-Clause).

Development occurs on GitHub at https://github.com/gulfofmaine/xpublish-edr/issues.

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

xpublish_edr-0.9.1.tar.gz (21.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

xpublish_edr-0.9.1-py3-none-any.whl (26.5 kB view details)

Uploaded Python 3

File details

Details for the file xpublish_edr-0.9.1.tar.gz.

File metadata

  • Download URL: xpublish_edr-0.9.1.tar.gz
  • Upload date:
  • Size: 21.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for xpublish_edr-0.9.1.tar.gz
Algorithm Hash digest
SHA256 18bb9c25044778c8b829fb72d007a69206590280f23ac2318f435ddd1fc8d378
MD5 0173b8a14836868d707456c568d74f1c
BLAKE2b-256 4e4f6cb97e61b3f8f3f4996125fe906871af469c0463cf8639b21a896e1e85ee

See more details on using hashes here.

Provenance

The following attestation bundles were made for xpublish_edr-0.9.1.tar.gz:

Publisher: publish-to-pypi.yml on xpublish-community/xpublish-edr

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

File details

Details for the file xpublish_edr-0.9.1-py3-none-any.whl.

File metadata

  • Download URL: xpublish_edr-0.9.1-py3-none-any.whl
  • Upload date:
  • Size: 26.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for xpublish_edr-0.9.1-py3-none-any.whl
Algorithm Hash digest
SHA256 baac6aa1021c075031784e50d37ff59a47ac3bfab7622641c650da547dc8df2a
MD5 2bd9e66e6a33535e6e593399731b6ffd
BLAKE2b-256 36469ea3b6c4c8c76e6e25b906b4af51d8bd754debff39ef073016b8f13a2c8a

See more details on using hashes here.

Provenance

The following attestation bundles were made for xpublish_edr-0.9.1-py3-none-any.whl:

Publisher: publish-to-pypi.yml on xpublish-community/xpublish-edr

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 Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page