From b1f2b9c3f16de75a404ccb65cb5c98ba59c52123 Mon Sep 17 00:00:00 2001 From: Haruue Date: Wed, 8 May 2024 19:35:17 +0800 Subject: [PATCH] feat(pcap): impl realtime wait() with time offset --- io/pcap.go | 36 ++++++++++++++++++------------------ 1 file changed, 18 insertions(+), 18 deletions(-) diff --git a/io/pcap.go b/io/pcap.go index 1da66a7..b941197 100644 --- a/io/pcap.go +++ b/io/pcap.go @@ -17,11 +17,11 @@ import ( var _ PacketIO = (*pcapPacketIO)(nil) type pcapPacketIO struct { - pcapFile io.ReadCloser - pcap *pcapgo.Reader - lastTime *time.Time - ioCancel context.CancelFunc - config PcapPacketIOConfig + pcapFile io.ReadCloser + pcap *pcapgo.Reader + timeOffset *time.Duration + ioCancel context.CancelFunc + config PcapPacketIOConfig dialer *net.Dialer } @@ -43,12 +43,12 @@ func NewPcapPacketIO(config PcapPacketIOConfig) (PacketIO, error) { } return &pcapPacketIO{ - pcapFile: pcapFile, - pcap: handle, - lastTime: nil, - ioCancel: nil, - config: config, - dialer: &net.Dialer{}, + pcapFile: pcapFile, + pcap: handle, + timeOffset: nil, + ioCancel: nil, + config: config, + dialer: &net.Dialer{}, }, nil } @@ -101,20 +101,20 @@ func (p *pcapPacketIO) Close() error { // Intentionally slow down the replay // In realtime mode, this is to match the timestamps in the capture -func (p *pcapPacketIO) wait(packet gopacket.Packet) error { +func (p *pcapPacketIO) wait(packet gopacket.Packet) { if !p.config.Realtime { - return nil + return } - if p.lastTime == nil { - p.lastTime = &packet.Metadata().Timestamp + if p.timeOffset == nil { + offset := time.Now().Sub(packet.Metadata().Timestamp) + p.timeOffset = &offset } else { - t := packet.Metadata().Timestamp.Sub(*p.lastTime) + t := packet.Metadata().Timestamp.Add(*p.timeOffset).Sub(time.Now()) time.Sleep(t) - p.lastTime = &packet.Metadata().Timestamp } - return nil + return } var _ Packet = (*pcapPacket)(nil)