mirror of
				https://github.com/firefly-iii/firefly-iii.git
				synced 2025-10-26 05:26:17 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			226 lines
		
	
	
		
			6.8 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			226 lines
		
	
	
		
			6.8 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * UserEventHandler.php
 | |
|  * Copyright (C) 2016 thegrumpydictator@gmail.com
 | |
|  *
 | |
|  * This software may be modified and distributed under the terms of the
 | |
|  * Creative Commons Attribution-ShareAlike 4.0 International License.
 | |
|  *
 | |
|  * See the LICENSE file for details.
 | |
|  */
 | |
| 
 | |
| declare(strict_types = 1);
 | |
| 
 | |
| namespace FireflyIII\Handlers\Events;
 | |
| 
 | |
| use Exception;
 | |
| use FireflyIII\Events\ConfirmedUser;
 | |
| use FireflyIII\Events\RegisteredUser;
 | |
| use FireflyIII\Events\ResentConfirmation;
 | |
| use FireflyIII\Repositories\User\UserRepositoryInterface;
 | |
| use Illuminate\Mail\Message;
 | |
| use Log;
 | |
| use Mail;
 | |
| use Preferences;
 | |
| use Session;
 | |
| use Swift_TransportException;
 | |
| 
 | |
| /**
 | |
|  * Class UserEventHandler
 | |
|  *
 | |
|  * This class responds to any events that have anything to do with the User object.
 | |
|  *
 | |
|  * The method name reflects what is being done. This is in the present tense.
 | |
|  *
 | |
|  *
 | |
|  * @package FireflyIII\Handlers\Events
 | |
|  */
 | |
| class UserEventHandler
 | |
| {
 | |
| 
 | |
|     /**
 | |
|      * This method will bestow upon a user the "owner" role if he is the first user in the system.
 | |
|      *
 | |
|      * @param RegisteredUser $event
 | |
|      *
 | |
|      * @return bool
 | |
|      */
 | |
|     public function attachUserRole(RegisteredUser $event): bool
 | |
|     {
 | |
|         /** @var UserRepositoryInterface $repository */
 | |
|         $repository = app(UserRepositoryInterface::class);
 | |
| 
 | |
|         // first user ever?
 | |
|         if ($repository->count() === 1) {
 | |
|             $repository->attachRole($event->user, 'owner');
 | |
|         }
 | |
| 
 | |
|         return true;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Handle user logout events.
 | |
|      *
 | |
|      * @return bool
 | |
|      */
 | |
|     public function logoutUser(): bool
 | |
|     {
 | |
|         // dump stuff from the session:
 | |
|         Session::forget('twofactor-authenticated');
 | |
|         Session::forget('twofactor-authenticated-date');
 | |
| 
 | |
|         return true;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * This method will send a newly registered user a confirmation message, urging him or her to activate their account.
 | |
|      *
 | |
|      * @param RegisteredUser $event
 | |
|      *
 | |
|      * @return bool
 | |
|      */
 | |
|     public function sendConfirmationMessage(RegisteredUser $event): bool
 | |
|     {
 | |
|         $user           = $event->user;
 | |
|         $ipAddress      = $event->ipAddress;
 | |
|         $confirmAccount = env('MUST_CONFIRM_ACCOUNT', false);
 | |
|         if ($confirmAccount === false) {
 | |
|             Preferences::setForUser($user, 'user_confirmed', true);
 | |
|             Preferences::setForUser($user, 'user_confirmed_last_mail', 0);
 | |
|             Preferences::mark();
 | |
| 
 | |
|             return true;
 | |
|         }
 | |
|         $email = $user->email;
 | |
|         $code  = str_random(16);
 | |
|         $route = route('do_confirm_account', [$code]);
 | |
|         Preferences::setForUser($user, 'user_confirmed', false);
 | |
|         Preferences::setForUser($user, 'user_confirmed_last_mail', time());
 | |
|         Preferences::setForUser($user, 'user_confirmed_code', $code);
 | |
|         try {
 | |
|             Mail::send(
 | |
|                 ['emails.confirm-account-html', 'emails.confirm-account'], ['route' => $route, 'ip' => $ipAddress],
 | |
|                 function (Message $message) use ($email) {
 | |
|                     $message->to($email, $email)->subject('Please confirm your Firefly III account');
 | |
|                 }
 | |
|             );
 | |
|         } catch (Swift_TransportException $e) {
 | |
|             Log::error($e->getMessage());
 | |
|         } catch (Exception $e) {
 | |
|             Log::error($e->getMessage());
 | |
|         }
 | |
| 
 | |
|         return true;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * If the user has somehow lost his or her confirmation message, this event will send it to the user again.
 | |
|      *
 | |
|      * At the moment, this method is exactly the same as the ::sendConfirmationMessage method, but that will change.
 | |
|      *
 | |
|      * @param ResentConfirmation $event
 | |
|      *
 | |
|      * @return bool
 | |
|      */
 | |
|     function sendConfirmationMessageAgain(ResentConfirmation $event): bool
 | |
|     {
 | |
|         $user           = $event->user;
 | |
|         $ipAddress      = $event->ipAddress;
 | |
|         $confirmAccount = env('MUST_CONFIRM_ACCOUNT', false);
 | |
|         if ($confirmAccount === false) {
 | |
|             Preferences::setForUser($user, 'user_confirmed', true);
 | |
|             Preferences::setForUser($user, 'user_confirmed_last_mail', 0);
 | |
|             Preferences::mark();
 | |
| 
 | |
|             return true;
 | |
|         }
 | |
|         $email = $user->email;
 | |
|         $code  = str_random(16);
 | |
|         $route = route('do_confirm_account', [$code]);
 | |
|         Preferences::setForUser($user, 'user_confirmed', false);
 | |
|         Preferences::setForUser($user, 'user_confirmed_last_mail', time());
 | |
|         Preferences::setForUser($user, 'user_confirmed_code', $code);
 | |
|         try {
 | |
|             Mail::send(
 | |
|                 ['emails.confirm-account-html', 'emails.confirm-account'], ['route' => $route, 'ip' => $ipAddress],
 | |
|                 function (Message $message) use ($email) {
 | |
|                     $message->to($email, $email)->subject('Please confirm your Firefly III account');
 | |
|                 }
 | |
|             );
 | |
|         } catch (Swift_TransportException $e) {
 | |
|             Log::error($e->getMessage());
 | |
|         } catch (Exception $e) {
 | |
|             Log::error($e->getMessage());
 | |
|         }
 | |
| 
 | |
|         return true;
 | |
| 
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * This method will send the user a registration mail, welcoming him or her to Firefly III.
 | |
|      * This message is only sent when the configuration of Firefly III says so.
 | |
|      *
 | |
|      * @param RegisteredUser $event
 | |
|      *
 | |
|      * @return bool
 | |
|      */
 | |
|     public function sendRegistrationMail(RegisteredUser $event)
 | |
|     {
 | |
| 
 | |
|         $sendMail = env('SEND_REGISTRATION_MAIL', true);
 | |
|         if (!$sendMail) {
 | |
|             return true;
 | |
|         }
 | |
|         // get the email address
 | |
|         $email     = $event->user->email;
 | |
|         $address   = route('index');
 | |
|         $ipAddress = $event->ipAddress;
 | |
|         // send email.
 | |
|         try {
 | |
|             Mail::send(
 | |
|                 ['emails.registered-html', 'emails.registered'], ['address' => $address, 'ip' => $ipAddress], function (Message $message) use ($email) {
 | |
|                 $message->to($email, $email)->subject('Welcome to Firefly III! ');
 | |
|             }
 | |
|             );
 | |
|         } catch (Swift_TransportException $e) {
 | |
|             Log::error($e->getMessage());
 | |
|         }
 | |
| 
 | |
|         return true;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * When the user is confirmed, this method stores the IP address of the user
 | |
|      * as a preference. Since this preference cannot be edited, it is effectively hidden
 | |
|      * from the user yet stored conveniently.
 | |
|      *
 | |
|      * @param ConfirmedUser $event
 | |
|      *
 | |
|      * @return bool
 | |
|      */
 | |
|     public function storeConfirmationIpAddress(ConfirmedUser $event): bool
 | |
|     {
 | |
|         Preferences::setForUser($event->user, 'confirmation_ip_address', $event->ipAddress);
 | |
| 
 | |
|         return true;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * This message stores the users IP address on registration, in much the same
 | |
|      * fashion as the previous method.
 | |
|      *
 | |
|      * @param RegisteredUser $event
 | |
|      *
 | |
|      * @return bool
 | |
|      */
 | |
|     public function storeRegistrationIpAddress(RegisteredUser $event): bool
 | |
|     {
 | |
|         Preferences::setForUser($event->user, 'registration_ip_address', $event->ipAddress);
 | |
| 
 | |
|         return true;
 | |
| 
 | |
|     }
 | |
| 
 | |
| }
 |