: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 ip protocol tcp redirect to :100-200;ok;ip protocol 6 redirect to :100-200 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 redirect;ok iifname "eth0" ct state established,new tcp dport vmap {22 : drop, 222 : drop } redirect;ok # redirect with maps ip protocol 6 redirect to :tcp dport map { 22 : 8000, 80 : 8080};ok