create_wx_logic.go 3.0 KB

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