$request]); } /** * Handle an incoming new password request. * * @throws \Illuminate\Validation\ValidationException */ public function store(Request $request): RedirectResponse { try { // Validasi input $request->validate([ 'token' => ['required'], 'email' => ['required', 'email'], 'password' => ['required', 'confirmed', Rules\Password::defaults()], ]); // Reset password $status = Password::reset( $request->only('email', 'password', 'password_confirmation', 'token'), function ($user) use ($request) { $user->forceFill([ 'password' => Hash::make($request->password), 'remember_token' => Str::random(60), ])->save(); event(new PasswordReset($user)); } ); // Cek status reset password if ($status == Password::PASSWORD_RESET) { return redirect()->route('login')->with('success', __('Password berhasil direset! Silakan login.')); } else { return back()->withInput($request->only('email')) ->withErrors(['email' => __($status)]); } } catch (\Throwable $e) { // Log error untuk debugging Log::error('Password reset failed: ' . $e->getMessage()); return back()->withInput($request->only('email')) ->withErrors(['error' => 'Terjadi kesalahan: ' . $e->getMessage()]); } } }