DailyJob.php 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. <?php
  2. namespace App\Console\Commands;
  3. use App\Components\Helpers;
  4. use App\Models\Ticket;
  5. use App\Models\User;
  6. use App\Notifications\TicketClosed;
  7. use App\Services\OrderService;
  8. use Illuminate\Console\Command;
  9. use Log;
  10. class DailyJob extends Command
  11. {
  12. protected $signature = 'dailyJob';
  13. protected $description = '每日任务';
  14. public function handle()
  15. {
  16. $jobTime = microtime(true);
  17. $this->expireUser(); // 过期用户处理
  18. $this->closeTickets(); // 关闭用户超时未处理的工单
  19. if (sysConfig('reset_traffic')) {// 重置用户流量
  20. $this->resetUserTraffic();
  21. }
  22. $jobTime = round((microtime(true) - $jobTime), 4);
  23. Log::info('---【'.$this->description.'】完成---,耗时'.$jobTime.'秒');
  24. }
  25. private function expireUser()// 过期用户处理
  26. {
  27. $isBanStatus = sysConfig('is_ban_status');
  28. User::activeUser()
  29. ->where('expired_at', '<', date('Y-m-d'))
  30. ->chunk(config('tasks.chunk'), function ($users) use ($isBanStatus) {
  31. foreach ($users as $user) {
  32. if ($isBanStatus) {
  33. $user->update([ // 停止服务 & 封禁账号
  34. 'u' => 0,
  35. 'd' => 0,
  36. 'transfer_enable' => 0,
  37. 'enable' => 0,
  38. 'level' => 0,
  39. 'reset_time' => null,
  40. 'ban_time' => null,
  41. 'status' => -1,
  42. ]);
  43. $user->banedLogs()->create(['description' => '【禁止登录,清空账户】-账号已过期']);
  44. // 废除其名下邀请码
  45. $user->invites()->whereStatus(0)->update(['status' => 2]);
  46. // 写入用户流量变动记录
  47. Helpers::addUserTrafficModifyLog($user->id, null, $user->transfer_enable, 0, '[定时任务]账号已过期(禁止登录,清空账户)');
  48. } else {
  49. $user->update([ // 停止服务
  50. 'u' => 0,
  51. 'd' => 0,
  52. 'transfer_enable' => 0,
  53. 'enable' => 0,
  54. 'level' => 0,
  55. 'reset_time' => null,
  56. 'ban_time' => null,
  57. ]);
  58. $user->banedLogs()->create(['description' => '【封禁代理,清空账户】-账号已过期']);
  59. // 写入用户流量变动记录
  60. Helpers::addUserTrafficModifyLog($user->id, null, $user->transfer_enable, 0, '[定时任务]账号已过期(封禁代理,清空账户)');
  61. }
  62. }
  63. });
  64. }
  65. private function closeTickets()// 关闭用户超时未处理的工单
  66. {
  67. Ticket::whereStatus(1)
  68. ->whereHas('reply', function ($q) {
  69. $q->where('admin_id', '<>', null);
  70. })
  71. ->has('reply')
  72. ->where('updated_at', '<=', date('Y-m-d', strtotime('-'.config('tasks.close.ticket').' hours')))
  73. ->chunk(config('tasks.chunk'), function ($tickets) {
  74. foreach ($tickets as $ticket) {
  75. if ($ticket->close()) {
  76. $ticket->user->notify(new TicketClosed($ticket->id, $ticket->title, route('replyTicket', ['id' => $ticket->id]),
  77. __('You have not responded this ticket in :num hours, System has closed your ticket.', ['num' => config('tasks.close.ticket')])));
  78. }
  79. }
  80. });
  81. }
  82. private function resetUserTraffic()// 重置用户流量
  83. {
  84. User::where('status', '<>', -1)
  85. ->where('expired_at', '>', date('Y-m-d'))
  86. ->whereNotNull('reset_time')
  87. ->where('reset_time', '<=', date('Y-m-d'))
  88. ->with('orders')->whereHas('orders')
  89. ->chunk(config('tasks.chunk'), function ($users) {
  90. foreach ($users as $user) {
  91. $order = $user->orders()->activePlan()->first(); // 取出用户正在使用的套餐
  92. if (! $order) {// 无套餐用户跳过
  93. continue;
  94. }
  95. $user->orders()->activePackage()->update(['is_expire' => 1]); // 过期生效中的加油包
  96. $oldData = $user->transfer_enable;
  97. // 重置流量与重置日期
  98. if ($user->update((new OrderService($order))->resetTimeAndData($user->expired_at))) {
  99. // 可用流量变动日志
  100. Helpers::addUserTrafficModifyLog($order->user_id, $order->id, $oldData, $user->transfer_enable, '【流量重置】重置可用流量');
  101. Log::notice('用户[ID:'.$user->id.' 昵称: '.$user->nickname.' 邮箱: '.$user->username.'] 流量重置为 '.flowAutoShow($user->transfer_enable).'. 重置日期为 '.($user->reset_time ?: '【无】'));
  102. } else {
  103. Log::alert('用户[ID:'.$user->id.' 昵称: '.$user->nickname.' 邮箱: '.$user->username.'] 流量重置失败');
  104. }
  105. }
  106. });
  107. }
  108. }