mirror of
https://github.com/karl0ss/homepage.git
synced 2025-04-29 12:03:41 +01:00
Add UptimeRobot widget
This commit is contained in:
parent
82d2f08e8b
commit
e19dab3c5d
@ -727,5 +727,19 @@
|
|||||||
"stopped": "Stopped",
|
"stopped": "Stopped",
|
||||||
"passed": "Passed",
|
"passed": "Passed",
|
||||||
"failed": "Failed"
|
"failed": "Failed"
|
||||||
|
},
|
||||||
|
"uptimerobot": {
|
||||||
|
"status": "Status",
|
||||||
|
"uptime": "Uptime",
|
||||||
|
"lastDown": "Last Downtime",
|
||||||
|
"downDuration": "Downtime Duration",
|
||||||
|
"sitesUp": "Sites Up",
|
||||||
|
"sitesDown": "Sites Down",
|
||||||
|
"paused": "Paused",
|
||||||
|
"notyetchecked": "Not Yet Checked",
|
||||||
|
"up": "Up",
|
||||||
|
"seemsdown": "Seems Down",
|
||||||
|
"down": "Down",
|
||||||
|
"unknown": "Unknown"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -97,6 +97,7 @@ const components = {
|
|||||||
unifi: dynamic(() => import("./unifi/component")),
|
unifi: dynamic(() => import("./unifi/component")),
|
||||||
unmanic: dynamic(() => import("./unmanic/component")),
|
unmanic: dynamic(() => import("./unmanic/component")),
|
||||||
uptimekuma: dynamic(() => import("./uptimekuma/component")),
|
uptimekuma: dynamic(() => import("./uptimekuma/component")),
|
||||||
|
uptimerobot: dynamic(() => import("./uptimerobot/component")),
|
||||||
urbackup: dynamic(() => import("./urbackup/component")),
|
urbackup: dynamic(() => import("./urbackup/component")),
|
||||||
watchtower: dynamic(() => import("./watchtower/component")),
|
watchtower: dynamic(() => import("./watchtower/component")),
|
||||||
whatsupdocker: dynamic(() => import("./whatsupdocker/component")),
|
whatsupdocker: dynamic(() => import("./whatsupdocker/component")),
|
||||||
|
99
src/widgets/uptimerobot/component.jsx
Normal file
99
src/widgets/uptimerobot/component.jsx
Normal file
@ -0,0 +1,99 @@
|
|||||||
|
import { useTranslation } from "next-i18next";
|
||||||
|
|
||||||
|
import Container from "components/services/widget/container";
|
||||||
|
import Block from "components/services/widget/block";
|
||||||
|
import useWidgetAPI from "utils/proxy/use-widget-api";
|
||||||
|
|
||||||
|
function secondsToDhms(seconds) {
|
||||||
|
const d = Math.floor(seconds / (3600*24));
|
||||||
|
const h = Math.floor(seconds % (3600*24) / 3600);
|
||||||
|
const m = Math.floor(seconds % 3600 / 60);
|
||||||
|
const s = Math.floor(seconds % 60);
|
||||||
|
|
||||||
|
const dDisplay = d > 0 ? d + (d === 1 ? " day, " : " days, ") : "";
|
||||||
|
const hDisplay = h > 0 ? h + (h === 1 ? " hr, " : " hrs, ") : "";
|
||||||
|
let mDisplay = m > 0 && d === 0 ? m + (m === 1 ? " min" : " mins") : "";
|
||||||
|
let sDisplay = "";
|
||||||
|
|
||||||
|
if (d === 0 && h === 0) {
|
||||||
|
mDisplay = m > 0 ? m + (m === 1 ? " min, " : " mins, ") : "";
|
||||||
|
sDisplay = s > 0 ? s + (s === 1 ? " sec" : " secs") : "";
|
||||||
|
}
|
||||||
|
return (dDisplay + hDisplay + mDisplay + sDisplay).replace(/,\s*$/, "");
|
||||||
|
}
|
||||||
|
|
||||||
|
export default function Component({ service }) {
|
||||||
|
const { widget } = service;
|
||||||
|
const { t } = useTranslation();
|
||||||
|
|
||||||
|
const { data: uptimerobotData, error: uptimerobotError } = useWidgetAPI(widget, "getmonitors");
|
||||||
|
|
||||||
|
if (uptimerobotError) {
|
||||||
|
return <Container service={service} error={uptimerobotError} />;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!uptimerobotData) {
|
||||||
|
return (
|
||||||
|
<Container service={service}>
|
||||||
|
<Block label="uptimerobot.status" />
|
||||||
|
<Block label="uptimerobot.uptime" />
|
||||||
|
<Block label="uptimerobot.lastDown" />
|
||||||
|
<Block label="uptimerobot.downDuration" />
|
||||||
|
</Container>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// multiple monitors
|
||||||
|
if (uptimerobotData.pagination?.total > 1) {
|
||||||
|
const sitesUp = uptimerobotData.monitors.filter(m => m.status === 2).length;
|
||||||
|
|
||||||
|
return (
|
||||||
|
<Container service={service}>
|
||||||
|
<Block label="uptimerobot.sitesUp" value={sitesUp} />
|
||||||
|
<Block label="uptimerobot.sitesDown" value={uptimerobotData.pagination.total - sitesUp} />
|
||||||
|
</Container>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// single monitor
|
||||||
|
const monitor = uptimerobotData.monitors[0];
|
||||||
|
let status;
|
||||||
|
let uptime = 0;
|
||||||
|
let logIndex = 0;
|
||||||
|
|
||||||
|
switch (monitor.status) {
|
||||||
|
case 0:
|
||||||
|
status = t("uptimerobot.paused");
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
status = t("uptimerobot.notyetchecked");
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
status = t("uptimerobot.up");
|
||||||
|
uptime = secondsToDhms(monitor.logs[0].duration);
|
||||||
|
logIndex = 1;
|
||||||
|
break;
|
||||||
|
case 8:
|
||||||
|
status = t("uptimerobot.seemsdown");
|
||||||
|
break;
|
||||||
|
case 9:
|
||||||
|
status = t("uptimerobot.down");
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
status = t("uptimerobot.unknown");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
const lastDown = new Date(monitor.logs[logIndex].datetime * 1000).toLocaleString();
|
||||||
|
const downDuration = secondsToDhms(monitor.logs[logIndex].duration);
|
||||||
|
const hideDown = logIndex === 1 && monitor.logs[logIndex].type !== 1;
|
||||||
|
|
||||||
|
return (
|
||||||
|
<Container service={service}>
|
||||||
|
<Block label="uptimerobot.status" value={status} />
|
||||||
|
<Block label="uptimerobot.uptime" value={uptime} />
|
||||||
|
{!hideDown && <Block label="uptimerobot.lastDown" value={lastDown} />}
|
||||||
|
{!hideDown && <Block label="uptimerobot.downDuration" value={downDuration} />}
|
||||||
|
</Container>
|
||||||
|
);
|
||||||
|
}
|
20
src/widgets/uptimerobot/widget.js
Normal file
20
src/widgets/uptimerobot/widget.js
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
import genericProxyHandler from "utils/proxy/handlers/generic";
|
||||||
|
|
||||||
|
const widget = {
|
||||||
|
api: "{url}/v2/{endpoint}?api_key={key}",
|
||||||
|
proxyHandler: genericProxyHandler,
|
||||||
|
|
||||||
|
mappings: {
|
||||||
|
getmonitors: {
|
||||||
|
method: "POST",
|
||||||
|
endpoint: "getMonitors",
|
||||||
|
body: 'format=json&logs=1',
|
||||||
|
headers: {
|
||||||
|
"content-type": "application/x-www-form-urlencoded",
|
||||||
|
"cache-control": "no-cache"
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
export default widget;
|
@ -91,6 +91,7 @@ import truenas from "./truenas/widget";
|
|||||||
import unifi from "./unifi/widget";
|
import unifi from "./unifi/widget";
|
||||||
import unmanic from "./unmanic/widget";
|
import unmanic from "./unmanic/widget";
|
||||||
import uptimekuma from "./uptimekuma/widget";
|
import uptimekuma from "./uptimekuma/widget";
|
||||||
|
import uptimerobot from "./uptimerobot/widget";
|
||||||
import watchtower from "./watchtower/widget";
|
import watchtower from "./watchtower/widget";
|
||||||
import whatsupdocker from "./whatsupdocker/widget";
|
import whatsupdocker from "./whatsupdocker/widget";
|
||||||
import xteve from "./xteve/widget";
|
import xteve from "./xteve/widget";
|
||||||
@ -192,6 +193,7 @@ const widgets = {
|
|||||||
unifi_console: unifi,
|
unifi_console: unifi,
|
||||||
unmanic,
|
unmanic,
|
||||||
uptimekuma,
|
uptimekuma,
|
||||||
|
uptimerobot,
|
||||||
urbackup,
|
urbackup,
|
||||||
watchtower,
|
watchtower,
|
||||||
whatsupdocker,
|
whatsupdocker,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user