. */ declare(strict_types=1); namespace FireflyIII\Handlers\Events; use FireflyIII\Events\RegisteredUser; use FireflyIII\Events\RequestedNewPassword; use FireflyIII\Events\UserChangedEmail; use FireflyIII\Mail\ConfirmEmailChangeMail; use FireflyIII\Mail\RegisteredUser as RegisteredUserMail; use FireflyIII\Mail\RequestedNewPassword as RequestedNewPasswordMail; use FireflyIII\Mail\UndoEmailChangeMail; use FireflyIII\Models\Role; use FireflyIII\Repositories\User\UserRepositoryInterface; use FireflyIII\User; use Illuminate\Auth\Events\Login; use Log; use Mail; use Preferences; 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. */ 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 (1 === $repository->count()) { $repository->attachRole($event->user, 'owner'); } return true; } /** * @param Login $event * * @return bool */ public function checkSingleUserIsAdmin(Login $event): bool { Log::debug('In checkSingleUserIsAdmin'); /** @var User $user */ $user = $event->user; $count = User::count(); if ($count > 1) { // if more than one user, do nothing. Log::debug(sprintf('System has %d users, will not change users roles.', $count)); return true; } // user is only user but has admin role if (1 === $count && $user->hasRole('owner')) { Log::debug(sprintf('User #%d is only user but has role owner so all is well.', $user->id)); return true; } // user is the only user but does not have role "owner". $role = Role::where('name', 'owner')->first(); if (is_null($role)) { // create role, does not exist. Very strange situation so let's raise a big fuss about it. $role = Role::create(['name' => 'owner', 'display_name' => 'Site Owner', 'description' => 'User runs this instance of FF3']); Log::error('Could not find role "owner". This is weird.'); } Log::info(sprintf('Gave user #%d role #%d ("%s")', $user->id, $role->id, $role->name)); // give user the role $user->attachRole($role); $user->save(); return true; } /** * @param UserChangedEmail $event * * @return bool */ public function sendEmailChangeConfirmMail(UserChangedEmail $event): bool { $newEmail = $event->newEmail; $oldEmail = $event->oldEmail; $user = $event->user; $ipAddress = $event->ipAddress; $token = Preferences::getForUser($user, 'email_change_confirm_token', 'invalid'); $uri = route('profile.confirm-email-change', [$token->data]); try { Mail::to($newEmail)->send(new ConfirmEmailChangeMail($newEmail, $oldEmail, $uri, $ipAddress)); // @codeCoverageIgnoreStart } catch (Swift_TransportException $e) { Log::error($e->getMessage()); } // @codeCoverageIgnoreEnd return true; } /** * @param UserChangedEmail $event * * @return bool */ public function sendEmailChangeUndoMail(UserChangedEmail $event): bool { $newEmail = $event->newEmail; $oldEmail = $event->oldEmail; $user = $event->user; $ipAddress = $event->ipAddress; $token = Preferences::getForUser($user, 'email_change_undo_token', 'invalid'); $uri = route('profile.undo-email-change', [$token->data, hash('sha256', $oldEmail)]); try { Mail::to($oldEmail)->send(new UndoEmailChangeMail($newEmail, $oldEmail, $uri, $ipAddress)); // @codeCoverageIgnoreStart } catch (Swift_TransportException $e) { Log::error($e->getMessage()); } // @codeCoverageIgnoreEnd return true; } /** * @param RequestedNewPassword $event * * @return bool */ public function sendNewPassword(RequestedNewPassword $event): bool { $email = $event->user->email; $ipAddress = $event->ipAddress; $token = $event->token; $url = route('password.reset', [$token]); // send email. try { Mail::to($email)->send(new RequestedNewPasswordMail($url, $ipAddress)); // @codeCoverageIgnoreStart } catch (Swift_TransportException $e) { Log::error($e->getMessage()); } // @codeCoverageIgnoreEnd 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; // @codeCoverageIgnore } // get the email address $email = $event->user->email; $uri = route('index'); $ipAddress = $event->ipAddress; // send email. try { Mail::to($email)->send(new RegisteredUserMail($uri, $ipAddress)); // @codeCoverageIgnoreStart } catch (Swift_TransportException $e) { Log::error($e->getMessage()); } // @codeCoverageIgnoreEnd return true; } }