invoiceninja/app/Http/Controllers/Auth/ResetPasswordController.php

73 lines
1.9 KiB
PHP
Raw Normal View History

2017-01-30 21:40:43 +02:00
<?php
namespace App\Http\Controllers\Auth;
2015-03-17 07:45:25 +10:00
use Event;
2017-11-15 11:25:41 +02:00
use Illuminate\Http\Request;
use App\Models\PasswordReset;
use App\Events\UserLoggedIn;
2015-03-23 14:20:33 +10:00
use App\Http\Controllers\Controller;
2015-03-17 07:45:25 +10:00
use Illuminate\Foundation\Auth\ResetsPasswords;
2017-11-14 10:58:08 +02:00
class ResetPasswordController extends Controller
{
/*
|--------------------------------------------------------------------------
| Password Reset Controller
|--------------------------------------------------------------------------
|
| This controller is responsible for handling password reset requests
| and uses a simple trait to include this behavior. You're free to
| explore this trait and override any methods you wish to tweak.
|
*/
2015-03-17 07:45:25 +10:00
use ResetsPasswords {
2017-11-14 10:58:08 +02:00
sendResetResponse as protected traitSendResetResponse;
}
2015-03-17 07:45:25 +10:00
/**
2017-11-14 10:58:08 +02:00
* Where to redirect users after resetting their password.
*
* @var string
*/
2015-03-30 18:20:53 +03:00
protected $redirectTo = '/dashboard';
/**
2017-11-14 10:58:08 +02:00
* Create a new controller instance.
*
2017-11-14 10:58:08 +02:00
* @return void
*/
public function __construct()
{
$this->middleware('guest');
}
2017-11-14 10:58:08 +02:00
protected function sendResetResponse($response)
{
$user = auth()->user();
if ($user->google_2fa_secret) {
auth()->logout();
session(['2fa:user:id' => $user->id]);
return redirect('/validate_two_factor/' . $user->account->account_key);
} else {
Event::fire(new UserLoggedIn());
2017-11-14 10:58:08 +02:00
return $this->traitSendResetResponse($response);
}
}
2017-11-15 09:51:49 +02:00
public function showResetForm(Request $request, $token = null)
{
$passwordReset = PasswordReset::whereToken($token)->first();
2017-11-15 11:25:41 +02:00
if (! $passwordReset) {
return redirect('login')->withMessage(trans('texts.invalid_code'));
}
2017-11-15 09:51:49 +02:00
return view('auth.passwords.reset')->with(
2017-11-15 11:25:41 +02:00
['token' => $token, 'email' => $passwordReset->email]
2017-11-15 09:51:49 +02:00
);
}
2015-03-17 07:45:25 +10:00
}