Ціль
Даний веб-сервіс розроблений для створення запиту на рецепт
Є два види запиту на рецепт:
plan - Запит відображає намір на формування мед. препаратів без необхідності підтвердження дії. Рецепт з типом план не може бути відпущений та тільки надає інструкцію для адміністрування мед препаратів.
order - Запит відображає намір запиту/вимоги авторизації на дію. Рецепт з типом запит може бути відпущений
Специфікація
Основні положення
Тільки автентифіковані та авторизовані користувачі з відповідним скоупом може створити запит на рецепт (MRR)
Пацієнт повинен зберігатися в захешованому виді у відповідності до вимог безпеки.
Авторизація
Перевірити валідність токену доступу
в разі помилки - повернути 401 (“Invalid access token”) в разі невалідних валідацій
Перевірити, що токен дійсний
в разі помилки - повернути 401 (“Invalid access token”)
Перевірити скоупи користувача (scope = 'medication_request_request:write') на можливість виконання даної дії
в разі помилки - надіслати у відповіді код 401
Якщо BLOCK_UNVERIFIED_PARTY_USERS є true, тоді перевірити дані співробітника на свіпадіння наступним умовам: verification_status != NOT_VERIFIED або (verification_status = NOT_VERIFIED та updated_at <= current_date - UNVERIFIED_PARTY_PERIOD_DAYS_ALLOWED):
в разі неспівпадіння - повернути 403 ("Access denied. Party is not verified")
Перевірки
Перевірка поля container_dosage
$.container_dosage - розмір первинної упаковки лікарських засобів, який запитаний лікарем або тим, хто створив рецепт, для відпуску пацієнту.
Перевірити поле $.container_dosage згідно схеми
$.container_dosage.code та $.container_dosage.value повинні бути заповнені
в разі помилки повернути 422 ("required property %{property} was not present")
$.container_dosage.system повинен бути “MEDICATION_UNIT”
в разі помилки повернути 422 ("value is not allowed in enum")
Перевірити пріорітет
Перевірити по схемі, що $.priority заповнений значення зі словника MEDICATION_REQUEST_PRIORITY
в разі помилки повернути 422 ("value is not allowed in enum")
Перевірити prior_prescription
Перевірити, що $.prior_prescription це UUID, наявний та належить персоні:
is_active = true, та та ж персона.
в разі помилки повернути - 422 (message: "Prior prescription is not found")
Перевірити співробітника
Ціль валідації: Перевірити співробітника на можливість створення рецепту.
Отримати employee_id з запиту
Перевірити співробітника
На існування
в разі помилки повернути код 422 з повідомленням ("Employee not found")
Перевірити, що $.employees.status == APPROVED
в разі помилки повернути код 409 з повідомленням ("Employee is not active")
Перевірити, що $.employees.legal_entity_id == client_id from token
в разі помилки повернути код 422 з повідомленням ("Employee does not belong to legal entity from token")
якщо medical_program_id є в запиті перевірити medical_program_settings.skip_employee_validation == false (або відсутня), то перевірити <employee_type>:
перевірити, що employee_type вказано в змінній medical_program_settings.employee_types_for_create_medication_request
в разі помилки повернути код 422 з повідомленням ("Employee type can't create medication request with medical program from request")
в разі employee_type = DOCTOR
якщо змінна skip_medication_request_employee_declaration_verify = false або null/absent
то: отримати $.declarations по employee_id, person_id, status=ACTIVE
якщо не знайдено - повернути помилку 422 "Only doctors with an active declaration with the patient can create medication request with medical program from request!"
в іншому випадку пропустити верифікацію декларації на рівні співробітника (якщо true)
якщо змінна skip_medication_request_legal_entity_declaration_verify = false або null/absent
то: get $.declarations по employee's legal_entity_id, person_id, status=ACTIVE
якщо не знайдено - повернути помилку 422 "Only legal entity with an active declaration with the patient can create medication request with medical program from request!"
в іншому випадку пропустити верифікацію декларації на рівні співробітника (якщо true)
якщо обидва true - пропустити верифікацію декларації взагалі
в разі employee_type = SPECIALIST
отримати $.employees.speciality.speciality(speciality_officio == true)
перевірити, що спеціалізація вказана для змінної $.medical_programs.medical_program_setting.speciality_types_allowed
в разі неуспішної перевірки - помилка 422 з повідомленням ("Employee's specialty doesn't allow create medication request with medical program from request")
якщо employee_type = MED_COORDINATOR
пропустити валідації, що спеціалізація присутня в змінній $.medical_programs.medical_program_setting.speciality_types_allowed
якщо medical_program_settings.skip_employee_validation == true або відсутня medical_program_id в запиті, будь-який користувач, який має скоуп може створити запит на рецепт
Перевірити підрозділ
Ціль валідації: Перевірити підрозділ на можливість створення рецепту.
Отримати Get division details
Перевірити division_id - division_id існує
в разі помилки направити код 422 з повідомленням ("Division not found")
Перевірити Response $.data.status==ACTIVE
якщо не знайдено - повернути код 422 (повідомлення: "Only employee of active divisions can create medication request!")
Підрозділ повинен бути активним або посилатися на поточну legal_entity
is_active = true
status = 'ACTIVE'
division.legal_entity_id = client_id (context)
Перевірити юридичну особу
Ціль перевірки: Перевірити юридичну особу на можливість створенна рецепту.
Отримати client_id з токену
Перевірити client_id=legal_entity_id
перевірити, що юридична особа існує
в разі помилки повернути код 422 з повідомленням (422 Legal entity not found)
перевірити, що legal_entities.status == ACTIVE
в разі помилки повернути код 422 з повідомленням ("Only active legal entity can provide medication request")
перевірити тип юридичної особи згідно з чарт параметрами MEDICATION_REQUEST_REQUEST_LEGAL_ENTITY_TYPES
в разі помилки повернути код 409 з повідомленням (“Invalid legal entity type“)
Перевірити персону
Ціль перевірки: Перевірити персону на можливість створення рецепту.
Отримати Get patient by ID
Перевірити, що person_id - mpi_id існують
в разі помилки повернути код 422 (422 Person not found)
Зберегти перемінні параметри з: $.data.authentication_methods
Перевірити відповідь $.data.is_active==TRUE
якщо не знайдено - повернути помилку з кодом 422 (повідомлення: "Only for active MPI record can be created medication request!")
Первірити статус верифікації персони:
Якщо MRR має based_on з валідною активністю, пропустити перевірку.
В іншому випадку перевірити, що verification_status не рівний NOT_VERIFIED.
в разі NOT_VERIFIED - повернути помилку 409, "Patient is not verified"
Перевірити дати
created_at - схожа з датою погодженя FHIR -> Актуальній даті створення рецепту
inserted_at - дата, коли рецепт був створений в E-Health
started_at/ended_at - Період лікування. Не може бути меньше ніж дата закінчення MR. Визначається лікарем.
dispence_valid_from - Використовується для перевірки відпуску. Аналогічно для дат створення.
dispense_valid_to - Вказує на дату закінчення строку відпуску. Якщо MR має вказані налаштування по програмі з заповненим параметром medication_dispense_period_day, то dispence_valid_from + medication_dispense_period_day, в іншому випадку відпуск валідний з + medication_dispense_period значення глобального параметру.
Ціль валідації: Повинна бути: ended_at >= started_at >= created_at
Перевірити, що created_at, started_at, ended_at в форматі дати
в разі помилки повернути код 422 в повідомленні ("expected \"%{actual}\" to be a valid ISO 8601 date")
Перевірити ended_at >= started_at
якщо помилка - повернути код 422 (повідомлення: "Ended date must be >= Started date!")
Перевірити started_at` >= created_at
якщо помилка - повернути код 422 (повідомлення: "Started date must be >= Created date!")
Перевірити started_at >= current_date()
якщо помилка - повернути код 422 (повідомлення: "Started date must be >= current date!")
Перевірити created_at >= current_date() - mrr_delay_input
якщо помилка - повернути код 422 (повідомлення: "Create date must be = current date!")
Перевірити started_at у відповідності до частоти отримання препаратів
отримати $.medical_programs.medical_program_setting по medical_program_id з запиту
перевірити параметр skip_mnn_in_treatment_period
в разі skip_mnn_in_treatment_period == FALSE (or absent)
перевірити запит на відповідність: PreQualify Medication request#2.Checkabsencethesamemedicationsfortheprograms
в разі skip_mnn_in_treatment_period == TRUE
пропустити перевірку періодичності отримання препаратів
Перевірити created_at у відповідності до періодичності отримання препаратів
отримати $.medical_programs.medical_program_setting по medical_program_id з запиту
перевірити параметр skip_mnn_in_treatment_period
в разі skip_mnn_in_treatment_period == FALSE (або відсутня)
перевірити запит у відповідності до логіки: PreQualify Medication request#2.Checkabsencethesamemedicationsfortheprograms
в разі skip_mnn_in_treatment_period == TRUE
пропустити перевірку періодичності отримання препаратів
Перевірити тривалість періоду (ended_at - started_at):
Якщо медична программа була вказана:
перевірити запит на відповідність логіки: PreQualify Medication request: 7. Validate period
в іншому випадку:
Перевірити, що період рецепту меньше або дорівнює MEDICATION_REQUEST_MAX_PERIOD_DAY параментру з чартів
в разі помилки - повернути код 409 “Period length exceeds default maximum value“
Перевірити препарат
Ціль валідації: Перевірити FK, status `is_active`=TRUE, type = INNM_DOSAGE
Отримати Get INNM Dosage by ID
Перевірити, що medication_id - medication_id існує
в разі помилки повернути код 422 ("Medication not found")
Перевірити код відповіді == 200
в разі помилки - повернути код 422 (повідомлення: "Only medication with type `INNM_DOSAGE` can be use for created medication request!")\
Перевірити відповідь $.is_active==TRUE
якщо не знайдено - повернути код 422 (повідомлення: "Only active innm_dosage can be use for created medication request!")
Перевірити контекст
Перевірити наявність "context" в запиті
у разу помилки повернути код 422 “required property context was not present“
Перевірити "context" це активна сутність (не entered-in-error) з відповідного довідника, який належить поточному пацієнту
Перевірити context.identifier.type.coding[0].code = encounter
в разі помилки повернути код 422 ("value is not allowed in enum")
Перевірити на наявність в колекції сутності $.data.context.identifier.type.coding[0].code з id == $.data.context.identifier.value , який належить поточному пацієнту
в разі помилки повернути код 422 "Entity not found"
Перевірити, що сутність не в статусі "entered-in-error"
в разі помилки повернути код 422 "Entity in status "entered-in-error" can not be referenced"
Діагнози взаємодії заповнені в $.encounter.diagnosis
в разі помилки повернути код 422 ("Encounter without diagnosis can not be referenced")
Перевірити інструкцію дозування
Кожний не порожній атрибут повинен бути валідним та посилатися на відповідний довідник або об'єкт
Послідовність повинна бути унікальна включаючи масив інстркцій дозування
в разі помилки повернути код (422, "Sequence must be unique")
Додаткова інструкція повинна посилатися на валідний довідник
$.dosage_instruction[*].additional_instruction.coding[*].system == "eHealth/SNOMED/additional_dosage_instructions"
$.dosage_instruction[*].additional_instruction.coding[*].code це валідне значення в довіднику "eHealth/SNOMED/additional_dosage_instructions"
в разі помилки повернути код 409 "Incorrect additional instruction"
Місце має посилатися на валдіний довідник
$.dosage_instruction[*].site.coding[*].system == "eHealth/SNOMED/anatomical_structure_administration_site_codes"
$.dosage_instruction[*].site.coding[*].code це валідне місце в довіднику "eHealth/SNOMED/anatomical_structure_administration_site_codes"
в разі помилки повернути код 409 "Incorrect site"
Шлях повинен посилатися на валідний довідник
$.dosage_instruction[*].route.coding[*].system == "eHealth/SNOMED/route_codes"
$.dosage_instruction[*].route.coding[*].code це валідне місце в довіднику "eHealth/SNOMED/route_codes"
в разі помилки повернути код 409 "Incorrect route"
Метод повинен посилатися на валідний довідник
$.dosage_instruction[*].method.coding[*].system == "eHealth/SNOMED/administration_methods"
$.dosage_instruction[*].method.coding[*].code це валідне місце в довіднику "eHealth/SNOMED/administration_methods"
в разі помилки повернути код 409 "Incorrect method"
Дозування та тип дозування повинні посилатися на валідний довідник
$.dosage_instruction[*].dose_and_rate.type.coding[*].system == "eHealth/SNOMED/dose_and_rate"
$.dosage_instruction[*].dose_and_rate.type.coding[*].code це валідне місце в довіднику "eHealth/SNOMED/dose_and_rate"
в разі помилки повернути код 409 "Incorrect dose and rate type"
Перевірити based_on
Якщо вказано, перевірити, що поле є масивом з двома значеннями типу Reference: одна - це валідний ресурс плану лікування, інший - ресурс активності.
Перевірити План лікування:
Від повинен належати тій же персоні, що і набір в MRR
в разі помилки повернути код 422 з повідомленням ("Care plan not found")
Від повинен бути в статусі active
Перевірити вказану активність:
Вона відповідає Плану лікування.
в разі помилки повернути код 422 з повідомленням ("Activity not found")
Вона має activity.detail.kind=medication_request; activity.detail.product_reference=medication_id.
в разі помилки повернути код 422 з повідомленням ("Invalid activity kind")
Вона має статус scheduled, in_progress
Якщо вона має quantity порахувати remaining quantity:
вибрати всі MRR в статусі NEW які створені на основі даної активності
вибрати всі MR в статусах ACTIVE, COMPLETED які створені на основі даної активності
порахувати зарезервовану на сьогодні кількість, як суму medication_qty у профільтрованому MRR та MR списку, включаючи medication_qty з поточного MRR
порахувати вказану кількість шляхом віднімання зарезервованої кількості з кількості активностей
Перевірити remaining quantity більше або дорівнює 0
в разі помилки повернути код 409 "The total amount of the prescribed medication quantity exceeds quantity in care plan activity"
перевірити, що medical_program_id дорівнює $.activity[].program
в разі помилки повернути код 422 з повідомленням ("Medical program from activity should be equal to medical program from request")
Перевірити started_at/ended_at для запиту рецепту:
Якщо активність плану лікування має detail.scheduled_timing.repeat.bounds_period - перевірити started_at/ended_at включаючи bounds_period
Якщо план активності має detail.scheduled_period - перевірити started_at/ended_at включаючи scheduled_period
в іншому випадку - перевірити started_at/ended_at у межах care_plan.period
у випадку якщо started_at/ended_at не в межах care_plan.period повернути код 422 з повідомленням ("Invalid care plan period")
Перевірити медичну програму
Перевірити наявність medical_program_id в реквесті
у разі помилки повернути код 422 (“required property medical_program_id was not present“)
Перевірити, що medical_program_id - medical_program_id існує
в разі помилки повернути код 422 ("Medical program not found")
Перевірити параметри medical_programs.medical_program_setting
перевірити, що care_plan_required == true тоді запит повинен містити based_on на план лікування і активність, що містять ту ж програму
в разі помилки повернути код 422 з повідомленням ("Care plan and activity with the same medical program should be present in request")
Якщо вказано параметр CONDITIONS_ICD10_AM_ALLOWED, то:
Перевірити що первинні діагнози зі взаємодії в контексті має код з довідника eHealth/ICD10_AM/condition_codes
Перевірити, що код діагнозу з CONDITIONS_ICD10_AM_ALLOWED
в разі помилки - повернути 422 “Encounter in context has no primary diagnosis allowed for the medical program“
Якщо вказано параметр CONDITIONS_ICPC2_ALLOWED, то:
Перевірити що первинні діагнози зі взаємодії в контексті має код з довідника eHealth/ICPC2/condition_codes
Перевірити, що код діагнозу з CONDITIONS_ICPC2_ALLOWED
в разі помилки - повернути 422 “Encounter in context has no primary diagnosis allowed for the medical program“
Якщо програма має funding_source = LOCAL , викликати валідації як описано для https://e-health-ua.atlassian.net/wiki/spaces/EPRx/pages/16981065737/PreQualify+Medication+request+request+modified+EN#11.-Check-provision-for-a-programs
Перевірити множинність & дозвіл на рецепт для участика
Виконати перевірки як описано для https://e-health-ua.atlassian.net/wiki/spaces/EH/pages/583405343/PreQualify+Medication+request+EN#1.-Check-INNM-complience-for-the-programs.
Виконати перевірки як описано
PreQalify Medication Request: Check absence the same medications for the programs.
Сервісна логіка
Згенерувати номер & verification_code для рецепту
Згенерувати читабельний номер для рецепту (See specs)
Structure number XXXX-1234-5678-9012-345-C , where: - XXXX - series: numbers + only some letters (A, E, H, K, M, P, T, X) - 1234-5678-9012-345 - randomly generated numbers - C - checksum: Should be calculated using the Damn algorithm or Verhoeff algorithm After new Request number was generated we should check that it is unique in the DB (entity: medication_request + medication_request_request
Згенерувати verification_code для MPI.person_authentication_methods == OTP або OFFLINE
Structure code 1234, where: - 1234 - randomly generated numbers
Створити запит на рецепт
встановити:
dispense_valid_from = created_at
dispensed_valid_to = dispensed_valid_from + dispense_period
Заповнити структуру 'data' для відповіді & зберегти в IL.medication_request_requests
якщо взаємодія наявна в контексті запита на основі якого створений рецепт - заповнити IL.medication_request_requests.context_episode_id
Заповнити окремо
data_employee_id,
data_intent,
data_based_on_care_plan_id,
data_based_on_activity_id,
data_context_id,
data_patient_id,
data_legal_entity_id
Згенерувати контекст для відповіді
Згенерувати структуру даних з структури відповіді WS
Встановити IL.medication_request_requests даної структури
в разі валідності відповіді VALID збагатити відповідь даними з urgent_data:
отримати authetification_method по person_id та повернути замаскований номер (а разі будь якого)
"urgent": { "authentication_method_current": { "type": "OTP", "number": "+38093*****85" } }