CRMEB/application/ebapi/model/user/UserExtract.php
2019-08-23 14:08:40 +08:00

163 lines
6.3 KiB
PHP

<?php
/**
*
* @author: xaboy<365615158@qq.com>
* @day: 2018/3/3
*/
namespace app\ebapi\model\user;
use app\core\model\user\UserBill;
use basic\ModelBasic;
use app\core\util\SystemConfigService;
use app\core\util\Template;
use traits\ModelTrait;
/** 用户提现
* Class UserExtract
* @package app\ebapi\model\user
*/
class UserExtract extends ModelBasic
{
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']);
$brokerage = UserBill::getBrokerage($userInfo['uid']);//获取总佣金
$recharge = UserBill::getRecharge($userInfo['uid']);//累计充值
$extractTotalPrice = UserExtract::userExtractTotalPrice($userInfo['uid']);//累计提现
if($brokerage > $extractTotalPrice) {
$orderYuePrice = StoreOrder::getOrderStatusYueSum($userInfo['uid']);//余额累计消费
$systemAdd = UserBill::getSystemAdd($userInfo['uid']);//后台添加余额
$yueCount = bcadd($recharge,$systemAdd,2);// 后台添加余额 + 累计充值 = 非佣金的总金额
$orderYuePrice = $yueCount > $orderYuePrice ? 0 : bcsub($orderYuePrice,$yueCount,2);// 余额累计消费(使用佣金消费的金额)
$brokerage = bcsub($brokerage,$extractTotalPrice,2);//减去已提现金额
$extract_price = self::userExtractTotalPrice($userInfo['uid'],0);
$brokerage = $extract_price < $brokerage ? bcsub($brokerage,$extract_price,2) : 0;//减去审核中的提现金额
$brokerage = $brokerage > $orderYuePrice ? bcsub($brokerage,$orderYuePrice,2) : 0;//减掉余额支付
}else{
$brokerage=0;
}
$extractPrice = (float)bcsub($brokerage,$extractTotalPrice,2) > 0 ?
bcsub($brokerage,$extractTotalPrice,2) : 0;//可提现
if($extractPrice < 0) return self::setErrorInfo('提现佣金不足'.$data['money']);
if($data['money'] > $extractPrice) return self::setErrorInfo('提现佣金不足'.$data['money']);
$balance = bcsub($userInfo['now_money'],$data['money'],2);
if($balance < 0) $balance=0;
$insertData = [
'uid'=>$userInfo['uid'],
'extract_type'=>$data['extract_type'],
'extract_price'=>(int)$data['money'],
'add_time'=>time(),
'balance'=>$balance,
'status'=>self::AUDIT_STATUS
];
if(isset($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'].'元';
}elseif($data['extract_type'] == 'bank'){
if(!$data['cardnum']) return self::setErrorInfo('请输入银行卡账号');
if(!$data['bankname']) return self::setErrorInfo('请输入开户行信息');
$mark = '使用银联卡'.$insertData['bank_code'].'提现'.$insertData['extract_price'].'元';
}elseif($data['extract_type'] == 'weixin') $mark = '使用微信提现'.$insertData['extract_price'].'元';
self::beginTrans();
try{
$res1 = self::set($insertData);
if(!$res1) return self::setErrorInfo('提现失败');
$res2 = User::edit(['now_money'=>$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();
//发送模板消息
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');
}
}