A Transport that communicates on a connected TCP socket. More...
#include <daemon/face/tcp-transport.hpp>
Public Types | |
using | Counters = TransportCounters |
Counters provided by a transport. More... | |
typedef boost::asio::ip::tcp | protocol |
Public Member Functions | |
TcpTransport (protocol::socket &&socket, ndn::nfd::FacePersistency persistency, ndn::nfd::FaceScope faceScope) | |
bool | canChangePersistencyTo (ndn::nfd::FacePersistency newPersistency) const |
check whether the face persistency can be changed to newPersistency More... | |
void | close () |
Request the transport to be closed. More... | |
virtual const Counters & | getCounters () const |
time::steady_clock::TimePoint | getExpirationTime () const |
const Face * | getFace () const |
const LinkService * | getLinkService () const |
LinkService * | getLinkService () |
ndn::nfd::LinkType | getLinkType () const |
FaceUri | getLocalUri () const |
ssize_t | getMtu () const |
ndn::nfd::FacePersistency | getPersistency () const |
FaceUri | getRemoteUri () const |
ndn::nfd::FaceScope | getScope () const |
ssize_t | getSendQueueCapacity () const |
ssize_t | getSendQueueLength () final |
TransportState | getState () const |
void | send (const Block &packet) |
Send a link-layer packet. More... | |
void | setFaceAndLinkService (Face &face, LinkService &service) |
set Face and LinkService for Transport More... | |
void | setPersistency (ndn::nfd::FacePersistency newPersistency) |
changes face persistency setting More... | |
Public Attributes | |
signal::Signal< Transport, TransportState, TransportState > | afterStateChange |
signals when transport state changes More... | |
Protected Member Functions | |
void | afterChangePersistency (ndn::nfd::FacePersistency oldPersistency) final |
invoked after the persistency has been changed More... | |
bool | canChangePersistencyToImpl (ndn::nfd::FacePersistency newPersistency) const final |
invoked by canChangePersistencyTo to perform the check More... | |
void | deferredClose () |
void | doClose () final |
performs Transport specific operations to close the transport More... | |
void | doSend (const Block &packet) override |
performs Transport specific operations to send a packet More... | |
size_t | getSendQueueBytes () const |
void | handleError (const boost::system::error_code &error) final |
void | handleReceive (const boost::system::error_code &error, size_t nBytesReceived) |
void | handleSend (const boost::system::error_code &error, size_t nBytesSent) |
void | processErrorCode (const boost::system::error_code &error) |
void | receive (const Block &packet, const EndpointId &endpoint=0) |
Pass a received link-layer packet to the upper layer for further processing. More... | |
void | resetReceiveBuffer () |
void | resetSendQueue () |
void | sendFromQueue () |
void | setExpirationTime (const time::steady_clock::TimePoint &expirationTime) |
void | setLinkType (ndn::nfd::LinkType linkType) |
void | setLocalUri (const FaceUri &uri) |
void | setMtu (ssize_t mtu) |
void | setRemoteUri (const FaceUri &uri) |
void | setScope (ndn::nfd::FaceScope scope) |
void | setSendQueueCapacity (ssize_t sendQueueCapacity) |
void | setState (TransportState newState) |
set transport state More... | |
void | startReceive () |
Protected Attributes | |
protocol::socket | m_socket |
ByteCounter | nInBytes |
total incoming bytes More... | |
PacketCounter | nInPackets |
count of incoming packets More... | |
ByteCounter | nOutBytes |
total outgoing bytes More... | |
PacketCounter | nOutPackets |
count of outgoing packets More... | |
A Transport that communicates on a connected TCP socket.
When persistency is set to permanent, whenever the TCP connection is severed, the transport state is set to DOWN, and the connection is retried periodically with exponential backoff until it is reestablished
Definition at line 43 of file tcp-transport.hpp.
|
inherited |
Counters provided by a transport.
Definition at line 114 of file transport.hpp.
|
inherited |
Definition at line 46 of file stream-transport.hpp.
nfd::face::TcpTransport::TcpTransport | ( | protocol::socket && | socket, |
ndn::nfd::FacePersistency | persistency, | ||
ndn::nfd::FaceScope | faceScope | ||
) |
Definition at line 43 of file tcp-transport.cpp.
|
finalprotectedvirtual |
invoked after the persistency has been changed
The base class implementation does nothing. When overridden in a subclass, the function should update internal states after persistency setting has been changed.
Reimplemented from nfd::face::Transport.
Definition at line 89 of file tcp-transport.cpp.
|
inherited |
check whether the face persistency can be changed to newPersistency
This function serves as the external API, and invokes the protected function canChangePersistencyToImpl to perform further checks if newPersistency
differs from the current persistency.
Definition at line 142 of file transport.cpp.
|
finalprotectedvirtual |
invoked by canChangePersistencyTo to perform the check
Base class implementation returns false.
newPersistency | the new persistency, guaranteed to be different from current persistency |
Reimplemented from nfd::face::Transport.
Definition at line 83 of file tcp-transport.cpp.
|
inherited |
Request the transport to be closed.
This operation is effective only if transport is in UP or DOWN state, otherwise it has no effect. The transport changes state to CLOSING, and performs cleanup procedure. The state will be changed to CLOSED when cleanup is complete, which may happen synchronously or asynchronously.
Definition at line 79 of file transport.cpp.
|
protectedinherited |
Definition at line 168 of file stream-transport.hpp.
|
finalprotectedvirtual |
performs Transport specific operations to close the transport
This is invoked once by close()
after changing state to CLOSING. It will not be invoked by Transport class if the transport is already CLOSING or CLOSED.
When the cleanup procedure is complete, this method should change state to CLOSED. This transition can happen synchronously or asynchronously.
Implements nfd::face::Transport.
Definition at line 193 of file tcp-transport.cpp.
|
overrideprotectedvirtualinherited |
performs Transport specific operations to send a packet
packet | the packet to be sent, can be assumed to be valid and well-formed |
Implements nfd::face::Transport.
Definition at line 183 of file stream-transport.hpp.
|
inlinevirtualinherited |
Reimplemented in nfd::face::WebSocketTransport.
Definition at line 373 of file transport.hpp.
|
inlineinherited |
time::steady_clock::TimePoint::max() | the transport has indefinite lifetime |
Definition at line 457 of file transport.hpp.
|
inlineinherited |
Definition at line 355 of file transport.hpp.
|
inlineinherited |
Definition at line 361 of file transport.hpp.
|
inlineinherited |
Definition at line 367 of file transport.hpp.
|
inlineinherited |
Definition at line 421 of file transport.hpp.
|
inlineinherited |
Definition at line 379 of file transport.hpp.
|
inlineinherited |
MTU_UNLIMITED | transport has no limit on payload size |
This size is the maximum packet size that can be sent or received through this transport.
For a datagram-based transport, this is typically the Maximum Transmission Unit (MTU), after the overhead of headers introduced by the transport has been accounted for. For a stream-based transport, this is typically unlimited (MTU_UNLIMITED).
Definition at line 433 of file transport.hpp.
|
inlineinherited |
Definition at line 415 of file transport.hpp.
|
inlineinherited |
Definition at line 391 of file transport.hpp.
|
inlineinherited |
Definition at line 403 of file transport.hpp.
|
protectedinherited |
Definition at line 330 of file stream-transport.hpp.
|
inlineinherited |
QUEUE_UNSUPPORTED | transport does not support queue capacity retrieval |
QUEUE_ERROR | transport was unable to retrieve the queue capacity |
Definition at line 439 of file transport.hpp.
|
finalvirtual |
QUEUE_UNSUPPORTED | transport does not support queue length retrieval |
QUEUE_ERROR | transport was unable to retrieve the queue length |
Reimplemented from nfd::face::Transport.
Definition at line 61 of file tcp-transport.cpp.
|
inlineinherited |
Definition at line 451 of file transport.hpp.
|
finalprotectedvirtual |
Reimplemented from nfd::face::StreamTransport< boost::asio::ip::tcp >.
Definition at line 102 of file tcp-transport.cpp.
|
protectedinherited |
Definition at line 238 of file stream-transport.hpp.
|
protectedinherited |
Definition at line 208 of file stream-transport.hpp.
|
protectedinherited |
Definition at line 283 of file stream-transport.hpp.
|
protectedinherited |
Pass a received link-layer packet to the upper layer for further processing.
packet | the received packet, must be a valid and well-formed TLV block |
endpoint | the source endpoint |
Definition at line 113 of file transport.cpp.
|
protectedinherited |
Definition at line 314 of file stream-transport.hpp.
|
protectedinherited |
Definition at line 321 of file stream-transport.hpp.
|
inherited |
Send a link-layer packet.
packet | the packet to be sent, must be a valid and well-formed TLV block |
Definition at line 92 of file transport.cpp.
|
protectedinherited |
Definition at line 200 of file stream-transport.hpp.
|
inlineprotectedinherited |
Definition at line 463 of file transport.hpp.
|
inherited |
set Face and LinkService for Transport
Definition at line 69 of file transport.cpp.
|
inlineprotectedinherited |
Definition at line 427 of file transport.hpp.
|
inlineprotectedinherited |
Definition at line 385 of file transport.hpp.
|
protectedinherited |
Definition at line 126 of file transport.cpp.
|
inherited |
changes face persistency setting
Definition at line 164 of file transport.cpp.
|
inlineprotectedinherited |
Definition at line 397 of file transport.hpp.
|
inlineprotectedinherited |
Definition at line 409 of file transport.hpp.
|
inlineprotectedinherited |
Definition at line 445 of file transport.hpp.
|
protectedinherited |
set transport state
Only the following transitions are valid: UP->DOWN, DOWN->UP, UP/DOWN->CLOSING/FAILED, CLOSING/FAILED->CLOSED
std::runtime_error | transition is invalid. |
Definition at line 187 of file transport.cpp.
|
protectedinherited |
Definition at line 227 of file stream-transport.hpp.
|
inherited |
signals when transport state changes
Definition at line 243 of file transport.hpp.
|
protectedinherited |
Definition at line 98 of file stream-transport.hpp.
|
inherited |
total incoming bytes
This counter includes headers imposed by NFD (such as NDNLP), but excludes overhead of underlying protocol (such as IP header). For a datagram-based transport, an incoming packet that cannot be parsed as TLV would not be counted.
Definition at line 78 of file transport.hpp.
|
inherited |
count of incoming packets
A 'packet' typically means a top-level TLV block. For a datagram-based transport, an incoming packet that cannot be parsed as TLV would not be counted.
Definition at line 62 of file transport.hpp.
|
inherited |
total outgoing bytes
This counter includes headers imposed by NFD (such as NDNLP), but excludes overhead of underlying protocol (such as IP header). This counter is increased only if transport is UP.
Definition at line 86 of file transport.hpp.
|
inherited |
count of outgoing packets
A 'packet' typically means a top-level TLV block. This counter is incremented only if transport is UP.
Definition at line 69 of file transport.hpp.