blob: f48da059a608a648b7463ef2ac97ad384a275614 [file] [log] [blame]
susmit91e1d7c2016-10-03 16:16:57 -06001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2/**
Junxiao Shi7003c602017-01-10 13:35:28 +00003 * Copyright (c) 2014-2017, Regents of the University of California,
4 * Arizona Board of Regents,
5 * Colorado State University,
6 * University Pierre & Marie Curie, Sorbonne University,
7 * Washington University in St. Louis,
8 * Beijing Institute of Technology,
9 * The University of Memphis.
susmit91e1d7c2016-10-03 16:16:57 -060010 *
11 * This file is part of NFD (Named Data Networking Forwarding Daemon).
12 * See AUTHORS.md for complete list of NFD authors and contributors.
13 *
14 * NFD is free software: you can redistribute it and/or modify it under the terms
15 * of the GNU General Public License as published by the Free Software Foundation,
16 * either version 3 of the License, or (at your option) any later version.
17 *
18 * NFD is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
19 * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
20 * PURPOSE. See the GNU General Public License for more details.
21 *
22 * You should have received a copy of the GNU General Public License along with
23 * NFD, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
24 */
25
26#ifndef NFD_CORE_NETWORK_INTERFACE_PREDICATE_HPP
27#define NFD_CORE_NETWORK_INTERFACE_PREDICATE_HPP
28
29#include "common.hpp"
30
31namespace nfd {
32
33class NetworkInterfaceInfo;
34
35/**
36 * \brief Represents a predicate to accept or reject a NetworkInterfaceInfo.
37 *
38 * The predicate consists of a whitelist and a blacklist. Whitelist and blacklist can contain,
39 * in no particular order, interface names (e.g., ifname eth0), mac addresses
40 * (e.g., ether 85:3b:4d:d3:5f:c2), subnets (e.g., subnet 192.0.2.0/24) or a wildcard (*) that matches
41 * all interfaces. A NetworkInterfaceInfo is accepted if it matches any entry in the whitelist and none
42 * of the entries in the blacklist.
43 */
susmit91e1d7c2016-10-03 16:16:57 -060044class NetworkInterfacePredicate
45{
46public:
47 NetworkInterfacePredicate();
48
49 /**
50 * \brief Set the whitelist to "*" and clear the blacklist
51 */
52 void
53 clear();
54
55 void
56 parseWhitelist(const boost::property_tree::ptree& list);
57
58 void
59 parseBlacklist(const boost::property_tree::ptree& list);
60
61 bool
Junxiao Shi7003c602017-01-10 13:35:28 +000062 operator()(const NetworkInterfaceInfo& netif) const;
63
64 bool
65 operator==(const NetworkInterfacePredicate& other) const;
66
67 bool
68 operator!=(const NetworkInterfacePredicate& other) const
69 {
70 return !this->operator==(other);
71 }
susmit91e1d7c2016-10-03 16:16:57 -060072
73private:
74 std::set<std::string> m_whitelist;
75 std::set<std::string> m_blacklist;
76};
77
78} // namespace nfd
79
80#endif // NFD_CORE_NETWORK_INTERFACE_PREDICATE_HPP