ЕСОЗ - публічна документація
RC_(CSI-1323)_Approve merge request
- 1 Purpose
- 2 Specification
- 3 Service logic
- 4 Authentication
- 5 Validate schema
- 6 Validate merge request
- 7 Validate legal entity
- 8 Validate person
- 9 Validate confidant person relationship
- 10 Validate preperson
- 11 Determine authorization method
- 12 Get preperson episodes
- 13 Generate printout form
- 14 Update object in DB
Purpose
This WS serves for receiving approval from person on action of merge with preperson.
Specification
Service logic
Only authenticated and authorized SPECIALIST, ASSISTANT or RECEPTIONIST employees can use this WS.
Usage of this WS allowed in EMERGENCY or OUTPATIENT legal entities.
Person should confirm merge with preperson by auth method chosen on create patient request or create declaration request processes.
The request can be approved only by employee who made the request.
Change status should be logged in the Event manager.
Authentication
Verify the validity of access token
Return 401 in case validation fails
Check user scopes in order to perform this action (scope = 'merge_request:write')
Return 403 in case invalid scope(s)
Check the employee has created this merge request. Thus select inserted_by from il.merge_requests of this merge request and compare it with user_id from the token.
If not match - return 403 error (Only author of merge request is allowed to approve it)
Check that client_id from the token maches with il.merge_requests.legal_entity_id
If not match - return 422 error (User doesn’t belong to legal entity where the merge request was created)
Validate schema
Validate request using schema.
Validate merge request
Validate merge request id exists in DB
In case of error - return 404
Check merge request status is NEW
In case of error - return 422 (Incorrect status to approve merge request)
Validate legal entity
Validate legal entity as on create merge request process.
Validate person
Validate person as on create merge request process.
Validate confidant person relationship
If authorize_with
of merge request is not empty and contains auth method with type = THIRD_PERSON - validate that person from value is an approved confidant for a person from request – exists active and approved confidant person relationship between person from request and person_id from authentication method value (using following logic: Check confidant person relationship with person_id
= person from request and confidant_person_id
= value from auth method - expected :ok, :approved
response)
in case of error - return 409 ‘Cannot be confirmed by method with not approved confidant person relationship’
Validate preperson
Validate preperson as on create merge request process, but w/o searching pending merge requests and episodes.
Determine authorization method
Get authorization_method from il.merge_requests.authentication_method_current.
Next steps is similar to determine authorization method and check OTP/check Documents process on approve patient request.
Get preperson episodes
Get all the preperson episodes for the printout form (mongodb, episodes collection).
Generate printout form
Define printout form template based on
authorize_with
field of merge request:If
authorize_with
is not empty and contains auth method with type = THIRD_PERSON - select printout form with confidant personelse - select printout form w/o confidant person
Invoke MAN to render print form.
Request mapping:
Parameter | Source |
---|---|
id | MERGE REQUEST |
For printout form with confidant person - preload confidant person object from MPI using auth method value:
get confidant person details from
persons
tableget confidant person documents from
person_documents
tableget relation documents from
confidant_person_relationship_documents
table
Setil.merge_requests.printout_form
Update object in DB
il.merge_requeststable
Parameter | Source | Description |
---|---|---|
status | Request: status | Status of the request, required. Set APPROVED |
data | Request: data | Request data for sign, required. Save master_person and merge_person blocks with detailed information, printout form, merge request id, patient_signed (master person) and status field. |
printout_form | text | Generated printout form (PREPERSON MERGE REQUEST) |
updated_by | uuid | Extract user from token |
updated_at | timestamp | Get current date-time |
ЕСОЗ - публічна документація