diff --git a/providers/os/connection/snapshot/blockdevices.go b/providers/os/connection/snapshot/blockdevices.go index 1e4ae7879f..5eaa96a035 100644 --- a/providers/os/connection/snapshot/blockdevices.go +++ b/providers/os/connection/snapshot/blockdevices.go @@ -166,10 +166,13 @@ func (blockEntries BlockDevices) FindDevice(requested string) (BlockDevice, erro func (device BlockDevice) GetMountablePartitions(includeAll bool) ([]*PartitionInfo, error) { log.Debug().Str("device", device.Name).Msg("get partitions for device") - blockDevices := device.Children + blockDevices := &BlockDevices{ + BlockDevices: device.Children, + } // sort the candidates by size, so we can pick the largest one - sortBlockDevicesBySize(blockDevices) + sortBlockDevicesBySize(blockDevices.BlockDevices) + blockDevices.findAliases() filter := func(partition BlockDevice) bool { if partition.FsType == "" { @@ -184,7 +187,7 @@ func (device BlockDevice) GetMountablePartitions(includeAll bool) ([]*PartitionI } partitions := []*PartitionInfo{} - for _, partition := range blockDevices { + for _, partition := range blockDevices.BlockDevices { log.Debug().Str("name", partition.Name).Int64("size", int64(partition.Size)).Msg("checking partition") if filter(partition) { log.Debug().Str("name", partition.Name).Msg("found suitable partition") @@ -192,6 +195,7 @@ func (device BlockDevice) GetMountablePartitions(includeAll bool) ([]*PartitionI partitions = append(partitions, &PartitionInfo{ Name: devFsName, FsType: partition.FsType, Label: partition.Label, Uuid: partition.Uuid, + Aliases: partition.Aliases, }) } else { log.Debug(). diff --git a/providers/os/connection/snapshot/partition.go b/providers/os/connection/snapshot/partition.go index c573dcfc66..5328688293 100644 --- a/providers/os/connection/snapshot/partition.go +++ b/providers/os/connection/snapshot/partition.go @@ -8,9 +8,13 @@ import ( ) type PartitionInfo struct { - Name string + // Device name (e.g. /dev/sda1) + Name string + // Filesystem type (e.g. ext4) FsType string + // Resolved device name aliases (e.g. /dev/sda1 -> /dev/nvme0n1p1) + Aliases []string // (optional) Label is the partition label Label string // (optional) UUID is the partition UUID