user.go 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. package api
  2. import (
  3. "errors"
  4. "github.com/0xJacky/Nginx-UI/server/model"
  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. curd := model.NewCurd(&model.Auth{})
  13. var list []model.Auth
  14. err := curd.GetList(&list)
  15. if err != nil {
  16. ErrHandler(c, err)
  17. return
  18. }
  19. c.JSON(http.StatusOK, gin.H{
  20. "data": list,
  21. })
  22. }
  23. func GetUser(c *gin.Context) {
  24. curd := model.NewCurd(&model.Auth{})
  25. id := c.Param("id")
  26. var user model.Auth
  27. err := curd.First(&user, id)
  28. if err != nil {
  29. ErrHandler(c, err)
  30. return
  31. }
  32. c.JSON(http.StatusOK, user)
  33. }
  34. type UserJson struct {
  35. Name string `json:"name" binding:"required,max=255"`
  36. Password string `json:"password" binding:"max=255"`
  37. }
  38. func AddUser(c *gin.Context) {
  39. var json UserJson
  40. ok := BindAndValid(c, &json)
  41. if !ok {
  42. return
  43. }
  44. curd := model.NewCurd(&model.Auth{})
  45. pwd, err := bcrypt.GenerateFromPassword([]byte(json.Password), bcrypt.DefaultCost)
  46. if err != nil {
  47. ErrHandler(c, err)
  48. return
  49. }
  50. json.Password = string(pwd)
  51. user := model.Auth{
  52. Name: json.Name,
  53. Password: json.Password,
  54. }
  55. err = curd.Add(&user)
  56. if err != nil {
  57. ErrHandler(c, err)
  58. return
  59. }
  60. c.JSON(http.StatusOK, user)
  61. }
  62. func EditUser(c *gin.Context) {
  63. userId := cast.ToInt(c.Param("id"))
  64. if settings.ServerSettings.Demo && userId == 1 {
  65. ErrHandler(c, errors.New("not allow to change the root password in demo"))
  66. return
  67. }
  68. var json UserJson
  69. ok := BindAndValid(c, &json)
  70. if !ok {
  71. return
  72. }
  73. curd := model.NewCurd(&model.Auth{})
  74. var user, edit model.Auth
  75. err := curd.First(&user, userId)
  76. if err != nil {
  77. ErrHandler(c, err)
  78. return
  79. }
  80. edit.Name = json.Name
  81. // 改密码加密
  82. if json.Password != "" {
  83. var pwd []byte
  84. pwd, err = bcrypt.GenerateFromPassword([]byte(json.Password), bcrypt.DefaultCost)
  85. if err != nil {
  86. ErrHandler(c, err)
  87. return
  88. }
  89. edit.Password = string(pwd)
  90. }
  91. err = curd.Edit(&user, &edit)
  92. if err != nil {
  93. ErrHandler(c, err)
  94. return
  95. }
  96. c.JSON(http.StatusOK, user)
  97. }
  98. func DeleteUser(c *gin.Context) {
  99. id := c.Param("id")
  100. if cast.ToInt(id) == 1 {
  101. ErrHandler(c, errors.New("not allow to delete the default user"))
  102. return
  103. }
  104. curd := model.NewCurd(&model.Auth{})
  105. err := curd.Delete(&model.Auth{}, "id", id)
  106. if err != nil {
  107. ErrHandler(c, err)
  108. return
  109. }
  110. c.JSON(http.StatusNoContent, gin.H{})
  111. }