created validators classes

This commit is contained in:
kiriharu 2021-01-13 22:22:35 +03:00
parent 1bbe0ade62
commit 8eea9a3a2f
3 changed files with 39 additions and 35 deletions

View File

@ -0,0 +1,10 @@
class NotEnoughArgs(Exception):
pass
class InvalidPort(Exception):
pass
class LocalhostForbidden(Exception):
pass

View File

@ -8,23 +8,9 @@ from aiogram.bot import Bot
from tgbot.handlers.metrics import push_api_request_status from tgbot.handlers.metrics import push_api_request_status
from tgbot.config import NOTIFICATION_BOT_TOKEN, NOTIFICATION_USERS from tgbot.config import NOTIFICATION_BOT_TOKEN, NOTIFICATION_USERS
from traceback import format_exc from traceback import format_exc
from functools import wraps
from time import time
import asyncio import asyncio
def timing(f):
@wraps(f)
def wrap(*args, **kw):
ts = time()
result = f(*args, **kw)
te = time()
logger.info(f"func {f.__name__} took {te - ts} sec")
return result
return wrap
def check_int(value) -> bool: def check_int(value) -> bool:
try: try:
int(value) int(value)
@ -34,27 +20,6 @@ def check_int(value) -> bool:
return True return True
def validate_local(target: str) -> bool:
"""
Validates ip or FQDN is localhost
:return True if localhost find
"""
if target == "localhost":
return True
with suppress(ValueError):
ip_addr = ip_address(target)
if any(
[ip_addr.is_loopback,
ip_addr.is_private,
ip_addr.is_multicast,
ip_addr.is_link_local,
ip_addr.is_unspecified]
):
return True
return False
async def send_api_request(client: AsyncClient, endpoint: str, data: dict, node: APINode): async def send_api_request(client: AsyncClient, endpoint: str, data: dict, node: APINode):
try: try:
data['token'] = node.token data['token'] = node.token

View File

@ -0,0 +1,29 @@
from .errors import LocalhostForbidden
from ipaddress import ip_address
from contextlib import suppress
class BaseValidator:
def __init__(self):
pass
def validate(self, target: str, **kwargs):
pass
class LocalhostValidator(BaseValidator):
def validate(self, target: str, **kwargs):
if target == "localhost":
raise LocalhostForbidden
with suppress(ValueError):
ip_addr = ip_address(target)
if any(
[ip_addr.is_loopback,
ip_addr.is_private,
ip_addr.is_multicast,
ip_addr.is_link_local,
ip_addr.is_unspecified]
):
raise LocalhostForbidden