Mercurial > code > home > repos > homeauto
view service/wallscreen/wallscreen.py @ 1229:02e4b84821d5
talk to store graph, second button for holding unlocked, etc
Ignore-this: c2ae7d756e743c26e5e01d99772899bd
darcs-hash:a0750d0bbc4dc7c0f65f63f3e7342b35a175141b
author | drewp <drewp@bigasterisk.com> |
---|---|
date | Thu, 04 Apr 2019 02:16:22 -0700 |
parents | c6e6f717fabe |
children |
line wrap: on
line source
""" for raspberry pi screen. B2G_HOMESCREEN=http://10.1.0.1:9102 b2g/b2g --screen=700x480 and then fix the window with this: echo "window.resizeTo(702,480)" | nc localhost 9999 """ import json, sys, time from dateutil.parser import parse from twisted.internet import reactor, task from twisted.internet.defer import inlineCallbacks import cyclone.web, cyclone.httpclient, cyclone.websocket from rdflib import Graph, ConjunctiveGraph, URIRef, Namespace, Literal, RDF sys.path.append("../../lib") from logsetup import log from cycloneerr import PrettyErrorHandler sys.path.append("../reasoning") from rdflibtrig import addTrig CV = Namespace("http://bigasterisk.com/checkvist/v1#") EV = Namespace("http://bigasterisk.com/event#") MAP = Namespace("http://bigasterisk.com/map#") class Content(PrettyErrorHandler, cyclone.web.RequestHandler): def get(self): out = [] if 1: g = Graph() g.parse("http://bang:9103/graph", format="n3") tasks = [] # (pos, task) for t in g.subjects(RDF.type, CV.OpenTask): if (None, CV.child, t) in g: continue tasks.append((g.value(t, CV.position), t)) tasks.sort() def appendTree(t, depth): out.append(dict( uri=t, depth=depth, mark=g.value(t, CV.mark), content=g.value(t, CV.content), )) for sub in g.objects(t, CV.child): if (sub, RDF.type, CV.OpenTask) not in g: continue appendTree(sub, depth+1) for pos, t in tasks[:10]: appendTree(t, depth=0) events = [] # [{'date':'yyyy-mm-dd', 'dayEvents':[], 'timeEvents':[]}] g = Graph() g.parse("http://bang:9105/events?days=3", format='n3') byDay = {} for ev in g.subjects(RDF.type, EV.Event): start = g.value(ev, EV['start']) s = parse(start) d = s.date().isoformat() byDay.setdefault(d, {'dayEvents':[], 'timeEvents':[]})[ 'timeEvents' if 'T' in start else 'dayEvents'].append({ 'title' : g.value(ev, EV['title']), 'start' : start, 'date' : s.date().isoformat(), 'time' : s.time().isoformat()[:-3], }) for k,v in sorted(byDay.items(), key=lambda (k,v): k): d = {'date':k, 'weekdayName':parse(k).strftime("%A")} d.update(v) d['dayEvents'].sort(key=lambda ev: ev['title']) d['timeEvents'].sort(key=lambda ev: ev['start']) events.append(d) self.write(json.dumps({'tasks':out, 'events' : events})) class ContentMap(PrettyErrorHandler, cyclone.web.RequestHandler): def get(self): g = ConjunctiveGraph() addTrig(g, "http://bang:9099/graph") maxMeters = 65000 pts = [] print "loaded", len(g) for s,p,o in g.triples((None, MAP['distanceToHomeM'], None)): pts.append(dict(who=s, frac=float(o) / maxMeters, distanceToHomeM=o, displayMilesDistance="%.1f miles" % (float(o) * 0.000621371))) self.write(json.dumps({'pts': pts})) @inlineCallbacks def pushThermostat(): f = json.loads((yield cyclone.httpclient.fetch("http://bang:10001/requestedTemperature")).body) [c.sendMessage(f) for c in liveClients] class RefreshTemperature(PrettyErrorHandler, cyclone.web.RequestHandler): def post(self): return pushThermostat() liveClients = set() class Live(cyclone.websocket.WebSocketHandler): def connectionMade(self, *args, **kwargs): log.info("websocket opened") liveClients.add(self) def connectionLost(self, reason): log.info("websocket closed") liveClients.remove(self) def messageReceived(self, message): log.info("got message %s" % message) self.sendMessage(message) if __name__ == '__main__': from twisted.python import log as twlog #twlog.startLogging(sys.stdout) task.LoopingCall(pushThermostat).start(1) port = 9102 reactor.listenTCP(port, cyclone.web.Application(handlers=[ (r'/content', Content), (r'/content/map', ContentMap), (r'/live', Live), (r'/refreshTemperature', RefreshTemperature), (r'/(.*)', cyclone.web.StaticFileHandler, {"path" : ".", # security hole- serves this dir too "default_filename" : "index.html"}), ])) log.info("serving on %s" % port) reactor.run()