l3_list::l3_list(const key_t& key)
: m_hdl(handle_t::INVALID)
, m_key(key)
-{
-}
+{}
l3_list::l3_list(const handle_t& hdl, const key_t& key)
: m_hdl(hdl)
, m_key(key)
-{
-}
+{}
l3_list::l3_list(const key_t& key, const rules_t& rules)
: m_hdl(handle_t::INVALID)
, m_key(key)
, m_rules(rules)
-{
-}
+{}
l3_list::l3_list(const l3_list& o)
: m_hdl(o.m_hdl)
, m_key(o.m_key)
, m_rules(o.m_rules)
-{
-}
+{}
l3_list::~l3_list()
{
l3_list acl(hdl, std::string(reinterpret_cast<const char*>(payload.tag)));
for (unsigned int ii = 0; ii < payload.count; ii++) {
- const route::prefix_t src(payload.r[ii].is_ipv6,
- payload.r[ii].src_ip_addr,
- payload.r[ii].src_ip_prefix_len);
- const route::prefix_t dst(payload.r[ii].is_ipv6,
- payload.r[ii].dst_ip_addr,
- payload.r[ii].dst_ip_prefix_len);
+ const route::prefix_t src(payload.r[ii].src_prefix.address.af,
+ (uint8_t*)&payload.r[ii].src_prefix.address.un,
+ payload.r[ii].src_prefix.len);
+ const route::prefix_t dst(payload.r[ii].dst_prefix.address.af,
+ (uint8_t*)&payload.r[ii].dst_prefix.address.un,
+ payload.r[ii].dst_prefix.len);
l3_rule rule(ii, action_t::from_int(payload.r[ii].is_permit), src, dst);
rule.set_proto(payload.r[ii].proto);