Documentation ¶
Index ¶
- Constants
- Variables
- func ClearModulesState() error
- func FillModulesFromProcFs() error
- func GetWakeupChannelRead() <-chan ScanRequest
- func InitHiddenKernelModules(modsMap *bpf.BPFMap, newModMap *bpf.BPFMap, deletedModMap *bpf.BPFMap, ...) error
- func InitHookedSyscall() error
- type DeriveFunction
- func ContainerCreate(cts *containers.Containers) DeriveFunction
- func ContainerRemove(cts *containers.Containers) DeriveFunction
- func DetectHookedSyscall(kernelSymbols helpers.KernelSymbolTable) DeriveFunction
- func HiddenKernelModule() DeriveFunction
- func HookedSeqOps(kernelSymbols helpers.KernelSymbolTable) DeriveFunction
- func NetPacketDNS() DeriveFunction
- func NetPacketDNSRequest() DeriveFunction
- func NetPacketDNSResponse() DeriveFunction
- func NetPacketHTTP() DeriveFunction
- func NetPacketHTTPRequest() DeriveFunction
- func NetPacketHTTPResponse() DeriveFunction
- func NetPacketICMP() DeriveFunction
- func NetPacketICMPv6() DeriveFunction
- func NetPacketIPv4() DeriveFunction
- func NetPacketIPv6() DeriveFunction
- func NetPacketTCP() DeriveFunction
- func NetPacketUDP() DeriveFunction
- func SymbolsCollision(soLoader sharedobjs.DynamicSymbolsLoader, policies *policy.Policies) DeriveFunction
- func SymbolsLoaded(soLoader sharedobjs.DynamicSymbolsLoader, policies *policy.Policies) DeriveFunction
- type ScanRequest
- type SymbolsCollisionArgsGenerator
- type Table
Constants ¶
const ( ProcModules uint32 = 1 << 0 // A hidden module detected by /proc/modules logic NewMod = 1 << 3 // A new modules only scan - without HiddenModule flag on, this is not yet a detection. See newModsCheckForHidden FullScan = 1 << 30 // Do a full scan - received after a new module was loaded (and finished running his init function) HiddenModule = 1 << 31 // Submit the module as event to user )
const ( IPPROTO_TCP uint8 = 6 IPPROTO_UDP uint8 = 17 )
Variables ¶
var NetSeqOps = [6]string{
"tcp4_seq_ops",
"tcp6_seq_ops",
"udp_seq_ops",
"udp6_seq_ops",
"raw_seq_ops",
"raw6_seq_ops",
}
Struct names for the interfaces HookedSeqOpsEventID checks for hooks The show,start,next and stop operation function pointers will be checked for each of those
var NetSeqOpsFuncs = [4]string{
"show",
"start",
"next",
"stop",
}
Functions ¶
func ClearModulesState ¶
func ClearModulesState() error
ClearModulesState clears the map (while not scanning)
func FillModulesFromProcFs ¶
func FillModulesFromProcFs() error
FillModulesFromProcFs fills a map with modules from /proc/modules, to be checked in kernel-space for inconsistencies.
func GetWakeupChannelRead ¶
func GetWakeupChannelRead() <-chan ScanRequest
GetWakeupChannelRead returns the reading-end of the channel
func InitHiddenKernelModules ¶
func InitHiddenKernelModules( modsMap *bpf.BPFMap, newModMap *bpf.BPFMap, deletedModMap *bpf.BPFMap, insertedModMap *bpf.BPFMap, ) error
InitHiddenKernelModules initializes the module components
func InitHookedSyscall ¶ added in v0.17.2
func InitHookedSyscall() error
InitHookedSyscall initialize lru
Types ¶
type DeriveFunction ¶
DeriveFunction is a function prototype for a function that receives an event as argument and may produce a new event if relevant. It returns a derived or empty event, depending on successful derivation, and an error if one occurred.
func ContainerCreate ¶
func ContainerCreate(cts *containers.Containers) DeriveFunction
ContainerCreate receives a containers as a closure argument to track it's containers. If it receives a cgroup_mkdir event, it can derive a container_create event from it.
func ContainerRemove ¶
func ContainerRemove(cts *containers.Containers) DeriveFunction
ContainerRemove receives a containers.Containers object as a closure argument to track it's containers. If it receives a cgroup_rmdir event, it can derive a container_remove event from it.
func DetectHookedSyscall ¶
func DetectHookedSyscall(kernelSymbols helpers.KernelSymbolTable) DeriveFunction
func HiddenKernelModule ¶
func HiddenKernelModule() DeriveFunction
func HookedSeqOps ¶
func HookedSeqOps(kernelSymbols helpers.KernelSymbolTable) DeriveFunction
func NetPacketDNS ¶
func NetPacketDNS() DeriveFunction
func NetPacketDNSRequest ¶
func NetPacketDNSRequest() DeriveFunction
func NetPacketDNSResponse ¶
func NetPacketDNSResponse() DeriveFunction
func NetPacketHTTP ¶
func NetPacketHTTP() DeriveFunction
func NetPacketHTTPRequest ¶
func NetPacketHTTPRequest() DeriveFunction
func NetPacketHTTPResponse ¶
func NetPacketHTTPResponse() DeriveFunction
func NetPacketICMP ¶
func NetPacketICMP() DeriveFunction
func NetPacketICMPv6 ¶
func NetPacketICMPv6() DeriveFunction
func NetPacketIPv4 ¶
func NetPacketIPv4() DeriveFunction
func NetPacketIPv6 ¶
func NetPacketIPv6() DeriveFunction
func NetPacketTCP ¶
func NetPacketTCP() DeriveFunction
func NetPacketUDP ¶
func NetPacketUDP() DeriveFunction
func SymbolsCollision ¶
func SymbolsCollision(soLoader sharedobjs.DynamicSymbolsLoader, policies *policy.Policies, ) DeriveFunction
func SymbolsLoaded ¶
func SymbolsLoaded( soLoader sharedobjs.DynamicSymbolsLoader, policies *policy.Policies, ) DeriveFunction
type ScanRequest ¶
ScanRequest the structure that is passed in the wake up channel
type SymbolsCollisionArgsGenerator ¶
type SymbolsCollisionArgsGenerator struct {
// contains filtered or unexported fields
}
SymbolsCollisionArgsGenerator creates the shared object symbols collisions derived events. To do so, it uses multiple caches to accelerate performance and reduce chances for failure.
type Table ¶
Table defines a table between events and events they can be derived into corresponding to a deriveFunction The Enabled flag is used in order to skip derivation of unneeded events.
func (Table) DeriveEvent ¶
DeriveEvent takes a trace.Event and checks if it can derive additional events from it as defined by a derivationTable.
Source Files ¶
- container_create.go
- container_remove.go
- derive.go
- errors.go
- hidden_kernel_module.go
- hooked_seq_ops.go
- hooked_syscall.go
- net_packet_dns.go
- net_packet_helpers.go
- net_packet_http.go
- net_packet_icmp.go
- net_packet_icmpv6.go
- net_packet_ipv4.go
- net_packet_ipv6.go
- net_packet_tcp.go
- net_packet_udp.go
- symbols_collision.go
- symbols_loaded.go