2013-07-26 19 views
8

現在ログインしているユーザーをリスナーに挿入しようとしています。私の目標は、ユーザーが何らかの操作を行うたびに(現在のthisメソッドは私のためには機能しません)、私の 'demo_user'テーブルの 'last_active'カラムに現在の\ DateTime()を書き込むことです。Symfony2 - 現在ログインしているユーザーをリスナーに挿入

アプリ/設定/ config.yml

# ... 
services: 
    demo.listener: 
     class: Demo\UserBundle\EventListener\ActivityWatcher.php 
     arguments: ['@service_container'] 
     tags: 
      - { name: doctrine.event_listener, event: postLoad } 

のsrc /デモ/ UserBundle /イベントリスナー/ ActivityWatcher.php

namespace Demo\UserBundle\EventListener; 

use Doctrine\ORM\Event\LifecycleEventArgs; 
use Symfony\Component\DependencyInjection\ContainerInterface; 
use Demo\UserBundle\Entity\DemoUser; 

class ActivityWatcher 
{ 

    protected $container; 

    public function __construct(ContainerInterface $container) 
    { 
     $this->container = $container; 
    } 


    public function postLoad(LifecycleEventArgs $args) 
    { 
     $entity = $args->getEntity(); 
     $entityManager = $args->getEntityManager(); 

     if ($entity instanceof DemoUser) { 
      $token = $this->container->get('security.context')->getToken(); 
      $user = $token->getUser(); 

      if($entity->getId() == $user->getId()) { 
       $entity->setLastActivity(new \DateTime()); 
       $entityManager->persist($entity); 
       $entityManager->flush(); 
      } 
     } 
    } 
} 

しかし、$トークンは常に空です... 更新:これが発生したときにログインし、認証されたことを言及していませんでした。

FatalErrorException: Error: Call to a member function getUser() 
on a non-object ... 

アイデア? Arrgh、おかげで、月

UPDATE:

arguments: ["@security.context"] 

が、循環参照の問題を解決

ServiceCircularReferenceException: Circular reference detected for "doctrine.orm.default_entity_manager", path: "doctrine.orm.default_entity_manager -> doctrine.dbal.default_connection -> wwk.listener -> security.context -> security.authentication.manager -> security.user.provider.concrete.administrators". 
+0

ないellegantソリューションが、ユーザーを取得するには@service_container 使用 @=service('security.context').getToken().getUser():http://stackoverflow.com/questions/7561013/injecting- symfony2-causes-circ- –

+0

私はこの時点でこれを正確に実行しようとしていると思いますが、成功していないと思います。 – jxp315

+0

@JovanPerovicが提供するリンクは問題ありません。正解はこれです:http://stackoverflow.com/questions/7561013/injecting-securitycontext-into-a-listener-prepersist-or-preupdate-in-symfony2-to#26011863 – webDEVILopers

答えて

2
あなたが表現を注入することができるはず symfony 2.4ため

、 ので、代わりに直接

+2

こんにちは、私はこれを試しましたが、私は同じ問題があります:サービス "doctrine.orm.default_entity_manager" *のための循環参照が検出されました。 'doctrine.event_listener'を使用している間に' @ security.context'を呼び出すように見えますが、それでもエラーが発生します。 –

+0

これは私にとって完璧に機能しました。 Symfony genieありがとう –

0

を得た:

私はまた、唯一のsecurity.contextを注入しようとしました現在のユーザーを注入すると、ユーザーが呼び出し可能になります。

KnpDoctrineBehaviorsが提供するUserCallableクラスを使用できます。

まず、ユーザーの呼び出し可能クラスからサービスを作成し、そのサービスにコンテナを注入する必要があります。

KnpDoctrineBehaviorsによって提供される設定で、これを行う方法に関するYMLの例が見つかります。

今すぐUserCallableサービスをリスナーに挿入し、source of Blameable listenerのようにユーザー呼び出し可能なユーザーからユーザーを取得してください。

関連する問題