@milaboratories/pl-middle-layer 1.51.0 → 1.52.0
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.
- package/dist/cfg_render/executor.cjs +2 -2
- package/dist/cfg_render/executor.js +1 -1
- package/dist/debug/index.cjs +4 -1
- package/dist/debug/index.cjs.map +1 -1
- package/dist/debug/index.js +4 -1
- package/dist/debug/index.js.map +1 -1
- package/dist/index.cjs +14 -0
- package/dist/index.d.ts +3 -2
- package/dist/index.js +2 -1
- package/dist/js_render/computable_context.cjs +12 -2
- package/dist/js_render/computable_context.cjs.map +1 -1
- package/dist/js_render/computable_context.js +12 -2
- package/dist/js_render/computable_context.js.map +1 -1
- package/dist/js_render/context.cjs +36 -3
- package/dist/js_render/context.cjs.map +1 -1
- package/dist/js_render/context.js +36 -3
- package/dist/js_render/context.js.map +1 -1
- package/dist/js_render/index.cjs +5 -1
- package/dist/js_render/index.cjs.map +1 -1
- package/dist/js_render/index.js +5 -1
- package/dist/js_render/index.js.map +1 -1
- package/dist/middle_layer/project.cjs +8 -5
- package/dist/middle_layer/project.cjs.map +1 -1
- package/dist/middle_layer/project.js +8 -5
- package/dist/middle_layer/project.js.map +1 -1
- package/dist/middle_layer/project_overview.cjs +28 -22
- package/dist/middle_layer/project_overview.cjs.map +1 -1
- package/dist/middle_layer/project_overview.js +28 -22
- package/dist/middle_layer/project_overview.js.map +1 -1
- package/dist/model/block_pack_spec.cjs.map +1 -1
- package/dist/model/block_pack_spec.d.ts +2 -2
- package/dist/model/block_pack_spec.js.map +1 -1
- package/dist/model/template_spec.d.ts +7 -2
- package/dist/mutator/block-pack/block_pack.cjs +20 -1
- package/dist/mutator/block-pack/block_pack.cjs.map +1 -1
- package/dist/mutator/block-pack/block_pack.d.ts +4 -0
- package/dist/mutator/block-pack/block_pack.js +19 -1
- package/dist/mutator/block-pack/block_pack.js.map +1 -1
- package/dist/mutator/template/template_cache.cjs +515 -0
- package/dist/mutator/template/template_cache.cjs.map +1 -0
- package/dist/mutator/template/template_cache.d.ts +78 -0
- package/dist/mutator/template/template_cache.js +502 -0
- package/dist/mutator/template/template_cache.js.map +1 -0
- package/dist/mutator/template/template_loading.cjs +3 -1
- package/dist/mutator/template/template_loading.cjs.map +1 -1
- package/dist/mutator/template/template_loading.js +3 -1
- package/dist/mutator/template/template_loading.js.map +1 -1
- package/package.json +11 -11
- package/src/debug/index.ts +6 -0
- package/src/index.ts +1 -0
- package/src/js_render/computable_context.ts +13 -2
- package/src/js_render/context.ts +58 -5
- package/src/js_render/index.ts +8 -1
- package/src/middle_layer/project.ts +12 -8
- package/src/middle_layer/project_overview.ts +6 -0
- package/src/model/block_pack_spec.ts +2 -2
- package/src/model/template_spec.ts +11 -1
- package/src/mutator/block-pack/block_pack.ts +35 -1
- package/src/mutator/template/template_cache.test.ts +373 -0
- package/src/mutator/template/template_cache.ts +763 -0
- package/src/mutator/template/template_loading.ts +3 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"computable_context.js","names":[],"sources":["../../src/js_render/computable_context.ts"],"sourcesContent":["import type { ComputableCtx } from \"@milaboratories/computable\";\nimport { Computable } from \"@milaboratories/computable\";\nimport type { PlTreeNodeAccessor } from \"@milaboratories/pl-tree\";\nimport { checkBlockFlag } from \"@platforma-sdk/model\";\nimport type {\n ArchiveFormat,\n CommonFieldTraverseOps as CommonFieldTraverseOpsFromSDK,\n DataInfo,\n FieldTraversalStep as FieldTraversalStepFromSDK,\n Option,\n PColumn,\n PColumnValues,\n PFrameDef,\n PFrameHandle,\n PObject,\n PObjectSpec,\n PSpecPredicate,\n PTableDef,\n PTableDefV2,\n PTableHandle,\n ResourceType as ResourceTypeFromSDK,\n ResultCollection,\n ValueOrError,\n RangeBytes,\n BlockCodeKnownFeatureFlags,\n JsRenderInternal,\n} from \"@platforma-sdk/model\";\nimport {\n isDataInfo,\n mapDataInfo,\n mapPObjectData,\n mapPTableDef,\n mapPTableDefV2,\n mapValueInVOE,\n} from \"@platforma-sdk/model\";\nimport { notEmpty } from \"@milaboratories/ts-helpers\";\nimport { randomUUID } from \"node:crypto\";\nimport type { Optional } from \"utility-types\";\nimport type { BlockContextAny } from \"../middle_layer/block_ctx\";\nimport type { MiddleLayerEnvironment } from \"../middle_layer/middle_layer\";\nimport type { Block } from \"../model/project_model\";\nimport { parseFinalPObjectCollection } from \"../pool/p_object_collection\";\nimport type { ResultPool } from \"../pool/result_pool\";\nimport type { JsExecutionContext } from \"./context\";\nimport type { VmFunctionImplementation } from \"quickjs-emscripten\";\nimport { Scope, type QuickJSHandle } from \"quickjs-emscripten\";\nimport type {\n DiscoverColumnsRequest,\n DiscoverColumnsResponse,\n PColumnSpec,\n SpecFrameHandle,\n} from \"@milaboratories/pl-model-common\";\nimport { SpecDriver } from \"./spec_driver\";\n\nfunction bytesToBase64(data: Uint8Array | undefined): string | undefined {\n return data !== undefined ? Buffer.from(data).toString(\"base64\") : undefined;\n}\n\nexport class ComputableContextHelper implements JsRenderInternal.GlobalCfgRenderCtxMethods<\n string,\n string\n> {\n public readonly computablesToResolve: Record<string, Computable<unknown>> = {};\n\n private computableCtx: ComputableCtx | undefined;\n private readonly accessors = new Map<string, PlTreeNodeAccessor | undefined>();\n private readonly specDriver = new SpecDriver();\n\n private readonly meta: Map<string, Block>;\n\n constructor(\n private readonly parent: JsExecutionContext,\n private readonly blockCtx: BlockContextAny,\n private readonly env: MiddleLayerEnvironment,\n private readonly featureFlags: BlockCodeKnownFeatureFlags | undefined,\n computableCtx: ComputableCtx,\n ) {\n this.computableCtx = computableCtx;\n this.meta = blockCtx.blockMeta(computableCtx);\n }\n\n public resetComputableCtx() {\n this.computableCtx = undefined;\n this.accessors.clear();\n }\n\n //\n // Methods for injected ctx object\n //\n\n getAccessorHandleByName(name: string): string | undefined {\n if (this.computableCtx === undefined)\n throw new Error(\"Accessors can't be used in this context\");\n const wellKnownAccessor = (name: string, ctxKey: \"staging\" | \"prod\"): string | undefined => {\n if (!this.accessors.has(name)) {\n const lambda = this.blockCtx[ctxKey];\n if (lambda === undefined) throw new Error(\"Staging context not available\");\n const entry = lambda(this.computableCtx!);\n if (!entry) this.accessors.set(name, undefined);\n else\n this.accessors.set(name, this.computableCtx!.accessor(entry).node({ ignoreError: true }));\n }\n return this.accessors.get(name) ? name : undefined;\n };\n if (name === \"staging\") return wellKnownAccessor(\"staging\", \"staging\");\n else if (name === \"main\") return wellKnownAccessor(\"main\", \"prod\");\n return undefined;\n }\n\n //\n // Accessors\n //\n\n resolveWithCommon(\n handle: string,\n commonOptions: CommonFieldTraverseOpsFromSDK,\n ...steps: (FieldTraversalStepFromSDK | string)[]\n ): string | undefined {\n return this.wrapAccessor(this.getAccessor(handle).traverseWithCommon(commonOptions, ...steps));\n }\n\n getResourceType(handle: string): ResourceTypeFromSDK {\n return this.getAccessor(handle).resourceType;\n }\n\n getInputsLocked(handle: string): boolean {\n return this.getAccessor(handle).getInputsLocked();\n }\n\n getOutputsLocked(handle: string): boolean {\n return this.getAccessor(handle).getOutputsLocked();\n }\n\n getIsReadyOrError(handle: string): boolean {\n return this.getAccessor(handle).getIsReadyOrError();\n }\n\n getIsFinal(handle: string): boolean {\n return this.getAccessor(handle).getIsFinal();\n }\n\n getError(handle: string): string | undefined {\n return this.wrapAccessor(this.getAccessor(handle).getError());\n }\n\n listInputFields(handle: string): string[] {\n return this.getAccessor(handle).listInputFields();\n }\n\n listOutputFields(handle: string): string[] {\n return this.getAccessor(handle).listOutputFields();\n }\n\n listDynamicFields(handle: string): string[] {\n return this.getAccessor(handle).listDynamicFields();\n }\n\n getKeyValueBase64(handle: string, key: string): string | undefined {\n return bytesToBase64(this.getAccessor(handle).getKeyValue(key));\n }\n\n getKeyValueAsString(handle: string, key: string): string | undefined {\n return this.getAccessor(handle).getKeyValueAsString(key);\n }\n\n getDataBase64(handle: string): string | undefined {\n return bytesToBase64(this.getAccessor(handle).getData());\n }\n\n getDataAsString(handle: string): string | undefined {\n return this.getAccessor(handle).getDataAsString();\n }\n\n //\n // Accessor helpers\n //\n\n parsePObjectCollection(\n handle: string,\n errorOnUnknownField: boolean,\n prefix: string,\n ...resolveSteps: string[]\n ): Record<string, PObject<string>> | undefined {\n const acc = this.getAccessor(handle);\n if (!acc.getIsReadyOrError()) return undefined;\n const accResult = parseFinalPObjectCollection(acc, errorOnUnknownField, prefix, resolveSteps);\n const result: Record<string, PObject<string>> = {};\n for (const [key, obj] of Object.entries(accResult)) {\n result[key] = mapPObjectData(obj, (d) => this.wrapAccessor(d));\n }\n return result;\n }\n\n //\n // Blobs\n //\n\n private registerComputable(hPrefix: string, computable: Computable<unknown>): string {\n const fHandle = `${hPrefix}_${randomUUID()}`;\n this.computablesToResolve[fHandle] = computable;\n return fHandle;\n }\n\n public getBlobContentAsString(handle: string, range?: RangeBytes): string {\n const resourceInfo = this.getAccessor(handle).resourceInfo;\n return this.registerComputable(\n \"getBlobContentAsString\",\n Computable.make((ctx) => this.env.driverKit.blobDriver.getDownloadedBlob(resourceInfo, ctx), {\n postprocessValue: async (value) => {\n if (value === undefined) return undefined;\n return Buffer.from(\n await this.env.driverKit.blobDriver.getContent(value.handle, range),\n ).toString(\"utf-8\");\n },\n }),\n );\n }\n\n public getBlobContentAsBase64(handle: string, range?: RangeBytes): string {\n const resourceInfo = this.getAccessor(handle).resourceInfo;\n return this.registerComputable(\n \"getBlobContentAsBase64\",\n Computable.make((ctx) => this.env.driverKit.blobDriver.getDownloadedBlob(resourceInfo, ctx), {\n postprocessValue: async (value) => {\n if (value === undefined) return undefined;\n return Buffer.from(\n await this.env.driverKit.blobDriver.getContent(value.handle, range),\n ).toString(\"base64\");\n },\n }),\n );\n }\n\n public getDownloadedBlobContentHandle(handle: string): string {\n const resourceInfo = this.getAccessor(handle).resourceInfo;\n return this.registerComputable(\n \"getDownloadedBlobContentHandle\",\n this.env.driverKit.blobDriver.getDownloadedBlob(resourceInfo),\n );\n }\n\n public getOnDemandBlobContentHandle(handle: string): string {\n const resource = this.getAccessor(handle).persist();\n return this.registerComputable(\n \"getOnDemandBlobContentHandle\",\n this.env.driverKit.blobDriver.getOnDemandBlob(resource),\n );\n }\n\n //\n // Blobs to URLs\n //\n\n public extractArchiveAndGetURL(handle: string, format: ArchiveFormat): string {\n const resource = this.getAccessor(handle).persist();\n return this.registerComputable(\n \"extractArchiveAndGetURL\",\n this.env.driverKit.blobToURLDriver.extractArchiveAndGetURL(resource, format),\n );\n }\n\n //\n // Import progress\n //\n\n getImportProgress(handle: string): string {\n const resource = this.getAccessor(handle).persist();\n return this.registerComputable(\n \"getImportProgress\",\n this.env.driverKit.uploadDriver.getProgressId(resource),\n );\n }\n\n //\n // Logs\n //\n\n getLastLogs(handle: string, nLines: number): string {\n const resource = this.getAccessor(handle).persist();\n return this.registerComputable(\n \"getLastLogs\",\n this.env.driverKit.logDriver.getLastLogs(resource, nLines),\n );\n }\n\n getProgressLog(handle: string, patternToSearch: string): string {\n const resource = this.getAccessor(handle).persist();\n return this.registerComputable(\n \"getProgressLog\",\n this.env.driverKit.logDriver.getProgressLog(resource, patternToSearch),\n );\n }\n\n getProgressLogWithInfo(handle: string, patternToSearch: string): string {\n const resource = this.getAccessor(handle).persist();\n return this.registerComputable(\n \"getProgressLogWithInfo\",\n this.env.driverKit.logDriver.getProgressLogWithInfo(resource, patternToSearch),\n );\n }\n\n getLogHandle(handle: string): string {\n const resource = this.getAccessor(handle).persist();\n return this.registerComputable(\n \"getLogHandle\",\n this.env.driverKit.logDriver.getLogHandle(resource),\n );\n }\n\n //\n // Blocks\n //\n\n public getBlockLabel(blockId: string): string {\n const b = this.meta.get(blockId);\n if (b === undefined) throw new Error(`Block ${blockId} not found.`);\n return b.label;\n }\n\n //\n // Result Pool\n //\n\n private _resultPool: ResultPool | undefined = undefined;\n private get resultPool(): ResultPool {\n if (this._resultPool === undefined) {\n if (this.computableCtx === undefined)\n throw new Error(\n \"can't use result pool in this context (most porbably called from the future mapper)\",\n );\n this._resultPool = notEmpty(\n this.blockCtx.getResultsPool,\n \"getResultsPool\",\n )(this.computableCtx);\n }\n return this._resultPool;\n }\n\n public calculateOptions(predicate: PSpecPredicate): Option[] {\n return this.resultPool.calculateOptions(predicate);\n }\n\n public getDataFromResultPool(): ResultCollection<PObject<string>> {\n const collection = this.resultPool.getData();\n if (collection.instabilityMarker !== undefined)\n this.computableCtx!.markUnstable(`incomplete_result_pool:${collection.instabilityMarker}`);\n return {\n isComplete: collection.isComplete,\n entries: collection.entries.map((e) => ({\n ref: e.ref,\n obj: mapPObjectData(e.obj, (d) => this.wrapAccessor(d)),\n })),\n };\n }\n\n public getDataWithErrorsFromResultPool(): ResultCollection<\n Optional<PObject<ValueOrError<string, Error>>, \"id\">\n > {\n const collection = this.resultPool.getDataWithErrors();\n if (collection.instabilityMarker !== undefined)\n this.computableCtx!.markUnstable(`incomplete_result_pool:${collection.instabilityMarker}`);\n return {\n isComplete: collection.isComplete,\n entries: collection.entries.map((e) => ({\n ref: e.ref,\n obj: {\n id: e.obj.id,\n spec: e.obj.spec,\n data: mapValueInVOE(e.obj.data, (d) => this.wrapAccessor(d)),\n },\n })),\n };\n }\n\n public getSpecsFromResultPool(): ResultCollection<PObjectSpec> {\n const specs = this.resultPool.getSpecs();\n if (specs.instabilityMarker !== undefined)\n this.computableCtx!.markUnstable(`specs_from_pool_incomplete:${specs.instabilityMarker}`);\n return specs;\n }\n\n getSpecFromResultPoolByRef(blockId: string, exportName: string): PObjectSpec | undefined {\n return this.resultPool.getSpecByRef(blockId, exportName);\n }\n\n getDataFromResultPoolByRef(blockId: string, exportName: string): PObject<string> | undefined {\n return mapPObjectData(this.resultPool.getDataByRef(blockId, exportName), (acc) =>\n this.wrapAccessor(acc),\n );\n }\n\n //\n // PFrames / PTables\n //\n\n public createPFrame(\n def: PFrameDef<PColumn<string | PColumnValues | DataInfo<string>>>,\n ): PFrameHandle {\n if (this.computableCtx === undefined)\n throw new Error(\n \"can't instantiate PFrames from this context (most porbably called from the future mapper)\",\n );\n const { key, unref } = this.env.driverKit.pFrameDriver.createPFrame(\n def.map((c) => mapPObjectData(c, (d) => this.transformInputPData(d))),\n );\n this.computableCtx.addOnDestroy(unref);\n return key;\n }\n\n public createPTable(\n def: PTableDef<PColumn<string | PColumnValues | DataInfo<string>>>,\n ): PTableHandle {\n if (this.computableCtx === undefined)\n throw new Error(\n \"can't instantiate PTable from this context (most porbably called from the future mapper)\",\n );\n const { key, unref } = this.env.driverKit.pFrameDriver.createPTable(\n mapPTableDef(def, (c) => mapPObjectData(c, (d) => this.transformInputPData(d))),\n );\n this.computableCtx.addOnDestroy(unref);\n return key;\n }\n public createPTableV2(\n def: PTableDefV2<PColumn<string | PColumnValues | DataInfo<string>>>,\n ): PTableHandle {\n if (this.computableCtx === undefined)\n throw new Error(\n \"can't instantiate PTable from this context (most porbably called from the future mapper)\",\n );\n const { key, unref } = this.env.driverKit.pFrameDriver.createPTableV2(\n mapPTableDefV2(def, (c) => mapPObjectData(c, (d) => this.transformInputPData(d))),\n );\n this.computableCtx.addOnDestroy(unref);\n return key;\n }\n\n //\n // Spec Frames\n //\n\n public createSpecFrame(specs: Record<string, PColumnSpec>): SpecFrameHandle {\n const handle = this.specDriver.createSpecFrame(specs);\n this.computableCtx?.addOnDestroy(() => this.specDriver.disposeSpecFrame(handle));\n return handle;\n }\n\n public specFrameDiscoverColumns(\n handle: SpecFrameHandle,\n request: DiscoverColumnsRequest,\n ): DiscoverColumnsResponse {\n return this.specDriver.specFrameDiscoverColumns(handle as SpecFrameHandle, request);\n }\n\n public specFrameDispose(handle: SpecFrameHandle): void {\n this.specDriver.disposeSpecFrame(handle as SpecFrameHandle);\n }\n\n /**\n * Transforms input data for PFrame/PTable creation\n * - Converts string handles to accessors\n * - Maps accessors in DataInfo objects\n * - Passes through other values\n */\n private transformInputPData(\n d: string | PColumnValues | DataInfo<string>,\n ): PlTreeNodeAccessor | PColumnValues | DataInfo<PlTreeNodeAccessor> {\n if (typeof d === \"string\") {\n return this.getAccessor(d);\n } else if (isDataInfo(d)) {\n return mapDataInfo(d, (a) => this.getAccessor(a));\n } else {\n return d;\n }\n }\n\n //\n // Computable\n //\n\n public getCurrentUnstableMarker(): string | undefined {\n return this.computableCtx?.unstableMarker;\n }\n\n //\n // Logging\n //\n\n public logInfo(message: string): void {\n this.env.blockEventDispatcher.logInfo(this.blockCtx.blockId, message);\n }\n\n public logWarn(message: string): void {\n this.env.blockEventDispatcher.logWarn(this.blockCtx.blockId, message);\n }\n\n public logError(message: string): void {\n this.env.blockEventDispatcher.logError(this.blockCtx.blockId, message);\n }\n\n //\n // Helpers\n //\n\n private getAccessor(handle: string): PlTreeNodeAccessor {\n const accessor = this.accessors.get(handle);\n if (accessor === undefined) throw new Error(\"No such accessor\");\n return accessor;\n }\n\n private wrapAccessor(accessor: PlTreeNodeAccessor): string;\n private wrapAccessor(accessor: PlTreeNodeAccessor | undefined): string | undefined;\n private wrapAccessor(accessor: PlTreeNodeAccessor | undefined): string | undefined {\n if (accessor === undefined) return undefined;\n else {\n const nextHandle = randomUUID();\n this.accessors.set(nextHandle, accessor);\n return nextHandle;\n }\n }\n\n public injectCtx(configCtx: QuickJSHandle): void {\n const parent = this.parent;\n const vm = parent.vm;\n\n Scope.withScope((localScope) => {\n // Exporting methods\n\n const exportCtxFunction = (\n name: string,\n fn: VmFunctionImplementation<QuickJSHandle>,\n ): void => {\n const withCachedError: VmFunctionImplementation<QuickJSHandle> = (...args) => {\n // QuickJS strips all fields from errors apart from 'name' and 'message'.\n // That's why here we need to store them, and rethrow them when we exit\n // from QuickJS code.\n try {\n return (fn as any)(...args);\n } catch (e: unknown) {\n const newErr = parent.errorRepo.setAndRecreateForQuickJS(e);\n throw vm.newError(newErr);\n }\n };\n\n vm.newFunction(name, withCachedError).consume((fnh) => vm.setProp(configCtx, name, fnh));\n vm.newFunction(name, fn).consume((fnh) =>\n vm.setProp(configCtx, name + \"__internal__\", fnh),\n );\n };\n\n // Check if this is a v1/v2 block (requiresModelAPIVersion !== 2)\n // For v1/v2 blocks, state is {args, uiState} and we need to inject uiState separately\n const isLegacyBlock = !checkBlockFlag(this.featureFlags, \"requiresModelAPIVersion\", 2);\n\n // Helper to extract uiState from legacy state format {args, uiState}\n const extractUiState = (stateJson: string | undefined): string => {\n if (!stateJson) return \"{}\";\n try {\n const parsed = JSON.parse(stateJson);\n return JSON.stringify(parsed?.uiState ?? {});\n } catch {\n return \"{}\";\n }\n };\n\n if (checkBlockFlag(this.featureFlags, \"supportsLazyState\")) {\n // injecting lazy state functions\n exportCtxFunction(\"args\", () => {\n if (this.computableCtx === undefined)\n throw new Error(\n `Add dummy call to ctx.args outside the future lambda. Can't be directly used in this context.`,\n );\n const args = this.blockCtx.args(this.computableCtx);\n return args === undefined ? vm.undefined : vm.newString(args);\n });\n exportCtxFunction(\"blockStorage\", () => {\n if (this.computableCtx === undefined)\n throw new Error(\n `Add dummy call to ctx.blockStorage outside the future lambda. Can't be directly used in this context.`,\n );\n return vm.newString(this.blockCtx.blockStorage(this.computableCtx) ?? \"{}\");\n });\n exportCtxFunction(\"data\", () => {\n if (this.computableCtx === undefined)\n throw new Error(\n `Add dummy call to ctx.data outside the future lambda. Can't be directly used in this context.`,\n );\n return vm.newString(this.blockCtx.data(this.computableCtx) ?? \"{}\");\n });\n exportCtxFunction(\"activeArgs\", () => {\n if (this.computableCtx === undefined)\n throw new Error(\n `Add dummy call to ctx.activeArgs outside the future lambda. Can't be directly used in this context.`,\n );\n const res = this.blockCtx.activeArgs(this.computableCtx);\n return res === undefined ? vm.undefined : vm.newString(res);\n });\n // For v1/v2 blocks, also inject uiState (extracted from state.uiState)\n if (isLegacyBlock) {\n exportCtxFunction(\"uiState\", () => {\n if (this.computableCtx === undefined)\n throw new Error(\n `Add dummy call to ctx.uiState outside the future lambda. Can't be directly used in this context.`,\n );\n return vm.newString(extractUiState(this.blockCtx.data(this.computableCtx)));\n });\n }\n } else {\n const args = this.blockCtx.args(this.computableCtx!);\n const activeArgs = this.blockCtx.activeArgs(this.computableCtx!);\n const data = this.blockCtx.data(this.computableCtx!);\n if (args !== undefined) {\n vm.setProp(configCtx, \"args\", localScope.manage(vm.newString(args)));\n }\n vm.setProp(configCtx, \"data\", localScope.manage(vm.newString(data ?? \"{}\")));\n if (activeArgs !== undefined)\n vm.setProp(configCtx, \"activeArgs\", localScope.manage(vm.newString(activeArgs)));\n // For v1/v2 blocks, also inject uiState (extracted from state.uiState)\n if (isLegacyBlock) {\n vm.setProp(configCtx, \"uiState\", localScope.manage(vm.newString(extractUiState(data))));\n }\n }\n\n //\n // Methods for injected ctx object\n //\n\n exportCtxFunction(\"getAccessorHandleByName\", (name) => {\n return parent.exportSingleValue(\n this.getAccessorHandleByName(vm.getString(name)),\n undefined,\n );\n });\n\n //\n // Accessors\n //\n\n exportCtxFunction(\"resolveWithCommon\", (handle, commonOptions, ...steps) => {\n return parent.exportSingleValue(\n this.resolveWithCommon(\n vm.getString(handle),\n parent.importObjectViaJson(commonOptions) as CommonFieldTraverseOpsFromSDK,\n ...steps.map(\n (step) => parent.importObjectViaJson(step) as FieldTraversalStepFromSDK | string,\n ),\n ),\n undefined,\n );\n });\n\n exportCtxFunction(\"getResourceType\", (handle) => {\n return parent.exportObjectViaJson(this.getResourceType(vm.getString(handle)), undefined);\n });\n\n exportCtxFunction(\"getInputsLocked\", (handle) => {\n return parent.exportSingleValue(this.getInputsLocked(vm.getString(handle)), undefined);\n });\n\n exportCtxFunction(\"getOutputsLocked\", (handle) => {\n return parent.exportSingleValue(this.getOutputsLocked(vm.getString(handle)), undefined);\n });\n\n exportCtxFunction(\"getIsReadyOrError\", (handle) => {\n return parent.exportSingleValue(this.getIsReadyOrError(vm.getString(handle)), undefined);\n });\n\n exportCtxFunction(\"getIsFinal\", (handle) => {\n return parent.exportSingleValue(this.getIsFinal(vm.getString(handle)), undefined);\n });\n\n exportCtxFunction(\"getError\", (handle) => {\n return parent.exportSingleValue(this.getError(vm.getString(handle)), undefined);\n });\n\n exportCtxFunction(\"listInputFields\", (handle) => {\n return parent.exportObjectViaJson(this.listInputFields(vm.getString(handle)), undefined);\n });\n\n exportCtxFunction(\"listOutputFields\", (handle) => {\n return parent.exportObjectViaJson(this.listOutputFields(vm.getString(handle)), undefined);\n });\n\n exportCtxFunction(\"listDynamicFields\", (handle) => {\n return parent.exportObjectViaJson(this.listDynamicFields(vm.getString(handle)), undefined);\n });\n\n exportCtxFunction(\"getKeyValueBase64\", (handle, key) => {\n return parent.exportSingleValue(\n this.getKeyValueBase64(vm.getString(handle), vm.getString(key)),\n undefined,\n );\n });\n\n exportCtxFunction(\"getKeyValueAsString\", (handle, key) => {\n return parent.exportSingleValue(\n this.getKeyValueAsString(vm.getString(handle), vm.getString(key)),\n undefined,\n );\n });\n\n exportCtxFunction(\"getDataBase64\", (handle) => {\n return parent.exportSingleValue(this.getDataBase64(vm.getString(handle)), undefined);\n });\n\n exportCtxFunction(\"getDataAsString\", (handle) => {\n return parent.exportSingleValue(this.getDataAsString(vm.getString(handle)), undefined);\n });\n\n //\n // Accessor helpers\n //\n\n exportCtxFunction(\n \"parsePObjectCollection\",\n (handle, errorOnUnknownField, prefix, ...resolveSteps) => {\n return parent.exportObjectUniversal(\n this.parsePObjectCollection(\n vm.getString(handle),\n vm.dump(errorOnUnknownField) as boolean,\n vm.getString(prefix),\n ...resolveSteps.map((stepHandle) => vm.getString(stepHandle)),\n ),\n undefined,\n );\n },\n );\n\n //\n // Blobs\n //\n\n exportCtxFunction(\"getBlobContentAsBase64\", (handle, range) => {\n return parent.exportSingleValue(\n this.getBlobContentAsBase64(\n vm.getString(handle),\n parent.importObjectUniversal(range) as RangeBytes | undefined,\n ),\n undefined,\n );\n });\n\n exportCtxFunction(\"getBlobContentAsString\", (handle, range) => {\n return parent.exportSingleValue(\n this.getBlobContentAsString(\n vm.getString(handle),\n parent.importObjectUniversal(range) as RangeBytes | undefined,\n ),\n undefined,\n );\n });\n\n exportCtxFunction(\"getDownloadedBlobContentHandle\", (handle) => {\n return parent.exportSingleValue(\n this.getDownloadedBlobContentHandle(vm.getString(handle)),\n undefined,\n );\n });\n\n exportCtxFunction(\"getOnDemandBlobContentHandle\", (handle) => {\n return parent.exportSingleValue(\n this.getOnDemandBlobContentHandle(vm.getString(handle)),\n undefined,\n );\n });\n\n //\n // Blobs to URLs\n //\n\n exportCtxFunction(\"extractArchiveAndGetURL\", (handle, format) => {\n return parent.exportSingleValue(\n this.extractArchiveAndGetURL(vm.getString(handle), vm.getString(format) as ArchiveFormat),\n undefined,\n );\n });\n\n //\n // ImportProgress\n //\n\n exportCtxFunction(\"getImportProgress\", (handle) => {\n return parent.exportSingleValue(this.getImportProgress(vm.getString(handle)), undefined);\n });\n\n //\n // Logs\n //\n\n exportCtxFunction(\"getLastLogs\", (handle, nLines) => {\n return parent.exportSingleValue(\n this.getLastLogs(vm.getString(handle), vm.getNumber(nLines)),\n undefined,\n );\n });\n\n exportCtxFunction(\"getProgressLog\", (handle, patternToSearch) => {\n return parent.exportSingleValue(\n this.getProgressLog(vm.getString(handle), vm.getString(patternToSearch)),\n undefined,\n );\n });\n\n exportCtxFunction(\"getProgressLogWithInfo\", (handle, patternToSearch) => {\n return parent.exportSingleValue(\n this.getProgressLogWithInfo(vm.getString(handle), vm.getString(patternToSearch)),\n undefined,\n );\n });\n\n exportCtxFunction(\"getLogHandle\", (handle) => {\n return parent.exportSingleValue(this.getLogHandle(vm.getString(handle)), undefined);\n });\n\n //\n // Blocks\n //\n\n exportCtxFunction(\"getBlockLabel\", (blockId) => {\n return parent.exportSingleValue(this.getBlockLabel(vm.getString(blockId)), undefined);\n });\n\n //\n // Result pool\n //\n\n exportCtxFunction(\"getDataFromResultPool\", () => {\n return parent.exportObjectUniversal(this.getDataFromResultPool(), undefined);\n });\n\n exportCtxFunction(\"getDataWithErrorsFromResultPool\", () => {\n return parent.exportObjectUniversal(this.getDataWithErrorsFromResultPool(), undefined);\n });\n\n exportCtxFunction(\"getSpecsFromResultPool\", () => {\n return parent.exportObjectUniversal(this.getSpecsFromResultPool(), undefined);\n });\n\n exportCtxFunction(\"calculateOptions\", (predicate) => {\n return parent.exportObjectUniversal(\n this.calculateOptions(parent.importObjectViaJson(predicate) as PSpecPredicate),\n undefined,\n );\n });\n\n exportCtxFunction(\"getSpecFromResultPoolByRef\", (blockId, exportName) => {\n return parent.exportObjectUniversal(\n this.getSpecFromResultPoolByRef(vm.getString(blockId), vm.getString(exportName)),\n undefined,\n );\n });\n\n exportCtxFunction(\"getDataFromResultPoolByRef\", (blockId, exportName) => {\n return parent.exportObjectUniversal(\n this.getDataFromResultPoolByRef(vm.getString(blockId), vm.getString(exportName)),\n undefined,\n );\n });\n\n //\n // PFrames / PTables\n //\n\n exportCtxFunction(\"createPFrame\", (def) => {\n return parent.exportSingleValue(\n this.createPFrame(\n parent.importObjectViaJson(def) as PFrameDef<PColumn<string | PColumnValues>>,\n ),\n undefined,\n );\n });\n\n exportCtxFunction(\"createPTable\", (def) => {\n return parent.exportSingleValue(\n this.createPTable(\n parent.importObjectViaJson(def) as PTableDef<PColumn<string | PColumnValues>>,\n ),\n undefined,\n );\n });\n\n exportCtxFunction(\"createPTableV2\", (def) => {\n return parent.exportSingleValue(\n this.createPTableV2(\n parent.importObjectViaJson(def) as PTableDefV2<PColumn<string | PColumnValues>>,\n ),\n undefined,\n );\n });\n\n //\n // Spec Frames\n //\n\n exportCtxFunction(\"createSpecFrame\", (specs) => {\n return parent.exportSingleValue(\n this.createSpecFrame(parent.importObjectViaJson(specs) as Record<string, PColumnSpec>),\n undefined,\n );\n });\n\n exportCtxFunction(\"specFrameDiscoverColumns\", (handle, request) => {\n return parent.exportObjectViaJson(\n this.specFrameDiscoverColumns(\n vm.getString(handle) as SpecFrameHandle,\n parent.importObjectViaJson(request) as DiscoverColumnsRequest,\n ),\n undefined,\n );\n });\n\n exportCtxFunction(\"specFrameDispose\", (handle) => {\n this.specFrameDispose(vm.getString(handle) as SpecFrameHandle);\n });\n\n //\n // Computable\n //\n\n exportCtxFunction(\"getCurrentUnstableMarker\", () => {\n return parent.exportSingleValue(this.getCurrentUnstableMarker(), undefined);\n });\n\n //\n // Logging\n //\n\n exportCtxFunction(\"logInfo\", (message) => {\n this.logInfo(vm.getString(message));\n });\n\n exportCtxFunction(\"logWarn\", (message) => {\n this.logWarn(vm.getString(message));\n });\n\n exportCtxFunction(\"logError\", (message) => {\n this.logError(vm.getString(message));\n });\n });\n }\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"computable_context.js","names":[],"sources":["../../src/js_render/computable_context.ts"],"sourcesContent":["import type { ComputableCtx } from \"@milaboratories/computable\";\nimport { Computable } from \"@milaboratories/computable\";\nimport type { PlTreeNodeAccessor } from \"@milaboratories/pl-tree\";\nimport { checkBlockFlag } from \"@platforma-sdk/model\";\nimport type {\n ArchiveFormat,\n CommonFieldTraverseOps as CommonFieldTraverseOpsFromSDK,\n DataInfo,\n FieldTraversalStep as FieldTraversalStepFromSDK,\n Option,\n PColumn,\n PColumnValues,\n PFrameDef,\n PFrameHandle,\n PObject,\n PObjectSpec,\n PSpecPredicate,\n PTableDef,\n PTableDefV2,\n PTableHandle,\n ResourceType as ResourceTypeFromSDK,\n ResultCollection,\n ValueOrError,\n RangeBytes,\n BlockCodeKnownFeatureFlags,\n JsRenderInternal,\n} from \"@platforma-sdk/model\";\nimport {\n isDataInfo,\n mapDataInfo,\n mapPObjectData,\n mapPTableDef,\n mapPTableDefV2,\n mapValueInVOE,\n} from \"@platforma-sdk/model\";\nimport { notEmpty } from \"@milaboratories/ts-helpers\";\nimport { randomUUID } from \"node:crypto\";\nimport type { Optional } from \"utility-types\";\nimport type { BlockContextAny } from \"../middle_layer/block_ctx\";\nimport type { MiddleLayerEnvironment } from \"../middle_layer/middle_layer\";\nimport type { Block } from \"../model/project_model\";\nimport { parseFinalPObjectCollection } from \"../pool/p_object_collection\";\nimport type { ResultPool } from \"../pool/result_pool\";\nimport type { JsExecutionContext } from \"./context\";\nimport type { VmFunctionImplementation } from \"quickjs-emscripten\";\nimport { Scope, type QuickJSHandle } from \"quickjs-emscripten\";\nimport type {\n DiscoverColumnsRequest,\n DiscoverColumnsResponse,\n PColumnSpec,\n SpecFrameHandle,\n} from \"@milaboratories/pl-model-common\";\nimport { SpecDriver } from \"./spec_driver\";\n\nfunction bytesToBase64(data: Uint8Array | undefined): string | undefined {\n return data !== undefined ? Buffer.from(data).toString(\"base64\") : undefined;\n}\n\nexport class ComputableContextHelper implements JsRenderInternal.GlobalCfgRenderCtxMethods<\n string,\n string\n> {\n public readonly computablesToResolve: Record<string, Computable<unknown>> = {};\n\n private computableCtx: ComputableCtx | undefined;\n private readonly accessors = new Map<string, PlTreeNodeAccessor | undefined>();\n private readonly specDriver = new SpecDriver();\n\n private _meta: Map<string, Block> | undefined;\n private get meta(): Map<string, Block> {\n if (this._meta === undefined) {\n if (this.computableCtx === undefined)\n throw new Error(\"blockMeta can't be resolved in this context\");\n this._meta = this.blockCtx.blockMeta(this.computableCtx);\n }\n return this._meta;\n }\n\n constructor(\n private readonly parent: JsExecutionContext,\n private readonly blockCtx: BlockContextAny,\n private readonly env: MiddleLayerEnvironment,\n private readonly featureFlags: BlockCodeKnownFeatureFlags | undefined,\n computableCtx: ComputableCtx,\n ) {\n this.computableCtx = computableCtx;\n }\n\n public resetComputableCtx() {\n this.computableCtx = undefined;\n this.accessors.clear();\n }\n\n //\n // Methods for injected ctx object\n //\n\n getAccessorHandleByName(name: string): string | undefined {\n if (this.computableCtx === undefined)\n throw new Error(\"Accessors can't be used in this context\");\n const wellKnownAccessor = (name: string, ctxKey: \"staging\" | \"prod\"): string | undefined => {\n if (!this.accessors.has(name)) {\n const lambda = this.blockCtx[ctxKey];\n if (lambda === undefined) throw new Error(\"Staging context not available\");\n const entry = lambda(this.computableCtx!);\n if (!entry) this.accessors.set(name, undefined);\n else\n this.accessors.set(name, this.computableCtx!.accessor(entry).node({ ignoreError: true }));\n }\n return this.accessors.get(name) ? name : undefined;\n };\n if (name === \"staging\") return wellKnownAccessor(\"staging\", \"staging\");\n else if (name === \"main\") return wellKnownAccessor(\"main\", \"prod\");\n return undefined;\n }\n\n //\n // Accessors\n //\n\n resolveWithCommon(\n handle: string,\n commonOptions: CommonFieldTraverseOpsFromSDK,\n ...steps: (FieldTraversalStepFromSDK | string)[]\n ): string | undefined {\n return this.wrapAccessor(this.getAccessor(handle).traverseWithCommon(commonOptions, ...steps));\n }\n\n getResourceType(handle: string): ResourceTypeFromSDK {\n return this.getAccessor(handle).resourceType;\n }\n\n getInputsLocked(handle: string): boolean {\n return this.getAccessor(handle).getInputsLocked();\n }\n\n getOutputsLocked(handle: string): boolean {\n return this.getAccessor(handle).getOutputsLocked();\n }\n\n getIsReadyOrError(handle: string): boolean {\n return this.getAccessor(handle).getIsReadyOrError();\n }\n\n getIsFinal(handle: string): boolean {\n return this.getAccessor(handle).getIsFinal();\n }\n\n getError(handle: string): string | undefined {\n return this.wrapAccessor(this.getAccessor(handle).getError());\n }\n\n listInputFields(handle: string): string[] {\n return this.getAccessor(handle).listInputFields();\n }\n\n listOutputFields(handle: string): string[] {\n return this.getAccessor(handle).listOutputFields();\n }\n\n listDynamicFields(handle: string): string[] {\n return this.getAccessor(handle).listDynamicFields();\n }\n\n getKeyValueBase64(handle: string, key: string): string | undefined {\n return bytesToBase64(this.getAccessor(handle).getKeyValue(key));\n }\n\n getKeyValueAsString(handle: string, key: string): string | undefined {\n return this.getAccessor(handle).getKeyValueAsString(key);\n }\n\n getDataBase64(handle: string): string | undefined {\n return bytesToBase64(this.getAccessor(handle).getData());\n }\n\n getDataAsString(handle: string): string | undefined {\n return this.getAccessor(handle).getDataAsString();\n }\n\n //\n // Accessor helpers\n //\n\n parsePObjectCollection(\n handle: string,\n errorOnUnknownField: boolean,\n prefix: string,\n ...resolveSteps: string[]\n ): Record<string, PObject<string>> | undefined {\n const acc = this.getAccessor(handle);\n if (!acc.getIsReadyOrError()) return undefined;\n const accResult = parseFinalPObjectCollection(acc, errorOnUnknownField, prefix, resolveSteps);\n const result: Record<string, PObject<string>> = {};\n for (const [key, obj] of Object.entries(accResult)) {\n result[key] = mapPObjectData(obj, (d) => this.wrapAccessor(d));\n }\n return result;\n }\n\n //\n // Blobs\n //\n\n private registerComputable(hPrefix: string, computable: Computable<unknown>): string {\n const fHandle = `${hPrefix}_${randomUUID()}`;\n this.computablesToResolve[fHandle] = computable;\n return fHandle;\n }\n\n public getBlobContentAsString(handle: string, range?: RangeBytes): string {\n const resourceInfo = this.getAccessor(handle).resourceInfo;\n return this.registerComputable(\n \"getBlobContentAsString\",\n Computable.make((ctx) => this.env.driverKit.blobDriver.getDownloadedBlob(resourceInfo, ctx), {\n postprocessValue: async (value) => {\n if (value === undefined) return undefined;\n return Buffer.from(\n await this.env.driverKit.blobDriver.getContent(value.handle, range),\n ).toString(\"utf-8\");\n },\n }),\n );\n }\n\n public getBlobContentAsBase64(handle: string, range?: RangeBytes): string {\n const resourceInfo = this.getAccessor(handle).resourceInfo;\n return this.registerComputable(\n \"getBlobContentAsBase64\",\n Computable.make((ctx) => this.env.driverKit.blobDriver.getDownloadedBlob(resourceInfo, ctx), {\n postprocessValue: async (value) => {\n if (value === undefined) return undefined;\n return Buffer.from(\n await this.env.driverKit.blobDriver.getContent(value.handle, range),\n ).toString(\"base64\");\n },\n }),\n );\n }\n\n public getDownloadedBlobContentHandle(handle: string): string {\n const resourceInfo = this.getAccessor(handle).resourceInfo;\n return this.registerComputable(\n \"getDownloadedBlobContentHandle\",\n this.env.driverKit.blobDriver.getDownloadedBlob(resourceInfo),\n );\n }\n\n public getOnDemandBlobContentHandle(handle: string): string {\n const resource = this.getAccessor(handle).persist();\n return this.registerComputable(\n \"getOnDemandBlobContentHandle\",\n this.env.driverKit.blobDriver.getOnDemandBlob(resource),\n );\n }\n\n //\n // Blobs to URLs\n //\n\n public extractArchiveAndGetURL(handle: string, format: ArchiveFormat): string {\n const resource = this.getAccessor(handle).persist();\n return this.registerComputable(\n \"extractArchiveAndGetURL\",\n this.env.driverKit.blobToURLDriver.extractArchiveAndGetURL(resource, format),\n );\n }\n\n //\n // Import progress\n //\n\n getImportProgress(handle: string): string {\n const resource = this.getAccessor(handle).persist();\n return this.registerComputable(\n \"getImportProgress\",\n this.env.driverKit.uploadDriver.getProgressId(resource),\n );\n }\n\n //\n // Logs\n //\n\n getLastLogs(handle: string, nLines: number): string {\n const resource = this.getAccessor(handle).persist();\n return this.registerComputable(\n \"getLastLogs\",\n this.env.driverKit.logDriver.getLastLogs(resource, nLines),\n );\n }\n\n getProgressLog(handle: string, patternToSearch: string): string {\n const resource = this.getAccessor(handle).persist();\n return this.registerComputable(\n \"getProgressLog\",\n this.env.driverKit.logDriver.getProgressLog(resource, patternToSearch),\n );\n }\n\n getProgressLogWithInfo(handle: string, patternToSearch: string): string {\n const resource = this.getAccessor(handle).persist();\n return this.registerComputable(\n \"getProgressLogWithInfo\",\n this.env.driverKit.logDriver.getProgressLogWithInfo(resource, patternToSearch),\n );\n }\n\n getLogHandle(handle: string): string {\n const resource = this.getAccessor(handle).persist();\n return this.registerComputable(\n \"getLogHandle\",\n this.env.driverKit.logDriver.getLogHandle(resource),\n );\n }\n\n //\n // Blocks\n //\n\n public getBlockLabel(blockId: string): string {\n const b = this.meta.get(blockId);\n if (b === undefined) throw new Error(`Block ${blockId} not found.`);\n return b.label;\n }\n\n //\n // Result Pool\n //\n\n private _resultPool: ResultPool | undefined = undefined;\n private get resultPool(): ResultPool {\n if (this._resultPool === undefined) {\n if (this.computableCtx === undefined)\n throw new Error(\n \"can't use result pool in this context (most porbably called from the future mapper)\",\n );\n this._resultPool = notEmpty(\n this.blockCtx.getResultsPool,\n \"getResultsPool\",\n )(this.computableCtx);\n }\n return this._resultPool;\n }\n\n public calculateOptions(predicate: PSpecPredicate): Option[] {\n return this.resultPool.calculateOptions(predicate);\n }\n\n public getDataFromResultPool(): ResultCollection<PObject<string>> {\n const collection = this.resultPool.getData();\n if (collection.instabilityMarker !== undefined)\n this.computableCtx!.markUnstable(`incomplete_result_pool:${collection.instabilityMarker}`);\n return {\n isComplete: collection.isComplete,\n entries: collection.entries.map((e) => ({\n ref: e.ref,\n obj: mapPObjectData(e.obj, (d) => this.wrapAccessor(d)),\n })),\n };\n }\n\n public getDataWithErrorsFromResultPool(): ResultCollection<\n Optional<PObject<ValueOrError<string, Error>>, \"id\">\n > {\n const collection = this.resultPool.getDataWithErrors();\n if (collection.instabilityMarker !== undefined)\n this.computableCtx!.markUnstable(`incomplete_result_pool:${collection.instabilityMarker}`);\n return {\n isComplete: collection.isComplete,\n entries: collection.entries.map((e) => ({\n ref: e.ref,\n obj: {\n id: e.obj.id,\n spec: e.obj.spec,\n data: mapValueInVOE(e.obj.data, (d) => this.wrapAccessor(d)),\n },\n })),\n };\n }\n\n public getSpecsFromResultPool(): ResultCollection<PObjectSpec> {\n const specs = this.resultPool.getSpecs();\n if (specs.instabilityMarker !== undefined)\n this.computableCtx!.markUnstable(`specs_from_pool_incomplete:${specs.instabilityMarker}`);\n return specs;\n }\n\n getSpecFromResultPoolByRef(blockId: string, exportName: string): PObjectSpec | undefined {\n return this.resultPool.getSpecByRef(blockId, exportName);\n }\n\n getDataFromResultPoolByRef(blockId: string, exportName: string): PObject<string> | undefined {\n return mapPObjectData(this.resultPool.getDataByRef(blockId, exportName), (acc) =>\n this.wrapAccessor(acc),\n );\n }\n\n //\n // PFrames / PTables\n //\n\n public createPFrame(\n def: PFrameDef<PColumn<string | PColumnValues | DataInfo<string>>>,\n ): PFrameHandle {\n if (this.computableCtx === undefined)\n throw new Error(\n \"can't instantiate PFrames from this context (most porbably called from the future mapper)\",\n );\n const { key, unref } = this.env.driverKit.pFrameDriver.createPFrame(\n def.map((c) => mapPObjectData(c, (d) => this.transformInputPData(d))),\n );\n this.computableCtx.addOnDestroy(unref);\n return key;\n }\n\n public createPTable(\n def: PTableDef<PColumn<string | PColumnValues | DataInfo<string>>>,\n ): PTableHandle {\n if (this.computableCtx === undefined)\n throw new Error(\n \"can't instantiate PTable from this context (most porbably called from the future mapper)\",\n );\n const { key, unref } = this.env.driverKit.pFrameDriver.createPTable(\n mapPTableDef(def, (c) => mapPObjectData(c, (d) => this.transformInputPData(d))),\n );\n this.computableCtx.addOnDestroy(unref);\n return key;\n }\n public createPTableV2(\n def: PTableDefV2<PColumn<string | PColumnValues | DataInfo<string>>>,\n ): PTableHandle {\n if (this.computableCtx === undefined)\n throw new Error(\n \"can't instantiate PTable from this context (most porbably called from the future mapper)\",\n );\n const { key, unref } = this.env.driverKit.pFrameDriver.createPTableV2(\n mapPTableDefV2(def, (c) => mapPObjectData(c, (d) => this.transformInputPData(d))),\n );\n this.computableCtx.addOnDestroy(unref);\n return key;\n }\n\n //\n // Spec Frames\n //\n\n public createSpecFrame(specs: Record<string, PColumnSpec>): SpecFrameHandle {\n const handle = this.specDriver.createSpecFrame(specs);\n this.computableCtx?.addOnDestroy(() => this.specDriver.disposeSpecFrame(handle));\n return handle;\n }\n\n public specFrameDiscoverColumns(\n handle: SpecFrameHandle,\n request: DiscoverColumnsRequest,\n ): DiscoverColumnsResponse {\n return this.specDriver.specFrameDiscoverColumns(handle as SpecFrameHandle, request);\n }\n\n public specFrameDispose(handle: SpecFrameHandle): void {\n this.specDriver.disposeSpecFrame(handle as SpecFrameHandle);\n }\n\n /**\n * Transforms input data for PFrame/PTable creation\n * - Converts string handles to accessors\n * - Maps accessors in DataInfo objects\n * - Passes through other values\n */\n private transformInputPData(\n d: string | PColumnValues | DataInfo<string>,\n ): PlTreeNodeAccessor | PColumnValues | DataInfo<PlTreeNodeAccessor> {\n if (typeof d === \"string\") {\n return this.getAccessor(d);\n } else if (isDataInfo(d)) {\n return mapDataInfo(d, (a) => this.getAccessor(a));\n } else {\n return d;\n }\n }\n\n //\n // Computable\n //\n\n public getCurrentUnstableMarker(): string | undefined {\n return this.computableCtx?.unstableMarker;\n }\n\n //\n // Logging\n //\n\n public logInfo(message: string): void {\n this.env.blockEventDispatcher.logInfo(this.blockCtx.blockId, message);\n }\n\n public logWarn(message: string): void {\n this.env.blockEventDispatcher.logWarn(this.blockCtx.blockId, message);\n }\n\n public logError(message: string): void {\n this.env.blockEventDispatcher.logError(this.blockCtx.blockId, message);\n }\n\n //\n // Helpers\n //\n\n private getAccessor(handle: string): PlTreeNodeAccessor {\n const accessor = this.accessors.get(handle);\n if (accessor === undefined) throw new Error(\"No such accessor\");\n return accessor;\n }\n\n private wrapAccessor(accessor: PlTreeNodeAccessor): string;\n private wrapAccessor(accessor: PlTreeNodeAccessor | undefined): string | undefined;\n private wrapAccessor(accessor: PlTreeNodeAccessor | undefined): string | undefined {\n if (accessor === undefined) return undefined;\n else {\n const nextHandle = randomUUID();\n this.accessors.set(nextHandle, accessor);\n return nextHandle;\n }\n }\n\n public injectCtx(configCtx: QuickJSHandle): void {\n const parent = this.parent;\n const vm = parent.vm;\n\n Scope.withScope((localScope) => {\n // Exporting methods\n\n const exportCtxFunction = (\n name: string,\n fn: VmFunctionImplementation<QuickJSHandle>,\n ): void => {\n const withCachedError: VmFunctionImplementation<QuickJSHandle> = (...args) => {\n // QuickJS strips all fields from errors apart from 'name' and 'message'.\n // That's why here we need to store them, and rethrow them when we exit\n // from QuickJS code.\n const t0 = performance.now();\n try {\n return (fn as any)(...args);\n } catch (e: unknown) {\n const newErr = parent.errorRepo.setAndRecreateForQuickJS(e);\n throw vm.newError(newErr);\n } finally {\n parent.stats.ctxMethodCalls++;\n parent.stats.ctxMethodMs += performance.now() - t0;\n }\n };\n\n vm.newFunction(name, withCachedError).consume((fnh) => vm.setProp(configCtx, name, fnh));\n vm.newFunction(name, fn).consume((fnh) =>\n vm.setProp(configCtx, name + \"__internal__\", fnh),\n );\n };\n\n // Check if this is a v1/v2 block (requiresModelAPIVersion !== 2)\n // For v1/v2 blocks, state is {args, uiState} and we need to inject uiState separately\n const isLegacyBlock = !checkBlockFlag(this.featureFlags, \"requiresModelAPIVersion\", 2);\n\n // Helper to extract uiState from legacy state format {args, uiState}\n const extractUiState = (stateJson: string | undefined): string => {\n if (!stateJson) return \"{}\";\n try {\n const parsed = JSON.parse(stateJson);\n return JSON.stringify(parsed?.uiState ?? {});\n } catch {\n return \"{}\";\n }\n };\n\n if (checkBlockFlag(this.featureFlags, \"supportsLazyState\")) {\n // injecting lazy state functions\n exportCtxFunction(\"args\", () => {\n if (this.computableCtx === undefined)\n throw new Error(\n `Add dummy call to ctx.args outside the future lambda. Can't be directly used in this context.`,\n );\n const args = this.blockCtx.args(this.computableCtx);\n return args === undefined ? vm.undefined : vm.newString(args);\n });\n exportCtxFunction(\"blockStorage\", () => {\n if (this.computableCtx === undefined)\n throw new Error(\n `Add dummy call to ctx.blockStorage outside the future lambda. Can't be directly used in this context.`,\n );\n return vm.newString(this.blockCtx.blockStorage(this.computableCtx) ?? \"{}\");\n });\n exportCtxFunction(\"data\", () => {\n if (this.computableCtx === undefined)\n throw new Error(\n `Add dummy call to ctx.data outside the future lambda. Can't be directly used in this context.`,\n );\n return vm.newString(this.blockCtx.data(this.computableCtx) ?? \"{}\");\n });\n exportCtxFunction(\"activeArgs\", () => {\n if (this.computableCtx === undefined)\n throw new Error(\n `Add dummy call to ctx.activeArgs outside the future lambda. Can't be directly used in this context.`,\n );\n const res = this.blockCtx.activeArgs(this.computableCtx);\n return res === undefined ? vm.undefined : vm.newString(res);\n });\n // For v1/v2 blocks, also inject uiState (extracted from state.uiState)\n if (isLegacyBlock) {\n exportCtxFunction(\"uiState\", () => {\n if (this.computableCtx === undefined)\n throw new Error(\n `Add dummy call to ctx.uiState outside the future lambda. Can't be directly used in this context.`,\n );\n return vm.newString(extractUiState(this.blockCtx.data(this.computableCtx)));\n });\n }\n } else {\n const args = this.blockCtx.args(this.computableCtx!);\n const activeArgs = this.blockCtx.activeArgs(this.computableCtx!);\n const data = this.blockCtx.data(this.computableCtx!);\n if (args !== undefined) {\n vm.setProp(configCtx, \"args\", localScope.manage(vm.newString(args)));\n }\n vm.setProp(configCtx, \"data\", localScope.manage(vm.newString(data ?? \"{}\")));\n if (activeArgs !== undefined)\n vm.setProp(configCtx, \"activeArgs\", localScope.manage(vm.newString(activeArgs)));\n // For v1/v2 blocks, also inject uiState (extracted from state.uiState)\n if (isLegacyBlock) {\n vm.setProp(configCtx, \"uiState\", localScope.manage(vm.newString(extractUiState(data))));\n }\n }\n\n //\n // Methods for injected ctx object\n //\n\n exportCtxFunction(\"getAccessorHandleByName\", (name) => {\n return parent.exportSingleValue(\n this.getAccessorHandleByName(vm.getString(name)),\n undefined,\n );\n });\n\n //\n // Accessors\n //\n\n exportCtxFunction(\"resolveWithCommon\", (handle, commonOptions, ...steps) => {\n return parent.exportSingleValue(\n this.resolveWithCommon(\n vm.getString(handle),\n parent.importObjectViaJson(commonOptions) as CommonFieldTraverseOpsFromSDK,\n ...steps.map(\n (step) => parent.importObjectViaJson(step) as FieldTraversalStepFromSDK | string,\n ),\n ),\n undefined,\n );\n });\n\n exportCtxFunction(\"getResourceType\", (handle) => {\n return parent.exportObjectViaJson(this.getResourceType(vm.getString(handle)), undefined);\n });\n\n exportCtxFunction(\"getInputsLocked\", (handle) => {\n return parent.exportSingleValue(this.getInputsLocked(vm.getString(handle)), undefined);\n });\n\n exportCtxFunction(\"getOutputsLocked\", (handle) => {\n return parent.exportSingleValue(this.getOutputsLocked(vm.getString(handle)), undefined);\n });\n\n exportCtxFunction(\"getIsReadyOrError\", (handle) => {\n return parent.exportSingleValue(this.getIsReadyOrError(vm.getString(handle)), undefined);\n });\n\n exportCtxFunction(\"getIsFinal\", (handle) => {\n return parent.exportSingleValue(this.getIsFinal(vm.getString(handle)), undefined);\n });\n\n exportCtxFunction(\"getError\", (handle) => {\n return parent.exportSingleValue(this.getError(vm.getString(handle)), undefined);\n });\n\n exportCtxFunction(\"listInputFields\", (handle) => {\n return parent.exportObjectViaJson(this.listInputFields(vm.getString(handle)), undefined);\n });\n\n exportCtxFunction(\"listOutputFields\", (handle) => {\n return parent.exportObjectViaJson(this.listOutputFields(vm.getString(handle)), undefined);\n });\n\n exportCtxFunction(\"listDynamicFields\", (handle) => {\n return parent.exportObjectViaJson(this.listDynamicFields(vm.getString(handle)), undefined);\n });\n\n exportCtxFunction(\"getKeyValueBase64\", (handle, key) => {\n return parent.exportSingleValue(\n this.getKeyValueBase64(vm.getString(handle), vm.getString(key)),\n undefined,\n );\n });\n\n exportCtxFunction(\"getKeyValueAsString\", (handle, key) => {\n return parent.exportSingleValue(\n this.getKeyValueAsString(vm.getString(handle), vm.getString(key)),\n undefined,\n );\n });\n\n exportCtxFunction(\"getDataBase64\", (handle) => {\n return parent.exportSingleValue(this.getDataBase64(vm.getString(handle)), undefined);\n });\n\n exportCtxFunction(\"getDataAsString\", (handle) => {\n return parent.exportSingleValue(this.getDataAsString(vm.getString(handle)), undefined);\n });\n\n //\n // Accessor helpers\n //\n\n exportCtxFunction(\n \"parsePObjectCollection\",\n (handle, errorOnUnknownField, prefix, ...resolveSteps) => {\n return parent.exportObjectUniversal(\n this.parsePObjectCollection(\n vm.getString(handle),\n vm.dump(errorOnUnknownField) as boolean,\n vm.getString(prefix),\n ...resolveSteps.map((stepHandle) => vm.getString(stepHandle)),\n ),\n undefined,\n );\n },\n );\n\n //\n // Blobs\n //\n\n exportCtxFunction(\"getBlobContentAsBase64\", (handle, range) => {\n return parent.exportSingleValue(\n this.getBlobContentAsBase64(\n vm.getString(handle),\n parent.importObjectUniversal(range) as RangeBytes | undefined,\n ),\n undefined,\n );\n });\n\n exportCtxFunction(\"getBlobContentAsString\", (handle, range) => {\n return parent.exportSingleValue(\n this.getBlobContentAsString(\n vm.getString(handle),\n parent.importObjectUniversal(range) as RangeBytes | undefined,\n ),\n undefined,\n );\n });\n\n exportCtxFunction(\"getDownloadedBlobContentHandle\", (handle) => {\n return parent.exportSingleValue(\n this.getDownloadedBlobContentHandle(vm.getString(handle)),\n undefined,\n );\n });\n\n exportCtxFunction(\"getOnDemandBlobContentHandle\", (handle) => {\n return parent.exportSingleValue(\n this.getOnDemandBlobContentHandle(vm.getString(handle)),\n undefined,\n );\n });\n\n //\n // Blobs to URLs\n //\n\n exportCtxFunction(\"extractArchiveAndGetURL\", (handle, format) => {\n return parent.exportSingleValue(\n this.extractArchiveAndGetURL(vm.getString(handle), vm.getString(format) as ArchiveFormat),\n undefined,\n );\n });\n\n //\n // ImportProgress\n //\n\n exportCtxFunction(\"getImportProgress\", (handle) => {\n return parent.exportSingleValue(this.getImportProgress(vm.getString(handle)), undefined);\n });\n\n //\n // Logs\n //\n\n exportCtxFunction(\"getLastLogs\", (handle, nLines) => {\n return parent.exportSingleValue(\n this.getLastLogs(vm.getString(handle), vm.getNumber(nLines)),\n undefined,\n );\n });\n\n exportCtxFunction(\"getProgressLog\", (handle, patternToSearch) => {\n return parent.exportSingleValue(\n this.getProgressLog(vm.getString(handle), vm.getString(patternToSearch)),\n undefined,\n );\n });\n\n exportCtxFunction(\"getProgressLogWithInfo\", (handle, patternToSearch) => {\n return parent.exportSingleValue(\n this.getProgressLogWithInfo(vm.getString(handle), vm.getString(patternToSearch)),\n undefined,\n );\n });\n\n exportCtxFunction(\"getLogHandle\", (handle) => {\n return parent.exportSingleValue(this.getLogHandle(vm.getString(handle)), undefined);\n });\n\n //\n // Blocks\n //\n\n exportCtxFunction(\"getBlockLabel\", (blockId) => {\n return parent.exportSingleValue(this.getBlockLabel(vm.getString(blockId)), undefined);\n });\n\n //\n // Result pool\n //\n\n exportCtxFunction(\"getDataFromResultPool\", () => {\n return parent.exportObjectUniversal(this.getDataFromResultPool(), undefined);\n });\n\n exportCtxFunction(\"getDataWithErrorsFromResultPool\", () => {\n return parent.exportObjectUniversal(this.getDataWithErrorsFromResultPool(), undefined);\n });\n\n exportCtxFunction(\"getSpecsFromResultPool\", () => {\n return parent.exportObjectUniversal(this.getSpecsFromResultPool(), undefined);\n });\n\n exportCtxFunction(\"calculateOptions\", (predicate) => {\n return parent.exportObjectUniversal(\n this.calculateOptions(parent.importObjectViaJson(predicate) as PSpecPredicate),\n undefined,\n );\n });\n\n exportCtxFunction(\"getSpecFromResultPoolByRef\", (blockId, exportName) => {\n return parent.exportObjectUniversal(\n this.getSpecFromResultPoolByRef(vm.getString(blockId), vm.getString(exportName)),\n undefined,\n );\n });\n\n exportCtxFunction(\"getDataFromResultPoolByRef\", (blockId, exportName) => {\n return parent.exportObjectUniversal(\n this.getDataFromResultPoolByRef(vm.getString(blockId), vm.getString(exportName)),\n undefined,\n );\n });\n\n //\n // PFrames / PTables\n //\n\n exportCtxFunction(\"createPFrame\", (def) => {\n return parent.exportSingleValue(\n this.createPFrame(\n parent.importObjectViaJson(def) as PFrameDef<PColumn<string | PColumnValues>>,\n ),\n undefined,\n );\n });\n\n exportCtxFunction(\"createPTable\", (def) => {\n return parent.exportSingleValue(\n this.createPTable(\n parent.importObjectViaJson(def) as PTableDef<PColumn<string | PColumnValues>>,\n ),\n undefined,\n );\n });\n\n exportCtxFunction(\"createPTableV2\", (def) => {\n return parent.exportSingleValue(\n this.createPTableV2(\n parent.importObjectViaJson(def) as PTableDefV2<PColumn<string | PColumnValues>>,\n ),\n undefined,\n );\n });\n\n //\n // Spec Frames\n //\n\n exportCtxFunction(\"createSpecFrame\", (specs) => {\n return parent.exportSingleValue(\n this.createSpecFrame(parent.importObjectViaJson(specs) as Record<string, PColumnSpec>),\n undefined,\n );\n });\n\n exportCtxFunction(\"specFrameDiscoverColumns\", (handle, request) => {\n return parent.exportObjectViaJson(\n this.specFrameDiscoverColumns(\n vm.getString(handle) as SpecFrameHandle,\n parent.importObjectViaJson(request) as DiscoverColumnsRequest,\n ),\n undefined,\n );\n });\n\n exportCtxFunction(\"specFrameDispose\", (handle) => {\n this.specFrameDispose(vm.getString(handle) as SpecFrameHandle);\n });\n\n //\n // Computable\n //\n\n exportCtxFunction(\"getCurrentUnstableMarker\", () => {\n return parent.exportSingleValue(this.getCurrentUnstableMarker(), undefined);\n });\n\n //\n // Logging\n //\n\n exportCtxFunction(\"logInfo\", (message) => {\n this.logInfo(vm.getString(message));\n });\n\n exportCtxFunction(\"logWarn\", (message) => {\n this.logWarn(vm.getString(message));\n });\n\n exportCtxFunction(\"logError\", (message) => {\n this.logError(vm.getString(message));\n });\n });\n }\n}\n"],"mappings":"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"}
|
|
@@ -17,6 +17,20 @@ var JsExecutionContext = class JsExecutionContext {
|
|
|
17
17
|
fnJSONParse;
|
|
18
18
|
errorRepo = new ErrorRepository();
|
|
19
19
|
computableHelper;
|
|
20
|
+
stats = {
|
|
21
|
+
bundleEvalMs: 0,
|
|
22
|
+
bundleBytes: 0,
|
|
23
|
+
callbackMs: 0,
|
|
24
|
+
callbackCount: 0,
|
|
25
|
+
serInMs: 0,
|
|
26
|
+
serInBytes: 0,
|
|
27
|
+
serInCalls: 0,
|
|
28
|
+
serOutMs: 0,
|
|
29
|
+
serOutBytes: 0,
|
|
30
|
+
serOutCalls: 0,
|
|
31
|
+
ctxMethodCalls: 0,
|
|
32
|
+
ctxMethodMs: 0
|
|
33
|
+
};
|
|
20
34
|
/**
|
|
21
35
|
* Creates a new JS execution context.
|
|
22
36
|
*
|
|
@@ -45,6 +59,7 @@ var JsExecutionContext = class JsExecutionContext {
|
|
|
45
59
|
if (typeof error === "object" && error !== null && "context" in error) delete error["context"];
|
|
46
60
|
}
|
|
47
61
|
evaluateBundle(code) {
|
|
62
|
+
const t0 = performance.now();
|
|
48
63
|
try {
|
|
49
64
|
this.deadlineSetter({
|
|
50
65
|
currentExecutionTarget: "evaluateBundle",
|
|
@@ -56,9 +71,12 @@ var JsExecutionContext = class JsExecutionContext {
|
|
|
56
71
|
throw err;
|
|
57
72
|
} finally {
|
|
58
73
|
this.deadlineSetter(void 0);
|
|
74
|
+
this.stats.bundleEvalMs += performance.now() - t0;
|
|
75
|
+
this.stats.bundleBytes += code.length;
|
|
59
76
|
}
|
|
60
77
|
}
|
|
61
78
|
runCallback(cbName, ...args) {
|
|
79
|
+
const t0 = performance.now();
|
|
62
80
|
try {
|
|
63
81
|
this.deadlineSetter({
|
|
64
82
|
currentExecutionTarget: cbName,
|
|
@@ -74,6 +92,8 @@ var JsExecutionContext = class JsExecutionContext {
|
|
|
74
92
|
throw this.errorRepo.getOriginal(err);
|
|
75
93
|
} finally {
|
|
76
94
|
this.deadlineSetter(void 0);
|
|
95
|
+
this.stats.callbackMs += performance.now() - t0;
|
|
96
|
+
this.stats.callbackCount++;
|
|
77
97
|
}
|
|
78
98
|
}
|
|
79
99
|
exportSingleValue(obj, scope) {
|
|
@@ -119,7 +139,12 @@ var JsExecutionContext = class JsExecutionContext {
|
|
|
119
139
|
return this.exportObjectViaJson(obj, scope);
|
|
120
140
|
}
|
|
121
141
|
exportObjectViaJson(obj, scope) {
|
|
122
|
-
const
|
|
142
|
+
const t0 = performance.now();
|
|
143
|
+
const json = JSON.stringify(obj);
|
|
144
|
+
this.stats.serInBytes += json.length;
|
|
145
|
+
this.stats.serInCalls++;
|
|
146
|
+
const result = this.vm.newString(json).consume((jsonHandle) => this.vm.unwrapResult(this.vm.callFunction(this.fnJSONParse, this.vm.undefined, jsonHandle)));
|
|
147
|
+
this.stats.serInMs += performance.now() - t0;
|
|
123
148
|
return scope !== void 0 ? scope.manage(result) : result;
|
|
124
149
|
}
|
|
125
150
|
importObjectUniversal(handle) {
|
|
@@ -133,9 +158,17 @@ var JsExecutionContext = class JsExecutionContext {
|
|
|
133
158
|
}
|
|
134
159
|
}
|
|
135
160
|
importObjectViaJson(handle) {
|
|
161
|
+
const t0 = performance.now();
|
|
136
162
|
const text = this.vm.unwrapResult(this.vm.callFunction(this.fnJSONStringify, this.vm.undefined, handle)).consume((strHandle) => this.vm.getString(strHandle));
|
|
137
|
-
|
|
138
|
-
|
|
163
|
+
this.stats.serOutBytes += text.length;
|
|
164
|
+
this.stats.serOutCalls++;
|
|
165
|
+
if (text === "undefined") {
|
|
166
|
+
this.stats.serOutMs += performance.now() - t0;
|
|
167
|
+
return;
|
|
168
|
+
}
|
|
169
|
+
const result = JSON.parse(text);
|
|
170
|
+
this.stats.serOutMs += performance.now() - t0;
|
|
171
|
+
return result;
|
|
139
172
|
}
|
|
140
173
|
injectCtx() {
|
|
141
174
|
quickjs_emscripten.Scope.withScope((localScope) => {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"context.cjs","names":["ComputableContextHelper","Scope","JsRenderInternal","errors","PlQuickJSError"],"sources":["../../src/js_render/context.ts"],"sourcesContent":["import type { ComputableCtx } from \"@milaboratories/computable\";\nimport type { BlockCodeKnownFeatureFlags } from \"@platforma-sdk/model\";\nimport { JsRenderInternal } from \"@platforma-sdk/model\";\nimport { notEmpty } from \"@milaboratories/ts-helpers\";\nimport { randomUUID } from \"node:crypto\";\nimport type { QuickJSContext, QuickJSHandle } from \"quickjs-emscripten\";\nimport { Scope, errors } from \"quickjs-emscripten\";\nimport type { BlockContextAny } from \"../middle_layer/block_ctx\";\nimport type { MiddleLayerEnvironment } from \"../middle_layer/middle_layer\";\nimport { stringifyWithResourceId } from \"@milaboratories/pl-client\";\nimport { PlQuickJSError } from \"@milaboratories/pl-errors\";\nimport { ComputableContextHelper } from \"./computable_context\";\n\nexport type DeadlineSettings = {\n currentExecutionTarget: string;\n deadline: number;\n};\n\n/**\n * Communicates a deadline to the quickjs runtime, that if passed, will interrupt the execution.\n * Undefined can be used to reset the deadline.\n * */\nexport type DeadlineSetter = (settings: DeadlineSettings | undefined) => void;\n\nfunction isArrayBufferOrView(obj: unknown): obj is ArrayBufferLike {\n return obj instanceof ArrayBuffer || ArrayBuffer.isView(obj);\n}\n\n/**\n * Contains references to objects needed to execute lambda within computable,\n * providing access to:\n * - block context\n * - computable context\n * - middle layer environment\n * */\nexport type ComputableEnv = {\n readonly blockCtx: BlockContextAny;\n readonly mlEnv: MiddleLayerEnvironment;\n computableCtx: ComputableCtx;\n};\n\nexport class JsExecutionContext {\n private readonly callbackRegistry: QuickJSHandle;\n private readonly fnJSONStringify: QuickJSHandle;\n private readonly fnJSONParse: QuickJSHandle;\n\n public readonly errorRepo = new ErrorRepository();\n\n public readonly computableHelper: ComputableContextHelper | undefined;\n\n /**\n * Creates a new JS execution context.\n *\n * @param scope - QuickJS scope for memory management\n * @param vm - QuickJS VM context\n * @param deadlineSetter - Function to set execution deadline\n * @param featureFlags - Block feature flags\n * @param computableEnv - Optional reactive computable environment (for outputs, inputsValid, etc.)\n */\n constructor(\n public readonly scope: Scope,\n public readonly vm: QuickJSContext,\n private readonly deadlineSetter: DeadlineSetter,\n featureFlags: BlockCodeKnownFeatureFlags | undefined,\n computableEnv?: ComputableEnv,\n ) {\n this.callbackRegistry = this.scope.manage(this.vm.newObject());\n\n this.fnJSONStringify = scope.manage(\n vm.getProp(vm.global, \"JSON\").consume((json) => vm.getProp(json, \"stringify\")),\n );\n if (vm.typeof(this.fnJSONStringify) !== \"function\")\n throw new Error(`JSON.stringify() not found.`);\n\n this.fnJSONParse = scope.manage(\n vm.getProp(vm.global, \"JSON\").consume((json) => vm.getProp(json, \"parse\")),\n );\n if (vm.typeof(this.fnJSONParse) !== \"function\") throw new Error(`JSON.parse() not found.`);\n\n if (computableEnv !== undefined)\n this.computableHelper = new ComputableContextHelper(\n this,\n computableEnv.blockCtx,\n computableEnv.mlEnv,\n featureFlags,\n computableEnv.computableCtx,\n );\n\n this.injectCtx();\n }\n\n public resetComputableCtx() {\n notEmpty(\n this.computableHelper,\n \"Computable context helper is not initialized\",\n ).resetComputableCtx();\n }\n\n private static cleanErrorContext(error: unknown): void {\n if (typeof error === \"object\" && error !== null && \"context\" in error) delete error[\"context\"];\n }\n\n // private static cleanError(error: unknown): unknown {\n // if (error instanceof errors.QuickJSUnwrapError) {\n // const { cause, context: _, name, message, stack, ...rest } = error;\n // const clean = new errors.QuickJSUnwrapError(cause);\n // Object.assign(clean, { ...rest, name, message, stack });\n // return clean;\n // }\n // return error;\n // }\n\n public evaluateBundle(code: string) {\n try {\n this.deadlineSetter({\n currentExecutionTarget: \"evaluateBundle\",\n deadline: Date.now() + 10000,\n });\n this.vm.unwrapResult(this.vm.evalCode(code, \"bundle.js\", { type: \"global\" })).dispose();\n } catch (err: unknown) {\n JsExecutionContext.cleanErrorContext(err);\n throw err;\n } finally {\n this.deadlineSetter(undefined);\n }\n }\n\n public runCallback(cbName: string, ...args: unknown[]): QuickJSHandle {\n try {\n this.deadlineSetter({ currentExecutionTarget: cbName, deadline: Date.now() + 10000 });\n return Scope.withScope((localScope) => {\n const targetCallback = localScope.manage(this.vm.getProp(this.callbackRegistry, cbName));\n\n if (this.vm.typeof(targetCallback) !== \"function\")\n throw new Error(`No such callback: ${cbName}`);\n\n return this.scope.manage(\n this.vm.unwrapResult(\n this.vm.callFunction(\n targetCallback,\n this.vm.undefined,\n ...args.map((arg) => this.exportObjectUniversal(arg, localScope)),\n ),\n ),\n );\n });\n } catch (err: unknown) {\n JsExecutionContext.cleanErrorContext(err);\n const original = this.errorRepo.getOriginal(err);\n throw original;\n } finally {\n this.deadlineSetter(undefined);\n }\n }\n\n //\n // QuickJS Helpers\n //\n\n public exportSingleValue(\n obj: boolean | number | string | null | ArrayBuffer | undefined,\n scope: Scope | undefined,\n ): QuickJSHandle {\n const result = this.tryExportSingleValue(obj, scope);\n if (result === undefined) {\n throw new Error(\n `Can't export value: ${obj === undefined ? \"undefined\" : JSON.stringify(obj)}`,\n );\n }\n return result;\n }\n\n public tryExportSingleValue(obj: unknown, scope: Scope | undefined): QuickJSHandle | undefined {\n let handle: QuickJSHandle;\n let manage = false;\n switch (typeof obj) {\n case \"string\":\n handle = this.vm.newString(obj);\n manage = true;\n break;\n case \"number\":\n handle = this.vm.newNumber(obj);\n manage = true;\n break;\n case \"undefined\":\n handle = this.vm.undefined;\n break;\n case \"boolean\":\n handle = obj ? this.vm.true : this.vm.false;\n break;\n default:\n if (obj === null) {\n handle = this.vm.null;\n break;\n }\n if (isArrayBufferOrView(obj)) {\n handle = this.vm.newArrayBuffer(obj);\n manage = true;\n break;\n }\n return undefined;\n }\n return manage && scope != undefined ? scope.manage(handle) : handle;\n }\n\n public exportObjectUniversal(obj: unknown, scope: Scope | undefined): QuickJSHandle {\n const simpleHandle = this.tryExportSingleValue(obj, scope);\n if (simpleHandle !== undefined) return simpleHandle;\n return this.exportObjectViaJson(obj, scope);\n }\n\n public exportObjectViaJson(obj: unknown, scope: Scope | undefined): QuickJSHandle {\n const result = this.vm\n .newString(JSON.stringify(obj))\n .consume((json) =>\n this.vm.unwrapResult(this.vm.callFunction(this.fnJSONParse, this.vm.undefined, json)),\n );\n return scope !== undefined ? scope.manage(result) : result;\n }\n\n public importObjectUniversal(handle: QuickJSHandle | undefined): unknown {\n if (handle === undefined) return undefined;\n switch (this.vm.typeof(handle)) {\n case \"undefined\":\n return undefined;\n case \"boolean\":\n case \"number\":\n case \"string\":\n return this.vm.dump(handle);\n default:\n return this.importObjectViaJson(handle);\n }\n }\n\n public importObjectViaJson(handle: QuickJSHandle): unknown {\n const text = this.vm\n .unwrapResult(this.vm.callFunction(this.fnJSONStringify, this.vm.undefined, handle))\n .consume((strHandle) => this.vm.getString(strHandle));\n if (text === \"undefined\")\n // special case with futures\n return undefined;\n return JSON.parse(text);\n }\n\n private injectCtx() {\n Scope.withScope((localScope) => {\n const configCtx = localScope.manage(this.vm.newObject());\n\n //\n // Core props\n //\n\n this.vm.setProp(configCtx, \"callbackRegistry\", this.callbackRegistry);\n this.vm.setProp(\n configCtx,\n \"featureFlags\",\n this.exportObjectUniversal(JsRenderInternal.GlobalCfgRenderCtxFeatureFlags, localScope),\n );\n\n // Inject context values from computableHelper (reactive context for outputs, inputsValid, etc.)\n if (this.computableHelper !== undefined) {\n this.computableHelper.injectCtx(configCtx);\n }\n\n //\n // Creating global variable inside the vm\n //\n\n this.vm.setProp(this.vm.global, \"cfgRenderCtx\", configCtx);\n });\n }\n}\n\n/** Holds errors that happened in the host code (like in middle-layer's drivers)\n * and then throws it where the error from quick JS is needed.\n * QuickJS couldn't throw custom errors, so we store them here, and rethrow them when we exit QuickJS side. */\nexport class ErrorRepository {\n private readonly errorIdToError = new Map<string, unknown>();\n\n /** Sets the error to the repository and returns a mimicrated error that also has uuid key of the original error. */\n public setAndRecreateForQuickJS(error: unknown): {\n name: string;\n message: string;\n } {\n const errorId = randomUUID();\n this.errorIdToError.set(errorId, error);\n\n if (error instanceof Error) {\n return {\n name: `${error.name}/uuid:${errorId}`,\n message: error.message,\n };\n }\n\n return {\n name: `UnknownErrorQuickJS/uuid:${errorId}`,\n message: `${error as any}`,\n };\n }\n\n /** Returns the original error that was stored by parsing uuid of mimicrated error. */\n public getOriginal(quickJSError: unknown): unknown {\n if (!(quickJSError instanceof errors.QuickJSUnwrapError)) {\n console.warn(\n \"ErrorRepo: quickJSError is not a QuickJSUnwrapError\",\n stringifyWithResourceId(quickJSError),\n );\n return quickJSError;\n }\n\n const cause = quickJSError.cause;\n if (\n !(\n typeof cause === \"object\" &&\n cause !== null &&\n \"name\" in cause &&\n typeof cause.name === \"string\"\n )\n ) {\n console.warn(\n \"ErrorRepo: quickJSError.cause is not an Error (can be stack limit exceeded)\",\n stringifyWithResourceId(quickJSError),\n );\n return quickJSError;\n }\n\n const causeName = cause.name;\n const errorId = causeName.slice(causeName.indexOf(\"/uuid:\") + \"/uuid:\".length);\n if (!errorId) {\n throw new Error(\n `ErrorRepo: quickJSError.cause.name does not contain errorId: ${causeName}, ${stringifyWithResourceId(quickJSError)}`,\n );\n }\n\n const error = this.errorIdToError.get(errorId);\n if (error === undefined) {\n throw new Error(\n `ErrorRepo: errorId not found: ${errorId}, ${stringifyWithResourceId(quickJSError)}`,\n );\n }\n\n return new PlQuickJSError(quickJSError, error as Error);\n }\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"context.cjs","names":["ComputableContextHelper","Scope","JsRenderInternal","errors","PlQuickJSError"],"sources":["../../src/js_render/context.ts"],"sourcesContent":["import type { ComputableCtx } from \"@milaboratories/computable\";\nimport type { BlockCodeKnownFeatureFlags } from \"@platforma-sdk/model\";\nimport { JsRenderInternal } from \"@platforma-sdk/model\";\nimport { notEmpty } from \"@milaboratories/ts-helpers\";\nimport { randomUUID } from \"node:crypto\";\nimport type { QuickJSContext, QuickJSHandle } from \"quickjs-emscripten\";\nimport { Scope, errors } from \"quickjs-emscripten\";\nimport type { BlockContextAny } from \"../middle_layer/block_ctx\";\nimport type { MiddleLayerEnvironment } from \"../middle_layer/middle_layer\";\nimport { stringifyWithResourceId } from \"@milaboratories/pl-client\";\nimport { PlQuickJSError } from \"@milaboratories/pl-errors\";\nimport { ComputableContextHelper } from \"./computable_context\";\n\nexport type DeadlineSettings = {\n currentExecutionTarget: string;\n deadline: number;\n};\n\n/**\n * Communicates a deadline to the quickjs runtime, that if passed, will interrupt the execution.\n * Undefined can be used to reset the deadline.\n * */\nexport type DeadlineSetter = (settings: DeadlineSettings | undefined) => void;\n\nfunction isArrayBufferOrView(obj: unknown): obj is ArrayBufferLike {\n return obj instanceof ArrayBuffer || ArrayBuffer.isView(obj);\n}\n\n/**\n * Contains references to objects needed to execute lambda within computable,\n * providing access to:\n * - block context\n * - computable context\n * - middle layer environment\n * */\nexport type ComputableEnv = {\n readonly blockCtx: BlockContextAny;\n readonly mlEnv: MiddleLayerEnvironment;\n computableCtx: ComputableCtx;\n};\n\n/** Execution stats accumulated during the lifetime of a JsExecutionContext. */\nexport type JsExecStats = {\n bundleEvalMs: number;\n bundleBytes: number;\n\n callbackMs: number;\n callbackCount: number;\n\n serInMs: number;\n serInBytes: number;\n serInCalls: number;\n\n serOutMs: number;\n serOutBytes: number;\n serOutCalls: number;\n\n ctxMethodCalls: number;\n ctxMethodMs: number;\n};\n\nexport class JsExecutionContext {\n private readonly callbackRegistry: QuickJSHandle;\n private readonly fnJSONStringify: QuickJSHandle;\n private readonly fnJSONParse: QuickJSHandle;\n\n public readonly errorRepo = new ErrorRepository();\n\n public readonly computableHelper: ComputableContextHelper | undefined;\n\n public readonly stats: JsExecStats = {\n bundleEvalMs: 0,\n bundleBytes: 0,\n callbackMs: 0,\n callbackCount: 0,\n serInMs: 0,\n serInBytes: 0,\n serInCalls: 0,\n serOutMs: 0,\n serOutBytes: 0,\n serOutCalls: 0,\n ctxMethodCalls: 0,\n ctxMethodMs: 0,\n };\n\n /**\n * Creates a new JS execution context.\n *\n * @param scope - QuickJS scope for memory management\n * @param vm - QuickJS VM context\n * @param deadlineSetter - Function to set execution deadline\n * @param featureFlags - Block feature flags\n * @param computableEnv - Optional reactive computable environment (for outputs, inputsValid, etc.)\n */\n constructor(\n public readonly scope: Scope,\n public readonly vm: QuickJSContext,\n private readonly deadlineSetter: DeadlineSetter,\n featureFlags: BlockCodeKnownFeatureFlags | undefined,\n computableEnv?: ComputableEnv,\n ) {\n this.callbackRegistry = this.scope.manage(this.vm.newObject());\n\n this.fnJSONStringify = scope.manage(\n vm.getProp(vm.global, \"JSON\").consume((json) => vm.getProp(json, \"stringify\")),\n );\n if (vm.typeof(this.fnJSONStringify) !== \"function\")\n throw new Error(`JSON.stringify() not found.`);\n\n this.fnJSONParse = scope.manage(\n vm.getProp(vm.global, \"JSON\").consume((json) => vm.getProp(json, \"parse\")),\n );\n if (vm.typeof(this.fnJSONParse) !== \"function\") throw new Error(`JSON.parse() not found.`);\n\n if (computableEnv !== undefined)\n this.computableHelper = new ComputableContextHelper(\n this,\n computableEnv.blockCtx,\n computableEnv.mlEnv,\n featureFlags,\n computableEnv.computableCtx,\n );\n\n this.injectCtx();\n }\n\n public resetComputableCtx() {\n notEmpty(\n this.computableHelper,\n \"Computable context helper is not initialized\",\n ).resetComputableCtx();\n }\n\n private static cleanErrorContext(error: unknown): void {\n if (typeof error === \"object\" && error !== null && \"context\" in error) delete error[\"context\"];\n }\n\n // private static cleanError(error: unknown): unknown {\n // if (error instanceof errors.QuickJSUnwrapError) {\n // const { cause, context: _, name, message, stack, ...rest } = error;\n // const clean = new errors.QuickJSUnwrapError(cause);\n // Object.assign(clean, { ...rest, name, message, stack });\n // return clean;\n // }\n // return error;\n // }\n\n public evaluateBundle(code: string) {\n const t0 = performance.now();\n try {\n this.deadlineSetter({\n currentExecutionTarget: \"evaluateBundle\",\n deadline: Date.now() + 10000,\n });\n this.vm.unwrapResult(this.vm.evalCode(code, \"bundle.js\", { type: \"global\" })).dispose();\n } catch (err: unknown) {\n JsExecutionContext.cleanErrorContext(err);\n throw err;\n } finally {\n this.deadlineSetter(undefined);\n this.stats.bundleEvalMs += performance.now() - t0;\n this.stats.bundleBytes += code.length;\n }\n }\n\n public runCallback(cbName: string, ...args: unknown[]): QuickJSHandle {\n const t0 = performance.now();\n try {\n this.deadlineSetter({ currentExecutionTarget: cbName, deadline: Date.now() + 10000 });\n return Scope.withScope((localScope) => {\n const targetCallback = localScope.manage(this.vm.getProp(this.callbackRegistry, cbName));\n\n if (this.vm.typeof(targetCallback) !== \"function\")\n throw new Error(`No such callback: ${cbName}`);\n\n return this.scope.manage(\n this.vm.unwrapResult(\n this.vm.callFunction(\n targetCallback,\n this.vm.undefined,\n ...args.map((arg) => this.exportObjectUniversal(arg, localScope)),\n ),\n ),\n );\n });\n } catch (err: unknown) {\n JsExecutionContext.cleanErrorContext(err);\n const original = this.errorRepo.getOriginal(err);\n throw original;\n } finally {\n this.deadlineSetter(undefined);\n this.stats.callbackMs += performance.now() - t0;\n this.stats.callbackCount++;\n }\n }\n\n //\n // QuickJS Helpers\n //\n\n public exportSingleValue(\n obj: boolean | number | string | null | ArrayBuffer | undefined,\n scope: Scope | undefined,\n ): QuickJSHandle {\n const result = this.tryExportSingleValue(obj, scope);\n if (result === undefined) {\n throw new Error(\n `Can't export value: ${obj === undefined ? \"undefined\" : JSON.stringify(obj)}`,\n );\n }\n return result;\n }\n\n public tryExportSingleValue(obj: unknown, scope: Scope | undefined): QuickJSHandle | undefined {\n let handle: QuickJSHandle;\n let manage = false;\n switch (typeof obj) {\n case \"string\":\n handle = this.vm.newString(obj);\n manage = true;\n break;\n case \"number\":\n handle = this.vm.newNumber(obj);\n manage = true;\n break;\n case \"undefined\":\n handle = this.vm.undefined;\n break;\n case \"boolean\":\n handle = obj ? this.vm.true : this.vm.false;\n break;\n default:\n if (obj === null) {\n handle = this.vm.null;\n break;\n }\n if (isArrayBufferOrView(obj)) {\n handle = this.vm.newArrayBuffer(obj);\n manage = true;\n break;\n }\n return undefined;\n }\n return manage && scope != undefined ? scope.manage(handle) : handle;\n }\n\n public exportObjectUniversal(obj: unknown, scope: Scope | undefined): QuickJSHandle {\n const simpleHandle = this.tryExportSingleValue(obj, scope);\n if (simpleHandle !== undefined) return simpleHandle;\n return this.exportObjectViaJson(obj, scope);\n }\n\n public exportObjectViaJson(obj: unknown, scope: Scope | undefined): QuickJSHandle {\n const t0 = performance.now();\n const json = JSON.stringify(obj);\n this.stats.serInBytes += json.length;\n this.stats.serInCalls++;\n const result = this.vm\n .newString(json)\n .consume((jsonHandle) =>\n this.vm.unwrapResult(this.vm.callFunction(this.fnJSONParse, this.vm.undefined, jsonHandle)),\n );\n this.stats.serInMs += performance.now() - t0;\n return scope !== undefined ? scope.manage(result) : result;\n }\n\n public importObjectUniversal(handle: QuickJSHandle | undefined): unknown {\n if (handle === undefined) return undefined;\n switch (this.vm.typeof(handle)) {\n case \"undefined\":\n return undefined;\n case \"boolean\":\n case \"number\":\n case \"string\":\n return this.vm.dump(handle);\n default:\n return this.importObjectViaJson(handle);\n }\n }\n\n public importObjectViaJson(handle: QuickJSHandle): unknown {\n const t0 = performance.now();\n const text = this.vm\n .unwrapResult(this.vm.callFunction(this.fnJSONStringify, this.vm.undefined, handle))\n .consume((strHandle) => this.vm.getString(strHandle));\n this.stats.serOutBytes += text.length;\n this.stats.serOutCalls++;\n if (text === \"undefined\") {\n // special case with futures\n this.stats.serOutMs += performance.now() - t0;\n return undefined;\n }\n const result = JSON.parse(text);\n this.stats.serOutMs += performance.now() - t0;\n return result;\n }\n\n private injectCtx() {\n Scope.withScope((localScope) => {\n const configCtx = localScope.manage(this.vm.newObject());\n\n //\n // Core props\n //\n\n this.vm.setProp(configCtx, \"callbackRegistry\", this.callbackRegistry);\n this.vm.setProp(\n configCtx,\n \"featureFlags\",\n this.exportObjectUniversal(JsRenderInternal.GlobalCfgRenderCtxFeatureFlags, localScope),\n );\n\n // Inject context values from computableHelper (reactive context for outputs, inputsValid, etc.)\n if (this.computableHelper !== undefined) {\n this.computableHelper.injectCtx(configCtx);\n }\n\n //\n // Creating global variable inside the vm\n //\n\n this.vm.setProp(this.vm.global, \"cfgRenderCtx\", configCtx);\n });\n }\n}\n\n/** Holds errors that happened in the host code (like in middle-layer's drivers)\n * and then throws it where the error from quick JS is needed.\n * QuickJS couldn't throw custom errors, so we store them here, and rethrow them when we exit QuickJS side. */\nexport class ErrorRepository {\n private readonly errorIdToError = new Map<string, unknown>();\n\n /** Sets the error to the repository and returns a mimicrated error that also has uuid key of the original error. */\n public setAndRecreateForQuickJS(error: unknown): {\n name: string;\n message: string;\n } {\n const errorId = randomUUID();\n this.errorIdToError.set(errorId, error);\n\n if (error instanceof Error) {\n return {\n name: `${error.name}/uuid:${errorId}`,\n message: error.message,\n };\n }\n\n return {\n name: `UnknownErrorQuickJS/uuid:${errorId}`,\n message: `${error as any}`,\n };\n }\n\n /** Returns the original error that was stored by parsing uuid of mimicrated error. */\n public getOriginal(quickJSError: unknown): unknown {\n if (!(quickJSError instanceof errors.QuickJSUnwrapError)) {\n console.warn(\n \"ErrorRepo: quickJSError is not a QuickJSUnwrapError\",\n stringifyWithResourceId(quickJSError),\n );\n return quickJSError;\n }\n\n const cause = quickJSError.cause;\n if (\n !(\n typeof cause === \"object\" &&\n cause !== null &&\n \"name\" in cause &&\n typeof cause.name === \"string\"\n )\n ) {\n console.warn(\n \"ErrorRepo: quickJSError.cause is not an Error (can be stack limit exceeded)\",\n stringifyWithResourceId(quickJSError),\n );\n return quickJSError;\n }\n\n const causeName = cause.name;\n const errorId = causeName.slice(causeName.indexOf(\"/uuid:\") + \"/uuid:\".length);\n if (!errorId) {\n throw new Error(\n `ErrorRepo: quickJSError.cause.name does not contain errorId: ${causeName}, ${stringifyWithResourceId(quickJSError)}`,\n );\n }\n\n const error = this.errorIdToError.get(errorId);\n if (error === undefined) {\n throw new Error(\n `ErrorRepo: errorId not found: ${errorId}, ${stringifyWithResourceId(quickJSError)}`,\n );\n }\n\n return new PlQuickJSError(quickJSError, error as Error);\n }\n}\n"],"mappings":"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"}
|
|
@@ -16,6 +16,20 @@ var JsExecutionContext = class JsExecutionContext {
|
|
|
16
16
|
fnJSONParse;
|
|
17
17
|
errorRepo = new ErrorRepository();
|
|
18
18
|
computableHelper;
|
|
19
|
+
stats = {
|
|
20
|
+
bundleEvalMs: 0,
|
|
21
|
+
bundleBytes: 0,
|
|
22
|
+
callbackMs: 0,
|
|
23
|
+
callbackCount: 0,
|
|
24
|
+
serInMs: 0,
|
|
25
|
+
serInBytes: 0,
|
|
26
|
+
serInCalls: 0,
|
|
27
|
+
serOutMs: 0,
|
|
28
|
+
serOutBytes: 0,
|
|
29
|
+
serOutCalls: 0,
|
|
30
|
+
ctxMethodCalls: 0,
|
|
31
|
+
ctxMethodMs: 0
|
|
32
|
+
};
|
|
19
33
|
/**
|
|
20
34
|
* Creates a new JS execution context.
|
|
21
35
|
*
|
|
@@ -44,6 +58,7 @@ var JsExecutionContext = class JsExecutionContext {
|
|
|
44
58
|
if (typeof error === "object" && error !== null && "context" in error) delete error["context"];
|
|
45
59
|
}
|
|
46
60
|
evaluateBundle(code) {
|
|
61
|
+
const t0 = performance.now();
|
|
47
62
|
try {
|
|
48
63
|
this.deadlineSetter({
|
|
49
64
|
currentExecutionTarget: "evaluateBundle",
|
|
@@ -55,9 +70,12 @@ var JsExecutionContext = class JsExecutionContext {
|
|
|
55
70
|
throw err;
|
|
56
71
|
} finally {
|
|
57
72
|
this.deadlineSetter(void 0);
|
|
73
|
+
this.stats.bundleEvalMs += performance.now() - t0;
|
|
74
|
+
this.stats.bundleBytes += code.length;
|
|
58
75
|
}
|
|
59
76
|
}
|
|
60
77
|
runCallback(cbName, ...args) {
|
|
78
|
+
const t0 = performance.now();
|
|
61
79
|
try {
|
|
62
80
|
this.deadlineSetter({
|
|
63
81
|
currentExecutionTarget: cbName,
|
|
@@ -73,6 +91,8 @@ var JsExecutionContext = class JsExecutionContext {
|
|
|
73
91
|
throw this.errorRepo.getOriginal(err);
|
|
74
92
|
} finally {
|
|
75
93
|
this.deadlineSetter(void 0);
|
|
94
|
+
this.stats.callbackMs += performance.now() - t0;
|
|
95
|
+
this.stats.callbackCount++;
|
|
76
96
|
}
|
|
77
97
|
}
|
|
78
98
|
exportSingleValue(obj, scope) {
|
|
@@ -118,7 +138,12 @@ var JsExecutionContext = class JsExecutionContext {
|
|
|
118
138
|
return this.exportObjectViaJson(obj, scope);
|
|
119
139
|
}
|
|
120
140
|
exportObjectViaJson(obj, scope) {
|
|
121
|
-
const
|
|
141
|
+
const t0 = performance.now();
|
|
142
|
+
const json = JSON.stringify(obj);
|
|
143
|
+
this.stats.serInBytes += json.length;
|
|
144
|
+
this.stats.serInCalls++;
|
|
145
|
+
const result = this.vm.newString(json).consume((jsonHandle) => this.vm.unwrapResult(this.vm.callFunction(this.fnJSONParse, this.vm.undefined, jsonHandle)));
|
|
146
|
+
this.stats.serInMs += performance.now() - t0;
|
|
122
147
|
return scope !== void 0 ? scope.manage(result) : result;
|
|
123
148
|
}
|
|
124
149
|
importObjectUniversal(handle) {
|
|
@@ -132,9 +157,17 @@ var JsExecutionContext = class JsExecutionContext {
|
|
|
132
157
|
}
|
|
133
158
|
}
|
|
134
159
|
importObjectViaJson(handle) {
|
|
160
|
+
const t0 = performance.now();
|
|
135
161
|
const text = this.vm.unwrapResult(this.vm.callFunction(this.fnJSONStringify, this.vm.undefined, handle)).consume((strHandle) => this.vm.getString(strHandle));
|
|
136
|
-
|
|
137
|
-
|
|
162
|
+
this.stats.serOutBytes += text.length;
|
|
163
|
+
this.stats.serOutCalls++;
|
|
164
|
+
if (text === "undefined") {
|
|
165
|
+
this.stats.serOutMs += performance.now() - t0;
|
|
166
|
+
return;
|
|
167
|
+
}
|
|
168
|
+
const result = JSON.parse(text);
|
|
169
|
+
this.stats.serOutMs += performance.now() - t0;
|
|
170
|
+
return result;
|
|
138
171
|
}
|
|
139
172
|
injectCtx() {
|
|
140
173
|
Scope.withScope((localScope) => {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"context.js","names":[],"sources":["../../src/js_render/context.ts"],"sourcesContent":["import type { ComputableCtx } from \"@milaboratories/computable\";\nimport type { BlockCodeKnownFeatureFlags } from \"@platforma-sdk/model\";\nimport { JsRenderInternal } from \"@platforma-sdk/model\";\nimport { notEmpty } from \"@milaboratories/ts-helpers\";\nimport { randomUUID } from \"node:crypto\";\nimport type { QuickJSContext, QuickJSHandle } from \"quickjs-emscripten\";\nimport { Scope, errors } from \"quickjs-emscripten\";\nimport type { BlockContextAny } from \"../middle_layer/block_ctx\";\nimport type { MiddleLayerEnvironment } from \"../middle_layer/middle_layer\";\nimport { stringifyWithResourceId } from \"@milaboratories/pl-client\";\nimport { PlQuickJSError } from \"@milaboratories/pl-errors\";\nimport { ComputableContextHelper } from \"./computable_context\";\n\nexport type DeadlineSettings = {\n currentExecutionTarget: string;\n deadline: number;\n};\n\n/**\n * Communicates a deadline to the quickjs runtime, that if passed, will interrupt the execution.\n * Undefined can be used to reset the deadline.\n * */\nexport type DeadlineSetter = (settings: DeadlineSettings | undefined) => void;\n\nfunction isArrayBufferOrView(obj: unknown): obj is ArrayBufferLike {\n return obj instanceof ArrayBuffer || ArrayBuffer.isView(obj);\n}\n\n/**\n * Contains references to objects needed to execute lambda within computable,\n * providing access to:\n * - block context\n * - computable context\n * - middle layer environment\n * */\nexport type ComputableEnv = {\n readonly blockCtx: BlockContextAny;\n readonly mlEnv: MiddleLayerEnvironment;\n computableCtx: ComputableCtx;\n};\n\nexport class JsExecutionContext {\n private readonly callbackRegistry: QuickJSHandle;\n private readonly fnJSONStringify: QuickJSHandle;\n private readonly fnJSONParse: QuickJSHandle;\n\n public readonly errorRepo = new ErrorRepository();\n\n public readonly computableHelper: ComputableContextHelper | undefined;\n\n /**\n * Creates a new JS execution context.\n *\n * @param scope - QuickJS scope for memory management\n * @param vm - QuickJS VM context\n * @param deadlineSetter - Function to set execution deadline\n * @param featureFlags - Block feature flags\n * @param computableEnv - Optional reactive computable environment (for outputs, inputsValid, etc.)\n */\n constructor(\n public readonly scope: Scope,\n public readonly vm: QuickJSContext,\n private readonly deadlineSetter: DeadlineSetter,\n featureFlags: BlockCodeKnownFeatureFlags | undefined,\n computableEnv?: ComputableEnv,\n ) {\n this.callbackRegistry = this.scope.manage(this.vm.newObject());\n\n this.fnJSONStringify = scope.manage(\n vm.getProp(vm.global, \"JSON\").consume((json) => vm.getProp(json, \"stringify\")),\n );\n if (vm.typeof(this.fnJSONStringify) !== \"function\")\n throw new Error(`JSON.stringify() not found.`);\n\n this.fnJSONParse = scope.manage(\n vm.getProp(vm.global, \"JSON\").consume((json) => vm.getProp(json, \"parse\")),\n );\n if (vm.typeof(this.fnJSONParse) !== \"function\") throw new Error(`JSON.parse() not found.`);\n\n if (computableEnv !== undefined)\n this.computableHelper = new ComputableContextHelper(\n this,\n computableEnv.blockCtx,\n computableEnv.mlEnv,\n featureFlags,\n computableEnv.computableCtx,\n );\n\n this.injectCtx();\n }\n\n public resetComputableCtx() {\n notEmpty(\n this.computableHelper,\n \"Computable context helper is not initialized\",\n ).resetComputableCtx();\n }\n\n private static cleanErrorContext(error: unknown): void {\n if (typeof error === \"object\" && error !== null && \"context\" in error) delete error[\"context\"];\n }\n\n // private static cleanError(error: unknown): unknown {\n // if (error instanceof errors.QuickJSUnwrapError) {\n // const { cause, context: _, name, message, stack, ...rest } = error;\n // const clean = new errors.QuickJSUnwrapError(cause);\n // Object.assign(clean, { ...rest, name, message, stack });\n // return clean;\n // }\n // return error;\n // }\n\n public evaluateBundle(code: string) {\n try {\n this.deadlineSetter({\n currentExecutionTarget: \"evaluateBundle\",\n deadline: Date.now() + 10000,\n });\n this.vm.unwrapResult(this.vm.evalCode(code, \"bundle.js\", { type: \"global\" })).dispose();\n } catch (err: unknown) {\n JsExecutionContext.cleanErrorContext(err);\n throw err;\n } finally {\n this.deadlineSetter(undefined);\n }\n }\n\n public runCallback(cbName: string, ...args: unknown[]): QuickJSHandle {\n try {\n this.deadlineSetter({ currentExecutionTarget: cbName, deadline: Date.now() + 10000 });\n return Scope.withScope((localScope) => {\n const targetCallback = localScope.manage(this.vm.getProp(this.callbackRegistry, cbName));\n\n if (this.vm.typeof(targetCallback) !== \"function\")\n throw new Error(`No such callback: ${cbName}`);\n\n return this.scope.manage(\n this.vm.unwrapResult(\n this.vm.callFunction(\n targetCallback,\n this.vm.undefined,\n ...args.map((arg) => this.exportObjectUniversal(arg, localScope)),\n ),\n ),\n );\n });\n } catch (err: unknown) {\n JsExecutionContext.cleanErrorContext(err);\n const original = this.errorRepo.getOriginal(err);\n throw original;\n } finally {\n this.deadlineSetter(undefined);\n }\n }\n\n //\n // QuickJS Helpers\n //\n\n public exportSingleValue(\n obj: boolean | number | string | null | ArrayBuffer | undefined,\n scope: Scope | undefined,\n ): QuickJSHandle {\n const result = this.tryExportSingleValue(obj, scope);\n if (result === undefined) {\n throw new Error(\n `Can't export value: ${obj === undefined ? \"undefined\" : JSON.stringify(obj)}`,\n );\n }\n return result;\n }\n\n public tryExportSingleValue(obj: unknown, scope: Scope | undefined): QuickJSHandle | undefined {\n let handle: QuickJSHandle;\n let manage = false;\n switch (typeof obj) {\n case \"string\":\n handle = this.vm.newString(obj);\n manage = true;\n break;\n case \"number\":\n handle = this.vm.newNumber(obj);\n manage = true;\n break;\n case \"undefined\":\n handle = this.vm.undefined;\n break;\n case \"boolean\":\n handle = obj ? this.vm.true : this.vm.false;\n break;\n default:\n if (obj === null) {\n handle = this.vm.null;\n break;\n }\n if (isArrayBufferOrView(obj)) {\n handle = this.vm.newArrayBuffer(obj);\n manage = true;\n break;\n }\n return undefined;\n }\n return manage && scope != undefined ? scope.manage(handle) : handle;\n }\n\n public exportObjectUniversal(obj: unknown, scope: Scope | undefined): QuickJSHandle {\n const simpleHandle = this.tryExportSingleValue(obj, scope);\n if (simpleHandle !== undefined) return simpleHandle;\n return this.exportObjectViaJson(obj, scope);\n }\n\n public exportObjectViaJson(obj: unknown, scope: Scope | undefined): QuickJSHandle {\n const result = this.vm\n .newString(JSON.stringify(obj))\n .consume((json) =>\n this.vm.unwrapResult(this.vm.callFunction(this.fnJSONParse, this.vm.undefined, json)),\n );\n return scope !== undefined ? scope.manage(result) : result;\n }\n\n public importObjectUniversal(handle: QuickJSHandle | undefined): unknown {\n if (handle === undefined) return undefined;\n switch (this.vm.typeof(handle)) {\n case \"undefined\":\n return undefined;\n case \"boolean\":\n case \"number\":\n case \"string\":\n return this.vm.dump(handle);\n default:\n return this.importObjectViaJson(handle);\n }\n }\n\n public importObjectViaJson(handle: QuickJSHandle): unknown {\n const text = this.vm\n .unwrapResult(this.vm.callFunction(this.fnJSONStringify, this.vm.undefined, handle))\n .consume((strHandle) => this.vm.getString(strHandle));\n if (text === \"undefined\")\n // special case with futures\n return undefined;\n return JSON.parse(text);\n }\n\n private injectCtx() {\n Scope.withScope((localScope) => {\n const configCtx = localScope.manage(this.vm.newObject());\n\n //\n // Core props\n //\n\n this.vm.setProp(configCtx, \"callbackRegistry\", this.callbackRegistry);\n this.vm.setProp(\n configCtx,\n \"featureFlags\",\n this.exportObjectUniversal(JsRenderInternal.GlobalCfgRenderCtxFeatureFlags, localScope),\n );\n\n // Inject context values from computableHelper (reactive context for outputs, inputsValid, etc.)\n if (this.computableHelper !== undefined) {\n this.computableHelper.injectCtx(configCtx);\n }\n\n //\n // Creating global variable inside the vm\n //\n\n this.vm.setProp(this.vm.global, \"cfgRenderCtx\", configCtx);\n });\n }\n}\n\n/** Holds errors that happened in the host code (like in middle-layer's drivers)\n * and then throws it where the error from quick JS is needed.\n * QuickJS couldn't throw custom errors, so we store them here, and rethrow them when we exit QuickJS side. */\nexport class ErrorRepository {\n private readonly errorIdToError = new Map<string, unknown>();\n\n /** Sets the error to the repository and returns a mimicrated error that also has uuid key of the original error. */\n public setAndRecreateForQuickJS(error: unknown): {\n name: string;\n message: string;\n } {\n const errorId = randomUUID();\n this.errorIdToError.set(errorId, error);\n\n if (error instanceof Error) {\n return {\n name: `${error.name}/uuid:${errorId}`,\n message: error.message,\n };\n }\n\n return {\n name: `UnknownErrorQuickJS/uuid:${errorId}`,\n message: `${error as any}`,\n };\n }\n\n /** Returns the original error that was stored by parsing uuid of mimicrated error. */\n public getOriginal(quickJSError: unknown): unknown {\n if (!(quickJSError instanceof errors.QuickJSUnwrapError)) {\n console.warn(\n \"ErrorRepo: quickJSError is not a QuickJSUnwrapError\",\n stringifyWithResourceId(quickJSError),\n );\n return quickJSError;\n }\n\n const cause = quickJSError.cause;\n if (\n !(\n typeof cause === \"object\" &&\n cause !== null &&\n \"name\" in cause &&\n typeof cause.name === \"string\"\n )\n ) {\n console.warn(\n \"ErrorRepo: quickJSError.cause is not an Error (can be stack limit exceeded)\",\n stringifyWithResourceId(quickJSError),\n );\n return quickJSError;\n }\n\n const causeName = cause.name;\n const errorId = causeName.slice(causeName.indexOf(\"/uuid:\") + \"/uuid:\".length);\n if (!errorId) {\n throw new Error(\n `ErrorRepo: quickJSError.cause.name does not contain errorId: ${causeName}, ${stringifyWithResourceId(quickJSError)}`,\n );\n }\n\n const error = this.errorIdToError.get(errorId);\n if (error === undefined) {\n throw new Error(\n `ErrorRepo: errorId not found: ${errorId}, ${stringifyWithResourceId(quickJSError)}`,\n );\n }\n\n return new PlQuickJSError(quickJSError, error as Error);\n }\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"context.js","names":[],"sources":["../../src/js_render/context.ts"],"sourcesContent":["import type { ComputableCtx } from \"@milaboratories/computable\";\nimport type { BlockCodeKnownFeatureFlags } from \"@platforma-sdk/model\";\nimport { JsRenderInternal } from \"@platforma-sdk/model\";\nimport { notEmpty } from \"@milaboratories/ts-helpers\";\nimport { randomUUID } from \"node:crypto\";\nimport type { QuickJSContext, QuickJSHandle } from \"quickjs-emscripten\";\nimport { Scope, errors } from \"quickjs-emscripten\";\nimport type { BlockContextAny } from \"../middle_layer/block_ctx\";\nimport type { MiddleLayerEnvironment } from \"../middle_layer/middle_layer\";\nimport { stringifyWithResourceId } from \"@milaboratories/pl-client\";\nimport { PlQuickJSError } from \"@milaboratories/pl-errors\";\nimport { ComputableContextHelper } from \"./computable_context\";\n\nexport type DeadlineSettings = {\n currentExecutionTarget: string;\n deadline: number;\n};\n\n/**\n * Communicates a deadline to the quickjs runtime, that if passed, will interrupt the execution.\n * Undefined can be used to reset the deadline.\n * */\nexport type DeadlineSetter = (settings: DeadlineSettings | undefined) => void;\n\nfunction isArrayBufferOrView(obj: unknown): obj is ArrayBufferLike {\n return obj instanceof ArrayBuffer || ArrayBuffer.isView(obj);\n}\n\n/**\n * Contains references to objects needed to execute lambda within computable,\n * providing access to:\n * - block context\n * - computable context\n * - middle layer environment\n * */\nexport type ComputableEnv = {\n readonly blockCtx: BlockContextAny;\n readonly mlEnv: MiddleLayerEnvironment;\n computableCtx: ComputableCtx;\n};\n\n/** Execution stats accumulated during the lifetime of a JsExecutionContext. */\nexport type JsExecStats = {\n bundleEvalMs: number;\n bundleBytes: number;\n\n callbackMs: number;\n callbackCount: number;\n\n serInMs: number;\n serInBytes: number;\n serInCalls: number;\n\n serOutMs: number;\n serOutBytes: number;\n serOutCalls: number;\n\n ctxMethodCalls: number;\n ctxMethodMs: number;\n};\n\nexport class JsExecutionContext {\n private readonly callbackRegistry: QuickJSHandle;\n private readonly fnJSONStringify: QuickJSHandle;\n private readonly fnJSONParse: QuickJSHandle;\n\n public readonly errorRepo = new ErrorRepository();\n\n public readonly computableHelper: ComputableContextHelper | undefined;\n\n public readonly stats: JsExecStats = {\n bundleEvalMs: 0,\n bundleBytes: 0,\n callbackMs: 0,\n callbackCount: 0,\n serInMs: 0,\n serInBytes: 0,\n serInCalls: 0,\n serOutMs: 0,\n serOutBytes: 0,\n serOutCalls: 0,\n ctxMethodCalls: 0,\n ctxMethodMs: 0,\n };\n\n /**\n * Creates a new JS execution context.\n *\n * @param scope - QuickJS scope for memory management\n * @param vm - QuickJS VM context\n * @param deadlineSetter - Function to set execution deadline\n * @param featureFlags - Block feature flags\n * @param computableEnv - Optional reactive computable environment (for outputs, inputsValid, etc.)\n */\n constructor(\n public readonly scope: Scope,\n public readonly vm: QuickJSContext,\n private readonly deadlineSetter: DeadlineSetter,\n featureFlags: BlockCodeKnownFeatureFlags | undefined,\n computableEnv?: ComputableEnv,\n ) {\n this.callbackRegistry = this.scope.manage(this.vm.newObject());\n\n this.fnJSONStringify = scope.manage(\n vm.getProp(vm.global, \"JSON\").consume((json) => vm.getProp(json, \"stringify\")),\n );\n if (vm.typeof(this.fnJSONStringify) !== \"function\")\n throw new Error(`JSON.stringify() not found.`);\n\n this.fnJSONParse = scope.manage(\n vm.getProp(vm.global, \"JSON\").consume((json) => vm.getProp(json, \"parse\")),\n );\n if (vm.typeof(this.fnJSONParse) !== \"function\") throw new Error(`JSON.parse() not found.`);\n\n if (computableEnv !== undefined)\n this.computableHelper = new ComputableContextHelper(\n this,\n computableEnv.blockCtx,\n computableEnv.mlEnv,\n featureFlags,\n computableEnv.computableCtx,\n );\n\n this.injectCtx();\n }\n\n public resetComputableCtx() {\n notEmpty(\n this.computableHelper,\n \"Computable context helper is not initialized\",\n ).resetComputableCtx();\n }\n\n private static cleanErrorContext(error: unknown): void {\n if (typeof error === \"object\" && error !== null && \"context\" in error) delete error[\"context\"];\n }\n\n // private static cleanError(error: unknown): unknown {\n // if (error instanceof errors.QuickJSUnwrapError) {\n // const { cause, context: _, name, message, stack, ...rest } = error;\n // const clean = new errors.QuickJSUnwrapError(cause);\n // Object.assign(clean, { ...rest, name, message, stack });\n // return clean;\n // }\n // return error;\n // }\n\n public evaluateBundle(code: string) {\n const t0 = performance.now();\n try {\n this.deadlineSetter({\n currentExecutionTarget: \"evaluateBundle\",\n deadline: Date.now() + 10000,\n });\n this.vm.unwrapResult(this.vm.evalCode(code, \"bundle.js\", { type: \"global\" })).dispose();\n } catch (err: unknown) {\n JsExecutionContext.cleanErrorContext(err);\n throw err;\n } finally {\n this.deadlineSetter(undefined);\n this.stats.bundleEvalMs += performance.now() - t0;\n this.stats.bundleBytes += code.length;\n }\n }\n\n public runCallback(cbName: string, ...args: unknown[]): QuickJSHandle {\n const t0 = performance.now();\n try {\n this.deadlineSetter({ currentExecutionTarget: cbName, deadline: Date.now() + 10000 });\n return Scope.withScope((localScope) => {\n const targetCallback = localScope.manage(this.vm.getProp(this.callbackRegistry, cbName));\n\n if (this.vm.typeof(targetCallback) !== \"function\")\n throw new Error(`No such callback: ${cbName}`);\n\n return this.scope.manage(\n this.vm.unwrapResult(\n this.vm.callFunction(\n targetCallback,\n this.vm.undefined,\n ...args.map((arg) => this.exportObjectUniversal(arg, localScope)),\n ),\n ),\n );\n });\n } catch (err: unknown) {\n JsExecutionContext.cleanErrorContext(err);\n const original = this.errorRepo.getOriginal(err);\n throw original;\n } finally {\n this.deadlineSetter(undefined);\n this.stats.callbackMs += performance.now() - t0;\n this.stats.callbackCount++;\n }\n }\n\n //\n // QuickJS Helpers\n //\n\n public exportSingleValue(\n obj: boolean | number | string | null | ArrayBuffer | undefined,\n scope: Scope | undefined,\n ): QuickJSHandle {\n const result = this.tryExportSingleValue(obj, scope);\n if (result === undefined) {\n throw new Error(\n `Can't export value: ${obj === undefined ? \"undefined\" : JSON.stringify(obj)}`,\n );\n }\n return result;\n }\n\n public tryExportSingleValue(obj: unknown, scope: Scope | undefined): QuickJSHandle | undefined {\n let handle: QuickJSHandle;\n let manage = false;\n switch (typeof obj) {\n case \"string\":\n handle = this.vm.newString(obj);\n manage = true;\n break;\n case \"number\":\n handle = this.vm.newNumber(obj);\n manage = true;\n break;\n case \"undefined\":\n handle = this.vm.undefined;\n break;\n case \"boolean\":\n handle = obj ? this.vm.true : this.vm.false;\n break;\n default:\n if (obj === null) {\n handle = this.vm.null;\n break;\n }\n if (isArrayBufferOrView(obj)) {\n handle = this.vm.newArrayBuffer(obj);\n manage = true;\n break;\n }\n return undefined;\n }\n return manage && scope != undefined ? scope.manage(handle) : handle;\n }\n\n public exportObjectUniversal(obj: unknown, scope: Scope | undefined): QuickJSHandle {\n const simpleHandle = this.tryExportSingleValue(obj, scope);\n if (simpleHandle !== undefined) return simpleHandle;\n return this.exportObjectViaJson(obj, scope);\n }\n\n public exportObjectViaJson(obj: unknown, scope: Scope | undefined): QuickJSHandle {\n const t0 = performance.now();\n const json = JSON.stringify(obj);\n this.stats.serInBytes += json.length;\n this.stats.serInCalls++;\n const result = this.vm\n .newString(json)\n .consume((jsonHandle) =>\n this.vm.unwrapResult(this.vm.callFunction(this.fnJSONParse, this.vm.undefined, jsonHandle)),\n );\n this.stats.serInMs += performance.now() - t0;\n return scope !== undefined ? scope.manage(result) : result;\n }\n\n public importObjectUniversal(handle: QuickJSHandle | undefined): unknown {\n if (handle === undefined) return undefined;\n switch (this.vm.typeof(handle)) {\n case \"undefined\":\n return undefined;\n case \"boolean\":\n case \"number\":\n case \"string\":\n return this.vm.dump(handle);\n default:\n return this.importObjectViaJson(handle);\n }\n }\n\n public importObjectViaJson(handle: QuickJSHandle): unknown {\n const t0 = performance.now();\n const text = this.vm\n .unwrapResult(this.vm.callFunction(this.fnJSONStringify, this.vm.undefined, handle))\n .consume((strHandle) => this.vm.getString(strHandle));\n this.stats.serOutBytes += text.length;\n this.stats.serOutCalls++;\n if (text === \"undefined\") {\n // special case with futures\n this.stats.serOutMs += performance.now() - t0;\n return undefined;\n }\n const result = JSON.parse(text);\n this.stats.serOutMs += performance.now() - t0;\n return result;\n }\n\n private injectCtx() {\n Scope.withScope((localScope) => {\n const configCtx = localScope.manage(this.vm.newObject());\n\n //\n // Core props\n //\n\n this.vm.setProp(configCtx, \"callbackRegistry\", this.callbackRegistry);\n this.vm.setProp(\n configCtx,\n \"featureFlags\",\n this.exportObjectUniversal(JsRenderInternal.GlobalCfgRenderCtxFeatureFlags, localScope),\n );\n\n // Inject context values from computableHelper (reactive context for outputs, inputsValid, etc.)\n if (this.computableHelper !== undefined) {\n this.computableHelper.injectCtx(configCtx);\n }\n\n //\n // Creating global variable inside the vm\n //\n\n this.vm.setProp(this.vm.global, \"cfgRenderCtx\", configCtx);\n });\n }\n}\n\n/** Holds errors that happened in the host code (like in middle-layer's drivers)\n * and then throws it where the error from quick JS is needed.\n * QuickJS couldn't throw custom errors, so we store them here, and rethrow them when we exit QuickJS side. */\nexport class ErrorRepository {\n private readonly errorIdToError = new Map<string, unknown>();\n\n /** Sets the error to the repository and returns a mimicrated error that also has uuid key of the original error. */\n public setAndRecreateForQuickJS(error: unknown): {\n name: string;\n message: string;\n } {\n const errorId = randomUUID();\n this.errorIdToError.set(errorId, error);\n\n if (error instanceof Error) {\n return {\n name: `${error.name}/uuid:${errorId}`,\n message: error.message,\n };\n }\n\n return {\n name: `UnknownErrorQuickJS/uuid:${errorId}`,\n message: `${error as any}`,\n };\n }\n\n /** Returns the original error that was stored by parsing uuid of mimicrated error. */\n public getOriginal(quickJSError: unknown): unknown {\n if (!(quickJSError instanceof errors.QuickJSUnwrapError)) {\n console.warn(\n \"ErrorRepo: quickJSError is not a QuickJSUnwrapError\",\n stringifyWithResourceId(quickJSError),\n );\n return quickJSError;\n }\n\n const cause = quickJSError.cause;\n if (\n !(\n typeof cause === \"object\" &&\n cause !== null &&\n \"name\" in cause &&\n typeof cause.name === \"string\"\n )\n ) {\n console.warn(\n \"ErrorRepo: quickJSError.cause is not an Error (can be stack limit exceeded)\",\n stringifyWithResourceId(quickJSError),\n );\n return quickJSError;\n }\n\n const causeName = cause.name;\n const errorId = causeName.slice(causeName.indexOf(\"/uuid:\") + \"/uuid:\".length);\n if (!errorId) {\n throw new Error(\n `ErrorRepo: quickJSError.cause.name does not contain errorId: ${causeName}, ${stringifyWithResourceId(quickJSError)}`,\n );\n }\n\n const error = this.errorIdToError.get(errorId);\n if (error === undefined) {\n throw new Error(\n `ErrorRepo: errorId not found: ${errorId}, ${stringifyWithResourceId(quickJSError)}`,\n );\n }\n\n return new PlQuickJSError(quickJSError, error as Error);\n }\n}\n"],"mappings":"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"}
|
package/dist/js_render/index.cjs
CHANGED
|
@@ -95,6 +95,7 @@ function computableFromRF(env, ctx, fh, codeWithInfo, configKey, ops = {}) {
|
|
|
95
95
|
const toBeResolved = rCtx.computableHelper.computablesToResolve;
|
|
96
96
|
if (Object.keys(toBeResolved).length === 0) {
|
|
97
97
|
const importedResult = rCtx.importObjectUniversal(result);
|
|
98
|
+
if (require_index.getDebugFlags().logJsExecStat) console.log(`[jsExec] ${key}: ${JSON.stringify(rCtx.stats)}`);
|
|
98
99
|
logOutputStatus(fh.handle, importedResult, cCtx.unstableMarker === void 0, -1, cCtx.unstableMarker);
|
|
99
100
|
return { ir: importedResult };
|
|
100
101
|
}
|
|
@@ -107,6 +108,7 @@ function computableFromRF(env, ctx, fh, codeWithInfo, configKey, ops = {}) {
|
|
|
107
108
|
for (const [handle, value] of Object.entries(resolved)) rCtx.runCallback(handle, value);
|
|
108
109
|
const renderedResult = rCtx.importObjectUniversal(result);
|
|
109
110
|
recalculationCounter++;
|
|
111
|
+
if (require_index.getDebugFlags().logJsExecStat) console.log(`[jsExec] ${key} #${recalculationCounter}: ${JSON.stringify(rCtx.stats)}`);
|
|
110
112
|
logOutputStatus(fh.handle, renderedResult, stable, recalculationCounter, unstableMarker);
|
|
111
113
|
return renderedResult;
|
|
112
114
|
}
|
|
@@ -136,7 +138,9 @@ function executeSingleLambda(quickJs, fh, codeWithInfo, ...args) {
|
|
|
136
138
|
deadlineSettings = s;
|
|
137
139
|
}, featureFlags);
|
|
138
140
|
rCtx.evaluateBundle(code.content);
|
|
139
|
-
|
|
141
|
+
const importedResult = rCtx.importObjectUniversal(rCtx.runCallback(fh.handle, ...args));
|
|
142
|
+
if (require_index.getDebugFlags().logJsExecStat) console.log(`[jsExec] ${fh.handle}: ${JSON.stringify(rCtx.stats)}`);
|
|
143
|
+
return importedResult;
|
|
140
144
|
} finally {
|
|
141
145
|
scope.dispose();
|
|
142
146
|
}
|