blob: 1b2d5a0536850cb460e8fbdbe5227a15cf195356 [file] [log] [blame]
susmit91e1d7c2016-10-03 16:16:57 -06001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
Junxiao Shi2760adc2017-07-06 05:44:52 +00002/*
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"
Junxiao Shi2760adc2017-07-06 05:44:52 +000030#include <ndn-cxx/net/network-interface.hpp>
susmit91e1d7c2016-10-03 16:16:57 -060031
32namespace nfd {
33
susmit91e1d7c2016-10-03 16:16:57 -060034/**
35 * \brief Represents a predicate to accept or reject a NetworkInterfaceInfo.
36 *
37 * The predicate consists of a whitelist and a blacklist. Whitelist and blacklist can contain,
38 * in no particular order, interface names (e.g., ifname eth0), mac addresses
39 * (e.g., ether 85:3b:4d:d3:5f:c2), subnets (e.g., subnet 192.0.2.0/24) or a wildcard (*) that matches
40 * all interfaces. A NetworkInterfaceInfo is accepted if it matches any entry in the whitelist and none
41 * of the entries in the blacklist.
42 */
susmit91e1d7c2016-10-03 16:16:57 -060043class NetworkInterfacePredicate
44{
45public:
46 NetworkInterfacePredicate();
47
48 /**
49 * \brief Set the whitelist to "*" and clear the blacklist
50 */
51 void
52 clear();
53
54 void
55 parseWhitelist(const boost::property_tree::ptree& list);
56
57 void
58 parseBlacklist(const boost::property_tree::ptree& list);
59
60 bool
Junxiao Shi2760adc2017-07-06 05:44:52 +000061 operator()(const ndn::net::NetworkInterface& netif) const;
62
63 bool
Junxiao Shi7003c602017-01-10 13:35:28 +000064 operator==(const NetworkInterfacePredicate& other) const;
65
66 bool
67 operator!=(const NetworkInterfacePredicate& other) const
68 {
69 return !this->operator==(other);
70 }
susmit91e1d7c2016-10-03 16:16:57 -060071
72private:
73 std::set<std::string> m_whitelist;
74 std::set<std::string> m_blacklist;
75};
76
77} // namespace nfd
78
79#endif // NFD_CORE_NETWORK_INTERFACE_PREDICATE_HPP