AppReportRecordService.cs 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. using Attribute;
  2. using Model;
  3. using Model.Base;
  4. using Repository;
  5. using Service;
  6. using Microsoft.AspNetCore.Mvc;
  7. using Vo.Admin;
  8. namespace Services
  9. {
  10. /// <summary>
  11. /// app上报记录Service业务层处理
  12. /// </summary>
  13. [AppService(ServiceType = typeof(IAppReportRecordService), ServiceLifetime = LifeTime.Transient)]
  14. public class AppReportRecordService : BaseService<AppReportRecord>, IAppReportRecordService
  15. {
  16. /// <summary>
  17. /// app上报记录-列表
  18. /// </summary>
  19. /// <param name="param">参数请求体</param>
  20. /// <param name="page">分页参数</param>
  21. /// <returns>列表</returns>
  22. public PagedInfo<GetAppReportRecordListVo> getAppReportRecordList([FromQuery] PagerInfo page, [FromQuery] AppReportRecord param)
  23. {
  24. //拼装查询条件
  25. var predicate = Expressionable.Create<AppReportRecord>();
  26. predicate = predicate.AndIF(!string.IsNullOrEmpty(param.appVersion), m => m.appVersion.Contains(param.appVersion));
  27. predicate = predicate.AndIF(!string.IsNullOrEmpty(param.userTag), m => m.userTag.Contains(param.userTag));
  28. predicate = predicate.AndIF(!string.IsNullOrEmpty(param.pageTitle), m => m.pageTitle.Contains(param.pageTitle));
  29. predicate = predicate.AndIF(!string.IsNullOrEmpty(param.pageUrl), m => m.pageUrl.Contains(param.pageUrl));
  30. predicate = predicate.AndIF(!string.IsNullOrEmpty(param.deviceSize), m => m.deviceSize.Contains(param.deviceSize));
  31. predicate = predicate.AndIF(!string.IsNullOrEmpty(param.reportType), m => m.reportType.Contains(param.reportType));
  32. var response = Queryable()
  33. .Where(predicate.ToExpression())
  34. .SplitTable(DateTime.Now.AddMonths(-3), DateTime.Now)
  35. .OrderByDescending(m => m.id)
  36. .ToPage<AppReportRecord, GetAppReportRecordListVo>(page);
  37. return response;
  38. }
  39. }
  40. }