// +---------------------------------------------------------------------- namespace App\Services; use App\Models\ActionLogModel; use App\Models\AdModel; use App\Models\CardModel; use App\Models\MemberModel; use App\Models\TradeModel; /** * 卡管理-服务类 * @author wesmiler * @since 2020/11/11 * Class CardService * @package App\Services */ class CardService extends BaseService { /** * 构造函数 * @author wesmiler * @since 2020/11/11 * CardService constructor. */ public function __construct() { $this->model = new CardModel(); } /** * 获取列表 * @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('cards as a') ->leftJoin('member as m', 'm.id', '=', 'a.user_id') ->where(function ($query) use ($params) { $query->where('a.mark', 1); $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('a.mobile', 'like', "%{$keyword}%")->orWhere('a.realname','like',"%{$keyword}%"); } }) ->select(['a.id', 'a.user_id', 'a.code', 'm.nickname','a.quota','a.realname','a.mobile', '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['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(); $userId = isset($data['user_id'])? $data['user_id'] : 0; $id = isset($data['id'])? $data['id'] : 0; if($userId && $id<=0){ $info = $this->model::where(['user_id'=> $userId,'mark'=> 1])->first(); if($info){ return message('每个用户暂时只能创建一张卡', false); } } if($id<=0){ $data['code'] = get_card_num('IC'); $params = [ 'CommandType'=> 0, // 执行命令方式:0-写卡,1-读卡 'ICid'=> $data['code'], // 卡号 ]; $dataStr = []; foreach($params as $k => $v){ $dataStr[] = $k.'='.$v; } // 调用亮灯接口处理 $errorKey = "caches:cards:make:{$userId}"; $dataStr = implode('&', $dataStr); $headers = ["Content-Type:application/x-www-form-urlencoded; charset=UTF-8"]; $apiUrl = ConfigService::make()->getConfigByCode('gd_api_url').'/ICcontrol.ashx'; RedisService::set($errorKey.':request', ['url'=> $apiUrl,'data'=> $params], 3600); $result = httpHeaderRequest($apiUrl, $dataStr,'post',$headers,'text',3); RedisService::set($errorKey.':result', ['result'=>$result], 3600); if($result !== 0){ return message('开卡处理失败', false); } } $data['update_time'] = time(); $this->model::where(['mark'=> 2])->where('update_time','<=', time() - 60)->delete(); return parent::edit($data); // TODO: Change the autogenerated stub } /** * 账户后台调整 * @param $userId * @return array */ public function quota($adminUid){ $params = request()->all(); $num = isset($params['num'])? intval($params['num']) : 0; $id = isset($params['id'])? $params['id'] : 1; $userId = isset($params['user_id'])? $params['user_id'] : 1; $changeType = isset($params['change_type'])? $params['change_type'] : 1; if($num<=0){ return message('请填写调整卡额度', false); } if(!in_array($changeType, [1,2])){ return message('操作类型错误', false); } $memberInfo = MemberModel::where(['id'=> $userId,'mark'=> 1,'status'=> 1]) ->select(['id','openid','nickname','coupon','score','salary']) ->first(); if($userId<=0 || !$memberInfo){ return message('用户账户状态不可操作', false); } $cardInfo = $this->model::where(['user_id'=> $userId,'mark'=> 1,'status'=> 1])->first(); if(!$cardInfo){ return message('卡状态无法操作', false); } if($changeType == 2 && $cardInfo->quota < $num){ return message('当前卡额度不足', false); } \DB::beginTransaction(); if(!$this->model::where(['user_id'=> $userId,'mark'=> 1])->increment('quota', ($changeType==1? $num : -$num))){ \DB::rollBack(); return message("用户卡额度更新失败", false); } // 卡入款 $params = [ 'CommandType'=> 1, // 执行命令方式:3-充值,4-扣款 'Amount'=> $cardInfo->code.','.$num ]; $dataStr = []; foreach($params as $k => $v){ $dataStr[] = $k.'='.$v; } // 充值卡接口处理 $errorKey = "caches:cards:recharge:{$userId}"; $dataStr = implode('&', $dataStr); // $headers = ["Content-Type:application/x-www-form-urlencoded; charset=UTF-8"]; $apiUrl = ConfigService::make()->getConfigByCode('gd_api_url').'/ICcontrol.ashx'; RedisService::set($errorKey.':request', ['url'=> $apiUrl,'data'=> $params], 3600); $result = httpHeaderRequest($apiUrl, $dataStr,'post',[],'text',3); RedisService::set($errorKey.':result', ['result'=>$result], 3600); if($result !== 0){ \DB::rollBack(); return message('充值入卡失败', false); } // 明细 $remark = isset($params['remark'])? $params['remark'] : ''; $data = [ 'user_id'=> $userId, 'source_uid'=> $adminUid, 'type'=> 5, 'coin_type'=> 5, 'pay_type'=> 4, 'money'=> $num, 'change_type'=> $changeType, 'balance'=> $cardInfo->quota, 'create_time'=> time(), 'remark'=> $remark? $remark : "平台调整卡账户额度,".($changeType==1?'增加':'减少')."{$num}", 'status'=> 1, ]; if(!TradeModel::insertGetId($data)){ \DB::rollBack(); return message("用户卡账户明细处理失败", false); } \DB::commit(); // 设置日志标题 ActionLogModel::setTitle("用户卡账户调整,".($changeType==1?'增加':'减少')."{$num}"); ActionLogModel::record(); return message(($changeType==1?'增加':'减少')."{$num}卡额度成功", true); } }