user.go 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. package api
  2. import (
  3. "github.com/0xJacky/Nginx-UI/server/model"
  4. "github.com/0xJacky/Nginx-UI/server/settings"
  5. "github.com/gin-gonic/gin"
  6. "github.com/spf13/cast"
  7. "golang.org/x/crypto/bcrypt"
  8. "net/http"
  9. )
  10. func GetUsers(c *gin.Context) {
  11. data := model.GetUserList(c, c.Query("name"))
  12. c.JSON(http.StatusOK, data)
  13. }
  14. func GetUser(c *gin.Context) {
  15. curd := model.NewCurd(&model.Auth{})
  16. id := c.Param("id")
  17. var user model.Auth
  18. err := curd.First(&user, 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. curd := model.NewCurd(&model.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 = curd.Add(&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. curd := model.NewCurd(&model.Auth{})
  67. var user, edit model.Auth
  68. err := curd.First(&user, userId)
  69. if err != nil {
  70. ErrHandler(c, err)
  71. return
  72. }
  73. edit.Name = json.Name
  74. // encrypt password
  75. if json.Password != "" {
  76. var pwd []byte
  77. pwd, err = bcrypt.GenerateFromPassword([]byte(json.Password), bcrypt.DefaultCost)
  78. if err != nil {
  79. ErrHandler(c, err)
  80. return
  81. }
  82. edit.Password = string(pwd)
  83. }
  84. err = curd.Edit(&user, &edit)
  85. if err != nil {
  86. ErrHandler(c, err)
  87. return
  88. }
  89. c.JSON(http.StatusOK, user)
  90. }
  91. func DeleteUser(c *gin.Context) {
  92. id := c.Param("id")
  93. if cast.ToInt(id) == 1 {
  94. c.JSON(http.StatusNotAcceptable, gin.H{
  95. "message": "Prohibit deleting the default user",
  96. })
  97. return
  98. }
  99. curd := model.NewCurd(&model.Auth{})
  100. err := curd.Delete(&model.Auth{}, "id", id)
  101. if err != nil {
  102. ErrHandler(c, err)
  103. return
  104. }
  105. c.JSON(http.StatusNoContent, gin.H{})
  106. }