SysSqlLogController.java 3.5 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107
package io.hmit.modules.datasource.controller;

import io.hmit.common.annotation.LogOperation;
import io.hmit.common.constant.Constant;
import io.hmit.common.page.PageData;
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.datasource.dto.SysSqlLogDTO;
import io.hmit.modules.datasource.service.SysSqlLogService;
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.web.bind.annotation.*;
import springfox.documentation.annotations.ApiIgnore;

import java.util.Map;


/**
 * <h1>SQL日志</h1>
 *
 * @author Shen
 * @since 1.0.0 2022-08-02
 */
@RestController
@RequestMapping("datasource/syssqllog")
@Api(tags="SQL日志")
public class SysSqlLogController {

    private final SysSqlLogService sysSqlLogService;

    public SysSqlLogController(SysSqlLogService sysSqlLogService) {
        this.sysSqlLogService = sysSqlLogService;
    }

    @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")
    })
    @RequiresPermissions("datasource:syssqllog:page")
    public Result<PageData<SysSqlLogDTO>> page(@ApiIgnore @RequestParam Map<String, Object> params){
        PageData<SysSqlLogDTO> page = sysSqlLogService.page(params);

        return new Result<PageData<SysSqlLogDTO>>().ok(page);
    }

    @GetMapping("{id}")
    @ApiOperation("信息")
    @RequiresPermissions("datasource:syssqllog:info")
    public Result<SysSqlLogDTO> get(@PathVariable("id") Long id){
        SysSqlLogDTO data = sysSqlLogService.get(id);

        return new Result<SysSqlLogDTO>().ok(data);
    }

/*
    @PostMapping
    @ApiOperation("保存")
    @LogOperation("保存")
    @RequiresPermissions("datasource:syssqllog:save")
    public Result<Object> save(@RequestBody SysSqlLogDTO dto){
        //校验数据
        ValidatorUtils.validateEntity(dto, AddGroup.class, DefaultGroup.class);

        sysSqlLogService.save(dto);

        return new Result();
    }
*/

    @PutMapping
    @ApiOperation("修改")
    @LogOperation("修改")
    @RequiresPermissions("datasource:syssqllog:update")
    public Result<Object> update(@RequestBody SysSqlLogDTO dto){
        //校验数据
        ValidatorUtils.validateEntity(dto, UpdateGroup.class, DefaultGroup.class);

        sysSqlLogService.update(dto);

        return new Result<>();
    }

    @DeleteMapping
    @ApiOperation("删除")
    @LogOperation("删除")
    @RequiresPermissions("datasource:syssqllog:delete")
    public Result<Object> delete(@RequestBody Long[] ids){
        //校验数据
        AssertUtils.isArrayEmpty(ids, "id");

        sysSqlLogService.delete(ids);

        return new Result<>();
    }

}