- Title: Order
- Identifier: https://stac-extensions.github.io/order/v1.1.0/schema.json
- Field Name Prefix: order
- Scope: Item, Collection
- Extension Maturity Classification: Pilot
- Owner: @emmanuelmathot
This document explains the Order Extension to the SpatioTemporal Asset Catalog (STAC) specification. This extension allows assets ordering management within STAC specification. In the context of this extension, the term "order" refers to a request for data to be delivered, served, or otherwise made available (e.g., after a purchase).
- Examples:
- Item example: Shows the basic usage of the extension in a STAC Item
- Collection example: Shows the basic usage of the extension in a STAC Collection
- JSON Schema
- Changelog
This extension can be used to enable several ordering scenarios. Some examples are described in the following sections
This scenario describes the "activation" of an offline product at the provider storage. It uses the storage extension to describe storage information necessary for the ordering status. The following diagram describe the states transition of the asset in a STAC Item.
This scenario describes the "ordering" of data product by a free or commercial provider. This use case is based on a per-user exchange with the provider for an individual service. The order information is not stored as a metadata of the Item but in the ordering information of the user request.
The fields in the table below can be used in these parts of STAC documents:
- Catalogs
- Collections
- Item Properties (incl. Summaries in Collections)
- Assets (for both Collections and Items, incl. Item Asset Definitions in Collections)
- Links
Field Name | Type | Description |
---|---|---|
order:status | string | REQUIRED. Describe the status of the ordering. One of the value listed here |
order:id | string | Identifier of the order. |
order:date | string | Indicates the order submission time, in UTC and formatted according to RFC 3339, section 5.6. |
order:expiration_date | string | DEPRECATED. Indicates the validity time of the order, in UTC and formatted according to RFC 3339, section 5.6. Use expires from the timestamps extension instead. |
These fields have different meaning depending on where they are used. When used as an Item properties or top-level Collection field, they refer to an order of all data referenced in the Item or Collection, which may include the metadata itself. When used in an Asset Object, the order refer to the particular data asset linked to in the Asset Object.
The main field describing the order status
orderable
: The item or asset is orderable via the provider scenario.ordered
: The item or asset is ordered and the provider is preparing to make it available.pending
: The item or asset is ordered but wait for an activation before being able for shipping.shipping
: The item or asset order are being processed by the provider to provide you with the asset(s).succeeded
: The provider has delivered your order and asset(s) are available.failed
: The provider is not able to deliver the order.canceled
The order has been canceled.
The timestamps extension and the fields
created
and updated
from common metadata
can be useful addition, usually used in the Item Properties and Collections, sometimes also in the Assets:
- Set
order:date
once the status switches toordered
(i.e. when the user submits the order). - Set
created
once the metadata files gets created, usually when the status isordered
orshipping
. - Set
published
once the order hassucceeded
. - Set the
expires
field when the order hassucceeded
and your order is meant to expire. - Update
updated
on each change oforder:status
and/or whenever an additional asset has been added.
The following types should be used as applicable rel
types in the
Link Object.
Type | Description |
---|---|
order | This link points to a document describing further the order (e.g. terms and conditions of the Item provider.) |
All contributions are subject to the STAC Specification Code of Conduct. For contributions, please follow the STAC specification contributing guide Instructions for running tests are copied here for convenience.
The same checks that run as checks on PR's are part of the repository and can be run locally to verify that changes are valid.
To run tests locally, you'll need npm
, which is a standard part of any node.js installation.
First you'll need to install everything with npm once. Just navigate to the root of this repository and on your command line run:
npm install
Then to check markdown formatting and test the examples against the JSON schema, you can run:
npm test
This will spit out the same texts that you see online, and you can then go and fix your markdown or examples.
If the tests reveal formatting problems with the examples, you can fix them with:
npm run format-examples