mirror of
https://github.com/zeek/zeek.git
synced 2025-10-02 22:58:20 +00:00
Initial import of svn+ssh:://svn.icir.org/bro/trunk/bro as of r7088
This commit is contained in:
commit
61757ac78b
1383 changed files with 380824 additions and 0 deletions
47
src/PacketFilter.h
Normal file
47
src/PacketFilter.h
Normal file
|
@ -0,0 +1,47 @@
|
|||
// $Id: PacketFilter.h 80 2004-07-14 20:15:50Z jason $
|
||||
//
|
||||
// Provides some very limited but fast packet filter mechanisms
|
||||
|
||||
#ifndef PACKETFILTER_H
|
||||
#define PACKETFILTER_H
|
||||
|
||||
#include "IP.h"
|
||||
#include "PrefixTable.h"
|
||||
|
||||
class PacketFilter {
|
||||
public:
|
||||
PacketFilter(bool arg_default) { default_match = arg_default; }
|
||||
~PacketFilter() {}
|
||||
|
||||
// Drops all packets from a particular source (which may be given
|
||||
// as an AddrVal or a SubnetVal) which hasn't any of TCP flags set
|
||||
// (TH_*) with the given probability (from 0..MAX_PROB).
|
||||
void AddSrc(addr_type src, uint32 tcp_flags, double probability);
|
||||
void AddSrc(Val* src, uint32 tcp_flags, double probability);
|
||||
void AddDst(addr_type src, uint32 tcp_flags, double probability);
|
||||
void AddDst(Val* src, uint32 tcp_flags, double probability);
|
||||
|
||||
// Removes the filter entry for the given src/dst
|
||||
// Returns false if filter doesn not exist.
|
||||
bool RemoveSrc(addr_type src);
|
||||
bool RemoveSrc(Val* dst);
|
||||
bool RemoveDst(addr_type dst);
|
||||
bool RemoveDst(Val* dst);
|
||||
|
||||
// Returns true if packet matches a drop filter
|
||||
bool Match(const IP_Hdr* ip, int len, int caplen);
|
||||
|
||||
private:
|
||||
struct Filter {
|
||||
uint32 tcp_flags;
|
||||
uint32 probability;
|
||||
};
|
||||
|
||||
bool MatchFilter(const Filter& f, const IP_Hdr& ip, int len, int caplen);
|
||||
|
||||
bool default_match;
|
||||
PrefixTable src_filter;
|
||||
PrefixTable dst_filter;
|
||||
};
|
||||
|
||||
#endif
|
Loading…
Add table
Add a link
Reference in a new issue