Оператор соответствия DICOM версии 1
Примечание.
API версии 2 — это последняя версия API, которая должна использоваться вместо версии 1. Дополнительные сведения см. в инструкции о соответствии DICOM версии 2 .
Сервер медицинской визуализации для DICOM® поддерживает подмножество DICOMweb Standard. Поддержка включает:
Кроме того, поддерживаются следующие нестандартные API:
Служба использует управление версиями REST API. Версия REST API должна быть явно указана как часть базового URL-адреса, как показано в следующем примере:
https://<service_url>/v<version>/studies
Эта версия инструкции соответствия соответствует v1
версии REST API.
Сведения о том, как указать версию при выполнении запросов, см. в документации по использованию версий API.
Примеры запросов для поддерживаемых транзакций можно найти в коллекции Postman.
Предварительная очистка
Служба игнорирует предварительное заполнение 128-байтового файла и заменяет его содержимое пустыми символами. Это поведение гарантирует, что никакие файлы, передаваемые через службу, не уязвимы для вредоносной уязвимости. Однако эта предварительная очистка также означает, что преамблирование, используемое для кодирования содержимого двойного формата, например TIFF, нельзя использовать с службой.
Служба исследований
Служба исследований позволяет пользователям хранить, извлекать и искать diCOM Studies, Series и Instances. Мы добавили нестандартную транзакцию Delete, чтобы включить полный жизненный цикл ресурсов.
Store (STOW-RS)
Эта транзакция использует метод POST или PUT для хранения представлений исследований, рядов и экземпляров, содержащихся в полезных данных запроса.
Способ | Путь | Description |
---|---|---|
POST | .. /учёба | Хранить экземпляры. |
POST | .. /studies/{study} | Храните экземпляры для определенного исследования. |
PUT | .. /учёба | Экземпляры Upsert. |
PUT | .. /studies/{study} | Экземпляры Upsert для определенного исследования. |
Параметр study
соответствует атрибуту StudyInstanceUID
DICOM. При указании любой экземпляр, который не принадлежит предоставленному 43265
исследованию, отклоняется с кодом предупреждения.
Поддерживается следующий Accept
заголовок ответа:
application/dicom+json
Поддерживаются следующие Content-Type
заголовки:
multipart/related; type="application/dicom"
application/dicom
Примечание.
Сервер не будет принуждать или заменить атрибуты, конфликтующие с существующими данными для запросов POST. Все данные хранятся как предоставленные. Для запросов upsert (PUT) существующие данные заменяются новыми полученными данными.
Хранение обязательных атрибутов
Следующие элементы DICOM должны присутствовать во всех файлах DICOM, пытающихся храниться:
StudyInstanceUID
SeriesInstanceUID
SOPInstanceUID
SOPClassUID
PatientID
Примечание.
Все идентификаторы пользовательского интерфейса должны находиться в диапазоне от 1 до 64 символов и содержать только буквы-числовые символы или следующие специальные символы: .
, . -
PatientID
проверяется на основе его LO
VR
типа.
Каждый сохраненный файл должен иметь уникальное сочетание StudyInstanceUID
, SeriesInstanceUID
и SopInstanceUID
. Код 45070
предупреждения возвращается, если файл с теми же идентификаторами уже существует.
Принимаются только синтаксисы передачи с явными представлениями значений.
Хранение кодов состояния ответа
Код | Описание |
---|---|
200 (OK) |
Все экземпляры SOP в запросе хранятся. |
202 (Accepted) |
Некоторые экземпляры в запросе хранятся, но другие не удалось. |
204 (No Content) |
Содержимое не было предоставлено в запросе транзакции хранилища. |
400 (Bad Request) |
Запрос был плохо отформатирован. Например, указанный идентификатор экземпляра исследования не соответствовал ожидаемому формату UID. |
401 (Unauthorized) |
Клиент не проходит проверку подлинности. |
403 (Forbidden) |
Пользователь не авторизован. |
406 (Not Acceptable) |
Указанный Accept заголовок не поддерживается. |
409 (Conflict) |
Ни один из экземпляров в запросе транзакции хранилища не был сохранен. |
415 (Unsupported Media Type) |
Предоставленный Content-Type параметр не поддерживается. |
503 (Service Unavailable) |
Служба недоступна или занята. Повторите попытку позже. |
Полезные данные ответа в магазине
Полезные данные ответа заполняют набор данных DICOM следующими элементами.
Тег | Имя | Описание |
---|---|---|
(0008, 1190) | RetrieveURL |
URL-адрес получения исследования, если StudyInstanceUID он был предоставлен в запросе хранилища и по крайней мере один экземпляр успешно хранится. |
(0008, 1198) | FailedSOPSequence |
Последовательность экземпляров, которые не удалось сохранить |
(0008, 1199) | ReferencedSOPSequence |
Последовательность сохраненных экземпляров |
Каждый набор данных в наборе FailedSOPSequence
данных содержит следующие элементы (если файл DICOM, пытающийся сохраниться, может быть прочитан).
Тег | Имя | Описание |
---|---|---|
(0008, 1150) | ReferencedSOPClassUID |
Уникальный идентификатор класса SOP экземпляра, который не удалось сохранить |
(0008, 1155) | ReferencedSOPInstanceUID |
Уникальный идентификатор экземпляра SOP экземпляра, который не удалось сохранить |
(0008, 1197) | FailureReason |
Код причины, почему этот экземпляр не удалось сохранить |
(0074, 1048) | FailedAttributesSequence |
Последовательность ErrorComment , которая включает причину для каждого неудачного атрибута |
Каждый набор данных в наборе ReferencedSOPSequence
данных содержит следующие элементы.
Тег | Имя | Описание |
---|---|---|
(0008, 1150) | ReferencedSOPClassUID |
Уникальный идентификатор класса SOP экземпляра, который не удалось сохранить |
(0008, 1155) | ReferencedSOPInstanceUID |
Уникальный идентификатор экземпляра SOP экземпляра, который не удалось сохранить |
(0008, 1190) | RetrieveURL |
URL-адрес извлечения этого экземпляра на сервере DICOM |
Пример ответа с Accept
заголовком application/dicom+json
:
{
"00081190":
{
"vr":"UR",
"Value":["http://localhost/studies/d09e8215-e1e1-4c7a-8496-b4f6641ed232"]
},
"00081198":
{
"vr":"SQ",
"Value":
[{
"00081150":
{
"vr":"UI","Value":["cd70f89a-05bc-4dab-b6b8-1f3d2fcafeec"]
},
"00081155":
{
"vr":"UI",
"Value":["22c35d16-11ce-43fa-8f86-90ceed6cf4e7"]
},
"00081197":
{
"vr":"US",
"Value":[43265]
}
}]
},
"00081199":
{
"vr":"SQ",
"Value":
[{
"00081150":
{
"vr":"UI",
"Value":["d246deb5-18c8-4336-a591-aeb6f8596664"]
},
"00081155":
{
"vr":"UI",
"Value":["4a858cbb-a71f-4c01-b9b5-85f88b031365"]
},
"00081190":
{
"vr":"UR",
"Value":["http://localhost/studies/d09e8215-e1e1-4c7a-8496-b4f6641ed232/series/8c4915f5-cc54-4e50-aa1f-9b06f6e58485/instances/4a858cbb-a71f-4c01-b9b5-85f88b031365"]
}
}]
}
}
Хранение кодов причин сбоя
Код | Описание |
---|---|
272 |
Транзакция хранилища не сохраняла экземпляр из-за общего сбоя при обработке операции. |
43264 |
Экземпляр DICOM завершился ошибкой проверки. |
43265 |
Предоставленный экземпляр StudyInstanceUID не соответствовал указанному StudyInstanceUID в запросе хранилища. |
45070 |
Экземпляр DICOM с тем же StudyInstanceUID именем SeriesInstanceUID и SopInstanceUID уже хранится. Если вы хотите обновить содержимое, сначала удалите этот экземпляр. |
45071 |
Экземпляр DICOM создается другим процессом или предыдущей попыткой создать сбой, и процесс очистки не завершен. Сначала удалите экземпляр перед попыткой создать еще раз. |
Хранение кодов причин предупреждения
Код | Описание |
---|---|
45063 |
Набор данных экземпляра DICOM не соответствует классу SOP. Транзакция хранилища исследований (раздел 10.5) отметила, что набор данных не соответствует ограничениям класса SOP во время хранения экземпляра. |
Хранение кодов ошибок
Код | Описание |
---|---|
100 |
Предоставленные атрибуты экземпляра не соответствуют критериям проверки. |
Получение (WADO-RS)
Эта транзакция извлекает хранимые исследования, ряды, экземпляры и кадры по ссылке.
Способ | Путь | Description |
---|---|---|
GET | .. /studies/{study} | Извлекает все экземпляры в исследовании |
GET | .. /studies/{study}/метаданные | Извлекает метаданные для всех экземпляров в исследовании |
GET | .. /studies/{study}/series/{series} | Извлекает все экземпляры в серии |
GET | .. /studies/{study}/series/{series}/metadata | Извлекает метаданные для всех экземпляров в серии |
GET | .. /studies/{study}/series/{series}/instances/{instance} | Получение одного экземпляра |
GET | .. /studies/{study}/series/{series}/instances/{instance}/metadata | Извлекает метаданные для одного экземпляра |
GET | .. /studies/{study}/series/{series}/instances/{instance}/rendered | Извлекает экземпляр, отрисованный в формате изображения |
GET | .. /studies/{study}/series/{series}/instances/{instance}/кадры/{кадры} | Извлекает один или несколько кадров из одного экземпляра; Чтобы указать несколько кадров, используйте запятую для разделения каждого кадра для возврата. Например, /studies/1/series/2/instance/3/frames/4,5,6 . |
GET | .. /studies/{study}/series/{series}/instances/{instance}/frame/{frame}/rendered | Извлекает один кадр, отрисованный в формате изображения |
Получение экземпляров в рамках исследования или ряда
Accept
Следующие заголовки поддерживаются для получения экземпляров в рамках исследования или ряда.
multipart/related; type="application/dicom"; transfer-syntax=*
multipart/related; type="application/dicom";
(если синтаксис передачи не указан, 1.2.840.10008.1.2.1 используется в качестве значения по умолчанию)multipart/related; type="application/dicom"; transfer-syntax=1.2.840.10008.1.2.1
multipart/related; type="application/dicom"; transfer-syntax=1.2.840.10008.1.2.4.90
*/*
(если синтаксис передачи не указан,*
используется в качестве значения по умолчанию и mediaType по умолчаниюapplication/dicom
)
Получение экземпляра
Для получения определенного экземпляра поддерживаются следующие Accept
заголовки:
application/dicom; transfer-syntax=*
multipart/related; type="application/dicom"; transfer-syntax=*
application/dicom;
(если синтаксис передачи не указан,1.2.840.10008.1.2.1
используется в качестве значения по умолчанию)multipart/related; type="application/dicom"
(если синтаксис передачи не указан,1.2.840.10008.1.2.1
используется в качестве значения по умолчанию)application/dicom; transfer-syntax=1.2.840.10008.1.2.1
multipart/related; type="application/dicom"; transfer-syntax=1.2.840.10008.1.2.1
application/dicom; transfer-syntax=1.2.840.10008.1.2.4.90
multipart/related; type="application/dicom"; transfer-syntax=1.2.840.10008.1.2.4.90
*/*
(если синтаксис передачи не указан,*
используется в качестве значения по умолчанию и mediaType по умолчаниюapplication/dicom
)
Получение кадров
Для получения кадров поддерживаются следующие Accept
заголовки.
multipart/related; type="application/octet-stream"; transfer-syntax=*
multipart/related; type="application/octet-stream";
(если синтаксис передачи не указан,1.2.840.10008.1.2.1
используется в качестве значения по умолчанию)multipart/related; type="application/octet-stream"; transfer-syntax=1.2.840.10008.1.2.1
multipart/related; type="image/jp2";
(если синтаксис передачи не указан,1.2.840.10008.1.2.4.90
используется в качестве значения по умолчанию)multipart/related; type="image/jp2";transfer-syntax=1.2.840.10008.1.2.4.90
*/*
(если синтаксис передачи не указан,*
используется в качестве значения по умолчанию и mediaType по умолчаниюapplication/octet-stream
)
Получение синтаксиса передачи
Если запрошенный синтаксис передачи отличается от исходного файла, исходный файл перекодируется в запрошенный синтаксис передачи. Исходный файл должен быть одним из следующих форматов для успешного транскодирования, в противном случае перекодирование может завершиться ошибкой.
- 1.2.840.10008.1.2 (маленький неявный эндиан)
- 1.2.840.10008.1.2.1 (маленький эндиан явный)
- 1.2.840.10008.1.2.2 (явный big endian VR)
- 1.2.840.10008.1.2.4.50 (базовый процесс JPEG 1)
- 1.2.840.10008.1.2.4.57 (JPEG Lossless)
- 1.2.840.10008.1.2.4.70 (значение выбора без потери JPEG 1)
- 1.2.840.10008.1.2.4.90 (ТОЛЬКО JPEG 2000 Без потери)
- 1.2.840.10008.1.2.4.91 (JPEG 2000)
- 1.2.840.10008.1.2.5 (RLE Lossless)
Неподдерживаемый transfer-syntax
результат 406 Not Acceptable
.
Получение метаданных (для изучения, ряда или экземпляра)
Accept
Следующий заголовок поддерживается для получения метаданных для исследования, ряда или экземпляра.
application/dicom+json
Получение метаданных не возвращает атрибуты со следующими представлениями значений.
Имя виртуальной реальности | Description |
---|---|
0 Б | Другие байты |
OD | Другие двойные |
OF | Другие плавающие |
OL | Другие длинные |
OV | Другие 64-разрядные очень длинные |
OW | Другое слово |
UN | Неизвестно |
Получение проверки кэша метаданных (для изучения, ряда или экземпляра)
Проверка кэша ETag
поддерживается с помощью механизма. В ответе на запрос метаданных ETag возвращается в качестве одного из заголовков. Этот ETag можно кэшировать и добавить в качестве If-None-Match
заголовка в последующих запросах на те же метаданные. Если существуют данные, возможны два типа ответов:
- Данные не изменяются с момента последнего запроса:
HTTP 304 (Not Modified)
ответ отправляется без текста ответа. - Данные изменились с момента последнего запроса:
HTTP 200 (OK)
ответ отправляется с обновленным ETag. Обязательные данные также возвращаются в составе тела.
Получение отрисованного изображения (для экземпляра или кадра)
Accept
Следующие заголовки поддерживаются для получения отрисованного изображения экземпляра или кадра.
image/jpeg
image/png
В случае, если заголовок не Accept
указан, служба отображается image/jpeg
по умолчанию.
Служба поддерживает отрисовку только одного кадра. Если для экземпляра с несколькими кадрами запрашивается отрисовка, по умолчанию отрисовывается только первый кадр в виде изображения.
При указании определенного кадра для возврата индексирование кадров начинается с 1.
Также quality
поддерживается параметр запроса. Целочисленное значение от 1
100
до инклюзивного (1 является худшим качеством и 100 лучшим качеством) может быть передано в качестве значения параметра запроса. Этот параметр используется для изображений, отображаемых как jpeg
, и игнорируется для запросов на png
отрисовку. Если параметр не указан, параметр по умолчанию используется 100
.
Получение кодов состояния ответа
Код | Описание |
---|---|
200 (OK) |
Извлекаются все запрошенные данные. |
304 (Not Modified) |
Запрошенные данные не были изменены с момента последнего запроса. В этом случае содержимое не добавляется в текст ответа. Дополнительные сведения см. в предыдущем разделе, посвященном извлечению проверки кэша метаданных (для исследования, ряда или экземпляра). |
400 (Bad Request) |
Запрос был плохо отформатирован. Например, указанный идентификатор экземпляра исследования не соответствует ожидаемому формату UID, или запрошенная кодировка синтаксиса передачи не поддерживается. |
401 (Unauthorized) |
Клиент не проходит проверку подлинности. |
403 (Forbidden) |
Пользователь не авторизован. |
404 (Not Found) |
Не удалось найти указанный ресурс DICOM или для отрисованного запроса экземпляр не содержал пиксельных данных. |
406 (Not Acceptable) |
Указанный Accept заголовок не поддерживается или для отрисовки и перекодировки запросов запрошенного файла было слишком большим. |
503 (Service Unavailable) |
Служба недоступна или занята. Повторите попытку позже. |
Поиск (QIDO-RS)
Запрос на основе идентификатора объектов DICOM (QIDO) позволяет искать исследования, ряды и экземпляры по атрибутам.
Способ | Путь | Description |
---|---|---|
Поиск исследований | ||
GET | .. /учёба?... | Поиск исследований |
Поиск ряда | ||
GET | .. /серия?... | Поиск рядов |
GET | .. /studies/{study}/series?... | Поиск ряда в исследовании |
Поиск экземпляров | ||
GET | .. /Экземпляров?... | Поиск экземпляров |
GET | .. /studies/{study}/instances?... | Поиск экземпляров в исследовании |
GET | .. /studies/{study}/series/{series}/instances?... | Поиск экземпляров в серии |
Для поиска поддерживается следующий Accept
заголовок:
application/dicom+json
Поддерживаемые параметры поиска
Поддерживаются следующие параметры для каждого запроса.
Ключ | Значения поддержки | Допустимое число | Description |
---|---|---|---|
{attributeID}= |
{value} |
0...N | Поиск сопоставления атрибутов и значений в запросе |
includefield= |
{attributeID} all |
0...N | Другие атрибуты, возвращаемые в ответе; Поддерживаются как общедоступные, так и частные теги. При all указании. Дополнительные сведения о том, какие атрибуты возвращаются для каждого типа запроса, см. в ответе поиска.Если используется смесь {attributeID} и all предоставляется, сервер по умолчанию используется all . |
limit= |
{value} |
0..1 | Целочисленное значение, ограничивающее количество значений, возвращаемых в ответе; Значение может быть между диапазоном 1 >= x <= 200, по умолчанию равно 100. |
offset= |
{value} |
0..1 | Пропустить {value} результаты; Если смещение больше числа результатов поискового запроса, 204 (no content) возвращается ответ. |
fuzzymatching= |
true / false |
0..1 | Если к атрибуту PatientName применяется истинное нечеткое сопоставление; Он выполняет сопоставление слов префикса любой части имени внутри значения PatientName. Например, если имя пациента — "John^Doe", то "joh", "do", "jo do", "Doe" и "Джон Doe" все совпадение. Однако "ohn" не соответствует. |
Атрибуты, доступные для поиска
Мы поддерживаем поиск следующих атрибутов и типов поиска.
Ключевое слово атрибута | Все исследования | Все серии | Все экземпляры | Серия исследований | Экземпляры исследования | Экземпляры серии исследований |
---|---|---|---|---|---|---|
StudyInstanceUID |
X | X | X | |||
PatientName |
X | X | X | |||
PatientID |
X | X | X | |||
PatientBirthDate |
X | X | X | |||
AccessionNumber |
X | X | X | |||
ReferringPhysicianName |
X | X | X | |||
StudyDate |
X | X | X | |||
StudyDescription |
X | X | X | |||
ModalitiesInStudy |
X | X | X | |||
SeriesInstanceUID |
X | X | X | X | ||
Modality |
X | X | X | X | ||
PerformedProcedureStepStartDate |
X | X | X | X | ||
ManufacturerModelName |
X | X | X | X | ||
SOPInstanceUID |
X | X | X |
Сопоставление поиска
Мы поддерживаем следующие типы сопоставления.
Тип поиска | Поддерживаемый атрибут | Пример |
---|---|---|
Запрос в диапазоне | StudyDate /PatientBirthDate |
{attributeID}={value1}-{value2} . Для значений даты и времени мы поддерживаем инклюзивное диапазон тега, сопоставленное с attributeID >= {value1} AND attributeID <= {value2} . Если {value1} значение не указано, все вхождения дат и времени до и в том числе {value2} совпадают. Аналогичным образом, если {value2} не указано, все вхождения {value1} и последующие даты и время сопоставляются. Однако одно из этих значений должно присутствовать. {attributeID}={value1}- и {attributeID}=-{value2} допустимы, однако, {attributeID}=- недопустимы. |
Точное совпадение | Все поддерживаемые атрибуты | {attributeID}={value1} |
Нечеткий матч | PatientName , ReferringPhysicianName |
Соответствует любому компоненту имени, начинающегося со значения. |
Идентификатор атрибута
Теги можно закодировать несколькими способами для параметра запроса. Мы частично реализовали стандарт, определенный в PS3.18 6.7.1.1.1. Поддерживаются следующие кодировки для тега.
Значение | Пример |
---|---|
{group}{element} |
0020000D |
{dicomKeyword} |
StudyInstanceUID |
Ниже приведен пример поиска экземпляров:
../instances?Modality=CT&00280011=512&includefield=00280010&limit=5&offset=0
Ответ поиска
Ответ представляет собой массив наборов данных DICOM. В зависимости от ресурса возвращаются следующие атрибуты.
Теги изучения по умолчанию
Тег | Имя атрибута |
---|---|
(0008, 0005) | SpecificCharacterSet |
(0008, 0020) | StudyDate |
(0008, 0030) | StudyTime |
(0008, 0050) | AccessionNumber |
(0008, 0056) | InstanceAvailability |
(0008, 0090) | ReferringPhysicianName |
(0008, 0201) | TimezoneOffsetFromUTC |
(0010, 0010) | PatientName |
(0010, 0020) | PatientID |
(0010, 0030) | PatientBirthDate |
(0010, 0040) | PatientSex |
(0020, 0010) | StudyID |
(0020, 000D) | StudyInstanceUID |
Теги серии по умолчанию
Тег | Имя атрибута |
---|---|
(0008, 0005) | SpecificCharacterSet |
(0008, 0060) | Modality |
(0008, 0201) | TimezoneOffsetFromUTC |
(0008, 103E) | SeriesDescription |
(0020, 000E) | SeriesInstanceUID |
(0040, 0244) | PerformedProcedureStepStartDate |
(0040, 0245) | PerformedProcedureStepStartTime |
(0040, 0275) | RequestAttributesSequence |
Теги экземпляра по умолчанию
Тег | Имя атрибута |
---|---|
(0008, 0005) | SpecificCharacterSet |
(0008, 0016) | SOPClassUID |
(0008, 0018) | SOPInstanceUID |
(0008, 0056) | InstanceAvailability |
(0008, 0201) | TimezoneOffsetFromUTC |
(0020, 0013) | InstanceNumber |
(0028, 0010) | Rows |
(0028, 0011) | Columns |
(0028, 0100) | BitsAllocated |
(0028, 0008) | NumberOfFrames |
Если includefield=all
эти атрибуты включены вместе с атрибутами по умолчанию. Вместе с атрибутами по умолчанию это полный список атрибутов, поддерживаемых на каждом уровне ресурсов.
Теги дополнительного исследования
Тег | Имя атрибута |
---|---|
(0008, 1030) | Study Description |
(0008, 0063) | AnatomicRegionsInStudyCodeSequence |
(0008, 1032) | ProcedureCodeSequence |
(0008, 1060) | NameOfPhysiciansReadingStudy |
(0008, 1080) | AdmittingDiagnosesDescription |
(0008, 1110) | ReferencedStudySequence |
(0010, 1010) | PatientAge |
(0010, 1020) | PatientSize |
(0010, 1030) | PatientWeight |
(0010, 2180) | Occupation |
(0010, 21B0) | AdditionalPatientHistory |
Другие теги серии
Тег | Имя атрибута |
---|---|
(0020, 0011) | SeriesNumber |
(0020, 0060) | Laterality |
(0008, 0021) | SeriesDate |
(0008, 0031) | SeriesTime |
Возвращаются следующие атрибуты:
- Все параметры запроса соответствия и идентификаторы пользовательского интерфейса в URL-адресе ресурса.
IncludeField
атрибуты, поддерживаемые на этом уровне ресурсов.- Если целевой ресурс имеет значение
All Series
,Study
то также возвращаются атрибуты уровня. - Если целевой ресурс имеет значение
All Instances
,Study
то такжеSeries
возвращаются атрибуты уровня. - Если целевой ресурс имеет значение
Study's Instances
,Series
то также возвращаются атрибуты уровня. NumberOfStudyRelatedInstances
Агрегированный атрибут поддерживается наStudy
уровнеincludeField
.NumberOfSeriesRelatedInstances
Агрегированный атрибут поддерживается наSeries
уровнеincludeField
.
Коды ответов поиска
API запросов возвращает один из следующих кодов состояния в ответе.
Код | Описание |
---|---|
200 (OK) |
Полезные данные ответа содержат все соответствующие ресурсы. |
204 (No Content) |
Поиск завершился успешно, но не вернул результатов. |
400 (Bad Request) |
Сервер не смог выполнить запрос, так как компонент запроса недействителен. Текст ответа содержит сведения о сбое. |
401 (Unauthorized) |
Клиент не проходит проверку подлинности. |
403 (Forbidden) |
Пользователь не авторизован. |
503 (Service Unavailable) |
Служба недоступна или занята. Повторите попытку позже. |
Другие примечания
- Запросы с помощью не
TimezoneOffsetFromUTC (00080201)
поддерживаются. - API запроса не возвращается
413 (request entity too large)
. Если запрошенное ограничение ответа запроса выходит за пределы допустимого диапазона, возвращается неправильный запрос. Разрешено все запрошенное в допустимом диапазоне. - Если целевой ресурс — Study/Series, существует потенциал для несогласованных метаданных уровня исследования или ряда в нескольких экземплярах. Например, два экземпляра могут иметь разные имена пациентов. В этом случае последние победы и вы можете искать только последние данные.
- Результаты страниц оптимизированы для возврата соответствующего нового экземпляра в первую очередь, это может привести к дублированию записей на последующих страницах, если добавлены новые данные, соответствующие запросу.
- Сопоставление не учитывает регистр и не учитывает акцент для типов виртуальной реальности PN.
- Сопоставление не учитывает регистр и учитывает акцент для других типов виртуальной реальности строки.
- Только первое значение индексируется, если один элемент данных с значением неправильно имеет несколько значений.
Удаление
Эта транзакция не является частью официального DICOMwe Standard. Он использует метод DELETE для удаления представлений исследований, ряда и экземпляров из хранилища.
Способ | Путь | Description |
---|---|---|
DELETE | .. /studies/{study} | Удаление всех экземпляров для определенного исследования |
DELETE | .. /studies/{study}/series/{series} | Удаление всех экземпляров для определенной серии в рамках исследования |
DELETE | .. /studies/{study}/series/{series}/instances/{instance} | Удаление определенного экземпляра в серии |
Параметры study
, series
и instance
соответствуют атрибутам StudyInstanceUID
SeriesInstanceUID
DICOM и SopInstanceUID
соответственно.
Нет ограничений на заголовок, Content-Type
заголовок или текст запросаAccept
.
Примечание.
После транзакции Delete удаленные экземпляры не будут восстановлены.
Коды состояния ответа
Код | Описание |
---|---|
204 (No Content) |
При удалении всех экземпляров SOP |
400 (Bad Request) |
Запрос был плохо отформатирован |
401 (Unauthorized) |
Клиент не проходит проверку подлинности |
403 (Forbidden) |
Пользователь не авторизован |
404 (Not Found) |
Если указанный ряд не найден в исследовании, или указанный экземпляр не найден в пределах ряда. |
503 (Service Unavailable) |
Служба недоступна или занята. Повторите попытку позже. |
Удаление полезных данных ответа
Текст ответа пуст. Код состояния — это единственная полезная информация, возвращаемая.
Служба worklist (UPS-RS)
Служба DICOM поддерживает поставщик услуг push-уведомлений и извлечения служб рабочего списка (UPS-RS). Служба Worklist предоставляет доступ к одному списку, содержаму Workitems, каждому из которых представляется шаг единой процедуры (UPS).
В течение всего переменная {workitem}
в шаблоне URI обозначает идентификатор пользовательского интерфейса Workitem.
Доступные конечные точки UPS-RS включают:
Команда | Путь | Description |
---|---|---|
POST | {s}/workitems{? AffectedSOPInstanceUID} | Создание рабочего элемента |
POST | {s}/workitems/{instance}{?transaction} | Обновить рабочий элемент |
GET | {s}/workitems{?query*} | Поиск рабочих элементов |
GET | {s}/workitems/{instance} | Получение рабочего элемента |
PUT | {s}/workitems/{instance}/state | Изменение состояния рабочего элемента |
POST | {s}/workitems/{instance}/cancelrequest | Отмена рабочего элемента |
POST | {s}/workitems/{instance}/subscription/{AETitle}{?удаление} | Создание подписки |
POST | {s}/workitems/1.2.840.10008.5.1.4.34.5/ | Приостановка подписки |
DELETE | {s}/workitems/{instance}/subscription/{AETitle} | Удаление подписки |
GET | {s}/подписчики/{AETitle} | Открытие канала подписки |
Создание Workitem
Эта транзакция использует метод POST для создания нового Workitem.
Способ | Путь | Description |
---|---|---|
POST | .. /workitems | Создание Workitem |
POST | .. /workitems? {workitem} | Создает Workitem с указанным идентификатором пользовательского интерфейса. |
Если он не указан в URI, полезный набор данных должен содержать Workitem в атрибуте SOPInstanceUID
.
В Accept
запросе требуются заголовки и Content-Type
должны иметь значение application/dicom+json
.
Существует несколько требований, связанных с атрибутами данных DICOM в контексте конкретной транзакции. Атрибуты могут быть обязательными, обязательными для того, чтобы не присутствовать, быть пустыми или не должны быть пустыми. Эти требования можно найти в этой таблице.
Примечание.
Хотя в справочной таблице указано, что идентификатор пользовательского интерфейса экземпляра SOP не должен присутствовать, это руководство зависит от протокола DIMSE и обрабатывается по-разному в DICOMWeb. Идентификатор пользовательского интерфейса экземпляра SOP должен присутствовать в наборе данных, если не в URI.
Примечание.
Все коды условных требований, включая 1C и 2C, рассматриваются как необязательные.
Создание кодов состояния ответа
Код | Описание |
---|---|
201 (Created) |
Целевой workitem успешно создан. |
400 (Bad Request) |
Возникла проблема с запросом. Например, полезные данные запроса не соответствуют требованиям. |
401 (Unauthorized) |
Клиент не проходит проверку подлинности. |
403 (Forbidden) |
Пользователь не авторизован. |
409 (Conflict) |
Workitem уже существует. |
415 (Unsupported Media Type) |
Предоставленный Content-Type параметр не поддерживается. |
503 (Service Unavailable) |
Служба недоступна или занята. Повторите попытку позже. |
Создание полезных данных ответа
Ответ успешного выполнения не содержит полезных данных. Заголовки Location
и Content-Location
заголовки ответов содержат ссылку URI на созданный Workitem.
Полезные данные ответа на сбои содержат сообщение, описывающее сбой.
Отмена запроса
Эта транзакция позволяет пользователю запрашивать отмену неовладельцированного Workitem.
Существует четыре допустимых состояния Workitem.
SCHEDULED
IN PROGRESS
CANCELED
COMPLETED
Эта транзакция выполняется только в отношении Workitems в SCHEDULED
состоянии. Любой пользователь может претендовать на владение Workitem, задав пользовательский интерфейс транзакции и изменив его состояние IN PROGRESS
на . После этого пользователь может изменить только Workitem, предоставив правильный пользовательский интерфейс транзакции. Хотя UPS определяет классы Watch и Event SOP, которые позволяют пересылать запросы на отмену и другие события, эта служба DICOM не реализует эти классы и поэтому запросы на отмену на рабочих объектах, которые IN PROGRESS
возвращают сбой. Принадлежащий Workitem можно отменить с помощью транзакции "Изменить состояние Workitem".
Способ | Путь | Description |
---|---|---|
POST | .. /workitems/{workitem}/cancelrequest | Запрос на отмену запланированного workitem |
Заголовок Content-Type
является обязательным и должен иметь значение application/dicom+json
.
Полезные данные запроса могут содержать сведения о действии, как определено в стандарте DICOM.
Коды состояния ответа отмены запроса
Код | Описание |
---|---|
202 (Accepted) |
Запрос был принят сервером, но состояние Target Workitem не изменилось. |
400 (Bad Request) |
Возникла проблема с синтаксисом запроса. |
401 (Unauthorized) |
Клиент не проходит проверку подлинности. |
403 (Forbidden) |
Пользователь не авторизован. |
404 (Not Found) |
Целевой workitem не найден. |
409 (Conflict) |
Запрос не согласуется с текущим состоянием target Workitem. Например, target Workitem находится в SCHEDULED состоянии или COMPLETED состоянии. |
415 (Unsupported Media Type) |
Предоставленный Content-Type параметр не поддерживается. |
Полезные данные ответа на отмену запроса
Ответ успешного выполнения не содержит полезных данных, а полезные данные ответа на сбои содержат сообщение, описывающее сбой.
Если экземпляр Workitem уже находится в отмененном состоянии, ответ содержит следующий заголовок предупреждения HTTP: 299: The UPS is already in the requested state of CANCELED.
Получение Workitem
Эта транзакция извлекает Workitem. Он соответствует операции UPS DIMSE N-GET.
См: https://dicom.nema.org/medical/dicom/current/output/html/part18.html#sect_11.5
Если Workitem существует на исходном сервере, workitem возвращается в допустимом типе мультимедиа. Возвращаемый workitem не будет содержать атрибут UID транзакции (0008 1195). Это необходимо для сохранения роли атрибута в качестве блокировки доступа.
Способ | Путь | Description |
---|---|---|
GET | .. /workitems/{workitem} | Запрос на получение Workitem |
Заголовок Accept
является обязательным и должен иметь значение application/dicom+json
.
Получение кодов состояния ответа Workitem
Код | Описание |
---|---|
200 OK; | Экземпляр Workitem успешно получен. |
400 (недопустимый запрос) | Возникла проблема с запросом. |
401 (Не авторизовано) | Клиент не проходит проверку подлинности. |
403 (Forbidden (Запрещено)) | Пользователь не авторизован. |
404 (не найдено) | Целевой workitem не найден. |
Получение полезных данных ответа Workitem
- Ответ успешного выполнения содержит одну часть полезных данных, содержащую запрошенный Workitem в выбранном типе мультимедиа.
- Возвращаемый Workitem не будет содержать атрибут UID транзакции (0008, 1195), так как это должно быть известно только владельцу.
Обновление Workitem
Эта транзакция изменяет атрибуты существующего Workitem. Он соответствует операции UPS DIMSE N-SET.
См: https://dicom.nema.org/medical/dicom/current/output/html/part18.html#sect_11.6
Чтобы обновить Workitem в настоящее время в SCHEDULED
состоянии, Transaction UID
атрибут не должен присутствовать. Для Workitem в IN PROGRESS
состоянии запрос должен включать текущий пользовательский интерфейс транзакции в качестве параметра запроса. Если Workitem уже находится в COMPLETED
или CANCELED
состояниях, ответ равен 400 (Bad Request)
.
Способ | Путь | Description |
---|---|---|
POST | .. /workitems/{workitem}? {transaction-uid} | Обновление транзакции Workitem |
Заголовок Content-Type
является обязательным и должен иметь значение application/dicom+json
.
Полезные данные запроса содержат набор данных с изменениями, которые будут применены к целевому Workitem. При изменении последовательности запрос должен включать все элементы в последовательность, а не только элементы, которые необходимо изменить. Если необходимо обновить несколько атрибутов в виде группы, выполните обновление в виде нескольких атрибутов в одном запросе, а не в виде нескольких запросов.
Существует множество требований, связанных с атрибутами данных DICOM в контексте конкретной транзакции. Атрибуты могут быть обязательными, обязательными для того, чтобы не присутствовать, быть пустыми или не должны быть пустыми. Эти требования можно найти в этой таблице.
Примечание.
Все коды условных требований, включая 1C и 2C, рассматриваются как необязательные.
Примечание.
Запрос не может задать значение атрибута "Состояние шага процедуры" (0074 1000). Состояние шага процедуры управляется с помощью транзакции "Изменение состояния" или транзакции "Отмена запроса".
Обновление кодов состояния отклика транзакций Workitem
Код | Описание |
---|---|
200 (OK) |
Объект Target Workitem был обновлен. |
400 (Bad Request) |
Возникла проблема с запросом. Например: (1) Target Workitem был в COMPLETED состоянии или CANCELED состоянии. (2) Отсутствует идентификатор пользовательского интерфейса транзакции. (3) Идентификатор пользовательского интерфейса транзакции неверный. (4) Набор данных не соответствовал требованиям. |
401 (Unauthorized) |
Клиент не проходит проверку подлинности. |
403 (Forbidden) |
Пользователь не авторизован. |
404 (Not Found) |
Целевой workitem не найден. |
409 (Conflict) |
Запрос не согласуется с текущим состоянием target Workitem. |
415 (Unsupported Media Type) |
Предоставленный Content-Type параметр не поддерживается. |
Обновление полезных данных ответа на транзакцию Workitem
Сервер-источник поддерживает поля заголовков в таблице 11.6.3-2.
Ответ успешного выполнения не содержит полезных данных или полезных данных, содержащих документ отчета о состоянии.
Полезные данные ответа на сбои могут содержать отчет о состоянии, описывающий любые сбои, предупреждения или другие полезные сведения.
Изменение состояния Workitem
Эта транзакция используется для изменения состояния Workitem. Он соответствует операции UPS DIMSE N-ACTION "Изменение состояния UPS". Изменения состояния используются для утверждения владения, завершения или отмены Workitem.
См: https://dicom.nema.org/medical/dicom/current/output/html/part18.html#sect_11.7
Если Workitem существует на исходном сервере, workitem возвращается в допустимом типе мультимедиа. Возвращенный Workitem не будет содержать атрибут UID транзакции (0008 1195). Это необходимо для сохранения роли этого атрибута в качестве блокировки доступа, как описано здесь.
Способ | Путь | Description |
---|---|---|
PUT | .. /workitems/{workitem}/state | Изменение состояния Workitem |
Заголовок Accept
является обязательным и должен иметь значение application/dicom+json
.
Полезные данные запроса содержат элементы данных состояния Change UPS. Эти элементы данных:
- UiD транзакции (0008, 1195) Полезные данные запроса включают идентификатор пользовательского интерфейса транзакции. Агент пользователя создает идентификатор пользовательского интерфейса транзакции при запросе перехода к
IN PROGRESS
состоянию для заданного Workitem. Агент пользователя предоставляет идентификатор пользовательского интерфейса транзакции в последующих транзакциях с этим Workitem. - Состояние шага процедуры (0074, 1000) Юридические значения соответствуют запрошенному переходу состояния. Они:
IN PROGRESS
,COMPLETED
илиCANCELED
.
Изменение кодов состояния ответа состояния Workitem
Код | Описание |
---|---|
200 (OK) |
Экземпляр Workitem успешно получен. |
400 (Bad Request) |
Запрос нельзя выполнить по одной из следующих причин. (1) Запрос недействителен, учитывая текущее состояние target Workitem. (2) Отсутствует идентификатор пользовательского интерфейса транзакции. (3) Идентификатор пользовательского интерфейса транзакции является неверным |
401 (Unauthorized) |
Клиент не проходит проверку подлинности. |
403 (Forbidden) |
Пользователь не авторизован. |
404 (Not Found) |
Целевой workitem не найден. |
409 (Conflict) |
Запрос не согласуется с текущим состоянием target Workitem. |
Изменение полезных данных ответа о состоянии Workitem
- Ответы включают поля заголовка, указанные в разделе 11.7.3.2.
- Ответ успешного выполнения не содержит полезных данных.
- Полезные данные ответа на сбои могут содержать отчет о состоянии, описывающий любые сбои, предупреждения или другие полезные сведения.
Поиск Workitems
Эта транзакция позволяет выполнять поиск Workitems по атрибутам.
Способ | Путь | Description |
---|---|---|
GET | .. /workitems? | Поиск Workitems |
Accept
Следующий заголовок поддерживается для поиска.
application/dicom+json
Поддерживаемые параметры поиска
Поддерживаются следующие параметры для каждого запроса.
Атрибуты, доступные для поиска
Мы поддерживаем поиск по этим атрибутам.
Ключевое слово атрибута |
---|
PatientName |
PatientID |
ReferencedRequestSequence.AccessionNumber |
ReferencedRequestSequence.RequestedProcedureID |
ScheduledProcedureStepStartDateTime |
ScheduledStationNameCodeSequence.CodeValue |
ScheduledStationClassCodeSequence.CodeValue |
ScheduledStationGeographicLocationCodeSequence.CodeValue |
ProcedureStepState |
StudyInstanceUID |
Сопоставление поиска
Мы поддерживаем эти типы сопоставления.
Тип поиска | Поддерживаемый атрибут | Пример |
---|---|---|
Запрос в диапазоне | ScheduledProcedureStepStartDateTime |
{attributeID}={value1}-{value2} . Для значений даты и времени мы поддерживаем инклюзивное диапазон тега. Это сопоставлено с attributeID >= {value1} AND attributeID <= {value2} . Если {value1} значение не указано, все вхождения дат и времени до и в том числе {value2} совпадают. Аналогичным образом, если {value2} не указано, все вхождения {value1} и последующие даты и время сопоставляются. Однако одно из этих значений должно присутствовать. {attributeID}={value1}- и {attributeID}=-{value2} допустимы, однако, {attributeID}=- недопустимы. |
Точное совпадение | Все поддерживаемые атрибуты | {attributeID}={value1} |
Нечеткий матч | PatientName |
Соответствует любому компоненту имени, начинающегося со значения |
Примечание.
Хотя мы не поддерживаем полное сопоставление последовательности, мы поддерживаем точное соответствие атрибутов, перечисленных в последовательности.
Идентификатор атрибута
Теги можно закодировать различными способами для параметра запроса. Мы частично реализовали стандарт, определенный в PS3.18 6.7.1.1.1. Поддерживаются следующие кодировки для тега.
Значение | Пример |
---|---|
{group}{element} |
00100010 |
{dicomKeyword} |
PatientName |
Пример запроса:
../workitems?PatientID=K123&0040A370.00080050=1423JS&includefield=00404005&limit=5&offset=0
Ответ поиска
Ответ представляет собой массив 0...N
наборов данных DICOM со следующими атрибутами:
- Все атрибуты в DICOM PowerShell 3.4 Table CC.2.5-3 с типом возвращаемого ключа 1 или 2.
- Все атрибуты в DICOM PowerShell 3.4 Table CC.2.5-3 с типом возвращаемого ключа 1C, для которого выполняются условные требования.
- Все остальные атрибуты Workitem передаются в качестве параметров соответствия.
- Все остальные атрибуты Workitem, передаваемые в качестве
includefield
значений параметров.
Коды ответов поиска
API запросов возвращает один из следующих кодов состояния в ответе.
Код | Описание |
---|---|
200 (OK) |
Полезные данные ответа содержат все соответствующие ресурсы. |
206 (Partial Content) |
Полезные данные ответа содержат только некоторые результаты поиска, а остальные можно запросить с помощью соответствующего запроса. |
204 (No Content) |
Поиск завершился успешно, но не вернул результатов. |
400 (Bad Request) |
Возникла проблема с запросом. Например, недопустимый синтаксис параметра запроса. Текст ответа содержит сведения о сбое. |
401 (Unauthorized) |
Клиент не проходит проверку подлинности. |
403 (Forbidden) |
Пользователь не авторизован. |
503 (Service Unavailable) |
Служба недоступна или занята. Повторите попытку позже. |
Другие заметки
API запроса не возвращается 413 (request entity too large)
. Если запрошенное ограничение ответа запроса выходит за пределы допустимого диапазона, возвращается неправильный запрос. Разрешено все запрошенное в допустимом диапазоне.
- Результаты страниц оптимизированы для возврата соответствующего нового экземпляра, что может привести к дублированию записей на последующих страницах, если добавлены новые данные, соответствующие запросу.
- Сопоставление не учитывает регистр и не учитывает акцент для типов виртуальной реальности PN.
- Сопоставление не учитывает регистр и учитывает акцент для других типов виртуальной реальности строки.
- Если есть сценарий, в котором отмена Workitem и запрос одного и того же Workitem происходит одновременно, запрос, скорее всего, исключает workitem, который обновляется, и код ответа.
206 (Partial Content)
Примечание.
DICOM® является зарегистрированным товарным знаком Национальной ассоциации производителей электрических технологий для публикаций по стандартам, касающихся цифровых коммуникаций медицинской информации.