Files
kopia/cli/command_mount_browse.go
Jarek Kowalski ac70a38101 lint: upgraded to 1.22.2 and make lint issues a build failure
fixed or silenced linter warnings, mostly due to magic numeric constants
2020-01-03 16:39:30 -08:00

80 lines
1.5 KiB
Go

package cli
import (
"os"
"os/exec"
"github.com/pkg/errors"
"github.com/skratchdot/open-golang/open"
)
var (
mountBrowser = mountCommand.Flag("browse", "Browse mounted filesystem using the provided method").Default("OS").Enum("NONE", "WEB", "OS")
)
var mountBrowsers = map[string]func(mountPoint, addr string) error{
"NONE": nil,
"WEB": openInWebBrowser,
"OS": openInOSBrowser,
}
func browseMount(mountPoint, addr string) error {
b := mountBrowsers[*mountBrowser]
if b == nil {
waitForCtrlC()
return nil
}
return b(mountPoint, addr)
}
// nolint:unparam
func openInWebBrowser(mountPoint, addr string) error {
startWebBrowser(addr)
waitForCtrlC()
return nil
}
func openInOSBrowser(mountPoint, addr string) error {
if isWindows() {
return netUSE(mountPoint, addr)
}
startWebBrowser(addr)
waitForCtrlC()
return nil
}
func netUSE(mountPoint, addr string) error {
c := exec.Command("net", "use", mountPoint, addr) // nolint:gosec
c.Stdout = os.Stdout
c.Stderr = os.Stderr
c.Stdin = os.Stdin
if err := c.Run(); err != nil {
return errors.Wrap(err, "unable to mount")
}
startWebBrowser("x:\\")
waitForCtrlC()
c = exec.Command("net", "use", mountPoint, "/d") // nolint:gosec
c.Stdout = os.Stdout
c.Stderr = os.Stderr
c.Stdin = os.Stdin
if err := c.Run(); err != nil {
return errors.Wrap(err, "unable to unmount")
}
return nil
}
func startWebBrowser(url string) {
if err := open.Start(url); err != nil {
log.Warningf("unable to start web browser: %v", err)
}
}