YDConf.java 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189
  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. multi_create, // 批量操作
  61. delete_batch, // 批量删除
  62. multi_update, // 批量更新
  63. start, // 发起流程
  64. batchSave, // 批量创建
  65. }
  66. /**
  67. * 关联表单处理
  68. *
  69. * @param formType: "receipt" 跳转为表单【若是流程,则权限体系会失效,但也会显示审批节点】; formType: "process" 为流程
  70. * @apiNote ppExt 接口更新, 传入jsonString或List都可以. 返回数据都是两层json解析, 组件 + _id格式
  71. */
  72. public List<Map> associationForm(String formUuid, String formInstanceId, String title, String subTitle, boolean isProcess) {
  73. return associationForm(appType, formUuid, formInstanceId, title, subTitle, isProcess);
  74. }
  75. // todo 部门ID写入需要是string集合\数组, 封装
  76. public static List<Map> associationForm(String appType, String formUuid, String formInstanceId, String title, String subTitle, boolean isProcess) {
  77. String formType = isProcess ? "process" : "receipt";
  78. return Arrays.asList(UtilMap.map("appType, formUuid, instanceId, title, subTitle, formType", appType, formUuid, formInstanceId, title, subTitle, formType));
  79. }
  80. /**
  81. * 读取关联表单: ppExt 两层解析后才是List, 若是赋值取值转一层, 宜搭也可进行写入
  82. * - 赋值说明 -
  83. * 若是同一个应用,appType与formUuid为空(不指定下formUuid可为错误,但appType只能为空),点击页面链接会自动匹配;
  84. * 若是跨应用实例,则不能通过导入,需要通过接口指定appType
  85. */
  86. public List<Map> associationForm(String associations) {
  87. if (UtilString.isBlankCompatNull(associations)) {
  88. return new ArrayList<>();
  89. }
  90. return (List<Map>) JSON.parse(String.valueOf(JSON.parse(String.valueOf(associations))));
  91. }
  92. /**
  93. * 高级筛选: ppExt 通过表单\流程 search 宜搭目前下拉框也会被模糊匹配, 为避免事后过滤, 使用高级查询; 且高级查询支持同一个字段多条件
  94. */
  95. public static Map searchCondition_TextFiled(String compId, Object value, String operator) {
  96. return UtilMap.map("key, value, type, operator, componentName", compId, value, "TEXT", operator, "TextField");
  97. }
  98. // todo text组件是否可用于select
  99. public static Map searchCondition_processInstanceStatus(List status) {
  100. return UtilMap.map("key, value, type, operator, componentName", "processInstanceStatus", status, "ARRAY", "in", "SelectField");
  101. }
  102. /**
  103. * 组件格式化取值 [取值] todo 明细表递归, 循环传递入参
  104. */
  105. public static Object getDataByCompId(Map formData, String compId_cur) {
  106. if (compId_cur.contains("associationFormField_")) {
  107. // 服务注册 #{_yida_all_data} 直接组件Id
  108. if (!formData.containsKey(compId_cur)) {
  109. // 接口返回数据, 关联组件ID, 不会返回组件id字段
  110. compId_cur = compId_cur + "_id";
  111. }
  112. return JSON.parse(String.valueOf(formData.get(compId_cur)));
  113. } else if (compId_cur.contains("employeeField_")) {
  114. if (!formData.containsKey(compId_cur + "_id")) {
  115. // 服务注册 #{_yida_all_data} 返回JsonString userid 数组
  116. return JSON.parse(String.valueOf(formData.get(compId_cur)));
  117. } else {
  118. // 成员组件, 接口返回组件id返回为姓名, _id返回是userId
  119. return formData.get(compId_cur + "_id");
  120. }
  121. }
  122. return formData.get(compId_cur);
  123. }
  124. ////////////////////////// 老版本API //////////////////////////
  125. /**
  126. * 表单接口适用于流程: 查询和更新以及删除
  127. */
  128. private static String formatApiForm(String uri) {
  129. return "/yida_vpc/form/" + uri + ".json";
  130. }
  131. private static String formatApiProcess(String uri) {
  132. return "/yida_vpc/process/" + uri + ".json";
  133. }
  134. /**
  135. * 接口地址: 表单
  136. */
  137. public static final String API_FORM_CREATE = formatApiForm("saveFormData");
  138. public static final String API_FORM_DELETE = formatApiForm("deleteFormData");
  139. public static final String API_FORM_UPDATE = formatApiForm("updateFormData");
  140. public static final String API_FORM_DETAIL = formatApiForm("getFormDataById");
  141. public static final String API_FORM_QUERY_ID = formatApiForm("searchFormDataIds");
  142. public static final String API_FORM_QUERY_DATA = formatApiForm("searchFormDatas");
  143. public static final String API_FORM_DEFINITION = "/yida_vpc/formDesign/getFormComponentDefinationList.json";
  144. /**
  145. * 接口地址: 流程
  146. */
  147. public static final String API_PROCESS_CREATE = formatApiProcess("startInstance");
  148. public static final String API_PROCESS_DELETE = formatApiProcess("deleteInstance");
  149. public static final String API_PROCESS_UPDATE = formatApiProcess("updateInstance");
  150. public static final String API_PROCESS_DETAIL = formatApiProcess("getInstanceById");
  151. public static final String API_PROCESS_BATCH_DETAIL = formatApiProcess("getInstancesByIds");
  152. public static final String API_PROCESS_QUERY_ID = formatApiProcess("getInstanceIds");
  153. public static final String API_PROCESS_QUERY_DATA = formatApiProcess("getInstances");
  154. /**
  155. * 其它接口
  156. */
  157. public static final String API_OPEN_URL = "/yida_vpc/file/getOpenUrl.json";
  158. }