承接 grupo-cometa/keycloak 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

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

grupo-cometa/keycloak

最新稳定版本:v1.0.5

Composer 安装命令:

composer require grupo-cometa/keycloak

包简介

Simples conexão com keycloak, authentication/authorization

README 文档

README

Cometa Keycloak

Uma simples biblioteca para "authentication/authorization" no sso keycloak utilizando o protocolo openid-connect.

A authorization funciona apenas para permissões baseadas em escopos ou permissões baseadas em recursos, para saber mais acesse Keycloak Authorization Services

Instalação LARAVEL

  • Instalar usando o composer: composer require grupo-cometa/keycloak

  • Publicar arquivos de configuração:Execute o seguinte código no terminal php artisan vendor:publish --tag=config isso fará com que o laravel crie o arquivo de configuração em config/ caso isso não saia como esperado será necessario fazer isso manualmente. Basta copiar _vendor/cometa-keycloack/config/keyCloack.php para config/.

  • Registrar Middlewares: Em app/Http/Kenel.php adicionar os dois items no array $routeMiddleware

   $routerMiddleware = [
       'auth' => GrupoCometa\Keycloak\Middlewares\Authenticate::class,
       'permission' => GrupoCometa\Keycloak\Middlewares\Authorization::class
       ...
   ];
  • Configurar config/auth.php: Alterar a key _guards
        'guards' => [
            'api' => [
                    'driver' => 'keycloak',
                    'provider' => 'users',
                ],
        ]

Instalação LUMEN

  • Instalar usando o composer: composer require grupo-cometa/keycloak
  • Publicar configurações:
    • Copiar vendor/grupo-cometa/keycloak/config/keycloak.php para config/.
    • Copiar vendor/grupo-cometa/keycloak/config/auth.php para config/., caso o arquivo auth já exista fazer apenas um merge das informações de acordo com sua necessidade, as extrutura e as chaves a baixo devem ficar da seguite forma.
// config/auth.php
    [
        'defaults' => [
            'guard' => 'api',
            'passwords' => 'users',
        ],

        'guards' => [
            'api' => [
                    'driver' => 'keycloak',
                    'provider' => 'users',
                ],
        ],

        'providers' => [
            'users' => [
                'driver' => 'eloquent',
                'model' => User::class
            ]
        ]
    ];
  • Registre as Variáveis de Ambiente:
    • realm_public_key
    • signature_algorithm
  • Altere o Model de Usuário:

    • Retire o cometário dessas linhas em bootstrap/app.php
    // $app->withFacades();
    
    // $app->withEloquent();
    
    • Copie vendor/grupo-cometa/keycloak/config/User.php para app/Models/User.php.
  • Registre o Controller de Autenticação:

    • Copie vendor/grupo-cometa/keycloak/config/AuthController.php para app/Http/Controllers/AuthController.php.
  • Registre a rota para cadastro de usuários:
$router->post('/', [
    'uses' => 'AuthController@store'
]);
  • Registrar Providers: Adicione a linha em bootstrap/app.php
$app->register(GrupoCometa\Keycloak\Providers\KeycloakServiceProvider::class);
  • Registrar middlewares authorization e authentication: adicionar as linhas em bootstrap/app.php
$app->routeMiddleware([
   'auth' => GrupoCometa\Keycloak\Middlewares\Authenticate::class,
   'permission' => GrupoCometa\Keycloak\Middlewares\Authorization::class
]);

Usando

Se voce seguiu todas os passos corretamente basta chamar o middleware um sua rota. O middleware permission recebe um parametro route#scoped, para entender mais sobre o controle de acesso com keycloak acesse Keycloak

$router->get('/keycloak', [
    'uses' => "KeycloakController@index",
    'middleware' => ['auth', 'permission:users#list-all']
]);

Exemplos

  • Captura o usuario autenticado
    /**
     * @return \Illuminate\Contracts\Auth\Authenticatable|null
     **/
    Illuminate\Support\Facades\Auth::user();
  • Verificar se o usuario logado possui um papel
    /**
     * @param  array<App\Model\Role>| Role
     * @return bool
     **/
     Illuminate\Support\Facades\Auth::hasRoles(Role::admin);
     ## OR
     Illuminate\Support\Facades\Auth::hasRoles([Role::admin, Role::gestor]);
  • Retornar todas as permissoes do usuario logado
    /**
     * @return array
     **/
    Illuminate\Support\Facades\Auth::allPermission();
  • Retornar todos os papeis
    /**
     * @return array
     **/
    Illuminate\Support\Facades\Auth::getRoles();
  • Retornar um atributos contido no token
    /**
     * @param string
     * @return mixed
     **/
    Illuminate\Support\Facades\Auth::getAttribute("name");

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: GPL-3.0-or-later
  • 更新时间: 2022-12-12