X-Git-Url: https://iankelling.org/git/?p=newns;a=blobdiff_plain;f=newns;fp=newns;h=313440730cd67b08406122dd5d2d727a12bbfa91;hp=34e4ca5da3454a8f4c4460e80f7a8fdef8917546;hb=92c7ca74a3b72ae77891a682c4fdff5dcdf06123;hpb=4c177e45b9aa0c9b26aefaabbc8acac767ac294f diff --git a/newns b/newns index 34e4ca5..3134407 100755 --- a/newns +++ b/newns @@ -220,6 +220,18 @@ find-network() { fi } +# ip add idempotent (if it doesn't exist already) +ip-add() { + local cmd net dev + cmd=$1 + net=$2 + dev=$3 + if ! $cmd addr show dev $dev | sed 's/^ *//;s/ *$//' | grep -xF "inet $net scope global $dev"; then + $cmd addr add $net dev $dev + fi + +} + start() { find-network @@ -257,7 +269,9 @@ start() { if $create; then - ip netns add $nn + if ! ip netns | grep -xF $nn &>/dev/null; then + ip netns add $nn + fi ip -n $nn link set dev lo up fi @@ -271,10 +285,10 @@ start() { err-cleanup() { stop; } ipnn link add $v0 type veth peer name $v1 ipnn link set $v0 netns default - ipd addr add $network.1/24 dev $v0 + ip-add ipd $network.1/24 $v0 ipd link set $v0 up nat -C &>/dev/null || nat -A - ipnn addr add $network.2/24 dev $v1 + ip-add ipnn $network.1/24 $v0 ipnn link set $v1 up cmd="ipnn route add default via $network.1" $cmd