app-layer: more generic state trait

Instead of a method that is required to return a slice of transactions,
use 2 methods, one to return the number of transactions in the
collection, and another to get a transaction by its index in the
collection.

This allows for the transaction collection to not be a contiguous array
and instead can be a VecDeque, or possibly another collection type that
supports retrieval by index.

Ticket #5278
pull/7349/head
Jason Ish 4 years ago committed by Victor Julien
parent bbd9a2ff1a
commit 7b11b4d3a1

@ -1,4 +1,4 @@
/* Copyright (C) 2017-2021 Open Information Security Foundation /* Copyright (C) 2017-2022 Open Information Security Foundation
* *
* You can copy, redistribute or modify this Program under the terms of * You can copy, redistribute or modify this Program under the terms of
* the GNU General Public License version 2 as published by the Free * the GNU General Public License version 2 as published by the Free
@ -535,14 +535,17 @@ pub trait Transaction {
} }
pub trait State<Tx: Transaction> { pub trait State<Tx: Transaction> {
fn get_transactions(&self) -> &[Tx]; /// Return the number of transactions in the state's transaction collection.
fn get_transaction_count(&self) -> usize;
/// Return a transaction by its index in the container.
fn get_transaction_by_index(&self, index: usize) -> Option<&Tx>;
fn get_transaction_iterator(&self, min_tx_id: u64, state: &mut u64) -> AppLayerGetTxIterTuple { fn get_transaction_iterator(&self, min_tx_id: u64, state: &mut u64) -> AppLayerGetTxIterTuple {
let mut index = *state as usize; let mut index = *state as usize;
let transactions = self.get_transactions(); let len = self.get_transaction_count();
let len = transactions.len();
while index < len { while index < len {
let tx = &transactions[index]; let tx = self.get_transaction_by_index(index).unwrap();
if tx.id() < min_tx_id + 1 { if tx.id() < min_tx_id + 1 {
index += 1; index += 1;
continue; continue;

@ -60,8 +60,12 @@ pub struct TemplateState {
} }
impl State<TemplateTransaction> for TemplateState { impl State<TemplateTransaction> for TemplateState {
fn get_transactions(&self) -> &[TemplateTransaction] { fn get_transaction_count(&self) -> usize {
&self.transactions self.transactions.len()
}
fn get_transaction_by_index(&self, index: usize) -> Option<&TemplateTransaction> {
self.transactions.get(index)
} }
} }

@ -109,8 +109,12 @@ pub struct DHCPState {
} }
impl State<DHCPTransaction> for DHCPState { impl State<DHCPTransaction> for DHCPState {
fn get_transactions(&self) -> &[DHCPTransaction] { fn get_transaction_count(&self) -> usize {
&self.transactions self.transactions.len()
}
fn get_transaction_by_index(&self, index: usize) -> Option<&DHCPTransaction> {
self.transactions.get(index)
} }
} }

@ -321,8 +321,12 @@ pub struct DNSState {
} }
impl State<DNSTransaction> for DNSState { impl State<DNSTransaction> for DNSState {
fn get_transactions(&self) -> &[DNSTransaction] { fn get_transaction_count(&self) -> usize {
&self.transactions self.transactions.len()
}
fn get_transaction_by_index(&self, index: usize) -> Option<&DNSTransaction> {
self.transactions.get(index)
} }
} }

@ -403,8 +403,12 @@ pub struct HTTP2State {
} }
impl State<HTTP2Transaction> for HTTP2State { impl State<HTTP2Transaction> for HTTP2State {
fn get_transactions(&self) -> &[HTTP2Transaction] { fn get_transaction_count(&self) -> usize {
&self.transactions self.transactions.len()
}
fn get_transaction_by_index(&self, index: usize) -> Option<&HTTP2Transaction> {
self.transactions.get(index)
} }
} }

@ -144,8 +144,12 @@ pub struct IKEState {
} }
impl State<IKETransaction> for IKEState { impl State<IKETransaction> for IKEState {
fn get_transactions(&self) -> &[IKETransaction] { fn get_transaction_count(&self) -> usize {
&self.transactions self.transactions.len()
}
fn get_transaction_by_index(&self, index: usize) -> Option<&IKETransaction> {
self.transactions.get(index)
} }
} }

@ -52,8 +52,12 @@ pub struct KRB5State {
} }
impl State<KRB5Transaction> for KRB5State { impl State<KRB5Transaction> for KRB5State {
fn get_transactions(&self) -> &[KRB5Transaction] { fn get_transaction_count(&self) -> usize {
&self.transactions self.transactions.len()
}
fn get_transaction_by_index(&self, index: usize) -> Option<&KRB5Transaction> {
self.transactions.get(index)
} }
} }

@ -96,8 +96,12 @@ pub struct ModbusState {
} }
impl State<ModbusTransaction> for ModbusState { impl State<ModbusTransaction> for ModbusState {
fn get_transactions(&self) -> &[ModbusTransaction] { fn get_transaction_count(&self) -> usize {
&self.transactions self.transactions.len()
}
fn get_transaction_by_index(&self, index: usize) -> Option<&ModbusTransaction> {
self.transactions.get(index)
} }
} }

@ -106,8 +106,12 @@ pub struct MQTTState {
} }
impl State<MQTTTransaction> for MQTTState { impl State<MQTTTransaction> for MQTTState {
fn get_transactions(&self) -> &[MQTTTransaction] { fn get_transaction_count(&self) -> usize {
&self.transactions self.transactions.len()
}
fn get_transaction_by_index(&self, index: usize) -> Option<&MQTTTransaction> {
self.transactions.get(index)
} }
} }

@ -325,8 +325,12 @@ pub struct NFSState {
} }
impl State<NFSTransaction> for NFSState { impl State<NFSTransaction> for NFSState {
fn get_transactions(&self) -> &[NFSTransaction] { fn get_transaction_count(&self) -> usize {
&self.transactions self.transactions.len()
}
fn get_transaction_by_index(&self, index: usize) -> Option<&NFSTransaction> {
self.transactions.get(index)
} }
} }

@ -74,8 +74,12 @@ impl NTPState {
} }
impl State<NTPTransaction> for NTPState { impl State<NTPTransaction> for NTPState {
fn get_transactions(&self) -> &[NTPTransaction] { fn get_transaction_count(&self) -> usize {
&self.transactions self.transactions.len()
}
fn get_transaction_by_index(&self, index: usize) -> Option<&NTPTransaction> {
self.transactions.get(index)
} }
} }

@ -125,8 +125,12 @@ pub struct PgsqlState {
} }
impl State<PgsqlTransaction> for PgsqlState { impl State<PgsqlTransaction> for PgsqlState {
fn get_transactions(&self) -> &[PgsqlTransaction] { fn get_transaction_count(&self) -> usize {
&self.transactions self.transactions.len()
}
fn get_transaction_by_index(&self, index: usize) -> Option<&PgsqlTransaction> {
self.transactions.get(index)
} }
} }

@ -113,8 +113,12 @@ pub struct RdpState {
} }
impl State<RdpTransaction> for RdpState { impl State<RdpTransaction> for RdpState {
fn get_transactions(&self) -> &[RdpTransaction] { fn get_transaction_count(&self) -> usize {
&self.transactions self.transactions.len()
}
fn get_transaction_by_index(&self, index: usize) -> Option<&RdpTransaction> {
self.transactions.get(index)
} }
} }

@ -84,9 +84,14 @@ pub struct RFBState {
} }
impl State<RFBTransaction> for RFBState { impl State<RFBTransaction> for RFBState {
fn get_transactions(&self) -> &[RFBTransaction] { fn get_transaction_count(&self) -> usize {
&self.transactions self.transactions.len()
} }
fn get_transaction_by_index(&self, index: usize) -> Option<&RFBTransaction> {
self.transactions.get(index)
}
} }
impl RFBState { impl RFBState {

@ -51,8 +51,12 @@ pub struct SIPState {
} }
impl State<SIPTransaction> for SIPState { impl State<SIPTransaction> for SIPState {
fn get_transactions(&self) -> &[SIPTransaction] { fn get_transaction_count(&self) -> usize {
&self.transactions self.transactions.len()
}
fn get_transaction_by_index(&self, index: usize) -> Option<&SIPTransaction> {
self.transactions.get(index)
} }
} }

@ -795,8 +795,12 @@ pub struct SMBState<> {
} }
impl State<SMBTransaction> for SMBState { impl State<SMBTransaction> for SMBState {
fn get_transactions(&self) -> &[SMBTransaction] { fn get_transaction_count(&self) -> usize {
&self.transactions self.transactions.len()
}
fn get_transaction_by_index(&self, index: usize) -> Option<&SMBTransaction> {
self.transactions.get(index)
} }
} }

@ -108,8 +108,12 @@ impl<'a> Default for SNMPPduInfo<'a> {
} }
impl<'a> State<SNMPTransaction<'a>> for SNMPState<'a> { impl<'a> State<SNMPTransaction<'a>> for SNMPState<'a> {
fn get_transactions(&self) -> &[SNMPTransaction<'a>] { fn get_transaction_count(&self) -> usize {
&self.transactions self.transactions.len()
}
fn get_transaction_by_index(&self, index: usize) -> Option<&SNMPTransaction<'a>> {
self.transactions.get(index)
} }
} }

@ -82,8 +82,12 @@ pub struct TelnetState {
} }
impl State<TelnetTransaction> for TelnetState { impl State<TelnetTransaction> for TelnetState {
fn get_transactions(&self) -> &[TelnetTransaction] { fn get_transaction_count(&self) -> usize {
&self.transactions self.transactions.len()
}
fn get_transaction_by_index(&self, index: usize) -> Option<&TelnetTransaction> {
self.transactions.get(index)
} }
} }

Loading…
Cancel
Save