2017 © Pedro Peláez
 

library yii2-esia

ESIA Authclient for gosuslugi.ru

image

heggi/yii2-esia

ESIA Authclient for gosuslugi.ru

  • Saturday, January 27, 2018
  • by heggi
  • Repository
  • 1 Watchers
  • 0 Stars
  • 2 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 2 Versions
  • 100 % Grown

The README.md

ESIA Authclient

Расширение для Yii2 для авторизации через портал госуслуг. Реализована только авторизация и получение базовых данных (personInfo), (*1)

Установка

Запустить, (*2)

php composer.phar require --prefer-dist heggi/yii2-esia "*"

Или добавить, (*3)

"heggi/yii2-esia": "*"

в секцию require вашего файла composer.json., (*4)

Настройка

В файле конфигурации (frontend/config/main.php или config/web.php) добавить, (*5)

return [
    'components' => [
        ...
        'authClientCollection' => [
            'class' => 'yii\authclient\Collection',
            'clients' => [
                ...
                'esia' => [
                    'class' => 'heggi\yii2esia\Esia',
                    'clientId' => 'xxx',
                    'certPath' => __DIR__ . '/xxx.pem',
                    'privateKeyPath' => __DIR__ . '/xxx.key',
                    'privateKeyPassword' => 'xxx',
                    'scope' => 'fullname',
                    'production' => false,
                ],
                ...
            ],
        ],
        ...
    ]
]

Указать верные clientId, certPath, privateKeyPath, privateKeyPassword., (*6)

'production' => false для подключения к тестовой среде ESIA., (*7)

В контроллере SiteController.php, (*8)

public function actions() {
    return [
        ...
        'auth' => [
            'class' => 'yii\authclient\AuthAction',
            'successCallback' => [$this, 'ssoCallback'],
        ],
        ...
    ];
}

public function ssoCallback($client) {
    $attributes = $client->getUserAttributes();
    $oid = $attributes['oid'];

    $user = User::findByOid($oid);
    if($user) {
        return Yii::$app->user->login($user);
    }

    $personInfo = $client->getPersonInfo($oid);
    $user = new User();
    $user->oid = $oid;
    $user->first_name = $personInfo['firstName'];
    $user->last_name = $personInfo['lastName'];
    $user->middle_name = $personInfo['middleName'];
    if(!$user->save()) {
        throw new yii\web\ServerErrorHttpException('Внутренняя ошибка сервера');
    }

    Yii::$app->user->login($user);
}

В файл views/layouts/main.php добавить ссылку для авторизации, (*9)

<?= Html::a('Войти через госуслуги', ['site/auth', 'authclient' => 'esia']) ?>

или использовать виджет, (*10)

<?= yii\authclient\widgets\AuthChoice::widget([
    'baseAuthUrl' => ['site/auth'],
    'popupMode' => false,
]) ?>

Полезные ссылки

Сайт госуслуги, (*11)

Информация про подключение, (*12)

The Versions

27/01 2018

dev-master

9999999-dev

ESIA Authclient for gosuslugi.ru

  Sources   Download

MIT

The Requires

 

by Avatar heggi

extension yii2 esia

27/01 2018

v0.2

0.2.0.0

ESIA Authclient for gosuslugi.ru

  Sources   Download

MIT

The Requires

 

by Avatar heggi

extension yii2 esia