summaryrefslogtreecommitdiffstats
path: root/src/nyancat.py
diff options
context:
space:
mode:
authorKevin Lange <kevin.lange@phpwnage.com>2011-11-30 22:12:44 -0800
committerKevin Lange <kevin.lange@phpwnage.com>2011-11-30 22:12:44 -0800
commit584fb40b7d158fb863dfbb77442486114956894b (patch)
treee6ecef21e6d002d7e8e8ef7d67e82f8a6c66e60d /src/nyancat.py
parentcb850e9ab9b70f183ef9afbda9952110b3922204 (diff)
parent900194edee61b6dded593e04b435e9b7c9ca0517 (diff)
downloadnyancat-584fb40b7d158fb863dfbb77442486114956894b.tar.gz
Merge pull request #2 from apeschel/autotools
[apeschel] Made project more in line with Autotools standard.
Diffstat (limited to 'src/nyancat.py')
-rwxr-xr-xsrc/nyancat.py41
1 files changed, 41 insertions, 0 deletions
diff --git a/src/nyancat.py b/src/nyancat.py
new file mode 100755
index 0000000..039581c
--- /dev/null
+++ b/src/nyancat.py
@@ -0,0 +1,41 @@
+#!/usr/bin/env python
+import SocketServer
+import threading, os
+from subprocess import Popen, PIPE
+from telnetsrvlib import TelnetHandler
+
+class TNS(SocketServer.ThreadingMixIn, SocketServer.TCPServer):
+ allow_reuse_address = True
+
+class TNH(TelnetHandler):
+ def handle(self):
+ print self.TERM
+ p = Popen(["./nyancat"], shell=False, stdout=PIPE, stdin=PIPE, bufsize=0)
+ if (self.TERM.lower().find("xterm") != -1):
+ p.stdin.write("1\n")
+ elif (self.TERM.lower().find("linux") != -1):
+ p.stdin.write("3\n")
+ elif (self.TERM.lower().find("fallback") != -1):
+ p.stdin.write("4\n")
+ elif (self.TERM.lower().find("rxvt") == 0):
+ p.stdin.write("3\n")
+ else:
+ p.stdin.write("2\n")
+ while 1:
+ s = p.stdout.read(1024)
+ try:
+ self.write(s)
+ except:
+ p.kill()
+ return
+
+class serverThread(threading.Thread):
+ def run(self):
+ tns = TNS(("0.0.0.0", 23), TNH)
+ tns.serve_forever()
+
+if __name__ == "__main__":
+ t = serverThread()
+ t.start()
+ raw_input("Let me know when to stop.")
+ os.kill(os.getpid(), 9)