create_wx_logic.go 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. package Wx
  2. import (
  3. "context"
  4. "errors"
  5. "github.com/zeromicro/go-zero/core/errorx"
  6. "wechat-api/ent"
  7. agentModel "wechat-api/ent/agent"
  8. "wechat-api/ent/wx"
  9. "wechat-api/hook"
  10. "wechat-api/internal/utils/dberrorhandler"
  11. "github.com/suyuan32/simple-admin-common/msg/errormsg"
  12. "wechat-api/internal/svc"
  13. "wechat-api/internal/types"
  14. "github.com/zeromicro/go-zero/core/logx"
  15. )
  16. type CreateWxLogic struct {
  17. ctx context.Context
  18. svcCtx *svc.ServiceContext
  19. logx.Logger
  20. }
  21. func NewCreateWxLogic(ctx context.Context, svcCtx *svc.ServiceContext) *CreateWxLogic {
  22. return &CreateWxLogic{
  23. ctx: ctx,
  24. svcCtx: svcCtx,
  25. Logger: logx.WithContext(ctx),
  26. }
  27. }
  28. func (l *CreateWxLogic) CreateWx(req *types.WxInfo) (*types.BaseMsgResp, error) {
  29. organizationId := l.ctx.Value("organizationId").(uint64)
  30. server, err := l.svcCtx.DB.Server.Get(l.ctx, *req.ServerId)
  31. if err != nil {
  32. l.Error("获取服务器信息失败", err)
  33. return nil, err
  34. }
  35. hook := hook.NewHook(server.PrivateIP, server.AdminPort, *req.Port)
  36. portOccupied, err := hook.GetPortOccupiedInfo(*req.Port)
  37. if err != nil {
  38. l.Error("获取端口占用信息失败", err)
  39. return nil, err
  40. }
  41. if portOccupied.Occupied != "1" {
  42. l.Error("端口未使用,请重新扫码登陆", err)
  43. return nil, err
  44. }
  45. // 判断所选模式是否可用
  46. if req.AgentId != nil {
  47. agent, err := l.svcCtx.DB.Agent.Query().Where(agentModel.Status(1), agentModel.ID(*req.AgentId)).First(l.ctx)
  48. if err != nil && ent.IsNotFound(err) || agent == nil {
  49. return nil, errors.New("所选模式不存在或者已被禁用,请选择其他模式")
  50. }
  51. }
  52. loginStatus, err := hook.IsLoginStatus()
  53. if err != nil {
  54. return nil, err
  55. }
  56. if loginStatus.Onlinestatus == "3" {
  57. selfInfo, err := hook.GetSelfLoginInfo()
  58. if err != nil {
  59. return nil, err
  60. }
  61. wxInfo, err := l.svcCtx.DB.Wx.Query().Where(wx.ServerIDEQ(server.ID)).Where(wx.PortEQ(*req.Port)).Limit(1).Only(l.ctx)
  62. if err != nil && !ent.IsNotFound(err) {
  63. l.Error("查询微信信息失败", err)
  64. return nil, err
  65. }
  66. var dbErr error
  67. if ent.IsNotFound(err) {
  68. if req.Callback != nil && *req.Callback != "" {
  69. _ = hook.ConfigureMsgRecive("1", *req.Callback)
  70. }
  71. _, dbErr = l.svcCtx.DB.Wx.Create().
  72. SetNotNilServerID(req.ServerId).
  73. SetNotNilPort(req.Port).
  74. SetNotNilProcessID(&selfInfo.ProcessID).
  75. SetNotNilCallback(req.Callback).
  76. SetNotNilWxid(&selfInfo.Wxid).
  77. SetNotNilAccount(&selfInfo.Account).
  78. SetNotNilNickname(&selfInfo.Nickname).
  79. SetNotNilTel(&selfInfo.Tel).
  80. SetNotNilHeadBig(&selfInfo.HeadBig).
  81. SetStatus(1).
  82. SetOrganizationID(organizationId).
  83. SetNotNilAgentID(req.AgentId).
  84. Save(l.ctx)
  85. } else {
  86. if req.Callback != nil && *req.Callback != "" {
  87. _ = hook.ConfigureMsgRecive("1", *req.Callback)
  88. }
  89. _, dbErr = l.svcCtx.DB.Wx.UpdateOneID(wxInfo.ID).
  90. SetNotNilProcessID(&selfInfo.ProcessID).
  91. SetNotNilCallback(req.Callback).
  92. SetNotNilWxid(&selfInfo.Wxid).
  93. SetNotNilAccount(&selfInfo.Account).
  94. SetNotNilNickname(&selfInfo.Nickname).
  95. SetNotNilTel(&selfInfo.Tel).
  96. SetNotNilHeadBig(&selfInfo.HeadBig).
  97. SetStatus(1).
  98. Save(l.ctx)
  99. }
  100. if dbErr != nil {
  101. return nil, dberrorhandler.DefaultEntError(l.Logger, dbErr, req)
  102. }
  103. } else {
  104. l.Error("微信未登录", "loginStatus", loginStatus)
  105. return nil, errorx.NewDefaultError("微信未登陆,当前登陆状态:" + loginStatus.Onlinestatus + "," + loginStatus.Msg)
  106. }
  107. return &types.BaseMsgResp{Msg: errormsg.Success}, nil
  108. }