CardService.php 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | Laravel框架 [ Laravel ]
  4. // +----------------------------------------------------------------------
  5. // | 版权所有 2017~2021 Laravel研发中心
  6. // +----------------------------------------------------------------------
  7. // | 官方网站: http://www.laravel.cn
  8. // +----------------------------------------------------------------------
  9. // | Author: wesmiler <12345678@qq.com>
  10. // +----------------------------------------------------------------------
  11. namespace App\Services;
  12. use App\Models\ActionLogModel;
  13. use App\Models\AdModel;
  14. use App\Models\CardModel;
  15. use App\Models\MemberModel;
  16. use App\Models\TradeModel;
  17. /**
  18. * 卡管理-服务类
  19. * @author wesmiler
  20. * @since 2020/11/11
  21. * Class CardService
  22. * @package App\Services
  23. */
  24. class CardService extends BaseService
  25. {
  26. /**
  27. * 构造函数
  28. * @author wesmiler
  29. * @since 2020/11/11
  30. * CardService constructor.
  31. */
  32. public function __construct()
  33. {
  34. $this->model = new CardModel();
  35. }
  36. /**
  37. * 获取列表
  38. * @return array
  39. * @since 2020/11/11
  40. * @author wesmiler
  41. */
  42. public function getList()
  43. {
  44. $params = request()->all();
  45. $page = isset($params['pageSize']) ? intval($params['pageSize']) : PAGE;
  46. $pageSize = isset($params['pageSize']) ? intval($params['pageSize']) : PERPAGE;
  47. $dataList = $this->model::from('cards as a')
  48. ->leftJoin('member as m', 'm.id', '=', 'a.user_id')
  49. ->where(function ($query) use ($params) {
  50. $query->where('a.mark', 1);
  51. $status = isset($params['status']) ? $params['status'] : 0;
  52. if ($status > 0) {
  53. $query->where('a.status', $status);
  54. } else {
  55. $query->whereIn('a.status', [1, 2]);
  56. }
  57. })
  58. ->where(function ($query) use ($params) {
  59. $keyword = isset($params['keyword']) ? trim($params['keyword']) : '';
  60. if (!empty($keyword)) {
  61. $query->where('a.mobile', 'like', "%{$keyword}%")->orWhere('a.realname','like',"%{$keyword}%");
  62. }
  63. })
  64. ->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'])
  65. ->orderBy('a.create_time', 'desc')
  66. ->paginate($pageSize);
  67. $dataList = $dataList ? $dataList->toArray() : [];
  68. if ($dataList) {
  69. foreach ($dataList['data'] as &$item) {
  70. $item['create_time'] = $item['create_time'] ? datetime($item['create_time'],'Y-m-d H:i:s') : '';
  71. }
  72. unset($item);
  73. }
  74. return [
  75. 'code' => 0,
  76. 'success'=> true,
  77. 'msg' => '操作成功',
  78. 'count' => isset($dataList['total']) ? $dataList['total'] : 0,
  79. 'data' => isset($dataList['data']) ? $dataList['data'] : 0,
  80. ];
  81. }
  82. /**
  83. * 添加或编辑
  84. * @return array
  85. * @since 2020/11/11
  86. * @author wesmiler
  87. */
  88. public function edit()
  89. {
  90. $data = request()->all();
  91. $userId = isset($data['user_id'])? $data['user_id'] : 0;
  92. $id = isset($data['id'])? $data['id'] : 0;
  93. if($userId && $id<=0){
  94. $info = $this->model::where(['user_id'=> $userId,'mark'=> 1])->first();
  95. if($info){
  96. return message('每个用户暂时只能创建一张卡', false);
  97. }
  98. }
  99. if($id<=0){
  100. $data['code'] = get_card_num('IC');
  101. $params = [
  102. 'CommandType'=> 0, // 执行命令方式:0-写卡,1-读卡
  103. 'ICid'=> $data['code'], // 卡号
  104. ];
  105. $dataStr = [];
  106. foreach($params as $k => $v){
  107. $dataStr[] = $k.'='.$v;
  108. }
  109. // 调用亮灯接口处理
  110. $errorKey = "caches:cards:make:{$userId}";
  111. $dataStr = implode('&', $dataStr);
  112. $headers = ["Content-Type:application/x-www-form-urlencoded; charset=UTF-8"];
  113. $apiUrl = ConfigService::make()->getConfigByCode('gd_api_url').'/ICcontrol.ashx';
  114. RedisService::set($errorKey.':request', ['url'=> $apiUrl,'data'=> $params], 3600);
  115. $result = httpHeaderRequest($apiUrl, $dataStr,'post',$headers,'text',3);
  116. RedisService::set($errorKey.':result', ['result'=>$result], 3600);
  117. if($result !== 0){
  118. return message('开卡处理失败', false);
  119. }
  120. }
  121. $data['update_time'] = time();
  122. $this->model::where(['mark'=> 2])->where('update_time','<=', time() - 60)->delete();
  123. return parent::edit($data); // TODO: Change the autogenerated stub
  124. }
  125. /**
  126. * 账户后台调整
  127. * @param $userId
  128. * @return array
  129. */
  130. public function quota($adminUid){
  131. $params = request()->all();
  132. $num = isset($params['num'])? intval($params['num']) : 0;
  133. $id = isset($params['id'])? $params['id'] : 1;
  134. $userId = isset($params['user_id'])? $params['user_id'] : 1;
  135. $changeType = isset($params['change_type'])? $params['change_type'] : 1;
  136. if($num<=0){
  137. return message('请填写调整卡额度', false);
  138. }
  139. if(!in_array($changeType, [1,2])){
  140. return message('操作类型错误', false);
  141. }
  142. $memberInfo = MemberModel::where(['id'=> $userId,'mark'=> 1,'status'=> 1])
  143. ->select(['id','openid','nickname','coupon','score','salary'])
  144. ->first();
  145. if($userId<=0 || !$memberInfo){
  146. return message('用户账户状态不可操作', false);
  147. }
  148. $cardInfo = $this->model::where(['user_id'=> $userId,'mark'=> 1,'status'=> 1])->first();
  149. if(!$cardInfo){
  150. return message('卡状态无法操作', false);
  151. }
  152. if($changeType == 2 && $cardInfo->quota < $num){
  153. return message('当前卡额度不足', false);
  154. }
  155. \DB::beginTransaction();
  156. if(!$this->model::where(['user_id'=> $userId,'mark'=> 1])->increment('quota', ($changeType==1? $num : -$num))){
  157. \DB::rollBack();
  158. return message("用户卡额度更新失败", false);
  159. }
  160. // 卡入款
  161. $params = [
  162. 'CommandType'=> 1, // 执行命令方式:3-充值,4-扣款
  163. 'Amount'=> $cardInfo->code.','.$num
  164. ];
  165. $dataStr = [];
  166. foreach($params as $k => $v){
  167. $dataStr[] = $k.'='.$v;
  168. }
  169. // 充值卡接口处理
  170. $errorKey = "caches:cards:recharge:{$userId}";
  171. $dataStr = implode('&', $dataStr);
  172. // $headers = ["Content-Type:application/x-www-form-urlencoded; charset=UTF-8"];
  173. $apiUrl = ConfigService::make()->getConfigByCode('gd_api_url').'/ICcontrol.ashx';
  174. RedisService::set($errorKey.':request', ['url'=> $apiUrl,'data'=> $params], 3600);
  175. $result = httpHeaderRequest($apiUrl, $dataStr,'post',[],'text',3);
  176. RedisService::set($errorKey.':result', ['result'=>$result], 3600);
  177. if($result !== 0){
  178. \DB::rollBack();
  179. return message('充值入卡失败', false);
  180. }
  181. // 明细
  182. $remark = isset($params['remark'])? $params['remark'] : '';
  183. $data = [
  184. 'user_id'=> $userId,
  185. 'source_uid'=> $adminUid,
  186. 'type'=> 5,
  187. 'coin_type'=> 5,
  188. 'pay_type'=> 4,
  189. 'money'=> $num,
  190. 'change_type'=> $changeType,
  191. 'balance'=> $cardInfo->quota,
  192. 'create_time'=> time(),
  193. 'remark'=> $remark? $remark : "平台调整卡账户额度,".($changeType==1?'增加':'减少')."{$num}",
  194. 'status'=> 1,
  195. ];
  196. if(!TradeModel::insertGetId($data)){
  197. \DB::rollBack();
  198. return message("用户卡账户明细处理失败", false);
  199. }
  200. \DB::commit();
  201. // 设置日志标题
  202. ActionLogModel::setTitle("用户卡账户调整,".($changeType==1?'增加':'减少')."{$num}");
  203. ActionLogModel::record();
  204. return message(($changeType==1?'增加':'减少')."{$num}卡额度成功", true);
  205. }
  206. }