today.webhook/app/lib/discord.ts
imnyang 601ebca93e
All checks were successful
/ print-content (push) Successful in 13s
Update timetable function to add input validation and improve error handling
2026-04-04 00:06:19 +09:00

99 lines
No EOL
3.4 KiB
TypeScript

import { getTimetable, room } from "./comcigan";
import { getMealInfo, NameToEmoji, removeNutritionInfo } from "./meal";
export async function Meal({ MLSV_YMD, ATPT_OFCDC_SC_CODE, SD_SCHUL_CODE, username, schoolName, WEBHOOK_URL }: { MLSV_YMD: string, ATPT_OFCDC_SC_CODE: string, SD_SCHUL_CODE: string, username: string, schoolName: string, WEBHOOK_URL: string }) {
const mealInfo = await getMealInfo(MLSV_YMD, ATPT_OFCDC_SC_CODE, SD_SCHUL_CODE);
//const isVTS = vts.VTS임(MLSV_YMD);
const lines = removeNutritionInfo(mealInfo.meal).split("\n");
let emojis = (await NameToEmoji(lines.toString())).split(",");
const data = {
content: `${MLSV_YMD.slice(0, 4)}${MLSV_YMD.slice(4, 6)}${MLSV_YMD.slice(6, 8)}일 급식 정보`,
username: username,
embeds: [
{
title: `🏫 | ${schoolName}`,
description: lines.map((line, index) => `${emojis[index] || "❓"} ${line}`).join("\n"),
footer: {
text: `🔥 ${mealInfo.kcal}`
}
},
],
};
console.log("🏓 | Sending Payload");
const response = await fetch(WEBHOOK_URL, {
method: "POST",
headers: {
"Content-Type": "application/json",
},
body: JSON.stringify(data),
});
if (!response.ok) {
console.error("Error sending Discord webhook:", response.statusText);
} else {
console.log(`✨ | Payload successfully sent, code ${response.status}`);
}
}
export async function Timetable({ schoolId, grade, classNum, weekday, WEBHOOK_URL }: { schoolId: number, grade: number, classNum: number, weekday: number, WEBHOOK_URL: string }) {
// 필수 값 검증: undefined/null 이면 전송 안 함
if ([schoolId, grade, classNum, weekday, WEBHOOK_URL].some((v) => v === undefined || v === null)) {
console.warn("⚠️ | Undefined input detected. Skip sending webhook.");
return;
}
const weekdayText = ["월", "화", "수", "목", "금"][weekday - 1];
if (!weekdayText) {
console.warn("⚠️ | Invalid weekday. Skip sending webhook.");
return;
}
const timetableInfo = await getTimetable({ schoolId, grade, classNum, weekday });
console.log("🏓 | Timetable Info Retrieved", timetableInfo);
// 받아온 시간표 값이 없거나(undefined) 항목에 undefined 값이 있으면 전송 안 함
if (
!timetableInfo ||
timetableInfo.length === 0 ||
timetableInfo.some((item) => !item || item.subject === undefined || item.teacher === undefined)
) {
console.warn("⚠️ | Timetable contains undefined/empty data. Skip sending webhook.");
return;
}
const data = {
content: `📅 | ${grade}학년 ${classNum}반 시간표 정보`,
embeds: [
{
title: `🏫 | 학교 : 선린인터넷고등학교`,
fields: timetableInfo.map((item) => ({
name: `${item.subject}${item.changed ? " *" : ""}`,
value: `${item.teacher}${item.subject in room ? ` | ${room[item.subject as keyof typeof room]}` : ""}`,
inline: false,
})),
footer: {
text: `${weekdayText}요일 시간표 정보`,
},
},
],
};
console.log("🏓 | Sending Payload");
const response = await fetch(WEBHOOK_URL, {
method: "POST",
headers: {
"Content-Type": "application/json",
},
body: JSON.stringify(data),
});
if (!response.ok) {
console.error("Error sending Discord webhook:", response.statusText);
} else {
console.log(`✨ | Payload successfully sent, code ${response.status}`);
}
}