user.go 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. package api
  2. import (
  3. "github.com/0xJacky/Nginx-UI/server/model"
  4. "github.com/0xJacky/Nginx-UI/server/query"
  5. "github.com/0xJacky/Nginx-UI/server/settings"
  6. "github.com/gin-gonic/gin"
  7. "github.com/spf13/cast"
  8. "golang.org/x/crypto/bcrypt"
  9. "net/http"
  10. )
  11. func GetUsers(c *gin.Context) {
  12. data := model.GetUserList(c, c.Query("name"))
  13. c.JSON(http.StatusOK, data)
  14. }
  15. func GetUser(c *gin.Context) {
  16. id := cast.ToInt(c.Param("id"))
  17. u := query.Auth
  18. user, err := u.FirstByID(id)
  19. if err != nil {
  20. ErrHandler(c, err)
  21. return
  22. }
  23. c.JSON(http.StatusOK, user)
  24. }
  25. type UserJson struct {
  26. Name string `json:"name" binding:"required,max=255"`
  27. Password string `json:"password" binding:"max=255"`
  28. }
  29. func AddUser(c *gin.Context) {
  30. var json UserJson
  31. ok := BindAndValid(c, &json)
  32. if !ok {
  33. return
  34. }
  35. u := query.Auth
  36. pwd, err := bcrypt.GenerateFromPassword([]byte(json.Password), bcrypt.DefaultCost)
  37. if err != nil {
  38. ErrHandler(c, err)
  39. return
  40. }
  41. json.Password = string(pwd)
  42. user := model.Auth{
  43. Name: json.Name,
  44. Password: json.Password,
  45. }
  46. err = u.Create(&user)
  47. if err != nil {
  48. ErrHandler(c, err)
  49. return
  50. }
  51. c.JSON(http.StatusOK, user)
  52. }
  53. func EditUser(c *gin.Context) {
  54. userId := cast.ToInt(c.Param("id"))
  55. if settings.ServerSettings.Demo && userId == 1 {
  56. c.JSON(http.StatusNotAcceptable, gin.H{
  57. "message": "Prohibit changing root password in demo",
  58. })
  59. return
  60. }
  61. var json UserJson
  62. ok := BindAndValid(c, &json)
  63. if !ok {
  64. return
  65. }
  66. u := query.Auth
  67. user, err := u.FirstByID(userId)
  68. if err != nil {
  69. ErrHandler(c, err)
  70. return
  71. }
  72. edit := &model.Auth{
  73. Name: json.Name,
  74. }
  75. // encrypt password
  76. if json.Password != "" {
  77. var pwd []byte
  78. pwd, err = bcrypt.GenerateFromPassword([]byte(json.Password), bcrypt.DefaultCost)
  79. if err != nil {
  80. ErrHandler(c, err)
  81. return
  82. }
  83. edit.Password = string(pwd)
  84. }
  85. _, err = u.Where(u.ID.Eq(userId)).Updates(&edit)
  86. if err != nil {
  87. ErrHandler(c, err)
  88. return
  89. }
  90. c.JSON(http.StatusOK, user)
  91. }
  92. func DeleteUser(c *gin.Context) {
  93. id := cast.ToInt(c.Param("id"))
  94. if cast.ToInt(id) == 1 {
  95. c.JSON(http.StatusNotAcceptable, gin.H{
  96. "message": "Prohibit deleting the default user",
  97. })
  98. return
  99. }
  100. u := query.Auth
  101. err := u.DeleteByID(id)
  102. if err != nil {
  103. ErrHandler(c, err)
  104. return
  105. }
  106. c.JSON(http.StatusNoContent, gin.H{})
  107. }