diff options
author | Simon THOBY <git@nightmared.fr> | 2021-10-22 22:56:45 +0200 |
---|---|---|
committer | Simon THOBY <git@nightmared.fr> | 2021-11-02 22:18:09 +0100 |
commit | 867e2df78a0e92cab93f647c3eeccabca5b869a2 (patch) | |
tree | 0f747929b6a5525ba76df37fd97364c71cec039c /rustables/src/expr/ct.rs | |
parent | d63381b5a1cc7cba91187eff7f87eeab35d4bc86 (diff) |
Add a (memory unsafe) manner to unserialize a few other expressions
Diffstat (limited to 'rustables/src/expr/ct.rs')
-rw-r--r-- | rustables/src/expr/ct.rs | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/rustables/src/expr/ct.rs b/rustables/src/expr/ct.rs index 1f15858..9d58591 100644 --- a/rustables/src/expr/ct.rs +++ b/rustables/src/expr/ct.rs @@ -31,6 +31,24 @@ impl Expression for Conntrack { b"ct\0" as *const _ as *const c_char } + fn from_expr(expr: *const sys::nftnl_expr) -> Option<Self> + where + Self: Sized, + { + unsafe { + let ct_key = sys::nftnl_expr_get_u32(expr, sys::NFTNL_EXPR_CT_KEY as u16); + let ct_sreg_is_set = sys::nftnl_expr_is_set(expr, sys::NFTNL_EXPR_CT_SREG as u16); + + match ct_key as i32 { + libc::NFT_CT_STATE => Some(Conntrack::State), + libc::NFT_CT_MARK => Some(Conntrack::Mark { + set: ct_sreg_is_set, + }), + _ => None, + } + } + } + fn to_expr(&self, _rule: &Rule) -> *mut sys::nftnl_expr { unsafe { let expr = try_alloc!(sys::nftnl_expr_alloc(Self::get_raw_name())); |