X-Git-Url: https://git.realraum.at/?p=svn42.git;a=blobdiff_plain;f=r3-webstatus-spaceapi%2Fmain.go;h=77dd32a1e6b17d3fe1c4626140cc6532f6c4913e;hp=f4e4e766d7621d52eb6949ca7daebb188ebc65dd;hb=098333f9a1d3fa389378a212dea39cf48030cd91;hpb=a5a4ac7a8733c31c14065230127c7836ac0de4f6 diff --git a/r3-webstatus-spaceapi/main.go b/r3-webstatus-spaceapi/main.go index f4e4e76..77dd32a 100644 --- a/r3-webstatus-spaceapi/main.go +++ b/r3-webstatus-spaceapi/main.go @@ -2,6 +2,7 @@ package main import ( "./spaceapi" + "./r3xmppbot" "bufio" "fmt" "net" @@ -15,6 +16,8 @@ import ( type SpaceState struct { present bool buttonpress_until int64 + door_locked bool + door_shut bool } var ( @@ -26,6 +29,7 @@ var ( re_querystresc_ *regexp.Regexp = regexp.MustCompile("[^\x30-\x39\x41-\x7E]") spaceapidata spaceapi.SpaceInfo = spaceapi.NewSpaceInfo("realraum", "http://realraum.at", "http://realraum.at/logo-red_250x250.png", "http://realraum.at/logo-re_open_100x100.png", "http://realraum.at/logo-re_empty_100x100.png",47.065779129, 15.442322614).AddSpaceAddress("Jakoministr. 16 ground level left, 8010 Graz, Austria") statusstate *SpaceState = new(SpaceState) + xmpp_presence_events_chan_ chan interface{} ) //------- @@ -75,17 +79,24 @@ func parseSocketInputLine(line string) { if match_presence != nil { statusstate.present = (match_presence[1] == "yes") + statusstate.door_locked = (match_presence[2] == "closed") //spaceapidata.MergeInSensor(spaceapi.MakeDoorLockSensor("Torwaechter", "Front Door", match_presence[2] == "closed")) - spaceapidata.MergeInSensor(spaceapi.MakeDoorLockSensor("TorwaechterLock", "Türschloß", match_presence[2] == "closed")) + spaceapidata.MergeInSensor(spaceapi.MakeDoorLockSensor("TorwaechterLock", "Türschloß", statusstate.door_locked)) publishStateToWeb() + xmpp_presence_events_chan_ <- r3xmppbot.PresenceEvent{statusstate.present, statusstate.door_locked, statusstate.door_shut} } else if match_status != nil { - spaceapidata.MergeInSensor(spaceapi.MakeDoorLockSensor("TorwaechterLock", "Türschloß", match_status[1] == "closed")) - spaceapidata.MergeInSensor(spaceapi.MakeDoorLockSensor("TorwaechterAjarSensor", "Türkontakt", match_status[3] == "shut")) + statusstate.door_locked = (match_status[1] == "closed") + statusstate.door_shut = (match_status[3] == "shut") + spaceapidata.MergeInSensor(spaceapi.MakeDoorLockSensor("TorwaechterLock", "Türschloß", statusstate.door_locked)) + spaceapidata.MergeInSensor(spaceapi.MakeDoorLockSensor("TorwaechterAjarSensor", "Türkontakt", statusstate.door_shut)) //spaceapidata.MergeInSensor(spaceapi.MakeDoorAjarSensor("Torwaechter", "Front Door", match_presence[3] == "shut")) + publishStateToWeb() + xmpp_presence_events_chan_ <- r3xmppbot.PresenceEvent{statusstate.present, statusstate.door_locked, statusstate.door_shut} } else if match_button != nil { statusstate.buttonpress_until = time.Now().Unix() + 3600 spaceapidata.AddSpaceEvent("PanicButton", "check-in", "The button has been pressed") publishStateToWeb() + xmpp_presence_events_chan_ <- "The button has been pressed ! Propably someone is bored and need company ! ;-)" } else if match_temp != nil { newtemp, err := strconv.ParseFloat((match_temp[1]), 32) if err == nil { @@ -122,10 +133,28 @@ ReOpenSocket: } func main() { - spaceapidata.AddSpaceFeed("calendar", "application/rss+xml", "http://grical.realraum.at/s/?query=!realraum&view=rss") - spaceapidata.AddSpaceFeed("google+", "text/html", "https://plus.google.com/113737596421797426873") + spaceapidata.AddSpaceFeed("calendar", "http://grical.realraum.at/s/?query=!realraum&view=rss") + spaceapidata.AddSpaceFeed("blog", "https://plus.google.com/113737596421797426873") + spaceapidata.AddSpaceFeed("wiki", "http://realraum.at/wiki") spaceapidata.AddSpaceContactInfo("+43780700888524", "irc://irc.oftc.net/#realraum", "realraum@realraum.at", "realraum@realraum.at", "realraum@realraum.at", "vorstand@realraum.at") - eventqueue := make(chan string) + + var err error + var bot *r3xmppbot.XmppBot + bot, xmpp_presence_events_chan_, err = r3xmppbot.NewStartedBot("realrauminfo@realraum.at/Tuer", "d7ynC6Dg", "r3alraumOLGAXMPPInfos", true) + if err != nil { + fmt.Println(err) + return + } + defer bot.StopBot() + + //~ presence_events <- PresenceEvent{true, true, true} + //~ presence_events <- PresenceEvent{true, true, false} + //~ presence_events <- PresenceEvent{true, false, false} + + + eventqueue := make(chan string) + defer close(eventqueue) + ticker := time.NewTicker(time.Duration(7) * time.Minute) go readFromUSocket("/var/run/tuer/presence.socket", eventqueue) for {