ЕСОЗ - публічна документація
RC_warranty_Initialize Person documents upload
Purpose
This WS is designed to initialize person documents uploading proccess through person information system (PIS).
Key points
This method is used only by PIS.
This method returns list of documents that needs to be uploaded for person and urls. In case no documents must be uploaded - empty list is returned.
Person is obtained from user that performs method.
Specification
Validations
Authorization
Verify the validity of the access token
in case of error - return 401 (“Invalid access token”)
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 = 'person_documents:write_pis')
in case of invalid scope(s) - return 403 (“Your scope does not allow to access this resource. Missing allowances: person_documents:write_pis”)
Validate person
Get
person_id
from userCheck person exists in mpi database and is active (status = ‘active’ and is_active=true)
in case of error - return 404 ('Person does not exist or is not active')
Service logic
Get list of person documents that must be uploaded to media content storage (for each type of documents, if couple of rules worked - only one file is expected):
Call https://e-health-ua.atlassian.net/wiki/spaces/PCAB/pages/17599399440, send
person_id
= person.id andconfidant_person_id
=applicant_person_id
(from token)in case if method returns
:ok, :approved
(relationship exists and is approved):Check for documents with name
confidant_person.{confidant_person_id}.documents_relationship.[:].{type}
, wheretype
= type of documents stored in https://e-health-ua.atlassian.net/wiki/spaces/PCAB/pages/17599401195/warranty+MPI#confidant_person_relationship_documents with confidant_person_relationship_id = id of found relationship and proceed to next steps (generate links for person documents if needed)
in case if method returns
:ok, :not_approved
(relationship exists but isn’t approved):Check for documents with name
confidant_person.{confidant_person_id}.documents_relationship.[:].{type}
, wheretype
= type of documents stored in https://e-health-ua.atlassian.net/wiki/spaces/PCAB/pages/17599401195/warranty+MPI#confidant_person_relationship_documents with confidant_person_relationship_id = id of found relationship and skip next steps (do not generate links for person documents)
If one of persons document has type = ‘BIRTH_CERTIFICATE_FOREIGN’ and there is no same document in {person.confidant_person.[:].documents_relationship.[:]}
and persons age < no_self_auth_age global parameter value then
Check for document with name
person.BIRTH_CERTIFICATE_FOREIGN
If one of persons document has type = ‘PERMANENT_RESIDENCE_PERMIT’ and persons age >= no_self_auth_age global parameter value then
Check for document with name
person.PERMANENT_RESIDENCE_PERMIT
If persons authentication method = ‘OFFLINE’ or ‘THIRD_PERSON’ authentication method = ‘OFFLINE’
Check for documents with name
person.{documents.[:].type} or third_person.{third_person.documents.[:].type}
If person.unzr field is not empty and first 8 digits of unzr != persons birth_date
Check for document with name
person.unzr
If persons age is greater then no_self_registration_age global parameter, but less then person_full_legal_capacity_age global parameter
and one of persons documents has type from PIS_PERSON_LEGAL_CAPACITY_DOCUMENT_TYPES config parameter thenGet type of document that has been found
AND check for documents with nameperson.{type}
Check existence of each document in existing media content storages for person:
persons
person_requests
authentication_method_requests
Generate signed urls for each document that must be uploaded but does not exist in persons media content storage.
Render a response according to specification.
ЕСОЗ - публічна документація