From d357dcb3349aa8cf40281bba98b5753a74f9b7c5 Mon Sep 17 00:00:00 2001 From: LouisLam Date: Sun, 11 Jul 2021 20:07:03 +0800 Subject: [PATCH] fix first beat's uptime is 0% --- package.json | 2 +- server/model/monitor.js | 49 ++++++++++++++++++++++++++--------------- 2 files changed, 32 insertions(+), 19 deletions(-) diff --git a/package.json b/package.json index 12ff6cfb..b8ee4ed3 100644 --- a/package.json +++ b/package.json @@ -7,7 +7,7 @@ "update": "", "build": "vite build", "vite-preview-dist": "vite preview --host", - "build-docker": "docker buildx build --platform linux/amd64,linux/arm64,linux/arm/v7 -t louislam/uptime-kuma . --push", + "build-docker": "docker buildx build --platform linux/amd64,linux/arm64,linux/arm/v7 -t louislam/uptime-kuma -t louislam/uptime-kuma:1 . --push", "setup": "git checkout 1.0.0 && npm install && npm run build" }, "dependencies": { diff --git a/server/model/monitor.js b/server/model/monitor.js index 269d9da2..2735c378 100644 --- a/server/model/monitor.js +++ b/server/model/monitor.js @@ -185,7 +185,7 @@ class Monitor extends BeanModel { static async sendUptime(duration, io, monitorID, userID) { let sec = duration * 3600; - let downtimeList = await R.getAll(` + let heartbeatList = await R.getAll(` SELECT duration, time, status FROM heartbeat WHERE time > DATETIME('now', ? || ' hours') @@ -198,32 +198,45 @@ class Monitor extends BeanModel { let total = 0; let uptime; - for (let row of downtimeList) { - let value = parseInt(row.duration) - let time = row.time + // Special handle for the first heartbeat only + if (heartbeatList.length === 1) { - // Handle if heartbeat duration longer than the target duration - // e.g. Heartbeat duration = 28hrs, but target duration = 24hrs - if (value > sec) { - let trim = dayjs.utc().diff(dayjs(time), 'second'); - value = sec - trim; + if (heartbeatList[0].status === 1) { + uptime = 1; + } else { + uptime = 0; + } - if (value < 0) { - value = 0; + } else { + for (let row of heartbeatList) { + let value = parseInt(row.duration) + let time = row.time + + // Handle if heartbeat duration longer than the target duration + // e.g. Heartbeat duration = 28hrs, but target duration = 24hrs + if (value > sec) { + let trim = dayjs.utc().diff(dayjs(time), 'second'); + value = sec - trim; + + if (value < 0) { + value = 0; + } + } + + total += value; + if (row.status === 0) { + downtime += value; } } - total += value; - if (row.status === 0) { - downtime += value; + uptime = (total - downtime) / total; + + if (uptime < 0) { + uptime = 0; } } - uptime = (total - downtime) / total; - if (uptime < 0) { - uptime = 0; - } io.to(userID).emit("uptime", monitorID, duration, uptime); }