2022-04-21 10:47:05 +10:00
package mmHa
import (
"encoding/json"
2022-12-13 22:25:28 +11:00
"github.com/MickMake/GoUnify/Only"
2022-12-19 22:11:22 +11:00
"strings"
2022-04-21 10:47:05 +10:00
)
2022-12-19 22:11:22 +11:00
const LabelLight = "light"
2022-04-21 10:47:05 +10:00
2022-10-11 17:26:26 +11:00
func ( m * Mqtt ) PublishLightConfig ( config EntityConfig ) error {
// func (m *Mqtt) PublishLightConfig(id string, name string, subName string, units string, valueName string, class string) error {
2022-04-21 10:47:05 +10:00
for range Only . Once {
2022-10-11 17:26:26 +11:00
config . FixConfig ( )
if ! config . IsLight ( ) {
break
}
ok , newDevice := m . NewDevice ( config )
if ! ok {
break
}
id := JoinStringsForId ( m . DeviceName , config . FullId )
2022-04-21 10:47:05 +10:00
payload := Light {
2022-10-11 17:26:26 +11:00
Device : newDevice ,
2022-12-19 22:11:22 +11:00
Name : String ( JoinStrings ( m . DeviceName , config . Name ) ) ,
StateTopic : String ( JoinStringsForTopic ( m . Prefix , LabelLight , m . ClientId , id , "state" ) ) ,
UniqueId : String ( id ) ,
ObjectId : String ( id ) ,
2022-10-11 17:26:26 +11:00
// StateClass: config.StateClass,
// UniqueId: id,
// UnitOfMeasurement: config.Units,
// DeviceClass: config.DeviceClass,
// Qos: 0,
// ForceUpdate: true,
// ExpireAfter: 0,
// Encoding: "utf-8",
// EnabledByDefault: true,
PayloadOn : "true" ,
PayloadOff : "false" ,
// LastResetValueTemplate: config.LastResetValueTemplate,
2022-12-19 22:11:22 +11:00
StateValueTemplate : String ( config . ValueTemplate ) ,
Icon : Icon ( config . Icon ) ,
2022-04-21 10:47:05 +10:00
}
2022-10-11 17:26:26 +11:00
// m.client.Publish(JoinStringsForTopic(m.lightPrefix, id, "config"), 0, true, payload.Json())
2022-12-19 22:11:22 +11:00
tag := JoinStringsForTopic ( m . Prefix , LabelLight , m . ClientId , id , "config" )
2022-10-11 17:26:26 +11:00
t := m . client . Publish ( tag , 0 , true , payload . Json ( ) )
2022-04-21 10:47:05 +10:00
if ! t . WaitTimeout ( m . Timeout ) {
m . err = t . Error ( )
}
}
return m . err
}
2022-10-11 17:26:26 +11:00
func ( m * Mqtt ) LightPublishValue ( config EntityConfig ) error {
2022-04-21 10:47:05 +10:00
for range Only . Once {
2022-10-11 17:26:26 +11:00
if ! config . IsLight ( ) {
break
}
2022-12-19 22:11:22 +11:00
if config . IgnoreUpdate {
break
}
2022-10-11 17:26:26 +11:00
id := JoinStringsForId ( m . DeviceName , config . FullId )
2022-12-19 22:11:22 +11:00
tag := JoinStringsForTopic ( m . Prefix , LabelLight , m . ClientId , id , "state" )
value := config . Value . String ( )
if value == "--" {
value = ""
}
// @TODO - Real hack here. Need to properly check for JSON.
2022-12-20 20:28:51 +11:00
if strings . Contains ( value , ` { ` ) || strings . Contains ( value , ` ": ` ) {
t := m . client . Publish ( tag , 0 , true , value )
2022-12-19 22:11:22 +11:00
if ! t . WaitTimeout ( m . Timeout ) {
m . err = t . Error ( )
}
break
}
2022-10-11 17:26:26 +11:00
payload := MqttState {
2022-12-19 22:11:22 +11:00
LastReset : config . LastReset , // m.GetLastReset(config.FullId),
Value : value ,
2022-10-11 17:26:26 +11:00
}
2022-12-19 22:11:22 +11:00
2022-10-11 17:26:26 +11:00
t := m . client . Publish ( tag , 0 , true , payload . Json ( ) )
2022-04-21 10:47:05 +10:00
if ! t . WaitTimeout ( m . Timeout ) {
m . err = t . Error ( )
}
}
2022-10-11 17:26:26 +11:00
2022-04-21 10:47:05 +10:00
return m . err
}
2022-03-02 14:32:56 +11:00
2022-12-19 22:11:22 +11:00
type Light struct {
// A list of MQTT topics subscribed to receive availability (online/offline) updates. Must not be used together with availability_topic.
Availability * Availability ` json:"availability,omitempty" `
2022-10-11 17:26:26 +11:00
2022-12-19 22:11:22 +11:00
// When availability is configured, this controls the conditions needed to set the entity to available. Valid entries are all, any, and latest. If set to all, payload_available must be received on all configured availability topics before the entity is marked as online. If set to any, payload_available must be received on at least one configured availability topic before the entity is marked as online. If set to latest, the last payload_available or payload_not_available received on any configured availability topic controls the availability.
AvailabilityMode String ` json:"availability_mode,omitempty" default:"latest" `
2022-03-02 14:32:56 +11:00
2022-12-19 22:11:22 +11:00
// Defines a template to extract device’ s availability from the availability_topic. To determine the devices’ s availability result of this template will be compared to payload_available and payload_not_available.
AvailabilityTemplate Template ` json:"availability_template,omitempty" `
// The MQTT topic subscribed to receive availability (online/offline) updates. Must not be used together with availability.
AvailabilityTopic String ` json:"availability_topic,omitempty" `
// The MQTT topic to publish commands to change the light’ s brightness.
BrightnessCommandTopic String ` json:"brightness_command_topic,omitempty" `
// Defines a template to compose message which will be sent to brightness_command_topic. Available variables: value.
BrightnessCommandTemplate String ` json:"brightness_command_template,omitempty" `
// Defines the maximum brightness value (i.e., 100%) of the MQTT device.
BrightnessScale Integer ` json:"brightness_scale,omitempty" default:"255" `
// The MQTT topic subscribed to receive brightness state updates.
BrightnessStateTopic String ` json:"brightness_state_topic,omitempty" `
// Defines a template to extract the brightness value.
BrightnessValueTemplate String ` json:"brightness_value_template,omitempty" `
// The MQTT topic subscribed to receive color mode updates. If this is not configured, color_mode will be automatically set according to the last received valid color or color temperature
ColorModeStateTopic String ` json:"color_mode_state_topic,omitempty" `
// Defines a template to extract the color mode.
ColorModeValueTemplate String ` json:"color_mode_value_template,omitempty" `
// Defines a template to compose message which will be sent to color_temp_command_topic. Available variables: value.
ColorTempCommandTemplate String ` json:"color_temp_command_template,omitempty" `
// The MQTT topic to publish commands to change the light’ s color temperature state. The color temperature command slider has a range of 153 to 500 mireds (micro reciprocal degrees).
ColorTempCommandTopic String ` json:"color_temp_command_topic,omitempty" `
// The MQTT topic subscribed to receive color temperature state updates.
ColorTempStateTopic String ` json:"color_temp_state_topic,omitempty" `
// Defines a template to extract the color temperature value.
ColorTempValueTemplate String ` json:"color_temp_value_template,omitempty" `
// The MQTT topic to publish commands to change the switch state.
CommandTopic String ` json:"command_topic,omitempty" required:"true" `
// Information about the device this light 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.
Device Device ` json:"device,omitempty" `
// Flag which defines if the entity should be enabled when first added.
EnabledByDefault Boolean ` json:"enabled_by_default,omitempty" default:"true" `
// The encoding of the payloads received and published messages. Set to "" to disable decoding of incoming payload.
Encoding String ` json:"encoding,omitempty" default:"utf" `
// The category of the entity.
EntityCategory String ` json:"entity_category,omitempty" default:"None" `
// The MQTT topic to publish commands to change the light’ s effect state.
EffectCommandTopic String ` json:"effect_command_topic,omitempty" `
// Defines a template to compose message which will be sent to effect_command_topic. Available variables: value.
EffectCommandTemplate String ` json:"effect_command_template,omitempty" `
// effect_list string | list (optional)
// The list of effects the light supports.
// The MQTT topic subscribed to receive effect state updates.
EffectStateTopic String ` json:"effect_state_topic,omitempty" `
// Defines a template to extract the effect value.
EffectValueTemplate String ` json:"effect_value_template,omitempty" `
// The MQTT topic to publish commands to change the light’ s color state in HS format (Hue Saturation). Range for Hue: 0° .. 360°, Range of Saturation: 0..100. Note: Brightness is sent separately in the brightness_command_topic.
HsCommandTopic String ` json:"hs_command_topic,omitempty" `
// The MQTT topic subscribed to receive color state updates in HS format. Note: Brightness is received separately in the brightness_state_topic.
HsStateTopic String ` json:"hs_state_topic,omitempty" `
// Defines a template to extract the HS value.
HsValueTemplate String ` json:"hs_value_template,omitempty" `
// Icon for the entity.
Icon Icon ` json:"icon,omitempty" `
// Defines a template to extract the JSON dictionary from messages received on the json_attributes_topic. Usage example can be found in MQTT sensor documentation.
JsonAttributesTemplate Template ` json:"json_attributes_template,omitempty" `
// The MQTT topic subscribed to receive a JSON dictionary payload and then set as sensor attributes. Usage example can be found in MQTT sensor documentation.
JsonAttributesTopic String ` json:"json_attributes_topic,omitempty" `
// The maximum color temperature in mireds.
MaxMireds Integer ` json:"max_mireds,omitempty" `
// The minimum color temperature in mireds.
MinMireds Integer ` json:"min_mireds,omitempty" `
// The name of the light.
Name String ` json:"name,omitempty" default:"MQTT" `
// Used instead of name for automatic generation of entity_id
ObjectId String ` json:"object_id,omitempty" `
// Defines when on the payload_on is sent. Using last (the default) will send any style (brightness, color, etc) topics first and then a payload_on to the command_topic. Using first will send the payload_on and then any style topics. Using brightness will only send brightness commands instead of the payload_on to turn the light on.
OnCommandType String ` json:"on_command_type,omitempty" `
// Flag that defines if switch works in optimistic mode.
Optimistic Boolean ` json:"optimistic,omitempty" `
// Default: true if no state topic defined, else false.
// The payload that represents the available state.
PayloadAvailable String ` json:"payload_available,omitempty" default:"online" `
// The payload that represents the unavailable state.
PayloadNotAvailable String ` json:"payload_not_available,omitempty" default:"offline" `
// The payload that represents disabled state.
PayloadOff String ` json:"payload_off,omitempty" default:"OFF" `
// The payload that represents enabled state.
PayloadOn String ` json:"payload_on,omitempty" default:"ON" `
// The maximum QoS level of the state topic.
Qos Integer ` json:"qos,omitempty" default:"0" `
// If the published message should have the retain flag on or not.
Retain Boolean ` json:"retain,omitempty" default:"false" `
// Defines a template to compose message which will be sent to rgb_command_topic. Available variables: red, green and blue.
RgbCommandTemplate String ` json:"rgb_command_template,omitempty" `
// The MQTT topic to publish commands to change the light’ s RGB state.
RgbCommandTopic String ` json:"rgb_command_topic,omitempty" `
// The MQTT topic subscribed to receive RGB state updates. The expected payload is the RGB values separated by commas, for example, 255,0,127.
RgbStateTopic String ` json:"rgb_state_topic,omitempty" `
// Defines a template to extract the RGB value.
RgbValueTemplate String ` json:"rgb_value_template,omitempty" `
// Defines a template to compose message which will be sent to rgbw_command_topic. Available variables: red, green, blue and white.
RgbwCommandTemplate String ` json:"rgbw_command_template,omitempty" `
// The MQTT topic to publish commands to change the light’ s RGBW state.
RgbwCommandTopic String ` json:"rgbw_command_topic,omitempty" `
// The MQTT topic subscribed to receive RGBW state updates. The expected payload is the RGBW values separated by commas, for example, 255,0,127,64.
RgbwStateTopic String ` json:"rgbw_state_topic,omitempty" `
// Defines a template to extract the RGBW value.
RgbwValueTemplate String ` json:"rgbw_value_template,omitempty" `
// Defines a template to compose message which will be sent to rgbww_command_topic. Available variables: red, green, blue, cold_white and warm_white.
RgbwwCommandTemplate String ` json:"rgbww_command_template,omitempty" `
// The MQTT topic to publish commands to change the light’ s RGBWW state.
RgbwwCommandTopic String ` json:"rgbww_command_topic,omitempty" `
// The MQTT topic subscribed to receive RGBWW state updates. The expected payload is the RGBWW values separated by commas, for example, 255,0,127,64,32.
RgbwwStateTopic String ` json:"rgbww_state_topic,omitempty" `
// Defines a template to extract the RGBWW value.
RgbwwValueTemplate String ` json:"rgbww_value_template,omitempty" `
// The schema to use. Must be default or omitted to select the default schema.
Schema String ` json:"schema,omitempty" default:"default" `
// The MQTT topic subscribed to receive state updates.
StateTopic String ` json:"state_topic,omitempty" `
// Defines a template to extract the state value. The template should match the payload on and off values, so if your light uses power on to turn on, your state_value_template string should return power on when the switch is on. For example if the message is just on, your state_value_template should be power .
StateValueTemplate String ` json:"state_value_template,omitempty" `
// An ID that uniquely identifies this light. If two lights have the same unique ID, Home Assistant will raise an exception.
UniqueId String ` json:"unique_id,omitempty" `
// The MQTT topic to publish commands to change the light to white mode with a given brightness.
WhiteCommandTopic String ` json:"white_command_topic,omitempty" `
// Defines the maximum white level (i.e., 100%) of the MQTT device.
WhiteScale Integer ` json:"white_scale,omitempty" default:"255" `
// The MQTT topic to publish commands to change the light’ s XY state.
XyCommandTopic String ` json:"xy_command_topic,omitempty" `
// The MQTT topic subscribed to receive XY state updates.
XyStateTopic String ` json:"xy_state_topic,omitempty" `
// Defines a template to extract the XY value.
XyValueTemplate String ` json:"xy_value_template,omitempty" `
2022-03-02 14:32:56 +11:00
}
2022-12-19 22:11:22 +11:00
// type Light struct {
// // availability list (optional)
// // A list of MQTT topics subscribed to receive availability (online/offline) updates. Must not be used together with availability_topic.
// Availability *Availability `json:"availability,omitempty" required:"false"`
//
// // availability_mode string (optional, default: latest)
// // When availability is configured, this controls the conditions needed to set the entity to available. Valid entries are all, any, and latest. If set to all, payload_available must be received on all configured availability topics before the entity is marked as online. If set to any, payload_available must be received on at least one configured availability topic before the entity is marked as online. If set to latest, the last payload_available or payload_not_available received on any configured availability topic controls the availability.
// AvailabilityMode string `json:"availability_mode,omitempty" required:"false"`
//
// // availability_template template (optional)
// // Defines a template to extract device’ s availability from the availability_topic. To determine the devices’ s availability result of this template will be compared to payload_available and payload_not_available.
// AvailabilityTemplate string `json:"availability_template,omitempty" required:"false"`
//
// // availability_topic string (optional)
// // The MQTT topic subscribed to receive availability (online/offline) updates. Must not be used together with availability.
// AvailabilityTopic string `json:"availability_topic,omitempty" required:"false"`
//
// // brightness_command_topic string (optional)
// // The MQTT topic to publish commands to change the light’ s brightness.
// BrightnessCommandTopic string `json:"brightness_command_topic,omitempty"`
//
// // brightness_command_template string (optional)
// // Defines a template to compose message which will be sent to brightness_command_topic. Available variables: value.
// BrightnessCommandTemplate string `json:"brightness_command_template,omitempty"`
//
// // brightness_scale integer (optional, default: 255)
// // Defines the maximum brightness value (i.e., 100%) of the MQTT device.
// BrightnessScale int `json:"brightness_scale,omitempty"`
//
// // brightness_state_topic string (optional)
// // The MQTT topic subscribed to receive brightness state updates.
// BrightnessStateTopic string `json:"brightness_state_topic,omitempty"`
//
// // brightness_value_template string (optional)
// // Defines a template to extract the brightness value.
// BrightnessValueTemplate string `json:"brightness_value_template,omitempty"`
//
// // color_mode_state_topic string (optional)
// // The MQTT topic subscribed to receive color mode updates. If this is not configured, color_mode will be automatically set according to the last received valid color or color temperature
// ColorModeStateTopic string `json:"color_mode_state_topic,omitempty"`
//
// // color_mode_value_template string (optional)
// // Defines a template to extract the color mode.
// ColorModeValueTemplate string `json:"color_mode_value_template,omitempty"`
//
// // color_temp_command_template string (optional)
// // Defines a template to compose message which will be sent to color_temp_command_topic. Available variables: value.
// ColorTempCommandTemplate string `json:"color_temp_command_template,omitempty"`
//
// // color_temp_command_topic string (optional)
// // The MQTT topic to publish commands to change the light’ s color temperature state. The color temperature command slider has a range of 153 to 500 mireds (micro reciprocal degrees).
// ColorTempCommandTopic string `json:"color_temp_command_topic,omitempty"`
//
// // color_temp_state_topic string (optional)
// // The MQTT topic subscribed to receive color temperature state updates.
// ColorTempStateTopic string `json:"color_temp_state_topic,omitempty"`
//
// // color_temp_value_template string (optional)
// // Defines a template to extract the color temperature value.
// ColorTempValueTemplate string `json:"color_temp_value_template,omitempty"`
// // CommandTemplate string `json:"command_template" required:"false"`
//
// // command_topic string REQUIRED
// // The MQTT topic to publish commands to change the switch state.
// CommandTopic string `json:"command_topic" required:"true"`
//
// // device map (optional)
// // Information about the device this light 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.
// Device Device `json:"device,omitempty" required:"false"`
//
// // enabled_by_default boolean (optional, default: true)
// // Flag which defines if the entity should be enabled when first added.
// EnabledByDefault bool `json:"enabled_by_default,omitempty" required:"false"`
//
// // encoding string (optional, default: utf-8)
// // The encoding of the payloads received and published messages. Set to "" to disable decoding of incoming payload.
// Encoding string `json:"encoding,omitempty" required:"false"`
//
// // entity_category string (optional, default: None)
// // The category of the entity.
// EntityCategory string `json:"entity_category,omitempty" required:"false"`
//
// // effect_command_template string (optional)
// // Defines a template to compose message which will be sent to effect_command_topic. Available variables: value.
// EffectCommandTemplate string `json:"effect_command_template" required:"true"`
//
// // effect_command_topic string (optional)
// // The MQTT topic to publish commands to change the light’ s effect state.
// EffectCommandTopic string `json:"effect_command_topic,omitempty"`
//
// // effect_list string | list (optional)
// // The list of effects the light supports.
// EffectList []string `json:"effect_list,omitempty"`
//
// // effect_state_topic string (optional)
// // The MQTT topic subscribed to receive effect state updates.
// EffectStateTopic string `json:"effect_state_topic,omitempty"`
//
// // effect_value_template string (optional)
// // Defines a template to extract the effect value.
// EffectValueTemplate string `json:"effect_value_template,omitempty"`
//
// // hs_command_topic string (optional)
// // The MQTT topic to publish commands to change the light’ s color state in HS format (Hue Saturation). Range for Hue: 0° .. 360°, Range of Saturation: 0..100. Note: Brightness is sent separately in the brightness_command_topic.
// HsCommandTopic string `json:"hs_command_topic,omitempty"`
//
// // hs_state_topic string (optional)
// // The MQTT topic subscribed to receive color state updates in HS format. Note: Brightness is received separately in the brightness_state_topic.
// HsStateTopic string `json:"hs_state_topic,omitempty"`
//
// // hs_value_template string (optional)
// // Defines a template to extract the HS value.
// HsValueTemplate string `json:"hs_value_template,omitempty"`
//
// // icon string (optional)
// // Icon for the entity.
// Icon string `json:"icon,omitempty" required:"false"`
//
// // json_attributes_template template (optional)
// // Defines a template to extract the JSON dictionary from messages received on the json_attributes_topic. Usage example can be found in MQTT sensor documentation.
// JsonAttributesTemplate string `json:"json_attributes_template,omitempty" required:"false"`
//
// // json_attributes_topic string (optional)
// // The MQTT topic subscribed to receive a JSON dictionary payload and then set as sensor attributes. Usage example can be found in MQTT sensor documentation.
// JsonAttributesTopic string `json:"json_attributes_topic,omitempty" required:"false"`
//
// // max_mireds integer (optional)
// // The maximum color temperature in mireds.
// MaxMireds int `json:"max_mireds,omitempty"`
//
// // min_mireds integer (optional)
// // The minimum color temperature in mireds.
// MinMireds int `json:"min_mireds,omitempty"`
//
// // name string (optional, default: MQTT Light)
// // The name of the light.
// Name string `json:"name,omitempty" required:"false"`
//
// // object_id string (optional)
// // Used instead of name for automatic generation of entity_id
// ObjectId string `json:"object_id,omitempty" required:"false"`
//
// // on_command_type string (optional)
// // Defines when on the payload_on is sent. Using last (the default) will send any style (brightness, color, etc) topics first and then a payload_on to the command_topic. Using first will send the payload_on and then any style topics. Using brightness will only send brightness commands instead of the payload_on to turn the light on.
// OnCommandType string `json:"on_command_type,omitempty"`
//
// // optimistic boolean (optional)
// // Flag that defines if switch works in optimistic mode.
// // Default: true if no state topic defined, else false.
// Optimistic bool `json:"optimistic,omitempty" required:"false"`
//
// // payload_available string (optional, default: online)
// // The payload that represents the available state.
// PayloadAvailable string `json:"payload_available,omitempty"`
//
// // payload_not_available string (optional, default: offline)
// // The payload that represents the unavailable state.
// PayloadNotAvailable string `json:"payload_not_available,omitempty"`
//
// // payload_off string (optional, default: OFF)
// // The payload that represents disabled state.
// PayloadOff string `json:"payload_off,omitempty"`
//
// // payload_on string (optional, default: ON)
// // The payload that represents enabled state.
// PayloadOn string `json:"payload_on,omitempty"`
//
// // qos integer (optional, default: 0)
// // The maximum QoS level of the state topic.
// Qos int `json:"qos,omitempty" required:"false"`
//
// // retain boolean (optional, default: false)
// // If the published message should have the retain flag on or not.
// Retain bool `json:"retain,omitempty" required:"false"`
//
// // rgb_command_template string (optional)
// // Defines a template to compose message which will be sent to rgb_command_topic. Available variables: red, green and blue.
// RgbCommandTemplate string `json:"rgb_command_template,omitempty"`
//
// // rgb_command_topic string (optional)
// // The MQTT topic to publish commands to change the light’ s RGB state.
// RgbCommandTopic string `json:"rgb_command_topic,omitempty"`
//
// // rgb_state_topic string (optional)
// // The MQTT topic subscribed to receive RGB state updates. The expected payload is the RGB values separated by commas, for example, 255,0,127.
// RgbStateTopic string `json:"rgb_state_topic,omitempty"`
//
// // rgb_value_template string (optional)
// // Defines a template to extract the RGB value.
// RgbValueTemplate string `json:"rgb_value_template,omitempty"`
//
// // rgbw_command_template string (optional)
// // Defines a template to compose message which will be sent to rgbw_command_topic. Available variables: red, green, blue and white.
// RgbwCommandTemplate string `json:"rgbw_command_template,omitempty"`
//
// // rgbw_command_topic string (optional)
// // The MQTT topic to publish commands to change the light’ s RGBW state.
// RgbwCommandTopic string `json:"rgbw_command_topic,omitempty"`
//
// // rgbw_state_topic string (optional)
// // The MQTT topic subscribed to receive RGBW state updates. The expected payload is the RGBW values separated by commas, for example, 255,0,127,64.
// RgbwStateTopic string `json:"rgbw_state_topic,omitempty"`
//
// // rgbw_value_template string (optional)
// // Defines a template to extract the RGBW value.
// RgbwValueTemplate string `json:"rgbw_value_template,omitempty"`
//
// // rgbww_command_template string (optional)
// // Defines a template to compose message which will be sent to rgbww_command_topic. Available variables: red, green, blue, cold_white and warm_white.
// RgbwwCommandTemplate string `json:"rgbww_command_template,omitempty"`
//
// // rgbww_command_topic string (optional)
// // The MQTT topic to publish commands to change the light’ s RGBWW state.
// RgbwwCommandTopic string `json:"rgbww_command_topic,omitempty"`
//
// // rgbww_state_topic string (optional)
// // The MQTT topic subscribed to receive RGBWW state updates. The expected payload is the RGBWW values separated by commas, for example, 255,0,127,64,32.
// RgbwwStateTopic string `json:"rgbww_state_topic,omitempty"`
//
// // rgbww_value_template string (optional)
// // Defines a template to extract the RGBWW value.
// RgbwwValueTemplate string `json:"rgbww_value_template,omitempty"`
//
// // schema string (optional, default: default)
// // The schema to use. Must be default or omitted to select the default schema.
// Schema string `json:"schema,omitempty"`
//
// // state_topic string (optional)
// // The MQTT topic subscribed to receive state updates.
// StateTopic string `json:"state_topic,omitempty" required:"false"`
//
// // state_value_template string (optional)
// // Defines a template to extract the state value. The template should match the payload on and off values, so if your light uses power on to turn on, your state_value_template string should return power on when the switch is on. For example if the message is just on, your state_value_template should be power .
// StateValueTemplate string `json:"state_value_template,omitempty"`
//
// // unique_id string (optional)
// // An ID that uniquely identifies this light. If two lights have the same unique ID, Home Assistant will raise an exception.
// UniqueId string `json:"unique_id,omitempty" required:"false"`
//
// // white_command_topic string (optional)
// // The MQTT topic to publish commands to change the light to white mode with a given brightness.
// WhiteCommandTopic string `json:"white_command_topic,omitempty"`
//
// // white_scale integer (optional, default: 255)
// // Defines the maximum white level (i.e., 100%) of the MQTT device.
// WhiteScale int `json:"white_scale,omitempty"`
//
// // xy_command_topic string (optional)
// // The MQTT topic to publish commands to change the light’ s XY state.
// XyCommandTopic string `json:"xy_command_topic,omitempty"`
//
// // xy_state_topic string (optional)
// // The MQTT topic subscribed to receive XY state updates.
// XyStateTopic string `json:"xy_state_topic,omitempty"`
//
// // xy_value_template string (optional)
// // Defines a template to extract the XY value.
// XyValueTemplate string `json:"xy_value_template,omitempty"`
//
// // WhiteValueCommandTopic string `json:"white_value_command_topic,omitempty"`
// // WhiteValueScale int `json:"white_value_scale,omitempty"`
// // WhiteValueStateTopic string `json:"white_value_state_topic,omitempty"`
// // WhiteValueTemplate string `json:"white_value_template,omitempty"`
// // ValueTemplate string `json:"value_template,omitempty" required:"false"`
//
// // BrightnessStateFunc func() string `json:"-"`
// // ColorTempStateFunc func() string `json:"-"`
// // EffectStateFunc func() string `json:"-"`
// // HsStateFunc func() string `json:"-"`
// // RgbStateFunc func() string `json:"-"`
// // StateFunc func() string `json:"-"`
// // WhiteValueStateFunc func() string `json:"-"`
// // XyStateFunc func() string `json:"-"`
// //
// // BrightnessCommandFunc func(mqtt.Message, mqtt.Client) `json:"-"`
// // ColorTempCommandFunc func(mqtt.Message, mqtt.Client) `json:"-"`
// // CommandFunc func(mqtt.Message, mqtt.Client) `json:"-"`
// // EffectCommandFunc func(mqtt.Message, mqtt.Client) `json:"-"`
// // HsCommandFunc func(mqtt.Message, mqtt.Client) `json:"-"`
// // RgbCommandFunc func(mqtt.Message, mqtt.Client) `json:"-"`
// // WhiteValueCommandFunc func(mqtt.Message, mqtt.Client) `json:"-"`
// // XyCommandFunc func(mqtt.Message, mqtt.Client) `json:"-"`
// //
// // UpdateInterval float64 `json:"-"`
// // ForceUpdateMQTT bool `json:"-"`
// //
// // messageHandler mqtt.MessageHandler
// }
2022-04-21 10:47:05 +10:00
func ( c * Light ) Json ( ) string {
j , _ := json . Marshal ( * c )
return string ( j )
}
2022-12-19 22:11:22 +11:00
func ( config * EntityConfig ) IsLight ( ) bool {
var ok bool
for range Only . Once {
if config . Units == LabelLight {
ok = true
break
}
}
return ok
}
2022-03-02 14:32:56 +11:00
// {
// "brightness": true,
// "cmd_t": "homeassistant/light/cbus_20/set",
// "device": {
// "connections": [
// [
// "cbus_group_address",
// "20"
// ]
// ],
// "identifiers": [
// "cbus_light_20"
// ],
// "manufacturer": "Clipsal",
// "model": "C-Bus Lighting Application",
// "name": "C-Bus Light 020",
// "sw_version": "cmqttd https://github.com/micolous/cbus",
// "via_device": "cmqttd"
// },
// "name": "C-Bus Light 020",
// "schema": "json",
// "stat_t": "homeassistant/light/cbus_20/state",
// "unique_id": "cbus_light_20"
// }
//
// type LightConfig struct {
// Name string `json:"name"`
// UniqueId string `json:"unique_id"`
// CmdT string `json:"cmd_t"`
// StatT string `json:"stat_t"`
// Schema string `json:"schema"`
// Brightness bool `json:"brightness"`
// LightDevice LightDevice `json:"device"`
// }
// type LightDevice struct {
// Identifiers []string `json:"identifiers"`
// Connections [][]string `json:"connections"`
// SwVersion string `json:"sw_version"`
// Name string `json:"name"`
// Manufacturer string `json:"manufacturer"`
// Model string `json:"model"`
// ViaDevice string `json:"via_device"`
// }
// {
// "brightness": 255,
// "cbus_source_addr": 7,
// "state": "ON",
// "transition": 0
// }
// type LightState struct {
// State string `json:"state"`
// Brightness int `json:"brightness"`
// Transition int `json:"transition"`
// CbusSourceAddr int `json:"cbus_source_addr"`
// }