1
0

user.go 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  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 := cosy.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. // duplicate name
  48. _, err = u.Where(u.Name.Eq(json.Name)).First()
  49. if !(err != nil && err.Error() == "record not found") {
  50. c.JSON(http.StatusConflict, gin.H{
  51. "message": "name already exists",
  52. })
  53. }
  54. err = u.Create(&user)
  55. if err != nil {
  56. api.ErrHandler(c, err)
  57. return
  58. }
  59. c.JSON(http.StatusOK, user)
  60. }
  61. func EditUser(c *gin.Context) {
  62. userId := cast.ToUint64(c.Param("id"))
  63. if settings.NodeSettings.Demo && userId == 1 {
  64. c.JSON(http.StatusNotAcceptable, gin.H{
  65. "message": "Changing user password is forbidden in demo mode",
  66. })
  67. return
  68. }
  69. var json UserJson
  70. ok := cosy.BindAndValid(c, &json)
  71. if !ok {
  72. return
  73. }
  74. u := query.User
  75. user, err := u.FirstByID(userId)
  76. if err != nil {
  77. api.ErrHandler(c, err)
  78. return
  79. }
  80. edit := &model.User{
  81. Name: json.Name,
  82. }
  83. // encrypt password
  84. if json.Password != "" {
  85. var pwd []byte
  86. pwd, err = bcrypt.GenerateFromPassword([]byte(json.Password), bcrypt.DefaultCost)
  87. if err != nil {
  88. api.ErrHandler(c, err)
  89. return
  90. }
  91. edit.Password = string(pwd)
  92. }
  93. _, err = u.Where(u.ID.Eq(userId)).Updates(&edit)
  94. if err != nil {
  95. api.ErrHandler(c, err)
  96. return
  97. }
  98. c.JSON(http.StatusOK, user)
  99. }
  100. func DeleteUser(c *gin.Context) {
  101. id := cast.ToInt(c.Param("id"))
  102. if cast.ToInt(id) == 1 {
  103. c.JSON(http.StatusNotAcceptable, gin.H{
  104. "message": "Prohibit deleting the default user",
  105. })
  106. return
  107. }
  108. cosy.Core[model.User](c).Destroy()
  109. }
  110. func RecoverUser(c *gin.Context) {
  111. cosy.Core[model.User](c).Recover()
  112. }