hack-house/cmd_chat/server/models.py
mirai 5cbe355660 feat: add SRP authentication, improve security
- Replace RSA key exchange with SRP (Secure Remote Password)
- Password never transmitted over network
- Add unit tests for endpoints
- Fix datetime.UTC compatibility for Python < 3.11
- Fix logger.exception usage
- Update README with new auth flow diagram
2026-01-02 23:09:00 +03:00

38 lines
1.0 KiB
Python

from dataclasses import dataclass, field
from uuid import uuid4
from datetime import datetime, timezone
from typing import Optional
@dataclass
class Message:
id: str = field(default_factory=lambda: str(uuid4()))
text: str = ""
timestamp: str = field(
default_factory=lambda: datetime.now(timezone.utc).isoformat()
)
user_ip: str = ""
username: str = ""
@dataclass
class UserSession:
user_id: str
ip: str
username: str = "unknown"
fernet_key: Optional[bytes] = None
created_at: str = field(
default_factory=lambda: datetime.now(timezone.utc).isoformat()
)
last_activity: str = field(
default_factory=lambda: datetime.now(timezone.utc).isoformat()
)
active: bool = True
def update_activity(self):
self.last_activity = datetime.now(timezone.utc).isoformat()
def is_stale(self, timeout_seconds: int = 3600) -> bool:
last = datetime.fromisoformat(self.last_activity)
return (datetime.now(timezone.utc) - last).total_seconds() > timeout_seconds