You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

user.go 4.2KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170
  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. "net/http"
  7. "github.com/codegangsta/martini"
  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/modules/log"
  14. )
  15. func Dashboard(r render.Render, data base.TmplData, session sessions.Session) {
  16. data["Title"] = "Dashboard"
  17. data["PageIsUserDashboard"] = true
  18. repos, err := models.GetRepositories(&models.User{Id: auth.SignedInId(session)})
  19. if err != nil {
  20. log.Handle(200, "user.Dashboard", data, r, err)
  21. return
  22. }
  23. data["MyRepos"] = repos
  24. r.HTML(200, "user/dashboard", data)
  25. }
  26. func Profile(params martini.Params, r render.Render, data base.TmplData, session sessions.Session) {
  27. data["Title"] = "Profile"
  28. // TODO: Need to check view self or others.
  29. user, err := models.GetUserByName(params["username"])
  30. if err != nil {
  31. log.Handle(200, "user.Profile", data, r, err)
  32. return
  33. }
  34. data["Owner"] = user
  35. feeds, err := models.GetFeeds(user.Id, 0, true)
  36. if err != nil {
  37. log.Handle(200, "user.Profile", data, r, err)
  38. return
  39. }
  40. data["Feeds"] = feeds
  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. log.Handle(200, "user.SignIn", data, r, err)
  63. return
  64. }
  65. session.Set("userId", user.Id)
  66. session.Set("userName", user.Name)
  67. r.Redirect("/")
  68. }
  69. func SignOut(r render.Render, session sessions.Session) {
  70. session.Delete("userId")
  71. session.Delete("userName")
  72. r.Redirect("/")
  73. }
  74. func SignUp(form auth.RegisterForm, data base.TmplData, req *http.Request, r render.Render) {
  75. data["Title"] = "Sign Up"
  76. data["PageIsSignUp"] = true
  77. if req.Method == "GET" {
  78. r.HTML(200, "user/signup", data)
  79. return
  80. }
  81. if form.Password != form.RetypePasswd {
  82. data["HasError"] = true
  83. data["Err_Password"] = true
  84. data["Err_RetypePasswd"] = true
  85. data["ErrorMsg"] = "Password and re-type password are not same"
  86. auth.AssignForm(form, data)
  87. }
  88. if hasErr, ok := data["HasError"]; ok && hasErr.(bool) {
  89. r.HTML(200, "user/signup", data)
  90. return
  91. }
  92. u := &models.User{
  93. Name: form.UserName,
  94. Email: form.Email,
  95. Passwd: form.Password,
  96. }
  97. if err := models.RegisterUser(u); err != nil {
  98. data["HasError"] = true
  99. auth.AssignForm(form, data)
  100. switch err.Error() {
  101. case models.ErrUserAlreadyExist.Error():
  102. data["Err_Username"] = true
  103. data["ErrorMsg"] = "Username has been already taken"
  104. r.HTML(200, "user/signup", data)
  105. case models.ErrEmailAlreadyUsed.Error():
  106. data["Err_Email"] = true
  107. data["ErrorMsg"] = "E-mail address has been already used"
  108. r.HTML(200, "user/signup", data)
  109. default:
  110. log.Handle(200, "user.SignUp", data, r, err)
  111. }
  112. return
  113. }
  114. r.Redirect("/user/login")
  115. }
  116. func Delete(data base.TmplData, req *http.Request, session sessions.Session, r render.Render) {
  117. data["Title"] = "Delete Account"
  118. if req.Method == "GET" {
  119. r.HTML(200, "user/delete", data)
  120. return
  121. }
  122. id := auth.SignedInId(session)
  123. u := &models.User{Id: id}
  124. if err := models.DeleteUser(u); err != nil {
  125. data["HasError"] = true
  126. switch err.Error() {
  127. case models.ErrUserOwnRepos.Error():
  128. data["ErrorMsg"] = "Your account still have ownership of repository, you have to delete or transfer them first."
  129. default:
  130. log.Handle(200, "user.Delete", data, r, err)
  131. return
  132. }
  133. }
  134. r.HTML(200, "user/delete", data)
  135. }
  136. func Feeds(form auth.FeedsForm, r render.Render) {
  137. actions, err := models.GetFeeds(form.UserId, form.Offset, false)
  138. if err != nil {
  139. r.JSON(500, err)
  140. }
  141. r.JSON(200, actions)
  142. }