Indhold

Introduktion

Formål

Formålet med dette dokument er at beskrive systemarkitekturen for CAVE servicen. 

Læsevejledning

Nærværende dokument er tiltænkt udviklere og IT-arkitekter med interesse i CAVE Servicen. 

Det forventes at læseren har en REST services. For en kort introduktion til FHIR henves til snitfladebeskrivelsen i CAVE anvenderguide og ellers til https://www.hl7.org/fhir/.

Dokument historik

Dato

Ansvarlig

Beskrivelse

5/2-2018KvalitetsITInitiel version

Definitioner og referencer



NSPNational Service Platform
LARLægemiddel Allergi Register
CAVELatin for vogt eller undgå. Fagudtryk for medicin som en patient bør undgå
FHIRFast Health Interoperability Resources
RESTRepresentational State Transfer
DGWSDen Gode WebService


Introduktion til CAVE

Løsningens opbygning

CAVE servicen er en løsning, der udstiller en FHIR snitflade. Det sker ved hjælp af HAPI FHIR java frameworket. I CAVE servicen udstilles der to typer af operationer. 

  1. Mulighed for at registrere lægemiddeloverfølsomhedsoplysninger på en given borger.
  2. Mulighed for at læse lægemiddeloverfølsomhedsoplysninger for en given borger. 

I FHIR terminologi så er data centreret omkring AllergyIntolerance ressourcen. De FHIR ressourcer, der ikke anvendes, er der heller ikke understøttelse for i servicen. 

CAVE servicen er installeret således at det kun er LAR der kan kalde servicen. 

Overblik over CAVE

CAVE er udviklet som en web applikation i henhold til Servlet specifikationen 2.5. Dette sikrer, at CAVE kan afvikles på enhver Servlet Engine, der overholder denne specifikation - specielt på WildFly Application Server 8.2, der i øjeblikket anvendes på NSP.

Løsningen er opbygget omkring to maven moduler. Hvert modul har sit eget ansvarsområde.


De med grå markerede komponenter er standard HAPI FHIR komponenter. 

Registrering af oplysning om lægemiddeloverfølsomhed 

Registrering af overølsomhed for lægemiddel sker på følgende måde.

  1. HAPI FHIR Servlet modtager et HTTP POST request. Eksempel på request kan ses i CAVE Anvenderguide.
  2. Request behandles af registrerede interceoptore. 
    1. SLA logning
    2. Validering af format i forhold til FHIR standarden. 
    3. Validering af om request indeholder FHIR ressourcer vi tillader. 
    4. Forretningsmæssig validering af indhold. Se afsnittet input validering for detaljer. 
  3. Behandling og persistering af request i bundle processor komponenten. 
    1. Verificering om patient, practitioner, pracitioner role og organization allerede findes. Hvis det er tilfældet anvendes disse når data persisteres ellers oprettes der nye. 
    2. AllergyIntolerance persisteres i databasen via HAPI JPA Server komponenten. 
  4. De oprettede data returneres til LAR servicen.

Opslag af oplysninger om lægemiddeloverfølsomhed

Opslag af oplysninger om lægemiddeloverfølsomhed sker på følgende måde. 

  1. HAPI FHIR Servlet modtager et HTTP Get kald. Eksempel på kald kan ses i CAVE Anvenderguide.
  2. Request behandles af registrerede interceoptore. 
    1. SLA logning
    2. Validering af format i forhold til FHIR standarden. 
  3. HAPI JPA serveren kaldes for at foretage søgningen og data returneres til kalderen.

Validering

Udover standard validering i forhold til FHIR standarden, så foretager cave servicen en række ekstra valideringer. Dette sker for at sikre en tilstrækelig høj datakvalitet, og for at sikre data opfylder de krav LAR servicen har. 

Nedenstående er de ekstra valideringer, der er lavet i forhold til FHIR standarden. 

Bundle

  1. Den modtagne request skal bestå af en AllergyIntolerance, Patient, PractitionerRole, Practitioner og Orgnization ressource. 

AllergyIntolerance

  1. Identifier i AllergyIntolerance skal være unik. 
  2. Der skal være et code element og system skal være valid oid. Se LAR Anvenderguide for valid værdi. 
  3. Der må maksimalt være én reaction. 
  4. Hvis der er en reaction så skal der være én manifestation. 
  5. Hvis der er en reaction skal coding indeholde enten en kode og system eller en text. Hvis der er kode og system skal system være valid oid. Se LAR Anvenderguide for valid værdi. 
  6. ClinicalStatus skal være sat. 
  7. VerificationStatus skal være CONFIRMED. 
  8. OnsetDateTime skal være sat.
  9. Type skal være sat.
  10. Category skal være sat.
  11. Der skal være reference til en patient. 
  12. Der skal være reference til en recorder. 

Patient

  1. Der skal være en identifer med en kode og system, hvor system er CPR. Se LAR Anvenderguide for valid oid. 

PractitionerRole

  1. Der skal være en reference til en practitioner. 
  2. Der skal vræe en reference til en organization. 

Practitioner

  1. Der skal være én identifier. 
  2. Der skal være en system og kode. Kode skal være oid for autorisationsid. Se LAR Anvenderguide for valid oid. 

Organization

  1. Der skal være én identifier. 
  2. Der skal være en system og kode. Kode skal være oid for SOR. Se LAR Anvenderguide for valid oid. 

Sikkerhed

Servicen er implementeret uden en egentlig sikkerhedsmodel. For at sikre utilsigtet adgang til servicen er den installeret således, at det kun er LAR servicen, der kan kalde den. Dermed er det LAR servicen, der afgør om en given slutbruger har adgang til CAVE servicen. 

Integrationer

CAVE servicen integrerer ikke til andre services. Registrering i Minlog,  MinSpærring og behandlerrelation tjek er anvendersystemets ansvar. Det vil sige at det er LAR servicen, der har ansvar for dette, da det CAVE kun er tilgængelig for LAR servicen. 

Designmålsætninger og -beslutninger

Anvendelse af HAPI FHIR

Det er besluttet at anvende HAPI FHIR som FHIR implementering. HAPI FHIR kan anvendes på flere niveauer. I cave servicen er det besluttet at anvende HAPI FHIR i størst muligt omfang. Det vil sige at det HAPI FHIR anvendes blandt andet til nedenståenbde.