//
namespace SafeCampus.System;
///
///
///
public class OperateLogService : DbRepository, IOperateLogService
{
///
/// 操作日志中文名称
///
private readonly string _nameOperate = "操作日志";
///
/// 异常日志中文名称
///
private readonly string _nameException = "异常日志";
///
/// 分表最多查近多少年的数据
///
private readonly int _maxTabs = 100;
///
public async Task> Page(OperateLogPageInput input)
{
var query = Context.Queryable().WhereIF(!string.IsNullOrEmpty(input.Account), it => it.OpAccount == input.Account)//根据账号查询
.WhereIF(!string.IsNullOrEmpty(input.Category), it => it.Category == input.Category)//根据分类查询
.WhereIF(!string.IsNullOrEmpty(input.SearchKey), it => it.Name.Contains(input.SearchKey) || it.OpIp.Contains(input.SearchKey))//根据关键字查询
.IgnoreColumns(it => new { it.ParamJson, it.ResultJson }).SplitTable(tabs => tabs.Take(_maxTabs))
.OrderByIF(!string.IsNullOrEmpty(input.SortField), $"{input.SortField} {input.SortOrder}")//排序
.OrderBy(it => it.CreateTime, OrderByType.Desc);
var pageInfo = await query.ToPagedListAsync(input.PageNum, input.PageSize);//分页
return pageInfo;
}
///
public async Task> StatisticsByDay(int day)
{
//取最近七天
var dayArray = Enumerable.Range(0, day).Select(it => DateTime.Now.Date.AddDays(it * -1)).ToList();
//生成时间表
var queryableLeft = Context.Reportable(dayArray).ToQueryable();
//ReportableDateType.MonthsInLast1yea 表式近一年月份 并且queryable之后还能在where过滤
var queryableRight = Context.Queryable().SplitTable(tabs => tabs.Take(_maxTabs));//声名表
//报表查询
var list = await Context
.Queryable(queryableLeft, queryableRight, JoinType.Left,
(x1, x2) => x2.CreateTime.Value.ToString("yyyy-MM-dd") == x1.ColumnName.ToString("yyyy-MM-dd"))
.GroupBy((x1, x2) => x1.ColumnName)//根据时间分组
.OrderBy((x1, x2) => x1.ColumnName)//根据时间升序排序
.Select((x1, x2) => new
{
OperateCount = SqlFunc.AggregateSum(SqlFunc.IIF(x2.Category == CateGoryConst.LOG_OPERATE, 1, 0)),//null的数据要为0所以不能用count
ExceptionCount = SqlFunc.AggregateSum(SqlFunc.IIF(x2.Category == CateGoryConst.LOG_EXCEPTION, 1, 0)),//null的数据要为0所以不能用count
Date = x1.ColumnName.ToString("yyyy-MM-dd")
}).ToListAsync();
//定义返回结果
var result = new List();
//遍历结果
list.ForEach(it =>
{
result.Add(new OperateLogDayStatisticsOutput { Date = it.Date, Name = _nameOperate, Count = it.OperateCount });//添加访问日志
result.Add(new OperateLogDayStatisticsOutput { Date = it.Date, Name = _nameException, Count = it.ExceptionCount });//添加异常日志
});
return result;
}
///
public async Task> TotalCount()
{
var data = await Context.Queryable().SplitTable(tabs => tabs.Take(_maxTabs)).GroupBy(it => it.Category)//根据分类分组
.Select(it => new
{
it.Category,//分类
Count = SqlFunc.AggregateCount(it.Category)//数量
}).ToListAsync();
//定义结果数组
var operateLogTotalCounts = new List
{
//添加操作日志数据
new OperateLogTotalCountOutput
{
Type = _nameOperate,
Value = data.Where(it => it.Category == CateGoryConst.LOG_OPERATE).Select(it => it.Count).FirstOrDefault()
},
//添加异常日志数据
new OperateLogTotalCountOutput
{
Type = _nameException,
Value = data.Where(it => it.Category == CateGoryConst.LOG_EXCEPTION).Select(it => it.Count).FirstOrDefault()
}
};
return operateLogTotalCounts;
}
///
public async Task Delete(string category)
{
await Context.Deleteable().Where(it => it.Category == category).SplitTable(tabs => tabs.Take(_maxTabs))
.ExecuteCommandAsync();//删除对应分类日志
}
///
public async Task Detail(BaseIdInput input)
{
return await GetFirstSplitTableAsync(it => it.Id == input.Id, tabs => tabs.Take(_maxTabs));
}
}