PLScenes (Planet Labs Scenes), Data V1 API
Added in version 2.2.
The driver supports read-only operations to list scenes and their metadata as a vector layer per item-types: "PSOrthoTile", "REOrthoTile", "PSScene3Band", "PSScene4Band", "REScene", "Landsat8L1G", "Sentinel2L1C". It can also access raster scenes.
Driver capabilities
Supports Georeferencing
This driver supports georeferencing
Dataset name syntax
The minimal syntax to open a datasource is :
PLScenes:[options]
Additional optional parameters can be specified after the ':' sign. Currently the following one is supported :
version=data_v1: To specify the API version to request.
api_key=value: To specify the Planet API KEY. It is mandatory, unless it is supplied through the open option API_KEY, or the configuration option
PL_API_KEY
.follow_links=YES/NO: Whether assets links should be followed for each scene (vector). Getting assets links require a HTTP request per scene, which might be costly when enumerating through a lot of products. Defaults to NO.
scene=scene_id: To specify the scene ID, when accessing raster data. Optional for vector layer access.
itemtypes=name: To specify the item types name. Optional for vector layer access. Mandatory for raster access.
asset=value: To specify the asset type (for raster fetching). Default is "visual". Optional for vector layer access. If the option is not specified and the 'visual' asset category does not exist for the scene (or if the value is set to 'list'), the returned dataset will have subdatasets for the available asset categories.
medata=YES/NO: (Raster only) Whether scene metadata should be fetch from the API and attached to the raster dataset. Defaults to YES.
If several parameters are specified, they must be separated by a comma.
Open options
Open options can be specified in command-line tools using the syntax -oo <NAME>=<VALUE>
or by providing the appropriate arguments to GDALOpenEx()
(C) or gdal.OpenEx
(Python).
The following open options are available:
VERSION=value: Defaults to
DATA_V1
. To specify the API version to request.API_KEY=value: To specify the Planet API KEY.
FOLLOW_LINKS=[YES/NO]: Defaults to
NO
. Whether assets links should be followed for each scene (vector). Getting assets links require a HTTP request per scene, which might be costly when enumerating through a lot of products.SCENE=<scene_id>: To specify the scene ID, when accessing raster data. Optional for vector layer access.
ITEMTYPES=<name>: To specify the item types name. Optional for vector layer access. Mandatory for raster access.
ASSET=value: Defaults to
visual
. To specify the asset type (for raster fetching). Optional for vector layer access. If the option is not specified and the 'visual' asset category does not exist for the scene (or if the value is set to 'list'), the returned dataset will have subdatasets for the available asset categories.RANDOM_ACCESS=[YES/NO]: Defaults to
YES
. Whether raster should be accessed in random access mode (but with potentially not optimal throughput). If NO, in-memory ingestion is done.ACTIVATION_TIMEOUT=seconds: Defaults to
3600
. Number of seconds during which to wait for asset activation (raster).METADATA=[YES/NO]: Defaults to
YES
. (Raster only) Whether scene metadata should be fetched from the API and attached to the raster dataset.
Configuration options
Configuration options can be specified in command-line tools using the syntax --config <NAME>=<VALUE>
or using functions such as CPLSetConfigOption()
(C) or gdal.config_options
(Python).
The following configuration options are available:
PL_API_KEY=value: To specify the Planet API key.
PLSCENES_PAGE_SIZE=value: Defaults to
250
. Chunk size for fetching features. Maximum value is 250.
Attributes
The layer field definition is built from the "plscenesconf.json" file in the GDAL configuration. The links to downloadable products are in asset_XXXXX_location attributes where XXXXX is the asset category id, when they are active. Otherwise they should be activated by sending a POST request to the URL in the asset_XXXXX_activate_link attribute (what the raster driver does automatically)
Geometry
The footprint of each scene is reported as a MultiPolygon with a longitude/latitude WGS84 coordinate system (EPSG:4326).
Filtering
The driver will forward any spatial filter set with SetSpatialFilter() to the server. It also makes the same for simple attribute filters set with SetAttributeFilter(). Note that not all attributes support all comparison operators. Refer to comparator column in Metadata properties
Paging
Features are retrieved from the server by chunks of 250 by default (and
this is the maximum value accepted by the server). This number can be
altered with the PLSCENES_PAGE_SIZE
configuration
option.
Vector layer (scene metadata) examples
Listing all scenes available (with the rights of the account) :
ogrinfo -ro -al "PLScenes:" -oo API_KEY=some_value
or
ogrinfo -ro -al "PLScenes:api_key=some_value"
or
ogrinfo -ro -al "PLScenes:" --config PL_API_KEY some_value
Listing all scenes available on PSOrthoTile item types, under a point of (lat,lon)=(40,-100) :
ogrinfo -ro -al "PLScenes:" -oo API_KEY=some_value PSOrthoTile -spat -100 40 -100 40
Listing all scenes available within a bounding box (lat,lon)=(40,-100) to (lat,lon)=(39,-99)
ogrinfo -ro -al "PLScenes:" -oo API_KEY=some_value -spat -100 40 -99 39
Listing all scenes available matching criteria :
ogrinfo -ro -al "PLScenes:" -oo API_KEY=some_value PSOrthoTile -where "acquired >= '2015/03/26 00:00:00' AND cloud_cover < 10"
List all downloadable scenes:
ogrinfo -ro -al -q "PLScenes:" -oo API_KEY=some_value PSOrthoTile -where "permissions='assets:download'"
Raster access
Scenes can be accessed as raster datasets, provided that the scene ID is
specified with the 'scene' parameter / SCENE
open option. The
'itemtypes' parameter / ITEMTYPES
open option must also be specified.
The asset type (visual, analytic, ...) can be specified with the 'asset'
parameter / ASSET
open option. The scene id is the content of the value
of the 'id' field of the features.
If the product is not already generated on the server, it will be
activated, and the driver will wait for it to be available. The length
of this retry can be configured with the ACTIVATION_TIMEOUT
open option.
Raster access examples
Displaying raster metadata :
gdalinfo "PLScenes:scene=scene_id,itemtypes=itemypes,asset=analytic" -oo API_KEY=some_value
or
gdalinfo "PLScenes:" -oo API_KEY=some_value -oo ITEMTYPES=itemtypes -oo SCENE=scene_id -oo ASSET=analytic
Converting/downloading a whole file:
gdal_translate "PLScenes:" -oo API_KEY=some_value -oo SCENE=scene_id \
-oo ITEMTYPES=itemtypes -oo ASSET=analytic -oo RANDOM_ACCESS=NO out.tif