AutoDecGoodsTraffic.php 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. <?php
  2. namespace App\Console\Commands;
  3. use App\Components\Helpers;
  4. use Illuminate\Console\Command;
  5. use App\Http\Models\Order;
  6. use App\Http\Models\User;
  7. use App\Http\Models\UserLabel;
  8. use App\Http\Models\GoodsLabel;
  9. use Log;
  10. use DB;
  11. class AutoDecGoodsTraffic extends Command
  12. {
  13. protected $signature = 'autoDecGoodsTraffic';
  14. protected $description = '自动扣减用户到期商品的流量';
  15. protected static $systemConfig;
  16. public function __construct()
  17. {
  18. parent::__construct();
  19. self::$systemConfig = Helpers::systemConfig();
  20. }
  21. public function handle()
  22. {
  23. $jobStartTime = microtime(true);
  24. // 扣减用户到期商品的流量
  25. $this->decGoodsTraffic();
  26. $jobEndTime = microtime(true);
  27. $jobUsedTime = round(($jobEndTime - $jobStartTime), 4);
  28. Log::info('执行定时任务【' . $this->description . '】,耗时' . $jobUsedTime . '秒');
  29. }
  30. // 扣减用户到期商品的流量
  31. private function decGoodsTraffic()
  32. {
  33. $orderList = Order::query()->with(['user', 'goods'])->where('status', 2)->where('is_expire', 0)->where('expire_at', '<', date('Y-m-d H:i:s'))->get();
  34. if (!$orderList->isEmpty()) {
  35. // 用户默认标签
  36. $defaultLabels = [];
  37. if (self::$systemConfig['initial_labels_for_user']) {
  38. $defaultLabels = explode(',', self::$systemConfig['initial_labels_for_user']);
  39. }
  40. DB::beginTransaction();
  41. try {
  42. foreach ($orderList as $order) {
  43. Order::query()->where('oid', $order->oid)->update(['is_expire' => 1]);
  44. if (empty($order->user) || empty($order->goods)) {
  45. continue;
  46. }
  47. if ($order->user->transfer_enable - $order->goods->traffic * 1048576 <= 0) {
  48. // 写入用户流量变动记录
  49. Helpers::addUserTrafficModifyLog($order->user_id, $order->oid, $order->user->transfer_enable, 0, '[定时任务]用户所购商品到期,扣减商品对应的流量(扣完并重置)');
  50. User::query()->where('id', $order->user_id)->update(['u' => 0, 'd' => 0, 'transfer_enable' => 0]);
  51. } else {
  52. // 写入用户流量变动记录
  53. Helpers::addUserTrafficModifyLog($order->user_id, $order->oid, $order->user->transfer_enable, ($order->goods->traffic * 1048576), '[定时任务]用户所购商品到期,扣减商品对应的流量(没扣完)');
  54. User::query()->where('id', $order->user_id)->decrement('transfer_enable', $order->goods->traffic * 1048576);
  55. // 处理已用流量
  56. if ($order->user->u + $order->user->d - $order->goods->traffic * 1048576 <= 0) {
  57. User::query()->where('id', $order->user_id)->update(['u' => 0, 'd' => 0]);
  58. } else {
  59. // 一般来说d的值远远大于u
  60. if ($order->user->d - $order->goods->traffic * 1048576 >= 0) {
  61. User::query()->where('id', $order->user_id)->decrement('d', $order->goods->traffic * 1048576);
  62. } else { // 如果d不够减,则减u,然后d置0
  63. User::query()->where('id', $order->user_id)->decrement('u', $order->goods->traffic * 1048576 - $order->user->d);
  64. User::query()->where('id', $order->user_id)->update(['d' => 0]);
  65. }
  66. }
  67. }
  68. // 删除该商品对应用户的所有标签
  69. UserLabel::query()->where('user_id', $order->user->id)->delete();
  70. // 取出用户的其他商品带有的标签
  71. $goodsIds = Order::query()->where('user_id', $order->user->id)->where('oid', '<>', $order->oid)->where('status', 2)->where('is_expire', 0)->groupBy('goods_id')->pluck('goods_id')->toArray();
  72. $goodsLabels = GoodsLabel::query()->whereIn('goods_id', $goodsIds)->groupBy('label_id')->pluck('label_id')->toArray();
  73. // 生成标签
  74. $labels = array_values(array_unique(array_merge($goodsLabels, $defaultLabels))); // 标签去重
  75. foreach ($labels as $vo) {
  76. $userLabel = new UserLabel();
  77. $userLabel->user_id = $order->user->id;
  78. $userLabel->label_id = $vo;
  79. $userLabel->save();
  80. }
  81. }
  82. DB::commit();
  83. } catch (\Exception $e) {
  84. \Log::error($this->description . ':' . $e);
  85. DB::rollBack();
  86. }
  87. }
  88. }
  89. }