Partial sync logic to publish data names. More...
#include <partial-producer.hpp>
Public Member Functions | |
PartialProducer (size_t expectedNumEntries, ndn::Face &face, const ndn::Name &syncPrefix, const ndn::Name &userPrefix, ndn::time::milliseconds helloReplyFreshness=HELLO_REPLY_FRESHNESS, ndn::time::milliseconds syncReplyFreshness=SYNC_REPLY_FRESHNESS) | |
constructor More... | |
bool | addUserNode (const ndn::Name &prefix) |
Adds a user node for synchronization. More... | |
ndn::optional< uint64_t > | getSeqNo (const ndn::Name &prefix) const |
Returns the current sequence number of the given prefix. More... | |
void | publishName (const ndn::Name &prefix, ndn::optional< uint64_t > seq=ndn::nullopt) |
Publish name to let subscribed consumers know. More... | |
void | removeUserNode (const ndn::Name &prefix) |
Remove the user node from synchronization. More... | |
Protected Member Functions | |
bool | isUserNode (const ndn::Name &prefix) |
void | onRegisterFailed (const ndn::Name &prefix, const std::string &msg) const |
Logs a message if setting an interest filter fails. More... | |
void | sendApplicationNack (const ndn::Name &name) |
Sends a data packet with content type nack. More... | |
void | updateSeqNo (const ndn::Name &prefix, uint64_t seq) |
Update m_prefixes and IBF with the given prefix and seq. More... | |
Protected Attributes | |
uint32_t | m_expectedNumEntries |
ndn::Face & | m_face |
std::map< uint32_t, ndn::Name > | m_hash2prefix |
ndn::time::milliseconds | m_helloReplyFreshness |
IBLT | m_iblt |
ndn::KeyChain | m_keyChain |
std::map< ndn::Name, uint32_t > | m_prefix2hash |
std::map< ndn::Name, uint64_t > | m_prefixes |
ndn::random::RandomNumberEngine & | m_rng |
ndn::Scheduler | m_scheduler |
SegmentPublisher | m_segmentPublisher |
ndn::Name | m_syncPrefix |
ndn::time::milliseconds | m_syncReplyFreshness |
uint32_t | m_threshold |
ndn::Name | m_userPrefix |
Partial sync logic to publish data names.
Application should call publishName whenever it wants to let consumers know that new data is available. Additional userPrefix should be added via addUserNode before calling publishName Currently, publishing of data needs to be handled by the application.
Definition at line 51 of file partial-producer.hpp.
psync::PartialProducer::PartialProducer | ( | size_t | expectedNumEntries, |
ndn::Face & | face, | ||
const ndn::Name & | syncPrefix, | ||
const ndn::Name & | userPrefix, | ||
ndn::time::milliseconds | helloReplyFreshness = HELLO_REPLY_FRESHNESS , |
||
ndn::time::milliseconds | syncReplyFreshness = SYNC_REPLY_FRESHNESS |
||
) |
constructor
Registers syncPrefix in NFD and sets internal filters for "sync" and "hello" under syncPrefix
expectedNumEntries | expected entries in IBF |
face | application's face |
syncPrefix | The prefix of the sync group |
userPrefix | The prefix of the first user in the group |
syncReplyFreshness | freshness of sync data |
helloReplyFreshness | freshness of hello data |
Definition at line 32 of file partial-producer.cpp.
|
inherited |
Adds a user node for synchronization.
Initializes m_prefixes[prefix] to zero Does not add zero-th sequence number to IBF because if a large number of user nodes are added then decoding of the difference between own IBF and other IBF will not be possible
prefix | the user node to be added |
Definition at line 55 of file producer-base.cpp.
|
inlineinherited |
Returns the current sequence number of the given prefix.
prefix | prefix to get the sequence number of |
Definition at line 83 of file producer-base.hpp.
|
inlineprotectedinherited |
Definition at line 132 of file producer-base.hpp.
|
protectedinherited |
Logs a message if setting an interest filter fails.
prefix | |
msg |
Definition at line 144 of file producer-base.cpp.
void psync::PartialProducer::publishName | ( | const ndn::Name & | prefix, |
ndn::optional< uint64_t > | seq = ndn::nullopt |
||
) |
Publish name to let subscribed consumers know.
If seq is null then the seq of prefix is incremented by 1 else the supplied sequence is set in the IBF. Upon updating the sequence in the IBF satisfyPendingSyncInterests is called to let subscribed consumers know.
prefix | the prefix to be updated |
seq | the sequence number of the prefix |
Definition at line 52 of file partial-producer.cpp.
|
inherited |
Remove the user node from synchronization.
Erases prefix from IBF and other maps
prefix | the user node to be removed |
Definition at line 67 of file producer-base.cpp.
|
protectedinherited |
Sends a data packet with content type nack.
Producer sends a nack to consumer if consumer has very old IBF whose differences with latest IBF can't be decoded successfully
name | send application nack with this name |
Definition at line 128 of file producer-base.cpp.
|
protectedinherited |
Update m_prefixes and IBF with the given prefix and seq.
Whoever calls this needs to make sure that prefix is in m_prefixes We remove already existing prefix/seq from IBF (unless seq is zero because we don't insert zero seq into IBF) Then we update m_prefix, m_prefix2hash, m_hash2prefix, and IBF
prefix | prefix of the update |
seq | sequence number of the update |
Definition at line 86 of file producer-base.cpp.
|
protectedinherited |
Definition at line 161 of file producer-base.hpp.
|
protectedinherited |
Definition at line 174 of file producer-base.hpp.
|
protectedinherited |
Definition at line 172 of file producer-base.hpp.
|
protectedinherited |
Definition at line 182 of file producer-base.hpp.
|
protectedinherited |
Definition at line 160 of file producer-base.hpp.
|
protectedinherited |
Definition at line 175 of file producer-base.hpp.
|
protectedinherited |
Definition at line 170 of file producer-base.hpp.
|
protectedinherited |
Definition at line 167 of file producer-base.hpp.
|
protectedinherited |
Definition at line 186 of file producer-base.hpp.
|
protectedinherited |
Definition at line 176 of file producer-base.hpp.
|
protectedinherited |
Definition at line 184 of file producer-base.hpp.
|
protectedinherited |
Definition at line 178 of file producer-base.hpp.
|
protectedinherited |
Definition at line 181 of file producer-base.hpp.
|
protectedinherited |
Definition at line 164 of file producer-base.hpp.
|
protectedinherited |
Definition at line 179 of file producer-base.hpp.