24 #include <boost/filesystem.hpp> 31 TrustAnchorContainer::AnchorContainer::add(Certificate&& cert)
33 AnchorContainerBase::insert(std::move(cert));
37 TrustAnchorContainer::AnchorContainer::remove(
const Name& certName)
39 AnchorContainerBase::erase(certName);
43 TrustAnchorContainer::AnchorContainer::clear()
45 AnchorContainerBase::clear();
51 auto group = m_groups.find(groupId);
52 if (group == m_groups.end()) {
53 std::tie(group, std::ignore) = m_groups.insert(make_shared<StaticTrustAnchorGroup>(m_anchors, groupId));
56 if (staticGroup ==
nullptr) {
57 BOOST_THROW_EXCEPTION(
Error(
"Cannot add static anchor to a non-static anchor group " + groupId));
59 staticGroup->add(std::move(cert));
64 time::nanoseconds refreshPeriod,
bool isDir)
66 if (m_groups.count(groupId) != 0) {
67 BOOST_THROW_EXCEPTION(
Error(
"Cannot create dynamic group, because group " + groupId +
" already exists"));
70 m_groups.insert(make_shared<DynamicTrustAnchorGroup>(m_anchors, groupId, path, refreshPeriod, isDir));
85 auto cert = m_anchors.lower_bound(keyName);
86 if (cert == m_anchors.end() || !keyName.
isPrefixOf(cert->getName()))
96 for (
auto cert = m_anchors.lower_bound(interest.
getName());
109 auto group = m_groups.find(groupId);
110 if (group == m_groups.end()) {
111 BOOST_THROW_EXCEPTION(
Error(
"Trust anchor group " + groupId +
" does not exist"));
119 return m_anchors.size();
123 TrustAnchorContainer::refresh()
125 for (
auto it = m_groups.begin(); it != m_groups.end(); ++it) {
126 m_groups.modify(it, [] (shared_ptr<TrustAnchorGroup>& group) { group->refresh(); });
const Name & getName() const
Copyright (c) 2011-2015 Regents of the University of California.
The certificate following the certificate format naming convention.
const Certificate * find(const Name &keyName) const
Search for certificate across all groups (longest prefix match)
size_t size() const
Get number of trust anchors across all groups.
void insert(const std::string &groupId, Certificate &&cert)
Insert a static trust anchor.
represents an Interest packet
Catch-all error for security policy errors that don't fit in other categories.
TrustAnchorGroup & getGroup(const std::string &groupId) const
Get trusted anchor group.
represents a container for trust anchors.
A group of trust anchors.
Static trust anchor group.
Represents an absolute name.
bool isPrefixOf(const Name &other) const
Check if this name is a prefix of another name.
bool matchesData(const Data &data) const
Check if Interest can be satisfied by data.
void clear()
Remove all static or dynamic anchors.