summaryrefslogtreecommitdiff
blob: d24dff8271f43b6f5544b3cba98c01f624af0d19 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
#!/sbin/runscript
# Copyright 1999-2002 Gentoo Technologies, Inc.
# Distributed under the terms of the GNU General Public License, v2 or later
# $Header: /var/cvsroot/gentoo-x86/net-analyzer/p0f/files/p0f-1.8.2.init,v 1.2 2002/02/21 23:14:00 m0rpheus Exp $


start() {
	ebegin "Starting p0f"
	# The 'tcp and tcp[13] & 2 = 2' requires at least syn set.
	# An alternative would be 'tcp and tcp[13] & 0x3f = 2', which
	# is syn and no other major flags (but ECN enabled packets are OK)
	if [ -z "$BpfFilter" ]; then
		BpfFilter='tcp and tcp[13] & 2 = 2'
	else
		BpfFilter="$BpfFilter and tcp and tcp[13] & 2 = 2"
	fi

	# The command in backticks returns all the local IP addresses on this machine.
	for OneIP in `/sbin/ifconfig 2>/dev/null | grep 'inet addr' | sed -e 's/.*addr://' -e 's/ .*//'` ; do
		BpfFilter="$BpfFilter and not src host $OneIP"
	done
	
	# Create a lock file.
	mkdir -p /var/lock/subsys
	touch /var/lock/subsys/p0f
	
	# Start up p0f and filter out all packets originating from any of this machines IP's.
	einfo "Logfile: ${P0FLOGFILE}"
	start-stop-daemon --start --quiet --exec /usr/sbin/p0f -- -v "$BpfFilter" >>"/var/log/p0f" 2>&1 &
	eend ${?}
}

stop() {
	ebegin "Stopping p0f"
	start-stop-daemon --stop --quiet --exec /usr/sbin/p0f
	rm -f /var/lock/subsys/p0f
	eend ${?}
}