mirror of
https://github.com/siderolabs/talos.git
synced 2025-08-19 05:31:14 +02:00
This change aims to make installations more unified and reliable. It introduces the concept of a mountpoint manager that is capable of mounting, unmounting, and moving a set of mountpoints in the correct order. Signed-off-by: Andrew Rynhard <andrew@andrewrynhard.com>
84 lines
2.5 KiB
Go
84 lines
2.5 KiB
Go
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
package installer
|
|
|
|
import (
|
|
"github.com/pkg/errors"
|
|
"github.com/talos-systems/talos/internal/pkg/blockdevice/probe"
|
|
"github.com/talos-systems/talos/internal/pkg/constants"
|
|
"github.com/talos-systems/talos/pkg/userdata"
|
|
)
|
|
|
|
// VerifyDataDevice verifies the supplied data device options.
|
|
func VerifyDataDevice(data *userdata.UserData) (err error) {
|
|
// Set data device to root device if not specified
|
|
if data.Install.Data == nil {
|
|
data.Install.Data = &userdata.InstallDevice{}
|
|
}
|
|
|
|
if data.Install.Data.Device == "" {
|
|
return errors.New("a data device is required")
|
|
}
|
|
|
|
if !data.Install.Force {
|
|
if err = VerifyDiskAvailability(constants.DataPartitionLabel); err != nil {
|
|
return errors.Wrap(err, "failed to verify disk availability")
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
// VerifyBootDevice verifies the supplied boot device options.
|
|
func VerifyBootDevice(data *userdata.UserData) (err error) {
|
|
if data.Install.Boot == nil {
|
|
return nil
|
|
}
|
|
|
|
if data.Install.Boot.Device == "" {
|
|
// We can safely assume data device is defined at this point
|
|
// because VerifyDataDevice should have been called first in
|
|
// in the chain
|
|
data.Install.Boot.Device = data.Install.Data.Device
|
|
}
|
|
|
|
if data.Install.Boot.Size == 0 {
|
|
data.Install.Boot.Size = DefaultSizeBootDevice
|
|
}
|
|
|
|
if data.Install.Boot.Kernel == "" {
|
|
data.Install.Boot.Kernel = DefaultKernelURL
|
|
}
|
|
|
|
if data.Install.Boot.Initramfs == "" {
|
|
data.Install.Boot.Initramfs = DefaultInitramfsURL
|
|
}
|
|
|
|
if !data.Install.Force {
|
|
if err = VerifyDiskAvailability(constants.BootPartitionLabel); err != nil {
|
|
return errors.Wrap(err, "failed to verify disk availability")
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// VerifyDiskAvailability verifies that no filesystems currently exist with
|
|
// the labels used by the OS.
|
|
func VerifyDiskAvailability(label string) (err error) {
|
|
var dev *probe.ProbedBlockDevice
|
|
if dev, err = probe.GetDevWithFileSystemLabel(label); err != nil {
|
|
// We return here because we only care if we can discover the
|
|
// device successfully and confirm that the disk is not in use.
|
|
// TODO(andrewrynhard): We should return a custom error type here
|
|
// that we can use to confirm the device was not found.
|
|
return nil
|
|
}
|
|
if dev.SuperBlock != nil {
|
|
return errors.Errorf("target install device %s is not empty, found existing %s file system", label, dev.SuperBlock.Type())
|
|
}
|
|
|
|
return nil
|
|
}
|