using Attribute; using Model; using Model.Base; using Repository; using Service; using Microsoft.AspNetCore.Mvc; using Vo.Admin; namespace Services { /// /// app上报记录Service业务层处理 /// [AppService(ServiceType = typeof(IAppReportRecordService), ServiceLifetime = LifeTime.Transient)] public class AppReportRecordService : BaseService, IAppReportRecordService { /// /// app上报记录-列表 /// /// 参数请求体 /// 分页参数 /// 列表 public PagedInfo getAppReportRecordList([FromQuery] PagerInfo page, [FromQuery] AppReportRecord param) { //拼装查询条件 var predicate = Expressionable.Create(); predicate = predicate.AndIF(!string.IsNullOrEmpty(param.appVersion), m => m.appVersion.Contains(param.appVersion)); predicate = predicate.AndIF(!string.IsNullOrEmpty(param.userTag), m => m.userTag.Contains(param.userTag)); predicate = predicate.AndIF(!string.IsNullOrEmpty(param.pageTitle), m => m.pageTitle.Contains(param.pageTitle)); predicate = predicate.AndIF(!string.IsNullOrEmpty(param.pageUrl), m => m.pageUrl.Contains(param.pageUrl)); predicate = predicate.AndIF(!string.IsNullOrEmpty(param.deviceSize), m => m.deviceSize.Contains(param.deviceSize)); predicate = predicate.AndIF(!string.IsNullOrEmpty(param.reportType), m => m.reportType.Contains(param.reportType)); var response = Queryable() .Where(predicate.ToExpression()) .SplitTable(DateTime.Now.AddMonths(-3), DateTime.Now) .OrderByDescending(m => m.id) .ToPage(page); return response; } } }