maplestory/backend/services/sundayMapleCron.js

36 lines
1.2 KiB
JavaScript
Raw Normal View History

import cron from 'node-cron';
import { fetchAndSaveSundayMaple } from './sundayMaple.js';
const POLL_INTERVAL_MS = 10_000; // 10초 간격
const MAX_DURATION_MS = 5 * 60 * 1000; // 최대 5분
/**
* 금요일 9시부터 10 간격 폴링 찾으면 저장 종료, 5 타임아웃.
*/
async function runPolling() {
const started = Date.now();
console.log('[sunday-maple cron] 폴링 시작');
while (Date.now() - started < MAX_DURATION_MS) {
try {
const row = await fetchAndSaveSundayMaple();
if (row) {
console.log('[sunday-maple cron] 저장 완료 → 종료');
return;
}
} catch (err) {
console.warn('[sunday-maple cron] 폴링 중 오류:', err.message);
}
await new Promise((r) => setTimeout(r, POLL_INTERVAL_MS));
}
console.log('[sunday-maple cron] 5분 타임아웃 → 종료 (lazy fallback이 커버)');
}
/**
* 매주 / 09:00 KST 실행 (금요일이 공휴일이면 목요일에 게시되는 경우 대응)
*/
export function scheduleSundayMapleCron() {
cron.schedule('0 9 * * 4,5', runPolling, { timezone: 'Asia/Seoul' });
console.log('[sunday-maple cron] 매주 목/금 09:00 KST 스케줄 등록');
}