user.go 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  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/validation"
  11. "github.com/gogits/gogs/models"
  12. "github.com/gogits/gogs/utils/auth"
  13. "github.com/gogits/gogs/utils/log"
  14. )
  15. func Profile(r render.Render) {
  16. r.HTML(200, "user/profile", map[string]interface{}{
  17. "Title": "Username",
  18. })
  19. return
  20. }
  21. func SignIn(req *http.Request, r render.Render, session sessions.Session) {
  22. var (
  23. errString string
  24. account string
  25. )
  26. if req.Method == "POST" {
  27. account = req.FormValue("account")
  28. user, err := models.LoginUserPlain(account, req.FormValue("passwd"))
  29. if err == nil {
  30. // login success
  31. session.Set("userId", user.Id)
  32. session.Set("userName", user.Name)
  33. r.Redirect("/")
  34. return
  35. }
  36. // login fail
  37. errString = fmt.Sprintf("%v", err)
  38. }
  39. r.HTML(200, "user/signin", map[string]interface{}{
  40. "Title": "Log In",
  41. "Error": errString,
  42. "Account": account,
  43. })
  44. }
  45. func SignUp(req *http.Request, r render.Render) {
  46. data := map[string]interface{}{"Title": "Sign Up"}
  47. if req.Method == "GET" {
  48. r.HTML(200, "user/signup", data)
  49. return
  50. }
  51. // Front-end should do double check of password.
  52. u := &models.User{
  53. Name: req.FormValue("username"),
  54. Email: req.FormValue("email"),
  55. Passwd: req.FormValue("passwd"),
  56. }
  57. valid := validation.Validation{}
  58. ok, err := valid.Valid(u)
  59. if err != nil {
  60. log.Error("user.SignUp -> valid user: %v", err)
  61. return
  62. }
  63. if !ok {
  64. data["HasError"] = true
  65. data["ErrorMsg"] = auth.GenerateErrorMsg(valid.Errors[0])
  66. r.HTML(200, "user/signup", data)
  67. return
  68. }
  69. // err = models.RegisterUser(u)
  70. // if err != nil {
  71. // r.HTML(200, "base/error", map[string]interface{}{
  72. // "Error": fmt.Sprintf("%v", err),
  73. // })
  74. // return
  75. // }
  76. // r.Redirect("/")
  77. }
  78. func Delete(req *http.Request, r render.Render) {
  79. if req.Method == "GET" {
  80. r.HTML(200, "user/delete", map[string]interface{}{
  81. "Title": "Delete user",
  82. })
  83. return
  84. }
  85. u := &models.User{}
  86. err := models.DeleteUser(u)
  87. r.HTML(403, "status/403", map[string]interface{}{
  88. "Title": fmt.Sprintf("%v", err),
  89. })
  90. }