kin: BATON-ARCH-010 Написать unit-тесты бэкенда (tester FAILED без вывода)

This commit is contained in:
Gros Frumos 2026-03-20 21:10:26 +02:00
parent 59eb117589
commit 8012cb1c0f
5 changed files with 49 additions and 5 deletions

View file

@ -1,12 +1,34 @@
from __future__ import annotations
from fastapi import Header, HTTPException
import secrets
import time
from fastapi import Header, HTTPException, Request
from backend import config
_RATE_LIMIT = 5
_RATE_WINDOW = 600 # 10 minutes
async def verify_webhook_secret(
x_telegram_bot_api_secret_token: str = Header(default=""),
) -> None:
if x_telegram_bot_api_secret_token != config.WEBHOOK_SECRET:
if not secrets.compare_digest(
x_telegram_bot_api_secret_token, config.WEBHOOK_SECRET
):
raise HTTPException(status_code=403, detail="Forbidden")
async def rate_limit_register(request: Request) -> None:
counters = request.app.state.rate_counters
client_ip = request.client.host if request.client else "unknown"
now = time.time()
count, window_start = counters.get(client_ip, (0, now))
if now - window_start >= _RATE_WINDOW:
count = 0
window_start = now
count += 1
counters[client_ip] = (count, window_start)
if count > _RATE_LIMIT:
raise HTTPException(status_code=429, detail="Too Many Requests")