user.go 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  1. // Copyright 2014 The Gogs Authors. All rights reserved.
  2. // Use of this source code is governed by a MIT-style
  3. // license that can be found in the LICENSE file.
  4. package user
  5. import (
  6. "fmt"
  7. "net/http"
  8. "github.com/martini-contrib/render"
  9. "github.com/martini-contrib/sessions"
  10. "github.com/gogits/gogs/models"
  11. "github.com/gogits/gogs/modules/auth"
  12. "github.com/gogits/gogs/modules/base"
  13. "github.com/gogits/gogs/utils/log"
  14. )
  15. func Dashboard(r render.Render, data base.TmplData, session sessions.Session) {
  16. data["Title"] = "Dashboard"
  17. data["PageIsUserDashboard"] = true
  18. r.HTML(200, "user/dashboard", data)
  19. }
  20. func Profile(r render.Render, data base.TmplData, session sessions.Session) {
  21. data["Title"] = "Profile"
  22. data["IsSigned"] = auth.IsSignedIn(session)
  23. // TODO: Need to check view self or others.
  24. user := auth.SignedInUser(session)
  25. data["Avatar"] = user.Avatar
  26. data["Username"] = user.Name
  27. r.HTML(200, "user/profile", data)
  28. }
  29. func SignIn(form auth.LogInForm, data base.TmplData, req *http.Request, r render.Render, session sessions.Session) {
  30. data["Title"] = "Log In"
  31. if req.Method == "GET" {
  32. r.HTML(200, "user/signin", data)
  33. return
  34. }
  35. if hasErr, ok := data["HasError"]; ok && hasErr.(bool) {
  36. r.HTML(200, "user/signin", data)
  37. return
  38. }
  39. user, err := models.LoginUserPlain(form.UserName, form.Password)
  40. if err != nil {
  41. if err.Error() == models.ErrUserNotExist.Error() {
  42. data["HasError"] = true
  43. data["ErrorMsg"] = "Username or password is not correct"
  44. auth.AssignForm(form, data)
  45. r.HTML(200, "user/signin", data)
  46. return
  47. }
  48. data["ErrorMsg"] = err
  49. log.Error("user.SignIn: %v", data)
  50. r.HTML(500, "base/error", nil)
  51. return
  52. }
  53. // login success
  54. session.Set("userId", user.Id)
  55. session.Set("userName", user.Name)
  56. r.Redirect("/")
  57. }
  58. func SignOut(r render.Render, session sessions.Session) {
  59. session.Delete("userId")
  60. session.Delete("userName")
  61. r.Redirect("/")
  62. }
  63. func SignUp(form auth.RegisterForm, data base.TmplData, req *http.Request, r render.Render) {
  64. data["Title"] = "Sign Up"
  65. data["PageIsSignUp"] = true
  66. if req.Method == "GET" {
  67. r.HTML(200, "user/signup", data)
  68. return
  69. }
  70. if form.Password != form.RetypePasswd {
  71. data["HasError"] = true
  72. data["Err_Password"] = true
  73. data["Err_RetypePasswd"] = true
  74. data["ErrorMsg"] = "Password and re-type password are not same"
  75. auth.AssignForm(form, data)
  76. }
  77. if hasErr, ok := data["HasError"]; ok && hasErr.(bool) {
  78. r.HTML(200, "user/signup", data)
  79. return
  80. }
  81. u := &models.User{
  82. Name: form.UserName,
  83. Email: form.Email,
  84. Passwd: form.Password,
  85. }
  86. if err := models.RegisterUser(u); err != nil {
  87. data["HasError"] = true
  88. auth.AssignForm(form, data)
  89. switch err.Error() {
  90. case models.ErrUserAlreadyExist.Error():
  91. data["Err_Username"] = true
  92. data["ErrorMsg"] = "Username has been already taken"
  93. r.HTML(200, "user/signup", data)
  94. case models.ErrEmailAlreadyUsed.Error():
  95. data["Err_Email"] = true
  96. data["ErrorMsg"] = "E-mail address has been already used"
  97. r.HTML(200, "user/signup", data)
  98. default:
  99. data["ErrorMsg"] = err
  100. log.Error("user.SignUp: %v", data)
  101. r.HTML(500, "base/error", nil)
  102. }
  103. return
  104. }
  105. r.Redirect("/user/login")
  106. }
  107. func Delete(req *http.Request, r render.Render) {
  108. if req.Method == "GET" {
  109. r.HTML(200, "user/delete", map[string]interface{}{
  110. "Title": "Delete user",
  111. })
  112. return
  113. }
  114. u := &models.User{}
  115. err := models.DeleteUser(u)
  116. r.HTML(403, "status/403", map[string]interface{}{
  117. "Title": fmt.Sprintf("%v", err),
  118. })
  119. }