智慧保安后台管理-外网
Administrator
2022-06-21 f61f487b258cf68b77ec9b9ddb0badfd94ce430b
src/main/java/org/springblade/modules/information/controller/InformationController.java
@@ -17,33 +17,48 @@
package org.springblade.modules.information.controller;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import lombok.AllArgsConstructor;
import com.alibaba.fastjson.JSON;
import org.springblade.common.cache.DictCache;
import org.springblade.common.constant.FtpConstant;
import org.springblade.common.config.FtpConfig;
import org.springblade.common.enums.DictEnum;
import org.springblade.common.utils.DesensitizedUtil;
import org.springblade.core.boot.ctrl.BladeController;
import org.springblade.core.cache.utils.CacheUtil;
import org.springblade.core.excel.util.ExcelUtil;
import org.springblade.core.log.exception.ServiceException;
import org.springblade.core.mp.support.Condition;
import org.springblade.core.mp.support.Query;
import org.springblade.core.tool.api.R;
import org.springblade.core.tool.support.Kv;
import org.springblade.core.tool.utils.*;
import org.springblade.modules.FTP.FtpUtil;
import org.springblade.modules.FTP.OutJson;
import org.springblade.modules.dispatcher.entity.DispatcherUnit;
import org.springblade.modules.information.entity.Information;
import org.springblade.modules.information.excel.ExportInformationExcel;
import org.springblade.modules.information.excel.ExportInformationSecurityStatistics;
import org.springblade.modules.information.excel.InforExcel;
import org.springblade.modules.information.excel.InforImporter;
import org.springblade.modules.information.service.IInformationService;
import org.springblade.modules.information.vo.InformationVO;
import org.springblade.modules.system.entity.Dept;
import org.springblade.modules.system.entity.Role;
import org.springblade.modules.system.entity.User;
import org.springblade.modules.system.service.IDeptService;
import org.springblade.modules.system.service.IRoleService;
import org.springblade.modules.system.service.IUserService;
import org.springblade.modules.system.service.MyAsyncService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.multipart.MultipartFile;
import javax.servlet.http.HttpServletResponse;
import javax.validation.Valid;
import java.io.*;
import java.text.DateFormat;
@@ -77,6 +92,12 @@
   private final IInformationService informationService;
   private final IDeptService iDeptService;
   private final IUserService userService;
   private final IRoleService roleService;
   private final MyAsyncService myAsyncService;
   /**
    * 详情
@@ -128,53 +149,38 @@
   @PostMapping("/save")
   @ApiOperationSupport(order = 4)
   @ApiOperation(value = "新增", notes = "传入information")
   public R save(@Valid @RequestBody Information information) throws Exception {
   @Transactional(rollbackFor = Exception.class)
   public R save(@Valid @RequestBody Information information) {
      Dept dept = new Dept();
      //自招保安公司
      if (information.getStats().equals("0")) {
         Long i = 1420222768149966850L;
         dept.setParentId(i);
         dept.setTenantId("000000");
         dept.setDeptName(information.getEnterprisename());
         dept.setParentId(1420222768149966850L);
         dept.setAncestors("0,1420222768149966850");
         dept.setDeptCategory(1);
      }
      //保安培训公司
      if (information.getStats().equals("1")) {
         Long i = 1418458374477549569L;
         dept.setParentId(i);
         dept.setTenantId("000000");
         dept.setDeptName(information.getEnterprisename());
         dept.setParentId(1418458374477549569L);
         dept.setAncestors("0,1418458374477549569");
         dept.setDeptCategory(1);
      }
      //保安服务公司
      if (information.getStats().equals("2")) {
         Long i = 1413470343230877697L;
         dept.setParentId(i);
         dept.setTenantId("000000");
         dept.setDeptName(information.getEnterprisename());
         dept.setParentId(1413470343230877697L);
         dept.setAncestors("0,1413470343230877697");
         dept.setDeptCategory(1);
      }
      //武装守押公司
      if (information.getStats().equals("3")) {
         Long i = 1420222961377357825L;
         dept.setParentId(i);
         dept.setTenantId("000000");
         dept.setDeptName(information.getEnterprisename());
         dept.setParentId(1420222961377357825L);
         dept.setAncestors("0,1420222961377357825");
         dept.setDeptCategory(1);
      }
      //跨区域保安公司
      if (information.getStats().equals("4")) {
         Long i = 1425366663452196865L;
         dept.setParentId(i);
         dept.setTenantId("000000");
         dept.setDeptName(information.getEnterprisename());
         dept.setParentId(1425366663452196865L);
         dept.setAncestors("0,1425366663452196865");
         dept.setDeptCategory(1);
      }
      dept.setTenantId("000000");
      dept.setDeptName(information.getEnterprisename());
      dept.setDeptCategory(1);
      if (iDeptService.submit(dept)) {
         CacheUtil.clear(SYS_CACHE);
         // 返回懒加载树更新节点所需字段
@@ -183,21 +189,102 @@
         String id = kv.get("id").toString();
         information.setDepartmentid(id);
      }
      informationService.save(information);
      String formatStr = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(information.getEstablishtime());
      //Integer id = information.getId();
      String s = "insert into sys_information(id,creditCode,enterpriseName,representative,establishTime," +
         "registeredCapital,organizationCode,registrationNumber, enterprises, address," +
         " business,region,registration,industry,departmentid,stats,jurisdiction,representativecell,contacts,contactscell) " +
         "values(" + "'" + information.getId() + "'" + "," + "'" + information.getCreditcode() + "'" + "," + "'" + information.getEnterprisename() + "'" + "," + "'" + information.getRepresentative() + "'" + "," +
         "'" + formatStr + "'" + "," + "'" + information.getRegisteredcapital() + "'" + "," + "'" + information.getOrganizationcode() + "'" + "," + "'" + information.getRegistrationnumber() + "'" + "," + "'" + information.getEnterprises() + "'" + "," + "'" +
         information.getAddress() + "'" + "," + "'" + information.getBusiness() + "'" + "," + "'" +
         information.getRegion() + "'" + "," + "'" + information.getRegistration() + "'" + "," + "'" + information.getIndustry() + "'" + "," + "'" + information.getDepartmentid() + "'" + "," +
         "'" + information.getStats() + "'" + "," + "'" + information.getJurisdiction() + "'" + "," + "'" + information.getRepresentativecell() + "'" + "," +
         "'" + information.getContacts() + "'" + "," + "'" + information.getContactscell() + "'" + ");" +
         "insert into blade_dept(id,parent_id,tenant_id,dept_name,ancestors,dept_category) values(" + "'" + information.getDepartmentid() + "'" + "," + "'" + dept.getParentId() + "'" + ","
         + "'" + dept.getTenantId() + "'" + "," + "'" + information.getEnterprisename() + "'" + "," + "'" + dept.getAncestors() + "'" + "," + "'" + dept.getDeptCategory() + "'" + ")";
      FtpUtil.sqlFileUpload(s);
      information.setCreateTime(new Date());
      Information information1 = Objects.requireNonNull(BeanUtil.copy(information, Information.class));
      //敏感数据处理
      if (null!=information1.getRepresentativecell() && !information1.getRepresentativecell().equals("")) {
         information1.setRepresentativecell(DesensitizedUtil.desensitizedPhoneNumber(information1.getRepresentativecell()));
      }
      if (null!=information1.getContacts() && !information1.getContacts().equals("")) {
         information1.setContacts(DesensitizedUtil.desensitizedName(information1.getContacts()));
      }
      if (null!=information1.getContactscell() && !information1.getContactscell().equals("")) {
         information1.setContactscell(DesensitizedUtil.desensitizedPhoneNumber(information1.getContactscell()));
      }
      //公司新增
      boolean status = informationService.save(information1);
      //公司新增成功则创建默认账户,公司名即为账号名,默认密码为 123456
      if (status) {
         User user = new User();
         user.setAccount(information.getEnterprisename());
         user.setPassword(DigestUtil.encrypt("123456"));
         Integer userCount = userService.selectCount(information.getEnterprisename());
         if (userCount > 0 && Func.isEmpty(user.getId())) {
            throw new ServiceException(StringUtil.format("当前用户 [{}] 已存在!", user.getAccount()));
         }
         user.setDeptId(information.getDepartmentid());
         user.setTenantId("000000");
         user.setCreateUser(Long.parseLong(information.getCreateUserId()));
         user.setCreateTime(new Date());
         user.setUpdateTime(new Date());
         user.setStatus(1);
         user.setIsDeleted(0);
         //分配保安角色
         //如果是本市保安公司,分公司,自招保安公司,分配保安公司管理员角色,如果是培训学校,则分配的是培训公司管理员角色
         Role role = new Role();
         if (information.getStats().equals("1")) {
            role.setRoleAlias("培训公司管理员");
         } else {
            role.setRoleAlias("保安公司管理员");
         }
         Role oneRole = roleService.getOne(Condition.getQueryWrapper(role));
         user.setRoleId(oneRole.getId().toString());
         //插入用户数据
         boolean save = userService.save(user);
         if (save) {
            Integer isDeleted = 0;
            String s = "insert into sys_information(id,creditCode,enterpriseName,representative" +
               ",registeredCapital,organizationCode,registrationNumber, enterprises, address," +
               " business,region,registration,industry,departmentid,stats,jurisdiction,representativecell," +
               "contacts,contactscell,create_time,create_user_id) " +
               "values(" + "'" + information1.getId() + "'" +
               "," + "'" + information.getCreditcode() + "'" +
               "," + "'" + information.getEnterprisename() + "'" +
               "," + "'" + information.getRepresentative() + "'" +
               "," + "'" + information.getRegisteredcapital() + "'" +
               "," + "'" + information.getOrganizationcode() + "'" +
               "," + "'" + information.getRegistrationnumber() + "'" +
               "," + "'" + information.getEnterprises() + "'" +
               "," + "'" + information.getAddress() + "'" +
               "," + "'" + information.getBusiness() + "'" +
               "," + "'" + information.getRegion() + "'" +
               "," + "'" + information.getRegistration() + "'" +
               "," + "'" + information.getIndustry() + "'" +
               "," + "'" + information.getDepartmentid() + "'" +
               "," + "'" + information.getStats() + "'" +
               "," + "'" + information.getJurisdiction() + "'" +
               "," + "'" + information.getRepresentativecell() + "'" +
               "," + "'" + information.getContacts() + "'" +
               "," + "'" + information.getContactscell() + "'" +
               "," + "'" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(information.getCreateTime()) + "'" +
               "," + "'" + information.getCreateUserId() + "'" + ");" +
               "insert into blade_dept(id,parent_id,tenant_id,dept_name,ancestors,dept_category,is_deleted) values(" + "'" + information.getDepartmentid() + "'" + "," + "'" + dept.getParentId() + "'" + ","
               + "'" + dept.getTenantId() + "'" +
               "," + "'" + information.getEnterprisename() + "'" +
               "," + "'" + dept.getAncestors() + "'" +
               "," + "'" + dept.getDeptCategory() + "'" +
               "," + "'" + isDeleted + "'" + ");" +
               "insert into blade_user(id,tenant_id,account,password,dept_id,create_user,create_time,update_time,status,is_deleted,role_id) " +
               "values(" + "'" + user.getId() + "'" +
               "," + "'" + user.getTenantId() + "'"
               + "," + "'" + user.getAccount() + "'" +
               "," + "'" + user.getPassword() + "'" +
               "," + "'" + user.getDeptId() + "'" +
               "," + "'" + user.getCreateUser() + "'" +
               "," + "'" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(user.getCreateTime()) + "'" +
               "," + "'" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(user.getUpdateTime()) + "'" +
               "," + "'" + user.getStatus() + "'" +
               "," + "'" + user.getIsDeleted() + "'" +
               "," + "'" + user.getRoleId() + "'" + ")";
            //FtpUtil.sqlFileUpload(s);
            myAsyncService.FTP(s);
         }
      }
      return R.success("成功");
   }
@@ -208,41 +295,97 @@
   @ApiOperationSupport(order = 5)
   @ApiOperation(value = "修改", notes = "传入information")
   public R update(@Valid @RequestBody Information information) throws Exception {
      informationService.updateById(information);
      String businessLicense=null;
      String licence=null;
      String format="";
      if(information.getBusinessLicense()!=null && !"".equals(information.getBusinessLicense())){
          businessLicense = information.getBusinessLicense().substring(26, information.getBusinessLicense().length());
      Information information1 = Objects.requireNonNull(BeanUtil.copy(information, Information.class));
      StringBuilder builder = new StringBuilder();
      //敏感数据处理
      if (null!=information1.getRepresentativecell() && !information1.getRepresentativecell().equals("")) {
         information1.setRepresentativecell(DesensitizedUtil.desensitizedPhoneNumber(information1.getRepresentativecell()));
         //如果带 * 则不修改
         if (!information.getRepresentativecell().contains("*")){
            builder.append(",representativecell = " + "'" + information.getRepresentativecell() + "'");
         }
      }
      if(information.getLicence()!=null && !"".equals(information.getLicence())){
          licence = information.getLicence().substring(26, information.getLicence().length());
      if (null!=information1.getContacts() && !information1.getContacts().equals("")) {
         information1.setContacts(DesensitizedUtil.desensitizedName(information1.getContacts()));
         //如果带 * 则不修改
         if (!information.getContacts().contains("*")){
            builder.append(",contacts = " + "'" + information.getContacts() + "'");
         }
      }
      if (information.getEstablishtime()!=null && !"".equals(information.getEstablishtime())){
          format = new SimpleDateFormat("yyyy-MM-dd").format(information.getEstablishtime());
      if (null!=information1.getContactscell() && !information1.getContactscell().equals("")) {
         information1.setContactscell(DesensitizedUtil.desensitizedPhoneNumber(information1.getContactscell()));
         //如果带 * 则不修改
         if (!information.getContactscell().contains("*")){
            builder.append(",contactscell = " + "'" + information.getContactscell() + "'");
         }
      }
      //内网同步
      String s1 = "update sys_information set creditCode = " + "'" + information.getCreditcode() + "'" +
         ",enterpriseName = " + "'" + information.getEnterprisename() + "'" +
         ",representative = " + "'" + information.getRepresentative() + "'" +
         ",establishTime = " + "'" + format + "'" +
         ",registeredCapital = " + "'" + information.getRegisteredcapital() + "'" +
         ",jurisdiction = " + "'" + information.getJurisdiction() + "'" +
         ",enterprises = " + "'" + information.getEnterprises() + "'" +
         ",address = " + "'" + information.getAddress() + "'" +
         ",business = " + "'" + information.getBusiness() + "'" +
         ",region = " + "'" + information.getRegion() + "'" +
         ",registration = " + "'" + information.getRegistration() + "'" +
         ",industry = " + "'" + information.getIndustry() + "'" +
         ",departmentid = " + "'" + information.getDepartmentid() + "'" +
         ",stats = " + "'" + information.getStats() + "'" +
         ",representativecell = " + "'" + information.getRepresentativecell() + "'" +
         ",contacts = " + "'" + information.getContacts() + "'" +
         ",contactscell = " + "'" + information.getContactscell() + "'" +
         ",business_License = " + "'" + FtpConstant.ip + businessLicense + "'" +
         ",licence = " + "'" + FtpConstant.ip + licence + "'" +
         " " + "where id = " + "'" + information.getId() + "'";
      FtpUtil.sqlFileUpload(s1);
      boolean b = informationService.updateById(information1);
      if (b) {
         String businessLicense = null;
         String businessLicenses = null;
         String licence = null;
         String licences = null;
         String format = "";
         if (information.getBusinessLicense() != null && !"".equals(information.getBusinessLicense())) {
            businessLicense = information.getBusinessLicense().substring(26, information.getBusinessLicense().length());
            businessLicenses = FtpConfig.ip + businessLicense;
         } else {
            businessLicenses = "";
         }
         if (information.getLicence() != null && !"".equals(information.getLicence())) {
            licence = information.getLicence().substring(26, information.getLicence().length());
            licences = FtpConfig.ip + licence;
         } else {
            licences = "";
         }
         if (information.getEstablishtime() != null && !"".equals(information.getEstablishtime())) {
            format = new SimpleDateFormat("yyyy-MM-dd").format(information.getEstablishtime());
            builder.append(",establishTime = " + "'" + format + "'");
            //内网同步
            String s1 = "update sys_information set creditCode = " + "'" + information.getCreditcode() + "'" +
               ",enterpriseName = " + "'" + information.getEnterprisename() + "'" +
               ",representative = " + "'" + information.getRepresentative() + "'" +
               ",registeredCapital = " + "'" + information.getRegisteredcapital() + "'" +
               ",jurisdiction = " + "'" + information.getJurisdiction() + "'" +
               ",enterprises = " + "'" + information.getEnterprises() + "'" +
               ",address = " + "'" + information.getAddress() + "'" +
               ",business = " + "'" + information.getBusiness() + "'" +
               ",region = " + "'" + information.getRegion() + "'" +
               ",registration = " + "'" + information.getRegistration() + "'" +
               ",industry = " + "'" + information.getIndustry() + "'" +
               ",departmentid = " + "'" + information.getDepartmentid() + "'" +
               ",stats = " + "'" + information.getStats() + "'" +
               builder.toString() +
               ",business_License = " + "'" + businessLicenses + "'" +
               ",licence = " + "'" + licences + "'" +
               " " + "where id = " + "'" + information.getId() + "'";
            //同步内网
            myAsyncService.FTP(s1);
         }else {
            //内网同步
            String s1 = "update sys_information set creditCode = " + "'" + information.getCreditcode() + "'" +
               ",enterpriseName = " + "'" + information.getEnterprisename() + "'" +
               ",representative = " + "'" + information.getRepresentative() + "'" +
               ",registeredCapital = " + "'" + information.getRegisteredcapital() + "'" +
               ",jurisdiction = " + "'" + information.getJurisdiction() + "'" +
               ",enterprises = " + "'" + information.getEnterprises() + "'" +
               ",address = " + "'" + information.getAddress() + "'" +
               ",business = " + "'" + information.getBusiness() + "'" +
               ",region = " + "'" + information.getRegion() + "'" +
               ",registration = " + "'" + information.getRegistration() + "'" +
               ",industry = " + "'" + information.getIndustry() + "'" +
               ",departmentid = " + "'" + information.getDepartmentid() + "'" +
               ",stats = " + "'" + information.getStats() + "'" +
               builder.toString() +
               ",business_License = " + "'" + businessLicenses + "'" +
               ",licence = " + "'" + licences + "'" +
               " " + "where id = " + "'" + information.getId() + "'";
            //同步内网
            myAsyncService.FTP(s1);
         }
      }
      return R.success("修改成功");
   }
@@ -264,19 +407,40 @@
   @ApiOperationSupport(order = 8)
   @ApiOperation(value = "删除", notes = "传入ids")
   public R remove(String creditcode, String departmentid) throws Exception {
      String[] strArray = creditcode.split(",");
      String[] strArrays = departmentid.split(",");
      for (int i = 0; i < strArray.length; i++) {
         informationService.deleteIn(strArray[i]);
         informationService.deleteSh(strArray[i]);
         informationService.deleteMe(strArray[i]);
      }
      for (int j = 0; j < strArrays.length; j++) {
      List<String> list = Arrays.asList(departmentid.split(","));
      list.forEach(s -> {
         //公司信息删除
         informationService.deleteIn(s);
         //主要管理人员信息删除
         informationService.deleteSh(s);
         //出资人信息删除
         informationService.deleteMe(s);
         //机构删除
         informationService.deleteDept(strArrays[j]);
      }
         informationService.deleteDept(s);
         //当前公司下人员逻辑删除
         informationService.deleteUserByDeptId(s);
         //保安公司信息
         String s1 = "delete from sys_information where departmentid = " + "'" + s + "'";
         //FtpUtil.sqlFileUpload(s1);
         myAsyncService.FTP(s1);
         //主要管理人
         String s2 = "delete from sys_shareholder where dept_id = " + "'" + s + "'";
         //FtpUtil.sqlFileUpload(s2);
         myAsyncService.FTP(s2);
         //出资人
         String s3 = "delete from sys_member where dept_id = " + "'" + s + "'";
         //FtpUtil.sqlFileUpload(s3);
         myAsyncService.FTP(s3);
         //组织机构信息逻辑删除
         String s4 = "update blade_dept set is_deleted  = 1 where id = " + "'" + s + "'";
         //FtpUtil.sqlFileUpload(s4);
         myAsyncService.FTP(s4);
         //保安公司人员信息删除
         String s5 = "update blade_user set is_deleted  = 1 where dept_id " + "'" + s + "'";
         //FtpUtil.sqlFileUpload(s5);
         myAsyncService.FTP(s5);
      });
      //返回
      return R.success("删除成功");
   }
@@ -284,8 +448,8 @@
    * 统计保安员资格异常的数量
    */
   @PostMapping("/selectExtype")
   public R selectExtype(String deptid,String jurisdiction) {
      List<Map<Object, Object>> lists = informationService.selectExtype(deptid,jurisdiction);
   public R selectExtype(String deptid, String jurisdiction) {
      List<Map<Object, Object>> lists = informationService.selectExtype(deptid, jurisdiction);
      return R.data(lists);
   }
@@ -293,8 +457,8 @@
    * 统计保安员持证的数量
    */
   @PostMapping("/selectHold")
   public R selectHold(String deptid,String jurisdiction) {
      List<Map<Object, Object>> lists = informationService.selectHold(deptid,jurisdiction);
   public R selectHold(String deptid, String jurisdiction) {
      List<Map<Object, Object>> lists = informationService.selectHold(deptid, jurisdiction);
      return R.data(lists);
   }
@@ -311,8 +475,8 @@
    * 保安派遣数量统计
    */
   @PostMapping("/selectDisp")
   public R selectDisp(String deptid,String jurisdiction) {
      List<Map<Object, Object>> lists = informationService.selectDisp(deptid,jurisdiction);
   public R selectDisp(String deptid, String jurisdiction) {
      List<Map<Object, Object>> lists = informationService.selectDisp(deptid, jurisdiction);
      return R.data(lists);
   }
@@ -320,8 +484,8 @@
    * 社保统计
    */
   @PostMapping("/selectSoil")
   public R selectSoil(String deptid,String jurisdiction) {
      List<Map<Object, Object>> lists = informationService.selectSoil(deptid,jurisdiction);
   public R selectSoil(String deptid, String jurisdiction) {
      List<Map<Object, Object>> lists = informationService.selectSoil(deptid, jurisdiction);
      List<Map<String, Object>> list = new ArrayList<>();
      for (int i = 0; i < lists.size(); i++) {
         Map<String, Object> map = new HashMap<String, Object>();
@@ -336,6 +500,7 @@
      }
      return R.data(list);
   }
   /**
    * 导入单位信息
@@ -361,6 +526,7 @@
      List list = informationService.queryYearKh(year, jurisdiction, deptid);
      return list;
   }
   //升序
   public static Map<String, String> sortMapBykeyAsc(Map<String, String> oriMap) {
      Map<String, String> sortedMap = new LinkedHashMap<String, String>();
@@ -394,4 +560,72 @@
      return sortedMap;
   }
   /**
    * 业务统计情况
    */
   @GetMapping("/selectBusinessStatistics")
   public R<IPage> selectBusinessStatistics(InformationVO information, Query query) {
      IPage list = informationService.selectBusinessStatistics(Condition.getPage(query), information);
      return R.data(list);
   }
   /**
    * 保安员情况统计
    */
   @GetMapping("/selectSecurityStatistics")
   public R<IPage> selectSecurityStatistics(InformationVO information, Query query) {
      IPage list = informationService.selectSecurityStatistics(Condition.getPage(query), information);
      return R.data(list);
   }
   /**
    * 业务统计情况导出
    */
   @GetMapping("/export-business-statis")
   public void exportBusinessStatis(HttpServletResponse response, InformationVO information) {
      List<ExportInformationExcel> list = informationService.exportBusinessStatis(information);
      ExcelUtil.export(response, "业务统计数据" + DateUtil.time(), "业务统计数据表", list, ExportInformationExcel.class);
   }
   /**
    * 保安员情况统计导出
    */
   @GetMapping("/export-security-statis-info")
   public void exportSecurityStatisInfo(HttpServletResponse response, InformationVO information) {
      List<ExportInformationSecurityStatistics> list = informationService.exportSecurityStatisInfo(information);
      ExcelUtil.export(response, "保安员统计数据" + DateUtil.time(), "保安员统计数据表", list, ExportInformationSecurityStatistics.class);
   }
   /**
    * 保安员详情
    */
   @PostMapping("/selectUIn")
   public R<IPage> selectUIn(String deptid, String name, String hold, String photo, String examinationtype, String dispatch, String soil, Query query) {
      IPage list = informationService.selectUIn(Condition.getPage(query), deptid, name, hold, photo, examinationtype, dispatch, soil);
      return R.data(list);
   }
   /**
    * 查询学历统计信息
    *
    * @param deptid       部门id
    * @param jurisdiction 辖区
    * @return
    */
   @PostMapping("/getEducationStatistics")
   public R getEducationStatistics(String deptid, String jurisdiction) {
      return R.data(informationService.getEducationStatistics(deptid, jurisdiction));
   }
   /**
    * 获取部门信息()
    *
    * @param information
    * @return
    */
   @GetMapping("/getInformationDetails")
   public R getInformationDetails(InformationVO information) {
      return R.data(informationService.getInformationDetails(information));
   }
}