2024-08-28 09:09:01 +00:00
|
|
|
package commentservicelogic
|
|
|
|
|
|
|
|
import (
|
2024-08-28 14:29:42 +00:00
|
|
|
"app-cloudep-tweeting-service/gen_result/pb/tweeting"
|
2024-08-30 07:08:43 +00:00
|
|
|
"app-cloudep-tweeting-service/internal/domain"
|
|
|
|
model "app-cloudep-tweeting-service/internal/model/mongo"
|
2024-08-28 14:29:42 +00:00
|
|
|
"app-cloudep-tweeting-service/internal/svc"
|
2024-08-30 07:08:43 +00:00
|
|
|
"context"
|
|
|
|
"errors"
|
|
|
|
|
|
|
|
ers "code.30cm.net/digimon/library-go/errs"
|
2024-08-28 09:09:01 +00:00
|
|
|
|
|
|
|
"github.com/zeromicro/go-zero/core/logx"
|
|
|
|
)
|
|
|
|
|
|
|
|
type NewCommentLogic struct {
|
|
|
|
ctx context.Context
|
|
|
|
svcCtx *svc.ServiceContext
|
|
|
|
logx.Logger
|
|
|
|
}
|
|
|
|
|
|
|
|
func NewNewCommentLogic(ctx context.Context, svcCtx *svc.ServiceContext) *NewCommentLogic {
|
|
|
|
return &NewCommentLogic{
|
|
|
|
ctx: ctx,
|
|
|
|
svcCtx: svcCtx,
|
|
|
|
Logger: logx.WithContext(ctx),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-08-30 07:08:43 +00:00
|
|
|
// 輸入的定義 -> 檢查用
|
|
|
|
type newCommentReq struct {
|
|
|
|
UID string `json:"uid" validate:"required"`
|
|
|
|
Content string `json:"content" validate:"required,lte=500"` // 貼文限制 500 字內
|
|
|
|
PostID string `json:"post_id" validate:"required"`
|
|
|
|
}
|
|
|
|
|
2024-08-28 09:09:01 +00:00
|
|
|
// NewComment 發表評論
|
2024-08-30 07:08:43 +00:00
|
|
|
func (l *NewCommentLogic) NewComment(in *tweeting.CommentPostReq) (*tweeting.CommentPostResp, error) {
|
|
|
|
// 驗證資料
|
|
|
|
if err := l.svcCtx.Validate.ValidateAll(&newCommentReq{
|
|
|
|
UID: in.GetUid(),
|
|
|
|
Content: in.GetContent(),
|
|
|
|
PostID: in.GetPostId(),
|
|
|
|
}); err != nil {
|
|
|
|
// 錯誤代碼 05-011-00
|
|
|
|
return nil, ers.InvalidFormat(err.Error())
|
|
|
|
}
|
|
|
|
|
|
|
|
// 檢查是否有這個文章
|
|
|
|
_, err := l.svcCtx.PostModel.FindOne(l.ctx, in.GetPostId())
|
|
|
|
if err != nil {
|
|
|
|
if errors.Is(model.ErrNotFound, err) {
|
|
|
|
// 錯誤代碼 05-031-00
|
|
|
|
return nil, ers.ResourceNotFound("failed to find post: ", in.GetPostId())
|
|
|
|
}
|
|
|
|
// 錯誤代碼 05-021-10
|
|
|
|
e := domain.CommentErrorL(
|
|
|
|
domain.CommentFoundErrorCode,
|
|
|
|
logx.WithContext(l.ctx),
|
|
|
|
[]logx.LogField{
|
|
|
|
{Key: "req", Value: in},
|
|
|
|
{Key: "func", Value: "PostModel.FindOne"},
|
|
|
|
{Key: "err", Value: err},
|
|
|
|
},
|
|
|
|
"failed to find post:", in.GetPostId()).Wrap(err)
|
|
|
|
|
|
|
|
return nil, e
|
|
|
|
}
|
|
|
|
|
|
|
|
data := &model.Comment{
|
|
|
|
PostID: in.GetPostId(),
|
|
|
|
UID: in.GetUid(),
|
|
|
|
Content: in.GetContent(),
|
|
|
|
LikeCount: 0,
|
|
|
|
DisLikeCount: 0,
|
|
|
|
}
|
|
|
|
err = l.svcCtx.CommentModel.Insert(l.ctx, data)
|
|
|
|
if err != nil {
|
|
|
|
// 錯誤代碼 05-021-11
|
|
|
|
e := domain.CommentErrorL(
|
|
|
|
domain.CommentInsertErrorCode,
|
|
|
|
logx.WithContext(l.ctx),
|
|
|
|
[]logx.LogField{
|
|
|
|
{Key: "req", Value: in},
|
|
|
|
{Key: "func", Value: "CommentModel.Insert"},
|
|
|
|
{Key: "err", Value: err},
|
|
|
|
},
|
|
|
|
"failed to insert comment:", in.GetPostId()).Wrap(err)
|
|
|
|
|
|
|
|
return nil, e
|
|
|
|
}
|
2024-08-28 09:09:01 +00:00
|
|
|
|
2024-08-30 07:08:43 +00:00
|
|
|
return &tweeting.CommentPostResp{
|
|
|
|
CommentId: data.ID.Hex(),
|
|
|
|
}, nil
|
2024-08-28 09:09:01 +00:00
|
|
|
}
|