user.go 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  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. "bytes"
  7. "net/http"
  8. "github.com/codegangsta/martini"
  9. "github.com/martini-contrib/render"
  10. "github.com/martini-contrib/sessions"
  11. "github.com/gogits/gogs/models"
  12. "github.com/gogits/gogs/modules/auth"
  13. "github.com/gogits/gogs/modules/base"
  14. "github.com/gogits/gogs/modules/log"
  15. )
  16. func Dashboard(r render.Render, data base.TmplData, session sessions.Session) {
  17. data["Title"] = "Dashboard"
  18. data["PageIsUserDashboard"] = true
  19. repos, err := models.GetRepositories(&models.User{Id: auth.SignedInId(session)})
  20. if err != nil {
  21. data["ErrorMsg"] = err
  22. log.Error("dashboard: %v", err)
  23. r.HTML(200, "base/error", data)
  24. return
  25. }
  26. data["MyRepos"] = repos
  27. r.HTML(200, "user/dashboard", data)
  28. }
  29. func Profile(params martini.Params, r render.Render, data base.TmplData, session sessions.Session) {
  30. data["Title"] = "Profile"
  31. // TODO: Need to check view self or others.
  32. user, err := models.GetUserByName(params["username"])
  33. if err != nil {
  34. data["ErrorMsg"] = err
  35. log.Error("user.Profile: %v", err)
  36. r.HTML(200, "base/error", data)
  37. return
  38. }
  39. data["Avatar"] = user.Avatar
  40. data["Username"] = user.Name
  41. r.HTML(200, "user/profile", data)
  42. }
  43. func SignIn(form auth.LogInForm, data base.TmplData, req *http.Request, r render.Render, session sessions.Session) {
  44. data["Title"] = "Log In"
  45. if req.Method == "GET" {
  46. r.HTML(200, "user/signin", data)
  47. return
  48. }
  49. if hasErr, ok := data["HasError"]; ok && hasErr.(bool) {
  50. r.HTML(200, "user/signin", data)
  51. return
  52. }
  53. user, err := models.LoginUserPlain(form.UserName, form.Password)
  54. if err != nil {
  55. if err.Error() == models.ErrUserNotExist.Error() {
  56. data["HasError"] = true
  57. data["ErrorMsg"] = "Username or password is not correct"
  58. auth.AssignForm(form, data)
  59. r.HTML(200, "user/signin", data)
  60. return
  61. }
  62. data["ErrorMsg"] = err
  63. log.Error("user.SignIn: %v", err)
  64. r.HTML(200, "base/error", data)
  65. return
  66. }
  67. session.Set("userId", user.Id)
  68. session.Set("userName", user.Name)
  69. r.Redirect("/")
  70. }
  71. func SignOut(r render.Render, session sessions.Session) {
  72. session.Delete("userId")
  73. session.Delete("userName")
  74. r.Redirect("/")
  75. }
  76. func SignUp(form auth.RegisterForm, data base.TmplData, req *http.Request, r render.Render) {
  77. data["Title"] = "Sign Up"
  78. data["PageIsSignUp"] = true
  79. if req.Method == "GET" {
  80. r.HTML(200, "user/signup", data)
  81. return
  82. }
  83. if form.Password != form.RetypePasswd {
  84. data["HasError"] = true
  85. data["Err_Password"] = true
  86. data["Err_RetypePasswd"] = true
  87. data["ErrorMsg"] = "Password and re-type password are not same"
  88. auth.AssignForm(form, data)
  89. }
  90. if hasErr, ok := data["HasError"]; ok && hasErr.(bool) {
  91. r.HTML(200, "user/signup", data)
  92. return
  93. }
  94. u := &models.User{
  95. Name: form.UserName,
  96. Email: form.Email,
  97. Passwd: form.Password,
  98. }
  99. if err := models.RegisterUser(u); err != nil {
  100. data["HasError"] = true
  101. auth.AssignForm(form, data)
  102. switch err.Error() {
  103. case models.ErrUserAlreadyExist.Error():
  104. data["Err_Username"] = true
  105. data["ErrorMsg"] = "Username has been already taken"
  106. r.HTML(200, "user/signup", data)
  107. case models.ErrEmailAlreadyUsed.Error():
  108. data["Err_Email"] = true
  109. data["ErrorMsg"] = "E-mail address has been already used"
  110. r.HTML(200, "user/signup", data)
  111. default:
  112. data["ErrorMsg"] = err
  113. log.Error("user.SignUp: %v", data)
  114. r.HTML(200, "base/error", nil)
  115. }
  116. return
  117. }
  118. r.Redirect("/user/login")
  119. }
  120. func Delete(data base.TmplData, req *http.Request, session sessions.Session, r render.Render) {
  121. data["Title"] = "Delete Account"
  122. if req.Method == "GET" {
  123. r.HTML(200, "user/delete", data)
  124. return
  125. }
  126. id := auth.SignedInId(session)
  127. u := &models.User{Id: id}
  128. if err := models.DeleteUser(u); err != nil {
  129. data["HasError"] = true
  130. switch err.Error() {
  131. case models.ErrUserOwnRepos.Error():
  132. data["ErrorMsg"] = "Your account still have ownership of repository, you have to delete or transfer them first."
  133. default:
  134. data["ErrorMsg"] = err
  135. log.Error("user.Delete: %v", data)
  136. r.HTML(200, "base/error", nil)
  137. return
  138. }
  139. }
  140. r.HTML(200, "user/delete", data)
  141. }
  142. func Feeds(form auth.FeedsForm, r render.Render) string {
  143. actions, err := models.GetFeeds(form.UserId, form.Offset)
  144. if err != nil {
  145. return err.Error()
  146. }
  147. length := len(actions)
  148. buf := bytes.NewBuffer([]byte("["))
  149. for i, action := range actions {
  150. buf.WriteString(action.Content)
  151. if i < length-1 {
  152. buf.WriteString(",")
  153. }
  154. }
  155. buf.WriteString("]")
  156. return buf.String()
  157. }