Note |
---|
Info |
REST API method / Метод REST API (настанова) (Сторінка знаходиться в процесі розробки. Інформація на ній може бути застарілою. |
Info |
---|
/wiki/spaces/EN/pages/17591304241 (remove the link block before publishing the document) |
Table of Contents |
---|
Properties of a REST API method document
Page Properties | ||||||||||||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| ||||||||||||||||||||||||||||||||||||||
|
Purpose
This WS allows prequalifying care plan activity in order to define whether the medical program could be applied in this particular case or not.
Процеси роботи з планом лікування (care plan) | Створення первинного призначення плану лікування
Key points
Activity can be prequalified by the employee who has Approval granted by the patient on write Care plan resource
Activity shouldn’t be signed with DS
Logic
Render response with prequalification result in order to define whether the medical program could be applied in this particular case or not.
Configuration parameters
Care Plan dictionaries and configurable parameters_UA | Конфігураційні параметри
Medical Events Dictionaries and configurations | ME_ALLOWED_TRANSACTIONS_LE_TYPES
Dictionaries
eHealth/care_plan_activity_outcomes
...
PROVIDING_CONDITIONS_ALLOWED
INNM_DOSAGE
Input parameters
Description of input parameters
Input parameter | Mandatory | Type | Description | Example | |
---|---|---|---|---|---|
1 | patient_id |
| String | Unique patient identifier. Required |
|
2 | care_plan_id |
| String | Unique Care Plan identifier. Required |
|
Request structure
...
See on API-specification (посилання на сторінку з API-специфікацією)
...
See on API-specification
Expand | |||||
---|---|---|---|---|---|
| |||||
|
Headers
...
...
Request data validation
...
Mandatory
...
Description
...
Example
...
Content-Type
...
application/json
...
M
...
Тип контенту
...
Content-Type:application/json
...
Authorization
...
Bearer {{access_token}}
...
Authorization:Bearer {{access_token}}
...
API-key
...
{{mis_client_secret}}
...
API-key:{{mis_client_secret}}
Request data validation
Authorize
Verify the validity of access token
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 = 'care_plan:write')
Return (403, 'Your scope does not allow to access this resource. Missing allowances: care_plan:write') in case of invalid scope(s)
Validate legal entity
Extract client_id from token
Check legal entity status is ACTIVE
In case of error - return 409 ('client_id refers to legal entity that is not active')
Check legal entity type in ME_ALLOWED_TRANSACTIONS_LE_TYPES config parameter
in case of error - return 409 ('client_id refers to legal entity with type that is not allowed to create medical events transactions')
Validate Care plan
Get Care plan identifier from the URL
Check Care plan:
belongs to patient (from url)
in case of error - return 422 ('Care plan with such id is not found')
is not in final status
in case of error - return 422 ('Invalid care plan status')
Care plan’s period.end >= current date.
in case of error - return 422 ('Care Plan end date is expired')
Validate Patient
Get person_id from URL
Validate patient status is active
in case of error - return 409 ('Person is not active')
If patient is a person - validate patient'sverification_status is not equal to NOT_VERIFIED.
in case NOT_VERIFIED - return error 409, "Patient is not verified"
Validate User
Extract user_id from token.
Check user has an active and approved employee from legal entity (token) that:
has an active Approval granted by the Patient on write the Care plan resource (care plan id from URL)
Return 403 ('Access denied') in case employee has no Approval on write
Check user's employee is from the same legal entity (token) as managing_organisation from the care_plan:
Return 422 ('User is not allowed to create care plan activity for this care plan') in case employee’s legal_entity do not match managing_organisation of related care_plan
Validate activity
Activity should be validated. User fills following fields in the activity:
Validate care plan identifier
As care plan identifier should be contained in signed content, $.care_plan required in the request body.
Check value matches with care plan identifier from URL
in case of error - return 409 ('Care Plan from url does not match to Care Plan ID specified in body')
Validate activity author
Validate value in the field $.author, required
Check employee belongs to the user and legal entity (from token)
Employee is:
an employee who has active Approval on write the Care plan
belongs to user
in case of error - return 422 ('User is not allowed to create care plan activity for the employee')
Validate activity detail
1. Kind
Validate value in the field $.detail.kind, required
Check value in enum: medication_request, service_request
Return 422 ('value is not allowed in enum')
2. Product
Validate value in the field $.detail.product_reference, required
If $detail.kind=medication_request:
Check the value is valid reference on medication resource.
Return 422 ('Cannot refer to service for kind = medication_request')
Check medication:
is active
in case of error - return 422 ('Medication should be active')
type is INNM_DOSAGE
in case of error - return 422 ('Medication does not exist')
Check there is no duplicated activities (status=scheduled, in_progress) with the same medication in the Care plan
Return 422 (“Another activity with status ‘scheduled' or ‘in_progress' already exists in the current Care plan”)
If $.detail.kind=service_request:
Check that value is a reference on service or service_group
Return 422 ('Cannot refer to medication for kind = service_request')
Check service or service_group is active
Return 422 ('<Service/Service group> should be active')
Check there is no activities (status=scheduled, in_progress) with the same service or service_group in the Care plan
Return 422 (“Another activity with status ‘scheduled' or ‘in_progress' already exists in the current Care plan“)
3. Reason code
Validate value in the field $.detail.reason_code, if submitted
Check that value matches with values in
eHealth/ICD10_AM/condition_codes
dictionaryin case of error - return 422 ('value is not allowed in enum')
4. Reason reference
Validate value in the field $.detail.reason_reference, if submitted
Check that value is an array with references of condition, observation, diagnostic report, clinical impression types.
in case of error - return 422 ('value is not allowed in enum')
Check that each reference:
is valid ME
belongs to the patient ($.subject)
in case of error - return 422 ('<medical event type> with such ID is not found')
If $.detail.reason_reference=clinical_impression:
Check that clinical impression is valid based on clinical_impression.code.coding.code and CLINICAL_IMPRESSION_PATIENT_CATEGORIES_<CODE.VALUE>_VALIDITY_PERIOD chart parameter: difference between now() and $.clinical_impression.effective_date_time OR $.clinical_impression.effective_period.end date must be less than a value in chart parameter (pointed in config for a corresponding care plan category) for clinical impression code
in case of error - return 422 ("Clinical impression with patient category exceeds validity period")
Check that clinical impression is based on active rule engine rule (exists record in rule_engine_rules collection with is_active=true, code.code=clinical_impression.code.coding.code, code.system=clinical_impression.code.coding.system)if true - check that clinical impression still corresponds to configured rulein case of error - return 422 (“Clinical impression with patient category does not correspond to rule engine rule“)
if false - skip rule validation
5. Goal
Validate value in the field $.detail.goal, if submitted
Check that value matches with values in
eHealth/care_plan_activity_goals
dictionaryin case of error - return 422 ('value is not allowed in enum')
6. Quantity
Validate value in the field $.detail.quantity, if submitted
Check $.detail.quantity.value is not empty, is fractional, greater than zero
Return 422 schema validation error
...
If $.detail.kind=medication_request:
Check (by schemata) the $.detail.quantity.system field’s value is MEDICATION_UNIT.
Return 422 ('value is not allowed in enum')
Check the $.detail.quantity.code field’s value equals to dosage.denumerator_unit of one of INNMs of a INNM_DOSAGE where innms with is_primary = true
Return 422 ('Code field of quantity object should be equal to denumerator_unit of one of medication’s innms')
If $.detail.kind is other than medication_request:Check the $.detail.quantity.system field is not present.Return 422 ('System field ofquantityobject is not allowed for kind other than medication_request')
Check the $.detail.quantity.code field is not present.Return 422 ('Code field ofquantityobject is not allowed for kind other than medication_request')
If $.detail.kind=service_request:
Check that $.detail.quantity.system field’s value is SERVICE_UNIT, if submitted.
Return 422 ('value is not allowed in enum')
If care plan category is class_23, class_24 or class_25:
Check $.detail.quantity.system and $.detail.quantity.code are set, $.detail.quantity.code = MINUTE
Return 422 ('Code field of quantity object should be in MINUTE for care plan’s category <category code>')
7. Scheduled
If submitted, validate there is one of the $.detail.scheduled_[x] field: scheduled_timing, scheduled_period or scheduled_string.
Return 422 ('Only one of the parameters must be present') in case more then one submitted
...
Validate value with schema of the Period type
in case of error - return 422 schema validation error
Check values within $.CarePlan.Period
in case period.end validation error - return 422 ('Period end time must be within care plan period range, after period start date')
in case period.start validation error - return 422 ('Period start time must be within care plan period range')
8. Location
Validate value in the field $.detail.location, if submitted
Check the value is valid reference on division resource
Check the division is active and division’s legal entity has active status
Return 422 ('Division is not active')
9. Performer
Validate value in the field $.detail.performer, if submitted
Check the value is valid reference o employee resource
Check employee is active and approved
Return 422 ('Invalid employee status')
10. Daily amount
If submitted, check $.detail.daily_amount has the same code and system as quantity field.
Return 422 ('Units of daily_amount field should be equal to units of quantity field')
Validate value in the field $.detail.daily_amount, if submitted.Check activity kind is medication_requestReturn 422 ('Field is allowed for medication request activities only') in case kind is not medication_request
Validate $.detail.daily_amount.system, $.detail.daily_amount.code fields and their values in the object $.detail.daily_amountIf $.detail.kind=medication_request:Check (by schemata) the $.detail.daily_amount.system field’s value is MEDICATION_UNIT.Return 422 ('value is not allowed in enum')
Check the $.detail.daily_amount.code field’s value equals to dosage.denumerator_unit of one of INNMs of a INNM_DOSAGE where innms with is_primary = trueReturn 422 ('Code field ofdaily_amountobject should be equal to denumerator_unit of one of medication’s innms')
If $.detail.kind is other than medication_request:Check the $.detail.daily_amount.system field is not present.Return 422 ('System field ofdaily_amountobject is not allowed for kind other than medication_request')
Check the $.detail.daily_amount.code field is not present.Return 422 ('Code field ofdaily_amountobject is not allowed for kind other than medication_request')
11. Do not perform flag
Validate value in the field $.do_not_perform
Check it is
false
in case of error - return 422 ('not allowed in enum')
12. Status
Validate value in the field $.status
Check it has value = scheduled
in case of error - return 422 ('value is not allowed in enum')
Validate programs
Validate value in the field $.programs
...
If program meets the requirements write status "VALID" according to apiary.
Processing
...
Processing
N/A
Response structure examples
See on API-specification (посилання на сторінку з API-специфікацією)
Description of the REST API response structure, example
Expand | |||||
---|---|---|---|---|---|
| |||||
|
Expand | |||||
---|---|---|---|---|---|
| |||||
|
HTTP status codes
Response code | HTTP Status code | Message | Internal name | Description | |||||
---|---|---|---|---|---|---|---|---|---|
1 | Базові | ||||||||
2 | 3 | 200 | Author’s specialty doesn't allow to create activity with medical program from request | Programs validation error | |||||
43 | 200 | Clinical impression with patient category should be present in request for this medical program | |||||||
54 | 200 | Care plan’s terms of service are not allowed for the medical program | |||||||
65 | 200 | Care plan diagnosis is not allowed for the medical program | |||||||
76 | 200 | Medication is not included in the program | |||||||
87 | 200 | Service is not included in the program | |||||||
98 | 200 | Service group is not included in the program | |||||||
109 | 401 | Invalid access token |
| 11 | 401 | Unauthorized | Помилка підтвердження | ||
1210 | 403 | Access denied |
| ||||||
1311 | 403 | Your scope does not allow to access this resource. Missing allowances: care_plan:write | |||||||
14 | 1000 | 404 | Composition not found | COMPOSITION_NOT_FOUND_404 | Не знайдено медичний висновок | ||||
15 | 12 | 409 | client_id refers to legal entity that is not active | Validation error | |||||
1613 | 409 | client_id refers to legal entity with type that is not allowed to create medical events transactions | |||||||
1714 | 409 | Care Plan from url does not match to Care Plan ID specified in body | |||||||
1815 | 409 | Person is not active | |||||||
1916 | 409 | Patient is not verified | |||||||
2017 | 422 | Another activity with status ‘scheduled' or ‘in_progress' already exists in the current Care plan | |||||||
2118 | 422 | Another activity with status ‘scheduled' or ‘in_progress' already exists in the current Care plan | |||||||
2219 | 422 | Bounds duration must be within care plan period range | |||||||
2320 | 422 | Code field of quantity object should be equal to denumerator_unit of one of medication’s innms | |||||||
2421 | 422 | Code field of quantity object should be in MINUTE for care plan’s category <category code> | |||||||
2522 | 422 | Care Plan end date is expired | |||||||
2623 | 422 | Cannot refer to service for kind = medication_request | |||||||
2724 | 422 | Cannot refer to medication for kind = service_request | |||||||
2825 | 422 | Clinical impression with patient category exceeds validity period | |||||||
2926 | 422 | Care plan with such id is not found | |||||||
3027 | 422 | Division is not active | |||||||
3128 | 422 | Event is not within care plan period range | |||||||
3229 | 422 | Forbidden to create care plan activity for this medication! | |||||||
3330 | |||||||||
3431 | 422 | High must be within care plan period range | |||||||
3532 | 422 | Invalid care plan status | |||||||
3633 | 422 | Invalid employee status | |||||||
3734 | 422 | Low must be within care plan period range, less than high, have the same code as high | |||||||
3835 | 422 | <medical event type> with such ID is not found | |||||||
3936 | 422 | Medication does not exist | |||||||
4037 | 422 | Medication should be active | |||||||
4138 | 422 | not allowed in enum | |||||||
4239 | 422 | Only one of the parameters must be present | |||||||
4340 | 422 | Program not found | |||||||
4441 | 422 | Period end time must be within care plan period range, after period start date | |||||||
4542 | 422 | Period start time must be within care plan period range | |||||||
4643 | 422 | String does not match pattern | |||||||
4744 | 422 | <Service/Service group> should be active | |||||||
4845 | 422 | User is not allowed to create care plan activity for this care plan | |||||||
4946 | 422 | User is not allowed to create care plan activity for the employee | |||||||
5047 | 422 | Units of daily_amount field should be equal to units of quantity field | |||||||
5148 | 422 | Value is not allowed in enum | |||||||
5249 | Специфічні | ||||||||
53 | 422 | Only for active MPI record can be created medication request! | 50 |
Post-processing processes
Description of actions performed on data after processing
Technical modules where the method is used
List of pages describing technical N/A
Technical modules where the method is used
Page Properties Report | ||||
---|---|---|---|---|
|
...