The STOW-RS Service defines one action type. An implementation shall support the following action type:
Store Instances
This action creates new resources for the given SOP Instances on the Server or appends to existing resources on the Server.
All request messages are HTTP/1.1 multipart messages. The organization of SOP Instances into message parts depends on whether the SOP Instances are structured as PS3.10 binary instances, or metadata and bulk data.
PS3.10 binary instances shall be encoded with one message part per DICOM Instance.
Metadata and bulk data requests will be encoded in the following manner:(see Figure 6.5-1 Mapping between IOD and HTTP message parts):
All XML request messages shall be encoded as described in the Native DICOM Model defined in PS3.19 with one message part per XML object.
All JSON requests shall be encoded as an array of DICOM JSON Model Objects defined in Annex F.
Uncompressed bulk and pixel data shall be encoded in a Little Endian format using the application/octet-stream media type with one message part per bulk data item.
Compressed pixel data shall be encoded in one of two ways:
Single-frame pixel data encoded using a single-frame media type (one message part)
Multi-frame or video pixel data encoded using a multi-frame media type (multiple frames in one message part)
Compressed pixel data shall be encoded using the Media Types as described in Table 6.5-1 WADO-RS Media Type Mapping to Transfer Syntax UID. Media Types corresponding to several DICOM Transfer Syntax UIDs may require a transfer-syntax parameter to disambiguate the request.
HTTP Request field Content-Type is used in the header lines by the client in an HTTP/1.1 transaction to indicate the type of data being sent to the Service. All lines are RFC822 or RFC2616 format headers. All HTTP header fields whose use is not defined by STOW-RS shall have the meaning defined by the HTTP standard.
The Service is required to support uncompressed bulk and pixel data (multipart/related; type= application/octet-stream).
This action stores one or more DICOM instances associated with one or more study instance unique identifiers (SUID). The request message can be DICOM or metadata and bulk data depending on the"Content-Type", and is encapsulated in a multipart request body.
The specific Service resource to be used for the Store Instances action shall be as follows:
Resource
{SERVICE}/studies[/{StudyInstanceUID}], where
{SERVICE} is the base URL for the service. This may be a combination of scheme (either HTTP or HTTPS), host, port, and application.
{StudyInstanceUID} (optional) is the study instance UID for a single study. If not specified, instances can be from multiple studies. If specified, all instances shall be from that study; instances not matching the StudyInstanceUID shall be rejected.
Method
POST
Headers
Content-Type - The representation scheme being posted to the RESTful service. The types allowed for this request header are as follows:
multipart/related; type=application/dicom; boundary={messageBoundary}
Specifies that the post is PS3.10 binary instances. All STOW-RS providers must accept this Content-Type.
multipart/related; type=application/dicom+xml; boundary={messageBoundary}
Specifies that the post is PS3.19 XML metadata and bulk data. All STOW-RS providers must accept this Content-Type.
multipart/related; type=application/json; boundary={messageBoundary}
Specifies that the post is DICOM JSON metadata and bulk data. A STOW-RS provider may optionally accept this Content-Type.
It is not necessary that the study referenced by the StudyInstanceUID in the resource (and in the provided instances) exists on the server, however it is necessary that it be a valid UID. The client may have obtained an appropriate UID from elsewhere or generated it as described in 9 in PS3.5 and B in PS3.5 .
The DICOM Request Message has a multipart body.
Content-Type:
multipart/related; type=application/dicom; boundary={MessageBoundary}
The multipart request body contains every instance to be stored. Each instance is in a separate part of the multipart body.
Each part in the multipart body represents a DICOM SOP Instance with the following HTTP headers:
Content-Type: application/dicom
The XML Metadata and Bulk Data Request Message has a multipart body.
Content-Type:
multipart/related; type=application/dicom+xml; boundary={MessageBoundary}
The multipart request body contains all the metadata and bulk data to be stored. If the number of bulk data parts does not correspond to the number of unique BulkDataURIs in the metadata then the entire message is invalid and will generate an error status line.
Each body part is either DICOM PS3.19 XML metadata or a bulk data item from a SOP Instance sent as part of the Store operation. The first part of the multipart message must be XML metadata.
The first part in the multipart request will contain the following HTTP headers:
Content-Type: application/dicom+xml; transfer-syntax={TransferSyntaxUID}
Subsequent items will contain the following HTTP headers (order is not guaranteed):
additional metadata with the following headers:
Content-Type: application/dicom+xml; transfer-syntax={TransferSyntaxUID}
an uncompressed bulk data element encoded in Little Endian binary format with the following headers:
Content-Type: application/octet-stream
Content-Location: {BulkDataURI}
a compressed pixel data object from a SOP Instance in the Study with the following headers:
Content-Type: {MediaType}
Content-Location: {BulkDataURI}
Metadata and its associated bulk data shall always be sent in the same POST request.
It is not intended that metadata and bulk data be stored separately in multiple POST requests since the service always requires the metadata for context.
The JSON Metadata and Bulk Data Request Message has a multipart body.
Content-Type:
multipart/related; type=application/json; boundary={MessageBoundary}
The multipart request body contains all the metadata and bulk data to be stored. If the number of bulk data parts does not correspond to the number of unique BulkDataURIs in the metadata then the entire message is invalid and will generate an error status line.
The first part in the multipart request will contain a JSON array of DICOM JSON Model Objects (defined in Annex F). Each array element is the metadata from a SOP Instance sent as part of the Store operation. This message part will have the following headers:
Content-Type: application/json; transfer-syntax={TransferSyntaxUID}
Subsequent items will be one of the following:
an uncompressed bulk data element encoded in Little Endian binary format with the following headers:
Content-Type: application/octet-stream
Content-Location: {BulkDataURI}
a compressed pixel data object from a SOP Instance in the Study with the following headers:
Content-Type: {MediaType}
Content-Location: {BulkDataURI}
JSON Metadata and its associated bulk data shall always be sent in the same POST request.
It is not intended that metadata and bulk data be stored separately in multiple POST requests since the service always requires the metadata for context.
The Service may coerce or replace values of attributes such as Patient Name, ID, Accession Number, for example, during import of media from an external institution, reconciliation against a master patient index, or reconciliation against an imaging procedure order. The Service may correct, or replace incorrect values, such as Patient Name or ID, for example, when incorrect worklist item was chosen or operator input error occurs.
If any element is coerced or corrected, the Original Attribute Sequence (0400,0561) shall be included in the DICOM Object that is stored and may be included in the PS3.18 XML Store Instances Response Module in the response.
For more information on populating the Original Attribute Sequence, see Section C.12.1 “SOP Common Module” in PS3.3 .
The RESTful Service shall return an HTTP status line, including a status code and associated textual phrase for the entire set of stored SOP Instances, followed by a message body containing the Store Instances Response Module as defined in Table 6.6.1-2. The message body shall be encoded as either:
If the status for all instances included in the POST request is Success, the RESTful Service shall return an "HTTP 200 - Success" response code.
If the status for all instances included in the POST request is Failure, the RESTful Service shall return an appropriate failure status line with a response code from Table 6.6.1-1. If there are instance specific errors, the response code shall be a 409 and the response payload shall contain the Store Instances Response Module, which contains additional information regarding instance errors.
In all other conditions, the RESTful Service shall return an "HTTP 202 - Accepted" response code. The response payload may contain a Store Instances Response Module, which specifies additional information regarding instance warnings or failures.
Table 6.6.1-1. HTTP/1.1 Standard Response Code
|
Service Status |
HTTP/1.1 Status Codes |
STOW-RS Description |
|---|---|---|
|
Failure |
400 - Bad Request |
This indicates that the STOW-RS Service was unable to store any instances due to bad syntax. |
|
401 - Unauthorized |
This indicates that the STOW-RS Service refused to create or append any instances because the client is not authorized. |
|
|
403 - Forbidden |
This indicates that the STOW-RS Service understood the request, but is refusing to fulfill it (e.g., an authorized user with insufficient privileges). |
|
|
409 - Conflict |
This indicates that the STOW-RS Service request was formed correctly but the service was unable to store any instances due to a conflict in the request (e.g., unsupported SOP Class or StudyInstanceUID mismatch). This may also be used to indicate that a STOW-RS Service was unable to store any instances for a mixture of reasons. Additional information regarding the instance errors can be found in the XML response message body. |
|
|
415 - Unsupported Media Type |
This indicates that the STOW-RS Service does not support the Content-Type specified in the storage request (e.g., the service does not support JSON metadata). |
|
|
503 - Busy |
This indicates that the STOW-RS Service was unable to store any instances because it was out of resources. |
|
|
Warning |
202 - Accepted |
This indicates that the STOW-RS Service stored some of the instances but warnings or failures exist for others. Additional information regarding this error can be found in the XML response message body. |
|
Success |
200 - OK |
This indicates that the STOW-RS Service successfully stored all the instances. |
HTTP Status Codes for Failures and Warnings are returned in HTTP response headers. It is recommended that the text returned in the HTTP Response Warning contain a DICOM Status Code and descriptive reason as defined in Section 6.6.1.3.2.1. For example,
Warning: "A700: Out of memory"
The message body shall provide appropriate status codes for individual SOP Instances indicating success, warning, or failure as defined below.
The message body may also include details about the processing of attributes by the service.
Table 6.6.1-2 defines the Attributes for referencing SOP Instances that are contained in a Store Instances Response Module in the response message body.
Table 6.6.1-2. Store Instances Response Module Attributes
|
Attribute Name |
Tag |
Type |
Attribute Description |
|---|---|---|---|
|
Retrieve URL |
(0008,1190) |
2 |
The URL where the Study is available for retrieval via a WADO-RS Retrieve Study service. |
|
Failed SOP Sequence |
(0008,1198) |
1C |
A sequence of Items where each Item references a single SOP Instance for which storage could not be provided. Required if one or more SOP Instances failed to store. |
|
>Table 10-11 “SOP Instance Reference Macro Attributes” in PS3.3 |
|||
|
>Failure Reason |
(0008,1197) |
1 |
The reason that storage could not be provided for this SOP Instance. |
|
Referenced SOP Sequence |
(0008,1199) |
1C |
A sequence of Items where each Item references a single SOP Instance that was successfully stored. Required if one or more SOP Instances were successfully stored. |
|
>Table 10-11 “SOP Instance Reference Macro Attributes” in PS3.3 |
|||
|
>Retrieve URL |
(0008,1190) |
2 |
The URL where the SOP Instance is available for retrieval via a WADO-URI or WADO-RS service. If the study Retrieve URI is specified above, this URI can be constructed if the client knows the series and instance UIDs. |
|
>Warning Reason |
(0008,1196) |
1C |
The reason that this SOP Instance was accepted with warnings. Required if there was a warning for this SOP Instance. |
|
>Original Attributes Sequence |
(0400,0561) |
3 |
Sequence of Items containing all attributes that were removed or replaced by other values. One or more Items are permitted in this sequence. |
|
>>Attribute Modification DateTime |
(0400,0562) |
1 |
Date and time the attributes were removed and/or replaced. |
|
>>Modifying System |
(0400,0563) |
1 |
Identification of the system that removed and/or replaced the attributes. |
|
>>Reason for the Attribute Modification |
(0400,0565) |
1 |
Reason for the attribute modification. Defined terms are: COERCE = Replace values of attributes such as Patient Name, ID, Accession Number, for example, during import of media from an external institution, or reconciliation against a master patient index. CORRECT = Replace incorrect values, such as Patient Name or ID, for example, when incorrect worklist item was chosen or operator input error. |
|
>>Modified Attributes Sequence |
(0400,0550) |
1 |
Sequence that contains all the Attributes, with their previous values, that were modified or removed from the main data set. Only a single Item shall be included in this sequence. |
|
>>Any Attribute from the main data set that was modified or removed; may include Sequence Attributes and their Items. |
|||
For the following semantics the associated value shall be used for the Warning Reason (0008,1196):
The STOW-RS Service modified one or more data elements during storage of the instance. See Section 6.6.1.3.
The STOW-RS Service discarded some data elements during storage of the instance. See Section 6.6.1.3.
The STOW-RS Service observed that the Data Set did not match the constraints of the SOP Class during storage of the instance.
Additional codes may be used for the Warning Reason (0008,1196) to address the semantics of other issues.
In the event that multiple codes may apply, the single most appropriate code shall be used.
For the following semantics the associated value shall be used for the Failure Reason (0008,1197). Implementation specific warning and error codes shall be defined in the conformance statement:
The STOW-RS Service did not store the instance because it was out of resources.
The STOW-RS Service did not store the instance because the instance does not conform to its specified SOP Class.
The STOW-RS Service did not store the instance because it cannot understand certain Data Elements.
The STOW-RS Service did not store the instance because it does not support the requested Transfer Syntax for the instance.
The STOW-RS Service did not store the instance because of a general failure in processing the operation.
The STOW-RS Service did not store the instance because it does not support the requested SOP Class.
Additional codes may be used for the Failure Reason (0008,1197) to address the semantics of other issues.
In the event that multiple codes may apply, the single most appropriate code shall be used.
The following is an example of a PS3.18 XML Store Instances Response Module in the response message body containing 2 failed SOP Instances, 1 successful SOP Instance, and 1 accepted SOP Instance with a warning:
<?xml version="1.0" encoding="utf-8"?>
<NativeDicomModel xmlns="http://dicom.nema.org/PS3.19/models/NativeDICOM"
xsi:schemaLocation="http://dicom.nema.org/PS3.19/models/NativeDICOM"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<DicomAttribute tag="00081198" vr="SQ" keyword="FailedSOPSequence">
<Item number="1">
<DicomAttribute tag="00081150" vr="UI" keyword="ReferencedSOPClassUID">
<Value number="1">1.2.840.10008.3.1.2.3.1</Value>
</DicomAttribute>
<DicomAttribute tag="00081155" vr="UI"
keyword="ReferencedSOPInstanceUID">
<Value number="1">
2.16.124.113543.6003.1011758472.49886.19426.2085542308</Value>
</DicomAttribute>
<DicomAttribute tag="00081197" vr="US" keyword="FailureReason">
<Value number="1">290</Value>
</DicomAttribute>
</Item>
<Item number="2">
<DicomAttribute tag="00081150" vr="UI" keyword="ReferencedSOPClassUID">
<Value number="1">1.2.840.10008.3.1.2.3.1</Value>
</DicomAttribute>
<DicomAttribute tag="00081155" vr="UI"
keyword="ReferencedSOPInstanceUID">
<Value number="1">
2.16.124.113543.6003.1011758472.49886.19426.2085542309</Value>
</DicomAttribute>
<DicomAttribute tag="00081197" vr="US" keyword="FailureReason">
<Value number="1">290</Value>
</DicomAttribute>
</Item>
</DicomAttribute>
<DicomAttribute tag="00081199" vr="SQ" keyword="ReferencedSOPSequence">
<Item number="1">
<DicomAttribute tag="00081150" vr="UI" keyword="ReferencedSOPClassUID">
<Value number="1">1.2.840.10008.5.1.4.1.1.2</Value>
</DicomAttribute>
<DicomAttribute tag="00081155" vr="UI"
keyword="ReferencedSOPInstanceUID">
<Value number="1">
2.16.124.113543.6003.189642796.63084.16748.2599092903</Value>
</DicomAttribute>
<DicomAttribute tag="00081190" vr="UT" keyword="RetrieveURL">
<Value number="1">
https://wadors.hospital.com/studies/2.16.124.113543.6003.1154777499.30246.19789.3503430045/
series/2.16.124.113543.6003.2588828330.45298.17418.2723805630/
instances/2.16.124.113543.6003.189642796.63084.16748.2599092903</Value>
</DicomAttribute>
</Item>
<Item number="2">
<DicomAttribute tag="00081150" vr="UI" keyword="ReferencedSOPClassUID">
<Value number="1">1.2.840.10008.5.1.4.1.1.2</Value>
</DicomAttribute>
<DicomAttribute tag="00081155" vr="UI"
keyword="ReferencedSOPInstanceUID">
<Value number="1">
2.16.124.113543.6003.189642796.63084.16748.2599092905</Value>
</DicomAttribute>
<DicomAttribute tag="00081196" vr="US" keyword="WarningReason">
<Value number="1">45056</Value>
</DicomAttribute>
<DicomAttribute tag="00081190" vr="UT" keyword="RetrieveURL">
<Value number="1">
https://wadors.hospital.com/studies/2.16.124.113543.6003.1154777499.30246.19789.3503430045/
series/2.16.124.113543.6003.2588828330.45298.17418.2723805630/
instances/2.16.124.113543.6003.189642796.63084.16748.2599092905</Value>
</DicomAttribute>
</Item>
</DicomAttribute>
<DicomAttribute tag="00081190" vr="UT" keyword="RetrieveURL">
<Value number="1">
https://wadors.hospital.com/studies/2.16.124.113543.6003.1154777499.30246.19789.3503430045</Value>
</DicomAttribute>
</NativeDicomModel>