RIV Tekniska Anvisningar Tjänsteschema
| RIV Tekniska Anvisningar Tjänsteschema
Version 2.2 ARK_0005 2024-09-18 |
Innehållsförteckning
- 1 RIV Tekniska Anvisningar Tjänsteschema
- 2 Innehållsförteckning
- 3 1 Inledning
- 3.1 1.1 Målgrupp
- 3.2 1.2 Syfte
- 3.3 1.3 Tillgänglighet
- 4 2. Beskrivning av namnregler
- 5 3. Detaljerade regler
- 5.1 Regel #1, designmönster för tjänstescheman
- 5.2 Regel #2, namn på xsd-filen
- 5.3 Regel #3, namn på target namespace
- 5.4 Regel #4, namn på element
- 5.5 Regel #5, namn på typer
- 5.6 Regel #6, användning av schema-attributen elementFormDefault och attributeFormDefault
- 5.7 Regel #7, användning av schema-attributet version
- 5.8 Regel #8, användning av any-element för utökningsbarhet
- 5.9 Regel #9, nya element i utökningsschema
- 5.10 Regel #10 Nationella tecken
- 5.11 Regel #11, Felhantering och återrapportering
Versionshistorik | |||
Utgåva | Revision Datum | Beskrivning | Ändringarna gjorda av |
A | 2011-10-19 | Revision fastställd | Marcus Krantz |
C | 2012-01-03 | Revision fastställd | Hans Thunberg |
D | 2013-06-27 | Ny version efter CeHis AR nya processer | CeHis AR T |
2.1.1 | 2014-08-20 | Förtydligat regel #9 och flyttat XML-exempel till bilaga. | Mattias Nordvall |
2.1.1 | 2014-09-26 | Lagt upp iinera mall och publicerat | Lennart Eriksson |
2.1.2 | 2014-10-03 | Rättat detaljer i bilaga 1. | Mattias Nordvall |
2.1.3 | 2015-12-17 | Uppdaterat länkar i referenstabell | Mattias Nordvall |
2.1.4 | 2016-09-27 | Läsande tjänster ska inte returnera logiska fel | Tommy Carlsson |
2.1.5 | 2018-05-08 | Lagt till att även domänprefix kan ha olika värden, var förut hårt satt till "riv:" Förtydligat namnsättningsregler och struktur för domän resp interaktionsnivå Uppdaterat regel #7 från bör till skall | Björn Hedman |
2.1.6 | 2019-12-18 | Uppdaterat regel #11 till att tydligare definiera hur felhantering och återrapportering skall ske. Specificerar användandet av SOAP Faults samt tydliggör hantering av ResultCode och ResultText | Anders Malmros |
2.1.7 | 2019-12-19 | Förtydligat hur hantering av minor uppdateringar ska ske regel 2, namsättning fil ändrat kapitel med exempel till att hänsvisa till bilagor | Björn Hedman |
2.1.8 | 2020-09-24 | Flyttat ut exempel på utökning av schemat till Bilaga, förtydligat att ANY-elementet kan bytas ut mot enbart ett element, rättat domän-prefix och små punkterings och skrivfel. | Ranjdar Fallyih, Thomas Siltberg, Claudia Ehrentraut Inera |
2.1.9 | 2021-09-09 | Obsoleta mailadresser borttagna ur revisionshistoriken. Ersatta med namn | Anders Malmros |
2.1.10 | 2021-09-14 | Uppdaterat regel #11 avseende ett exempel på ett soap faults detail-fält då detta var fel formaterat | Anders Malmros |
2.1.11 | 2021-11-24 | Ingen uppdatering. Vill endast komplettera i versionshistoriken att anvisningen sedan v 2.1.6 tillåter läsande tjänster att returnera logiska fel. | Anders Malmros |
2.2 | 2024-09-18 | Flyttat regelverk för hur tekniska fel förmedlas med hjälp av SOAP Faults från regel #11 till RIV Tekniska Anvisningar Basic Profile 2.1. Ändrat skrivningen under “återrapportering” att meddelande till användare så att tjänstekonsumenten kan VÄLJA att visa upp det istället för SKA. | Anders Malmros Björn Hedman |
1 Inledning
Detta dokument beskriver regelverket RIV Tekniska Anvisningar Tjänsteschema 2.0.
1.1 Målgrupp
Denna anvisning riktar sig till dem som ska specificera XML-scheman för tjänstekontrakt i en nationell tjänsteinteraktion. Anvisningen innehåller endast regeluppsättningen. För bakgrund, motiv, krav samt de principer som ligger till grund för framtagning av reglerna hänvisas till RIV Tekniska Anvisningar - Översikt 2.0
1.2 Syfte
Syftet med denna anvisning är att beskriva designregler och namngivningsregler för interoperabilitet samt riktlinjer för att bygga in stöd för versionshantering i tjänstescheman.
Ett uttalat syfte med tjänstescheman är att de ska kunna användas oberoende av kommunikationsstandard. Många tjänstescheman kommer dock att skapas i syfte att importeras i WSDL-filer. Reglerna för tjänstescheman är därför baserade på WS-Basic Profiles regelverk för WS-I Basic Profile - Version 1.1. Målet med anvisningen är att optimera för interoperabilitet vid användning av web-service-baserade RIV TA-profiler utan att göra tjänstescheman beroende av web-services för transport och kuvertering
1.3 Tillgänglighet
Detta dokument är publicerat under licensen Creative Commons CC-BY-SA (Sammanfattning - Erkännande-DelaLika 2.5 - Creative Commons ).
Det betyder att du fritt får kopiera, distribuera och skapa bearbetningar av anvisningarna under förutsättning att upphovsmannen Sveriges Kommuner och Regioner anges, men inte på ett sätt som antyder att de godkänt eller rekommenderar din användning av verket.
2. Beskrivning av namnregler
Namngivningsregler i detta dokument är formulerade enligt följande uppställning:
Tjänstedomänens prefix: ${domänPrefix}, t ex riv eller riv-application
Tjänstedomänens namn: ${tjänsteDomän}, t ex clinicalprocess:activity:request
Tjänsteinteraktionens namn: ${tjänsteInteraktion}, t ex GetRequest
Tjänsteinteraktionsroll: ${roll} = Initiator eller Responder, motsvarande tjänsteinteraktionsroller initiativtagare och utförare
Tjänsteinteraktionens version:
m.n = förkortning av ${majorVersion}.${minorVersion}
m = förkortning av ${majorVersion}Operationens namn: ${operation}, t ex MakeBooking
3. Detaljerade regler
Regel #1, designmönster för tjänstescheman
"Venetian Blind” http://www.xfront.com/GlobalVersusLocal.html skall användas som designmönster för tjänstescheman. Designmönstret Venetian Blind innebär följande:
Den interna strukturen i ett meddelande byggs upp med hjälp av globalt deklarerade typer. Med ”globalt deklarerade” menas deklarationer som görs direkt under schema-elementet.
Endast rotelementet är deklarerat som ett globalt element. I web-service-fallet innebär det att request- och response-elementen är globalt deklarerade element medan resten är typer.
Anm. I vissa fall kan även andra element än request och response behöva vara globala, t ex används element-referenser till globala element i importerade scheman för att stödja versioneringsstrategin, se nedan.
Motiv: Interoperabilitet, WS-I Basic Profile
Regel #2, namn på xsd-filen
Schema-filen för ett tjänstekontrat bör namnges enligt följande regel: ${tjänsteInteraktion}${roll}_${m.n}.xsd
Observera utökningsscheman namnsätts enligt ${tjänsteInteraktion}${roll}_${m.n}_ext.xsd
Motiv: Att ha med versionsnummer i namnet på källkodsfiler är generellt sett något man försöker undvika då det försvårar användning av versionshanteringsverktyg (t ex Subversion, Microsoft Visual Studio). I fallet med tjänsteschema behöver man dock kunna hantera flera olika versioner samtidigt (i byggsystem mm) och för att underlätta den hanteringen ingår versionsnumret i filnamnet på tjänstekontrakt.
Anm. Detta gäller principiellt sett också de XML Schema som importeras/inkluderas av att tjänsteschema och som beskriver RIV Meddelanden men denna anvisning täcker inte in utformning av dessa XML Scheman.
Exempel: MakeBookingResponder_1.0.xsd
Version i filnamnet: Versionen i filnamnet ska återspegla interaktionens logiska version och räknas alltså bara upp om strukturen för interaktionen förändras, övriga förändringar som sker rent tekniskt i filen påverkar inte versionen.
Om ett gemensamt schema har förändrats och bytt version och därigenom filnamn så behöver importen av detta i interaktionsschemat uppdateras men om inga objekt i interaktionen påverkas så behöver inte interaktionens version lyftas
Se även Bilaga1 "Exempel på utökning av tjänsteschema"
Regel #3, namn på target namespace
Attributet targetNamespace på schema-elementet för en tjänsteinteraktion skall ha ett värde som definieras av följande regel: urn:${domänPrefix}:${tjänsteDomän}:${tjänsteInteraktion}${roll}:${m}
(Reglerna för namnsättning av domänprefix och tjänstedomän finns mer utförligt beskrivna i dokumentet Domännamnsättning
Motiv:
Användningen av major-version i namnrymden är en av att följa fastslagen versioneringsstrategi se W3C Extending and Versioning Languages: XML Languages . Att ha en unik namnrymd per tjänstekontrakt (tjänsteinteraktion + roll) är en förutsättning för att följa WS-I Basic Profiles Basic Profile - Version 1.1 regel om ”operation signature”. Det också generellt goda förutsättningar för att implementera generella bryggor och tjänsteväxlar
Exempel:
Nationell domän
urn:riv:crm:scheduling:MakeBookingResponder:1
Regel #4, namn på element
Attributet ”name” på element som deklarerar request-element i tjänsteschemat skall ha ett värde som följer följande regel: ${operation}, t ex: MakeBooking
Attributet ”name” på element som deklarerar response-element i tjänsteschemat skall ha ett värde som följer följande regel ${operation}Response, t ex: MakeBookingResponse
Motiv: För konsistent namngivning skall element för in-parametrar ha samma namn som operationen.
Exempel: ”MakeBooking” respektive “MakeBookingResponse”
Regel #5, namn på typer
Attributet ”name” på element som deklarerar request-typer i tjänsteschemat bör ha ett värde som följer följande regel: ${operation}Type
Attributet ”name” på element som deklarerar response-typer i tjänsteschemat skall ha ett värde som följer följande regel: ${operation}ResponseType
Motiv: Enhetlighet.
Exempel: ” MakeBookingType” respektive ” MakeBookingResponseType”
Regel #6, användning av schema-attributen elementFormDefault och attributeFormDefault
Schema-attributen elementFormDefault och attributeFormDefault skall sättas till "qualified" respektive "unqualified".
Motiv: För att versioneringsstrategin skall fungera är det viktigt att alla element i instans-dokument är namespace-qualified. Detta uppnås genom att sätta schema-attributet elementFormDefault till "qualified".
Regel #7, användning av schema-attributet version
Schema-attributet version skall sättas till "m.n"
Motiv: Då namnrymden inte innehåller minor-version, ger detta en dokumentation som följer intentionen med attributet.
Exempel: <schema ... version="1.0>
Regel #8, användning av any-element för utökningsbarhet
För att uppnå framåtkompatibilitet skall ett xsd:any element läggas in sist i alla komplexa typer som ska kunna utökas.
Motiv: För att uppnå framåtkompatibilitet måste man "förbereda" sina XML scheman för framtida utökningsbarhet. Detta är en del av den tillämpade strategin för versionering.
Exempel:
<xs:complexType name="SomeType">
<xs:sequence>
<xs:element name="someElement" type="xsd:string" />
<xs:element name="someOtherElement" type="xsd:int" />
<xs:any processContents="lax" minOccurs="0" maxOccurs="unbounded" namespace="##other"/>
</xs:sequence>
</xs:complexType>
Regel #9, nya element i utökningsschema
För att lägga till nya element och skapa en ny minor-version av ett tjänsteschema, skall följande regler följas:
Det nya elementet läggs till i befintligt schema närmast före any-elementet i den komplexa typ som ska utökas. Detta nya element har ingen typ, utan refererar (xsd:ref=”…”) element som är rotelement i en ny schema-fil (utöknings-schema)
Exempel <xs:element ref="m1:financingOrganization" minOccurs="0" maxOccurs="unbounded" />
För att ändringen ska vara bakåtkompatibel så måste det nya elementet ha attributet minoccurs=”0”. Det leder i sin tur att any-elementet måste tas bort. Detta för att uppfylla kravet på Unique Particle Attribution i Xml Schema 1.0. Följden blir att denna komplexa typ inte kan förändras fler gånger på ett bakåtkompatibelt sätt.
Det nya elementet definieras i en ny schema-fil (utökningsschema) med ett namn som följer följande regel: ${tjänsteInteraktion}${roll}_${m.n}_ext.xsd
Utökningsschemat ska ha en targetNamespace enligt följande regel: urn:$(domänPrefix):${tjänsteDomän}:${tjänsteInteraktion}${roll}:${m.n}
Tjänsteschemat importerar (xsd:import) utöknings-schemat som ges namnrymdsalias enligt följande regel: m${n}
Exempel: xmlns:m1='urn:riv:infrastructure:directory:organization:GetUnitResponder:2.2'
Tjänsteschemats versionsattribut ändras till den nya minor-versionen.
I nästa major-version av tjänsteschemat flyttas element-deklarationerna in från alla utökningsscheman (det finns ett för varje minor-version som tilkommit sedan förra major-versionen skapades). Dessutom läggs eventuellt borttagna any-element tillbaka, enligt regel #8.
Motiv: Detta förfarande är en konsekvens av vald strategi för versionering.
Se även Bilaga1 "Exempel på utökning av tjänsteschema"
Regel #10 Nationella tecken
Tjänstescheman ska undvika att använda nationella tecken i såväl elementnamn, attributnamn som vid listning av värdemämngder för uppräkningstyper. Följande exempel bör därför undvikas:
<xs:simpleType name=”Å”>
<xs:annotation>
<xs:documentation>…</xs:documentation>
</xs:annotation>
<xs:restriction base=”xs:string”>
<xs:enumeration value=”Återställas helt” />
<xs:enumeration value=”Återställas delvis” />
<xs:enumeration value=”Det går inte att bedöma” />
</xs:restriction>
</xs:simpleType>
Motiv: För att undvika interoperabilitetsproblem bör man ej använda sig av nationella tecken när man definierar typer som kommer att användas i ett tjänstekontrakt. Ofta uppstår annars fel vid kodgenerering från schemat.
Regel #11, Felhantering och återrapportering
Tekniska fel hanteras enligt RIV Tekniska Anvisningar Basic Profile 2.1.
För logiska fel och återrapportering av status kan svar inkludera elementen resultCode och resultText. ResultCode kan endast ha värdena OK, INFO eller ERROR enligt följande:
<xs:complexType name="X">
<xs:sequence>
...
<xs:element name="resultCode" type="tns:ResultCodeEnum" minOccurs="1" maxOccurs="1" />
<xs:element name="resultText" type="xs:string" minOccurs="0" maxOccurs="1" />
...
</xs:sequence>
</xs:complexType>
<xs:simpleType name="ResultCodeEnum">
<xs:restriction base="xs:string">
<xs:enumeration value="OK"/>
<xs:enumeration value="ERROR"/>
<xs:enumeration value="INFO"/>
</xs:restriction>
</xs:simpleType>
Logiska fel
Ett logisk fel är en situation där behandlingen kan ha resulterat i ett, ur slutanvändarens perspektiv, oväntat utfall. För att klassas som ett logiskt fel måste tjänstebegäran utformats enligt överenskommelse (korrekt enligt XML-schema och tjänstekontraktsbeskrivning) och tjänsteproducentens behandling har inte misslyckats på grund av ett tekniskt fel hos vare sig tjänstekonsument eller tjänsteproducent enligt definitionen ovan.
För återrapportering av logiska fel ska svaret innehålla ett element “resultCode” med värde ERROR och en textuell felbeskrivning av felet i element “resultText”.
ResultText skall loggas och kan visas upp för användaren i de fall då det är tillämpbart.
Exempel:
Återrapportering
Inget att rapportera
Om man inte har något speciellt att rapportera kring behandling av en tjänstebegäran kan man i svaret ändå inkludera elementet “resultCode” med värde OK och utelämna elementet “resultText”.
Exempel:
Meddelande till systemförvaltare
Om man efter lyckad behandling av en tjänstebegäran vill återrapportera information från behandlingen eller beskrivande text för returnerad data ska man i svaret inkludera elementet “resultCode” med värde OK och elementet “resultText” innehållande den text som ska loggas men inte visas för användaren.
Exempel:
Meddelande till användare
Om man efter lyckad behandling av en tjänstebegäran vill återrapportera ett meddelande, som tjänstekonsumenten kan välja att visa upp för en användare, ska man i svaret inkludera elementet “resultCode” med värde INFO och elementet “resultText” innehållande meddelandet som ska visas upp.
Exempel: