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-2018 | KvalitetsIT | Initiel version |
Definitioner og referencer
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.
- Mulighed for at registrere lægemiddeloverfølsomhedsoplysninger på en given borger.
- 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.
- Cave-Service: Forretningslogik og konfiguration af HAPI framworket. Ved at anvende HAPI FHIR framework skal vi ikke selv implementere datamodel, persistering osv. i servicen. Det skal blot konfigureres i servicen. Der er implemeteret ekstra validering i forhold til FHIR standarden samt transaktionel håndtering af bundles. Dette er for at sikre en høj datakvalitet i servicen.
- Cave-war: Modul, der samler de forgående moduler i en sammenhængende og eksekverbar (i f.eks. WildFly) WAR fil. Modulet indeholder også kode til integrationstests af CAVE servicen.
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.
- HAPI FHIR Servlet modtager et HTTP POST request. Eksempel på request kan ses i CAVE Anvenderguide.
- Request behandles af registrerede interceoptore.
- SLA logning
- Validering af format i forhold til FHIR standarden.
- Validering af om request indeholder FHIR ressourcer vi tillader.
- Forretningsmæssig validering af indhold. Se afsnittet input validering for detaljer.
- Behandling og persistering af request i bundle processor komponenten.
- 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.
- AllergyIntolerance persisteres i databasen via HAPI JPA Server komponenten.
- 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.
- HAPI FHIR Servlet modtager et HTTP Get kald. Eksempel på kald kan ses i CAVE Anvenderguide.
- Request behandles af registrerede interceoptore.
- SLA logning
- Validering af format i forhold til FHIR standarden.
- 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
- Den modtagne request skal bestå af en AllergyIntolerance, Patient, PractitionerRole, Practitioner og Orgnization ressource.
AllergyIntolerance
- Identifier i AllergyIntolerance skal være unik.
- Der skal være et code element og system skal være valid oid. Se LAR Anvenderguide for valid værdi.
- Der må maksimalt være én reaction.
- Hvis der er en reaction så skal der være én manifestation.
- 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.
- ClinicalStatus skal være sat.
- VerificationStatus skal være CONFIRMED.
- OnsetDateTime skal være sat.
- Type skal være sat.
- Category skal være sat.
- Der skal være reference til en patient.
- Der skal være reference til en recorder.
Patient
- Der skal være en identifer med en kode og system, hvor system er CPR. Se LAR Anvenderguide for valid oid.
PractitionerRole
- Der skal være en reference til en practitioner.
- Der skal vræe en reference til en organization.
Practitioner
- Der skal være én identifier.
- Der skal være en system og kode. Kode skal være oid for autorisationsid. Se LAR Anvenderguide for valid oid.
Organization
- Der skal være én identifier.
- 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.
- Udstille REST snitflade, der overholder FHIR standarden
- Validering af data i forhold til FHIR standarden
- Persistering af data. Det betyder også datamodellen er den HAPI FHIR dikterer.