get_wx_list_logic.go 4.9 KB

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