Process graphs
A process graph is a chain of specific processes. Similarly to scripts in the context of programming, process graphs organize and automate the execution of one or more processes that could alternatively be executed individually. In a process graph, processes need to be specific, i.e. concrete values for input parameters need to be specified. These arguments can again be process graphs, scalar values, arrays or objects.
Schematic definition
A process graph is defined to consist of chained processes:
<ProcessGraph> := <Process>
An argument value of a process can hold a Process again. This allows chaining of processes.
Process
A single process in a process graph is defined as follows:
<Process> := { "process_id": <string>, "process_description": <string>, "<ArgumentName>": <Value>, ... }
process_id
and MAY contain a process_description
. It MAY hold an arbitrary number of additional elements as arguments for the process.
process_id
can contain any of the processes defined by a back-end, which are all listed at GET /processes
, e.g. get_collection
to retrieve data from a specific collection for processing.
Arguments
A process can have an arbitrary number of arguments.
The key <ArgumentName>
can be any valid JSON key, but it is RECOMMENDED to use snake case and limit the characters to a-z
, 0-9
and _
. <ArgumentName>
MUST NOT use the names process_id
or process_description
as it would result in a naming conflict.
A value is defined as follows:
<Value> := <string|number|boolean|null|array|object|Process|Variable>
Note
The specified data types except Process
and Variable
(see definition above) are the native data types supported by JSON. Some limitations apply:
An array MUST always contain one data type only and is allowed to contain the data types allowed for <Value>
.
Objects are not allowed to have keys with the following names:
* process_id
, except for objects of type Process
* variable_id
, except for objects of type Variable
Caution
The expected names of arguments are defined by the process descriptions, which can be discovered with calls to GET /processes
. Therefore, the key name for a key-value-pair holding an image collection as value doesn't necessarily need to be named imagery
. The name depends on the name of the corresponding process argument the image collection is assigned to. Example 2 demonstrates this by using collection
as a key once.
Variables
Process graphs can also hold a variable, which can be filled in later. For shared process graphs this can be useful to make them more portable, e.g in case a back-end specific product name would be stored with the process graph.
Variables are defined as follows:
<Process> := { "variable_id": <string>, "description": <string>, "type": <string>, "default": <Value> }
The value for type
is the expected data type for the content of the variable and MUST be one of string
(default), number
, boolean
, array
or object
.
The value for variable_id
is the name of the variable and can be any valid JSON key, but it is RECOMMENDED to use snake case and limit the characters to a-z
, 0-9
and _
.
Whenever no value for the variable is defined, the default
value is used. <Value>
can be used as defined above, but MUST NOT be a Variable
. Values for variables can be specified in the query string or body of endpoints supporting variables. See the API reference for more information.
Examples
Example 1: A full process graph definition including a variable for the collection name
.
{ "process_id":"min_time", "imagery":{ "process_id":"/udf/Python/custom_ndvi", "imagery":{ "process_id":"filter_daterange", "imagery":{ "process_id":"filter_bbox", "imagery":{ "process_id":"get_collection", "name":{ "variable_id":"product", "description":"Identifier of the collection", "type":"string", "default":"S2_L2A_T32TPS_20M" } }, "west":652000, "east":672000, "north":5161000, "south":5181000, "srs":"EPSG:32632" }, "extent":[ "2017-01-01T00:00:00Z", "2017-01-31T23:59:59Z" ] }, "red":"B04", "nir":"B8A" } }
Example 2: If a process needs multiple processes as input, it is allowed to use arrays of the respective types.
{ "imagery":{ "process_id":"union", "collection":[ { "process_id":"filter_bands", "imagery":{ "process_id":"get_collection", "name":"Sentinel2-L1C" }, "bands":"8" }, { "process_id":"filter_bands", "imagery":{ "process_id":"get_collection", "name":"Sentinel2-L1C" }, "bands":"5" } ] } }