pub struct Sensor<'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 last_reset_value_template: Option<Template<'a>>, pub state_class: StateClass, pub state_topic: Topic<'a>, pub unit_of_measurement: Option<Cow<'a, str>>, pub value_template: Option<Template<'a>>,
}
Expand description

This mqtt sensor platform uses the MQTT message payload as the sensor value. If messages in this state_topic are published with RETAIN flag, the sensor will receive an instant update with last known value. Otherwise, the initial state will be undefined.

See: https://www.home-assistant.io/integrations/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 even if the value hasn’t changed. Useful if you want to have meaningful value graphs in history. Defaults to false.

§last_reset_value_template: Option<Template<'a>>

Defines a template to extract the last_reset. Available variables: entity_id. The entity_id can be used to reference the entity’s attributes.

§state_class: StateClass

The state_class of the sensor.

§state_topic: Topic<'a>

The MQTT topic subscribed to receive sensor values.

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

Defines the units of measurement of the sensor, if any.

§value_template: Option<Template<'a>>

Defines a template to extract the value. Available variables: entity_id. The entity_id can be used to reference the entity’s attributes.

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 even if the value hasn’t changed. Useful if you want to have meaningful value graphs in history. Defaults to false.

Sends update events even if the value hasn’t changed. Useful if you want to have meaningful value graphs in history. Defaults to false.

Defines a template to extract the last_reset. Available variables: entity_id. The entity_id can be used to reference the entity’s attributes.

Defines a template to extract the last_reset. Available variables: entity_id. The entity_id can be used to reference the entity’s attributes.

The state_class of the sensor.

The MQTT topic subscribed to receive sensor values.

Defines the units of measurement of the sensor, if any.

Defines the units of measurement of the sensor, if any.

Defines a template to extract the value. Available variables: entity_id. The entity_id can be used to reference the entity’s attributes.

Defines a template to extract the value. Available variables: entity_id. The entity_id can be used to reference the entity’s attributes.

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