STAC API Validator
Project description
STAC API Validator
Introduction
The STAC API Validator is the official validation suite for the STAC API family of specifications.
Installation
STAC API Validator requires Python 3.10.
You can install STAC API Validator via pip from PyPI:
$ pip install stac-api-validator
and then run it:
$ stac-api-validator \
--root-url https://planetarycomputer.microsoft.com/api/stac/v1/ \
--conformance core --conformance item-search
Contributing
Contributions are very welcome. To learn more, see the Contributor Guide.
Usage
Please see the Command-line Reference for details.
Features
Work in Progress -- this currently only validates a subset of behavior
This validation suite focuses on validating STAC API interactions. Tools such as pystac and stac4s do a good job of validating STAC objects (Catalog, Collection, Item). This suite focuses on the STAC API behavior validation.
The three key concepts within a STAC API are:
- Conformance classes advertising the capabilities of the API
- Link relations between resources within the web API (hypermedia)
- Parameters that filter search results
The conformance classes, as defined in the conformsTo
field of the Landing Page (root, /
), advertise to
clients which capabilities are available in the API. Without this field, a client would not even be able to tell that a
root URI was a STAC API.
The link relations define how to navigate a STAC catalog through parent-child links and find resources such as the OpenAPI specification. While many OGC API and STAC API endpoint have a fixed value (e.g., /collections
), it is preferable for clients discover the paths via hypermedia.
The parameters that filter results apply to the Items resource and Item Search endpoints.
The current validity status of several popular STAC API implementations can be found here.
Command-line Reference
Usage:
Usage: stac-api-validator [OPTIONS]
STAC API Validator.
Options:
--version Show the version and exit.
--log-level TEXT Logging level, one of DEBUG, INFO, WARN,
ERROR, CRITICAL
--root-url TEXT STAC API Root / Landing Page URL [required]
--post / --no-post Test all validations with POST method for
requests in addition to GET
--conformance [core|browseable|item-search|features|collections|children]
Conformance class URIs to validate
[required]
--help Show this message and exit.
Example:
stac-api-validator \
--root-url https://cmr.earthdata.nasa.gov/stac/LARC_ASDC \
--conformance core --conformance item-search --conformance features
Example output:
Validating https://cmr.earthdata.nasa.gov/stac/LARC_ASDC ...
STAC API - Core conformance class found.
STAC API - Item Search conformance class found.
warnings: none
errors:
- service-desc (https://api.stacspec.org/v1.0.0-beta.1/openapi.yaml): should have content-type header 'application/vnd.oai.openapi+json;version=3.0'', actually 'text/yaml'
- service-desc (https://api.stacspec.org/v1.0.0-beta.1/openapi.yaml): should return JSON, instead got non-JSON text
- GET Search with bbox=100.0, 0.0, 105.0, 1.0 returned status code 400
- POST Search with bbox:[100.0, 0.0, 105.0, 1.0] returned status code 502
- GET Search with bbox=100.0,0.0,0.0,105.0,1.0,1.0 returned status code 400
- POST Search with bbox:[100.0, 0.0, 0.0, 105.0, 1.0, 1.0] returned status code 400
Additionally, the --no-post
option can be specified to only test GET requests, instead of the default of using
both GET and POST.
Validating OGC API Features - Part 1 compliance
A STAC API that conforms to the "STAC API - Features" conformance class will also be a valid implementation of OGC API Features - Part 1. In general, this validator focuses on those aspects of API behavior that are different between STAC and OGC. It is recommended that implementers also use the OGC API Features - Part 1 validation test suite to validate conformance.
Full instructions are available at the link above, but the simplest way to run this is with:
docker run -p 8081:8080 ogccite/ets-ogcapi-features10
Then, open http://localhost:8081/teamengine/ and login with the
username and password ogctest
, Create a new session
, with Organization OGC
, Specification OGC API - Features
, Start a new test session
, input he root URL for the service, and Start
.
Common Mistakes
- incorrect
conformsTo
in the Landing Page. This was added between STAC API 0.9 and 1.0. It should be the same as the value in theconformsTo
in the OAFeat/conformance
endpoint. - OGC API Features uses
data
relation link relation at the root to point to the Collections endpoint (/collections
), notcollections
relation - media type for link relation
service-desc
and endpoint isapplication/vnd.oai.openapi+json;version=3.0
(notapplication/json
) and link relationsearch
and endpoint isapplication/geo+json
(notapplication/json
) - Use of OCG API "req" urls instead of "conf" urls, e.g.
http://www.opengis.net/spec/ogcapi-features-1/1.0/conf/core
should be used, nothttp://www.opengis.net/spec/ogcapi-features-1/1.0/req/core
License
Distributed under the terms of the Apache 2.0 license, STAC API Validator is free and open source software.
Issues
If you encounter any problems, please file an issue along with a detailed description.
Credits
This project was generated from @cjolowicz's Hypermodern Python Cookiecutter template.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file stac-api-validator-0.0.3.tar.gz
.
File metadata
- Download URL: stac-api-validator-0.0.3.tar.gz
- Upload date:
- Size: 19.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.9.14
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 594e91cf60d22e582ff2c4f7a06642bc898a0e66be7ccc83679a088a9a058825 |
|
MD5 | c143fba0d5a2d9135ebffbebab23bbbc |
|
BLAKE2b-256 | 3954b92c90fff77531ade763bdd77a82fb462395a9a398abeb24427597da65d6 |
File details
Details for the file stac_api_validator-0.0.3-py3-none-any.whl
.
File metadata
- Download URL: stac_api_validator-0.0.3-py3-none-any.whl
- Upload date:
- Size: 17.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.9.14
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1251aded5cbc46db3861db58108736bc11148b1364640e49048b3abd3a69ec32 |
|
MD5 | 5a03dfb31de6c62a1135152037a4c19f |
|
BLAKE2b-256 | a7004c757f91017a5b5a46bf3a5c6ee16f844178dea6963ef19bbffd6de6344b |