天気機能を最適化

This commit is contained in:
Last2014 2025-06-30 12:24:03 +09:00
parent c4d2990118
commit c5bd22600a
4 changed files with 88 additions and 29 deletions

10
main.ts
View File

@ -5,17 +5,17 @@ import weatherNotice from "./scripts/weatherNotice.js";
import followBack from "./scripts/followBack.js"; import followBack from "./scripts/followBack.js";
weatherNotice();
// 時報・フォローバック(毎時) // 時報・フォローバック(毎時)
cron.schedule("0 * * * *", () => { cron.schedule("0 * * * *", () => {
timeNotice(); timeNotice();
followBack(); followBack();
}); });
// 天気お知らせ(毎日7:01) // 天気お知らせ(毎日7:00)
cron.schedule("1 7 * * *", () => { cron.schedule("0 7 * * *", () => {
weatherNotice(); setTimeout(() => {
weatherNotice();
}, 100)
}); });
console.log("サーバーが起動しました"); console.log("サーバーが起動しました");

View File

@ -5,11 +5,12 @@ import type * as types from "../types";
dotenv.config(); dotenv.config();
export default async function followBack() { export default async function followBack() {
// uwuzu.netで/api/meのPOSTが死んでいるため簡易的にGET // フォロワーを取得
const resMe = await fetch( const resMe = await fetch(
`https://${process.env.SERVER}/api/me?token=${process.env.TOKEN}`, `https://${process.env.SERVER}/api/me?token=${process.env.TOKEN}`,
{ {
method: "GET", method: "GET",
// uwuzu.netで/api/meのPOSTが死んでいるため簡易的にGET
}, },
); );
@ -19,6 +20,7 @@ export default async function followBack() {
const followers: Array<string> = meData.follower; const followers: Array<string> = meData.follower;
// フォロー
for (let i = 0; i < followers.length; i++) { for (let i = 0; i < followers.length; i++) {
const followerItem = followers[i]; const followerItem = followers[i];

View File

@ -6,8 +6,10 @@ import type * as types from "../types";
dotenv.config(); dotenv.config();
export default async function timeNotice() { export default async function timeNotice() {
// 現在時刻を取得
const now = format(new Date(), "HH:mm"); const now = format(new Date(), "HH:mm");
// 投稿
const resUeuse = await fetch( const resUeuse = await fetch(
`https://${process.env.SERVER}/api/ueuse/create`, `https://${process.env.SERVER}/api/ueuse/create`,
{ {

View File

@ -5,7 +5,7 @@ import type * as types from "../types";
dotenv.config(); dotenv.config();
export default async function weatherNotice() { export default async function weatherNotice() {
/*// 稿 // 仮投稿
const resUeuse = await fetch( const resUeuse = await fetch(
`https://${process.env.SERVER}/api/ueuse/create`, `https://${process.env.SERVER}/api/ueuse/create`,
{ {
@ -22,16 +22,29 @@ export default async function weatherNotice() {
const ueuseData: types.ueuseCreateApi = await resUeuse.json(); const ueuseData: types.ueuseCreateApi = await resUeuse.json();
console.log(JSON.stringify(ueuseData));*/ console.log(JSON.stringify(ueuseData));
// 3分割処理
const total = cityList.length;
const firstLength = Math.trunc(total / 3);
const secondLength = Math.trunc((total - firstLength) / 2);
const thirdLength = total - firstLength - secondLength;
let weatherResults: string = ""; // インデックス作成
const firstStart = 0;
const firstEnd = firstStart + firstLength;
const secondStart = firstEnd;
const secondEnd = secondStart + secondLength;
const thirdStart = secondEnd;
const thirdEnd = total;
for (let i = 0; i < cityList.length; i++) { let weatherResults = ["", "", ""];
// 投稿1
for (let i = firstStart; i < firstEnd; i++) {
const res = await fetch( const res = await fetch(
`https://weather.tsukumijima.net/api/forecast/city/${cityList[i]}`, `https://weather.tsukumijima.net/api/forecast/city/${cityList[i]}`,
); );
const data = await res.json(); const data = await res.json();
const today = data.forecasts[0]; const today = data.forecasts[0];
@ -40,31 +53,73 @@ export default async function weatherNotice() {
const minTemp = today.temperature.min?.celsius ?? "取得できませんでした"; const minTemp = today.temperature.min?.celsius ?? "取得できませんでした";
const chanceOfRain = data.chanceOfRain?.["T06_12"] ?? "取得できませんでした"; const chanceOfRain = data.chanceOfRain?.["T06_12"] ?? "取得できませんでした";
weatherResults = weatherResults + weatherResults[0] += `
`${data.location.city}\n ${data.location.city}\n
${weather}\n ${weather}\n
${maxTemp}\n ${maxTemp}\n
${minTemp}\n ${minTemp}\n
${chanceOfRain} ${chanceOfRain}\n
`; `;
} }
console.log(weatherResults); // 投稿2
for (let i = secondStart; i < secondEnd; i++) {
const res = await fetch(
`https://weather.tsukumijima.net/api/forecast/city/${cityList[i]}`,
);
const data = await res.json();
const today = data.forecasts[0];
/*// const weather = today.telop ?? "取得できませんでした";
const resReply = await fetch( const maxTemp = today.temperature.max?.celsius ?? "取得できませんでした";
`https://${process.env.SERVER}/api/ueuse/create`, const minTemp = today.temperature.min?.celsius ?? "取得できませんでした";
{ const chanceOfRain = data.chanceOfRain?.["T06_12"] ?? "取得できませんでした";
method: "POST",
body: JSON.stringify({
token: process.env.TOKEN,
text: weatherResults,
replyid: ueuseData.uniqid
}),
},
);
const replyData: types.ueuseCreateApi = await resReply.json(); weatherResults[1] += `
${data.location.city}\n
${weather}\n
${maxTemp}\n
${minTemp}\n
${chanceOfRain}\n
`;
}
console.log(JSON.stringify(replyData));*/ // 投稿3
for (let i = thirdStart; i < thirdEnd; i++) {
const res = await fetch(
`https://weather.tsukumijima.net/api/forecast/city/${cityList[i]}`,
);
const data = await res.json();
const today = data.forecasts[0];
const weather = today.telop ?? "取得できませんでした";
const maxTemp = today.temperature.max?.celsius ?? "取得できませんでした";
const minTemp = today.temperature.min?.celsius ?? "取得できませんでした";
const chanceOfRain = data.chanceOfRain?.["T06_12"] ?? "取得できませんでした";
weatherResults[2] += `
${data.location.city}\n
${weather}\n
${maxTemp}\n
${minTemp}\n
${chanceOfRain}\n
`;
}
// 3分割投稿
for (let i = 0; i < 3; i++) {
const resReply = await fetch(
`https://${process.env.SERVER}/api/ueuse/create`,
{
method: "POST",
body: JSON.stringify({
token: process.env.TOKEN,
text: weatherResults[i],
replyid: ueuseData.uniqid
}),
},
);
const replyData: types.ueuseCreateApi = await resReply.json();
console.log(JSON.stringify(replyData));
}
} }