X-Git-Url: http://dolda2000.com/gitweb/?a=blobdiff_plain;f=python%2Fashd%2Fscgi.py;h=f7ba3a8f5db1ea52149422249cc44b8a59b8f014;hb=328d1dbcd801cd602fb245642bede234a7726c0c;hp=a4342d02892016271a0157e7da40acd0cbf4053c;hpb=699754de7dc11275d9d94eb521111609a6d73ed7;p=ashd.git diff --git a/python/ashd/scgi.py b/python/ashd/scgi.py index a4342d0..f7ba3a8 100644 --- a/python/ashd/scgi.py +++ b/python/ashd/scgi.py @@ -4,6 +4,10 @@ import threading class protoerr(Exception): pass +class closed(IOError): + def __init__(self): + super(closed, self).__init__("The client has closed the connection.") + def readns(sk): hln = 0 while True: @@ -33,7 +37,8 @@ def readhead(sk): class reqthread(threading.Thread): def __init__(self, sk, handler): super(reqthread, self).__init__(name = "SCGI request handler") - self.sk = sk.dup().makefile("r+") + self.bsk = sk.dup() + self.sk = self.bsk.makefile("r+") self.handler = handler def run(self): @@ -42,6 +47,7 @@ class reqthread(threading.Thread): self.handler(head, self.sk) finally: self.sk.close() + self.bsk.close() def handlescgi(sk, handler): t = reqthread(sk, handler) @@ -80,17 +86,23 @@ def wrapwsgi(handler): raise Exception, "Trying to write data before starting response." status, headers = resp respsent[:] = [True] - sk.write("Status: %s\n" % status) - for nm, val in headers: - sk.write("%s: %s\n" % (nm, val)) - sk.write("\n") + try: + sk.write("Status: %s\n" % status) + for nm, val in headers: + sk.write("%s: %s\n" % (nm, val)) + sk.write("\n") + except IOError: + raise closed() def write(data): if not data: return flushreq() - sk.write(data) - sk.flush() + try: + sk.write(data) + sk.flush() + except IOError: + raise closed() def startreq(status, headers, exc_info = None): if resp: @@ -107,10 +119,13 @@ def wrapwsgi(handler): respiter = handler(env, startreq) try: - for data in respiter: - write(data) - if resp: - flushresp() + try: + for data in respiter: + write(data) + if resp: + flushreq() + except closed: + pass finally: if hasattr(respiter, "close"): respiter.close()