create_wx_logic.go 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  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. server, err := l.svcCtx.DB.Server.Get(l.ctx, *req.ServerId)
  28. if err != nil {
  29. l.Error("获取服务器信息失败", err)
  30. return nil, err
  31. }
  32. hook := hook.NewHook(server.PrivateIP, server.AdminPort, *req.Port)
  33. portOccupied, err := hook.GetPortOccupiedInfo(*req.Port)
  34. if err != nil {
  35. l.Error("获取端口占用信息失败", err)
  36. return nil, err
  37. }
  38. if portOccupied.Occupied != "1" {
  39. l.Error("端口未使用,请重新扫码登陆", err)
  40. return nil, err
  41. }
  42. loginStatus, err := hook.IsLoginStatus()
  43. if err != nil {
  44. return nil, err
  45. }
  46. if loginStatus.Onlinestatus == "3" {
  47. selfInfo, err := hook.GetSelfLoginInfo()
  48. if err != nil {
  49. return nil, err
  50. }
  51. wxInfo, err := l.svcCtx.DB.Wx.Query().Where(wx.ServerIDEQ(server.ID)).Where(wx.PortEQ(*req.Port)).Limit(1).Only(l.ctx)
  52. if err != nil && !ent.IsNotFound(err) {
  53. l.Error("查询微信信息失败", err)
  54. return nil, err
  55. }
  56. var dbErr error
  57. if ent.IsNotFound(err) {
  58. if req.Callback != nil && *req.Callback != "" {
  59. _ = hook.ConfigureMsgRecive("1", *req.Callback)
  60. }
  61. _, dbErr = l.svcCtx.DB.Wx.Create().
  62. SetNotNilServerID(req.ServerId).
  63. SetNotNilPort(req.Port).
  64. SetNotNilProcessID(&selfInfo.ProcessID).
  65. SetNotNilCallback(req.Callback).
  66. SetNotNilWxid(&selfInfo.Wxid).
  67. SetNotNilAccount(&selfInfo.Account).
  68. SetNotNilNickname(&selfInfo.Nickname).
  69. SetNotNilTel(&selfInfo.Tel).
  70. SetNotNilHeadBig(&selfInfo.HeadBig).
  71. SetStatus(1).
  72. Save(l.ctx)
  73. } else {
  74. if req.Callback != nil && *req.Callback != "" && wxInfo.Callback != *req.Callback {
  75. _ = hook.ConfigureMsgRecive("1", *req.Callback)
  76. }
  77. _, dbErr = l.svcCtx.DB.Wx.UpdateOneID(wxInfo.ID).
  78. SetNotNilProcessID(&selfInfo.ProcessID).
  79. SetNotNilCallback(req.Callback).
  80. SetNotNilWxid(&selfInfo.Wxid).
  81. SetNotNilAccount(&selfInfo.Account).
  82. SetNotNilNickname(&selfInfo.Nickname).
  83. SetNotNilTel(&selfInfo.Tel).
  84. SetNotNilHeadBig(&selfInfo.HeadBig).
  85. SetStatus(1).
  86. Save(l.ctx)
  87. }
  88. if dbErr != nil {
  89. return nil, dberrorhandler.DefaultEntError(l.Logger, dbErr, req)
  90. }
  91. } else {
  92. l.Error("微信未登录", "loginStatus", loginStatus)
  93. return nil, errorx.NewDefaultError("微信未登陆,当前登陆状态:" + loginStatus.Onlinestatus + "," + loginStatus.Msg)
  94. }
  95. return &types.BaseMsgResp{Msg: errormsg.Success}, nil
  96. }