mirror of
https://github.com/LamGC/ContentGrabbingJi.git
synced 2025-04-30 22:57:31 +00:00
[Fix] Dockerfile.sample 修复Java应用无法接收stop命令发送信号的问题; [Change] RankingUpdateTimer 调整更新投递形式, 将同步更新调整为异步更新; [Change] BotEventHandler 实装TimeLimitThreadPoolExecutor;
86 lines
3.4 KiB
Java
86 lines
3.4 KiB
Java
package net.lamgc.cgj.bot;
|
|
|
|
import net.lamgc.cgj.bot.event.BotEventHandler;
|
|
import net.lamgc.cgj.bot.event.VirtualLoadMessageEvent;
|
|
import net.lamgc.cgj.pixiv.PixivURL;
|
|
import org.slf4j.Logger;
|
|
import org.slf4j.LoggerFactory;
|
|
|
|
import java.time.LocalDate;
|
|
import java.util.Calendar;
|
|
import java.util.Date;
|
|
import java.util.Timer;
|
|
import java.util.TimerTask;
|
|
|
|
public class RankingUpdateTimer {
|
|
|
|
private final Timer timer = new Timer("PixivRankingUpdate@" + Integer.toHexString(this.hashCode()), true);
|
|
private final Logger log = LoggerFactory.getLogger(this.toString());
|
|
|
|
/**
|
|
* 启动定时任务.
|
|
* 本方法在设置后立即返回
|
|
* @param firstRunDate 首次运行时间, 只需要设置日期, 时间为自动设置.
|
|
*/
|
|
public void schedule(Date firstRunDate) {
|
|
Calendar cal = Calendar.getInstance();
|
|
cal.setTime(firstRunDate == null ? new Date() : firstRunDate);
|
|
LocalDate currentLocalDate = LocalDate.now();
|
|
if(cal.get(Calendar.DAY_OF_YEAR) <= currentLocalDate.getDayOfYear() && cal.get(Calendar.HOUR_OF_DAY) >= 12) {
|
|
cal.set(Calendar.DAY_OF_YEAR, currentLocalDate.getDayOfYear() + 1);
|
|
}
|
|
cal.set(Calendar.HOUR_OF_DAY, 12);
|
|
cal.set(Calendar.MINUTE, 0);
|
|
cal.set(Calendar.SECOND, 0);
|
|
cal.set(Calendar.MILLISECOND, 0);
|
|
|
|
log.warn("已设置排行榜定时更新, 首次运行时间: {}", cal.getTime());
|
|
timer.schedule(new TimerTask() {
|
|
@Override
|
|
public void run() {
|
|
now(null);
|
|
}
|
|
}, cal.getTime(), 86400000); // 1 Day
|
|
}
|
|
|
|
public void now(Date queryDate) {
|
|
log.warn("当前时间 {}, 定时任务开始执行...", new Date());
|
|
Calendar calendar = Calendar.getInstance();
|
|
calendar.setTime(queryDate == null ? new Date() : queryDate);
|
|
|
|
LocalDate currentLocalDate = LocalDate.now();
|
|
if(calendar.get(Calendar.DAY_OF_YEAR) == currentLocalDate.getDayOfYear() ||
|
|
calendar.get(Calendar.DAY_OF_YEAR) == currentLocalDate.getDayOfYear() - 1) {
|
|
if(calendar.get(Calendar.HOUR_OF_DAY) < 12) {
|
|
calendar.add(Calendar.DAY_OF_YEAR, -2);
|
|
} else {
|
|
calendar.add(Calendar.DAY_OF_YEAR, -1);
|
|
}
|
|
}
|
|
|
|
log.info("正在获取 {} 期排行榜数据...", calendar.getTime());
|
|
for (PixivURL.RankingMode rankingMode : PixivURL.RankingMode.values()) {
|
|
for (PixivURL.RankingContentType contentType : PixivURL.RankingContentType.values()) {
|
|
if(!contentType.isSupportedMode(rankingMode)) {
|
|
log.debug("不支持的类型, 填空值跳过...(类型: {}.{})", rankingMode.name(), contentType.name());
|
|
}
|
|
log.info("当前排行榜类型: {}.{}, 正在更新...", rankingMode.name(), contentType.name());
|
|
BotEventHandler.executor.executor(
|
|
new VirtualLoadMessageEvent(0,0,
|
|
".cgj ranking -type=" + contentType.name() + " -mode=" + rankingMode.name()));
|
|
log.info("排行榜 {}.{} 负载指令已投递.", rankingMode.name(), contentType.name());
|
|
}
|
|
}
|
|
log.warn("定时任务更新完成.");
|
|
}
|
|
|
|
/**
|
|
* 取消任务.
|
|
*/
|
|
public void stop() {
|
|
timer.cancel();
|
|
log.warn("排行榜更新任务已取消.");
|
|
}
|
|
|
|
}
|