2009-02-19 22:07:34 +01:00
|
|
|
import md5
|
|
|
|
from logger import Logger
|
|
|
|
import Entry
|
|
|
|
|
2009-02-19 17:54:22 +01:00
|
|
|
class AdminFuncException(Exception):
|
|
|
|
def __init__(self, msg):
|
|
|
|
Logger.log("Exception in AdminFuncs: %s" % msg)
|
|
|
|
self.msg = msg
|
|
|
|
|
|
|
|
class AdminFuncs(object):
|
2009-02-19 22:07:34 +01:00
|
|
|
@classmethod
|
|
|
|
def setParams(cls, entries, adminPwd):
|
|
|
|
cls.entries = entries
|
|
|
|
cls.adminPwd = adminPwd
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def register(cls, dynid, subdomain, zone, sharedSecret, checksum):
|
|
|
|
di = "%s %s %s %s %s" % (dynid, subdomain, zone, sharedSecret, AdminFuncs.adminPwd)
|
|
|
|
d = md5.new(di).hexdigest()
|
|
|
|
Logger.debug("%s, received: %s, calculated: %s" % (di, checksum, d))
|
|
|
|
if d != checksum:
|
|
|
|
raise AdminFuncException("access denied: %s" % di)
|
2009-02-19 17:54:22 +01:00
|
|
|
|
2009-02-19 22:07:34 +01:00
|
|
|
if AdminFuncs.entries.has_key(dynid):
|
|
|
|
raise AdminFuncException("duplicate dynid")
|
2009-02-19 17:54:22 +01:00
|
|
|
|
2009-02-19 22:07:34 +01:00
|
|
|
for entry in AdminFuncs.entries.values():
|
|
|
|
if entry.name == subdomain and entry.zone == zone:
|
|
|
|
raise AdminFuncException("duplicate full name")
|
2009-02-19 17:54:22 +01:00
|
|
|
|
2009-02-19 22:07:34 +01:00
|
|
|
newEntry = Entry.Entry(dynid, sharedSecret, subdomain, zone)
|
|
|
|
AdminFuncs.entries[dynid] = newEntry
|
|
|
|
|
|
|
|
|
2009-02-19 17:54:22 +01:00
|
|
|
|