From b87eed2597914aca4e00fe0daf47983e5bc3fe47 Mon Sep 17 00:00:00 2001 From: lucasheld Date: Tue, 2 May 2023 20:34:26 +0200 Subject: [PATCH 1/2] fix: adjust monitor `status` type to allow all used values BREAKING CHANGE: monitor `status` type changed from `bool` to `MonitorStatus` --- uptime_kuma_api/__init__.py | 1 + uptime_kuma_api/api.py | 42 +++++++++++++++++++++++-------- uptime_kuma_api/monitor_status.py | 17 +++++++++++++ 3 files changed, 49 insertions(+), 11 deletions(-) create mode 100644 uptime_kuma_api/monitor_status.py diff --git a/uptime_kuma_api/__init__.py b/uptime_kuma_api/__init__.py index b069d5b..a62c17b 100644 --- a/uptime_kuma_api/__init__.py +++ b/uptime_kuma_api/__init__.py @@ -1,5 +1,6 @@ from .__version__ import __title__, __version__, __author__, __copyright__ from .auth_method import AuthMethod +from .monitor_status import MonitorStatus from .monitor_type import MonitorType from .notification_providers import NotificationType, notification_provider_options, notification_provider_conditions from .proxy_protocol import ProxyProtocol diff --git a/uptime_kuma_api/api.py b/uptime_kuma_api/api.py index 36fe904..4355de4 100644 --- a/uptime_kuma_api/api.py +++ b/uptime_kuma_api/api.py @@ -13,11 +13,12 @@ import requests import socketio from packaging.version import parse as parse_version -from . import (AuthMethod, +from . import (AuthMethod, DockerType, Event, IncidentStyle, MaintenanceStrategy, + MonitorStatus, MonitorType, NotificationType, ProxyProtocol, @@ -33,6 +34,7 @@ from .docstrings import (append_docstring, proxy_docstring, tag_docstring) + def int_to_bool(data, keys) -> None: if isinstance(data, list): for d in data: @@ -43,6 +45,20 @@ def int_to_bool(data, keys) -> None: data[key] = True if data[key] == 1 else False +def parse_value(data, func) -> None: + if isinstance(data, list): + for d in data: + parse_value(d, func) + else: + func(data) + + +def parse_monitor_status(data) -> None: + def parse(x): + x["status"] = MonitorStatus(x["status"]) + parse_value(data, parse) + + def gen_secret(length: int) -> str: chars = string.ascii_uppercase + string.ascii_lowercase + string.digits return ''.join(random.choice(chars) for _ in range(length)) @@ -1123,7 +1139,7 @@ class UptimeKumaApi(object): 'monitor_id': 1, 'msg': '200 - OK', 'ping': 201, - 'status': True, + 'status': , 'time': '2022-12-15 12:38:42.661' }, { @@ -1134,14 +1150,15 @@ class UptimeKumaApi(object): 'monitor_id': 1, 'msg': '200 - OK', 'ping': 193, - 'status': True, + 'status': , 'time': '2022-12-15 12:39:42.878' }, ... ] """ r = self._call('getMonitorBeats', (id_, hours))["data"] - int_to_bool(r, ["important", "status"]) + int_to_bool(r, ["important"]) + parse_monitor_status(r) return r def get_game_list(self) -> list[dict]: @@ -1945,7 +1962,7 @@ class UptimeKumaApi(object): 'monitor_id': 1, 'msg': 'connect ECONNREFUSED 127.0.0.1:80', 'ping': None, - 'status': False, + 'status': , 'time': '2022-12-15 16:51:41.782' }, { @@ -1956,7 +1973,7 @@ class UptimeKumaApi(object): 'monitor_id': 1, 'msg': 'connect ECONNREFUSED 127.0.0.1:80', 'ping': None, - 'status': False, + 'status': , 'time': '2022-12-15 16:52:41.799' }, ... @@ -1967,7 +1984,8 @@ class UptimeKumaApi(object): """ r = self._get_event_data(Event.HEARTBEAT_LIST) for i in r: - int_to_bool(i["data"], ["important", "status"]) + int_to_bool(i["data"], ["important"]) + parse_monitor_status(i["data"]) return r def get_important_heartbeats(self) -> list[dict]: @@ -1990,7 +2008,7 @@ class UptimeKumaApi(object): 'monitorID': 1, 'msg': 'connect ECONNREFUSED 127.0.0.1:80', 'ping': None, - 'status': False, + 'status': , 'time': '2022-12-15 16:51:41.782' } ], @@ -2000,7 +2018,8 @@ class UptimeKumaApi(object): """ r = self._get_event_data(Event.IMPORTANT_HEARTBEAT_LIST) for i in r: - int_to_bool(i["data"], ["important", "status"]) + int_to_bool(i["data"], ["important"]) + parse_monitor_status(i["data"]) return r def get_heartbeat(self) -> list[dict]: @@ -2019,13 +2038,14 @@ class UptimeKumaApi(object): 'important': False, 'monitorID': 1, 'msg': 'connect ECONNREFUSED 127.0.0.1:80', - 'status': False, + 'status': , 'time': '2022-12-15 17:17:42.099' } ] """ r = self._get_event_data(Event.HEARTBEAT) - int_to_bool(r, ["important", "status"]) + int_to_bool(r, ["important"]) + parse_monitor_status(r) return r # avg ping diff --git a/uptime_kuma_api/monitor_status.py b/uptime_kuma_api/monitor_status.py new file mode 100644 index 0000000..abf3d23 --- /dev/null +++ b/uptime_kuma_api/monitor_status.py @@ -0,0 +1,17 @@ +from enum import Enum + + +class MonitorStatus(int, Enum): + """Enumerate monitor statuses.""" + + DOWN = 0 + """DOWN""" + + UP = 1 + """UP""" + + PENDING = 2 + """PENDING""" + + MAINTENANCE = 3 + """MAINTENANCE""" From a9f2b6d894503fdcbb402353fb5aa76ec5eeb0df Mon Sep 17 00:00:00 2001 From: lucasheld Date: Tue, 2 May 2023 20:36:49 +0200 Subject: [PATCH 2/2] feat: implement `get_monitor_status` helper method --- uptime_kuma_api/api.py | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/uptime_kuma_api/api.py b/uptime_kuma_api/api.py index 4355de4..e35d739 100644 --- a/uptime_kuma_api/api.py +++ b/uptime_kuma_api/api.py @@ -3560,3 +3560,13 @@ class UptimeKumaApi(object): """ with self.wait_for_event(Event.API_KEY_LIST): return self._call('deleteAPIKey', id_) + + # helper methods + + def get_monitor_status(self, monitor_id: int) -> MonitorStatus: + heartbeats = self.get_heartbeats() + for heartbeat in heartbeats: + if int(heartbeat["id"]) == monitor_id: + status = heartbeat["data"][-1]["status"] + return MonitorStatus(status) + raise UptimeKumaException("monitor does not exist")