jinlin
2024-01-10 cdf29a8f6fb9990f82ccc1d3f47bfba48cfaf4fc
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
108
109
110
111
112
113
114
115
package ${package}.controller;
 
 
import com.zt.common.annotation.LogOperation;
import com.zt.common.constant.Constant;
import com.zt.common.annotation.QueryParam;
import com.zt.common.db.query.QueryFilter;
import com.zt.common.servlet.Result;
import com.zt.common.servlet.PageResult;
import com.zt.common.validator.AssertUtils;
import com.zt.common.validator.ValidatorUtils;
import com.zt.common.validator.group.AddGroup;
import com.zt.common.validator.group.DefaultGroup;
import com.zt.common.validator.group.UpdateGroup;
#if($isExport == 'true')
import com.zt.common.utils.ExcelUtils;
#end
import ${package}.model.${className};
#if($isExport == 'true')
import ${package}.excel.${className}Excel;
#end
import ${package}.service.${className}Service;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiImplicitParam;
import io.swagger.annotations.ApiImplicitParams;
import io.swagger.annotations.ApiOperation;
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;
 
 
/**
 * ${comments}
 *
 * @author ${author} ${email}
 * @since ${version} ${date}
 */
@RestController
@RequestMapping("/${moduleName}/${className}/")
@Api(tags="${comments}")
public class ${className}Controller {
    @Autowired
    private ${className}Service ${classBean}Service;
 
    @GetMapping("page")
    @ApiOperation("分页")
    @ApiImplicitParams({
        @ApiImplicitParam(name = Constant.Q.PAGE, value = Constant.QV.PAGE, required = true, dataType = Constant.QT.INT),
        @ApiImplicitParam(name = Constant.Q.LIMIT, value = Constant.QV.LIMIT, required = true, dataType = Constant.QT.INT),
        @ApiImplicitParam(name = Constant.Q.ORDER_FIELD, value = Constant.QV.ORDER_FIELD, dataType = Constant.QT.STRING),
        @ApiImplicitParam(name = Constant.Q.ORDER, value = Constant.QV.ORDER, dataType = Constant.QT.STRING),
#foreach($column in $selectColumns)
        @ApiImplicitParam(name = "${column.attrName}", value = "${column.comments}", dataType = Constant.QT.STRING, format = "${column.columnName}^${column.op}")#if($velocityCount != $selectColumns.size()),#end
#end
    })
    public PageResult<${className}> page(@ApiIgnore @QueryParam QueryFilter queryFilter){
 
        return PageResult.ok(${classBean}Service.page(queryFilter));
    }
 
    @GetMapping("{id}")
    @ApiOperation("信息")
    public Result<${className}> get(@PathVariable("id") Long id){
        ${className} data = ${classBean}Service.get(id);
 
        return Result.ok(data);
    }
 
    @PostMapping
    @ApiOperation("新增")
    @LogOperation("新增")
    public Result insert(@RequestBody ${className} ${modelName}){
        //效验数据
        ValidatorUtils.validateEntity(${modelName}, AddGroup.class, DefaultGroup.class);
        ${classBean}Service.insert(${modelName});
 
        return Result.ok();
    }
 
    @PutMapping
    @ApiOperation("修改")
    @LogOperation("修改")
    public Result update(@RequestBody ${className} ${modelName}){
        //效验数据
        ValidatorUtils.validateEntity(${modelName}, UpdateGroup.class, DefaultGroup.class);
        ${classBean}Service.update(${modelName});
 
        return Result.ok();
    }
 
    @DeleteMapping
    @ApiOperation("删除")
    @LogOperation("删除")
    public Result delete(@RequestBody Long[] ids){
        //效验数据
        AssertUtils.isArrayEmpty(ids, "id");
        ${classBean}Service.delete(ids);
 
        return Result.ok();
    }
 
#if($isExport == 'true')
    @GetMapping("export")
    @ApiOperation("导出")
    @LogOperation("导出")
    public void export(@ApiIgnore @QueryParam QueryFilter queryFilter, HttpServletResponse response) throws Exception {
        List<${className}> list = ${classBean}Service.page(queryFilter);
 
        ExcelUtils.exportExcelToTarget(response, null, list, ${className}Excel.class);
    }
#end
}