forked from DGNum/uptime-kuma-api
prepare pypi release and fix add monitor
This commit is contained in:
parent
b87a1bdaf0
commit
140784c4e0
13 changed files with 96 additions and 52 deletions
1
.gitignore
vendored
1
.gitignore
vendored
|
@ -3,3 +3,4 @@ venv
|
||||||
.envrc
|
.envrc
|
||||||
__pycache__
|
__pycache__
|
||||||
*.egg-info
|
*.egg-info
|
||||||
|
dist
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
import re
|
import re
|
||||||
import os
|
import os
|
||||||
|
|
||||||
from uptimekumaapi import notification_provider_options
|
from uptime_kuma_api import notification_provider_options
|
||||||
|
|
||||||
|
|
||||||
def build_notification_provider_map():
|
def build_notification_provider_map():
|
||||||
|
|
54
setup.py
54
setup.py
|
@ -1,12 +1,48 @@
|
||||||
from setuptools import setup, find_packages
|
from setuptools import setup
|
||||||
|
from codecs import open
|
||||||
|
import os
|
||||||
|
import sys
|
||||||
|
|
||||||
|
# "setup.py publish" shortcut.
|
||||||
|
if sys.argv[-1] == "publish":
|
||||||
|
os.system("rm dist/*")
|
||||||
|
os.system("python setup.py sdist")
|
||||||
|
os.system("twine upload --repository-url https://test.pypi.org/legacy/ dist/*")
|
||||||
|
sys.exit()
|
||||||
|
|
||||||
|
info = {}
|
||||||
|
here = os.path.abspath(os.path.dirname(__file__))
|
||||||
|
with open(os.path.join(here, "uptime_kuma_api", "__version__.py"), "r", "utf-8") as f:
|
||||||
|
exec(f.read(), info)
|
||||||
|
|
||||||
setup(
|
setup(
|
||||||
name="uptimekumaapi",
|
name=info["__title__"],
|
||||||
version="0.0.0",
|
version=info["__version__"],
|
||||||
packages=find_packages(),
|
description="A python wrapper for the Uptime Kuma WebSocket API",
|
||||||
install_requires=[
|
url="https://github.com/lucasheld/uptime-kuma-api",
|
||||||
"python-socketio==5.6.0",
|
author=info["__author__"],
|
||||||
"requests==2.28.1",
|
author_email="lucasheld@hotmail.de",
|
||||||
"websocket-client==1.3.3",
|
# license=info["__license__"],
|
||||||
],
|
packages=["uptime_kuma_api"],
|
||||||
|
python_requires=">=3.6, <4",
|
||||||
|
install_requires=["python-socketio", "requests", "websocket-client"],
|
||||||
|
classifiers=[
|
||||||
|
"Development Status :: 1 - Planning",
|
||||||
|
"Environment :: Web Environment",
|
||||||
|
"Intended Audience :: Developers",
|
||||||
|
# "License :: OSI Approved :: ",
|
||||||
|
"Natural Language :: English",
|
||||||
|
"Operating System :: OS Independent",
|
||||||
|
"Programming Language :: Python",
|
||||||
|
"Programming Language :: Python :: 3",
|
||||||
|
"Programming Language :: Python :: 3.6",
|
||||||
|
"Programming Language :: Python :: 3.7",
|
||||||
|
"Programming Language :: Python :: 3.8",
|
||||||
|
"Programming Language :: Python :: 3.9",
|
||||||
|
"Programming Language :: Python :: 3.10",
|
||||||
|
"Programming Language :: Python :: 3.11",
|
||||||
|
"Programming Language :: Python :: 3 :: Only",
|
||||||
|
"Topic :: Internet :: WWW/HTTP",
|
||||||
|
"Topic :: Software Development :: Libraries"
|
||||||
|
]
|
||||||
)
|
)
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
from .__version__ import __title__, __version__, __author__, __copyright__
|
||||||
from .auth_method import AuthMethod
|
from .auth_method import AuthMethod
|
||||||
from .monitor_type import MonitorType
|
from .monitor_type import MonitorType
|
||||||
from .notification_providers import NotificationType, notification_provider_options
|
from .notification_providers import NotificationType, notification_provider_options
|
5
uptime_kuma_api/__version__.py
Normal file
5
uptime_kuma_api/__version__.py
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
__title__ = "uptime_kuma_api"
|
||||||
|
__version__ = "0.0.3"
|
||||||
|
__author__ = "Lucas Held"
|
||||||
|
# __license__ = ""
|
||||||
|
__copyright__ = "Copyright 2022 Lucas Held"
|
|
@ -14,7 +14,7 @@ from . import convert_from_socket, convert_to_socket, params_map_monitor, params
|
||||||
from . import UptimeKumaException
|
from . import UptimeKumaException
|
||||||
|
|
||||||
|
|
||||||
def int_to_bool(data: list[dict] | dict, keys):
|
def int_to_bool(data, keys):
|
||||||
if type(data) == list:
|
if type(data) == list:
|
||||||
for d in data:
|
for d in data:
|
||||||
int_to_bool(d, keys)
|
int_to_bool(d, keys)
|
||||||
|
@ -102,55 +102,55 @@ def _build_monitor_data(
|
||||||
"keyword": keyword,
|
"keyword": keyword,
|
||||||
})
|
})
|
||||||
|
|
||||||
if type_ in [MonitorType.HTTP, MonitorType.KEYWORD]:
|
# if type_ in [MonitorType.HTTP, MonitorType.KEYWORD]:
|
||||||
|
data.update({
|
||||||
|
"url": url,
|
||||||
|
"certificate_expiry_notification": certificate_expiry_notification,
|
||||||
|
"ignore_tls_error": ignore_tls_error,
|
||||||
|
"max_redirects": max_redirects,
|
||||||
|
"accepted_status_codes": accepted_status_codes,
|
||||||
|
"proxy_id": proxy_id,
|
||||||
|
"http_method": http_method,
|
||||||
|
"http_body": http_body,
|
||||||
|
"http_headers": http_headers,
|
||||||
|
"auth_method": auth_method,
|
||||||
|
})
|
||||||
|
|
||||||
|
if auth_method in [AuthMethod.HTTP_BASIC, AuthMethod.NTLM]:
|
||||||
data.update({
|
data.update({
|
||||||
"url": url,
|
"auth_user": auth_user,
|
||||||
"certificate_expiry_notification": certificate_expiry_notification,
|
"auth_pass": auth_pass,
|
||||||
"ignore_tls_error": ignore_tls_error,
|
|
||||||
"max_redirects": max_redirects,
|
|
||||||
"accepted_status_codes": accepted_status_codes,
|
|
||||||
"proxy_id": proxy_id,
|
|
||||||
"http_method": http_method,
|
|
||||||
"http_body": http_body,
|
|
||||||
"http_headers": http_headers,
|
|
||||||
"auth_method": auth_method,
|
|
||||||
})
|
})
|
||||||
|
|
||||||
if auth_method in [AuthMethod.HTTP_BASIC, AuthMethod.NTLM]:
|
if auth_method == AuthMethod.NTLM:
|
||||||
data.update({
|
|
||||||
"auth_user": auth_user,
|
|
||||||
"auth_pass": auth_pass,
|
|
||||||
})
|
|
||||||
|
|
||||||
if auth_method == AuthMethod.NTLM:
|
|
||||||
data.update({
|
|
||||||
"auth_domain": auth_domain,
|
|
||||||
"auth_workstation": auth_workstation,
|
|
||||||
})
|
|
||||||
|
|
||||||
if type_ in [MonitorType.DNS, MonitorType.PING, MonitorType.STEAM, MonitorType.MQTT]:
|
|
||||||
data.update({
|
data.update({
|
||||||
"hostname": hostname,
|
"auth_domain": auth_domain,
|
||||||
|
"auth_workstation": auth_workstation,
|
||||||
})
|
})
|
||||||
|
|
||||||
|
# if type_ in [MonitorType.DNS, MonitorType.PING, MonitorType.STEAM, MonitorType.MQTT]:
|
||||||
|
data.update({
|
||||||
|
"hostname": hostname,
|
||||||
|
})
|
||||||
|
|
||||||
if type_ in [MonitorType.DNS, MonitorType.STEAM, MonitorType.MQTT]:
|
if type_ in [MonitorType.DNS, MonitorType.STEAM, MonitorType.MQTT]:
|
||||||
data.update({
|
data.update({
|
||||||
"port": port,
|
"port": port,
|
||||||
})
|
})
|
||||||
|
|
||||||
if type_ == MonitorType.DNS:
|
# if type_ == MonitorType.DNS:
|
||||||
data.update({
|
data.update({
|
||||||
"dns_resolve_server": dns_resolve_server,
|
"dns_resolve_server": dns_resolve_server,
|
||||||
"dns_resolve_type": dns_resolve_type,
|
"dns_resolve_type": dns_resolve_type,
|
||||||
})
|
})
|
||||||
|
|
||||||
if type_ == MonitorType.MQTT:
|
# if type_ == MonitorType.MQTT:
|
||||||
data.update({
|
data.update({
|
||||||
"mqtt_username": mqtt_username,
|
"mqtt_username": mqtt_username,
|
||||||
"mqtt_password": mqtt_password,
|
"mqtt_password": mqtt_password,
|
||||||
"mqtt_topic": mqtt_topic,
|
"mqtt_topic": mqtt_topic,
|
||||||
"mqtt_success_message": mqtt_success_message,
|
"mqtt_success_message": mqtt_success_message,
|
||||||
})
|
})
|
||||||
|
|
||||||
if type_ == MonitorType.SQLSERVER:
|
if type_ == MonitorType.SQLSERVER:
|
||||||
data.update({
|
data.update({
|
||||||
|
@ -286,9 +286,10 @@ class UptimeKumaApi(object):
|
||||||
|
|
||||||
def _call(self, event, data=None):
|
def _call(self, event, data=None):
|
||||||
r = self.sio.call(event, data)
|
r = self.sio.call(event, data)
|
||||||
if type(r) == dict and not r["ok"]:
|
if type(r) == dict and "ok" in r:
|
||||||
raise UptimeKumaException(r["msg"])
|
if not r["ok"]:
|
||||||
r.pop("ok")
|
raise UptimeKumaException(r["msg"])
|
||||||
|
r.pop("ok")
|
||||||
return r
|
return r
|
||||||
|
|
||||||
# event handlers
|
# event handlers
|
|
@ -207,7 +207,7 @@ params_map_settings = {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
def _convert_to_from_socket(params_map: dict[str, str], params: list[dict] | dict | str, to_socket=False):
|
def _convert_to_from_socket(params_map: dict[str, str], params, to_socket=False):
|
||||||
if type(params) == list:
|
if type(params) == list:
|
||||||
out = []
|
out = []
|
||||||
params_list = params
|
params_list = params
|
Loading…
Reference in a new issue