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
|
}
|