summaryrefslogtreecommitdiffstats
path: root/tests/shell/testcases/nft-f/0012different_defines_0
blob: c17b06b18d236bc21ce4c08b8e65a4c416408dd5 (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
#!/bin/bash

# tests different spots, datatypes and usages for nft defines

RULESET="
define d_iifname = whatever
define d_oifname = \$d_iifname
define d_iif = lo
define d_oif = \$d_iif
define d_mark = 123
define d_state = new,established,related
define d_ipv4 = 10.0.0.0
define d_ipv4_2 = 10.0.0.2
define d_ipv6 = fe0::1
define d_ipv6_2 = fe0::2
define d_ports = 100-222

table inet t {
	chain c {
		iifname \$d_iifname oifname \$d_oifname iif \$d_iif oif \$d_oif
		iifname { \$d_iifname , \$d_oifname } iif { \$d_iif , \$d_oif } meta mark \$d_mark
		ct state \$d_state
		ct state != \$d_state
		ip saddr \$d_ipv4 ip daddr \$d_ipv4_2 ip saddr \$d_ipv4
		ip6 daddr \$d_ipv6 ip6 saddr \$d_ipv6_2
		ip saddr vmap { \$d_ipv4 : drop , \$d_ipv4_2 : accept }
		ip6 daddr vmap { \$d_ipv6 : drop , \$d_ipv6_2 : accept }
		ip6 saddr . ip6 nexthdr { \$d_ipv6 . udp, \$d_ipv6_2 . tcp }
		ip daddr . meta iif vmap { \$d_ipv4 . \$d_iif : accept }
		tcp dport \$d_ports
		udp dport vmap { \$d_ports : accept }
	}
}"

set -e
$NFT -f - <<< $RULESET