E-Document
Описание#
E-Document - это сервис-интеграция с Egov для получения личных электронных документов с государственной базы. Электронные документы могут быть получены в формате JSON, PDF или фотографии.
Для комфортной интеграции через Backend API воспользуйтесь Swagger (OpenAPI)
Термины#
- Субъект - это человек, который является объектом запроса на получение документов в электронном формате в сервисе E-Document.
- OTP-код - это временный код, который приходит на телефон субъекта от 1414 и используется для подтверждения получения электронных документов.
- База мобильных граждан(БМГ) - это единая база номеров мобильных телефонов пользователей, необходимых для оказания государственных услуг, отправки SMS-паролей при авторизации или подписании услуг, с помощью одноразового пароля. Найти инструкцию по регистрации в базе можно здесь.
- ИИН - индивидуальный идентификационный номер гражданина Республики Казахстан.
- Unix timestamp - система описания моментов во времени, принятая в Unix и других POSIX-совместимых операционных системах. Определяется как количество секунд, прошедших с полуночи 1 января 1970 года.
Этапы:#
1. Получение API-KEY организации#
Первый этап для использования технологии - получение API-KEY организации. Чтобы получить API-KEY организации, необходимо зайти в Личный Кабинет по данной ссылке. API-KEY находится в поле Backend Api Key
Пример API-KEY организации:
API-KEY: Efy202XKbVAWRu...
Примечание
Для наглядности используется укороченная длина
API KEY
. Его фактическая длина составляет 47 и более символов.
2. Отправка запроса на получение электронного документа#
Необходимо учесть
Чтобы запросить электронный документ субъекта необходимо, чтобы его персональные данные были зарегистрированы в Базе мобильных граждан Республики Казахстан.
При отправке запроса на получение электронного документа используются данные в формате JSON.
Важно
Чтобы использовать данный сервис, необходимо иметь на него подписку. Подробнее о подписках можно прочитать здесь.
URL запроса:
https://kyc.biometric.kz/api/v1/backend/e-document/online-access/request/{document_type}/
Формат запроса | Метод запроса |
---|---|
JSON | POST |
document_type
необходимо передать как параметр пути:
Значение | Описание |
---|---|
identity_card | Удостоверение личности |
driver_license | Водительское удостоверение |
birth_certificate | Свидетельство о рождении |
marriage_certificate | Свидетельство о заключении брака |
change_fio_certificate | Свидетельство о перемене фамилии, имени, отчества |
divorce_certificate | Свидетельство о расторжении брака |
diploma | Диплом |
srts | Свидетельство о регистрации транспортного средства |
vaccination | Паспорт вакцинации |
social_id | Социальный ID |
disability_certificate | Удостоверение лица с инвалидностью |
large_family_certificate | Удостоверение о многодетной семье |
asp_certificate | Удостоверение получателя адресной социальной помощи |
tech_passport | Технический паспорт |
pension | Удостоверение пенсионера |
passport | Паспорт гражданина РК |
student_card | Студенческий билет |
vnzh | Вид на жительство |
pcr_certificate | Результат ПЦР тестирования на COVID-19 |
lbg_card | Лицо без гражданства |
insurance_policy | Страховые полисы |
hunter | Удостоверение охотника |
oralman | Удостоверение кандаса |
attorney | Доверенность |
Необходимо учесть
Чтобы запросить необходимый тип документа, он должен быть в государственной базе данных Республики Казахстан. При отсутствии документа в базе данных, субъекту не придет сообщение с OTP-кодом для дальнейшего подтверждения и получения электронного документа.
К сожалению, мы не вправе предоставить информацию о наличии или отсутствии документа в связи с ограничениями государственного сервиса, который не предоставляет такие данные.
API KEY
необходимо передать в теле запроса:
Наименование поля | Тип | Обязательно | Описание |
---|---|---|---|
api_key | String | Да | API KEY организации в личном кабинете |
iin | String | Да | ИИН субъекта |
phone | String | Да | Телефонный номер субъекта, пример: 77********* |
Примеры запроса:
import requests
url = 'https://kyc.biometric.kz/api/v1/backend/e-document/online-access/request/{document_type}/'
headers = {
'Accept': 'application/json',
'Content-Type': 'application/json',
}
data = {
'api_key': '<organization_api_key>',
'iin': '<subjects_iin>',
'phone': '<subjects_phone>',
}
response = requests.post(url, headers=headers, json=data)
print(response.json())
const url = 'https://kyc.biometric.kz/api/v1/backend/e-document/online-access/request/{document_type}/';
const apiKey = '<organization_api_key>';
const headers = {
'Accept': 'application/json',
'Content-Type': 'application/json'
};
const data = {
api_key: apiKey,
iin: '<subjects_iin>',
phone: '<subjects_phone>'
};
fetch(url, {
method: 'POST',
headers: headers,
body: JSON.stringify(data)
})
.then(response => response.json())
.then(data => console.log(data))
.catch(error => console.error(error));
В качестве ответа придет JSON со следующими полями:
- backend_session_id - идентификатор сессии для получения электронного документа;
После отправки запроса, на указанный в запросе телефонный номер субъекта приходит сообщение с OTP-кодом для дальнейшего подтверждения и получения электронного документа.
3. Отправка запроса на подтверждение получения электронного документа#
Необходимо учесть
Необходимо обязательно отправить запрос на получение электронного документа
В запросах к нашему сервису используются только данные в формате JSON.
Ответные данные от сервиса будут представлены в том же формате.
URL запроса:
https://kyc.biometric.kz/api/v1/backend/e-document/online-access/approve/
Формат запроса | Метод запроса |
---|---|
JSON | POST |
Наименование поля | Тип | Обязательно | Описание |
---|---|---|---|
backend_session_id | String | Да | Идентификатор сессии, из ответа отправки запроса на получение |
code | String | Да | Полученный OTP-код |
file | Boolean | Да | Включить в ответ файл документа |
file_type | String | Да | Тип файла документа. Доступные значения: pdf, image |
Примеры запроса:
import requests
url = 'https://kyc.biometric.kz/api/v1/backend/e-document/online-access/approve/'
headers = {
'accept': 'application/json',
'Content-Type': 'application/json',
}
data = {
'backend_session_id': '<backend_session_id>',
'code': '<otp_code>',
'file': True,
'file_type': 'pdf',
}
response = requests.post(url, headers=headers, json=data)
print(response.json())
const url = 'https://kyc.biometric.kz/api/v1/backend/e-document/online-access/approve/';
const headers = {
'accept': 'application/json',
'Content-Type': 'application/json',
};
const data = {
'backend_session_id': '<backend_session_id>',
'code': '<otp_code>',
'file': true,
'file_type': 'pdf',
};
fetch(url, {
method: 'POST',
headers: headers,
body: JSON.stringify(data)
})
.then(response => response.json())
.then(data => console.log(data))
.catch(error => console.error(error));
Важно
Все изображения и файлы приходят в формате base64.
В зависимости от выбора типа файла в запросе на подтверждение электронный документ может
придти в виде pdf или изображения в формате base64.
Полученные файлы необходимо сохранять с расширением .pdf или .jpg .
В качестве ответа придет запрошенный документ в формате JSON со следующими полями:
- document_type - тип документа.
- result_json - данные документа субъекта в формате json.
- face_photo - фотография лица субъекта в формате base64.
- qrcode - qr-код документа в формате base64.
- barcode - штрих-код документа в формате base64.
- document_image - изображение документа в формате base64.
- document_pdf - документ в формате PDF в кодировке base64.
- gender - пол субъекта, вычисленный из ИИНа субъекта.
- failure_reason - причина провала цифрового документа.
Ошибки#
Код состояния | Ответ | Описание |
---|---|---|
404 | Subject not found in CMDB | Пользователь не зарегистрирован в БМГ(база мобильных граждан). Найти инструкцию по регистрации в базе можно здесь |
503 | Can`t connect to e-document service | Не получается подключиться к государственному сервису Egov |
503 | EDocument service is not available now | Государственный сервис Egov на данный момент не доступен |
504 | Could not send request to e-document service | Таймаут запроса к государственному сервису Egov |
424 | Government service error | Получен необрабатываемый ответ от государственного сервиса Egov |
404 | Profile is not found | Профиль запрашиваемого гражданина не найден |
400 | Invalid IIN | Неверный ИИН |
400 | EDocument for this session has already been received | Документ для этой сессии уже получен. Возникает если пользователь с одной и той же сессией проходит несколько раз |
400 | Client does not have access to E-Document technology | У клиента нет доступа к технологии. Причины: подписка отсутствует, либо она истекла, или технология не активна |
400 | You have already requested a document for this session | Нельзя делать несколько запросов с одной сессией |
400 | You have not sent a request for access to an e-document | Пользователь не запросил доступ к электронному документу, отправьте запрос на получение документа |
400 | Subscription has not started | Подписка еще не активировалась |
400 | No active or future subscription for technology | Нет активной или будущей подписки на технологию |
400 | Client does not have subscription | У клиента отсутствует подписка, подробнее о подписках можно прочитать здесь |