...
№ | условие | как выполнить | |||
---|---|---|---|---|---|
0 | убедиться, что ОС и браузер подходят для работы Рутокен КоннектКоннекта | через USERAgent браузера | |||
1 | установить Рутокен Коннект | установка руками пользователя | |||
2 | убедиться, что Рутокен Коннект активирован | через USERAgent браузерафункцию Рутокен Коннекта | |||
3 | установить Рутокен Плагин | установка руками пользователя | |||
4 | убедиться, что Рутокен Плагин активирован | через функцию Рутокен Плагина | |||
5 | проверить наличие корневого сертификата в доверенном хранилище сертификатов пользователя системы | через функцию Рутокен Плагина | 6 | проверить наличие подключенного устройства семейства Рутокена ЭЦП | через функцию Рутокен Плагина |
76 | ввести PIN-код пользователя Рутокена ЭЦП | через функцию Рутокен Плагина | |||
87 | проверить наличие корректного личного сертификата на Рутокене | через функцию Рутокен Плагина | |||
98 | перенаправить пользователя на защищенный ресурс | ссылкой или через redirect |
0. Определяем окружение для корректной работы Рутокен
...
Коннекта
Используем User-agent для поиска условий указанных в описании продукта.
Если условия не соответствуют следует показать пользователю сообщение с просьбой использовать подходящую для Рутокен Коннект Коннекта платформу и окружение.
1. Установка Рутокен
...
Коннекта
По ссылке на сайте производителя либо на собственном сайте.
Если использовать ссылку на сайте производителя, то не нужно беспокоиться об обновлении версий, так как эту заботу берет на себя сам производитель.
Используя ссылку на собственном сайте, вы избегаете лишних переходов на сторонние сайты, но должны самостоятельно отслеживать обновления программного обеспечения.
2. Убеждаемся, что Рутокен Коннект активирован
...
Функции:
- isExtensionInstalled() -> Promise(bool)
- isPluginInstalled() -> Promise(bool)
Должны вернуть true.
Если одна из функций или обе вернули false - необходимо
В User-agent строке должен появиться признак RutokenConnect
Если признак не найден необходимо вернуться к пункту 1.
3. Установка Рутокен Плагин
По ссылке на сайте производителя либо на собственном сайте.
Если использовать ссылку на сайте производителя, то не нужно беспокоиться об обновлении версий, так как эту заботу берет на себя сам производитель.
Используя ссылку на собственном сайте, вы избегаете лишних переходов на сторонние сайты, но должны самостоятельно отслеживать обновления программного обеспечения
4. Убеждаемся что Рутокен Плагин активирован
Функции Функции:
- isExtensionInstalled() -> Promise(bool)
- isPluginInstalled() -> Promise(bool)
Должны вернуть true.
Если одна из функций или обе вернули false - необходимо вернуться к пункту 3
5. Проверяем наличие корневого сертификата вашего защищенного ресурса в хранилище корневых сертификатов пользователя операционной системы
Функция enumerateStoreCertificates(options) → {string[]} возвращает список установленных ГОСТ сертификатов.
А функция getStoreCertificate(certId, options) → {string} позволяет получить тело конкретного сертификата в формате PEM, среди которых вы можете найти нужный.Если необходимый корневой сертификат не будет найден среди тех, которые вернула функция, то необходимо предложить пользователю его загрузить и установить, а затем повторить пункт
5
...
. Проверяем наличие подключенного Рутокена ЭЦП
Устройства семейств Рутокен S, Lite и PKI не поддерживаются.
Рутокен Коннект работает только с устройствами семейства Рутокен ЭЦП с поддержкой аппаратной ГОСТ-криптографии, поэтому отсутствие подходящего устройства не даст возможности подключиться к защищенному серверу через Рутокен Коннект.
Функция enumerateDevices(options) → {number[]} возвращает список подключенных устройств.
Функция getDeviceInfo(deviceId, option) → {object} может вернуть модель устройства (option - TOKEN_INFO_MODEL).
Warning |
---|
Необходимо убедиться, что подключенное устройство не принадлежит к семейству Рутокен Lite, так как с ним работа |
...
Рутокен |
...
Коннекта невозможна. |
Если ваш защищенный сервер работает по шифрсьютам основанным на алгоритмах электронной подписи 2012 года, то дополнительно нужно убедиться что подключенное устройство поддерживает работу по новым алгоритмам
Код:
var options = plugin.TOKEN_INFO_SUPPORTED_MECHANISMS;
...
вернет 2, если подключенное устройство Рутокен поддерживает алгоритмы электронной подписи 2012 года.
Если подключенного устройства нет, или оно неподходящее, то пользователю следует показать предупреждение с просьбой подключить подходящее устройство и повторить пункт 6.
...
6. Вводим PIN-код от устройства Рутокен ЭЦП
Перед проверкой сертификатов хранящихся на Рутокене ЭЦП необходимо авторизоваться на устройстве. Без авторизации перечисление сертификатов и закрытых ключей невозможно.
Функция login(deviceId, pin) принимает PIN-код пользователя, который необходимо принять с помощью специального окна или поля ввода.
Если функция бросает исключение значит PIN-код неверный и следует сообщить об этом пользователю и повторить пункт 7.
...
Если их станет меньше 1 - значит PIN-код заблокирован и пользователю следует обратиться к администратору для разблокировки PIN-кода.
...
7. Проверяем наличие подходящего личного сертификата на Рутокене ЭЦП
Список сертификатов с соответствующими им закрытыми ключами возвращает функция enumerateCertificates(deviceId, category) → {string[]}
...
Если среди обнаруженных сертификатов не оказалось подходящего, либо Рутокен пуст, следует сообщить пользователю, что необходимый для подключения сертификат не найден и ему необходимо его получить установленным для вашей информационной системы способом.
...
8. Перенаправляем пользователя на защищенный ресурс
Необходимо дать возможность пользователю нажать на кнопку или ссылку для перехода на защищенный ресурс вашей информационной системы либо автоматически его редиректить его.