Files
ProxyPanel/app/Console/Commands/UserExpireAutoWarning.php
兔姬桑 8f06a74b48 修复与规范日期有关代码
1. 修复原版本中节点/用户每日流量日志记录错误;
原版:在30号看到的29号的总流量,其实是28号当天产生的流量;依次类推全部流量都错位1天;
现:日流量表精确到当天,天流量表精确到当前;
2. 修复原流量折线图的日期-流量配对错误;
原版:并不是按照记录日期,而是按照有的记录;
现:按照记录日期排序;
----- 以上皆为SSRPanel中遗留的问题代码-----
3. 简化,规范化日期转换
4. 清理多余代码;
2020-08-05 03:51:29 +08:00

63 lines
1.9 KiB
PHP
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
<?php
namespace App\Console\Commands;
use App\Components\Helpers;
use App\Mail\userExpireWarning;
use App\Mail\userExpireWarningToday;
use App\Models\User;
use Illuminate\Console\Command;
use Log;
use Mail;
class UserExpireAutoWarning extends Command {
protected static $systemConfig;
protected $signature = 'userExpireAutoWarning';
protected $description = '用户临近到期自动发邮件提醒';
public function __construct() {
parent::__construct();
self::$systemConfig = Helpers::systemConfig();
}
public function handle(): void {
$jobStartTime = microtime(true);
// 用户临近到期自动发邮件提醒
if(self::$systemConfig['expire_warning']){
$this->userExpireWarning();
}
$jobEndTime = microtime(true);
$jobUsedTime = round(($jobEndTime - $jobStartTime), 4);
Log::info('---【'.$this->description.'】完成---,耗时'.$jobUsedTime.'秒');
}
private function userExpireWarning(): void {
// 只取SSR没被禁用的用户其他不用管
foreach(User::query()->whereEnable(1)->get() as $user){
// 用户名不是邮箱的跳过
if(false === filter_var($user->email, FILTER_VALIDATE_EMAIL)){
continue;
}
// 计算剩余可用时间
$lastCanUseDays = ceil(round(strtotime($user->expire_time) - time()) / Day);
if($lastCanUseDays == 0){
$title = '账号过期提醒';
$content = '您的账号将于今天晚上【24:00】过期。';
$logId = Helpers::addNotificationLog($title, $content, 1, $user->email);
Mail::to($user->email)->send(new userExpireWarningToday($logId));
}elseif($lastCanUseDays > 0 && $lastCanUseDays <= self::$systemConfig['expire_days']){
$title = '账号过期提醒';
$content = '您的账号还剩'.$lastCanUseDays.'天即将过期。';
$logId = Helpers::addNotificationLog($title, $content, 1, $user->email);
Mail::to($user->email)->send(new userExpireWarning($logId, $lastCanUseDays));
}
}
}
}