@milaboratories/pl-middle-layer 1.42.1 → 1.42.3

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 (410) hide show
  1. package/dist/block_registry/index.d.ts +0 -1
  2. package/dist/block_registry/registry-v2-provider.cjs +22 -0
  3. package/dist/block_registry/registry-v2-provider.cjs.map +1 -0
  4. package/dist/block_registry/registry-v2-provider.d.ts +0 -1
  5. package/dist/block_registry/registry-v2-provider.js +20 -0
  6. package/dist/block_registry/registry-v2-provider.js.map +1 -0
  7. package/dist/block_registry/registry.cjs +231 -0
  8. package/dist/block_registry/registry.cjs.map +1 -0
  9. package/dist/block_registry/registry.d.ts +0 -1
  10. package/dist/block_registry/registry.js +227 -0
  11. package/dist/block_registry/registry.js.map +1 -0
  12. package/dist/block_registry/registry.test.d.ts +0 -1
  13. package/dist/block_registry/watcher.cjs +174 -0
  14. package/dist/block_registry/watcher.cjs.map +1 -0
  15. package/dist/block_registry/watcher.d.ts +0 -1
  16. package/dist/block_registry/watcher.js +171 -0
  17. package/dist/block_registry/watcher.js.map +1 -0
  18. package/dist/block_registry/well_known_registries.cjs +19 -0
  19. package/dist/block_registry/well_known_registries.cjs.map +1 -0
  20. package/dist/block_registry/well_known_registries.d.ts +0 -1
  21. package/dist/block_registry/well_known_registries.js +15 -0
  22. package/dist/block_registry/well_known_registries.js.map +1 -0
  23. package/dist/cfg_render/executor.cjs +159 -0
  24. package/dist/cfg_render/executor.cjs.map +1 -0
  25. package/dist/cfg_render/executor.d.ts +0 -1
  26. package/dist/cfg_render/executor.js +156 -0
  27. package/dist/cfg_render/executor.js.map +1 -0
  28. package/dist/cfg_render/executor.test.d.ts +0 -1
  29. package/dist/cfg_render/operation.d.ts +0 -1
  30. package/dist/cfg_render/renderer.cjs +528 -0
  31. package/dist/cfg_render/renderer.cjs.map +1 -0
  32. package/dist/cfg_render/renderer.d.ts +0 -1
  33. package/dist/cfg_render/renderer.js +525 -0
  34. package/dist/cfg_render/renderer.js.map +1 -0
  35. package/dist/cfg_render/traverse.cjs +65 -0
  36. package/dist/cfg_render/traverse.cjs.map +1 -0
  37. package/dist/cfg_render/traverse.d.ts +0 -1
  38. package/dist/cfg_render/traverse.js +63 -0
  39. package/dist/cfg_render/traverse.js.map +1 -0
  40. package/dist/cfg_render/util.cjs +32 -0
  41. package/dist/cfg_render/util.cjs.map +1 -0
  42. package/dist/cfg_render/util.d.ts +0 -1
  43. package/dist/cfg_render/util.js +28 -0
  44. package/dist/cfg_render/util.js.map +1 -0
  45. package/dist/debug/index.cjs +21 -0
  46. package/dist/debug/index.cjs.map +1 -0
  47. package/dist/debug/index.d.ts +0 -1
  48. package/dist/debug/index.js +19 -0
  49. package/dist/debug/index.js.map +1 -0
  50. package/dist/dev_env/index.cjs +59 -0
  51. package/dist/dev_env/index.cjs.map +1 -0
  52. package/dist/dev_env/index.d.ts +0 -1
  53. package/dist/dev_env/index.js +48 -0
  54. package/dist/dev_env/index.js.map +1 -0
  55. package/dist/dev_env/util.cjs +37 -0
  56. package/dist/dev_env/util.cjs.map +1 -0
  57. package/dist/dev_env/util.d.ts +0 -1
  58. package/dist/dev_env/util.js +16 -0
  59. package/dist/dev_env/util.js.map +1 -0
  60. package/dist/index.cjs +74 -0
  61. package/dist/index.cjs.map +1 -0
  62. package/dist/index.d.ts +0 -1
  63. package/dist/index.js +15 -75
  64. package/dist/index.js.map +1 -1
  65. package/dist/js_render/computable_context.cjs +525 -0
  66. package/dist/js_render/computable_context.cjs.map +1 -0
  67. package/dist/js_render/computable_context.d.ts +0 -1
  68. package/dist/js_render/computable_context.js +523 -0
  69. package/dist/js_render/computable_context.js.map +1 -0
  70. package/dist/js_render/context.cjs +229 -0
  71. package/dist/js_render/context.cjs.map +1 -0
  72. package/dist/js_render/context.d.ts +0 -1
  73. package/dist/js_render/context.js +226 -0
  74. package/dist/js_render/context.js.map +1 -0
  75. package/dist/js_render/index.cjs +163 -0
  76. package/dist/js_render/index.cjs.map +1 -0
  77. package/dist/js_render/index.d.ts +0 -1
  78. package/dist/js_render/index.js +160 -0
  79. package/dist/js_render/index.js.map +1 -0
  80. package/dist/middle_layer/active_cfg.cjs +37 -0
  81. package/dist/middle_layer/active_cfg.cjs.map +1 -0
  82. package/dist/middle_layer/active_cfg.d.ts +0 -1
  83. package/dist/middle_layer/active_cfg.js +35 -0
  84. package/dist/middle_layer/active_cfg.js.map +1 -0
  85. package/dist/middle_layer/block.cjs +51 -0
  86. package/dist/middle_layer/block.cjs.map +1 -0
  87. package/dist/middle_layer/block.d.ts +0 -1
  88. package/dist/middle_layer/block.js +48 -0
  89. package/dist/middle_layer/block.js.map +1 -0
  90. package/dist/middle_layer/block_ctx.cjs +87 -0
  91. package/dist/middle_layer/block_ctx.cjs.map +1 -0
  92. package/dist/middle_layer/block_ctx.d.ts +0 -1
  93. package/dist/middle_layer/block_ctx.js +84 -0
  94. package/dist/middle_layer/block_ctx.js.map +1 -0
  95. package/dist/middle_layer/block_ctx_unsafe.cjs +19 -0
  96. package/dist/middle_layer/block_ctx_unsafe.cjs.map +1 -0
  97. package/dist/middle_layer/block_ctx_unsafe.d.ts +0 -1
  98. package/dist/middle_layer/block_ctx_unsafe.js +16 -0
  99. package/dist/middle_layer/block_ctx_unsafe.js.map +1 -0
  100. package/dist/middle_layer/driver_kit.cjs +42 -0
  101. package/dist/middle_layer/driver_kit.cjs.map +1 -0
  102. package/dist/middle_layer/driver_kit.d.ts +0 -1
  103. package/dist/middle_layer/driver_kit.js +40 -0
  104. package/dist/middle_layer/driver_kit.js.map +1 -0
  105. package/dist/middle_layer/frontend_path.cjs +64 -0
  106. package/dist/middle_layer/frontend_path.cjs.map +1 -0
  107. package/dist/middle_layer/frontend_path.d.ts +0 -1
  108. package/dist/middle_layer/frontend_path.js +62 -0
  109. package/dist/middle_layer/frontend_path.js.map +1 -0
  110. package/dist/middle_layer/index.d.ts +0 -1
  111. package/dist/middle_layer/middle_layer.cjs +226 -0
  112. package/dist/middle_layer/middle_layer.cjs.map +1 -0
  113. package/dist/middle_layer/middle_layer.d.ts +0 -1
  114. package/dist/middle_layer/middle_layer.js +224 -0
  115. package/dist/middle_layer/middle_layer.js.map +1 -0
  116. package/dist/middle_layer/navigation_states.cjs +41 -0
  117. package/dist/middle_layer/navigation_states.cjs.map +1 -0
  118. package/dist/middle_layer/navigation_states.d.ts +0 -1
  119. package/dist/middle_layer/navigation_states.js +39 -0
  120. package/dist/middle_layer/navigation_states.js.map +1 -0
  121. package/dist/middle_layer/ops.cjs +75 -0
  122. package/dist/middle_layer/ops.cjs.map +1 -0
  123. package/dist/middle_layer/ops.d.ts +0 -1
  124. package/dist/middle_layer/ops.js +70 -0
  125. package/dist/middle_layer/ops.js.map +1 -0
  126. package/dist/middle_layer/project.cjs +446 -0
  127. package/dist/middle_layer/project.cjs.map +1 -0
  128. package/dist/middle_layer/project.d.ts +0 -1
  129. package/dist/middle_layer/project.js +444 -0
  130. package/dist/middle_layer/project.js.map +1 -0
  131. package/dist/middle_layer/project_list.cjs +53 -0
  132. package/dist/middle_layer/project_list.cjs.map +1 -0
  133. package/dist/middle_layer/project_list.d.ts +0 -1
  134. package/dist/middle_layer/project_list.js +48 -0
  135. package/dist/middle_layer/project_list.js.map +1 -0
  136. package/dist/middle_layer/project_overview.cjs +225 -0
  137. package/dist/middle_layer/project_overview.cjs.map +1 -0
  138. package/dist/middle_layer/project_overview.d.ts +0 -1
  139. package/dist/middle_layer/project_overview.js +204 -0
  140. package/dist/middle_layer/project_overview.js.map +1 -0
  141. package/dist/middle_layer/project_overview_light.cjs +20 -0
  142. package/dist/middle_layer/project_overview_light.cjs.map +1 -0
  143. package/dist/middle_layer/project_overview_light.d.ts +0 -1
  144. package/dist/middle_layer/project_overview_light.js +18 -0
  145. package/dist/middle_layer/project_overview_light.js.map +1 -0
  146. package/dist/middle_layer/render.cjs +26 -0
  147. package/dist/middle_layer/render.cjs.map +1 -0
  148. package/dist/middle_layer/render.d.ts +0 -1
  149. package/dist/middle_layer/render.js +23 -0
  150. package/dist/middle_layer/render.js.map +1 -0
  151. package/dist/middle_layer/render.test.d.ts +0 -1
  152. package/dist/middle_layer/types.d.ts +0 -1
  153. package/dist/middle_layer/util.cjs +22 -0
  154. package/dist/middle_layer/util.cjs.map +1 -0
  155. package/dist/middle_layer/util.d.ts +0 -1
  156. package/dist/middle_layer/util.js +20 -0
  157. package/dist/middle_layer/util.js.map +1 -0
  158. package/dist/model/args.cjs +62 -0
  159. package/dist/model/args.cjs.map +1 -0
  160. package/dist/model/args.d.ts +0 -1
  161. package/dist/model/args.js +58 -0
  162. package/dist/model/args.js.map +1 -0
  163. package/dist/model/block_pack.d.ts +0 -1
  164. package/dist/model/block_pack_spec.cjs +11 -0
  165. package/dist/model/block_pack_spec.cjs.map +1 -0
  166. package/dist/model/block_pack_spec.d.ts +0 -1
  167. package/dist/model/block_pack_spec.js +8 -0
  168. package/dist/model/block_pack_spec.js.map +1 -0
  169. package/dist/model/frontend.d.ts +0 -1
  170. package/dist/model/index.d.ts +0 -1
  171. package/dist/model/project_helper.cjs +36 -0
  172. package/dist/model/project_helper.cjs.map +1 -0
  173. package/dist/model/project_helper.d.ts +0 -1
  174. package/dist/model/project_helper.js +34 -0
  175. package/dist/model/project_helper.js.map +1 -0
  176. package/dist/model/project_model.cjs +74 -0
  177. package/dist/model/project_model.cjs.map +1 -0
  178. package/dist/model/project_model.d.ts +0 -1
  179. package/dist/model/project_model.js +54 -0
  180. package/dist/model/project_model.js.map +1 -0
  181. package/dist/model/project_model.test.d.ts +0 -1
  182. package/dist/model/project_model_util.cjs +176 -0
  183. package/dist/model/project_model_util.cjs.map +1 -0
  184. package/dist/model/project_model_util.d.ts +0 -1
  185. package/dist/model/project_model_util.js +170 -0
  186. package/dist/model/project_model_util.js.map +1 -0
  187. package/dist/model/project_model_util.test.d.ts +0 -1
  188. package/dist/model/project_model_v1.cjs +9 -0
  189. package/dist/model/project_model_v1.cjs.map +1 -0
  190. package/dist/model/project_model_v1.d.ts +0 -1
  191. package/dist/model/project_model_v1.js +6 -0
  192. package/dist/model/project_model_v1.js.map +1 -0
  193. package/dist/model/template_spec.d.ts +0 -1
  194. package/dist/mutator/block-pack/block_pack.cjs +233 -0
  195. package/dist/mutator/block-pack/block_pack.cjs.map +1 -0
  196. package/dist/mutator/block-pack/block_pack.d.ts +0 -1
  197. package/dist/mutator/block-pack/block_pack.js +227 -0
  198. package/dist/mutator/block-pack/block_pack.js.map +1 -0
  199. package/dist/mutator/block-pack/block_pack.test.d.ts +0 -1
  200. package/dist/mutator/block-pack/frontend.cjs +21 -0
  201. package/dist/mutator/block-pack/frontend.cjs.map +1 -0
  202. package/dist/mutator/block-pack/frontend.d.ts +0 -1
  203. package/dist/mutator/block-pack/frontend.js +19 -0
  204. package/dist/mutator/block-pack/frontend.js.map +1 -0
  205. package/dist/mutator/context_export.cjs +26 -0
  206. package/dist/mutator/context_export.cjs.map +1 -0
  207. package/dist/mutator/context_export.d.ts +2 -3
  208. package/dist/mutator/context_export.js +23 -0
  209. package/dist/mutator/context_export.js.map +1 -0
  210. package/dist/mutator/migration.cjs +57 -0
  211. package/dist/mutator/migration.cjs.map +1 -0
  212. package/dist/mutator/migration.d.ts +0 -1
  213. package/dist/mutator/migration.js +55 -0
  214. package/dist/mutator/migration.js.map +1 -0
  215. package/dist/mutator/project.cjs +997 -0
  216. package/dist/mutator/project.cjs.map +1 -0
  217. package/dist/mutator/project.d.ts +0 -1
  218. package/dist/mutator/project.js +992 -0
  219. package/dist/mutator/project.js.map +1 -0
  220. package/dist/mutator/project.test.d.ts +0 -1
  221. package/dist/mutator/template/direct_template_loader.cjs +146 -0
  222. package/dist/mutator/template/direct_template_loader.cjs.map +1 -0
  223. package/dist/mutator/template/direct_template_loader.d.ts +0 -1
  224. package/dist/mutator/template/direct_template_loader.js +143 -0
  225. package/dist/mutator/template/direct_template_loader.js.map +1 -0
  226. package/dist/mutator/template/direct_template_loader_v3.cjs +139 -0
  227. package/dist/mutator/template/direct_template_loader_v3.cjs.map +1 -0
  228. package/dist/mutator/template/direct_template_loader_v3.d.ts +0 -1
  229. package/dist/mutator/template/direct_template_loader_v3.js +137 -0
  230. package/dist/mutator/template/direct_template_loader_v3.js.map +1 -0
  231. package/dist/mutator/template/render_block.cjs +43 -0
  232. package/dist/mutator/template/render_block.cjs.map +1 -0
  233. package/dist/mutator/template/render_block.d.ts +0 -1
  234. package/dist/mutator/template/render_block.js +34 -0
  235. package/dist/mutator/template/render_block.js.map +1 -0
  236. package/dist/mutator/template/render_template.cjs +35 -0
  237. package/dist/mutator/template/render_template.cjs.map +1 -0
  238. package/dist/mutator/template/render_template.d.ts +0 -1
  239. package/dist/mutator/template/render_template.js +33 -0
  240. package/dist/mutator/template/render_template.js.map +1 -0
  241. package/dist/mutator/template/template_loading.cjs +71 -0
  242. package/dist/mutator/template/template_loading.cjs.map +1 -0
  243. package/dist/mutator/template/template_loading.d.ts +0 -1
  244. package/dist/mutator/template/template_loading.js +60 -0
  245. package/dist/mutator/template/template_loading.js.map +1 -0
  246. package/dist/mutator/template/template_render.test.d.ts +0 -1
  247. package/dist/network_check/network_check.cjs +267 -0
  248. package/dist/network_check/network_check.cjs.map +1 -0
  249. package/dist/network_check/network_check.d.ts +0 -1
  250. package/dist/network_check/network_check.js +264 -0
  251. package/dist/network_check/network_check.js.map +1 -0
  252. package/dist/network_check/network_check.test.d.ts +0 -1
  253. package/dist/network_check/pings.cjs +107 -0
  254. package/dist/network_check/pings.cjs.map +1 -0
  255. package/dist/network_check/pings.d.ts +0 -1
  256. package/dist/network_check/pings.js +96 -0
  257. package/dist/network_check/pings.js.map +1 -0
  258. package/dist/network_check/template.cjs +318 -0
  259. package/dist/network_check/template.cjs.map +1 -0
  260. package/dist/network_check/template.d.ts +0 -1
  261. package/dist/network_check/template.js +302 -0
  262. package/dist/network_check/template.js.map +1 -0
  263. package/dist/network_check/template.test.d.ts +0 -1
  264. package/dist/network_check/test_utils.d.ts +0 -1
  265. package/dist/node_modules/.pnpm/@rollup_plugin-typescript@12.1.4_rollup@4.45.1_tslib@2.7.0_typescript@5.6.3/node_modules/tslib/tslib.es6.cjs +77 -0
  266. package/dist/node_modules/.pnpm/@rollup_plugin-typescript@12.1.4_rollup@4.45.1_tslib@2.7.0_typescript@5.6.3/node_modules/tslib/tslib.es6.cjs.map +1 -0
  267. package/dist/node_modules/.pnpm/@rollup_plugin-typescript@12.1.4_rollup@4.45.1_tslib@2.7.0_typescript@5.6.3/node_modules/tslib/tslib.es6.js +74 -0
  268. package/dist/node_modules/.pnpm/@rollup_plugin-typescript@12.1.4_rollup@4.45.1_tslib@2.7.0_typescript@5.6.3/node_modules/tslib/tslib.es6.js.map +1 -0
  269. package/dist/pool/data.cjs +298 -0
  270. package/dist/pool/data.cjs.map +1 -0
  271. package/dist/pool/data.d.ts +7 -9
  272. package/dist/pool/data.js +282 -0
  273. package/dist/pool/data.js.map +1 -0
  274. package/dist/pool/driver.cjs +620 -0
  275. package/dist/pool/driver.cjs.map +1 -0
  276. package/dist/pool/driver.d.ts +0 -1
  277. package/dist/pool/driver.js +598 -0
  278. package/dist/pool/driver.js.map +1 -0
  279. package/dist/pool/index.d.ts +0 -1
  280. package/dist/pool/p_object_collection.cjs +87 -0
  281. package/dist/pool/p_object_collection.cjs.map +1 -0
  282. package/dist/pool/p_object_collection.d.ts +0 -1
  283. package/dist/pool/p_object_collection.js +84 -0
  284. package/dist/pool/p_object_collection.js.map +1 -0
  285. package/dist/pool/ref_count_pool.cjs +58 -0
  286. package/dist/pool/ref_count_pool.cjs.map +1 -0
  287. package/dist/pool/ref_count_pool.d.ts +0 -1
  288. package/dist/pool/ref_count_pool.js +56 -0
  289. package/dist/pool/ref_count_pool.js.map +1 -0
  290. package/dist/pool/result_pool.cjs +265 -0
  291. package/dist/pool/result_pool.cjs.map +1 -0
  292. package/dist/pool/result_pool.d.ts +0 -1
  293. package/dist/pool/result_pool.js +263 -0
  294. package/dist/pool/result_pool.js.map +1 -0
  295. package/dist/test/block_packs.d.ts +0 -1
  296. package/dist/test/explicit_templates.d.ts +0 -1
  297. package/dist/test/known_templates.d.ts +0 -1
  298. package/dist/test_env.d.ts +0 -1
  299. package/dist/worker/WorkerManager.cjs +53 -0
  300. package/dist/worker/WorkerManager.cjs.map +1 -0
  301. package/dist/worker/WorkerManager.d.ts +0 -1
  302. package/dist/worker/WorkerManager.js +51 -0
  303. package/dist/worker/WorkerManager.js.map +1 -0
  304. package/dist/worker/worker.cjs +16 -0
  305. package/dist/worker/worker.cjs.map +1 -0
  306. package/dist/worker/worker.d.ts +0 -1
  307. package/dist/worker/worker.js +14 -0
  308. package/dist/worker/worker.js.map +1 -0
  309. package/dist/worker/workerApi.cjs +20 -0
  310. package/dist/worker/workerApi.cjs.map +1 -0
  311. package/dist/worker/workerApi.d.ts +1 -3
  312. package/dist/worker/workerApi.js +18 -0
  313. package/dist/worker/workerApi.js.map +1 -0
  314. package/package.json +26 -34
  315. package/src/cfg_render/executor.test.ts +5 -4
  316. package/src/model/project_model.test.ts +3 -3
  317. package/src/model/project_model_util.test.ts +3 -2
  318. package/src/mutator/block-pack/block_pack.test.ts +5 -4
  319. package/src/mutator/project.test.ts +4 -4
  320. package/src/mutator/template/template_render.test.ts +7 -6
  321. package/src/network_check/network_check.test.ts +1 -0
  322. package/src/network_check/test_utils.ts +2 -0
  323. package/src/worker/WorkerManager.ts +6 -8
  324. package/dist/block_registry/index.d.ts.map +0 -1
  325. package/dist/block_registry/registry-v2-provider.d.ts.map +0 -1
  326. package/dist/block_registry/registry.d.ts.map +0 -1
  327. package/dist/block_registry/registry.test.d.ts.map +0 -1
  328. package/dist/block_registry/watcher.d.ts.map +0 -1
  329. package/dist/block_registry/well_known_registries.d.ts.map +0 -1
  330. package/dist/cfg_render/executor.d.ts.map +0 -1
  331. package/dist/cfg_render/executor.test.d.ts.map +0 -1
  332. package/dist/cfg_render/operation.d.ts.map +0 -1
  333. package/dist/cfg_render/renderer.d.ts.map +0 -1
  334. package/dist/cfg_render/traverse.d.ts.map +0 -1
  335. package/dist/cfg_render/util.d.ts.map +0 -1
  336. package/dist/debug/index.d.ts.map +0 -1
  337. package/dist/dev_env/index.d.ts.map +0 -1
  338. package/dist/dev_env/util.d.ts.map +0 -1
  339. package/dist/index.d.ts.map +0 -1
  340. package/dist/index.mjs +0 -6742
  341. package/dist/index.mjs.map +0 -1
  342. package/dist/js_render/computable_context.d.ts.map +0 -1
  343. package/dist/js_render/context.d.ts.map +0 -1
  344. package/dist/js_render/index.d.ts.map +0 -1
  345. package/dist/middle_layer/active_cfg.d.ts.map +0 -1
  346. package/dist/middle_layer/block.d.ts.map +0 -1
  347. package/dist/middle_layer/block_ctx.d.ts.map +0 -1
  348. package/dist/middle_layer/block_ctx_unsafe.d.ts.map +0 -1
  349. package/dist/middle_layer/driver_kit.d.ts.map +0 -1
  350. package/dist/middle_layer/frontend_path.d.ts.map +0 -1
  351. package/dist/middle_layer/index.d.ts.map +0 -1
  352. package/dist/middle_layer/middle_layer.d.ts.map +0 -1
  353. package/dist/middle_layer/navigation_states.d.ts.map +0 -1
  354. package/dist/middle_layer/ops.d.ts.map +0 -1
  355. package/dist/middle_layer/project.d.ts.map +0 -1
  356. package/dist/middle_layer/project_list.d.ts.map +0 -1
  357. package/dist/middle_layer/project_overview.d.ts.map +0 -1
  358. package/dist/middle_layer/project_overview_light.d.ts.map +0 -1
  359. package/dist/middle_layer/render.d.ts.map +0 -1
  360. package/dist/middle_layer/render.test.d.ts.map +0 -1
  361. package/dist/middle_layer/types.d.ts.map +0 -1
  362. package/dist/middle_layer/util.d.ts.map +0 -1
  363. package/dist/model/args.d.ts.map +0 -1
  364. package/dist/model/block_pack.d.ts.map +0 -1
  365. package/dist/model/block_pack_spec.d.ts.map +0 -1
  366. package/dist/model/frontend.d.ts.map +0 -1
  367. package/dist/model/index.d.ts.map +0 -1
  368. package/dist/model/project_helper.d.ts.map +0 -1
  369. package/dist/model/project_model.d.ts.map +0 -1
  370. package/dist/model/project_model.test.d.ts.map +0 -1
  371. package/dist/model/project_model_util.d.ts.map +0 -1
  372. package/dist/model/project_model_util.test.d.ts.map +0 -1
  373. package/dist/model/project_model_v1.d.ts.map +0 -1
  374. package/dist/model/template_spec.d.ts.map +0 -1
  375. package/dist/mutator/block-pack/block_pack.d.ts.map +0 -1
  376. package/dist/mutator/block-pack/block_pack.test.d.ts.map +0 -1
  377. package/dist/mutator/block-pack/frontend.d.ts.map +0 -1
  378. package/dist/mutator/context_export.d.ts.map +0 -1
  379. package/dist/mutator/migration.d.ts.map +0 -1
  380. package/dist/mutator/project.d.ts.map +0 -1
  381. package/dist/mutator/project.test.d.ts.map +0 -1
  382. package/dist/mutator/template/direct_template_loader.d.ts.map +0 -1
  383. package/dist/mutator/template/direct_template_loader_v3.d.ts.map +0 -1
  384. package/dist/mutator/template/render_block.d.ts.map +0 -1
  385. package/dist/mutator/template/render_template.d.ts.map +0 -1
  386. package/dist/mutator/template/template_loading.d.ts.map +0 -1
  387. package/dist/mutator/template/template_render.test.d.ts.map +0 -1
  388. package/dist/network_check/network_check.d.ts.map +0 -1
  389. package/dist/network_check/network_check.test.d.ts.map +0 -1
  390. package/dist/network_check/pings.d.ts.map +0 -1
  391. package/dist/network_check/template.d.ts.map +0 -1
  392. package/dist/network_check/template.test.d.ts.map +0 -1
  393. package/dist/network_check/test_utils.d.ts.map +0 -1
  394. package/dist/pool/data.d.ts.map +0 -1
  395. package/dist/pool/driver.d.ts.map +0 -1
  396. package/dist/pool/index.d.ts.map +0 -1
  397. package/dist/pool/p_object_collection.d.ts.map +0 -1
  398. package/dist/pool/ref_count_pool.d.ts.map +0 -1
  399. package/dist/pool/result_pool.d.ts.map +0 -1
  400. package/dist/test/block_packs.d.ts.map +0 -1
  401. package/dist/test/explicit_templates.d.ts.map +0 -1
  402. package/dist/test/known_templates.d.ts.map +0 -1
  403. package/dist/test_env.d.ts.map +0 -1
  404. package/dist/worker/WorkerManager.d.ts.map +0 -1
  405. package/dist/worker/worker.d.ts.map +0 -1
  406. package/dist/worker/workerApi.d.ts.map +0 -1
  407. package/dist/worker.js +0 -2
  408. package/dist/worker.js.map +0 -1
  409. package/dist/worker.mjs +0 -20
  410. package/dist/worker.mjs.map +0 -1
@@ -0,0 +1,598 @@
1
+ import { isPlTreeNodeAccessor } from '@milaboratories/pl-tree';
2
+ import { PFrameDriverError, isPFrameDriverError, ensureError, mapPObjectData, mapDataInfo, isDataInfo, extractAllColumns, mapPTableDef, isAbortError } from '@platforma-sdk/model';
3
+ import { LRUCache } from 'lru-cache';
4
+ import { RefCountResourcePool } from './ref_count_pool.js';
5
+ import { parseDataInfoResource, makeDataInfoFromPColumnValues, traverseParquetPartitionedResource, allBlobs, mapBlobs } from './data.js';
6
+ import { createHash } from 'node:crypto';
7
+ import { emptyDir, ConcurrencyLimitingExecutor, assertNever } from '@milaboratories/ts-helpers';
8
+ import canonicalize from 'canonicalize';
9
+ import { PFrame } from '@milaboratories/pframes-rs-node';
10
+ import * as fs from 'node:fs/promises';
11
+ import * as path from 'node:path';
12
+ import { getDebugFlags } from '../debug/index.js';
13
+
14
+ function blobKey(res) {
15
+ return String(res.id);
16
+ }
17
+ const valueTypes = ['Int', 'Long', 'Float', 'Double', 'String', 'Bytes'];
18
+ function migrateFilters(filters) {
19
+ const filtersV1 = [];
20
+ const filtersV2 = [];
21
+ for (const filter of filters) {
22
+ if (filter.type === 'bySingleColumn') {
23
+ filtersV1.push(filter);
24
+ filtersV2.push({
25
+ ...filter,
26
+ type: 'bySingleColumnV2',
27
+ });
28
+ }
29
+ else {
30
+ filtersV2.push(filter);
31
+ }
32
+ }
33
+ if (filtersV1.length > 0) {
34
+ const filtersV1Json = JSON.stringify(filtersV1);
35
+ console.warn(`type overriten from 'bySingleColumn' to 'bySingleColumnV2' for filters: ${filtersV1Json}`);
36
+ }
37
+ return filtersV2;
38
+ }
39
+ function migratePTableFilters(def) {
40
+ if (!('partitionFilters' in def)) {
41
+ // For old blocks assume all axes filters to be partition filters
42
+ return {
43
+ ...def,
44
+ partitionFilters: migrateFilters(def.filters.filter((f) => f.column.type === 'axis')),
45
+ filters: migrateFilters(def.filters.filter((f) => f.column.type === 'column')),
46
+ };
47
+ }
48
+ return {
49
+ ...def,
50
+ partitionFilters: migrateFilters(def.partitionFilters),
51
+ filters: migrateFilters(def.filters),
52
+ };
53
+ }
54
+ const bigintReplacer = (_, v) => (typeof v === 'bigint' ? v.toString() : v);
55
+ class PTableCache {
56
+ logger;
57
+ ops;
58
+ perFrame = new Map();
59
+ global;
60
+ disposeListeners = new Map();
61
+ constructor(logger, ops) {
62
+ this.logger = logger;
63
+ this.ops = ops;
64
+ this.global = new LRUCache({
65
+ maxSize: this.ops.pFramesCacheMaxSize,
66
+ dispose: (resource, key, reason) => {
67
+ if (reason === 'evict') {
68
+ this.perFrame.get(resource.resource.pFrame)?.delete(key);
69
+ }
70
+ if (this.perFrame.get(resource.resource.pFrame)?.size === 0) {
71
+ this.perFrame.delete(resource.resource.pFrame);
72
+ }
73
+ const disposeListener = this.disposeListeners.get(key);
74
+ this.disposeListeners.delete(key);
75
+ resource.resource.disposeSignal.removeEventListener('abort', disposeListener);
76
+ resource.unref();
77
+ if (getDebugFlags().logPFrameRequests) {
78
+ this.logger.info(`calculateTableData cache - removed PTable ${key}`);
79
+ }
80
+ },
81
+ });
82
+ }
83
+ cache(resource, size) {
84
+ const key = resource.key;
85
+ if (getDebugFlags().logPFrameRequests) {
86
+ this.logger.info(`calculateTableData cache - added PTable ${key} with size ${size}`);
87
+ }
88
+ this.global.set(key, resource, { size });
89
+ let perFrame = this.perFrame.get(resource.resource.pFrame);
90
+ if (!perFrame) {
91
+ perFrame = new LRUCache({
92
+ max: this.ops.pFrameCacheMaxCount,
93
+ dispose: (_resource, key, reason) => {
94
+ if (reason === 'evict') {
95
+ this.global.delete(key);
96
+ }
97
+ },
98
+ });
99
+ this.perFrame.set(resource.resource.pFrame, perFrame);
100
+ }
101
+ perFrame.set(key, resource);
102
+ const disposeListener = () => {
103
+ this.perFrame.get(resource.resource.pFrame)?.delete(key);
104
+ this.global.delete(key);
105
+ };
106
+ this.disposeListeners.set(key, disposeListener);
107
+ resource.resource.disposeSignal.addEventListener('abort', disposeListener);
108
+ }
109
+ }
110
+ class PFrameHolder {
111
+ blobDriver;
112
+ logger;
113
+ spillPath;
114
+ pFramePromise;
115
+ abortController = new AbortController();
116
+ blobIdToResource = new Map();
117
+ blobHandleComputables = new Map();
118
+ constructor(blobDriver, logger, spillPath, columns) {
119
+ this.blobDriver = blobDriver;
120
+ this.logger = logger;
121
+ this.spillPath = spillPath;
122
+ const logFunc = (level, message) => this.logger[level](message);
123
+ for (const column of columns) {
124
+ for (const blob of allBlobs(column.data)) {
125
+ this.blobIdToResource.set(blobKey(blob), blob);
126
+ }
127
+ }
128
+ const distinctСolumns = [
129
+ ...new Map(columns.map((column) => ({
130
+ ...column,
131
+ data: mapBlobs(column.data, blobKey),
132
+ })).map((item) => [canonicalize(item), item])).values(),
133
+ ];
134
+ try {
135
+ const pFrame = new PFrame(this.spillPath, logFunc);
136
+ pFrame.setDataSource(this);
137
+ const promises = [];
138
+ for (const column of distinctСolumns) {
139
+ pFrame.addColumnSpec(column.id, column.spec);
140
+ promises.push(pFrame.setColumnData(column.id, column.data, { signal: this.disposeSignal }));
141
+ }
142
+ this.pFramePromise = Promise.all(promises)
143
+ .then(() => pFrame)
144
+ .catch((err) => {
145
+ this.dispose();
146
+ pFrame.dispose();
147
+ throw new PFrameDriverError(`PFrame creation failed asynchronously, columns: ${JSON.stringify(distinctСolumns)}, error: ${ensureError(err)}`);
148
+ });
149
+ }
150
+ catch (err) {
151
+ throw new PFrameDriverError(`PFrame creation failed synchronously, columns: ${JSON.stringify(distinctСolumns)}, error: ${ensureError(err)}`);
152
+ }
153
+ }
154
+ getOrCreateComputableForBlob(blobId) {
155
+ let computable = this.blobHandleComputables.get(blobId);
156
+ if (computable !== undefined)
157
+ return computable;
158
+ const blobResource = this.blobIdToResource.get(blobId);
159
+ if (blobResource === undefined)
160
+ throw new PFrameDriverError(`Blob with id ${blobId} not found.`);
161
+ // precalculation of value tree will trigger the download proecess right away
162
+ computable = this.blobDriver.getDownloadedBlob(blobResource).withPreCalculatedValueTree();
163
+ this.blobHandleComputables.set(blobId, computable);
164
+ return computable;
165
+ }
166
+ preloadBlob = async (blobIds) => {
167
+ const computables = blobIds.map((blobId) => this.getOrCreateComputableForBlob(blobId));
168
+ for (const computable of computables) {
169
+ try {
170
+ await computable.awaitStableFullValue(this.disposeSignal);
171
+ }
172
+ catch (err) {
173
+ if (isAbortError(err)) {
174
+ break; // silence abort errors
175
+ }
176
+ throw err;
177
+ }
178
+ }
179
+ };
180
+ resolveBlobContent = async (blobId) => {
181
+ const computable = this.getOrCreateComputableForBlob(blobId);
182
+ const path = this.blobDriver.getLocalPath((await computable.awaitStableValue(this.disposeSignal)).handle);
183
+ return await fs.readFile(path);
184
+ };
185
+ get disposeSignal() {
186
+ return this.abortController.signal;
187
+ }
188
+ dispose() {
189
+ this.abortController.abort();
190
+ for (const computable of this.blobHandleComputables.values())
191
+ computable.resetState();
192
+ }
193
+ async [Symbol.asyncDispose]() {
194
+ this.dispose();
195
+ await this.pFramePromise
196
+ .then((pFrame) => pFrame.dispose())
197
+ .catch(() => { });
198
+ }
199
+ }
200
+ class PTableHolder {
201
+ pFrame;
202
+ pTablePromise;
203
+ predecessor;
204
+ abortController = new AbortController();
205
+ combinedDisposeSignal;
206
+ constructor(pFrame, pFrameDisposeSignal, pTablePromise, predecessor) {
207
+ this.pFrame = pFrame;
208
+ this.pTablePromise = pTablePromise;
209
+ this.predecessor = predecessor;
210
+ this.combinedDisposeSignal = AbortSignal.any([pFrameDisposeSignal, this.abortController.signal]);
211
+ }
212
+ get disposeSignal() {
213
+ return this.combinedDisposeSignal;
214
+ }
215
+ async [Symbol.asyncDispose]() {
216
+ this.abortController.abort();
217
+ await this.pTablePromise
218
+ .then((pTable) => pTable.dispose())
219
+ .catch(() => { });
220
+ this.predecessor?.unref();
221
+ }
222
+ }
223
+ class PFrameDriver {
224
+ blobDriver;
225
+ logger;
226
+ spillPath;
227
+ pFrames;
228
+ pTables;
229
+ pTableCache;
230
+ frameConcurrencyLimiter;
231
+ tableConcurrencyLimiter;
232
+ async pprofDump() {
233
+ return await PFrame.pprofDump();
234
+ }
235
+ static async init(blobDriver, logger, spillPath, ops) {
236
+ const resolvedSpillPath = path.resolve(spillPath);
237
+ await emptyDir(resolvedSpillPath);
238
+ return new PFrameDriver(blobDriver, logger, resolvedSpillPath, ops);
239
+ }
240
+ constructor(blobDriver, logger, spillPath, ops) {
241
+ this.blobDriver = blobDriver;
242
+ this.logger = logger;
243
+ this.spillPath = spillPath;
244
+ const concurrencyLimiter = new ConcurrencyLimitingExecutor(ops.pFrameConcurrency);
245
+ this.frameConcurrencyLimiter = concurrencyLimiter;
246
+ this.tableConcurrencyLimiter = new ConcurrencyLimitingExecutor(ops.pTableConcurrency);
247
+ this.pTableCache = new PTableCache(this.logger, ops);
248
+ this.pFrames = new (class extends RefCountResourcePool {
249
+ blobDriver;
250
+ logger;
251
+ spillPath;
252
+ constructor(blobDriver, logger, spillPath) {
253
+ super();
254
+ this.blobDriver = blobDriver;
255
+ this.logger = logger;
256
+ this.spillPath = spillPath;
257
+ }
258
+ acquire(params) {
259
+ return super.acquire(params);
260
+ }
261
+ getByKey(key) {
262
+ const resource = super.tryGetByKey(key);
263
+ if (!resource)
264
+ throw new PFrameDriverError(`PFrame not found, handle = ${key}`);
265
+ return resource;
266
+ }
267
+ createNewResource(params) {
268
+ if (getDebugFlags().logPFrameRequests)
269
+ logger.info(`PFrame creation (pFrameHandle = ${this.calculateParamsKey(params)}): ${JSON.stringify(params, bigintReplacer)}`);
270
+ return new PFrameHolder(this.blobDriver, this.logger, this.spillPath, params);
271
+ }
272
+ calculateParamsKey(params) {
273
+ try {
274
+ return stableKeyFromPFrameData(params);
275
+ }
276
+ catch (err) {
277
+ if (isPFrameDriverError(err))
278
+ throw err;
279
+ throw new PFrameDriverError(`PFrame handle calculation failed, request: ${JSON.stringify(params, bigintReplacer)}, error: ${ensureError(err)}`);
280
+ }
281
+ }
282
+ })(this.blobDriver, this.logger, this.spillPath);
283
+ this.pTables = new (class extends RefCountResourcePool {
284
+ pFrames;
285
+ constructor(pFrames) {
286
+ super();
287
+ this.pFrames = pFrames;
288
+ }
289
+ getByKey(key) {
290
+ const resource = super.tryGetByKey(key);
291
+ if (!resource)
292
+ throw new PFrameDriverError(`PTable not found, handle = ${key}`);
293
+ return resource;
294
+ }
295
+ createNewResource(params) {
296
+ if (getDebugFlags().logPFrameRequests) {
297
+ logger.info(`PTable creation (pTableHandle = ${this.calculateParamsKey(params)}): ${JSON.stringify(params, bigintReplacer)}`);
298
+ }
299
+ const handle = params.pFrameHandle;
300
+ const { pFramePromise, disposeSignal } = this.pFrames.getByKey(handle);
301
+ // 3. Sort
302
+ if (params.def.sorting.length > 0) {
303
+ const predecessor = this.acquire({
304
+ ...params,
305
+ def: {
306
+ ...params.def,
307
+ sorting: [],
308
+ },
309
+ });
310
+ const { resource: { pTablePromise } } = predecessor;
311
+ const sortedTable = pTablePromise.then((pTable) => pTable.sort(params.def.sorting));
312
+ return new PTableHolder(handle, disposeSignal, sortedTable, predecessor);
313
+ }
314
+ // 2. Filter
315
+ if (params.def.filters.length > 0) {
316
+ const predecessor = this.acquire({
317
+ ...params,
318
+ def: {
319
+ ...params.def,
320
+ filters: [],
321
+ },
322
+ });
323
+ const { resource: { pTablePromise } } = predecessor;
324
+ const filteredTable = pTablePromise.then((pTable) => pTable.filter(params.def.filters));
325
+ return new PTableHolder(handle, disposeSignal, filteredTable, predecessor);
326
+ }
327
+ // 1. Join
328
+ const table = pFramePromise.then((pFrame) => pFrame.createTable({
329
+ src: joinEntryToInternal(params.def.src),
330
+ filters: params.def.partitionFilters,
331
+ }));
332
+ return new PTableHolder(handle, disposeSignal, table);
333
+ }
334
+ calculateParamsKey(params) {
335
+ try {
336
+ return stableKeyFromFullPTableDef(params);
337
+ }
338
+ catch (err) {
339
+ throw new PFrameDriverError(`PTable handle calculation failed, request: ${JSON.stringify(params)}, error: ${ensureError(err)}`);
340
+ }
341
+ }
342
+ })(this.pFrames);
343
+ }
344
+ //
345
+ // Internal / Config API Methods
346
+ //
347
+ createPFrame(def, ctx) {
348
+ const internalData = def
349
+ .filter((c) => valueTypes.find((t) => t === c.spec.valueType))
350
+ .map((c) => mapPObjectData(c, (d) => isPlTreeNodeAccessor(d)
351
+ ? parseDataInfoResource(d)
352
+ : isDataInfo(d)
353
+ ? d.type === 'ParquetPartitioned'
354
+ ? mapDataInfo(d, (a) => traverseParquetPartitionedResource(a))
355
+ : mapDataInfo(d, (a) => a.resourceInfo)
356
+ : makeDataInfoFromPColumnValues(c.spec, d)));
357
+ const res = this.pFrames.acquire(internalData);
358
+ ctx.addOnDestroy(res.unref);
359
+ return res.key;
360
+ }
361
+ createPTable(rawDef, ctx) {
362
+ const def = migratePTableFilters(rawDef);
363
+ const pFrameHandle = this.createPFrame(extractAllColumns(def.src), ctx);
364
+ const defIds = mapPTableDef(def, (c) => c.id);
365
+ const res = this.pTables.acquire({ def: defIds, pFrameHandle });
366
+ if (getDebugFlags().logPFrameRequests)
367
+ this.logger.info(`Create PTable call (pFrameHandle = ${pFrameHandle}; pTableHandle = ${JSON.stringify(res)}): ${JSON.stringify(mapPTableDef(def, (c) => c.spec), bigintReplacer)}`);
368
+ ctx.addOnDestroy(res.unref); // in addition to pframe unref added in createPFrame above
369
+ return res.key;
370
+ }
371
+ //
372
+ // PFrame istance methods
373
+ //
374
+ async findColumns(handle, request) {
375
+ const iRequest = {
376
+ ...request,
377
+ compatibleWith: request.compatibleWith.length !== 0
378
+ ? [{
379
+ axesSpec: [
380
+ ...new Map(request.compatibleWith.map((item) => [canonicalize(item), item])).values(),
381
+ ],
382
+ qualifications: [],
383
+ }]
384
+ : [],
385
+ };
386
+ const { pFramePromise } = this.pFrames.getByKey(handle);
387
+ const pFrame = await pFramePromise;
388
+ const responce = await pFrame.findColumns(iRequest);
389
+ return {
390
+ hits: responce.hits
391
+ .filter((h) => // only exactly matching columns
392
+ h.mappingVariants.length === 0
393
+ || h.mappingVariants.some((v) => v.qualifications.forHit.length === 0
394
+ && v.qualifications.forQueries.every((q) => q.length === 0)))
395
+ .map((h) => h.hit),
396
+ };
397
+ }
398
+ async getColumnSpec(handle, columnId) {
399
+ const { pFramePromise } = this.pFrames.getByKey(handle);
400
+ const pFrame = await pFramePromise;
401
+ return await pFrame.getColumnSpec(columnId);
402
+ }
403
+ async listColumns(handle) {
404
+ const { pFramePromise } = this.pFrames.getByKey(handle);
405
+ const pFrame = await pFramePromise;
406
+ return await pFrame.listColumns();
407
+ }
408
+ async calculateTableData(handle, request, range, signal) {
409
+ if (getDebugFlags().logPFrameRequests) {
410
+ this.logger.info(`Call calculateTableData, handle = ${handle}, request = ${JSON.stringify(request, bigintReplacer)}`);
411
+ }
412
+ const table = this.pTables.acquire({
413
+ pFrameHandle: handle,
414
+ def: migratePTableFilters(request),
415
+ });
416
+ const { resource: { pTablePromise, disposeSignal } } = table;
417
+ const pTable = await pTablePromise;
418
+ const combinedSignal = AbortSignal.any([signal, disposeSignal].filter((s) => !!s));
419
+ return await this.frameConcurrencyLimiter.run(async () => {
420
+ try {
421
+ const spec = pTable.getSpec();
422
+ const data = await pTable.getData([...spec.keys()], {
423
+ range,
424
+ signal: combinedSignal,
425
+ });
426
+ const size = await pTable.getFootprint({
427
+ withPredecessors: true,
428
+ signal: combinedSignal,
429
+ });
430
+ this.pTableCache.cache(table, size);
431
+ return spec.map((spec, i) => ({
432
+ spec: spec,
433
+ data: data[i],
434
+ }));
435
+ }
436
+ catch (err) {
437
+ table.unref();
438
+ throw err;
439
+ }
440
+ });
441
+ }
442
+ async getUniqueValues(handle, request, signal) {
443
+ if (getDebugFlags().logPFrameRequests) {
444
+ this.logger.info(`Call getUniqueValues, handle = ${handle}, request = ${JSON.stringify(request, bigintReplacer)}`);
445
+ }
446
+ const { pFramePromise, disposeSignal } = this.pFrames.getByKey(handle);
447
+ const pFrame = await pFramePromise;
448
+ const combinedSignal = AbortSignal.any([signal, disposeSignal].filter((s) => !!s));
449
+ return await this.frameConcurrencyLimiter.run(async () => {
450
+ return await pFrame.getUniqueValues({
451
+ ...request,
452
+ filters: migrateFilters(request.filters),
453
+ }, {
454
+ signal: combinedSignal,
455
+ });
456
+ });
457
+ }
458
+ //
459
+ // PTable istance methods
460
+ //
461
+ async getSpec(handle) {
462
+ const { pTablePromise } = this.pTables.getByKey(handle);
463
+ const pTable = await pTablePromise;
464
+ return pTable.getSpec();
465
+ }
466
+ async getShape(handle, signal) {
467
+ const { pTablePromise, disposeSignal } = this.pTables.getByKey(handle);
468
+ const pTable = await pTablePromise;
469
+ const combinedSignal = AbortSignal.any([signal, disposeSignal].filter((s) => !!s));
470
+ return await this.tableConcurrencyLimiter.run(async () => {
471
+ return await pTable.getShape({
472
+ signal: combinedSignal,
473
+ });
474
+ });
475
+ }
476
+ async getData(handle, columnIndices, range, signal) {
477
+ const { pTablePromise, disposeSignal } = this.pTables.getByKey(handle);
478
+ const pTable = await pTablePromise;
479
+ const combinedSignal = AbortSignal.any([signal, disposeSignal].filter((s) => !!s));
480
+ return await this.tableConcurrencyLimiter.run(async () => {
481
+ return await pTable.getData(columnIndices, {
482
+ range,
483
+ signal: combinedSignal,
484
+ });
485
+ });
486
+ }
487
+ }
488
+ function joinEntryToInternal(entry) {
489
+ switch (entry.type) {
490
+ case 'column':
491
+ return {
492
+ type: 'column',
493
+ columnId: entry.column,
494
+ };
495
+ case 'slicedColumn':
496
+ return {
497
+ type: 'slicedColumn',
498
+ columnId: entry.column,
499
+ newId: entry.newId,
500
+ axisFilters: entry.axisFilters,
501
+ };
502
+ case 'inlineColumn':
503
+ return {
504
+ type: 'inlineColumn',
505
+ newId: entry.column.id,
506
+ spec: entry.column.spec,
507
+ dataInfo: {
508
+ type: 'Json',
509
+ keyLength: entry.column.spec.axesSpec.length,
510
+ data: entry.column.data.reduce((acc, row) => {
511
+ acc[JSON.stringify(row.key)] = row.val;
512
+ return acc;
513
+ }, {}),
514
+ },
515
+ };
516
+ case 'inner':
517
+ case 'full':
518
+ return {
519
+ type: entry.type,
520
+ entries: entry.entries.map((col) => joinEntryToInternal(col)),
521
+ };
522
+ case 'outer':
523
+ return {
524
+ type: 'outer',
525
+ primary: joinEntryToInternal(entry.primary),
526
+ secondary: entry.secondary.map((col) => joinEntryToInternal(col)),
527
+ };
528
+ default:
529
+ assertNever(entry);
530
+ }
531
+ }
532
+ function stableKeyFromFullPTableDef(data) {
533
+ const hash = createHash('sha256');
534
+ hash.update(canonicalize(data));
535
+ return hash.digest().toString('hex');
536
+ }
537
+ function stableKeyFromPFrameData(data) {
538
+ const orderedData = [...data].map((column) => mapPObjectData(column, (r) => {
539
+ let result;
540
+ const type = r.type;
541
+ switch (type) {
542
+ case 'Json':
543
+ result = {
544
+ type: r.type,
545
+ keyLength: r.keyLength,
546
+ payload: Object.entries(r.data).map(([part, value]) => ({
547
+ key: part,
548
+ value,
549
+ })),
550
+ };
551
+ break;
552
+ case 'JsonPartitioned':
553
+ result = {
554
+ type: r.type,
555
+ keyLength: r.partitionKeyLength,
556
+ payload: Object.entries(r.parts).map(([part, info]) => ({
557
+ key: part,
558
+ value: blobKey(info),
559
+ })),
560
+ };
561
+ break;
562
+ case 'BinaryPartitioned':
563
+ result = {
564
+ type: r.type,
565
+ keyLength: r.partitionKeyLength,
566
+ payload: Object.entries(r.parts).map(([part, info]) => ({
567
+ key: part,
568
+ value: [blobKey(info.index), blobKey(info.values)],
569
+ })),
570
+ };
571
+ break;
572
+ case 'ParquetPartitioned':
573
+ result = {
574
+ type: r.type,
575
+ keyLength: r.partitionKeyLength,
576
+ payload: Object.entries(r.parts).map(([part, info]) => ({
577
+ key: part,
578
+ value: info.dataDigest || [
579
+ blobKey(info.data),
580
+ JSON.stringify({ axes: info.axes, column: info.column }),
581
+ ],
582
+ })),
583
+ };
584
+ break;
585
+ default:
586
+ throw new PFrameDriverError(`unsupported resource type: ${JSON.stringify(type)}`);
587
+ }
588
+ result.payload.sort((lhs, rhs) => lhs.key.localeCompare(rhs.key));
589
+ return result;
590
+ }));
591
+ orderedData.sort((lhs, rhs) => lhs.id.localeCompare(rhs.id));
592
+ const hash = createHash('sha256');
593
+ hash.update(canonicalize(orderedData));
594
+ return hash.digest().toString('hex');
595
+ }
596
+
597
+ export { PFrameDriver };
598
+ //# sourceMappingURL=driver.js.map