Callback.php 8.7 KB

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