Fordele ved brug af REST
Servicetyper
Når en webservice konfigureres genereres der automatisk en url.
Opbygningen af url’en sker ud fra følgende kriterier, som angives i forbindelse med konfigurationen af webservicen:
- Protokol (http/https)
- Webservicetype (REST, WFS, WMS, WMTS, WCS)
- Webservicenavn
- Version af webservicen
Strukturen for den genererede url sker i overensstemmelse med følgende skema:
<scheme>://<authority>/<path>/?<parameters>
Strukturen for den samlede url sker i overensstemmelse med følgende skema, når<authority> og <path> bliver foldet ud:
<scheme>://<alias>.datafordeler.dk/<owner>/<service>/<version>/<metode>/?<parameters>
Sikkerhedsparametre
OCES certifikater
Kald med certifikater skal ikke ske til det ”normale” endpoint, men skal gå til et separat endpoint specifikt for anvendelse af certifikater.
- Url vil for webservices med certifikater i zone 0 starte med: https://certservices.datafordeler.dk/
- Url vil for webservices med certifikater i zone 5 starte med: https://s5-certservices.datafordeler.dk/
Se endpoint for testmiljøerne på siden Hent data.
Brugernavn/adgangskode
<scheme>://<alias>.datafordeler.dk/<owner>/<service>/<version>/<metode>/?username=xxx&password=yyy
Paging
Det er muligt at anvende paging for de REST-services, der er konfigureret til det.
I webservicekatalogerne vil det fremgå af de generelle informationer om registrets webservices er konfigureret til at benytte paging samt informationer om en default paging-størrelse.
Anvender paging:
- Bygnings- og Boligregistret (BBR) (Default paging-størrelse: 100)
- Danmarks Administrative Geografiske Inddeling (DAGI) (Default paging-størrelse: 20)
- Danmarks Adresseregister (DAR) (Default paging-størrelse: 100)
- Det Centrale Personregister (CPR) - offentlig (Default paging-størrelse: 20)
- Ejendomsbeliggenhedsregistret (EBR) (Default paging-størrelse: 20)
- Ejerfortegnelsen (EJF) (Default paging-størrelse: 20)
Anvender ikke paging:
- Danmarks Højdemodel (DHM)
- Danske Stednavne
- Det Centrale Personregister (CPR) - privat
- Det Centrale Virksomhedsregister (CVR)
- Ejendomsvurdering (VUR)
- Historiske kort og data
- Matriklen (MAT)
Benytter du paging vil den samlede url følge dette skema:
<scheme>://<alias>.datafordeler.dk/<owner>/<service>/<version>/<metode>/?page=xxx&pagesize=yyy
Count
Antal elementer i resultatsættet returneres ved at angive parameteren count i REST kald.
Benytter du count vil den samlede url følge dette skema:
<scheme>://<alias>.datafordeler.dk/<owner>/<service>/<version>/<metode>/?count=true
Format
REST-servicen kan returnere data i formaterne JSON og XML. Angiver du ikke hvilket format du ønsker dit output vil du modtage det i JSON, da de er defaultværdien på Datafordeleren.
Vælger du at specificere formatet, vil den samlede url følge dette skema:
<scheme>://<alias>.datafordeler.dk/<owner>/<service>/<version>/<metode>/?format=xxx
En anden mulighed er at sætte accept headeren til "application/json" eller "application/xml".
jsonpCallback
jsonpCallback: jsonp kan anvendes ved at angive jsonpCallback=xxx.
De registerspecifikke servicekataloger er knyttet til de specifikationer, som registret har specificeret i deres Dataleverancespecifikation (DLS). For hver parameter er dens type angivet.
Der benyttes følgende typer:
- UUID
- Liste af værdier af typen UUID
- String
- Liste af værdier af typen String
- Integer
- Liste af værdier af typen Integer
- DateTime
- Date
- Boolean
- Double
I de registerspecifikke servicekatologer vil du under hver metode kunne se hvilke parametre, som det er muligt at benytte på den enkelt metode og af hvilken type den er.
Liste af værdier
Nogle tjenester accepterer at en parameter består af en liste af værdier.
For de REST baserede webservices er dette understøttet ved at de enkelte værdier i listen adskilles af et ”|”-tegn (pipe karakter).
Eksempel med 4 værdier i en liste til en parameter: Værdi1|Værdi2|Værdi3|Værdi4
Webservices kan i Datafordeleren konfigureres til at kræve kvitteringer fra anvenderen.
Alle forespørgsler til en webservice vil returnere en response-header med kvitteringsID (receipt id) og kaldet DataDistributor.ReceiptId.
For at kvittere for data skal du sende en POST anmodning til kvitteringsservicen.
https://<endpoint>.datafordeler.dk/system/receipt/1/rest?username=xxx&password=yyy
med en request body der ser ud som (json eksempel):
{ "ReceiptId":"zzz" }
hvor “zzz” angiver kvitteringsID.