filecat 5.32.0 → 5.32.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (352) hide show
  1. package/build/dist/{377.f1e5a0d0f7800c8306ee.js → 377.4047ae540e74884d3ff5.js} +2 -2
  2. package/build/dist/543.ac5d314a52e99934103c.js +2 -0
  3. package/build/dist/{943.7c72fe51510266a06ea6.js → 943.d055d58eee66f1ab0414.js} +2 -2
  4. package/build/dist/index.html +1 -1
  5. package/build/dist/{main.b593eb159b18a7b4eefa.js → main.494c8bcf15274aeca600.js} +2 -2
  6. package/build/server/common/DataUtil.js +7 -0
  7. package/build/server/common/DataUtil.js.map +1 -0
  8. package/build/server/common/FileMenuType.js +48 -0
  9. package/build/server/common/FileMenuType.js.map +1 -0
  10. package/build/server/common/ListUtil.js +224 -0
  11. package/build/server/common/ListUtil.js.map +1 -0
  12. package/build/server/common/Result.pojo.js +15 -0
  13. package/build/server/common/Result.pojo.js.map +1 -0
  14. package/build/server/common/RouterConfig.js +20 -0
  15. package/build/server/common/RouterConfig.js.map +1 -0
  16. package/build/server/common/StringUtil.js +223 -0
  17. package/build/server/common/StringUtil.js.map +1 -0
  18. package/build/server/common/ValueUtil.js +70 -0
  19. package/build/server/common/ValueUtil.js.map +1 -0
  20. package/build/server/common/common.util.js +32 -0
  21. package/build/server/common/common.util.js.map +1 -0
  22. package/build/server/common/event.js +48 -0
  23. package/build/server/common/event.js.map +1 -0
  24. package/build/server/common/file.pojo.js +65 -0
  25. package/build/server/common/file.pojo.js.map +1 -0
  26. package/build/server/common/frame/WsData.js +127 -0
  27. package/build/server/common/frame/WsData.js.map +1 -0
  28. package/build/server/common/frame/constant.js +6 -0
  29. package/build/server/common/frame/constant.js.map +1 -0
  30. package/build/server/common/frame/data.encode.js +115 -0
  31. package/build/server/common/frame/data.encode.js.map +1 -0
  32. package/build/server/common/frame/router.js +25 -0
  33. package/build/server/common/frame/router.js.map +1 -0
  34. package/build/server/common/frame/ws.client.js +173 -0
  35. package/build/server/common/frame/ws.client.js.map +1 -0
  36. package/build/server/common/frame/ws.server.js +145 -0
  37. package/build/server/common/frame/ws.server.js.map +1 -0
  38. package/build/server/common/fun.util.js +65 -0
  39. package/build/server/common/fun.util.js.map +1 -0
  40. package/build/server/common/node/Env.js +198 -0
  41. package/build/server/common/node/Env.js.map +1 -0
  42. package/build/server/common/node/childProcessUtil.js +209 -0
  43. package/build/server/common/node/childProcessUtil.js.map +1 -0
  44. package/build/server/common/node/findPort.js +38 -0
  45. package/build/server/common/node/findPort.js.map +1 -0
  46. package/build/server/common/node/http.js +38 -0
  47. package/build/server/common/node/http.js.map +1 -0
  48. package/build/server/common/node/install.js +132 -0
  49. package/build/server/common/node/install.js.map +1 -0
  50. package/build/server/common/node/value.util.js +8 -0
  51. package/build/server/common/node/value.util.js.map +1 -0
  52. package/build/server/common/path_util.js +86 -0
  53. package/build/server/common/path_util.js.map +1 -0
  54. package/build/server/common/req/common.pojo.js +42 -0
  55. package/build/server/common/req/common.pojo.js.map +1 -0
  56. package/build/server/common/req/customerRouter.pojo.js +9 -0
  57. package/build/server/common/req/customerRouter.pojo.js.map +1 -0
  58. package/build/server/common/req/data.pojo.js +3 -0
  59. package/build/server/common/req/data.pojo.js.map +1 -0
  60. package/build/server/common/req/ddns.pojo.js +39 -0
  61. package/build/server/common/req/ddns.pojo.js.map +1 -0
  62. package/build/server/common/req/file.req.js +49 -0
  63. package/build/server/common/req/file.req.js.map +1 -0
  64. package/build/server/common/req/http_controller_router.js +13 -0
  65. package/build/server/common/req/http_controller_router.js.map +1 -0
  66. package/build/server/common/req/net.pojo.js +71 -0
  67. package/build/server/common/req/net.pojo.js.map +1 -0
  68. package/build/server/common/req/setting.req.js +140 -0
  69. package/build/server/common/req/setting.req.js.map +1 -0
  70. package/build/server/common/req/ssh.pojo.js +13 -0
  71. package/build/server/common/req/ssh.pojo.js.map +1 -0
  72. package/build/server/common/req/sys.pojo.js +29 -0
  73. package/build/server/common/req/sys.pojo.js.map +1 -0
  74. package/build/server/common/req/user.req.js +117 -0
  75. package/build/server/common/req/user.req.js.map +1 -0
  76. package/build/server/common/word_detection_js.js +142 -0
  77. package/build/server/common/word_detection_js.js.map +1 -0
  78. package/build/server/main/domain/ai_agent/ai_agent.constant.js +142 -0
  79. package/build/server/main/domain/ai_agent/ai_agent.constant.js.map +1 -0
  80. package/build/server/main/domain/ai_agent/ai_agent.controller.js +136 -0
  81. package/build/server/main/domain/ai_agent/ai_agent.controller.js.map +1 -0
  82. package/build/server/main/domain/ai_agent/ai_agent.service.js +715 -0
  83. package/build/server/main/domain/ai_agent/ai_agent.service.js.map +1 -0
  84. package/build/server/main/domain/ai_agent/ai_agent.tools.js +79 -0
  85. package/build/server/main/domain/ai_agent/ai_agent.tools.js.map +1 -0
  86. package/build/server/main/domain/ai_agent/ai_agent.worker.js +169 -0
  87. package/build/server/main/domain/ai_agent/ai_agent.worker.js.map +1 -0
  88. package/build/server/main/domain/bin/bin.file.util.js +109 -0
  89. package/build/server/main/domain/bin/bin.file.util.js.map +1 -0
  90. package/build/server/main/domain/bin/bin.js +147 -0
  91. package/build/server/main/domain/bin/bin.js.map +1 -0
  92. package/build/server/main/domain/bin/get_bin_dependency.js +36 -0
  93. package/build/server/main/domain/bin/get_bin_dependency.js.map +1 -0
  94. package/build/server/main/domain/crypto/crypto.controller.js +50 -0
  95. package/build/server/main/domain/crypto/crypto.controller.js.map +1 -0
  96. package/build/server/main/domain/crypto/crypto.service.js +112 -0
  97. package/build/server/main/domain/crypto/crypto.service.js.map +1 -0
  98. package/build/server/main/domain/data/DataUtil.js +127 -0
  99. package/build/server/main/domain/data/DataUtil.js.map +1 -0
  100. package/build/server/main/domain/data/basedata/base_data_util.js +214 -0
  101. package/build/server/main/domain/data/basedata/base_data_util.js.map +1 -0
  102. package/build/server/main/domain/data/data_type.js +92 -0
  103. package/build/server/main/domain/data/data_type.js.map +1 -0
  104. package/build/server/main/domain/ddns/ddns.ali.server.js +77 -0
  105. package/build/server/main/domain/ddns/ddns.ali.server.js.map +1 -0
  106. package/build/server/main/domain/ddns/ddns.controller.js +88 -0
  107. package/build/server/main/domain/ddns/ddns.controller.js.map +1 -0
  108. package/build/server/main/domain/ddns/ddns.dnspod.service.js +102 -0
  109. package/build/server/main/domain/ddns/ddns.dnspod.service.js.map +1 -0
  110. package/build/server/main/domain/ddns/ddns.pre.js +104 -0
  111. package/build/server/main/domain/ddns/ddns.pre.js.map +1 -0
  112. package/build/server/main/domain/ddns/ddns.service.js +161 -0
  113. package/build/server/main/domain/ddns/ddns.service.js.map +1 -0
  114. package/build/server/main/domain/ddns/ddns.tengxun.service.js +46 -0
  115. package/build/server/main/domain/ddns/ddns.tengxun.service.js.map +1 -0
  116. package/build/server/main/domain/ddns/tx/abstract_client.js +247 -0
  117. package/build/server/main/domain/ddns/tx/abstract_client.js.map +1 -0
  118. package/build/server/main/domain/ddns/tx/dnspod_client.js +38 -0
  119. package/build/server/main/domain/ddns/tx/dnspod_client.js.map +1 -0
  120. package/build/server/main/domain/ddns/tx/dnspod_models.js +3 -0
  121. package/build/server/main/domain/ddns/tx/dnspod_models.js.map +1 -0
  122. package/build/server/main/domain/ddns/tx/exception/tencent_cloud_sdk_exception.js +38 -0
  123. package/build/server/main/domain/ddns/tx/exception/tencent_cloud_sdk_exception.js.map +1 -0
  124. package/build/server/main/domain/ddns/tx/http/fetch.js +3 -0
  125. package/build/server/main/domain/ddns/tx/http/fetch.js.map +1 -0
  126. package/build/server/main/domain/ddns/tx/http/http_connection.js +181 -0
  127. package/build/server/main/domain/ddns/tx/http/http_connection.js.map +1 -0
  128. package/build/server/main/domain/ddns/tx/interface.js +5 -0
  129. package/build/server/main/domain/ddns/tx/interface.js.map +1 -0
  130. package/build/server/main/domain/ddns/tx/sdk_version.js +5 -0
  131. package/build/server/main/domain/ddns/tx/sdk_version.js.map +1 -0
  132. package/build/server/main/domain/ddns/tx/sign.js +142 -0
  133. package/build/server/main/domain/ddns/tx/sign.js.map +1 -0
  134. package/build/server/main/domain/ddns/tx/sse_response_model.js +89 -0
  135. package/build/server/main/domain/ddns/tx/sse_response_model.js.map +1 -0
  136. package/build/server/main/domain/file/FileUtil.js +230 -0
  137. package/build/server/main/domain/file/FileUtil.js.map +1 -0
  138. package/build/server/main/domain/file/file.compress.js +246 -0
  139. package/build/server/main/domain/file/file.compress.js.map +1 -0
  140. package/build/server/main/domain/file/file.controller.js +450 -0
  141. package/build/server/main/domain/file/file.controller.js.map +1 -0
  142. package/build/server/main/domain/file/file.service.js +1276 -0
  143. package/build/server/main/domain/file/file.service.js.map +1 -0
  144. package/build/server/main/domain/file/search/file.search.js +78 -0
  145. package/build/server/main/domain/file/search/file.search.js.map +1 -0
  146. package/build/server/main/domain/file/search/file.search.worker.js +107 -0
  147. package/build/server/main/domain/file/search/file.search.worker.js.map +1 -0
  148. package/build/server/main/domain/file/search/file.type.js +3 -0
  149. package/build/server/main/domain/file/search/file.type.js.map +1 -0
  150. package/build/server/main/domain/file/workflow/workflow.process.js +100 -0
  151. package/build/server/main/domain/file/workflow/workflow.process.js.map +1 -0
  152. package/build/server/main/domain/file/workflow/workflow.service.js +659 -0
  153. package/build/server/main/domain/file/workflow/workflow.service.js.map +1 -0
  154. package/build/server/main/domain/file/workflow/workflow.util.js +111 -0
  155. package/build/server/main/domain/file/workflow/workflow.util.js.map +1 -0
  156. package/build/server/main/domain/navindex/navindex.controller.js +73 -0
  157. package/build/server/main/domain/navindex/navindex.controller.js.map +1 -0
  158. package/build/server/main/domain/net/net.controller.js +318 -0
  159. package/build/server/main/domain/net/net.controller.js.map +1 -0
  160. package/build/server/main/domain/net/net.datautil.js +8 -0
  161. package/build/server/main/domain/net/net.datautil.js.map +1 -0
  162. package/build/server/main/domain/net/net.service.js +627 -0
  163. package/build/server/main/domain/net/net.service.js.map +1 -0
  164. package/build/server/main/domain/net/tcp.forward.client.service.js +223 -0
  165. package/build/server/main/domain/net/tcp.forward.client.service.js.map +1 -0
  166. package/build/server/main/domain/net/tcp.forward.controller.js +482 -0
  167. package/build/server/main/domain/net/tcp.forward.controller.js.map +1 -0
  168. package/build/server/main/domain/net/tcp.forward.server.service.js +407 -0
  169. package/build/server/main/domain/net/tcp.forward.server.service.js.map +1 -0
  170. package/build/server/main/domain/net/type.js +3 -0
  171. package/build/server/main/domain/net/type.js.map +1 -0
  172. package/build/server/main/domain/net/util/NetClientUtil.js +76 -0
  173. package/build/server/main/domain/net/util/NetClientUtil.js.map +1 -0
  174. package/build/server/main/domain/net/util/NetServerUtil.js +128 -0
  175. package/build/server/main/domain/net/util/NetServerUtil.js.map +1 -0
  176. package/build/server/main/domain/net/util/NetUtil.js +187 -0
  177. package/build/server/main/domain/net/util/NetUtil.js.map +1 -0
  178. package/build/server/main/domain/net/util/tcp.client.js +211 -0
  179. package/build/server/main/domain/net/util/tcp.client.js.map +1 -0
  180. package/build/server/main/domain/net/util/tcp_stream_util.js +69 -0
  181. package/build/server/main/domain/net/util/tcp_stream_util.js.map +1 -0
  182. package/build/server/main/domain/net/util/type.js +3 -0
  183. package/build/server/main/domain/net/util/type.js.map +1 -0
  184. package/build/server/main/domain/net/virtual/tcp_proxy.js +125 -0
  185. package/build/server/main/domain/net/virtual/tcp_proxy.js.map +1 -0
  186. package/build/server/main/domain/net/virtual/virtual.client.service.js +402 -0
  187. package/build/server/main/domain/net/virtual/virtual.client.service.js.map +1 -0
  188. package/build/server/main/domain/net/virtual/virtual.controller.js +211 -0
  189. package/build/server/main/domain/net/virtual/virtual.controller.js.map +1 -0
  190. package/build/server/main/domain/net/virtual/virtual.server.service.js +72 -0
  191. package/build/server/main/domain/net/virtual/virtual.server.service.js.map +1 -0
  192. package/build/server/main/domain/pre/lifeRecordService.js +79 -0
  193. package/build/server/main/domain/pre/lifeRecordService.js.map +1 -0
  194. package/build/server/main/domain/rdp/lib/asn1/ber.js +66 -0
  195. package/build/server/main/domain/rdp/lib/asn1/ber.js.map +1 -0
  196. package/build/server/main/domain/rdp/lib/asn1/index.js +9 -0
  197. package/build/server/main/domain/rdp/lib/asn1/index.js.map +1 -0
  198. package/build/server/main/domain/rdp/lib/asn1/spec.js +56 -0
  199. package/build/server/main/domain/rdp/lib/asn1/spec.js.map +1 -0
  200. package/build/server/main/domain/rdp/lib/asn1/univ.js +315 -0
  201. package/build/server/main/domain/rdp/lib/asn1/univ.js.map +1 -0
  202. package/build/server/main/domain/rdp/lib/core/error.js +25 -0
  203. package/build/server/main/domain/rdp/lib/core/error.js.map +1 -0
  204. package/build/server/main/domain/rdp/lib/core/index.js +13 -0
  205. package/build/server/main/domain/rdp/lib/core/index.js.map +1 -0
  206. package/build/server/main/domain/rdp/lib/core/layer.js +135 -0
  207. package/build/server/main/domain/rdp/lib/core/layer.js.map +1 -0
  208. package/build/server/main/domain/rdp/lib/core/log.js +25 -0
  209. package/build/server/main/domain/rdp/lib/core/log.js.map +1 -0
  210. package/build/server/main/domain/rdp/lib/core/rle.js +22699 -0
  211. package/build/server/main/domain/rdp/lib/core/rle.js.map +1 -0
  212. package/build/server/main/domain/rdp/lib/core/type.js +245 -0
  213. package/build/server/main/domain/rdp/lib/core/type.js.map +1 -0
  214. package/build/server/main/domain/rdp/lib/index.js +6 -0
  215. package/build/server/main/domain/rdp/lib/index.js.map +1 -0
  216. package/build/server/main/domain/rdp/lib/protocol/cert.js +115 -0
  217. package/build/server/main/domain/rdp/lib/protocol/cert.js.map +1 -0
  218. package/build/server/main/domain/rdp/lib/protocol/index.js +11 -0
  219. package/build/server/main/domain/rdp/lib/protocol/index.js.map +1 -0
  220. package/build/server/main/domain/rdp/lib/protocol/nla.js +549 -0
  221. package/build/server/main/domain/rdp/lib/protocol/nla.js.map +1 -0
  222. package/build/server/main/domain/rdp/lib/protocol/pdu/caps.js +486 -0
  223. package/build/server/main/domain/rdp/lib/protocol/pdu/caps.js.map +1 -0
  224. package/build/server/main/domain/rdp/lib/protocol/pdu/cliprdr.js +167 -0
  225. package/build/server/main/domain/rdp/lib/protocol/pdu/cliprdr.js.map +1 -0
  226. package/build/server/main/domain/rdp/lib/protocol/pdu/data.js +876 -0
  227. package/build/server/main/domain/rdp/lib/protocol/pdu/data.js.map +1 -0
  228. package/build/server/main/domain/rdp/lib/protocol/pdu/global.js +260 -0
  229. package/build/server/main/domain/rdp/lib/protocol/pdu/global.js.map +1 -0
  230. package/build/server/main/domain/rdp/lib/protocol/pdu/index.js +13 -0
  231. package/build/server/main/domain/rdp/lib/protocol/pdu/index.js.map +1 -0
  232. package/build/server/main/domain/rdp/lib/protocol/pdu/lic.js +199 -0
  233. package/build/server/main/domain/rdp/lib/protocol/pdu/lic.js.map +1 -0
  234. package/build/server/main/domain/rdp/lib/protocol/pdu/sec.js +333 -0
  235. package/build/server/main/domain/rdp/lib/protocol/pdu/sec.js.map +1 -0
  236. package/build/server/main/domain/rdp/lib/protocol/rdp.js +255 -0
  237. package/build/server/main/domain/rdp/lib/protocol/rdp.js.map +1 -0
  238. package/build/server/main/domain/rdp/lib/protocol/t125/gcc.js +354 -0
  239. package/build/server/main/domain/rdp/lib/protocol/t125/gcc.js.map +1 -0
  240. package/build/server/main/domain/rdp/lib/protocol/t125/index.js +7 -0
  241. package/build/server/main/domain/rdp/lib/protocol/t125/index.js.map +1 -0
  242. package/build/server/main/domain/rdp/lib/protocol/t125/mcs.js +318 -0
  243. package/build/server/main/domain/rdp/lib/protocol/t125/mcs.js.map +1 -0
  244. package/build/server/main/domain/rdp/lib/protocol/t125/per.js +188 -0
  245. package/build/server/main/domain/rdp/lib/protocol/t125/per.js.map +1 -0
  246. package/build/server/main/domain/rdp/lib/protocol/tpkt.js +94 -0
  247. package/build/server/main/domain/rdp/lib/protocol/tpkt.js.map +1 -0
  248. package/build/server/main/domain/rdp/lib/protocol/x224.js +207 -0
  249. package/build/server/main/domain/rdp/lib/protocol/x224.js.map +1 -0
  250. package/build/server/main/domain/rdp/lib/security/index.js +7 -0
  251. package/build/server/main/domain/rdp/lib/security/index.js.map +1 -0
  252. package/build/server/main/domain/rdp/lib/security/jsbn.js +1372 -0
  253. package/build/server/main/domain/rdp/lib/security/jsbn.js.map +1 -0
  254. package/build/server/main/domain/rdp/lib/security/md4.js +401 -0
  255. package/build/server/main/domain/rdp/lib/security/md4.js.map +1 -0
  256. package/build/server/main/domain/rdp/lib/security/rc4.js +45 -0
  257. package/build/server/main/domain/rdp/lib/security/rc4.js.map +1 -0
  258. package/build/server/main/domain/rdp/lib/security/rsa.js +15 -0
  259. package/build/server/main/domain/rdp/lib/security/rsa.js.map +1 -0
  260. package/build/server/main/domain/rdp/lib/security/x509.js +106 -0
  261. package/build/server/main/domain/rdp/lib/security/x509.js.map +1 -0
  262. package/build/server/main/domain/rdp/rdp.controller.js +116 -0
  263. package/build/server/main/domain/rdp/rdp.controller.js.map +1 -0
  264. package/build/server/main/domain/rdp/rdp.service.js +117 -0
  265. package/build/server/main/domain/rdp/rdp.service.js.map +1 -0
  266. package/build/server/main/domain/setting/setting.controller.js +621 -0
  267. package/build/server/main/domain/setting/setting.controller.js.map +1 -0
  268. package/build/server/main/domain/setting/setting.prefile.js +69 -0
  269. package/build/server/main/domain/setting/setting.prefile.js.map +1 -0
  270. package/build/server/main/domain/setting/setting.service.js +763 -0
  271. package/build/server/main/domain/setting/setting.service.js.map +1 -0
  272. package/build/server/main/domain/shell/shell.controller.js +92 -0
  273. package/build/server/main/domain/shell/shell.controller.js.map +1 -0
  274. package/build/server/main/domain/shell/shell.service.js +448 -0
  275. package/build/server/main/domain/shell/shell.service.js.map +1 -0
  276. package/build/server/main/domain/shell/util.js +101 -0
  277. package/build/server/main/domain/shell/util.js.map +1 -0
  278. package/build/server/main/domain/ssh/ssh.controller.js +203 -0
  279. package/build/server/main/domain/ssh/ssh.controller.js.map +1 -0
  280. package/build/server/main/domain/ssh/ssh.service.js +238 -0
  281. package/build/server/main/domain/ssh/ssh.service.js.map +1 -0
  282. package/build/server/main/domain/ssh/ssh.ssh2.js +217 -0
  283. package/build/server/main/domain/ssh/ssh.ssh2.js.map +1 -0
  284. package/build/server/main/domain/sys/sys.controller.js +374 -0
  285. package/build/server/main/domain/sys/sys.controller.js.map +1 -0
  286. package/build/server/main/domain/sys/sys.docker.service.js +339 -0
  287. package/build/server/main/domain/sys/sys.docker.service.js.map +1 -0
  288. package/build/server/main/domain/sys/sys.process.service.js +218 -0
  289. package/build/server/main/domain/sys/sys.process.service.js.map +1 -0
  290. package/build/server/main/domain/sys/sys.service.js +85 -0
  291. package/build/server/main/domain/sys/sys.service.js.map +1 -0
  292. package/build/server/main/domain/sys/sys.sys.service.js +206 -0
  293. package/build/server/main/domain/sys/sys.sys.service.js.map +1 -0
  294. package/build/server/main/domain/sys/sys.systemd.service.js +276 -0
  295. package/build/server/main/domain/sys/sys.systemd.service.js.map +1 -0
  296. package/build/server/main/domain/sys/sys.utl.js +42 -0
  297. package/build/server/main/domain/sys/sys.utl.js.map +1 -0
  298. package/build/server/main/domain/user/user.controller.js +277 -0
  299. package/build/server/main/domain/user/user.controller.js.map +1 -0
  300. package/build/server/main/domain/user/user.hash.js +8 -0
  301. package/build/server/main/domain/user/user.hash.js.map +1 -0
  302. package/build/server/main/domain/user/user.service.js +584 -0
  303. package/build/server/main/domain/user/user.service.js.map +1 -0
  304. package/build/server/main/domain/video/video.controller.js +71 -0
  305. package/build/server/main/domain/video/video.controller.js.map +1 -0
  306. package/build/server/main/domain/video/video.service.js +45 -0
  307. package/build/server/main/domain/video/video.service.js.map +1 -0
  308. package/build/server/main/main.js +171 -0
  309. package/build/server/main/main.js.map +1 -0
  310. package/build/server/main/other/Result.js +25 -0
  311. package/build/server/main/other/Result.js.map +1 -0
  312. package/build/server/main/other/cache.js +50 -0
  313. package/build/server/main/other/cache.js.map +1 -0
  314. package/build/server/main/other/config.js +6 -0
  315. package/build/server/main/other/config.js.map +1 -0
  316. package/build/server/main/other/middleware/AuthMiddleware.js +101 -0
  317. package/build/server/main/other/middleware/AuthMiddleware.js.map +1 -0
  318. package/build/server/main/other/middleware/GlobalErrorHandler.js +23 -0
  319. package/build/server/main/other/middleware/GlobalErrorHandler.js.map +1 -0
  320. package/build/server/main/other/middleware/decorator.js +15 -0
  321. package/build/server/main/other/middleware/decorator.js.map +1 -0
  322. package/build/server/main/other/middleware/redirect.js +20 -0
  323. package/build/server/main/other/middleware/redirect.js.map +1 -0
  324. package/build/server/main/server.js +22 -0
  325. package/build/server/main/server.js.map +1 -0
  326. package/build/server/main/threads/filecat/threads.filecat.js +16 -0
  327. package/build/server/main/threads/filecat/threads.filecat.js.map +1 -0
  328. package/build/server/main/threads/filecat/threads.work.filecat.js +7 -0
  329. package/build/server/main/threads/filecat/threads.work.filecat.js.map +1 -0
  330. package/build/server/main/threads/threads.main.js +224 -0
  331. package/build/server/main/threads/threads.main.js.map +1 -0
  332. package/build/server/main/threads/threads.type.js +19 -0
  333. package/build/server/main/threads/threads.type.js.map +1 -0
  334. package/build/server/main/threads/threads.work.js +52 -0
  335. package/build/server/main/threads/threads.work.js.map +1 -0
  336. package/build/server/main/watch.js +187 -0
  337. package/build/server/main/watch.js.map +1 -0
  338. package/build/server/tsconfig.tsbuildinfo +1 -0
  339. package/build/server/web/project/util/noty.js +45 -0
  340. package/build/server/web/project/util/noty.js.map +1 -0
  341. package/build/threads.work.filecat.js +1 -1
  342. package/package.json +5 -4
  343. package/shell/build.js +8 -0
  344. package/build/dist/543.9305b93ceeffabfa9862.js +0 -2
  345. package/build/jieba_rs_wasm_bg.wasm +0 -0
  346. package/build/main.js +0 -2
  347. package/build/main.js.LICENSE.txt +0 -445
  348. package/build/unrar.wasm +0 -0
  349. /package/build/dist/{377.f1e5a0d0f7800c8306ee.js.LICENSE.txt → 377.4047ae540e74884d3ff5.js.LICENSE.txt} +0 -0
  350. /package/build/dist/{543.9305b93ceeffabfa9862.js.LICENSE.txt → 543.ac5d314a52e99934103c.js.LICENSE.txt} +0 -0
  351. /package/build/dist/{943.7c72fe51510266a06ea6.js.LICENSE.txt → 943.d055d58eee66f1ab0414.js.LICENSE.txt} +0 -0
  352. /package/build/dist/{main.b593eb159b18a7b4eefa.js.LICENSE.txt → main.494c8bcf15274aeca600.js.LICENSE.txt} +0 -0
@@ -0,0 +1,659 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.workflowService = exports.WorkflowService = exports.work_children = exports.workflow_logger = exports.send_ws_type = void 0;
7
+ const WsData_1 = require("../../../../common/frame/WsData");
8
+ const file_req_1 = require("../../../../common/req/file.req");
9
+ const setting_service_1 = require("../../setting/setting.service");
10
+ const path_1 = __importDefault(require("path"));
11
+ const fs_extra_1 = __importDefault(require("fs-extra"));
12
+ const user_service_1 = require("../../user/user.service");
13
+ const user_req_1 = require("../../../../common/req/user.req");
14
+ const base_data_util_1 = require("../../data/basedata/base_data_util");
15
+ const StringUtil_1 = require("../../../../common/StringUtil");
16
+ const ValueUtil_1 = require("../../../../common/ValueUtil");
17
+ const FileUtil_1 = require("../FileUtil");
18
+ const workflow_util_1 = require("./workflow.util");
19
+ const workflow_process_1 = require("./workflow.process");
20
+ const common_util_1 = require("../../../../common/common.util");
21
+ const readYamlFile = require('read-yaml-file');
22
+ const Mustache = require('mustache');
23
+ var send_ws_type;
24
+ (function (send_ws_type) {
25
+ send_ws_type[send_ws_type["done"] = 0] = "done";
26
+ send_ws_type[send_ws_type["new_log"] = 1] = "new_log";
27
+ })(send_ws_type || (exports.send_ws_type = send_ws_type = {}));
28
+ class workflow_logger {
29
+ constructor(instance) {
30
+ this.wss_call_set = new Set();
31
+ this.instance = instance;
32
+ }
33
+ send_wss(type, ...wss) {
34
+ const r_list = [];
35
+ if (type !== send_ws_type.new_log) {
36
+ work_children.get_workflow_realtime_tree_list(r_list, this.instance);
37
+ }
38
+ for (const w of wss) {
39
+ const result = new WsData_1.WsData(WsData_1.CmdType.workflow_realtime_one_rsq);
40
+ result.context = {
41
+ done: type === undefined ? undefined : type === send_ws_type.done,
42
+ list: r_list,
43
+ new_log: this.running_log
44
+ };
45
+ w.sendData(result.encode());
46
+ }
47
+ }
48
+ send_all_wss(type) {
49
+ if (this.wss_call_set) {
50
+ this.send_wss(type, ...this.wss_call_set.values());
51
+ }
52
+ }
53
+ add_wss(wss) {
54
+ if (!this.wss_call_set.has(wss)) {
55
+ this.wss_call_set.add(wss);
56
+ }
57
+ this.send_wss(undefined, wss);
58
+ }
59
+ remove_wss(wss) {
60
+ if (!this.wss_call_set) {
61
+ this.wss_call_set.delete(wss);
62
+ }
63
+ }
64
+ }
65
+ exports.workflow_logger = workflow_logger;
66
+ class work_children {
67
+ constructor(yaml_path = undefined, workflow_dir_path = undefined) {
68
+ this.running_type = file_req_1.running_type.running;
69
+ this.import_files_map = new Map();
70
+ this.jobs_map = new Map();
71
+ this.done_jobs = new Set();
72
+ this.need_job_set = new Set();
73
+ this.pty_shell_set = new Set();
74
+ this.worker_children_use_yml_map = new Map();
75
+ this.yaml_path = yaml_path;
76
+ if (workflow_dir_path) {
77
+ this.workflow_dir_path = workflow_dir_path;
78
+ }
79
+ this.logger = new workflow_logger(this);
80
+ }
81
+ static get_workflow_realtime_tree_list(r_list, worker) {
82
+ for (const it of worker.jobs_map.values()) {
83
+ const v = {
84
+ name: it.name,
85
+ extra_data: { running_type: it.running_type },
86
+ code: it.code,
87
+ children: []
88
+ };
89
+ if (it.code !== 0 && it.steps) {
90
+ const children = [];
91
+ for (const step of it.steps ?? []) {
92
+ let name = '';
93
+ if (step.run) {
94
+ name = step.run;
95
+ }
96
+ else if (step["use-yml"]) {
97
+ name = step["use-yml"];
98
+ }
99
+ else if (step["run-js"]) {
100
+ name = step["run-js"];
101
+ }
102
+ else if (step["sleep"]) {
103
+ name = `sleep ${step.sleep}`;
104
+ }
105
+ else if (step["runs"]) {
106
+ name = JSON.stringify(step.runs);
107
+ }
108
+ const p = {
109
+ name: name,
110
+ extra_data: { running_type: step.running_type },
111
+ code: step.code,
112
+ children: []
113
+ };
114
+ const children_worker = worker.worker_children_use_yml_map.get(step['use-yml']);
115
+ if (children_worker) {
116
+ this.get_workflow_realtime_tree_list(p.children, children_worker);
117
+ }
118
+ children.push(p);
119
+ }
120
+ v.children = children;
121
+ }
122
+ r_list.push(v);
123
+ }
124
+ }
125
+ async init(param) {
126
+ if (param?.yaml_path) {
127
+ this.yaml_path = param.yaml_path;
128
+ }
129
+ if (param?.workflow_logger) {
130
+ this.logger = param.workflow_logger;
131
+ }
132
+ this.filename = path_1.default.basename(this.yaml_path);
133
+ const yaml_data = param?.yaml_data ?? await readYamlFile(this.yaml_path);
134
+ this.env = yaml_data.env ?? {};
135
+ if (param.pre_env) {
136
+ for (const key of Object.keys(param.pre_env)) {
137
+ this.env[key] = param.pre_env[key];
138
+ }
139
+ }
140
+ this.env['filecat_user_id'] = param.filecat_user_id;
141
+ this.env['filecat_user_name'] = param.filecat_user_name;
142
+ this.env['filecat_user_note'] = param.filecat_user_note;
143
+ let user_id = `${yaml_data.user_id || yaml_data['user-id'] || ""}`;
144
+ if (!user_id) {
145
+ user_id = user_service_1.userService.get_user_id(`${yaml_data.username}`);
146
+ }
147
+ if (!user_id) {
148
+ throw "user not exists";
149
+ }
150
+ this.user_id = user_id;
151
+ if (param?.yaml_path)
152
+ user_service_1.userService.check_user_path_by_user_id(this.user_id, param?.yaml_path);
153
+ user_service_1.userService.check_user_auth_by_user_id(this.user_id, user_req_1.UserAuth.workflow_exe_user, {
154
+ auto_throw: true,
155
+ root_check: true
156
+ });
157
+ if (!this.workflow_dir_path) {
158
+ let find_p = path_1.default.dirname(this.yaml_path);
159
+ let have_find = false;
160
+ while (true) {
161
+ if (await FileUtil_1.FileUtil.access(path_1.default.join(find_p, file_req_1.workflow_dir_name))) {
162
+ have_find = true;
163
+ break;
164
+ }
165
+ const p = path_1.default.join(find_p, "..");
166
+ if (p === find_p) {
167
+ have_find = false;
168
+ break;
169
+ }
170
+ find_p = p;
171
+ if (!user_service_1.userService.check_user_path_by_user_id(this.user_id, find_p, false)) {
172
+ have_find = false;
173
+ break;
174
+ }
175
+ }
176
+ if (have_find) {
177
+ this.workflow_dir_path = path_1.default.join(find_p, file_req_1.workflow_dir_name);
178
+ }
179
+ else {
180
+ this.workflow_dir_path = path_1.default.join(path_1.default.dirname(this.yaml_path), file_req_1.workflow_dir_name);
181
+ await fs_extra_1.default.ensureDir(this.workflow_dir_path);
182
+ }
183
+ }
184
+ if (yaml_data.jobs) {
185
+ for (const key of Object.keys(yaml_data.jobs)) {
186
+ const v = yaml_data.jobs[key];
187
+ v.key = key;
188
+ this.jobs_map.set(v.key, v);
189
+ }
190
+ }
191
+ if (yaml_data['import-files']) {
192
+ for (const p of yaml_data['import-files']) {
193
+ let p1 = p;
194
+ if (!path_1.default.isAbsolute(p)) {
195
+ p1 = path_1.default.join(path_1.default.dirname(this.yaml_path), p);
196
+ }
197
+ user_service_1.userService.check_user_path_by_user_id(this.user_id, p1);
198
+ const d = await readYamlFile(p1);
199
+ this.import_files_map.set(d.name, { yaml_path: p1, yaml_data: d });
200
+ }
201
+ }
202
+ yaml_data['run-name'] = Mustache.render(`${yaml_data['run-name'] ?? ""}`, this.env ?? {});
203
+ this["run-name"] = `${yaml_data['run-name'] ?? ""}`;
204
+ this.name = `${yaml_data.name}`;
205
+ if (param?.env) {
206
+ for (const key of Object.keys(param.env)) {
207
+ this.env[key] = param.env[key];
208
+ }
209
+ }
210
+ if (yaml_data['file-env']) {
211
+ for (const key of Object.keys(yaml_data['file-env'])) {
212
+ let p1 = yaml_data['file-env'][key];
213
+ if (!path_1.default.isAbsolute(p1)) {
214
+ p1 = path_1.default.join(path_1.default.dirname(this.yaml_path), p1);
215
+ }
216
+ user_service_1.userService.check_user_path_by_user_id(this.user_id, p1);
217
+ this.env[key] = (await FileUtil_1.FileUtil.readFileSync(p1)).toString();
218
+ }
219
+ }
220
+ return this;
221
+ }
222
+ async run_jobs(return_steps = false) {
223
+ const start_time = Date.now();
224
+ await new Promise(resolve => {
225
+ this.all_job_resolve = resolve;
226
+ const v_List = [...this.jobs_map.values()];
227
+ for (let i = 0; i < v_List.length; i++) {
228
+ const job = v_List[i];
229
+ this.run_job(job).then(() => {
230
+ });
231
+ }
232
+ });
233
+ const all_jobs = [];
234
+ let failed = false;
235
+ for (const it of this.jobs_map.values()) {
236
+ all_jobs.push(it);
237
+ if (it.code !== 0 && it.code !== undefined) {
238
+ failed = true;
239
+ }
240
+ }
241
+ this.close(failed ? file_req_1.running_type.fail : file_req_1.running_type.success);
242
+ if (return_steps) {
243
+ return { all_jobs, failed };
244
+ }
245
+ this.logger.send_all_wss(failed === true ? send_ws_type.done : undefined);
246
+ this.running_type = failed === false ? file_req_1.running_type.success : file_req_1.running_type.fail;
247
+ try {
248
+ const base_data_util = new base_data_util_1.Base_data_util({ base_dir: this.workflow_dir_path });
249
+ await base_data_util.init();
250
+ await base_data_util.insert(JSON.stringify({
251
+ all_jobs
252
+ }), JSON.stringify({
253
+ name: this.name,
254
+ "run-name": this["run-name"],
255
+ is_success: failed === false,
256
+ timestamp: (0, ValueUtil_1.formatter_time)(new Date()),
257
+ duration: `${((Date.now() - start_time) / 1000).toFixed(2)} s`
258
+ }));
259
+ }
260
+ catch (error) {
261
+ console.log('插入数据库失败', error);
262
+ }
263
+ }
264
+ done_fail_job_handle(job, fail_message) {
265
+ job.code = -1;
266
+ this.logger.send_all_wss();
267
+ job.message = fail_message;
268
+ this.close();
269
+ this.all_job_resolve("ok");
270
+ }
271
+ async run_job(job) {
272
+ try {
273
+ let job_can_run = false;
274
+ if (!job.if) {
275
+ job_can_run = true;
276
+ }
277
+ else {
278
+ job_can_run = await workflow_util_1.workflow_util.run_js(job.if, this.env);
279
+ }
280
+ if (job_can_run) {
281
+ workflow_util_1.workflow_util.handle_job_pre(job, this);
282
+ if (job['need-jobs']) {
283
+ if (!workflow_util_1.workflow_util.all_jobs_done(job['need-jobs'], this)) {
284
+ this.need_job_set.add(job);
285
+ return;
286
+ }
287
+ }
288
+ job.running_type = file_req_1.running_type.running;
289
+ const start_time = Date.now();
290
+ const process_runner = new workflow_process_1.WorkflowProcess(this, job);
291
+ this.pty_shell_set.add(process_runner.pty);
292
+ for (let i = 0; i < job.steps.length; i++) {
293
+ const step = job.steps[i];
294
+ if (step.if) {
295
+ if (!await workflow_util_1.workflow_util.run_js(step.if, this.env)) {
296
+ this.logger.send_all_wss();
297
+ continue;
298
+ }
299
+ }
300
+ step.running_type = file_req_1.running_type.running;
301
+ this.logger.send_all_wss();
302
+ if (step['sleep']) {
303
+ await common_util_1.CommonUtil.sleep(step['sleep']);
304
+ }
305
+ const step_start_time = Date.now();
306
+ try {
307
+ if (step["run-js"]) {
308
+ await workflow_util_1.workflow_util.run_code_js_by_step(step, job, this.env, true);
309
+ }
310
+ else if (step["use-yml"]) {
311
+ const yaml = this.import_files_map.get(step["use-yml"]);
312
+ if (step['with-env']) {
313
+ for (const key of Object.keys(step['with-env'])) {
314
+ step['with-env'][key] = Mustache.render(`${step['with-env'][key] ?? ""}`, this.env);
315
+ }
316
+ }
317
+ const worker = new work_children(undefined, this.workflow_dir_path);
318
+ await worker.init({
319
+ env: step['with-env'] ?? this.env,
320
+ yaml_data: yaml.yaml_data,
321
+ yaml_path: yaml.yaml_path,
322
+ filecat_user_name: this.env['filecat_user_name'],
323
+ filecat_user_id: this.env['filecat_user_id'],
324
+ filecat_user_note: this.env['filecat_user_note'],
325
+ workflow_logger: this.logger
326
+ });
327
+ this.worker_children_use_yml_map.set(step["use-yml"], worker);
328
+ const r = await worker.run_jobs(true);
329
+ step.use_job_children_list = r.all_jobs;
330
+ if (r.failed) {
331
+ step.code = -1;
332
+ this.logger.send_all_wss();
333
+ throw "";
334
+ }
335
+ step.code = 0;
336
+ this.logger.send_all_wss();
337
+ }
338
+ else if (step.run != null || step.runs != null) {
339
+ step.code = await process_runner.run_step(step);
340
+ if (step.code !== 0) {
341
+ throw step.message;
342
+ }
343
+ }
344
+ else {
345
+ step.code = 0;
346
+ }
347
+ }
348
+ catch (e) {
349
+ if (step['catch-js'] != null && await workflow_util_1.workflow_util.run_js(step['catch-js'], this.env)) {
350
+ }
351
+ else {
352
+ throw e;
353
+ }
354
+ }
355
+ finally {
356
+ step.duration = `${((Date.now() - step_start_time) / 1000).toFixed(2)} s`;
357
+ }
358
+ if (step['then-log']) {
359
+ const log = Mustache.render(`${step['then-log'] ?? ""}`, this.env);
360
+ this.logger.running_log = log;
361
+ if (!step.message) {
362
+ step.message = '';
363
+ }
364
+ step.message += log;
365
+ this.logger.send_all_wss();
366
+ if (step['then-log-file']) {
367
+ const p = step['then-log-file'];
368
+ let p1 = p;
369
+ if (!path_1.default.isAbsolute(p)) {
370
+ p1 = path_1.default.join(path_1.default.dirname(this.yaml_path), p);
371
+ }
372
+ user_service_1.userService.check_user_path_by_user_id(this.user_id, p1);
373
+ await FileUtil_1.FileUtil.writeFileSync(p1, log);
374
+ }
375
+ }
376
+ if (step["while"] != null && this.running_type === file_req_1.running_type.running && await workflow_util_1.workflow_util.run_js(step["while"], this.env)) {
377
+ i--;
378
+ await common_util_1.CommonUtil.sleep(100);
379
+ continue;
380
+ }
381
+ this.logger.send_all_wss();
382
+ }
383
+ this.pty_shell_set.delete(process_runner.pty);
384
+ job.duration = `${((Date.now() - start_time) / 1000).toFixed(2)} s`;
385
+ }
386
+ else {
387
+ job.duration = `0 s`;
388
+ }
389
+ if (job.while != null && this.running_type === file_req_1.running_type.running && await workflow_util_1.workflow_util.run_js(job.while, this.env)) {
390
+ workflow_util_1.workflow_util.reset_all_step_status(job);
391
+ await common_util_1.CommonUtil.sleep(100);
392
+ this.run_job(job);
393
+ console.log('run again job');
394
+ return;
395
+ }
396
+ job.code = 0;
397
+ this.done_jobs.add(job.key);
398
+ this.logger.send_all_wss();
399
+ if (this.need_job_set.size) {
400
+ const v_List = [...this.need_job_set];
401
+ for (let i = 0; i < v_List.length; i++) {
402
+ const job = v_List[i];
403
+ this.need_job_set.delete(job);
404
+ this.run_job(job).catch(e => {
405
+ throw e;
406
+ }).then(() => {
407
+ });
408
+ }
409
+ }
410
+ if (this.done_jobs.size === this.jobs_map.size) {
411
+ this.all_job_resolve("ok");
412
+ }
413
+ }
414
+ catch (error) {
415
+ if (job['catch-js'] != null && await workflow_util_1.workflow_util.run_js(job['catch-js'], this.env)) {
416
+ }
417
+ else {
418
+ console.log('workflows job error ', error);
419
+ this.done_fail_job_handle(job, typeof error === 'string' ? error : error?.message ?? JSON.stringify(error));
420
+ }
421
+ }
422
+ }
423
+ close(type) {
424
+ this.running_type = type ?? file_req_1.running_type.fail;
425
+ for (const it of this.pty_shell_set) {
426
+ it.close();
427
+ }
428
+ for (const worker of this.worker_children_use_yml_map.values()) {
429
+ worker.close(type);
430
+ }
431
+ this.all_job_resolve("ok");
432
+ }
433
+ }
434
+ exports.work_children = work_children;
435
+ const work_exec_map = new Map();
436
+ const realtime_user_dir_wss_map = new Map();
437
+ class WorkflowService {
438
+ async workflow_get_pre_inputs(path) {
439
+ const list = [];
440
+ const yml_data = await readYamlFile(path);
441
+ if (yml_data.inputs && typeof yml_data.inputs === "object") {
442
+ for (const key of Object.keys(yml_data.inputs)) {
443
+ const v = yml_data.inputs[key];
444
+ list.push({
445
+ key: key,
446
+ description: v.description,
447
+ required: v.required,
448
+ default: v.default,
449
+ options: v.options
450
+ });
451
+ }
452
+ }
453
+ return list;
454
+ }
455
+ async workflow_exec(data) {
456
+ const token = data.wss.token;
457
+ const pojo = data.context;
458
+ const root_path = setting_service_1.settingService.getFileRootPath(token);
459
+ const file_path = path_1.default.join(root_path, decodeURIComponent(pojo.path));
460
+ const user_info = user_service_1.userService.get_user_info_by_token(token);
461
+ if (pojo.run_type === file_req_1.WorkRunType.start) {
462
+ await this.exec_file(file_path, user_info, pojo.inputs);
463
+ }
464
+ else if (pojo.run_type === file_req_1.WorkRunType.stop) {
465
+ const worker = work_exec_map.get(file_path);
466
+ if (!worker)
467
+ throw "no task exists";
468
+ worker.close();
469
+ work_exec_map.delete(file_path);
470
+ this.online_change_push();
471
+ }
472
+ }
473
+ async exec_file(file_path, user_info, inputs) {
474
+ if (work_exec_map.get(file_path))
475
+ throw "Workflow exec task already exists";
476
+ const worker = new work_children(file_path);
477
+ work_exec_map.set(file_path, worker);
478
+ try {
479
+ const pre_env = {};
480
+ if (inputs) {
481
+ for (const it of inputs) {
482
+ pre_env[it.key] = it.default;
483
+ }
484
+ }
485
+ await worker.init({
486
+ filecat_user_id: user_service_1.userService.get_user_id(user_info.username),
487
+ filecat_user_name: user_info.username,
488
+ filecat_user_note: user_info.note,
489
+ pre_env
490
+ });
491
+ }
492
+ catch (e) {
493
+ worker.running_type = file_req_1.running_type.fail;
494
+ this.online_change_push();
495
+ work_exec_map.delete(file_path);
496
+ throw e;
497
+ }
498
+ this.online_change_push();
499
+ worker.run_jobs().then(e => {
500
+ this.online_change_push();
501
+ work_exec_map.delete(file_path);
502
+ }).catch(e => {
503
+ this.online_change_push();
504
+ worker.running_type = file_req_1.running_type.fail;
505
+ console.log('任务执行失败', e);
506
+ work_exec_map.delete(file_path);
507
+ worker.close();
508
+ });
509
+ }
510
+ async workflow_realtime_one(data) {
511
+ const token = data.wss.token;
512
+ const pojo = data.context;
513
+ const root_path = setting_service_1.settingService.getFileRootPath(token);
514
+ const file_path = path_1.default.join(root_path, decodeURIComponent(pojo.filename_path));
515
+ user_service_1.userService.check_user_path(data.wss.token, file_path);
516
+ const v = work_exec_map.get(file_path);
517
+ if (!v) {
518
+ return;
519
+ }
520
+ v.logger.add_wss(data.wss);
521
+ data.wss.setClose(() => {
522
+ v.logger.remove_wss(data.wss);
523
+ });
524
+ }
525
+ async workflow_get(data) {
526
+ const token = data.wss.token;
527
+ const pojo = data.context;
528
+ const root_path = setting_service_1.settingService.getFileRootPath(token);
529
+ const dir_path = path_1.default.join(root_path, decodeURIComponent(pojo.dir_path), file_req_1.workflow_dir_name);
530
+ user_service_1.userService.check_user_path(data.wss.token, dir_path);
531
+ const basedata = new base_data_util_1.Base_data_util({ base_dir: dir_path });
532
+ const r = new file_req_1.WorkflowGetRsq();
533
+ if (pojo.index !== undefined) {
534
+ r.one_data = await basedata.find_one_by_index(pojo.index);
535
+ return r;
536
+ }
537
+ const running_list = [];
538
+ for (const it of work_exec_map.values()) {
539
+ running_list.push({
540
+ meta: {
541
+ is_running: true,
542
+ name: it.name,
543
+ "run-name": it["run-name"]
544
+ },
545
+ index: -1
546
+ });
547
+ }
548
+ r.list = [...running_list, ...await basedata.find_page(pojo.page_num, pojo.page_size, true)];
549
+ r.total = await basedata.find_num();
550
+ return r;
551
+ }
552
+ async workflow_search_by_run_name(data) {
553
+ const token = data.wss.token;
554
+ const pojo = data.context;
555
+ const root_path = setting_service_1.settingService.getFileRootPath(token);
556
+ const dir_path = path_1.default.join(root_path, decodeURIComponent(pojo.dir_path), file_req_1.workflow_dir_name);
557
+ user_service_1.userService.check_user_path(data.wss.token, dir_path);
558
+ const basedata = new base_data_util_1.Base_data_util({ base_dir: dir_path });
559
+ const r = new file_req_1.WorkflowGetRsq();
560
+ const regex = new RegExp(pojo.search_name);
561
+ r.list = await basedata.find_list((index, meta) => {
562
+ if (!meta)
563
+ return false;
564
+ return regex.test(JSON.parse(meta)['run-name']);
565
+ });
566
+ r.total = await basedata.find_num();
567
+ return r;
568
+ }
569
+ workflow_realtime(data) {
570
+ const token = data.wss.token;
571
+ const pojo = data.context;
572
+ const wss = data.wss;
573
+ const root_path = setting_service_1.settingService.getFileRootPath(token);
574
+ const dir_path = path_1.default.join(root_path, pojo.dir_path);
575
+ user_service_1.userService.check_user_path(data.wss.token, dir_path);
576
+ const runing_filename_list = [];
577
+ const parent = (0, StringUtil_1.removeTrailingPath)(decodeURIComponent(dir_path));
578
+ for (const key of work_exec_map.keys()) {
579
+ const child = (0, StringUtil_1.removeTrailingPath)(path_1.default.dirname(key));
580
+ const p = work_exec_map.get(key);
581
+ if (parent === child && p.running_type === file_req_1.running_type.running) {
582
+ runing_filename_list.push(p.filename);
583
+ }
584
+ }
585
+ const pre_path = wss.dataMap.get("pre_path");
586
+ if (pre_path) {
587
+ let set = realtime_user_dir_wss_map.get(pre_path);
588
+ if (set) {
589
+ set.delete(wss);
590
+ }
591
+ }
592
+ let set = realtime_user_dir_wss_map.get(parent);
593
+ if (!set) {
594
+ set = new Set();
595
+ realtime_user_dir_wss_map.set(parent, set);
596
+ }
597
+ set.add(wss);
598
+ wss.setClose(() => {
599
+ set.delete(wss);
600
+ });
601
+ wss.dataMap.set("pre_path", parent);
602
+ const rsq = new file_req_1.WorkFlowRealTimeRsq();
603
+ rsq.running_file_list = runing_filename_list;
604
+ return rsq;
605
+ }
606
+ online_change_push() {
607
+ const map = new Map();
608
+ const faile_map = new Map();
609
+ const run_map = new Map();
610
+ for (const it of work_exec_map.values()) {
611
+ const key = it.yaml_path;
612
+ const dir_path = (0, StringUtil_1.removeTrailingPath)(path_1.default.dirname(key));
613
+ let list;
614
+ if (it.running_type === file_req_1.running_type.fail) {
615
+ list = faile_map.get(dir_path);
616
+ if (!list) {
617
+ list = [];
618
+ faile_map.set(dir_path, list);
619
+ }
620
+ }
621
+ else if (it.running_type === file_req_1.running_type.success) {
622
+ list = map.get(dir_path);
623
+ if (!list) {
624
+ list = [];
625
+ map.set(dir_path, list);
626
+ }
627
+ }
628
+ else {
629
+ list = run_map.get(dir_path);
630
+ if (!list) {
631
+ list = [];
632
+ run_map.set(dir_path, list);
633
+ }
634
+ }
635
+ list.push(work_exec_map.get(key).filename);
636
+ }
637
+ for (const key of realtime_user_dir_wss_map.keys()) {
638
+ const result = new WsData_1.WsData(WsData_1.CmdType.workflow_realtime);
639
+ const rsq = new file_req_1.WorkFlowRealTimeRsq();
640
+ result.context = rsq;
641
+ if (map.has(key)) {
642
+ rsq.sucess_file_list = map.get(key);
643
+ }
644
+ if (faile_map.has(key)) {
645
+ rsq.failed_file_list = faile_map.get(key);
646
+ }
647
+ if (run_map.has(key)) {
648
+ rsq.running_file_list = run_map.get(key);
649
+ }
650
+ const user_wss_set = realtime_user_dir_wss_map.get(key);
651
+ for (const v of user_wss_set) {
652
+ v.sendData(result.encode());
653
+ }
654
+ }
655
+ }
656
+ }
657
+ exports.WorkflowService = WorkflowService;
658
+ exports.workflowService = new WorkflowService();
659
+ //# sourceMappingURL=workflow.service.js.map