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 |  209 +++++++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 196 insertions(+), 13 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 7dac69e..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;
@@ -18,9 +23,13 @@
 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;
 
@@ -72,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当做查询条件进行查询")
@@ -86,22 +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
+    @PostMapping("/{hosId}")
     @Transactional(rollbackFor = {Exception.class})
-    public ResultBody save(@Valid @RequestBody SysDepartment sysDepartment, BindingResult bindingResult) {
+    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()) {
@@ -111,11 +150,8 @@
         } else {
             //先检查该医院该科室是否已经存在
             if (sysDepartment.getId() == null) {
-                Map<String, Object> checkDepartment = new HashMap<String, Object>();
-                checkDepartment.put("page", 1);
-                checkDepartment.put("limit", 1);
-                checkDepartment.put("departmentName", sysDepartment.getDepartmentName());
-                if (sysDepartmentService.findList(checkDepartment).getData().size() > 0) {
+
+                if (departMentNameIsUsed(hosId, sysDepartment.getDepartmentName())) {
                     return ResultBody.failed().msg(String.format("该医院下已经存在科室 %s", sysDepartment.getDepartmentName()));
                 }
             }
@@ -137,6 +173,9 @@
                 sysOrganization.setOrgLevel(2);
                 //临时暂用其它字段承载数据
                 sysOrganization.setOrgParentId(sysDepartment.getUpdateUserId());
+                if (!sysUser.getOrganizations().isEmpty()) {
+                    sysOrganization.setCreateUserOrgCode(sysUser.getOrganizations().get(1).getOrgCode());
+                }
             } else {
                 sysOrganization.setOrgName(sysDepartment.getDepartmentName());
             }
@@ -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