29 TrustAnchorContainer::AnchorContainer::add(Certificate&& cert)
31 AnchorContainerBase::insert(std::move(cert));
35 TrustAnchorContainer::AnchorContainer::remove(
const Name& certName)
37 AnchorContainerBase::erase(certName);
41 TrustAnchorContainer::AnchorContainer::clear()
43 AnchorContainerBase::clear();
49 auto group = m_groups.find(groupId);
50 if (group == m_groups.end()) {
51 std::tie(group, std::ignore) = m_groups.insert(std::make_shared<StaticTrustAnchorGroup>(m_anchors,
55 if (staticGroup ==
nullptr) {
56 NDN_THROW(
Error(
"Cannot add static anchor to a non-static anchor group " + groupId));
58 staticGroup->add(std::move(cert));
65 if (m_groups.count(groupId) != 0) {
66 NDN_THROW(
Error(
"Cannot create dynamic group, because group " + groupId +
" already exists"));
69 m_groups.insert(std::make_shared<DynamicTrustAnchorGroup>(m_anchors, groupId, path,
70 refreshPeriod, isDir));
85 auto cert = m_anchors.lower_bound(keyName);
86 if (cert == m_anchors.end() || !keyName.
isPrefixOf(cert->getName()))
97 for (
auto cert = m_anchors.lower_bound(interest.
getName());
110 auto group = m_groups.find(groupId);
111 if (group == m_groups.end()) {
112 NDN_THROW(
Error(
"Trust anchor group " + groupId +
" does not exist"));
120 return m_anchors.size();
124 TrustAnchorContainer::refresh()
126 for (
auto it = m_groups.begin(); it != m_groups.end(); ++it) {
127 m_groups.modify(it, [] (
const auto& group) { group->refresh(); });
Represents an Interest packet.
const Name & getName() const noexcept
bool matchesData(const Data &data) const
Check if Interest can be satisfied by data.
Represents an absolute name.
bool isPrefixOf(const Name &other) const noexcept
Check if this name is a prefix of another name.
Represents an NDN certificate.
Static trust anchor group.
A container for trust anchors.
void insert(const std::string &groupId, Certificate &&cert)
Insert a static trust anchor.
const Certificate * find(const Name &keyName) const
Search for certificate across all groups (longest prefix match).
void clear()
Remove all static or dynamic anchors.
size_t size() const
Get number of trust anchors across all groups.
TrustAnchorGroup & getGroup(const std::string &groupId) const
Get trusted anchor group.
A group of trust anchors.
boost::chrono::nanoseconds nanoseconds