Проблема обратного вызова жизненного цикла при расширении пользовательского объекта FOSUserBundle

Я только что впервые импортировал FOSUserBundle в проект symfony2 и заметил проблему с расширением пользовательского объекта. Я добавил поля create_at и updated_at с обратными вызовами жизненного цикла prePersist и preUpdate, но эти методы не читаются.

Если я помещаю сеттеры для этих полей в конструктор, то поля заполняются (но, очевидно, это не работает правильно с updated_at). Другие поля, которые я добавил, работали, как и ожидалось.

Вам нужно каким-то образом расширить UserListener, чтобы события жизненного цикла работали правильно?

Пожалуйста, найдите мой код ниже, любая помощь или совет будет принята с благодарностью.

UserEntity:

namespace Acme\UserExtensionBundle\Entity;

use FOS\UserBundle\Entity\User as BaseUser;
use Doctrine\ORM\Mapping as ORM;
use Doctrine\Common\Collections\ArrayCollection;

/**
 * Acme\UserExtensionBundle\Entity\User
 *
 * @ORM\Table(name="acme_user")
 * @ORM\Entity()
 * @ORM\HasLifecycleCallbacks()
 */
class User extends BaseUser{

  /**
   * @var integer $id
   * @ORM\Column(name="id", type="integer")
   * @ORM\Id
   * @ORM\GeneratedValue(strategy="AUTO")
   */
  protected $id;

  /**
   * @var datetime $created_at
   * @ORM\Column(name="created_at", type="datetime")
   */
  protected $created_at;

  /**
   * @var datetime $updated_at
   * @ORM\Column(name="updated_at", type="datetime")
   */
  protected $updated_at;

  ...

  public function __construct() {
    parent::__construct();
    $this->created_at = new \DateTime;
    $this->updated_at = new \DateTime;
  }

  /*
   * @ORM\preUpdate
   */
  public function setUpdatedTimestamp(){
    $this->updated_at = new \DateTime();
  }

  ...

1 ответ

Решение

После быстрого просмотра я могу заметить только небольшую ошибку в случае имени аннотации.

Так должно быть

@ORM\PreUpdate

вместо

@ORM\preUpdate

который ИМХО должен привести к ошибке при выполнении.

В любом случае я бы предложил вам использовать пакет DoctrineExtensionsBundle, описанный в http://symfony.com/doc/current/cookbook/doctrine/common_extensions.html.

Он поставляется с метками времени (и многими другими), поэтому вам не нужно кодировать это самостоятельно (изобретать велосипед).

Я использую его вместе с FOSUserBundle, и он отлично работает. Вот как выглядит мое определение в User Entity:

 /**
 * @var \DateTime $created
 *
 * @Gedmo\Timestampable(on="create")
 * @ORM\Column(type="datetime")
 */
protected $created;

/**
 * @var \DateTime  $updated
 *
 * @Gedmo\Timestampable(on="update")
 * @ORM\Column(type="datetime")
 */
protected $updated;
Другие вопросы по тегам