send_text_msg_logic.go 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. package Wxhook
  2. import (
  3. "context"
  4. "github.com/suyuan32/simple-admin-common/enum/errorcode"
  5. "github.com/suyuan32/simple-admin-common/msg/errormsg"
  6. "wechat-api/ent/predicate"
  7. "wechat-api/ent/wx"
  8. "wechat-api/hook"
  9. "wechat-api/internal/svc"
  10. "wechat-api/internal/types"
  11. "github.com/zeromicro/go-zero/core/logx"
  12. )
  13. type SendTextMsgLogic struct {
  14. logx.Logger
  15. ctx context.Context
  16. svcCtx *svc.ServiceContext
  17. }
  18. func NewSendTextMsgLogic(ctx context.Context, svcCtx *svc.ServiceContext) *SendTextMsgLogic {
  19. return &SendTextMsgLogic{
  20. Logger: logx.WithContext(ctx),
  21. ctx: ctx,
  22. svcCtx: svcCtx}
  23. }
  24. func (l *SendTextMsgLogic) SendTextMsg(req *types.SendTextMsgReq) (resp *types.BaseMsgResp, err error) {
  25. //根据wx实体的wxid查询
  26. var predicates []predicate.Wx
  27. if req.WxWxid != nil {
  28. predicates = append(predicates, wx.WxidContains(*req.WxWxid))
  29. }
  30. wxInfo, err := l.svcCtx.DB.Wx.Query().Where(predicates...).Only(l.ctx)
  31. //根据wx实体的主键ID查询
  32. //wxInfo, err := l.svcCtx.DB.Wx.Get(l.ctx, *req.AgentWxId)
  33. l.Infof("wxInfo = %v", wxInfo)
  34. if err != nil {
  35. l.Error("查询微信信息失败", err)
  36. return
  37. }
  38. privateIP := ""
  39. adminPort := ""
  40. port := ""
  41. if wxInfo.ServerID != 0 {
  42. serverInfo, err := l.svcCtx.DB.Server.Get(l.ctx, wxInfo.ServerID)
  43. if err != nil {
  44. l.Error("查询服务器信息失败", err)
  45. return nil, err
  46. }
  47. privateIP = serverInfo.PrivateIP
  48. adminPort = serverInfo.AdminPort
  49. port = wxInfo.Port
  50. }
  51. hookClient := hook.NewHook(privateIP, adminPort, port)
  52. err = hookClient.SendTextMsg(*req.Wxid, *req.Msg, wxInfo.Wxid)
  53. if err != nil {
  54. l.Error("发送微信文本消息失败", err)
  55. return nil, err
  56. }
  57. resp = &types.BaseMsgResp{
  58. Msg: errormsg.Success,
  59. Code: errorcode.OK,
  60. }
  61. return resp, nil
  62. }