OXIESEC PANEL
- Current Dir:
/
/
usr
/
lib
/
python3
/
dist-packages
/
twisted
/
protocols
Server IP: 139.59.38.164
Upload:
Create Dir:
Name
Size
Modified
Perms
📁
..
-
03/31/2022 06:22:38 AM
rwxr-xr-x
📄
__init__.py
572 bytes
09/23/2017 05:52:21 AM
rw-r--r--
📁
__pycache__
-
03/31/2022 06:22:39 AM
rwxr-xr-x
📄
amp.py
95.83 KB
09/08/2017 10:38:36 AM
rw-r--r--
📄
basic.py
31.26 KB
09/08/2017 10:38:36 AM
rw-r--r--
📄
dict.py
10.52 KB
09/08/2017 10:38:36 AM
rw-r--r--
📄
finger.py
1.19 KB
09/08/2017 10:38:36 AM
rw-r--r--
📄
ftp.py
103.64 KB
09/08/2017 10:38:36 AM
rw-r--r--
📁
haproxy
-
03/31/2022 06:22:38 AM
rwxr-xr-x
📄
htb.py
9.11 KB
09/08/2017 10:38:36 AM
rw-r--r--
📄
ident.py
7.6 KB
09/08/2017 10:38:36 AM
rw-r--r--
📄
loopback.py
11.65 KB
09/08/2017 10:38:36 AM
rw-r--r--
📄
memcache.py
23.14 KB
09/08/2017 10:38:36 AM
rw-r--r--
📄
pcp.py
6.92 KB
09/08/2017 10:38:36 AM
rw-r--r--
📄
policies.py
20.72 KB
09/08/2017 10:38:36 AM
rw-r--r--
📄
portforward.py
2.33 KB
09/08/2017 10:38:36 AM
rw-r--r--
📄
postfix.py
3.65 KB
09/08/2017 10:38:36 AM
rw-r--r--
📄
sip.py
36.91 KB
09/08/2017 10:38:36 AM
rw-r--r--
📄
socks.py
7.63 KB
09/08/2017 10:38:36 AM
rw-r--r--
📄
stateful.py
1.6 KB
09/08/2017 10:38:36 AM
rw-r--r--
📁
test
-
03/31/2022 06:22:38 AM
rwxr-xr-x
📄
tls.py
31.73 KB
09/08/2017 10:38:36 AM
rw-r--r--
📄
wire.py
2.5 KB
09/08/2017 10:38:36 AM
rw-r--r--
Editing: portforward.py
Close
# Copyright (c) Twisted Matrix Laboratories. # See LICENSE for details. """ A simple port forwarder. """ # Twisted imports from twisted.internet import protocol from twisted.python import log class Proxy(protocol.Protocol): noisy = True peer = None def setPeer(self, peer): self.peer = peer def connectionLost(self, reason): if self.peer is not None: self.peer.transport.loseConnection() self.peer = None elif self.noisy: log.msg("Unable to connect to peer: %s" % (reason,)) def dataReceived(self, data): self.peer.transport.write(data) class ProxyClient(Proxy): def connectionMade(self): self.peer.setPeer(self) # Wire this and the peer transport together to enable # flow control (this stops connections from filling # this proxy memory when one side produces data at a # higher rate than the other can consume). self.transport.registerProducer(self.peer.transport, True) self.peer.transport.registerProducer(self.transport, True) # We're connected, everybody can read to their hearts content. self.peer.transport.resumeProducing() class ProxyClientFactory(protocol.ClientFactory): protocol = ProxyClient def setServer(self, server): self.server = server def buildProtocol(self, *args, **kw): prot = protocol.ClientFactory.buildProtocol(self, *args, **kw) prot.setPeer(self.server) return prot def clientConnectionFailed(self, connector, reason): self.server.transport.loseConnection() class ProxyServer(Proxy): clientProtocolFactory = ProxyClientFactory reactor = None def connectionMade(self): # Don't read anything from the connecting client until we have # somewhere to send it to. self.transport.pauseProducing() client = self.clientProtocolFactory() client.setServer(self) if self.reactor is None: from twisted.internet import reactor self.reactor = reactor self.reactor.connectTCP(self.factory.host, self.factory.port, client) class ProxyFactory(protocol.Factory): """ Factory for port forwarder. """ protocol = ProxyServer def __init__(self, host, port): self.host = host self.port = port