1
0

user.go 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. package user
  2. import (
  3. "github.com/0xJacky/Nginx-UI/internal/user"
  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/uozi-tech/cosy"
  9. "golang.org/x/crypto/bcrypt"
  10. )
  11. func encryptPassword(ctx *cosy.Ctx[model.User]) {
  12. if ctx.Payload["password"] == nil {
  13. return
  14. }
  15. pwd := ctx.Payload["password"].(string)
  16. if pwd != "" {
  17. pwdBytes, err := bcrypt.GenerateFromPassword([]byte(pwd), bcrypt.DefaultCost)
  18. if err != nil {
  19. ctx.AbortWithError(err)
  20. return
  21. }
  22. ctx.Model.Password = string(pwdBytes)
  23. } else {
  24. delete(ctx.Payload, "password")
  25. }
  26. }
  27. func InitManageUserRouter(g *gin.RouterGroup) {
  28. c := cosy.Api[model.User]("users")
  29. c.CreateHook(func(c *cosy.Ctx[model.User]) {
  30. c.BeforeDecodeHook(encryptPassword)
  31. })
  32. c.ModifyHook(func(c *cosy.Ctx[model.User]) {
  33. c.BeforeDecodeHook(func(ctx *cosy.Ctx[model.User]) {
  34. if settings.NodeSettings.Demo && ctx.ID == 1 {
  35. ctx.AbortWithError(user.ErrChangeInitUserPwdInDemo)
  36. }
  37. })
  38. c.BeforeDecodeHook(encryptPassword)
  39. c.ExecutedHook(func(ctx *cosy.Ctx[model.User]) {
  40. if ctx.Payload["password"] != "" {
  41. a := query.AuthToken
  42. _, _ = a.Where(a.UserID.Eq(ctx.ID)).Delete()
  43. }
  44. })
  45. })
  46. c.DestroyHook(func(c *cosy.Ctx[model.User]) {
  47. c.BeforeExecuteHook(func(ctx *cosy.Ctx[model.User]) {
  48. if ctx.ID == 1 {
  49. ctx.AbortWithError(user.ErrCannotRemoveInitUser)
  50. }
  51. })
  52. })
  53. c.InitRouter(g)
  54. }