| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202 |
- <?php
- class Post extends CActiveRecord
- {
- /**
- * The followings are the available columns in table 'tbl_post':
- * @var integer $id
- * @var string $title
- * @var string $content
- * @var string $tags
- * @var integer $status
- * @var integer $create_time
- * @var integer $update_time
- * @var integer $author_id
- */
- const STATUS_DRAFT=1;
- const STATUS_PUBLISHED=2;
- const STATUS_ARCHIVED=3;
- private $_oldTags;
- /**
- * Returns the static model of the specified AR class.
- * @return CActiveRecord the static model class
- */
- public static function model($className=__CLASS__)
- {
- return parent::model($className);
- }
- /**
- * @return string the associated database table name
- */
- public function tableName()
- {
- return '{{post}}';
- }
- /**
- * @return array validation rules for model attributes.
- */
- public function rules()
- {
- // NOTE: you should only define rules for those attributes that
- // will receive user inputs.
- return array(
- array('title, content, status', 'required'),
- array('status', 'in', 'range'=>array(1,2,3)),
- array('title', 'length', 'max'=>128),
- array('tags', 'match', 'pattern'=>'/^[\w\s,]+$/', 'message'=>'Tags can only contain word characters.'),
- array('tags', 'normalizeTags'),
- array('title, status', 'safe', 'on'=>'search'),
- );
- }
- /**
- * @return array relational rules.
- */
- public function relations()
- {
- // NOTE: you may need to adjust the relation name and the related
- // class name for the relations automatically generated below.
- return array(
- 'author' => array(self::BELONGS_TO, 'User', 'author_id'),
- 'comments' => array(self::HAS_MANY, 'Comment', 'post_id', 'condition'=>'comments.status='.Comment::STATUS_APPROVED, 'order'=>'comments.create_time DESC'),
- 'commentCount' => array(self::STAT, 'Comment', 'post_id', 'condition'=>'status='.Comment::STATUS_APPROVED),
- );
- }
- /**
- * @return array customized attribute labels (name=>label)
- */
- public function attributeLabels()
- {
- return array(
- 'id' => 'Id',
- 'title' => 'Title',
- 'content' => 'Content',
- 'tags' => 'Tags',
- 'status' => 'Status',
- 'create_time' => 'Create Time',
- 'update_time' => 'Update Time',
- 'author_id' => 'Author',
- );
- }
- /**
- * @return string the URL that shows the detail of the post
- */
- public function getUrl()
- {
- return Yii::app()->createUrl('post/view', array(
- 'id'=>$this->id,
- 'title'=>$this->title,
- ));
- }
- /**
- * @return array a list of links that point to the post list filtered by every tag of this post
- */
- public function getTagLinks()
- {
- $links=array();
- foreach(Tag::string2array($this->tags) as $tag)
- $links[]=CHtml::link(CHtml::encode($tag), array('post/index', 'tag'=>$tag));
- return $links;
- }
- /**
- * Normalizes the user-entered tags.
- */
- public function normalizeTags($attribute,$params)
- {
- $this->tags=Tag::array2string(array_unique(Tag::string2array($this->tags)));
- }
- /**
- * Adds a new comment to this post.
- * This method will set status and post_id of the comment accordingly.
- * @param Comment the comment to be added
- * @return boolean whether the comment is saved successfully
- */
- public function addComment($comment)
- {
- if(Yii::app()->params['commentNeedApproval'])
- $comment->status=Comment::STATUS_PENDING;
- else
- $comment->status=Comment::STATUS_APPROVED;
- $comment->post_id=$this->id;
- return $comment->save();
- }
- /**
- * This is invoked when a record is populated with data from a find() call.
- */
- protected function afterFind()
- {
- parent::afterFind();
- $this->_oldTags=$this->tags;
- }
- /**
- * This is invoked before the record is saved.
- * @return boolean whether the record should be saved.
- */
- protected function beforeSave()
- {
- if(parent::beforeSave())
- {
- if($this->isNewRecord)
- {
- $this->create_time=$this->update_time=time();
- $this->author_id=Yii::app()->user->id;
- }
- else
- $this->update_time=time();
- return true;
- }
- else
- return false;
- }
- /**
- * This is invoked after the record is saved.
- */
- protected function afterSave()
- {
- parent::afterSave();
- Tag::model()->updateFrequency($this->_oldTags, $this->tags);
- }
- /**
- * This is invoked after the record is deleted.
- */
- protected function afterDelete()
- {
- parent::afterDelete();
- Comment::model()->deleteAll('post_id='.$this->id);
- Tag::model()->updateFrequency($this->tags, '');
- }
- /**
- * Retrieves the list of posts based on the current search/filter conditions.
- * @return CActiveDataProvider the data provider that can return the needed posts.
- */
- public function search()
- {
- $criteria=new CDbCriteria;
- $criteria->compare('title',$this->title,true);
- $criteria->compare('status',$this->status);
- return new CActiveDataProvider('Post', array(
- 'criteria'=>$criteria,
- 'sort'=>array(
- 'defaultOrder'=>'status, update_time DESC',
- ),
- ));
- }
- }
|