pub struct Switch<'a> {
Show 23 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 command_topic: Topic<'a>, pub device_class: DeviceClass, pub optimistic: Option<bool>, pub payload_off: Option<Payload<'a>>, pub payload_on: Option<Payload<'a>>, pub retain: Option<bool>, pub state_off: Option<Payload<'a>>, pub state_on: Option<Payload<'a>>, pub state_topic: Option<Topic<'a>>, pub value_template: Option<Template<'a>>,
}
Expand description

The mqtt switch platform lets you control your MQTT enabled switches.

See: https://www.home-assistant.io/integrations/switch.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.

§command_topic: Topic<'a>

The MQTT topic to publish commands to change the switch state.

§device_class: DeviceClass

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

§optimistic: Option<bool>

Flag that defines if switch works in optimistic mode. Defaults to true if no state_topic defined, else false.

§payload_off: Option<Payload<'a>>

The payload that represents off state. If specified, will be used for both comparing to the value in the state_topic (see value_template and state_off for details) and sending as off command to the command_topic. Defaults to "OFF".

§payload_on: Option<Payload<'a>>

The payload that represents on state. If specified, will be used for both comparing to the value in the state_topic (see value_template and state_on for details) and sending as on command to the command_topic. Defaults to "ON".

§retain: Option<bool>

If the published message should have the retain flag on or not. Defaults to false.

§state_off: Option<Payload<'a>>

The payload that represents the off state. Used when value that represents off state in the state_topic is different from value that should be sent to the command_topic to turn the device off. Defaults to payload_off if defined, else "OFF".

§state_on: Option<Payload<'a>>

The payload that represents the on state. Used when value that represents on state in the state_topic is different from value that should be sent to the command_topic to turn the device on. Defaults to payload_on if defined, else "ON".

§state_topic: Option<Topic<'a>>

The MQTT topic subscribed to receive state updates.

§value_template: Option<Template<'a>>

Defines a template to extract device’s state from the state_topic. To determine the switches’s state result of this template will be compared to state_on and state_off.

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 MQTT topic to publish commands to change the switch state.

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

Flag that defines if switch works in optimistic mode. Defaults to true if no state_topic defined, else false.

Flag that defines if switch works in optimistic mode. Defaults to true if no state_topic defined, else false.

The payload that represents off state. If specified, will be used for both comparing to the value in the state_topic (see value_template and state_off for details) and sending as off command to the command_topic. Defaults to "OFF".

The payload that represents off state. If specified, will be used for both comparing to the value in the state_topic (see value_template and state_off for details) and sending as off command to the command_topic. Defaults to "OFF".

The payload that represents on state. If specified, will be used for both comparing to the value in the state_topic (see value_template and state_on for details) and sending as on command to the command_topic. Defaults to "ON".

The payload that represents on state. If specified, will be used for both comparing to the value in the state_topic (see value_template and state_on for details) and sending as on command to the command_topic. Defaults to "ON".

If the published message should have the retain flag on or not. Defaults to false.

If the published message should have the retain flag on or not. Defaults to false.

The payload that represents the off state. Used when value that represents off state in the state_topic is different from value that should be sent to the command_topic to turn the device off. Defaults to payload_off if defined, else "OFF".

The payload that represents the off state. Used when value that represents off state in the state_topic is different from value that should be sent to the command_topic to turn the device off. Defaults to payload_off if defined, else "OFF".

The payload that represents the on state. Used when value that represents on state in the state_topic is different from value that should be sent to the command_topic to turn the device on. Defaults to payload_on if defined, else "ON".

The payload that represents the on state. Used when value that represents on state in the state_topic is different from value that should be sent to the command_topic to turn the device on. Defaults to payload_on if defined, else "ON".

The MQTT topic subscribed to receive state updates.

The MQTT topic subscribed to receive state updates.

Defines a template to extract device’s state from the state_topic. To determine the switches’s state result of this template will be compared to state_on and state_off.

Defines a template to extract device’s state from the state_topic. To determine the switches’s state result of this template will be compared to state_on and state_off.

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