UserExpireAutoWarning.php 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  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. protected $signature = 'userExpireAutoWarning';
  12. protected $description = '用户临近到期自动发邮件提醒';
  13. public function handle(): void {
  14. $jobStartTime = microtime(true);
  15. // 用户临近到期自动发邮件提醒
  16. if(sysConfig('expire_warning')){
  17. $this->userExpireWarning();
  18. }
  19. $jobEndTime = microtime(true);
  20. $jobUsedTime = round(($jobEndTime - $jobStartTime), 4);
  21. Log::info('---【'.$this->description.'】完成---,耗时'.$jobUsedTime.'秒');
  22. }
  23. private function userExpireWarning(): void {
  24. // 只取SSR没被禁用的用户,其他不用管
  25. foreach(User::query()->whereEnable(1)->get() as $user){
  26. // 用户名不是邮箱的跳过
  27. if(false === filter_var($user->email, FILTER_VALIDATE_EMAIL)){
  28. continue;
  29. }
  30. // 计算剩余可用时间
  31. $lastCanUseDays = ceil(round(strtotime($user->expire_time) - time()) / Day);
  32. if($lastCanUseDays == 0){
  33. $title = '账号过期提醒';
  34. $content = '您的账号将于今天晚上【24:00】过期。';
  35. $logId = Helpers::addNotificationLog($title, $content, 1, $user->email);
  36. Mail::to($user->email)->send(new userExpireWarningToday($logId));
  37. }elseif($lastCanUseDays > 0 && $lastCanUseDays <= sysConfig('expire_days')){
  38. $title = '账号过期提醒';
  39. $content = '您的账号还剩'.$lastCanUseDays.'天即将过期。';
  40. $logId = Helpers::addNotificationLog($title, $content, 1, $user->email);
  41. Mail::to($user->email)->send(new userExpireWarning($logId, $lastCanUseDays));
  42. }
  43. }
  44. }
  45. }