Kanta PHR:n CapabilityStatement ja REST-API. Eeva Turkka

Samankaltaiset tiedostot
Kanta PHR:n CapabilityStatement ja REST-API. Eeva Turkka

Kanta PHR:n Sandboxympäristöt. Eeva Turkka

Suuli api dokumentaatio

Käyttäjähallintapalvelun REST-rajapinnat

Omatietovaranto. Sovellustoimittajat

HL7 Finland koulutus. FHIR profilointi osa , Helsinki. Tietohiisi, Mika Tuomainen

Tiedonsiirto- ja rajapintastandardit

Omatietovaranto. Jari Suhonen, THL Jari Suhoenn/ OPER

Ilmonet ja rajapinnat Pääkaupunkiseudun kansalais- ja työväenopistojen kurssit

Julkisen rajapinnan testausohje Swaggerin kautta

Vaalikone.fi API Presidentinvaalit 2012

Kansallinen Omakannan Omatietovaranto, kansalaisen hyvinvointitiedon tallennuspaikka

Järjestelmäarkkitehtuuri (TK081702)

Veronumero.fi Tarkastaja rajapinta

HL7 Finland koulutus. FHIR profilointi perusteet , Helsinki. Tietohiisi, Mika Tuomainen

Omatietovaranto tilannekatsaus

Suomi.fi-palvelutietovaranto

Onecapital Invoicer XML API

KaTSO. KaTSO FAQ. Solteq Oyj. (järjestelmätoimittaja) Päivitetty Update disclaimer here.

Toimintaympäristön kuvaus. LTC-Otso Myyjän työkalu (POC)

Trimble Feedback Mobile app ja rajapinnat Kuvaus

Yksittäisen tapahtumakategorian hakeminen... 3 Parametrit... 4 Vastausesimerkki... 4 Tapahtumien hakeminen hakukriteerin avulla...

Tekninen rajapinta Zip-tiedosto sovelluskehittäjälle Kansallisen tulorekisterin perustamishanke

HL7 Finland koulutus. FHIR profilointi osa , Helsinki. Tietohiisi, Mika Tuomainen

ehoks: tietomalli ja rajapinta

Tekninen rajapinta Zip-tiedosto sovelluskehittäjälle Kansallisen tulorekisterin perustamishanke

HYÖDYNNÄ SUBSCRIPTION-ETUSI

Sosiaalihuollon asiakastiedon arkiston validointipalvelu

Suomi.fi-palvelutietovaranto Kaikki oleellinen julkishallinnon palveluista yhdessä paikassa

Tuotetietopankin alustanvaihdon muutostöiden luokittelu

Action Request System

Käyttöohje. Ticket Inspector. Versio 1.0. Sportum Oy

eperusteet julkiset rajapinnat

Sosiaalihuollon asiakastiedon arkiston validointipalvelu. Käyttöohje

T2V2 Turvallisuushavaintoilmoitussanomakuvaus

Mittaustietojen SAF-aineistokuvaus kaasudatahubiin

Rajapintakuvaus Liikenneluvat

TIETOKANTOJEN PERUSTEET OSIO 14 MARKKU SUNI

Tilaajavastuu.fi. Muutoshistoria. Suomen Tilaajavastuu Oy. Raporttinoutaja Rajapinta yritysten tilaajavastuutietojen tarkistamiseen

Contents AdsML ympäristö... 2 AdsML Testi ympäristö... 2 AdsML tuotantoympäristö... 2 AdsML käyttöliittymä... 3 Kirjautuminen...

DYNAMIC CARE PLANNING (DCP) JA DYNAMIC CARE TEAM MANAGEMENT (DCTM) IHE-PROFIILIT. Konstantin Hyppönen IHE-Finland

Asiakastietoa käsittelevä järjestelmä. Rajapintakäyttötapaukset

Asiakastietoa käsittelevä järjestelmä. Rajapintakäyttötapaukset

A TIETORAKENTEET JA ALGORITMIT

T2V2 Vaaratilanneilmoitussanomakuvaus

1. KÄYTTÖKONTEKSTI. jamkad VAATIMUSMÄÄRITTELY. Liite1_Vaatimusmaarittely_Elainklinikka.doc Filename: Last saved:

EMCS-järjestelmän sanomarajapinnan toiminnallinen kuvaus asiakkaille Meeri Nieminen

HYÖDYNNÄ SUBSCRIPTION-ETUSI

Liite 7: Asiakastietoa käsittelevä järjestelmä Sosiaalihuollon asiakastiedon arkisto. Rajapintakäyttötapaukset

DOORS 7.1 Test Tracking Toolkit

Harjoitustyö: virtuaalikone

Katselupalvelujen INSPIRE-yhteensopivuuden testaus

TIMMI-TILAVARAUSOHJELMISTO

Museo 2015 järjestelmä ja Museoiden luettelointiohjeet

Kemikaalitieto yhdestä palvelusta

Tietojen toimittaminen Skeemat Käsittelypalautteen kysely Kansallisen tulorekisterin perustamishanke

Omakannan omatietovaranto (PHR)

RockID-varastonhallintajärjestelmän käyttöohje. v. 1.0

Visma Software Oy

Kuva: Ilpo Okkonen

Ohjelmoinnin peruskurssi Y1

Security server v6 installation requirements

JWT 2016 luento 11. to klo Aulikki Hyrskykari. PinniB Aulikki Hyrskykari

Ohjelmistojen mallintamisen ja tietokantojen perusteiden yhteys

Ohjelmoinnin perusteet Y Python

Kirjasto Relaatiotietokannat Kevät Auvinen Annemari Niemi Anu Passoja Jonna Pulli Jari Tersa Tiina

Omakannan omatietovaranto aka Kansallinen PHR. Konstantin Hyppönen, Kanta-palvelut, Kela HL7 Finland PH SIG -kokous

HYÖDYNNÄ SUBSCRIPTION-ETUSI

Mainosankkuri.fi-palvelun käyttöohjeita

Omat Lähdöt ohjelmointirajapinta: Versio 1.01

Visma Business AddOn Factoring-laskuaineisto. Käyttäjän käsikirja

Täysautomatisoitu raportointiympäristö. Joni-Petteri Paavilainen Jani Alatalo

REST an idealistic model or a realistic solution?

1 Yleistä Kooste-objektista Käyttöönotto Kooste-objektin luominen Sisällön lisääminen Kooste objektiin Sivut...

Security server v6 installation requirements

ORGANISAATIO- JA AMMATINHARJOITTAJATIETOJEN TARKASTAMINEN KANSALLISELTA KOODISTOPALVELIMELTA

HY:n ehdotus käyttäjähallintotuotteesta

NORDEAN WEB SERVICES YHTEYDEN KÄYTTÖÖNOTTO

Avoin metsätieto - Rajapintapalvelut

Palkkatietoilmoitus Esimerkki 18 Työkorvaus, tulonsaajana luonnollinen henkilö

Raporttiarkiston (RATKI) käyttöohjeet Ohjeet

2017/S Contract notice. Supplies

Modulaariset tietosisältömäärittelyt Tilannekatsaus

Kansallinen koodistojen siirtoformaatti

Koodistoeditorin toteutuksen lähtökohtia: KaPA-koodistopalvelu ja REST-rajapinnat

Primuksen ja Wilman viestitoiminnot

Nippupelipassi. Nippupelipassien rakentaminen

Esimerkkinä - ilmainen blogi-julkaisujärjestelmä. WordPress:stä on myös palvelimelle asennettava versio (WordPress.

Ohjelmoinnin perusteet Y Python

Ovid Medline käyttöohjeita (10/2010)

Tietokanta.java Luokka tarjoaa välineet tietokannan lukemiseen. Haetuista tiedoista muodostetaan kurssi- ja opetus-olioita.

Kuinka ladata tulostusprofiilit Antalis ICC Profile Centrestä

Tietojen toimittaminen Skeemat Käsittelypalautteen kysely Kansallisen tulorekisterin perustamishanke

Javascript 2: Ohjelmointikielen ominaisuudet. Jaana Holvikivi Metropolia

Paroc Panel System ArchiCAD-sovellus

Garmin laitteiden ohjelmistopäivitys

Tik Tietojenkäsittelyopin ohjelmatyö Tietotekniikan osasto Teknillinen korkeakoulu KÄYTTÖOHJE. LiKe Liiketoiminnan kehityksen tukiprojekti

Käyttöohje

Android ohjelmointi Tunti 5. SQLite, Cursor, Intent ja ADB

Rajapintapalvelujen INSPIRE-yhteensopivuus

Transkriptio:

Kanta PHR:n CapabilityStatement ja REST-API Eeva Turkka

PHR:n kaksi osaa: tietosisältö ja käyttöluvat Resurssipalvelin FHIR REST-rajapinnat CapabilityStatement kuvaa toiminnot Resurssisäilö Auktorisointipalvelin OAuth2.0 Antaa käyttölupia ja tokeneita Ei säilö resursseja 2

Mikä on CapabilityStatement https://www.hl7.org/fhir/capabilitystatement.html CapabilityStatement dokumentoi joukon toimintoja, jotka kertovat mitä palvelin tekee tai määrittelee halutun toiminnallisuuden

Kanta PHR:n CapabilityStatement https://simplifier.net/finnishphr/capabilitystatement3 CapabilityStatement tyyppinen resurssi, jossa on kuvattu Kanta PHR:n sääntöjä Listaa tuetut toiminnot ja resurssit ja muita asioita, joiden toteuttamiseen on useita vaihtoehtoja standardissa CapabilityStatement pääosin listaa tuetut toiminnot, koska standardi on laaja Ei kuvaa asioita, jotka ovat profiloinnin piirissä Osa järjestelmän yksityiskohdista on kuvattu implementation guideen 4

5 CapabilityStatementin osat

CapabilityStatementin osat OAuth2.0! Jokainen tuettu resurssityyppi listattu Hakuehdot joko resurssille tai koko palvelimella 6

Rest? https://en.wikipedia.org/wiki/representational_state_transfer HTTP-standardin tietty käyttötapa palveluiden toteuttamiseen Tilaton, eli palvelimelle ei ole istuntoa eikä palvelin ylläpidä tietoa edellisistä viesteistä Käyttää HTTP-metodeja toimintoihin: GET, PUT, POST jne Laajalti käytössä, mutta ei itsessään kuvaa tarkasti toimintoja https://www.w3.org/tr/2004/note-ws-arch-20040211/#relwwwrest

Tallenna POST http://fhirsandbox.kanta.fi/phrresourceserver/basestu3/observation Tallenna verenpainemittaus Kanta PHR:ään? Mittaustulos on Observation-tyypin resurssi Resurssi esitetään json-objektina Tallennus PHR:ään tehdään lähettämällä resurssi PHR:n FHIRpalvelimelle Pyyntö on restin mukaan POST ja varsinainen resurssi jsonina bodyssa Paluusanomassa saa tiedon resurssin id:stä: http://fhirsandbox.kanta.fi/phr- resourceserver/basestu3/observation/435b5586-7f65-439e-9d6d- 9ca2ae07e11f/_history/1 8

Mitä tallentamisesta on CapabilityStatementissa? Osa CapabilityStatementin kentistä koskee kaikkia toimintoja acceptunknown kertoo että tunnistamattomia tietotyyppejä, resursseja tai extensioineja ei tueta Format kertoo, että palvelimen tukee json-muotoisia resursseja "acceptunknown": "no", "format": [ "json" ], 9

Mitä tallentamisesta on CapabilityStatementissa? REST-noodin alla löytyy lista resursseja, jotka dokumentoivat toteutusta Esimerkiksi Observationista on kerrottu, että perusprofiili on vitalsigns Toiminnoista create ja update on tuettu (muista listatuista toiminnoista lisää myöhemmin) "type": "Observation", "profile": { "reference": "http://phr.kanta.fi/structuredefinition/fiphrvitalsigns-stu3" }, "interaction": [ { "code": "read" }, { "code": "vread" }, { "code": "update }, { "code": "create", "documentation": "Conditional create allows only the use of identifier as condition" }, 10

Mitä tallentamisesta on CapabilityStatementissa? Resurssit täytyy luoda ilman id:tä (updatecreate) Resurssille voi antaa luontiehdon: jos tällä identifierilla löytyy jos resurssi, älä tee uutta Päivitystä ei voi tehdä ehdollisesti Viittaukset tarkastetaan ja viittauksia Kanta PHR:n ulkopuolisille palvelimille ei sallita (esimerkiksi mittaustulosten subject kenttä) nämä ovat kenttäkohtaisesti jokaisessa profiilissa vielä "updatecreate": false, "conditionalcreate": true, "conditionalupdate": false, "referencepolicy": [ "literal", "enforced", "local" ], 11

Päivitä PUT http://fhirsandbox.kanta.fi/phr- resourceserver/basestu3/observation/435b5586-7f65-439e-9d6d- 9ca2ae07e11f Tämä on uusin versio mittaustuloksesta X Päivitys on kuten tallennus, mutta sen REST-pyyntötyyppi on PUT postin sijaan FHIRin update Osoitteessa on myös päivitettävän resurssin tunniste ja bodyssa kokonaan uusi resurssi, joka korvaa aikaisemman Tunniste ei muutu päivittäessä! Vastauksena päivityksestä palvelu kertoo mikä uusi versio oli Location: http://fhirsandbox.kanta.fi/phr-resourceserver/basestu3/observation/435b5586-7f65-439e-9d6d-9ca2ae07e11f/_history/2 Vastauksen osoitteen osoittama resurssi tekee versiohaun 12

Hae GET http://fhirsandbox.kanta.fi/phrresourceserver/basestu3/observation?patient=91db836a-b62a-49af-8e7aa94ed90a41d5 Hae henkilön Y mittaustulokset FHIRin search / search-type eli resurssityyppikohtainen haku Palauttaa tulosjoukon parametreja vastaavia mittaustuloksia Haun tulos palautetaan FHIRin bundlena, jossa on sisällä resurssit CapabilityStatementin interaktio search-type on listattuna muiden interaktioiden tasolla 13

Mitä CapabilityStatement sanoo hauista? Kanta PHR ei tue resurssityyppien yli menevää hakua, vaan haku on aina kohdistettava johonkin tiettyyn tyyppiin Hakuparametrit on listattu CapabilityStatementissa Kanta PHR:n CapabilityStatementissa ahakuparametreja ei ole palvelimen tasolla vaan ainoastaan kunkin resurssin alla "searchparam": [ { "name": "_id", "definition": "Observation.id", "type": "token", "documentation": "Logical id of this artifact" }, { "name": "_lastupdated", "definition": "Observation.meta.lastUpdated", "type": "date", "documentation": "When the resource version last changed" }, { "name": "_security", "definition": "Observation.meta.security", "type": "token", "documentation": "If the viewing the resource is restricted. The following syntaxes are supported: [parameter]=[code] and [parameter]=[system] [code]." }, { "name": "date", "definition": "Observation.effective[x]", "type": "date", "documentation": "Obtained date/time. If the obtained element is a period, a date that falls in the period." }, 14

Hakuparametrit { "name": "patient", "definition": "Observation.subject", "type": "reference", "documentation": "The patient that the observation is about" }, Esimerkiksi mittaustuloksilla yksi hakuparametri on patient Kaikki tuetut hakuparametrit on listattu Definition-kentässä kerrotaan mihin resurssin jsonpath-kohtaan parametri kohdistuu, esim. patient kohdistuu subject-kenttään Hakuparametrin tyyppi kertoo millaisia arvoja hakuun voi antaa, tässä hakuparametrin tyyppi on kentässä oleva referenssiviittaus https://www.hl7.org/fhir/search.html#reference 15

Hakuparametrit Muita hakuparametrityyppejä ovat esimerkiksi päivämäärät ja koodit Näiden osalta noudatetaan standardin käytöstä, mutta osin suppeammin esimerkiksi modifierien osalta CapabilityStatementiin ei pysty kuvaamaan kaikkea hakuparametreista searchinclude ja searchrevinclude puuttuvat, eli niitä ei tueta. Osa kuvauksesta on kenttien puuttumista CapabilityStatementista, koska kuvaus tehdään listaamalla tuetut vaihtoehdot! 16

Lue GET http://fhirsandbox.kanta.fi/phr-resourceserver/basestu3/observation/435b5586-7f65-439e-9d6d-9ca2ae07e11f Anna mittaustulos X Viittaa suoraan resurssiin Fhirin read tai vread Osoite on [base][objektityyppi][id] GET-pyyntö Palauttaa vastauksessa sanoman bodyssa resurssin jsonmuodossa 17

Mitä resurssin lukemisesta on CapabilityStatementissa? Lukemiseen on interaktiot read ja vread Read-toiminto palauttaa aina resurssin uusimman version Vread-toiminnolla, jos jostain syystä on tarve, voi hakea vanhoja versioita Historiasta on myös tieto: "readhistory": true, joka kertoo palauttaako vread vanhoja versioita resurssista "interaction": [ { "code": "read" }, { "code": "vread" }, 18

Poista DELETE http://fhirsandbox.kanta.fi/phr- resourceserver/basestu3/observation/fcd8b4c9-a0c0-43d6-9774- 7dd916137fab Poistamisesta on varsin vähän CapabilityStatementissa FHIRin delete Toiminto on kuvattuna interaktiona resursseilla joilla se on tuettu Patient ja Consent -tyyppien resursseja ei saa poistaa Lisäksi ehdollista poistamista ei tueta vaan resurssi on poistettava käyttämällä sen loogista tunnistetta "conditionaldelete": "not-supported", 19

Miten CapabilityStatementia hyödynnetään? Kanta PHR:n Simplifierissa oleva CapabilityStatement on tyyppiä requirements eli kuvaa miten palvelin itse toimii Esimerkiksi Sandboxin käyttöliittymä (joka pohjautuu Hapi-projektin FHIR-tester käyttöliittymään) lukee PHR-palvelimen CapabilityStatementista tuetut resurssit ja muodostaa näytölle listan sen pohjalta Eniten CapabilityStatementista on hyötyä (ainakin itselleni kehittäjänä!) tiiviinä yleiskuvana palvelimen toiminnoista 20

Miten luvat ja FHIR-toiminnot liittyvät toisiinsa? Kanta PHR:n FHIR-toimintojen luvitus on toteutettu OAuth2.0 standardilla Viime kokouksessa käytiin läpi yksityiskohtia, kuinka Sandoboxin palvelua käytetään (ja varsinainen tuotantoympäristö toimii vastaavalla tavalla) Luvat ovat resurssityyppikohtaisia, esim. lupa voi olla Observation - resurssiin Koska mittaustuloksilla on omistaja, lupa on aina omistajakohtainen Resurssiin on erikseen lukuoikeus ja kirjoitusoikeus Kirjoitusoikeudella myös päivitetään ja poistetaan 21

Kiitos! Eeva Turkka Software Architect eeva.turkka@citrus.fi @kantapalvelut