// +---------------------------------------------------------------------- namespace Admin\Model; use Think\Model; /** * 投放平台模型 * @author 鹿文学 */ class LaunchPlatformModel extends Model{ /* 自动验证规则 */ protected $_validate = array( array('name', 'require', '投放平台名称不能为空', self::MUST_VALIDATE, 'regex', self::MODEL_BOTH), array('name', '1,30', '投放平台名称不能超过30个字符', self::VALUE_VALIDATE, 'length', self::MODEL_BOTH), array('name', '', '该投放平台已添加,请重新输入!', self::EXISTS_VALIDATE, 'unique', self::MODEL_INSERT), array('name', '', '该投放平台已存在,请重新输入!', self::EXISTS_VALIDATE, 'unique', self::MODEL_UPDATE), ); /* 自动完成规则 */ protected $_auto = array( array('create_time', 'getCreateTime', self::MODEL_INSERT,'callback'), array('update_time', 'getUpdateTime', self::MODEL_BOTH,'callback'), ); /** * 构造函数 * @param string $name 模型名称 * @param string $tablePrefix 表前缀 * @param mixed $connection 数据库连接信息 */ public function __construct($name = '', $tablePrefix = '', $connection = '') { /* 设置默认的表前缀 */ $this->tablePrefix ='tab_'; /* 执行构造方法 */ parent::__construct($name, $tablePrefix, $connection); } /** * 投放平台列表 * @param integer $p 页码 * @param array $map 条件数组 * @param array $flag 是否需要分页(0:需要,1:不需要,只要数据) * @return array 结果数据集 * @author 鹿文学 */ public function lists($p=1,$map=array(),$flag=0) { $page = intval($p); $page = $page ? $page : 1; //默认显示第一页数据 if(isset($_REQUEST['row'])) {$row = $_REQUEST['row'];}else{$row = 10;} $lists = $this->where($map)->page($page,$row)->order('id desc')->select(); if($flag) { return $lists; } else { $count = $this->where($map)->count(); $data['data'] = $lists; $page = set_pagination($count,$row); if($page) {$data['page']=$page;} return $data; } } /** * 投放平台所有列表 * @param array $map 条件数组 * @return array 结果数据集 * @author 鹿文学 */ public function all_lists($map=array()) { $lists = $this->where($map)->order('id desc')->select(); return $lists; } /** * 创建时间不写则取当前时间 * @return int 时间戳 * @author huajie */ protected function getCreateTime(){ $create_time = I('post.create_time'); return $create_time?strtotime($create_time):NOW_TIME; } protected function getUpdateTime(){ $update_time = I('post.update_time'); return $update_time?strtotime($update_time):NOW_TIME; } /** * 新增或更新一个游戏 * @param array $data 手动传入的数据 * @return boolean fasle 失败 , int 成功 返回完整的数据 * @author 王贺 */ public function update($data = null){ /* 获取数据对象 */ $data = $this->token(false)->create($data); if(empty($data)){ return false; } /* 添加或新增基础内容 */ if(empty($data['id'])){ //新增数据 $id = $this->add($data); //添加基础内容 if(!$id){ $this->error = '新增基础内容出错!'; return false; } } else { //更新数据 $status = $this->save(); //更新基础内容 if(false === $status){ $this->error = '更新基础内容出错!'; return false; } } return $data; } /** * 删除投放平台 * @author 鹿文学 */ public function del() { $ids = array_unique((array)I('ids',null)); if (empty($ids)) { $this->error ='请选择要操作的数据!'; return false; } $map = array('id' => array('in', $ids) ); if($this->where($map)->delete()){ $this->error ='删除成功'; return true; } else { $this->error ='删除失败!'; return false; } } }