user.go 2.3 KB

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