2024-03-26 07:04:17 +00:00
|
|
|
import json
|
2024-03-31 19:17:29 +00:00
|
|
|
import logging
|
|
|
|
|
2024-08-27 22:10:27 +00:00
|
|
|
import requests
|
2024-09-04 14:54:48 +00:00
|
|
|
from open_webui.config import WEBUI_FAVICON_URL, WEBUI_NAME
|
|
|
|
from open_webui.env import SRC_LOG_LEVELS, VERSION
|
2024-03-31 19:17:29 +00:00
|
|
|
|
|
|
|
log = logging.getLogger(__name__)
|
|
|
|
log.setLevel(SRC_LOG_LEVELS["WEBHOOK"])
|
2024-03-21 01:35:02 +00:00
|
|
|
|
2024-03-31 08:13:39 +00:00
|
|
|
|
2024-03-21 01:47:13 +00:00
|
|
|
def post_webhook(url: str, message: str, event_data: dict) -> bool:
|
2024-03-21 01:35:02 +00:00
|
|
|
try:
|
2024-12-21 06:54:43 +00:00
|
|
|
log.debug(f"post_webhook: {url}, {message}, {event_data}")
|
2024-03-21 01:47:13 +00:00
|
|
|
payload = {}
|
|
|
|
|
2024-03-27 02:25:57 +00:00
|
|
|
# Slack and Google Chat Webhooks
|
|
|
|
if "https://hooks.slack.com" in url or "https://chat.googleapis.com" in url:
|
2024-03-21 01:47:13 +00:00
|
|
|
payload["text"] = message
|
2024-03-27 02:25:57 +00:00
|
|
|
# Discord Webhooks
|
2024-03-21 01:47:13 +00:00
|
|
|
elif "https://discord.com/api/webhooks" in url:
|
2024-12-21 07:05:22 +00:00
|
|
|
payload["content"] = (
|
|
|
|
message
|
|
|
|
if len(message) > 2000
|
2024-12-25 04:17:24 +00:00
|
|
|
else f"{message[: 2000 - 20]}... (truncated)"
|
2024-12-21 07:05:22 +00:00
|
|
|
)
|
2024-03-27 02:25:57 +00:00
|
|
|
# Microsoft Teams Webhooks
|
2024-03-26 07:04:17 +00:00
|
|
|
elif "webhook.office.com" in url:
|
|
|
|
action = event_data.get("action", "undefined")
|
|
|
|
facts = [
|
|
|
|
{"name": name, "value": value}
|
|
|
|
for name, value in json.loads(event_data.get("user", {})).items()
|
|
|
|
]
|
|
|
|
payload = {
|
|
|
|
"@type": "MessageCard",
|
|
|
|
"@context": "http://schema.org/extensions",
|
|
|
|
"themeColor": "0076D7",
|
|
|
|
"summary": message,
|
|
|
|
"sections": [
|
|
|
|
{
|
|
|
|
"activityTitle": message,
|
2024-03-26 07:45:36 +00:00
|
|
|
"activitySubtitle": f"{WEBUI_NAME} ({VERSION}) - {action}",
|
|
|
|
"activityImage": WEBUI_FAVICON_URL,
|
2024-03-26 07:04:17 +00:00
|
|
|
"facts": facts,
|
|
|
|
"markdown": True,
|
|
|
|
}
|
|
|
|
],
|
|
|
|
}
|
2024-03-27 02:25:57 +00:00
|
|
|
# Default Payload
|
2024-03-21 01:47:13 +00:00
|
|
|
else:
|
|
|
|
payload = {**event_data}
|
|
|
|
|
2024-03-31 19:17:29 +00:00
|
|
|
log.debug(f"payload: {payload}")
|
2024-03-21 01:47:13 +00:00
|
|
|
r = requests.post(url, json=payload)
|
2024-03-21 01:35:02 +00:00
|
|
|
r.raise_for_status()
|
2024-03-31 19:17:29 +00:00
|
|
|
log.debug(f"r.text: {r.text}")
|
2024-03-21 01:35:02 +00:00
|
|
|
return True
|
|
|
|
except Exception as e:
|
2024-03-31 19:17:29 +00:00
|
|
|
log.exception(e)
|
2024-03-31 08:13:39 +00:00
|
|
|
return False
|