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 | 273 ++++++++++++++++++++++++++++++++++++++++++++++++++---- 1 files changed, 251 insertions(+), 22 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 e06449c..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,21 +1,34 @@ 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; import io.swagger.annotations.Api; import io.swagger.annotations.ApiImplicitParam; import io.swagger.annotations.ApiImplicitParams; 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.List; import java.util.Map; @@ -23,6 +36,7 @@ /** * 石家庄喜高科技有限责任公司 版权所有 © Copyright 2020<br> + * * @Description: 科室表 * @Project: 用户中心 * @CreateDate: Created in 2020-04-02 18:32:36 <br> @@ -33,9 +47,11 @@ @RestController @RequestMapping("/sysdepartment") @Api(tags = "科室表") -public class SysDepartmentController extends BaseController{ +public class SysDepartmentController extends BaseController { @Autowired private ISysDepartmentService sysDepartmentService; + @Autowired + private ISysOrganizationService sysOrganizationService; /** * 列表 @@ -47,9 +63,9 @@ }) @GetMapping public ResultBody<PageResult> list(@RequestParam Map<String, Object> params) { - if(params.size()==0){ - params.put("page",1); - params.put("limit",10); + if (params.size() == 0) { + params.put("page", 1); + params.put("limit", 10); } return ResultBody.ok().data(sysDepartmentService.findList(params)); } @@ -65,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当做查询条件进行查询") @@ -75,31 +111,80 @@ } /** + * 检查科室名是否存在 + */ + @ApiOperation(value = "检查科室名是否存在") + @GetMapping("/checkName") + 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) { - List<String> errMsg= new ArrayList<>(); + @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()) { errMsg.add(error.getDefaultMessage()); } return ResultBody.failed().msg(errMsg.toString()); } else { - //先检查该医院下的该科室名是否已经存在? - SysDepartment sysDepartmentTemp=new SysDepartment(); - sysDepartmentTemp.setHospitalId(sysDepartment.getHospitalId()); - sysDepartmentTemp.setDepartmentName(sysDepartment.getDepartmentName().trim()); - sysDepartmentTemp=sysDepartmentService.findByObject(sysDepartmentTemp); - if (sysDepartmentTemp!=null) { - 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())); + } } - boolean v= sysDepartmentService.saveOrUpdate(sysDepartment); - if(v) { + //先检查是否存在组织信息 + 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 = new SysOrganization(); + sysOrganization.setOrgName(sysDepartment.getDepartmentName()); + sysOrganization.setOrgAttr(2); + sysOrganization.setOrgLevel(2); + //临时暂用其它字段承载数据 + sysOrganization.setOrgParentId(sysDepartment.getUpdateUserId()); + if (!sysUser.getOrganizations().isEmpty()) { + sysOrganization.setCreateUserOrgCode(sysUser.getOrganizations().get(1).getOrgCode()); + } + } else { + sysOrganization.setOrgName(sysDepartment.getDepartmentName()); + } + boolean org = sysOrganizationService.saveOrUpdateSer(sysOrganization); + sysDepartment.setOrgId(sysOrganization.getId()); + boolean v = sysDepartmentService.saveOrUpdate(sysDepartment); + if (v) { return ResultBody.ok().data(sysDepartment).msg("保存成功"); - } - else { + } else { return ResultBody.failed().msg("保存失败"); } } @@ -111,17 +196,17 @@ @ApiOperation(value = "删除") @DeleteMapping("/{id}") public ResultBody delete(@PathVariable Long id) { - boolean v= sysDepartmentService.removeById(id); - if(v) { + boolean v = sysDepartmentService.removeById(id); + if (v) { return ResultBody.ok().msg("删除成功"); - } - else { + } else { return ResultBody.failed().msg("删除失败"); } } /** * 根据医院获取 组织,通过组织,获取科室; + * * @param params * @return */ @@ -129,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