diff options
Diffstat (limited to 'server')
-rw-r--r-- | server/button.py | 45 | ||||
-rw-r--r-- | server/buttonDispatcher.py | 55 | ||||
-rw-r--r-- | server/dispatcher.py | 29 | ||||
-rw-r--r-- | server/lib/database.py | 5 |
4 files changed, 101 insertions, 33 deletions
diff --git a/server/button.py b/server/button.py index a5b52b8..1e79629 100644 --- a/server/button.py +++ b/server/button.py @@ -3,6 +3,7 @@ import sqlite3 import json from lib import uuid from lib import database +from time import time STATUS_INVENTORY = 0 STATUS_ACTIVE = 1 @@ -12,7 +13,7 @@ STATUS_DEAD = 4 def loadAll(): db = database.connect() - db.execute("SELECT id,status FROM buttons") + db.execute("SELECT id,status,last_pressed FROM buttons") results = [] while True: @@ -30,19 +31,22 @@ class Button(object): self.persisted = False self.id = None self.status = STATUS_INVENTORY + self.last_pressed = 0 + self.history = [] def toDict(self): return { 'id': self.id, - 'status': self.status + 'status': self.status, + 'last_pressed': self.last_pressed } def toJSON(self): - return json.dumps(self.toDict()) + return self.toDict() def loadById(self, id): db = database.connect() - db.execute("SELECT id,status FROM buttons WHERE id = ?" , (str(id),)) + db.execute("SELECT id,status,last_pressed FROM buttons WHERE id = ?" , (str(id),)) return self.loadFromDb(db.fetchone()) @@ -51,14 +55,18 @@ class Button(object): raise cherrypy.HTTPError(404, 'Button not found') self.persisted = True - self.id, self.status = dbrs + self.id, self.status, self.last_pressed = dbrs return self + def press(self): + if self.last_pressed: + self.history.insert(0, self.last_pressed) + + self.last_pressed = int(time()) + return self + def save(self): - cherrypy.log('SAVE {} -> {} (persisted: {})'.format( - self.id, self.status, self.persisted - )) db = database.connect() # validate @@ -67,17 +75,24 @@ class Button(object): # upsert: update elif self.persisted: - cherrypy.log("setting other status to " + str(self.status)) - db.execute("UPDATE buttons SET status = ? WHERE id = ?", - (int(self.status), str(self.id),) + db.execute("UPDATE buttons SET status = ?, last_pressed = ? WHERE id = ?", + (self.status, self.last_pressed, self.id,) ) # upsert: insert else: - cherrypy.log('INSERT {} -> {} (persisted: {})'.format( - self.id, self.status, self.persisted - )) - db.execute("INSERT INTO buttons VALUES (?, ?)", (self.id, self.status)) + db.execute("INSERT INTO buttons VALUES (?, ?, ?)", (self.id, self.status, self.last_pressed)) db.connection.commit() return self + + def delete(self): + db = database.connect() + + if self.id is None: + raise cherrypy.HTTPError(500, "uhh wat") + + db.execute("DELETE FROM buttons WHERE id = ?", (self.id,)) + db.connection.commit() + + return None diff --git a/server/buttonDispatcher.py b/server/buttonDispatcher.py index 5dac61c..59672d6 100644 --- a/server/buttonDispatcher.py +++ b/server/buttonDispatcher.py @@ -1,38 +1,59 @@ import json import cherrypy from button import loadAll, Button +from dispatcher import Dispatcher from lib import uuid +# Tweak: consider using serpy for serializing objects for JSON. + @cherrypy.expose -class ButtonDispatcher(object): +class ButtonDispatcher(Dispatcher): def GET(self, id=None): + # GET /button - return all buttons if id is None: - return json.dumps(loadAll()) - elif uuid.validate(id): - button = Button() - return button.loadById(id).toJSON() - else: - raise cherrypy.HTTPError(400, 'Invalid ID') + return self.response(loadAll()) + + # GET /button/{id} - return single button + self.validate_uuid(id) + + button = Button() + return self.response(button.loadById(id).toJSON()) def POST(self, id, status): - if not uuid.validate(id): - raise cherrypy.HTTPError(401) + # POST /button/{id}?status={} - updates button status + self.validate_uuid(id) button = Button() button.loadById(id) cherrypy.log("Updating status to " + str(status)) - button.status = status + # TODO validate status + button.status = int(status) button.save() - return button.toJSON() + return self.response(button.toJSON()) - def PUT(self): - cherrypy.log('Generating new button') + def PUT(self, id=None): button = Button() - button.id = uuid.gen() - return button.save().toJSON() + # PUT /button - creates button + if id is None: + button.id = uuid.gen() + return self.response(button.save().toJSON()) + + # PUT /button/{id} - presses button + else: + button.loadById(id) + button.press() + + button.save() + + return self.response(button.toJSON()) + + def DELETE(self, id): + # DELETE /button/{id} - deletes button + button = Button() + button.loadById(id) + button.delete() - def DELETE(self): - return 'DELETE BUTTON' + return self.response(True) diff --git a/server/dispatcher.py b/server/dispatcher.py new file mode 100644 index 0000000..36dd8da --- /dev/null +++ b/server/dispatcher.py @@ -0,0 +1,29 @@ +import json +import cherrypy +from lib import uuid + +class Dispatcher(object): + def validate_uuid(self, uuid4): + if not uuid.validate(uuid4): + self.error(1, 'Invalid UUID in request') + + def response(self, data): + # Pretty print responses + return json.dumps(data, sort_keys=True, indent=2, separators=(',', ': ')) + + def error(self, code, message='An application error occurred'): + raise cherrypy.HTTPError(400, + self.response({'error': {'code': int(code), 'message': str(message)}}) + ) + + def GET(self, id=None): + raise cherrypy.HTTPError(405) + + def POST(self, id, status): + raise cherrypy.HTTPError(405) + + def PUT(self): + raise cherrypy.HTTPError(405) + + def DELETE(self): + raise cherrypy.HTTPError(405) diff --git a/server/lib/database.py b/server/lib/database.py index d4e47e6..c144d07 100644 --- a/server/lib/database.py +++ b/server/lib/database.py @@ -1,5 +1,8 @@ import sqlite3 +import os def connect(): - connection = sqlite3.connect('../data/imok.db') + connection = sqlite3.connect( + os.path.dirname(os.path.realpath(__file__)) + '/../../data/imok.db' + ) return connection.cursor() |