use byteorder_slice::{BigEndian, LittleEndian};
use super::RawPcapPacket;
use crate::Endianness;
use crate::errors::*;
use crate::pcap::PcapHeader;
use crate::pcap::PcapPacket;
#[derive(Debug)]
pub struct PcapParser {
header: PcapHeader,
}
impl PcapParser {
pub fn new(slice: &[u8]) -> PcapResult<(&[u8], PcapParser)> {
let (slice, header) = PcapHeader::from_slice(slice)?;
let parser = PcapParser { header };
Ok((slice, parser))
}
pub fn next_packet<'a>(&self, slice: &'a [u8]) -> PcapResult<(&'a [u8], PcapPacket<'a>)> {
let res = match self.header.endianness {
Endianness::Big => RawPcapPacket::from_slice::<BigEndian>(slice),
Endianness::Little => RawPcapPacket::from_slice::<LittleEndian>(slice),
};
let header = &self.header;
res.and_then(|(rem, raw_pkt)| raw_pkt.try_into_pcap_packet(header.ts_resolution, header.snaplen).map(|pkt| (rem, pkt)))
}
pub fn next_raw_packet<'a>(&self, slice: &'a [u8]) -> PcapResult<(&'a [u8], RawPcapPacket<'a>)> {
match self.header.endianness {
Endianness::Big => RawPcapPacket::from_slice::<BigEndian>(slice),
Endianness::Little => RawPcapPacket::from_slice::<LittleEndian>(slice),
}
}
pub fn header(&self) -> PcapHeader {
self.header
}
}