| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208 |
- <?php
- // +----------------------------------------------------------------------
- // | Laravel框架 [ Laravel ]
- // +----------------------------------------------------------------------
- // | 版权所有 2017~2021 Laravel研发中心
- // +----------------------------------------------------------------------
- // | 官方网站: http://www.laravel.cn
- // +----------------------------------------------------------------------
- // | Author: wesmiler <12345678@qq.com>
- // +----------------------------------------------------------------------
- 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-读卡
- 'data'=> $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);
- }
- // 明细
- $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);
- }
- }
|