mirror of
				https://github.com/karl0ss/homepage.git
				synced 2025-11-04 08:20:58 +00:00 
			
		
		
		
	Merge pull request #1876 from tomhoover/uptimerobot-widget
Add UptimeRobot widget --------- Co-authored-by: shamoon <4887959+shamoon@users.noreply.github.com>
This commit is contained in:
		
						commit
						e990ba3394
					
				@ -727,5 +727,19 @@
 | 
			
		||||
        "stopped": "Stopped",
 | 
			
		||||
        "passed": "Passed",
 | 
			
		||||
        "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")),
 | 
			
		||||
  unmanic: dynamic(() => import("./unmanic/component")),
 | 
			
		||||
  uptimekuma: dynamic(() => import("./uptimekuma/component")),
 | 
			
		||||
  uptimerobot: dynamic(() => import("./uptimerobot/component")),
 | 
			
		||||
  urbackup: dynamic(() => import("./urbackup/component")),
 | 
			
		||||
  watchtower: dynamic(() => import("./watchtower/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 unmanic from "./unmanic/widget";
 | 
			
		||||
import uptimekuma from "./uptimekuma/widget";
 | 
			
		||||
import uptimerobot from "./uptimerobot/widget";
 | 
			
		||||
import watchtower from "./watchtower/widget";
 | 
			
		||||
import whatsupdocker from "./whatsupdocker/widget";
 | 
			
		||||
import xteve from "./xteve/widget";
 | 
			
		||||
@ -192,6 +193,7 @@ const widgets = {
 | 
			
		||||
  unifi_console: unifi,
 | 
			
		||||
  unmanic,
 | 
			
		||||
  uptimekuma,
 | 
			
		||||
  uptimerobot,
 | 
			
		||||
  urbackup,
 | 
			
		||||
  watchtower,
 | 
			
		||||
  whatsupdocker,
 | 
			
		||||
 | 
			
		||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user