#!/usr/bin/env python import socket, pexpect, ANSI import time, sys, os # Clearly having the password on the command line is not a good idea, but # then this entire enterprise is probably not the most security concious thing # I've ever built. This should be considered an experimental tool. # USER = sys.argv[1] # PASSWORD = sys.argv[2] # PORT = sys.argv[3] def daemonize (stdin='/dev/null', stdout='/dev/null', stderr='/dev/null'): '''This forks the current process into a daemon. Almost none of this is necessary (or advisable) if your daemon is being started by inetd. In that case, stdin, stdout and stderr are all set up for you to refer to the network connection, and the fork()s and session manipulation should not be done (to avoid confusing inetd). Only the chdir() and umask() steps remain as useful. References: UNIX Programming FAQ 1.7 How do I get my program to act like a daemon? http://www.erlenstar.demon.co.uk/unix/faq_2.html#SEC16 Advanced Programming in the Unix Environment W. Richard Stevens, 1992, Addison-Wesley, ISBN 0-201-56317-7. The stdin, stdout, and stderr arguments are file names that will be opened and be used to replace the standard file descriptors in sys.stdin, sys.stdout, and sys.stderr. These arguments are optional and default to /dev/null. Note that stderr is opened unbuffered, so if it shares a file with stdout then interleaved output may not appear in the order that you expect. ''' # Do first fork. try: pid = os.fork() if pid > 0: sys.exit(0) # Exit first parent. except OSError, e: sys.stderr.write ("fork #1 failed: (%d) %s\n" % (e.errno, e.strerror) ) sys.exit(1) # Decouple from parent environment. os.chdir("/") os.umask(0) os.setsid() # Do second fork. try: pid = os.fork() if pid > 0: sys.exit(0) # Exit second parent. except OSError, e: sys.stderr.write ("fork #2 failed: (%d) %s\n" % (e.errno, e.strerror) ) sys.exit(1) # Now I am a daemon! # Redirect standard file descriptors. si = open(stdin, 'r') so = open(stdout, 'a+') se = open(stderr, 'a+', 0) os.dup2(si.fileno(), sys.stdin.fileno()) os.dup2(so.fileno(), sys.stdout.fileno()) os.dup2(se.fileno(), sys.stderr.fileno()) # I now return as the daemon return 0 def main (): USER = sys.argv[1] PASSWORD = sys.argv[2] PORT = int(sys.argv[3]) #daemonize () #daemonize('/dev/null','/tmp/daemon.log','/tmp/daemon.log') sys.stdout.write ('Daemon started with pid %d\n' % os.getpid() ) vs = ANSI.ANSI (24,80) p = pexpect.spawn ('ssh %(USER)s@localhost'%locals(), timeout=9) p.expect ('assword') p.sendline (PASSWORD) time.sleep (0.2) #p.sendline ('stty -echo') #time.sleep (0.2) p.sendline ('export PS1="HAON "') time.sleep (0.2) p.expect (pexpect.TIMEOUT) print p.before vs.process (p.before) HOST = '' # Symbolic name meaning the local host s = socket.socket(socket.AF_INET, socket.SOCK_STREAM) s.bind((HOST, PORT)) print 'Listen' s.listen(1) print 'Accept' while 1: conn, addr = s.accept() print 'Connected by', addr data = conn.recv(1024) print data if data == 'exit': p.sendline (exit) break if not data == "pass": p.sendline (data) time.sleep (0.1) p.expect (['HAON ',pexpect.TIMEOUT]) #response = p.before sh_response = p.before.replace ('\r', '') vs.process_list (sh_response) response = str (vs) print response sent = conn.send(response) if sent < len (response): print "Sent is too short" if __name__ == "__main__": # daemonize('/dev/null','/tmp/daemon.log','/tmp/daemon.log') main()