blob: 244373511173ff58dd04ca9522c9c0db06947d0c [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
34class NetworkInterfaceInfo;
35
36/**
37 * \brief Represents a predicate to accept or reject a NetworkInterfaceInfo.
38 *
39 * The predicate consists of a whitelist and a blacklist. Whitelist and blacklist can contain,
40 * in no particular order, interface names (e.g., ifname eth0), mac addresses
41 * (e.g., ether 85:3b:4d:d3:5f:c2), subnets (e.g., subnet 192.0.2.0/24) or a wildcard (*) that matches
42 * all interfaces. A NetworkInterfaceInfo is accepted if it matches any entry in the whitelist and none
43 * of the entries in the blacklist.
44 */
susmit91e1d7c2016-10-03 16:16:57 -060045class NetworkInterfacePredicate
46{
47public:
48 NetworkInterfacePredicate();
49
50 /**
51 * \brief Set the whitelist to "*" and clear the blacklist
52 */
53 void
54 clear();
55
56 void
57 parseWhitelist(const boost::property_tree::ptree& list);
58
59 void
60 parseBlacklist(const boost::property_tree::ptree& list);
61
62 bool
Junxiao Shi7003c602017-01-10 13:35:28 +000063 operator()(const NetworkInterfaceInfo& netif) const;
64
65 bool
Junxiao Shi2760adc2017-07-06 05:44:52 +000066 operator()(const ndn::net::NetworkInterface& netif) const;
67
68 bool
Junxiao Shi7003c602017-01-10 13:35:28 +000069 operator==(const NetworkInterfacePredicate& other) const;
70
71 bool
72 operator!=(const NetworkInterfacePredicate& other) const
73 {
74 return !this->operator==(other);
75 }
susmit91e1d7c2016-10-03 16:16:57 -060076
77private:
78 std::set<std::string> m_whitelist;
79 std::set<std::string> m_blacklist;
80};
81
82} // namespace nfd
83
84#endif // NFD_CORE_NETWORK_INTERFACE_PREDICATE_HPP