YDConf.java 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190
  1. package com.malk.server.aliwork;
  2. import com.alibaba.fastjson.JSON;
  3. import com.malk.utils.UtilMap;
  4. import com.malk.utils.UtilString;
  5. import lombok.Data;
  6. import lombok.extern.slf4j.Slf4j;
  7. import org.springframework.boot.context.properties.ConfigurationProperties;
  8. import org.springframework.stereotype.Component;
  9. import java.util.ArrayList;
  10. import java.util.Arrays;
  11. import java.util.List;
  12. import java.util.Map;
  13. @Data
  14. @Component
  15. @ConfigurationProperties(prefix = "aliwork")
  16. @Slf4j
  17. public class YDConf {
  18. private String appType;
  19. private String systemToken;
  20. /**
  21. * 一个切片数量上限
  22. */
  23. public static final Integer UPPER_LIMIT = 30000;
  24. /**
  25. * 一个分页数量上限
  26. */
  27. public static final Integer PAGE_SIZE_LIMIT = 100;
  28. /**
  29. * 接口访问账号 [不能触发待办与消息通知, 业务规则亦不能]
  30. * -
  31. * 非管理员账号只可以查询, 不检验权限
  32. * 操作数据需要管理员账号, 或宜搭平台
  33. */
  34. public static final String PUB_ACCOUNT = "yida_pub_account";
  35. ////////////////////////// 新版本API //////////////////////////
  36. /**
  37. * 查询表单
  38. */
  39. public enum FORM_QUERY {
  40. retrieve_list, // 全局查询, 不包含子表单
  41. retrieve_list_all, // 全局查询, 包含子表单
  42. multi_retrieve_id,
  43. retrieve_id, // 单个ID查询 todo 若秘钥不匹配, 返回空, 添加报错说明
  44. retrieve_search_process, // 流程列表
  45. retrieve_search_form, // 表单列表
  46. retrieve_search_process_id, // 流程列表
  47. retrieve_search_form_id, // 表单列表
  48. retrieve_details, // 子表数据[表单]
  49. retrieve_changed, // 变更记录
  50. retrieve_definition, // 表单定义
  51. }
  52. /**
  53. * 表单操作
  54. */
  55. public enum FORM_OPERATION {
  56. create,
  57. delete, // 传入为body, 文档为param
  58. update,
  59. upsert,
  60. upsert_v2, // 新版本 searchCondition 条件精准匹配
  61. multi_create, // 批量操作
  62. delete_batch, // 批量删除
  63. multi_update, // 批量更新
  64. start, // 发起流程
  65. batchSave, // 批量创建
  66. }
  67. /**
  68. * 关联表单处理
  69. *
  70. * @param formType: "receipt" 跳转为表单【若是流程,则权限体系会失效,但也会显示审批节点】; formType: "process" 为流程
  71. * @apiNote ppExt 接口更新, 传入jsonString或List都可以. 返回数据都是两层json解析, 组件 + _id格式
  72. */
  73. public List<Map> associationForm(String formUuid, String formInstanceId, String title, String subTitle, boolean isProcess) {
  74. return associationForm(appType, formUuid, formInstanceId, title, subTitle, isProcess);
  75. }
  76. // todo 部门ID写入需要是string集合\数组, 封装
  77. public static List<Map> associationForm(String appType, String formUuid, String formInstanceId, String title, String subTitle, boolean isProcess) {
  78. String formType = isProcess ? "process" : "receipt";
  79. return Arrays.asList(UtilMap.map("appType, formUuid, instanceId, title, subTitle, formType", appType, formUuid, formInstanceId, title, subTitle, formType));
  80. }
  81. /**
  82. * 读取关联表单: ppExt 两层解析后才是List, 若是赋值取值转一层, 宜搭也可进行写入
  83. * - 赋值说明 -
  84. * 若是同一个应用,appType与formUuid为空(不指定下formUuid可为错误,但appType只能为空),点击页面链接会自动匹配;
  85. * 若是跨应用实例,则不能通过导入,需要通过接口指定appType
  86. */
  87. public List<Map> associationForm(String associations) {
  88. if (UtilString.isBlankCompatNull(associations)) {
  89. return new ArrayList<>();
  90. }
  91. return (List<Map>) JSON.parse(String.valueOf(JSON.parse(String.valueOf(associations))));
  92. }
  93. /**
  94. * 高级筛选: ppExt 通过表单\流程 search 宜搭目前下拉框也会被模糊匹配, 为避免事后过滤, 使用高级查询; 且高级查询支持同一个字段多条件
  95. */
  96. public static Map searchCondition_TextFiled(String compId, Object value, String operator) {
  97. return UtilMap.map("key, value, type, operator, componentName", compId, value, "TEXT", operator, "TextField");
  98. }
  99. // todo text组件是否可用于select
  100. public static Map searchCondition_processInstanceStatus(List status) {
  101. return UtilMap.map("key, value, type, operator, componentName", "processInstanceStatus", status, "ARRAY", "in", "SelectField");
  102. }
  103. /**
  104. * 组件格式化取值 [取值] todo 明细表递归, 循环传递入参
  105. */
  106. public static Object getDataByCompId(Map formData, String compId_cur) {
  107. if (compId_cur.contains("associationFormField_")) {
  108. // 服务注册 #{_yida_all_data} 直接组件Id
  109. if (!formData.containsKey(compId_cur)) {
  110. // 接口返回数据, 关联组件ID, 不会返回组件id字段
  111. compId_cur = compId_cur + "_id";
  112. }
  113. return JSON.parse(String.valueOf(formData.get(compId_cur)));
  114. } else if (compId_cur.contains("employeeField_")) {
  115. if (!formData.containsKey(compId_cur + "_id")) {
  116. // 服务注册 #{_yida_all_data} 返回JsonString userid 数组
  117. return JSON.parse(String.valueOf(formData.get(compId_cur)));
  118. } else {
  119. // 成员组件, 接口返回组件id返回为姓名, _id返回是userId
  120. return formData.get(compId_cur + "_id");
  121. }
  122. }
  123. return formData.get(compId_cur);
  124. }
  125. ////////////////////////// 老版本API //////////////////////////
  126. /**
  127. * 表单接口适用于流程: 查询和更新以及删除
  128. */
  129. private static String formatApiForm(String uri) {
  130. return "/yida_vpc/form/" + uri + ".json";
  131. }
  132. private static String formatApiProcess(String uri) {
  133. return "/yida_vpc/process/" + uri + ".json";
  134. }
  135. /**
  136. * 接口地址: 表单
  137. */
  138. public static final String API_FORM_CREATE = formatApiForm("saveFormData");
  139. public static final String API_FORM_DELETE = formatApiForm("deleteFormData");
  140. public static final String API_FORM_UPDATE = formatApiForm("updateFormData");
  141. public static final String API_FORM_DETAIL = formatApiForm("getFormDataById");
  142. public static final String API_FORM_QUERY_ID = formatApiForm("searchFormDataIds");
  143. public static final String API_FORM_QUERY_DATA = formatApiForm("searchFormDatas");
  144. public static final String API_FORM_DEFINITION = "/yida_vpc/formDesign/getFormComponentDefinationList.json";
  145. /**
  146. * 接口地址: 流程
  147. */
  148. public static final String API_PROCESS_CREATE = formatApiProcess("startInstance");
  149. public static final String API_PROCESS_DELETE = formatApiProcess("deleteInstance");
  150. public static final String API_PROCESS_UPDATE = formatApiProcess("updateInstance");
  151. public static final String API_PROCESS_DETAIL = formatApiProcess("getInstanceById");
  152. public static final String API_PROCESS_BATCH_DETAIL = formatApiProcess("getInstancesByIds");
  153. public static final String API_PROCESS_QUERY_ID = formatApiProcess("getInstanceIds");
  154. public static final String API_PROCESS_QUERY_DATA = formatApiProcess("getInstances");
  155. /**
  156. * 其它接口
  157. */
  158. public static final String API_OPEN_URL = "/yida_vpc/file/getOpenUrl.json";
  159. }