Diese Implementierung beinhaltet einen ETL-Prozesses zur Überführung KDS-konformer Daten von einem FHIR-Server in eine Postgres-Datenbank.
Die Ausleitung der FHIR-Daten in die Datenbank sollte möglichst 1 mal täglich passieren. Dabei werden die Daten aller Patienten, die sich auf einer der relevanten Stationen befinden bzw. die sich am Tag zuvor auf einer der relevanten Stationen befanden vom FHIR-Server geladen und in die Datenbank überspielt.
Der ETL-Prozess kann über die Datei cds2db_config.toml konfiguriert werden. Alle Parameter sind in der Datei durch Kommentare beschrieben. Hier werden u.a. sowohl die Logging-Parameter, als auch die Parameter zum Zugriff auf den FHIR-Server angegeben. Außerdem stehen Debug-Parameter zur Verfügung. Damit kann man für ältere Zeiträume Daten übertragen, falls für Tests keine aktuellen Daten vorliegen.
Die Ermittlung der Patienten relevanter Stationen erfolgt über eine der beiden folgenden Varianten.
Bei dieser Variante ist es notwendig, dass die relevanten Stationen aus dem FHIR-Profil Encounter ausgelesen werden können.
Ziel ist es Patienten-IDs von Encountern zu finden, die bestimmte Eigenschaften in den FHIR-Daten aufweisen. Idealerweise sollte es so etwas sein wie, der Encounter ist noch nicht abgeschlossen und als ServiceProvider ist der gesuchte Stationsname angegeben oder der Encounter referenziert eine bestimmte Location.
Die Encounter können also über beliebige Einträge identifiziert werden. Es ist frei konfigurierbar und auf die lokalen Gegebenheiten am DIZ einstellbar. Die Beschreibung der Einstellungsmöglichkeiten befinden sich direkt in der toml-Datei als Kommentar zu den ENCOUNTER_FILTER_PATTERN.
ACHTUNG: Im Moment ist es nicht möglich, in diesen Filtern Referenzen vom Encounter auf andere Ressourcen aufzulösen und sich auf Eigenschaften der referenzierten Objekte zu beziehen. Z.B. kann man aktuell nicht den Namen einer referenzierten Location ermitteln. Da die in Frage kommende Location aber eine feste Referenz/ID auf dem FHIR-Server haben sollte, müsste diese ID in die Filter eingebaut werden.
Variante 2: Die relevanten Patienten werden über Informationen aus einer Textdatei mit Patientenliste ermittelt
Diese Variante sollte genommen werden, wenn es keine Möglichkeit gibt, die aktuellen Fälle der Stationen über die Encounter zu ermitteln. Bei dieser Variante muss das DIZ eine Textdatei erzeugen, die folgende Form hat: source_PIDs. Diese Datei muss ständig aktualisiert werden. Wie ein DIZ diese Datei erzeugt, ist ihm selbst überlassen. Um diese Variante 2 zu aktivieren und damit die Variante 1 auszuschalten, muss der Parameter 'PATH_TO_PID_LIST_FILE' aktiviert werden und der Pfad auf die entsprechende Datei zeigen.
Das R-Skript StartRetrieval.R startet das Retrieval für den ETL-Prozess. Dieses kann an der Console manuell über den folgenden Befehl ausgeführt werden:
docker compose run --rm --no-deps r-env Rscript R-cds2db/StartRetrieval.R
Weitere Details siehe README des R Packages cds2db.