PSA Workflow (MVP, taken)
Vanuit verschillende richtingen is de wens uitgesproken dat Zorgverleners en Zorggebruikers vanuit workflows elkaar opdrachten/taken moeten kunnen geven. Door het geven van een eerste opdracht wordt een workflow gestart en binnen de grenzen van de workflow moeten de taken uitgevoerd worden. De invoering van workflows zorgt er voor dat de Zorggebruiker en dus de PGO meer betrokken worden bij het zorgproces en dat opdrachten asynchroon uitgevoerd kunnen worden, zonder direct contact tussen Zorgverlener en Zorgaanbieder.
1. Doel van het project
Binnen het minimum viable product (MVP) is het van belang de implementatie zo simpel mogelijk te houden, maar wel waarde te bieden aan de gebruikers. Voor het onderwerp workflow betekent dit dat de Zorgverlener en Zorggebruiker elkaar taken moeten kunnen geven en terugkoppeling krijgen als de taken zijn uitgevoerd. Eventuele vervolgstappen worden niet in het MVP meegenomen, het gaat in deze fase om enkelvoudige taken.
Wel moet rekening worden gehouden met het feit dat Zorgaanbieders moeten weten waar zij een Zorggebruiker kunnen vinden. In het stelsel moet bekend zijn welke PGO door de Zorggebruiker wordt gebruikt. Hiervoor wordt gedacht aan een implementatie van de functie Abonneren, maar eventueel kan een wijziging in de werking van toestemmingen ook volstaan.
Aangezien op termijn meerdere organisaties betrokken kunnen zijn bij de uitvoering van eenzelfde workflow, is het van belang dat taken en processen duidelijk en zoveel mogelijk conform gangbare standaarden worden gedefinieerd. Hierbij kan, voor het zorgdomein, ondermeer worden gekeken naar vigerende zorgstandaarden en naar technische standaarden, zoals aanbevolen en/of opgesteld door IHE en HL7.
2. Betrokken architecten
Casper van der Harst (Lead architect)
Vincent Klaassen (Solution architect)
3. Stakeholderanalyse
Idee | Ready | Alpha uitwerking | Alpha POC | Beta uitwerking | Beta Pilot | Release candidate | Publicatie | |
---|---|---|---|---|---|---|---|---|
Kernteam ontwikkeling | A | I | I | I | I | I | A | A |
Product manager | R | A | A | I | A | I | C | I |
Lead architect | I | R | C | C | C | C | C | I |
Release manager | I | R | C | |||||
Afsprakenstelsel | I | C | R | C | R | C | C | R |
Referentie implementatie | C | C | C | C | I | |||
Proves | I | A | I | A | I | |||
Monitoring | C | C | I | |||||
Testomgeving | C | C | C | C | I | |||
Acceptatie | C | C | C | I | ||||
Deelnemers | (I) | C | R | C | R | C | I | |
Zorgaanbieders | C | C | I | C | I | I | ||
Juristen | C | I | C | I | I | |||
Security | C | C | I | |||||
R&A | C | C | I | I | ||||
CCDA | C | I | I | |||||
Leveranciers management | I | I | I | I | ||||
Loket | I | I |
4. Usecases op het hoogste niveau
Als Zorgverlener wil ik in het kader van een behandeling een taak naar een Zorggebruiker kunnen sturen, met daarin het verzoek iets uit te voeren.
Als Zorggebruiker wil ik in mijn PGO in het kader van een behandeling verzoeken van een Zorgverlener om bepaalde taken uit te voeren ontvangen.
5. Beleidsuitgangspunten
Er wordt zoveel mogelijk gebruikgemaakt van de al bestaande MedMij functionaliteiten en gegevensdiensten.
DVP’s moeten workflow implementeren, zodat zij allen notificaties en taken kunnen verwerken.
DVA’s mogen workflow implementeren en moeten dit kenbaar maken aan het netwerk.
Authenticatie en langdurige toestemming zijn van toepassing op de MVP voor workflow.
Naast de gegevensuitwisseling moet ook het gebruik van modules mogelijk zijn vanuit workflow.
Er wordt gebruikgemaakt van bestaande, internationale standaarden.
6. Architectuurdrijfveren
Voor monitoring-doeleinden wordt logging ingebouwd in het proces.
Beveiliging van en veiligheid binnen het MedMij netwerk blijft hoog.
Zorgen dat de deelnemers niet geconfronteerd met teveel verschillende oplossingen/mogelijkheden voor het starten en uitvoeren van workflows.
Authenticatie, autorisatie, patiënttoestemming en lokalisatie worden in de toekomst zorgbreed ingevuld. Hiermee moet rekening worden gehouden in de uitwerking.
Zorgen dat de modellen/architectuur (in EA) worden toegevoegd of bijgewerkt op basis van wat ontworpen is.
7. Referentiearchitecturen
8. Architectuurprincipes
8.1. Organisatiebeleid
De rol van Procesbeheerder wordt toegekend aan de Zorgaanbieder. De Zorgaanbieder vult deze rol zelf in, bijvoorbeeld vanuit zijn interne processen.
8.2. Zorgproces
Workflows bestaan uit enkelvoudige taken. Dit wil zeggen dat de Zorgverlener per workflow één taak aan een Zorggebruiker kan toewijzen.
Taken van de zorgaanbieder voor de zorggebruiker kunnen op verschillende manieren bij de PGO bekend worden:
Gebruikmakend van de functie verzamelen kan een Zorggebruiker de aan de Zorggebruiker toegekende taken laten ophalen.
Vanuit een abonnement op taken worden notificaties gestuurd naar de PGO die het abonnement heeft afgesloten. De PGO haalt op basis van een gebruikersactie of de toestemming voor automatische gegevensuitwisseling de taken ook daadwerkelijk op. Hiervoor wordt dan weer gebruikgemaakt van de hiervoor genoemde gegevensdienst.
Taken worden alleen uitgewisseld als deze bijdragen aan een verbetering/versnelling van het zorgproces.
De rol van procesbeheerder is altijd de zorgaanbieder. Hiermee liggen regie en verantwoordelijkheid altijd bij de zorgaanbieder, ook op het moment dat een proces wordt geïnitieerd door de zorggebruiker.
8.3. Informatie
Taken moeten kunnen worden verzameld. Hiervoor moet een gegevensdienst worden ontwikkeld en beheerd.
Er wordt zoveel als mogelijk gebruikgemaakt van standaarden uit het domein zorg, zoals FHIR.
8.4. Applicatie
Er wordt zoveel als mogelijk gebruikgemaakt van standaarden uit het domein zorg, zoals FHIR. Binnen het onderwerp Workflow betekent dit dat onder andere gekeken moet worden naar
Activity definitions
Tasks
Subscriptions
Assertions
8.5. IT-infrastructuur
9. Afhankelijkheden
Qua interne onderwerpen
De MVP is nauwelijks afhankelijk van externe onderwerpen. Met het oog op de toekomst moet wel rekening worden gehouden met de gewenste afhankelijkheden. Te noemen zijn bijvoorbeeld de generieke diensten ‘Vertrouwde authenticatie', ‘Toestemmingsregister’ en 'Lokalisatiedienst’.
10. Relaties met andere projecten
De alpha fase voor de MVP voor Modules moetzijn afgerond, zodat taken binnen deze MVP de volgende functies kunnen omvatten:
Gegevens verzamelen
Gegevens delen
Uitvoeren van een module
11. Oplossingsrichting(en)
Voor abonneren moet gekeken worden welke wijzigingen in het afsprakenstelsel nodig zijn om de FHIR variant te implementeren. Zie https://fhir-ru.github.io/subscription.html, zoals bijvoorbeeld ook binnen Koppeltaal gebruikt wordt. Daarnaast moet ook voor Workflow zoveel als mogelijk worden aangesloten bij de oplossing die binnen Koppeltaal is neergezet.
12. Architectuurrisicoanalyse
Nr | Beschrijving | Conclusie |
---|---|---|
1 |
13. Project overstijgende ontwerpkeuzes
-
14. Architectuurafwijkingen
Bij abonneren wordt in de huidige vorm (afsprakenstelsel versie 2) gebruikgemaakt van door MedMij samengestelde JSON berichten. De wens is geuit om binnen de zorg hiervoor gebruik te maken van FHIR abonnementen. Onderzocht moet worden wat de voordelen en nadelen zijn en of een afwijking van de huidige architectuur voldoende van waarde is.
15. Fasering
15.1. Minimum Viable Product (MVP)
Bij het minimum viable product gaat het alleen om het werkend krijgen van de modules, zonder rekening te houden met afhankelijkheden. Het MVP moet zo snel mogelijk opgeleverd kunnen worden, waarbij vooral gebruikgemaakt wordt van zaken die nu al aanwezig zijn. Dit betekent dat bijvoorbeeld gebruiksvriendelijkheid nog niet wordt geoptimaliseerd. Het MVP wordt hoogstwaarschijnlijk ook nooit gepubliceerd.
15.1.1. Scopebepaling
15.1.1.1. In scope
Abonneren op taken door de Zorggebruiker (PGO) bij de Zorgaanbieder (DVA)
Workflow starten door taak aan te maken
Taken van de Zorgverlener voor de Zorggebruiker
Notificeren van klaarstaande taken door DVA aan PGO en daarmee de Zorggebruiker
Verzamelen van taken door de PGO
Uitvoeren van taken
Delen van resultaat met de DVA en daarmee met de Zorgaanbieder en Zorgverlener
Taken van de Zorggebruiker voor de Zorgaanbieder
Delen van de taak met de DVA door de PGO
Notificeren van de klaarstaande resultaten dor de DVA aan de PGO en daarmee de Zorggebruiker
Verzamelen van de resultaten door de PGO
Dit alles wordt uitgevoerd met de al beschikbare functies. Taken kunnen bestaat uit het ophalen van gegevens, het delen van gegevens en het uitvoeren van een module.
15.1.1.2. Buiten scope
Herhalende en gelaagde taken
Generieke functies
Vertrouwde authenticatie
Toestemmingen
Lokalisatie
Machtigingen / vertegenwoordiging
Workflows met meerdere (achtereenvolgende) taken
Bij Zorgaanbieders aanwezige workflow-oplossingen
Discovery
Herinneringsnotificatie sturen naar Persoon
Vraagfunctie bij taken in de vorm van chat
Inhoudelijk wijzigen van taken (dit wordt vormgegeven met het verwijderen van de bestaande en het uitgeven van een nieuwe taak)
15.1.2. Afgeleide functionele usecases
15.1.2.1. Zorgverlener
Als Zorgverlener wil ik per keer één taak aan een Zorggebruiker kunnen toewijzen.
Als Zorgverlener wil ik de Zorggebruiker notificeren dat er één of meerdere taken klaarstaan (abonnement).
Als Zorgverlener wil ik een uitgegeven taak kunnen intrekken / annuleren.
Als Zorgverlener wil ik genotificeerd worden over een statuswijziging, dus ook bij het afwijzen van een taak door de Zorggebruiker.
Als Zorgverlener wil ik de uiterste datum aan kunnen geven dat de taak uitgevoerd moet worden.
Als Zorgverlener wil ik (meervoudige) resultaten kunnen ontvangen op één taak.
15.1.2.2. Zorggebruiker
Als Zorggebruiker wil ik taken kunnen verzamelen door op een knop drukken.
Als Zorggebruiker wil ik aangeven dat ik van mijn Zorgverlener notificaties wil ontvangen over taken.
Als Zorggebruiker wil ik een bericht ontvangen op het moment dat er één of meerdere taken klaar staan in mijn PGO.
Als Zorggebruiker wil ik (meervoudige) resultaten kunnen versturen naar de Zorgverlener, gebaseerd op één taak.
Als Zorggebruiker wil ik een aan mij toegewezen taak kunnen uitvoeren.
Als Zorggebruiker wil ik een aan mij toegewezen toegewezen taak kunnen afwijzen.
Als Zorggebruiker wil ik de historie van mijn taken inzien (levenslang).
15.1.2.3. MedMij Beheer
Als MedMij Beheer wil ik een lijst beschikbaar hebben met alle workflow-profielen (zie koppeltaal).
Als MedMij Beheer wil ik deelnemers kunnen kwalificeren op de ondersteuning van workflow-profielen.
Als MedMij Beheer wil ik partijen kunnen accepteren voor de functie Workflow ( o.a. security, juridisch, R&A).
Als MedMij Beheer wil ik het gebruik van Workflows kunnen monitoren.
15.2. Volgende fasen
Door afhankelijkheden met externe projecten kan volgorde in de volgende fasen niet bepaald worden.
Toevoegen van het gebruik van Vertrouwde authenticatie en Machtigingen (Afhankelijkheid implementatie VWS)
Toevoegen van het gebruik van Toestemmingsregister (Afhankelijkheid implementatie Mitz / VZVZ)
Toevoegen van het gebruik van Lokalisatieregister (Afhankelijkheid implementatie Mitz / VZVZ)
Toevoegen van het gebruik van Discovery
Toevoegen van het gebruik van workflows met meerdere taken
- 1 Doel van het project
- 2 Betrokken architecten
- 3 Stakeholderanalyse
- 4 Usecases op het hoogste niveau
- 5 Beleidsuitgangspunten
- 6 Architectuurdrijfveren
- 7 Referentiearchitecturen
- 8 Architectuurprincipes
- 8.1 Organisatiebeleid
- 8.2 Zorgproces
- 8.3 Informatie
- 8.4 Applicatie
- 8.5 IT-infrastructuur
- 9 Afhankelijkheden
- 10 Relaties met andere projecten
- 11 Oplossingsrichting(en)
- 12 Architectuurrisicoanalyse
- 13 Project overstijgende ontwerpkeuzes
- 14 Architectuurafwijkingen
- 15 Fasering
- 15.1 Minimum Viable Product (MVP)
- 15.1.1 Scopebepaling
- 15.1.1.1 In scope
- 15.1.1.2 Buiten scope
- 15.1.2 Afgeleide functionele usecases
- 15.1.2.1 Zorgverlener
- 15.1.2.2 Zorggebruiker
- 15.1.2.3 MedMij Beheer
- 15.1.1 Scopebepaling
- 15.2 Volgende fasen
- 15.1 Minimum Viable Product (MVP)