Siden beskriver GraphQL, der udstilles på Datafordeleren fra CPR.
Få en introduktion til GraphQL på Datafordeleren, hvis du har brug for en generel og mere teknisk indføring i GraphQL på Datafordeleren.
Læs derudover mere om Anmodning om adgang til beskyttede registerdata.
| Version |
| |
|---|---|---|
| Sikkerhedszone | 5 – Indeholder fortrolige eller følsomme data | |
| Adgangsniveau | Bruger oprettet med MitID Erhverv, og OAuth Shared Secret eller OAuth Certifikat | |
| GraphQL skemaer | https://graphql.datafordeler.dk/CPR/custom/PrivateSector/v2/schema? | |
| https://graphql.datafordeler.dk/CPR/custom/PublicSector/v2/schema? | ||
| Endepunkt for CPR | https://graphql.datafordeler.dk/CPR/custom/<entitet>/<version> | |
| Dato- og tidsformat | Datoformat følger ISO 8601 Date and time format. Alle datoer skrives med andre ord i formatet yyyy-mm-ddTHH:MM:SS.ssssss, hvor tidsangivelsen kan udelades. UTC kan angives enten ved +HH:MM (2019-07-05T07:50:14.687580+01:00) eller ved at benytte Z (2019-07-05T07:50:14.687580Z) | |
| Tjenester og entiteter | Registret har følgende specialudviklede tjenester, der skal anmodes om adgang til for at få adgang til CPR:
|
Bemærk Hvis du skal have adgang til GraphQL-tjenesten CustomPublicSectorPerson, skal det være den eneste valgte tjeneste i feltet ”Entiteter og tjenester” i menuen under Anmodning i Datafordeler Administration. Ingen entiteter skal være valgt. Adgang til tjenesten CustomPublicSectorPerson giver tillige adgang til CPR_Events (hændelser) - også selvom dette ikke fremgår af feltet ”Entiteter og tjenester”. Skal du også have adgang til CPR fildownload, skal du oprette andet IT-system og anmode om dataadgang til entiteter via dette. Anmodninger bliver afslået, hvis der både er valgt GraphQL-tjenester og entiteter til Fildownload i samme anmodning, eller hvis anmodningerne kommer fra samme IT-system. |
For at imødekomme specielle forretningsmæssige behov for enkelte registre udstilles der en række specialudviklede entiteter og tjenester der kan søges adgang til gennem Datafordeler Administration.
Hvis du ønsker at tilgå CPR-data hos Datafordeleren via GraphQL på vegne af en privat virksomhed, skal du først have adgang til CPR's CustomPrivateSectorPerson-tjeneste.
Adgang søges på samme måde som for andre registre med beskyttet data hos Datafordeleren.
Tjenesten vælges i drop-down-menuen ”Vælg entiteter og tjenester” når CPR-registeret er valgt i ”Register”-menuen i en almindelig ”Dataadgang”-ansøgning.
”Dataadgang”-ansøgninger er beskrevet yderligere under Anmodning om adgang til beskyttede registerdata .
Med godkendt adgang til CustomPrivateSectorPerson-tjenesten, har du mulighed for at tilgå entiteten CPRCustom_PrivateSectorPerson via GraphQL. Denne specialudviklede entitet giver mulighed for at tilgå en række af de almindelige entiteter fra CPR-registret og sammenstiller disse, så du ikke selv behøver at tage stilling til hvordan data hænger sammen.
Bemærk at der er en række begrænsninger på hvilke data der kan returneres, som følge af CPR-lovgivningen. Tjenesten udstiller for eksempel udelukkende aktuelle data og der kan ikke hentes data på personer, der har status = ’nedlagt’. Derudover vil adresser, udrejse/indrejse og navn, i tilfælde hvor den pågældende person har navne- og adressebeskyttelse, ikke blive inkluderet i outputtet.
Generelt gælder der de samme regler for udstilling af CPR-data til private anvendere gennem CustomPrivateSectorPerson som for Datafordelerens nuværende REST-tjenester for private. Du kan læse mere om disse regler på siden REST - private (CPR) (udfases Q2-2026) på Det Centrale Personregister (CPR).
For at bruge CustomPrivateSectorPerson-tjenesten skal du give en række input, der unikt identificerer en person. Normalt kan du udelukkende hente data på én person ad gangen. Dog er det muligt at hente flere personer ved brug af PNR-liste-søgning. Tjenesten tager følgende inputparametre:
Du kan identificere en person på en af tre følgende måder:
Udover brug af inputparametre, kalder du CustomPrivateSectorPerson på nøjagtig samme måde som de almindelige GraphQL-tjenester. Hvis du for eksempel ønsker at hente adresseoplysninger for en bestemt person, kan du sende nedenstående GraphQL-query som en POST-request til https://graphql.datafordeler.dk/CPR/custom/PrivateSector/v2:
query {
CPRCustom_PrivateSectorPerson(
input: {
navn: { fornavne: "John", efternavn: "Doe" }
adresse: { postnr: 1550, vejnavn: "Rådhuspladsen", husnr: "1" }
}
) {
statusdato
statusdatousikkerhedsmarkering
status
beskyttelser {
beskyttelsestype
status
virkningfra
}
navn {
adresseringsnavn
efternavn
fornavne
mellemnavn
status
}
vaergemaal {
vaergenavn
adresselinie1
adresselinie2
adresselinie3r
adresselinie4
adresselinie5
vaergemaalstype
virkningfra
virkningfrausikkerhedsmarkering
status
}
udrejseIndrejse {
cprLandIndrejse {
kode
navn
landekode
administrativEnhedType {
typeKode
typeNavn
}
}
cprLandUdrejse {
kode
navn
landekode
administrativEnhedType {
typeKode
typeNavn
}
}
status
udenlandsadresselinie1
udenlandsadresselinie2
udenlandsadresselinie3
udenlandsadresselinie4
udenlandsadresselinie5
virkningfra
virkningfrausikkerhedsmarkering
}
forsvinding {
status
virkningfra
virkningfrausikkerhedsmarkering
}
kontaktadresse {
adresselinie1
adresselinie2
adresselinie3
adresselinie4
adresselinie5
virkningfra
}
adresseoplysninger {
cprAdresse {
bygningsnummer
bynavn
cprkommunekode
cprkommunenavn
cprvejkode
etage
husnummer
postdistrikt
postnummer
sidedoer
vejadresseringsnavn
vejnavn
daradresse
}
conavn
status
virkningfra
virkningfrausikkerhedsmarkering
}
}
} |
Bemærk at overstående eksempel indeholder alle de obligatoriske-felter, som altid skal inkluderes i en query. Alle kald til CustomPrivateSectorPerson-tjenesten uden de obligatoriske felter inkluderet i query’en vil blive afvist og intet data returneret.
Hvis du ønsker at tilgå CPR-data hos Datafordeleren via GraphQL på vegne af en offentlig myndighed, skal du først have adgang til CPR's CustomPublicSectorPerson-tjeneste.
Adgang søges på samme måde som for andre registre med beskyttet data hos Datafordeleren.
Tjenesten vælges blot i drop-down-menuen ”Vælg entiteter og tjenester” når CPR-registeret er valgt i ”Register”-menuen i en”Dataadgang”-ansøgning.
”Dataadgang”-ansøgninger er beskrevet yderligere under Anmodning om adgang til beskyttede registerdata .
Med godkendt adgang til CustomPublicSectorPerson-tjenesten, har du mulighed for at tilgå entiteten CPRCustom_PublicSectorPerson via GraphQL. Denne specialudviklede entitet giver mulighed for at tilgå en række af de almindelige entiteter fra CPR-registret og sammenstille disse, så du ikke selv behøver at tage stilling til hvordan data hænger sammen.
Bemærk at du med denne tjeneste har mulighed for at hente alle data som CPR har tilgængeligt og der derfor er et dataminimeringsansvar, som ligger hos anvenderen, i kun at hente den data der er nødvendigt for at udføre sin funktion i den tilknyttede myndighed.
Ligesom i CustomPrivateSectorPerson-tjenesten kan CustomPublicSectorPerson tage en række inputparametre. Hvilke inputparametre og datafiltreringer og hvordan disse benyttes, fremgår af det tilhørende GraphQL-skema. I modsætning til den private tjeneste, er der ingen af parametrene der er obligatoriske, da du behøver ikke unikt at kunne identificere en person for at fremsøge informationer om vedkommende og tjenesten kan derfor returnere flere personer samtidig. Du kan for eksempel fremsøge adresseoplysninger for flere personer der hedder ”John Doe” samtidig ved at sende nedenstående GraphQL-query, som en POST-request til https://graphql.datafordeler.dk/CPR/custom/PublicSector/v2:
query {
CPRCustom_PublicSectorPerson(
first: 3
input: { navn: { fornavne: { eq: "John" }, efternavn: { eq: "Doe" } } }
) {
nodes {
id
navne {
fornavne
mellemnavn
efternavn
}
adresseoplysninger {
cprAdresse {
daradresse
bygningsnummer
bynavn
cprkommunekode
cprvejkode
etage
husnummer
postdistrikt
postnummer
sidedoer
vejadresseringsnavn
vejnavn
}
status
virkningfra
virkningfrausikkerhedsmarkering
}
beskyttelser {
beskyttelsestype
status
virkningfra
virkningtil
}
}
}
} |
Du kan fremsøge flere personer samtidig, understøtter CustomPublicSectorPerson paging af resultaterne, så du ved almindelige query-parametre (se afsnit om paging) kan specificere hvor mange personer du ønsker returneret ved at givet kald.
Bemærk at beskyttelser-feltet altid skal inkluderes i en query og alle kald til tjenesten uden beskyttelser inkluderet i query’en vil blive afvist og intet data returneret.
Noget nyt sammenlignet med de tidligere CPR-tjenester er, at det nu er muligt at filtrere på "Hændelse" og "Hændelseskoder" for den offentlige sektor. Der er introduceret fire nye parametre: haendelsekode.haendelsekode, haendelsekode.virkningfra, haendelse.forretningshaendelse og haendelse.afleveringdato.
En komplet liste over hvilke hændelseskoder og forretningshændelser der findes kan ses på CPR's egen dokumentation CPRhændelser til Datafordeleren.