c3803203bc
Some small fixes: - lets make sure we are not adding ipv4 addresses in ipv6 section in keyfile and vice versa. - ADDR_FAMILY_IPV6 is a bit in addr_family. Test that bit instead of checking the whole value of addr_family. - Some trivial fixes in hv_set_ifconfig.sh. These fixes are proposed after doing some internal testing at Red Hat. CC: Shradha Gupta <shradhagupta@linux.microsoft.com> CC: Saurabh Sengar <ssengar@linux.microsoft.com> Fixes: 42999c904612 ("hv/hv_kvp_daemon:Support for keyfile based connection profile") Signed-off-by: Ani Sinha <anisinha@redhat.com> Reviewed-by: Shradha Gupta <Shradhagupta@linux.microsoft.com> Signed-off-by: Wei Liu <wei.liu@kernel.org> Message-ID: <20231016133122.2419537-1-anisinha@redhat.com>
93 lines
2.4 KiB
Bash
Executable File
93 lines
2.4 KiB
Bash
Executable File
#!/bin/bash
|
|
# SPDX-License-Identifier: GPL-2.0
|
|
|
|
# This example script activates an interface based on the specified
|
|
# configuration.
|
|
#
|
|
# In the interest of keeping the KVP daemon code free of distro specific
|
|
# information; the kvp daemon code invokes this external script to configure
|
|
# the interface.
|
|
#
|
|
# The only argument to this script is the configuration file that is to
|
|
# be used to configure the interface.
|
|
#
|
|
# Each Distro is expected to implement this script in a distro specific
|
|
# fashion. For instance, on Distros that ship with Network Manager enabled,
|
|
# this script can be based on the Network Manager APIs for configuring the
|
|
# interface.
|
|
#
|
|
# This example script is based on a RHEL environment.
|
|
#
|
|
# Here is the ifcfg format of the ip configuration file:
|
|
#
|
|
# HWADDR=macaddr
|
|
# DEVICE=interface name
|
|
# BOOTPROTO=<protocol> (where <protocol> is "dhcp" if DHCP is configured
|
|
# or "none" if no boot-time protocol should be used)
|
|
#
|
|
# IPADDR0=ipaddr1
|
|
# IPADDR1=ipaddr2
|
|
# IPADDRx=ipaddry (where y = x + 1)
|
|
#
|
|
# NETMASK0=netmask1
|
|
# NETMASKx=netmasky (where y = x + 1)
|
|
#
|
|
# GATEWAY=ipaddr1
|
|
# GATEWAYx=ipaddry (where y = x + 1)
|
|
#
|
|
# DNSx=ipaddrx (where first DNS address is tagged as DNS1 etc)
|
|
#
|
|
# IPV6 addresses will be tagged as IPV6ADDR, IPV6 gateway will be
|
|
# tagged as IPV6_DEFAULTGW and IPV6 NETMASK will be tagged as
|
|
# IPV6NETMASK.
|
|
#
|
|
# Here is the keyfile format of the ip configuration file:
|
|
#
|
|
# [ethernet]
|
|
# mac-address=macaddr
|
|
# [connection]
|
|
# interface-name=interface name
|
|
#
|
|
# [ipv4]
|
|
# method=<protocol> (where <protocol> is "auto" if DHCP is configured
|
|
# or "manual" if no boot-time protocol should be used)
|
|
#
|
|
# address1=ipaddr1/plen
|
|
# address2=ipaddr2/plen
|
|
#
|
|
# gateway=gateway1;gateway2
|
|
#
|
|
# dns=dns1;
|
|
#
|
|
# [ipv6]
|
|
# address1=ipaddr1/plen
|
|
# address2=ipaddr2/plen
|
|
#
|
|
# gateway=gateway1;gateway2
|
|
#
|
|
# dns=dns1;dns2
|
|
#
|
|
# The host can specify multiple ipv4 and ipv6 addresses to be
|
|
# configured for the interface. Furthermore, the configuration
|
|
# needs to be persistent. A subsequent GET call on the interface
|
|
# is expected to return the configuration that is set via the SET
|
|
# call.
|
|
#
|
|
|
|
echo "IPV6INIT=yes" >> $1
|
|
echo "NM_CONTROLLED=no" >> $1
|
|
echo "PEERDNS=yes" >> $1
|
|
echo "ONBOOT=yes" >> $1
|
|
|
|
cp $1 /etc/sysconfig/network-scripts/
|
|
|
|
chmod 600 $2
|
|
interface=$(echo $2 | awk -F - '{ print $2 }')
|
|
filename="${2##*/}"
|
|
|
|
sed '/\[connection\]/a autoconnect=true' $2 > /etc/NetworkManager/system-connections/${filename}
|
|
|
|
|
|
/sbin/ifdown $interface 2>/dev/null
|
|
/sbin/ifup $interface 2>/dev/null
|