using Microsoft.AspNetCore.Mvc; using SqlSugar; using Infrastructure.Attribute; using Infrastructure.Enums; using Infrastructure.Model; using ZR.Admin.WebApi.Filters; using ZR.Common; using ZR.Model.System; using ZR.Service.System.IService; using ZR.Model.System.Dto; namespace ZR.Admin.WebApi.Controllers { /// /// 文件存储Controller /// [Verify] [Route("tool/file")] public class SysFileController : BaseController { /// /// 文件存储接口 /// private readonly ISysFileService _SysFileService; public SysFileController(ISysFileService SysFileService) { _SysFileService = SysFileService; } /// /// 查询文件存储列表 /// /// /// [HttpGet("list")] [ActionPermissionFilter(Permission = "tool:file:list")] public IActionResult QuerySysFile([FromQuery] SysFileQueryDto parm) { //开始拼装查询条件 var predicate = Expressionable.Create(); //搜索条件查询语法参考Sqlsugar predicate = predicate.AndIF(parm.BeginCreate_time != null, it => it.Create_time >= parm.BeginCreate_time); predicate = predicate.AndIF(parm.EndCreate_time != null, it => it.Create_time <= parm.EndCreate_time); predicate = predicate.AndIF(parm.StoreType != null, m => m.StoreType == parm.StoreType); predicate = predicate.AndIF(parm.FileId != null, m => m.Id == parm.FileId); //搜索条件查询语法参考Sqlsugar var response = _SysFileService.GetPages(predicate.ToExpression(), parm); return SUCCESS(response); } /// /// 查询文件存储详情 /// /// /// [HttpGet("{Id}")] [ActionPermissionFilter(Permission = "tool:file:query")] public IActionResult GetSysFile(int Id) { var response = _SysFileService.GetFirst(x => x.Id == Id); return SUCCESS(response); } ///// ///// 添加文件存储 ///// ///// //[HttpPost] //[ActionPermissionFilter(Permission = "tool:file:add")] //[Log(Title = "文件存储", BusinessType = BusinessType.INSERT)] //public IActionResult AddSysFile([FromBody] SysFileDto parm) //{ // if (parm == null) // { // throw new CustomException("请求参数错误"); // } // //从 Dto 映射到 实体 // var model = parm.Adapt().ToCreate(HttpContext); // var response = _SysFileService.Insert(model, it => new // { // it.FileName, // it.FileUrl, // it.StorePath, // it.FileSize, // it.FileExt, // it.Create_by, // it.Create_time, // it.StoreType, // it.AccessUrl, // }); // return ToResponse(response); //} ///// ///// 更新文件存储 ///// ///// //[HttpPut] //[ActionPermissionFilter(Permission = "tool:file:update")] //[Log(Title = "文件存储", BusinessType = BusinessType.UPDATE)] //public IActionResult UpdateSysFile([FromBody] SysFileDto parm) //{ // if (parm == null) // { // throw new CustomException("请求实体不能为空"); // } // //从 Dto 映射到 实体 // var model = parm.Adapt().ToUpdate(HttpContext); // var response = _SysFileService.Update(w => w.Id == model.Id, it => new SysFile() // { // //Update 字段映射 // FileUrl = model.FileUrl, // StorePath = model.StorePath, // FileSize = model.FileSize, // FileExt = model.FileExt, // StoreType = model.StoreType, // AccessUrl = model.AccessUrl, // }); // return ToResponse(response); //} /// /// 删除文件存储 /// /// [HttpDelete("{ids}")] [ActionPermissionFilter(Permission = "tool:file:delete")] [Log(Title = "文件存储", BusinessType = BusinessType.DELETE)] public IActionResult DeleteSysFile(string ids) { int[] idsArr = Tools.SpitIntArrary(ids); if (idsArr.Length <= 0) { return ToResponse(ApiResult.Error($"删除失败Id 不能为空")); } var response = _SysFileService.Delete(idsArr); //TODO 删除本地资源 return ToResponse(response); } /// /// 文件存储导出 /// /// [Log(BusinessType = BusinessType.EXPORT, IsSaveResponseData = false, Title = "文件存储")] [HttpGet("export")] [ActionPermissionFilter(Permission = "tool:file:export")] public IActionResult Export() { var list = _SysFileService.GetAll(); string sFileName = ExportExcel(list, "SysFile", "文件存储"); return SUCCESS(new { path = "/export/" + sFileName, fileName = sFileName }); } } }