summaryrefslogtreecommitdiffstats
path: root/modules/user/user.go
diff options
context:
space:
mode:
authorSagePtr <sageptr@gmail.com>2018-10-18 09:08:20 +0200
committerLunny Xiao <xiaolunwen@gmail.com>2018-10-18 15:08:20 +0800
commiteb0c848f5be5f9ce6fdb29bc13641d207a93b19d (patch)
treee0497cfbee6f8313cf062946fe7a072195dcf46a /modules/user/user.go
parent637c5fe1eb8ab245b547e127f06257558fbb4636 (diff)
downloadgitea-eb0c848f5be5f9ce6fdb29bc13641d207a93b19d.tar.gz
gitea-eb0c848f5be5f9ce6fdb29bc13641d207a93b19d.zip
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
Diffstat (limited to 'modules/user/user.go')
-rw-r--r--modules/user/user.go21
1 files changed, 20 insertions, 1 deletions
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