represents a forwarding strategy More...
#include <strategy.hpp>
Classes | |
struct | ParsedInstanceName |
Public Member Functions | |
Strategy (Forwarder &forwarder) | |
construct a strategy instance More... | |
virtual | ~Strategy () |
const Name & | getInstanceName () const |
virtual void | afterReceiveInterest (const Face &inFace, const Interest &interest, const shared_ptr< pit::Entry > &pitEntry)=0 |
trigger after Interest is received More... | |
virtual void | beforeSatisfyInterest (const shared_ptr< pit::Entry > &pitEntry, const Face &inFace, const Data &data) |
trigger before PIT entry is satisfied More... | |
virtual void | beforeExpirePendingInterest (const shared_ptr< pit::Entry > &pitEntry) |
trigger before PIT entry expires More... | |
virtual void | afterReceiveNack (const Face &inFace, const lp::Nack &nack, const shared_ptr< pit::Entry > &pitEntry) |
trigger after Nack is received More... | |
Static Public Member Functions | |
template<typename S > | |
static void | registerType (const Name &strategyName=S::getStrategyName()) |
register a strategy type More... | |
static bool | canCreate (const Name &instanceName) |
static unique_ptr< Strategy > | create (const Name &instanceName, Forwarder &forwarder) |
static bool | areSameType (const Name &instanceNameA, const Name &instanceNameB) |
static std::set< Name > | listRegistered () |
static const Name & | getStrategyName () |
Protected Member Functions | |
void | sendInterest (const shared_ptr< pit::Entry > &pitEntry, Face &outFace, const Interest &interest) |
send Interest to outFace More... | |
void | rejectPendingInterest (const shared_ptr< pit::Entry > &pitEntry) |
decide that a pending Interest cannot be forwarded More... | |
void | sendNack (const shared_ptr< pit::Entry > &pitEntry, const Face &outFace, const lp::NackHeader &header) |
send Nack to outFace More... | |
void | sendNacks (const shared_ptr< pit::Entry > &pitEntry, const lp::NackHeader &header, std::initializer_list< const Face * > exceptFaces=std::initializer_list< const Face * >()) |
send Nack to every face that has an in-record, except those in exceptFaces More... | |
const fib::Entry & | lookupFib (const pit::Entry &pitEntry) const |
performs a FIB lookup, considering Link object if present More... | |
MeasurementsAccessor & | getMeasurements () |
Face * | getFace (FaceId id) const |
const FaceTable & | getFaceTable () const |
void | setInstanceName (const Name &name) |
set strategy instance name More... | |
Static Protected Member Functions | |
static ParsedInstanceName | parseInstanceName (const Name &input) |
parse a strategy instance name More... | |
static Name | makeInstanceName (const Name &input, const Name &strategyName) |
construct a strategy instance name More... | |
Protected Attributes | |
signal::Signal< FaceTable, Face & > & | afterAddFace |
signal::Signal< FaceTable, Face & > & | beforeRemoveFace |
represents a forwarding strategy
Definition at line 37 of file strategy.hpp.
|
explicit |
construct a strategy instance
forwarder | a reference to the forwarder, used to enable actions and accessors. |
Definition at line 141 of file strategy.cpp.
References ~Strategy().
Referenced by registerType().
|
virtualdefault |
Referenced by registerType(), and Strategy().
|
inlinestatic |
register a strategy type
S | subclass of Strategy |
strategyName | strategy program name, must contain version |
Definition at line 48 of file strategy.hpp.
References areSameType(), canCreate(), create(), getStrategyName(), listRegistered(), Strategy(), and ~Strategy().
|
static |
instanceName
instanceName | strategy instance name, may contain version and parameters |
create
, but does not attempt to construct an instance. Definition at line 84 of file strategy.cpp.
Referenced by registerType().
|
static |
instanceName
nullptr | if !canCreate(instanceName) |
std::invalid_argument | strategy type constructor does not accept specified version or parameters |
Definition at line 90 of file strategy.cpp.
References websocketpp::http::status_code::found, and NFD_LOG_DEBUG.
Referenced by registerType().
|
static |
instanceNameA
and instanceNameA
will initiate same strategy type Definition at line 106 of file strategy.cpp.
Referenced by registerType().
|
static |
Definition at line 112 of file strategy.cpp.
Referenced by registerType().
|
static |
The strategy name is defined by the strategy program. It must end with a version component.
Referenced by registerType().
|
inline |
The instance name is assigned during instantiation. It contains a version component, and may have extra parameter components.
Definition at line 110 of file strategy.hpp.
References afterReceiveInterest(), afterReceiveNack(), beforeExpirePendingInterest(), beforeSatisfyInterest(), Face, and VIRTUAL_WITH_TESTS.
Referenced by nfd::strategy_choice::Entry::getStrategyInstanceName().
|
pure virtual |
trigger after Interest is received
The Interest:
The strategy should decide whether and where to forward this Interest.
Implemented in nfd::fw::BestRouteStrategy2, nfd::fw::AccessStrategy, nfd::fw::asf::AsfStrategy, nfd::fw::MulticastStrategy, nfd::fw::NccStrategy, and nfd::fw::BestRouteStrategyBase.
Referenced by nfd::Forwarder::Forwarder(), and getInstanceName().
|
virtual |
trigger before PIT entry is satisfied
This trigger is invoked when an incoming Data satisfies the PIT entry. It can be invoked even if the PIT entry has already been satisfied.
In this base class this method does nothing.
Reimplemented in nfd::fw::AccessStrategy, nfd::fw::asf::AsfStrategy, and nfd::fw::NccStrategy.
Definition at line 152 of file strategy.cpp.
References ndn::Data::getName(), and NFD_LOG_DEBUG.
Referenced by nfd::Forwarder::Forwarder(), and getInstanceName().
|
virtual |
trigger before PIT entry expires
PIT entry expires when InterestLifetime has elapsed for all InRecords, and it is not satisfied by an incoming Data.
This trigger is not invoked for PIT entry already satisfied.
In this base class this method does nothing.
Definition at line 160 of file strategy.cpp.
References NFD_LOG_DEBUG.
Referenced by nfd::Forwarder::Forwarder(), and getInstanceName().
|
virtual |
trigger after Nack is received
This trigger is invoked when an incoming Nack is received in response to an forwarded Interest. The Nack has been confirmed to be a response to the last Interest forwarded to that upstream, i.e. the PIT out-record exists and has a matching Nonce. The NackHeader has been recorded in the PIT out-record.
In this base class this method does nothing.
Reimplemented in nfd::fw::BestRouteStrategy2, nfd::fw::asf::AsfStrategy, and nfd::fw::MulticastStrategy.
Definition at line 166 of file strategy.cpp.
References NFD_LOG_DEBUG.
Referenced by nfd::Forwarder::Forwarder(), and getInstanceName().
|
inlineprotected |
send Interest to outFace
pitEntry | PIT entry |
outFace | face through which to send out the Interest |
interest | the Interest packet |
Definition at line 191 of file strategy.hpp.
References VIRTUAL_WITH_TESTS.
Referenced by nfd::fw::BestRouteStrategyBase::afterReceiveInterest(), nfd::fw::NccStrategy::afterReceiveInterest(), nfd::fw::MulticastStrategy::afterReceiveInterest(), nfd::fw::AccessStrategy::afterReceiveInterest(), nfd::fw::BestRouteStrategy2::afterReceiveInterest(), nfd::fw::asf::AsfStrategy::afterReceiveNack(), and nfd::fw::NccStrategy::doPropagate().
|
inlineprotected |
decide that a pending Interest cannot be forwarded
pitEntry | PIT entry |
This shall not be called if the pending Interest has been forwarded earlier, and does not need to be resent now.
Definition at line 204 of file strategy.hpp.
References VIRTUAL_WITH_TESTS.
Referenced by nfd::fw::BestRouteStrategyBase::afterReceiveInterest(), nfd::fw::NccStrategy::afterReceiveInterest(), nfd::fw::MulticastStrategy::afterReceiveInterest(), nfd::fw::asf::AsfStrategy::afterReceiveInterest(), nfd::fw::AccessStrategy::afterReceiveInterest(), and nfd::fw::BestRouteStrategy2::afterReceiveInterest().
|
inlineprotected |
send Nack to outFace
pitEntry | PIT entry |
outFace | face through which to send out the Nack |
header | Nack header |
The outFace must have a PIT in-record, otherwise this method has no effect.
Definition at line 217 of file strategy.hpp.
References lookupFib(), and sendNacks().
Referenced by nfd::fw::MulticastStrategy::afterReceiveInterest(), nfd::fw::BestRouteStrategy2::afterReceiveInterest(), nfd::fw::asf::getValueForSorting(), and sendNacks().
|
protected |
send Nack to every face that has an in-record, except those in exceptFaces
pitEntry | PIT entry |
header | NACK header |
exceptFaces | list of faces that should be excluded from sending Nacks |
Definition at line 174 of file strategy.cpp.
References Face, nfd::pit::FaceRecord::getFace(), and sendNack().
Referenced by sendNack().
|
protected |
performs a FIB lookup, considering Link object if present
Definition at line 196 of file strategy.cpp.
References ndn::DelegationList::empty(), nfd::Forwarder::getFib(), ndn::Interest::getForwardingHint(), nfd::pit::Entry::getInterest(), nfd::Forwarder::getNetworkRegionTable(), nfd::fib::Entry::getPrefix(), nfd::NetworkRegionTable::isInProducerRegion(), and NFD_LOG_TRACE.
Referenced by nfd::fw::BestRouteStrategyBase::afterReceiveInterest(), nfd::fw::NccStrategy::afterReceiveInterest(), nfd::fw::MulticastStrategy::afterReceiveInterest(), nfd::fw::asf::AsfStrategy::afterReceiveInterest(), nfd::fw::AccessStrategy::afterReceiveInterest(), nfd::fw::BestRouteStrategy2::afterReceiveInterest(), nfd::fw::NccStrategy::doPropagate(), and sendNack().
|
inlineprotected |
Definition at line 241 of file strategy.hpp.
References Face.
Referenced by nfd::fw::NccStrategy::beforeSatisfyInterest(), nfd::fw::AccessStrategy::beforeSatisfyInterest(), nfd::fw::NccStrategy::getMeasurementsEntryInfo(), and nfd::fw::NccStrategy::timeoutOnBestFace().
|
inlineprotected |
Definition at line 247 of file strategy.hpp.
References nfd::Forwarder::getFace().
Referenced by nfd::fw::AccessStrategy::afterReceiveInterest(), and nfd::fw::NccStrategy::doPropagate().
|
inlineprotected |
Definition at line 253 of file strategy.hpp.
References nfd::Forwarder::getFaceTable().
|
staticprotected |
parse a strategy instance name
input | strategy instance name, may contain version and parameters |
std::invalid_argument | input format is unacceptable |
Definition at line 121 of file strategy.cpp.
References ndn::Name::getPrefix(), ndn::Name::getSubName(), ndn::nullopt, and ndn::Name::size().
Referenced by nfd::fw::AccessStrategy::AccessStrategy(), nfd::fw::asf::AsfStrategy::AsfStrategy(), nfd::fw::BestRouteStrategy::BestRouteStrategy(), nfd::fw::BestRouteStrategy2::BestRouteStrategy2(), nfd::fw::ClientControlStrategy::ClientControlStrategy(), nfd::fw::MulticastStrategy::MulticastStrategy(), and nfd::fw::NccStrategy::NccStrategy().
|
staticprotected |
construct a strategy instance name
input | strategy instance name, may contain version and parameters |
strategyName | strategy name with version but without parameters; typically this should be getStrategyName() |
If input
contains a version component, return input
unchanged. Otherwise, return input
plus the version component taken from strategyName
. This allows a strategy instance to be constructed with an unversioned name, but its final instance name should contain the version.
Definition at line 132 of file strategy.cpp.
References ndn::Name::at(), ndn::name::Component::isVersion(), ns3::ndn::Name, ndn::Name::rbegin(), and ndn::Name::rend().
Referenced by nfd::fw::AccessStrategy::AccessStrategy(), nfd::fw::asf::AsfStrategy::AsfStrategy(), nfd::fw::BestRouteStrategy::BestRouteStrategy(), nfd::fw::BestRouteStrategy2::BestRouteStrategy2(), nfd::fw::ClientControlStrategy::ClientControlStrategy(), nfd::fw::MulticastStrategy::MulticastStrategy(), and nfd::fw::NccStrategy::NccStrategy().
|
inlineprotected |
set strategy instance name
Definition at line 290 of file strategy.hpp.
References nfd::fw::Strategy::ParsedInstanceName::strategyName.
Referenced by nfd::fw::AccessStrategy::AccessStrategy(), nfd::fw::asf::AsfStrategy::AsfStrategy(), nfd::fw::BestRouteStrategy::BestRouteStrategy(), nfd::fw::BestRouteStrategy2::BestRouteStrategy2(), nfd::fw::ClientControlStrategy::ClientControlStrategy(), nfd::fw::MulticastStrategy::MulticastStrategy(), and nfd::fw::NccStrategy::NccStrategy().
|
protected |
Definition at line 306 of file strategy.hpp.
|
protected |
Definition at line 307 of file strategy.hpp.