josecl/claveunica 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

josecl/claveunica

最新稳定版本:v1.0.0

Composer 安装命令:

composer require josecl/claveunica

包简介

Cliente Laravel para autenticar con servicio OAuth2 de ClaveÚnica del Gobierno de Chile

README 文档

README

Cliente Laravel para autenticar con servicio OAuth2 de ClaveÚnica del Gobierno de Chile.

Basado en socialiteproviders/claveunica, permite ser configurado en ambientes de desarrollo para emular el servicio de ClaveÚnica mediante josecl/emulador-claveunica.

Requerimientos

  • Laravel 9
  • php 8.0

Instalación y configuración

Se utiliza de manera similar a los provider de Socialite.

Instalar dependencia:

composer require josecl/claveunica

Agregar configuración al archivo config/services.php:

'claveunica' => [    
  'client_id' => env('CLAVEUNICA_CLIENT_ID'),  
  'client_secret' => env('CLAVEUNICA_CLIENT_SECRET'),  
  'redirect' => env('CLAVEUNICA_REDIRECT_URI') 
],

Agregar event listener para los eventos SocialiteWasCalled en tu archivo app/Providers/EventServiceProvider.php:

protected $listen = [
    \SocialiteProviders\Manager\SocialiteWasCalled::class => [
        // ...
        \Josecl\ClaveUnica\ClaveUnicaExtendSocialite::class . '@handle',
    ],
];

Uso

Para redireccianar al servicio OAuth usar un contoller que haga redirect con:

return Socialite::driver('claveunica')->redirect();

Una vez que el usuario complete el flujo de autenticación será redireccionado a la URL definida por CLAVEUNICA_REDIRECT_URI.

Debes configurar un segundo controller que procese ese redirect y completar el inicio de sesión en tu aplicación. Puedes obtener los datos del usuario autenticado mediante este ejemplo:

    $claveUnicaUser = Socialite::driver('claveunica')->user();

    dump($claveUnicaUser->run);
    dump($claveUnicaUser->dv);
    dump($claveUnicaUser->first_name);
    dump($claveUnicaUser->last_name);

Emulador de ClaveÚnica

En ambientes de desarrollo puedes iniciar sesión simulando el flujo por ClaveÚnica mediante josecl/emulador-claveunica.

Instalación:

composer require josecl/emulador-claveunica

Actualizar el archivo config/services.php con los parámetros adicionales y configurar las variables de ambiente de acuerdo a la documentación de josecl/emulador-claveunica.

'claveunica' => [    
  'client_id' => env('CLAVEUNICA_CLIENT_ID'),  
  'client_secret' => env('CLAVEUNICA_CLIENT_SECRET'),  
  'redirect' => env('CLAVEUNICA_REDIRECT_URI') 
  // Configura servicio alternativo a ClaveÚnica
  'auth_uri' => env('CLAVEUNICA_AUTH_URI', 'https://accounts.claveunica.gob.cl/openid/authorize'),
  'token_uri' => env('CLAVEUNICA_TOKEN_URI', 'https://accounts.claveunica.gob.cl/openid/token'),
  'user_uri' => env('CLAVEUNICA_USER_URI', 'https://www.claveunica.gob.cl/openid/userinfo'),
],

统计信息

  • 总下载量: 834
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 2
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 2
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2022-08-29