2022-12-03 00:40:46 +08:00
|
|
|
#!/bin/sh
|
|
|
|
BRIDGE=mg_bridge0
|
|
|
|
BRIDGE_BROADCAST=192.168.32.255
|
|
|
|
BRIDGE_IP=192.168.32.1
|
|
|
|
BRIDGE_IP_MASK=192.168.32.0/24
|
|
|
|
BRIDGE_MASK=255.255.255.0
|
|
|
|
PHY=eth0
|
|
|
|
TAP=tap0
|
2022-11-29 18:20:22 +08:00
|
|
|
|
|
|
|
# see our network configuration
|
|
|
|
echo "Network configuration:"
|
|
|
|
timeout 1s ifconfig
|
|
|
|
timeout 1s sudo route -n # see our gateway
|
|
|
|
timeout 1s bridge link
|
|
|
|
timeout 1s bridge fdb
|
|
|
|
echo
|
|
|
|
|
2022-12-03 00:40:46 +08:00
|
|
|
# Package installation
|
|
|
|
echo "Package installation"
|
|
|
|
sudo apt-get -y install isc-dhcp-server net-tools
|
|
|
|
# sudo apt-get -y install build-essential sshpassecho "Network configuration script: Bridge"
|
|
|
|
echo
|
2022-11-29 18:20:22 +08:00
|
|
|
|
2022-12-03 00:40:46 +08:00
|
|
|
echo "Network configuration script: TAP"
|
2022-11-29 18:20:22 +08:00
|
|
|
sudo ip link add $BRIDGE type bridge # Create brige
|
|
|
|
sudo ifconfig $BRIDGE $BRIDGE_IP netmask $BRIDGE_MASK up
|
2022-12-03 00:40:46 +08:00
|
|
|
echo
|
2022-11-29 18:20:22 +08:00
|
|
|
|
2022-12-03 00:40:46 +08:00
|
|
|
echo "Create $TAP attached to $BRIDGE"
|
2022-11-29 18:20:22 +08:00
|
|
|
sudo ip tuntap add dev $TAP mode tap # Create tuntap
|
|
|
|
sudo ip link set $TAP master $BRIDGE # Link tap-bridge
|
|
|
|
sudo ip link set $TAP up
|
2022-12-03 00:40:46 +08:00
|
|
|
echo
|
2022-11-29 18:20:22 +08:00
|
|
|
|
2022-12-03 00:40:46 +08:00
|
|
|
echo "Network configuration script: NAT"
|
2022-11-29 18:20:22 +08:00
|
|
|
sudo iptables -A FORWARD -d $BRIDGE_IP_MASK -o $BRIDGE -m conntrack --ctstate RELATED,ESTABLISHED -j ACCEPT
|
|
|
|
sudo iptables -A FORWARD -s $BRIDGE_IP_MASK -i $BRIDGE -j ACCEPT
|
|
|
|
sudo iptables -A FORWARD -i $BRIDGE -o $BRIDGE -j ACCEPT
|
|
|
|
sudo iptables -A FORWARD -o $BRIDGE -j REJECT --reject-with icmp-port-unreachable
|
|
|
|
sudo iptables -A FORWARD -i $BRIDGE -j REJECT --reject-with icmp-port-unreachable
|
|
|
|
sudo iptables -t nat -A POSTROUTING -s $BRIDGE_IP_MASK -d 224.0.0.0/24 -j RETURN
|
|
|
|
sudo iptables -t nat -A POSTROUTING -s $BRIDGE_IP_MASK -d 255.255.255.255/32 -j RETURN
|
|
|
|
sudo iptables -t nat -A POSTROUTING -s $BRIDGE_IP_MASK ! -d $BRIDGE_IP_MASK -p tcp -j MASQUERADE --to-ports 1024-65535
|
|
|
|
sudo iptables -t nat -A POSTROUTING -s $BRIDGE_IP_MASK ! -d $BRIDGE_IP_MASK -p udp -j MASQUERADE --to-ports 1024-65535
|
|
|
|
sudo iptables -t nat -A POSTROUTING -s $BRIDGE_IP_MASK ! -d $BRIDGE_IP_MASK -j MASQUERADE
|
|
|
|
echo 1 | sudo tee /proc/sys/net/ipv4/ip_forward
|
2022-12-03 00:40:46 +08:00
|
|
|
echo
|
|
|
|
|
|
|
|
# Setup DHCP server
|
|
|
|
echo "Network configuration script: DHCP server"
|
|
|
|
echo "Serving from $BRIDGE_IP"
|
|
|
|
echo "dhcpd.conf:"
|
|
|
|
cat test/dhcpd.conf
|
|
|
|
echo
|
|
|
|
sudo cp test/dhcpd.conf /etc/dhcp/dhcpd.conf
|
|
|
|
sudo chmod a+w /var/lib/dhcp/*
|
|
|
|
sudo dhcpd mg_bridge0 &
|
|
|
|
echo
|
2022-11-29 18:20:22 +08:00
|
|
|
|
|
|
|
# Do we have connectivity ?
|
|
|
|
echo "Check connectivity:"
|
|
|
|
wget https://cesanta.com/robots.txt
|
|
|
|
echo robots.txt:
|
|
|
|
cat robots.txt
|
|
|
|
rm robots.txt
|
|
|
|
echo
|
|
|
|
|
|
|
|
# Confirm OK
|
|
|
|
echo "Done:"
|
|
|
|
timeout 1s ifconfig
|
|
|
|
timeout 1s sudo route -n
|
|
|
|
timeout 1s bridge fdb
|
2022-12-03 00:40:46 +08:00
|
|
|
timeout 1s bridge link
|