mqtt: use generic tx iterator

pull/6629/head
Jason Ish 4 years ago committed by Victor Julien
parent d71bcd82d9
commit b335409690

@ -99,6 +99,12 @@ impl Drop for MQTTTransaction {
}
}
impl Transaction for MQTTTransaction {
fn id(&self) -> u64 {
self.tx_id
}
}
pub struct MQTTState {
tx_id: u64,
pub protocol_version: u8,
@ -109,6 +115,12 @@ pub struct MQTTState {
max_msg_len: usize,
}
impl State<MQTTTransaction> for MQTTState {
fn get_transactions(&self) -> &[MQTTTransaction] {
&self.transactions
}
}
impl MQTTState {
pub fn new() -> Self {
Self {
@ -520,27 +532,6 @@ impl MQTTState {
let ev = event as u8;
core::sc_app_layer_decoder_events_set_event_raw(&mut tx.events, ev);
}
fn tx_iterator(
&mut self,
min_tx_id: u64,
state: &mut u64,
) -> Option<(&MQTTTransaction, u64, bool)> {
let mut index = *state as usize;
let len = self.transactions.len();
while index < len {
let tx = &self.transactions[index];
if tx.tx_id < min_tx_id + 1 {
index += 1;
continue;
}
*state = index as u64;
return Some((tx, tx.tx_id - 1, (len - index) > 1));
}
return None;
}
}
// C exports.
@ -700,28 +691,6 @@ pub unsafe extern "C" fn rs_mqtt_state_get_events(
return tx.events;
}
#[no_mangle]
pub unsafe extern "C" fn rs_mqtt_state_get_tx_iterator(
_ipproto: u8,
_alproto: AppProto,
state: *mut std::os::raw::c_void,
min_tx_id: u64,
_max_tx_id: u64,
istate: &mut u64,
) -> applayer::AppLayerGetTxIterTuple {
let state = cast_pointer!(state, MQTTState);
match state.tx_iterator(min_tx_id, istate) {
Some((tx, out_tx_id, has_next)) => {
let c_tx = tx as *const _ as *mut _;
let ires = applayer::AppLayerGetTxIterTuple::with_values(c_tx, out_tx_id, has_next);
return ires;
}
None => {
return applayer::AppLayerGetTxIterTuple::not_found();
}
}
}
// Parser name as a C style string.
const PARSER_NAME: &'static [u8] = b"mqtt\0";
@ -758,7 +727,7 @@ pub unsafe extern "C" fn rs_mqtt_register_parser(cfg_max_msg_len: u32) {
localstorage_new: None,
localstorage_free: None,
get_files: None,
get_tx_iterator: Some(rs_mqtt_state_get_tx_iterator),
get_tx_iterator: Some(crate::applayer::state_get_tx_iterator::<MQTTState, MQTTTransaction>),
get_tx_data: rs_mqtt_get_tx_data,
apply_tx_config: None,
flags: APP_LAYER_PARSER_OPT_UNIDIR_TXS,

Loading…
Cancel
Save