blob: 8ee193fda0585c759195732186260ea348768381 (
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
39
40
41
42
43
44
45
46
47
48
|
#!/bin/bash
set -e
tmpdir=$(mktemp -d)
if [ ! -d $tmpdir ] ; then
echo "Failed to create tmp directory" >&2
exit 0
fi
tmpfile1="$tmpdir/01_file.nft"
touch $tmpfile1
if [ ! -w $tmpfile1 ] ; then
echo "Failed to create tmp file" >&2
exit 0
fi
tmpfile2="$tmpdir/02_file.nft"
touch $tmpfile2
if [ ! -w $tmpfile2 ] ; then
echo "Failed to create tmp file" >&2
exit 0
fi
tmpfile3=$(mktemp)
if [ ! -w $tmpfile3 ] ; then
echo "Failed to create tmp file" >&2
exit 0
fi
# cleanup if aborted
trap "rm -rf $tmpfile1 $tmpfile2 $tmpfile3 && rmdir $tmpdir" EXIT
# add interdependent rulesets
RULESET1="add table x"
RULESET2="add chain x y"
RULESET3="include \"$tmpdir/\""
echo "$RULESET1" > $tmpfile1
echo "$RULESET2" > $tmpfile2
echo "$RULESET3" > $tmpfile3
$NFT -f $tmpfile3
if [ $? -ne 0 ] ; then
echo "E: unable to load good ruleset" >&2
exit 1
fi
|