Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Table of Contents

Purpose

This WS allows to get a list of Specimens in patient context. Also, this list can be filtered using search parameters.

Specification

Link

 Apiary

Resource

 api/patients/patient_id/specimens

Scope

 specimen:read

Components

 Specimen

Microservices

 

Protocol type

 REST

Request type

 GET

Sync/Async

 Async

Public/Private/Internal

 Public

Key points

  1. Only authenticated and authorized employee with appropriate scope can get a list of Specimen.

  2. Method returns a list of Specimen that belongs to the specified patient.

  3. List can be filtered by search params.

  4. ABAC rules are used here

Specification

Logic

https://e-health-ua.atlassian.net/wiki/spaces/EH/pages/17629118915/RC.#%D0%9E%D1%82%D1%80%D0%B8%D0%BC%D0%B0%D0%BD%D0%BD%D1%8F-%D1%96%D0%BD%D1%84%D0%BE%D1%80%D0%BC%D0%B0%D1%86%D1%96%D1%97-%D0%97%D1%80%D0%B0%D0%B7%D0%BA%D0%B0-%D0%BF%D1%80%D0%B8-%D0%B2%D0%B7%D0%B0%D1%94%D0%BC%D0%BE%D0%B4%D1%96%D1%97-%D0%B7-%D0%BF%D0%B0%D1%86%D1%96%D1%94%D0%BD%D1%82%D0%BE%D0%BC

Service returns all Specimens related to the patient filtered by submitted parameters:

  • Get all Specimens by subject from specimens collection (MongoDB)

  • Filter list above by submitted search parameters

  • Render a response according to specification with a list of found Specimen entities.

Filters

Filter

Values

Type

Description

Example

status

 https://e-health-ua.atlassian.net/wiki/spaces/EH/pages/17629118869/RC.+Specimen+status+model#Statuses-of-Specimen

String

status of the Specimen

available

type

String

kind of material that forms the Specimen

ABP

registered_by

String

identifier of employee who registered the specimen

ef30f210-5328-4f48-bfe6-c7150d4737a6

collected_date

String

date when Specimen was collected. Matches the date of collected_date_time field or date within collected_period field

2023-12-28

container_identifier

String

identifier of the container in the Specimen

1-ABC-4311

container_type

String

type of the container in the Specimen

tube

parent

String

parent Specimen

9075e0e2-6b57-47fd-aff7-324806efa7e6

request

String

service request identifier linked to the Specimen

7075e0e2-6b57-47fd-aff7-324806efa7e5

Dictionaries

https://e-health-ua.atlassian.net/wiki/spaces/EH/pages/17629119370/RC.+Specimen+dictionaries+and+configurable+parameters#Dictionaries

Request structure

See on Apiary

Authorization

  • Verify the validity of access token

    • in case of error - return 401 “Invalid access token” in case of validation fails

  • Verify that token is not expired

    • in case of error - return 401 “Invalid access token”

  • Check user and client scopes in order to perform this action (scope = 'specimen:read')

    • return 403 “Your scope does not allow to access this resource. Missing allowances: specimen:read” in case of invalid scope(s)

  • Access to the resource is also managed by ABAC module

Request data validation

Validate Patient

  • Get Patient identifier from the URL

  • Check it exists in DB

    • Return 404 ('not found') in case of error

...

  • status

    • filter list by specimen.status

  • type

    • filter list by specimen.type.coding[*].code

  • registered_by.

    • filter list by specimen.registered_by.identifier.value

  • collected_date

    • In depend on what is set, filter by collected_date_time or collected_period field. Do not take time into account.

      • filter list by specimen.collection.collected_date_time.

      • filter within specimen.collection.collected_period, including start and end dates.

  • container_identifier

    • filter list by specimen.container[*].identifier

  • container_type

    • filter list by specimen.container[*].type

  • parent

    • filter list by specimen.parent.identifier.value

  • request

    • filter list by specimen.request[*].identifier.value

Service logic

Service returns all Specimens related to the patient filtered by submitted parameters:

  • Get all Specimens by subject from specimens collection (MongoDB)

  • Filter list above by submitted search parameters

  • Render a response according to specification with a list of found Specimen entities.

Response structure

See on Apiary

HTTP status codes

HTTP status code

Message

What caused the error

200

 

 

401

 Invalid access token

 

403

Your scope does not allow to access this resource. Missing allowances: specimen:read