get_usage_detail_list_logic.go 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. package UsageDetail
  2. import (
  3. "context"
  4. "github.com/suyuan32/simple-admin-common/msg/errormsg"
  5. "github.com/suyuan32/simple-admin-common/utils/pointy"
  6. "time"
  7. "wechat-api/ent/predicate"
  8. "wechat-api/ent/usagedetail"
  9. "wechat-api/internal/svc"
  10. "wechat-api/internal/types"
  11. "wechat-api/internal/utils/dberrorhandler"
  12. "github.com/zeromicro/go-zero/core/logx"
  13. )
  14. type GetUsageDetailListLogic struct {
  15. logx.Logger
  16. ctx context.Context
  17. svcCtx *svc.ServiceContext
  18. }
  19. func NewGetUsageDetailListLogic(ctx context.Context, svcCtx *svc.ServiceContext) *GetUsageDetailListLogic {
  20. return &GetUsageDetailListLogic{
  21. Logger: logx.WithContext(ctx),
  22. ctx: ctx,
  23. svcCtx: svcCtx}
  24. }
  25. func (l *GetUsageDetailListLogic) GetUsageDetailList(req *types.UsageDetailListReq) (resp *types.UsageDetailListResp, err error) {
  26. organizationId := l.ctx.Value("organizationId").(uint64)
  27. isAdmin := l.ctx.Value("isAdmin").(bool)
  28. var predicates []predicate.UsageDetail
  29. if !isAdmin {
  30. predicates = append(predicates, usagedetail.OrganizationIDEQ(organizationId))
  31. } else {
  32. if req.OrganizationId != nil && *req.OrganizationId > 0 {
  33. predicates = append(predicates, usagedetail.OrganizationIDEQ(*req.OrganizationId))
  34. }
  35. }
  36. if req.Type != nil {
  37. predicates = append(predicates, usagedetail.TypeEQ(*req.Type))
  38. }
  39. if req.BotId != nil {
  40. predicates = append(predicates, usagedetail.BotID(*req.BotId))
  41. }
  42. if req.ReceiverId != nil {
  43. predicates = append(predicates, usagedetail.ReceiverID(*req.ReceiverId))
  44. }
  45. // 这里是为限制时间段
  46. if req.StartDate != nil && *req.StartDate != "" {
  47. startDate, err := time.Parse("2006-01-02 15:04:05", *req.StartDate)
  48. if err != nil {
  49. l.Logger.Errorf("时间字符串startDate转换错误: %v", err)
  50. } else {
  51. predicates = append(predicates, usagedetail.CreatedAtGTE(startDate))
  52. }
  53. }
  54. if req.EndDate != nil && *req.EndDate != "" {
  55. endDate, err := time.Parse("2006-01-02 15:04:05", *req.EndDate)
  56. if err != nil {
  57. l.Logger.Errorf("时间字符串endDate转换错误: %v", err)
  58. } else {
  59. predicates = append(predicates, usagedetail.CreatedAtLTE(endDate))
  60. }
  61. }
  62. data, err := l.svcCtx.DB.UsageDetail.Query().Where(predicates...).Page(l.ctx, req.Page, req.PageSize)
  63. if err != nil {
  64. return nil, dberrorhandler.DefaultEntError(l.Logger, err, req)
  65. }
  66. resp = &types.UsageDetailListResp{}
  67. resp.Msg = errormsg.Success
  68. resp.Data.Total = data.PageDetails.Total
  69. for _, v := range data.List {
  70. app := "未知"
  71. if v.App == 1 {
  72. app = "智能回复"
  73. } else if v.App == 2 {
  74. app = "AI角色-优化问题"
  75. } else if v.App == 3 {
  76. app = "AI角色-回复"
  77. } else if v.App == 4 {
  78. app = "SOP-节点判断"
  79. } else if v.App == 5 {
  80. app = "SOP-节点判断"
  81. }
  82. request := v.Request
  83. if v.App == 2 {
  84. request = "问题优化"
  85. } else if v.App == 4 {
  86. request = "节点判断"
  87. }
  88. resp.Data.Data = append(resp.Data.Data,
  89. types.UsageDetailInfo{
  90. BaseIDInfo: types.BaseIDInfo{
  91. Id: &v.ID,
  92. CreatedAt: pointy.GetPointer(v.CreatedAt.UnixMilli()),
  93. UpdatedAt: pointy.GetPointer(v.UpdatedAt.UnixMilli()),
  94. },
  95. Status: &v.Status,
  96. Type: &v.Type,
  97. BotId: &v.BotID,
  98. ReceiverId: &v.ReceiverID,
  99. App: &app,
  100. SessionId: &v.SessionID,
  101. Request: &request,
  102. Response: &v.Response,
  103. TotalTokens: &v.TotalTokens,
  104. PromptTokens: &v.PromptTokens,
  105. CompletionTokens: &v.CompletionTokens,
  106. OrganizationId: &v.OrganizationID,
  107. })
  108. }
  109. return resp, nil
  110. //return nil, nil
  111. }