Callback.php 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228
  1. <?php
  2. namespace App\Components;
  3. use App\Http\Models\Goods;
  4. use App\Http\Models\GoodsLabel;
  5. use App\Http\Models\Order;
  6. use App\Http\Models\Payment;
  7. use App\Http\Models\User;
  8. use App\Http\Models\UserLabel;
  9. use DB;
  10. use Exception;
  11. use Hash;
  12. use Log;
  13. trait Callback
  14. {
  15. protected static $systemConfig;
  16. function __construct()
  17. {
  18. self::$systemConfig = Helpers::systemConfig();
  19. }
  20. public function show()
  21. {
  22. exit('show');
  23. }
  24. // 交易支付
  25. private function tradePaid($msg, $pay_type)
  26. {
  27. $pay_type_name = $pay_type == 1? '余额支付' : ($pay_type == 4? '支付宝国际' : ($pay_type == 5? '支付宝当面付' : ''));
  28. $payment = Payment::query()->with(['order', 'order.goods'])->where('status', 0)->where('order_sn', $msg['out_trade_no'])->first();
  29. if(!$payment){
  30. Log::info('【'.$pay_type_name.'】回调订单【'.$msg['out_trade_no'].'】不存在');
  31. return FALSE;
  32. }
  33. if($pay_type != 1){
  34. Log::info('【'.$pay_type_name.'】支付成功,开始处理回调订单');
  35. // 获取未完成状态的订单防止重复增加时间
  36. }else{
  37. Log::info('【'.$pay_type_name.'】订单处理');
  38. }
  39. // 处理订单
  40. try{
  41. DB::beginTransaction();
  42. if($pay_type != 1){
  43. // 如果支付单中没有用户信息则创建一个用户
  44. if(!$payment->user_id){
  45. $uid = Helpers::addUser('自动生成-'.$payment->order->email, Hash::make(makeRandStr()), 1, $payment->order->goods->days);
  46. if($uid){
  47. Order::query()->where('oid', $payment->oid)->update(['user_id' => $uid]);
  48. }
  49. }
  50. // 更新支付单
  51. $payment->pay_way = $pay_type == 4 || $pay_type == 5? 2 : 1; // 1-微信、2-支付宝
  52. $payment->status = 1;
  53. $payment->save();
  54. }
  55. // 更新订单
  56. $order = Order::query()->where('order_sn', $msg['out_trade_no'])->first();
  57. if($order->goods_id == -1){
  58. $order->status = 2;
  59. $order->save();
  60. User::query()->where('id', $order->user_id)->increment('balance', $order->amount*100);
  61. // 余额变动记录日志
  62. $this->addUserBalanceLog($order->user_id, $order->oid, $order->user->balance, $order->user->balance+$order->amount, $order->amount, '用户在线充值');
  63. }else{
  64. // 提取商品信息
  65. $goods = Goods::query()->where('id', $order->goods_id)->first();
  66. // 取出用户信息
  67. $user = User::query()->where('id', $order->user_id)->first();
  68. // 商品为流量或者套餐
  69. switch($goods->type){
  70. case 1:
  71. $order->status = 2;
  72. $order->save();
  73. Helpers::addUserTrafficModifyLog($order->user_id, $order->oid, $user->transfer_enable, $user->transfer_enable+$goods->traffic*1048576, '[在线支付]加上用户购买的套餐流量');
  74. User::query()->where('id', $order->user_id)->increment('transfer_enable', $goods->traffic*1048576);
  75. break;
  76. case 2:
  77. $activePlan = Order::query()
  78. ->where('user_id', $order->user_id)
  79. ->with(['goods'])
  80. ->whereHas('goods', function($q){
  81. $q->where('type', 2);
  82. })
  83. ->where('is_expire', 0)
  84. ->where('status', 2)
  85. ->exists();
  86. // 2为开始生效,3为预支付
  87. $order->status = $activePlan? 3 : 2;
  88. $order->save();
  89. // 预支付不执行
  90. if(!$activePlan){
  91. // 如果买的是套餐,则先将之前购买的套餐都无效化,重置用户已用、可用流量为0
  92. Order::query()
  93. ->where('user_id', $order->user_id)
  94. ->with(['goods'])
  95. ->whereHas('goods', function($q){
  96. $q->where('type', '<=', 2);
  97. })
  98. ->where('is_expire', 0)
  99. ->where('status', 2)
  100. ->where('oid', '<>', $order->oid)
  101. ->update(['expire_at' => date('Y-m-d H:i:s'), 'is_expire' => 1]);
  102. Helpers::addUserTrafficModifyLog($order->user_id, $order->oid, $user->transfer_enable, 0, '[在线支付]用户购买新套餐,先清空流量');
  103. User::query()->where('id', $order->user_id)->update(['u' => 0, 'd' => 0, 'transfer_enable' => 0]);
  104. $userTraffic = $goods->traffic*1048576;
  105. // 添加账号有效期
  106. $expireTime = date('Y-m-d', strtotime("+".$goods->days." days"));
  107. //账号下一个重置时间
  108. $nextResetTime = date('Y-m-d', strtotime("+".$goods->period." days"));
  109. if($nextResetTime >= $expireTime){
  110. $nextResetTime = NULL;
  111. }
  112. // 写入用户标签
  113. if($goods->label){
  114. // 删除用户所有标签
  115. UserLabel::query()->where('user_id', $order->user_id)->delete();
  116. //取出 商品默认标签 & 系统默认标签 去重
  117. $newUserLabels = array_values(array_unique(array_merge(GoodsLabel::query()->where('goods_id', $order->goods_id)->pluck('label_id')->toArray(), self::$systemConfig['initial_labels_for_user']? explode(',', self::$systemConfig['initial_labels_for_user']) : [])));
  118. // 生成标签
  119. foreach($newUserLabels as $vo){
  120. $obj = new UserLabel();
  121. $obj->user_id = $order->user_id;
  122. $obj->label_id = $vo;
  123. $obj->save();
  124. }
  125. }
  126. // 写入返利日志
  127. if($order->user->referral_uid){
  128. $this->addReferralLog($order->user_id, $order->user->referral_uid, $order->oid, $order->amount, $order->amount*self::$systemConfig['referral_percent']);
  129. // 邀请注册功能开启时,每成功邀请一名付费用户,返还邀请者邀请名额
  130. if(self::$systemConfig['is_invite_register']){
  131. User::query()->where('id', $order->user->referral_uid)->increment('invite_num', 1);
  132. }
  133. }
  134. Helpers::addUserTrafficModifyLog($order->user_id, $order->oid, $user->transfer_enable, $userTraffic, '[在线支付]加上用户购买的套餐流量');
  135. User::query()->where('id', $order->user_id)->increment('invite_num', $goods->invite_num? : 0, ['transfer_enable' => $userTraffic, 'reset_time' => $nextResetTime, 'expire_time' => $expireTime, 'enable' => 1]);
  136. }else{
  137. //预支付订单先给上账号时间用于流量重置判断
  138. User::query()->where('id', $order->user_id)->update(['expire_time' => date('Y-m-d', strtotime("+".$goods->days." days", strtotime($user->expire_time)))]);
  139. }
  140. break;
  141. case 3:
  142. $order->status = 2;
  143. $order->save();
  144. User::query()->where('id', $order->user_id)->increment('balance', $goods->price*100);
  145. // 余额变动记录日志
  146. $this->addUserBalanceLog($order->user_id, $order->oid, $order->user->balance, $order->user->balance+$goods->price, $goods->price, '用户在线充值');
  147. break;
  148. default:
  149. Log::info('【处理订单】出现错误-未知套餐类型');
  150. }
  151. }
  152. DB::commit();
  153. Log::info('【'.$pay_type_name.'】处理成功');
  154. } catch(Exception $e){
  155. DB::rollBack();
  156. Log::info('【'.$pay_type_name.'】回调更新支付单和订单异常:'.$e->getMessage());
  157. }
  158. return FALSE;
  159. }
  160. private function activePrepaidOrder($oid)
  161. {
  162. // 取出预支付订单
  163. $prepaidOrder = Order::query()->where('oid', $oid)->first();
  164. //去除使用中的套餐和 流量包
  165. Order::query()->where('user_id', $prepaidOrder->user_id)->where('status', 2)->where('is_expire', 0)->update(['expire_at' => date('Y-m-d H:i:s'), 'is_expire' => 1]);
  166. //取出对应套餐信息
  167. $prepaidGood = Goods::query()->where('id', $prepaidOrder->goods_id)->first();
  168. //激活预支付套餐
  169. Order::query()->where('oid', $prepaidOrder->oid)->update(['expire_at' => date("Y-m-d H:i:s", strtotime("+".$prepaidGood->days." days")), 'status' => 2]);
  170. //取出用户信息
  171. $user = User::query()->where('id', $prepaidOrder->user_id)->first();
  172. $userTraffic = $prepaidGood->traffic*1048576;
  173. //拿出可能存在的其余套餐, 推算 最新的到期时间
  174. $expire_time = date('Y-m-d', strtotime("+".$prepaidGood->days." days"));
  175. $prepaidOrders = Order::query()->where('user_id', $prepaidOrder->user_id)->where('status', 3)->get();
  176. foreach($prepaidOrders as $paidOrder){
  177. //取出对应套餐信息
  178. $goods = Goods::query()->where('id', $paidOrder->goods_id)->first();
  179. $expire_time = date('Y-m-d', strtotime("+".$goods->days." days", strtotime($expire_time)));
  180. }
  181. //计算账号下一个重置时间
  182. $nextResetTime = date('Y-m-d', strtotime("+".$prepaidGood->period." days"));
  183. if($nextResetTime >= $expire_time){
  184. $nextResetTime = NULL;
  185. }
  186. // 用户默认标签
  187. $defaultLabels = self::$systemConfig['initial_labels_for_user']? explode(',', self::$systemConfig['initial_labels_for_user']) : [];
  188. //取出 商品默认标签 & 系统默认标签 去重
  189. $newUserLabels = array_values(array_unique(array_merge(GoodsLabel::query()->where('goods_id', $prepaidOrder->goods_id)->pluck('label_id')->toArray(), $defaultLabels)));
  190. // 生成标签
  191. foreach($newUserLabels as $vo){
  192. $obj = new UserLabel();
  193. $obj->user_id = $prepaidOrder->user_id;
  194. $obj->label_id = $vo;
  195. $obj->save();
  196. }
  197. Helpers::addUserTrafficModifyLog($prepaidOrder->user_id, $prepaidOrder->oid, $user->transfer_enable, $userTraffic, '[预支付订单激活]加上用户购买的套餐流量');
  198. User::query()->where('id', $prepaidOrder->user_id)->increment('invite_num', $prepaidOrder->invite_num? : 0, ['u' => 0, 'd' => 0, 'transfer_enable' => $userTraffic, 'expire_time' => $expire_time, 'reset_time' => $nextResetTime]);
  199. }
  200. }