aboutsummaryrefslogtreecommitdiffstats
path: root/modules/auth
diff options
context:
space:
mode:
authorEthan Koenig <etk39@cornell.edu>2017-02-05 08:10:46 -0500
committerLunny Xiao <xiaolunwen@gmail.com>2017-02-05 21:10:46 +0800
commite86d9351754f85b1508092b793dbd8a5cd1456f2 (patch)
tree7444e1381e696de539323465236cade9aa2e1c35 /modules/auth
parentbf647ce14384e2b115843c6999437b02fe2da0e5 (diff)
downloadgitea-e86d9351754f85b1508092b793dbd8a5cd1456f2.tar.gz
gitea-e86d9351754f85b1508092b793dbd8a5cd1456f2.zip
Avoid duplicate queries in auth (#827)
Avoid identical making calls to GetUserByID(..) in SignedInUser(..)
Diffstat (limited to 'modules/auth')
-rw-r--r--modules/auth/auth.go105
1 files changed, 48 insertions, 57 deletions
diff --git a/modules/auth/auth.go b/modules/auth/auth.go
index 811f890746..33ba777966 100644
--- a/modules/auth/auth.go
+++ b/modules/auth/auth.go
@@ -69,14 +69,7 @@ func SignedInID(ctx *macaron.Context, sess session.Store) int64 {
uid := sess.Get("uid")
if uid == nil {
return 0
- }
- if id, ok := uid.(int64); ok {
- if _, err := models.GetUserByID(id); err != nil {
- if !models.IsErrUserNotExist(err) {
- log.Error(4, "GetUserById: %v", err)
- }
- return 0
- }
+ } else if id, ok := uid.(int64); ok {
return id
}
return 0
@@ -89,66 +82,64 @@ func SignedInUser(ctx *macaron.Context, sess session.Store) (*models.User, bool)
return nil, false
}
- uid := SignedInID(ctx, sess)
+ if uid := SignedInID(ctx, sess); uid > 0 {
+ user, err := models.GetUserByID(uid)
+ if err == nil {
+ return user, false
+ } else if !models.IsErrUserNotExist(err) {
+ log.Error(4, "GetUserById: %v", err)
+ }
+ }
- if uid <= 0 {
- if setting.Service.EnableReverseProxyAuth {
- webAuthUser := ctx.Req.Header.Get(setting.ReverseProxyAuthUser)
- if len(webAuthUser) > 0 {
- u, err := models.GetUserByName(webAuthUser)
- if err != nil {
- if !models.IsErrUserNotExist(err) {
- log.Error(4, "GetUserByName: %v", err)
- return nil, false
- }
+ if setting.Service.EnableReverseProxyAuth {
+ webAuthUser := ctx.Req.Header.Get(setting.ReverseProxyAuthUser)
+ if len(webAuthUser) > 0 {
+ u, err := models.GetUserByName(webAuthUser)
+ if err != nil {
+ if !models.IsErrUserNotExist(err) {
+ log.Error(4, "GetUserByName: %v", err)
+ return nil, false
+ }
- // Check if enabled auto-registration.
- if setting.Service.EnableReverseProxyAutoRegister {
- u := &models.User{
- Name: webAuthUser,
- Email: gouuid.NewV4().String() + "@localhost",
- Passwd: webAuthUser,
- IsActive: true,
- }
- if err = models.CreateUser(u); err != nil {
- // FIXME: should I create a system notice?
- log.Error(4, "CreateUser: %v", err)
- return nil, false
- }
- return u, false
+ // Check if enabled auto-registration.
+ if setting.Service.EnableReverseProxyAutoRegister {
+ u := &models.User{
+ Name: webAuthUser,
+ Email: gouuid.NewV4().String() + "@localhost",
+ Passwd: webAuthUser,
+ IsActive: true,
+ }
+ if err = models.CreateUser(u); err != nil {
+ // FIXME: should I create a system notice?
+ log.Error(4, "CreateUser: %v", err)
+ return nil, false
}
+ return u, false
}
- return u, false
}
+ return u, false
}
+ }
- // Check with basic auth.
- baHead := ctx.Req.Header.Get("Authorization")
- if len(baHead) > 0 {
- auths := strings.Fields(baHead)
- if len(auths) == 2 && auths[0] == "Basic" {
- uname, passwd, _ := base.BasicAuthDecode(auths[1])
-
- u, err := models.UserSignIn(uname, passwd)
- if err != nil {
- if !models.IsErrUserNotExist(err) {
- log.Error(4, "UserSignIn: %v", err)
- }
- return nil, false
- }
+ // Check with basic auth.
+ baHead := ctx.Req.Header.Get("Authorization")
+ if len(baHead) > 0 {
+ auths := strings.Fields(baHead)
+ if len(auths) == 2 && auths[0] == "Basic" {
+ uname, passwd, _ := base.BasicAuthDecode(auths[1])
- return u, true
+ u, err := models.UserSignIn(uname, passwd)
+ if err != nil {
+ if !models.IsErrUserNotExist(err) {
+ log.Error(4, "UserSignIn: %v", err)
+ }
+ return nil, false
}
- }
- return nil, false
- }
- u, err := models.GetUserByID(uid)
- if err != nil {
- log.Error(4, "GetUserById: %v", err)
- return nil, false
+ return u, true
+ }
}
- return u, false
+ return nil, false
}
// Form form binding interface