163 lines
5.4 KiB
C#
163 lines
5.4 KiB
C#
using Microsoft.AspNetCore.Mvc;
|
|
using SqlSugar;
|
|
using Infrastructure;
|
|
using Infrastructure.Attribute;
|
|
using Infrastructure.Enums;
|
|
using Infrastructure.Model;
|
|
using Mapster;
|
|
using ZR.Admin.WebApi.Extensions;
|
|
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
|
|
{
|
|
/// <summary>
|
|
/// 文件存储Controller
|
|
/// </summary>
|
|
[Verify]
|
|
[Route("tool/file")]
|
|
public class SysFileController : BaseController
|
|
{
|
|
/// <summary>
|
|
/// 文件存储接口
|
|
/// </summary>
|
|
private readonly ISysFileService _SysFileService;
|
|
|
|
public SysFileController(ISysFileService SysFileService)
|
|
{
|
|
_SysFileService = SysFileService;
|
|
}
|
|
|
|
/// <summary>
|
|
/// 查询文件存储列表
|
|
/// </summary>
|
|
/// <param name="parm"></param>
|
|
/// <returns></returns>
|
|
[HttpGet("list")]
|
|
[ActionPermissionFilter(Permission = "tool:file:list")]
|
|
public IActionResult QuerySysFile([FromQuery] SysFileQueryDto parm)
|
|
{
|
|
//开始拼装查询条件
|
|
var predicate = Expressionable.Create<SysFile>();
|
|
//搜索条件查询语法参考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);
|
|
|
|
//搜索条件查询语法参考Sqlsugar
|
|
var response = _SysFileService.GetPages(predicate.ToExpression(), parm);
|
|
return SUCCESS(response);
|
|
}
|
|
|
|
/// <summary>
|
|
/// 查询文件存储详情
|
|
/// </summary>
|
|
/// <param name="Id"></param>
|
|
/// <returns></returns>
|
|
[HttpGet("{Id}")]
|
|
[ActionPermissionFilter(Permission = "tool:file:query")]
|
|
public IActionResult GetSysFile(int Id)
|
|
{
|
|
var response = _SysFileService.GetFirst(x => x.Id == Id);
|
|
|
|
return SUCCESS(response);
|
|
}
|
|
|
|
/// <summary>
|
|
/// 添加文件存储
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
[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<SysFile>().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);
|
|
}
|
|
|
|
/// <summary>
|
|
/// 更新文件存储
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
[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<SysFile>().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);
|
|
}
|
|
|
|
/// <summary>
|
|
/// 删除文件存储
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
[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);
|
|
}
|
|
|
|
/// <summary>
|
|
/// 文件存储导出
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
[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 });
|
|
}
|
|
}
|
|
} |