validate([ 'email' => 'required|email', 'password' => 'required' ]); $user = User::query() ->where('email', $request->email) ->first(); if (!$user) { return response(['message' => 'User Tidak Ditemukan'], 404); } if (!Hash::check($request->password, $user->password)) { return response(['message' => 'Password Salah'], 403); } return response([ 'message' => 'Selamat Datang', 'user' => $user, 'token' => $user->createToken('app')->plainTextToken ]); } public function logout(Request $request) { $token = $request->bearerToken(); Auth::user()->tokens()->where('id', $token)->delete(); return response(['message' => 'Berhasil Logout.']); } public function resetPassword(Request $request) { $user = Auth::user(); $request->validate([ 'old_password' => 'required', 'new_password' => 'required', 'confirm_new_password' => 'required' ]); if (!Hash::check($request['old_password'], $user->password)) { return response(['message' => 'Password Salah'], 403); } if ($request["new_password"] != $request["confirm_new_password"]) { return response([ 'message' => "Password Tidak Sama" ]); } $user->update([ 'password' => Hash::make($request->confirm_new_password), ]); return response()->json($user); } public function verifyEmail(Request $request) { $request->validate([ 'email' => 'required|email', ]); $user = User::query() ->where('email', $request->email) ->first(); if (!$user) { return response(['message' => 'User Tidak Ditemukan'], 404); } Event(new ForgetPassword($user)); // Mail::to($user->email)->send(new SendVerifyEmail($user)); return response()->json($user); } public function forgetPassword(Request $request) { $request->validate([ 'new_password' => 'required', 'confirm_new_password' => 'required' ]); $token = Crypt::decryptString($request->token); $email = explode('|', $token)[0]; $user = User::query() ->where('email', $email) ->first(); if (!$user) { return response(['message' => 'User Tidak Ditemukan'], 404); } if ($request["new_password"] != $request["confirm_new_password"]) { return response([ 'message' => "Password Tidak Sama" ], 404); } $user->update([ 'password' => Hash::make($request->confirm_new_password), ]); return response()->json($user); } }