mirror of
https://github.com/zeek/zeek.git
synced 2025-10-10 10:38:20 +00:00

Checking for netinet/if_ether.h and netinet/ip6.h depended on including other headers first; observed when trying to build on FreeBSD. ARP.h was changed to conform to CMake style config.h generation. Definitions are not set to 1 like with autotools, so we have to check for definition, not just that the value is true.
55 lines
1.3 KiB
C++
55 lines
1.3 KiB
C++
// $Id: ARP.h 6219 2008-10-01 05:39:07Z vern $
|
|
//
|
|
// See the file "COPYING" in the main distribution directory for copyright.
|
|
|
|
#ifndef arp_h
|
|
#define arp_h
|
|
|
|
#include "config.h"
|
|
#include <sys/types.h>
|
|
#include <sys/socket.h>
|
|
#include <netinet/in.h>
|
|
#include <net/if.h>
|
|
#include <net/if_arp.h>
|
|
#ifdef HAVE_NET_ETHERNET_H
|
|
#include <net/ethernet.h>
|
|
#elif defined(HAVE_SYS_ETHERNET_H)
|
|
#include <sys/ethernet.h>
|
|
#elif defined(HAVE_NETINET_IF_ETHER_H)
|
|
#include <netinet/if_ether.h>
|
|
#endif
|
|
|
|
#ifndef arp_pkthdr
|
|
#define arp_pkthdr arphdr
|
|
#endif
|
|
|
|
#include "NetVar.h"
|
|
|
|
|
|
class ARP_Analyzer : public BroObj {
|
|
public:
|
|
ARP_Analyzer();
|
|
virtual ~ARP_Analyzer();
|
|
|
|
// Whether a packet is of interest for ARP analysis.
|
|
bool IsARP(const u_char* pkt, int hdr_size) const;
|
|
|
|
void NextPacket(double t, const struct pcap_pkthdr* hdr,
|
|
const u_char* const pkt, int hdr_size);
|
|
|
|
void Describe(ODesc* d) const;
|
|
void RREvent(EventHandlerPtr e, const u_char* src, const u_char* dst,
|
|
const char* spa, const char* sha,
|
|
const char* tpa, const char* tha);
|
|
protected:
|
|
AddrVal* ConstructAddrVal(const void* addr);
|
|
StringVal* EthAddrToStr(const u_char* addr);
|
|
void BadARP(const struct arp_pkthdr* hdr, const char* string);
|
|
void Corrupted(const char* string);
|
|
|
|
EventHandlerPtr arp_corrupted_packet;
|
|
EventHandlerPtr arp_request;
|
|
EventHandlerPtr arp_reply;
|
|
};
|
|
|
|
#endif
|