"""RPC Server module.""" import sys import socket import pickle from fnmatch import fnmatch from repr import repr # Default verbosity (0 = silent, 1 = print connections, 2 = print requests too) VERBOSE = 1 class Server: """RPC Server class. Derive a class to implement a particular service.""" def __init__(self, address, verbose = VERBOSE): if type(address) == type(0): address = ('', address) self._address = address self._verbose = verbose self._socket = None self._socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM) self._socket.bind(address) self._socket.listen(1) self._listening = 1 def _setverbose(self, verbose): self._verbose = verbose def __del__(self): self._close() def _close(self): self._listening = 0 if self._socket: self._socket.close() self._socket = None def _serverloop(self): while self._listening: self._serve() def _serve(self): if self._verbose: print "Wait for connection ..." conn, address = self._socket.accept() if self._verbose: print "Accepted connection from %s" % repr(address) if not self._verify(conn, address): print "*** Connection from %s refused" % repr(address) conn.close() return rf = conn.makefile('r') wf = conn.makefile('w') ok = 1 while ok: wf.flush() if self._verbose > 1: print "Wait for next request ..." ok = self._dorequest(rf, wf) _valid = ['192.16.201.*', '192.16.197.*', '132.151.1.*', '129.6.64.*'] def _verify(self, conn, address): host, port = address for pat in self._valid: if fnmatch(host, pat): return 1 return 0 def _dorequest(self, rf, wf): rp = pickle.Unpickler(rf) try: request = rp.load() except EOFError: return 0 if self._verbose > 1: print "Got request: %s" % repr(request) try: methodname, args, id = request if '.' in methodname: reply = (None, self._special(methodname, args), id) elif methodname[0] == '_': raise NameError, "illegal method name %s" % repr(methodname) else: method = getattr(self, methodname) reply = (None, apply(method, args), id) except: reply = (sys.exc_type, sys.exc_value, id) if id < 0 and reply[:2] == (None, None): if self._verbose > 1: print "Suppress reply" return 1 if self._verbose > 1: print "Send reply: %s" % repr(reply) wp = pickle.Pickler(wf) wp.dump(reply) return 1 def _special(self, methodname, args): if methodname == '.methods': if not hasattr(self, '_methods'): self._methods = tuple(self._listmethods()) return self._methods raise NameError, "unrecognized special method name %s" % repr(methodname) def _listmethods(self, cl=None): if not cl: cl = self.__class__ names = cl.__dict__.keys() names = filter(lambda x: x[0] != '_', names) names.sort() for base in cl.__bases__: basenames = self._listmethods(base) basenames = filter(lambda x, names=names: x not in names, basenames) names[len(names):] = basenames return names from security import Security class SecureServer(Server, Security): def __init__(self, *args): apply(Server.__init__, (self,) + args) Security.__init__(self) def _verify(self, conn, address): import string challenge = self._generate_challenge() conn.send("%d\n" % challenge) response = "" while "\n" not in response and len(response) < 100: data = conn.recv(100) if not data: break response = response + data try: response = string.atol(string.strip(response)) except string.atol_error: if self._verbose > 0: print "Invalid response syntax", repr(response) return 0 if not self._compare_challenge_response(challenge, response): if self._verbose > 0: print "Invalid response value", repr(response) return 0 if self._verbose > 1: print "Response matches challenge. Go ahead!" return 1
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
FSProxy.py | File | 7.64 KB | 0644 |
|
FSProxy.pyc | File | 12.5 KB | 0644 |
|
FSProxy.pyo | File | 12.5 KB | 0644 |
|
RCSProxy.py | File | 4.61 KB | 0755 |
|
RCSProxy.pyc | File | 7.57 KB | 0644 |
|
RCSProxy.pyo | File | 7.57 KB | 0644 |
|
README | File | 4.16 KB | 0644 |
|
client.py | File | 4.6 KB | 0644 |
|
client.pyc | File | 6.57 KB | 0644 |
|
client.pyo | File | 6.57 KB | 0644 |
|
cmdfw.py | File | 4.53 KB | 0644 |
|
cmdfw.pyc | File | 5.12 KB | 0644 |
|
cmdfw.pyo | File | 5.12 KB | 0644 |
|
cmptree.py | File | 5.64 KB | 0644 |
|
cmptree.pyc | File | 5.98 KB | 0644 |
|
cmptree.pyo | File | 5.98 KB | 0644 |
|
cvslib.py | File | 9.94 KB | 0644 |
|
cvslib.pyc | File | 12.83 KB | 0644 |
|
cvslib.pyo | File | 12.83 KB | 0644 |
|
cvslock.py | File | 6.61 KB | 0644 |
|
cvslock.pyc | File | 8.36 KB | 0644 |
|
cvslock.pyo | File | 8.36 KB | 0644 |
|
mac.py | File | 352 B | 0644 |
|
mac.pyc | File | 598 B | 0644 |
|
mac.pyo | File | 598 B | 0644 |
|
makechangelog.py | File | 2.92 KB | 0755 |
|
makechangelog.pyc | File | 3.05 KB | 0644 |
|
makechangelog.pyo | File | 3.05 KB | 0644 |
|
rcsbump | File | 745 B | 0755 |
|
rcsclient.py | File | 1.76 KB | 0644 |
|
rcsclient.pyc | File | 2.05 KB | 0644 |
|
rcsclient.pyo | File | 2.05 KB | 0644 |
|
rcslib.py | File | 10.08 KB | 0644 |
|
rcslib.pyc | File | 11.28 KB | 0644 |
|
rcslib.pyo | File | 11.28 KB | 0644 |
|
rcvs | File | 117 B | 0755 |
|
rcvs.py | File | 13.32 KB | 0755 |
|
rcvs.pyc | File | 14.08 KB | 0644 |
|
rcvs.pyo | File | 14.08 KB | 0644 |
|
rrcs | File | 117 B | 0755 |
|
rrcs.py | File | 3.9 KB | 0755 |
|
rrcs.pyc | File | 5.5 KB | 0644 |
|
rrcs.pyo | File | 5.5 KB | 0644 |
|
security.py | File | 1.07 KB | 0644 |
|
security.pyc | File | 1.64 KB | 0644 |
|
security.pyo | File | 1.64 KB | 0644 |
|
server.py | File | 4.47 KB | 0644 |
|
server.pyc | File | 5.83 KB | 0644 |
|
server.pyo | File | 5.83 KB | 0644 |
|
sumtree.py | File | 518 B | 0644 |
|
sumtree.pyc | File | 903 B | 0644 |
|
sumtree.pyo | File | 903 B | 0644 |
|