summaryrefslogtreecommitdiffstats
path: root/routers/user/auth.go
diff options
context:
space:
mode:
Diffstat (limited to 'routers/user/auth.go')
-rw-r--r--routers/user/auth.go442
1 files changed, 442 insertions, 0 deletions
diff --git a/routers/user/auth.go b/routers/user/auth.go
new file mode 100644
index 0000000000..163df34a4a
--- /dev/null
+++ b/routers/user/auth.go
@@ -0,0 +1,442 @@
+// Copyright 2014 The Gogs Authors. All rights reserved.
+// Use of this source code is governed by a MIT-style
+// license that can be found in the LICENSE file.
+
+package user
+
+import (
+ "net/url"
+ "strings"
+
+ "github.com/gogits/gogs/models"
+ "github.com/gogits/gogs/modules/auth"
+ "github.com/gogits/gogs/modules/base"
+ "github.com/gogits/gogs/modules/captcha"
+ "github.com/gogits/gogs/modules/log"
+ // "github.com/gogits/gogs/modules/mailer"
+ "github.com/gogits/gogs/modules/middleware"
+ "github.com/gogits/gogs/modules/setting"
+)
+
+const (
+ SIGNIN base.TplName = "user/signin"
+ SIGNUP base.TplName = "user/signup"
+ DELETE base.TplName = "user/delete"
+ ACTIVATE base.TplName = "user/activate"
+ FORGOT_PASSWORD base.TplName = "user/forgot_passwd"
+ RESET_PASSWORD base.TplName = "user/reset_passwd"
+)
+
+func SignIn(ctx *middleware.Context) {
+ ctx.Data["Title"] = ctx.Tr("sign_in")
+
+ // if _, ok := ctx.Session.Get("socialId").(int64); ok {
+ // ctx.Data["IsSocialLogin"] = true
+ // ctx.HTML(200, SIGNIN)
+ // return
+ // }
+
+ // if setting.OauthService != nil {
+ // ctx.Data["OauthEnabled"] = true
+ // ctx.Data["OauthService"] = setting.OauthService
+ // }
+
+ // Check auto-login.
+ uname := ctx.GetCookie(setting.CookieUserName)
+ if len(uname) == 0 {
+ ctx.HTML(200, SIGNIN)
+ return
+ }
+
+ isSucceed := false
+ defer func() {
+ if !isSucceed {
+ log.Trace("auto-login cookie cleared: %s", uname)
+ ctx.SetCookie(setting.CookieUserName, "", -1)
+ ctx.SetCookie(setting.CookieRememberName, "", -1)
+ return
+ }
+ }()
+
+ u, err := models.GetUserByName(uname)
+ if err != nil {
+ if err != models.ErrUserNotExist {
+ ctx.Handle(500, "GetUserByName", err)
+ }
+ return
+ }
+
+ if val, _ := ctx.GetSuperSecureCookie(
+ base.EncodeMd5(u.Rands+u.Passwd), setting.CookieRememberName); val != u.Name {
+ ctx.HTML(200, SIGNIN)
+ return
+ }
+
+ isSucceed = true
+
+ ctx.Session.Set("uid", u.Id)
+ ctx.Session.Set("uname", u.Name)
+ if redirectTo, _ := url.QueryUnescape(ctx.GetCookie("redirect_to")); len(redirectTo) > 0 {
+ ctx.SetCookie("redirect_to", "", -1)
+ ctx.Redirect(redirectTo)
+ return
+ }
+
+ ctx.Redirect("/")
+}
+
+func SignInPost(ctx *middleware.Context, form auth.SignInForm) {
+ ctx.Data["Title"] = ctx.Tr("sign_in")
+
+ // sid, isOauth := ctx.Session.Get("socialId").(int64)
+ // if isOauth {
+ // ctx.Data["IsSocialLogin"] = true
+ // } else if setting.OauthService != nil {
+ // ctx.Data["OauthEnabled"] = true
+ // ctx.Data["OauthService"] = setting.OauthService
+ // }
+
+ if ctx.HasError() {
+ ctx.HTML(200, SIGNIN)
+ return
+ }
+
+ u, err := models.UserSignIn(form.UserName, form.Password)
+ if err != nil {
+ if err == models.ErrUserNotExist {
+ ctx.RenderWithErr(ctx.Tr("form.username_password_incorrect"), SIGNIN, &form)
+ return
+ }
+
+ ctx.Handle(500, "UserSignIn", err)
+ return
+ }
+
+ if form.Remember {
+ days := 86400 * setting.LogInRememberDays
+ ctx.SetCookie(setting.CookieUserName, u.Name, days)
+ ctx.SetSuperSecureCookie(base.EncodeMd5(u.Rands+u.Passwd),
+ setting.CookieRememberName, u.Name, days)
+ }
+
+ // Bind with social account.
+ // if isOauth {
+ // if err = models.BindUserOauth2(user.Id, sid); err != nil {
+ // if err == models.ErrOauth2RecordNotExist {
+ // ctx.Handle(404, "user.SignInPost(GetOauth2ById)", err)
+ // } else {
+ // ctx.Handle(500, "user.SignInPost(GetOauth2ById)", err)
+ // }
+ // return
+ // }
+ // ctx.Session.Delete("socialId")
+ // log.Trace("%s OAuth binded: %s -> %d", ctx.Req.RequestURI, form.UserName, sid)
+ // }
+
+ ctx.Session.Set("uid", u.Id)
+ ctx.Session.Set("uname", u.Name)
+ if redirectTo, _ := url.QueryUnescape(ctx.GetCookie("redirect_to")); len(redirectTo) > 0 {
+ ctx.SetCookie("redirect_to", "", -1)
+ ctx.Redirect(redirectTo)
+ return
+ }
+
+ ctx.Redirect("/")
+}
+
+func SignOut(ctx *middleware.Context) {
+ ctx.Session.Delete("uid")
+ ctx.Session.Delete("uname")
+ // ctx.Session.Delete("socialId")
+ // ctx.Session.Delete("socialName")
+ // ctx.Session.Delete("socialEmail")
+ ctx.SetCookie(setting.CookieUserName, "", -1)
+ ctx.SetCookie(setting.CookieRememberName, "", -1)
+ ctx.Redirect("/")
+}
+
+func SignUp(ctx *middleware.Context) {
+ ctx.Data["Title"] = ctx.Tr("sign_up")
+
+ if setting.Service.DisableRegistration {
+ ctx.Data["DisableRegistration"] = true
+ ctx.HTML(200, SIGNUP)
+ return
+ }
+
+ // if sid, ok := ctx.Session.Get("socialId").(int64); ok {
+ // oauthSignUp(ctx, sid)
+ // return
+ // }
+
+ ctx.HTML(200, SIGNUP)
+}
+
+// func oauthSignUp(ctx *middleware.Context, sid int64) {
+// ctx.Data["Title"] = "OAuth Sign Up"
+// ctx.Data["PageIsSignUp"] = true
+
+// if _, err := models.GetOauth2ById(sid); err != nil {
+// if err == models.ErrOauth2RecordNotExist {
+// ctx.Handle(404, "user.oauthSignUp(GetOauth2ById)", err)
+// } else {
+// ctx.Handle(500, "user.oauthSignUp(GetOauth2ById)", err)
+// }
+// return
+// }
+
+// ctx.Data["IsSocialLogin"] = true
+// ctx.Data["username"] = strings.Replace(ctx.Session.Get("socialName").(string), " ", "", -1)
+// ctx.Data["email"] = ctx.Session.Get("socialEmail")
+// log.Trace("user.oauthSignUp(social ID): %v", ctx.Session.Get("socialId"))
+// ctx.HTML(200, SIGNUP)
+// }
+
+func SignUpPost(ctx *middleware.Context, cpt *captcha.Captcha, form auth.RegisterForm) {
+ ctx.Data["Title"] = ctx.Tr("sign_up")
+
+ if setting.Service.DisableRegistration {
+ ctx.Error(403)
+ return
+ }
+
+ isOauth := false
+ // sid, isOauth := ctx.Session.Get("socialId").(int64)
+ // if isOauth {
+ // ctx.Data["IsSocialLogin"] = true
+ // }
+
+ // May redirect from home page.
+ if ctx.Query("from") == "home" {
+ // Clear input error box.
+ ctx.Data["Err_UserName"] = false
+ ctx.Data["Err_Email"] = false
+
+ // Make the best guess.
+ uname := ctx.Query("uname")
+ i := strings.Index(uname, "@")
+ if i > -1 {
+ ctx.Data["email"] = uname
+ ctx.Data["uname"] = uname[:i]
+ } else {
+ ctx.Data["uname"] = uname
+ }
+ ctx.Data["password"] = ctx.Query("password")
+ ctx.HTML(200, SIGNUP)
+ return
+ }
+
+ if ctx.HasError() {
+ ctx.HTML(200, SIGNUP)
+ return
+ }
+
+ if !cpt.VerifyReq(ctx.Req) {
+ ctx.Data["Err_Captcha"] = true
+ ctx.RenderWithErr(ctx.Tr("form.captcha_incorrect"), SIGNUP, &form)
+ return
+ } else if form.Password != form.Retype {
+ ctx.Data["Err_Password"] = true
+ ctx.RenderWithErr(ctx.Tr("form.password_not_match"), SIGNUP, &form)
+ return
+ }
+
+ u := &models.User{
+ Name: form.UserName,
+ Email: form.Email,
+ Passwd: form.Password,
+ IsActive: !setting.Service.RegisterEmailConfirm || isOauth,
+ }
+
+ if err := models.CreateUser(u); err != nil {
+ switch err {
+ case models.ErrUserAlreadyExist:
+ ctx.Data["Err_UserName"] = true
+ ctx.RenderWithErr(ctx.Tr("form.username_been_taken"), SIGNUP, &form)
+ case models.ErrEmailAlreadyUsed:
+ ctx.Data["Err_Email"] = true
+ ctx.RenderWithErr(ctx.Tr("form.email_been_used"), SIGNUP, &form)
+ case models.ErrUserNameIllegal:
+ ctx.Data["Err_UserName"] = true
+ ctx.RenderWithErr(ctx.Tr("form.illegal_username"), SIGNUP, &form)
+ default:
+ ctx.Handle(500, "CreateUser", err)
+ }
+ return
+ }
+ log.Trace("Account created: %s", u.Name)
+
+ // Bind social account.
+ // if isOauth {
+ // if err = models.BindUserOauth2(u.Id, sid); err != nil {
+ // ctx.Handle(500, "user.SignUp(BindUserOauth2)", err)
+ // return
+ // }
+ // ctx.Session.Delete("socialId")
+ // log.Trace("%s OAuth binded: %s -> %d", ctx.Req.RequestURI, form.UserName, sid)
+ // }
+
+ // Send confirmation e-mail, no need for social account.
+ // if !isOauth && setting.Service.RegisterEmailConfirm && u.Id > 1 {
+ // mailer.SendRegisterMail(ctx.Render, u)
+ // ctx.Data["IsSendRegisterMail"] = true
+ // ctx.Data["Email"] = u.Email
+ // ctx.Data["Hours"] = setting.Service.ActiveCodeLives / 60
+ // ctx.HTML(200, "user/activate")
+
+ // if err = ctx.Cache.Put("MailResendLimit_"+u.LowerName, u.LowerName, 180); err != nil {
+ // log.Error("Set cache(MailResendLimit) fail: %v", err)
+ // }
+ // return
+ // }
+
+ ctx.Redirect("/user/login")
+}
+
+func Activate(ctx *middleware.Context) {
+ // code := ctx.Query("code")
+ // if len(code) == 0 {
+ // ctx.Data["IsActivatePage"] = true
+ // if ctx.User.IsActive {
+ // ctx.Handle(404, "user.Activate", nil)
+ // return
+ // }
+ // // Resend confirmation e-mail.
+ // if setting.Service.RegisterEmailConfirm {
+ // if ctx.Cache.IsExist("MailResendLimit_" + ctx.User.LowerName) {
+ // ctx.Data["ResendLimited"] = true
+ // } else {
+ // ctx.Data["Hours"] = setting.Service.ActiveCodeLives / 60
+ // mailer.SendActiveMail(ctx.Render, ctx.User)
+
+ // if err := ctx.Cache.Put("MailResendLimit_"+ctx.User.LowerName, ctx.User.LowerName, 180); err != nil {
+ // log.Error("Set cache(MailResendLimit) fail: %v", err)
+ // }
+ // }
+ // } else {
+ // ctx.Data["ServiceNotEnabled"] = true
+ // }
+ // ctx.HTML(200, ACTIVATE)
+ // return
+ // }
+
+ // // Verify code.
+ // if user := models.VerifyUserActiveCode(code); user != nil {
+ // user.IsActive = true
+ // user.Rands = models.GetUserSalt()
+ // if err := models.UpdateUser(user); err != nil {
+ // ctx.Handle(404, "user.Activate", err)
+ // return
+ // }
+
+ // log.Trace("%s User activated: %s", ctx.Req.RequestURI, user.Name)
+
+ // ctx.Session.Set("userId", user.Id)
+ // ctx.Session.Set("userName", user.Name)
+ // ctx.Redirect("/")
+ // return
+ // }
+
+ // ctx.Data["IsActivateFailed"] = true
+ // ctx.HTML(200, ACTIVATE)
+}
+
+func ForgotPasswd(ctx *middleware.Context) {
+ ctx.Data["Title"] = "Forgot Password"
+
+ if setting.MailService == nil {
+ ctx.Data["IsResetDisable"] = true
+ ctx.HTML(200, FORGOT_PASSWORD)
+ return
+ }
+
+ ctx.Data["IsResetRequest"] = true
+ ctx.HTML(200, FORGOT_PASSWORD)
+}
+
+func ForgotPasswdPost(ctx *middleware.Context) {
+ // ctx.Data["Title"] = "Forgot Password"
+
+ // if setting.MailService == nil {
+ // ctx.Handle(403, "user.ForgotPasswdPost", nil)
+ // return
+ // }
+ // ctx.Data["IsResetRequest"] = true
+
+ // email := ctx.Query("email")
+ // u, err := models.GetUserByEmail(email)
+ // if err != nil {
+ // if err == models.ErrUserNotExist {
+ // ctx.RenderWithErr("This e-mail address does not associate to any account.", "user/forgot_passwd", nil)
+ // } else {
+ // ctx.Handle(500, "user.ResetPasswd(check existence)", err)
+ // }
+ // return
+ // }
+
+ // if ctx.Cache.IsExist("MailResendLimit_" + u.LowerName) {
+ // ctx.Data["ResendLimited"] = true
+ // ctx.HTML(200, FORGOT_PASSWORD)
+ // return
+ // }
+
+ // mailer.SendResetPasswdMail(ctx.Render, u)
+ // if err = ctx.Cache.Put("MailResendLimit_"+u.LowerName, u.LowerName, 180); err != nil {
+ // log.Error("Set cache(MailResendLimit) fail: %v", err)
+ // }
+
+ // ctx.Data["Email"] = email
+ // ctx.Data["Hours"] = setting.Service.ActiveCodeLives / 60
+ // ctx.Data["IsResetSent"] = true
+ // ctx.HTML(200, FORGOT_PASSWORD)
+}
+
+func ResetPasswd(ctx *middleware.Context) {
+ ctx.Data["Title"] = "Reset Password"
+
+ code := ctx.Query("code")
+ if len(code) == 0 {
+ ctx.Error(404)
+ return
+ }
+ ctx.Data["Code"] = code
+ ctx.Data["IsResetForm"] = true
+ ctx.HTML(200, RESET_PASSWORD)
+}
+
+func ResetPasswdPost(ctx *middleware.Context) {
+ // ctx.Data["Title"] = "Reset Password"
+
+ // code := ctx.Query("code")
+ // if len(code) == 0 {
+ // ctx.Error(404)
+ // return
+ // }
+ // ctx.Data["Code"] = code
+
+ // if u := models.VerifyUserActiveCode(code); u != nil {
+ // // Validate password length.
+ // passwd := ctx.Query("passwd")
+ // if len(passwd) < 6 || len(passwd) > 30 {
+ // ctx.Data["IsResetForm"] = true
+ // ctx.RenderWithErr("Password length should be in 6 and 30.", "user/reset_passwd", nil)
+ // return
+ // }
+
+ // u.Passwd = passwd
+ // u.Rands = models.GetUserSalt()
+ // u.Salt = models.GetUserSalt()
+ // u.EncodePasswd()
+ // if err := models.UpdateUser(u); err != nil {
+ // ctx.Handle(500, "user.ResetPasswd(UpdateUser)", err)
+ // return
+ // }
+
+ // log.Trace("%s User password reset: %s", ctx.Req.RequestURI, u.Name)
+ // ctx.Redirect("/user/login")
+ // return
+ // }
+
+ // ctx.Data["IsResetFailed"] = true
+ // ctx.HTML(200, RESET_PASSWORD)
+}