You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
144 lines
4.2 KiB
PHP
144 lines
4.2 KiB
PHP
<?php
|
|
// +----------------------------------------------------------------------
|
|
// | OneThink [ WE CAN DO IT JUST THINK IT ]
|
|
// +----------------------------------------------------------------------
|
|
// | Copyright (c) 2013 http://www.onethink.cn All rights reserved.
|
|
// +----------------------------------------------------------------------
|
|
// | Author: 麦当苗儿 <zuojiazi@vip.qq.com> <http://www.zjzit.cn>
|
|
// +----------------------------------------------------------------------
|
|
|
|
namespace Admin\Model;
|
|
use Think\Model;
|
|
|
|
/**
|
|
* 分类模型
|
|
*/
|
|
class WithdrawModel extends Model{
|
|
|
|
//操作人类型
|
|
const OP_TYPE_PROMOTE = 1;
|
|
const OP_TYPE_ADMIN = 2;
|
|
const OP_TYPE_AUTO = 3;
|
|
|
|
//结算类型
|
|
const SETTLEMENT_TYPE_WEEK = 1;
|
|
const SETTLEMENT_TYPE_MONTH = 2;
|
|
const SETTLEMENT_TYPE_ADMIN = 3;
|
|
const SETTLEMENT_TYPE_PROMOTE = 4;
|
|
const SETTLEMENT_TYPE_OTHER = 5;
|
|
|
|
/**
|
|
* 构造函数
|
|
* @param string $name 模型名称
|
|
* @param string $tablePrefix 表前缀
|
|
* @param mixed $connection 数据库连接信息
|
|
*/
|
|
public function __construct($name = '', $tablePrefix = '', $connection = '') {
|
|
/* 设置默认的表前缀 */
|
|
$this->tablePrefix ='tab_';
|
|
/* 执行构造方法 */
|
|
parent::__construct($name, $tablePrefix, $connection);
|
|
}
|
|
|
|
public static $opTypeList = [
|
|
self::OP_TYPE_PROMOTE => '推广员',
|
|
self::OP_TYPE_ADMIN => '管理员',
|
|
self::OP_TYPE_AUTO => '自动',
|
|
];
|
|
|
|
public static $settlementTypeList = [
|
|
self::SETTLEMENT_TYPE_WEEK => '周结',
|
|
self::SETTLEMENT_TYPE_MONTH => '月结',
|
|
self::SETTLEMENT_TYPE_ADMIN => '管理员提现',
|
|
self::SETTLEMENT_TYPE_OTHER => '其他',
|
|
];
|
|
|
|
/*
|
|
* 开发者提现未处理列表
|
|
* @return array 检测结果数据集
|
|
* @author 鹿文学
|
|
*/
|
|
public function checkDeveloperWithdraw() {
|
|
|
|
$list = $this->field('tab_withdraw.id,tab_withdraw.settlement_number,tab_developers.account')
|
|
|
|
->join('tab_developers on (tab_withdraw.developers = tab_developers.id) ','left')
|
|
|
|
->where(array('tab_withdraw.status'=>0,'tab_withdraw.developers'=>array('gt',0)))->select();
|
|
$type=200;
|
|
if ($list[0]) {
|
|
|
|
$list = D('check')->dealWithCheckList($type,$list);
|
|
|
|
if (empty($list[0])) {return '';}
|
|
|
|
foreach ($list as $k => $v) {
|
|
$data[$k]['info'] = '开发者:'.$v['account'].'申请提现,提现状态:未审核';
|
|
$data[$k]['type'] = $type;
|
|
$data[$k]['url'] = U('Query/cp_withdraw',array('settlement_number'=>$v['settlement_number']));
|
|
$data[$k]['create_time'] = time();
|
|
$data[$k]['status']=0;
|
|
$data[$k]['position'] = $v['id'];
|
|
}
|
|
return $data;
|
|
}else {
|
|
D('check')->dealWithCheckListOnNull($type);
|
|
return '';
|
|
}
|
|
|
|
}
|
|
|
|
|
|
/*
|
|
* 推广员提现未处理列表
|
|
* @return array 检测结果数据集
|
|
* @author 鹿文学
|
|
*/
|
|
public function checkPromoteWithdraw() {
|
|
|
|
$list = $this->field('tab_withdraw.id,tab_withdraw.settlement_number,tab_promote.account')
|
|
|
|
->join('tab_promote on (tab_withdraw.promote_id = tab_promote.id) ','left')
|
|
|
|
->where(array('tab_withdraw.status'=>0,'tab_withdraw.promote_id'=>array('gt',0)))->select();
|
|
$type=201;
|
|
if ($list[0]) {
|
|
|
|
$list = D('check')->dealWithCheckList($type,$list);
|
|
|
|
if (empty($list[0])) {return '';}
|
|
|
|
foreach ($list as $k => $v) {
|
|
$data[$k]['info'] = '推广员:'.$v['account'].'申请提现,提现状态:未审核';
|
|
$data[$k]['type'] = $type;
|
|
$data[$k]['url'] = U('Query/withdraw',array('settlement_number'=>$v['settlement_number']));
|
|
$data[$k]['create_time'] = time();
|
|
$data[$k]['status']=0;
|
|
$data[$k]['position'] = $v['id'];
|
|
}
|
|
return $data;
|
|
}else {
|
|
D('check')->dealWithCheckListOnNull($type);
|
|
return '';
|
|
}
|
|
|
|
}
|
|
|
|
//生成提现单号
|
|
public function produceWithdrawNumber()
|
|
{
|
|
$prefix = 'WD_';
|
|
$number = '';
|
|
while (true) {
|
|
$randomNum = rand(10, 99);
|
|
$number = $prefix . time() . $randomNum;
|
|
$map['widthdraw_number'] = $number;
|
|
$res = $this->where($map)->getField('id');
|
|
if (!$res) {
|
|
break;
|
|
}
|
|
}
|
|
return $number;
|
|
}
|
|
}
|