Skip to content

Модуль аутентификации и авторизации в ЕСИА

License

Notifications You must be signed in to change notification settings

mysilkworld/esia-gosuslugi

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

4 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

esia-gosuslugi

Модуль идентификации и авторизации пользователей через ЕСИА для Node.js с поддержкой ГОСТ 34.10

Перед использованием ознакомтесь с документацией.

использование

  1. Установите
npm i -s esia-gosuslugi
  1. Создайте экземпляр подключения к ЕСИА
const fs = require('fs');
const esia = require('esia');

// читается сертификат используемый в ЕСИА
const cert = fs.readFileSync('./cert.pem', 'utf8');
const key =  fs.readFileSync('./privkey.key', 'utf8');

const esiaConnection = esia({
    clientId: 'ISMNEMONIKA',
    redirectUri: 'https://my-site.com/esiacode/',
    scope: 'openid id_doc mobile fullname',
    certificate: cert,
    key: key
});
  1. Направьте пользвателя в ЕСИА для получения подтверждения
// сгенерируйте url для пользователя
await esiaConnection.getAuth()
  1. После того как пользователь авторизуется и даст разрешение на доступ к своим данным, он будет перенаправлен по адресу, указанному в redirectUri. Вы получите параметр code, который нужно будет использовать для запроса данных
await esiaConnection.getAccess(code)

Метод getAccess возвращает Promise, в который приходит объект результата. Этот объект содержит два поля:

  • marker - маркер доступа. Объект, содержащий поля:
    • response - объект, ответ от ЕСИА при запросе маркера
    • decodedAccessToken - объект, jwt декодированное значение поля access_token, содержащееся в response.
  • data - массив записей данных о пользователе.

В метод getAccess вторым параметром можно передать массив путей для получения записей данных о пользователе. Они будут содержаться в ответе, в поле data, описанном выше. Если параметр не передавать, по умолчанию будет использоваться ['/']. Если передать null, то данные о пользователе запрашиваться не будут.

const { data } = await esiaConnection.getAccess(code, ['/', '/docs']) 

// не будет запрошена информация о пользователе
const { data } = await esiaConnection.getAccess(code, null)

Подробнее о получении информации о пользователе читайте в официальной документации ЕСИА.

About

Модуль аутентификации и авторизации в ЕСИА

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 100.0%