|  | 
| IPAddress | getRemoteMachineIpAddress () const | 
|  | 
| uint16_t | getRemoteMachinePort () const | 
|  | 
| LiveDeviceType | getDeviceType () const override | 
|  | 
| uint32_t | getMtu () const override | 
|  | 
| MacAddress | getMacAddress () const override | 
|  | 
| bool | open () override | 
|  | 
| void | getStatistics (IPcapDevice::PcapStats &stats) const override | 
|  | 
| PcapRemoteDevice * | clone () const override | 
|  | 
|  | ~PcapLiveDevice () override | 
|  | A destructor for this class. 
 | 
|  | 
| std::string | getName () const | 
|  | 
| std::string | getDesc () const | 
|  | 
| bool | getLoopback () const | 
|  | 
| virtual LinkLayerType | getLinkType () const | 
|  | 
| std::vector< IPAddress > | getIPAddresses () const | 
|  | 
| IPv4Address | getIPv4Address () const | 
|  | 
| IPv6Address | getIPv6Address () const | 
|  | 
| IPv4Address | getDefaultGateway () const | 
|  | 
| const std::vector< IPv4Address > & | getDnsServers () const | 
|  | 
| virtual bool | startCapture (OnPacketArrivesCallback onPacketArrives, void *onPacketArrivesUserCookie) | 
|  | 
| virtual bool | startCapture (OnPacketArrivesCallback onPacketArrives, void *onPacketArrivesUserCookie, int intervalInSecondsToUpdateStats, OnStatsUpdateCallback onStatsUpdate, void *onStatsUpdateUserCookie) | 
|  | 
| virtual bool | startCapture (int intervalInSecondsToUpdateStats, OnStatsUpdateCallback onStatsUpdate, void *onStatsUpdateUserCookie) | 
|  | 
| virtual bool | startCapture (RawPacketVector &capturedPacketsVector) | 
|  | 
| virtual int | startCaptureBlockingMode (OnPacketArrivesStopBlocking onPacketArrives, void *userCookie, const double timeout) | 
|  | 
| void | stopCapture () | 
|  | 
| bool | captureActive () | 
|  | 
| bool | doMtuCheck (int packetPayloadLength) const | 
|  | 
| bool | sendPacket (Packet *packet, bool checkMtu=true) | 
|  | 
| bool | sendPacket (Packet const &packet, bool checkMtu=true) | 
|  | 
| bool | sendPacket (RawPacket const &rawPacket, bool checkMtu=false) | 
|  | 
| bool | sendPacket (const uint8_t *packetData, int packetDataLength, int packetPayloadLength) | 
|  | 
| bool | sendPacket (const uint8_t *packetData, int packetDataLength, bool checkMtu=false, pcpp::LinkLayerType linkType=pcpp::LINKTYPE_ETHERNET) | 
|  | 
| virtual int | sendPackets (RawPacket *rawPacketsArr, int arrLength, bool checkMtu=false) | 
|  | 
| virtual int | sendPackets (Packet **packetsArr, int arrLength, bool checkMtu=true) | 
|  | 
| virtual int | sendPackets (const RawPacketVector &rawPackets, bool checkMtu=false) | 
|  | 
| bool | open (const DeviceConfiguration &config) | 
|  | 
| void | close () override | 
|  | Close the device. 
 | 
|  | 
| bool | isOpened () const override | 
|  | 
| bool | setFilter (std::string filterAsString) override | 
|  | 
| bool | clearFilter () override | 
|  | 
| virtual bool | setFilter (GeneralFilter &filter) | 
|  | 
| virtual bool | setFilter (std::string filterAsString)=0 | 
|  | 
| virtual bool | setFilter (GeneralFilter &filter) | 
|  | 
| PcapStats | getStatistics () const | 
|  | Get statistics from the device.  More... 
 | 
|  | 
|  | 
| enum | LiveDeviceType { LibPcapDevice
, WinPcapDevice
, RemoteDevice
 } | 
|  | The type of the live device.  More... 
 | 
|  | 
| enum | DeviceMode { Normal = 0
, Promiscuous = 1
 } | 
|  | Device capturing mode.  More... 
 | 
|  | 
| enum | PcapDirection { PCPP_INOUT = 0
, PCPP_IN
, PCPP_OUT
 } | 
|  | 
| enum class | TimestampProvider { Host = 0
, HostLowPrecision
, HostHighPrecision
, Adapter
,
 AdapterUnsynced
, HostHighPrecisionUnsynced
 }
 | 
|  | 
| enum class | TimestampPrecision { Microseconds = 0
, Nanoseconds
 } | 
|  | 
| static std::string | getPcapLibVersionInfo () | 
|  | 
| static bool | matchPacketWithFilter (GeneralFilter &filter, RawPacket *rawPacket) | 
|  | 
| virtual void | prepareCapture (bool asyncCapture, bool captureStats) | 
|  | Called before starting a capture to prepare the device for capturing packets.  More... 
 | 
|  | 
| bool | isPayloadWithinMtu (size_t payloadLength) const | 
|  | Checks whether the packetPayloadLength is smaller or equal than the device MTU.  More... 
 | 
|  | 
| bool | isPayloadWithinMtu (Packet const &packet, bool allowUnknownLength=false, size_t *outPayloadLength=nullptr) const | 
|  | Checks whether the packet's payload length is smaller or equal than the device MTU.  More... 
 | 
|  | 
| bool | isPayloadWithinMtu (RawPacket const &rawPacket, bool allowUnknownLength=false, size_t *outPayloadLength=nullptr) const | 
|  | Checks whether the payload length of a RawPacket is smaller or equal than the device MTU.  More... 
 | 
|  | 
| bool | isPayloadWithinMtu (uint8_t const *packetData, size_t packetLen, LinkLayerType linkType=pcpp::LINKTYPE_ETHERNET, bool allowUnknownLength=false, size_t *outPayloadLength=nullptr) const | 
|  | Checks whether the payload length of a packet's raw data is smaller or equal than the device MTU.  More... 
 | 
|  | 
A class that provides a C++ wrapper for WinPcap/Npcap Remote Capture feature. This feature allows to interact to a remote machine and capture packets that are being transmitted on the remote network interfaces. This requires a remote daemon (called rpcapd) which performs the capture and sends data back and the local client (represented by PcapRemoteDevice) that sends the appropriate commands and receives the captured data. You can read more about this feature in WinPcap Remote Capture manual: https://www.winpcap.org/docs/docs_412/html/group__remote.html
 Since this feature is supported in WinPcap and Npcap only and not in libpcap, PcapRemoteDevice can only be used in Windows only.
 This class provides a wrapper for the local client, meaning it assumes the daemon (rpcapd) is already running on the remote machine and it tries to connect to it and start receiving/sending packets from/to it. This class assumes rpcapd is in passive mode, meaning PcapRemoteDevice connects to the remote daemon, sends the appropriate commands to it, and starts capturing packets, rather than letting the daemon connect to the client by itself. Using PcapRemoteDevice is very similar to using the other live devices (PcapLiveDevice or WinPcapLiveDevice), meaning the API's are the same and the same logic is used (for example: capturing is done on a different thread, sending packets are done on the same thread, etc.). For the full API and explanations, please refer to PcapLiveDevice. The reason for the similar API is that WinPcap/Npcap's API is very similar between Remote Capture and local network interface capture. The things that are different are some are some implementation details, mainly in making the connection to the remote daemon, and the way the user can get the instance of PcapRemoteDevice. For more details on that please refer to PcapRemoteDeviceList