logging_sender.py: permit to choose a matrix chan where to send the notification
This commit is contained in:
parent
fd1df4e508
commit
c320396bc7
2 changed files with 40 additions and 17 deletions
|
@ -1,16 +1,39 @@
|
||||||
#!/usr/bin/env python3
|
#!/usr/bin/env python3
|
||||||
|
|
||||||
import subprocess
|
import subprocess
|
||||||
from shutil import which
|
|
||||||
import logging
|
import logging
|
||||||
import logging.handlers
|
import logging.handlers
|
||||||
|
|
||||||
|
|
||||||
def send_to_matrix(message: str) -> None:
|
def notify(message, channel):
|
||||||
if which("sendxmpppy") is None:
|
print(f"{channel} -> {message}")
|
||||||
logging.warning("Could not send error via xmpp.")
|
|
||||||
return
|
chan_list = ["dev", "apps", "doc"]
|
||||||
subprocess.call(["sendxmpppy", message], stdout=subprocess.DEVNULL)
|
|
||||||
|
try:
|
||||||
|
any(channel in x for x in chan_list)
|
||||||
|
except False:
|
||||||
|
logging.warning(
|
||||||
|
f"Provided chan '{channel}' is not part of the available options ('dev', 'apps', 'doc')."
|
||||||
|
)
|
||||||
|
|
||||||
|
for char in ["'", "`", "!", ";", "$"]:
|
||||||
|
message = message.replace(char, "")
|
||||||
|
|
||||||
|
try:
|
||||||
|
subprocess.call(
|
||||||
|
[
|
||||||
|
"/var/www/webhooks/matrix-commander",
|
||||||
|
"--markdown -m '{message}' -c /var/www/webhooks/credentials.json --store /var/www/webhooks/store --room 'yunohost-{channel}'",
|
||||||
|
],
|
||||||
|
stdout=subprocess.DEVNULL,
|
||||||
|
)
|
||||||
|
except subprocess.CalledProcessError as e:
|
||||||
|
logging.warning(
|
||||||
|
f"""Could not send a notification on {channel}.
|
||||||
|
Message: {message}
|
||||||
|
Error: {e}"""
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
class LogSenderHandler(logging.Handler):
|
class LogSenderHandler(logging.Handler):
|
||||||
|
@ -20,7 +43,7 @@ class LogSenderHandler(logging.Handler):
|
||||||
|
|
||||||
def emit(self, record):
|
def emit(self, record):
|
||||||
msg = f"[Apps tools error] {record.msg}"
|
msg = f"[Apps tools error] {record.msg}"
|
||||||
send_to_matrix(msg)
|
notify(msg, "dev")
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def add(cls, level=logging.ERROR):
|
def add(cls, level=logging.ERROR):
|
||||||
|
|
|
@ -54,11 +54,13 @@ STRATEGIES = [
|
||||||
|
|
||||||
|
|
||||||
@cache
|
@cache
|
||||||
def get_github() -> tuple[
|
def get_github() -> (
|
||||||
|
tuple[
|
||||||
Optional[tuple[str, str]],
|
Optional[tuple[str, str]],
|
||||||
Optional[github.Github],
|
Optional[github.Github],
|
||||||
Optional[github.InputGitAuthor],
|
Optional[github.InputGitAuthor],
|
||||||
]:
|
]
|
||||||
|
):
|
||||||
try:
|
try:
|
||||||
github_login = (
|
github_login = (
|
||||||
(REPO_APPS_ROOT / ".github_login")
|
(REPO_APPS_ROOT / ".github_login")
|
||||||
|
@ -286,7 +288,6 @@ class AppAutoUpdater:
|
||||||
def relevant_versions(
|
def relevant_versions(
|
||||||
tags: list[str], app_id: str, version_regex: Optional[str]
|
tags: list[str], app_id: str, version_regex: Optional[str]
|
||||||
) -> tuple[str, str]:
|
) -> tuple[str, str]:
|
||||||
|
|
||||||
def apply_version_regex(tag: str) -> Optional[str]:
|
def apply_version_regex(tag: str) -> Optional[str]:
|
||||||
# First preprocessing according to the manifest version_regex…
|
# First preprocessing according to the manifest version_regex…
|
||||||
if version_regex:
|
if version_regex:
|
||||||
|
@ -452,8 +453,8 @@ class AppAutoUpdater:
|
||||||
|
|
||||||
api: Union[GithubAPI, GitlabAPI, GiteaForgejoAPI]
|
api: Union[GithubAPI, GitlabAPI, GiteaForgejoAPI]
|
||||||
if remote_type == "github":
|
if remote_type == "github":
|
||||||
assert upstream and upstream.startswith(
|
assert (
|
||||||
"https://github.com/"
|
upstream and upstream.startswith("https://github.com/")
|
||||||
), f"When using strategy {strategy}, having a defined upstream code repo on github.com is required"
|
), f"When using strategy {strategy}, having a defined upstream code repo on github.com is required"
|
||||||
api = GithubAPI(upstream, auth=get_github()[0])
|
api = GithubAPI(upstream, auth=get_github()[0])
|
||||||
if remote_type == "gitlab":
|
if remote_type == "gitlab":
|
||||||
|
@ -594,7 +595,6 @@ def paste_on_haste(data):
|
||||||
|
|
||||||
|
|
||||||
class StdoutSwitch:
|
class StdoutSwitch:
|
||||||
|
|
||||||
class DummyFile:
|
class DummyFile:
|
||||||
def __init__(self) -> None:
|
def __init__(self) -> None:
|
||||||
self.result = ""
|
self.result = ""
|
||||||
|
@ -728,7 +728,7 @@ def main() -> None:
|
||||||
paste_url = paste_on_haste(paste_message)
|
paste_url = paste_on_haste(paste_message)
|
||||||
matrix_message += f"\nSee the full log here: {paste_url}"
|
matrix_message += f"\nSee the full log here: {paste_url}"
|
||||||
|
|
||||||
appslib.logging_sender.send_to_matrix(matrix_message)
|
appslib.logging_sender.notify(matrix_message, "apps")
|
||||||
print(paste_message)
|
print(paste_message)
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue