SysCustomTableController.java 4.8 KB
package com.skua.modules.system.controller;

import java.util.Arrays;

import javax.servlet.http.HttpServletRequest;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.DeleteMapping;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.PutMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.skua.core.api.vo.Result;
import com.skua.core.aspect.annotation.AutoLog;
import com.skua.core.query.QueryGenerator;
import com.skua.modules.system.entity.SysCustomTable;
import com.skua.modules.system.service.ISysCustomTableService;

import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import lombok.extern.slf4j.Slf4j;
import springfox.documentation.annotations.ApiIgnore;

 /**
  * 表维护
  * @author liyy
  *
  */
@Slf4j
@Api(tags="表维护")
@ApiIgnore
@RestController
@RequestMapping("/sys/sysCustomTable")
public class SysCustomTableController {
	@Autowired
	private ISysCustomTableService sysCustomTableService;
	
	/**
	  * 分页列表查询
	 * @param sysCustomTable
	 * @param pageNo
	 * @param pageSize
	 * @param req
	 * @return
	 */
	@AutoLog(value = "表维护-分页列表查询")
	@ApiOperation(value="表维护-分页列表查询", notes="表维护-分页列表查询")
	@GetMapping(value = "/list")
	public Result<IPage<SysCustomTable>> queryPageList(SysCustomTable sysCustomTable,
									  @RequestParam(name="pageNo", defaultValue="1") Integer pageNo,
									  @RequestParam(name="pageSize", defaultValue="10") Integer pageSize,
									  HttpServletRequest req) {
		Result<IPage<SysCustomTable>> result = new Result<IPage<SysCustomTable>>();
		QueryWrapper<SysCustomTable> queryWrapper = QueryGenerator.initQueryWrapper(sysCustomTable, req.getParameterMap());
		Page<SysCustomTable> page = new Page<SysCustomTable>(pageNo, pageSize);
		IPage<SysCustomTable> pageList = sysCustomTableService.page(page, queryWrapper);
		result.setSuccess(true);
		result.setResult(pageList);
		return result;
	}
	
	/**
	  *   添加
	 * @param sysCustomTable
	 * @return
	 */
	@AutoLog(value = "表维护-添加")
	@ApiOperation(value="表维护-添加", notes="表维护-添加")
	@PostMapping(value = "/add")
	public Result<SysCustomTable> add(@RequestBody SysCustomTable sysCustomTable) {
		Result<SysCustomTable> result = new Result<SysCustomTable>();
		try {
			sysCustomTableService.save(sysCustomTable);
			result.success("添加成功!");
		} catch (Exception e) {
			log.error(e.getMessage(),e);
			result.error500("操作失败");
		}
		return result;
	}
	
	/**
	  *  编辑
	 * @param sysCustomTable
	 * @return
	 */
	@AutoLog(value = "表维护-编辑")
	@ApiOperation(value="表维护-编辑", notes="表维护-编辑")
	@PutMapping(value = "/edit")
	public Result<SysCustomTable> edit(@RequestBody SysCustomTable sysCustomTable) {
		Result<SysCustomTable> result = new Result<SysCustomTable>();
		SysCustomTable sysCustomTableEntity = sysCustomTableService.getById(sysCustomTable.getId());
		if(sysCustomTableEntity==null) {
			result.error500("未找到对应实体");
		}else {
			boolean ok = sysCustomTableService.updateById(sysCustomTable);
			//TODO 返回false说明什么?
			if(ok) {
				result.success("修改成功!");
			}
		}
		
		return result;
	}
	
	/**
	  *   通过id删除
	 * @param id
	 * @return
	 */
	@AutoLog(value = "表维护-通过id删除")
	@ApiOperation(value="表维护-通过id删除", notes="表维护-通过id删除")
	@DeleteMapping(value = "/delete")
	public Result<?> delete(@RequestParam(name="id",required=true) String id) {
		try {
			sysCustomTableService.removeById(id);
		} catch (Exception e) {
			log.error("删除失败",e.getMessage());
			return Result.error("删除失败!");
		}
		return Result.ok("删除成功!");
	}
	
	/**
	  *  批量删除
	 * @param ids
	 * @return
	 */
	@AutoLog(value = "表维护-批量删除")
	@ApiOperation(value="表维护-批量删除", notes="表维护-批量删除")
	@DeleteMapping(value = "/deleteBatch")
	public Result<SysCustomTable> deleteBatch(@RequestParam(name="ids",required=true) String ids) {
		Result<SysCustomTable> result = new Result<SysCustomTable>();
		if(ids==null || "".equals(ids.trim())) {
			result.error500("参数不识别!");
		}else {
			this.sysCustomTableService.removeByIds(Arrays.asList(ids.split(",")));
			result.success("删除成功!");
		}
		return result;
	}

}