の停止期間設定機能を追加・地震発生お知らせにマグニチュード/深さを追加・天気お知らせに%が2つ付く問題を修正・地域情報更新が正常に発信されない問題を修正・地域情報更新のレート制限のデフォルト設定を30分に一回に・v4.0
This commit is contained in:
Last2014 2025-07-04 19:07:05 +09:00
parent 8be3684a78
commit e3451323f3
6 changed files with 78 additions and 23 deletions

View File

@ -2,12 +2,18 @@ import type { configTypes } from "types/config";
// READMEの設定項目を参照
const config: configTypes = {
time: {
stopTimes: {
start: new Date("23:00"),
stop: new Date("6:00"),
}
},
earthquake: {
reconnectTimes: 5000,
websocketUrl: "wss://api.p2pquake.net/v2/ws",
areasCsvUrl: "https://raw.githubusercontent.com/p2pquake/epsp-specifications/master/epsp-area.csv",
maxScaleMax: 30,
rateLimit: 10,
rateLimit: 30,
},
weather: {
splitCount: 4,

View File

@ -1,6 +1,6 @@
{
"name": "noticeuwuzu",
"version": "v3.5.6@uwuzu1.5.4",
"version": "v4.0@uwuzu1.5.4",
"description": "uwuzu Notice Bot",
"main": "dist/main.js",
"scripts": {

View File

@ -291,11 +291,37 @@ async function event(earthquakeInfo: any): Promise<void> {
description = `この地震について:${earthquakeInfo.comments.freeFormComment}`;
}
// 深さ
let depth: string = "";
if (
earthquakeInfo.earthquake.hypocenter.depth !== null ||
earthquakeInfo.earthquake.hypocenter.depth !== -1
) {
if (earthquakeInfo.earthquake.hypocenter.depth === 0) {
depth = "深さ:ごく浅い";
} else {
depth = `深さ:${earthquakeInfo.hypocenter.depth}km`;
}
}
// マグニチュード
let magnitude: string = "";
if(
earthquakeInfo.earthquake.hypocenter.magnitude !== null ||
earthquakeInfo.earthquake.hypocenter.magnitude !== -1
) {
magnitude = `マグニチュード:${earthquakeInfo.earthquake.hypocenter.magnitude}`;
}
ueuse(`
====
${earthquakeInfo.time}
${description}
${magnitude}
${depth}
${maxScale}
${areas}
${domesticTsunami}
@ -323,7 +349,7 @@ async function event(earthquakeInfo: any): Promise<void> {
const areas = areaNames.join("・");
if (differenceInMinutes(new Date(), rateLimit) >= config.earthquake.rateLimit) {
if (differenceInMinutes(rateLimit, new Date()) >= config.earthquake.rateLimit) {
ueuse(`
====

View File

@ -1,26 +1,39 @@
import { format } from "date-fns";
import { format, isAfter, isBefore } from "date-fns";
import type * as types from "types/types";
import config from "../config.js";
export default async function timeNotice() {
// 現在時刻を取得
const now = format(new Date(), "HH:mm");
// 時刻取得
const now = new Date();
const start = config.time.stopTimes.start;
const stop = config.time.stopTimes.stop;
// 投稿
const resUeuse = await fetch(
`https://${config.uwuzuServer}/api/ueuse/create`,
{
method: "POST",
body: JSON.stringify({
token: config.apiToken,
text: `${now}になりました`,
}),
},
);
// 停止時刻外
let inRange: Boolean = false;
const ueuseData: types.ueuseCreateApi = await resUeuse.json();
console.log(JSON.stringify(ueuseData));
if (isBefore(start, stop)) {
inRange = isAfter(now, start) && isBefore(now, stop);
} else {
inRange = isAfter(now, start) || isBefore(now, stop);
}
export default async function timeNotice() {
if (inRange === false) {
// 投稿
const resUeuse = await fetch(
`https://${config.uwuzuServer}/api/ueuse/create`,
{
method: "POST",
body: JSON.stringify({
token: config.apiToken,
text: `${now}になりました`,
}),
},
);
const ueuseData: types.ueuseCreateApi = await resUeuse.json();
console.log(JSON.stringify(ueuseData));
}
}

View File

@ -83,7 +83,7 @@ export default async function weatherNotice() {
today.chanceOfRain.T06_12 !== null ||
today.chanceOfRain.T06_12 !== "--%"
) {
chanceOfRain = `${today.chanceOfRain.T06_12}%`;
chanceOfRain = today.chanceOfRain.T06_12;
} else {
chanceOfRain = "取得できませんでした";
}

10
types/config.d.ts vendored
View File

@ -10,7 +10,17 @@ interface weatherTypes {
splitCount: number;
}
interface stopsTypes {
start: Date;
stop: Date;
}
interface timeTypes {
stopTimes: stopsTypes;
}
export interface configTypes {
time: timeTypes,
earthquake: earthquakeTypes;
weather: weatherTypes;