quanwei
2025-12-10 898043fc97d2ab8b793fd317a049b874ed207c6d
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
<?php
 
namespace app\api\model\plus\bonus;
 
use app\common\exception\BaseException;
use app\common\model\plus\bonus\Cash as CashModel;
use app\common\model\user\User as UserModel;
use app\common\model\plus\yms\Setting as YmsSettingModel;
use app\common\model\plus\yms\User as YmsUserModel;
 
/**
 * 分销商提现明细模型
 */
class Cash extends CashModel
{
    /**
     * 隐藏字段
     */
    protected $hidden = [
        'update_time',
    ];
 
    /**
     * 完税待完成提现申请详情
     */
    public static function getPayDetail($cashNo, $apply_status)
    {
        $model = new static();
        $model = $model->where('cash_no', '=', $cashNo);
        if($apply_status > 0){
            $model = $model->where('apply_status', '=', 50);
        }
        return $model->find();
    }
 
    /**
     * 获取分销商提现明细
     */
    public function getList($user_id, $apply_status = -1,$limit=15)
    {
        $model = $this;
        $apply_status > -1 && $model = $model->where('apply_status', '=', $apply_status);
        return $model->where('user_id', '=', $user_id)->order(['create_time' => 'desc'])
            ->paginate($limit);
    }
 
    /**
     * 提交申请
     */
    public function submit($user, $data)
    {
        $this->startTrans();
        try {
            // 数据验证
            $this->validation($user, $data,['is_open'=>0]);
            // 新增申请记录
            $this->save(array_merge($data, [
                'user_id' => $user['user_id'],
                'apply_status' => 10,
                'app_id' => self::$app_id,
                'cash_no' => $this->createCashNo(),
                'is_yms' =>  0, // 是否使用完税系统打款 by lyzflash
            ]));
            // 将支付宝或银行卡信息保存到用户表 by lyzflash
            $this->saveAccount($user['user_id'], $data, ['is_open'=>0]);
            // 冻结用户资金
            $user->freezeMoney($data['money']);
            $this->commit();
            return true;
        } catch (\Exception $e) {
            $this->error = $e->getMessage();
            $this->rollback();
            return false;
        }
    }
 
    /**
     * 数据验证
     */
    private function validation($user, $data, $ymsSetting)
    {
        // 结算设置
        $settlement = Setting::getItem('settlement');
        // 最低提现分红
        if ($data['money'] <= 0) {
            throw new BaseException(['msg' => '提现金额不正确']);
        }
        if ($user['money'] <= 0) {
            throw new BaseException(['msg' => '当前用户没有可提现分红']);
        }
        if ($data['money'] > $user['money']) {
            throw new BaseException(['msg' => '提现金额不能大于可提现分红']);
        }
        if ($data['money'] < $settlement['min_money']) {
            throw new BaseException(['msg' => '最低提现金额为' . $settlement['min_money']]);
        }
        if (!in_array($data['pay_type'], $settlement['pay_type'])) {
            throw new BaseException(['msg' => '提现方式不正确']);
        }
        if ($data['pay_type'] == '20') {
            if (empty($data['alipay_name']) || empty($data['alipay_account'])) {
                throw new BaseException(['msg' => '请补全提现信息']);
            }
        } elseif ($data['pay_type'] == '30' && $ymsSetting['is_open'] == '0') {
            if (empty($data['bank_name']) || empty($data['bank_account']) || empty($data['bank_card'])) {
                throw new BaseException(['msg' => '请补全提现信息']);
            }
        }
    }
 
    /**
     * 数据验证
     */
    private function saveAccount($user_id, $formData, $ymsSetting)
    {
        if ($formData['pay_type'] == 20) {
            $data = [
                'alipay_name' => $formData['alipay_name'],
                'alipay_account' => $formData['alipay_account'],
            ];
        } elseif ($formData['pay_type'] == 30 && $ymsSetting['is_open'] == '0') {
            $data = [
                'bank_name' => $formData['bank_name'],
                'bank_account' => $formData['bank_account'],
                'bank_card' => $formData['bank_card'],
            ];
        } else {
            return false;
        }
        $user = UserModel::detail($user_id);
        $user->save($data);
    }
 
    private function createCashNo()
    {
        return date('Ymd') . substr(implode(NULL, array_map('ord', str_split(substr(uniqid(), 7, 13), 1))), 0, 8);
    }
 
}