import time
import Queue as queue
-from processor import Session, Dispatcher, timestr
+from processor import Session, Dispatcher, print_log
class TcpSession(Session):
self._connection = connection
self.address = address[0]
- self.name = "TCP"
+ self.name = "TCP " if not use_ssl else "SSL "
def connection(self):
if self.stopped():
self.ssl_certfile = ssl_certfile
def run(self):
- print "TCP server started.", self.use_ssl
+ if self.use_ssl:
+ print_log( "TCP/SSL server started.")
+ else:
+ print_log( "TCP server started.")
sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
sock.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
sock.bind((self.host, self.port))
sock.listen(1)
while not self.shared.stopped():
- session = TcpSession(*sock.accept(), use_ssl=self.use_ssl, ssl_certfile=self.ssl_certfile, ssl_keyfile=self.ssl_keyfile)
+ try:
+ session = TcpSession(*sock.accept(), use_ssl=self.use_ssl, ssl_certfile=self.ssl_certfile, ssl_keyfile=self.ssl_keyfile)
+ except BaseException, e:
+ error = str(e)
+ print_log("cannot start TCP session", error)
+ continue
self.dispatcher.add_session(session)
self.dispatcher.collect_garbage()
client_req = TcpClientRequestor(self.dispatcher, session)