pub struct BinarySensor<'a> {
Show 21 fields pub availability: Cow<'a, [Availability<'a>]>, pub availability_mode: AvailabilityMode, pub device: Option<Device<'a>>, pub enabled_by_default: Option<bool>, pub encoding: Option<Cow<'a, str>>, pub entity_category: EntityCategory, pub icon: Option<Icon<'a>>, pub json_attributes_template: Option<Template<'a>>, pub json_attributes_topic: Option<Topic<'a>>, pub name: Option<Name<'a>>, pub object_id: Option<Cow<'a, str>>, pub qos: MqttQoS, pub unique_id: Option<UniqueId<'a>>, pub device_class: DeviceClass, pub expire_after: Option<NonZeroU32>, pub force_update: Option<bool>, pub off_delay: Option<NonZeroU32>, pub payload_off: Option<Payload<'a>>, pub payload_on: Option<Payload<'a>>, pub state_topic: Topic<'a>, pub value_template: Option<Template<'a>>,
}
Expand description

The mqtt binary sensor platform uses an MQTT message received to set the binary sensor’s state to on, off or unknown.

The state will be updated only after a new message is published on state_topic matching payload_on, payload_off or None. If these messages are published with the retain flag set, the binary sensor will receive an instant state update after subscription and Home Assistant will display the correct state on startup. Otherwise, the initial state displayed in Home Assistant will be unknown.

Stateless devices such as buttons, remote controls etc are better represented by MQTT device triggers than by binary sensors.

See: https://www.home-assistant.io/integrations/binary_sensor.mqtt/

Fields§

§availability: Cow<'a, [Availability<'a>]>

A list of MQTT topics subscribed to receive availability (online/offline) updates.

§availability_mode: AvailabilityMode

When availability is configured, this controls the conditions needed to set the entity to available.

§device: Option<Device<'a>>

Information about the device this entity is a part of to tie it into the device registry. Only works through MQTT discovery and when unique_id is set. At least one of identifiers or connections must be present to identify the device.

§enabled_by_default: Option<bool>

Flag which defines if the entity should be enabled when first added. Defaults to true.

§encoding: Option<Cow<'a, str>>

The encoding of the payloads received and published messages. Set to “” to disable decoding of incoming payload. Defaults to "utf-8".

§entity_category: EntityCategory

The category of the entity.

§icon: Option<Icon<'a>>

Icon for the entity.

§json_attributes_template: Option<Template<'a>>

Defines a template to extract the JSON dictionary from messages received on the json_attributes_topic.

§json_attributes_topic: Option<Topic<'a>>

The MQTT topic subscribed to receive a JSON dictionary payload and then set as entity attributes.

Implies force_update of the current state when a message is received on this topic.

§name: Option<Name<'a>>

The name of the MQTT entity.

§object_id: Option<Cow<'a, str>>

Used instead of name for automatic generation of entity_id.

§qos: MqttQoS

The maximum QoS level of the state topic.

§unique_id: Option<UniqueId<'a>>

An ID that uniquely identifies this entity. If two entities have the same unique ID, Home Assistant will raise an exception.

§device_class: DeviceClass

The type/class of the sensor to set the icon in the frontend.

§expire_after: Option<NonZeroU32>

Defines the number of seconds after the value expires if it’s not updated. After expiry, the sensor’s state becomes unavailable.

§force_update: Option<bool>

Sends update events (which results in update of state object’s last_changed) even if the sensor’s state hasn’t changed. Useful if you want to have meaningful value graphs in history or want to create an automation that triggers on every incoming state message (not only when the sensor’s new state is different to the current one).

§off_delay: Option<NonZeroU32>

For sensors that only send on state updates (like PIRs), this variable sets a delay in seconds after which the sensor’s state will be updated back to off.

§payload_off: Option<Payload<'a>>

The string that represents the off state. It will be compared to the message in the state_topic (see value_template for details) Defaults to "OFF".

§payload_on: Option<Payload<'a>>

The string that represents the on state. It will be compared to the message in the state_topic (see value_template for details) Defaults to "ON".

§state_topic: Topic<'a>

The MQTT topic subscribed to receive sensor values.

§value_template: Option<Template<'a>>

Defines a template that returns a string to be compared to payload_on/payload_off or an empty string, in which case the MQTT message will be removed. Available variables: entity_id. Remove this option when payload_on and payload_off are sufficient to match your payloads (i.e no pre-processing of original message is required).

Implementations§

A list of MQTT topics subscribed to receive availability (online/offline) updates.

When availability is configured, this controls the conditions needed to set the entity to available.

Information about the device this entity is a part of to tie it into the device registry. Only works through MQTT discovery and when unique_id is set. At least one of identifiers or connections must be present to identify the device.

Information about the device this entity is a part of to tie it into the device registry. Only works through MQTT discovery and when unique_id is set. At least one of identifiers or connections must be present to identify the device.

Flag which defines if the entity should be enabled when first added. Defaults to true.

Flag which defines if the entity should be enabled when first added. Defaults to true.

The encoding of the payloads received and published messages. Set to “” to disable decoding of incoming payload. Defaults to "utf-8".

The encoding of the payloads received and published messages. Set to “” to disable decoding of incoming payload. Defaults to "utf-8".

The category of the entity.

Icon for the entity.

Icon for the entity.

Defines a template to extract the JSON dictionary from messages received on the json_attributes_topic.

Defines a template to extract the JSON dictionary from messages received on the json_attributes_topic.

The MQTT topic subscribed to receive a JSON dictionary payload and then set as entity attributes.

Implies force_update of the current state when a message is received on this topic.

The MQTT topic subscribed to receive a JSON dictionary payload and then set as entity attributes.

Implies force_update of the current state when a message is received on this topic.

The name of the MQTT entity.

The name of the MQTT entity.

Used instead of name for automatic generation of entity_id.

Used instead of name for automatic generation of entity_id.

The maximum QoS level of the state topic.

An ID that uniquely identifies this entity. If two entities have the same unique ID, Home Assistant will raise an exception.

An ID that uniquely identifies this entity. If two entities have the same unique ID, Home Assistant will raise an exception.

The type/class of the sensor to set the icon in the frontend.

Defines the number of seconds after the value expires if it’s not updated. After expiry, the sensor’s state becomes unavailable.

Defines the number of seconds after the value expires if it’s not updated. After expiry, the sensor’s state becomes unavailable.

Sends update events (which results in update of state object’s last_changed) even if the sensor’s state hasn’t changed. Useful if you want to have meaningful value graphs in history or want to create an automation that triggers on every incoming state message (not only when the sensor’s new state is different to the current one).

Sends update events (which results in update of state object’s last_changed) even if the sensor’s state hasn’t changed. Useful if you want to have meaningful value graphs in history or want to create an automation that triggers on every incoming state message (not only when the sensor’s new state is different to the current one).

For sensors that only send on state updates (like PIRs), this variable sets a delay in seconds after which the sensor’s state will be updated back to off.

For sensors that only send on state updates (like PIRs), this variable sets a delay in seconds after which the sensor’s state will be updated back to off.

The string that represents the off state. It will be compared to the message in the state_topic (see value_template for details) Defaults to "OFF".

The string that represents the off state. It will be compared to the message in the state_topic (see value_template for details) Defaults to "OFF".

The string that represents the on state. It will be compared to the message in the state_topic (see value_template for details) Defaults to "ON".

The string that represents the on state. It will be compared to the message in the state_topic (see value_template for details) Defaults to "ON".

The MQTT topic subscribed to receive sensor values.

Defines a template that returns a string to be compared to payload_on/payload_off or an empty string, in which case the MQTT message will be removed. Available variables: entity_id. Remove this option when payload_on and payload_off are sufficient to match your payloads (i.e no pre-processing of original message is required).

Defines a template that returns a string to be compared to payload_on/payload_off or an empty string, in which case the MQTT message will be removed. Available variables: entity_id. Remove this option when payload_on and payload_off are sufficient to match your payloads (i.e no pre-processing of original message is required).

Trait Implementations§

Returns a copy of the value. Read more
Performs copy-assignment from source. Read more
Formats the value using the given formatter. Read more
Deserialize this value from the given Serde deserializer. Read more
This method tests for self and other values to be equal, and is used by ==. Read more
This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason. Read more
Serialize this value into the given Serde serializer. Read more
Invalidity objectives
Perform the validation Read more

Auto Trait Implementations§

Blanket Implementations§

Gets the TypeId of self. Read more
Immutably borrows from an owned value. Read more
Mutably borrows from an owned value. Read more

Returns the argument unchanged.

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Convert self into output value and validate the output Read more
Check if this instance is valid, discarding all further information why if not. Read more
Set the foreground color generically Read more
Set the background color generically. Read more
Change the foreground color to black
Change the background color to black
Change the foreground color to red
Change the background color to red
Change the foreground color to green
Change the background color to green
Change the foreground color to yellow
Change the background color to yellow
Change the foreground color to blue
Change the background color to blue
Change the foreground color to magenta
Change the background color to magenta
Change the foreground color to purple
Change the background color to purple
Change the foreground color to cyan
Change the background color to cyan
Change the foreground color to white
Change the background color to white
Change the foreground color to the terminal default
Change the background color to the terminal default
Change the foreground color to bright black
Change the background color to bright black
Change the foreground color to bright red
Change the background color to bright red
Change the foreground color to bright green
Change the background color to bright green
Change the foreground color to bright yellow
Change the background color to bright yellow
Change the foreground color to bright blue
Change the background color to bright blue
Change the foreground color to bright magenta
Change the background color to bright magenta
Change the foreground color to bright purple
Change the background color to bright purple
Change the foreground color to bright cyan
Change the background color to bright cyan
Change the foreground color to bright white
Change the background color to bright white
Make the text bold
Make the text dim
Make the text italicized
Make the text italicized
Make the text blink
Make the text blink (but fast!)
Swap the foreground and background colors
Hide the text
Cross out the text
Set the foreground color at runtime. Only use if you do not know which color will be used at compile-time. If the color is constant, use either OwoColorize::fg or a color-specific method, such as OwoColorize::green, Read more
Set the background color at runtime. Only use if you do not know what color to use at compile-time. If the color is constant, use either OwoColorize::bg or a color-specific method, such as OwoColorize::on_yellow, Read more
Set the foreground color to a specific RGB value.
Set the background color to a specific RGB value.
Sets the foreground color to an RGB value.
Sets the background color to an RGB value.
Apply a runtime-determined style
Apply a given transformation function to all formatters if the given stream supports at least basic ANSI colors, allowing you to conditionally apply given styles/colors. Read more
The resulting type after obtaining ownership.
Creates owned data from borrowed data, usually by cloning. Read more
Uses borrowed data to replace owned data, usually by cloning. Read more
The type returned in the event of a conversion error.
Performs the conversion.
The type returned in the event of a conversion error.
Performs the conversion.
Convert input value into Self and validate self Read more