simple-ocpp-cs/app/util/websocket_wrapper.py
Oliver Traber dfa36b6294
All checks were successful
ci/woodpecker/push/docker Pipeline was successful
Fix logging
2024-04-20 17:36:35 +02:00

25 lines
849 B
Python

import logging
from fastapi import WebSocket, WebSocketDisconnect
from websockets import ConnectionClosed
logger = logging.getLogger("gunicorn.error")
# Wrapper to transform a FastAPI websocket to a standard websocket
class WebSocketWrapper():
def __init__(self, websocket: WebSocket):
self._websocket = websocket
async def recv(self) -> str:
try:
text = await self._websocket.receive_text()
logger.info("Message received: %s", text)
return text
except WebSocketDisconnect as e:
raise ConnectionClosed(e.code, 'WebSocketWrapper')
async def send(self, msg: str) -> None:
logger.info("Message sent: %s", msg)
await self._websocket.send_text(msg)
async def close(self, code: int, reason: str) -> None:
await self._websocket.close(code)