From eb0c848f5be5f9ce6fdb29bc13641d207a93b19d Mon Sep 17 00:00:00 2001 From: SagePtr Date: Thu, 18 Oct 2018 09:08:20 +0200 Subject: Use native go method to get current user rather than environment variable (#4930) * Use native go method to get current user rather than environment var * Use t.Skip instead of return in test --- modules/user/user.go | 21 ++++++++++++++++++++- 1 file changed, 20 insertions(+), 1 deletion(-) (limited to 'modules/user/user.go') diff --git a/modules/user/user.go b/modules/user/user.go index b9911e6f52..af49d7b06a 100644 --- a/modules/user/user.go +++ b/modules/user/user.go @@ -4,10 +4,29 @@ package user -import "os" +import ( + "os" + "os/user" + "runtime" + "strings" +) // CurrentUsername return current login OS user name func CurrentUsername() string { + userinfo, err := user.Current() + if err != nil { + return fallbackCurrentUsername() + } + username := userinfo.Username + if runtime.GOOS == "windows" { + parts := strings.Split(username, "\\") + username = parts[len(parts)-1] + } + return username +} + +// Old method, used if new method doesn't work on your OS for some reason +func fallbackCurrentUsername() string { curUserName := os.Getenv("USER") if len(curUserName) > 0 { return curUserName -- cgit v1.2.3