/
Create full medication registry (NHS Admin)

ЕСОЗ - публічна документація

Create full medication registry (NHS Admin)

Purpose

The service is designed for uploading new medication registry. The process uses the jabba service. Upon execution of the request, a job is created, on the basis of which tasks are created. Each task is one request to create entity from registry.

Key points

  1. This is a REST API method that is used by Administrators until ETL module is in eHealth system cluster.

    1. It is method of multi-part type

  2. Only authenticated and authorized NHS employee with appropriate scope can create full medication registry.

  3. Full medication registry file should be in .csv format.

Specification

Link

https://uaehealthapi.docs.apiary.io/#reference/internal.-nhs-admin/uploading-and-processing-registries/post-medication-registry

Посилання на Apiary або Swagger

Resource

api/registries/medications/

Посилання на ресурс, наприклад: /api/persons/create

Scope

medication_registry:write

Scope для доступу

Components

ePrescription

Зазначається перелік бізнес компонентів, які використовують цей метод, наприклад: ePrescription

Microservices

API paragraph not found

Перелік мікросервісів, які використовує метод API, наприклад: Auth, ABAC

Protocol type

REST

Тип протоколу, який використовується запитом, наприклад: SOAP | REST

Request type

POST

Тип запиту API, наприклад: GET, POST, PATCH…

Sync/Async

Async

Метод є синхронним чи асинхронним?

Public/Private/Internal

Internal

Потрібно зазначити тип методу за ступенем доступності

Logic

Service logic, validations and creation of records - please see details in GraphQL mutation specification

Request structure

Example:

---BOUNDARY Content-Disposition: form-data; name="reason_description" Доповнення переліку антибіотиків ---BOUNDARY Content-Disposition: form-data; name="csv_data"; filename="filename.csv" Content-Type: text/plain ---BOUNDARY--

Authorize

  • 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 scopes in order to perform this action (scope = 'medication_registry:write')

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

Headers

Наприклад:

Content-Type:multipart/form-data;boundary=---BOUNDARY

Authorization:Bearer c2778f3064753ea70de870a53795f5c9

Request data validation

Validate request

  1. Check request using schema

    1. Return 422 with the list of validation errors in case validation fails

  2. Check csv_data input according to file structure

    1. Return 422 with the list of validation errors in case validation fails

  3. Check csv_data input file size - csv file with max 30k lines is allowed.

    1. Return 422 The number of tasks for the job with a sequential execution strategy is limited to 30,000 in case validation fails

 

File example

Please see examples in GraphQL mutation specification

Processing

API paragraph not found

Response structure

Example:

{ "meta": { "code": 200, "url": "https://example.com/resource", "type": "object", "request_id": "6617aeec-15e2-4d6f-b9bd-53559c358f97#17810" }, "data": { "job": { "id": "11ecabef-5b67-4838-8f4c-72155e05dd12", "name": "Name of operation with the registry", "type": "type_of_operation", "strategy": "SEQUENTIALLY", "status": "PENDING", "meta": { "register_type": "REGISTER_TYPE", "reason_description": "appropriate text" }, "ended_at": "2022-08-21T15:37:40.625778Z", "inserted_at": "2022-08-21T15:35:38.625778Z", "updated_at": "2022-08-21T15:37:40.625778Z" } } }

Post-processing processes

API paragraph not found

HTTP status codes

HTTP status code

Message

What caused the error

HTTP status code

Message

What caused the error

 200

 Response

 

 401

 Invalid access token

 

403

Your scope does not allow to access this resource. Missing allowances: medication_registry:write

 

422

 

Validation error

ЕСОЗ - публічна документація