2 * Copyright (c) 2017 Cisco and/or its affiliates.
3 * Licensed under the Apache License, Version 2.0 (the "License");
4 * you may not use this file except in compliance with the License.
5 * You may obtain a copy of the License at:
7 * http://www.apache.org/licenses/LICENSE-2.0
9 * Unless required by applicable law or agreed to in writing, software
10 * distributed under the License is distributed on an "AS IS" BASIS,
11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 * See the License for the specific language governing permissions and
13 * limitations under the License.
18 #include "vom/acl_l3_rule.hpp"
22 l3_rule::l3_rule(uint32_t priority,
23 const action_t& action,
24 const route::prefix_t& src,
25 const route::prefix_t& dst,
27 uint16_t srcport_or_icmptype_first,
28 uint16_t srcport_or_icmptype_last,
29 uint16_t dstport_or_icmpcode_first,
30 uint16_t dstport_or_icmpcode_last,
31 uint8_t tcp_flags_mask,
32 uint8_t tcp_flags_value)
33 : m_priority(priority)
38 , m_srcport_or_icmptype_first(srcport_or_icmptype_first)
39 , m_srcport_or_icmptype_last(srcport_or_icmptype_last)
40 , m_dstport_or_icmpcode_first(dstport_or_icmpcode_first)
41 , m_dstport_or_icmpcode_last(dstport_or_icmpcode_last)
42 , m_tcp_flags_mask(tcp_flags_mask)
43 , m_tcp_flags_value(tcp_flags_value)
48 l3_rule::operator<(const l3_rule& other) const
50 return (other.m_priority < m_priority);
54 l3_rule::operator==(const l3_rule& rule) const
56 return ((m_action == rule.m_action) && (m_src == rule.m_src) &&
57 (m_dst == rule.m_dst) && (m_proto == rule.m_proto) &&
58 (m_srcport_or_icmptype_first == rule.m_srcport_or_icmptype_first) &&
59 (m_srcport_or_icmptype_last == rule.m_srcport_or_icmptype_last) &&
60 (m_dstport_or_icmpcode_first == rule.m_dstport_or_icmpcode_first) &&
61 (m_dstport_or_icmpcode_last == rule.m_dstport_or_icmpcode_last) &&
62 (m_tcp_flags_mask == rule.m_tcp_flags_mask) &&
63 (m_tcp_flags_value == rule.m_tcp_flags_value));
67 l3_rule::to_string() const
72 << "priority:" << m_priority << " action:" << m_action.to_string()
73 << " src:" << m_src.to_string() << " dst:" << m_dst.to_string()
74 << " proto:" << std::to_string(m_proto)
75 << " srcportfrom:" << m_srcport_or_icmptype_first
76 << " srcportto: " << m_srcport_or_icmptype_last
77 << " dstportfrom:" << m_dstport_or_icmpcode_first
78 << " dstportto:" << m_dstport_or_icmpcode_last
79 << " tcpflagmask:" << std::to_string(m_tcp_flags_mask)
80 << " tcpflagvalue:" << std::to_string(m_tcp_flags_value) << "]";
86 l3_rule::set_src_ip(route::prefix_t src)
92 l3_rule::set_dst_ip(route::prefix_t dst)
98 l3_rule::set_proto(uint8_t proto)
103 l3_rule::set_src_from_port(uint16_t srcport_or_icmptype_first)
105 m_srcport_or_icmptype_first = srcport_or_icmptype_first;
109 l3_rule::set_src_to_port(uint16_t srcport_or_icmptype_last)
111 m_srcport_or_icmptype_last = srcport_or_icmptype_last;
115 l3_rule::set_dst_from_port(uint16_t dstport_or_icmpcode_first)
117 m_dstport_or_icmpcode_first = dstport_or_icmpcode_first;
121 l3_rule::set_dst_to_port(uint16_t dstport_or_icmpcode_last)
123 m_dstport_or_icmpcode_last = dstport_or_icmpcode_last;
127 l3_rule::set_tcp_flags_mask(uint8_t tcp_flags_mask)
129 m_tcp_flags_mask = tcp_flags_mask;
133 l3_rule::set_tcp_flags_value(uint8_t tcp_flags_value)
135 m_tcp_flags_value = tcp_flags_value;
138 const route::prefix_t&
145 l3_rule::priority() const
151 l3_rule::action() const
156 const route::prefix_t&
163 l3_rule::proto() const
169 l3_rule::srcport_or_icmptype_first() const
171 return m_srcport_or_icmptype_first;
175 l3_rule::srcport_or_icmptype_last() const
177 return m_srcport_or_icmptype_last;
181 l3_rule::dstport_or_icmpcode_first() const
183 return m_dstport_or_icmpcode_first;
187 l3_rule::dstport_or_icmpcode_last() const
189 return m_dstport_or_icmpcode_last;
193 l3_rule::tcp_flags_mask() const
195 return m_tcp_flags_mask;
199 l3_rule::tcp_flags_value() const
201 return m_tcp_flags_value;
208 * fd.io coding-style-patch-verification: ON
211 * eval: (c-set-style "mozilla")