class ITransport(Interface): (source)
Known subclasses: twisted.conch.insults.insults.ITerminalTransport
, twisted.conch.telnet.ITelnetTransport
, twisted.internet.interfaces.IProcessTransport
, twisted.internet.interfaces.ITCPTransport
, twisted.internet.interfaces.IUNIXTransport
Known implementations: twisted.conch.ssh.channel.SSHChannel
, twisted.conch.ssh.session.SSHSessionProcessProtocol
, twisted.internet._posixstdio.StandardIO
, twisted.internet.abstract.FileDescriptor
, twisted.internet.iocpreactor.abstract.FileHandle
, twisted.internet.protocol.FileWrapper
, twisted.internet.stdio.StandardIO
, twisted.internet.testing.StringTransport
, twisted.protocols.loopback.LoopbackRelay
, twisted.protocols.tls.TLSMemoryBIOProtocol
, twisted.trial._dist.worker.LocalWorkerTransport
, twisted.web._http2.H2Stream
, twisted.web.http.HTTPChannel
, twisted.protocols.loopback._LoopbackTransport
I am a transport for bytes.
I represent (and wrap) the physical connection and synchronicity of the framework which is talking to the network. I make no representations about whether calls to me will happen immediately or require returning to a control loop, or whether they will happen in the same or another thread. Consider methods of this class (aside from getPeer) to be 'thrown over the wall', to happen at some indeterminate time.
Method | get |
Similar to getPeer, but returns an address describing this side of the connection. |
Method | get |
Get the remote address of this connection. |
Method | lose |
Close my connection, after writing all pending data. |
Method | write |
Write some data to the physical connection, in sequence, in a non-blocking fashion. |
Method | write |
Write an iterable of byte strings to the physical connection. |
twisted.internet.interfaces.ITCPTransport
Get the remote address of this connection.
Treat this method with caution. It is the unfortunate result of the CGI and Jabber standards, but should not be considered reliable for the usual host of reasons; port forwarding, proxying, firewalls, IP masquerading, etc.
Returns | |
IAddress | An IAddress provider. |
twisted.internet.interfaces.IProcessTransport
Close my connection, after writing all pending data.
Note that if there is a registered producer on a transport it will not be closed until the producer has been unregistered.
Write some data to the physical connection, in sequence, in a non-blocking fashion.
If possible, make sure that it is all written. No data will ever be lost, although (obviously) the connection may be closed before it all gets through.
Parameters | |
data:bytes | The data to write. |