Sophie

Sophie

distrib > CentOS > 5 > x86_64 > by-pkgid > c7d5af816329c171c658e5facf128c02 > files > 339

m2crypto-0.16-9.el5.x86_64.rpm

#!/usr/bin/python

"""Another multi-threading SSL 'echo' server.

Copyright (c) 1999-2003 Ng Pheng Siong. All rights reserved."""

from M2Crypto import Rand, SSL, threading
import echod_lib

import thread
from socket import *

buffer='Ye Newe Threading Echo Servre\r\n'

def echo_handler(sslctx, sock, addr):
    sslconn = SSL.Connection(sslctx, sock)
    sslconn.setup_addr(addr)
    sslconn.setup_ssl()
    sslconn.set_accept_state()
    sslconn.accept_ssl()
    sslconn.write(buffer) 
    while 1:
        try:
            buf = sslconn.read()
            if not buf:
                break
            sslconn.write(buf) 
        except SSL.SSLError, what:
            if str(what) == 'unexpected eof':
                break
            else:
                raise
        except:
            break
    # Threading servers need this.
    sslconn.set_shutdown(SSL.SSL_RECEIVED_SHUTDOWN|SSL.SSL_SENT_SHUTDOWN)
    sslconn.close()


if __name__=='__main__':
    threading.init()
    Rand.load_file('../randpool.dat', -1) 
    ctx=echod_lib.init_context('sslv23', 'server.pem', 'ca.pem', 
        SSL.verify_peer | SSL.verify_fail_if_no_peer_cert)
    ctx.set_tmp_dh('dh1024.pem')
    sock = socket(AF_INET, SOCK_STREAM)
    sock.setsockopt(SOL_SOCKET, SO_REUSEADDR, 1)
    sock.bind(('', 9999))
    sock.listen(5)
    while 1:
        conn, addr = sock.accept()
        thread.start_new_thread(echo_handler, (ctx, conn, addr))
    Rand.save_file('../randpool.dat')
    threading.cleanup()