TaskMonthly.php 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. <?php
  2. namespace App\Console\Commands;
  3. use App\Models\NotificationLog;
  4. use App\Models\Order;
  5. use App\Models\Payment;
  6. use App\Models\User;
  7. use App\Models\UserBanedLog;
  8. use App\Models\UserLoginLog;
  9. use Exception;
  10. use Illuminate\Console\Command;
  11. use Log;
  12. class TaskMonthly extends Command
  13. {
  14. protected $signature = 'task:monthly';
  15. protected $description = '每月任务';
  16. public function handle(): void
  17. {
  18. $jobTime = microtime(true);
  19. $this->cleanAccounts(); // 清理僵尸账号
  20. if (sysConfig('is_clear_log')) {
  21. $this->clearLog(); // 清除小日志
  22. }
  23. $jobTime = round(microtime(true) - $jobTime, 4);
  24. Log::info(__('----「:job」Completed, Used :time seconds ----', ['job' => $this->description, 'time' => $jobTime]));
  25. }
  26. private function cleanAccounts(): void
  27. {
  28. User::where('expired_at', '<', date('Y-m-d'))->where('transfer_enable', '==', 0)->whereEnable(0)
  29. ->whereRaw('u + d > transfer_enable')->update(['u' => 0, 'd' => 0]);
  30. }
  31. private function clearLog(): void
  32. {
  33. try {
  34. NotificationLog::where('updated_at', '<=', date('Y-m-d H:i:s', strtotime(config('tasks.clean.notification_logs'))))->delete(); // 清理通知日志
  35. UserLoginLog::where('created_at', '<=', date('Y-m-d H:i:s', strtotime(config('tasks.clean.login_logs'))))->delete(); // 清除用户登陆日志
  36. Payment::where('created_at', '<=', date('Y-m-d H:i:s', strtotime(config('tasks.clean.payments'))))->delete(); // 清理在线支付日志
  37. UserBanedLog::where('created_at', '<=', date('Y-m-d H:i:s', strtotime(config('tasks.clean.user_baned_logs'))))->delete(); // 清理用户封禁日志
  38. Order::whereStatus(-1)->where('created_at', '<=', date('Y-m-d H:i:s', strtotime(config('tasks.clean.unpaid_orders'))))->delete(); // 清理用户未支付订单
  39. } catch (Exception $e) {
  40. Log::emergency('【清理日志】错误: '.$e->getMessage());
  41. }
  42. }
  43. }