From 4e620374b8912342c0baf7391099c703cf55c0a7 Mon Sep 17 00:00:00 2001 From: Guido van Rossum Date: Mon, 10 Apr 1995 11:46:03 +0000 Subject: added rpython --- Demo/sockets/rpythond.py | 52 ++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 52 insertions(+) create mode 100755 Demo/sockets/rpythond.py (limited to 'Demo/sockets/rpythond.py') diff --git a/Demo/sockets/rpythond.py b/Demo/sockets/rpythond.py new file mode 100755 index 00000000000..f67570bc958 --- /dev/null +++ b/Demo/sockets/rpythond.py @@ -0,0 +1,52 @@ +#! /usr/local/bin/python + +# Remote python server. +# Execute Python commands remotely and send output back. +# WARNING: This version has a gaping security hole -- it accepts requests +# from any host on the Internet! + +import sys +from socket import * +import StringIO +import traceback + +PORT = 4127 +BUFSIZE = 1024 + +def main(): + if len(sys.argv) > 1: + port = int(eval(sys.argv[1])) + else: + port = PORT + s = socket(AF_INET, SOCK_STREAM) + s.bind('', port) + s.listen(1) + while 1: + conn, (remotehost, remoteport) = s.accept() + print 'connected by', remotehost, remoteport + request = '' + while 1: + data = conn.recv(BUFSIZE) + if not data: + break + request = request + data + reply = execute(request) + conn.send(reply) + conn.close() + +def execute(request): + stdout = sys.stdout + stderr = sys.stderr + sys.stdout = sys.stderr = fakefile = StringIO.StringIO() + try: + try: + exec request in {}, {} + except: + print + traceback.print_exc(100) + finally: + sys.stderr = stderr + sys.stdout = stdout + return fakefile.getvalue() + +main() -- cgit v1.2.3