12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485 |
- package install
- import (
- "os"
- "os/exec"
- "path/filepath"
- "strings"
- "github.com/rancher/os/config"
- "github.com/rancher/os/log"
- "github.com/rancher/os/util"
- )
- const BootDir = "boot/"
- type MenuEntry struct {
- Name, BootDir, Version, KernelArgs, Append string
- }
- type BootVars struct {
- BaseName, BootDir string
- Timeout uint
- Fallback int
- Entries []MenuEntry
- }
- func MountDevice(baseName, device, partition string, raw bool) (string, string, error) {
- log.Debugf("mountdevice %s, raw %v", partition, raw)
- if partition == "" {
- if raw {
- log.Debugf("util.Mount (raw) %s, %s", partition, baseName)
- cmd := exec.Command("lsblk", "-no", "pkname", partition)
- log.Debugf("Run(%v)", cmd)
- cmd.Stderr = os.Stderr
- device := ""
- // TODO: out can == "" - this is used to "detect software RAID" which is terrible
- if out, err := cmd.Output(); err == nil {
- device = "/dev/" + strings.TrimSpace(string(out))
- }
- log.Debugf("mountdevice return -> d: %s, p: %s", device, partition)
- return device, partition, util.Mount(partition, baseName, "", "")
- }
- //rootfs := partition
- // Don't use ResolveDevice - it can fail, whereas `blkid -L LABEL` works more often
- cfg := config.LoadConfig()
- d, _, err := util.Blkid("RANCHER_BOOT")
- if err != nil {
- log.Errorf("Failed to run blkid: %s", err)
- }
- if d != "" {
- partition = d
- baseName = filepath.Join(baseName, BootDir)
- } else {
- if dev := util.ResolveDevice(cfg.Rancher.State.Dev); dev != "" {
- // try the rancher.state.dev setting
- partition = dev
- } else {
- d, _, err := util.Blkid("RANCHER_STATE")
- if err != nil {
- log.Errorf("Failed to run blkid: %s", err)
- }
- if d != "" {
- partition = d
- }
- }
- }
- cmd := exec.Command("lsblk", "-no", "pkname", partition)
- log.Debugf("Run(%v)", cmd)
- cmd.Stderr = os.Stderr
- // TODO: out can == "" - this is used to "detect software RAID" which is terrible
- if out, err := cmd.Output(); err == nil {
- device = "/dev/" + strings.TrimSpace(string(out))
- }
- }
- os.MkdirAll(baseName, 0755)
- cmd := exec.Command("mount", partition, baseName)
- //cmd.Stdout, cmd.Stderr = os.Stdout, os.Stderr
- log.Debugf("mountdevice return2 -> d: %s, p: %s", device, partition)
- return device, partition, cmd.Run()
- }
|