Feat: 地震情報のWebSocket再接続

This commit is contained in:
2026-05-02 20:32:15 +09:00
parent c0df3d7344
commit d61fc56a38
3 changed files with 50 additions and 30 deletions
+2
View File
@@ -12,6 +12,8 @@ earthquake:
# 過去のデバッグ用データを使用して地震情報を配信するかどうか boolean # 過去のデバッグ用データを使用して地震情報を配信するかどうか boolean
# デバッグ用途のみで使用してください。 # デバッグ用途のみで使用してください。
useHistoryData: false useHistoryData: false
# 再接続の間隔(ミリ秒) number
reconnectInterval: 3000
uwuzu: uwuzu:
# APIトークン string # APIトークン string
# とくに理由がない限り、全権限を与えてください。 # とくに理由がない限り、全権限を与えてください。
+18 -1
View File
@@ -21,6 +21,7 @@ if (config.earthquake?.useHistoryData) {
i++; i++;
}, 10 * 1000); }, 10 * 1000);
} else { } else {
const connect = () => {
const WEBSOCKET_URL = config.debug const WEBSOCKET_URL = config.debug
? "wss://api-realtime-sandbox.p2pquake.net/v2/ws" ? "wss://api-realtime-sandbox.p2pquake.net/v2/ws"
: "wss://api.p2pquake.net/v2/ws"; : "wss://api.p2pquake.net/v2/ws";
@@ -32,6 +33,19 @@ if (config.earthquake?.useHistoryData) {
console.log("P2P地震情報のWebSocketに接続しました"); console.log("P2P地震情報のWebSocketに接続しました");
}); });
socket.addEventListener("close", (err) => {
const interval = config.earthquake.reconnectInterval;
console.log(`WebSocketが切断されました。${interval / 1000}秒後に再接続します:`, err.reason);
setTimeout(() => {
connect();
}, interval);
});
socket.addEventListener("error", (err) => {
console.error("WebSocketでエラーが発生しました:", err);
socket.close();
});
socket.addEventListener("message", async (event) => { socket.addEventListener("message", async (event) => {
let message; let message;
@@ -40,7 +54,7 @@ if (config.earthquake?.useHistoryData) {
? JSON.parse(event.data) ? JSON.parse(event.data)
: event.data; : event.data;
} catch (err) { } catch (err) {
console.error(`地震情報メッセージのパースでエラーが発生: ${err}`); console.error("地震情報メッセージのパースでエラーが発生:", err);
return; return;
} }
@@ -60,6 +74,9 @@ if (config.earthquake?.useHistoryData) {
}); });
} }
connect();
}
const processMessage = async (message: any) => { const processMessage = async (message: any) => {
try { try {
const scaleMessages: Record<string, string> = { const scaleMessages: Record<string, string> = {
+1
View File
@@ -21,6 +21,7 @@ const schema = z.object({
]), ]),
canUnknownMaxScale: z.boolean(), canUnknownMaxScale: z.boolean(),
useHistoryData: z.boolean(), useHistoryData: z.boolean(),
reconnectInterval: z.number().positive(),
}), }),
uwuzu: z.object({ uwuzu: z.object({
token: z.string().length(64), token: z.string().length(64),