[RFC] Public API for stactools packages #1176
gadomski
started this conversation in
STAC Software
Replies: 0 comments
# for free
to join this conversation on GitHub.
Already have an account?
# to comment
-
This is a Request For Comment following the Rust template. This is just a proposal -- please comment/suggest/advance as you see fit!
Summary
The public API of a stactools package consists of:
The package's command-line interface is not part of the public API.
Each stactools package hosts examples of its own generated objects, so downstream users and other developers can "see" the public metadata API.
Motivation
The semver documentation begins by laying out the requirements for good versioning:
As more and more folks are using/modifying stactools packages, we need to define a general public API for all stactools packages, so downstream users can have some trust in their version numbers as they use packages in their own data pipelines. This also will help developers make decisions about which features to change or which new features to include.
Guide-level explanation
The public API of a software packages defines which features/attributes downstream users can rely upon with some expectations of stability. In particular, a good public API will allow downstream users to take up new bug fixes or features without breaking existing code.
Because stactools packages are generally used to generate metadata, we consider those generated metadata as "first class" members of the package. Any breaking changes to those metadata are considered breaking changes to the public API, and require a MAJOR version change.
STAC examples
Let's use a hypothetical stactools package,
stactools.foo
, which provides a single functionstactools.foo.stac.create_item(href: str) -> pystac.Item
. For a given GeoTIFFdata.tif
,create_item
creates an Item that looks like this:Breaking changes
A change to any existing attribute (except for
created
) is a breaking change and requires a MAJOR release, e.g. this is breaking:is a breaking change. The only exception is
created
on non-assets (i.e. at the top level for Catalogs and Collections, and inproperties
for Items). E.g. this is non-breaking:EDIT 2022-03-31: It is also a non-breaking changing to re-order a list where list order is not meaningful, e.g.
roles
.Backwards-compatible feature additions
Adding new attributes, including extensions, is a backwards-compatible feature addition and requires a MINOR release:
Backwards-compatible bugfixes
Changing values to make them correct is considered a backwards-compatible bugfix and requires a PATCH release. E.g. let's say the datetime had the wrong year; this would be a backwards compatible bugfix:
Note the use of the word correct. Merely bringing the value in line with best practices is not enough to be considered a bugfix -- the value needs to be well and truly incorrect.
Python API
The Python API is treated normally w.r.t public API. Any declared entity that does not begin with an
_
is considered part of the public API. While its from a different language, I find the Cargo book's explanation of API stability helpful -- if someone has a Python version of that, please point me that way and I'll update this RFC.Command-line interface
The command-line interface is meant to be used manually in one-off operations. If downstream users need stability and repeatability, they should use the Python API. Therefore, the command-line interface, and any Python functions used strictly for the CLI (e.g.
click
-decorated functions) are not part of the public API.Unresolved questions
Future possibilities
Beta Was this translation helpful? Give feedback.
All reactions