FOSUserBundle を使用して HWIOAuthBundle をセットアップするためにここにあるすべてのアドバイスに従いましたが、ユーザーが登録したときに発生するイベントにアクセスできるようにしたいのですが、これまでのところアクセスできないようです。この質問のアドバイスに従って、これが私のイベント サブスクライバーです (すべてのイベントに関心があるわけではありませんが、いずれかのイベントが起動されているかどうかをテストしたかっただけです)。
<?php
namespace Acme\ClientBundle\EventListener;
use FOS\UserBundle\Event\FilterUserResponseEvent;
use FOS\UserBundle\Event\FormEvent;
use FOS\UserBundle\Event\GetResponseUserEvent;
use Symfony\Component\EventDispatcher\EventSubscriberInterface;
use FOS\UserBundle\FOSUserEvents;
use FOS\UserBundle\Event\UserEvent;
use Symfony\Bridge\Monolog\Logger;
/**
* RegistrationConfirmListener
*/
class RegistrationConfirmListener implements EventSubscriberInterface
{
/**
* @var Logger
*/
private $logger;
function __construct(UrlGeneratorInterface $router, Logger $logger)
{
$this->router = $router;
$this->logger = $logger;
}
public static function getSubscribedEvents()
{
return array(
FOSUserEvents::REGISTRATION_INITIALIZE => 'onRegistrationInit',
FOSUserEvents::REGISTRATION_CONFIRM => 'onRegistrationConfirm',
FOSUserEvents::REGISTRATION_CONFIRMED => 'onRegistrationConfirmed',
FOSUserEvents::REGISTRATION_COMPLETED => 'onRegistrationCompleted',
FOSUserEvents::REGISTRATION_SUCCESS => 'onRegistrationSuccess',
);
}
public function onRegistrationInit(UserEvent $event)
{
$this->logger->info('Registration has started: ' . serialize($event));
}
public function onRegistrationConfirm(GetResponseUserEvent $event)
{
$this->logger->info("Registration is confirming: " . serialize($event));
}
public function onRegistrationConfirmed(FilterUserResponseEvent $event)
{
$this->logger->info("Registration has been confirmed: " . serialize($event));
}
public function onRegistrationCompleted(FilterUserResponseEvent $event)
{
$this->logger->info("Registration has been completed: " . serialize($event));
}
public function onRegistrationSuccess(FormEvent $event)
{
$this->logger->info("Registration has been successful: " . serialize($event));
}
}
そして、ここに私のサービス定義があります:
acme_user.registration_complete:
class: Acme\ClientBundle\EventListener\RegistrationConfirmListener
arguments: [ @router, @logger ]
tags:
- { name: kernel.event_subscriber }
ただし、認証/登録が成功したにもかかわらず、ログに記録されている FOSUserEvents が表示されません。私が関連していると思われる唯一の他の情報は、FOSUserBundle を SonataAdminBundle と統合していることです。これも正しく機能しているようです。(まあ、FOSUserBundle を v2.0 にアップグレードする方法を見つけて、必要な変更を修正したら、正しくはありません。)
これらのイベントにフックできるようにするために、ここで何が欠けているのか誰にもわかりませんか?