From 3c27734e774c575f62f305edba77f057808a9315 Mon Sep 17 00:00:00 2001 From: Javi Fontan Date: Mon, 14 Jul 2014 11:18:09 +0200 Subject: [PATCH] Use "ip" command and identify using MAC addresses (RPM) --- base_rpm/etc/one-context.d/00-network | 33 +++++++++++++++++++-------- 1 file changed, 24 insertions(+), 9 deletions(-) diff --git a/base_rpm/etc/one-context.d/00-network b/base_rpm/etc/one-context.d/00-network index 74149b6..8350ce1 100755 --- a/base_rpm/etc/one-context.d/00-network +++ b/base_rpm/etc/one-context.d/00-network @@ -72,10 +72,6 @@ get_interfaces() { $IFCMD | grep ^eth | sed 's/ *Link encap:Ethernet.*HWaddr /-/g' } -get_dev() { - echo $1 | cut -d'-' -f 1 -} - get_mac() { echo $1 | cut -d'-' -f 2 } @@ -127,14 +123,33 @@ EOT echo "" } +get_interface_mac() +{ + ip link show | awk '/^[0-9]+: [[:alnum:]]+:/ { device=$2; gsub(/:/, "",device)} /link\/ether/ { print device " " $2 }' +} + +get_context_interfaces() +{ + env | grep -E "^ETH[0-9]+_MAC=" | sed 's/_.*$//' | sort +} + +get_dev() +{ + list="$1" + mac="$2" + + echo "$list" | grep "$mac" | cut -d' ' -f1 | tail -n1 +} + gen_network_configuration() { - IFACES=`get_interfaces` + INTERFACE_MAC=$(get_interface_mac) + CONTEXT_INTERFACES=$(get_context_interfaces) - for i in $IFACES; do - MAC=`get_mac $i` - DEV=`get_dev $i` - UPCASE_DEV=`upcase $DEV` + for interface in $CONTEXT_INTERFACES; do + UPCASE_DEV=$interface + MAC=$(get_iface_var "MAC") + DEV=$(get_dev "$INTERFACE_MAC" "$MAC") IP=$(get_ip) NETWORK=$(get_network)