developers.home-assistant/docs/core/entity/camera.md

7.9 KiB

title sidebar_label
Camera entity Camera

A camera entity can display images, and optionally a video stream. Derive a platform entity from homeassistant.components.camera.Camera.

Properties

:::tip Properties should always only return information from memory and not do I/O (like network requests). Implement update() or async_update() to fetch data. :::

Name Type Default Description
brand str | None None The brand (manufacturer) of the camera.
frame_interval float 0.5 The interval between frames of the stream.
is_on bool True Indication of whether the camera is on.
is_recording bool False Indication of whether the camera is recording. Used to determine state.
is_streaming bool False Indication of whether the camera is streaming. Used to determine state.
model str | None None The model of the camera.
motion_detection_enabled bool False Indication of whether the camera has motion detection enabled.
use_stream_for_stills bool False Determines whether or not to use the Stream integration to generate still images

States

The state is defined by setting the properties above. The resulting state uses the CameraState enum to return one of the below members.

Value Description
RECORDING The camera is currently recording.
STREAMING The camera is currently streaming.
IDLE The camera is currently idle.

Supported features

Supported features are defined by using values in the CameraEntityFeature enum and are combined using the bitwise or (|) operator.

Value Description
ON_OFF The device supports turn_on and turn_off
STREAM The device supports streaming

Methods

Camera image

When the width and height are passed, scaling should be done on a best-effort basis. The UI will fall back to scaling at the display layer if scaling cannot be done by the camera.

  • Return the smallest image that meets the minimum width and minimum height.

  • When scaling the image, aspect ratio must be preserved. If the aspect ratio is not the same as the requsted height or width, it is expected that the width and/or height of the returned image will be larger than requested.

  • Pass on the width and height if the underlying camera is capable of scaling the image.

  • If the integration cannot scale the image and returns a jpeg image, it will automatically be scaled by the camera integration when requested.

class MyCamera(Camera):
    # Implement one of these methods.

    def camera_image(
        self, width: int | None = None, height: int | None = None
    ) -> bytes | None:
        """Return bytes of camera image."""
        raise NotImplementedError()

    async def async_camera_image(
        self, width: int | None = None, height: int | None = None
    ) -> bytes | None:
        """Return bytes of camera image."""

Stream source

The stream source should return a url that is usable by ffmpeg (e.g. an RTSP url). Requires CameraEntityFeature.STREAM.

A camera entity with a stream source by default uses StreamType.HLS to tell the frontend to use an HLS feed with the stream component. This stream source will also be used with stream for recording.

class MyCamera(Camera):

    async def stream_source(self) -> str | None:
        """Return the source of the stream."""

A common way for a camera entity to render a camera still image is to pass the stream source to async_get_image in the ffmpeg component.

WebRTC streams

WebRTC enabled cameras can be used by facilitating a direct connection with the home assistant frontend. This usage requires CameraEntityFeature.STREAM and the integration must implement the two following methods to support native WebRTC:

  • async_handle_async_webrtc_offer: To initialize a WebRTC stream. Any messages/errors coming in async should be forwared to the frontend with the send_message callback.
  • async_on_webrtc_candidate: The frontend will call it with any candidate coming in after the offer is sent. The following method can optionally be implemented:
  • close_webrtc_session (Optional): The frontend will call it when the stream is closed. Can be used to clean up things.

WebRTC streams do not use the stream component and do not support recording. By implementing the WebRTC methods, the frontend assumes that the camera supports only WebRTC and therefore will not fallbac to HLS.

class MyCamera(Camera):

    async def async_handle_async_webrtc_offer(
        self, offer_sdp: str, session_id: str, send_message: WebRTCSendMessage
    ) -> None:
        """Handle the async WebRTC offer.

        Async means that it could take some time to process the offer and responses/message
        will be sent with the send_message callback.
        This method is used by cameras with CameraEntityFeature.STREAM
        An integration overriding this method must also implement async_on_webrtc_candidate.

        Integrations can override with a native WebRTC implementation.
        """

    async def async_on_webrtc_candidate(self, session_id: str, candidate: RTCIceCandidate) -> None:
        """Handle a WebRTC candidate."""

    @callback
    def close_webrtc_session(self, session_id: str) -> None:
        """Close a WebRTC session."""

WebRTC Providers

An integration may provide a WebRTC stream from an existing camera's stream source using the libraries in homeassistant.components.camera.webrtc. An integration may implement CameraWebRTCProvider and register it with async_register_webrtc_provider.

Turn on

class MyCamera(Camera):
    # Implement one of these methods.

    def turn_on(self) -> None:
        """Turn on camera."""

    async def async_turn_on(self) -> None:
        """Turn on camera."""

Turn off

class MyCamera(Camera):
    # Implement one of these methods.

    def turn_off(self) -> None:
        """Turn off camera."""

    async def async_turn_off(self) -> None:
        """Turn off camera."""

Enable motion detection

class MyCamera(Camera):
    # Implement one of these methods.

    def enable_motion_detection(self) -> None:
        """Enable motion detection in the camera."""

    async def async_enable_motion_detection(self) -> None:
        """Enable motion detection in the camera."""

Disable motion detection

class MyCamera(Camera):
    # Implement one of these methods.

    def disable_motion_detection(self) -> None:
        """Disable motion detection in camera."""

    async def async_disable_motion_detection(self) -> None:
        """Disable motion detection in camera."""