use core::ffi::c_void; use aya_bpf_bindings::helpers::bpf_sock_ops_cb_flags_set; use crate::{bindings::bpf_sock_ops, BpfContext}; pub struct SockOpsContext { pub ops: *mut bpf_sock_ops, } impl SockOpsContext { pub fn new(ops: *mut bpf_sock_ops) -> SockOpsContext { SockOpsContext { ops } } pub fn op(&self) -> u32 { unsafe { (*self.ops).op } } pub fn family(&self) -> u32 { unsafe { (*self.ops).family } } pub fn cb_flags(&self) -> u32 { unsafe { (*self.ops).bpf_sock_ops_cb_flags } } pub fn set_cb_flags(&self, flags: i32) -> Result<(), i64> { let ret = unsafe { bpf_sock_ops_cb_flags_set(self.ops, flags) }; if ret == 0 { Ok(()) } else { Err(ret) } } pub fn remote_ip4(&self) -> u32 { unsafe { (*self.ops).remote_ip4 } } pub fn local_ip4(&self) -> u32 { unsafe { (*self.ops).local_ip4 } } pub fn remote_ip6(&self) -> [u32; 4] { unsafe { (*self.ops).remote_ip6 } } pub fn local_ip6(&self) -> [u32; 4] { unsafe { (*self.ops).local_ip6 } } pub fn local_port(&self) -> u32 { unsafe { (*self.ops).local_port } } pub fn remote_port(&self) -> u32 { unsafe { (*self.ops).remote_port } } pub fn arg(&self, n: usize) -> u32 { unsafe { (*self.ops).__bindgen_anon_1.args[n] } } } impl BpfContext for SockOpsContext { fn as_ptr(&self) -> *mut c_void { self.ops as *mut _ } }