// +---------------------------------------------------------------------- namespace App\Services; use App\Models\MemberModel; use App\Models\RechargeModel; use App\Models\WithdrawModel; /** * 提现记录管理-服务类 * @author wesmiler * @since 2020/11/11 * Class WithdrawService * @package App\Services */ class WithdrawService extends BaseService { /** * 构造函数 * @author wesmiler * @since 2020/11/11 * WithdrawService constructor. */ public function __construct() { $this->model = new WithdrawModel(); } /** * 获取列表 * @return array * @since 2020/11/11 * @author wesmiler */ public function getList() { $params = request()->all(); $page = isset($params['pageSize']) ? intval($params['pageSize']) : PAGE; $pageSize = isset($params['pageSize']) ? intval($params['pageSize']) : PERPAGE; $dataList = $this->model::from('withdraw_logs as a') ->leftJoin('member as m', 'm.id', '=', 'a.user_id') ->where(function ($query) use ($params) { $query->where('a.mark', 1); $payType = isset($params['pay_type']) ? $params['pay_type'] : 0; if ($payType > 0) { $query->where('a.pay_type', $payType); } $userId = isset($params['user_id']) ? $params['user_id'] : 0; if ($userId > 0) { $query->where('a.user_id', $userId); } $datetime = isset($params['datetime'])? $params['datetime'] : []; $dateStart = $datetime && isset($datetime[0])? $datetime[0] : ''; $dateEnd = isset($datetime[1])? $datetime[1] : ''; if($dateStart && $dateEnd && $dateEnd> $dateStart){ $query->where('a.create_time', '>', strtotime($dateStart))->where('a.create_time','<=', strtotime($dateEnd)+86399); }else if($dateStart && $dateStart == $dateEnd){ $query->where('a.create_time', '>=', strtotime($dateStart))->where('a.create_time','<=', strtotime($dateStart)+86399); }else if ($dateStart){ $query->where('a.create_time', '<=', strtotime($dateStart)+86399); } $status = isset($params['status']) ? $params['status'] : 0; if ($status > 0) { $query->where('a.status', $status); } else { $query->whereIn('a.status', [1, 2]); } }) ->where(function ($query) use ($params) { $keyword = isset($params['keyword']) ? trim($params['keyword']) : ''; if (!empty($keyword)) { $query->where('m.nickname','like',"%{$keyword}%") ->orWhere('a.order_sn','like',"%{$keyword}%"); } }) ->select(['a.id', 'a.user_id','a.order_sn','a.trade_no','a.pay_at', 'm.nickname','a.realname','a.account','a.qrcode','a.pay_type','a.money', 'a.balance','a.reason', 'a.status', 'a.create_time', 'a.update_time','a.remark']) ->orderBy('a.create_time', 'desc') ->paginate($pageSize); $dataList = $dataList ? $dataList->toArray() : []; if ($dataList) { foreach ($dataList['data'] as &$item) { $item['qrcode'] = $item['qrcode']? get_image_url($item['qrcode']) : ''; $item['create_time'] = $item['create_time'] ? datetime($item['create_time'],'Y-m-d H:i:s') : ''; } unset($item); } return [ 'code' => 0, 'success'=> true, 'msg' => '操作成功', 'count' => isset($dataList['total']) ? $dataList['total'] : 0, 'data' => isset($dataList['data']) ? $dataList['data'] : 0, ]; } /** * 添加或编辑 * @return array * @since 2020/11/11 * @author wesmiler */ public function edit() { $data = request()->all(); $data['update_time'] = time(); return parent::edit($data); // TODO: Change the autogenerated stub } /** * 用户工资提现 * @param $userId * @return array */ public function withdraw($userId){ $params = request()->all(); $money = isset($params['money'])? $params['money'] : 0; if($money<=0){ return message('提现金额错误', false); } // 验证提现限制 $limitMin = ConfigService::make()->getConfigByCode('withdraw_min'); if($money < $limitMin){ return message('最低提现金额为:'.$limitMin.'元', false); } // 验证账户 $memberInfo = MemberModel::where(['id'=> $userId,'mark'=> 1,'status'=> 1]) ->select(['id','openid','nickname','salary']) ->first(); if(!$memberInfo){ return message('账户不可操作或已冻结,请联系客服', false); } if($memberInfo->salary < $money){ return message('可提现金额不足', false); } // 处理 $data = [ 'order_sn'=> get_order_num('T'), 'user_id'=> $userId, 'pay_type'=> isset($params['pay_type'])? $params['pay_type'] : 1, 'money'=> $money, 'balance'=> $memberInfo->salary, 'realname'=> isset($params['realname'])? $params['realname'] : '', 'account'=> isset($params['account'])? $params['account'] : '', 'qrcode'=> isset($params['qrcode'])? $params['qrcode'] : '', 'remark'=> isset($params['remark'])? $params['remark'] : '', 'status'=> 2, ]; \DB::beginTransaction(); if(!MemberModel::where(['id'=> $userId,'mark'=> 1])->decrement('salary', $money)){ \DB::rollBack(); return message('更新账户失败,请刷新后重试',false); } if(!$this->model::insertGetId($data)){ \DB::rollBack(); return message('提现处理失败,请刷新后重试',false); } \DB::commit(); return message('提现申请成功,请耐心等候审核打款',true); } }