2015-02-06 18:18:49 +00:00
|
|
|
package homedir
|
|
|
|
|
|
|
|
import (
|
|
|
|
"os"
|
|
|
|
"runtime"
|
2015-03-10 13:55:55 +00:00
|
|
|
|
2015-07-16 23:00:55 +00:00
|
|
|
"github.com/opencontainers/runc/libcontainer/user"
|
2015-02-06 18:18:49 +00:00
|
|
|
)
|
|
|
|
|
2015-02-06 22:17:34 +00:00
|
|
|
// Key returns the env var name for the user's home dir based on
|
|
|
|
// the platform being run on
|
|
|
|
func Key() string {
|
|
|
|
if runtime.GOOS == "windows" {
|
|
|
|
return "USERPROFILE"
|
|
|
|
}
|
|
|
|
return "HOME"
|
|
|
|
}
|
|
|
|
|
2015-02-06 18:18:49 +00:00
|
|
|
// Get returns the home directory of the current user with the help of
|
|
|
|
// environment variables depending on the target operating system.
|
|
|
|
// Returned path should be used with "path/filepath" to form new paths.
|
|
|
|
func Get() string {
|
2015-03-10 13:55:55 +00:00
|
|
|
home := os.Getenv(Key())
|
|
|
|
if home == "" && runtime.GOOS != "windows" {
|
|
|
|
if u, err := user.CurrentUser(); err == nil {
|
|
|
|
return u.Home
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return home
|
2015-02-06 18:18:49 +00:00
|
|
|
}
|
2015-02-19 06:53:04 +00:00
|
|
|
|
2016-02-22 13:48:25 +00:00
|
|
|
// GetWithSudoUser returns the home directory of the user who called sudo (if
|
|
|
|
// available, retrieved from $SUDO_USER). It fallbacks to Get if any error occurs.
|
|
|
|
// Returned path should be used with "path/filepath" to form new paths.
|
|
|
|
func GetWithSudoUser() string {
|
|
|
|
sudoUser := os.Getenv("SUDO_USER")
|
|
|
|
if sudoUser != "" {
|
|
|
|
if user, err := user.LookupUser(sudoUser); err == nil {
|
|
|
|
return user.Home
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return Get()
|
|
|
|
}
|
|
|
|
|
2015-02-19 06:53:04 +00:00
|
|
|
// GetShortcutString returns the string that is shortcut to user's home directory
|
|
|
|
// in the native shell of the platform running on.
|
|
|
|
func GetShortcutString() string {
|
|
|
|
if runtime.GOOS == "windows" {
|
|
|
|
return "%USERPROFILE%" // be careful while using in format functions
|
|
|
|
}
|
|
|
|
return "~"
|
|
|
|
}
|