DigitalFactory/Admin.NET/Admin.NET.Core/Service/Logging/SysLogOpService.cs

65 lines
2.4 KiB
C#
Raw Blame History

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

// 大名科技(天津)有限公司版权所有 电话18020030720 QQ515096995
//
// 此源代码遵循位于源代码树根目录中的 LICENSE 文件的许可证
namespace Admin.NET.Core.Service;
/// <summary>
/// 系统操作日志服务
/// </summary>
[ApiDescriptionSettings(Order = 360)]
public class SysLogOpService : IDynamicApiController, ITransient
{
private readonly SqlSugarRepository<SysLogOp> _sysLogOpRep;
public SysLogOpService(SqlSugarRepository<SysLogOp> sysLogOpRep)
{
_sysLogOpRep = sysLogOpRep;
}
/// <summary>
/// 获取操作日志分页列表
/// </summary>
/// <returns></returns>
[SuppressMonitor]
[DisplayName("获取操作日志分页列表")]
public async Task<SqlSugarPagedList<SysLogOp>> Page(PageLogInput input)
{
return await _sysLogOpRep.AsQueryable()
.WhereIF(!string.IsNullOrWhiteSpace(input.StartTime.ToString()), u => u.CreateTime >= input.StartTime)
.WhereIF(!string.IsNullOrWhiteSpace(input.EndTime.ToString()), u => u.CreateTime <= input.EndTime)
//.OrderBy(u => u.CreateTime, OrderByType.Desc)
.OrderBuilder(input)
.ToPagedListAsync(input.Page, input.PageSize);
}
/// <summary>
/// 清空操作日志
/// </summary>
/// <returns></returns>
[ApiDescriptionSettings(Name = "Clear"), HttpPost]
[DisplayName("清空操作日志")]
public async Task<bool> Clear()
{
return await _sysLogOpRep.DeleteAsync(u => u.Id > 0);
}
/// <summary>
/// 导出操作日志
/// </summary>
/// <returns></returns>
[ApiDescriptionSettings(Name = "Export"), NonUnify]
[DisplayName("导出操作日志")]
public async Task<IActionResult> ExportLogOp(LogInput input)
{
var logOpList = await _sysLogOpRep.AsQueryable()
.WhereIF(!string.IsNullOrWhiteSpace(input.StartTime.ToString()) && !string.IsNullOrWhiteSpace(input.EndTime.ToString()),
u => u.CreateTime >= input.StartTime && u.CreateTime <= input.EndTime)
.OrderBy(u => u.CreateTime, OrderByType.Desc)
.Select<ExportLogDto>().ToListAsync();
IExcelExporter excelExporter = new ExcelExporter();
var res = await excelExporter.ExportAsByteArray(logOpList);
return new FileStreamResult(new MemoryStream(res), "application/octet-stream") { FileDownloadName = DateTime.Now.ToString("yyyyMMddHHmm") + "操作日志.xlsx" };
}
}