mirror of
				https://github.com/firefly-iii/firefly-iii.git
				synced 2025-10-25 05:03:13 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			113 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			113 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * ForgotPasswordController.php
 | |
|  * Copyright (c) 2017 thegrumpydictator@gmail.com
 | |
|  *
 | |
|  * This file is part of Firefly III.
 | |
|  *
 | |
|  * Firefly III is free software: you can redistribute it and/or modify
 | |
|  * it under the terms of the GNU General Public License as published by
 | |
|  * the Free Software Foundation, either version 3 of the License, or
 | |
|  * (at your option) any later version.
 | |
|  *
 | |
|  * Firefly III is distributed in the hope that it will be useful,
 | |
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
|  * GNU General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU General Public License
 | |
|  * along with Firefly III. If not, see <http://www.gnu.org/licenses/>.
 | |
|  */
 | |
| /** @noinspection PhpDynamicAsStaticMethodCallInspection */
 | |
| declare(strict_types=1);
 | |
| 
 | |
| namespace FireflyIII\Http\Controllers\Auth;
 | |
| 
 | |
| use FireflyConfig;
 | |
| use FireflyIII\Http\Controllers\Controller;
 | |
| use FireflyIII\Repositories\User\UserRepositoryInterface;
 | |
| use FireflyIII\User;
 | |
| use Illuminate\Foundation\Auth\SendsPasswordResetEmails;
 | |
| use Illuminate\Http\Request;
 | |
| use Illuminate\Support\Facades\Password;
 | |
| 
 | |
| /**
 | |
|  * Class ForgotPasswordController
 | |
|  */
 | |
| class ForgotPasswordController extends Controller
 | |
| {
 | |
|     /*
 | |
|     |--------------------------------------------------------------------------
 | |
|     | Password Reset Controller
 | |
|     |--------------------------------------------------------------------------
 | |
|     |
 | |
|     | This controller is responsible for handling password reset emails and
 | |
|     | includes a trait which assists in sending these notifications from
 | |
|     | your application to your users. Feel free to explore this trait.
 | |
|     |
 | |
|     */
 | |
| 
 | |
|     use SendsPasswordResetEmails;
 | |
| 
 | |
|     /**
 | |
|      * Create a new controller instance.
 | |
|      */
 | |
|     public function __construct()
 | |
|     {
 | |
|         parent::__construct();
 | |
|         $this->middleware('guest');
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Send a reset link to the given user.
 | |
|      *
 | |
|      * @param  \Illuminate\Http\Request $request
 | |
|      *
 | |
|      * @param UserRepositoryInterface   $repository
 | |
|      *
 | |
|      * @return \Illuminate\Http\RedirectResponse|\Illuminate\Http\JsonResponse
 | |
|      */
 | |
|     public function sendResetLinkEmail(Request $request, UserRepositoryInterface $repository)
 | |
|     {
 | |
|         $this->validateEmail($request);
 | |
| 
 | |
|         // verify if the user is not a demo user. If so, we give him back an error.
 | |
|         $user = User::where('email', $request->get('email'))->first();
 | |
| 
 | |
|         if (null !== $user && $repository->hasRole($user, 'demo')) {
 | |
|             return back()->withErrors(['email' => trans('firefly.cannot_reset_demo_user')]);
 | |
|         }
 | |
| 
 | |
|         // We will send the password reset link to this user. Once we have attempted
 | |
|         // to send the link, we will examine the response then see the message we
 | |
|         // need to show to the user. Finally, we'll send out a proper response.
 | |
|         $response = $this->broker()->sendResetLink(
 | |
|             $request->only('email')
 | |
|         );
 | |
| 
 | |
|         if ($response === Password::RESET_LINK_SENT) {
 | |
|             return back()->with('status', trans($response));
 | |
|         }
 | |
| 
 | |
|         return back()->withErrors(['email' => trans($response)]); // @codeCoverageIgnore
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @codeCoverageIgnore
 | |
|      *
 | |
|      * @return \Illuminate\Contracts\View\Factory|\Illuminate\View\View
 | |
|      */
 | |
|     public function showLinkRequestForm()
 | |
|     {
 | |
|         // is allowed to?
 | |
|         $singleUserMode    = FireflyConfig::get('single_user_mode', config('firefly.configuration.single_user_mode'))->data;
 | |
|         $userCount         = User::count();
 | |
|         $allowRegistration = true;
 | |
|         if (true === $singleUserMode && $userCount > 0) {
 | |
|             $allowRegistration = false;
 | |
|         }
 | |
| 
 | |
|         return view('auth.passwords.email')->with(compact('allowRegistration'));
 | |
|     }
 | |
| }
 |