X-Git-Url: https://git.realraum.at/?a=blobdiff_plain;f=go%2Fr3-netstatus%2Fwebstatus.go;fp=go%2Fr3-netstatus%2Fwebstatus.go;h=d303b13080de4230c5e51c230ba170ad6e9d4377;hb=70bd6ea215fdd1dbd2eb9556ff4aa0a2acde24bc;hp=0000000000000000000000000000000000000000;hpb=4c36e4d9f491d1f75295e7c8a3c31e5aaa59acc8;p=svn42.git diff --git a/go/r3-netstatus/webstatus.go b/go/r3-netstatus/webstatus.go new file mode 100644 index 0000000..d303b13 --- /dev/null +++ b/go/r3-netstatus/webstatus.go @@ -0,0 +1,95 @@ +package main + +import ( + pubsub "github.com/tuxychandru/pubsub" + "./spaceapi" + "regexp" + "net/http" + "net/url" + "log" + "time" + ) + + +type spaceState struct { + present bool + buttonpress_until int64 +} + +var ( + 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.065554, 15.450435).AddSpaceAddress("Brockmanngasse 15, 8010 Graz, Austria") + statusstate *spaceState = new(spaceState) + re_querystresc_ *regexp.Regexp = regexp.MustCompile("[^\x30-\x39\x41-\x7E]") +) + + +func init() { + 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") +} + + +func updateStatusString() { + var spacestatus string + if statusstate.present { + if statusstate.buttonpress_until > time.Now().Unix() { + spacestatus = "Panic! Present&Bored" + } else { + spacestatus = "Leute Anwesend" + } + } else { + spacestatus = "Keiner Da" + } + spaceapidata.SetStatus(statusstate.present, spacestatus) +} + +func publishStateToWeb() { + updateStatusString() + jsondata_b, err := spaceapidata.MakeJSON() + if err != nil { + log.Println("Error:", err) + return + } + //jsondata_b := re_querystresc_.ReplaceAllFunc(jsondata_b, func(in []byte) []byte { + // out := make([]byte, 4) + // out[0] = '%' + // copy(out[1:], []byte(strconv.FormatInt(int64(in[0]), 16))) + // return out + //}) + jsondata := url.QueryEscape(string(jsondata_b)) + resp, err := http.Get("http://www.realraum.at/cgi/status.cgi?pass=jako16&set=" + jsondata) + if err != nil { + log.Println("Error publishing realraum info", err) + return + } + resp.Body.Close() +} + +func EventToWeb(ps *pubsub.PubSub) { + events := ps.Sub("presence","door","sensors","buttons","updateinterval") + + for eventinterface := range(events) { + switch event := eventinterface.(type) { + case TimeTick: + publishStateToWeb() + case PresenceUpdate: + statusstate.present = event.Present + publishStateToWeb() + case DoorStatusUpdate: + spaceapidata.MergeInSensor(spaceapi.MakeDoorLockSensor("TorwaechterLock", "Türschloß", event.Locked)) + spaceapidata.MergeInSensor(spaceapi.MakeDoorLockSensor("TorwaechterAjarSensor", "Türkontakt", event.Shut)) + publishStateToWeb() + case ButtonPressUpdate: + statusstate.buttonpress_until = event.Ts + 3600 + spaceapidata.AddSpaceEvent("PanicButton", "check-in", "The button has been pressed") + publishStateToWeb() + case TempSensorUpdate: + spaceapidata.MergeInSensor(spaceapi.MakeTempCSensor("Temp0","Decke", event.Value)) + case IlluminationSensorUpdate: + spaceapidata.MergeInSensor(spaceapi.MakeIlluminationSensor("Photodiode","Decke","1024V/5V", event.Value)) + } + } +} +