|
@@ -11,7 +11,6 @@ import (
|
|
|
"code.google.com/p/goauth2/oauth"
|
|
|
|
|
|
"github.com/gogits/gogs/models"
|
|
|
- "github.com/gogits/gogs/modules/base"
|
|
|
"github.com/gogits/gogs/modules/log"
|
|
|
"github.com/gogits/gogs/modules/middleware"
|
|
|
"github.com/gogits/gogs/modules/oauth2"
|
|
@@ -85,7 +84,6 @@ func SocialSignIn(ctx *middleware.Context, tokens oauth2.Tokens) {
|
|
|
return
|
|
|
}
|
|
|
var err error
|
|
|
- var u *models.User
|
|
|
if err = gh.Update(); err != nil {
|
|
|
// FIXME: handle error page
|
|
|
log.Error("connect with github error: %s", err)
|
|
@@ -93,20 +91,14 @@ func SocialSignIn(ctx *middleware.Context, tokens oauth2.Tokens) {
|
|
|
}
|
|
|
var soc SocialConnector = gh
|
|
|
log.Info("login: %s", soc.Name())
|
|
|
- // FIXME: login here, user email to check auth, if not registe, then generate a uniq username
|
|
|
- if u, err = models.GetOauth2User(soc.Identity()); err != nil {
|
|
|
- u = &models.User{
|
|
|
- Name: soc.Name(),
|
|
|
- Email: soc.Email(),
|
|
|
- Passwd: "123456",
|
|
|
- IsActive: !base.Service.RegisterEmailConfirm,
|
|
|
- }
|
|
|
- if u, err = models.RegisterUser(u); err != nil {
|
|
|
- log.Error("register user: %v", err)
|
|
|
- return
|
|
|
- }
|
|
|
- oa := &models.Oauth2{}
|
|
|
- oa.Uid = u.Id
|
|
|
+ oa, err := models.GetOauth2(soc.Identity())
|
|
|
+ switch err {
|
|
|
+ case nil:
|
|
|
+ ctx.Session.Set("userId", oa.User.Id)
|
|
|
+ ctx.Session.Set("userName", oa.User.Name)
|
|
|
+ case models.ErrOauth2RecordNotExists:
|
|
|
+ oa = &models.Oauth2{}
|
|
|
+ oa.Uid = 0
|
|
|
oa.Type = soc.Type()
|
|
|
oa.Token = soc.Token()
|
|
|
oa.Identity = soc.Identity()
|
|
@@ -115,8 +107,10 @@ func SocialSignIn(ctx *middleware.Context, tokens oauth2.Tokens) {
|
|
|
log.Error("add oauth2 %v", err)
|
|
|
return
|
|
|
}
|
|
|
+ case models.ErrOauth2NotAssociatedWithUser:
|
|
|
+ // pass
|
|
|
}
|
|
|
- ctx.Session.Set("userId", u.Id)
|
|
|
- ctx.Session.Set("userName", u.Name)
|
|
|
+ ctx.Session.Set("socialId", oa.Id)
|
|
|
+ log.Info("socialId: %v", oa.Id)
|
|
|
ctx.Redirect("/")
|
|
|
}
|