| 1234567891011121314151617181920212223242526272829303132333435363738394041424344 |
- using Attribute;
- using Model;
- using Model.Base;
- using Repository;
- using Service;
- using Microsoft.AspNetCore.Mvc;
- using Vo.Admin;
- namespace Services
- {
- /// <summary>
- /// app上报记录Service业务层处理
- /// </summary>
- [AppService(ServiceType = typeof(IAppReportRecordService), ServiceLifetime = LifeTime.Transient)]
- public class AppReportRecordService : BaseService<AppReportRecord>, IAppReportRecordService
- {
- /// <summary>
- /// app上报记录-列表
- /// </summary>
- /// <param name="param">参数请求体</param>
- /// <param name="page">分页参数</param>
- /// <returns>列表</returns>
- public PagedInfo<GetAppReportRecordListVo> getAppReportRecordList([FromQuery] PagerInfo page, [FromQuery] AppReportRecord param)
- {
- //拼装查询条件
- var predicate = Expressionable.Create<AppReportRecord>();
- 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<AppReportRecord, GetAppReportRecordListVo>(page);
- return response;
- }
- }
- }
|