-
Notifications
You must be signed in to change notification settings - Fork 46
/
Copy pathtg_notify.py
62 lines (53 loc) · 2.68 KB
/
tg_notify.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
#!/usr/bin/env python3
from datetime import datetime
import pytz
import requests
from logger_wrapper import LoggerWrapper
from sys_config_entry import SysConfigEntry
class TgNotify:
_instance = None
def __new__(cls, sys_config_entry: SysConfigEntry):
if cls._instance is None:
cls._instance = super().__new__(cls)
cls._instance._initialized = False
return cls._instance
def __init__(self, sys_config_entry: SysConfigEntry):
if self._initialized:
return
self._initialized = True
self.sys_config_entry = sys_config_entry
self.logger = LoggerWrapper()
self.bot_token = self.sys_config_entry.get("TG_ROBOT_KEY")
self.chat_id = self.sys_config_entry.get("TG_CHAT_ID")
def check_monitor_url_dns_fail_notify(self, url: str, e: Exception):
title = "💣 解析失败提醒 💣"
content = f"域名: {url}\n错误: {e}\n请检查dns解析"
self.logger.error(f"{title}\n{content}")
self._send_notify(title, content)
def check_monitor_url_visit_ok_notify(self, url: str, response):
title = "🎉 当前服务稳如泰山 🎉"
content = f"域名: {url}\n状态码: {response.status_code}\n继续加油!"
self.logger.info(f"监控域名{url} {title}\n{content}")
self._send_notify(title, content)
def check_monitor_url_visit_fail_notify(self, url: str, response):
title = "💥 当前服务不可用 💥"
content = f"域名: {url}\n状态码: {response.status_code}\n心跳模块会拉起进程,请稍后检查"
self.logger.info(f"监控域名{url} {title}\n{content}")
self._send_notify(title, content)
def _build_message(self, title: str, content: str) -> str:
system_time = datetime.now().strftime('%Y-%m-%d %H:%M:%S')
beijing_time = datetime.now(pytz.timezone('Asia/Shanghai')).strftime('%Y-%m-%d %H:%M:%S')
return f"----- {title} -----\n{content}\n系统时间: {system_time}\n北京时间: {beijing_time}"
def _send_notify(self, title: str, content: str) -> None:
try:
message = self._build_message(title, content)
api_url = f"https://api.telegram.org/bot{self.bot_token}/sendMessage"
payload = {
'chat_id': self.chat_id,
'text': message
}
with requests.post(api_url, data=payload) as response:
response.raise_for_status()
self.logger.info(f"telegram推送消息成功: {response.text}")
except requests.RequestException as e:
self.logger.error(f"telegram推送消息失败,错误: {str(e)}")