update scripts

This commit is contained in:
lucasheld 2022-09-07 13:04:16 +02:00
parent a7f571f508
commit 384fd21726
12 changed files with 231 additions and 113 deletions

78
scripts/build_inputs.py Normal file
View file

@ -0,0 +1,78 @@
import glob
import re
from utils import deduplicate_list, parse_vue_template
def parse_model_keys(content, object_name):
match = re.findall(object_name + r"\.[0-9a-zA-Z_$]+", content)
keys = []
for m in match:
key = m.replace(object_name + ".", "")
keys.append(key)
keys = deduplicate_list(keys)
return keys
def parse_proxy_keys():
content = parse_vue_template("uptime-kuma/src/components/ProxyDialog.vue")
keys = parse_model_keys(content, "proxy")
return keys
def parse_notification_keys():
content = parse_vue_template("uptime-kuma/src/components/NotificationDialog.vue")
keys = parse_model_keys(content, "notification")
return keys
def parse_settings_keys():
all_keys = []
for path in glob.glob('uptime-kuma/src/components/settings/*'):
content = parse_vue_template(path)
keys = parse_model_keys(content, "settings")
all_keys.extend(keys)
all_keys = deduplicate_list(all_keys)
return all_keys
def parse_monitor_keys():
content = parse_vue_template("uptime-kuma/src/pages/EditMonitor.vue")
keys = parse_model_keys(content, "monitor")
return keys
def parse_status_page_keys():
all_keys = ["id"]
content = parse_vue_template("uptime-kuma/src/pages/StatusPage.vue")
keys = parse_model_keys(content, "config")
all_keys.extend(keys)
content = parse_vue_template("uptime-kuma/src/pages/ManageStatusPage.vue")
keys = parse_model_keys(content, "statusPage")
all_keys.extend(keys)
all_keys = deduplicate_list(all_keys)
return all_keys
def main():
proxy_keys = parse_proxy_keys()
print("proxy:", proxy_keys)
notification_keys = parse_notification_keys()
print("notification:", notification_keys)
settings_keys = parse_settings_keys()
print("settings:", settings_keys)
monitor_keys = parse_monitor_keys()
print("monitor:", monitor_keys)
status_page_keys = parse_status_page_keys()
print("status_page:", status_page_keys)
if __name__ == "__main__":
main()

View file

@ -1,8 +1,10 @@
import re import re
from pprint import pprint from pprint import pprint
from utils import deduplicate_list
def parse_data_keys(data):
def parse_json_keys(data):
keys = [] keys = []
for line in data.split("\n"): for line in data.split("\n"):
line = line.strip() line = line.strip()
@ -17,19 +19,28 @@ def parse_data_keys(data):
return keys return keys
# def parse_object_keys(code, object_name):
# match = re.findall(object_name + r'\.[0-9a-zA-Z_$]+', code)
# keys = []
# for m in match:
# key = m.replace(object_name + ".", "")
# keys.append(key)
# return list(set(keys))
def parse_heartbeat(): def parse_heartbeat():
with open('uptime-kuma/server/model/heartbeat.js') as f: with open('uptime-kuma/server/model/heartbeat.js') as f:
content = f.read() content = f.read()
all_keys = [] all_keys = []
match = re.search(r'toJSON\(\) {\s+return.*{([^}]+)}', content) match = re.search(r'toJSON\(\) {\s+return.*{([^}]+)}', content)
data = match.group(1) data = match.group(1)
keys = parse_data_keys(data) keys = parse_json_keys(data)
all_keys.extend(keys) all_keys.extend(keys)
match = re.search(r'toPublicJSON\(\) {\s+return.*{([^}]+)}', content) match = re.search(r'toPublicJSON\(\) {\s+return.*{([^}]+)}', content)
data = match.group(1) data = match.group(1)
keys = parse_data_keys(data) keys = parse_json_keys(data)
all_keys.extend(keys) all_keys.extend(keys)
all_keys = list(set(all_keys)) all_keys = deduplicate_list(all_keys)
return all_keys return all_keys
@ -38,7 +49,7 @@ def parse_incident():
content = f.read() content = f.read()
match = re.search(r'toPublicJSON\(\) {\s+return.*{([^}]+)}', content) match = re.search(r'toPublicJSON\(\) {\s+return.*{([^}]+)}', content)
data = match.group(1) data = match.group(1)
keys = parse_data_keys(data) keys = parse_json_keys(data)
return keys return keys
@ -49,9 +60,10 @@ def parse_monitor():
matches = re.findall(r'data = {([^}]+)}', content) matches = re.findall(r'data = {([^}]+)}', content)
all_keys = [] all_keys = []
for match in matches: for match in matches:
keys = parse_data_keys(match) keys = parse_json_keys(match)
keys = [i for i in keys if i != "...data"] keys = [i for i in keys if i != "...data"]
all_keys.extend(keys) all_keys.extend(keys)
all_keys = deduplicate_list(all_keys)
return all_keys return all_keys
@ -60,23 +72,54 @@ def parse_proxy():
content = f.read() content = f.read()
match = re.search(r'toJSON\(\) {\s+return.*{([^}]+)}', content) match = re.search(r'toJSON\(\) {\s+return.*{([^}]+)}', content)
data = match.group(1) data = match.group(1)
keys = parse_data_keys(data) keys = parse_json_keys(data)
return keys return keys
# def parse_function(regex_name, content):
# match = re.search(regex_name, content)
# name = match.group(0)
# rest = "".join(content.split(name)[1:])
#
# brackets = 0
# opening_bracket_found = False
# code = ""
# for i in rest:
# code += i
# if i == "{":
# opening_bracket_found = True
# brackets += 1
# if i == "}":
# opening_bracket_found = True
# brackets -= 1
# if opening_bracket_found and brackets == 0:
# break
# return code
# # input (add, edit proxy)
# def parse_proxy2():
# with open('uptime-kuma/server/proxy.js') as f:
# content = f.read()
#
# code = parse_function(r'async save\([^)]+\) ', content)
# keys = parse_object_keys(code, "proxy")
# return keys
def parse_status_page(): def parse_status_page():
with open('uptime-kuma/server/model/status_page.js') as f: with open('uptime-kuma/server/model/status_page.js') as f:
content = f.read() content = f.read()
all_keys = [] all_keys = []
match = re.search(r'toJSON\(\) {\s+return.*{([^}]+)}', content) match = re.search(r'toJSON\(\) {\s+return.*{([^}]+)}', content)
data = match.group(1) data = match.group(1)
keys = parse_data_keys(data) keys = parse_json_keys(data)
all_keys.extend(keys) all_keys.extend(keys)
match = re.search(r'toPublicJSON\(\) {\s+return.*{([^}]+)}', content) match = re.search(r'toPublicJSON\(\) {\s+return.*{([^}]+)}', content)
data = match.group(1) data = match.group(1)
keys = parse_data_keys(data) keys = parse_json_keys(data)
all_keys.extend(keys) all_keys.extend(keys)
all_keys = list(set(all_keys)) all_keys = deduplicate_list(all_keys)
return all_keys return all_keys
@ -85,16 +128,37 @@ def parse_tag():
content = f.read() content = f.read()
match = re.search(r'toJSON\(\) {\s+return.*{([^}]+)}', content) match = re.search(r'toJSON\(\) {\s+return.*{([^}]+)}', content)
data = match.group(1) data = match.group(1)
keys = parse_data_keys(data) keys = parse_json_keys(data)
return keys return keys
print("heartbeat")
pprint(parse_heartbeat()) pprint(parse_heartbeat())
print("")
print("incident")
pprint(parse_incident()) pprint(parse_incident())
print("")
print("monitor")
pprint(parse_monitor()) pprint(parse_monitor())
print("")
print("proxy")
pprint(parse_proxy()) pprint(parse_proxy())
print("")
# print("prox2")
# pprint(parse_proxy2())
# print("")
print("status page")
pprint(parse_status_page()) pprint(parse_status_page())
print("")
print("tag")
pprint(parse_tag()) pprint(parse_tag())
print("")
# TODO: # TODO:

View file

@ -0,0 +1,25 @@
from bs4 import BeautifulSoup
from utils import parse_vue_template, write_to_file
def parse_monitor_types():
content = parse_vue_template("uptime-kuma/src/pages/EditMonitor.vue")
soup = BeautifulSoup(content, "html.parser")
select = soup.find("select", id="type")
options = select.find_all("option")
types = []
for o in options:
type_ = o.attrs["value"]
types.append(type_)
return types
monitor_types = parse_monitor_types()
write_to_file(
"monitor_type.py.j2", "./../uptime_kuma_api/monitor_type.py",
monitor_types=monitor_types
)

View file

@ -1,18 +0,0 @@
from uptime_kuma_api import notification_provider_options
def build_providers():
providers = []
for provider_enum in notification_provider_options:
provider = provider_enum.__dict__["_value_"]
providers.append(provider)
return providers
for provider in build_providers():
options = notification_provider_options[provider]
for option in options:
print(f'{option}:')
print(f' description: {provider} provider option.')
print(f' returned: if type is {provider}')
print(' type: str')

View file

@ -1,19 +1,9 @@
import glob import glob
import re import re
from pprint import pprint
import jinja2
from bs4 import BeautifulSoup from bs4 import BeautifulSoup
from uptime_kuma_api import convert_from_socket, params_map_notification_provider_options from utils import deduplicate_list, write_to_file
def deduplicate_list(l):
out = []
for i in l:
if i not in out:
out.append(i)
return out
def build_notification_providers(): def build_notification_providers():
@ -61,18 +51,14 @@ def build_notification_provider_conditions():
param_name = re.match(r'\$parent.notification.(.*)$', v_model).group(1) param_name = re.match(r'\$parent.notification.(.*)$', v_model).group(1)
if condition: if condition:
conditions[param_name] = condition conditions[param_name] = condition
conditions = convert_from_socket(params_map_notification_provider_options, conditions)
return conditions return conditions
def write_to_file(template, destination, **kwargs): notification_providers = build_notification_providers()
env = jinja2.Environment(loader=jinja2.FileSystemLoader("./")) notification_provider_conditions = build_notification_provider_conditions()
template = env.get_template(template)
rendered = template.render(**kwargs)
with open(destination, "w") as f:
f.write(rendered)
conditions = build_notification_provider_conditions() write_to_file(
pprint(conditions) "notification_providers.py.j2", "./../uptime_kuma_api/notification_providers.py",
# notification_providers = build_notification_providers() notification_providers=notification_providers,
# write_to_file("notification_providers.py.j2", "./../uptimekumaapi/notification_providers.py", notification_providers=notification_providers) notification_provider_conditions=notification_provider_conditions
)

View file

@ -1,10 +0,0 @@
params_map_notification_provider_options = {
{%- for provider in notification_provider_map %}
{%- set options = notification_provider_map[provider] %}
'{{ provider }}': {
{%- for key, value in options.items() %}
'{{ key }}': '{{ value }}',
{%- endfor %}
},
{%- endfor %}
}

View file

@ -1,40 +0,0 @@
import re
import os
import jinja2
from uptime_kuma_api import params_map_notification_providers, notification_provider_options
def build_notification_provider_map():
params_map_notification_provider_options = {}
for provider_sock, provider_py in params_map_notification_providers.items():
options_sock = notification_provider_options[provider_sock]
params_map_notification_provider_options[provider_py] = {}
for option in options_sock:
option_orig = option
# for example for rocket_chat
prefix = os.path.commonprefix([o.lower() for o in options_sock] + [provider_py])
option = option[len(prefix):]
option = re.sub('([A-Z]+)', r'_\1', option).lower()
# for example for smtp
if option.startswith(provider_py):
option = option[len(provider_py):]
option = provider_py + "_" + option
option = option.replace("__", "_")
params_map_notification_provider_options[provider_py][option_orig] = option
return params_map_notification_provider_options
notification_provider_map = build_notification_provider_map()
env = jinja2.Environment(loader=jinja2.FileSystemLoader("./"))
template = env.get_template("build_params_map_notification_provider_options.j2")
rendered = template.render(notification_provider_map=notification_provider_map)
print(rendered)

View file

@ -1,12 +0,0 @@
import re
from uptime_kuma_api import notification_provider_options
params_map_notification_providers = {}
for notification_provider in notification_provider_options:
provider_name_orig = notification_provider.__dict__["_value_"]
provider_name = re.sub('([A-Z]+)', r'_\1', provider_name_orig).lower().replace(".", "_").strip("_")
params_map_notification_providers[provider_name_orig] = provider_name
print(params_map_notification_providers)

View file

@ -0,0 +1,8 @@
from enum import Enum
class MonitorType(str, Enum):
{%- for name in monitor_types %}
{{ name.upper() }} = "{{ name }}"
{%- endfor %}

View file

@ -19,3 +19,13 @@ notification_provider_options = {
{%- endfor %} {%- endfor %}
} }
notification_provider_conditions = {
{%- for provider in notification_provider_conditions %}
"{{ provider }}": {
{%- for key, value in notification_provider_conditions[provider].items() %}
"{{ key }}": {{ value }},
{%- endfor %}
},
{%- endfor %}
}

View file

@ -1 +1,2 @@
Jinja2==3.1.2 Jinja2==3.1.2
BeautifulSoup4==4.11.1

26
scripts/utils.py Normal file
View file

@ -0,0 +1,26 @@
import re
import jinja2
def deduplicate_list(l):
out = []
for i in l:
if i not in out:
out.append(i)
return out
def parse_vue_template(path):
with open(path) as f:
vue = f.read()
match = re.search(r'<template>[\s\S]+</template>', vue, re.MULTILINE)
template = match.group(0)
return template
def write_to_file(template, destination, **kwargs):
env = jinja2.Environment(loader=jinja2.FileSystemLoader("./"))
template = env.get_template(template)
rendered = template.render(**kwargs)
with open(destination, "w") as f:
f.write(rendered)