1*4a64e381SAndroid Build Coastguard Worker#!/bin/bash 2*4a64e381SAndroid Build Coastguard Worker# 3*4a64e381SAndroid Build Coastguard Worker# Copyright (c) 2021, The OpenThread Authors. 4*4a64e381SAndroid Build Coastguard Worker# All rights reserved. 5*4a64e381SAndroid Build Coastguard Worker# 6*4a64e381SAndroid Build Coastguard Worker# Redistribution and use in source and binary forms, with or without 7*4a64e381SAndroid Build Coastguard Worker# modification, are permitted provided that the following conditions are met: 8*4a64e381SAndroid Build Coastguard Worker# 1. Redistributions of source code must retain the above copyright 9*4a64e381SAndroid Build Coastguard Worker# notice, this list of conditions and the following disclaimer. 10*4a64e381SAndroid Build Coastguard Worker# 2. Redistributions in binary form must reproduce the above copyright 11*4a64e381SAndroid Build Coastguard Worker# notice, this list of conditions and the following disclaimer in the 12*4a64e381SAndroid Build Coastguard Worker# documentation and/or other materials provided with the distribution. 13*4a64e381SAndroid Build Coastguard Worker# 3. Neither the name of the copyright holder nor the 14*4a64e381SAndroid Build Coastguard Worker# names of its contributors may be used to endorse or promote products 15*4a64e381SAndroid Build Coastguard Worker# derived from this software without specific prior written permission. 16*4a64e381SAndroid Build Coastguard Worker# 17*4a64e381SAndroid Build Coastguard Worker# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 18*4a64e381SAndroid Build Coastguard Worker# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 19*4a64e381SAndroid Build Coastguard Worker# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 20*4a64e381SAndroid Build Coastguard Worker# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE 21*4a64e381SAndroid Build Coastguard Worker# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 22*4a64e381SAndroid Build Coastguard Worker# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 23*4a64e381SAndroid Build Coastguard Worker# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 24*4a64e381SAndroid Build Coastguard Worker# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 25*4a64e381SAndroid Build Coastguard Worker# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 26*4a64e381SAndroid Build Coastguard Worker# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 27*4a64e381SAndroid Build Coastguard Worker# POSSIBILITY OF SUCH DAMAGE. 28*4a64e381SAndroid Build Coastguard Worker# 29*4a64e381SAndroid Build Coastguard Worker### BEGIN INIT INFO 30*4a64e381SAndroid Build Coastguard Worker# Provides: otbr-firewall 31*4a64e381SAndroid Build Coastguard Worker# Required-Start: 32*4a64e381SAndroid Build Coastguard Worker# Required-Stop: 33*4a64e381SAndroid Build Coastguard Worker# Should-Start: 34*4a64e381SAndroid Build Coastguard Worker# Should-Stop: 35*4a64e381SAndroid Build Coastguard Worker# Default-Start: 2 3 4 5 36*4a64e381SAndroid Build Coastguard Worker# Default-Stop: 37*4a64e381SAndroid Build Coastguard Worker# Short-Description: OTBR firewall 38*4a64e381SAndroid Build Coastguard Worker# Description: This service sets up firewall for OTBR. 39*4a64e381SAndroid Build Coastguard Worker### END INIT INFO 40*4a64e381SAndroid Build Coastguard Worker 41*4a64e381SAndroid Build Coastguard WorkerTHREAD_IF="wpan0" 42*4a64e381SAndroid Build Coastguard WorkerOTBR_FORWARD_INGRESS_CHAIN="OTBR_FORWARD_INGRESS" 43*4a64e381SAndroid Build Coastguard Worker 44*4a64e381SAndroid Build Coastguard Worker. /lib/lsb/init-functions 45*4a64e381SAndroid Build Coastguard Worker. /lib/init/vars.sh 46*4a64e381SAndroid Build Coastguard Worker 47*4a64e381SAndroid Build Coastguard Workerset -euxo pipefail 48*4a64e381SAndroid Build Coastguard Worker 49*4a64e381SAndroid Build Coastguard Workeripset_destroy_if_exist() 50*4a64e381SAndroid Build Coastguard Worker{ 51*4a64e381SAndroid Build Coastguard Worker if ipset list "$1"; then 52*4a64e381SAndroid Build Coastguard Worker ipset destroy "$1" 53*4a64e381SAndroid Build Coastguard Worker fi 54*4a64e381SAndroid Build Coastguard Worker} 55*4a64e381SAndroid Build Coastguard Worker 56*4a64e381SAndroid Build Coastguard Workerfirewall_start() 57*4a64e381SAndroid Build Coastguard Worker{ 58*4a64e381SAndroid Build Coastguard Worker firewall_stop 59*4a64e381SAndroid Build Coastguard Worker ipset create -exist otbr-ingress-deny-src hash:net family inet6 60*4a64e381SAndroid Build Coastguard Worker ipset create -exist otbr-ingress-deny-src-swap hash:net family inet6 61*4a64e381SAndroid Build Coastguard Worker ipset create -exist otbr-ingress-allow-dst hash:net family inet6 62*4a64e381SAndroid Build Coastguard Worker ipset create -exist otbr-ingress-allow-dst-swap hash:net family inet6 63*4a64e381SAndroid Build Coastguard Worker 64*4a64e381SAndroid Build Coastguard Worker ip6tables -N $OTBR_FORWARD_INGRESS_CHAIN 65*4a64e381SAndroid Build Coastguard Worker ip6tables -I FORWARD 1 -o $THREAD_IF -j $OTBR_FORWARD_INGRESS_CHAIN 66*4a64e381SAndroid Build Coastguard Worker 67*4a64e381SAndroid Build Coastguard Worker ip6tables -A $OTBR_FORWARD_INGRESS_CHAIN -m pkttype --pkt-type unicast -i $THREAD_IF -j DROP 68*4a64e381SAndroid Build Coastguard Worker ip6tables -A $OTBR_FORWARD_INGRESS_CHAIN -m set --match-set otbr-ingress-deny-src src -j DROP 69*4a64e381SAndroid Build Coastguard Worker ip6tables -A $OTBR_FORWARD_INGRESS_CHAIN -m set --match-set otbr-ingress-allow-dst dst -j ACCEPT 70*4a64e381SAndroid Build Coastguard Worker ip6tables -A $OTBR_FORWARD_INGRESS_CHAIN -m pkttype --pkt-type unicast -j DROP 71*4a64e381SAndroid Build Coastguard Worker ip6tables -A $OTBR_FORWARD_INGRESS_CHAIN -j ACCEPT 72*4a64e381SAndroid Build Coastguard Worker} 73*4a64e381SAndroid Build Coastguard Worker 74*4a64e381SAndroid Build Coastguard Workerfirewall_stop() 75*4a64e381SAndroid Build Coastguard Worker{ 76*4a64e381SAndroid Build Coastguard Worker while ip6tables -C FORWARD -o $THREAD_IF -j $OTBR_FORWARD_INGRESS_CHAIN; do 77*4a64e381SAndroid Build Coastguard Worker ip6tables -D FORWARD -o $THREAD_IF -j $OTBR_FORWARD_INGRESS_CHAIN 78*4a64e381SAndroid Build Coastguard Worker done 79*4a64e381SAndroid Build Coastguard Worker 80*4a64e381SAndroid Build Coastguard Worker if ip6tables -L $OTBR_FORWARD_INGRESS_CHAIN; then 81*4a64e381SAndroid Build Coastguard Worker ip6tables -w -F $OTBR_FORWARD_INGRESS_CHAIN 82*4a64e381SAndroid Build Coastguard Worker ip6tables -w -X $OTBR_FORWARD_INGRESS_CHAIN 83*4a64e381SAndroid Build Coastguard Worker fi 84*4a64e381SAndroid Build Coastguard Worker 85*4a64e381SAndroid Build Coastguard Worker ipset_destroy_if_exist otbr-ingress-deny-src 86*4a64e381SAndroid Build Coastguard Worker ipset_destroy_if_exist otbr-ingress-deny-src-swap 87*4a64e381SAndroid Build Coastguard Worker ipset_destroy_if_exist otbr-ingress-allow-dst 88*4a64e381SAndroid Build Coastguard Worker ipset_destroy_if_exist otbr-ingress-allow-dst-swap 89*4a64e381SAndroid Build Coastguard Worker} 90*4a64e381SAndroid Build Coastguard Worker 91*4a64e381SAndroid Build Coastguard Workercase "$1" in 92*4a64e381SAndroid Build Coastguard Worker start) 93*4a64e381SAndroid Build Coastguard Worker firewall_start 94*4a64e381SAndroid Build Coastguard Worker ;; 95*4a64e381SAndroid Build Coastguard Worker restart | reload | force-reload) 96*4a64e381SAndroid Build Coastguard Worker echo "Error: argument '$1' not supported" >&2 97*4a64e381SAndroid Build Coastguard Worker exit 3 98*4a64e381SAndroid Build Coastguard Worker ;; 99*4a64e381SAndroid Build Coastguard Worker stop) 100*4a64e381SAndroid Build Coastguard Worker firewall_stop 101*4a64e381SAndroid Build Coastguard Worker ;; 102*4a64e381SAndroid Build Coastguard Worker status) 103*4a64e381SAndroid Build Coastguard Worker # No-op 104*4a64e381SAndroid Build Coastguard Worker ;; 105*4a64e381SAndroid Build Coastguard Worker *) 106*4a64e381SAndroid Build Coastguard Worker echo "Usage: $0 start|stop" >&2 107*4a64e381SAndroid Build Coastguard Worker exit 3 108*4a64e381SAndroid Build Coastguard Worker ;; 109*4a64e381SAndroid Build Coastguard Workeresac 110