135 lines
4.0 KiB
Plaintext
Executable File
135 lines
4.0 KiB
Plaintext
Executable File
PREFIXMASK#!/bin/sh
|
|
# pmatch determines if 1st argument string is matched by 2nd argument pattern
|
|
|
|
pmatch ()
|
|
{
|
|
case $1 in
|
|
$2) return 0;; # zero return code means string matched by pattern
|
|
esac
|
|
|
|
return 1 # non-zero return code means string not matched by pattern
|
|
}
|
|
# converts netmask CIDR fromat to x.x.x.x mask value
|
|
maskfromprefix ()
|
|
{
|
|
prefixlen=$1
|
|
maskval=$((0xffffffff>>(32-prefixlen)<<(32-prefixlen)))
|
|
mask1=$((maskval >> 24))
|
|
mask2=$((maskval >> 16 & 0xff))
|
|
mask3=$((maskval >> 8 & 0xff))
|
|
mask4=$((maskval & 0xff))
|
|
echo $mask1.$mask2.$mask3.$mask4
|
|
NETMASK=$mask1.$mask2.$mask3.$mask4
|
|
}
|
|
|
|
network_ipv4calc ()
|
|
{
|
|
# Returns the network value needed for Ubuntu /etc/network/interface file
|
|
# $1 must be the IP Address
|
|
# $2 must be the Netmask value
|
|
IP_1=`echo $1 | cut -d . -f 1`
|
|
IP_2=`echo $1 | cut -d . -f 2`
|
|
IP_3=`echo $1 | cut -d . -f 3`
|
|
IP_4=`echo $1 | cut -d . -f 4`
|
|
|
|
NETM_1=`echo $2 | cut -d . -f 1`
|
|
NETM_2=`echo $2 | cut -d . -f 2`
|
|
NETM_3=`echo $2 | cut -d . -f 3`
|
|
NETM_4=`echo $2 | cut -d . -f 4`
|
|
|
|
NET_1=$(($IP_1 & $NETM_1))
|
|
NET_2=$(($IP_2 & $NETM_2))
|
|
NET_3=$(($IP_3 & $NETM_3))
|
|
NET_4=$(($IP_4 & $NETM_4))
|
|
|
|
NETWORK="$NET_1.$NET_2.$NET_3.$NET_4"
|
|
echo $NETWORK
|
|
}
|
|
|
|
defgw=`ip route | grep default | awk '{print $3}'`
|
|
if ( pmatch $OSVER "ubuntu*" )
|
|
then
|
|
echo `hostname` >/etc/hostname
|
|
mv /etc/network/interfaces /etc/network/interfaces.old # this file will be filled up next
|
|
elif [ -f /etc/SuSE-release ]
|
|
then
|
|
#SLES9 and SLES10, uses /etc/sysconfig/network/ifcfg-eth-id-<mac>
|
|
#SLES11, uses /etc/sysconfig/network/ifcfg-eth<x>
|
|
NICFILEPRE="/etc/sysconfig/network/ifcfg-"
|
|
echo `hostname` > /etc/HOSTNAME
|
|
if [ ! -z "$defgw" ]; then
|
|
echo "default $defgw - -" > /etc/sysconfig/routes
|
|
fi
|
|
else
|
|
#RedHat uses /etc/sysconfig/network-scripts/ifcfg-eth<x>
|
|
NICFILEPRE="/etc/sysconfig/network-scripts/ifcfg-"
|
|
sed -i "s/HOSTNAME.*/HOSTNAME=`hostname`/" /etc/sysconfig/network
|
|
if [ ! -z "$defgw" ]; then
|
|
echo "GATEWAY=$defgw" >> /etc/sysconfig/network
|
|
fi
|
|
fi
|
|
for nic in `ip link |grep "BROADCAST" |awk '{print $2}' | sed s/://`; do
|
|
IPADDRMASK=`ip addr show dev $nic | grep inet | grep -v inet6 | awk '{print $2}' | head -n 1`
|
|
IPADDR=`echo $IPADDRMASK | awk -F'/' '{print $1}'`
|
|
PREFIXMASK=`echo $IPADDRMASK | awk -F'/' '{print $2}'`
|
|
# converts to x.x.x.x mask value
|
|
maskfromprefix $PREFIXMASK
|
|
if ( pmatch $OSVER "ubuntu*" )
|
|
then
|
|
NETWORK=`network_ipv4calc $IPADDR $NETMASK`
|
|
BROADCAST=`ifconfig $nic | grep Bcast | awk '{print $3}' | awk -F: '{print $2}'`
|
|
|
|
if [ ! -z "$defgw" ]; then
|
|
gateway_line="gateway $defgw"
|
|
else
|
|
gateway_line=""
|
|
fi
|
|
# add info to interfaces file on ubuntu, TBD does unbuntu change to systemd, this will not exist
|
|
cat >>/etc/network/interfaces <<EOF
|
|
auto $nic
|
|
iface $nic inet static
|
|
address $IPADDR
|
|
network $NETWORK
|
|
netmask $NETMASK
|
|
broadcast $BROADCAST
|
|
$gateway_line
|
|
|
|
|
|
EOF
|
|
# not ubuntu
|
|
else
|
|
if [ -f ${NICFILEPRE}${nic} ]
|
|
then
|
|
NICFILE=${NICFILEPRE}${nic}
|
|
else
|
|
#mac=`ifconfig $nic|grep HWaddr|awk '{print $5}'|tr "[A-Z]" "[a-z]"`
|
|
mac=`ip link show $nic | grep ether | awk '{print $2}'`
|
|
NICFILE=${NICFILEPRE}eth-id-${mac}
|
|
fi
|
|
sed -i s/BOOTPROTO=dhcp/BOOTPROTO=static/ $NICFILE
|
|
sed -i s/BOOTPROTO=\'dhcp\'/BOOTPROTO=static/ $NICFILE
|
|
sed -i s/BOOTPROTO=\"dhcp\"/BOOTPROTO=static/ $NICFILE
|
|
echo IPADDR=$IPADDR >> $NICFILE
|
|
echo NETMASK=$NETMASK >> $NICFILE
|
|
fi
|
|
|
|
#for netboot/statelite case, restart the network interface. For diskful installation, it is not necessary because the restart of the network will happen at the first boot.
|
|
if [ "$NODESETSTATE" = "netboot" ] || [ "$NODESETSTATE" = "statelite" ]
|
|
then
|
|
ifdown $nic
|
|
ifup $nic
|
|
fi
|
|
done
|
|
|
|
if ( pmatch $OSVER "ubuntu*")
|
|
then
|
|
cat >>/etc/network/interfaces <<EOF
|
|
auto lo
|
|
iface lo inet loopback
|
|
|
|
|
|
EOF
|
|
fi
|
|
|
|
exit 0
|