flags: u16, name: &[u8], data: &[u8],
chunk_offset: u64, chunk_size: u32, fill_bytes: u8, is_last: bool, xid: &u32)
{
- match unsafe {SURICATA_NFS_FILE_CONFIG} {
- Some(sfcm) => {
- ft.new_chunk(sfcm, files, flags, name, data, chunk_offset,
- chunk_size, fill_bytes, is_last, xid); }
- None => panic!("no SURICATA_NFS_FILE_CONFIG"),
+ if let Some(sfcm) = unsafe { SURICATA_NFS_FILE_CONFIG } {
+ ft.new_chunk(sfcm, files, flags, name, data, chunk_offset,
+ chunk_size, fill_bytes, is_last, xid);
}
}
+fn filetracker_trunc(ft: &mut FileTransferTracker, files: &mut FileContainer,
+ flags: u16)
+{
+ ft.trunc(files, flags);
+}
+
+pub fn filetracker_close(ft: &mut FileTransferTracker, files: &mut FileContainer,
+ flags: u16)
+{
+ ft.close(files, flags);
+}
+
+fn filetracker_update(ft: &mut FileTransferTracker, files: &mut FileContainer,
+ flags: u16, data: &[u8], gap_size: u32) -> u32
+{
+ ft.update(files, flags, data, gap_size)
+}
+
+
#[derive(Debug)]
pub struct NFSState {
state_data: AppLayerStateData,
tx.request_done = true;
tx.response_done = true;
let (files, flags) = f.files.get(tx.file_tx_direction);
- f.file_tracker.trunc(files, flags);
+ filetracker_trunc(&mut f.file_tracker, files, flags);
} else {
post_gap_txs = true;
}
let queued_data = tdf.file_tracker.get_queued_size();
if queued_data > 2000000 { // TODO should probably be configurable
SCLogDebug!("QUEUED size {} while we've seen GAPs. Truncating file.", queued_data);
- tdf.file_tracker.trunc(files, flags);
+ filetracker_trunc(&mut tdf.file_tracker, files, flags);
}
}
}
tdf.chunk_count += 1;
- let cs = tdf.file_tracker.update(files, flags, data, gap_size);
+ let cs = filetracker_update(&mut tdf.file_tracker, files, flags, data, gap_size);
/* see if we need to close the tx */
if tdf.file_tracker.is_done() {
if direction == Direction::ToClient {