|
|
|
|
<?php
|
|
|
|
|
namespace Mobile\Model;
|
|
|
|
|
|
|
|
|
|
use Think\Model;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 金币提现记录
|
|
|
|
|
*/
|
|
|
|
|
class WithdrawGoldCoinModel extends Model{
|
|
|
|
|
/* 自动验证规则 */
|
|
|
|
|
protected $_validate = array(
|
|
|
|
|
array('money','require','到账金额不能为空',self::MUST_VALIDATE,'regex', self::MODEL_BOTH),
|
|
|
|
|
//array('money','/^\d+(\.\d{1,2})?$/','到账金额不正确',self::MUST_VALIDATE,'regex', self::MODEL_BOTH),
|
|
|
|
|
array('coin','require','提现金币不能为空',self::MUST_VALIDATE,'regex', self::MODEL_BOTH),
|
|
|
|
|
//array('coin','/^\d+(\.\d{1,2})?$/','提现金币不正确',self::MUST_VALIDATE,'regex', self::MODEL_BOTH),
|
|
|
|
|
array('poundage','require','手续费不能为空',self::MUST_VALIDATE,'regex', self::MODEL_BOTH),
|
|
|
|
|
//array('poundage','/^\d+(\.\d{1,2})?$/','手续费不正确',self::MUST_VALIDATE,'regex', self::MODEL_BOTH),
|
|
|
|
|
array('gold_coin_balance','require','金币余额不能为空',self::MUST_VALIDATE,'regex', self::MODEL_BOTH),
|
|
|
|
|
array('alipay','require','支付宝不能为空',self::MUST_VALIDATE,'regex', self::MODEL_BOTH),
|
|
|
|
|
array('alipay_real_name','require','支付宝真实姓名不能为空',self::MUST_VALIDATE,'regex', self::MODEL_BOTH),
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
/* 自动完成规则 */
|
|
|
|
|
protected $_auto = array(
|
|
|
|
|
array('create_time', 'getCreateTime', self::MODEL_INSERT, 'callback'),
|
|
|
|
|
array('order_number', 'get_order_number', self::MODEL_INSERT, '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 string $fields 字段列表
|
|
|
|
|
* @param string $order 排序
|
|
|
|
|
* @param integer $row 每页数量
|
|
|
|
|
* @return array 结果数据集
|
|
|
|
|
* @author 鹿文学
|
|
|
|
|
*/
|
|
|
|
|
public function lists($p=1,$map=array(),$fields=true,$order='online_time desc',$row=10) {
|
|
|
|
|
$page = intval($p);
|
|
|
|
|
$page = $page ? $page : 1; //默认显示第一页数据
|
|
|
|
|
|
|
|
|
|
$user = D('User')->getLoginInfo();
|
|
|
|
|
if(is_array($user)){
|
|
|
|
|
$map['status'] = array('gt',0);
|
|
|
|
|
$map['user_id'] = $user['user_id'];
|
|
|
|
|
$lists = $this->alias('m')->field($fields)
|
|
|
|
|
->where($map)->page($page,$row)->order($order)->select();
|
|
|
|
|
|
|
|
|
|
$count = $this->alias('m')->where($map)->count();
|
|
|
|
|
}
|
|
|
|
|
if(is_array($lists)) {
|
|
|
|
|
$data['lists'] = $lists;$data['status']=1;
|
|
|
|
|
if($count > $row){
|
|
|
|
|
$data['total'] = ceil($count/$row);
|
|
|
|
|
} else {
|
|
|
|
|
$data['total']=1;
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
$data['lists']='';$data['total'] = 1;$data['status'] = 0;
|
|
|
|
|
}
|
|
|
|
|
$data['current'] = $page;
|
|
|
|
|
|
|
|
|
|
return $data;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 新增或更新一个记录
|
|
|
|
|
* @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{
|
|
|
|
|
$data['id'] = $id;
|
|
|
|
|
}
|
|
|
|
|
} else { //更新数据
|
|
|
|
|
$status = $this->save(); //更新基础内容
|
|
|
|
|
if(false === $status){
|
|
|
|
|
$this->error = '更新基础内容出错!';
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return $data;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 创建时间不写则取当前时间
|
|
|
|
|
* @return int 时间戳
|
|
|
|
|
* @author huajie <banhuajie@163.com>
|
|
|
|
|
*/
|
|
|
|
|
protected function getCreateTime(){
|
|
|
|
|
$create_time = I('post.create_time');
|
|
|
|
|
return $create_time?strtotime($create_time):NOW_TIME;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 创建订单号
|
|
|
|
|
* @return int 时间戳
|
|
|
|
|
* @author huajie <banhuajie@163.com>
|
|
|
|
|
*/
|
|
|
|
|
protected function get_order_number() {
|
|
|
|
|
$order_number = I('post.order_number');
|
|
|
|
|
return $order_number?$order_number:'WG_'.date('Ymd').date('His').sp_random_string(4);;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 获取商品总数
|
|
|
|
|
* @param array $map 条件数组
|
|
|
|
|
* @return integer 总数
|
|
|
|
|
* @author 鹿文学
|
|
|
|
|
*/
|
|
|
|
|
public function total($map) {
|
|
|
|
|
|
|
|
|
|
return $this->where($map)->count();
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 商品详情
|
|
|
|
|
* @param integer $id 商品编号
|
|
|
|
|
* @return array 结果数据集
|
|
|
|
|
* @author 鹿文学
|
|
|
|
|
*/
|
|
|
|
|
public function detail($id=0) {
|
|
|
|
|
|
|
|
|
|
if(is_numeric($id) && $id > 0) {
|
|
|
|
|
|
|
|
|
|
$map['m.id'] = $id;
|
|
|
|
|
|
|
|
|
|
$data = $this->merchandise_info($map);
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return $data;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 商品详情
|
|
|
|
|
* @param integer $id 商品编号
|
|
|
|
|
* @return array 结果数据集
|
|
|
|
|
* @author 鹿文学
|
|
|
|
|
*/
|
|
|
|
|
public function sale_detail($id=0) {
|
|
|
|
|
|
|
|
|
|
if(is_numeric($id) && $id > 0) {
|
|
|
|
|
|
|
|
|
|
$map['m.id'] = $id;
|
|
|
|
|
|
|
|
|
|
$map['m.status']=3;
|
|
|
|
|
|
|
|
|
|
$map['m.online_time'] = ['gt',0];
|
|
|
|
|
|
|
|
|
|
$data = $this->merchandise_info($map);
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return $data;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 商品详情
|
|
|
|
|
* @param integer $id 商品编号
|
|
|
|
|
* @return array 结果数据集
|
|
|
|
|
* @author 鹿文学
|
|
|
|
|
*/
|
|
|
|
|
public function deal_detail($id=0) {
|
|
|
|
|
|
|
|
|
|
if(is_numeric($id) && $id > 0) {
|
|
|
|
|
|
|
|
|
|
$map['m.id'] = $id;
|
|
|
|
|
|
|
|
|
|
$map['m.status']=1;
|
|
|
|
|
|
|
|
|
|
$data = $this->merchandise_info($map);
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return $data;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private function merchandise_info($map) {
|
|
|
|
|
|
|
|
|
|
return $this->alias('m')->field('m.id,m.title,m.content,m.status,m.screenshot,m.online_time,m.server_name,m.price,m.day,m.accumulation,m.small_account,g.relation_game_id,g.game_name,g.game_size,g.game_type_name,g.sdk_version,g.down_port,g.add_game_address,g.ios_game_address')
|
|
|
|
|
|
|
|
|
|
->join('tab_game as g on(g.id = m.game_id) ')
|
|
|
|
|
|
|
|
|
|
->where($map)->find();
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 商品信息
|
|
|
|
|
* @param integer $id 商品编号
|
|
|
|
|
* @return array 结果数据集
|
|
|
|
|
* @author 鹿文学
|
|
|
|
|
*/
|
|
|
|
|
public function info($id=0) {
|
|
|
|
|
|
|
|
|
|
if(is_numeric($id) && $id > 0) {
|
|
|
|
|
$map['m.id'] = $id;
|
|
|
|
|
|
|
|
|
|
$map['m.status'] = 3;
|
|
|
|
|
|
|
|
|
|
$map['m.online_time'] = ['gt',0];
|
|
|
|
|
|
|
|
|
|
$data = $this->alias('m')->field('m.id,m.title,m.price,m.game_name,m.screenshot')
|
|
|
|
|
|
|
|
|
|
->where($map)->find();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return $data;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 商品购买需要的信息
|
|
|
|
|
* @param integer $id 商品编号
|
|
|
|
|
* @return array 结果数据集
|
|
|
|
|
* @author 鹿文学
|
|
|
|
|
*/
|
|
|
|
|
public function buy_info($id=0) {
|
|
|
|
|
|
|
|
|
|
if(is_numeric($id) && $id > 0) {
|
|
|
|
|
$map['m.id'] = $id;
|
|
|
|
|
|
|
|
|
|
$map['m.status'] = 3;
|
|
|
|
|
|
|
|
|
|
$data = $this->alias('m')->field('m.id,m.price,m.small_id,m.small_account,m.user_id as seller_id,m.user_account as seller_account,m.game_id')
|
|
|
|
|
|
|
|
|
|
->where($map)->find();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return $data;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|