+ last_frontdoor_ajar = event
+ case r3events.BackdoorAjarUpdate:
+ xmpp_presence_events_chan <- r3xmppbot.XMPPMsgEvent{Msg: fmt.Sprintf("Backdoor is %s (%s)",IfThenElseStr(event.Shut,"now shut.","ajar!"),time.Unix(event.Ts,0).String()), DistributeLevel: standard_distribute_level, RememberAsStatus: false}
+ case r3events.GasLeakAlert:
+ xmpp_presence_events_chan <- r3xmppbot.XMPPMsgEvent{Msg: fmt.Sprintf("ALERT !! GasLeak Detected !!! (%s)", time.Unix(event.Ts,0).String()), DistributeLevel: r3xmppbot.R3NeverInfo, RememberAsStatus: false}
+ case r3events.IlluminationSensorUpdate:
+ light_lothr = event.Value
+ case r3events.TempSensorUpdate:
+ if event.Sensorindex == 1 {
+ temp_cx = event.Value
+ }
+ case r3events.BoreDoomButtonPressEvent:
+ last_buttonpress = event.Ts
+ xmpp_presence_events_chan <- composePresence(present, temp_cx, light_lothr, last_buttonpress)
+ xmpp_presence_events_chan <- r3xmppbot.XMPPMsgEvent{Msg: button_msg, DistributeLevel: standard_distribute_level}
+ case r3events.TimeTick:
+ // update presence text with sensor and button info
+ xmpp_presence_events_chan <- composePresence(present, temp_cx, light_lothr, last_buttonpress)
+ // Try to XMPP Ping the server and if that fails, quit XMPPBot
+ if bot.PingServer(900) == false && bot.PingServer(900) == false && bot.PingServer(900) == false && bot.PingServer(900) == false && bot.PingServer(900) == false { return }
+ case r3events.DoorProblemEvent:
+ xmpp_presence_events_chan <- r3xmppbot.XMPPMsgEvent{Msg: fmt.Sprintf("Door Problem: %s. SeverityLevel: %d (%s)",event.Problem, event.Severity, time.Unix(event.Ts,0).String()), DistributeLevel: r3xmppbot.R3OnlineOnlyInfo, RememberAsStatus: false}