Подтверждение по электронной почте на профиле FOSUserBundle Редактировать - PullRequest
13 голосов
/ 03 апреля 2012

Я хотел бы активировать подтверждение по электронной почте на FOSUserBundle / profile / edit

В / profile / edit вы уже вошли в систему и можете редактировать имя пользователя или адрес электронной почты, вводя текущий пароль. Теперь я хотел бы отправить подтверждение по электронной почте, если пользователь отредактирует адрес электронной почты:)

В справочнике по конфигурации FOSUserBundle Я не нашел настройки для этого ... https://github.com/FriendsOfSymfony/FOSUserBundle/blob/master/Resources/doc/configuration_reference.md

Это мои текущие настройки:

fos_user:
  db_driver: orm
  firewall_name: main
  user_class: Acme\CoreBundle\Entity\User
  registration:
    confirmation: { enabled: true }
  from_email:
    address: noreply@%domain%
    sender_name: %site_name% Staff
  resetting:
    token_ttl: %reset_password_ttl%

Кто-нибудь может мне помочь?

Ответы [ 2 ]

17 голосов
/ 04 мая 2013

Используя новые события FOSUserBundle (функция FOS 2.0), вы можете создать ChangeProfileListener, который обрабатывает изменения электронной почты.

Идея: использовать ту же логику, что и при регистрации: отключить нашего пользователя, отправить ему токен (и выйти из него для нашего случая).

Есть две вещи, которые нужно сделать:

  • создать участника события
  • перезаписать mail.txt.twig, чтобы заменить сообщение «регистрация» нейтральным сообщением «подтверждение по электронной почте».

Вот мой слушатель, не забудьте заменить пространство имен.

EventListener / ChangeProfileListener.php:

<?php

// src/Fuz/HomeBundle/EventListener/ChangeProfileListener.php

namespace Fuz\HomeBundle\EventListener;

use FOS\UserBundle\FOSUserEvents;
use FOS\UserBundle\Event\GetResponseUserEvent;
use FOS\UserBundle\Event\FormEvent;
use FOS\UserBundle\Mailer\MailerInterface;
use FOS\UserBundle\Util\TokenGeneratorInterface;
use Symfony\Component\Security\Core\Authentication\Token\Storage\TokenStorageInterface;
use Symfony\Component\EventDispatcher\EventSubscriberInterface;
use Symfony\Component\HttpFoundation\RedirectResponse;
use Symfony\Component\HttpFoundation\Session\SessionInterface;
use Symfony\Component\Routing\Generator\UrlGeneratorInterface;

class ChangeProfileListener implements EventSubscriberInterface
{

    private $mailer;
    private $tokenGenerator;
    private $router;
    private $session;
    private $tokenStorage;

    public function __construct(MailerInterface $mailer, TokenGeneratorInterface $tokenGenerator,
       UrlGeneratorInterface $router, SessionInterface $session, TokenStorageInterface $tokenStorage)
    {
        $this->mailer = $mailer;
        $this->tokenGenerator = $tokenGenerator;
        $this->router = $router;
        $this->session = $session;
        $this->tokenStorage = $tokenStorage;
    }

    public static function getSubscribedEvents()
    {
        return array(
                FOSUserEvents::PROFILE_EDIT_INITIALIZE => 'onProfileEditInitialize',
                FOSUserEvents::PROFILE_EDIT_SUCCESS => 'onProfileEditSuccess',
        );
    }

    public function onProfileEditInitialize(GetResponseUserEvent $event)
    {
        // required, because when Success's event is called, session already contains new email
        $this->email = $event->getUser()->getEmail();
    }

    public function onProfileEditSuccess(FormEvent $event)
    {
        $user = $event->getForm()->getData();
        if ($user->getEmail() !== $this->email)
        {
            // disable user
            $user->setEnabled(false);

            // send confirmation token to new email
            $user->setConfirmationToken($this->tokenGenerator->generateToken());
            $this->mailer->sendConfirmationEmailMessage($user);

            // force user to log-out
            $this->tokenStorage->setToken();

            // redirect user to check email page
            $this->session->set('fos_user_send_confirmation_email/email', $user->getEmail());
            $url = $this->router->generate('fos_user_registration_check_email');
            $event->setResponse(new RedirectResponse($url));
        }
    }

}

services.yml:

parameters:
    fuz_home.email_change.listener.class: Fuz\HomeBundle\EventListener\ChangeProfileListener

services:
      fuz_home.email_change.listener:
          class: %fuz_home.email_change.listener.class%
          arguments: ['@fos_user.mailer', '@fos_user.util.token_generator', '@router', '@session', '@security.token_storage']
          tags:
            - { name: kernel.event_subscriber }

О перезаписи шаблона электронной почты, это просто создание приложения / Resources / FOSUserBundle / views / Registration / email.txt.twig и вставка, например:

{% block subject %}
Email Confirmation
{% endblock %}

{% block body_text %}

Welcome to example.com, {{ user.username }}!                                                

To confirm your email, please follow this link:                                                                    
{{ confirmationUrl }}

You will be able to log-in using the username or email you given:                                        

Username : {{ user.username }}                                                                                                         
Email    : {{ user.email }}                                                                                                 

If you received this e-mail in error just ignore this message. No further actions are required from you.                  



                                                     *****                                                           

                                                 See you soon!
{% endblock %}
4 голосов
/ 15 мая 2012

Функция отправки электронного письма с подтверждением существует только в

RegistrationFormHandler->onSucces

где эта переменная конфигурации передается и проверяется. Аналогичная функциональность отсутствует в профиле / редактировать:

ProfileFormHandler->onSuccess.

Поэтому вам необходимо переопределить FOS ProfileFormHandler и добавить эту функцию самостоятельно. Это описано в документации FOSUserBundle: переопределение форм .

...