forked from rsyslog/rsyslog
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathmmdb-lookup-wrong-ip-type.sh
executable file
·33 lines (31 loc) · 1.32 KB
/
mmdb-lookup-wrong-ip-type.sh
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
#!/bin/bash
# added 2014-11-17 by singh.janmejay
# This file is part of the rsyslog project, released under ASL 2.0
echo ===============================================================================
echo \[mmdb-lookup-wrong-ip-type.sh\]: test for mmdb
# uncomment for debugging support:
export RSYSLOG_DEBUG="debug"
export RSYSLOG_DEBUGLOG="log"
. ${srcdir:=.}/diag.sh init
generate_conf
add_conf '
template(name="outfmt" type="string" string="%$!iplocation%\n")
module(load="../plugins/mmdblookup/.libs/mmdblookup")
module(load="../plugins/mmnormalize/.libs/mmnormalize")
module(load="../plugins/imptcp/.libs/imptcp")
input(type="imptcp" port="0" listenPortFileName="'$RSYSLOG_DYNNAME'.tcpflood_port" ruleset="testing")
ruleset(name="testing") {
action(type="mmnormalize" rulebase=`echo $srcdir/mmdb.rb`)
action(type="mmdblookup" mmdbfile=`echo $srcdir/test.mmdb` key="$!ip" fields="city" )
action(type="omfile" file=`echo $RSYSLOG_OUT_LOG` template="outfmt")
}'
startup
# This won't work, as the test.mmdb file is only IPv4-compatible
tcpflood -m 1 -j "::1\ "
# This MUST work, the test checks that the action is not suspended when encountering an IPv6 address
tcpflood -m 1 -j "202.106.0.20\ "
shutdown_when_empty
wait_shutdown
# If the second tcpflood worked, this sould be in the output file
content_check '{ "city": "Beijing" }'
exit_test