get_wx_list_logic.go 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202
  1. package Wx
  2. import (
  3. "context"
  4. "github.com/suyuan32/simple-admin-core/rpc/types/core"
  5. "wechat-api/ent"
  6. "wechat-api/ent/predicate"
  7. "wechat-api/ent/wx"
  8. "wechat-api/hook"
  9. "wechat-api/internal/svc"
  10. "wechat-api/internal/types"
  11. "wechat-api/internal/utils/dberrorhandler"
  12. "github.com/suyuan32/simple-admin-common/msg/errormsg"
  13. "github.com/suyuan32/simple-admin-common/utils/pointy"
  14. "github.com/zeromicro/go-zero/core/logx"
  15. )
  16. type GetWxListLogic struct {
  17. ctx context.Context
  18. svcCtx *svc.ServiceContext
  19. logx.Logger
  20. }
  21. func NewGetWxListLogic(ctx context.Context, svcCtx *svc.ServiceContext) *GetWxListLogic {
  22. return &GetWxListLogic{
  23. ctx: ctx,
  24. svcCtx: svcCtx,
  25. Logger: logx.WithContext(ctx),
  26. }
  27. }
  28. func (l *GetWxListLogic) GetWxList(req *types.WxListReq) (*types.WxListResp, error) {
  29. organizationId := l.ctx.Value("organizationId").(uint64)
  30. isAdmin := l.ctx.Value("isAdmin").(bool)
  31. servers, err := l.svcCtx.DB.Server.Query().All(l.ctx)
  32. serverSet := make(map[uint64]*ent.Server, len(servers))
  33. serverSet[0] = &ent.Server{
  34. ID: 0,
  35. Name: "工作手机",
  36. Status: 1,
  37. }
  38. for _, s := range servers {
  39. serverSet[s.ID] = s
  40. }
  41. var predicates []predicate.Wx
  42. if !isAdmin {
  43. predicates = append(predicates, wx.OrganizationIDEQ(organizationId))
  44. } else {
  45. if req.OrganizationId != nil {
  46. predicates = append(predicates, wx.OrganizationIDEQ(*req.OrganizationId))
  47. }
  48. if req.OrganizationName != nil {
  49. departmentList, _ := l.svcCtx.CoreRpc.GetDepartmentList(l.ctx, &core.DepartmentListReq{Name: req.OrganizationName})
  50. organizationIds := make([]uint64, 0)
  51. for _, department := range departmentList.Data {
  52. organizationIds = append(organizationIds, *department.Id)
  53. }
  54. predicates = append(predicates, wx.OrganizationIDIn(organizationIds...))
  55. }
  56. }
  57. if req.ServerId != nil {
  58. predicates = append(predicates, wx.ServerIDEQ(*req.ServerId))
  59. }
  60. if req.Port != nil {
  61. predicates = append(predicates, wx.PortContains(*req.Port))
  62. }
  63. if req.ProcessId != nil {
  64. predicates = append(predicates, wx.ProcessIDContains(*req.ProcessId))
  65. }
  66. if req.Callback != nil {
  67. predicates = append(predicates, wx.CallbackContains(*req.Callback))
  68. }
  69. data, err := l.svcCtx.DB.Wx.Query().Where(predicates...).Order(ent.Desc(wx.FieldOrganizationID)).WithAgent().WithServer().Page(l.ctx, req.Page, req.PageSize)
  70. if err != nil {
  71. return nil, dberrorhandler.DefaultEntError(l.Logger, err, req)
  72. }
  73. resp := &types.WxListResp{}
  74. resp.Msg = errormsg.Success
  75. resp.Data.Total = data.PageDetails.Total
  76. for _, v := range data.List {
  77. // 创建 hookClient 客户端
  78. serverInfo := serverSet[v.ServerID]
  79. var loginStatus uint8 = 0
  80. hookClient := hook.NewHook(serverInfo.PrivateIP, serverInfo.AdminPort, v.Port)
  81. if v.ServerID > 0 {
  82. if serverInfo.Status == 1 {
  83. // 获取登录状态
  84. loginInfo, err := hookClient.IsLoginStatus()
  85. if err != nil {
  86. l.Error("退出登录失败", err)
  87. } else {
  88. if loginInfo.Onlinestatus == "3" {
  89. loginStatus = 1
  90. }
  91. }
  92. }
  93. } else {
  94. loginStatus = v.Status
  95. }
  96. processID := v.ProcessID
  97. wxid := v.Wxid
  98. account := v.Account
  99. nickname := v.Nickname
  100. tel := v.Tel
  101. headBig := v.HeadBig
  102. departmentInfo, err := l.svcCtx.CoreRpc.GetDepartmentById(l.ctx, &core.IDReq{Id: v.OrganizationID})
  103. if err != nil {
  104. l.Error("获取部门信息失败", err)
  105. }
  106. if v.ServerID > 0 {
  107. if loginStatus == 1 {
  108. // 如果处于登录状态,获取登录信息
  109. wxInfo, _ := hookClient.GetSelfLoginInfo()
  110. if err != nil {
  111. l.Error("获取登录信息失败", err)
  112. } else {
  113. if wxid != wxInfo.Wxid {
  114. l.svcCtx.Rds.HDel(l.ctx, "wx_info", wxid)
  115. l.svcCtx.Rds.HDel(l.ctx, "wx_info", wxInfo.Wxid)
  116. l.svcCtx.Rds.HDel(l.ctx, "crontask_wx_server_info", wxid)
  117. l.svcCtx.Rds.HDel(l.ctx, "crontask_wx_server_info", wxInfo.Wxid)
  118. }
  119. processID = wxInfo.ProcessID
  120. wxid = wxInfo.Wxid
  121. account = wxInfo.Account
  122. nickname = wxInfo.Nickname
  123. tel = wxInfo.Tel
  124. headBig = wxInfo.HeadBig
  125. _ = l.svcCtx.DB.Wx.UpdateOneID(v.ID).
  126. SetNotNilStatus(&loginStatus).
  127. SetNotNilProcessID(&wxInfo.ProcessID).
  128. SetNotNilWxid(&wxInfo.Wxid).
  129. SetNotNilAccount(&wxInfo.Account).
  130. SetNotNilNickname(&wxInfo.Nickname).
  131. SetNotNilTel(&wxInfo.Tel).
  132. SetNotNilHeadBig(&wxInfo.HeadBig).
  133. Exec(l.ctx)
  134. }
  135. } else {
  136. if loginStatus != v.Status {
  137. _ = l.svcCtx.DB.Wx.UpdateOneID(v.ID).
  138. SetNotNilStatus(&loginStatus).
  139. Exec(l.ctx)
  140. }
  141. }
  142. }
  143. var agent types.AgentInfo
  144. if v.Edges.Agent != nil {
  145. agent = types.AgentInfo{
  146. BaseIDInfo: types.BaseIDInfo{
  147. Id: &v.AgentID,
  148. CreatedAt: pointy.GetPointer(v.Edges.Agent.CreatedAt.UnixMilli()),
  149. UpdatedAt: pointy.GetPointer(v.Edges.Agent.UpdatedAt.UnixMilli()),
  150. },
  151. Name: &v.Edges.Agent.Name,
  152. Role: &v.Edges.Agent.Role,
  153. Status: &v.Edges.Agent.Status,
  154. Background: &v.Edges.Agent.Background,
  155. Examples: &v.Edges.Agent.Examples,
  156. }
  157. }
  158. resp.Data.Data = append(resp.Data.Data,
  159. types.WxInfo{
  160. BaseIDInfo: types.BaseIDInfo{
  161. Id: &v.ID,
  162. CreatedAt: pointy.GetPointer(v.CreatedAt.UnixMilli()),
  163. UpdatedAt: pointy.GetPointer(v.UpdatedAt.UnixMilli()),
  164. },
  165. Status: &loginStatus,
  166. ServerId: &v.ServerID,
  167. ServerName: &serverInfo.Name,
  168. Port: &v.Port,
  169. ProcessId: &processID,
  170. Callback: &v.Callback,
  171. Wxid: &wxid,
  172. Account: &account,
  173. Nickname: &nickname,
  174. Tel: &tel,
  175. HeadBig: &headBig,
  176. OrganizationId: &v.OrganizationID,
  177. OrganizationName: departmentInfo.Name,
  178. AgentId: &v.AgentID,
  179. AgentInfo: &agent,
  180. ApiBase: &v.APIBase,
  181. ApiKey: &v.APIKey,
  182. })
  183. }
  184. return resp, nil
  185. }