create_wx_logic.go 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  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. agent, err := l.svcCtx.DB.Agent.Query().Where(agentModel.Status(1), agentModel.ID(*req.AgentId)).First(l.ctx)
  47. if err != nil && ent.IsNotFound(err) || agent == nil {
  48. return nil, errors.New("所选模式不存在或者已被禁用,请选择其他模式")
  49. }
  50. loginStatus, err := hook.IsLoginStatus()
  51. if err != nil {
  52. return nil, err
  53. }
  54. if loginStatus.Onlinestatus == "3" {
  55. selfInfo, err := hook.GetSelfLoginInfo()
  56. if err != nil {
  57. return nil, err
  58. }
  59. wxInfo, err := l.svcCtx.DB.Wx.Query().Where(wx.ServerIDEQ(server.ID)).Where(wx.PortEQ(*req.Port)).Limit(1).Only(l.ctx)
  60. if err != nil && !ent.IsNotFound(err) {
  61. l.Error("查询微信信息失败", err)
  62. return nil, err
  63. }
  64. var dbErr error
  65. if ent.IsNotFound(err) {
  66. if req.Callback != nil && *req.Callback != "" {
  67. _ = hook.ConfigureMsgRecive("1", *req.Callback)
  68. }
  69. _, dbErr = l.svcCtx.DB.Wx.Create().
  70. SetNotNilServerID(req.ServerId).
  71. SetNotNilPort(req.Port).
  72. SetNotNilProcessID(&selfInfo.ProcessID).
  73. SetNotNilCallback(req.Callback).
  74. SetNotNilWxid(&selfInfo.Wxid).
  75. SetNotNilAccount(&selfInfo.Account).
  76. SetNotNilNickname(&selfInfo.Nickname).
  77. SetNotNilTel(&selfInfo.Tel).
  78. SetNotNilHeadBig(&selfInfo.HeadBig).
  79. SetStatus(1).
  80. SetOrganizationID(organizationId).
  81. SetAgentID(*req.AgentId).
  82. Save(l.ctx)
  83. } else {
  84. if req.Callback != nil && *req.Callback != "" {
  85. _ = hook.ConfigureMsgRecive("1", *req.Callback)
  86. }
  87. _, dbErr = l.svcCtx.DB.Wx.UpdateOneID(wxInfo.ID).
  88. SetNotNilProcessID(&selfInfo.ProcessID).
  89. SetNotNilCallback(req.Callback).
  90. SetNotNilWxid(&selfInfo.Wxid).
  91. SetNotNilAccount(&selfInfo.Account).
  92. SetNotNilNickname(&selfInfo.Nickname).
  93. SetNotNilTel(&selfInfo.Tel).
  94. SetNotNilHeadBig(&selfInfo.HeadBig).
  95. SetStatus(1).
  96. Save(l.ctx)
  97. }
  98. if dbErr != nil {
  99. return nil, dberrorhandler.DefaultEntError(l.Logger, dbErr, req)
  100. }
  101. } else {
  102. l.Error("微信未登录", "loginStatus", loginStatus)
  103. return nil, errorx.NewDefaultError("微信未登陆,当前登陆状态:" + loginStatus.Onlinestatus + "," + loginStatus.Msg)
  104. }
  105. return &types.BaseMsgResp{Msg: errormsg.Success}, nil
  106. }