BackendController.java.vm 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199
  1. package com.fuint.module.backendApi.controller;
  2. import com.fuint.common.dto.AccountInfo;
  3. import com.fuint.common.util.TokenUtil;
  4. import com.fuint.framework.web.BaseController;
  5. import com.fuint.framework.web.ResponseObject;
  6. import com.fuint.common.Constants;
  7. import com.fuint.common.enums.StatusEnum;
  8. import com.fuint.framework.pagination.PaginationRequest;
  9. import com.fuint.framework.pagination.PaginationResponse;
  10. import com.fuint.framework.exception.BusinessCheckException;
  11. import com.fuint.common.service.BannerService;
  12. import com.fuint.repository.model.${className};
  13. import com.fuint.utils.StringUtil;
  14. import io.swagger.annotations.Api;
  15. import io.swagger.annotations.ApiOperation;
  16. import lombok.AllArgsConstructor;
  17. import org.springframework.security.access.prepost.PreAuthorize;
  18. import org.springframework.web.bind.annotation.*;
  19. import javax.servlet.http.HttpServletRequest;
  20. import java.util.HashMap;
  21. import java.util.Map;
  22. /**
  23. * ${moduleName}管理类controller
  24. *
  25. * Created by ${author}
  26. * CopyRight https://www.fuint.cn
  27. */
  28. @Api(tags="管理端-${moduleName}相关接口")
  29. @RestController
  30. @AllArgsConstructor
  31. @RequestMapping(value = "/backendApi/${tableName}")
  32. public class Backend${tableClass}Controller extends BaseController {
  33. /**
  34. * ${moduleName}服务接口
  35. */
  36. private ${tableClass}Service ${tableName}Service;
  37. /**
  38. * ${moduleName}列表查询
  39. *
  40. * @param request HttpServletRequest对象
  41. * @return ${moduleName}列表
  42. */
  43. @ApiOperation(value = "${moduleName}列表查询")
  44. @RequestMapping(value = "/list", method = RequestMethod.GET)
  45. @CrossOrigin
  46. @PreAuthorize("@pms.hasPermission('${tableName}:list')")
  47. public ResponseObject list(HttpServletRequest request) throws BusinessCheckException {
  48. String token = request.getHeader("Access-Token");
  49. Integer page = request.getParameter("page") == null ? Constants.PAGE_NUMBER : Integer.parseInt(request.getParameter("page"));
  50. Integer pageSize = request.getParameter("pageSize") == null ? Constants.PAGE_SIZE : Integer.parseInt(request.getParameter("pageSize"));
  51. String title = request.getParameter("title");
  52. String status = request.getParameter("status");
  53. String searchStoreId = request.getParameter("storeId");
  54. AccountInfo accountInfo = TokenUtil.getAccountInfoByToken(token);
  55. Integer storeId;
  56. if (accountInfo == null) {
  57. return getFailureResult(1001, "请先登录");
  58. } else {
  59. storeId = accountInfo.getStoreId();
  60. }
  61. PaginationRequest paginationRequest = new PaginationRequest();
  62. paginationRequest.setCurrentPage(page);
  63. paginationRequest.setPageSize(pageSize);
  64. Map<String, Object> params = new HashMap<>();
  65. if (accountInfo.getMerchantId() != null && accountInfo.getMerchantId() > 0) {
  66. params.put("merchantId", accountInfo.getMerchantId());
  67. }
  68. if (StringUtil.isNotEmpty(title)) {
  69. params.put("title", title);
  70. }
  71. if (StringUtil.isNotEmpty(status)) {
  72. params.put("status", status);
  73. }
  74. if (StringUtil.isNotEmpty(searchStoreId)) {
  75. params.put("storeId", searchStoreId);
  76. }
  77. if (storeId != null && storeId > 0) {
  78. params.put("storeId", storeId);
  79. }
  80. paginationRequest.setSearchParams(params);
  81. PaginationResponse<${className}> paginationResponse = ${tableName}Service.query${tableClass}ListByPagination(paginationRequest);
  82. Map<String, Object> paramsStore = new HashMap<>();
  83. paramsStore.put("status", StatusEnum.ENABLED.getKey());
  84. if (accountInfo.getStoreId() != null && accountInfo.getStoreId() > 0) {
  85. paramsStore.put("storeId", accountInfo.getStoreId().toString());
  86. }
  87. if (accountInfo.getMerchantId() != null && accountInfo.getMerchantId() > 0) {
  88. paramsStore.put("merchantId", accountInfo.getMerchantId());
  89. }
  90. Map<String, Object> result = new HashMap<>();
  91. result.put("dataList", paginationResponse);
  92. return getSuccessResult(result);
  93. }
  94. /**
  95. * 更新${moduleName}状态
  96. *
  97. * @return
  98. */
  99. @ApiOperation(value = "更新${moduleName}状态")
  100. @RequestMapping(value = "/updateStatus", method = RequestMethod.POST)
  101. @CrossOrigin
  102. @PreAuthorize("@pms.hasPermission('${tableName}:edit')")
  103. public ResponseObject updateStatus(HttpServletRequest request, @RequestBody Map<String, Object> params) throws BusinessCheckException {
  104. String token = request.getHeader("Access-Token");
  105. String status = params.get("status") != null ? params.get("status").toString() : StatusEnum.ENABLED.getKey();
  106. Integer id = params.get("id") == null ? 0 : Integer.parseInt(params.get("id").toString());
  107. AccountInfo accountInfo = TokenUtil.getAccountInfoByToken(token);
  108. if (accountInfo == null) {
  109. return getFailureResult(1001, "请先登录");
  110. }
  111. ${className} ${tablePrefix}${tableClass} = ${tableName}Service.query${tableClass}ById(id);
  112. if (${tablePrefix}${tableClass} == null) {
  113. return getFailureResult(201);
  114. }
  115. String operator = accountInfo.getAccountName();
  116. ${tablePrefix}${tableClass}.setOperator(operator);
  117. ${tablePrefix}${tableClass}.setStatus(status);
  118. ${tableName}Service.update${tableClass}(${tablePrefix}${tableClass});
  119. return getSuccessResult(true);
  120. }
  121. /**
  122. * 保存${moduleName}
  123. *
  124. * @param request HttpServletRequest对象
  125. * @return
  126. */
  127. @ApiOperation(value = "保存${moduleName}")
  128. @RequestMapping(value = "/save", method = RequestMethod.POST)
  129. @CrossOrigin
  130. @PreAuthorize("@pms.hasPermission('${tableName}:add')")
  131. public ResponseObject saveHandler(HttpServletRequest request, @RequestBody Map<String, Object> params) throws BusinessCheckException {
  132. String token = request.getHeader("Access-Token");
  133. String id = params.get("id") == null ? "" : params.get("id").toString();
  134. String status = params.get("status") == null ? "" : params.get("status").toString();
  135. String storeId = params.get("storeId") == null ? "0" : params.get("storeId").toString();
  136. String sort = params.get("sort") == null ? "0" : params.get("sort").toString();
  137. AccountInfo accountInfo = TokenUtil.getAccountInfoByToken(token);
  138. if (accountInfo == null) {
  139. return getFailureResult(1001, "请先登录");
  140. }
  141. ${className} info = new ${className}();
  142. info.setOperator(accountInfo.getAccountName());
  143. info.setStatus(status);
  144. info.setStoreId(Integer.parseInt(storeId));
  145. info.setSort(Integer.parseInt(sort));
  146. info.setMerchantId(accountInfo.getMerchantId());
  147. if (StringUtil.isNotEmpty(id)) {
  148. info.setId(Integer.parseInt(id));
  149. ${tableName}Service.update${tableClass}(info);
  150. } else {
  151. ${tableName}Service.add${tableClass}(info);
  152. }
  153. return getSuccessResult(true);
  154. }
  155. /**
  156. * 获取${moduleName}详情
  157. *
  158. * @param id
  159. * @return
  160. */
  161. @ApiOperation(value = "获取${moduleName}详情")
  162. @RequestMapping(value = "/info/{id}", method = RequestMethod.GET)
  163. @CrossOrigin
  164. @PreAuthorize("@pms.hasPermission('${tableName}:list')")
  165. public ResponseObject info(HttpServletRequest request, @PathVariable("id") Integer id) throws BusinessCheckException {
  166. String token = request.getHeader("Access-Token");
  167. AccountInfo accountInfo = TokenUtil.getAccountInfoByToken(token);
  168. if (accountInfo == null) {
  169. return getFailureResult(1001, "请先登录");
  170. }
  171. ${className} ${tableName}Info = ${tableName}Service.query${tableClass}ById(id);
  172. Map<String, Object> result = new HashMap<>();
  173. result.put("${tableName}Info", ${tableName}Info);
  174. return getSuccessResult(result);
  175. }
  176. }