mirror of
https://github.com/home-assistant/core.git
synced 2025-07-20 03:37:07 +00:00
Catch ConnectionResetError when writing MJPEG in camera (#66245)
This commit is contained in:
parent
9fa2bdd3fd
commit
c222be0958
@ -221,7 +221,12 @@ async def async_get_mjpeg_stream(
|
|||||||
"""Fetch an mjpeg stream from a camera entity."""
|
"""Fetch an mjpeg stream from a camera entity."""
|
||||||
camera = _get_camera_from_entity_id(hass, entity_id)
|
camera = _get_camera_from_entity_id(hass, entity_id)
|
||||||
|
|
||||||
return await camera.handle_async_mjpeg_stream(request)
|
try:
|
||||||
|
stream = await camera.handle_async_mjpeg_stream(request)
|
||||||
|
except ConnectionResetError:
|
||||||
|
stream = None
|
||||||
|
_LOGGER.debug("Error while writing MJPEG stream to transport")
|
||||||
|
return stream
|
||||||
|
|
||||||
|
|
||||||
async def async_get_still_stream(
|
async def async_get_still_stream(
|
||||||
@ -783,7 +788,11 @@ class CameraMjpegStream(CameraView):
|
|||||||
async def handle(self, request: web.Request, camera: Camera) -> web.StreamResponse:
|
async def handle(self, request: web.Request, camera: Camera) -> web.StreamResponse:
|
||||||
"""Serve camera stream, possibly with interval."""
|
"""Serve camera stream, possibly with interval."""
|
||||||
if (interval_str := request.query.get("interval")) is None:
|
if (interval_str := request.query.get("interval")) is None:
|
||||||
stream = await camera.handle_async_mjpeg_stream(request)
|
try:
|
||||||
|
stream = await camera.handle_async_mjpeg_stream(request)
|
||||||
|
except ConnectionResetError:
|
||||||
|
stream = None
|
||||||
|
_LOGGER.debug("Error while writing MJPEG stream to transport")
|
||||||
if stream is None:
|
if stream is None:
|
||||||
raise web.HTTPBadGateway()
|
raise web.HTTPBadGateway()
|
||||||
return stream
|
return stream
|
||||||
|
Loading…
x
Reference in New Issue
Block a user