SysLogOpService.cs 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. // 麻省理工学院许可证
  2. //
  3. // 版权所有 (c) 2021-2023 zuohuaijun,大名科技(天津)有限公司 联系电话/微信:18020030720 QQ:515096995
  4. //
  5. // 特此免费授予获得本软件的任何人以处理本软件的权利,但须遵守以下条件:在所有副本或重要部分的软件中必须包括上述版权声明和本许可声明。
  6. //
  7. // 软件按“原样”提供,不提供任何形式的明示或暗示的保证,包括但不限于对适销性、适用性和非侵权的保证。
  8. // 在任何情况下,作者或版权持有人均不对任何索赔、损害或其他责任负责,无论是因合同、侵权或其他方式引起的,与软件或其使用或其他交易有关。
  9. using Magicodes.ExporterAndImporter.Excel;
  10. namespace Admin.NET.Core.Service;
  11. /// <summary>
  12. /// 系统操作日志服务
  13. /// </summary>
  14. [ApiDescriptionSettings(Order = 360)]
  15. public class SysLogOpService : IDynamicApiController, ITransient
  16. {
  17. private readonly SqlSugarRepository<SysLogOp> _sysLogOpRep;
  18. public SysLogOpService(SqlSugarRepository<SysLogOp> sysLogOpRep)
  19. {
  20. _sysLogOpRep = sysLogOpRep;
  21. }
  22. /// <summary>
  23. /// 获取操作日志分页列表
  24. /// </summary>
  25. /// <returns></returns>
  26. [SuppressMonitor]
  27. [DisplayName("获取操作日志分页列表")]
  28. public async Task<SqlSugarPagedList<SysLogOp>> Page(PageLogInput input)
  29. {
  30. return await _sysLogOpRep.AsQueryable()
  31. .WhereIF(!string.IsNullOrWhiteSpace(input.StartTime.ToString()), u => u.CreateTime >= input.StartTime)
  32. .WhereIF(!string.IsNullOrWhiteSpace(input.EndTime.ToString()), u => u.CreateTime <= input.EndTime)
  33. //.OrderBy(u => u.CreateTime, OrderByType.Desc)
  34. .OrderBuilder(input)
  35. .ToPagedListAsync(input.Page, input.PageSize);
  36. }
  37. /// <summary>
  38. /// 清空操作日志
  39. /// </summary>
  40. /// <returns></returns>
  41. [ApiDescriptionSettings(Name = "Clear"), HttpPost]
  42. [DisplayName("清空操作日志")]
  43. public async Task<bool> Clear()
  44. {
  45. return await _sysLogOpRep.DeleteAsync(u => u.Id > 0);
  46. }
  47. /// <summary>
  48. /// 导出操作日志
  49. /// </summary>
  50. /// <returns></returns>
  51. [ApiDescriptionSettings(Name = "Export"), NonUnify]
  52. [DisplayName("导出操作日志")]
  53. public async Task<IActionResult> ExportLogOp(LogInput input)
  54. {
  55. var logOpList = await _sysLogOpRep.AsQueryable()
  56. .WhereIF(!string.IsNullOrWhiteSpace(input.StartTime.ToString()) && !string.IsNullOrWhiteSpace(input.EndTime.ToString()),
  57. u => u.CreateTime >= input.StartTime && u.CreateTime <= input.EndTime)
  58. .OrderBy(u => u.CreateTime, OrderByType.Desc)
  59. .Select<ExportLogDto>().ToListAsync();
  60. IExcelExporter excelExporter = new ExcelExporter();
  61. var res = await excelExporter.ExportAsByteArray(logOpList);
  62. return new FileStreamResult(new MemoryStream(res), "application/octet-stream") { FileDownloadName = DateTime.Now.ToString("yyyyMMddHHmm") + "操作日志.xlsx" };
  63. }
  64. }