From c1b942ccf2ee1ab5d01ae590d6a16ce14d0cf54b Mon Sep 17 00:00:00 2001 From: luliqiang <kidgrow> Date: Fri, 12 Mar 2021 19:21:45 +0800 Subject: [PATCH] 1、增加私有云客户创建时的标识位和服务器Guuid 2、增加私有云服务器License下载 3、增加私有云数据库下载 --- kidgrow-business/kidgrow-usercenter/kidgrow-usercenter-server/src/main/java/com/kidgrow/usercenter/controller/SysDepartmentController.java | 237 ++++++++++++++++++++++++++++++++++++++++++++++++++++------ 1 files changed, 210 insertions(+), 27 deletions(-) diff --git a/kidgrow-business/kidgrow-usercenter/kidgrow-usercenter-server/src/main/java/com/kidgrow/usercenter/controller/SysDepartmentController.java b/kidgrow-business/kidgrow-usercenter/kidgrow-usercenter-server/src/main/java/com/kidgrow/usercenter/controller/SysDepartmentController.java index 08b11d1..5eb5a1c 100644 --- a/kidgrow-business/kidgrow-usercenter/kidgrow-usercenter-server/src/main/java/com/kidgrow/usercenter/controller/SysDepartmentController.java +++ b/kidgrow-business/kidgrow-usercenter/kidgrow-usercenter-server/src/main/java/com/kidgrow/usercenter/controller/SysDepartmentController.java @@ -1,9 +1,14 @@ package com.kidgrow.usercenter.controller; +import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; +import com.kidgrow.common.annotation.LoginUser; import com.kidgrow.common.controller.BaseController; import com.kidgrow.common.model.PageResult; import com.kidgrow.common.model.ResultBody; import com.kidgrow.common.model.SysOrganization; +import com.kidgrow.common.model.SysUser; +import com.kidgrow.common.utils.AesUtils; +import com.kidgrow.common.utils.StringUtils; import com.kidgrow.usercenter.model.SysDepartment; import com.kidgrow.usercenter.service.ISysDepartmentService; import com.kidgrow.usercenter.service.ISysOrganizationService; @@ -13,13 +18,18 @@ import io.swagger.annotations.ApiOperation; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.transaction.annotation.Transactional; import org.springframework.validation.BindingResult; import org.springframework.validation.ObjectError; import org.springframework.web.bind.annotation.*; +import javax.servlet.http.HttpServletResponse; import javax.validation.Valid; +import java.io.ByteArrayInputStream; +import java.io.IOException; +import java.io.InputStream; +import java.io.OutputStream; import java.util.ArrayList; -import java.util.HashMap; import java.util.List; import java.util.Map; @@ -71,6 +81,26 @@ } /** + * 查询 + */ + @ApiOperation(value = "更新支付功能的开通状态") + @GetMapping("/updatePay") + public ResultBody updatePay(Long departmentId, Boolean isPay) { + boolean isPays = sysDepartmentService.updatePay(departmentId, isPay); + return ResultBody.ok().data(isPays).msg("操作成功"); + } + + /** + * 查询 + */ + @ApiOperation(value = "查看支付功能的开通状态") + @GetMapping("/getPayMes") + public ResultBody getPayMes(Long departmentId) { + SysDepartment model = sysDepartmentService.getById(departmentId); + return ResultBody.ok().data(model.getIsPay()).msg("操作成功"); + } + + /** * 根据SysDepartment当做查询条件进行查询 */ @ApiOperation(value = "根据SysDepartment当做查询条件进行查询") @@ -85,21 +115,32 @@ */ @ApiOperation(value = "检查科室名是否存在") @GetMapping("/checkName") - public ResultBody checkDepName(@RequestParam Map<String, Object> params) { - params.put("page", 1); - params.put("limit", 1); - if (sysDepartmentService.findList(params).getData().size()>0) { - return ResultBody.failed().msg(String.format("该医院下已经存在科室 %s", params.get("departmentName"))); + public ResultBody checkDepName(Long hospitalId, String departmentName) { + if (departMentNameIsUsed(hospitalId, departmentName)) { + return ResultBody.failed().msg(String.format("该医院下已经存在科室 %s", departmentName)); } return ResultBody.ok().msg(""); + } + + /** + * 检查科室名是否存在 + * + * @param hosId + * @param departmentName + * @return + */ + private Boolean departMentNameIsUsed(Long hosId, String departmentName) { + String departName = sysDepartmentService.checkDepartmentName(hosId, departmentName); + return StringUtils.isNotBlank(departName); } /** * 新增or更新 */ @ApiOperation(value = "保存") - @PostMapping - public ResultBody save(@Valid @RequestBody SysDepartment sysDepartment, BindingResult bindingResult) { + @PostMapping("/{hosId}") + @Transactional(rollbackFor = {Exception.class}) + public ResultBody save(@Valid @RequestBody SysDepartment sysDepartment, @PathVariable Long hosId, BindingResult bindingResult, @LoginUser SysUser sysUser) { List<String> errMsg = new ArrayList<>(); if (bindingResult.hasErrors()) { for (ObjectError error : bindingResult.getAllErrors()) { @@ -108,39 +149,37 @@ return ResultBody.failed().msg(errMsg.toString()); } else { //先检查该医院该科室是否已经存在 - Map<String, Object> checkDepartment=new HashMap<String,Object>(); - checkDepartment.put("page", 1); - checkDepartment.put("limit", 1); - checkDepartment.put("hospitalId",sysDepartment.getHospitalId()); - checkDepartment.put("departmentName",sysDepartment.getDepartmentName()); - if (sysDepartmentService.findList(checkDepartment).getData().size()>0) { - return ResultBody.failed().msg(String.format("该医院下已经存在科室 %s", sysDepartment.getDepartmentName())); + if (sysDepartment.getId() == null) { + + if (departMentNameIsUsed(hosId, sysDepartment.getDepartmentName())) { + return ResultBody.failed().msg(String.format("该医院下已经存在科室 %s", sysDepartment.getDepartmentName())); + } } //先检查是否存在组织信息 - SysOrganization sysOrganization=new SysOrganization(); - if(sysDepartment.getOrgId()!=null){ - sysOrganization.setId(sysDepartment.getOrgId());} - else{ + SysOrganization sysOrganization = new SysOrganization(); + if (sysDepartment.getOrgId() != null) { + sysOrganization.setId(sysDepartment.getOrgId()); + } else { sysOrganization.setOrgName(sysDepartment.getDepartmentName()); //临时暂用其它字段承载数据 sysOrganization.setOrgParentId(sysDepartment.getUpdateUserId()); } - sysOrganization=sysOrganizationService.findByObject(sysOrganization); - if(sysOrganization==null) - { + sysOrganization = sysOrganizationService.findByObject(sysOrganization); + if (sysOrganization == null) { //创建一个组织 - sysOrganization=new SysOrganization(); + sysOrganization = new SysOrganization(); sysOrganization.setOrgName(sysDepartment.getDepartmentName()); sysOrganization.setOrgAttr(2); sysOrganization.setOrgLevel(2); //临时暂用其它字段承载数据 sysOrganization.setOrgParentId(sysDepartment.getUpdateUserId()); - } - else - { + if (!sysUser.getOrganizations().isEmpty()) { + sysOrganization.setCreateUserOrgCode(sysUser.getOrganizations().get(1).getOrgCode()); + } + } else { sysOrganization.setOrgName(sysDepartment.getDepartmentName()); } - boolean org=sysOrganizationService.saveOrUpdate(sysOrganization); + boolean org = sysOrganizationService.saveOrUpdateSer(sysOrganization); sysDepartment.setOrgId(sysOrganization.getId()); boolean v = sysDepartmentService.saveOrUpdate(sysDepartment); if (v) { @@ -175,4 +214,148 @@ public ResultBody findListByHospitalId(@RequestParam Map<String, Object> params) { return sysDepartmentService.findListByHospitalId(params); } + + @PostMapping + public ResultBody update(@RequestBody SysDepartment sysDepartment) { + if (sysDepartment.getId() == null) { + return ResultBody.failed("请输入id"); + } + QueryWrapper queryWrapper = new QueryWrapper(); + queryWrapper.eq("id", sysDepartment.getId()); + boolean update = sysDepartmentService.update(sysDepartment, queryWrapper); + if (update) { + return ResultBody.ok(); + } else { + return ResultBody.failed("更新数据失败"); + } + } + + /** + * 运动处方调用 是否开通服务 + */ + + @PostMapping("getHealth") + public ResultBody getHealth(@RequestBody SysDepartment sysDepartment) { + if (sysDepartment.getId() == null) { + return ResultBody.failed("请输入id"); + } + return sysDepartmentService.getHealth(sysDepartment); + } + + /** + * 下载私有云服务器License文件 + * + * @param departmentId 科室ID + * @param response HttpServletResponse + * @return void + */ + @PostMapping("/downloadLicense") + public void downloadLicense(@RequestParam Long departmentId, HttpServletResponse response) { + + SysDepartment department = sysDepartmentService.getById(departmentId); + String serverLicense = ""; + + OutputStream out = null; + InputStream fileInputStream = null; + try { + if (department != null) { + if (department.getIsPrivate() == 1) { + if ((department.getPrivateServerGuuid() != null) && (!department.getPrivateServerGuuid().isEmpty())) { + serverLicense = AesUtils.encrypt(department.getPrivateServerGuuid()); + + } else { + serverLicense = String.format("此科室【%s】未设置服务器GUUID,不能下载私有云服务器License", departmentId); + log.error(serverLicense); + } + } else { + serverLicense = String.format("此科室【%s】非私有云客户,不能下载私有云服务器License", departmentId); + log.error(serverLicense); + } + } else { + serverLicense = String.format("此科室【%s】不存在,不能下载私有云服务器License", departmentId); + log.error(serverLicense); + } + + + + + byte[] arr = serverLicense.getBytes(); + + // 设置输出的格式 + response.reset(); + response.setContentType("application/x-msdownload"); + response.addHeader("Content-Length", "" + arr.length); + response.addHeader("Content-Disposition", "attachment; filename=\"" + department.getDepartmentName() + "License.txt\""); + + + out = response.getOutputStream(); + fileInputStream = new ByteArrayInputStream(arr); + byte[] buffer = new byte[1024 * 10]; + int len = 0; + while ((len = fileInputStream.read(buffer)) > 0) { + out.write(buffer, 0, len); + } + } catch (Exception e) { + e.printStackTrace(); + //log.error("私有云服务器Guuid加密出错"); + } finally { + + if (fileInputStream != null) { + try { + fileInputStream.close(); + } catch (IOException e) { + e.printStackTrace(); + } + } + } + } + + /** + * 下载私有云本地数据库初始化数据 + * @param hospitalId + * @param departmentId + * @param response + * @return void + */ + @PostMapping("/downloadData") + public void downloadPrivateData(@RequestParam("hospitalId") Long hospitalId,@RequestParam("departmentId") Long departmentId, HttpServletResponse response){ + String dataSql = ""; + + dataSql = sysDepartmentService.initPrivateData(hospitalId,departmentId); + + OutputStream out = null; + InputStream fileInputStream = null; + try { + byte[] arr = dataSql.getBytes(); + + // 设置输出的格式 + response.reset(); + response.setContentType("application/x-msdownload"); + response.addHeader("Content-Length", "" + arr.length); + response.addHeader("Content-Disposition", "attachment; filename=\"" + departmentId.toString() + ".sql\""); + + + out = response.getOutputStream(); + fileInputStream = new ByteArrayInputStream(arr); + byte[] buffer = new byte[1024 * 10]; + int len = 0; + while ((len = fileInputStream.read(buffer)) > 0) { + out.write(buffer, 0, len); + } + } catch (Exception e) { + e.printStackTrace(); + + } finally { + + if (fileInputStream != null) { + try { + fileInputStream.close(); + } catch (IOException e) { + e.printStackTrace(); + } + } + } + + } + } -- Gitblit v1.8.0