Blame view

app/Http/Controllers/Auth/Reset.php 3.31 KB
b7c7a5f6   Alexey Boroda   first commit
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
  <?php
  
  namespace App\Http\Controllers\Auth;
  
  use App\Http\Controllers\Controller;
  use Illuminate\Foundation\Auth\ResetsPasswords;
  use Illuminate\Http\Request;
  use Illuminate\Support\Facades\Password;
  use Illuminate\Support\Str;
  
  class Reset 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.
      |
      */
  
      use ResetsPasswords;
  
      /**
       * Where to redirect users after resetting their password.
       *
       * @var string
       */
      public $redirectTo = '/';
  
      /**
       * Create a new controller instance.
       *
       * @return void
       */
      public function __construct()
      {
          $this->middleware('guest');
      }
  
      public function create(Request $request, $token = null)
      {
          return view('auth.reset.create')->with(
              ['token' => $token, 'email' => $request->email]
          );
      }
  
      public function store(Request $request)
      {
          $this->validate($request, $this->rules(), $this->validationErrorMessages());
  
          // Here we will attempt to reset the user's password. If it is successful we
          // will update the password on an actual user model and persist it to the
          // database. Otherwise we will parse the error and return the response.
          $response = $this->broker()->reset(
              $this->credentials($request), function ($user, $password) {
                  $this->resetPassword($user, $password);
              }
          );
  
          // If the password was successfully reset, we will redirect the user back to
          // the application's home authenticated view. If there is an error we can
          // redirect them back to where they came from with their error message.
          return $response == Password::PASSWORD_RESET
              ? $this->sendResetResponse($response)
              : $this->sendResetFailedResponse($request, $response);
      }
  
      /**
       * Reset the given user's password.
       *
       * @param  \Illuminate\Contracts\Auth\CanResetPassword  $user
       * @param  string  $password
       * @return void
       */
      protected function resetPassword($user, $password)
      {
          $user->forceFill([
              'password' => $password,
              'remember_token' => Str::random(60),
          ])->save();
  
          $this->guard()->login($user);
      }
  
      /**
       * Get the response for a successful password reset.
       *
       * @param  string  $response
       * @return \Illuminate\Http\RedirectResponse
       */
      protected function sendResetResponse($response)
      {
          flash(trans($response))->success();
  
          return redirect($this->redirectTo);
      }
  
      /**
       * Get the response for a failed password reset.
       *
       * @param  \Illuminate\Http\Request
       * @param  string  $response
       * @return \Illuminate\Http\RedirectResponse
       */
      protected function sendResetFailedResponse(Request $request, $response)
      {
          return redirect()->back()
              ->withInput($request->only('email'))
              ->withErrors(['email' => trans($response)]);
      }
  }