summaryrefslogtreecommitdiffstats
path: root/browserlogger.py
blob: 24f961dc889b408693ddc67f8624102e2b3bc439 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
from BaseHTTPServer import HTTPServer, BaseHTTPRequestHandler
from threading import Thread
from datetime import datetime

from models import BrowserEvent


class MyHandler(BaseHTTPRequestHandler):

    def do_POST(self):
        time = datetime.utcfromtimestamp(int(self.headers["time"]) / 1000.)
        if self.headers["url"] == "null":
            url, title = None, None
        else:
            url, title = (self.headers["url"].decode("utf8"),
                          self.headers["title"].decode("utf8"))
        event = BrowserEvent(time=time, url=url,
                             title=title)
        self.server.logger.info(event)
        self.send_response(202)
        self.end_headers()
        return

    def log_request(self, code):
        pass


class MyServer(HTTPServer):

    def __init__(self, addr, handler, logger):
        HTTPServer.__init__(self, addr, handler)
        self.logger = logger


class ServerThread(Thread):

    def __init__(self, logger):
        Thread.__init__(self)
        self.server = MyServer(("localhost", 8080), MyHandler, logger)

    def run(self):
        self.server.serve_forever()

    def stop(self):
        self.server.shutdown()