mirror of
https://github.com/crmeb/CRMEB.git
synced 2025-12-15 13:22:51 +00:00
164 lines
5.5 KiB
PHP
164 lines
5.5 KiB
PHP
<?php
|
|
/**
|
|
*
|
|
* @author: xaboy<365615158@qq.com>
|
|
* @day: 2018/3/3
|
|
*/
|
|
|
|
namespace app\models\user;
|
|
|
|
use crmeb\basic\BaseModel;
|
|
use crmeb\services\workerman\ChannelService;
|
|
use crmeb\traits\ModelTrait;
|
|
|
|
|
|
/**
|
|
* TODO 用户提现
|
|
* Class UserExtract
|
|
* @package app\models\user
|
|
*/
|
|
class UserExtract extends BaseModel
|
|
{
|
|
/**
|
|
* 数据表主键
|
|
* @var string
|
|
*/
|
|
protected $pk = 'id';
|
|
|
|
/**
|
|
* 模型名称
|
|
* @var string
|
|
*/
|
|
protected $name = 'user_extract';
|
|
|
|
use ModelTrait;
|
|
|
|
//审核中
|
|
const AUDIT_STATUS = 0;
|
|
//未通过
|
|
const FAIL_STATUS = -1;
|
|
//已提现
|
|
const SUCCESS_STATUS = 1;
|
|
|
|
protected static $extractType = ['alipay','bank','weixin'];
|
|
|
|
protected static $extractTypeMsg = ['alipay'=>'支付宝','bank'=>'银行卡','weixin'=>'微信'];
|
|
|
|
protected static $status = array(
|
|
-1=>'未通过',
|
|
0 =>'审核中',
|
|
1 =>'已提现'
|
|
);
|
|
|
|
/*
|
|
* 用户自主提现记录提现记录,后台执行审核
|
|
* @param array $userInfo 用户个人信息
|
|
* @param array $data 提现详细信息
|
|
* @return boolean
|
|
* */
|
|
public static function userExtract($userInfo,$data){
|
|
if(!in_array($data['extract_type'],self::$extractType))
|
|
return self::setErrorInfo('提现方式不存在');
|
|
$userInfo = User::get($userInfo['uid']);
|
|
$extractPrice = $userInfo['brokerage_price'];
|
|
if($extractPrice < 0) return self::setErrorInfo('提现佣金不足'.$data['money']);
|
|
if($data['money'] > $extractPrice) return self::setErrorInfo('提现佣金不足'.$data['money']);
|
|
if($data['money'] <= 0) return self::setErrorInfo('提现佣金大于0');
|
|
$balance = bcsub($userInfo['brokerage_price'],$data['money'],2);
|
|
if($balance < 0) $balance=0;
|
|
$insertData = [
|
|
'uid' => $userInfo['uid'],
|
|
'extract_type' => $data['extract_type'],
|
|
'extract_price' => $data['money'],
|
|
'add_time' => time(),
|
|
'balance' => $balance,
|
|
'status' => self::AUDIT_STATUS
|
|
];
|
|
if(isset($data['name']) && strlen(trim($data['name']))) $insertData['real_name'] = $data['name'];
|
|
else $insertData['real_name'] = $userInfo['nickname'];
|
|
if(isset($data['cardnum'])) $insertData['bank_code'] = $data['cardnum'];
|
|
else $insertData['bank_code'] = '';
|
|
if(isset($data['bankname'])) $insertData['bank_address']=$data['bankname'];
|
|
else $insertData['bank_address']='';
|
|
if(isset($data['weixin'])) $insertData['wechat'] = $data['weixin'];
|
|
else $insertData['wechat'] = $userInfo['nickname'];
|
|
if($data['extract_type'] == 'alipay'){
|
|
if(!$data['alipay_code']) return self::setErrorInfo('请输入支付宝账号');
|
|
$insertData['alipay_code'] = $data['alipay_code'];
|
|
$mark = '使用支付宝提现'.$insertData['extract_price'].'元';
|
|
}else if($data['extract_type'] == 'bank'){
|
|
if(!$data['cardnum']) return self::setErrorInfo('请输入银行卡账号');
|
|
if(!$data['bankname']) return self::setErrorInfo('请输入开户行信息');
|
|
$mark = '使用银联卡'.$insertData['bank_code'].'提现'.$insertData['extract_price'].'元';
|
|
}else if($data['extract_type'] == 'weixin'){
|
|
if(!$data['weixin']) return self::setErrorInfo('请输入微信账号');
|
|
$mark = '使用微信提现'.$insertData['extract_price'].'元';
|
|
}
|
|
self::beginTrans();
|
|
try{
|
|
$res1 = self::create($insertData);
|
|
if(!$res1) return self::setErrorInfo('提现失败');
|
|
$res2 = User::edit(['brokerage_price'=>$balance],$userInfo['uid'],'uid');
|
|
$res3 = UserBill::expend('余额提现',$userInfo['uid'],'now_money','extract',$data['money'],$res1['id'],$balance,$mark);
|
|
$res = $res2 && $res3;
|
|
if($res){
|
|
self::commitTrans();
|
|
try{
|
|
ChannelService::instance()->send('WITHDRAW', ['id'=>$res1->id]);
|
|
}catch (\Exception $e){}
|
|
//发送模板消息
|
|
return true;
|
|
}else return self::setErrorInfo('提现失败!');
|
|
}catch (\Exception $e){
|
|
self::rollbackTrans();
|
|
return self::setErrorInfo('提现失败!');
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 获得用户最后一次提现信息
|
|
* @param $openid
|
|
* @return mixed
|
|
*/
|
|
public static function userLastInfo($uid)
|
|
{
|
|
return self::where(compact('uid'))->order('add_time DESC')->find();
|
|
}
|
|
|
|
/**
|
|
* 获得用户提现总金额
|
|
* @param $uid
|
|
* @return mixed
|
|
*/
|
|
public static function userExtractTotalPrice($uid,$status=self::SUCCESS_STATUS)
|
|
{
|
|
return self::where('uid',$uid)->where('status',$status)->value('SUM(extract_price)')?:0;
|
|
}
|
|
|
|
/*
|
|
* 用户提现记录列表
|
|
* @param int $uid 用户uid
|
|
* @param int $first 截取行数
|
|
* @param int $limit 截取数
|
|
* @return array
|
|
* */
|
|
public static function extractList($uid,$first = 0,$limit = 8)
|
|
{
|
|
$list=UserExtract::where('uid',$uid)->order('add_time desc')->limit($first,$limit)->select();
|
|
foreach($list as &$v){
|
|
$v['add_time']=date('Y/m/d',$v['add_time']);
|
|
}
|
|
return $list;
|
|
}
|
|
|
|
/*
|
|
* 获取累计已提现佣金
|
|
* @param int $uid
|
|
* @return float
|
|
* */
|
|
public static function extractSum($uid)
|
|
{
|
|
return self::where('uid',$uid)->where('status',1)->sum('extract_price');
|
|
}
|
|
|
|
} |