:output;type nat hook output priority 0 *ip;test-ip4;output # without arguments udp dport 53 redirect;ok # nf_nat flags combination udp dport 53 redirect random;ok udp dport 53 redirect random,persistent;ok udp dport 53 redirect random,persistent,fully-random;ok;udp dport 53 redirect random,fully-random,persistent udp dport 53 redirect random,fully-random;ok udp dport 53 redirect random,fully-random,persistent;ok udp dport 53 redirect persistent;ok udp dport 53 redirect persistent,random;ok;udp dport 53 redirect random,persistent udp dport 53 redirect persistent,random,fully-random;ok;udp dport 53 redirect random,fully-random,persistent udp dport 53 redirect persistent,fully-random;ok;udp dport 53 redirect fully-random,persistent udp dport 53 redirect persistent,fully-random,random;ok;udp dport 53 redirect random,fully-random,persistent # port specification tcp dport 22 redirect to 22;ok udp dport 1234 redirect to 4321;ok ip daddr 172.16.0.1 udp dport 9998 redirect to 6515;ok tcp dport 39128 redirect to 993;ok redirect to 1234;fail redirect to 12341111;fail # both port and nf_nat flags tcp dport 9128 redirect to 993 random;ok tcp dport 9128 redirect to 993 fully-random;ok tcp dport 9128 redirect to 123 persistent;ok tcp dport 9128 redirect to 123 random,persistent;ok # nf_nat flags is the last argument udp dport 1234 redirect random to 123;fail udp dport 21234 redirect persistent,fully-random to 431;fail # redirect is a terminal statement tcp dport 22 redirect counter packets 0 bytes 0 accept;fail tcp sport 22 redirect accept;fail ip saddr 10.1.1.1 redirect drop;fail # redirect with sets tcp dport { 1, 2, 3, 4, 5, 6, 7, 8, 101, 202, 303, 1001, 2002, 3003} redirect;ok ip daddr 10.0.0.0-10.2.3.4 udp dport 53 counter packets 0 bytes 0 redirect;ok iifname eth0 ct state new,established tcp dport vmap {22 : drop, 222 : drop } redirect;ok