72 lines
2.1 KiB
PHP
72 lines
2.1 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers;
|
|
|
|
use App\Actions\Fortify\CreateNewUser;
|
|
use App\Models\User;
|
|
use Illuminate\Http\JsonResponse;
|
|
use Illuminate\Http\Request;
|
|
use Illuminate\Support\Facades\Hash;
|
|
use Illuminate\Validation\ValidationException;
|
|
|
|
class AuthController extends Controller
|
|
{
|
|
public function register(Request $request, CreateNewUser $creator): JsonResponse
|
|
{
|
|
$input = [
|
|
'name' => $request->input('name') ?? $request->input('username'),
|
|
'email' => $request->input('email'),
|
|
'password' => $request->input('password') ?? $request->input('plainPassword'),
|
|
'password_confirmation' => $request->input('password_confirmation') ?? $request->input('plainPassword'),
|
|
];
|
|
|
|
$user = $creator->create($input);
|
|
|
|
$user->sendEmailVerificationNotification();
|
|
|
|
return response()->json([
|
|
'user_id' => $user->id,
|
|
'email' => $user->email,
|
|
'message' => 'Verification email sent.',
|
|
]);
|
|
}
|
|
|
|
public function login(Request $request): JsonResponse
|
|
{
|
|
$request->validate([
|
|
'email' => ['required', 'email'],
|
|
'password' => ['required', 'string'],
|
|
]);
|
|
|
|
$user = User::where('email', $request->input('email'))->first();
|
|
|
|
if (!$user || !Hash::check($request->input('password'), $user->password)) {
|
|
throw ValidationException::withMessages([
|
|
'email' => ['Invalid credentials.'],
|
|
]);
|
|
}
|
|
|
|
if (!$user->hasVerifiedEmail()) {
|
|
return response()->json([
|
|
'message' => 'Email not verified.',
|
|
], 403);
|
|
}
|
|
|
|
$token = $user->createToken('api')->plainTextToken;
|
|
|
|
return response()->json([
|
|
'token' => $token,
|
|
'user_id' => $user->id,
|
|
'email' => $user->email,
|
|
'roles' => $user->roles()->pluck('name')->values(),
|
|
]);
|
|
}
|
|
|
|
public function logout(Request $request): JsonResponse
|
|
{
|
|
$request->user()?->currentAccessToken()?->delete();
|
|
|
|
return response()->json(null, 204);
|
|
}
|
|
}
|