使用Code Igniter和Doctrine ORM为每条记录创建一个标记

时间:2010-11-16 04:52:31

标签: php codeigniter doctrine

我使用Doctrine进行模型设置。我想为每条记录生成一个令牌,所以我想想我需要使用Symfony重载Doctrine的save()函数:

class JobeetAffiliate extends BaseJobeetAffiliate
{
  public function save(Doctrine_Connection $conn = null)
  {
    if (!$this->getToken())
    {
      $this->setToken(sha1($this->getEmail().rand(11111, 99999)));
    }

    return parent::save($conn);
  }

  // ...
} 

我目前的型号如下:

<?php
class Photo extends Doctrine_Record {

    public function setTableDefinition() {
        $this->hasColumn('photo_path', 'string', 255, array('unique' => 'true'));
        $this->hasColumn('count', 'integer', 4, array('unsigned' => 'true'));
        $this->hasColumn('is_count', 'integer', 4, array('unsigned' => 'true'));
        $this->hasColumn('region_id', 'integer', 4);
        $this->hasColumn('region_id', 'integer', 4);
        $this->hasColumn('token', 'string', 255);
    }

    public function setUp() {
        $this->actAs('Timestampable');
        $this->hasOne('Region', array(
            'local' => 'region_id',
            'foreign' => 'id'
        ));     
    }   

}

任何有关在模型中生成令牌字段的帮助都会非常感激,因为我无法弄清楚如何在该模型中适当地重载save()。

2 个答案:

答案 0 :(得分:2)

您应该查看Doctrine的Record Hooks及其preSave()函数。所以你只需要在你的模型中工作:

public function setTableDefinition() {
    $this->hasColumn('photo_path', 'string', 255, array('unique' => 'true'));
    $this->hasColumn('count', 'integer', 4, array('unsigned' => 'true'));
    $this->hasColumn('is_count', 'integer', 4, array('unsigned' => 'true'));
    $this->hasColumn('region_id', 'integer', 4);
    $this->hasColumn('region_id', 'integer', 4);
    $this->hasColumn('token', 'string', 255);
}

public function setUp() {
    $this->actAs('Timestampable');
    $this->hasOne('Region', array(
        'local' => 'region_id',
        'foreign' => 'id'
    ));     
}   

public funcion preSave($event) {
    if( ! $this->token) {
        $this->setToken(sha1($this->getEmail().rand(11111, 99999)));
     }
}

答案 1 :(得分:0)

你不能只在Photo类中添加save()方法吗?