feat: 添加评价微服务,支持密封互评与订单状态联动
This commit is contained in:
@@ -0,0 +1,64 @@
|
||||
package logic
|
||||
|
||||
import (
|
||||
"context"
|
||||
"errors"
|
||||
|
||||
"juwan-backend/app/review/rpc/internal/svc"
|
||||
"juwan-backend/app/review/rpc/pb"
|
||||
"juwan-backend/app/snowflake/rpc/snowflake"
|
||||
|
||||
"github.com/zeromicro/go-zero/core/logx"
|
||||
)
|
||||
|
||||
type AddReviewsLogic struct {
|
||||
ctx context.Context
|
||||
svcCtx *svc.ServiceContext
|
||||
logx.Logger
|
||||
}
|
||||
|
||||
func NewAddReviewsLogic(ctx context.Context, svcCtx *svc.ServiceContext) *AddReviewsLogic {
|
||||
return &AddReviewsLogic{
|
||||
ctx: ctx,
|
||||
svcCtx: svcCtx,
|
||||
Logger: logx.WithContext(ctx),
|
||||
}
|
||||
}
|
||||
|
||||
func (l *AddReviewsLogic) AddReviews(in *pb.AddReviewsReq) (*pb.AddReviewsResp, error) {
|
||||
if in.GetOrderId() <= 0 {
|
||||
return nil, errors.New("orderId is required")
|
||||
}
|
||||
if in.GetFromUserId() <= 0 {
|
||||
return nil, errors.New("fromUserId is required")
|
||||
}
|
||||
if in.GetToUserId() <= 0 {
|
||||
return nil, errors.New("toUserId is required")
|
||||
}
|
||||
if in.GetRating() < 1 || in.GetRating() > 5 {
|
||||
return nil, errors.New("rating must be between 1 and 5")
|
||||
}
|
||||
|
||||
idResp, err := l.svcCtx.Snowflake.NextId(l.ctx, &snowflake.NextIdReq{})
|
||||
if err != nil {
|
||||
return nil, errors.New("create review id failed")
|
||||
}
|
||||
|
||||
created, err := l.svcCtx.ReviewModelRW.Reviews.Create().
|
||||
SetID(idResp.Id).
|
||||
SetOrderID(in.GetOrderId()).
|
||||
SetFromUserID(in.GetFromUserId()).
|
||||
SetFromUserName(in.GetFromUserName()).
|
||||
SetFromUserAvatar(in.GetFromUserAvatar()).
|
||||
SetToUserID(in.GetToUserId()).
|
||||
SetRating(int16(in.GetRating())).
|
||||
SetContent(in.GetContent()).
|
||||
SetSealed(in.GetSealed()).
|
||||
Save(l.ctx)
|
||||
if err != nil {
|
||||
logx.Errorf("addReviews err: %v", err)
|
||||
return nil, errors.New("add review failed")
|
||||
}
|
||||
|
||||
return &pb.AddReviewsResp{Id: created.ID}, nil
|
||||
}
|
||||
@@ -0,0 +1,33 @@
|
||||
package logic
|
||||
|
||||
import (
|
||||
"context"
|
||||
|
||||
"juwan-backend/app/review/rpc/internal/svc"
|
||||
"juwan-backend/app/review/rpc/pb"
|
||||
|
||||
"github.com/zeromicro/go-zero/core/logx"
|
||||
)
|
||||
|
||||
type DelReviewsLogic struct {
|
||||
ctx context.Context
|
||||
svcCtx *svc.ServiceContext
|
||||
logx.Logger
|
||||
}
|
||||
|
||||
func NewDelReviewsLogic(ctx context.Context, svcCtx *svc.ServiceContext) *DelReviewsLogic {
|
||||
return &DelReviewsLogic{
|
||||
ctx: ctx,
|
||||
svcCtx: svcCtx,
|
||||
Logger: logx.WithContext(ctx),
|
||||
}
|
||||
}
|
||||
|
||||
func (l *DelReviewsLogic) DelReviews(in *pb.DelReviewsReq) (*pb.DelReviewsResp, error) {
|
||||
err := l.svcCtx.ReviewModelRW.Reviews.DeleteOneID(in.GetId()).Exec(l.ctx)
|
||||
if err != nil {
|
||||
logx.Errorf("delReviews err: %v", err)
|
||||
return nil, err
|
||||
}
|
||||
return &pb.DelReviewsResp{}, nil
|
||||
}
|
||||
@@ -0,0 +1,32 @@
|
||||
package logic
|
||||
|
||||
import (
|
||||
"context"
|
||||
|
||||
"juwan-backend/app/review/rpc/internal/svc"
|
||||
"juwan-backend/app/review/rpc/pb"
|
||||
|
||||
"github.com/zeromicro/go-zero/core/logx"
|
||||
)
|
||||
|
||||
type GetReviewsByIdLogic struct {
|
||||
ctx context.Context
|
||||
svcCtx *svc.ServiceContext
|
||||
logx.Logger
|
||||
}
|
||||
|
||||
func NewGetReviewsByIdLogic(ctx context.Context, svcCtx *svc.ServiceContext) *GetReviewsByIdLogic {
|
||||
return &GetReviewsByIdLogic{
|
||||
ctx: ctx,
|
||||
svcCtx: svcCtx,
|
||||
Logger: logx.WithContext(ctx),
|
||||
}
|
||||
}
|
||||
|
||||
func (l *GetReviewsByIdLogic) GetReviewsById(in *pb.GetReviewsByIdReq) (*pb.GetReviewsByIdResp, error) {
|
||||
r, err := l.svcCtx.ReviewModelRO.Reviews.Get(l.ctx, in.GetId())
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return &pb.GetReviewsByIdResp{Reviews: entReviewToPb(r)}, nil
|
||||
}
|
||||
@@ -0,0 +1,25 @@
|
||||
package logic
|
||||
|
||||
import (
|
||||
"juwan-backend/app/review/rpc/internal/models"
|
||||
"juwan-backend/app/review/rpc/pb"
|
||||
)
|
||||
|
||||
func entReviewToPb(r *models.Reviews) *pb.Reviews {
|
||||
out := &pb.Reviews{
|
||||
Id: r.ID,
|
||||
OrderId: r.OrderID,
|
||||
FromUserId: r.FromUserID,
|
||||
FromUserName: r.FromUserName,
|
||||
FromUserAvatar: r.FromUserAvatar,
|
||||
ToUserId: r.ToUserID,
|
||||
Rating: int32(r.Rating),
|
||||
Content: r.Content,
|
||||
Sealed: r.Sealed,
|
||||
CreatedAt: r.CreatedAt.Unix(),
|
||||
}
|
||||
if r.UnsealedAt != nil {
|
||||
out.UnsealedAt = r.UnsealedAt.Unix()
|
||||
}
|
||||
return out
|
||||
}
|
||||
@@ -0,0 +1,76 @@
|
||||
package logic
|
||||
|
||||
import (
|
||||
"context"
|
||||
"errors"
|
||||
|
||||
"juwan-backend/app/review/rpc/internal/models/reviews"
|
||||
"juwan-backend/app/review/rpc/internal/svc"
|
||||
"juwan-backend/app/review/rpc/pb"
|
||||
|
||||
"entgo.io/ent/dialect/sql"
|
||||
"github.com/zeromicro/go-zero/core/logx"
|
||||
)
|
||||
|
||||
type SearchReviewsLogic struct {
|
||||
ctx context.Context
|
||||
svcCtx *svc.ServiceContext
|
||||
logx.Logger
|
||||
}
|
||||
|
||||
func NewSearchReviewsLogic(ctx context.Context, svcCtx *svc.ServiceContext) *SearchReviewsLogic {
|
||||
return &SearchReviewsLogic{
|
||||
ctx: ctx,
|
||||
svcCtx: svcCtx,
|
||||
Logger: logx.WithContext(ctx),
|
||||
}
|
||||
}
|
||||
|
||||
func (l *SearchReviewsLogic) SearchReviews(in *pb.SearchReviewsReq) (*pb.SearchReviewsResp, error) {
|
||||
limit := in.GetLimit()
|
||||
if limit <= 0 {
|
||||
limit = 20
|
||||
}
|
||||
if limit > 100 {
|
||||
return nil, errors.New("limit too large")
|
||||
}
|
||||
offset := in.GetOffset()
|
||||
if offset < 0 {
|
||||
offset = 0
|
||||
}
|
||||
|
||||
query := l.svcCtx.ReviewModelRO.Reviews.Query()
|
||||
|
||||
if in.Id != nil {
|
||||
query = query.Where(reviews.IDEQ(in.GetId()))
|
||||
}
|
||||
if in.OrderId != nil {
|
||||
query = query.Where(reviews.OrderIDEQ(in.GetOrderId()))
|
||||
}
|
||||
if in.FromUserId != nil {
|
||||
query = query.Where(reviews.FromUserIDEQ(in.GetFromUserId()))
|
||||
}
|
||||
if in.ToUserId != nil {
|
||||
query = query.Where(reviews.ToUserIDEQ(in.GetToUserId()))
|
||||
}
|
||||
if in.Sealed != nil {
|
||||
query = query.Where(reviews.SealedEQ(in.GetSealed()))
|
||||
}
|
||||
|
||||
list, err := query.
|
||||
Order(reviews.ByCreatedAt(sql.OrderDesc()), reviews.ByID(sql.OrderDesc())).
|
||||
Offset(int(offset)).
|
||||
Limit(int(limit)).
|
||||
All(l.ctx)
|
||||
if err != nil {
|
||||
logx.Errorf("searchReviews err: %v", err)
|
||||
return nil, errors.New("search reviews failed")
|
||||
}
|
||||
|
||||
out := make([]*pb.Reviews, len(list))
|
||||
for i, r := range list {
|
||||
out[i] = entReviewToPb(r)
|
||||
}
|
||||
|
||||
return &pb.SearchReviewsResp{Reviews: out}, nil
|
||||
}
|
||||
@@ -0,0 +1,49 @@
|
||||
package logic
|
||||
|
||||
import (
|
||||
"context"
|
||||
"time"
|
||||
|
||||
"juwan-backend/app/review/rpc/internal/svc"
|
||||
"juwan-backend/app/review/rpc/pb"
|
||||
|
||||
"github.com/zeromicro/go-zero/core/logx"
|
||||
)
|
||||
|
||||
type UpdateReviewsLogic struct {
|
||||
ctx context.Context
|
||||
svcCtx *svc.ServiceContext
|
||||
logx.Logger
|
||||
}
|
||||
|
||||
func NewUpdateReviewsLogic(ctx context.Context, svcCtx *svc.ServiceContext) *UpdateReviewsLogic {
|
||||
return &UpdateReviewsLogic{
|
||||
ctx: ctx,
|
||||
svcCtx: svcCtx,
|
||||
Logger: logx.WithContext(ctx),
|
||||
}
|
||||
}
|
||||
|
||||
func (l *UpdateReviewsLogic) UpdateReviews(in *pb.UpdateReviewsReq) (*pb.UpdateReviewsResp, error) {
|
||||
updater := l.svcCtx.ReviewModelRW.Reviews.UpdateOneID(in.GetId())
|
||||
|
||||
if in.Sealed != nil {
|
||||
updater = updater.SetSealed(in.GetSealed())
|
||||
}
|
||||
if in.UnsealedAt != nil {
|
||||
updater = updater.SetUnsealedAt(time.Unix(in.GetUnsealedAt(), 0))
|
||||
}
|
||||
if in.Rating != nil {
|
||||
updater = updater.SetRating(int16(in.GetRating()))
|
||||
}
|
||||
if in.Content != nil {
|
||||
updater = updater.SetContent(in.GetContent())
|
||||
}
|
||||
|
||||
_, err := updater.Save(l.ctx)
|
||||
if err != nil {
|
||||
logx.Errorf("updateReviews err: %v", err)
|
||||
return nil, err
|
||||
}
|
||||
return &pb.UpdateReviewsResp{}, nil
|
||||
}
|
||||
Reference in New Issue
Block a user