perling/app/Http/Controllers/WebAuthController.php

51 lines
1.3 KiB
PHP

<?php
namespace App\Http\Controllers;
use App\Http\Requests\Auth\LoginRequest;
use App\Models\User;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\Hash;
use Illuminate\Validation\ValidationException;
use Illuminate\Http\Request;
class WebAuthController extends Controller
{
public function sessionLogin(LoginRequest $request)
{
$data = $request->validated();
$identifier = $data['identifier'];
$password = $data['password'];
$user = User::where('email', $identifier)->first();
if (!$user) {
$user = User::where('username', $identifier)->first();
}
if (!$user || !Hash::check($password, $user->password)) {
throw ValidationException::withMessages([
'identifier' => ['email/username/password yang diberikan salah.'],
]);
}
Auth::login($user, true);
request()->session()->regenerate();
return response()->json(['success' => true]);
}
public function logout(Request $request)
{
Auth::logout();
$request->session()->invalidate();
$request->session()->regenerateToken();
if ($request->expectsJson()) {
return response()->json(['success' => true]);
}
return redirect()->route('login.index');
}
}