using NetAdmin.Application.Repositories; using NetAdmin.Application.Services; using NetAdmin.Domain.DbMaps.Sys; using NetAdmin.Domain.Dto.Dependency; using NetAdmin.Domain.Dto.Sys.RequestLog; using NetAdmin.SysComponent.Application.Services.Sys.Dependency; namespace NetAdmin.SysComponent.Application.Services.Sys; /// public sealed class RequestLogService(DefaultRepository rpo) // : RepositoryService(rpo), IRequestLogService { /// public async Task BulkDeleteAsync(BulkReq req) { req.ThrowIfInvalid(); var ret = 0; // ReSharper disable once LoopCanBeConvertedToQuery foreach (var item in req.Items) { ret += await DeleteAsync(item).ConfigureAwait(false); } return ret; } /// public async Task CreateAsync(CreateRequestLogReq req) { req.ThrowIfInvalid(); var ret = await Rpo.InsertAsync(req).ConfigureAwait(false); return ret.Adapt(); } /// public Task DeleteAsync(DelReq req) { req.ThrowIfInvalid(); throw new NotImplementedException(); } /// public Task ExistAsync(QueryReq req) { req.ThrowIfInvalid(); return QueryInternal(req).AnyAsync(); } /// public async Task GetAsync(QueryRequestLogReq req) { req.ThrowIfInvalid(); var ret = await QueryInternal(new QueryReq { Filter = req }) .ToOneAsync() .ConfigureAwait(false); return ret.Adapt(); } /// public async Task> PagedQueryAsync(PagedQueryReq req) { req.ThrowIfInvalid(); var list = await QueryInternal(req) .Page(req.Page, req.PageSize) .Count(out var total) .ToListAsync(a => new { a.ApiId , ApiSummary = a.Api.Summary , a.ExtraData , a.CreatedClientIp , a.CreatedTime , a.CreatedUserName , a.Duration , a.Method , a.CreatedUserAgent , a.HttpStatusCode , a.Id }) .ConfigureAwait(false); return new PagedQueryRsp(req.Page, req.PageSize, total , list.Adapt>()); } /// public async Task> QueryAsync(QueryReq req) { req.ThrowIfInvalid(); var ret = await QueryInternal(req).Take(req.Count).ToListAsync().ConfigureAwait(false); return ret.Adapt>(); } /// public Task UpdateAsync(NopReq req) { req.ThrowIfInvalid(); throw new NotImplementedException(); } /// protected override Task UpdateForSqliteAsync(Sys_RequestLog req) { throw new NotImplementedException(); } private ISelect QueryInternal(QueryReq req) { var ret = Rpo.Select.Include(a => a.Api) .WhereDynamicFilter(req.DynamicFilter) .WhereDynamic(req.Filter) .OrderByPropertyNameIf(req.Prop?.Length > 0, req.Prop, req.Order == Orders.Ascending); if (!req.Prop?.Equals(nameof(req.Filter.CreatedTime), StringComparison.OrdinalIgnoreCase) ?? true) { ret = ret.OrderByDescending(a => a.CreatedTime); } return ret; } }