OGC API - Features
Added in version 2.3.
Driver short name
OAPIF
Build dependencies
libcurl
This driver can connect to a OGC API - Features service. It assumes that the service supports OpenAPI 3.0/JSON/GeoJSON encoding for respectively API description, feature collection metadata and feature collection data.
Note
In versions prior to GDAL 3.1, this driver was called the WFS3 driver, and only supported draft versions of the specification.
Driver capabilities
Supports Georeferencing
This driver supports georeferencing
Dataset name syntax
The syntax to open a OGC API - Features datasource is : OAPIF:http://path/to/OAPIF/endpoint
where endpoint is the landing page or a the path to collections/{id}.
Starting with GDAL 3.10, specifying the -if OAPIF
option to command line utilities
accepting it, or OAPIF
as the only value of the papszAllowedDrivers
of
GDALOpenEx()
, also forces the driver to recognize the passed
URL without the OAPIF:
prefix.
Layer schema
OGR needs a fixed schema per layer, but OGC API - Features Core doesn't impose fixed schema. The driver will use the XML schema or JSON schema pointed by the "describedby" relationship of a collection, if it exists. The driver will also retrieve the first page of features (using the selected page) and establish a schema from this.
Filtering
The driver will forward any spatial filter set with SetSpatialFilter() to the server. In OGC API - Features Core, only a subset of attributes allowed by the server can be queried for equalities, potentially combined with a AND logical operator. More complex requests will be partly or completely evaluated on client-side.
Rectangular spatial filtering is forward to the server as well.
Starting with GDAL 3.10, the DATETIME
open option can also be specified for
temporal filtering.
CRS support
Starting with GDAL 3.7, the driver supports the OGC API - Features - Part 2: Coordinate Reference Systems by Reference extension. If a server reports a storageCRS property, that property will be used to set the CRS of the OGR layer. Otherwise the default will be OGC:CRS84 (WGS84 longitude, latitude). As most all OGR drivers, the OAPIF driver will report the SRS and geometries, and expect spatial filters, in the "GIS-friendly" order, with longitude/easting first (X component), latitude/northing second (Y component), potentially overriding the axis order of the authority.
The CRS of layers can also be controlled with the CRS
or PREFERRED_CRS
open
options documented below.
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:
URL=value: URL to the OGC API - Features server landing page, or to a given collection. Required when using the "OAPIF:" string as the connection string.
PAGE_SIZE=<integer>: Defaults to
1000
. Number of features to retrieve per request. Minimum is 1. If not set, an attempt to determine the maximum allowed size will be done by examining the API schema.INITIAL_REQUEST_PAGE_SIZE=<integer>: Defaults to
20
. Number of features to retrieve during the initial request done in order to retrieve information about the features. Minimum is 1. Maximum is the value of thePAGE_SIZE
option. If not set the default (20) will be used.USERPWD=value: May be supplied with userid:password to pass a userid and password to the remote server.
IGNORE_SCHEMA=[YES/NO]: (GDAL >= 3.1)
Set to YES to ignore the XML Schema or JSON schema that may be offered by the server.
CRS=value: (GDAL >= 3.7) Set to a CRS identifier, e.g
EPSG:3067
orhttp://www.opengis.net/def/crs/EPSG/0/3067
, to use as the layer CRS. That CRS must be listed in the lists of CRS supported by the layers of the dataset, otherwise layers not listing it cannot be opened.PREFERRED_CRS=value: (GDAL >= 3.7) Identical to the
CRS
option, except that if a layer does not list the PREFERRED_CRS in its list of supported CRS, the default CRS (storageCRS when present, otherwise EPSG:4326) will be used.CRS
andPREFERRED_CRS
option are mutually exclusive.SERVER_FEATURE_AXIS_ORDER=[AUTHORITY_COMPLIANT/GIS_FRIENDLY]: Defaults to
AUTHORITY_COMPLIANT
. This option can be set to GIS_FRIENDLY if axis order issue are noticed in features received from the server, indicating that the server does not return them in the axis order mandated by the CRS authority, but in a more traditional "GIS friendly" order, with longitude/easting first, latitude/northing second. Do not set this option unless actual problems arise.DATETIME=value: (GDAL >= 3.10)
Temporal filter. Its value should match the ones mentioned at paragraph Parameter datetime of the OGC API Features specification
Examples
Listing the types of a OGC API - Features server :
$ ogrinfo OAPIF:https://ogc-api.nrw.de/inspire-us-feuerwehr INFO: Open of `OAPIF:https://ogc-api.nrw.de/inspire-us-feuerwehr' using driver `OAPIF' successful. 1: governmentalservice (title: Feuerwehrleitstellen) (Point)
Listing the summary information of a OGC API - Features layer :
$ ogrinfo OAPIF:https://ogc-api.nrw.de/inspire-us-feuerwehr governmentalservice -al -so INFO: Open of `OAPIF:https://ogc-api.nrw.de/inspire-us-feuerwehr' using driver `OAPIF' successful. Layer name: governmentalservice Metadata: DESCRIPTION=Staatliche Verwaltungs- und Sozialdienste wie öffentliche Verwaltung, Katastrophenschutz, Schulen und Krankenhäuser, die von öffentlichen oder privaten Einrichtungen erbracht werden, soweit sie in den Anwendungsbereich der Richtlinie 2007/2/EG fallen. Dieser Datensatz enthält Informationen zu Feuerwehrleitstellen. TITLE=Feuerwehrleitstellen Geometry: Point Feature Count: 52 Extent: (6.020720, 50.654901) - (9.199363, 52.300806) Layer SRS WKT: GEOGCRS["WGS 84", DATUM["World Geodetic System 1984", ELLIPSOID["WGS 84",6378137,298.257223563, LENGTHUNIT["metre",1]]], PRIMEM["Greenwich",0, ANGLEUNIT["degree",0.0174532925199433]], CS[ellipsoidal,2], AXIS["geodetic latitude (Lat)",north, ORDER[1], ANGLEUNIT["degree",0.0174532925199433]], AXIS["geodetic longitude (Lon)",east, ORDER[2], ANGLEUNIT["degree",0.0174532925199433]], ID["EPSG",4326]] Data axis to CRS axis mapping: 2,1 id: String (0.0) name: String (0.0) inspireId: String (0.0) serviceType.title: String (0.0) serviceType.href: String (0.0) areaOfResponsibility.1.title: String (0.0) areaOfResponsibility.1.href: String (0.0) pointOfContact.address.thoroughfare: String (0.0) pointOfContact.address.locatorDesignator: String (0.0) pointOfContact.address.postCode: String (0.0) pointOfContact.address.adminUnit: String (0.0) pointOfContact.address.text: String (0.0) pointOfContact.telephoneVoice: String (0.0) pointOfContact.telephoneFacsimile: String (0.0) pointOfContact.telephoneFacsimileEmergency: String (0.0) inDistrict.title: String (0.0) inDistrict.href: String (0.0) inDistrictFreeTown.title: String (0.0) inDistrictFreeTown.href: String (0.0) inGovernmentalDistrict.title: String (0.0) inGovernmentalDistrict.href: String (0.0)
Filtering on a property (depending on if the server exposes filtering capabilities of the properties, part or totally of the filter might be evaluated on client side)
$ ogrinfo OAPIF:https://ogc-api.nrw.de/inspire-us-feuerwehr governmentalservice -al -q -where "name = 'Schwelm'" Layer name: governmentalservice Metadata: DESCRIPTION=Staatliche Verwaltungs- und Sozialdienste wie öffentliche Verwaltung, Katastrophenschutz, Schulen und Krankenhäuser, die von öffentlichen oder privaten Einrichtungen erbracht werden, soweit sie in den Anwendungsbereich der Richtlinie 2007/2/EG fallen. Dieser Datensatz enthält Informationen zu Feuerwehrleitstellen. TITLE=Feuerwehrleitstellen OGRFeature(governmentalservice):1 id (String) = LtS01 name (String) = Schwelm inspireId (String) = https://geodaten.nrw.de/id/inspire-us-feuerwehr/governmentalservice/LtS01 serviceType.title (String) = Brandschutzdienst serviceType.href (String) = http://inspire.ec.europa.eu/codelist/ServiceTypeValue/fireProtectionService areaOfResponsibility.1.title (String) = Breckerfeld areaOfResponsibility.1.href (String) = https://registry.gdi-de.org/id/de.nw.inspire.au.basis-dlm/AdministrativeUnit_05954004 pointOfContact.address.thoroughfare (String) = Hauptstr. pointOfContact.address.locatorDesignator (String) = 92 pointOfContact.address.postCode (String) = 58332 pointOfContact.address.adminUnit (String) = Schwelm pointOfContact.address.text (String) = Hauptstr. 92, 58332 Schwelm pointOfContact.telephoneVoice (String) = +49233644400 pointOfContact.telephoneFacsimile (String) = +4923364440400 pointOfContact.telephoneFacsimileEmergency (String) = +49233644407100 inDistrict.title (String) = Ennepe-Ruhr inDistrict.href (String) = Ennepe-Ruhr inGovernmentalDistrict.title (String) = Arnsberg inGovernmentalDistrict.href (String) = https://registry.gdi-de.org/id/de.nw.inspire.au.basis-dlm/AdministrativeUnit_059 POINT (7.29854802787082 51.2855116825595)
Spatial filtering
$ ogrinfo OAPIF:https://ogc-api.nrw.de/inspire-us-feuerwehr governmentalservice -al -q -spat 7.1 51.2 7.2 51.5 Layer name: governmentalservice Metadata: DESCRIPTION=Staatliche Verwaltungs- und Sozialdienste wie öffentliche Verwaltung, Katastrophenschutz, Schulen und Krankenhäuser, die von öffentlichen oder privaten Einrichtungen erbracht werden, soweit sie in den Anwendungsbereich der Richtlinie 2007/2/EG fallen. Dieser Datensatz enthält Informationen zu Feuerwehrleitstellen. TITLE=Feuerwehrleitstellen OGRFeature(governmentalservice):1 id (String) = LtS33 name (String) = Wuppertal-Solingen inspireId (String) = https://geodaten.nrw.de/id/inspire-us-feuerwehr/governmentalservice/LtS33 serviceType.title (String) = Brandschutzdienst serviceType.href (String) = http://inspire.ec.europa.eu/codelist/ServiceTypeValue/fireProtectionService areaOfResponsibility.1.title (String) = Wuppertal areaOfResponsibility.1.href (String) = https://registry.gdi-de.org/id/de.nw.inspire.au.basis-dlm/AdministrativeUnit_05124000 pointOfContact.address.thoroughfare (String) = August-Bebel-Str. pointOfContact.address.locatorDesignator (String) = 55 pointOfContact.address.postCode (String) = 42109 pointOfContact.address.adminUnit (String) = Wuppertal pointOfContact.address.text (String) = August-Bebel-Str. 55, 42109 Wuppertal pointOfContact.telephoneVoice (String) = +492025631111 pointOfContact.telephoneFacsimile (String) = +49202445331 pointOfContact.telephoneFacsimileEmergency (String) = 112 inDistrictFreeTown.title (String) = Wuppertal inDistrictFreeTown.href (String) = Wuppertal inGovernmentalDistrict.title (String) = Düsseldorf inGovernmentalDistrict.href (String) = https://registry.gdi-de.org/id/de.nw.inspire.au.basis-dlm/AdministrativeUnit_051 POINT (7.13806554104892 51.2674471939457)