Introduction
Actinia is a REST service to process geographical data that can be managed by the GRASS GIS software system. The software is designed to expose a GRASS GIS database and many GRASS GIS^1 processing tools as REST service^2. Hence, access to GRASS resources like raster maps, space-time raster datasets, processing and analysis modules are available via URL. In addition Actinia allows the processing of cloud based data, for example all Landsat 4-8 scenes as well as all Sentinel-2A scenes in an ephemeral database. The computational results of ephemeral processing are available via object storage as GeoTIFF files.
The actinia service consists of the actinia core that provides the basic but sophisticated processing service and actinia plugins that provide problem specific services like Sentinel-2 and Landsat NDVI computation, spatio-temporal statistical analysis and many more.
To use actinia the user must have an understanding of the GRASS GIS concept^3 of location, mapsets, raster maps, space-time datasets and modules. The URLs that provide access to the GRASS database reflect these concepts. Hence, the location, the mapset and the required raster map are part of the URL to access the service.
What is REST?
The Representational state transfer (REST)^4 is an architectural style based on HTTP^5 that uses GET^6, DELETE^7, POST^8 and PUT^9 methods to manipulate and receive resources with stateless operations.
While GET requests can be send easily from a browser, POST, PUT or DELETE request can not. To access the full potential of actinia you will need a HTTP client, that talks all HTTP communication methods.
Examples
We will use the Unix shell and curl to access the REST API. First open a shell of choice (we use bash here) and setup the login information, the IP address and the port on which the actinia service is running, so you can simply change the IP and port if your server uses a different address:
export ACTINIA_URL=https://actinia.mundialis.de/latest
export AUTH='-u demouser:gu3st!pa55w0rd'
# other user credentials can be provided in the same way
Data management
List all locations that are available in the actinia persistent database:
curl ${AUTH} -X GET "${ACTINIA_URL}/locations"
List all mapsets in the location latlong_wgs84:
curl ${AUTH} -X GET "${ACTINIA_URL}/locations/latlong_wgs84/mapsets"
List all raster layers in location latlong_wgs84 and mapset Sentinel2A:
curl ${AUTH} -X GET "${ACTINIA_URL}/locations/latlong_wgs84/mapsets/Sentinel2A/raster_layers"
List all space-time raster datasets (STRDS) in location ECAD and mapset PERMANENT:
curl ${AUTH} -X GET "${ACTINIA_URL}/locations/ECAD/mapsets/PERMANENT/strds"
List all raster map layers of the STRDS precipitation_1950_2013_yearly_mm:
curl ${AUTH} -X GET "${ACTINIA_URL}/locations/ECAD/mapsets/PERMANENT/strds/precipitation_1950_2013_yearly_mm/raster_layers"
Landsat and Sentinel-2A NDVI computation
This API call will compute the NDVI of the top of athmosphere (TOAR) corrected Landsat4 scene LC80440342016259LGN00:
curl ${AUTH} -X POST "${ACTINIA_URL}/landsat_process/LC80440342016259LGN00/TOAR/NDVI"
NDVI computation of Sentinel-2A scene S2A_MSIL1C_20170212T104141_N0204_R008_T31TGJ_20170212T104138:
curl ${AUTH} -X POST "${ACTINIA_URL}/sentinel2_process/ndvi/S2A_MSIL1C_20170212T104141_N0204_R008_T31TGJ_20170212T104138"
The results of the asynchronous computations are available as GeoTIFF file in a cloud storage for download.
Footnotes