All notable changes to this project will be documented in this file.
The format is (loosely) based on Keep a Changelog and this project adheres to Semantic Versioning.
v3.10.2 - 2025-11-16
- Added validation for STAC version format to provide clear error messages when stac_version field is missing, empty, or incorrectly formatted (e.g., "1.1" instead of "1.1.0"). #268
- Migrated from
setup.pyto modernpyproject.tomlpackaging (PEP 621), removing legacyrequirements-dev.txtfile. #268
v3.10.1 - 2025-07-26
- Reverted path cleaning changes that removed
./prefix from relative paths, which was causing compatibility issues with tools like stac-check. The validator now correctly preserves the./prefix for relative paths in the current directory. #266
v3.10.0 - 2025-07-20
- Added detailed recursive validation summary showing validation counts by STAC object type (Catalog, Collection, etc.) #265
- Added validation duration timing that shows total processing time in a human-readable format #265
- Added support for pydantic validation in recursive mode with proper schema reporting #265
- Standardized summary output formatting across all validation modes for consistency #265
v3.9.3 - 2025-06-28
- Improved path resolution in recursive validation to handle relative paths more reliably, especially in GitHub repository structures #264
- Fixed issue where validator would get confused by repository structure when validating catalogs with relative paths #264
- Cleaned up path output by removing unnecessary
./components from displayed paths #264
v3.9.2 - 2025-06-18
- Fixed missing item id in the url path with --item-collection output #263
v3.9.1 - 2025-06-13
failed_schemafield to error messages for easier error handling #260recommendationfield to --verbose mode #260
v3.9.0 - 2025-06-13
- Added separate
recommendationfield in error messages when running in non-verbose mode #257 - Verbose error messages for JSONSchemaValidationErrors #257
- Changed --verbose for recursive mode to --trace-recursive to make way for more comprehensive error messaging #257
v3.8.1 - 2025-06-04
- Fixed the pydantic extra dependency in setup.py to properly install stac-pydantic when using
pip install stac-validator[pydantic]#254
v3.8.0 - 2025-06-03
- Added
--schema-configoption to specify a YAML or JSON configuration file that maps remote schema URLs to local file paths, making it easier to validate against multiple local schemas, allowing offline validation and improved performance #253
v3.7.0 - 2025-05-30
- Added a comprehensive Table of Contents to README.md #247
- Added Sponsors and Supporters section to README.md with organizational logos and acknowledgments #247
- Added
--pydanticoption for validating STAC objects using stac-pydantic models, providing enhanced type checking and validation #249 - Added optional dependency for stac-pydantic that can be installed with
pip install stac-validator[pydantic]#249 - Added GitHub Actions workflow for automatically building and deploying documentation to GitHub Pages #250
- Reformatted and restructured the README.md for improved readability and organization #247
- Migrated documentation from Read the Docs to GitHub Pages for better integration with the repository #250
- Updated documentation system to use Sphinx with MyST parser for improved Markdown support #250
- Enhanced documentation to include content directly from README.md for consistency #250
v3.6.0 - 2025-03-25
- If a validation error occurs in recursive mode only show the invalid items unless verbose mode is on. #243
- Added ability to validate extensions of Collections #243
- Improve error reporting through use of best_match #243
- Add
schema-mapoption similar to stac-node-validator SchemaMap to allow validation against local copies of schemas. #243
v3.5.0 - 2025-01-10
- Added publish.yml to automatically publish new releases to PyPI #236
- Configure whether to open URLs when validating assets #238
- Allow to provide HTTP headers #239
- Switched to the referencing library for dynamic JSON schema validation and reference resolution #241
v3.4.0 - 2024-10-08
- Added ability to validate response from a /collections endpoint #220
- Added mypy to pre-commit config (#229)
- Support for stac spec version 1.1.0 #235
v3.3.2 - 2023-11-17
- Docstrings (#224)
- Development dependencies removed from runtime dependency list (#228)
- Remove jsonschema RefResolver (#228
v3.3.1 - 2022-12-16
- Moved --verbose messaging for --recursive as --verbose was printing out the wrong messages #222
v3.3.0 - 2022-11-28
- Added --item-collection to validate local and remote item collections #219
- Added --pages to validate additional items retrieved via pagination links #219
v3.2.0 - 2022-09-20
- Added ability to check local schemas in item extensions #215
- Added an example on validating a dictionary #215
- Changed 'ValidationError' error type to 'JSONSchemaValidationError' #213
v3.1.0 - 2022-04-28
- Added update stac version message to cli output #211
- Reordered exception handlers to avoid unreachable code #203
- Details about invalid items are shown in the message when in recursive mode #202
- Dockerfile - change cli command from stac_validator to stac-validator #201
- Items with no assets key can still be valid #206
- Top-level
is_validflag for recursive JSONSchema exceptions #208
- Stac-check linting as it creates a circular dependency #209
- Remove v0.7.0 test data and v0.7.0 local tests #210
- Removed pystac from dependencies #210
v3.0.0 - 2022-03-11
- A note about full recursion to the
--max-depthhelp text
- Item messages are now included even if
max_depth is None - Exit with non-zero code when validation fails
- References to Python 3.6
v2.5.0 - 2022-03-10
- Split the
--recursiveoption into a--recursiveflag and a--max-depthoption - Renamed the entry point from
stac_validatortostac-validator
v2.4.3 - 2022-03-10
- Add schema caching
v2.4.2 - 2022-03-02
- Loosen pystac version dependency
v2.4.1 - 2022-03-02
- Loosen stac-check version dependency
v2.4.0 - 2022-02-02
- Linting option in cli to display stac-check generated information
v2.3.0 - 2021-08-31 - 2021-11-28
- Added --links option to validate links on format and a valid response
- Added --assets option to validate assets on format and and a valid response
- Added test_links.py
- Added v1.0.0 STAC examples from radiant earth github
- Added v1.0.0 examples to tests
- Upgraded pystac to 1.1.0 from 0.5.6
- Moved tests for cli options out of test_stac_validator into individual files
- Moved utilities to utilities.py
- Moved backend to validate.py
v2.2.0 - 2021-05-25
- Added Support for STAC 1.0.0
- Added more tests for STAC 1.0.0-rc.4
- Option to pass stac dictionary into validator in python with new stac_dict method
- Moved std out to cli so that it doesn't display in pure python applications
- Added Pypi badges to readme
v2.1.0 - 2021-05-06
- Added more tests for STAC 1.0.0-rc.3
- Added basic support for rc.4
- Add system exit code to CLI. see #144
- Modified how Lambda CDK is built
v2.0.0 - 2021-04-28
- Stac versions from 0.8.0 --> 1.0.0-rc.3 are now supported.
- Version is detected automatically.
- Default validation attempts to validate a core Stac object as well as any extensions.
- Recursion which was previously handled by Pystac is now done natively with both a depth option to limit the time it takes to validate and a verbose option to display output as individual objects are being validated one by one.
- Added AWS CDK deployment example.
- Added FastAPI routing to CDK deployment.
- Pystac is now only being used to identify stac objects. Jsonschema is being used for all other validation.
- The cli library was changed from Docopt to Click.
- Custom validation was updated to allow for local schemas.
- The force, legacy, version, and update methods were removed.
- stac versions where a
stac_versionfield is not present are no longer supported.
v1.0.1 - 2020-09-01
- The ability (--update) to update a STAC object. This is based on migrate from pystac. It doesn't always work. Frequently it does. Presently it tries to update to version 1.0.0-beta.2
- A function to display what has changed via --update. This is represented in the logs as diff.
- A --force option. This updates the stac_version to v0.9.0 and adds an id field as older STAC versions seem to be missing this sometimes. This seems to be especially effective with objects as old as 0.6.0 and 0.6.1
- An option (--version) to specify and set a specific version to validate against.
- The --extension option. This uses pystac validation to validate against various extension schemas.
- The ExtensionError, as inputing a bad value for extension caused validation in pystac to be bypassed.
- The VersionError, as inputing a bad value for version was causing validation in pystac to be bypassed as well.
- The --recursive option. This uses validate_all from pystac to recursively search the links from a catalog or collection.
- The ability (--core) to validate against the core only. This is provided by pystac.
- (--legacy). This validates agains schemas from v0.4.0 to v1.0.0-beta.1 Legacy must be accompanied by --version.
- valid_versions for --legacy are: 'v0.4.0', 'v0.4.1', 'v0.5.0', 'v0.5.1', 'v0.5.2', 'v0.6.0', 'v0.6.0-rc1', 'v0.6.0-rc2', 'v0.6.1', 'v0.6.2', 'v0.7.0', 'v0.8.0', 'v0.8.0-rc1', 'v0.8.1', 'v0.9.0', 'v0.9.0-rc1', 'v0.9.0-rc2', and 'v1.0.0-beta.1'
- (--custom). Validate against a custom schema
- Tests to explore new functionality.
- Updated core validation to use validation from pystac instead of jsonchema.
- With the newest version - 1.0.0-beta.2 - items will run through jsonchema validation before the PySTAC validation. The reason for this is that jsonschema will give more informative error messages. This should be addressed better in the future. This is not the case with the --recursive option as time can be a concern here with larger collections.
- Logging. Various additions were made here depending on the options selected. This was done to help assist people to update their STAC collections.