diff options
author | Unknwon <joe2010xtmf@163.com> | 2014-12-05 18:08:09 -0500 |
---|---|---|
committer | Unknwon <joe2010xtmf@163.com> | 2014-12-05 18:08:09 -0500 |
commit | 0b785ad96785f62166eb88e7f1415c918e102e71 (patch) | |
tree | a9b5fbb1227d4e08fa0428855343a694e8e24be7 /models | |
parent | 069486d169d7adac902a310e10b6580857735880 (diff) | |
download | gitea-0b785ad96785f62166eb88e7f1415c918e102e71.tar.gz gitea-0b785ad96785f62166eb88e7f1415c918e102e71.zip |
work on #672
Diffstat (limited to 'models')
-rw-r--r-- | models/login.go | 19 |
1 files changed, 11 insertions, 8 deletions
diff --git a/models/login.go b/models/login.go index 87dbbacc76..3986353192 100644 --- a/models/login.go +++ b/models/login.go @@ -18,6 +18,7 @@ import ( "github.com/gogits/gogs/modules/auth/ldap" "github.com/gogits/gogs/modules/log" + "github.com/gogits/gogs/modules/uuid" ) type LoginType int @@ -228,30 +229,32 @@ func UserSignIn(uname, passwd string) (*User, error) { // Query if name/passwd can login against the LDAP direcotry pool // Create a local user if success // Return the same LoginUserPlain semantic +// FIXME: https://github.com/gogits/gogs/issues/672 func LoginUserLdapSource(u *User, name, passwd string, sourceId int64, cfg *LDAPConfig, autoRegister bool) (*User, error) { mail, logged := cfg.Ldapsource.SearchEntry(name, passwd) if !logged { - // user not in LDAP, do nothing + // User not in LDAP, do nothing return nil, ErrUserNotExist } if !autoRegister { return u, nil } - // fake a local user creation + // Fallback. + if len(mail) == 0 { + mail = uuid.NewV4().String() + "@localhost" + } + u = &User{ - LowerName: strings.ToLower(name), - Name: strings.ToLower(name), + Name: name, LoginType: LDAP, LoginSource: sourceId, LoginName: name, - IsActive: true, Passwd: passwd, Email: mail, + IsActive: true, } - - err := CreateUser(u) - return u, err + return u, CreateUser(u) } type loginAuth struct { |