Table of Contents
List of Figures
List of Tables
The information in this publication was considered technically sound by the consensus of persons engaged in the development and approval of the document at the time it was developed. Consensus does not necessarily mean that there is unanimous agreement among every person participating in the development of this document.
NEMA standards and guideline publications, of which the document contained herein is one, are developed through a voluntary consensus standards development process. This process brings together volunteers and/or seeks out the views of persons who have an interest in the topic covered by this publication. While NEMA administers the process and establishes rules to promote fairness in the development of consensus, it does not write the document and it does not independently test, evaluate, or verify the accuracy or completeness of any information or the soundness of any judgments contained in its standards and guideline publications.
NEMA disclaims liability for any personal injury, property, or other damages of any nature whatsoever, whether special, indirect, consequential, or compensatory, directly or indirectly resulting from the publication, use of, application, or reliance on this document. NEMA disclaims and makes no guaranty or warranty, expressed or implied, as to the accuracy or completeness of any information published herein, and disclaims and makes no warranty that the information in this document will fulfill any of your particular purposes or needs. NEMA does not undertake to guarantee the performance of any individual manufacturer or seller's products or services by virtue of this standard or guide.
In publishing and making this document available, NEMA is not undertaking to render professional or other services for or on behalf of any person or entity, nor is NEMA undertaking to perform any duty owed by any person or entity to someone else. Anyone using this document should rely on his or her own independent judgment or, as appropriate, seek the advice of a competent professional in determining the exercise of reasonable care in any given circumstances. Information and other standards on the topic covered by this publication may be available from other sources, which the user may wish to consult for additional views or information not covered by this publication.
NEMA has no power, nor does it undertake to police or enforce compliance with the contents of this document. NEMA does not certify, test, or inspect products, designs, or installations for safety or health purposes. Any certification or other statement of compliance with any health or safety-related information in this document shall not be attributable to NEMA and is solely the responsibility of the certifier or maker of the statement.
This DICOM Standard was developed according to the procedures of the DICOM Standards Committee.
The DICOM Standard is structured as a multi-part document using the guidelines established in ???.
This part of the DICOM Standard specifies Security and System Management Profiles to which implementations may claim conformance. Security and System Management Profiles are defined by referencing externally developed standard protocols, such as TLS, ISCL, DHCP, and LDAP, with attention to their use in a system that uses DICOM Standard protocols for information interchange.
The DICOM standard does not address issues of security policies, though clearly adherence to appropriate security policies is necessary for any level of security. The standard only provides mechanisms that could be used to implement security policies with regard to the interchange of DICOM objects between Application Entities. For example, a security policy may dictate some level of access control. This Standard does not consider access control policies, but does provide the technological means for the Application Entities involved to exchange sufficient information to implement access control policies.
This Standard assumes that the Application Entities involved in a DICOM interchange are implementing appropriate security policies, including, but not limited to access control, audit trails, physical protection, maintaining the confidentiality and integrity of data, and mechanisms to identify users and their rights to access data. Essentially, each Application Entity must insure that their own local environment is secure before even attempting secure communications with other Application Entities.
When Application Entities agree to interchange information via DICOM through association negotiation, they are essentially agreeing to some level of trust in the other Application Entities. Primarily Application Entities trust that their communication partners will maintain the confidentiality and integrity of data under their control. Of course that level of trust may be dictated by local security and access control policies.
Application Entities may not trust the communications channel by which they communicate with other Application Entities. Thus, this Standard provides mechanisms for Application Entities to securely authenticate each other, to detect any tampering with or alteration of messages exchanged, and to protect the confidentiality of those messages while traversing the communications channel. Application Entities can optionally utilize any of these mechanisms, depending on the level of trust they place in the communications channel.
This Standard assumes that Application Entities can securely identify local users of the Application Entity, and that user's roles or licenses. Note that users may be persons, or may be abstract entities, such as organizations or pieces of equipment. When Application Entities agree to an exchange of information via DICOM, they may also exchange information about the users of the Application Entity via the Certificates exchanged in setting up the secure channel. The Application Entity may then consider the information contained in the Certificates about the users, whether local or remote, in implementing an access control policy or in generating audit trails.
This Standard also assumes that Application Entities have means to determine whether or not the "owners" (e.g., patient, institution) of information have authorized particular users, or classes of users to access information. This Standard further assumes that such authorization might be considered in the access control provided by the Application Entity. At this time, this Standard does not consider how such authorization might be communicated between Application Entities, though that may be a topic for consideration at some future date.
This Standard also assumes that an Application Entity using TLS has secure access to or can securely obtain X.509 key Certificates for the users of the application entity. In addition, this standard assumes that an Application Entity has the means to validate an X.509 certificate that it receives. The validation mechanism may use locally administered authorities, publicly available authorities, or some trusted third party.
This Standard assumes that an Application Entity using ISCL has access to an appropriate key management and distribution system (e.g., smartcards). The nature and use of such a key management and distribution system is beyond the scope of DICOM, though it may be part of the security policies used at particular sites.
The System Management Profiles specified in this Part are designed to support automation of the configuration management processes necessary to operate a system that uses DICOM Standard protocols for information interchange.
This Part assumes that the Application Entities may operate in a variety of network environments of differing complexity. These environments may range from a few units operating on an isolated network, to a department-level network with some limited centralized network support services, to an enterprise-level network with significant network management services. Note that the System Management Profiles are generally addressed to the implementation, not to Application Entities. The same Profiles need to be supported by the different applications on the network.
The following standards contain provisions that, through reference in this text, constitute provisions of this Standard. At the time of publication, the editions indicated were valid. All standards are subject to revision, and parties to agreements based on this Standard are encouraged to investigate the possibilities of applying the most recent editions of the standards indicated below.
ANSI X9.52 American National Standards Institute. ANSI X9.52-1998, Triple Data Encryption Algorithm Modes of Operation. 1998.
ECMA 235, The ECMA GSS-API Mechanism
FIPS PUB 46 Data Encryption Standard
FIPS PUB 81 DES Modes of Operation
IETF Internet X.509 Public Key Infrastructure; Time Stamp Protocols; March 2000
ISO/IEC Directives, 1989 Part 3 - Drafting and Presentation of International Standards
ISO/IEC 10118-:1998 Information technology - Security techniques - Hash-functions - Part 3: Dedicated hash-functions (RIPEMD-160 reference)
Note: The draft RIPEMD-160 specification and sample code are also available at ftp://ftp.esat.kuleuven.ac.be/pub/bosselae/ripemd
ISO 7498-1, Information Processing Systems - Open Systems Interconnection - Basic Reference Model
ISO 7498-2, Information processing systems - Open Systems Interconnection - Basic reference Model - Part 2: Security Architecture
ISO/TR 8509, Information Processing Systems - Open Systems Interconnection - Service Conventions
ISO 8649:1987, Information Processing Systems ‑ Open Systems Interconnection ‑ Service Definition for the Association Control Service Element
Integrated Secure Communication Layer V1.00 MEDIS-DC
ITU-T Recommendation X.509 (03/00) "Information technology - Open Systems Interconnection - The directory: Public-key and attribute certificate frameworks"
ITU-T Recommendation X.509 is similar to ISO/IEC 9594-8 1990. However, the ITU-T recommendation is the more familiar form, and was revised in 1993 and 2000, with two sets of corrections in 2001. ITU-T was formerly known as CCITT.
RFC 1035 Domain Name System (DNS)
RFC 1305 Network Time Protocol (Version 3) Specification, Implementation
RFC 2030 Simple Network Time Protocol (SNTP) Version 4
RFC 2131 Dynamic Host Configuration Protocol
RFC 2132 Dynamic Host Configuration Protocol Options
RFC 2136 Dynamic Updates in the Domain Name System (DNS UPDATE)
RFC 2181 Clarifications to the DNS Specification
RFC 2219 Use of DNS Aliases for Network Services
RFC 2246, Transport Layer Security (TLS) 1.0 Internet Engineering Task Force
TLS is derived from SSL 3.0, and is largely compatible with it.
RFC 2251 Lightweight Directory Access Protocol (v3)
RFC-2313 PKCS #1: RSA Encryption, Version 1.5, March 1998.
RFC 2563 DHCP Option to Disable Stateless Auto-Configuration in IPv4 Clients
RFC 2782 A DNS RR for specifying the location of services (DNS SRV)
RFC 2849 The LDAP Data Interchange Format (LDIF)
RFC 2898 PKCS #5: Password-Based Cryptography Specification Version 2.0, September 2000
RFC 3211 Password-based Encryption for CMS, December 2001
RFC 3268 Advanced Encryption Standard (AES) Ciphersuites for Transport Layer Security (TLS), June 2002.
RFC 3447 PKCS #1 RSA Cryptography Specifications Version 2.1, February 2003
The RSA Encryption Standard is also defined in informative annex A of ISO/IEC 9796, and in Normative Annex A of the CEN/TC251 European Prestandard prENV 12388:1996.
RFC 3852 Cryptographic Message Syntax,July 2004
RFC 3370 Cryptographic Message Syntax (CMS) Algorithms, August 2002
RFC 3565 Use of the Advanced Encryption Standard (AES) Encryption Algorithm in Cryptographic Message Syntax (CMS), July 2003
SHA-1 National Institute of Standards and Technology, FIPS Pub 180-1: Secure Hash Standard, 17 April 1995
SHA-2 National Institute of Standards and Technology, FIPS Pub 180-2: Secure Hash Standard, 1 August 2002
RFC 3851 Secure/Multipurpose Internet Mail Extensions (S/MIME) Version 3.1 Message Specification
RFC 3853 S/MIME Advanced Encryption Standard (AES) Requirement for the Session Initiation Protocol (SIP)
RFC5424 The Syslog Protocol
RFC5425 Transport Layer Security (TLS) Transport Mapping for Syslog
RFC5426 Transmission of Syslog Messages over UDP
Normative RFC's are frequently updated by issuance of subsequent RFC's. The original older RFC is not modified to include references to the newer RFC.
For the purposes of this Standard the following definitions apply.
This part of the Standard makes use of the following terms defined in ISO 7498‑1:
Application Entity
Protocol Data Unit or Layer Protocol Data Unit
Transport Connection
This Part of the Standard makes use of the following terms defined in ISO 7498-2:
Data Confidentiality
The definition is "the property that information is not made available or disclosed to unauthorized individuals, entities or processes."
Data Origin Authentication
The definition is "the corroboration that the source of data received is as claimed."
Data Integrity
The definition is "the property that data has not been altered or destroyed in an unauthorized manner."
Key Management
The definition is "the generation, storage, distribution, deletion, archiving and application of keys in accordance with a security policy."
Digital Signature
The definition is "Data appended to, or a cryptographic transformation of, a data unit that allows a recipient of the data unit to prove the source and integrity of that unit and protect against forgery e.g., by the recipient."
This part of the Standard makes use of the following terms defined in ISO 8649:
Association or Application Association
This Part of the Standard makes use of the following terms defined in ECMA 235:
Security Context
The definition is "security information that represents, or will represent a Security Association to an initiator or acceptor that has formed, or is attempting to form such an association."
This Part of the Standard makes use of the following terms defined in PS3.1:
Attribute
This Part of the Standard makes use of the following terms defined in PS3.2:
Security Profile
This Part of the Standard makes use of the following terms defined in PS3.3:
Module
This Part of the Standard makes use of the following terms defined in PS3.4:
Service Class
Service-Object Pair (SOP) Instance
This Part of the Standard makes use of the following terms defined in PS3.8:
DICOM Upper Layer
The following definitions are commonly used in this Part of the DICOM Standard:
a Transport Connection that provides some level of protection against tampering, eavesdropping, masquerading.
A digest or hash code derived from a subset of Data Elements.
An electronic document that identifies a party and that party's public encryption algorithm, parameters, and key. The Certificate also includes, among other things, the identity and a digital signature from the entity that created the certificate. The content and format of a Certificate are defined by ITU-T Recommendation X.509.
The following symbols and abbreviations are used in this Part of the Standard.
American College of Radiology
Application Entity
Advanced Encryption Standard
American National Standards Institute
Comite European de Normalisation-Technical Committee 251-Medical Informatics
Cipher Block Chaining
Consultative Committee, International Radio
Common Name
Data Encryption Standard
Dynamic Host Configuration Protocol
Digital Imaging and Communications in Medicine
Distinguished Name
Domain Name System
Dynamic Domain Name System
European Computer Manufacturers Association
Encrypt-Decrypt-Encrypt
Health Level 7
International Electrical Commission
Institute of Electrical and Electronics Engineers
Internet Engineering Task Force
Information Object Definition
Integrated Secure Communication Layer
International Standards Organization
Japan Medical Imaging and Radiological Systems Industries Association
Lightweight Directory Access Protocol
LDAP Interchange Format
Message Authentication Code
Message Digest - 5
Medical Information System Development Center
Maximum Transmission Unit
National Electrical Manufacturers Association
Network Time Protocol
Object Identifier (analogous to UID)
Protocol Data Unit
Relative Distinguished Name
Request For Comment (used for standards issued by the IETF)
Resource Record (when used in the context of DNS)
Rivest-Shamir-Adleman
Service Class Provider
Service Class User
Secure Hash Algorithm
Simple Network Time Protocol
Service-Object Pair
Secure Shell
Secure Sockets Layer
Transport Layer Security
Unique Identifier
Universal Coordinated Time
An implementation may claim conformance to any of the Security and System Management Profiles individually. It may also claim conformance to more than one Security or System Management Profile. It shall indicate in its Conformance Statement how it chooses which profiles to use for any given transaction.
An implementation may claim conformance to one or more Secure Use Profiles. Such profiles outline the use of attributes and other Security Profiles in a specific fashion.
Secure Use Profiles are specified in Annex A.
An implementation may claim conformance to one or more Secure Transport Connection Profiles.
A Secure Transport Connection Profile includes the following information:
Description of the protocol framework and negotiation mechanisms
Description of the entity authentication an implementation shall support
The identity of the entities being authenticated
The mechanism by which entities are authenticated
Any special considerations for audit log support
Description of the encryption mechanism an implementation shall support
The method of distributing session keys
The encryption protocol and relevant parameters
Description of the integrity check mechanism an implementation shall support
Secure Transport Connection Profiles are specified in Annex B.
An implementation may claim conformance to one or more Digital Signature Profiles.
A Digital Signature profile consists of the following information:
The role that the Digital Signature plays, including:
Who or what entity the Digital Signature represents.
A description of the purpose of the Digital Signature.
The conditions under which the Digital Signature is included in the Data Set.
A list of Attributes that shall be included in the Digital Signature.
The mechanisms that shall be used to generate or verify the Digital Signature, including:
The algorithm and relevant parameters that shall be used to create the MAC or hash code, including the Value to be used for the MAC Algorithm (0400,0015) Attribute.
The encryption algorithm and relevant parameters that shall be used to encrypt the MAC or hash code in forming the Digital Signature.
The certificate type or key distribution mechanism that shall be used, including the Value to be used for the Certificate Type (0400,0110) Attribute.
Any requirements for the Certified Timestamp Type (0400,0305) and Certified Timestamp (0400,0310) Attributes.
Any special requirements for identifying the signatory.
The relationship with other Digital Signatures, if any.
Any other factors needed to create, verify, or interpret the Digital Signature
Digital Signature Profiles are specified in Annex C.
An implementation may claim conformance to one or more Media Storage Application Profiles, which in turn require conformance to one or more Media Storage Security Profiles.
An implementation may not claim conformance to a Media Storage Security Profile without claiming conformance to a Media Storage Application Profile.
A Media Storage Security Profile includes the following specifications:
What aspects of security are addressed by the profile.
The restrictions on the types of DICOM Files that can be secured, if any.
How the DICOM Files will be encapsulated and secured.
Media Storage Security Profiles are specified in Annex D.
An implementation may claim conformance to one or more Network Address Management Profiles. Such profiles outline the use of non-DICOM network protocols to obtain the network addresses for the implementation.
Network Address Management Profiles are specified in Annex F.
An implementation may claim conformance to one or more Time Synchronization Profiles. Such profiles outline the use of non-DICOM protocols to set the current time for the implementation.
Time Synchronization Profiles are specified in Annex G.
An implementation may claim conformance to one or more Application Configuration Management Profiles. Such profiles outline the use of non-DICOM network protocols to obtain the descriptions, addresses and capabilities of other devices with which the implementation may communicate using the DICOM Protocol. They also specify the use of those non-DICOM protocols for the implementation to publish or announce its description, addresses and capabilities. They also specify how implementation specific configuration information can be obtained by devices.
Application Configuration Management Profiles are specified in Annex H.
Configuration management support is implemented by means of protocols defined in standards other than the DICOM standard. These protocols are described here in terms of actors, transactions, and profiles.
Actors are analogous to the Application Entities used within the DICOM profile. An actor is a collection of hardware and software processes that perform a particular role. When a device provides or uses a service it will include an actor to handle the relevant network activity. DICOM Configuration actors may co-exist with other Application Entities on a device. Some DICOM Configuration actors exist as parts of general use IT equipment. Like the Application Entity, specification of an Actor does not imply anything about the details of the actual implementation.
The actor interactions are defined in terms of Transactions. Each transaction is given a name. The transaction may in turn comprise a variety of activity. All transactions are defined in terms of actors that are communicating. The relationships between actors in a transaction may be more complex than the simple SCU and SCP roles in DICOM activities. When the transaction includes interactions with a person, the transactions may be implemented by user interfaces, removable media. and other mechanisms. The person is described in terms of being an actor from the perspective of the transaction use case model. More typically the transactions are a series of network activities that perform a specific operation.
A transaction includes both mandatory and optional components. An Actor that is implementing a transaction is required to implement all of the mandatory components.
Some transactions include human actors in the transaction definition. These actors are not defined as actors elsewhere, nor are they included in profile descriptions. They exist to specify that some sort of mechanism must be provided to permit these people to interact with the computer actor. Other details of how that user interface is provided are not specified by this standard. For an example, see the definition of the Configure DHCP transaction.
Conformance is further managed by means of Profiles. A Profile is defined in terms of what transactions are required for an actor and what transactions are optional. An implementation of a specific actor is documented by specifying what optional transactions and transaction components have been implemented. An implementation that omits any required transactions or components cannot claim to be an implementation of that Actor.
For example, in the Network Address Management Profile the DHCP Server is required to perform the three Transactions to configure the DHCP server, find and use DHCP servers, and maintain the DHCP leases. It may also support the transaction to update the DNS server by means of DDNS coordination.
A Profile includes definitions for more than one Actor. It specifies the transactions for all of the actors that cooperate to perform a function. For example, the Network Address Management Profile covers the DHCP Server actor, the DHCP client Actor, and the DNS Server actor. There must be at least one DHCP Server and one DHCP Client for the system to be useful. The DNS Server itself is optional because the DHCP Server need not implement the DDNS Coordination transaction. If the DNS Server is part of the system, the DDNS coordination is required and the DHCP Server will be expected to participate in the DDNS Coordination transaction.
There may be a DNS server present on the same network as a DHCP Server, but if it is not providing the DNS Server actor from this profile it is not part of the DICOM Configuration activities.
The profiles, actors, and transactions are summarized in the following sections. The detailed description of actor and transactions for each specific profile are described in annexes for each profile. The transactions are documented in terms of parameters and terms from their original standards document, e.g., an RFC for Internet protocols. The full details of the transaction are not described in the annex, only particular details that are relevant to the DICOM application of that transaction. The complete details for these external protocols are documented in the relevant standards documents for the external protocols. Compliance with the requirements of a particular profile shall include compliance with these external protocol documents.
DHCP Server
The DHCP Server is a computer/software feature that is provided with a network configuration description, and that provides startup configuration services in accordance with the DHCP protocol.
DHCP Client
The DHCP Client is a software feature that is used to obtain TCP/IP parameters during the startup of a computer. It continues operation to maintain validity of these parameters.
DNS Server
The DNS server is a computer/software feature that provides IP related information in response to queries from clients utilizing the DNS protocol. It is a part of a federated database facility that maintains the current database relating machine names to IP address information. The DNS server may also be isolated from the worldwide federated database and provide only local DNS services.
DNS Client
The DNS client as a computer/software feature that utilizes the DNS protocols to obtain IP information when given hostnames. The hostnames may be in configuration files or other files instead of explicit IP addresses. The hostnames are converted into IP addresses dynamically when necessary. The DNS client uses a DNS server to provide the necessary information.
NTP Server
The NTP server is a computer/software feature that provides time services in accordance with the NTP or SNTP protocol.
NTP Client
The NTP client is software that obtains time information from an NTP server and maintains the client time in synchronization with the time signals from the NTP server.
SNTP Client
The SNTP client is software that obtains time information from an NTP server and maintains the client time in approximate synchronization with time signals from the NTP server. The SNTP client synchronization is not maintained with the accuracy or precision that NTP provides.
LDAP Server
The LDAP server is a computer/ software feature that maintains an internal database of various directory information. Some of this directory information corresponds to DICOM Configuration schema. The LDAP server provides network access to read and update the directory information. The LDAP server provides a mechanism for external loading, unloading, and backup of directory information. The LDAP server may be part of a federated network of servers that provides a coordinated view of a federated directory database in accordance with the rules of the LDAP protocols.
LDAP Client
The LDAP client utilizes the LDAP protocol to make queries to an LDAP server. The LDAP server maintains a database and responds to these queries based on the contents of this database.
The following transactions are used to provide communications between actors in accordance with one or more of the DICOM Configuration protocols.
Configure DHCP Server
This transaction changes the configuration on a DHCP server to reflect additions, deletions, and changes to the IP parameters that have been established for this network.
Find and Use DHCP Server
This transaction is a sequence of network messages that comply with the rules of the DHCP protocol. It allows a DHCP client to find available DHCP servers and select the server appropriate for that client. This transaction obtains the mandatory IP parameter information from the DHCP server and obtains additional optional parameters from the DHCP server.
Configure Client
The service staff uses this transaction to set the initial configuration for a client.
Maintain Lease
This transaction deals with how the DHCP client should behave when its IP lease is not renewed.
DDNS Coordination
This transaction documents whether the DHCP server is coordinating with a DNS server so that access to the DHCP client can be maintained using the hostname assigned to the DHCP client.
Resolve Hostname
This transaction obtains the IP address for a computer when given a hostname.
Maintain Time
These transactions are the activities needed for an NTP or SNTP client to maintain time synchronization with a master time service.
Find NTP Server
This transaction is the autodiscovery procedure defined for NTP. This may use either a broadcast method or a DHCP supported method.
Find LDAP Server
In this transaction the DNS server is queried to obtain the IP address, port, and name of the LDAP server.
Query LDAP Server
In this transaction the LDAP server is queried regarding contents of the LDAP database.
Client Update LDAP Server
This transaction updates the configuration database using LDAP update instructions from the client being configured.
Maintain LDAP Server
This transaction updates the configuration database using local services of the LDAP server.
Figure 7-1 shows the actors and their transactions. The usual device will have an NTP Client, DHCP Client, and LDAP client in addition to the other applications actors. The transactions "Configure DHCP Server", "Configure Client", and "Maintain LDAP Server" are not shown because these transactions are between a software actor and a human actor. DICOM does not specify the means or user interface. It only requires that certain capabilities be supported.
The Online Electronic Storage Secure Use Profile allows Application Entities to track and verify the status of SOP Instances in those cases where local security policies require tracking of the original data set and subsequent copies.
The Conformance Statement shall indicate in what manner the system restricts remote access.
An implementation that conforms to the Online Electronic Storage Secure Use Profile shall conform to the following rules regarding the use of the SOP Instance Status (0100,0410) Attribute with SOP Instances that are transferred using the Storage Service Class:
An Application Entity that supports the Online Electronic Storage Secure Use Profile and that creates a SOP Instance intended for diagnostic use in Online Electronic Storage shall:
Set the SOP Instance Status to Original (OR).
Include the following Attributes:
the SOP Class UID (0008,0016) and SOP Instance UID (0008,0018)
the Instance Creation Date (0008,0012) and Instance Creation Time (0008,0013), if known
the SOP Instance Status
the SOP Authorization Date and Time (0100,0420)
the SOP Authorization Comment, if any (0100,0424)
the SOP Equipment Certification Number (0100,0426)
the Study Instance UID (0020,000D) and Series Instance UID (0020,000E)
any Attributes of the General Equipment Module that are known
any overlay data present
any image data present
The Application Entity that holds a SOP Instance where the SOP Instance Status is Original (OR) may change the SOP Instance Status to Authorized Original(AO) as long as the following rules are followed:
The Application Entity shall determine that an authorized entity has certified the SOP Instance as useable for diagnostic purposes.
The Application Entity shall change the SOP Instance Status to Authorized Original (AO). The SOP Instance UID shall not change.
The Application Entity shall set the SOP Authorization Date and Time (0100,0420) and Authorization Equipment Certification Number (0100,0426) Attributes to appropriate values. It may also add an appropriate SOP Authorization Comment (0100,0424) Attribute.
There shall only be one Application Entity that holds a SOP Instance where the SOP Instance Status is Original (OR) or Authorized Original (AO). The Application Entity that holds such a SOP instance shall not delete it.
When communicating with an Application Entity that supports Online Electronic Storage the Application Entity that holds a SOP Instance where the SOP Instance Status is Original(OR) or Authorized Original(AO) may transfer that SOP Instance to another Application Entity that also conforms to the Online Electronic Storage Secure Use Profile as long as the following rules are followed:
The transfer shall occur on a Secure Transport Connection.
The two Application Entities involved in the transfer shall authenticate each other and shall confirm via the authentication that the other supports the Online Electronic Storage Secure Use Profile.
The receiving Application Entity shall reject the storage request and discard the received SOP Instance if the data integrity checks done after the transfer indicate that the SOP Instance was altered during transmission.
The transfer shall be confirmed using the push model of the Storage Commitment Service Class. Until it has completed this confirmation, the receiving Application Entity shall not forward the SOP Instance or Authorized Copies of the SOP instance to any other Application Entity.
Once confirmed that the receiving Application Entity has successfully committed the SOP Instance to storage, the sending Application Entity shall do one of the following to its local copy of the SOP Instance:
delete the SOP Instance,
change the SOP Instance Status to Not Specified (NS),
if the SOP Instance Status was Authorized Original (AO), change the SOP Instance Status to Authorized Copy (AC).
When communicating with an Application Entity that supports Online Electronic Storage an Application Entity that holds a SOP Instance whose SOP Instance Status is Authorized Original (AO) or Authorized Copy (AC) may send an Authorized Copy of the SOP Instance to another Application Entity as long as the following rules are followed:
The transfer shall occur on a Secure Transport Connection.
The two Application Entities involved in the transfer shall authenticate each other, and shall confirm via the authentication that the other supports the Online Electronic Storage Secure Use Profile.
The sending Application Entity shall set the SOP Instance Status to either Not Specified (NS) or Authorized Copy (AC) in the copy sent. The SOP Instance UID shall not change.
The receiving Application Entity shall reject the storage request and discard the copy if data integrity checks done after the transfer indicate that the SOP Instance was altered during transmission.
If communicating with a system that does not support the Online Electronic Storage Secure Use Profile, or if communication is not done over a Secure Transport Connection, then
A sending Application Entity that conforms to this Security Profile shall either set the SOP Instance Status to Not Specified (NS), or leave out the SOP Instance Status and associated parameters of any SOP Instances that the sending Application Entity sends out over the unsecured Transport Connection or to systems that do not support the Online Electronic Storage Secure Use Profile.
A receiving Application Entity that conforms to this Security Profile shall set the SOP Instance Status to Not Specified (NS) of any SOP Instance received over the unsecured Transport Connection or from systems that do not support the Online Electronic Storage Secure Use Profile.
The receiving Application Entity shall store SOP Instances in accordance with Level 2 as defined in the Storage Service Class (i.e., all Attributes, including Private Attributes), as required by the Storage Commitment Storage Service Class, and shall not coerce any Attribute other than SOP Instance Status, SOP Authorization Date and Time, Authorization Equipment Certification Number, and SOP Authorization Comment.
Other than changes to the SOP Instance Status, SOP Authorization Date and Time, Authorization Equipment Certification Number, and SOP Authorization Comment Attributes, as outlined above, or changes to group length Attributes to accommodate the aforementioned changes, the Application Entity shall not change any Attribute values.
An implementation that validates and generates Digital Signatures may claim conformance to the Basic Digital Signatures Secure Use Profile. Any implementation that claims conformance to this Security Profile shall obey the following rules in handling Digital Signatures:
The implementation shall store any SOP Instances that it receives in such a way that it guards against any unauthorized tampering of the SOP Instance.
Wherever possible, the implementation shall validate the Digital Signatures within any SOP Instance that it receives.
If the implementation sends the SOP Instance to another Application Entity, it shall do the following:
remove any Digital Signatures that may have become invalid due to any allowed variations to the format of Attribute Values (e.g., trimming of padding, alternate representations of numbers),
generate one or more new Digital Signatures covering the Data Elements that the implementation was able to verify when the SOP Instance was received.
An implementation that stores and forwards SOP Instances may claim conformance to the Bit-Preserving Digital Signatures Secure Use Profile. Any implementation that claims conformance to this Security Profile shall obey the following rules in handling Digital Signatures:
The implementation shall store any SOP Instances that it receives in such a way that when the SOP instance is forwarded to another Application Entity, the Value fields of all Attributes are bit-for-bit duplicates of the fields originally received.
The implementation shall not change the order of Items in a Sequence.
The implementation shall not remove or change any Data Element of any SOP Instance that it receives when sending that SOP Instance on to another Application Entity via DICOM. This includes any Digital Signatures received.
Implementations may add new Data Elements that do not alter any existing Digital Signatures.
The implementation shall utilize an explicit VR Transfer Syntax.
Implementations that cannot use an explicit VR Transfer Syntax cannot conform to this Secure Use Profile, since it may not be able to verify Digital Signatures that are received with an implicit VR Transfer Syntax.
The implementation shall not change the VR of any Data Element that it receives when it transmits that object to another Application Entity.
Any implementation that claims conformance to this Security Profile shall obey the following rules when creating a Structured Report or Key Object Selection Document that includes Digital Signatures:
When the implementation signs a Structured Report or Key Object Selection Document SOP Instance the Digital Signatures shall be created in accordance with the Structured Report RSA Digital Signature Profile.
In every signed Structured Report or Key Object Selection Document SOP Instance created, all referenced SOP Instances listed in the Referenced SOP Sequence Items of the Current Requested Procedure Evidence Sequence (0040,A375) and Pertinent Other Evidence Sequence (0040,A385)shall include either a Referenced Digital Signature Sequence or a Referenced SOP Instance MAC Sequence. The references may include both.
The implementation claiming conformance shall outline in its conformance statement the conditions under which it will either sign or not sign a Structured Report or Key Object Selection Document.
To help assure healthcare privacy and security in automated systems, usage data need to be collected. These data will be reviewed by administrative staff to verify that healthcare data is being used in accordance with the healthcare provider's data security requirements and to establish accountability for data use. This data collection and review process is called security auditing and the data itself comprises the audit trail. Audit trails can be used for surveillance purposes to detect when interesting events might be happening that warrant further investigation.
This profile defines the format of the data to be collected and the minimum set of attributes to be captured by healthcare application systems for subsequent use by a review application. The data includes records of who accessed healthcare data, when, for what action, from where, and which patients' records were involved. No behavioral requirements are specified for when audit messages are generated, or for what action should be taken on their receipt. These are subject to local policy decisions and legal requirements.
Any implementation that claims conformance to this Security Profile shall:
format audit trail messages in accordance with the XML schema specified in A.5.1 in a fashion that allows those messages to be validated against that XML schema, following the general conventions specified in Section A.5.2.
for the events described in this Profile comply with the restrictions specified by this Profile in Section A.5.3, and describe in its conformance statement any extensions.
An implementation may include implementation-specific extensions as long as the above conditions are met.
describe in its conformance statement the events that it can detect and report,
describe in its conformance statement the processing it can perform upon receipt of a message
describe in its conformance statement how event reporting and processing can be configured
Other profiles specify the transmission of audit messages.
Implementations claiming conformance to this profile shall use the following XML schema to format audit trail messages. This schema is derived from the schema specified in RFC 3881 IETF draft internet standard "Security Audit and Access Accountability XML Message Data Definitions for Healthcare Applications", according to W3C Recommendation "XML Schema Part 1: Structures," version 1.0, May 2001, and incorporates the DICOM extensions and restrictions outlined in Section A.5.2.
This schema is provided in Relax NG Compact format.
This schema can be converted into an equivalent XML schema or other electronic format. It includes some modifications to the RFC 3881 schema that reflect field experience with audit message requirements. It extends the RFC 3881 schema.
datatypes xsd = "http://www.w3.org/2001/XMLSchema-datatypes" # This defines the coded value type. The comment shows a pattern that can be used to further # constrain the token to limit it to the format of an OID. Not all schema software # implementations support the pattern option for tokens. other-csd-attributes = (attribute codeSystemName { token } | # OID pattern="[0-2]((\.0)|(\.[1-9][0-9]*))*" attribute codeSystemName { token }), # This makes clear that codeSystemName is # either an OID or String attribute displayName { token }?, attribute originalText { token } # Note: this also corresponds to DICOM "Code Meaning" CodedValueType = attribute csd-code { token }, other-csd-attributes # Define the event identification, used later EventIdentificationContents = element EventID { CodedValueType }, element EventTypeCode { CodedValueType }*, # Note: DICOM/IHE defines and uses this # differently than RFC-3881 attribute EventActionCode { # Optional action code "C" | ## Create "R" | ## Read "U" | ## Update "D" | ## Delete "E" ## Execute }?, attribute EventDateTime { xsd:dateTime }, attribute EventOutcomeIndicator { "0" | ## Nominal Success (use if status otherwise unknown or ambiguous) "4" | ## Minor failure (per reporting application definition) "8" | ## Serious failure (per reporting application definition) "12" ## Major failure, (reporting application now unavailable) }, element EventOutcomeDescription { text }? # Define AuditSourceIdentification, used later # Note: This includes one constraint that cannot be represented yet in RNC. The use # of a token other than the specified codes is permitted only if the codeSystemName # is present. # Note: This has no elements, only attributes. AuditSourceIdentificationContents = attribute code { "1" | ## End-user display device, diagnostic device "2" | ## Data acquisition device or instrument "3" | ## Web Server process or thread "4" | ## Application Server process or thread "5" | ## Database Server process or thread "6" | ## Security server, e.g., a domain controller "7" | ## ISO level 1-3 network component "8" | ## ISO level 4-6 operating software "9" | ## other token }, ## other values are allowed if a codeSystemName is present other-csd-attributes?, ## If these are present, they define the meaning of code attribute AuditEnterpriseSiteID { token }?, attribute AuditSourceID { token }, element AuditSourceTypeCode { token }* # Define ActiveParticipantType, used later ActiveParticipantContents = element RoleIDCode { CodedValueType }*, element MediaIdentifier { element MediaType { CodedValueType } }?, attribute UserID { text }, attribute AlternativeUserID { text }?, attribute UserName { text }?, attribute UserIsRequestor { xsd:boolean }, attribute NetworkAccessPointID { token }?, attribute NetworkAccessPointTypeCode { "1" | ## Machine Name, including DNS name "2" | ## IP Address "3" | ## Telephone Number "4" | ## Email address "5" }? ## URI (user directory, HTTP-PUT, ftp, etc.) # The BinaryValuePair is used in ParticipantObject descriptions to capture parameters. # All values (even those that are normally plain text) are encoded as xsd:base64Binary. # This is to preserve details of encoding (e.g., nulls) and to protect against text # contents that contain XML fragments. These are known attack points against applications, # so security logs can be expected to need to capture them without modification by the # audit encoding process. ValuePair = # clarify the name attribute type { token }, attribute value { xsd:base64Binary } # used to encode potentially binary, malformed XML text, etc. # Define ParticipantObjectIdentification, used later # Participant Object Description, used later DICOMObjectDescriptionContents = element MPPS { attribute UID { token } # OID pattern="[0-2]((\.0)|(\.[1-9][0-9]*))*" }*, element Accession { attribute Number { token } }*, element SOPClass { # SOP class for one study element Instance { attribute UID { token } # OID pattern="[0-2]((\.0)|(\.[1-9][0-9]*))*" }*, attribute UID { token }?, # OID pattern="[0-2]((\.0)|(\.[1-9][0-9]*))*" attribute NumberOfInstances { xsd:integer } }, element ParticipantObjectContainsStudy { element StudyIDs { attribute UID { token } }* }, element Encrypted { xsd:boolean }?, element Anonymized { xsd:boolean }? ParticipantObjectIdentificationContents = element ParticipantObjectIDTypeCode { CodedValueType }, (element ParticipantObjectName { token } | # either a name or element ParticipantObjectQuery { xsd:base64Binary }), # a query ID field, element ParticipantObjectDetail { ValuePair }*, # optional details, these can be extensive # and large element ParticipantObjectDescription { token }*, # optional descriptive text DICOMObjectDescriptionContents, # These are extensions made by DICOM to RFC- # 3881 schema for use describing DICOM objects attribute ParticipantObjectID { token }, # mandatory ID attribute ParticipantObjectTypeCode { # optional type "1" | #3 Person "2" | #3 System object "3" | #3 Organization "4" ## Other }?, attribute ParticipantObjectTypeCodeRole { ## optional role "1" | ## Patient "2" | ## Location "3" | ## Report "4" | ## Resource "5" | ## Master File "6" | ## User "7" | ## List "8" | ## Doctor "9" | ## Subscriber "10" | ## guarantor "11" | ## Security User Entity "12" | ## Security User Group "13" | ## Security Resource "14" | ## Security Granulatiry Definition "15" | ## Provider "16" | ## Report Destination "17" | ## Report Library "18" | ## Schedule "19" | ## Customer "20" | ## Job "21" | ## Job Stream "22" | ## Table "23" | ## Routing Criteria "24" }?, ## Query?, attribute ParticipantObjectDataLifeCycle { # optional life cycle stage "1" | ## Origination, Creation "2" | ## Import/ Copy "3" | ## Amendment "4" | ## Verification "5" | ## Translation "6" | ## Access/Use "7" | ## De-identification "8" | ## Aggregation, summarization, derivation "9" | ## Report "10" | ## Export "11" | ## Disclosure "12" | ## Receipt of Disclosure "13" | ## Archiving "14" | ## Logical deletion "15" }?, ## Permanent erasure, physical destruction attribute ParticipantObjectSensistity { token }? # The basic message message = element AuditMessage { (element EventIdentification { EventIdentificationContents }, # The event must be identified element ActiveParticipant { ActiveParticipantContents }+, # It has one or more active # participants element AuditSourceIdentification { # It is reported by one source AuditSourceIdentificationContents }, element ParticipantObjectIdentification { # It may have other objects involved ParticipantObjectIdentificationContents }*) } # And finally the magic statement that message is the root of everything. start = message
The following table lists the primary fields from the message schema specified in A.5.1, with additional instructions, conventions, and restrictions on how DICOM applications shall fill in the field values. Please refer to RFC 3881 for the complete definition and specification of fields taken from the schema specified therein. In addition, the following table lists the additional fields that are part of DICOM-specific extensions in the DICOM Audit Message Schema (see Section A.5.1). The fields names are only those leaf elements and attributes that are specialized or extended for this profile. Note that these fields may be enclosed in other XML elements, as specified by the schema.
Table A.5.2-1. General Message Format
Field Name |
Opt. |
Description from RFC 3881 |
Additional Conditions on Field Format/Value |
|
---|---|---|---|---|
Event |
EventID |
M |
"Identifier for a specific audited event …" |
The identifier for the family of event. E.g., "User Authentication". Extended by DICOM using DCID (400) |
EventActionCode |
U |
"Indicator for type of action performed during the event that generated the audit." |
See Schema |
|
EventDateTime |
M |
"Universal coordinated time (UTC), i.e., a date/time specification that is unambiguous as to local time zones." |
The time at which the audited event occurred.See Section A.5.2.5 |
|
EventOutcomeIndicator |
M |
"Indicates whether the event succeeded or failed." |
When a particular event has some aspects that succeeded and some that failed, then one message shall be generated for successful actions and one message for the failed actions (i.e., not a single message with mixed results). |
|
EventTypeCode |
U |
"Identifier for the category of event." |
The specific type(s) within the family applicable to the event, e.g., "User Login". Extended by DICOM using DCID (401) |
|
Active Participant (multi-valued) |
UserID |
M |
"Unique identifier for the user actively participating in the event." |
See Section A.5.2.1 |
AlternativeUserID |
U |
"Alternative unique identifier for the user." |
See Section A.5.2.2 |
|
UserName |
U |
"The human-meaningful name for the user." |
See Section A.5.2.3 |
|
UserIsRequestor |
M |
"Indicator that the user is or is not the requestor, or initiator, for the event being audited." |
Used to identify which of the participants initiated the transaction being audited. If the audit source cannot determine which of the participants is the requestor, then the field shall be present with the value FALSE in all participants. The system shall not identify multiple participants as UserIsRequestor. If there are several known requestors, the reporting system shall pick only one as UserIsRequestor. |
|
RoleIDCode |
U |
"Specification of the role(s) the user plays when performing the event, as assigned in role-based access control security." |
Extended by DICOM using DCID (402) Usage of this field is refined in the individual message descriptions below. Other additional roles may also be present, since this is a multi-valued field. |
|
NetworkAccessPointTypeCode |
U |
"An identifier for the type of network access point …" |
See Section A.5.2.4 |
|
NetworkAccessPointID |
U |
"An identifier for the network access point of the user device This could be a device id, IP address, or some other identifier associated with a device." |
||
Audit Source |
AuditEnterpriseSiteID |
U |
"Logical source location within the healthcare enterprise network, e.g., a hospital or other provider location within a multi-entity provider group." |
Serves to further qualify the Audit Source ID, since Audit Source ID is not required to be globally unique. |
AuditSourceID |
M |
"Identifier of the source …" |
The identification of the system that detected the auditable event and created this audit message. Although often the audit source is one of the participants, it could also be an external system that is monitoring the activities of the participants (e.g., an add-on audit-generating device). |
|
AuditSourceTypeCode |
U |
"Code specifying the type of source …" |
Used as defined in RFC 3881. E.g., an acquisition device might use "2" (data acquisition device), a PACS/RIS system might use "4 "(application server process). |
|
Participant Object (multi-valued) |
ParticipantObjectTypeCode |
U |
"Code for the participant object type being audited. This value is distinct from the user's role or any user relationship to the participant object." |
Used as defined in RFC 3881 |
ParticipantObjectTypeCodeRole |
U |
"Code representing the functional application role of Participant Object being audited." |
Used as defined in RFC 3881 |
|
ParticipantObjectDataLifeCycle |
U |
"Identifier for the data life-cycle stage for the participant object. This can be used to provide an audit trail for data, over time, as it passes through the system." |
Used as defined in RFC 3881. |
|
ParticipantObjectIDTypeCode |
M |
"Describes the identifier that is contained in Participant Object ID." |
Values may be drawn from those listed in RFC 3881 and DCID (404), as specified in the individual message descriptions. |
|
ParticipantObjectSensitivity |
U |
"Denotes policy-defined sensitivity for the Participant Object ID such as VIP, HIV status, mental health status, or similar topics." |
Used as defined in RFC 3881. |
|
ParticipantObjectID |
M |
"Identifies a specific instance of the participant object." |
Usage refined by individual message descriptions |
|
ParticipantObjectName |
U |
"An instance-specific descriptor of the Participant Object ID audited, such as a person's name." |
Usage refined by individual message descriptions |
|
ParticipantObjectQuery |
U |
"The actual query for a query-type participant object." |
Usage refined by individual message descriptions |
|
ParticipantObjectDetail |
U |
"Implementation-defined data about specific details of the object accessed or used." |
Used as defined in RFC 3881. NoteThe value field is xs:base64Binary encoded, making this attribute suitable for conveying binary data. |
|
SOPClass |
MC |
(DICOM extension) |
The UIDs of SOP classes referred to in this participant object. Required if ParticipantObjectIDTypeCode is (110180, DCM, "Study Instance UID") and any of the optional fields (AccessionNumber, ContainsMPPS, NumberOfInstances, ContainsSOPInstances,Encrypted,Anonymized) are present in this Participant Object. May be present if ParticipantObjectIDTypeCode is (110180, DCM, "Study Instance UID") even though none of the optional fields are present. |
|
Accession |
U |
(DICOM extension) |
An Accession Number(s) associated with this participant object. |
|
MPPS |
U |
(DICOM extension) |
An MPPS Instance UID(s) associated with this participant object. |
|
NumberOfInstances |
U |
(DICOM extension) |
The number of SOP Instances referred to by this participant object. |
|
Instance |
U |
(DICOM extension) |
SOP Instance UID value(s) NoteIncluding the list of SOP Instances can create a fairly large audit message. Under most circumstances, the list of SOP Instance UIDs is not needed for audit purposes. |
|
Encrypted |
U |
(DICOM extension) |
A single value of True or False indicating whether or not the data was encrypted. NoteIf there was a mix of encrypted and non-encrypted data, then create two event reports. |
|
Anonymized |
U |
(DICOM extension) |
A single value of True or False indicating whether or not all patient identifying information was removed from the data |
|
ParticipantObjectContainsStudy |
U |
(DICOM extension) |
A Study Instance UID, which may be used when the ParticipantObjectIDTypeCode is not (110180, DCM, "Study Instance UID"). |
If the participant is a person, then the User ID shall be the identifier used for that person on this particular system, in the form of loginName@domain-name.
If the participant is an identifiable process, the UserID selected shall be one of the identifiers used in the internal system logs. For example, the User ID may be the process ID as used within the local operating system in the local system logs. If the participant is a node, then User ID may be the node name assigned by the system administrator. Other participants such as threads, relocatable processes, web service end-points, web server dispatchable threads, etc. will have an appropriate identifier. The implementation shall document in the conformance statement the identifiers used, see Section A.6. The purpose of this requirement is to allow matching of the audit log identifiers with internal system logs on the reporting systems. .
When importing or exporting data, e.g., by means of media, the UserID field is used both to identify people and to identify the media itself. When the Role ID Code is EV(110154, DCM, "Destination Media") or EV(110155, DCM, "Source Media"), the UserID may be:
a URI (the preferred form) identifying the source or destination,
an email address of the form "mailto:user@address"
a description of the media type (e.g., DVD) together with a description of its identifying label, as a free text field,
a description of the media type (e.g., paper, film) together with a description of the location of the media creator (i.e., the printer).
The UserID field for Media needs to be highly flexible given the large variety of media and transports that might be used.
If the participant is a person, then Alternative User ID shall be the identifier used for that person within an enterprise for authentication purposes, for example, a Kerberos Username (user@realm). If the participant is a DICOM application, then Alternative User ID shall be one or more of the AE Titles that participated in the event. Multiple AE titles shall be encoded as:
AETITLES= aetitle1;aetitle2;…
When importing or exporting data, e.g., by means of media, the Alternative UserID field is used either to identify people or to identify the media itself. When the Role ID Code is (110154, DCM, "Destination Media") or (110155, DCM, "Source Media"), the Alternative UserID may be any machine readable identifications on the media, such as media serial number, volume label, or DICOMDIR SOP Instance UID.
A human readable identification of the participant. If the participant is a person, the person's name shall be used. If the participant is a process, then the process name shall be used.
The NetworkAccessPointTypeCode and NetworkAccessPointID can be ambiguous for systems that have multiple physical network connections. For these multi-homed nodes a single DNS name or IP address shall be selected and used when reporting audit events. DICOM does not require the use of a specific method for selecting the network connection to be used for identification, but it must be the same for all of the audit messages generated for events on that node.
The EventDateTime is the date and time that the event being reported took place. Some events have a significant duration. In these cases, a date and time shall be chosen by a method that is consistent and appropriate for the event being reported.
The EventDateTime shall include the time zone information.
Creators of audit messages may support leap-seconds, but are not required to. Recipients of audit messages shall be able to process messages with leap-second information.
The following subsections define message specializations for use by implementations that claim conformance to the DICOM Audit Trail Profile. Any field (i.e., XML element and associated attributes) not specifically mentioned in the following tables shall follow the conventions specified in A.5.1 and A.5.2.
An implementation claiming conformance to this Profile that reports an activity covered by one of the audit messages defined by this Profile shall use the message format defined in this Profile. However, a system claiming conformance to this Profile is not required to send a message each time the activity reported by that audit message occurs. It is expected that the triggering of audit messages would be configurable on an individual basis, to be able to balance network load versus the severity of threats, in accordance with local security policies.
It is a system design issue outside the scope of DICOM as to what entity actually sends an audit event and when. For example, a Query message could be generated by the entity where the query originated, by the entity that eventually would respond to the query, or by a monitoring entity not directly involved with the query, but that generates audit messages based on monitored network traffic.
To report events that are similar to the events described here, these definitions can be used as the basis for extending the schema.
In the subsequent tables, the information entity column indicates the relationship between real world entities and the information elements encoded into the message.
This audit message describes the event of an Application Entity starting or stopping. This is closely related to the more general case of any kind of application startup or shutdown, and may be suitable for those purposes also.
Table A.5.3.1-1. Application Activity Message
Real World Entities |
Field Name |
Opt. |
Value Constraints |
---|---|---|---|
Event |
EventID |
M |
EV (110100, DCM,"Application Activity") |
EventActionCode |
M |
Enumerated Value E = Execute |
|
EventDateTime |
M |
not specialized |
|
EventOutcomeIndicator |
M |
not specialized |
|
EventTypeCode |
M |
DT (110120, DCM, "Application Start") DT (110121, DCM, "Application Stop") |
|
Active Participant: Application started (1) |
UserID |
M |
The identity of the process started or stopped formatted as specified in A.5.2.1. |
AlternativeUserID |
MC |
If the process supports DICOM, then the AE Titles as specified in A.5.2.2. |
|
UserName |
U |
not specialized |
|
UserIsRequestor |
M |
not specialized |
|
RoleIDCode |
M |
EV (110150, DCM, "Application") |
|
NetworkAccessPointTypeCode |
U |
not specialized |
|
NetworkAccessPointID |
U |
not specialized |
|
Active Participant: Persons and or processes that started the Application (0..N) |
UserID |
M |
The person or process starting or stopping the Application |
AlternativeUserID |
U |
not specialized |
|
UserName |
U |
not specialized |
|
UserIsRequestor |
M |
not specialized |
|
RoleIDCode |
M |
EV (110151, DCM, "Application Launcher") |
|
NetworkAccessPointTypeCode |
U |
not specialized |
|
NetworkAccessPointID |
U |
not specialized |
No Participant Objects are needed for this message.
This message describes the event of a person or process reading a log of audit trail information.
For example, an implementation that maintains a local cache of audit information that has not been transferred to a central collection point might generate this message if its local cache were accessed by a user.
Table A.5.3.2-1. Audit Log Used Message
Real World Entities |
Field Name |
Opt. |
Value Constraints |
---|---|---|---|
Event |
EventID |
M |
EV (110101, DCM, "Audit Log Used") |
EventActionCode |
M |
Shall be enumerated value: R = read |
|
EventDateTime |
M |
not specialized |
|
EventOutcomeIndicator |
M |
not specialized |
|
EventTypeCode |
U |
not specialized |
|
Active Participant: Persons and or processes that started the Application (1..2) |
UserID |
M |
The person or process accessing the audit trail. If both are known, then two active participants shall be included (both the person and the process). |
AlternativeUserID |
U |
not specialized |
|
UserName |
U |
not specialized |
|
UserIsRequestor |
M |
not specialized |
|
RoleIDCode |
U |
not specialized |
|
NetworkAccessPointTypeCode |
U |
not specialized |
|
NetworkAccessPointID |
U |
not specialized |
|
Participating Object: Identity of the audit log (1) |
ParticipantObjectTypeCode |
M |
Shall be: 2 = system |
ParticipantObjectTypeCodeRole |
M |
Shall be: 13 = security resource |
|
ParticipantObjectDataLifeCycle |
U |
not specialized |
|
ParticipantObjectIDTypeCode |
M |
Shall be: 12 = URI |
|
ParticipantObjectSensitivity |
U |
not specialized |
|
ParticipantObjectID |
M |
The URI of the audit log |
|
ParticipantObjectName |
U |
Shall be: "Security Audit Log" |
|
ParticipantObjectQuery |
U |
not specialized |
|
ParticipantObjectDetail |
U |
not specialized |
|
ParticipantObjectDescription |
U |
not specialized |
|
SOPClass |
U |
See Section A.5.2 |
|
Accession |
U |
See Section A.5.2 |
|
NumberOfInstances |
U |
See Section A.5.2 |
|
Instances |
U |
See Section A.5.2 |
|
Encrypted |
U |
See Section A.5.2 |
|
Anonymized |
U |
See Section A.5.2 |
|
ParticipantObjectContainsStudy |
U |
See Section A.5.2 |
This message describes the event of a system beginning to transfer a set of DICOM instances from one node to another node within control of the system's security domain. This message may only include information about a single patient.
A separate Instances Transferred message is defined for transfer completion, allowing comparison of what was intended to be sent and what was actually sent.
Table A.5.3.3-1. Audit Message for Begin Transferring DICOM Instances
Real World Entities |
Field Name |
Opt. |
Value Constraints |
---|---|---|---|
Event |
EventID |
M |
EV (110102, DCM, "Begin Transferring DICOM Instances") |
EventActionCode |
M |
Shall be: E = Execute |
|
EventDateTime |
M |
not specialized |
|
EventOutcomeIndicator |
M |
not specialized |
|
EventTypeCode |
U |
not specialized |
|
Active Participant: Process Sending the Data (1) |
UserID |
M |
The identity of the process sending the data. |
AlternativeUserID |
U |
not specialized |
|
UserName |
U |
not specialized |
|
UserIsRequestor |
M |
not specialized |
|
RoleIDCode |
M |
EV (110153, DCM, "Source Role ID") |
|
NetworkAccessPointTypeCode |
U |
not specialized |
|
NetworkAccessPointID |
U |
not specialized |
|
Active Participant: Process receiving the data (1) |
UserID |
M |
The identity of the process receiving the data. |
AlternativeUserID |
U |
not specialized |
|
UserName |
U |
not specialized |
|
UserIsRequestor |
M |
not specialized |
|
RoleIDCode |
M |
EV (110152, DCM, "Destination Role ID") |
|
NetworkAccessPointTypeCode |
U |
not specialized |
|
NetworkAccessPointID |
U |
not specialized |
|
Active Participant: Other Participants (0..N) |
UserID |
M |
The identity of any other participants that might be involved and known, especially third parties that are the requestor |
AlternativeUserID |
U |
not specialized |
|
UserName |
U |
not specialized |
|
UserIsRequestor |
M |
not specialized |
|
RoleIDCode |
U |
not specialized |
|
NetworkAccessPointTypeCode |
U |
not specialized |
|
NetworkAccessPointID |
U |
not specialized |
|
Participating Object: Studies being transferred (1..N) |
ParticipantObjectTypeCode |
M |
Shall be: 2 = system |
ParticipantObjectTypeCodeRole |
M |
Shall be: 3 = report |
|
ParticipantObjectDataLifeCycle |
U |
not specialized |
|
ParticipantObjectIDTypeCode |
M |
EV (110180, DCM, "Study Instance UID") |
|
ParticipantObjectSensitivity |
U |
not specialized |
|
ParticipantObjectID |
M |
The Study Instance UID |
|
ParticipantObjectName |
U |
not specialized |
|
ParticipantObjectQuery |
U |
not specialized |
|
ParticipantObjectDetail |
U |
Element "ContainsSOPClass" with one or more SOP Class UID values |
|
ParticipantObjectDescription |
U |
not specialized |
|
SOPClass |
MC |
not specialized |
|
Accession |
U |
not specialized |
|
NumberOfInstances |
U |
not specialized |
|
Instances |
U |
not specialized |
|
Encrypted |
U |
not specialized |
|
Anonymized |
U |
not specialized |
|
Participating Object: Patient (1) |
ParticipantObjectTypeCode |
M |
Shall be: 1 = person |
ParticipantObjectTypeCodeRole |
M |
Shall be: 1 = patient |
|
ParticipantObjectDataLifeCycle |
U |
not specialized |
|
ParticipantObjectIDTypeCode |
M |
Shall be: 2 = patient ID |
|
ParticipantObjectSensitivity |
U |
not specialized |
|
ParticipantObjectID |
M |
The patient ID |
|
ParticipantObjectName |
U |
The patient name |
|
ParticipantObjectQuery |
U |
not specialized |
|
ParticipantObjectDetail |
U |
not specialized |
|
ParticipantObjectDescription |
U |
not specialized |
This message describes the event of exporting data from a system, meaning that the data is leaving control of the system's security domain. Examples of exporting include printing to paper, recording on film, conversion to another format for storage in an EHR, writing to removable media, or sending via e-mail. Multiple patients may be described in one event message.
Table A.5.3.4-1. Audit Message for Data Export
Real World Entities |
Field Name |
Opt. |
Value Constraints |
---|---|---|---|
Event |
EventID |
M |
EV (110106, DCM, "Export") |
EventActionCode |
M |
Shall be: R = Read |
|
EventDateTime |
M |
not specialized |
|
EventOutcomeIndicator |
M |
not specialized |
|
EventTypeCode |
U |
not specialized |
|
Participating Object: Remote Users and Processes (0..n) |
UserID |
M |
The identity of the remote user or process receiving the data |
AlternativeUserID |
U |
not specialized |
|
UserName |
U |
not specialized |
|
UserIsRequestor |
M |
||
RoleIDCode |
M |
EV (110152, DCM, "Destination Role ID") |
|
NetworkAccessPointTypeCode |
U |
not specialized |
|
NetworkAccessPointID |
U |
not specialized |
|
Participating Object: User or Process Exporting the data(1..2) |
UserID |
M |
The identity of the local user or process exporting the data. If both are known, then two active participants shall be included (both the person and the process). |
AlternativeUserID |
U |
not specialized |
|
UserName |
U |
not specialized |
|
UserIsRequestor |
M |
||
RoleIDCode |
M |
EV (110153, DCM, "Source Role ID") |
|
NetworkAccessPointTypeCode |
U |
not specialized |
|
NetworkAccessPointID |
U |
not specialized |
|
Active Participant: Media (1) |
UserID |
M |
See Section A.5.2.3 |
AlternativeUserID |
U |
See Section A.5.2.4 |
|
UserName |
U |
not specialized |
|
UserIsRequestor |
M |
Shall be FALSE |
|
RoleIDCode |
M |
EV (110154, DCM, "Destination Media") |
|
NetworkAccessPointTypeCode |
MC |
Required if being exported to other than physical media, e.g., to a network destination rather than to film, paper or CD. May be present otherwise. |
|
NetworkAccessPointID |
MC |
Required if Net Access Point Type Code is present. May be present otherwise. |
|
MediaIdentifier |
MC |
Volume ID, URI, or other identifier for media. Required if digital media. May be present otherwise. |
|
MediaType |
M |
Values selected from DCID (405) |
|
Participating Object: Studies (0..N) |
ParticipantObjectTypeCode |
M |
Shall be: 2 = system |
ParticipantObjectTypeCodeRole |
M |
Shall be: 3 = report |
|
ParticipantObjectDataLifeCycle |
U |
not specialized |
|
ParticipantObjectIDTypeCode |
M |
EV (110180, DCM, "Study Instance UID") |
|
ParticipantObjectSensitivity |
U |
not specialized |
|
ParticipantObjectID |
M |
The Study Instance UID |
|
ParticipantObjectName |
U |
not specialized |
|
ParticipantObjectQuery |
U |
not specialized |
|
ParticipantObjectDetail |
U |
not specialized |
|
ParticipantObjectDescription |
U |
not specialized |
|
SOPClass |
MC |
See Table A.5.2-1 |
|
Accession |
U |
not specialized |
|
NumberOfInstances |
U |
not specialized |
|
Instances |
U |
not specialized |
|
Encrypted |
U |
not specialized |
|
Anonymized |
U |
not specialized |
|
Participating Object: Patients (1..N) |
ParticipantObjectTypeCode |
M |
Shall be: 1 = person |
ParticipantObjectTypeCodeRole |
M |
Shall be: 1 = patient |
|
ParticipantObjectDataLifeCycle |
U |
not specialized |
|
ParticipantObjectIDTypeCode |
M |
Shall be: 2 = patient ID |
|
ParticipantObjectSensitivity |
U |
not specialized |
|
ParticipantObjectID |
M |
The patient ID |
|
ParticipantObjectName |
U |
The patient name |
|
ParticipantObjectQuery |
U |
not specialized |
|
ParticipantObjectQuery |
U |
not specialized |
|
ParticipantObjectDetail |
U |
not specialized |
|
ParticipantObjectDescription |
U |
not specialized |
This message describes the event of importing data into an organization, implying that the data now entering the system was not under the control of the security domain of this organization. Transfer by media within an organization is often considered a data transfer rather than a data import event. An example of importing is creating new local instances from data on removable media. Multiple patients may be described in one event message.
A single user (either local or remote) shall be identified as the requestor, i.e., UserIsRequestor with a value of TRUE. This accommodates both push and pull transfer models for media.
Table A.5.3.5-1. Audit Message for Data Import
Real World Entities |
Field Name |
Opt. |
Value Constraints |
---|---|---|---|
Event |
EventID |
M |
EV (110107, DCM, "Import") |
EventActionCode |
M |
Shall be: C = Create |
|
EventDateTime |
M |
not specialized |
|
EventOutcomeIndicator |
M |
not specialized |
|
EventTypeCode |
U |
not specialized |
|
Participating Object: User or Process Importing the data (1..n) |
UserID |
M |
The identity of the local user or process importing the data. |
AlternativeUserID |
U |
not specialized |
|
UserName |
U |
not specialized |
|
UserIsRequestor |
M |
See Section A.5.3.5 |
|
RoleIDCode |
M |
EV (110152, DCM, "Destination Role ID") |
|
NetworkAccessPointTypeCode |
U |
not specialized |
|
NetworkAccessPointID |
U |
not specialized |
|
Active Participant: Source Media (1) |
UserID |
M |
See Section A.5.2.3 |
AlternativeUserID |
U |
See Section A.5.2.4 |
|
UserName |
U |
not specialized |
|
UserIsRequestor |
M |
Shall be FALSE |
|
RoleIDCode |
M |
EV (110155, DCM, "Source Media") |
|
NetworkAccessPointTypeCode |
U |
not specialized |
|
NetworkAccessPointID |
MC |
Shall be present if Net Access Point Type Code is present. Shall use fields as specified in RFC 3881. |
|
MediaIdentifier |
M |
Volume ID, URI, or other identifier for media |
|
MediaType |
M |
Values selected from DCID (405) |
|
Active Participant: Source (0..n) |
UserID |
M |
See Section A.5.2.3 |
AlternativeUserID |
U |
See Section A.5.2.4 |
|
UserName |
U |
not specialized |
|
UserIsRequestor |
M |
See Section A.5.3.5 |
|
RoleIDCode |
M |
EV (110153, DCM, "Source Role ID") |
|
NetworkAccessPointTypeCode |
U |
not specialized |
|
NetworkAccessPointID |
MC |
Shall be present if Net Access Point Type Code is present. |
|
Participating Object: Studies (0..N) |
ParticipantObjectTypeCode |
M |
Shall be: 2 = system |
ParticipantObjectTypeCodeRole |
M |
Shall be: 3 = report |
|
ParticipantObjectDataLifeCycle |
U |
not specialized |
|
ParticipantObjectIDTypeCode |
M |
EV (110180, DCM, "Study Instance UID") |
|
ParticipantObjectSensitivity |
U |
not specialized |
|
ParticipantObjectID |
M |
The Study Instance UID |
|
ParticipantObjectName |
U |
not specialized |
|
ParticipantObjectQuery |
U |
not specialized |
|
ParticipantObjectDetail |
U |
Not specialized |
|
ParticipantObjectDescription |
U |
not specialized |
|
SOPClass |
MC |
See Table A.5.2-1 |
|
Accession |
U |
not specialized |
|
NumberOfInstances |
U |
not specialized |
|
Instances |
U |
not specialized |
|
Encrypted |
U |
not specialized |
|
Anonymized |
U |
not specialized |
|
Participating Object: Patients (1..N) |
ParticipantObjectTypeCode |
M |
Shall be: 1 = person |
ParticipantObjectTypeCodeRole |
M |
Shall be: 1 = patient |
|
ParticipantObjectDataLifeCycle |
U |
not specialized |
|
ParticipantObjectIDTypeCode |
M |
Shall be: 2 = patient ID |
|
ParticipantObjectSensitivity |
U |
not specialized |
|
ParticipantObjectID |
M |
The patient ID |
|
ParticipantObjectName |
U |
The patient name |
|
ParticipantObjectQuery |
U |
not specialized |
|
ParticipantObjectDetail |
U |
not specialized |
|
ParticipantObjectDescription |
U |
not specialized |
This message describes the event of DICOM SOP Instances being viewed, utilized, updated, or deleted. This message shall only include information about a single patient and can be used to summarize all activity for several studies for that patient. This message records the studies to which the instances belong, not the individual instances.
If all instances within a study are deleted, then the EV(110105, DCM, "DICOM Study Deleted") event shall be used, see Section A.5.3.8.
Table A.5.3.6-1. Audit Message for DICOM Instances Accessed
Real World Entities |
Field Name |
Opt. |
Value Constraints |
---|---|---|---|
Event |
EventID |
M |
EV (110103, DCM, "DICOM Instances Accessed") |
EventActionCode |
M |
Enumerated value: C = create R = read U = update D = delete |
|
EventDateTime |
M |
not specialized |
|
EventOutcomeIndicator |
M |
not specialized |
|
EventTypeCode |
U |
not specialized |
|
Active Participant: Person and or Process manipulating the data (1..2) |
UserID |
M |
not specialized |
AlternativeUserID |
U |
not specialized |
|
UserName |
U |
not specialized |
|
UserIsRequestor |
M |
not specialized |
|
RoleIDCode |
U |
not specialized |
|
NetworkAccessPointTypeCode |
U |
not specialized |
|
NetworkAccessPointID |
U |
not specialized |
|
Participating Object: Studies (1..N) |
ParticipantObjectTypeCode |
M |
Shall be: 2 = system |
ParticipantObjectTypeCodeRole |
M |
Shall be: 3 = report |
|
ParticipantObjectDataLifeCycle |
U |
not specialized |
|
ParticipantObjectIDTypeCode |
M |
EV (110180, DCM, "Study Instance UID") |
|
ParticipantObjectSensitivity |
U |
not specialized |
|
ParticipantObjectID |
M |
The Study Instance UID |
|
ParticipantObjectName |
U |
not specialized |
|
ParticipantObjectQuery |
U |
not specialized |
|
ParticipantObjectDetail |
U |
Not specialized |
|
ParticipantObjectDescription |
U |
Not specialized |
|
SOPClass |
MC |
See Table A.5.2-1 |
|
Accession |
U |
not specialized |
|
NumberOfInstances |
U |
not specialized |
|
Instances |
U |
not specialized |
|
Encrypted |
U |
not specialized |
|
Anonymized |
U |
not specialized |
|
Participating Object: Patient (1) |
ParticipantObjectTypeCode |
M |
Shall be: 1 = person |
ParticipantObjectTypeCodeRole |
M |
Shall be: 1 = patient |
|
ParticipantObjectDataLifeCycle |
U |
not specialized |
|
ParticipantObjectIDTypeCode |
M |
Shall be: 2 = patient ID |
|
ParticipantObjectSensitivity |
U |
not specialized |
|
ParticipantObjectID |
M |
The patient ID |
|
ParticipantObjectName |
U |
The patient name |
|
ParticipantObjectQuery |
U |
not specialized |
|
ParticipantObjectDetail |
U |
not specialized |
|
ParticipantObjectDescription |
U |
not specialized |
This message describes the event of the completion of transferring DICOM SOP Instances between two Application Entities. This message may only include information about a single patient.
This message may have been preceded by a Begin Transferring Instances message. The Begin Transferring Instances message conveys the intent to store SOP Instances, while the Instances Transferred message records the completion of the transfer. Any disagreement between the two messages might indicate a potential security breach.
Table A.5.3.7-1. Audit Message for DICOM Instances Transferred
Real World Entities |
Field Name |
Opt. |
Value Constraints |
---|---|---|---|
Event |
EventID |
M |
EV (110104, DCM, "DICOM Instances Transferred") |
EventActionCode |
M |
Enumerated Value: C = (create) if the receiver did not hold copies of the instances transferred R = (read) if the receiver already holds copies of the SOP Instances transferred, and has determined that no changes are needed to the copies held. U = (update) if the receiver is altering its held copies to reconcile differences between the held copies and the received copies. If the Audit Source is either not the receiver, or otherwise does not know whether or not the instances previously were held by the receiving node, then use "R" = (Read). |
|
EventDateTime |
M |
Shall be the time when the transfer has completed |
|
EventOutcomeIndicator |
M |
not specialized |
|
EventTypeCode |
U |
not specialized |
|
Active Participant: Process that sent the data (1) |
UserID |
M |
not specialized |
AlternativeUserID |
U |
not specialized |
|
UserName |
U |
not specialized |
|
UserIsRequestor |
M |
not specialized |
|
RoleIDCode |
M |
EV (110153, DCM, "Source Role ID") |
|
NetworkAccessPointTypeCode |
U |
not specialized |
|
NetworkAccessPointID |
U |
not specialized |
|
Active Participant: The process that received the data. (1) |
UserID |
M |
not specialized |
AlternativeUserID |
U |
not specialized |
|
UserName |
U |
not specialized |
|
UserIsRequestor |
M |
not specialized |
|
RoleIDCode |
M |
EV (110152, DCM, "Destination Role ID") |
|
NetworkAccessPointTypeCode |
U |
not specialized |
|
NetworkAccessPointID |
U |
not specialized |
|
Active Participant: Other participants that are known, especially third parties that are the requestor (0..N) |
UserID |
M |
not specialized |
AlternativeUserID |
U |
not specialized |
|
UserName |
U |
not specialized |
|
UserIsRequestor |
M |
not specialized |
|
RoleIDCode |
U |
not specialized |
|
NetworkAccessPointTypeCode |
U |
not specialized |
|
NetworkAccessPointID |
U |
not specialized |
|
Participating Object: Studies being transferred (1..N) |
ParticipantObjectTypeCode |
M |
Shall be: 2 = system |
ParticipantObjectTypeCodeRole |
M |
Shall be: 3 = report |
|
ParticipantObjectDataLifeCycle |
U |
not specialized |
|
ParticipantObjectIDTypeCode |
M |
EV (110180, DCM, "Study Instance UID") |
|
ParticipantObjectSensitivity |
U |
not specialized |
|
ParticipantObjectID |
M |
The Study Instance UID |
|
ParticipantObjectName |
U |
not specialized |
|
ParticipantObjectQuery |
U |
not specialized |
|
ParticipantObjectDetail |
U |
Not specialized |
|
ParticipantObjectDescription |
U |
Not specialized |
|
SOPClass |
MC |
See Table A.5.2-1 |
|
Accession |
U |
not specialized |
|
NumberOfInstances |
U |
not specialized |
|
Instances |
U |
not specialized |
|
Encrypted |
U |
not specialized |
|
Anonymized |
U |
not specialized |
|
Participating Object: Patient (1) |
ParticipantObjectTypeCode |
M |
Shall be: 1 = person |
ParticipantObjectTypeCodeRole |
M |
Shall be: 1 = patient |
|
ParticipantObjectDataLifeCycle |
U |
not specialized |
|
ParticipantObjectIDTypeCode |
M |
Shall be: 2 = patient ID |
|
ParticipantObjectSensitivity |
U |
not specialized |
|
ParticipantObjectID |
M |
The patient ID |
|
ParticipantObjectName |
U |
The patient name |
|
ParticipantObjectQuery |
U |
not specialized |
|
ParticipantObjectDetail |
U |
not specialized |
|
ParticipantObjectDescription |
U |
not specialized |
This message describes the event of deletion of one or more studies and all associated SOP Instances in a single action. This message shall only include information about a single patient.
Table A.5.3.8-1. Audit Message for DICOM Study Deleted
Real World Entities |
Field Name |
Opt. |
Value Constraints |
---|---|---|---|
Event |
EventID |
M |
EV (110105, DCM, "DICOM Study Deleted") |
EventActionCode |
M |
Shall be: D = delete |
|
EventDateTime |
M |
not specialized |
|
EventOutcomeIndicator |
M |
not specialized |
|
EventTypeCode |
U |
not specialized |
|
Active Participant: the person or process deleting the study (1..2) |
UserID |
M |
not specialized |
AlternativeUserID |
U |
not specialized |
|
UserName |
U |
not specialized |
|
UserIsRequestor |
M |
not specialized |
|
RoleIDCode |
U |
not specialized |
|
NetworkAccessPointTypeCode |
U |
not specialized |
|
NetworkAccessPointID |
U |
not specialized |
|
Participating Object: Studies being transferred (1..N) |
ParticipantObjectTypeCode |
M |
Shall be: 2 = system |
ParticipantObjectTypeCodeRole |
M |
Shall be: 3 = report |
|
ParticipantObjectDataLifeCycle |
U |
not specialized |
|
ParticipantObjectIDTypeCode |
M |
EV (110180, DCM, "Study Instance UID") |
|
ParticipantObjectSensitivity |
U |
not specialized |
|
ParticipantObjectID |
M |
The Study Instance UID |
|
ParticipantObjectName |
U |
not specialized |
|
ParticipantObjectQuery |
U |
not specialized |
|
ParticipantObjectDetail |
U |
Not specialized |
|
ParticipantObjectDescription |
U |
Not specialized |
|
SOPClass |
MC |
See Table A.5.2-1 |
|
Accession |
U |
not specialized |
|
NumberOfInstances |
U |
not specialized |
|
Instances |
U |
not specialized |
|
Encrypted |
U |
not specialized |
|
Anonymized |
U |
not specialized |
|
Participating Object: Patient (1) |
ParticipantObjectTypeCode |
M |
Shall be: 1 = person |
ParticipantObjectTypeCodeRole |
M |
Shall be: 1 = patient |
|
ParticipantObjectDataLifeCycle |
U |
not specialized |
|
ParticipantObjectIDTypeCode |
M |
Shall be: 2 = patient ID |
|
ParticipantObjectSensitivity |
U |
not specialized |
|
ParticipantObjectID |
M |
The patient ID |
|
ParticipantObjectName |
U |
The patient name |
|
ParticipantObjectQuery |
U |
not specialized |
|
ParticipantObjectDetail |
U |
not specialized |
|
ParticipantObjectDescription |
U |
not specialized |
This message describes the event of a system, such as a mobile device, intentionally entering or leaving the network.
The machine should attempt to send this message prior to detaching. If this is not possible, it should retain the message in a local buffer so that it can be sent later. The mobile machine can then capture audit messages in a local buffer while it is outside the secure domain. When it is reconnected to the secure domain, it can send the detach message (if buffered), followed by the buffered messages, followed by a mobile machine message for rejoining the secure domain. The timestamps on these messages is the time that the event was noticed to have occurred, not the time that the message is sent.
Table A.5.3.9-1. Audit Message for Network Entry
Real World Entities |
Field Name |
Opt. |
Value |
---|---|---|---|
Event |
EventID |
M |
EV (110108, DCM, "Network Entry") |
EventActionCode |
M |
Shall be: E = Execute |
|
EventDateTime |
M |
not specialized |
|
EventOutcomeIndicator |
M |
not specialized |
|
EventTypeCode |
M |
EV (110124, DCM, "Attach")EV (110125, DCM, "Detach") |
|
Active Participant: Node or System entering or leaving the network (1) |
UserID |
M |
not specialized |
AlternativeUserID |
U |
not specialized |
|
UserName |
U |
not specialized |
|
UserIsRequestor |
M |
Shall be FALSE |
|
RoleIDCode |
U |
not specialized |
|
NetworkAccessPointTypeCode |
U |
not specialized |
|
NetworkAccessPointID |
U |
not specialized |
No Participant Objects are needed for this message.
This message describes the event of a Query being issued or received. The message does not record the response to the query, but merely records the fact that a query was issued. For example, this would report queries using the DICOM SOP Classes:
Modality Worklist
UPS Pull
UPS Watch
Composite Instance Query
The response to a query may result in one or more Instances Transferred or Instances Accessed messages, depending on what events transpire after the query. If there were security-related failures, such as access violations, when processing a query, those failures should show up in other audit messages, such as a Security Alert message.
Non-DICOM queries may also be captured by this message. The Participant Object ID Type Code, the Participant Object ID, and the Query fields may have values related to such non-DICOM queries.
Table A.5.3.10-1. Audit Message for Query
Real World Entities |
Field Name |
Opt. |
Value Constraints |
---|---|---|---|
Event |
EventID |
M |
EV (110112, DCM, "Query") |
EventActionCode |
M |
Shall be: E = Execute |
|
EventDateTime |
M |
not specialized |
|
EventOutcomeIndicator |
M |
not specialized |
|
EventTypeCode |
U |
not specialized |
|
Active Participant: Process Issuing the Query (1) |
UserID |
M |
not specialized |
AlternativeUserID |
U |
not specialized |
|
UserName |
U |
not specialized |
|
UserIsRequestor |
M |
not specialized |
|
RoleIDCode |
M |
EV (110153, DCM, "Source Role ID") |
|
NetworkAccessPointTypeCode |
U |
not specialized |
|
NetworkAccessPointID |
U |
not specialized |
|
Active Participant: The process that will respond to the query (1) |
UserID |
M |
not specialized |
AlternativeUserID |
U |
not specialized |
|
UserName |
U |
not specialized |
|
UserIsRequestor |
M |
not specialized |
|
RoleIDCode |
M |
EV (110152, DCM, "Destination Role ID") |
|
NetworkAccessPointTypeCode |
U |
not specialized |
|
NetworkAccessPointID |
U |
not specialized |
|
Active Participant: Other Participants that are known, especially third parties that requested the query (0..N) |
UserID |
M |
not specialized |
AlternativeUserID |
U |
not specialized |
|
UserName |
U |
not specialized |
|
UserIsRequestor |
M |
not specialized |
|
RoleIDCode |
U |
not specialized |
|
NetworkAccessPointTypeCode |
U |
not specialized |
|
NetworkAccessPointID |
U |
not specialized |
|
Participating Object: SOP Queried and the Query (1) |
ParticipantObjectTypeCode |
M |
Shall be: 2 = system |
ParticipantObjectTypeCodeRole |
M |
Shall be: 3 = report |
|
ParticipantObjectDataLifeCycle |
U |
not specialized |
|
ParticipantObjectIDTypeCode |
M |
DT (110181, DCM, "SOP Class UID") |
|
ParticipantObjectSensitivity |
U |
not specialized |
|
ParticipantObjectID |
M |
If the ParticipantObjectIDTypeCode is (110181, DCM, "SOP Class UID"), then this field shall hold the UID of the SOP Class being queried |
|
ParticipantObjectName |
U |
not specialized |
|
ParticipantObjectQuery |
M |
If the ParticipantObjectIDTypeCode is (110181, DCM, "SOP Class UID"), then this field shall hold the Dataset of the DICOM query, xs:base64Binary encoded. Otherwise, it shall be the query in the format of the protocol used. |
|
ParticipantObjectDetail |
MC |
Required if the ParticipantObjectIDTypeCode is (110181, DCM, "SOP Class UID") A ParticipantObjectDetail element with the XML attribute "TransferSyntax" shall be present. The value of the Transfer Syntax attribute shall be the UID of the transfer syntax of the query. The element contents shall be xs:base64Binary encoding. The Transfer Syntax shall be a DICOM Transfer Syntax. |
|
ParticipantObjectDescription |
U |
not specialized |
|
SOPClass |
U |
See Table A.5.2-1 |
|
Accession |
U |
not specialized |
|
NumberOfInstances |
U |
not specialized |
|
Instances |
U |
not specialized |
|
Encrypted |
U |
not specialized |
|
Anonymized |
U |
not specialized |
This message describes any event for which a node needs to report a security alert, e.g., a node authentication failure when establishing a secure communications channel.
The Node Authentication event can be used to report both successes and failures. If reporting of success is done, this could generate a very large number of audit messages, since every authenticated DICOM association, HL7 transaction, and HTML connection should result in a successful node authentication. It is expected that in most situations only the failures will be reported.
Table A.5.3.11-1. Audit Message for Security Alert
Real World Entities |
Field Name |
Opt. |
Value Constraints |
---|---|---|---|
Event |
EventID |
M |
EV (110113, DCM, "Security Alert") |
EventActionCode |
M |
Shall be: E = Execute |
|
EventDateTime |
M |
not specialized |
|
EventOutcomeIndicator |
M |
Success implies an informative alert. The other failure values imply warning codes that indicate the severity of the alert. A Minor or Serious failure indicates that mitigation efforts were effective in maintaining system security. A Major failure indicates that mitigation efforts may not have been effective, and that the security system may have been compromised. |
|
EventTypeCode |
M |
Values selected from DCID( 403) |
|
Active Participant: Reporting Person and/or Process (1..2) |
UserID |
M |
not specialized |
AlternativeUserID |
U |
not specialized |
|
UserName |
U |
not specialized |
|
UserIsRequestor |
M |
not specialized |
|
RoleIDCode |
U |
not specialized |
|
NetworkAccessPointTypeCode |
U |
not specialized |
|
NetworkAccessPointID |
U |
not specialized |
|
Active Participant: Performing Persons or Processes (0..N) |
UserID |
M |
not specialized |
AlternativeUserID |
U |
not specialized |
|
UserName |
U |
not specialized |
|
UserIsRequestor |
M |
Shall be FALSE |
|
RoleIDCode |
U |
not specialized |
|
NetworkAccessPointTypeCode |
U |
not specialized |
|
NetworkAccessPointID |
U |
not specialized |
|
Participating Object: Alert Subject (0..N) |
ParticipantObjectTypeCode |
M |
Shall be: 2 = system |
ParticipantObjectTypeCodeRole |
U |
Defined Terms: 5 = master file 13 = security resource |
|
ParticipantObjectDataLifeCycle |
U |
not specialized |
|
ParticipantObjectIDTypeCode |
M |
Defined Terms: 12 = URI(110182, DCM, "Node ID") = Node Identifier |
|
ParticipantObjectSensitivity |
U |
not specialized |
|
ParticipantObjectID |
M |
For a ParticipantObjectIDTypeCode of 12 (URI), then this value shall be the URI of the file or other resource that is the subject of the alert. For a ParticipantObjectIDTypeCode of (110182, DCM, "Node ID") then the value shall include the identity of the node that is the subject of the alert either in the form ofnode_name@domain_nameor as an IP address. Otherwise, the value shall be an identifier of the type specified by ParticipantObjectIDTypeCode of the subject of the alert. |
|
ParticipantObjectName |
U |
not specialized |
|
ParticipantObjectQuery |
U |
not specialized |
|
ParticipantObjectDetail |
M |
An element with the Attribute "type" equal to "Alert Description" shall be present with a free text description of the nature of the alert as the value |
|
ParticipantObjectDescription |
U |
not specialized |
|
SOPClass |
U |
See Table A.5.2-1 |
|
Accession |
U |
not specialized |
|
NumberOfInstances |
U |
not specialized |
|
Instances |
U |
not specialized |
|
Encrypted |
U |
not specialized |
|
Anonymized |
U |
not specialized |
This message describes the event that a user has attempted to log on or log off. This report can be made regardless of whether the attempt was successful or not. No Participant Objects are needed for this message.
The user usually has UserIsRequestor TRUE, but in the case of a logout timer, the Node might be the UserIsRequestor.
Table A.5.3.12-1. Audit Message for User Authentication
Real World Entities |
Field Name |
Opt. |
Value Constraints |
---|---|---|---|
Event |
EventID |
M |
EV (110114, DCM, "User Authentication") |
EventActionCode |
M |
Shall be: E = Execute |
|
EventDateTime |
M |
not specialized |
|
EventOutcomeIndicator |
M |
not specialized |
|
EventTypeCode |
M |
Defined Terms: EV (110122, DCM, "Login") EV (110123, DCM, "Logout") |
|
Active Participant: Person Authenticated or claimed (1) |
UserID |
M |
not specialized |
AlternativeUserID |
U |
not specialized |
|
UserName |
U |
not specialized |
|
UserIsRequestor |
M |
not specialized |
|
RoleIDCode |
U |
not specialized |
|
NetworkAccessPointTypeCode |
M |
not specialized |
|
NetworkAccessPointID |
M |
not specialized |
|
Active Participant: Node or System performing authentication (0..1) |
UserID |
M |
not specialized |
AlternativeUserID |
U |
not specialized |
|
UserName |
U |
not specialized |
|
UserIsRequestor |
M |
not specialized |
|
RoleIDCode |
U |
not specialized |
|
NetworkAccessPointTypeCode |
U |
not specialized |
|
NetworkAccessPointID |
U |
not specialized |
This profile defines the transmission of audit trail messages. Transport Layer Security (TLS) Transport Mapping for Syslog (RFC 5425) provides the mechanisms for reliable transport, buffering, acknowledgement, authentication, identification, and encryption. The RFC5424 states that the TLS used MUST be TLS version 1.2. For this DICOM profile TLS MUST be used, and version 1.2 or later is RECOMMENDED.
The words MUST and RECOMMENDED are used in accordance with the IETF specification for normative requirements.
Any implementation that claims conformance to this profile shall also conform to the Audit Trail Message Format Profile. XML audit trail messages created using the format defined in Audit Trail Message Format Profile shall be transmitted to a collection point using the syslog over TLS mechanism, defined in RFC 5425. Systems that comply with this profile shall support message sizes of at least 32768 octets.
Audit messages for other purposes may also be transferred on the same syslog connection. These messages might not conform to the Audit Trail Message Format.
RFC 5425 specifies mandatory support for 2KB messages, strongly recommends support for at least 8KB, and does not restrict the maximum size.
When a received message is longer than the receiving application supports, the message might be discarded or truncated. The sending application will not be notified.
The XML audit trail message shall be inserted into the MSG portion of the SYSLOG-MSG element of the syslog message as defined in RFC 5424 "The Syslog Protocol".The XML audit message may contain Unicode characters that are encoded using the UTF-8 encoding rules.
UTF-8 avoids utilizing the control characters that are reserved by the syslog protocol, but a system that is not prepared for UTF-8 may not be able to display these messages correctly.
The PRI field shall be set using the facility value of 10 (security/authorization messages). Most messages should have the severity value of 5 (normal but significant), although applications may choose other values if that is appropriate to the more detailed information in the audit message. This means that for most audit messages the PRI field will contain the value "<85>".
The MSGID field in the HEADER of the SYSLOG-MSG shall be set. The value "DICOM+RFC3881" may be used for messages that comply with this profile.
The MSG field of the SYSLOG-MSG shall be present and shall be an XML structure following the RFC 3881 format, as extended in the audit trail message format profile.
The syslog message shall be created and transmitted as described in RFC 5424.
Any implementation that claims conformance to this Security Profile shall describe in its conformance statement:
any configuration parameters relevant to RFC 5424 and RFC 5425.
Any STRUCTURED-DATA that is generated or processed.
Any implementation schema or message element extensions for the audit messages.
The maximum size of messages that can be sent or received.
This profile defines the transmission of audit trail messages. Transmission of Syslog Messages over UDP (RFC5426) provides the mechanisms for rapid transport of audit messages. It is the standardized successor to the informative standard "The BSD syslog protocol (RFC3164) ", which is widely used in a variety of settings.
The syslog port number shall be configurable, with the port number (514) as the default.
The underlying UDP transport might not accept messages longer than the MTU size minus the UDP header length. This may result in longer syslog messages being truncated. When these messages are truncated the resulting XML may be incorrect. Because of this potential for truncated messages and other security concerns, the transmission of syslog messages over TLS may be preferred (see Section A.6).
The PRI field shall be set using the facility value of 10 (security/authorization messages). Most messages should have the severity value of 5 (normal but significant), although applications may choose values of 4 (warning condition) if that is appropriate to the more detailed information in the audit message. This means that for most audit messages the PRI field will contain the value "<85>". Audit repositories shall be prepared to deal appropriately with any incoming PRI value.
The MSGID field in the HEADER of the SYSLOG-MSG shall be set. The value "DICOM+RFC3881" may be used for messages that comply with this profile.
The MSG field of the SYSLOG-MSG shall be present and shall be an XML structure following the RFC 3881 format, as extended in this profile.
The syslog message shall be created and transmitted as described in RFC 5424.
Any implementation that claims conformance to this Security Profile shall describe in its conformance statement:
any configuration parameters relevant to RFC 5424 and RFC 5426.
Any STRUCTURED-DATA that is generated or processed.
Any implementation schema or message element extensions for the audit messages.
The maximum size of messages that can be sent or received.
An implementation that supports the Basic TLS Secure Transport Connection Profile shall utilize the framework and negotiation mechanism specified by the Transport Layer Security Version 1.0 protocol. Table B.1-1 specifies mechanisms that shall be supported if the corresponding features within TLS are supported by the Application Entity. The profile does not require the implementation to support all of the features (entity authentication, encryption, integrity checks) of TLS. Other mechanisms may also be used if agreed to by negotiation during establishment of the TLS channel.
Table B.1-1. Minimum Mechanisms for TLS Features
Supported TLS Feature |
Minimum Mechanism |
---|---|
Entity Authentication |
RSA based certificates |
Exchange of Master Secrets |
RSA |
Data Integrity |
SHA |
Privacy |
Triple DES EDE, CBC |
IP ports on which an implementation accepts TLS connections, or the mechanism by which this port number is selected or configured, shall be specified in the Conformance Statement. This port shall be different from ports used for other types of transport connections (secure or unsecure).
It is strongly recommended that systems supporting the Basic TLS Secure Transport Connection Profile use as their port the registered port number "2762 dicom-tls" for the DICOM Upper Layer Protocol on TLS: (decimal).
The Conformance Statement shall also indicate what mechanisms the implementation supports for Key Management.
The profile does not specify how a TLS Secure Transport Connection is established, or the significance of any certificates exchanged during peer entity authentication. These issues are left up to the Application Entity, which presumably is following some site specified security policy. The identities of the certificate owners can by used by the application entity for audit log support, or to restrict access based on some external access rights control framework. Once the Application Entity has established a Secure Transport Connection, then an Upper Layer Association can use that secure channel.
There may be an interaction between PDU size and TLS Record size that impacts efficiency of transport. The maximum allowed TLS record size is smaller than the maximum allowed PDU size.
When an integrity check fails, the connection shall be dropped per the TLS protocol, causing both the sender and the receiver to issue an A-P-ABORT indication to the upper layers with an implementation-specific provider reason. The provider reason used shall be documented in the conformance statement.
An integrity check failure indicates that the security of the channel may have been compromised.
An implementation that supports the ISCL Transport Connection Profile shall utilize the framework and negotiation mechanism specified by the Integrated Secure Communication Layer, V1.00. An Application Entity shall use ISCL to select the mechanisms specified in Table B.2-1. An Application Entity shall as a minimum use an Entity Authentication mechanism and Data Integrity checks. An Application Entity may optionally use a privacy mechanism.
Table B.2-1. Minimum Mechanisms for ISCL Features
Supported ISCL Feature |
Minimum Mechanism |
---|---|
Entity Authentication |
Three pass (four-way) authentication(ISO/IEC 9798-2) |
Data Integrity |
Either MD-5 encrypted with DES,or DES-MAC (ISO 8730) |
Privacy |
DES (see Note) |
The use of DES for privacy is optional for Online Electronic Storage.
For the Data Integrity check, an implementation may either encrypt the random number before applying MD-5, or encrypt the output of MD-5. The order is specified in the protocol. A receiver shall be able to perform the integrity check on messages regardless of the order.
IP ports on which an implementation accepts ISCL connections, or the mechanism by which this port number is selected or configured, shall be specified in the Conformance Statement. This port shall be different from ports used for other types of transport connections (secure or unsecure).
It is strongly recommended that systems supporting the ISCL Secure Transport Connection Profile use as their port the registered port number "2761 dicom-iscl" for the DICOM Upper Layer Protocol on ISCL.
The Conformance Statement shall also indicate what mechanisms the implementation supports for Key Management.
The profile does not specify how an ISCL Secure Transport Connection is established. This issue is left up to the Application Entity, which presumably is following some site specified security policy. Once the Application Entity has established a Secure Transport Connection, then an Upper Layer Association can use that secure channel.
There may be an interaction between PDU size and ISCL record size that impacts efficiency of transport.
When an integrity check fails, the connection shall be dropped, per the ISCL protocol, causing both the sender and the receiver to issue an A-P-ABORT indication to the upper layers with an implementation-specific provider reason. The provider reason used shall be documented in the conformance statement.
An integrity check failure indicates that the security of the channel may have been compromised.
An implementation that supports the AES TLS Secure Transport Connection Profile shall utilize the framework and negotiation mechanism specified by the Transport Layer Security Version 1.0 protocol. Table B.3-1 specifies mechanisms that shall be supported if the corresponding features within TLS are supported by the Application Entity. The profile does not require the implementation to support all of the features (entity authentication, encryption, integrity checks) of TLS. Other mechanisms may also be used if agreed to by negotiation during establishment of the TLS channel.
Table B.3-1. Minimum Mechanisms for TLS Features
Supported TLS Feature |
Minimum Mechanism |
---|---|
Entity Authentication |
RSA based Certificates |
Two cyphersuite options shall be offered during TLS negotiation by applications that comply with this profile:
TLS_RSA_WITH_AES_128_CBC_SHA
TLS_RSA_WITH_3DES_EDE_CBC_SHA
The application shall offer both options. The AES version shall be preferred. The fallback to 3DES is offered so that this profile can interoperate easily with applications that only support the 3DES cyphersuite.
IP ports on which an implementation accepts TLS connections, or the mechanism by which this port number is selected or configured, shall be specified in the Conformance Statement. This port shall be different from ports used for other types of transport connections (secure or unsecure).
It is strongly recommended that systems supporting the AES TLS Secure Transport Connection Profile use as their port the registered port number "2762 dicom-tls" for the DICOM Upper Layer Protocol on TLS: (decimal).
The Conformance Statement shall also indicate what mechanisms the implementation supports for Key Management.
The profile does not specify how a TLS Secure Transport Connection is established, or the significance of any certificates exchanged during peer entity authentication. These issues are left up to the Application Entity, which presumably is following some site specified security policy. The identities of the certificate owners can by used by the application entity for audit log support, or to restrict access based on some external access rights control framework. Once the Application Entity has established a Secure Transport Connection, then an Upper Layer Association can use that secure channel.
There may be an interaction between PDU size and TLS Record size that impacts efficiency of transport. The maximum allowed TLS record size is smaller than the maximum allowed PDU size.
When an integrity check fails, the connection shall be dropped per the TLS protocol, causing both the sender and the receiver to issue an A-P-ABORT indication to the upper layers with an implementation-specific provider reason. The provider reason used shall be documented in the conformance statement.
An integrity check failure indicates that the security of the channel may have been compromised.
An implementation that supports the Basic User Identity Association profile shall accept the User Identity association negotiation sub-item, for User-Identity-Type of 1 or 2. It need not verify the passcode. If a positive response is requested, the implementation shall respond with the association response sub-item.
The user identity from the Primary-field shall be used within the implementation as the user identification. Such uses include recording user identification in audit messages.
Table B.4-1. Minimum Mechanisms for DICOM Association Negotiation Features - Basic User Identity Association Profile
Supported Association Negotiation Feature |
Minimum Mechanism |
---|---|
User Identity |
Username |
An implementation that supports the User Identity plus Passcode Association Profile shall send/accept the User Identity association negotiation sub-item, for User-Identity-Type of 2. If a positive response is requested, the association acceptor implementation shall respond with the association response sub-item. The passcode information shall be made available to internal or external authentication systems. The user identity shall be authenticated by means of the passcode and the authentication system. If the authentication fails, the association shall be rejected.
The user identity from the Primary-field shall be used within the implementation as the user identification. Such uses include recording user identification in audit messages.
Table B.5-1. User Identity Plus Passcode Association Profile - Minimum Mechanisms for DICOM Association Negotiation Features
Supported Association Negotiation Feature |
Minimum Mechanism |
---|---|
User Identity |
Username and Passcode |
An implementation that supports the Kerberos Identity Negotiation Association Profile shall send/accept the User Identity association negotiation sub-item, for User-Identity-Type of 3. If a positive response is requested, the association acceptor implementation shall respond with the association response sub-item containing a Kerberos server ticket. The Kerberos server ticket information shall be made available to internal or external Kerberos authentication systems. The user identity shall be authenticated by means of the Kerberos authentication system. If the authentication fails, the association shall be rejected.
The user identity from the Primary-field shall be used within the implementation as the user identification. Such uses include recording user identification in audit messages.
Table B.6-1. Kerberos Identity Negotiation Association Profile - Minimum Mechanisms for DICOM Association Negotiation Features
Supported Association Negotiation Feature |
Minimum Mechanism |
---|---|
User Identity |
Kerberos |
An implementation that supports the Generic SAML Assertion Identity Negotiation Association Profile shall send/accept the User Identity association negotiation sub-item, for User-Identity-Type of 4. If a positive response is requested, the association acceptor implementation shall respond with the association response sub-item containing a SAML response. The SAML Assertion information shall be made available to internal or external authentication systems. The user identity shall be authenticated by means of an authentication system that employs SAML Assertions. If the authentication fails, the association shall be rejected.
The user identity from the Primary-field shall be used within the implementation as the user identification. Such uses include recording user identification in audit messages.
Table B.7-1. Generic SAML Assertion Identity Negotiation Association Profile - Minimum Mechanisms for DICOM Association Negotiation Features
Supported Association Negotiation Feature |
Minimum Mechanism |
---|---|
User Identity |
SAML Assertion |
When a DICOM File Set is sent over Email transport in compliance with this profile the following rules shall be followed:
The File Set shall be an attachment to the email body.
The entire email (body, File Set attachment, and any other attachments) shall be encrypted using AES, in accordance with RFC 3851 and RFC 3853.
The email body and attachments may be compressed in accordance with RFC 3851.
The email shall be digitally signed by the sender. The signing may be applied before or after encryption. This digital signature shall be interpreted to mean that the sender is attesting to his authorization to disclose the information in this email to the recipient.
The email signature is present to provide minimum sender information and to confirm the integrity of the email transmission (body contents, attachment, etc.). The email signature is separate from other signatures that may be present in DICOM reports and objects contained in the File set attached to the email. Those signatures are defined in terms of clinical uses. Any clinical content attestations shall be encoded as digital signatures in the DICOM SOP instances, not as the email signature. The email may be composed by someone who cannot make clinical attestations. Through the use of the email signature, the composer attests that he or she is authorized to transmit the data to the recipient.
This profile is separate from the underlying use of ZIP File or other File Set packaging over email.
Where private information is being conveyed, most country regulations require the use of encryption or equivalent protections. This Profile meets the most common requirements of regulations, but there may be additional local requirements. Additional requirements may include mandatory statements in the email body and prohibitions on contents of the email body to protect patient privacy.
The Base RSA Digital Signature Profile outlines the use of RSA encryption of a MAC to generate a Digital Signature. This Profile does not specify any particular set of Data Elements to sign. Other Digital Signature profiles may refer to this profile, adding specifications of which Data Elements to sign or other customizations.
The creator of a digital signature shall use one of the RIPEMD-160, MD5, SHA-1 or SHA-2 family (SHA256, SHA384, SHA512) of hashing functions to generate a MAC, which is then encrypted using a private RSA key. All validators of digital signatures shall be capable of using a MAC generated by any of the hashing functions specified (RIPEMD-160, MD5, SHA-1 or SHA256, SHA384, SHA512).
The use of MD5 is not recommended by its inventors, RSA. See:ftp://ftp.rsasecurity.com/pub/pdfs/bulletn4.pdf
The MAC to be signed shall be padded to a block size matching the RSA key size, as directed in RFC 2437 (PKCS #1). The Value of MAC Algorithm (0400,0015) shall be set to either "RIPEMD160", "MD5", "SHA1", "SHA256", "SHA384" or "SHA512". The public key associated with the private key as well as the identity of the Application Entity or equipment manufacturer that owns the RSA key pair shall be transmitted in an X.509 (1993) signature certificate. The Value of the Certificate Type (0400,0110) Attribute shall be set to "X509_1993_SIG". A site-specific policy determines how the X.509 certificates are generated, authenticated, and distributed. A site may issue and distribute X.509 certificates directly, may utilize the services of a Certificate Authority, or use any reasonable method for certificate generation and verification.
If an implementation utilizes timestamps, it shall use a Certified Timestamp Type (0400,0305) of "CMS_TSP". The Certified Timestamp (0400,0310) shall be generated as described in "Internet X.509 Public Key Infrastructure; Time Stamp Protocols; March 2000".
The creator of a DICOM SOP Instance may generate signatures using the Creator RSA Digital Signature Profile. The Digital Signature produced by this Profile serves as a lifetime data integrity check that can be used to verify that the pixel data in the SOP instance has not been altered since its initial creation. An implementation that supports the Creator RSA Digital Signature Profile may include a Creator RSA Digital Signature with every SOP Instance that it creates; however, the implementation is not required to do so.
As a minimum, an implementation shall include the following attributes in generating the Creator RSA Digital Signature:
the SOP Class and Instance UIDs
the SOP Creation Date and Time, if present
the Study and Series Instance UIDs
any attributes of the General Equipment module that are present
any attributes of the Overlay Plane, Curve or Graphic Annotation modules that are present
any attributes of the General Image and Image Pixel modules that are present
any attributes of the SR Document General and SR Document Content modules that are present
any attributes of the Waveform and Waveform Annotation modules that are present
any attributes of the Multi-frame Functional Groups module that are present
any attributes of the Enhanced MR Image module that are present
any attributes of the MR Spectroscopy modules that are present
any attributes of the Raw Data module that are present
any attributes of the Enhanced CT Image module that are present
any attributes of the Enhanced XA/XRF Image module that are present
any attributes of the Segmentation Image module that are present
any attributes of the Encapsulated Document module that are present
any attributes of the X-Ray 3D Image module that are present
any attributes of the Enhanced PET Image module that are present
any attributes of the Enhanced US Image module that are present
any attributes of the Surface Segmentation module that are present
any attributes of the Surface Mesh Module that are present
any attributes of the Structured Display, Structured Display Annotation, and Structured Display Image Box modules that are present
any Attributes of the Implant Template module that are present
any Attributes of the Implant Assembly Template module that are present
any Attributes of the Implant Template Group module that are present
any attributes of the Point Cloud Module that are present
The Digital Signature shall be created using the methodology described in the Base RSA Digital Signature Profile. Typically the certificate and associated private key used to produce Creator RSA Digital Signatures are configuration parameters of the Application Entity set by service or installation engineers.
Creator RSA Digital Signatures bear no direct relationship to other Digital Signatures. However, other Digital Signatures, such as the Authorization Digital Signature, may be used to collaborate the timestamp of a Creator RSA Digital Signature.
The technician or physician who approves a DICOM SOP Instance for use may request the Application Entity to generate a signature using the Authorization RSA Digital Signature Profile. The Digital Signature produced serves as a lifetime data integrity check that can be used to verify that the pixel data in the SOP instance is the same that the technician or physician saw when they made the approval.
As a minimum, an implementation shall include the following attributes in generating the Authorization RSA Digital Signature:
the SOP Class and Instance UIDs
the Study and Series Instance UIDs
any attributes whose Values are verifiable by the technician or physician (e.g., their Values are displayed to the technician or physician)
any attributes of the Overlay Plane, Curve or Graphic Annotation modules that are present
any attributes of the General Image and Image Pixel modules that are present
any attributes of the SR Document General and SR Document Content modules that are present
any attributes of the Waveform and Waveform Annotation modules that are present
any attributes of the Multi-frame Functional Groups module that are present
any attributes of the Enhanced MR Image module that are present
any attributes of the MR Spectroscopy modules that are present
any attributes of the Raw Data module that are present
any attributes of the Enhanced CT Image module that are present
any attributes of the Enhanced XA/XRF Image module that are present
any attributes of the Segmentation Image module that are present
any attributes of the Encapsulated Document module that are present
any attributes of the X-Ray 3D Image module that are present
any attributes of the Enhanced PET Image module that are present
any attributes of the Enhanced US Image module that are present
any attributes of the Surface Segmentation module that are present
any attributes of the Surface Mesh Module that are present
any attributes of the Structured Display, Structured Display Annotation, and Structured Display Image Box modules that are present
any Attributes of the Implant Template module that are present
any Attributes of the Implant Assembly Template module that are present
any Attributes of the Implant Template Group module that are present
any attributes of the Point Cloud Module that are present
The Digital Signature shall be created using the methodology described in the Base RSA Digital Signature Profile. The Application Entity shall determine the identity of the technician or physician and obtain their certificate through a site-specific procedure such as a login mechanism or a smart card.
Authorization RSA Digital Signatures bear no direct relationship to other Digital Signatures. However, other Digital Signatures, such as the Creator RSA Digital Signature, may be used to collaborate the timestamp of an Authorization RSA Digital Signature.
This profile defines a mechanism for adding Digital Signatures to Structured Reports or Key Object Selection Documents where there is no more than one Verifying Observer. Instances that follow this Digital Signature Profile shall include at least one Digital Signature at the top level of the Data Set.
All Digital Signatures that follow this profile shall include a Digital Signature Purpose Code Sequence Attribute (0400,0401).
As a minimum, an implementation shall include the following attributes in generating the Digital Signature required by this profile:
the SOP Class UID
the Study and Series Instance UIDs
all attributes of the General Equipment Module that are present
the Current Requested Procedure Evidence Sequence
the Pertinent Other Evidence Sequence
the Predecessor Documents Sequence
the Observation DateTime
all attributes of the SR Document Content Module that are present
If the Verification Flag is set to "VERIFIED" (and the SOP Instance UID can no longer change) at least one of the Digital Signatures profile shall have the purpose of (5,ASTM-sigpurpose,"Verification Signature") and shall also include the following Attributes in addition to the above attributes:
the SOP Instance UID
the Verification Flag
the Verifying Observer Sequence
the Verification DateTime
The system may also add a Creator RSA Digital Signature, which could cover other attributes that the machine can verify.
All occurrences of Referenced SOP Instance MAC Sequence (0400,0403) shall have the Value of MAC Algorithm (0400,0015) set to either "RIPEMD160", "MD5", "SHA1", "SHA256", "SHA384" or "SHA512"..
The Digital Signature shall be created using the methodology described in the Base RSA Digital Signature Profile. The Application Entity shall determine the identity of the signatories and obtain their certificate through an application-specific procedure such as a login mechanism or a smart card. The conformance statement shall specify how the application identifies signatories and obtains certificates.
Structured Report RSA Digital Signatures bear no direct relationship to other Digital Signatures. However, other Digital Signatures, such as the Creator RSA Digital Signature, may be used to corroborate the timestamp of a Structured Report RSA Digital Signature.
The Basic DICOM Media Security Profile allows encapsulation of a DICOM File into a Secure DICOM File such that the following aspects of security are addressed:
confidentiality,
integrity,
data origin authentication (optional).
This profile specifies the use of either AES or Triple-DES for content encryption and RSA, or password-based encryption and AES or Triple-DES, for the key transport of the content-encryption keys. The encrypted content is a DICOM File that can either
be signed with one or more digital signatures, using SHA-1, SHA256, SHA384, or SHA512 as the digest algorithm and RSA as the signature algorithm, or
be digested with SHA-1, SHA256, SHA384, or SHA512 as digest algorithm, without application of digital signatures.
The digest algorithm requirements will evolve as the threats evolve. As the digest requirements have changed, this profile has changed to include additional requirements.
A Secure DICOM File conforming to this security profile shall contain an Enveloped-data content type of the Cryptographic Message Syntax defined in RFC 3852, 3370 and 3565. The enveloped data shall use RSA [RFC 3447], or password-based encryption using PBKDF2 [RFC 2898] for the key derivation algorithm and either AES or Triple-DES [RFC 3211], for the key transport of the content-encryption keys. Creators of a Secure DICOM File conforming to this security profile may use either AES or Triple-DES for content-encryption. Readers claiming conformance to this profile shall be capable of decrypting Secure DICOM Files using either AES or Triple-DES. The AES key length may be any length allowed by the RFCs. The Triple-DES key length is 168 bits as defined by ANSI X9.52. Encoding shall be performed according to the specifications for RSA Key Transport and Triple DES Content Encryption in RFC-3370, and for AES Content Encryption in RFC-3565.
The encrypted content of the Enveloped-data content type shall be of the following choices:
Signed-data content type;
Digested-data content type.
In both cases, SHA-1 [SHA-1], SHA256, SHA384, or SHA512 [SHA-2] shall be used as the digest algorithm. In case of the Signed-data content type, RSA [RFC 2313] shall be used as the signature algorithm.
In the case of password-based encryption using PBKDF2, the octet string that contains the password used to generate the key shall be limited to the encoding and the graphic character representation defined by the Default Character Repertoire.
RSA key transport of the content-encryption keys is specified as a requirement in the European Prestandard ENV 13608-2: Health Informatics - Security for healthcare communication - Part 2: Secure data objects.
No requirements on the size of the asymmetric key pairs used for RSA key transport are defined in this profile.
No requirements or restrictions on the use of the SignedAttributes element of the Signed-data content type's SignerInfo structure are defined in this profile. SignedAttributes might for example be used to specify the signing time or SMIME capabilities, as required by ENV 13608-2.
The use of password-based encryption for key transport of content encryption keys is potentially less secure than certificate-based encryption, but may be useful when the list of recipients is not known a priori or when there is no public key infrastructure deployed. The security depends on the entropy of the password, which if user-selected can be quite low. RFC 3211 strongly recommends the use of a pass "phrase" rather than a single word, and RFC 2898 does not impose any practical length limit. Also, the method used to exchange the password or pass phrase also could have a significant impact on the level of security.
PBKDF2 as defined in RFC 2898 specifies the password to be "an octet string of arbitrary length whose interpretation as a text string is unspecified". For interoperability between the sender and recipient, both a character encoding scheme and a graphic character representation needs to be defined. ISO IR6 (US-ASCII), being the Default Character Repertoire for DICOM (see PS3.5), is specified in order to avoid any potential ambiguity caused by the use of other character sets (such as UTF-8) that do not necessarily result in the same binary values for particular graphic character representation.
The graphic character representation of certain symbols in ISO IR6 is explicitly defined, even though the same binary representation may have a different graphic character representation in other 7-bit schemes. For example, in the version of ISO 646 used in Japan (ISO-IR 14 Romaji), 05/12 is represented as "¥" rather than backslash "\". It is the responsibility of the application to assure that the input method and display of such symbols to the user is mapped to the correct encoding, regardless of locale. I.e., if the password is "123\$", then it should be encoded as 03/01 03/02 03/03 05/12 02/04, regardless of whether the user types the backslash "\"(U+005C) on a Japanese or US keyboard; they should not be expected to type the "¥" (U+00A5) key on a Japanese keyboard, nor should 05/12 be displayed as "¥" if the password is displayed as text.
The restriction to the ISO IR 6 encoding and graphic character representation (rather than, for example, the minimal encoding of UTF-8) also eliminates the ambiguity introduced by homographs (characters that look the same but encode differently), and alternative encodings with the same meaning, such as the single German character "ß" (U+00DF) as opposed to the two-character "ss" (U+0073 U+0073), and the use of phonetic as opposed to ideographic representation of the same meaning, such as Japanese hiragana "ぞう" (U+305E U+3046) versus kanji "像" (U+50CF).
It is the responsibility of the application to prevent the user from creating passwords using characters that cannot be represented; e.g., on a Western European keyboard, the user should not be permitted to enter an accented character such as "é" (U+00E9) or "ö" (U+00F6), since there is no defined mapping of such characters to IS IR 6 characters (such as "e" or "o").
This Annex describes Profiles and Options to address the removal and replacement of Attributes within a DICOM Dataset that may potentially result in leakage of Individually Identifiable Information (III) about the patient or other individuals or organizations involved in acquisition.
Profiles are provided to address the balance between the removal of information and the need to retain information so that the Datasets remain useful for their intended purpose.
Options are used in addition to profiles to prevent a combinatorial expansion of different Profiles.
Application Level Confidentiality Profiles address the following aspects of security:
Data Confidentiality at the application layer.
Other aspects of security not addressed by these profiles, that may be addressed elsewhere in the standard include:
Confidentiality in other layers of the DICOM model;
Data Integrity.
These Profiles are targeted toward creating a special purpose, de-identified version of an already-existing Data Set. It is not intended to replace the original SOP Instance from which the de-identified SOP Instance is created, nor is it intended to act as the primary representation of clinical Data Sets in image archives. The de-identified SOP Instances are useful, for example, in creating teaching or research files, performing clinical trials, or submission to registries where the identity of the patient and other individuals is required to be protected. In some cases, it is also necessary to provide a means of recovering identity by authorized personnel.
An Application may claim conformance to an Application Level Confidentiality Profile and Options as a de-identifier if it protects and retains allAttributes as specified in the Profile and Options. Protection in this context is defined as the following process:
The application may create one or more instances of the Encrypted Attributes Data Set and copy Attributes to be protected into the (single) item of the Modified Attributes Sequence (0400,0550) of one or more of the Encrypted Attributes Data Set instances.
A complete reconstruction of the original Data Set may not be possible; however, Attributes (e.g., SOP Instance UID) in the Modified Attributes Sequence of an Encrypted Attributes Data Set may refer back to the original SOP Instance holding the original Data Set.
It is not required that the Encrypted Attributes Data Set be created; indeed, there may be circumstances where the Dataset is expected to be archived long enough that any contemporary encryption technology may be inadequate to provide long term protection against unauthorized recovery of identification.
Other mechanisms to assist in identity recovery or longitudinal consistency of replaced UIDs or dates and times are deprecated in favor of the Encrypted Attributes Data Set mechanism that is intended for this purpose. For example, if it is desired to include an encrypted hash of the Patient's Name, it should not be encoded in a separate private attribute implemented for that purpose, but should be included in the Encrypted Attributes Data Set and encoded using the standard mechanism. This allows for compatibility between different implementations and provides security based on the quality and control of the encryption keys. Note also, that unencrypted hashes are considerably less secure and should be avoided, since they are vulnerable to trivial dictionary based attacks.
Each Attribute to be protected shall then either be removed from the dataset, or have its value replaced by a different "replacement value" that does not allow identification of the patient.
It is the responsibility of the de-identifier to ensure that this process does not negatively affect the integrity of the Information Object Definition, i. e. Dummy values may be necessary for Type 1 Attributes that are protected but may not be sent with zero length, and are to be stored or exchanged in encrypted form by applications that may not be aware of the security mechanism.
The standard does not mandate the use of any particular dummy value, and indeed it may have some meaning, for example in a data set that may be used for teaching purposes, where the real patient identifying information is encrypted for later retrieval, but a meaningful alternative form of identification is provided. For example, a dummy Patient's Name (0010,0010) may convey the type of pathology in a teaching case. It is the responsibility of the de-identifier software or human operator to ensure that the dummy values cannot be used to identify the patient.
It is the responsibility of the de-identifier to ensure the consistency of dummy values for Attributes such as Study Instance UID (0020,000D) or Frame of Reference UID (0020,0052) if multiple related SOP Instances are protected. Indeed, all Attributes of every entity about the Instance level should remain consistent for all Instances protected, e.g., Patient ID for the Patient entity, Study ID for the Study entity, Series Number for the Series entity.
Some profiles do not allow selective protection of parts of a Sequence of Items. If an Attribute to be protected is contained in a Sequence of Items, the complete Sequence of Items may need to be protected.
The de-identifier should ensure that no identifying information that is burned in to the image pixel data either because the modality does not generate such burned in identification in the first place, or by removing it through the use of the Clean Pixel Data Option; see Section E.3. If non-pixel data graphics or overlays contain identification, the de-identifier is required to remove them, or clean them if the Clean Graphics option is supported. See Section E.3.3 The means by which burned in or graphic identifying information is located and removed is outside the scope of this standard.
Each Attribute specified to be retained shall be retained. At the discretion of the de-identifier, Attributes may be added to the dataset to be protected.
As an example, the Attribute Patient's Age (0010,1010) might be introduced as a replacement for Patient's Birth Date (0010,0030) if the patient's age is of importance, and the profile permits it.
If used, all instances of the Encrypted Attributes Data Set shall be encoded with a DICOM Transfer Syntax, encrypted, and stored in the dataset to be protected as an Item of the Encrypted Attributes Sequence (0400,0500). The encryption shall be done using RSA [RFC 2313] for the key transport of the content-encryption keys. A de-identifier conforming to this security profile may use either AES or Triple-DES for content-encryption. The AES key length may be any length allowed by the RFCs. The Triple-DES key length is 168 bits as defined by ANSI X9.52. Encoding shall be performed according to the specifications for RSA Key Transport and Triple DES Content Encryption in RFC-3370 and for AES Content Encryption in RFC-3565.
Each item of the Encrypted Attributes Sequence (0400,0500) consists of two Attributes, Encrypted Content Transfer Syntax UID (0400,0510) containing the UID of the Transfer Syntax that was used to encode the instance of the Encrypted Attributes Data Set, and Encrypted Content (0400,0520) containing the block of data resulting from the encryption of the Encrypted Attributes Data Set instance.
RSA key transport of the content-encryption keys is specified as a requirement in the European Prestandard ENV 13608-2: Health Informatics - Security for healthcare communication - Part 2: Secure data objects.
No requirements on the size of the asymmetric key pairs used for RSA key transport are defined in this confidentiality scheme. Implementations claiming conformance to the Basic Application Level Confidentiality Profile as a de-identifier shall always protect (e.g., encrypt and replace) the SOP Instance UID (0008,0018) Attribute as well as all references to other SOP Instances, whether contained in the main dataset or embedded in an Item of a Sequence of Items, that could potentially be used by unauthorized entities to identify the patient.
In the case of a SOP Instance UID embedded in an item of a sequence, this means that the enclosing Attribute in the top-level data set must be encrypted in its entirety.
The attribute Patient Identity Removed (0012,0062) shall be replaced or added to the dataset with a value of YES, and one or more codes from CID 7050 “De-identification Method” corresponding to the profile and options used shall be added to De-identification Method Code Sequence (0012,0064). A text string describing the method used may also be inserted in or added to De-identification Method (0012,0063), but is not required.
If the Dataset being de-identified is being stored within a DICOM File, then the File Meta Information including the 128 byte preamble, if present, shall be replaced with a description of the de-identifying application. Otherwise, there is a risk that identity information may leak through unmodified File Meta Information or preamble. See PS3.10.
The Attributes listed in Table E.1-1 for each profile are contained in Standard IODs, or may be contained in Standard Extended IODs. An implementation claiming conformance to an Application Level Confidentiality Profile as a de-identifier shall protect or retain all instances of the Attributes listed in Table E.1-1, whether contained in the main dataset or embedded in an Item of a Sequence of Items. The following action codes are used in the table:
D - replace with a non-zero length value that may be a dummy value and consistent with the VR
Z - replace with a zero length value, or a non-zero length value that may be a dummy value and consistent with the VR
X - remove
K - keep (unchanged for non-sequence attributes, cleaned for sequences)
C - clean, that is replace with values of similar meaning known not to contain identifying information and consistent with the VR
U - replace with a non-zero length UID that is internally consistent within a set of Instances
Z/D - Z unless D is required to maintain IOD conformance (Type 2 versus Type 1)
X/Z - X unless Z is required to maintain IOD conformance (Type 3 versus Type 2)
X/D - X unless D is required to maintain IOD conformance (Type 3 versus Type 1)
X/Z/D - X unless Z or D is required to maintain IOD conformance (Type 3 versus Type 2 versus Type 1)
X/Z/U* - X unless Z or replacement of contained instance UIDs (U) is required to maintain IOD conformance (Type 3 versus Type 2 versus Type 1 sequences containing UID references)
These action codes are applicable to both Sequence and non-Sequence attributes; in the case of Sequences, the action is applicable to the Sequence and all of its contents. Cleaning a sequence ("C" action) may entail either changing values of attributes within that Sequence when the meaning of the Sequence within the context of its use in the IOD is understood, or recursively applying the profile rules to each Dataset in each Item of the Sequence. Keeping a Sequence ("K" action) requires recursively applying the profile rules to each Dataset in each Item of the Sequence (for example, in order to remap any UIDs contained within that sequence).
A requirement for an Option, when implemented, overrides any requirement for the underlying Profile.
The Attributes listed in Table E.1-1 may not be sufficient to guarantee confidentiality of patient identity. In particular, identifying information may be contained in Private Attributes, new Standard Attributes, Retired Standard Attributes and additional Standard Attributes not present in Standard Composite IODs (as defined in PS3.3) but used in Standard Extended SOP Classes. Table E.1-1 indicates those Attributes that are used in Standard Composite IODs as well as those Attributes that are Retired. Also included in Table E.1-1 are some Elements that are not normally found in a Dataset, but are used in Commands, Directories and Meta Information Headers, but that could be misused within Private Sequences. Textual Content Items of Structured Reports, textual annotations of Presentation States, Curves and Overlays are specifically addressed. It is the responsibility of the de-identifier to ensure that all identifying information is removed.
It should be noted that conformance to an Application Level Confidentiality Profile does not necessarily guarantee confidentiality. For example, if an attacker already has access to the original images, the Pixel Data could be matched, though the probability and impact of such a threat may be deemed to be negligible. If the Encrypted Attributes Sequence is used, it should be understood that any encryption scheme may be vulnerable to attack. Also, an organization's Security Policy and Key Management policy are recognized to have a much greater impact on the effectiveness of protection.
National and local regulations, which may vary, might require that additional attributes be de-identified, though the Profiles and Options have been designed to be sufficient to satisfy known regulations without compromising the usefulness of the de-identified instances for their intended purpose.
Table E.1-1 is normative, but it is subject to extension as the DICOM Standard evolves and other similar Attributes are added to IODs. De-identifiers may take this extensibility into account, for example, by considering handling all dates and times on the basis of their Value Representation of DT, DA or TM, rather than just those date and time Attributes lists.
The Profiles and Options do not specify whether the design of a de-identifier should be to remove what is know to be a risk of identity leakage, or to retain only what is known to be safe. The former approach may fail when the standard is extended, or when a vendor adds unanticipated standard or private attributes, whilst the latter requires an extensive, if not complete, comparison of each instance with the Information Object Definitions in PS3.3 to avoid discarding required or useful information. Table E.1-1 defines the minimum actions required for conformance.
De-identification of Private SOP Classes is not defined.
The "C" (clean) action is specified not only for string VRs, but also for Code Sequences, since the use of private or local codes and non-standard code meanings may potentially cause identity leakage.
The Digital Signatures Sequences needs to be removed because it contains the certificate of the signer; theoretically the signature could be verified and the object re-signed by the de-identifier itself with its own certificate, but this is not required by the Standard.
In general, there are no CS VR Attributes in this table, since it is usually safe to assume that code strings do not contain identifying information.
In general, there are no Code Sequence Attributes in this table, since it is usually safe to assume that coded sequence entries, including private codes, do not contain identifying information. Exceptions are codes for providers and staff.
The Clean Pixel Data and Clean Recognizable Visual Features Options are not listed in this table, since they are defined by descriptions of operations on the Pixel Data itself. The Clean Pixel Data option may be applied to the Pixel Data within the Icon Image Sequence, or more likely the Icon Image Sequence may be recreated entirely once the Pixel Data of the main Dataset has been cleaned. The Icon Image Sequence is to be removed when its Pixel Data cannot be cleaned.
The Original Attributes Sequence (0400,0561) (which in turn contains the Modified Attributes Sequence (0400,0550) ) generally needs to be removed, because it may contain unencrypted copies of other Attributes that may have been modified (e.g., coerced to use local identifiers and names during import of foreign images); an alternative approach would be to selectively modify its contents. This is distinct from the use of the Modified Attributes Sequence (0400,0550) within the Encrypted Attributes Sequence (0400,0500).
Table E.1-1 distinguishes Attributes that are in standard Composite IODs defined in PS3.3 from those that are not; some Attributes are defined in PS3.3 for other IODs, or have a specific usage other than in the top level Dataset of a Composite IOD, but are (mis-) used by implementers in instances as a Standard Extended SOP Class at other levels than as defined by the Standard. Any such Attributes encountered may be removed without compromising the conformance of the instance with the standard IOD. For example, Verifying Observer Sequence (0040,A073) is only defined in structured report IODs and hence is described in Table E.1-1 as D since it is Type 1C; if encountered in an image instance, it should simply be removed (treated as X).
Table E.1-1. Application Level Confidentiality Profile Attributes
Attribute Name |
Tag |
Retired (from PS3.6) |
In Std. Comp. IOD (from PS3.3) |
Basic Profile |
Retain Safe Private Option |
Retain UIDs Option |
Retain Device Ident. Option |
Retain Patient Chars. Option |
Retain Long. Full Dates Option |
Retain Long. Modif. Dates Option |
Clean Desc. Option |
Clean Struct. Cont. Option |
Clean Graph. Option |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Accession Number |
(0008,0050) |
N |
Y |
Z |
|||||||||
Acquisition Comments |
(0018,4000) |
Y |
N |
X |
C |
||||||||
Acquisition Context Sequence |
(0040,0555) |
N |
Y |
X |
C |
||||||||
Acquisition Date |
(0008,0022) |
N |
Y |
X/Z |
K |
C |
|||||||
Acquisition DateTime |
(0008,002A) |
N |
Y |
X/D |
K |
C |
|||||||
Acquisition Device Processing Description |
(0018,1400) |
N |
Y |
X/D |
C |
||||||||
Acquisition Protocol Description |
(0018,9424) |
N |
Y |
X |
C |
||||||||
Acquisition Time |
(0008,0032) |
N |
Y |
X/Z |
K |
C |
|||||||
Actual Human Performers Sequence |
(0040,4035) |
N |
N |
X |
|||||||||
Additional Patient's History |
(0010,21B0) |
N |
Y |
X |
C |
||||||||
Admission ID |
(0038,0010) |
N |
Y |
X |
|||||||||
Admitting Date |
(0038,0020) |
N |
N |
X |
K |
C |
|||||||
Admitting Diagnoses Code Sequence |
(0008,1084) |
N |
Y |
X |
C |
||||||||
Admitting Diagnoses Description |
(0008,1080) |
N |
Y |
X |
C |
||||||||
Admitting Time |
(0038,0021) |
N |
N |
X |
K |
C |
|||||||
Affected SOP Instance UID |
(0000,1000) |
N |
N |
X |
K |
||||||||
Allergies |
(0010,2110) |
N |
N |
X |
C |
C |
|||||||
Arbitrary |
(4000,0010) |
Y |
N |
X |
|||||||||
Author Observer Sequence |
(0040,A078) |
N |
Y |
X |
|||||||||
Branch of Service |
(0010,1081) |
N |
N |
X |
|||||||||
Cassette ID |
(0018,1007) |
N |
Y |
X |
K |
||||||||
Comments on the Performed Procedure Step |
(0040,0280) |
N |
Y |
X |
C |
||||||||
Concatenation UID |
(0020,9161) |
N |
Y |
U |
K |
||||||||
Confidentiality Constraint on Patient Data Description |
(0040,3001) |
N |
N |
X |
|||||||||
Content Creator's Name |
(0070,0084) |
N |
Y |
Z |
|||||||||
Content Creator's Identification Code Sequence |
(0070,0086) |
N |
Y |
X |
|||||||||
Content Date |
(0008,0023) |
N |
Y |
Z/D |
K |
C |
|||||||
Content Sequence |
(0040,A730) |
N |
Y |
X |
C |
||||||||
Content Time |
(0008,0033) |
N |
Y |
Z/D |
K |
C |
|||||||
Context Group Extension Creator UID |
(0008,010D) |
N |
Y |
U |
K |
||||||||
Contrast Bolus Agent |
(0018,0010) |
N |
Y |
Z/D |
C |
||||||||
Contribution Description |
(0018,A003) |
N |
Y |
X |
C |
||||||||
Country of Residence |
(0010,2150) |
N |
N |
X |
|||||||||
Creator Version UID |
(0008,9123) |
N |
Y |
U |
K |
||||||||
Current Patient Location |
(0038,0300) |
N |
N |
X |
|||||||||
Curve Data |
(50xx,xxxx) |
Y |
N |
X |
C |
||||||||
Curve Date |
(0008,0025) |
Y |
Y |
X |
K |
C |
|||||||
Curve Time |
(0008,0035) |
Y |
Y |
X |
K |
C |
|||||||
Custodial Organization Sequence |
(0040,A07C) |
N |
Y |
X |
|||||||||
Data Set Trailing Padding |
(FFFC,FFFC) |
N |
Y |
X |
|||||||||
Derivation Description |
(0008,2111) |
N |
Y |
X |
C |
||||||||
Detector ID |
(0018,700A) |
N |
Y |
X/D |
K |
||||||||
Device Serial Number |
(0018,1000) |
N |
Y |
X/Z/D |
K |
||||||||
Device UID |
(0018,1002) |
N |
Y |
U |
K |
K |
|||||||
Digital Signature UID |
(0400,0100) |
N |
Y |
X |
|||||||||
Digital Signatures Sequence |
(FFFA,FFFA) |
N |
Y |
X |
|||||||||
Dimension Organization UID |
(0020,9164) |
N |
Y |
U |
K |
||||||||
Discharge Diagnosis Description |
(0038,0040) |
Y |
N |
X |
C |
||||||||
Distribution Address |
(4008,011A) |
Y |
N |
X |
|||||||||
Distribution Name |
(4008,0119) |
Y |
N |
X |
|||||||||
Dose Reference UID |
(300A,0013) |
N |
Y |
U |
K |
||||||||
Ethnic Group |
(0010,2160) |
N |
Y |
X |
K |
||||||||
Failed SOP Instance UID List |
(0008,0058) |
N |
N |
U |
K |
||||||||
Fiducial UID |
(0070,031A) |
N |
Y |
U |
K |
||||||||
Filler Order Number / Imaging Service Request |
(0040,2017) |
N |
Y |
Z |
|||||||||
Frame Comments |
(0020,9158) |
N |
Y |
X |
C |
||||||||
Frame of Reference UID |
(0020,0052) |
N |
Y |
U |
K |
||||||||
Gantry ID |
(0018,1008) |
N |
Y |
X |
K |
||||||||
Generator ID |
(0018,1005) |
N |
Y |
X |
K |
||||||||
Graphic Annotation Sequence |
(0070,0001) |
N |
Y |
D |
C |
||||||||
Human Performers Name |
(0040,4037) |
N |
N |
X |
|||||||||
Human Performers Organization |
(0040,4036) |
N |
N |
X |
|||||||||
Icon Image Sequence(see Note 12) |
(0088,0200) |
N |
Y |
X |
|||||||||
Identifying Comments |
(0008,4000) |
Y |
N |
X |
C |
||||||||
Image Comments |
(0020,4000) |
N |
Y |
X |
C |
||||||||
Image Presentation Comments |
(0028,4000) |
Y |
N |
X |
|||||||||
Imaging Service Request Comments |
(0040,2400) |
N |
N |
X |
C |
||||||||
Impressions |
(4008,0300) |
Y |
N |
X |
C |
||||||||
Instance Creator UID |
(0008,0014) |
N |
Y |
U |
K |
||||||||
Institution Address |
(0008,0081) |
N |
Y |
X |
|||||||||
Institution Code Sequence |
(0008,0082) |
N |
Y |
X/Z/D |
|||||||||
Institution Name |
(0008,0080) |
N |
Y |
X/Z/D |
|||||||||
Institutional Department Name |
(0008,1040) |
N |
Y |
X |
|||||||||
Insurance Plan Identification |
(0010,1050) |
Y |
N |
X |
|||||||||
Intended Recipients of Results Identification Sequence |
(0040,1011) |
N |
N |
X |
|||||||||
Interpretation Approver Sequence |
(4008,0111) |
Y |
N |
X |
|||||||||
Interpretation Author |
(4008,010C) |
Y |
N |
X |
|||||||||
Interpretation Diagnosis Description |
(4008,0115) |
Y |
N |
X |
C |
||||||||
Interpretation ID Issuer |
(4008,0202) |
Y |
N |
X |
|||||||||
Interpretation Recorder |
(4008,0102) |
Y |
N |
X |
|||||||||
Interpretation Text |
(4008,010B) |
Y |
N |
X |
C |
||||||||
Interpretation Transcriber |
(4008,010A) |
Y |
N |
X |
|||||||||
Irradiation Event UID |
(0008,3010) |
N |
Y |
U |
K |
||||||||
Issuer of Admission ID |
(0038,0011) |
N |
Y |
X |
|||||||||
Issuer of Patient ID |
(0010,0021) |
N |
Y |
X |
|||||||||
Issuer of Service Episode ID |
(0038,0061) |
N |
Y |
X |
|||||||||
Large Palette Color Lookup Table UID |
(0028,1214) |
Y |
N |
U |
K |
||||||||
Last Menstrual Date |
(0010,21D0) |
N |
N |
X |
K |
C |
|||||||
MAC |
(0400,0404) |
N |
Y |
X |
|||||||||
Media Storage SOP Instance UID |
(0002,0003) |
N |
N |
U |
K |
||||||||
Medical Alerts |
(0010,2000) |
N |
N |
X |
C |
||||||||
Medical Record Locator |
(0010,1090) |
N |
N |
X |
|||||||||
Military Rank |
(0010,1080) |
N |
N |
X |
|||||||||
Modified Attributes Sequence |
(0400,0550) |
N |
N |
X |
|||||||||
Modified Image Description |
(0020,3406) |
Y |
N |
X |
|||||||||
Modifying Device ID |
(0020,3401) |
Y |
N |
X |
|||||||||
Modifying Device Manufacturer |
(0020,3404) |
Y |
N |
X |
|||||||||
Name of Physician(s) Reading Study |
(0008,1060) |
N |
Y |
X |
|||||||||
Names of Intended Recipient of Results |
(0040,1010) |
N |
N |
X |
|||||||||
Occupation |
(0010,2180) |
N |
Y |
X |
C |
||||||||
Operators' Identification Sequence |
(0008,1072) |
N |
Y |
X/D |
|||||||||
Operators' Name |
(0008,1070) |
N |
Y |
X/Z/D |
|||||||||
Original Attributes Sequence |
(0400,0561) |
N |
Y |
X |
|||||||||
Order Callback Phone Number |
(0040,2010) |
N |
N |
X |
|||||||||
Order Entered By |
(0040,2008) |
N |
N |
X |
|||||||||
Order Enterer Location |
(0040,2009) |
N |
N |
X |
|||||||||
Other Patient IDs |
(0010,1000) |
N |
Y |
X |
|||||||||
Other Patient IDs Sequence |
(0010,1002) |
N |
Y |
X |
|||||||||
Other Patient Names |
(0010,1001) |
N |
Y |
X |
|||||||||
Overlay Comments |
(60xx,4000) |
Y |
N |
X |
C |
||||||||
Overlay Data |
(60xx,3000) |
N |
Y |
X |
C |
||||||||
Overlay Date |
(0008,0024) |
Y |
Y |
X |
K |
C |
|||||||
Overlay Time |
(0008,0034) |
Y |
Y |
X |
K |
C |
|||||||
Palette Color Lookup Table UID |
(0028,1199) |
N |
Y |
U |
K |
||||||||
Participant Sequence |
(0040,A07A) |
N |
Y |
X |
|||||||||
Patient Address |
(0010,1040) |
N |
N |
X |
|||||||||
Patient Comments |
(0010,4000) |
N |
Y |
X |
C |
||||||||
Patient ID |
(0010,0020) |
N |
Y |
Z |
|||||||||
Patient Sex Neutered |
(0010,2203) |
N |
Y |
X/Z |
K |
||||||||
Patient State |
(0038,0500) |
N |
N |
X |
C |
C |
|||||||
Patient Transport Arrangements |
(0040,1004) |
N |
N |
X |
|||||||||
Patient's Age |
(0010,1010) |
N |
Y |
X |
K |
||||||||
Patient's Birth Date |
(0010,0030) |
N |
Y |
Z |
|||||||||
Patient's Birth Name |
(0010,1005) |
N |
N |
X |
|||||||||
Patient's Birth Time |
(0010,0032) |
N |
Y |
X |
|||||||||
Patient's Institution Residence |
(0038,0400) |
N |
N |
X |
|||||||||
Patient's Insurance Plan Code Sequence |
(0010,0050) |
X |
|||||||||||
Patient's Mother's Birth Name |
(0010,1060) |
N |
N |
X |
|||||||||
Patient's Name |
(0010,0010) |
N |
Y |
Z |
|||||||||
Patient's Primary Language Code Sequence |
(0010,0101) |
X |
|||||||||||
Patient's Primary Language Modifier Code Sequence |
(0010,0102) |
X |
|||||||||||
Patient's Religious Preference |
(0010,21F0) |
N |
N |
X |
|||||||||
Patient's Sex |
(0010,0040) |
N |
Y |
Z |
K |
||||||||
Patient's Size |
(0010,1020) |
N |
Y |
X |
K |
||||||||
Patient's Telephone Numbers |
(0010,2154) |
N |
N |
X |
|||||||||
Patient's Weight |
(0010,1030) |
N |
Y |
X |
K |
||||||||
Performed Location |
(0040,0243) |
N |
N |
X |
|||||||||
Performed Procedure Step Description |
(0040,0254) |
N |
Y |
X |
C |
||||||||
Performed Procedure Step End Date |
(0040,0250) |
N |
Y |
X |
K |
C |
|||||||
Performed Procedure Step End Time |
(0040,0251) |
N |
Y |
X |
K |
C |
|||||||
Performed Procedure Step ID |
(0040,0253) |
N |
Y |
X |
|||||||||
Performed Procedure Step Start Date |
(0040,0244) |
N |
Y |
X |
K |
C |
|||||||
Performed Procedure Step Start Time |
(0040,0245) |
N |
Y |
X |
K |
C |
|||||||
Performed Station AE Title |
(0040,0241) |
N |
N |
X |
K |
||||||||
Performed Station Geographic Location Code Sequence |
(0040,4030) |
N |
N |
X |
K |
||||||||
Performed Station Name |
(0040,0242) |
N |
N |
X |
K |
||||||||
Performed Station Name Code Sequence |
(0040, 4028) |
N |
N |
X |
K |
||||||||
Performing Physician Identification Sequence |
(0008,1052) |
N |
Y |
X |
|||||||||
Performing Physicians' Name |
(0008,1050) |
N |
Y |
X |
|||||||||
Person Address |
(0040,1102) |
N |
Y |
X |
|||||||||
Person Identification Code Sequence |
(0040,1101) |
N |
Y |
D |
|||||||||
Person Name |
(0040,A123) |
N |
Y |
D |
|||||||||
Person Telephone Numbers |
(0040,1103) |
N |
Y |
X |
|||||||||
Physician Approving Interpretation |
(4008,0114) |
Y |
N |
X |
|||||||||
Physician(s) Reading Study Identification Sequence |
(0008,1062) |
N |
Y |
X |
|||||||||
Physician(s) of Record |
(0008,1048) |
N |
Y |
X |
|||||||||
Physician(s) of Record Identification Sequence |
(0008,1049) |
N |
Y |
X |
|||||||||
Placer Order Number / Imaging Service Request |
(0040,2016) |
N |
Y |
Z |
|||||||||
Plate ID |
(0018,1004) |
N |
Y |
X |
K |
||||||||
Pre-Medication |
(0040,0012) |
N |
N |
X |
C |
||||||||
Pregnancy Status |
(0010,21C0) |
N |
N |
X |
K |
||||||||
Private attributes |
(gggg,eeee) where gggg is odd |
N |
N |
X |
C |
||||||||
Protocol Name |
(0018,1030) |
N |
Y |
X/D |
C |
||||||||
Reason for the Imaging Service Request |
(0040,2001) |
Y |
N |
X |
C |
||||||||
Reason for Study |
(0032,1030) |
Y |
N |
X |
C |
||||||||
Referenced Digital Signature Sequence |
(0400,0402) |
N |
Y |
X |
|||||||||
Referenced Frame of Reference UID |
(3006,0024) |
N |
Y |
U |
K |
||||||||
Referenced General Purpose Scheduled Procedure Step Transaction UID |
(0040,4023) |
Y |
N |
U |
K |
||||||||
Referenced Image Sequence |
(0008,1140) |
N |
Y |
X/Z/U* |
K |
||||||||
Referenced Patient Alias Sequence |
(0038, 0004) |
N |
N |
X |
|||||||||
Referenced Patient Sequence |
(0008,1120) |
N |
Y |
X |
X |
||||||||
Referenced Performed Procedure Step Sequence |
(0008,1111) |
N |
Y |
X/Z/D |
K |
||||||||
Referenced SOP Instance MAC Sequence |
(0400,0403) |
N |
Y |
X |
|||||||||
Referenced SOP Instance UID |
(0008,1155) |
N |
Y |
U |
K |
||||||||
Referenced SOP Instance UID in File |
(0004,1511) |
N |
N |
U |
K |
||||||||
Referenced Study Sequence |
(0008,1110) |
N |
Y |
X/Z |
K |
||||||||
Referring Physician's Address |
(0008,0092) |
N |
N |
X |
|||||||||
Referring Physician's Identification Sequence |
(0008,0096) |
N |
Y |
X |
|||||||||
Referring Physician's Name |
(0008,0090) |
N |
Y |
Z |
|||||||||
Referring Physician's Telephone Numbers |
(0008,0094) |
N |
N |
X |
|||||||||
Region of Residence |
(0010,2152) |
N |
N |
X |
|||||||||
Related Frame of Reference UID |
(3006,00C2) |
N |
Y |
U |
K |
||||||||
Request Attributes Sequence |
(0040,0275) |
N |
Y |
X |
C |
||||||||
Requested Contrast Agent |
(0032,1070) |
N |
N |
X |
C |
||||||||
Requested Procedure Comments |
(0040,1400) |
N |
N |
X |
C |
||||||||
Requested Procedure Description |
(0032,1060) |
N |
Y |
X/Z |
C |
||||||||
Requested Procedure ID |
(0040,1001) |
N |
N |
X |
|||||||||
Requested Procedure Location |
(0040,1005) |
N |
N |
X |
|||||||||
Requested SOP Instance UID |
(0000,1001) |
N |
N |
U |
K |
||||||||
Requesting Physician |
(0032,1032) |
N |
N |
X |
|||||||||
Requesting Service |
(0032,1033) |
N |
N |
X |
|||||||||
Responsible Organization |
(0010,2299) |
N |
Y |
X |
|||||||||
Responsible Person |
(0010,2297) |
N |
Y |
X |
|||||||||
Results Comments |
(4008,4000) |
Y |
N |
X |
C |
||||||||
Results Distribution List Sequence |
(4008,0118) |
Y |
N |
X |
|||||||||
Results ID Issuer |
(4008,0042) |
Y |
N |
X |
|||||||||
Reviewer Name |
(300E,0008) |
N |
Y |
X/Z |
|||||||||
Scheduled Human Performers Sequence |
(0040,4034) |
N |
N |
X |
|||||||||
Scheduled Patient Institution Residence |
(0038,001E) |
Y |
N |
X |
|||||||||
Scheduled Performing Physician Identification Sequence |
(0040,000B) |
N |
N |
X |
|||||||||
Scheduled Performing Physician Name |
(0040,0006) |
N |
N |
X |
|||||||||
Scheduled Procedure Step End Date |
(0040,0004) |
N |
N |
X |
K |
C |
|||||||
Scheduled Procedure Step End Time |
(0040,0005) |
N |
N |
X |
K |
C |
|||||||
Scheduled Procedure Step Description |
(0040,0007) |
N |
Y |
X |
C |
||||||||
Scheduled Procedure Step Location |
(0040,0011) |
N |
N |
X |
K |
||||||||
Scheduled Procedure Step Start Date |
(0040,0002) |
N |
N |
X |
K |
C |
|||||||
Scheduled Procedure Step Start Time |
(0040,0003) |
N |
N |
X |
K |
C |
|||||||
Scheduled Station AE Title |
(0040,0001) |
N |
N |
X |
K |
||||||||
Scheduled Station Geographic Location Code Sequence |
(0040,4027) |
N |
N |
X |
K |
||||||||
Scheduled Station Name |
(0040,0010) |
N |
N |
X |
K |
||||||||
Scheduled Station Name Code Sequence |
(0040,4025) |
N |
N |
X |
K |
||||||||
Scheduled Study Location |
(0032,1020) |
Y |
N |
X |
K |
||||||||
Scheduled Study Location AE Title |
(0032,1021) |
Y |
N |
X |
K |
||||||||
Series Date |
(0008,0021) |
N |
Y |
X/D |
K |
C |
|||||||
Series Description |
(0008,103E) |
N |
Y |
X |
C |
||||||||
Series Instance UID |
(0020,000E) |
N |
Y |
U |
K |
||||||||
Series Time |
(0008,0031) |
N |
Y |
X/D |
K |
C |
|||||||
Service Episode Description |
(0038,0062) |
N |
Y |
X |
C |
||||||||
Service Episode ID |
(0038,0060) |
N |
Y |
X |
|||||||||
Smoking Status |
(0010,21A0) |
N |
N |
X |
K |
||||||||
SOP Instance UID |
(0008,0018) |
N |
Y |
U |
K |
||||||||
Source Image Sequence |
(0008,2112) |
N |
Y |
X/Z/U* |
K |
||||||||
Special Needs |
(0038,0050) |
N |
N |
X |
C |
||||||||
Station Name |
(0008,1010) |
N |
Y |
X/Z/D |
K |
||||||||
Storage Media File-set UID |
(0088,0140) |
N |
Y |
U |
K |
||||||||
Study Comments |
(0032,4000) |
Y |
N |
X |
C |
||||||||
Study Date |
(0008,0020) |
N |