user.go 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196
  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. "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/middleware"
  14. )
  15. func Dashboard(ctx *middleware.Context) {
  16. ctx.Data["Title"] = "Dashboard"
  17. ctx.Data["PageIsUserDashboard"] = true
  18. repos, err := models.GetRepositories(&models.User{Id: ctx.User.Id})
  19. if err != nil {
  20. ctx.Handle(200, "user.Dashboard", err)
  21. return
  22. }
  23. ctx.Data["MyRepos"] = repos
  24. feeds, err := models.GetFeeds(ctx.User.Id, 0, false)
  25. if err != nil {
  26. ctx.Handle(200, "user.Dashboard", err)
  27. return
  28. }
  29. ctx.Data["Feeds"] = feeds
  30. ctx.Render.HTML(200, "user/dashboard", ctx.Data)
  31. }
  32. func Profile(ctx *middleware.Context, params martini.Params) {
  33. ctx.Data["Title"] = "Profile"
  34. // TODO: Need to check view self or others.
  35. user, err := models.GetUserByName(params["username"])
  36. if err != nil {
  37. ctx.Handle(200, "user.Profile", err)
  38. return
  39. }
  40. ctx.Data["Owner"] = user
  41. tab := ctx.Query("tab")
  42. ctx.Data["TabName"] = tab
  43. switch tab {
  44. case "activity":
  45. feeds, err := models.GetFeeds(user.Id, 0, true)
  46. if err != nil {
  47. ctx.Handle(200, "user.Profile", err)
  48. return
  49. }
  50. ctx.Data["Feeds"] = feeds
  51. default:
  52. }
  53. ctx.Render.HTML(200, "user/profile", ctx.Data)
  54. }
  55. func SignIn(ctx *middleware.Context, form auth.LogInForm) {
  56. ctx.Data["Title"] = "Log In"
  57. if ctx.Req.Method == "GET" {
  58. ctx.Render.HTML(200, "user/signin", ctx.Data)
  59. return
  60. }
  61. if hasErr, ok := ctx.Data["HasError"]; ok && hasErr.(bool) {
  62. ctx.Render.HTML(200, "user/signin", ctx.Data)
  63. return
  64. }
  65. user, err := models.LoginUserPlain(form.UserName, form.Password)
  66. if err != nil {
  67. if err.Error() == models.ErrUserNotExist.Error() {
  68. ctx.Data["HasError"] = true
  69. ctx.Data["ErrorMsg"] = "Username or password is not correct"
  70. auth.AssignForm(form, ctx.Data)
  71. ctx.Render.HTML(200, "user/signin", ctx.Data)
  72. return
  73. }
  74. ctx.Handle(200, "user.SignIn", err)
  75. return
  76. }
  77. ctx.Session.Set("userId", user.Id)
  78. ctx.Session.Set("userName", user.Name)
  79. ctx.Render.Redirect("/")
  80. }
  81. func SignOut(r render.Render, session sessions.Session) {
  82. session.Delete("userId")
  83. session.Delete("userName")
  84. r.Redirect("/")
  85. }
  86. func SignUp(ctx *middleware.Context, form auth.RegisterForm) {
  87. ctx.Data["Title"] = "Sign Up"
  88. ctx.Data["PageIsSignUp"] = true
  89. if ctx.Req.Method == "GET" {
  90. ctx.Render.HTML(200, "user/signup", ctx.Data)
  91. return
  92. }
  93. if form.Password != form.RetypePasswd {
  94. ctx.Data["HasError"] = true
  95. ctx.Data["Err_Password"] = true
  96. ctx.Data["Err_RetypePasswd"] = true
  97. ctx.Data["ErrorMsg"] = "Password and re-type password are not same"
  98. auth.AssignForm(form, ctx.Data)
  99. }
  100. if hasErr, ok := ctx.Data["HasError"]; ok && hasErr.(bool) {
  101. ctx.Render.HTML(200, "user/signup", ctx.Data)
  102. return
  103. }
  104. u := &models.User{
  105. Name: form.UserName,
  106. Email: form.Email,
  107. Passwd: form.Password,
  108. }
  109. if err := models.RegisterUser(u); err != nil {
  110. ctx.Data["HasError"] = true
  111. auth.AssignForm(form, ctx.Data)
  112. switch err.Error() {
  113. case models.ErrUserAlreadyExist.Error():
  114. ctx.Data["Err_Username"] = true
  115. ctx.Data["ErrorMsg"] = "Username has been already taken"
  116. ctx.Render.HTML(200, "user/signup", ctx.Data)
  117. case models.ErrEmailAlreadyUsed.Error():
  118. ctx.Data["Err_Email"] = true
  119. ctx.Data["ErrorMsg"] = "E-mail address has been already used"
  120. ctx.Render.HTML(200, "user/signup", ctx.Data)
  121. default:
  122. ctx.Handle(200, "user.SignUp", err)
  123. }
  124. return
  125. }
  126. ctx.Render.Redirect("/user/login")
  127. }
  128. func Delete(ctx *middleware.Context) {
  129. ctx.Data["Title"] = "Delete Account"
  130. if ctx.Req.Method == "GET" {
  131. ctx.Render.HTML(200, "user/delete", ctx.Data)
  132. return
  133. }
  134. if err := models.DeleteUser(ctx.User); err != nil {
  135. ctx.Data["HasError"] = true
  136. switch err.Error() {
  137. case models.ErrUserOwnRepos.Error():
  138. ctx.Data["ErrorMsg"] = "Your account still have ownership of repository, you have to delete or transfer them first."
  139. default:
  140. ctx.Handle(200, "user.Delete", err)
  141. return
  142. }
  143. }
  144. ctx.Render.HTML(200, "user/delete", ctx.Data)
  145. }
  146. const (
  147. feedTpl = `<i class="icon fa fa-%s"></i>
  148. <div class="info"><span class="meta">%s</span><br>%s</div>`
  149. )
  150. func Feeds(ctx *middleware.Context, form auth.FeedsForm) {
  151. actions, err := models.GetFeeds(form.UserId, form.Page*20, false)
  152. if err != nil {
  153. ctx.Render.JSON(500, err)
  154. }
  155. feeds := make([]string, len(actions))
  156. for i := range actions {
  157. feeds[i] = fmt.Sprintf(feedTpl, base.ActionIcon(actions[i].OpType),
  158. base.TimeSince(actions[i].Created), base.ActionDesc(actions[i]))
  159. }
  160. ctx.Render.JSON(200, &feeds)
  161. }