SynctaskUtils.java 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  1. package com.kingdee.eas.custom.synctask.utils;
  2. import com.alibaba.fastjson.JSONObject;
  3. import com.fasterxml.jackson.databind.ObjectMapper;
  4. import com.kingdee.bos.BOSException;
  5. import com.kingdee.bos.Context;
  6. import com.kingdee.bos.metadata.entity.EntityViewInfo;
  7. import com.kingdee.bos.metadata.entity.FilterInfo;
  8. import com.kingdee.bos.metadata.entity.FilterItemInfo;
  9. import com.kingdee.bos.metadata.entity.SelectorItemCollection;
  10. import com.kingdee.bos.metadata.query.util.CompareType;
  11. import com.kingdee.eas.basedata.org.AdminOrgUnitCollection;
  12. import com.kingdee.eas.basedata.org.AdminOrgUnitFactory;
  13. import com.kingdee.eas.basedata.org.AdminOrgUnitInfo;
  14. import com.kingdee.eas.basedata.org.IAdminOrgUnit;
  15. import com.kingdee.eas.custom.synctask.ActionTypeEnum;
  16. import com.kingdee.eas.custom.synctask.entity.AdminOrg;
  17. import com.kingdee.eas.hr.ats.AtsUtil;
  18. import com.kingdee.util.StringUtils;
  19. import okhttp3.*;
  20. import org.apache.commons.codec.digest.DigestUtils;
  21. import org.apache.log4j.Logger;
  22. import java.io.FileInputStream;
  23. import java.io.IOException;
  24. import java.util.*;
  25. /**
  26. * @author qingwu
  27. * @date 2024/10/21
  28. * @apiNote
  29. */
  30. public class SynctaskUtils {
  31. public static Logger logger = Logger.getLogger("com.kingdee.eas.custom.synctask.utils.SynctaskUtils");
  32. private Properties propt = new Properties();
  33. public SynctaskUtils() {
  34. try {
  35. this.propt.load(new FileInputStream("E:\\Kingdee\\eas\\server\\properties\\scy\\syncOAConfig.properties"));
  36. //propt.load(new FileInputStream(System.getProperty("EAS_HOME") + "/server/properties/scy/syncOAConfig.properties"));
  37. } catch (IOException e) {
  38. e.printStackTrace();
  39. }
  40. }
  41. /**
  42. * 同步组织
  43. * 1、当参数billIds不为空值时,增量同步参数中的部门数据到OA
  44. * 2、当参数billIds为空时,全量同步所有组织数据到OA
  45. * 3、当参数action不为空时,根据操作类型同步数据
  46. * 4、当参数action为空时,判断部门状态是否为失效,如果失效就执行删除同步,否则就执行编辑同步
  47. * 5、部门新增,调用部门同步方法增量同步,操作类型为新增
  48. *
  49. * @param billds
  50. * @param action
  51. * @throws BOSException
  52. */
  53. public void _syncOrgUnitToOA(Context ctx, String billds, ActionTypeEnum action) throws BOSException, IOException {
  54. logger.error("_syncOrgUnitToOA----------------------start");
  55. logger.error("_syncOrgUnitToOA----------------------billds: " + billds);
  56. IAdminOrgUnit iAdminOrgUnit = AdminOrgUnitFactory.getLocalInstance(ctx);
  57. List dataList = new ArrayList();
  58. String actionType = action == null ? "" : action.getValue().toLowerCase();
  59. //当参数billIds不为空值时,增量同步参数中的部门数据到OA
  60. FilterInfo filterInfo = null;
  61. if (!StringUtils.isEmpty(billds)) {
  62. Set<String> adminOrgIds = AtsUtil.toSet(billds);
  63. filterInfo = new FilterInfo();
  64. filterInfo.getFilterItems().add(new FilterItemInfo("id", adminOrgIds, CompareType.INCLUDE));
  65. }
  66. SelectorItemCollection sic = new SelectorItemCollection();
  67. sic.add("*");
  68. sic.add("parent.number");
  69. EntityViewInfo entityViewInfo = EntityViewInfo.getInstance(filterInfo, sic, null);
  70. AdminOrgUnitCollection adminOrgUnitCollection = iAdminOrgUnit.getAdminOrgUnitCollection(entityViewInfo);
  71. for (int i = 0; i < adminOrgUnitCollection.size(); i++) {
  72. AdminOrgUnitInfo adminOrgUnitInfo = adminOrgUnitCollection.get(i);
  73. String orgName = adminOrgUnitInfo.getName();
  74. AdminOrg adminOrg = new AdminOrg();
  75. boolean isSealUp = adminOrgUnitInfo.isIsSealUp();
  76. if (isSealUp) {
  77. adminOrg.setAction("delete");
  78. adminOrg.setCanceled("0");
  79. } else {
  80. adminOrg.setAction("add");
  81. }
  82. adminOrg.setCode(adminOrgUnitInfo.getNumber());
  83. adminOrg.setShortname(orgName);
  84. adminOrg.setFullname(orgName);
  85. //adminOrg.setParent_code("ITCS");
  86. adminOrg.setOrg_code("0");
  87. adminOrg.setParent_code(adminOrgUnitInfo.getParent().getNumber());
  88. //adminOrg.setOrder((String.valueOf(adminOrgUnitInfo.getIndex())));
  89. dataList.add(adminOrg);
  90. }
  91. //调用执行同步组织到OA
  92. executeSyncOrgUnitToOA(dataList);
  93. }
  94. /**
  95. * 执行同步组织到OA
  96. *
  97. * @param dataList
  98. */
  99. public void executeSyncOrgUnitToOA(List dataList) throws IOException, BOSException {
  100. if (dataList != null && dataList.size() > 0) {
  101. ObjectMapper mapper = new ObjectMapper();
  102. //封装请求参数
  103. String data = mapper.writeValueAsString(dataList);
  104. String params = String.format("token = %s &data = %s", getToken(), data);
  105. logger.error("executeSyncOrgUnitToOA----------------------params" + params);
  106. //封装请求参数
  107. //String syncOrgUnitApiUrl = "/api/hrm/resful/synDepartment";
  108. String syncOrgUnitApiUrl = this.propt.getProperty("syncOrgUnitApiUrl");
  109. String url = this.propt.getProperty("url");
  110. logger.error("executeSyncOrgUnitToOA----------------------syncOrgUnitApiUrl" + syncOrgUnitApiUrl);
  111. if (StringUtils.isEmpty(syncOrgUnitApiUrl)) {
  112. throw new BOSException("同步组织到OA接口地址不能为空!");
  113. }
  114. OkHttpClient client = new OkHttpClient();
  115. MediaType mediaType = MediaType.parse("application/x-www-form-urlencoded");
  116. RequestBody body = RequestBody.create(mediaType, params);
  117. Request request = new Request.Builder()
  118. .url(url + syncOrgUnitApiUrl)
  119. .post(body)
  120. .addHeader("Content-Type", "application/json")
  121. .addHeader("Accept", "*/*")
  122. .addHeader("Accept-Encoding", "gzip, deflate, br")
  123. .addHeader("User-Agent", "PostmanRuntime-ApipostRuntime/1.1.0")
  124. .addHeader("Connection", "keep-alive")
  125. .build();
  126. Response response = client.newCall(request).execute();
  127. String respBody = response.body().string();
  128. if (response.isSuccessful()) {
  129. } else {
  130. }
  131. }
  132. }
  133. /**
  134. * 获取token
  135. *
  136. * @return
  137. */
  138. public String getToken() {
  139. String key = this.propt.getProperty("key");
  140. long l = System.currentTimeMillis();//时间戳毫秒数
  141. String code = key.concat(Long.toString(l));
  142. //String s = DigestUtils.md5Hex(code).toUpperCase();
  143. String s = DigestUtils.md5Hex(code).toUpperCase();
  144. Map<String, String> map = new HashMap<>();
  145. map.put("key", s);
  146. map.put("ts", Long.toString(l));
  147. logger.error("getToken" + JSONObject.toJSONString(map));
  148. return JSONObject.toJSONString(map);
  149. }
  150. }