4.10 REST-tjänster för filhantering
Innehåll
- 1 Innehåll
- 2 Inledning
- 3 Användningsfall
- 3.1 Söka personuppgifter via fil: SearchPersonsByFile
- 3.1.1 Parametrar
- 3.1.2 Version
- 3.1.3 Exempel
- 3.2 Hämta resultat för personsök
- 3.2.1 Exempel
- 3.2.1.1 SearchPersonsForProfileByOrder
- 3.2.1.2 GetFilesForOrderId
- 3.2.1.3 REST
- 3.2.1 Exempel
- 3.3 Bilagor för reservidentitet
- 3.3.1 Ladda upp bilaga
- 3.3.1.1 URL
- 3.3.1.2 Parametrar
- 3.3.1.3 Exempel
- 3.3.2 Koppla / Koppla ifrån bilaga
- 3.3.3 Hämta bilaga
- 3.3.3.1 URL
- 3.3.3.2 Parametrar
- 3.3.3.3 Exempel
- 3.3.4 Ta bort bilaga
- 3.3.4.1 URL
- 3.3.4.2 Parametrar
- 3.3.4.3 Exempel
- 3.3.1 Ladda upp bilaga
- 3.1 Söka personuppgifter via fil: SearchPersonsByFile
Inledning
Om dokumentet
Denna beskrivning är ett tillägg av tjänstekontrakten i tjänstedomänen strategicresourcemanagement:persons:person. Dokumentet beskriver hur tjänstens funktionalitet för att hämta och ladda upp filer är uppbyggd. Funktionaliteten baseras på dokument ARK_0038 enligt RIV-TA standarden och där grundprincipen för att hämta filer bygger på en RIV-tjänst för att lista tillgängliga filer och en REST-tjänst för att hämta de filer som listas via RIV-tjänsten. Anrop mot tjänsterna sker med HTTPS (Mutual-TLS) och validering av certifikatet från tjänstekonsument utförs för att endast tillåta att tjänsten levererar data till tillåtna mottagare.
Konnektivitet
SOAP-tjänst för att lista tillgängliga filer är tillgängliga via Nationell Tjänsteplattform (NTjP). NTjP saknar dock stöd för REST-baserade tjänster vilket medför att REST-tjänst för att hämta filer (ladda upp/ta bort) enbart är tillgänglig genom direktaccess mot tjänsteproducent.
Versionshantering av searchPersonsByFile i version 4.8
Vid Release 4.8 gjordes en driftsförändring som gav REST-tjänsten för searchPersonsByFile två versioner. Läs mer under 2.1.1.2 Version
Notering om HSA-id: Personuppgiftstjänstens REST-tjänster kontrollerar vid begäran om filnedladdning att det är systemet med samma HSA-id som beställt filen. Om anropande konsument använder ett mellanlager i anslutning till NTjP, såsom en lokal tjänsteplattform, är det då viktigt för konsumenten att korrekt populera headern x-rivta-originalserviceconsumer-hsaid. Denna header skall ange det ursrungliga konsumerande systemets HSA-id, i enlighet med regel "Bevara ursprunglig avsändares identitet i http header" samt RIVTA Regel 23.
Beställning av behörighet
Personuppgiftstjänstens filhanteringstjänster är REST-tjänster som inte ingår i Inera NTjP. Behörighet för att använda dessa följer därför ett separat beställningsförfarande.
Beställning av behörighet till REST-tjänster görs genom att fylla i följande beställningsformulär, vilket skickas till Ineras kundtjänst på kundservice@inera.se. Ange i mailtexten att det gäller "Beställning av REST-tjänst för Personuppgiftstjänsten – se bilaga."
HSA-id: Till skillnad från NTjP-baserade tjänstekontrakt så kommer behörighet till REST-tjänsterna alltid att utgå ifrån HSA-id hos det konsumerande systemet, inte ifrån HSA-id hos eventuellt mellanlager. Ange därför i beställningen av REST-tjänst alltid det konsumerande systemets HSA-id.
Ärendenummer för NTjP tjänstekontrakt: Godkännande av beställning av behörighet för REST-tjänster kräver att beställaren redan har en godkänd beställning av NTjP tjänstekontrakt för Personuppgiftstjänsten. I beställning av REST-tjänst anges därför ärendenumret för denna tidigare "Beställning från beställningsstödet" avseende NTjP tjänstekontrakt.
Användningsfall: Beställning av behörighet för REST-tjänsterna görs utifrån användningsfall enligt tabell nedan. Varje beställt användningsfall ger behörighet till en eller flera ingående REST-tjänster.
Användningsfall | Syfte | Ingående REST-tjänster |
Söka personuppgifter via fil | Begär en sökning på en bifogad lista med identiteter | SearchPersonsByFile Order/Get |
Hämta resultatfil från kriteriesökning | Hämta resultat från en sökning gjord via NTjP tjänstekontrakt som genererat en resultatfil | Order/Get |
Hantering av bilagor för reservidentiteter | Inkludera bilagd fil som styrker en reservidentitet | Attachment/Put Attachment/Get Attachment/Delete |
Användningsfall
Filhantering förekommer i följande användningsfall inom Personuppgiftstjänsten:
Söka personuppgifter via fil: SearchPersonsByFile
Hämta resultat för asynkron personsökning: SearchPersonsForProfileByOrder och SearchPersonsByFile
Hantering av bilagor för reservidentiteter: Hämta, ladda upp samt ta bort
Användningsfall 2 och delvis 3 följer flödet som beskrivs i ARK_0038 Refererad bilaga, medans detta inte är applicerbart i användningsfallen 1 och delvis 3 vid uppladdning av bilagor. Flöden för samtliga användningsfall specificeras i följande avsnitt.
Söka personuppgifter via fil: SearchPersonsByFile
Funktionen finns endast som restricted-variant. Returnerar alltså inte adress m.m på sekretessmarkerade personposter.
Flödet startar med att att en lista med personidentiteter behöver uppdateras. Listan upprättas som en radbruten CSV-fil där identiteterna anges med personid och personid-typ (OID) separerade med semikolon. Ex: 191212121212;1.2.752.129.2.1.3.1
Filen laddas upp via REST-metoden SearchPersonsByFile som vid lyckad uppladdning returnerar ett Order-Id. Detta Order-Id används som inparameter till tjänsten GetFilesForOrderId som returnerar ett svar om var den resulterande filen kan hämtas.
Om ordern inte är redo för nedladdning än så returneras inget svar, försök senare. Då ordern läggs på kö så kan väntetiden variera mycket. Kontakta supporten om din order inte är redo efter 24h.
OBS: Filer skapade via personsök är garanterat tillgängliga i ett dygn, därefter rensas dom automatiskt bort från Personuppgiftstjänsten. Filer som har hämtats kan rensas bort tidigare.
Den slutgiltiga filen som hämtas är en zippad fil innehållande en XML med det urval som efterfrågats, GetPersonsForProfileResponse. Notera där följande:
SearchPersonsByFile har ej stöd för sökning mot personposter med testIndicator=true, dvs personidentiteter som i testmiljö kallas testpersoner och i produktionsmiljö kallas valideringspersoner. En sökning mot sådan identitet kommer inte att returnera någon personRecord oavsett om personposten finns i databasen eller ej, dvs svaret ser alltid ut som att ingen träff fanns på denna identitet. För tester av SearchPersonsByFile behöver istället testpersoner med testIndicator=false användas.
Parametrar
Namn | Beskrivning |
---|---|
profile | Obligatorisk parameter för vilken profil som önskas i svaret. Se TKB för beskrivning av profilerna P1-P5. Observera att profilen skall anges med versalt P. Datatyp: String. Exempel: P1 |
fromDate | Valfri parameter för det datum man är intresserad av förändringar från och med baserat på fältet version i personposten. Datatyp: LocalDateTime. Exempel: 2021-10-12T00:00:00 |
maxResultsPerFile | Valfri parameter för max antal personposter per fil. Ej angivet så returneras alltid resultatet i endast en fil. Detta värde får ej vara lägre än 500. Datatyp: Integer. Exempel: 1000 |
primaryidentities | Valfri parameter som om satt gör att endast personposter som är markerad som huvudidentitet inkluderas i svaret. En efterfrågad personpost som inte är en huvudidentitet kommer då varken att generera en requestedPersonalIdentity eller en personRecord i svarsfilen. Datatyp: Boolean. Exempel: true |
Version
REST-tjänsten SearchPersonsByFile finns i två versioner och anropas via två olika url:er. Det som skiljer versionerna åt är att de är kompatibla med olika versioner av domänen strategicresourcemanagement:persons:person.
https://api.pu.ineratest.org:443/purest/searchPersonsByFile - kompatibel med domänversion 3.
https://api.pu.ineratest.org:443/purest/v2/searchPersonsByFile - kompatibel med domänversion 4.
Exempel
Via cURL
Request | Response |
---|---|
Version 1 curl -X POST \ Version 2 curl -X POST \ | Statuskod: 201 CREATED { Statuskod: 400 BAD_REQUEST
Statuskod: 401 UNAUTHORIZED
Statuskod: 500 INTERNAL SERVER ERROR
|
Hämta resultat för personsök
Flödet startar med att ett urval för ett stort antal patienter behöver göras. Detta urval sker genom anrop till någon av de asynkron "*ByOrder-tjänsterna" eller SearchPersonsByFile som alla returnerar ett Order-Id.
Fråga | Svar |
---|---|
Detta Order-Id används sedan som inparameter till tjänsten GetFilesForOrderId som returnerar ett svar med en eller flera länkar till resultatfilerna.
Fråga | Svar |
---|---|
Då ordnarna som inkommer via dessa asynkrona tjänster läggs på kö så är det inte säkert att resultatet är färdigt ifall man frågar direkt efter att ordern har lagts. Tiden för orderna att bli klar varierar beroende på last på systemet och storleken på resultatet. Ett frågande system bör dock kunna förvänta sig ett svar inom fyra timmar.
Under tiden ordern inte är klar returnerar GetFilesForOrderId ett svar utan länkar/<multimedia>-stycke.
OBS: Resultatfilerna är garanterat tillgängliga i ett dygn. Därefter rensas dom automatiskt bort. Filen kan bara hämtas en gång då de efter hämtning rensas bort.
Resultatfilerna är ZIP:ade och innehåller en XML-fil med det urval som efterfrågats. Formatet som specificeras i TKB och XSD för strategicresourcemanagement:persons:person.
Exempel
SearchPersonsForProfileByOrder
Request | Response |
---|---|
<soapenv:Envelope
xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/"
xmlns:urn="urn:riv:itintegration:registry:1"
xmlns:urn1="urn:riv:strategicresourcemanagement:persons:person:SearchPersonsForProfileByOrderResponder:3">
<soapenv:Header>
<urn:LogicalAddress>SE165565594230-1000</urn:LogicalAddress>
</soapenv:Header>
<soapenv:Body>
<urn1:SearchPersonsForProfileByOrder>
<urn1:query>FROM personrecord WHERE name.givenname LIKE 'Daniel%';</urn1:query>
<urn1:queryLanguage>SimpleQL</urn1:queryLanguage>
<urn1:profile>P5</urn1:profile>
</urn1:SearchPersonsForProfileByOrder>
</soapenv:Body>
</soapenv:Envelope>
|
<S:Envelope
xmlns:S="http://schemas.xmlsoap.org/soap/envelope/">
<S:Body>
<ns2:SearchPersonsForProfileByOrderResponse
xmlns:ns2="urn:riv:strategicresourcemanagement:persons:person:SearchPersonsForProfileByOrderResponder:3"
xmlns:ns3="urn:riv:strategicresourcemanagement:persons:person:3"
xmlns:ns4="urn:riv:itintegration:registry:1">
<ns2:orderId>0622-TO17-09215997</ns2:orderId>
</ns2:SearchPersonsForProfileByOrderResponse>
</S:Body>
</S:Envelope>
|
GetFilesForOrderId
Request | Response |
---|---|
<soapenv:Envelope
xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/"
xmlns:urn="urn:riv:itintegration:registry:1"
xmlns:urn1="urn:riv:strategicresourcemanagement:persons:person:GetFilesForOrderIdResponder:3">
<soapenv:Header>
<urn:LogicalAddress>SE165565594230-1000</urn:LogicalAddress>
</soapenv:Header>
<soapenv:Body>
<urn1:GetFilesForOrderId>
<urn1:orderId>0622-TO17-09215997</urn1:orderId>
</urn1:GetFilesForOrderId>
</soapenv:Body>
</soapenv:Envelope>
| Resultat ej klart: Resultat klart:
|
REST
Request | Response |
---|---|
https://api.pu.ineratest.org:443/purest/order/get/fd6a78ee-da71-4ec6-a099-cbccc21fe468 | Statuskod: 200 OK Struktur för filnamn (både ZIP och XML): <orderId>_<datum>_<löpnummer>.zip (samt .xml) Statuskod: 400 BAD_REQUEST
Statuskod: 401 UNAUTHORIZED
Statuskod: 404 NOT FOUND
Statuskod: 500 INTERNAL SERVER ERROR
|
Bilagor för reservidentitet
En reservidentitet kan i PU-tjänsten ha 0..n bilagor. Dessa används för att styrka identiteten och kan vara exempelvis en kopia på ett pass. Bilagan kan laddas upp till reservidentiteten och senare kopplas till en specifik uppgift om styrkande av identitet. All operationer gällande bilagor görs med fördel i det av PU-tjänsten tillhandahålla GUI't, men kan vid behov hanteras av integrerande tjänster. För hantering av bilagor via GUI hänvisas till Användarhanboken för PU. Nedan beskrivs de flöden som appliceras vid integration av konsument.
Enbart exempel för REST-tjänster redovisas i följande kapitel. För information om användandet av RIV-tjänsterna hänvisas till TKB.
Ladda upp bilaga
Uppladdning av bilaga sker genom PUT och föregås av en hämtning av personpost för aktuell reservidentitet. Detta för att säkerställa att identiteten finns.
URL
Beror på miljö, men exempelvis: https://api.pu.ineratest.org:443/purest/attachment/put
Parametrar
Namn | Beskrivning |
---|---|
actorRoot | root (OID) för aktör |
actorExtension | värde för aktör |
actorProfessionalRoot | root (OID) för aktörens organisation/vårdgivare |
actorProfessionalExtension | värde för aktörens organisation/vårdgivare |
patientRoot | root (OID) för patientidentitet |
patientExtension | värde patientidentitet |
file | bilagan |
Exempel
Via cURL
Request | Response |
---|---|
curl -X PUT \ | Statuskod: 200 OK {
Statuskod: 400 BAD_REQUEST
Statuskod: 401 UNAUTHORIZED
Statuskod: 500 INTERNAL SERVER ERROR
|
Koppla / Koppla ifrån bilaga
Dessa operationer är rena RIV-tjänster och beskrivs i TKB.
Hämta bilaga
Bilagor erhålls som en referens-URL i svaret från PU-tjänstens. Dessa används sedan som GET anrop för att hämta filerna.
URL
Beror på miljö, men exempelvis: https://api.pu.ineratest.org:443/purest/attachment/get/e870cddb-5842-4c72-a804-7d39fa4c5478
Parametrar
Bilagans referensID som en del av URL
Exempel
Via cURL
Request | Response |
---|---|
curl -X GET \ | Statuskod: 200 OK
Statuskod: 400 BAD_REQUEST
Statuskod: 401 UNAUTHORIZED
Statuskod: 404 NOT FOUND
Statuskod: 500 INTERNAL SERVER ERROR
|
Ta bort bilaga
Flödet förutsätter att bilagan inte har kvar några kopplingar inom reservidentiteten. Dvs flöde för "koppla ifrån bilaga" måste genomföras då det är applicerbart.
URL
Beror på miljö, men exempelvis: https://api.pu.ineratest.org:443/purest/attachment/delete
Parametrar
Namn | Beskrivning |
---|---|
actorRoot | root (OID) för aktör |
actorExtension | värde för aktör |
actorProfessionalRoot | root (OID) för aktörens organisation/vårsgivare |
actorProfessionalExtension | värde för aktörens organisation/vårsgivare |
patientRoot | root (OID) för patientidentitet |
patientExtension | värde patientidentitet |
referenceId | bilagans id |
Exempel
Via cURL.
Request | Response |
---|---|
curl -X DELETE \ | Statuskod: 200 OK File with id: e870cddb-5842-4c72-a804-7d39fa4c5478 was successfully deleted.
Statuskod: 400 BAD_REQUEST
Statuskod: 401 UNAUTHORIZED
Statuskod: 404 NOT FOUND
Statuskod: 500 INTERNAL SERVER ERROR
|