coolify/app/Http/Middleware/CheckForcePasswordReset.php

39 lines
1.2 KiB
PHP
Raw Normal View History

2023-08-15 14:11:38 +02:00
<?php
namespace App\Http\Middleware;
use Closure;
use Illuminate\Http\Request;
use Symfony\Component\HttpFoundation\Response;
class CheckForcePasswordReset
{
/**
* Handle an incoming request.
*
* @param \Closure(\Illuminate\Http\Request): (\Symfony\Component\HttpFoundation\Response) $next
*/
public function handle(Request $request, Closure $next): Response
{
if (auth()->user()) {
if ($request->path() === 'auth/link') {
auth()->logout();
request()->session()->invalidate();
request()->session()->regenerateToken();
2024-06-10 22:43:34 +02:00
return $next($request);
}
2023-08-15 14:11:38 +02:00
$force_password_reset = auth()->user()->force_password_reset;
if ($force_password_reset) {
2024-06-10 22:43:34 +02:00
if ($request->routeIs('auth.force-password-reset') || $request->path() === 'force-password-reset' || $request->path() === 'livewire/update' || $request->path() === 'logout') {
2023-08-15 14:11:38 +02:00
return $next($request);
}
2024-06-10 22:43:34 +02:00
2023-08-15 14:11:38 +02:00
return redirect()->route('auth.force-password-reset');
}
}
2024-06-10 22:43:34 +02:00
2023-08-15 14:11:38 +02:00
return $next($request);
}
}