定制 agrodata/cognito-guard 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

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

agrodata/cognito-guard

最新稳定版本:1.30

Composer 安装命令:

composer require agrodata/cognito-guard

包简介

A laravel auth guard for JSON Web Tokens issued by Amazon AWS Cognito

README 文档

README

Biblioteca para usar autenticação com token JWT com Amazon Cognito e Permissionamento com Amazon Verified Permissions.

Installation

Instalação do pacote via composer

composer require agrodata/cognito-guard

Publique o arquivo de migration os arquivod de configuração config/cognito.php e config/verified-permission.php:

 php artisan vendor:publish --provider="Agrodata\CognitoGuard\CognitoServiceProvider"

Execute o comando para criar a nova migration. Isso irá adicionar o campo [cognito_uuid] na tabela "users"

php artisan migrate

Adicione as variáveis de ambiente do 'User Pool' do Cognito no seu .env

AWS_COGNITO_REGION=us-east-2
AWS_COGNITO_USER_POOL_ID=us-east-2_PxDu3D4G4

Para o permissionamento com Verified Permissions, deverá adicionar as seguintes variáveis:

AVP_REGION=
AVP_NAMESPACE=
AVP_POLICY_STORE_ID=

Você também precisará alterar o driver "auth" no arquivo [config/auth.php] do seu projeto;

// config/auth.php
'guards' => [
    'web' => [
        'driver' => 'session',
        'provider' => 'users',
    ],
    'api' => [
        'driver' => 'cognito', // aqui!!!!
        'provider' => 'users',
    ],
],

Finally, depending on how you configured your Cognito User Pool's required attributes you may also want to make adjustments to your Single Sign-On settings in the published config/cognito.php file

// config/cognito.php

'leeway' => 0, 
'input_key' => null,
'append_decoded_token' => false,
'load_user_from_database' => true,
'user_provider_custom_retrieve_method' => null

Verified Permission

O amazon verified permission deve estar integrado ao Cognito UserPool que está sendo utilizado no projeto. Haverá 2 middlewares para validar as permissões do verifiedPermission:

Middlewares

can:

Serão consultadas todas as permissões no verifiedPermission atribuidas ao "grupo" do cognito ao qual o usuário pertence:

  • CognitoUser->Group->VerifiedPermission

Todas as permissões serão buscadas e adicionadas em Cache na aplicação local.

Todas as consultas posteriores serão consultadas na listagem em cache.

Caso uma nova permissão seja atribuida à um grupo, o usuário precisará re-logar para re-cadastrar as novas permissões em cache.

Route::middleware('can:admin.user:read')

permission:

Cada permissão será verifica individualmente na API do VerifiedPermission.

Esse método é um pouco menos performatico que o anterior e custará mais caro na AWS (visto que o VerifiedPermission cobra por consulta nas suas Api's).

A vantagem dessa abordagem é que as permissões sempre serão validadas em tempo real, sem a necessidade de re-logar +no Cognito.

Route::middleware('permission:admin.user:read')

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2024-06-26

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固