yadyn/server/HttpCmdReceiver.py

120 lines
3.9 KiB
Python
Raw Normal View History

2008-03-20 11:28:15 +01:00
import threading
import time
2009-02-19 17:54:22 +01:00
from Event import IllegalEventException
2008-03-20 11:28:15 +01:00
from logger import Logger
2008-03-20 11:31:11 +01:00
import BaseHTTPServer
2008-03-20 11:50:43 +01:00
import SocketServer
import cgi
import urlparse
2009-02-19 17:54:22 +01:00
import time
import Queue
2008-03-20 11:28:15 +01:00
import Entry
2009-02-19 17:54:22 +01:00
import AdminFuncs
2008-03-20 11:28:15 +01:00
class LocalException(Exception):
def __init__(self, msg):
2008-08-12 16:18:57 +02:00
Logger.log("Exception in HttpCmdReceiver: %s" % msg)
self.msg = msg
2008-03-20 11:28:15 +01:00
2008-03-20 11:31:11 +01:00
class HttpCmdHandler(BaseHTTPServer.BaseHTTPRequestHandler):
2008-03-20 11:28:15 +01:00
server_version = "YadynCMDHTTP/1.0"
@classmethod
2009-02-19 17:54:22 +01:00
def setClassParams(cls, entries, adminPwd, dnsq, nullAddress):
2008-08-12 16:18:57 +02:00
cls.entries = entries
cls.adminPwd = adminPwd
2009-02-19 17:54:22 +01:00
cls.dnsq = dnsq
2009-02-19 22:07:34 +01:00
cls.nullAddress = nullAddress
2008-03-20 11:28:15 +01:00
2008-03-20 11:50:43 +01:00
def do_GET(self):
2009-02-19 17:54:22 +01:00
Logger.log("Request: %s, %s" % (self.path, self.client_address))
2008-08-12 16:18:57 +02:00
try:
if self.command == "GET":
q = urlparse.urlparse(self.path).query
c = cgi.parse_qs(q)
if not c.has_key('c'):
raise LocalException('no cmd given')
cmd = c['c'][0]
Logger.log("Cmd: " + cmd)
if cmd == 'register':
self.register(c)
2009-02-19 17:54:22 +01:00
elif cmd == 'start':
2009-02-19 22:07:34 +01:00
self.setAddress(c, self.client_address[0])
2009-02-19 17:54:22 +01:00
elif cmd == 'stop':
2009-02-19 22:07:34 +01:00
self.setAddress(c, HttpCmdHandler.nullAddress)
2008-08-12 16:18:57 +02:00
else:
raise LocalException('unknown cmd')
2008-03-20 11:28:15 +01:00
2008-08-12 16:18:57 +02:00
self.send_response(200, "OK")
2009-02-19 22:07:34 +01:00
self.send_header("Content-Length", "0")
2008-08-12 16:18:57 +02:00
self.end_headers()
2009-02-19 17:54:22 +01:00
except IllegalEventException, e:
Logger.log("Some failure (%s), not notifying user" % e.msg)
self.send_response(200, "OK")
2009-02-19 22:07:34 +01:00
self.send_header("Content-Length", "0")
2009-02-19 17:54:22 +01:00
self.end_headers()
except AdminFuncs.AdminFuncException, e:
self.send_response(400, e.msg)
self.end_headers()
2008-08-12 16:18:57 +02:00
except LocalException, e:
self.send_response(400, e.msg)
self.end_headers()
2008-03-20 11:57:52 +01:00
2009-02-19 22:07:34 +01:00
2008-03-20 11:57:52 +01:00
def register(self, c):
2008-08-12 16:18:57 +02:00
try:
2009-02-19 17:54:22 +01:00
dynid = c['dynid'][0]
2008-08-12 16:18:57 +02:00
subdomain = c['subdomain'][0]
2009-02-19 17:54:22 +01:00
zone = c['zone'][0]
2008-08-12 16:18:57 +02:00
sharedSecret = c['sharedsecret'][0]
2009-02-19 17:54:22 +01:00
checkSum = c['checksum'][0]
2008-08-12 16:18:57 +02:00
except KeyError, e:
raise LocalException('Parameter missing: ' + str(e))
2008-03-20 11:28:15 +01:00
2009-02-19 22:07:34 +01:00
AdminFuncs.AdminFuncs.register(dynid, subdomain, zone, sharedSecret, checkSum)
2009-02-19 17:54:22 +01:00
2009-02-19 22:24:40 +01:00
2009-02-19 17:54:22 +01:00
def setAddress(self, c, address):
try:
dynId = c['dynid'][0]
sharedSecret = c['sharedsecret'][0]
except KeyError, e:
2009-02-19 22:07:34 +01:00
raise LocalException('Parameter missing: ' + str(e))
2009-02-19 10:58:56 +01:00
2009-02-19 17:54:22 +01:00
if not HttpCmdHandler.entries.has_key(dynId):
2009-02-19 22:07:34 +01:00
raise IllegalEventException("unknown dynid %s" % dynId)
2009-02-19 17:54:22 +01:00
entry = HttpCmdHandler.entries[dynId]
if entry.sharedSecret != sharedSecret:
raise IllegalEventException("shared secret %s does not match to dynid %s" % (sharedSecret, dynId))
entry.lastEventTime = int(time.time())
entry.address = address
Logger.debug("Set in DNS: %s -> %s" % (entry.name, entry.address))
try:
HttpCmdHandler.dnsq.put_nowait(entry)
except Queue.Full, e:
Logger.log("Dns Queue overrun, drop event for %s" % str(entry))
2009-02-19 10:58:56 +01:00
2008-03-20 11:28:15 +01:00
class HttpCmdServer(SocketServer.ThreadingTCPServer):
def __init__(self, serverAddr):
2008-08-12 16:18:57 +02:00
self.allow_reuse_address = True
SocketServer.ThreadingTCPServer.__init__(self, serverAddr, HttpCmdHandler)
2008-03-20 11:28:15 +01:00
class HttpCmdReceiver(threading.Thread):
2009-02-19 17:54:22 +01:00
def __init__(self, httpCmdRecvAddr, entries, adminPwd, dnsq, nullAddress):
2008-03-20 11:28:15 +01:00
threading.Thread.__init__(self)
self.httpCmdRecvAddr = httpCmdRecvAddr
2009-02-19 17:54:22 +01:00
HttpCmdHandler.setClassParams(entries, adminPwd, dnsq, nullAddress)
2008-03-20 11:28:15 +01:00
self.setDaemon(True)
def run(self):
2008-08-12 16:18:57 +02:00
server = HttpCmdServer(self.httpCmdRecvAddr)
server.serve_forever()
2008-03-20 11:28:15 +01:00