Issue with security header in Audit messages on NCP-A side
During the autumn Wave 7 test event, we noticed an issue with the audit logs.
For NCP-A, the request and response security headers are displayed like this: {code:java} <ParticipantObjectIdentification ParticipantObjectID="urn:uuid:f62655ef-f797-4960-a1d1-3d7bf161d389" ParticipantObjectTypeCode="4"> <ParticipantObjectIDTypeCode codeSystemName="eHealth DSI Msg" csd-code="req" displayName="Request Message" originalText="req"/> <ParticipantObjectDetail type="securityheader" value="<soapenv:Header xmlns:soapenv="http://www.w3.org/2003/05/soap-envelope" xmlns:wsa="http://www.w3.org/2005/08/addressing"><wsse:Security xmlns:wsse="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd"><saml2:Assertion xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:xsd="http://www.w3.org/2001/XMLSchema" ID="_d06c8a37-7617-4b11-8bcd-4101f511e73f" IssueInstant="2023-11-08T10:10:57.578Z" Version="2.0"><saml2:Issuer NameQualifier="urn:ehdsi:assertions:hcp">urn:idp:MT:countryB</saml2:Issuer><ds:Signature xmlns:ds="http://www.w3.org/2000/09/xmldsig#">
<ds:SignedInfo>
<ds:CanonicalizationMethod Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/>
<ds:SignatureMethod Algorithm="http://www.w3.org/2001/04/xmldsig-more#rsa-sha256"/>
<ds:Reference URI="#_d06c8a37-7617-4b11-8bcd-4101f511e73f">
<ds:Transforms>
<ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/>
<ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"><ec:InclusiveNamespaces xmlns:ec="http://www.w3.org/2001/10/xml-exc-c14n#" PrefixList="xsd"/></ds:Transform>
</ds:Transforms>
<ds:DigestMethod Algorithm="http://www.w3.org/2001/04/xmlenc#sha256"/>
<ds:DigestValue>On/YbtBioN+J3zCYOmt2x7QgArxpT9RPPf8UC3IXH3Y=</ds:DigestValue>
</ds:Reference>
</ds:SignedInfo>
<ds:SignatureValue>
CEB08PDZw+b06goqzvDsWKIxxpzYFk3sK349i7/+bipJ619/NN0jkOZHdANfiBONZ8TQyVZ1JGj4&#13;
4yKgqInLC1XtFdL2CjoOrpxCTAMSSVld0Nuhxd318/aZdj5d86snCtcCpHrBIIA5S/cg3Ne3MFBg&#13;
KLSrNhQxCPS8LVN+Yzoag89xvAc1JK6Bt9r6Wyy7ltT28f8UdG/9UZkRqRy+ZZgNufUPTEsjODup&#13;
SwAfm68tb/Q0MQp8OAB/iwW83uPf94dORJ1R8WNO+meaotU7JB66mbAs5b8HtX9l8s0OSFp5yqT8&#13;
Pmj5c4+3+gli2SgGHb3kjTzXU64e0W6OgQUwMg==
</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIFmjCCBIKgAwIBAgIMbIVZPMCqT5gZa9cuMA0GCSqGSIb3DQEBCwUAMFsxCzAJBgNVBAYTAkJF&#13;
MRkwFwYDVQQKExBHbG9iYWxTaWduIG52LXNhMTEwLwYDVQQDEyhHbG9iYWxTaWduIEdDQyBSMyBQ&#13;
ZXJzb25hbFNpZ24gMiBDQSAyMDIwMB4XDTIyMDkxMzA0MTcxMVoXDTI1MDkxMzA0MTcxMVowgdEx&#13;
CzAJBgNVBAYTAk1UMREwDwYDVQQIEwhWYWxsZXR0YTERMA8GA1UEBxMIVmFsbGV0dGExHDAaBgNV&#13;
BAoTE01pbmlzdHJ5IGZvciBIZWFsdGgxLjAsBgNVBAsMJU5DUF9QUFQtR1RDX09JRC0xLjMuMTMw&#13;
LjAuMjAxOC45OTY5MTExIzAhBgNVBAMMGkdSUDpFSEVBTFRIX05DUF9QUFRfTVRfMDAyMSkwJwYJ&#13;
KoZIhvcNAQkBFhpjcm9zc2JvcmRlci5laGVhbHRoQGdvdi5tdDCCASIwDQYJKoZIhvcNAQEBBQAD&#13;
ggEPADCCAQoCggEBANDfqzoba+mjbfxJ8C67vXZaQQQGhZ6osyUz3Y1q8xAIA9dt9DdNol6LHoe2&#13;
brYAU5OJvTZqUYKBoh+701SP3U9/RMJ6K9rP8+MKv0TPXKeKZYsFv+tOFgnwpD0OlEGSeQ1L0t3x&#13;
NQTrK7eFCUGUtC74MIRAF84YKCF8psPHefnEkG+oJabeJjeHExdN3/LZzDSzHSy0gCBuHbRcSxTi&#13;
eElLE6Ux04I4osfIdJgID7cRKoRSkmijbNa197vjESveHcwZG7zfK392JtiNlrv+l9ei1gN1hsKs&#13;
4AhUcC9Bg9Y+nBvpJ7gydzbO1kEqaRBdhGHRfoF37JVO3gve5Z0YTOsCAwEAAaOCAeUwggHhMA4G&#13;
A1UdDwEB/wQEAwIFoDCBowYIKwYBBQUHAQEEgZYwgZMwTgYIKwYBBQUHMAKGQmh0dHA6Ly9zZWN1&#13;
cmUuZ2xvYmFsc2lnbi5jb20vY2FjZXJ0L2dzZ2NjcjNwZXJzb25hbHNpZ24yY2EyMDIwLmNydDBB&#13;
BggrBgEFBQcwAYY1aHR0cDovL29jc3AuZ2xvYmFsc2lnbi5jb20vZ3NnY2NyM3BlcnNvbmFsc2ln&#13;
bjJjYTIwMjAwTQYDVR0gBEYwRDBCBgorBgEEAaAyASgKMDQwMgYIKwYBBQUHAgEWJmh0dHBzOi8v&#13;
d3d3Lmdsb2JhbHNpZ24uY29tL3JlcG9zaXRvcnkvMAkGA1UdEwQCMAAwSQYDVR0fBEIwQDA+oDyg&#13;
OoY4aHR0cDovL2NybC5nbG9iYWxzaWduLmNvbS9nc2djY3IzcGVyc29uYWxzaWduMmNhMjAyMC5j&#13;
cmwwJQYDVR0RBB4wHIEaY3Jvc3Nib3JkZXIuZWhlYWx0aEBnb3YubXQwHQYDVR0lBBYwFAYIKwYB&#13;
BQUHAwIGCCsGAQUFBwMEMB8GA1UdIwQYMBaAFJYz0eZYF1s0dYqBVmTVvkjeoY/PMB0GA1UdDgQW&#13;
BBSyAPMAPCBOynIkUqfrKW/dS3HpRDANBgkqhkiG9w0BAQsFAAOCAQEAMvoccFk3mI2ZpmoTf4HD&#13;
Wg+06cYCStnj9kd+VELttChhGR5vnb6bcRgOp6nlYZD8Z7Zzw/XuAiA7JUT/B/1SDa1bUw4IjtTw&#13;
asQEo4ZoTV3HFSkXTpJmrwO14Rr0B5dXEl2CSI4RDefw1A1amvz1heyQhyGkiRuUq5NTu2pM0PC7&#13;
jNzbfkquBg6gqH1UGNE8jg0E/qbi9eedmUJyHr0Ce+MQ8THyJdMy7946/GdZyo4PT5K6/RJFP1eE&#13;
O09NNKV+tY5kdX82WlX41E1+K9lhuFZNB2mdhz/Ev0CQY2gwt/gLh8lzGW9o8onRof2bWXf84Nmw&#13;
cX6KKU5cA8vQqFSMcQ==</ds:X509Certificate></ds:X509Data></ds:KeyInfo></ds:Signature><saml2:Subject><saml2:NameID Format="urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress">doctor@ncp.eu</saml2:NameID><saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:sender-vouches"/></saml2:Subject><saml2:Conditions NotBefore="2023-11-08T10:10:57.578Z" NotOnOrAfter="2023-11-08T14:10:57.578Z"><saml2:AudienceRestriction><saml2:Audience>urn:ehdsi:assertions.audience:x-border</saml2:Audience></saml2:AudienceRestriction></saml2:Conditions><saml2:AuthnStatement AuthnInstant="2023-11-08T10:10:57.578Z"><saml2:AuthnContext><saml2:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:SmartcardPKI</saml2:AuthnContextClassRef></saml2:AuthnContext></saml2:AuthnStatement><saml2:AttributeStatement><saml2:Attribute FriendlyName="HCI Identifier" Name="urn:ihe:iti:xca:2010:homeCommunityId" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:uri"><saml2:AttributeValue xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xsd:string">2.16.470.1.100.1.2.1000.990.1</saml2:AttributeValue></saml2:Attribute><saml2:Attribute FriendlyName="XSPA Subject" Name="urn:oasis:names:tc:xspa:1.0:subject:subject-id" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:uri"><saml2:AttributeValue xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xsd:string">doctor doctor</saml2:AttributeValue></saml2:Attribute><saml2:Attribute FriendlyName="XSPA Role" Name="urn:oasis:names:tc:xacml:2.0:subject:role"><saml2:AttributeValue><Role xmlns="urn:hl7-org:v3" code="221" codeSystem="2.16.840.1.113883.2.9.6.2.7" codeSystemName="ISCO" displayName="Medical Doctors"/></saml2:AttributeValue></saml2:Attribute><saml2:Attribute FriendlyName="XSPA Organization ID" Name="urn:oasis:names:tc:xspa:1.0:subject:organization-id" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:uri"><saml2:AttributeValue xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xsd:string">urn:hl7ii:2.16.470.1.100.1.2.1000.990.1:94e9cd39-f9c2-434c-9069-ee8bd81b11c1</saml2:AttributeValue></saml2:Attribute><saml2:Attribute FriendlyName="eHealth DSI Healthcare Facility Type" Name="urn:ehdsi:names:subject:healthcare-facility-type" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:uri"><saml2:AttributeValue xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xsd:string">Resident Physician</saml2:AttributeValue></saml2:Attribute><saml2:Attribute FriendlyName="XSPA Purpose Of Use" Name="urn:oasis:names:tc:xspa:1.0:subject:purposeofuse" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:uri"><saml2:AttributeValue><PurposeOfUse xmlns="urn:hl7-org:v3" code="TREATMENT" codeSystem="3bc18518-d305-46c2-a8d6-94bd59856e9e" codeSystemName="eHDSI XSPA PurposeOfUse" displayName="TREATMENT"/></saml2:AttributeValue></saml2:Attribute><saml2:Attribute FriendlyName="XSPA Locality" Name="urn:oasis:names:tc:xspa:1.0:environment:locality" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:uri"><saml2:AttributeValue xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xsd:string">Mater Dei Hospital, Malta</saml2:AttributeValue></saml2:Attribute><saml2:Attribute FriendlyName="Hl7 Permissions" Name="urn:oasis:names:tc:xspa:1.0:subject:hl7:permission" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:uri"><saml2:AttributeValue xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xsd:string">urn:oasis:names:tc:xspa:1.0:subject:hl7:permission:PRD-006</saml2:AttributeValue><saml2:AttributeValue xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xsd:string">urn:oasis:names:tc:xspa:1.0:subject:hl7:permission:PRD-003</saml2:AttributeValue><saml2:AttributeValue xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xsd:string">urn:oasis:names:tc:xspa:1.0:subject:hl7:permission:PRD-004</saml2:AttributeValue><saml2:AttributeValue xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xsd:string">urn:oasis:names:tc:xspa:1.0:subject:hl7:permission:PRD-005</saml2:AttributeValue><saml2:AttributeValue xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xsd:string">urn:oasis:names:tc:xspa:1.0:subject:hl7:permission:PRD-010</saml2:AttributeValue><saml2:AttributeValue xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xsd:string">urn:oasis:names:tc:xspa:1.0:subject:hl7:permission:PRD-016</saml2:AttributeValue><saml2:AttributeValue xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xsd:string">urn:oasis:names:tc:xspa:1.0:subject:hl7:permission:PPD-032</saml2:AttributeValue><saml2:AttributeValue xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xsd:string">urn:oasis:names:tc:xspa:1.0:subject:hl7:permission:PPD-033</saml2:AttributeValue></saml2:Attribute></saml2:AttributeStatement></saml2:Assertion></wsse:Security><Action xmlns="http://www.w3.org/2005/08/addressing" soapenv:mustUnderstand="1">urn:hl7-org:v3:PRPA_IN201305UV02:CrossGatewayPatientDiscovery</Action><MessageID xmlns="http://www.w3.org/2005/08/addressing">urn:uuid:f62655ef-f797-4960-a1d1-3d7bf161d389</MessageID><wsa:To>https://ncp-ppt.gr.ehealth.testa.eu:9443/openncp-ws-server/services/XCPD_Service</wsa:To></soapenv:Header>"/> <ParticipantObjectIdentification ParticipantObjectID="urn:uuid:03d4ad7b-6b9c-4cc7-8ac7-52f4123ef92d" ParticipantObjectTypeCode="4"> <ParticipantObjectIDTypeCode codeSystemName="eHealth DSI Msg" csd-code="rsp" displayName="Response Message" originalText="rsp"/> <ParticipantObjectDetail type="securityheader" value="PHNvYXBlbnY6SGVhZGVyIHhtbG5zOnNvYXBlbnY9Imh0dHA6Ly93d3cudzMub3JnLzIwMDMvMDUvc29hcC1lbnZlbG9wZSIvPg=="/> {code} Where for the NCP-B, the same securityheaders are like this: {code:java} {code} If we Base64 decode the security header of the response on NCP-A side, we read: {code:java} <soapenv:Header xmlns:soapenv="http://www.w3.org/2003/05/soap-envelope"/>{code} This is not the same as the security header of the response on NCP-B side.
For NCP-B it is ok, but maybe it makes sense, since on the B side, you have both the request and the response. If on the NCP-A side, the audit log is generated before the response, it is logic that the security header for the response is empty...
This ticket is to review the OpenNCP code to see how it is generated and whether it could be aligned or not.