SysDictController.java 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. package com.pj.project.sys_dict;
  2. import cn.dev33.satoken.annotation.SaCheckPermission;
  3. import com.pj.current.satoken.StpUserUtil;
  4. import com.pj.project4sp.SP;
  5. import com.pj.utils.sg.AjaxError;
  6. import com.pj.utils.sg.AjaxJson;
  7. import com.pj.utils.so.SoMap;
  8. import org.springframework.beans.factory.annotation.Autowired;
  9. import org.springframework.transaction.annotation.Transactional;
  10. import org.springframework.web.bind.annotation.RequestMapping;
  11. import org.springframework.web.bind.annotation.RestController;
  12. import java.util.List;
  13. /**
  14. * Controller: sys_dict -- 字典表
  15. *
  16. * @author qzyReal
  17. */
  18. @RestController
  19. @RequestMapping("/SysDict/")
  20. public class SysDictController {
  21. /**
  22. * 底层 Service 对象
  23. */
  24. @Autowired
  25. SysDictService sysDictService;
  26. /**
  27. * 增
  28. */
  29. @RequestMapping("add")
  30. @SaCheckPermission(SysDict.PERMISSION_CODE)
  31. @Transactional(rollbackFor = Exception.class)
  32. public AjaxJson add(SysDict s) {
  33. sysDictService.add(s);
  34. return AjaxJson.getSuccessData(s);
  35. }
  36. /**
  37. * 删
  38. */
  39. @RequestMapping("delete")
  40. @SaCheckPermission(SysDict.PERMISSION_CODE)
  41. public AjaxJson delete(Long id) {
  42. int line = sysDictService.delete(id);
  43. return AjaxJson.getByLine(line);
  44. }
  45. /**
  46. * 删 - 根据id列表
  47. */
  48. @RequestMapping("deleteByIds")
  49. @SaCheckPermission(SysDict.PERMISSION_CODE)
  50. public AjaxJson deleteByIds() {
  51. List<Long> ids = SoMap.getRequestSoMap().getListByComma("ids", long.class);
  52. int line = SP.publicMapper.deleteByIds(SysDict.TABLE_NAME, ids);
  53. return AjaxJson.getByLine(line);
  54. }
  55. /**
  56. * 改
  57. */
  58. @RequestMapping("update")
  59. @SaCheckPermission(SysDict.PERMISSION_CODE)
  60. public AjaxJson update(SysDict s) {
  61. int line = sysDictService.update(s);
  62. return AjaxJson.getByLine(line);
  63. }
  64. /**
  65. * 查 - 根据id
  66. */
  67. @RequestMapping("getById")
  68. public AjaxJson getById(Long id) {
  69. SysDict s = sysDictService.getById(id);
  70. return AjaxJson.getSuccessData(s);
  71. }
  72. /**
  73. * 查集合 - 根据条件(参数为空时代表忽略指定条件)
  74. */
  75. @RequestMapping("getList")
  76. public AjaxJson getList() {
  77. SoMap so = SoMap.getRequestSoMap();
  78. List<SysDict> list = sysDictService.getList(so.startPage());
  79. return AjaxJson.getPageData(so.getDataCount(), list);
  80. }
  81. // ------------------------- 前端接口 -------------------------
  82. /**
  83. * 改 - 不传不改 [G]
  84. */
  85. @RequestMapping("updateByNotNull")
  86. public AjaxJson updateByNotNull(Long id) {
  87. AjaxError.throwBy(true, "如需正常调用此接口,请删除此行代码");
  88. // 鉴别身份,是否为数据创建者
  89. long userId = SP.publicMapper.getColumnByIdToLong(SysDict.TABLE_NAME, "user_id", id);
  90. AjaxError.throwBy(userId != StpUserUtil.getLoginIdAsLong(), "此数据您无权限修改");
  91. // 开始修改 (请只保留需要修改的字段)
  92. SoMap so = SoMap.getRequestSoMap();
  93. so.clearNotIn("id", "name", "code", "desc").clearNull().humpToLineCase();
  94. int line = SP.publicMapper.updateBySoMapById(SysDict.TABLE_NAME, so, id);
  95. return AjaxJson.getByLine(line);
  96. }
  97. }