andradedaniel / jwt-auth-consumer
Pacote Laravel para validar JWTs em serviços consumidores
Installs: 4
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/andradedaniel/jwt-auth-consumer
Requires
- php: ^8.2
- firebase/php-jwt: ^6.0
- illuminate/auth: ^11.0
- illuminate/http: ^11.0
- illuminate/routing: ^11.0
- illuminate/support: ^11.0
Requires (Dev)
- laravel/pint: ^1.24.0
- orchestra/testbench: ^9.0
- peckphp/peck: ^0.1.3
- pestphp/pest: ^4.1.0
- pestphp/pest-plugin-type-coverage: ^4.0.2
- phpstan/phpstan: ^2.1.26
- rector/rector: ^2.1.7
- symfony/var-dumper: ^7.3.3
README
Pacote Laravel para validar JWTs emitidos por um serviço central de autenticação e disponibilizar o usuário autenticado no contexto de aplicações consumidoras.
Instalação
Instale o pacote diretamente do Packagist via Composer (recomendado fixar a versão principal):
composer require andradedaniel/jwt-auth-consumer:^1.0
Publicação da configuração
php artisan vendor:publish --tag=config --provider="SpunetGestao\JwtAuthConsumer\JwtAuthConsumerServiceProvider"
Isso criará o arquivo config/jwt-auth-consumer.php.
Variáveis de ambiente
Adicione no .env do projeto:
JWT_SHARED_SECRET=segredo-compartilhado
JWT_ALGO=HS256
JWT_LEEWAY=60
JWT_LEEWAY define, em segundos, a tolerância para diferenças de relógio entre emissores e consumidores do token (ajuda a evitar falhas de validação por pequenos desvios de tempo).
Uso
Proteja rotas com o middleware fornecido:
Route::middleware('jwt.auth')->group(function () { Route::get('/relatorios', ReportController::class); });
Controle fino por permissões com o middleware access-control:
Route::get('/atendimento', AtendimentoController::class) ->middleware(['jwt.auth', 'access-control:ATENDIMENTO_CRIAR_PRESENCIAL|ATENDIMENTO_CRIAR_TELEFONICO']);
O middleware verifica se o usuário autenticado possui ao menos uma das permissões informadas (separadas por pipe).
Dentro dos controladores, o usuário autenticado está disponível:
$user = $request->user(); // instância de SpunetGestao\JwtAuthConsumer\Auth\JwtUser
Observações
- O pacote apenas valida e consome tokens JWT; ele não emite tokens.
- Os dados do usuário são derivados das claims do token e não são persistidos em banco.