diff options
author | Ethel Morgan <eth@ethulhu.co.uk> | 2020-06-20 10:09:12 +0100 |
---|---|---|
committer | Ethel Morgan <eth@ethulhu.co.uk> | 2020-06-20 10:09:12 +0100 |
commit | 09bb9e12fcd0336af2a3a9f9aacc6384ac004943 (patch) | |
tree | 8f63a8fadcf3f823c86d06e29cc938065a345687 /cmd/catbus-actuator-wakeonlan/main.go | |
parent | d8d9b04ebbdfff0dd3d952d2658f117d47730c9d (diff) |
move package mqtt to package catbus, make more convenient
Diffstat (limited to 'cmd/catbus-actuator-wakeonlan/main.go')
-rw-r--r-- | cmd/catbus-actuator-wakeonlan/main.go | 80 |
1 files changed, 38 insertions, 42 deletions
diff --git a/cmd/catbus-actuator-wakeonlan/main.go b/cmd/catbus-actuator-wakeonlan/main.go index 53da4d9..37efbbe 100644 --- a/cmd/catbus-actuator-wakeonlan/main.go +++ b/cmd/catbus-actuator-wakeonlan/main.go @@ -9,9 +9,9 @@ import ( "flag" "log" + "go.eth.moe/catbus-wakeonlan/catbus" "go.eth.moe/catbus-wakeonlan/config" "go.eth.moe/catbus-wakeonlan/logger" - "go.eth.moe/catbus-wakeonlan/mqtt" "go.eth.moe/catbus-wakeonlan/wakeonlan" ) @@ -34,52 +34,48 @@ func main() { log.WithError(err).Fatal("could not parse config file") } - log.AddField("broker-uri", config.Broker) + log.AddField("broker-uri", config.BrokerURI) - brokerOptions := mqtt.NewClientOptions() - brokerOptions.AddBroker(config.Broker) - brokerOptions.SetAutoReconnect(true) - brokerOptions.SetConnectionLostHandler(func(_ mqtt.Client, err error) { - log := log - if err != nil { - log = log.WithError(err) - } - log.Error("disconnected from MQTT broker") - }) - brokerOptions.SetOnConnectHandler(func(broker mqtt.Client) { - log.Info("connected to MQTT broker") - - for topic := range config.MACsByTopic { - token := broker.Subscribe(topic, mqtt.AtLeastOnce, func(_ mqtt.Client, msg mqtt.Message) { - if string(msg.Payload()) != "on" { - return - } + catbusOptions := catbus.ClientOptions{ + DisconnectHandler: func(_ *catbus.Client, err error) { + log := log + if err != nil { + log = log.WithError(err) + } + log.Error("disconnected from MQTT broker") + }, + ConnectHandler: func(client *catbus.Client) { + log.Info("connected to MQTT broker") - mac, ok := config.MACsByTopic[msg.Topic()] - if !ok { - return - } + for topic := range config.MACsByTopic { + err := client.Subscribe(topic, func(_ *catbus.Client, msg catbus.Message) { + if string(msg.Payload()) != "on" { + return + } + mac, ok := config.MACsByTopic[msg.Topic()] + if !ok { + return + } - log.AddField("mac", mac) - log.AddField("topic", topic) - if err := wakeonlan.Wake(mac); err != nil { - log.WithError(err).Error("could not send wake-on-lan packet") - return + log.AddField("mac", mac) + log.AddField("topic", topic) + if err := wakeonlan.Wake(mac); err != nil { + log.WithError(err).Error("could not send wake-on-lan packet") + return + } + log.Info("sent wake-on-lan packet") + }) + if err != nil { + log := log.WithError(err) + log.AddField("topic", topic) + log.Error("could not subscribe to MQTT topic") } - log.Info("sent wake-on-lan packet") - }) - if err := token.Error(); err != nil { - log := log.WithError(err) - log.AddField("topic", topic) - log.Error("could not subscribe to MQTT topic") } - } - }) - - broker := mqtt.NewClient(brokerOptions) - if token := broker.Connect(); token.Error() != nil { - log.WithError(token.Error()).Fatal("could not connect to MQTT broker") + }, } + catbus := catbus.NewClient(config.BrokerURI, catbusOptions) - select {} + if err := catbus.Connect(); err != nil { + log.WithError(err).Fatal("could not connect to MQTT broker") + } } |