|
@@ -5,21 +5,47 @@ import com.baomidou.mybatisplus.core.metadata.IPage;
|
|
import com.qmth.boot.api.annotation.Aac;
|
|
import com.qmth.boot.api.annotation.Aac;
|
|
import com.qmth.boot.api.annotation.BOOL;
|
|
import com.qmth.boot.api.annotation.BOOL;
|
|
import com.qmth.boot.api.constant.ApiConstant;
|
|
import com.qmth.boot.api.constant.ApiConstant;
|
|
|
|
+import com.qmth.boot.api.exception.ApiException;
|
|
import com.qmth.distributed.print.business.bean.ApiUser;
|
|
import com.qmth.distributed.print.business.bean.ApiUser;
|
|
import com.qmth.distributed.print.business.bean.dto.UserDto;
|
|
import com.qmth.distributed.print.business.bean.dto.UserDto;
|
|
|
|
+import com.qmth.distributed.print.business.bean.dto.excel.UserExportDto;
|
|
|
|
+import com.qmth.distributed.print.business.bean.query.ArraysParams;
|
|
import com.qmth.distributed.print.business.bean.query.UserParam;
|
|
import com.qmth.distributed.print.business.bean.query.UserParam;
|
|
|
|
+import com.qmth.distributed.print.business.bean.result.EditResult;
|
|
|
|
+import com.qmth.distributed.print.business.entity.BasicAttachment;
|
|
import com.qmth.distributed.print.business.entity.SysUser;
|
|
import com.qmth.distributed.print.business.entity.SysUser;
|
|
|
|
+import com.qmth.distributed.print.business.entity.TBTask;
|
|
|
|
+import com.qmth.distributed.print.business.enums.TaskTypeEnum;
|
|
|
|
+import com.qmth.distributed.print.business.enums.UploadFileEnum;
|
|
|
|
+import com.qmth.distributed.print.business.service.BasicAttachmentService;
|
|
import com.qmth.distributed.print.business.service.SysUserService;
|
|
import com.qmth.distributed.print.business.service.SysUserService;
|
|
|
|
+import com.qmth.distributed.print.business.service.TBTaskService;
|
|
|
|
+import com.qmth.distributed.print.business.util.ExcelUtil;
|
|
import com.qmth.distributed.print.business.util.RequestUtils;
|
|
import com.qmth.distributed.print.business.util.RequestUtils;
|
|
|
|
+import com.qmth.distributed.print.business.util.ServletUtil;
|
|
|
|
+import com.qmth.distributed.print.common.contant.SystemConstant;
|
|
|
|
+import com.qmth.distributed.print.common.enums.ExceptionResultEnum;
|
|
import com.qmth.distributed.print.common.util.Result;
|
|
import com.qmth.distributed.print.common.util.Result;
|
|
import com.qmth.distributed.print.common.util.ResultUtil;
|
|
import com.qmth.distributed.print.common.util.ResultUtil;
|
|
-import io.swagger.annotations.Api;
|
|
|
|
-import io.swagger.annotations.ApiOperation;
|
|
|
|
|
|
+import com.qmth.distributed.print.task.templete.execute.AsyncUserImportTempleteService;
|
|
|
|
+import com.qmth.distributed.print.task.templete.execute.UserImportTempleteService;
|
|
|
|
+import io.swagger.annotations.*;
|
|
|
|
+import org.slf4j.Logger;
|
|
|
|
+import org.slf4j.LoggerFactory;
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
|
+import org.springframework.transaction.annotation.Transactional;
|
|
|
|
+import org.springframework.validation.BindingResult;
|
|
import org.springframework.web.bind.annotation.*;
|
|
import org.springframework.web.bind.annotation.*;
|
|
|
|
+import org.springframework.web.multipart.MultipartFile;
|
|
|
|
|
|
|
|
+import javax.annotation.Resource;
|
|
import javax.servlet.http.HttpServletRequest;
|
|
import javax.servlet.http.HttpServletRequest;
|
|
|
|
+import javax.validation.Valid;
|
|
|
|
+import java.io.IOException;
|
|
|
|
+import java.util.Collections;
|
|
|
|
+import java.util.List;
|
|
import java.util.Map;
|
|
import java.util.Map;
|
|
|
|
+import java.util.Objects;
|
|
|
|
|
|
/**
|
|
/**
|
|
* <p>
|
|
* <p>
|
|
@@ -34,10 +60,23 @@ import java.util.Map;
|
|
@RequestMapping(ApiConstant.DEFAULT_URI_PREFIX + "/${prefix.url.sys}/user")
|
|
@RequestMapping(ApiConstant.DEFAULT_URI_PREFIX + "/${prefix.url.sys}/user")
|
|
@Aac(auth = BOOL.FALSE)
|
|
@Aac(auth = BOOL.FALSE)
|
|
public class SysUserController {
|
|
public class SysUserController {
|
|
|
|
+ private final static Logger log = LoggerFactory.getLogger(SysUserController.class);
|
|
|
|
|
|
@Autowired
|
|
@Autowired
|
|
private SysUserService sysUserService;
|
|
private SysUserService sysUserService;
|
|
|
|
|
|
|
|
+ @Resource
|
|
|
|
+ BasicAttachmentService basicAttachmentService;
|
|
|
|
+
|
|
|
|
+ @Resource
|
|
|
|
+ UserImportTempleteService userImportTempleteService;
|
|
|
|
+
|
|
|
|
+ @Resource
|
|
|
|
+ AsyncUserImportTempleteService asyncUserImportTempleteService;
|
|
|
|
+
|
|
|
|
+ @Resource
|
|
|
|
+ TBTaskService tbTaskService;
|
|
|
|
+
|
|
/**
|
|
/**
|
|
* 查询
|
|
* 查询
|
|
* @param request
|
|
* @param request
|
|
@@ -124,5 +163,54 @@ public class SysUserController {
|
|
boolean isSuccess = sysUserService.bindRoles(sysUser);
|
|
boolean isSuccess = sysUserService.bindRoles(sysUser);
|
|
return ResultUtil.ok(isSuccess);
|
|
return ResultUtil.ok(isSuccess);
|
|
}
|
|
}
|
|
|
|
+
|
|
|
|
+ @ApiOperation(value = "用户批量导入接口")
|
|
|
|
+ @RequestMapping(value = "/import", method = RequestMethod.POST)
|
|
|
|
+ @ApiResponses({@ApiResponse(code = 200, message = "返回信息", response = EditResult.class)})
|
|
|
|
+ @Transactional
|
|
|
|
+ public Result userImport(@ApiParam(value = "上传文件", required = true) @RequestParam MultipartFile file) {
|
|
|
|
+ BasicAttachment basicAttachment = null;
|
|
|
|
+ try {
|
|
|
|
+ basicAttachment = basicAttachmentService.saveAttachment(file, ServletUtil.getRequestMd5(), UploadFileEnum.FILE);
|
|
|
|
+ if (Objects.isNull(basicAttachment)) {
|
|
|
|
+ throw ExceptionResultEnum.ATTACHMENT_ERROR.exception();
|
|
|
|
+ } else {
|
|
|
|
+ userImportTempleteService.importTask(Collections.singletonMap(SystemConstant.FILE, file));
|
|
|
|
+ }
|
|
|
|
+ } catch (Exception e) {
|
|
|
|
+ log.error("请求出错", e);
|
|
|
|
+ if (Objects.nonNull(basicAttachment)) {
|
|
|
|
+ basicAttachmentService.deleteAttachment(basicAttachment);
|
|
|
|
+ }
|
|
|
|
+ if (e instanceof ApiException) {
|
|
|
|
+ ResultUtil.error((ApiException) e, e.getMessage());
|
|
|
|
+ } else {
|
|
|
|
+ ResultUtil.error(e.getMessage());
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ return ResultUtil.ok();
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @ApiOperation(value = "异步用户批量导入接口")
|
|
|
|
+ @RequestMapping(value = "/async/import", method = RequestMethod.POST)
|
|
|
|
+ @ApiResponses({@ApiResponse(code = 200, message = "返回信息", response = EditResult.class)})
|
|
|
|
+ public Result userImportAysnc(@ApiParam(value = "上传文件", required = true) @RequestParam MultipartFile file) throws IOException {
|
|
|
|
+ Map<String, Object> map = tbTaskService.saveTask(file, TaskTypeEnum.USER_IMPORT);
|
|
|
|
+ asyncUserImportTempleteService.importTask(map);
|
|
|
|
+ TBTask tbTask = Objects.nonNull(map.get(SystemConstant.TASK)) ? (TBTask) map.get(SystemConstant.TASK) : null;
|
|
|
|
+ return Objects.nonNull(tbTask) ? ResultUtil.ok(tbTask.getId()) : ResultUtil.error("创建任务失败");
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @ApiOperation(value = "用户批量导出接口")
|
|
|
|
+ @RequestMapping(value = "/export", method = RequestMethod.POST)
|
|
|
|
+ @ApiResponses({@ApiResponse(code = 200, message = "返回信息", response = EditResult.class)})
|
|
|
|
+ public Result export(@ApiParam(value = "数组id", required = true) @Valid @RequestBody ArraysParams arraysParams, BindingResult bindingResult) throws Exception {
|
|
|
|
+ if (bindingResult.hasErrors()) {
|
|
|
|
+ return ResultUtil.error(bindingResult.getAllErrors().get(0).getDefaultMessage());
|
|
|
|
+ }
|
|
|
|
+ List<UserExportDto> userExportDtoList = sysUserService.queryByExport(arraysParams);
|
|
|
|
+ ExcelUtil.excelExport("用户列表", UserExportDto.class, userExportDtoList, ServletUtil.getResponse());
|
|
|
|
+ return ResultUtil.ok();
|
|
|
|
+ }
|
|
}
|
|
}
|
|
|
|
|