Advancing on client for mac os x

This commit is contained in:
Adolfo Gómez García 2015-04-01 09:07:11 +02:00
parent 646334ece5
commit e4192e6064
3 changed files with 88 additions and 25 deletions

View File

@ -178,6 +178,8 @@ if __name__ == "__main__":
exitVal = app.exec_() exitVal = app.exec_()
tools.waitForTasks()
time.sleep(3) time.sleep(3)
tools.unlinkFiles() tools.unlinkFiles()

View File

@ -7,10 +7,9 @@ from __future__ import unicode_literals
import select import select
import SocketServer import SocketServer
import sys
import paramiko import paramiko
import threading import threading
import random
g_verbose = True g_verbose = True
@ -23,6 +22,8 @@ class ForwardServer (SocketServer.ThreadingTCPServer):
class Handler (SocketServer.BaseRequestHandler): class Handler (SocketServer.BaseRequestHandler):
def handle(self): def handle(self):
self.thread.alreadyConnected = True
try: try:
chan = self.ssh_transport.open_channel('direct-tcpip', chan = self.ssh_transport.open_channel('direct-tcpip',
(self.chain_host, self.chain_port), (self.chain_host, self.chain_port),
@ -39,24 +40,32 @@ class Handler (SocketServer.BaseRequestHandler):
verbose('Connected! Tunnel open %r -> %r -> %r' % (self.request.getpeername(), verbose('Connected! Tunnel open %r -> %r -> %r' % (self.request.getpeername(),
chan.getpeername(), (self.chain_host, self.chain_port))) chan.getpeername(), (self.chain_host, self.chain_port)))
while self.event.is_set() is False: try:
r, w, x = select.select([self.request, chan], [], [], 1) while self.event.is_set() is False:
r, _w, _x = select.select([self.request, chan], [], [], 1)
if self.request in r: if self.request in r:
data = self.request.recv(1024) data = self.request.recv(1024)
if len(data) == 0: if len(data) == 0:
break break
chan.send(data) chan.send(data)
if chan in r: if chan in r:
data = chan.recv(1024) data = chan.recv(1024)
if len(data) == 0: if len(data) == 0:
break break
self.request.send(data) self.request.send(data)
except Exception:
pass
peername = self.request.getpeername() try:
chan.close() peername = self.request.getpeername()
self.request.close() chan.close()
verbose('Tunnel closed from %r' % (peername,)) self.request.close()
verbose('Tunnel closed from %r' % (peername,))
except Exception:
pass
self.thread.stop()
def verbose(s): def verbose(s):
@ -65,7 +74,7 @@ def verbose(s):
class ForwardThread(threading.Thread): class ForwardThread(threading.Thread):
def __init__(self, server, port, username, password, localPort, redirectHost, redirectPort): def __init__(self, server, port, username, password, localPort, redirectHost, redirectPort, waitTime):
threading.Thread.__init__(self) threading.Thread.__init__(self)
self.client = None self.client = None
self.fs = None self.fs = None
@ -79,8 +88,19 @@ class ForwardThread(threading.Thread):
self.redirectHost = redirectHost self.redirectHost = redirectHost
self.redirectPort = redirectPort self.redirectPort = redirectPort
self.waitTime = waitTime
self.stopEvent = threading.Event() self.stopEvent = threading.Event()
self.timer = None
self.alreadyConnected = False
def _timerFnc(self):
self.timer = None
verbose('Timer fnc: {}'.format(self.alreadyConnected))
if self.alreadyConnected is False:
self.stop()
def run(self): def run(self):
self.client = paramiko.SSHClient() self.client = paramiko.SSHClient()
self.client.load_system_host_keys() self.client.load_system_host_keys()
@ -90,17 +110,25 @@ class ForwardThread(threading.Thread):
self.client.connect(self.server, self.port, username=self.username, password=self.password) self.client.connect(self.server, self.port, username=self.username, password=self.password)
class SubHander (Handler): class SubHandler (Handler):
chain_host = self.redirectHost chain_host = self.redirectHost
chain_port = self.redirectPort chain_port = self.redirectPort
ssh_transport = self.client.get_transport() ssh_transport = self.client.get_transport()
event = self.stopEvent event = self.stopEvent
thread = self
self.fs = ForwardServer(('', self.redirectPort), SubHander) verbose('Wait Time: {}'.format(self.waitTime))
self.timer = threading.Timer(self.waitTime, self._timerFnc)
self.timer.start()
self.fs = ForwardServer(('', self.localPort), SubHandler)
self.fs.serve_forever() self.fs.serve_forever()
def stop(self): def stop(self):
try: try:
if self.timer:
self.timer.cancel()
self.stopEvent.set() self.stopEvent.set()
self.fs.shutdown() self.fs.shutdown()
@ -110,14 +138,21 @@ class ForwardThread(threading.Thread):
pass pass
def forward(server, port, username, password, localPort, redirectHost, redirectPort): def forward(server, port, username, password, redirectHost, redirectPort, localPort=None, waitTime=10):
'''
Instantiates an ssh connection to server:port
Returns the Thread created and the local redirected port as a list: (thread, port)
'''
port, redirectPort = int(port), int(redirectPort) port, redirectPort = int(port), int(redirectPort)
if localPort is None:
localPort = random.randrange(40000, 50000)
verbose('Connected') verbose('Connecting to {}:{} using {}/{} redirecting to {}:{}, listening on 127.0.0.1:{}'.format(
server, port, username, password, redirectHost, redirectPort, localPort))
ft = ForwardThread(server, port, username, password, localPort, redirectHost, redirectPort) ft = ForwardThread(server, port, username, password, localPort, redirectHost, redirectPort, waitTime)
ft.start() ft.start()
return ft return (ft, localPort)

View File

@ -38,6 +38,8 @@ import random
import os import os
_unlinkFiles = [] _unlinkFiles = []
_tasksToWait = []
_execBeforeExit = []
def saveTempFile(content, filename=None): def saveTempFile(content, filename=None):
@ -52,12 +54,36 @@ def saveTempFile(content, filename=None):
def addFileToUnlink(filename): def addFileToUnlink(filename):
'''
Adds a file to the wait-and-unlink list
'''
_unlinkFiles.append(filename) _unlinkFiles.append(filename)
def unlinkFiles(): def unlinkFiles():
'''
Removes all wait-and-unlink files
'''
for f in _unlinkFiles: for f in _unlinkFiles:
try: try:
os.unlink(f) os.unlink(f)
except Exception: except Exception:
pass pass
def addTaskToWait(taks):
_tasksToWait.append(taks)
def waitForTasks():
for t in _tasksToWait:
t.join()
def addExecBeforeExit(fnc):
_execBeforeExit.append(fnc)
def execBeforeExit():
for fnc in _execBeforeExit:
fnc.call()