worker.go 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. package admin
  2. import (
  3. "Wine-Server/utils"
  4. "Wine-Server/utils/tables"
  5. "github.com/gorilla/websocket"
  6. )
  7. func Query(conn *websocket.Conn, manager *tables.ManagerTable, data any) {
  8. if !manager.Super {
  9. _ = conn.WriteJSON(utils.WsEvent("superRoleAdminQueryRes", utils.Fail("权限不足")))
  10. return
  11. }
  12. var param queryParam
  13. err := utils.AnyTrans(data, &param)
  14. if err != nil {
  15. utils.Logger.Println(err)
  16. _ = conn.WriteJSON(utils.WsEvent("superRoleAdminQueryRes", utils.Fail("参数错误")))
  17. return
  18. }
  19. total, men, err := tables.ManagerQueryForAdmin(param.Cond, param.Limit, param.Page)
  20. if err != nil {
  21. utils.Logger.Println(err)
  22. _ = conn.WriteJSON(utils.WsEvent("superRoleAdminQueryRes", utils.Fail("查询管理员失败")))
  23. return
  24. }
  25. _ = conn.WriteJSON(utils.WsEvent(
  26. "superRoleAdminQueryRes",
  27. utils.Success(utils.JsonType{"total": total, "list": men}),
  28. ))
  29. }
  30. func Update(conn *websocket.Conn, manager *tables.ManagerTable, data any) {
  31. if !manager.Super {
  32. _ = conn.WriteJSON(utils.WsEvent("superRoleAdminUpdateRes", utils.Fail("权限不足")))
  33. return
  34. }
  35. var param updateParam
  36. err := utils.AnyTrans(data, &param)
  37. if err != nil {
  38. _ = conn.WriteJSON(utils.WsEvent("superRoleAdminUpdateRes", utils.Fail("参数错误")))
  39. return
  40. }
  41. man := &tables.ManagerTable{Id: param.Id}
  42. err = man.Get()
  43. if err != nil {
  44. _ = conn.WriteJSON(utils.WsEvent("superRoleAdminUpdateRes", utils.Fail("管理员不存在")))
  45. return
  46. }
  47. if param.Password != "" {
  48. password, err := utils.Decrypt(param.Password)
  49. if err != nil {
  50. _ = conn.WriteJSON(utils.WsEvent("superRoleAdminUpdateRes", utils.Fail("解密失败")))
  51. return
  52. }
  53. man.Password = utils.HashPassword(password)
  54. }
  55. man.Name, man.Account = param.Name, param.Account
  56. err = man.UpdateSelf()
  57. if err != nil {
  58. _ = conn.WriteJSON(utils.WsEvent("superRoleAdminUpdateRes", utils.Fail("更新失败")))
  59. return
  60. }
  61. _ = conn.WriteJSON(utils.WsEvent("superRoleAdminUpdateRes", utils.Success(nil)))
  62. // TODO: inform admin login expired
  63. }
  64. func Delete(conn *websocket.Conn, manager *tables.ManagerTable, data any) {
  65. if !manager.Super {
  66. _ = conn.WriteJSON(utils.WsEvent("superRoleAdminDeleteRes", utils.Fail("权限不足")))
  67. return
  68. }
  69. var ids []string
  70. err := utils.AnyTrans(data, &ids)
  71. if err != nil {
  72. utils.Logger.Println(err)
  73. _ = conn.WriteJSON(utils.WsEvent("superRoleAdminDeleteRes", utils.Fail("参数错误")))
  74. return
  75. }
  76. err = tables.ManagersDelete(ids)
  77. if err != nil {
  78. utils.Logger.Println(err)
  79. _ = conn.WriteJSON(utils.WsEvent("superRoleAdminDeleteRes", utils.Fail("删除失败")))
  80. return
  81. }
  82. _ = conn.WriteJSON(utils.WsEvent("superRoleAdminDeleteRes", utils.Success(nil)))
  83. }
  84. func Add(conn *websocket.Conn, manager *tables.ManagerTable, data any) {
  85. if !manager.Super {
  86. _ = conn.WriteJSON(utils.WsEvent("superRoleAdminAddRes", utils.Fail("权限不足")))
  87. return
  88. }
  89. var param addParam
  90. err := utils.AnyTrans(data, &param)
  91. if err != nil {
  92. utils.Logger.Println(err)
  93. _ = conn.WriteJSON(utils.WsEvent("superRoleAdminAddRes", utils.Fail("参数错误")))
  94. return
  95. }
  96. if param.Name == "" || param.Account == "" || param.Password == "" {
  97. _ = conn.WriteJSON(utils.WsEvent("superRoleAdminAddRes", utils.Fail("数据不可为空")))
  98. return
  99. }
  100. var password string
  101. password, err = utils.Decrypt(param.Password)
  102. if err != nil {
  103. utils.Logger.Println(err)
  104. _ = conn.WriteJSON(utils.WsEvent("superRoleAdminAddRes", utils.Fail("解密失败")))
  105. return
  106. }
  107. id := utils.RandomString(16, utils.AlphaNumPatten)
  108. man := &tables.ManagerTable{Id: id, Name: param.Name, Account: param.Account, Password: utils.HashPassword(password)}
  109. err = man.Insert()
  110. if err != nil {
  111. utils.Logger.Println(err)
  112. _ = conn.WriteJSON(utils.WsEvent("superRoleAdminAddRes", utils.Fail("添加失败")))
  113. return
  114. }
  115. _ = conn.WriteJSON(utils.WsEvent("superRoleAdminAddRes", utils.Success(nil)))
  116. }