messageaddlogic.go 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. package logic
  2. import (
  3. "bp.jydev.jianyu360.cn/SocialPlatform/messageCenter/api/messagecenter/util"
  4. "context"
  5. "net/http"
  6. quitl "app.yhyue.com/moapp/jybase/common"
  7. "app.yhyue.com/moapp/jybase/encrypt"
  8. "app.yhyue.com/moapp/jybase/fsw"
  9. "bp.jydev.jianyu360.cn/SocialPlatform/messageCenter/api/messagecenter/internal/svc"
  10. "bp.jydev.jianyu360.cn/SocialPlatform/messageCenter/api/messagecenter/internal/types"
  11. "bp.jydev.jianyu360.cn/SocialPlatform/messageCenter/rpc/messagecenter/messagecenter"
  12. "github.com/microcosm-cc/bluemonday"
  13. "github.com/gogf/gf/v2/util/gconv"
  14. "github.com/zeromicro/go-zero/core/logx"
  15. )
  16. type MessageAddLogic struct {
  17. logx.Logger
  18. ctx context.Context
  19. svcCtx *svc.ServiceContext
  20. r *http.Request
  21. }
  22. func NewMessageAddLogic(ctx context.Context, svcCtx *svc.ServiceContext, r *http.Request) *MessageAddLogic {
  23. return &MessageAddLogic{
  24. Logger: logx.WithContext(ctx),
  25. ctx: ctx,
  26. svcCtx: svcCtx,
  27. r: r,
  28. }
  29. }
  30. var (
  31. htmlFilter = bluemonday.NewPolicy()
  32. )
  33. func init() {
  34. htmlFilter.AllowStandardURLs()
  35. htmlFilter.AllowAttrs("href").OnElements("a")
  36. htmlFilter.AllowAttrs("class").OnElements("li")
  37. htmlFilter.AllowAttrs("src").OnElements("img")
  38. }
  39. func (l *MessageAddLogic) MessageAdd(req *types.MessageEntity) (*types.CommonRes, error) {
  40. if req.NewUserId == 0 {
  41. r, err := util.GetTouristInfo(l.r, l.svcCtx.Social, l.ctx)
  42. if err != nil || r.BaseUserId == 0 {
  43. return nil, err
  44. }
  45. req.NewUserId = r.BaseUserId
  46. req.PositionId = r.BaseUserId
  47. }
  48. receiverIds := []int64{}
  49. for _, v := range req.ReceiverIds {
  50. receiverIds = append(receiverIds, gconv.Int64(encrypt.SE.Decode4Hex(v)))
  51. }
  52. groupIds := []int64{}
  53. for _, v := range req.GroupIds {
  54. groupIds = append(groupIds, gconv.Int64(encrypt.SE.Decode4Hex(v)))
  55. }
  56. sendId := quitl.Int64All(encrypt.SE.Decode4Hex(req.SendId))
  57. if req.SendId == "" {
  58. sendId = req.PositionId
  59. }
  60. typ := func(typ int64) int64 {
  61. if typ == 5 || typ == 6 {
  62. return 1
  63. }
  64. return typ
  65. }(req.Type)
  66. resp, err := l.svcCtx.Message.SaveMessage(l.ctx, &messagecenter.MessageEntity{
  67. OwnType: req.OwnType,
  68. Title: req.Title,
  69. SendId: sendId,
  70. Content: quitl.ObjToString(quitl.If(req.Type == 3 || req.Type == 4 || req.Type == 5, fsw.Repl(req.Content), htmlFilter.Sanitize(fsw.Repl(req.Content)))),
  71. Item: req.Item,
  72. Type: typ,
  73. Link: req.Link,
  74. Appid: req.Appid,
  75. ItemType: req.ItemType,
  76. ReceiveId: quitl.Int64All(encrypt.SE.Decode4Hex(req.ReceiveId)),
  77. NewUserId: req.NewUserId,
  78. EntUserId: req.EntUserId,
  79. ReceiverIds: receiverIds,
  80. GroupIds: groupIds,
  81. })
  82. if err != nil {
  83. return nil, err
  84. }
  85. return &types.CommonRes{
  86. Error_msg: resp.ErrorMsg,
  87. Error_code: int(resp.ErrorCode),
  88. Data: resp.Data,
  89. }, nil
  90. }