27 lines
853 B
Bash
Executable File
27 lines
853 B
Bash
Executable File
#!/bin/bash
|
|
#
|
|
# Oneshot daemon which creates a networking bridge.
|
|
#
|
|
# Creates br-ex, and sets up an ip address for it. We put this in a
|
|
# oneshot so that the ip address persists after reboot, without
|
|
# needing to add networking entries to the host system. (We want this
|
|
# to work well when we turn off classic confinement.)
|
|
|
|
set -ex
|
|
|
|
extcidr=$(snapctl get config.network.ext-cidr)
|
|
|
|
# Create external integration bridge
|
|
ovs-wrapper ovs-vsctl --retry --may-exist add-br br-ex
|
|
[ $(snapctl get config.network.ovs-dpdk) == true ] && \
|
|
ovs-wrapper ovs-vsctl -- set Bridge br-ex datapath_type=netdev
|
|
|
|
# Configure br-ex
|
|
ip address add $extcidr dev br-ex || :
|
|
ip link set br-ex up || :
|
|
|
|
sudo iptables -w -t nat -C POSTROUTING -s $extcidr ! -d $extcidr -j MASQUERADE || \
|
|
sudo iptables -w -t nat -A POSTROUTING -s $extcidr ! -d $extcidr -j MASQUERADE
|
|
|
|
exit 0
|