mirror of
https://github.com/catspace-dev/unicheckbot.git
synced 2024-11-21 21:46:32 +03:00
sentry integration
This commit is contained in:
parent
4ce150a42b
commit
4ff26959ee
|
@ -15,6 +15,8 @@ loguru = "^0.5.3"
|
||||||
whois-vu = "^0.3.0"
|
whois-vu = "^0.3.0"
|
||||||
tortoise-orm = "^0.16.20"
|
tortoise-orm = "^0.16.20"
|
||||||
aiomysql = "^0.0.21"
|
aiomysql = "^0.0.21"
|
||||||
|
sentry-sdk = "^1.0.0"
|
||||||
|
aiocontextvars = "^0.2.2"
|
||||||
|
|
||||||
[tool.poetry.dev-dependencies]
|
[tool.poetry.dev-dependencies]
|
||||||
pytest = "^6.2.2"
|
pytest = "^6.2.2"
|
||||||
|
|
|
@ -1,3 +1,12 @@
|
||||||
|
import sentry_sdk
|
||||||
|
from tgbot import config
|
||||||
|
|
||||||
|
if config.SENTRY_DSN:
|
||||||
|
|
||||||
|
sentry_sdk.init(
|
||||||
|
dsn=config.SENTRY_DSN,
|
||||||
|
)
|
||||||
|
|
||||||
from asyncio import sleep
|
from asyncio import sleep
|
||||||
|
|
||||||
from aiogram import Bot, Dispatcher, executor
|
from aiogram import Bot, Dispatcher, executor
|
||||||
|
@ -6,9 +15,10 @@ from loguru import logger
|
||||||
from tortoise import Tortoise
|
from tortoise import Tortoise
|
||||||
from tortoise.exceptions import DBConnectionError
|
from tortoise.exceptions import DBConnectionError
|
||||||
|
|
||||||
from . import config, handlers
|
from . import handlers
|
||||||
from .middlewares import (LoggingMiddleware, ThrottlingMiddleware,
|
from .middlewares import (
|
||||||
UserMiddleware, WriteCommandMetric)
|
LoggingMiddleware, ThrottlingMiddleware, UserMiddleware, WriteCommandMetric
|
||||||
|
)
|
||||||
|
|
||||||
storage = MemoryStorage()
|
storage = MemoryStorage()
|
||||||
telegram_bot = Bot(token=config.TELEGRAM_BOT_TOKEN)
|
telegram_bot = Bot(token=config.TELEGRAM_BOT_TOKEN)
|
||||||
|
|
|
@ -20,3 +20,6 @@ MYSQL_USER = os.getenv("MYSQL_USER")
|
||||||
MYSQL_PASSWORD = os.getenv("MYSQL_PASSWORD")
|
MYSQL_PASSWORD = os.getenv("MYSQL_PASSWORD")
|
||||||
MYSQL_PORT = os.getenv("MYSQL_PORT", 3306)
|
MYSQL_PORT = os.getenv("MYSQL_PORT", 3306)
|
||||||
MYSQL_DATABASE = os.getenv("MYSQL_DATABASE", "unicheckbot")
|
MYSQL_DATABASE = os.getenv("MYSQL_DATABASE", "unicheckbot")
|
||||||
|
|
||||||
|
# Sentry
|
||||||
|
SENTRY_DSN = os.getenv("SENTRY_DSN")
|
||||||
|
|
|
@ -36,4 +36,8 @@ start_message = """
|
||||||
@userdata_required
|
@userdata_required
|
||||||
@rate_limit
|
@rate_limit
|
||||||
async def start_cmd(msg: Message, user: User):
|
async def start_cmd(msg: Message, user: User):
|
||||||
await msg.answer(start_message.replace("%name%", msg.from_user.full_name), parse_mode='markdown', disable_web_page_preview=True)
|
await msg.answer(
|
||||||
|
start_message.replace("%name%", msg.from_user.full_name),
|
||||||
|
parse_mode='markdown',
|
||||||
|
disable_web_page_preview=True
|
||||||
|
)
|
||||||
|
|
|
@ -4,6 +4,7 @@ from typing import Optional
|
||||||
from aiogram.types import Message
|
from aiogram.types import Message
|
||||||
from whois_vu.api import WhoisSource
|
from whois_vu.api import WhoisSource
|
||||||
from whois_vu.errors import IncorrectZone, QueryNotMatchRegexp
|
from whois_vu.errors import IncorrectZone, QueryNotMatchRegexp
|
||||||
|
from sentry_sdk import capture_exception
|
||||||
|
|
||||||
from whois import parser, whois
|
from whois import parser, whois
|
||||||
|
|
||||||
|
@ -72,7 +73,8 @@ def create_whois_message(domain: str) -> str:
|
||||||
domain_info = whois_request(domain)
|
domain_info = whois_request(domain)
|
||||||
except parser.PywhoisError:
|
except parser.PywhoisError:
|
||||||
return f"❗ Домен {domain} свободен или не был найден."
|
return f"❗ Домен {domain} свободен или не был найден."
|
||||||
except IncorrectZone:
|
except IncorrectZone as e:
|
||||||
|
capture_exception(e)
|
||||||
return incorrect_domain.format(domain=domain)
|
return incorrect_domain.format(domain=domain)
|
||||||
except QueryNotMatchRegexp:
|
except QueryNotMatchRegexp:
|
||||||
return incorrect_domain.format(domain=domain)
|
return incorrect_domain.format(domain=domain)
|
||||||
|
|
|
@ -1,13 +1,12 @@
|
||||||
import asyncio
|
import asyncio
|
||||||
from contextlib import suppress
|
|
||||||
from ipaddress import ip_address
|
|
||||||
from traceback import format_exc
|
from traceback import format_exc
|
||||||
from typing import Callable, List
|
from typing import List
|
||||||
|
|
||||||
from aiogram.bot import Bot
|
from aiogram.bot import Bot
|
||||||
from core.coretypes import APINode
|
from core.coretypes import APINode
|
||||||
from httpx import AsyncClient, Response, Timeout
|
from httpx import AsyncClient, Response, Timeout
|
||||||
from loguru import logger
|
from loguru import logger
|
||||||
|
from sentry_sdk import capture_exception
|
||||||
|
|
||||||
from ..config import NOTIFICATION_BOT_TOKEN, NOTIFICATION_USERS
|
from ..config import NOTIFICATION_BOT_TOKEN, NOTIFICATION_USERS
|
||||||
from .metrics import push_api_request_status
|
from .metrics import push_api_request_status
|
||||||
|
@ -20,13 +19,19 @@ async def send_api_request(client: AsyncClient, endpoint: str, data: dict, node:
|
||||||
f"{node.address}/{endpoint}", params=data
|
f"{node.address}/{endpoint}", params=data
|
||||||
)
|
)
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
|
exc_id = capture_exception(e)
|
||||||
# Remove token from log data
|
# Remove token from log data
|
||||||
data.pop('token', None)
|
data.pop('token', None)
|
||||||
logger.error(f"Node {node.address} got Error. Data: {data}. Endpoint: {endpoint}. Full exception: {e}")
|
logger.error(f"Node {node.address} got Error. Data: {data}. Endpoint: {endpoint}. Full exception: {e}")
|
||||||
result = Response(500)
|
result = Response(500)
|
||||||
await send_message_to_admins(f"Node {node.address} got error: `{e}`. \n"
|
if exc_id:
|
||||||
f"Data: `{data}`, Endpoint: `{endpoint}`\n"
|
await send_message_to_admins(f"Node {node.address} got error: `{e}`. \n"
|
||||||
f"Full exception: ```{format_exc()}```")
|
f"Data: `{data}`, Endpoint: `{endpoint}`\n"
|
||||||
|
f"Exc sentry: {exc_id}")
|
||||||
|
else:
|
||||||
|
await send_message_to_admins(f"Node {node.address} got error: `{e}`. \n"
|
||||||
|
f"Data: `{data}`, Endpoint: `{endpoint}`\n"
|
||||||
|
f"Full exception: ```{format_exc()}```")
|
||||||
await push_api_request_status(
|
await push_api_request_status(
|
||||||
result.status_code,
|
result.status_code,
|
||||||
endpoint
|
endpoint
|
||||||
|
|
Loading…
Reference in New Issue
Block a user