Auth: convert auth views and verification email to Nova layout
This commit is contained in:
36
app/Http/Middleware/EnsureOnboardingComplete.php
Normal file
36
app/Http/Middleware/EnsureOnboardingComplete.php
Normal file
@@ -0,0 +1,36 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Middleware;
|
||||
|
||||
use Closure;
|
||||
use Illuminate\Http\Request;
|
||||
use Symfony\Component\HttpFoundation\Response;
|
||||
|
||||
class EnsureOnboardingComplete
|
||||
{
|
||||
public function handle(Request $request, Closure $next): Response
|
||||
{
|
||||
$user = $request->user();
|
||||
if (! $user) {
|
||||
return $next($request);
|
||||
}
|
||||
|
||||
$step = strtolower((string) ($user->onboarding_step ?? ''));
|
||||
if ($step === 'complete') {
|
||||
return $next($request);
|
||||
}
|
||||
|
||||
$target = match ($step) {
|
||||
'email' => '/login',
|
||||
'verified' => '/setup/password',
|
||||
'password', 'username' => '/setup/username',
|
||||
default => '/setup/password',
|
||||
};
|
||||
|
||||
if ($request->is(ltrim($target, '/'))) {
|
||||
return $next($request);
|
||||
}
|
||||
|
||||
return redirect($target);
|
||||
}
|
||||
}
|
||||
28
app/Http/Middleware/NormalizeUsername.php
Normal file
28
app/Http/Middleware/NormalizeUsername.php
Normal file
@@ -0,0 +1,28 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Middleware;
|
||||
|
||||
use App\Support\UsernamePolicy;
|
||||
use Closure;
|
||||
use Illuminate\Http\Request;
|
||||
use Symfony\Component\HttpFoundation\Response;
|
||||
|
||||
class NormalizeUsername
|
||||
{
|
||||
public function handle(Request $request, Closure $next): Response
|
||||
{
|
||||
$payload = $request->all();
|
||||
|
||||
if (array_key_exists('username', $payload)) {
|
||||
$payload['username'] = UsernamePolicy::normalize((string) $payload['username']);
|
||||
}
|
||||
|
||||
if (array_key_exists('old_username', $payload)) {
|
||||
$payload['old_username'] = UsernamePolicy::normalize((string) $payload['old_username']);
|
||||
}
|
||||
|
||||
$request->merge($payload);
|
||||
|
||||
return $next($request);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user