51 lines
1.3 KiB
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');
|
|
}
|
|
}
|
|
|
|
|