summaryrefslogtreecommitdiffstats
path: root/vserver.functions
diff options
context:
space:
mode:
authorAlexander Sulfrian <alexander@sulfrian.net>2014-02-28 21:09:25 +0100
committerAlexander Sulfrian <alexander@sulfrian.net>2014-02-28 21:09:25 +0100
commita97473c54a958d14cf083a19134767345b42be81 (patch)
treeeb6759574194e601b935046dee98fde249e92830 /vserver.functions
parentd9d60af781079936010f8fe700ad4e5f1deb1e5a (diff)
parent3ed5f40df866fe48b7f634e353e40b699899c1f8 (diff)
downloadutil-vserver-netns-a97473c54a958d14cf083a19134767345b42be81.tar.gz
util-vserver-netns-a97473c54a958d14cf083a19134767345b42be81.tar.bz2
util-vserver-netns-a97473c54a958d14cf083a19134767345b42be81.zip
Merge commit '1.4' into debian
* commit '1.4': vserver.netns: only delete the netns, if nothing is active in it vserver.functions: add magically localhost for netns vserver.netns: interface has to be down to change mac
Diffstat (limited to 'vserver.functions')
-rw-r--r--vserver.functions13
1 files changed, 13 insertions, 0 deletions
diff --git a/vserver.functions b/vserver.functions
index a75d717..8c25f74 100644
--- a/vserver.functions
+++ b/vserver.functions
@@ -47,6 +47,14 @@ function _netnsProcessSingleGateway() {
_addInterfaceCmd IP_ROUTE default via "$gw" dev "$iface"
}
+function _netnsAddLocalhost() {
+ if [ -r "${1}/nflags" ]; then
+ if grep -q '^~LBACK_REMAP$' "${1}/nflags"; then
+ INTERFACES=( "${INTERFACES[@]}" "127.0.0.1/8" "::1/128" )
+ fi
+ fi
+}
+
function _netnsFilterNetnsUmount() {
local args=( "$@" )
@@ -93,13 +101,18 @@ function _generateInterfaceOptions() {
ret=$?
# add commands for default route
+ local netns=0
for net in "$VSERVER_DIR/netns/"*; do
test -d "$net" || continue
test ! -e "${net}/disabled" || continue
_netnsProcessSingleGateway "$net"
+ netns=1
done
+ # if using netns, automatically add localhost
+ [ "$netns" != "0" ] && _netnsAddLocalhost "$VSERVER_DIR"
+
return $ret
}