mirror of
https://git.proxmox.com/git/pve-installer
synced 2025-04-28 04:44:59 +00:00
gui: fall back to first found NIC if no default could be determined
If no DHCP server is configured on the network and/or no DHCP lease and thus network configuration is retrieved, the installer will also be unable to determine the default interface, aka. the one with the default gateway set. Fix it by pre-selecting the first found interface. If we *do* have a default interface, the index will be later overwritten, but ensures that always *some* interface is pre-selected in the dropdown. As it is already checked that the machine has any network interfaces before starting the installation wizard, it is safe to rely on the fact that at least one NIC must be present. For completeness, all the other network inputs already have (hardcoded) fallbacks, namely 192.168.100.2/24 as address/netmask, 192.168.100.1 as gateway and the gateway address as DNS server address. Reported-by: Christian Ebner <c.ebner@proxmox.com> Signed-off-by: Christoph Heiss <c.heiss@proxmox.com> Link: https://lore.proxmox.com/20250407135510.1138958-1-c.heiss@proxmox.com
This commit is contained in:
parent
dc5b8d7c6f
commit
c53166998d
@ -389,7 +389,7 @@ sub create_ipconf_view {
|
||||
if $iface->{inet}->{prefix} || $iface->{inet6}->{prefix};
|
||||
};
|
||||
|
||||
my ($initial_active_device_pos, $initial_addr, $initial_mask) = (-1, undef, undef);
|
||||
my ($initial_active_device_pos, $initial_addr, $initial_mask) = (0, undef, undef);
|
||||
|
||||
my $i = 0;
|
||||
for my $index (sort keys $ipconf->{ifaces}->%*) {
|
||||
@ -402,7 +402,8 @@ sub create_ipconf_view {
|
||||
);
|
||||
$device_active_map->{$i} = $index;
|
||||
$device_active_reverse_map->{$iface->{name}} = $i;
|
||||
if ($index == $ipconf->{default}) {
|
||||
|
||||
if (defined($ipconf->{default}) && $index == $ipconf->{default}) {
|
||||
$initial_active_device_pos = $i;
|
||||
$initial_addr = $iface->{inet}->{addr} || $iface->{inet6}->{addr};
|
||||
$initial_mask = $iface->{inet}->{prefix} || $iface->{inet6}->{prefix};
|
||||
@ -412,7 +413,7 @@ sub create_ipconf_view {
|
||||
|
||||
if (my $nic = Proxmox::Install::Config::get_mngmt_nic()) {
|
||||
$initial_active_device_pos = $device_active_reverse_map->{$nic};
|
||||
} elsif ($initial_active_device_pos >= 0) {
|
||||
} else {
|
||||
my $iface_id = $device_active_map->{$initial_active_device_pos};
|
||||
my $iface = $ipconf->{ifaces}->{$iface_id};
|
||||
Proxmox::Install::Config::set_mngmt_nic($iface->{name});
|
||||
|
Loading…
Reference in New Issue
Block a user