forked from DGNum/uptime-kuma-api
fix: update event list data after changes
This commit is contained in:
parent
fee0a1dd8e
commit
06fa29cd41
7 changed files with 115 additions and 29 deletions
|
@ -13,6 +13,9 @@ class TestDockerHost(UptimeKumaTestCase):
|
||||||
self.skipTest("Unsupported in this Uptime Kuma version")
|
self.skipTest("Unsupported in this Uptime Kuma version")
|
||||||
|
|
||||||
def test_docker_host(self):
|
def test_docker_host(self):
|
||||||
|
# get empty list to make sure that future accesses will also work
|
||||||
|
self.api.get_docker_hosts()
|
||||||
|
|
||||||
expected_docker_host = {
|
expected_docker_host = {
|
||||||
"name": "name 1",
|
"name": "name 1",
|
||||||
"dockerType": DockerType.SOCKET,
|
"dockerType": DockerType.SOCKET,
|
||||||
|
|
|
@ -7,6 +7,9 @@ from uptime_kuma_test_case import UptimeKumaTestCase
|
||||||
|
|
||||||
class TestMonitor(UptimeKumaTestCase):
|
class TestMonitor(UptimeKumaTestCase):
|
||||||
def test_monitor(self):
|
def test_monitor(self):
|
||||||
|
# get empty list to make sure that future accesses will also work
|
||||||
|
self.api.get_monitors()
|
||||||
|
|
||||||
notification_id_1 = self.add_notification()
|
notification_id_1 = self.add_notification()
|
||||||
notification_id_2 = self.add_notification()
|
notification_id_2 = self.add_notification()
|
||||||
|
|
||||||
|
@ -75,6 +78,9 @@ class TestMonitor(UptimeKumaTestCase):
|
||||||
monitor = self.api.get_monitor(monitor_id)
|
monitor = self.api.get_monitor(monitor_id)
|
||||||
self.compare(monitor, expected_monitor)
|
self.compare(monitor, expected_monitor)
|
||||||
|
|
||||||
|
expected_monitor.update({
|
||||||
|
"name": "monitor 2"
|
||||||
|
})
|
||||||
r = self.api.edit_monitor(monitor_id, **expected_monitor)
|
r = self.api.edit_monitor(monitor_id, **expected_monitor)
|
||||||
self.assertEqual(r["msg"], "Saved.")
|
self.assertEqual(r["msg"], "Saved.")
|
||||||
monitor = self.api.get_monitor(monitor_id)
|
monitor = self.api.get_monitor(monitor_id)
|
||||||
|
|
|
@ -18,10 +18,20 @@ class TestMonitorTag(UptimeKumaTestCase):
|
||||||
r = self.api.add_monitor_tag(**expected_monitor_tag)
|
r = self.api.add_monitor_tag(**expected_monitor_tag)
|
||||||
self.assertEqual(r["msg"], "Added Successfully.")
|
self.assertEqual(r["msg"], "Added Successfully.")
|
||||||
|
|
||||||
|
# check if tag is listed in monitor tags
|
||||||
|
monitors = self.api.get_monitors()
|
||||||
|
monitor = self.find_by_id(monitors, monitor_id)
|
||||||
|
self.assertEqual(monitor["tags"][0]["tag_id"], tag_id)
|
||||||
|
|
||||||
# delete monitor tag
|
# delete monitor tag
|
||||||
r = self.api.delete_monitor_tag(**expected_monitor_tag)
|
r = self.api.delete_monitor_tag(**expected_monitor_tag)
|
||||||
self.assertEqual(r["msg"], "Deleted Successfully.")
|
self.assertEqual(r["msg"], "Deleted Successfully.")
|
||||||
|
|
||||||
|
# check if tag is not listed in monitor tags
|
||||||
|
monitors = self.api.get_monitors()
|
||||||
|
monitor = self.find_by_id(monitors, monitor_id)
|
||||||
|
self.assertEqual(monitor["tags"], [])
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
unittest.main()
|
unittest.main()
|
||||||
|
|
|
@ -6,6 +6,9 @@ from uptime_kuma_test_case import UptimeKumaTestCase
|
||||||
|
|
||||||
class TestNotification(UptimeKumaTestCase):
|
class TestNotification(UptimeKumaTestCase):
|
||||||
def test_notification(self):
|
def test_notification(self):
|
||||||
|
# get empty list to make sure that future accesses will also work
|
||||||
|
self.api.get_notifications()
|
||||||
|
|
||||||
expected_notification = {
|
expected_notification = {
|
||||||
"name": "notification 1",
|
"name": "notification 1",
|
||||||
"isDefault": True,
|
"isDefault": True,
|
||||||
|
|
|
@ -6,6 +6,9 @@ from uptime_kuma_test_case import UptimeKumaTestCase
|
||||||
|
|
||||||
class TestProxy(UptimeKumaTestCase):
|
class TestProxy(UptimeKumaTestCase):
|
||||||
def test_proxy(self):
|
def test_proxy(self):
|
||||||
|
# get empty list to make sure that future accesses will also work
|
||||||
|
self.api.get_proxies()
|
||||||
|
|
||||||
expected_proxy = {
|
expected_proxy = {
|
||||||
"protocol": ProxyProtocol.HTTP,
|
"protocol": ProxyProtocol.HTTP,
|
||||||
"host": "127.0.0.1",
|
"host": "127.0.0.1",
|
||||||
|
|
|
@ -6,6 +6,9 @@ from uptime_kuma_test_case import UptimeKumaTestCase
|
||||||
|
|
||||||
class TestStatusPage(UptimeKumaTestCase):
|
class TestStatusPage(UptimeKumaTestCase):
|
||||||
def test_status_page(self):
|
def test_status_page(self):
|
||||||
|
# get empty list to make sure that future accesses will also work
|
||||||
|
self.api.get_status_pages()
|
||||||
|
|
||||||
monitor_id = self.add_monitor()
|
monitor_id = self.add_monitor()
|
||||||
|
|
||||||
slug = "slug1"
|
slug = "slug1"
|
||||||
|
@ -81,6 +84,10 @@ class TestStatusPage(UptimeKumaTestCase):
|
||||||
with self.assertRaises(UptimeKumaException):
|
with self.assertRaises(UptimeKumaException):
|
||||||
self.api.get_status_page(slug)
|
self.api.get_status_page(slug)
|
||||||
|
|
||||||
|
status_pages = self.api.get_status_pages()
|
||||||
|
status_page = self.find_by_id(status_pages, slug, "slug")
|
||||||
|
self.assertIsNone(status_page)
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
unittest.main()
|
unittest.main()
|
||||||
|
|
|
@ -1,19 +1,21 @@
|
||||||
import json
|
import json
|
||||||
import time
|
|
||||||
import string
|
|
||||||
import random
|
import random
|
||||||
|
import string
|
||||||
|
import time
|
||||||
|
from contextlib import contextmanager
|
||||||
|
from copy import deepcopy
|
||||||
|
|
||||||
import requests
|
import requests
|
||||||
import socketio
|
import socketio
|
||||||
from packaging.version import parse as parse_version
|
from packaging.version import parse as parse_version
|
||||||
|
|
||||||
from . import AuthMethod
|
from . import AuthMethod
|
||||||
|
from . import DockerType
|
||||||
|
from . import Event
|
||||||
|
from . import IncidentStyle
|
||||||
from . import MonitorType
|
from . import MonitorType
|
||||||
from . import NotificationType, notification_provider_options, notification_provider_conditions
|
from . import NotificationType, notification_provider_options, notification_provider_conditions
|
||||||
from . import ProxyProtocol
|
from . import ProxyProtocol
|
||||||
from . import IncidentStyle
|
|
||||||
from . import DockerType
|
|
||||||
from . import Event
|
|
||||||
from . import UptimeKumaException
|
from . import UptimeKumaException
|
||||||
|
|
||||||
|
|
||||||
|
@ -305,6 +307,24 @@ class UptimeKumaApi(object):
|
||||||
|
|
||||||
self.connect()
|
self.connect()
|
||||||
|
|
||||||
|
@contextmanager
|
||||||
|
def wait_for_event(self, event: Event):
|
||||||
|
retries = 200
|
||||||
|
event_data_before = deepcopy(self._event_data)
|
||||||
|
|
||||||
|
try:
|
||||||
|
yield
|
||||||
|
except:
|
||||||
|
raise
|
||||||
|
else:
|
||||||
|
counter = 0
|
||||||
|
while event_data_before[event] == self._event_data[event]:
|
||||||
|
time.sleep(0.01)
|
||||||
|
counter += 1
|
||||||
|
if counter >= retries:
|
||||||
|
print("wait_for_event timeout")
|
||||||
|
break
|
||||||
|
|
||||||
def _get_event_data(self, event):
|
def _get_event_data(self, event):
|
||||||
monitor_events = [Event.AVG_PING, Event.UPTIME, Event.HEARTBEAT_LIST, Event.IMPORTANT_HEARTBEAT_LIST, Event.CERT_INFO, Event.HEARTBEAT]
|
monitor_events = [Event.AVG_PING, Event.UPTIME, Event.HEARTBEAT_LIST, Event.IMPORTANT_HEARTBEAT_LIST, Event.CERT_INFO, Event.HEARTBEAT]
|
||||||
while self._event_data[event] is None:
|
while self._event_data[event] is None:
|
||||||
|
@ -313,7 +333,7 @@ class UptimeKumaApi(object):
|
||||||
return []
|
return []
|
||||||
time.sleep(0.01)
|
time.sleep(0.01)
|
||||||
time.sleep(0.05) # wait for multiple messages
|
time.sleep(0.05) # wait for multiple messages
|
||||||
return self._event_data[event]
|
return deepcopy(self._event_data[event])
|
||||||
|
|
||||||
def _call(self, event, data=None):
|
def _call(self, event, data=None):
|
||||||
r = self.sio.call(event, data)
|
r = self.sio.call(event, data)
|
||||||
|
@ -578,7 +598,7 @@ class UptimeKumaApi(object):
|
||||||
|
|
||||||
return data
|
return data
|
||||||
|
|
||||||
# monitors
|
# monitor
|
||||||
|
|
||||||
def get_monitors(self):
|
def get_monitors(self):
|
||||||
r = list(self._get_event_data(Event.MONITOR_LIST).values())
|
r = list(self._get_event_data(Event.MONITOR_LIST).values())
|
||||||
|
@ -600,7 +620,8 @@ class UptimeKumaApi(object):
|
||||||
return self._call('resumeMonitor', id_)
|
return self._call('resumeMonitor', id_)
|
||||||
|
|
||||||
def delete_monitor(self, id_: int):
|
def delete_monitor(self, id_: int):
|
||||||
return self._call('deleteMonitor', id_)
|
with self.wait_for_event(Event.MONITOR_LIST):
|
||||||
|
return self._call('deleteMonitor', id_)
|
||||||
|
|
||||||
def get_monitor_beats(self, id_: int, hours: int):
|
def get_monitor_beats(self, id_: int, hours: int):
|
||||||
r = self._call('getMonitorBeats', (id_, hours))["data"]
|
r = self._call('getMonitorBeats', (id_, hours))["data"]
|
||||||
|
@ -611,30 +632,36 @@ class UptimeKumaApi(object):
|
||||||
data = self._build_monitor_data(**kwargs)
|
data = self._build_monitor_data(**kwargs)
|
||||||
_convert_monitor_input(data)
|
_convert_monitor_input(data)
|
||||||
_check_arguments_monitor(data)
|
_check_arguments_monitor(data)
|
||||||
r = self._call('add', data)
|
with self.wait_for_event(Event.MONITOR_LIST):
|
||||||
return r
|
return self._call('add', data)
|
||||||
|
|
||||||
def edit_monitor(self, id_: int, **kwargs):
|
def edit_monitor(self, id_: int, **kwargs):
|
||||||
data = self.get_monitor(id_)
|
data = self.get_monitor(id_)
|
||||||
data.update(kwargs)
|
data.update(kwargs)
|
||||||
_convert_monitor_input(data)
|
_convert_monitor_input(data)
|
||||||
_check_arguments_monitor(data)
|
_check_arguments_monitor(data)
|
||||||
r = self._call('editMonitor', data)
|
with self.wait_for_event(Event.MONITOR_LIST):
|
||||||
return r
|
return self._call('editMonitor', data)
|
||||||
|
|
||||||
# monitor tags
|
# monitor tags
|
||||||
|
|
||||||
def add_monitor_tag(self, tag_id: int, monitor_id: int, value=""):
|
def add_monitor_tag(self, tag_id: int, monitor_id: int, value=""):
|
||||||
return self._call('addMonitorTag', (tag_id, monitor_id, value))
|
r = self._call('addMonitorTag', (tag_id, monitor_id, value))
|
||||||
|
# the monitor list event does not send the updated tags
|
||||||
|
self._event_data[Event.MONITOR_LIST][str(monitor_id)] = self.get_monitor(monitor_id)
|
||||||
|
return r
|
||||||
|
|
||||||
# editMonitorTag is unused in uptime-kuma
|
# editMonitorTag is unused in uptime-kuma
|
||||||
# def edit_monitor_tag(self, tag_id: int, monitor_id: int, value=""):
|
# def edit_monitor_tag(self, tag_id: int, monitor_id: int, value=""):
|
||||||
# return self._call('editMonitorTag', (tag_id, monitor_id, value))
|
# return self._call('editMonitorTag', (tag_id, monitor_id, value))
|
||||||
|
|
||||||
def delete_monitor_tag(self, tag_id: int, monitor_id: int, value=""):
|
def delete_monitor_tag(self, tag_id: int, monitor_id: int, value=""):
|
||||||
return self._call('deleteMonitorTag', (tag_id, monitor_id, value))
|
r = self._call('deleteMonitorTag', (tag_id, monitor_id, value))
|
||||||
|
# the monitor list event does not send the updated tags
|
||||||
|
self._event_data[Event.MONITOR_LIST][str(monitor_id)] = self.get_monitor(monitor_id)
|
||||||
|
return r
|
||||||
|
|
||||||
# notifications
|
# notification
|
||||||
|
|
||||||
def get_notifications(self):
|
def get_notifications(self):
|
||||||
notifications = self._get_event_data(Event.NOTIFICATION_LIST)
|
notifications = self._get_event_data(Event.NOTIFICATION_LIST)
|
||||||
|
@ -664,7 +691,8 @@ class UptimeKumaApi(object):
|
||||||
data = _build_notification_data(**kwargs)
|
data = _build_notification_data(**kwargs)
|
||||||
|
|
||||||
_check_arguments_notification(data)
|
_check_arguments_notification(data)
|
||||||
return self._call('addNotification', (data, None))
|
with self.wait_for_event(Event.NOTIFICATION_LIST):
|
||||||
|
return self._call('addNotification', (data, None))
|
||||||
|
|
||||||
def edit_notification(self, id_: int, **kwargs):
|
def edit_notification(self, id_: int, **kwargs):
|
||||||
notification = self.get_notification(id_)
|
notification = self.get_notification(id_)
|
||||||
|
@ -680,10 +708,12 @@ class UptimeKumaApi(object):
|
||||||
|
|
||||||
notification.update(kwargs)
|
notification.update(kwargs)
|
||||||
_check_arguments_notification(notification)
|
_check_arguments_notification(notification)
|
||||||
return self._call('addNotification', (notification, id_))
|
with self.wait_for_event(Event.NOTIFICATION_LIST):
|
||||||
|
return self._call('addNotification', (notification, id_))
|
||||||
|
|
||||||
def delete_notification(self, id_: int):
|
def delete_notification(self, id_: int):
|
||||||
return self._call('deleteNotification', id_)
|
with self.wait_for_event(Event.NOTIFICATION_LIST):
|
||||||
|
return self._call('deleteNotification', id_)
|
||||||
|
|
||||||
def check_apprise(self):
|
def check_apprise(self):
|
||||||
return self._call('checkApprise')
|
return self._call('checkApprise')
|
||||||
|
@ -706,22 +736,24 @@ class UptimeKumaApi(object):
|
||||||
data = _build_proxy_data(**kwargs)
|
data = _build_proxy_data(**kwargs)
|
||||||
|
|
||||||
_check_arguments_proxy(data)
|
_check_arguments_proxy(data)
|
||||||
return self._call('addProxy', (data, None))
|
with self.wait_for_event(Event.PROXY_LIST):
|
||||||
|
return self._call('addProxy', (data, None))
|
||||||
|
|
||||||
def edit_proxy(self, id_: int, **kwargs):
|
def edit_proxy(self, id_: int, **kwargs):
|
||||||
proxy = self.get_proxy(id_)
|
proxy = self.get_proxy(id_)
|
||||||
proxy.update(kwargs)
|
proxy.update(kwargs)
|
||||||
_check_arguments_proxy(proxy)
|
_check_arguments_proxy(proxy)
|
||||||
return self._call('addProxy', (proxy, id_))
|
with self.wait_for_event(Event.PROXY_LIST):
|
||||||
|
return self._call('addProxy', (proxy, id_))
|
||||||
|
|
||||||
def delete_proxy(self, id_: int):
|
def delete_proxy(self, id_: int):
|
||||||
return self._call('deleteProxy', id_)
|
with self.wait_for_event(Event.PROXY_LIST):
|
||||||
|
return self._call('deleteProxy', id_)
|
||||||
|
|
||||||
# status page
|
# status page
|
||||||
|
|
||||||
def get_status_pages(self):
|
def get_status_pages(self):
|
||||||
r = list(self._get_event_data(Event.STATUS_PAGE_LIST).values())
|
return list(self._get_event_data(Event.STATUS_PAGE_LIST).values())
|
||||||
return r
|
|
||||||
|
|
||||||
def get_status_page(self, slug: str):
|
def get_status_page(self, slug: str):
|
||||||
r1 = self._call('getStatusPage', slug)
|
r1 = self._call('getStatusPage', slug)
|
||||||
|
@ -736,17 +768,36 @@ class UptimeKumaApi(object):
|
||||||
}
|
}
|
||||||
|
|
||||||
def add_status_page(self, slug: str, title: str):
|
def add_status_page(self, slug: str, title: str):
|
||||||
return self._call('addStatusPage', (title, slug))
|
with self.wait_for_event(Event.STATUS_PAGE_LIST):
|
||||||
|
return self._call('addStatusPage', (title, slug))
|
||||||
|
|
||||||
def delete_status_page(self, slug: str):
|
def delete_status_page(self, slug: str):
|
||||||
return self._call('deleteStatusPage', slug)
|
r = self._call('deleteStatusPage', slug)
|
||||||
|
|
||||||
|
# uptime kuma does not send the status page list event when a status page is deleted
|
||||||
|
for status_page in self._event_data[Event.STATUS_PAGE_LIST].values():
|
||||||
|
if status_page["slug"] == slug:
|
||||||
|
status_page_id = status_page["id"]
|
||||||
|
del self._event_data[Event.STATUS_PAGE_LIST][str(status_page_id)]
|
||||||
|
break
|
||||||
|
|
||||||
|
return r
|
||||||
|
|
||||||
def save_status_page(self, slug: str, **kwargs):
|
def save_status_page(self, slug: str, **kwargs):
|
||||||
status_page = self.get_status_page(slug)
|
status_page = self.get_status_page(slug)
|
||||||
status_page.pop("incident")
|
status_page.pop("incident")
|
||||||
status_page.update(kwargs)
|
status_page.update(kwargs)
|
||||||
data = _build_status_page_data(**status_page)
|
data = _build_status_page_data(**status_page)
|
||||||
return self._call('saveStatusPage', data)
|
r = self._call('saveStatusPage', data)
|
||||||
|
|
||||||
|
# uptime kuma does not send the status page list event when a status page is saved
|
||||||
|
status_page = self._call('getStatusPage', slug)["config"]
|
||||||
|
status_page_id = status_page["id"]
|
||||||
|
if self._event_data[Event.STATUS_PAGE_LIST] is None:
|
||||||
|
self._event_data[Event.STATUS_PAGE_LIST] = {}
|
||||||
|
self._event_data[Event.STATUS_PAGE_LIST][str(status_page_id)] = status_page
|
||||||
|
|
||||||
|
return r
|
||||||
|
|
||||||
def post_incident(
|
def post_incident(
|
||||||
self,
|
self,
|
||||||
|
@ -990,13 +1041,16 @@ class UptimeKumaApi(object):
|
||||||
def add_docker_host(self, **kwargs):
|
def add_docker_host(self, **kwargs):
|
||||||
data = _build_docker_host_data(**kwargs)
|
data = _build_docker_host_data(**kwargs)
|
||||||
_convert_docker_host_input(data)
|
_convert_docker_host_input(data)
|
||||||
return self._call('addDockerHost', (data, None))
|
with self.wait_for_event(Event.DOCKER_HOST_LIST):
|
||||||
|
return self._call('addDockerHost', (data, None))
|
||||||
|
|
||||||
def edit_docker_host(self, id_: int, **kwargs):
|
def edit_docker_host(self, id_: int, **kwargs):
|
||||||
data = self.get_docker_host(id_)
|
data = self.get_docker_host(id_)
|
||||||
data.update(kwargs)
|
data.update(kwargs)
|
||||||
_convert_docker_host_input(data)
|
_convert_docker_host_input(data)
|
||||||
return self._call('addDockerHost', (data, id_))
|
with self.wait_for_event(Event.DOCKER_HOST_LIST):
|
||||||
|
return self._call('addDockerHost', (data, id_))
|
||||||
|
|
||||||
def delete_docker_host(self, id_: int):
|
def delete_docker_host(self, id_: int):
|
||||||
return self._call('deleteDockerHost', id_)
|
with self.wait_for_event(Event.DOCKER_HOST_LIST):
|
||||||
|
return self._call('deleteDockerHost', id_)
|
||||||
|
|
Loading…
Reference in a new issue