package io.hmit.modules.sys.controller; import io.hmit.common.annotation.LogOperation; import io.hmit.common.constant.Constant; import io.hmit.common.page.PageData; import io.hmit.common.utils.ExcelUtils; import io.hmit.common.utils.Result; import io.hmit.common.validator.AssertUtils; import io.hmit.common.validator.ValidatorUtils; import io.hmit.common.validator.group.AddGroup; import io.hmit.common.validator.group.DefaultGroup; import io.hmit.common.validator.group.UpdateGroup; import io.hmit.modules.sys.dto.SysParamsDTO; import io.hmit.modules.sys.excel.SysParamsExcel; import io.hmit.modules.sys.service.SysParamsService; import io.swagger.annotations.Api; import io.swagger.annotations.ApiImplicitParam; import io.swagger.annotations.ApiImplicitParams; import io.swagger.annotations.ApiOperation; import org.apache.shiro.authz.annotation.RequiresPermissions; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.*; import springfox.documentation.annotations.ApiIgnore; import javax.servlet.http.HttpServletResponse; import java.util.List; import java.util.Map; /** * 参数管理 * * @author * @since 1.0.0 */ @RestController @RequestMapping("sys/params") @Api(tags = "参数管理") public class SysParamsController { @Autowired private SysParamsService sysParamsService; @GetMapping("page") @ApiOperation("分页") @ApiImplicitParams({ @ApiImplicitParam(name = Constant.PAGE, value = "当前页码,从1开始", paramType = "query", required = true, dataType = "int"), @ApiImplicitParam(name = Constant.LIMIT, value = "每页显示记录数", paramType = "query", required = true, dataType = "int"), @ApiImplicitParam(name = Constant.ORDER_FIELD, value = "排序字段", paramType = "query", dataType = "String"), @ApiImplicitParam(name = Constant.ORDER, value = "排序方式,可选值(asc、desc)", paramType = "query", dataType = "String"), @ApiImplicitParam(name = "paramCode", value = "参数编码", paramType = "query", dataType = "String") }) @RequiresPermissions("sys:params:page") public Result<PageData<SysParamsDTO>> page(@ApiIgnore @RequestParam Map<String, Object> params) { PageData<SysParamsDTO> page = sysParamsService.page(params); return new Result<PageData<SysParamsDTO>>().ok(page); } @GetMapping("/getValue") @ApiOperation("获取参数") public Result<String> getValue(@RequestParam("paramCode") String paramCode) { String data = sysParamsService.getValue(paramCode); return new Result<String>().ok(data); } @GetMapping("{id}") @ApiOperation("信息") @RequiresPermissions("sys:params:info") public Result<SysParamsDTO> get(@PathVariable("id") Long id) { SysParamsDTO data = sysParamsService.get(id); return new Result<SysParamsDTO>().ok(data); } @PostMapping @ApiOperation("保存") @LogOperation("保存") @RequiresPermissions("sys:params:save") public Result<Object> save(@RequestBody SysParamsDTO dto) { //校验数据 ValidatorUtils.validateEntity(dto, AddGroup.class, DefaultGroup.class); sysParamsService.save(dto); return new Result<>(); } @PutMapping @ApiOperation("修改") @LogOperation("修改") @RequiresPermissions("sys:params:update") public Result<Object> update(@RequestBody SysParamsDTO dto) { //校验数据 ValidatorUtils.validateEntity(dto, UpdateGroup.class, DefaultGroup.class); sysParamsService.update(dto); return new Result<>(); } @DeleteMapping @ApiOperation("删除") @LogOperation("删除") @RequiresPermissions("sys:params:delete") public Result<Object> delete(@RequestBody Long[] ids) { //校验数据 AssertUtils.isArrayEmpty(ids, "id"); sysParamsService.delete(ids); return new Result<>(); } @GetMapping("export") @ApiOperation("导出") @LogOperation("导出") @RequiresPermissions("sys:params:export") @ApiImplicitParam(name = "paramCode", value = "参数编码", paramType = "query", dataType = "String") public void export(@ApiIgnore @RequestParam Map<String, Object> params, HttpServletResponse response) throws Exception { List<SysParamsDTO> list = sysParamsService.list(params); ExcelUtils.exportExcelToTarget(response, null, list, SysParamsExcel.class); } }