- 
                Notifications
    You must be signed in to change notification settings 
- Fork 11
Support ctnetlink messages #9
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
base: main
Are you sure you want to change the base?
Conversation
Signed-off-by: terassyi <[email protected]>
Signed-off-by: terassyi <[email protected]>
Signed-off-by: terassyi <[email protected]>
Signed-off-by: terassyi <[email protected]>
Signed-off-by: terassyi <[email protected]>
Signed-off-by: terassyi <[email protected]>
Signed-off-by: terassyi <[email protected]>
Signed-off-by: terassyi <[email protected]>
Signed-off-by: terassyi <[email protected]>
Signed-off-by: terassyi <[email protected]>
Signed-off-by: terassyi <[email protected]>
Signed-off-by: terassyi <[email protected]>
98ea7f8    to
    2cb429b      
    Compare
  
    There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Just some cosmetic review comments.
Please give me more time(up to 2 weeks) to test and review the real functionality.
        
          
                src/ctnetlink/mod.rs
              
                Outdated
          
        
      | @@ -0,0 +1,4 @@ | |||
| // SPDX-License-Identifier: MIT | |||
|  | |||
| pub mod message; | |||
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Let's not expose internal module path to public.
I prefer expose all types as netlink-packet-netfilter::conn_track::{ContrackAttr, etc}.
        
          
                src/ctnetlink/nlas/ct_attr.rs
              
                Outdated
          
        
      | }; | ||
|  | ||
| #[derive(Debug, Clone, PartialEq, Eq)] | ||
| pub struct CtAttr { | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
How about ConnTrackAttribute?
| GetUnconfirmed(Option<Vec<FlowNla>>), | ||
| Other { | ||
| message_type: u8, | ||
| nlas: Vec<DefaultNla>, | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Unless kernel code confirmed future data will always a array of Nla, we should use Other((u8, DefaultNla)).
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It seems NetfilterBuffer doesn't provide the method to parse it to a single DefaultNla, should I create a new method?
        
          
                src/constants.rs
              
                Outdated
          
        
      |  | ||
| // netflter/nfnetlink_conntrack.h | ||
| // There is no definitions in rust-lang/libc | ||
| pub const IPCTNL_MSG_CT_NEW: u8 = 0; | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The netlink-packet-route has stopped exposing constants out.
I do not have time to polish here yet, but please do not add more lines to src/contants.rs.
Please:
- Remoev pub.
- Move constant to its user, this make our review easier.
| ]; | ||
|  | ||
| #[test] | ||
| fn test_ct_attr_parse() { | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I am expecting test case looks like:
https://github.com/rust-netlink/netlink-packet-route/blob/main/src/link/tests/vrf.rs#L68
(You do not need to document every bits)
You may use nlmon to capture real netlink message:
https://github.com/rust-netlink/netlink-packet-route?tab=readme-ov-file#development
| pub struct ProtocolInfoTcp { | ||
| pub state: u8, | ||
| pub wscale_original: u8, | ||
| pub wscale_reply: u8, | ||
| pub flgas_original: u16, | ||
| pub flags_reply: u16, | ||
| } | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Please consider to use NlaBuffer, example: https://github.com/rust-netlink/netlink-packet-route/blob/main/src/route/via.rs#L31
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I tried to use buffer macro like the following.
buffer!(ProtocolInfoTcpBuffer {
    state: (u8, 0),
    wscale_original: (u8, 1),
    wscale_reply: (u8, 2),
    flags_original: (u16, 3..5),
    flags_reply: (u16, 5..7),
});But ProtocolInfoTcp cannot be parsed simply like the example you gave, because it consists of nested ConntrackAttribute.
I'm not familiar with using buffer macro, so if you have any better idea about this, could you give me any hints?
        
          
                src/ctnetlink/nlas/flow/status.rs
              
                Outdated
          
        
      | use crate::constants::CTA_STATUS; | ||
|  | ||
| #[derive(Debug, Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash)] | ||
| pub enum ConnectionStatusFlag { | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Please use bitflags! here. Example: https://github.com/rust-netlink/netlink-packet-route/blob/main/src/route/next_hops.rs#L22
| // SPDX-License-Identifier: MIT | ||
|  | ||
| pub mod ct_attr; | ||
| pub mod flow; | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
do not expose module path out.
        
          
                src/ctnetlink/nlas/stat/nla.rs
              
                Outdated
          
        
      | Invalid(u32), | ||
| Ignore(u32), // no longer used | ||
| Delete(u32), // no longer used | ||
| DeleteList(u32), // no longer used | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If no longer used, please remove it.
| pub mod constants; | ||
| mod message; | ||
| pub use message::{NetfilterHeader, NetfilterMessage, NetfilterMessageInner}; | ||
| pub mod ctnetlink; | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The crate name already contains netlink, how about conn_track?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It is fine for me to change.
How about conntrack?
Upstream netfilter.org seems to use conntrack rather than conn_track.
83942c6    to
    17bb58f      
    Compare
  
    | pub struct ProtocolTuple { | ||
| pub src_port: u16, | ||
| pub dst_port: u16, | ||
| pub protocol: u8, | ||
| } | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The protocol tuple doesn't always include ports, and might include other information (attributes). ICMP flows have id, type and code, and IGMP has no additional fields (only CTA_PROTO_NUM should always be present):
enum ctattr_l4proto {
	CTA_PROTO_UNSPEC,
	CTA_PROTO_NUM,
	CTA_PROTO_SRC_PORT,
	CTA_PROTO_DST_PORT,
	CTA_PROTO_ICMP_ID,
	CTA_PROTO_ICMP_TYPE,
	CTA_PROTO_ICMP_CODE,
	CTA_PROTO_ICMPV6_ID,
	CTA_PROTO_ICMPV6_TYPE,
	CTA_PROTO_ICMPV6_CODE,
	__CTA_PROTO_MAX
};There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hi, @tik-stbuehler !
Thank you for your comments.
Yeah, I didn't consider non TCP and UDP protocols.
I've checked ICMP and ICMPv6 flows have id, type and code by wireshark.
So, I have a few plans to handle other protocols.
- Use Vec<DefaultNla>orVec<ProtocolTupleElement>as a field ofProtocolTuplestruct.
- In this case, ProtocolTupleElementis the attribute that represents allctattr_l4protovariants.
- Make ProtocolTuplean enum and define types representing each protocol.
How do you think?
- rename from CtAttr to ConntrackAttribute - rename from FlowNla and StatNla to FlowAttribute and StatCpuAttribute - use buffier!() for ProtocolInfoTcp - use bitflags!() for ConnectionStatusFlag - remove constant values and enum variants that is no longer used - move values from src/constatnts.rs to its users - stop exposing internal modules - introduce StatGlobalAttribute that represents ctattr_stats_global in the kernel - fix typo Signed-off-by: terassyi <[email protected]>
17bb58f    to
    d681983      
    Compare
  
    
This PR supports CtNetlink messages and add some example code to use it.
This is based on #8.
And as a reference implementation, I'm developing conntrack command in Rust with rust-netlink.
https://github.com/terassyi/rconntrack