UserExpireAutoWarning.php 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. <?php
  2. namespace App\Console\Commands;
  3. use App\Components\Helpers;
  4. use App\Mail\userExpireWarning;
  5. use App\Mail\userExpireWarningToday;
  6. use App\Models\User;
  7. use Illuminate\Console\Command;
  8. use Log;
  9. use Mail;
  10. class UserExpireAutoWarning extends Command
  11. {
  12. protected $signature = 'userExpireAutoWarning';
  13. protected $description = '用户临近到期自动发邮件提醒';
  14. public function handle(): void
  15. {
  16. $jobStartTime = microtime(true);
  17. // 用户临近到期自动发邮件提醒
  18. if (sysConfig('expire_warning')) {
  19. $this->userExpireWarning();
  20. }
  21. $jobEndTime = microtime(true);
  22. $jobUsedTime = round(($jobEndTime - $jobStartTime), 4);
  23. Log::info('---【'.$this->description.'】完成---,耗时'.$jobUsedTime.'秒');
  24. }
  25. private function userExpireWarning(): void
  26. {
  27. $expireDays = sysConfig('expire_days');
  28. // 只取SSR没被禁用的用户,其他不用管
  29. foreach (User::whereEnable(1)->get() as $user) {
  30. // 用户名不是邮箱的跳过
  31. if (false === filter_var($user->email, FILTER_VALIDATE_EMAIL)) {
  32. continue;
  33. }
  34. // 计算剩余可用时间
  35. $lastCanUseDays = Helpers::daysToNow($user->expired_at);
  36. if ($lastCanUseDays === 0) {
  37. $title = '账号过期提醒';
  38. $content = '您的账号将于今天晚上【24:00】过期。';
  39. $logId = Helpers::addNotificationLog($title, $content, 1, $user->email);
  40. Mail::to($user->email)->send(new userExpireWarningToday($logId));
  41. } elseif ($lastCanUseDays > 0 && $lastCanUseDays <= $expireDays) {
  42. $title = '账号过期提醒';
  43. $content = '您的账号还剩'.$lastCanUseDays.'天即将过期。';
  44. $logId = Helpers::addNotificationLog($title, $content, 1, $user->email);
  45. Mail::to($user->email)->send(new userExpireWarning($logId, $lastCanUseDays));
  46. }
  47. }
  48. }
  49. }