@milaboratories/pl-middle-layer 1.43.59 → 1.43.60
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/debug/index.cjs +0 -1
- package/dist/debug/index.cjs.map +1 -1
- package/dist/debug/index.d.ts +0 -1
- package/dist/debug/index.d.ts.map +1 -1
- package/dist/debug/index.js +0 -1
- package/dist/debug/index.js.map +1 -1
- package/dist/js_render/computable_context.cjs +6 -2
- package/dist/js_render/computable_context.cjs.map +1 -1
- package/dist/js_render/computable_context.d.ts +1 -1
- package/dist/js_render/computable_context.d.ts.map +1 -1
- package/dist/js_render/computable_context.js +6 -2
- package/dist/js_render/computable_context.js.map +1 -1
- package/dist/middle_layer/driver_kit.cjs +6 -1
- package/dist/middle_layer/driver_kit.cjs.map +1 -1
- package/dist/middle_layer/driver_kit.js +7 -2
- package/dist/middle_layer/driver_kit.js.map +1 -1
- package/dist/middle_layer/ops.cjs +4 -8
- package/dist/middle_layer/ops.cjs.map +1 -1
- package/dist/middle_layer/ops.d.ts +1 -1
- package/dist/middle_layer/ops.d.ts.map +1 -1
- package/dist/middle_layer/ops.js +4 -8
- package/dist/middle_layer/ops.js.map +1 -1
- package/dist/pool/data.cjs +0 -15
- package/dist/pool/data.cjs.map +1 -1
- package/dist/pool/data.d.ts +1 -2
- package/dist/pool/data.d.ts.map +1 -1
- package/dist/pool/data.js +1 -15
- package/dist/pool/data.js.map +1 -1
- package/dist/pool/driver.cjs +88 -906
- package/dist/pool/driver.cjs.map +1 -1
- package/dist/pool/driver.d.ts +14 -86
- package/dist/pool/driver.d.ts.map +1 -1
- package/dist/pool/driver.js +88 -907
- package/dist/pool/driver.js.map +1 -1
- package/package.json +20 -19
- package/src/debug/index.ts +0 -2
- package/src/js_render/computable_context.ts +8 -6
- package/src/middle_layer/driver_kit.ts +6 -6
- package/src/middle_layer/ops.ts +2 -9
- package/src/pool/data.ts +0 -22
- package/src/pool/driver.ts +141 -1208
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"computable_context.js","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 {\n checkBlockFlag,\n} 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 PTableHandle,\n ResourceType as ResourceTypeFromSDK,\n ResultCollection,\n ValueOrError,\n RangeBytes,\n BlockCodeKnownFeatureFlags,\n\n JsRenderInternal } from '@platforma-sdk/model';\nimport {\n isDataInfo,\n mapDataInfo,\n mapPObjectData,\n mapPTableDef,\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';\n\nfunction bytesToBase64(data: Uint8Array | undefined): string | undefined {\n return data !== undefined ? Buffer.from(data).toString('base64') : undefined;\n}\n\nexport class ComputableContextHelper\nimplements JsRenderInternal.GlobalCfgRenderCtxMethods<string, string> {\n public readonly computablesToResolve: Record<string, Computable<unknown>> = {};\n\n private computableCtx: ComputableCtx | undefined;\n private readonly accessors = new Map<string, PlTreeNodeAccessor | undefined>();\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(await this.env.driverKit.blobDriver.getContent(value.handle, range)).toString(\n 'utf-8',\n );\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(await this.env.driverKit.blobDriver.getContent(value.handle, range)).toString(\n 'base64',\n );\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(def: PFrameDef<string | PColumnValues | DataInfo<string>>): 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 return this.env.driverKit.pFrameDriver.createPFrame(\n def.map((c) => mapPObjectData(c, (d) => this.transformInputPData(d))),\n this.computableCtx,\n );\n }\n\n public createPTable(def: PTableDef<PColumn<string | PColumnValues | DataInfo<string>>>): 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 return this.env.driverKit.pFrameDriver.createPTable(\n mapPTableDef(def, (c) =>\n mapPObjectData(c, (d) => this.transformInputPData(d)),\n ),\n this.computableCtx,\n );\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(d: string | PColumnValues | DataInfo<string>): 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\n // eslint-disable-next-line @typescript-eslint/only-throw-error\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) => vm.setProp(configCtx, name + '__internal__', fnh));\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(`Add dummy call to ctx.args outside the future lambda. Can't be directly used in this context.`);\n return vm.newString(this.blockCtx.args(this.computableCtx));\n });\n exportCtxFunction('uiState', () => {\n if (this.computableCtx === undefined)\n throw new Error(`Add dummy call to ctx.uiState outside the future lambda. Can't be directly used in this context.`);\n return vm.newString(this.blockCtx.uiState(this.computableCtx) ?? '{}');\n });\n exportCtxFunction('activeArgs', () => {\n if (this.computableCtx === undefined)\n throw new Error(`Add dummy call to ctx.activeArgs outside the future lambda. Can't be directly used in this context.`);\n const res = this.blockCtx.activeArgs(this.computableCtx);\n return res === undefined ? vm.undefined : vm.newString(res);\n });\n } else {\n const args = this.blockCtx.args(this.computableCtx!);\n const activeArgs = this.blockCtx.activeArgs(this.computableCtx!);\n const uiState = this.blockCtx.uiState(this.computableCtx!);\n vm.setProp(configCtx, 'args', localScope.manage(vm.newString(args)));\n vm.setProp(configCtx, 'uiState', localScope.manage(vm.newString(uiState ?? '{}')));\n if (activeArgs !== undefined)\n vm.setProp(configCtx, 'activeArgs', localScope.manage(vm.newString(activeArgs)));\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.listInputFields(vm.getString(handle)), undefined);\n });\n\n exportCtxFunction('listDynamicFields', (handle) => {\n return parent.exportObjectViaJson(this.listInputFields(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(vm.getString(handle), parent.importObjectUniversal(range) as RangeBytes | undefined),\n undefined,\n );\n });\n\n exportCtxFunction('getBlobContentAsString', (handle, range) => {\n return parent.exportSingleValue(\n this.getBlobContentAsString(vm.getString(handle), parent.importObjectUniversal(range) as RangeBytes | undefined),\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 // 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(\n vm.getString(blockId),\n vm.getString(exportName),\n ),\n undefined,\n );\n });\n\n exportCtxFunction('getDataFromResultPoolByRef', (blockId, exportName) => {\n return parent.exportObjectUniversal(\n this.getDataFromResultPoolByRef(\n vm.getString(blockId),\n vm.getString(exportName),\n ),\n undefined,\n );\n });\n\n //\n // PFrames / PTables\n //\n\n exportCtxFunction('createPFrame', (def) => {\n return parent.exportSingleValue(\n this.createPFrame(parent.importObjectViaJson(def) as PFrameDef<string | PColumnValues>),\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 //\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"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"computable_context.js","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 {\n checkBlockFlag,\n} 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 PTableHandle,\n ResourceType as ResourceTypeFromSDK,\n ResultCollection,\n ValueOrError,\n RangeBytes,\n BlockCodeKnownFeatureFlags,\n\n JsRenderInternal } from '@platforma-sdk/model';\nimport {\n isDataInfo,\n mapDataInfo,\n mapPObjectData,\n mapPTableDef,\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';\n\nfunction bytesToBase64(data: Uint8Array | undefined): string | undefined {\n return data !== undefined ? Buffer.from(data).toString('base64') : undefined;\n}\n\nexport class ComputableContextHelper\nimplements JsRenderInternal.GlobalCfgRenderCtxMethods<string, string> {\n public readonly computablesToResolve: Record<string, Computable<unknown>> = {};\n\n private computableCtx: ComputableCtx | undefined;\n private readonly accessors = new Map<string, PlTreeNodeAccessor | undefined>();\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(await this.env.driverKit.blobDriver.getContent(value.handle, range)).toString(\n 'utf-8',\n );\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(await this.env.driverKit.blobDriver.getContent(value.handle, range)).toString(\n 'base64',\n );\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(def: PFrameDef<PColumn<string | PColumnValues | DataInfo<string>>>): 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(def: PTableDef<PColumn<string | PColumnValues | DataInfo<string>>>): 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) =>\n mapPObjectData(c, (d) => this.transformInputPData(d)),\n ),\n );\n this.computableCtx.addOnDestroy(unref);\n return key;\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(d: string | PColumnValues | DataInfo<string>): 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\n // eslint-disable-next-line @typescript-eslint/only-throw-error\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) => vm.setProp(configCtx, name + '__internal__', fnh));\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(`Add dummy call to ctx.args outside the future lambda. Can't be directly used in this context.`);\n return vm.newString(this.blockCtx.args(this.computableCtx));\n });\n exportCtxFunction('uiState', () => {\n if (this.computableCtx === undefined)\n throw new Error(`Add dummy call to ctx.uiState outside the future lambda. Can't be directly used in this context.`);\n return vm.newString(this.blockCtx.uiState(this.computableCtx) ?? '{}');\n });\n exportCtxFunction('activeArgs', () => {\n if (this.computableCtx === undefined)\n throw new Error(`Add dummy call to ctx.activeArgs outside the future lambda. Can't be directly used in this context.`);\n const res = this.blockCtx.activeArgs(this.computableCtx);\n return res === undefined ? vm.undefined : vm.newString(res);\n });\n } else {\n const args = this.blockCtx.args(this.computableCtx!);\n const activeArgs = this.blockCtx.activeArgs(this.computableCtx!);\n const uiState = this.blockCtx.uiState(this.computableCtx!);\n vm.setProp(configCtx, 'args', localScope.manage(vm.newString(args)));\n vm.setProp(configCtx, 'uiState', localScope.manage(vm.newString(uiState ?? '{}')));\n if (activeArgs !== undefined)\n vm.setProp(configCtx, 'activeArgs', localScope.manage(vm.newString(activeArgs)));\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.listInputFields(vm.getString(handle)), undefined);\n });\n\n exportCtxFunction('listDynamicFields', (handle) => {\n return parent.exportObjectViaJson(this.listInputFields(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(vm.getString(handle), parent.importObjectUniversal(range) as RangeBytes | undefined),\n undefined,\n );\n });\n\n exportCtxFunction('getBlobContentAsString', (handle, range) => {\n return parent.exportSingleValue(\n this.getBlobContentAsString(vm.getString(handle), parent.importObjectUniversal(range) as RangeBytes | undefined),\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 // 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(\n vm.getString(blockId),\n vm.getString(exportName),\n ),\n undefined,\n );\n });\n\n exportCtxFunction('getDataFromResultPoolByRef', (blockId, exportName) => {\n return parent.exportObjectUniversal(\n this.getDataFromResultPoolByRef(\n vm.getString(blockId),\n vm.getString(exportName),\n ),\n undefined,\n );\n });\n\n //\n // PFrames / PTables\n //\n\n exportCtxFunction('createPFrame', (def) => {\n return parent.exportSingleValue(\n this.createPFrame(parent.importObjectViaJson(def) as PFrameDef<PColumn<string | PColumnValues>>),\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 //\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"],"names":[],"mappings":"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"}
|
|
@@ -24,7 +24,12 @@ async function initDriverKit(pl, workdir, frontendDownloadPath, _ops) {
|
|
|
24
24
|
const logsStreamDriver = new plDrivers.LogsStreamDriver(ops$1.logger, logsClient, ops$1.logStreamDriverOps);
|
|
25
25
|
const logDriver = new plDrivers.LogsDriver(ops$1.logger, logsStreamDriver, blobDriver);
|
|
26
26
|
const lsDriver = await plDrivers.LsDriver.init(ops$1.logger, pl, signer, ops$1.localProjections, ops$1.openFileDialogCallback, ops$1.virtualLocalStoragesOverride);
|
|
27
|
-
const pFrameDriver = await driver.
|
|
27
|
+
const pFrameDriver = await driver.createPFrameDriver({
|
|
28
|
+
blobDriver,
|
|
29
|
+
logger: ops$1.logger,
|
|
30
|
+
spillPath: ops$1.pframesSpillPath,
|
|
31
|
+
options: ops$1.pFrameDriverOps,
|
|
32
|
+
});
|
|
28
33
|
const frontendDownloadDriver = new plDrivers.DownloadUrlDriver(ops$1.logger, pl.httpDispatcher, frontendDownloadPath, signer, ops$1.frontendDownloadDriverOps);
|
|
29
34
|
const driverKit = {
|
|
30
35
|
blobDriver,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"driver_kit.cjs","sources":["../../src/middle_layer/driver_kit.ts"],"sourcesContent":["import type { PlClient } from '@milaboratories/pl-client';\nimport type {\n InternalLsDriver } from '@milaboratories/pl-drivers';\nimport {\n createDownloadClient,\n createLogsClient,\n createUploadBlobClient,\n createUploadProgressClient,\n DownloadDriver,\n DownloadBlobToURLDriver,\n LogsDriver,\n LogsStreamDriver,\n LsDriver,\n UploadDriver,\n DownloadUrlDriver,\n} from '@milaboratories/pl-drivers';\nimport type * as Sdk from '@milaboratories/pl-model-common';\nimport type { Signer } from '@milaboratories/ts-helpers';\nimport { HmacSha256Signer, isAsyncDisposable } from '@milaboratories/ts-helpers';\nimport type { InternalPFrameDriver } from '../pool';\nimport {
|
|
1
|
+
{"version":3,"file":"driver_kit.cjs","sources":["../../src/middle_layer/driver_kit.ts"],"sourcesContent":["import type { PlClient } from '@milaboratories/pl-client';\nimport type {\n InternalLsDriver } from '@milaboratories/pl-drivers';\nimport {\n createDownloadClient,\n createLogsClient,\n createUploadBlobClient,\n createUploadProgressClient,\n DownloadDriver,\n DownloadBlobToURLDriver,\n LogsDriver,\n LogsStreamDriver,\n LsDriver,\n UploadDriver,\n DownloadUrlDriver,\n} from '@milaboratories/pl-drivers';\nimport type * as Sdk from '@milaboratories/pl-model-common';\nimport type { Signer } from '@milaboratories/ts-helpers';\nimport { HmacSha256Signer, isAsyncDisposable } from '@milaboratories/ts-helpers';\nimport type { InternalPFrameDriver } from '../pool';\nimport { createPFrameDriver } from '../pool';\nimport type {\n DriverKitOps,\n DriverKitOpsConstructor,\n} from './ops';\nimport {\n DefaultDriverKitOpsPaths,\n DefaultDriverKitOpsSettings,\n} from './ops';\n\n/**\n * Drivers offered by the middle-layer for internal consumers,\n * like configuration rendering routines.\n *\n * This intertface is basically a version of the DriverKit from\n * UI SDK with extended API.\n * */\nexport interface MiddleLayerDriverKit extends Sdk.DriverKit, AsyncDisposable {\n /** Dispose the driver kit and all its resources. */\n dispose(): Promise<void>;\n\n // override with wider interface\n readonly blobDriver: DownloadDriver;\n // override with wider interface\n readonly blobToURLDriver: DownloadBlobToURLDriver;\n // override with wider interface\n readonly logDriver: LogsDriver;\n // override with wider interface\n readonly lsDriver: InternalLsDriver;\n // override with wider interface\n readonly pFrameDriver: InternalPFrameDriver;\n // override with wider interface\n readonly frontendDriver: DownloadUrlDriver;\n\n /**\n * Signer is initialized from local secret in drivers initialization routine,\n * so constitutes a part of the driver kit\n * */\n readonly signer: Signer;\n\n /**\n * Used to retrieve upload progress, and initiate upload porecesses driven by\n * upload requests from block outputs.\n * */\n readonly uploadDriver: UploadDriver;\n}\n\nexport async function initDriverKit(\n pl: PlClient,\n workdir: string,\n frontendDownloadPath: string,\n _ops: DriverKitOpsConstructor,\n): Promise<MiddleLayerDriverKit> {\n const ops: DriverKitOps = {\n ...DefaultDriverKitOpsSettings,\n ...DefaultDriverKitOpsPaths(workdir),\n ..._ops,\n };\n\n const signer = new HmacSha256Signer(ops.localSecret);\n\n const downloadClient = createDownloadClient(ops.logger, pl, ops.localProjections);\n const logsClient = createLogsClient(pl, ops.logger);\n const uploadBlobClient = createUploadBlobClient(pl, ops.logger);\n const uploadProgressClient = createUploadProgressClient(pl, ops.logger);\n\n const blobDriver = await DownloadDriver.init(\n ops.logger,\n downloadClient,\n logsClient,\n ops.blobDownloadPath,\n ops.blobDownloadRangesCachePath,\n signer,\n ops.blobDriverOps,\n );\n\n const blobToURLDriver = new DownloadBlobToURLDriver(\n ops.logger,\n signer,\n downloadClient,\n ops.downloadBlobToURLPath,\n ops.downloadBlobToURLDriverOps,\n );\n\n const uploadDriver = new UploadDriver(\n ops.logger,\n signer,\n uploadBlobClient,\n uploadProgressClient,\n ops.uploadDriverOps,\n );\n const logsStreamDriver = new LogsStreamDriver(ops.logger, logsClient, ops.logStreamDriverOps);\n const logDriver = new LogsDriver(ops.logger, logsStreamDriver, blobDriver);\n const lsDriver = await LsDriver.init(\n ops.logger,\n pl,\n signer,\n ops.localProjections,\n ops.openFileDialogCallback,\n ops.virtualLocalStoragesOverride,\n );\n\n const pFrameDriver = await createPFrameDriver({\n blobDriver,\n logger: ops.logger,\n spillPath: ops.pframesSpillPath,\n options: ops.pFrameDriverOps,\n });\n\n const frontendDownloadDriver = new DownloadUrlDriver(\n ops.logger,\n pl.httpDispatcher,\n frontendDownloadPath,\n signer,\n ops.frontendDownloadDriverOps,\n );\n\n const driverKit = {\n blobDriver,\n blobToURLDriver: blobToURLDriver,\n logDriver,\n lsDriver,\n signer,\n uploadDriver,\n pFrameDriver,\n frontendDriver: frontendDownloadDriver,\n };\n\n const dispose = async () => {\n const disposePromises = Object.values(driverKit)\n .flatMap((driver) => isAsyncDisposable(driver) ? [driver[Symbol.asyncDispose]] : []);\n await Promise.all(disposePromises);\n };\n\n return {\n ...driverKit,\n dispose,\n [Symbol.asyncDispose]: dispose,\n };\n}\n"],"names":["ops","DefaultDriverKitOpsSettings","DefaultDriverKitOpsPaths","HmacSha256Signer","createDownloadClient","createLogsClient","createUploadBlobClient","createUploadProgressClient","DownloadDriver","DownloadBlobToURLDriver","UploadDriver","LogsStreamDriver","LogsDriver","LsDriver","createPFrameDriver","DownloadUrlDriver","isAsyncDisposable"],"mappings":"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"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { createDownloadClient, createLogsClient, createUploadBlobClient, createUploadProgressClient, DownloadDriver, DownloadBlobToURLDriver, UploadDriver, LogsStreamDriver, LogsDriver, LsDriver, DownloadUrlDriver } from '@milaboratories/pl-drivers';
|
|
2
2
|
import { HmacSha256Signer, isAsyncDisposable } from '@milaboratories/ts-helpers';
|
|
3
|
-
import {
|
|
3
|
+
import { createPFrameDriver } from '../pool/driver.js';
|
|
4
4
|
import '@platforma-sdk/model';
|
|
5
5
|
import '../pool/data.js';
|
|
6
6
|
import { DefaultDriverKitOpsPaths, DefaultDriverKitOpsSettings } from './ops.js';
|
|
@@ -22,7 +22,12 @@ async function initDriverKit(pl, workdir, frontendDownloadPath, _ops) {
|
|
|
22
22
|
const logsStreamDriver = new LogsStreamDriver(ops.logger, logsClient, ops.logStreamDriverOps);
|
|
23
23
|
const logDriver = new LogsDriver(ops.logger, logsStreamDriver, blobDriver);
|
|
24
24
|
const lsDriver = await LsDriver.init(ops.logger, pl, signer, ops.localProjections, ops.openFileDialogCallback, ops.virtualLocalStoragesOverride);
|
|
25
|
-
const pFrameDriver = await
|
|
25
|
+
const pFrameDriver = await createPFrameDriver({
|
|
26
|
+
blobDriver,
|
|
27
|
+
logger: ops.logger,
|
|
28
|
+
spillPath: ops.pframesSpillPath,
|
|
29
|
+
options: ops.pFrameDriverOps,
|
|
30
|
+
});
|
|
26
31
|
const frontendDownloadDriver = new DownloadUrlDriver(ops.logger, pl.httpDispatcher, frontendDownloadPath, signer, ops.frontendDownloadDriverOps);
|
|
27
32
|
const driverKit = {
|
|
28
33
|
blobDriver,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"driver_kit.js","sources":["../../src/middle_layer/driver_kit.ts"],"sourcesContent":["import type { PlClient } from '@milaboratories/pl-client';\nimport type {\n InternalLsDriver } from '@milaboratories/pl-drivers';\nimport {\n createDownloadClient,\n createLogsClient,\n createUploadBlobClient,\n createUploadProgressClient,\n DownloadDriver,\n DownloadBlobToURLDriver,\n LogsDriver,\n LogsStreamDriver,\n LsDriver,\n UploadDriver,\n DownloadUrlDriver,\n} from '@milaboratories/pl-drivers';\nimport type * as Sdk from '@milaboratories/pl-model-common';\nimport type { Signer } from '@milaboratories/ts-helpers';\nimport { HmacSha256Signer, isAsyncDisposable } from '@milaboratories/ts-helpers';\nimport type { InternalPFrameDriver } from '../pool';\nimport {
|
|
1
|
+
{"version":3,"file":"driver_kit.js","sources":["../../src/middle_layer/driver_kit.ts"],"sourcesContent":["import type { PlClient } from '@milaboratories/pl-client';\nimport type {\n InternalLsDriver } from '@milaboratories/pl-drivers';\nimport {\n createDownloadClient,\n createLogsClient,\n createUploadBlobClient,\n createUploadProgressClient,\n DownloadDriver,\n DownloadBlobToURLDriver,\n LogsDriver,\n LogsStreamDriver,\n LsDriver,\n UploadDriver,\n DownloadUrlDriver,\n} from '@milaboratories/pl-drivers';\nimport type * as Sdk from '@milaboratories/pl-model-common';\nimport type { Signer } from '@milaboratories/ts-helpers';\nimport { HmacSha256Signer, isAsyncDisposable } from '@milaboratories/ts-helpers';\nimport type { InternalPFrameDriver } from '../pool';\nimport { createPFrameDriver } from '../pool';\nimport type {\n DriverKitOps,\n DriverKitOpsConstructor,\n} from './ops';\nimport {\n DefaultDriverKitOpsPaths,\n DefaultDriverKitOpsSettings,\n} from './ops';\n\n/**\n * Drivers offered by the middle-layer for internal consumers,\n * like configuration rendering routines.\n *\n * This intertface is basically a version of the DriverKit from\n * UI SDK with extended API.\n * */\nexport interface MiddleLayerDriverKit extends Sdk.DriverKit, AsyncDisposable {\n /** Dispose the driver kit and all its resources. */\n dispose(): Promise<void>;\n\n // override with wider interface\n readonly blobDriver: DownloadDriver;\n // override with wider interface\n readonly blobToURLDriver: DownloadBlobToURLDriver;\n // override with wider interface\n readonly logDriver: LogsDriver;\n // override with wider interface\n readonly lsDriver: InternalLsDriver;\n // override with wider interface\n readonly pFrameDriver: InternalPFrameDriver;\n // override with wider interface\n readonly frontendDriver: DownloadUrlDriver;\n\n /**\n * Signer is initialized from local secret in drivers initialization routine,\n * so constitutes a part of the driver kit\n * */\n readonly signer: Signer;\n\n /**\n * Used to retrieve upload progress, and initiate upload porecesses driven by\n * upload requests from block outputs.\n * */\n readonly uploadDriver: UploadDriver;\n}\n\nexport async function initDriverKit(\n pl: PlClient,\n workdir: string,\n frontendDownloadPath: string,\n _ops: DriverKitOpsConstructor,\n): Promise<MiddleLayerDriverKit> {\n const ops: DriverKitOps = {\n ...DefaultDriverKitOpsSettings,\n ...DefaultDriverKitOpsPaths(workdir),\n ..._ops,\n };\n\n const signer = new HmacSha256Signer(ops.localSecret);\n\n const downloadClient = createDownloadClient(ops.logger, pl, ops.localProjections);\n const logsClient = createLogsClient(pl, ops.logger);\n const uploadBlobClient = createUploadBlobClient(pl, ops.logger);\n const uploadProgressClient = createUploadProgressClient(pl, ops.logger);\n\n const blobDriver = await DownloadDriver.init(\n ops.logger,\n downloadClient,\n logsClient,\n ops.blobDownloadPath,\n ops.blobDownloadRangesCachePath,\n signer,\n ops.blobDriverOps,\n );\n\n const blobToURLDriver = new DownloadBlobToURLDriver(\n ops.logger,\n signer,\n downloadClient,\n ops.downloadBlobToURLPath,\n ops.downloadBlobToURLDriverOps,\n );\n\n const uploadDriver = new UploadDriver(\n ops.logger,\n signer,\n uploadBlobClient,\n uploadProgressClient,\n ops.uploadDriverOps,\n );\n const logsStreamDriver = new LogsStreamDriver(ops.logger, logsClient, ops.logStreamDriverOps);\n const logDriver = new LogsDriver(ops.logger, logsStreamDriver, blobDriver);\n const lsDriver = await LsDriver.init(\n ops.logger,\n pl,\n signer,\n ops.localProjections,\n ops.openFileDialogCallback,\n ops.virtualLocalStoragesOverride,\n );\n\n const pFrameDriver = await createPFrameDriver({\n blobDriver,\n logger: ops.logger,\n spillPath: ops.pframesSpillPath,\n options: ops.pFrameDriverOps,\n });\n\n const frontendDownloadDriver = new DownloadUrlDriver(\n ops.logger,\n pl.httpDispatcher,\n frontendDownloadPath,\n signer,\n ops.frontendDownloadDriverOps,\n );\n\n const driverKit = {\n blobDriver,\n blobToURLDriver: blobToURLDriver,\n logDriver,\n lsDriver,\n signer,\n uploadDriver,\n pFrameDriver,\n frontendDriver: frontendDownloadDriver,\n };\n\n const dispose = async () => {\n const disposePromises = Object.values(driverKit)\n .flatMap((driver) => isAsyncDisposable(driver) ? [driver[Symbol.asyncDispose]] : []);\n await Promise.all(disposePromises);\n };\n\n return {\n ...driverKit,\n dispose,\n [Symbol.asyncDispose]: dispose,\n };\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -2,6 +2,9 @@
|
|
|
2
2
|
|
|
3
3
|
var tsHelpers = require('@milaboratories/ts-helpers');
|
|
4
4
|
var path = require('node:path');
|
|
5
|
+
var driver = require('../pool/driver.cjs');
|
|
6
|
+
require('@platforma-sdk/model');
|
|
7
|
+
require('../pool/data.cjs');
|
|
5
8
|
|
|
6
9
|
/** Some defaults fot MiddleLayerOps. */
|
|
7
10
|
const DefaultDriverKitOpsSettings = {
|
|
@@ -31,14 +34,7 @@ const DefaultDriverKitOpsSettings = {
|
|
|
31
34
|
pollingInterval: 1000,
|
|
32
35
|
stopPollingDelay: 1000,
|
|
33
36
|
},
|
|
34
|
-
pFrameDriverOps:
|
|
35
|
-
parquetServerPort: 0, // 0 means that some unused port will be assigned by the OS
|
|
36
|
-
pFrameConcurrency: 1, // 1 join is executed in parallel and utilize all RAM and CPU cores
|
|
37
|
-
pTableConcurrency: 1, // 1 joined table is read from disk at a time, which matches 1 table the user can view in the UI
|
|
38
|
-
pFrameCacheMaxCount: 18, // SHM trees create 3 PTables per graphic, we want to cache 6 graphics per PFrame
|
|
39
|
-
pFramesCacheMaxSize: 8 * 1024 * 1024 * 1024, // 8 GB, same as blob driver cache (must be at lease 2GB)
|
|
40
|
-
pTablesCacheMaxSize: 32 * 1024 * 1024 * 1024, // 32 GB (must be at lease 8GB)
|
|
41
|
-
},
|
|
37
|
+
pFrameDriverOps: driver.PFrameDriverOpsDefaults,
|
|
42
38
|
};
|
|
43
39
|
function DefaultDriverKitOpsPaths(workDir) {
|
|
44
40
|
return {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ops.cjs","sources":["../../src/middle_layer/ops.ts"],"sourcesContent":["import type { TemporalSynchronizedTreeOps } from './types';\nimport type {\n DownloadBlobToURLDriverOps,\n DownloadDriverOps,\n DownloadUrlDriverOps,\n OpenFileDialogCallback,\n VirtualLocalStorageSpec,\n} from '@milaboratories/pl-drivers';\nimport type { UploadDriverOps } from '@milaboratories/pl-drivers';\nimport type { LogsStreamDriverOps } from '@milaboratories/pl-drivers';\nimport type { MiLogger } from '@milaboratories/ts-helpers';\nimport { ConsoleLoggerAdapter } from '@milaboratories/ts-helpers';\nimport type { LocalStorageProjection } from '@milaboratories/pl-drivers';\nimport path from 'node:path';\nimport type { PFrameDriverOps } from '../pool/driver';\n\n/** Paths part of {@link DriverKitOps}. */\nexport type DriverKitOpsPaths = {\n /** Common root where to put downloaded blobs / downloaded blob cache */\n readonly blobDownloadPath: string;\n\n /** Common root for a cache for range queries. */\n readonly blobDownloadRangesCachePath: string;\n\n /** Common root where to put downloaded blobs with */\n readonly downloadBlobToURLPath: string;\n\n /**\n * List of pl storages that have projections in local file system.\n *\n * This option affect two drivers:\n *\n * (1) LS driver generates \"index\" handles instead of \"upload\" for paths inside those locations\n *\n * (2) Download driver directly serves content retrieval requests for blobs from listed storages,\n * and don't apply any caching for such blobs (i.e. preventing duplication of files for Downloaded\n * type handles, making OnDemand and Downloaded handles equivalent)\n *\n * */\n readonly localProjections: LocalStorageProjection[];\n\n /**\n * List of virtual storages that will allow homogeneous access to local FSs through LS API.\n * If undefined, default list will be created.\n * */\n readonly virtualLocalStoragesOverride?: VirtualLocalStorageSpec[];\n\n /** Path to the directory where pframes will spill temporary files and store materialized views */\n readonly pframesSpillPath: string;\n};\n\n/** Options required to initialize full set of middle layer driver kit */\nexport type DriverKitOpsSettings = {\n //\n // Common\n //\n\n readonly logger: MiLogger;\n\n //\n // Signer\n //\n\n /**\n * Local secret, that is used to sign and verify different pieces of information\n * that can be used to access local data, like local paths for ongoing uploads.\n *\n * Use {@link MiddleLayer.generateLocalSecret} to generate sufficiently random string.\n * */\n readonly localSecret: string;\n\n //\n // Blob Driver\n //\n\n /**\n * Settings related to the download driver making operations with blobs. This driver is also used\n * to download logs when source process terminates and log terns into a blob\n */\n readonly blobDriverOps: DownloadDriverOps;\n\n //\n // Frontend Driver\n //\n\n /** Settings related to the frontend driver that downloads frontends. */\n readonly frontendDownloadDriverOps: DownloadUrlDriverOps;\n\n //\n // Blob To URL Driver\n //\n\n readonly downloadBlobToURLDriverOps: DownloadBlobToURLDriverOps;\n\n //\n // Upload Driver\n //\n\n /**\n * Settings related to the upload driver that actually performs upload and helps render upload\n * and indexing progresses from related pl resources.\n * */\n readonly uploadDriverOps: UploadDriverOps;\n\n //\n // Log streaming ops\n // (static logs are served via the blob driver)\n //\n\n /** Settings related to the streaming log driver */\n readonly logStreamDriverOps: LogsStreamDriverOps;\n\n //\n // LS Driver\n //\n\n /**\n * Callback to access system file open dialog, must be provided by the environment,\n * to allow for {@link showOpenSingleFileDialog} / {@link showOpenMultipleFilesDialog}\n * calls from the UI.\n */\n readonly openFileDialogCallback: OpenFileDialogCallback;\n\n //\n // PFrame Driver\n //\n\n /** Settings related to the PFrame driver */\n readonly pFrameDriverOps: PFrameDriverOps;\n};\n\nexport type DriverKitOps = DriverKitOpsPaths & DriverKitOpsSettings;\n\n/** Some defaults fot MiddleLayerOps. */\nexport const DefaultDriverKitOpsSettings: Pick<\n DriverKitOpsSettings,\n | 'logger'\n | 'blobDriverOps'\n | 'frontendDownloadDriverOps'\n | 'downloadBlobToURLDriverOps'\n | 'uploadDriverOps'\n | 'logStreamDriverOps'\n | 'pFrameDriverOps'\n> = {\n logger: new ConsoleLoggerAdapter(),\n blobDriverOps: {\n cacheSoftSizeBytes: 8 * 1024 * 1024 * 1024, // 8 GB\n rangesCacheMaxSizeBytes: 8 * 1024 * 1024 * 1024, // 8 GB\n nConcurrentDownloads: 10,\n },\n frontendDownloadDriverOps: {\n cacheSoftSizeBytes: 1 * 1024 * 1024 * 1024, // 1 GB\n withGunzip: true,\n nConcurrentDownloads: 50,\n },\n downloadBlobToURLDriverOps: {\n cacheSoftSizeBytes: 1 * 1024 * 1024 * 1024, // 1 GB\n nConcurrentDownloads: 10,\n },\n uploadDriverOps: {\n nConcurrentPartUploads: 10,\n nConcurrentGetProgresses: 10,\n pollingInterval: 1000,\n stopPollingDelay: 1000,\n },\n logStreamDriverOps: {\n nConcurrentGetLogs: 10,\n pollingInterval: 1000,\n stopPollingDelay: 1000,\n },\n pFrameDriverOps: {\n parquetServerPort: 0, // 0 means that some unused port will be assigned by the OS\n pFrameConcurrency: 1, // 1 join is executed in parallel and utilize all RAM and CPU cores\n pTableConcurrency: 1, // 1 joined table is read from disk at a time, which matches 1 table the user can view in the UI\n pFrameCacheMaxCount: 18, // SHM trees create 3 PTables per graphic, we want to cache 6 graphics per PFrame\n pFramesCacheMaxSize: 8 * 1024 * 1024 * 1024, // 8 GB, same as blob driver cache (must be at lease 2GB)\n pTablesCacheMaxSize: 32 * 1024 * 1024 * 1024, // 32 GB (must be at lease 8GB)\n },\n};\n\nexport function DefaultDriverKitOpsPaths(\n workDir: string,\n): Pick<DriverKitOpsPaths,\n| 'blobDownloadPath'\n| 'blobDownloadRangesCachePath'\n| 'downloadBlobToURLPath'\n| 'pframesSpillPath'> {\n return {\n blobDownloadPath: path.join(workDir, 'download'),\n blobDownloadRangesCachePath: path.join(workDir, 'downloadRangesCache'),\n downloadBlobToURLPath: path.join(workDir, 'downloadToURL'),\n pframesSpillPath: path.join(workDir, 'pframes'),\n };\n}\n\n/** Fields with default values are marked as optional here. */\n// prettier-ignore\nexport type DriverKitOpsConstructor =\n Omit<DriverKitOpsSettings, keyof typeof DefaultDriverKitOpsSettings>\n & Partial<typeof DefaultDriverKitOpsSettings>\n & Omit<DriverKitOpsPaths, keyof ReturnType<typeof DefaultDriverKitOpsPaths>>\n & Partial<ReturnType<typeof DefaultDriverKitOpsPaths>>;\n\nexport type MiddleLayerOpsPaths = DriverKitOpsPaths & {\n /** Common root where to put frontend code. */\n readonly frontendDownloadPath: string;\n};\n\n/** Debug options for middle layer. */\nexport type MiddleLayerDebugOptions = {\n /** If true, will dump initial tree state to the file with root resource id as name. */\n dumpInitialTreeState: boolean;\n};\n\n/** Configuration controlling different aspects of middle layer behaviour. */\nexport type MiddleLayerOpsSettings = DriverKitOpsSettings & {\n /** Debug options. */\n readonly debugOps: MiddleLayerDebugOptions;\n\n /** Contain temporal options controlling how often should pl trees be\n * synchronized with the pl server. */\n readonly defaultTreeOptions: TemporalSynchronizedTreeOps;\n\n /** Defines interval in milliseconds for running periodic project maintenance job.\n * Project maintenance includes gradual staging rendering and cached outputs cleanup. */\n readonly projectRefreshInterval: number;\n\n /** This controls average number of block staging states that are rendered per\n * second during project maintenance job execution. */\n readonly stagingRenderingRate: number;\n\n /** How often to check for dev block updates */\n readonly devBlockUpdateRecheckInterval: number;\n\n /** Prioritize this channel if update is available in this block */\n readonly preferredUpdateChannel?: string;\n};\n\nexport type MiddleLayerOps = MiddleLayerOpsSettings & MiddleLayerOpsPaths;\n\n/** Some defaults fot MiddleLayerOps. */\nexport const DefaultMiddleLayerOpsSettings: Pick<\n MiddleLayerOps,\n | keyof typeof DefaultDriverKitOpsSettings\n | 'defaultTreeOptions'\n | 'projectRefreshInterval'\n | 'stagingRenderingRate'\n | 'devBlockUpdateRecheckInterval'\n | 'debugOps'\n> = {\n ...DefaultDriverKitOpsSettings,\n defaultTreeOptions: {\n pollingInterval: 350,\n stopPollingDelay: 2500,\n initialTreeLoadingTimeout: 100 * 60 * 60 * 1000, // disable timeout for loading project tree (100 hours)\n },\n debugOps: {\n dumpInitialTreeState: false,\n },\n devBlockUpdateRecheckInterval: 1000,\n projectRefreshInterval: 700,\n stagingRenderingRate: 5,\n};\n\nexport function DefaultMiddleLayerOpsPaths(\n workDir: string,\n): Pick<\n MiddleLayerOpsPaths,\n keyof ReturnType<typeof DefaultDriverKitOpsPaths> | 'frontendDownloadPath'\n > {\n return {\n ...DefaultDriverKitOpsPaths(workDir),\n frontendDownloadPath: path.join(workDir, 'frontend'),\n };\n}\n\nexport type MiddleLayerOpsConstructor = Omit<\n MiddleLayerOpsSettings,\n keyof typeof DefaultMiddleLayerOpsSettings\n> &\nPartial<typeof DefaultMiddleLayerOpsSettings> &\nOmit<MiddleLayerOpsPaths, keyof Awaited<ReturnType<typeof DefaultMiddleLayerOpsPaths>>> &\nPartial<Awaited<ReturnType<typeof DefaultMiddleLayerOpsPaths>>>;\n"],"names":["ConsoleLoggerAdapter"],"mappings":";;;;;AAqIA;AACO,MAAM,2BAA2B,GASpC;IACF,MAAM,EAAE,IAAIA,8BAAoB,EAAE;AAClC,IAAA,aAAa,EAAE;QACb,kBAAkB,EAAE,CAAC,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI;QAC1C,uBAAuB,EAAE,CAAC,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI;AAC/C,QAAA,oBAAoB,EAAE,EAAE;AACzB,KAAA;AACD,IAAA,yBAAyB,EAAE;QACzB,kBAAkB,EAAE,CAAC,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI;AAC1C,QAAA,UAAU,EAAE,IAAI;AAChB,QAAA,oBAAoB,EAAE,EAAE;AACzB,KAAA;AACD,IAAA,0BAA0B,EAAE;QAC1B,kBAAkB,EAAE,CAAC,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI;AAC1C,QAAA,oBAAoB,EAAE,EAAE;AACzB,KAAA;AACD,IAAA,eAAe,EAAE;AACf,QAAA,sBAAsB,EAAE,EAAE;AAC1B,QAAA,wBAAwB,EAAE,EAAE;AAC5B,QAAA,eAAe,EAAE,IAAI;AACrB,QAAA,gBAAgB,EAAE,IAAI;AACvB,KAAA;AACD,IAAA,kBAAkB,EAAE;AAClB,QAAA,kBAAkB,EAAE,EAAE;AACtB,QAAA,eAAe,EAAE,IAAI;AACrB,QAAA,gBAAgB,EAAE,IAAI;AACvB,KAAA;AACD,IAAA,eAAe,EAAE;QACf,iBAAiB,EAAE,CAAC;QACpB,iBAAiB,EAAE,CAAC;QACpB,iBAAiB,EAAE,CAAC;QACpB,mBAAmB,EAAE,EAAE;QACvB,mBAAmB,EAAE,CAAC,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI;QAC3C,mBAAmB,EAAE,EAAE,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI;AAC7C,KAAA;;AAGG,SAAU,wBAAwB,CACtC,OAAe,EAAA;IAMf,OAAO;QACL,gBAAgB,EAAE,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,UAAU,CAAC;QAChD,2BAA2B,EAAE,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,qBAAqB,CAAC;QACtE,qBAAqB,EAAE,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,eAAe,CAAC;QAC1D,gBAAgB,EAAE,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,SAAS,CAAC;KAChD;AACH;AA+CA;AACO,MAAM,6BAA6B,GAQtC;AACF,IAAA,GAAG,2BAA2B;AAC9B,IAAA,kBAAkB,EAAE;AAClB,QAAA,eAAe,EAAE,GAAG;AACpB,QAAA,gBAAgB,EAAE,IAAI;QACtB,yBAAyB,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI;AAChD,KAAA;AACD,IAAA,QAAQ,EAAE;AACR,QAAA,oBAAoB,EAAE,KAAK;AAC5B,KAAA;AACD,IAAA,6BAA6B,EAAE,IAAI;AACnC,IAAA,sBAAsB,EAAE,GAAG;AAC3B,IAAA,oBAAoB,EAAE,CAAC;;AAGnB,SAAU,0BAA0B,CACxC,OAAe,EAAA;IAKf,OAAO;QACL,GAAG,wBAAwB,CAAC,OAAO,CAAC;QACpC,oBAAoB,EAAE,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,UAAU,CAAC;KACrD;AACH;;;;;;;"}
|
|
1
|
+
{"version":3,"file":"ops.cjs","sources":["../../src/middle_layer/ops.ts"],"sourcesContent":["import type { TemporalSynchronizedTreeOps } from './types';\nimport type {\n DownloadBlobToURLDriverOps,\n DownloadDriverOps,\n DownloadUrlDriverOps,\n OpenFileDialogCallback,\n VirtualLocalStorageSpec,\n} from '@milaboratories/pl-drivers';\nimport type { UploadDriverOps } from '@milaboratories/pl-drivers';\nimport type { LogsStreamDriverOps } from '@milaboratories/pl-drivers';\nimport type { MiLogger } from '@milaboratories/ts-helpers';\nimport { ConsoleLoggerAdapter } from '@milaboratories/ts-helpers';\nimport type { LocalStorageProjection } from '@milaboratories/pl-drivers';\nimport path from 'node:path';\nimport { PFrameDriverOpsDefaults, type PFrameDriverOps } from '../pool';\n\n/** Paths part of {@link DriverKitOps}. */\nexport type DriverKitOpsPaths = {\n /** Common root where to put downloaded blobs / downloaded blob cache */\n readonly blobDownloadPath: string;\n\n /** Common root for a cache for range queries. */\n readonly blobDownloadRangesCachePath: string;\n\n /** Common root where to put downloaded blobs with */\n readonly downloadBlobToURLPath: string;\n\n /**\n * List of pl storages that have projections in local file system.\n *\n * This option affect two drivers:\n *\n * (1) LS driver generates \"index\" handles instead of \"upload\" for paths inside those locations\n *\n * (2) Download driver directly serves content retrieval requests for blobs from listed storages,\n * and don't apply any caching for such blobs (i.e. preventing duplication of files for Downloaded\n * type handles, making OnDemand and Downloaded handles equivalent)\n *\n * */\n readonly localProjections: LocalStorageProjection[];\n\n /**\n * List of virtual storages that will allow homogeneous access to local FSs through LS API.\n * If undefined, default list will be created.\n * */\n readonly virtualLocalStoragesOverride?: VirtualLocalStorageSpec[];\n\n /** Path to the directory where pframes will spill temporary files and store materialized views */\n readonly pframesSpillPath: string;\n};\n\n/** Options required to initialize full set of middle layer driver kit */\nexport type DriverKitOpsSettings = {\n //\n // Common\n //\n\n readonly logger: MiLogger;\n\n //\n // Signer\n //\n\n /**\n * Local secret, that is used to sign and verify different pieces of information\n * that can be used to access local data, like local paths for ongoing uploads.\n *\n * Use {@link MiddleLayer.generateLocalSecret} to generate sufficiently random string.\n * */\n readonly localSecret: string;\n\n //\n // Blob Driver\n //\n\n /**\n * Settings related to the download driver making operations with blobs. This driver is also used\n * to download logs when source process terminates and log terns into a blob\n */\n readonly blobDriverOps: DownloadDriverOps;\n\n //\n // Frontend Driver\n //\n\n /** Settings related to the frontend driver that downloads frontends. */\n readonly frontendDownloadDriverOps: DownloadUrlDriverOps;\n\n //\n // Blob To URL Driver\n //\n\n readonly downloadBlobToURLDriverOps: DownloadBlobToURLDriverOps;\n\n //\n // Upload Driver\n //\n\n /**\n * Settings related to the upload driver that actually performs upload and helps render upload\n * and indexing progresses from related pl resources.\n * */\n readonly uploadDriverOps: UploadDriverOps;\n\n //\n // Log streaming ops\n // (static logs are served via the blob driver)\n //\n\n /** Settings related to the streaming log driver */\n readonly logStreamDriverOps: LogsStreamDriverOps;\n\n //\n // LS Driver\n //\n\n /**\n * Callback to access system file open dialog, must be provided by the environment,\n * to allow for {@link showOpenSingleFileDialog} / {@link showOpenMultipleFilesDialog}\n * calls from the UI.\n */\n readonly openFileDialogCallback: OpenFileDialogCallback;\n\n //\n // PFrame Driver\n //\n\n /** Settings related to the PFrame driver */\n readonly pFrameDriverOps: PFrameDriverOps;\n};\n\nexport type DriverKitOps = DriverKitOpsPaths & DriverKitOpsSettings;\n\n/** Some defaults fot MiddleLayerOps. */\nexport const DefaultDriverKitOpsSettings: Pick<\n DriverKitOpsSettings,\n | 'logger'\n | 'blobDriverOps'\n | 'frontendDownloadDriverOps'\n | 'downloadBlobToURLDriverOps'\n | 'uploadDriverOps'\n | 'logStreamDriverOps'\n | 'pFrameDriverOps'\n> = {\n logger: new ConsoleLoggerAdapter(),\n blobDriverOps: {\n cacheSoftSizeBytes: 8 * 1024 * 1024 * 1024, // 8 GB\n rangesCacheMaxSizeBytes: 8 * 1024 * 1024 * 1024, // 8 GB\n nConcurrentDownloads: 10,\n },\n frontendDownloadDriverOps: {\n cacheSoftSizeBytes: 1 * 1024 * 1024 * 1024, // 1 GB\n withGunzip: true,\n nConcurrentDownloads: 50,\n },\n downloadBlobToURLDriverOps: {\n cacheSoftSizeBytes: 1 * 1024 * 1024 * 1024, // 1 GB\n nConcurrentDownloads: 10,\n },\n uploadDriverOps: {\n nConcurrentPartUploads: 10,\n nConcurrentGetProgresses: 10,\n pollingInterval: 1000,\n stopPollingDelay: 1000,\n },\n logStreamDriverOps: {\n nConcurrentGetLogs: 10,\n pollingInterval: 1000,\n stopPollingDelay: 1000,\n },\n pFrameDriverOps: PFrameDriverOpsDefaults,\n};\n\nexport function DefaultDriverKitOpsPaths(\n workDir: string,\n): Pick<DriverKitOpsPaths,\n| 'blobDownloadPath'\n| 'blobDownloadRangesCachePath'\n| 'downloadBlobToURLPath'\n| 'pframesSpillPath'> {\n return {\n blobDownloadPath: path.join(workDir, 'download'),\n blobDownloadRangesCachePath: path.join(workDir, 'downloadRangesCache'),\n downloadBlobToURLPath: path.join(workDir, 'downloadToURL'),\n pframesSpillPath: path.join(workDir, 'pframes'),\n };\n}\n\n/** Fields with default values are marked as optional here. */\n// prettier-ignore\nexport type DriverKitOpsConstructor =\n Omit<DriverKitOpsSettings, keyof typeof DefaultDriverKitOpsSettings>\n & Partial<typeof DefaultDriverKitOpsSettings>\n & Omit<DriverKitOpsPaths, keyof ReturnType<typeof DefaultDriverKitOpsPaths>>\n & Partial<ReturnType<typeof DefaultDriverKitOpsPaths>>;\n\nexport type MiddleLayerOpsPaths = DriverKitOpsPaths & {\n /** Common root where to put frontend code. */\n readonly frontendDownloadPath: string;\n};\n\n/** Debug options for middle layer. */\nexport type MiddleLayerDebugOptions = {\n /** If true, will dump initial tree state to the file with root resource id as name. */\n dumpInitialTreeState: boolean;\n};\n\n/** Configuration controlling different aspects of middle layer behaviour. */\nexport type MiddleLayerOpsSettings = DriverKitOpsSettings & {\n /** Debug options. */\n readonly debugOps: MiddleLayerDebugOptions;\n\n /** Contain temporal options controlling how often should pl trees be\n * synchronized with the pl server. */\n readonly defaultTreeOptions: TemporalSynchronizedTreeOps;\n\n /** Defines interval in milliseconds for running periodic project maintenance job.\n * Project maintenance includes gradual staging rendering and cached outputs cleanup. */\n readonly projectRefreshInterval: number;\n\n /** This controls average number of block staging states that are rendered per\n * second during project maintenance job execution. */\n readonly stagingRenderingRate: number;\n\n /** How often to check for dev block updates */\n readonly devBlockUpdateRecheckInterval: number;\n\n /** Prioritize this channel if update is available in this block */\n readonly preferredUpdateChannel?: string;\n};\n\nexport type MiddleLayerOps = MiddleLayerOpsSettings & MiddleLayerOpsPaths;\n\n/** Some defaults fot MiddleLayerOps. */\nexport const DefaultMiddleLayerOpsSettings: Pick<\n MiddleLayerOps,\n | keyof typeof DefaultDriverKitOpsSettings\n | 'defaultTreeOptions'\n | 'projectRefreshInterval'\n | 'stagingRenderingRate'\n | 'devBlockUpdateRecheckInterval'\n | 'debugOps'\n> = {\n ...DefaultDriverKitOpsSettings,\n defaultTreeOptions: {\n pollingInterval: 350,\n stopPollingDelay: 2500,\n initialTreeLoadingTimeout: 100 * 60 * 60 * 1000, // disable timeout for loading project tree (100 hours)\n },\n debugOps: {\n dumpInitialTreeState: false,\n },\n devBlockUpdateRecheckInterval: 1000,\n projectRefreshInterval: 700,\n stagingRenderingRate: 5,\n};\n\nexport function DefaultMiddleLayerOpsPaths(\n workDir: string,\n): Pick<\n MiddleLayerOpsPaths,\n keyof ReturnType<typeof DefaultDriverKitOpsPaths> | 'frontendDownloadPath'\n > {\n return {\n ...DefaultDriverKitOpsPaths(workDir),\n frontendDownloadPath: path.join(workDir, 'frontend'),\n };\n}\n\nexport type MiddleLayerOpsConstructor = Omit<\n MiddleLayerOpsSettings,\n keyof typeof DefaultMiddleLayerOpsSettings\n> &\nPartial<typeof DefaultMiddleLayerOpsSettings> &\nOmit<MiddleLayerOpsPaths, keyof Awaited<ReturnType<typeof DefaultMiddleLayerOpsPaths>>> &\nPartial<Awaited<ReturnType<typeof DefaultMiddleLayerOpsPaths>>>;\n"],"names":["ConsoleLoggerAdapter","PFrameDriverOpsDefaults"],"mappings":";;;;;;;;AAqIA;AACO,MAAM,2BAA2B,GASpC;IACF,MAAM,EAAE,IAAIA,8BAAoB,EAAE;AAClC,IAAA,aAAa,EAAE;QACb,kBAAkB,EAAE,CAAC,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI;QAC1C,uBAAuB,EAAE,CAAC,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI;AAC/C,QAAA,oBAAoB,EAAE,EAAE;AACzB,KAAA;AACD,IAAA,yBAAyB,EAAE;QACzB,kBAAkB,EAAE,CAAC,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI;AAC1C,QAAA,UAAU,EAAE,IAAI;AAChB,QAAA,oBAAoB,EAAE,EAAE;AACzB,KAAA;AACD,IAAA,0BAA0B,EAAE;QAC1B,kBAAkB,EAAE,CAAC,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI;AAC1C,QAAA,oBAAoB,EAAE,EAAE;AACzB,KAAA;AACD,IAAA,eAAe,EAAE;AACf,QAAA,sBAAsB,EAAE,EAAE;AAC1B,QAAA,wBAAwB,EAAE,EAAE;AAC5B,QAAA,eAAe,EAAE,IAAI;AACrB,QAAA,gBAAgB,EAAE,IAAI;AACvB,KAAA;AACD,IAAA,kBAAkB,EAAE;AAClB,QAAA,kBAAkB,EAAE,EAAE;AACtB,QAAA,eAAe,EAAE,IAAI;AACrB,QAAA,gBAAgB,EAAE,IAAI;AACvB,KAAA;AACD,IAAA,eAAe,EAAEC,8BAAuB;;AAGpC,SAAU,wBAAwB,CACtC,OAAe,EAAA;IAMf,OAAO;QACL,gBAAgB,EAAE,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,UAAU,CAAC;QAChD,2BAA2B,EAAE,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,qBAAqB,CAAC;QACtE,qBAAqB,EAAE,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,eAAe,CAAC;QAC1D,gBAAgB,EAAE,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,SAAS,CAAC;KAChD;AACH;AA+CA;AACO,MAAM,6BAA6B,GAQtC;AACF,IAAA,GAAG,2BAA2B;AAC9B,IAAA,kBAAkB,EAAE;AAClB,QAAA,eAAe,EAAE,GAAG;AACpB,QAAA,gBAAgB,EAAE,IAAI;QACtB,yBAAyB,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI;AAChD,KAAA;AACD,IAAA,QAAQ,EAAE;AACR,QAAA,oBAAoB,EAAE,KAAK;AAC5B,KAAA;AACD,IAAA,6BAA6B,EAAE,IAAI;AACnC,IAAA,sBAAsB,EAAE,GAAG;AAC3B,IAAA,oBAAoB,EAAE,CAAC;;AAGnB,SAAU,0BAA0B,CACxC,OAAe,EAAA;IAKf,OAAO;QACL,GAAG,wBAAwB,CAAC,OAAO,CAAC;QACpC,oBAAoB,EAAE,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,UAAU,CAAC;KACrD;AACH;;;;;;;"}
|
|
@@ -4,7 +4,7 @@ import type { UploadDriverOps } from '@milaboratories/pl-drivers';
|
|
|
4
4
|
import type { LogsStreamDriverOps } from '@milaboratories/pl-drivers';
|
|
5
5
|
import type { MiLogger } from '@milaboratories/ts-helpers';
|
|
6
6
|
import type { LocalStorageProjection } from '@milaboratories/pl-drivers';
|
|
7
|
-
import type
|
|
7
|
+
import { type PFrameDriverOps } from '../pool';
|
|
8
8
|
/** Paths part of {@link DriverKitOps}. */
|
|
9
9
|
export type DriverKitOpsPaths = {
|
|
10
10
|
/** Common root where to put downloaded blobs / downloaded blob cache */
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ops.d.ts","sourceRoot":"","sources":["../../src/middle_layer/ops.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,SAAS,CAAC;AAC3D,OAAO,KAAK,EACV,0BAA0B,EAC1B,iBAAiB,EACjB,oBAAoB,EACpB,sBAAsB,EACtB,uBAAuB,EACxB,MAAM,4BAA4B,CAAC;AACpC,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAClE,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,4BAA4B,CAAC;AACtE,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAC;AAE3D,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAC;AAEzE,OAAO,KAAK,
|
|
1
|
+
{"version":3,"file":"ops.d.ts","sourceRoot":"","sources":["../../src/middle_layer/ops.ts"],"names":[],"mappings":"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"}
|
package/dist/middle_layer/ops.js
CHANGED
|
@@ -1,5 +1,8 @@
|
|
|
1
1
|
import { ConsoleLoggerAdapter } from '@milaboratories/ts-helpers';
|
|
2
2
|
import path from 'node:path';
|
|
3
|
+
import { PFrameDriverOpsDefaults } from '../pool/driver.js';
|
|
4
|
+
import '@platforma-sdk/model';
|
|
5
|
+
import '../pool/data.js';
|
|
3
6
|
|
|
4
7
|
/** Some defaults fot MiddleLayerOps. */
|
|
5
8
|
const DefaultDriverKitOpsSettings = {
|
|
@@ -29,14 +32,7 @@ const DefaultDriverKitOpsSettings = {
|
|
|
29
32
|
pollingInterval: 1000,
|
|
30
33
|
stopPollingDelay: 1000,
|
|
31
34
|
},
|
|
32
|
-
pFrameDriverOps:
|
|
33
|
-
parquetServerPort: 0, // 0 means that some unused port will be assigned by the OS
|
|
34
|
-
pFrameConcurrency: 1, // 1 join is executed in parallel and utilize all RAM and CPU cores
|
|
35
|
-
pTableConcurrency: 1, // 1 joined table is read from disk at a time, which matches 1 table the user can view in the UI
|
|
36
|
-
pFrameCacheMaxCount: 18, // SHM trees create 3 PTables per graphic, we want to cache 6 graphics per PFrame
|
|
37
|
-
pFramesCacheMaxSize: 8 * 1024 * 1024 * 1024, // 8 GB, same as blob driver cache (must be at lease 2GB)
|
|
38
|
-
pTablesCacheMaxSize: 32 * 1024 * 1024 * 1024, // 32 GB (must be at lease 8GB)
|
|
39
|
-
},
|
|
35
|
+
pFrameDriverOps: PFrameDriverOpsDefaults,
|
|
40
36
|
};
|
|
41
37
|
function DefaultDriverKitOpsPaths(workDir) {
|
|
42
38
|
return {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ops.js","sources":["../../src/middle_layer/ops.ts"],"sourcesContent":["import type { TemporalSynchronizedTreeOps } from './types';\nimport type {\n DownloadBlobToURLDriverOps,\n DownloadDriverOps,\n DownloadUrlDriverOps,\n OpenFileDialogCallback,\n VirtualLocalStorageSpec,\n} from '@milaboratories/pl-drivers';\nimport type { UploadDriverOps } from '@milaboratories/pl-drivers';\nimport type { LogsStreamDriverOps } from '@milaboratories/pl-drivers';\nimport type { MiLogger } from '@milaboratories/ts-helpers';\nimport { ConsoleLoggerAdapter } from '@milaboratories/ts-helpers';\nimport type { LocalStorageProjection } from '@milaboratories/pl-drivers';\nimport path from 'node:path';\nimport type { PFrameDriverOps } from '../pool/driver';\n\n/** Paths part of {@link DriverKitOps}. */\nexport type DriverKitOpsPaths = {\n /** Common root where to put downloaded blobs / downloaded blob cache */\n readonly blobDownloadPath: string;\n\n /** Common root for a cache for range queries. */\n readonly blobDownloadRangesCachePath: string;\n\n /** Common root where to put downloaded blobs with */\n readonly downloadBlobToURLPath: string;\n\n /**\n * List of pl storages that have projections in local file system.\n *\n * This option affect two drivers:\n *\n * (1) LS driver generates \"index\" handles instead of \"upload\" for paths inside those locations\n *\n * (2) Download driver directly serves content retrieval requests for blobs from listed storages,\n * and don't apply any caching for such blobs (i.e. preventing duplication of files for Downloaded\n * type handles, making OnDemand and Downloaded handles equivalent)\n *\n * */\n readonly localProjections: LocalStorageProjection[];\n\n /**\n * List of virtual storages that will allow homogeneous access to local FSs through LS API.\n * If undefined, default list will be created.\n * */\n readonly virtualLocalStoragesOverride?: VirtualLocalStorageSpec[];\n\n /** Path to the directory where pframes will spill temporary files and store materialized views */\n readonly pframesSpillPath: string;\n};\n\n/** Options required to initialize full set of middle layer driver kit */\nexport type DriverKitOpsSettings = {\n //\n // Common\n //\n\n readonly logger: MiLogger;\n\n //\n // Signer\n //\n\n /**\n * Local secret, that is used to sign and verify different pieces of information\n * that can be used to access local data, like local paths for ongoing uploads.\n *\n * Use {@link MiddleLayer.generateLocalSecret} to generate sufficiently random string.\n * */\n readonly localSecret: string;\n\n //\n // Blob Driver\n //\n\n /**\n * Settings related to the download driver making operations with blobs. This driver is also used\n * to download logs when source process terminates and log terns into a blob\n */\n readonly blobDriverOps: DownloadDriverOps;\n\n //\n // Frontend Driver\n //\n\n /** Settings related to the frontend driver that downloads frontends. */\n readonly frontendDownloadDriverOps: DownloadUrlDriverOps;\n\n //\n // Blob To URL Driver\n //\n\n readonly downloadBlobToURLDriverOps: DownloadBlobToURLDriverOps;\n\n //\n // Upload Driver\n //\n\n /**\n * Settings related to the upload driver that actually performs upload and helps render upload\n * and indexing progresses from related pl resources.\n * */\n readonly uploadDriverOps: UploadDriverOps;\n\n //\n // Log streaming ops\n // (static logs are served via the blob driver)\n //\n\n /** Settings related to the streaming log driver */\n readonly logStreamDriverOps: LogsStreamDriverOps;\n\n //\n // LS Driver\n //\n\n /**\n * Callback to access system file open dialog, must be provided by the environment,\n * to allow for {@link showOpenSingleFileDialog} / {@link showOpenMultipleFilesDialog}\n * calls from the UI.\n */\n readonly openFileDialogCallback: OpenFileDialogCallback;\n\n //\n // PFrame Driver\n //\n\n /** Settings related to the PFrame driver */\n readonly pFrameDriverOps: PFrameDriverOps;\n};\n\nexport type DriverKitOps = DriverKitOpsPaths & DriverKitOpsSettings;\n\n/** Some defaults fot MiddleLayerOps. */\nexport const DefaultDriverKitOpsSettings: Pick<\n DriverKitOpsSettings,\n | 'logger'\n | 'blobDriverOps'\n | 'frontendDownloadDriverOps'\n | 'downloadBlobToURLDriverOps'\n | 'uploadDriverOps'\n | 'logStreamDriverOps'\n | 'pFrameDriverOps'\n> = {\n logger: new ConsoleLoggerAdapter(),\n blobDriverOps: {\n cacheSoftSizeBytes: 8 * 1024 * 1024 * 1024, // 8 GB\n rangesCacheMaxSizeBytes: 8 * 1024 * 1024 * 1024, // 8 GB\n nConcurrentDownloads: 10,\n },\n frontendDownloadDriverOps: {\n cacheSoftSizeBytes: 1 * 1024 * 1024 * 1024, // 1 GB\n withGunzip: true,\n nConcurrentDownloads: 50,\n },\n downloadBlobToURLDriverOps: {\n cacheSoftSizeBytes: 1 * 1024 * 1024 * 1024, // 1 GB\n nConcurrentDownloads: 10,\n },\n uploadDriverOps: {\n nConcurrentPartUploads: 10,\n nConcurrentGetProgresses: 10,\n pollingInterval: 1000,\n stopPollingDelay: 1000,\n },\n logStreamDriverOps: {\n nConcurrentGetLogs: 10,\n pollingInterval: 1000,\n stopPollingDelay: 1000,\n },\n pFrameDriverOps: {\n parquetServerPort: 0, // 0 means that some unused port will be assigned by the OS\n pFrameConcurrency: 1, // 1 join is executed in parallel and utilize all RAM and CPU cores\n pTableConcurrency: 1, // 1 joined table is read from disk at a time, which matches 1 table the user can view in the UI\n pFrameCacheMaxCount: 18, // SHM trees create 3 PTables per graphic, we want to cache 6 graphics per PFrame\n pFramesCacheMaxSize: 8 * 1024 * 1024 * 1024, // 8 GB, same as blob driver cache (must be at lease 2GB)\n pTablesCacheMaxSize: 32 * 1024 * 1024 * 1024, // 32 GB (must be at lease 8GB)\n },\n};\n\nexport function DefaultDriverKitOpsPaths(\n workDir: string,\n): Pick<DriverKitOpsPaths,\n| 'blobDownloadPath'\n| 'blobDownloadRangesCachePath'\n| 'downloadBlobToURLPath'\n| 'pframesSpillPath'> {\n return {\n blobDownloadPath: path.join(workDir, 'download'),\n blobDownloadRangesCachePath: path.join(workDir, 'downloadRangesCache'),\n downloadBlobToURLPath: path.join(workDir, 'downloadToURL'),\n pframesSpillPath: path.join(workDir, 'pframes'),\n };\n}\n\n/** Fields with default values are marked as optional here. */\n// prettier-ignore\nexport type DriverKitOpsConstructor =\n Omit<DriverKitOpsSettings, keyof typeof DefaultDriverKitOpsSettings>\n & Partial<typeof DefaultDriverKitOpsSettings>\n & Omit<DriverKitOpsPaths, keyof ReturnType<typeof DefaultDriverKitOpsPaths>>\n & Partial<ReturnType<typeof DefaultDriverKitOpsPaths>>;\n\nexport type MiddleLayerOpsPaths = DriverKitOpsPaths & {\n /** Common root where to put frontend code. */\n readonly frontendDownloadPath: string;\n};\n\n/** Debug options for middle layer. */\nexport type MiddleLayerDebugOptions = {\n /** If true, will dump initial tree state to the file with root resource id as name. */\n dumpInitialTreeState: boolean;\n};\n\n/** Configuration controlling different aspects of middle layer behaviour. */\nexport type MiddleLayerOpsSettings = DriverKitOpsSettings & {\n /** Debug options. */\n readonly debugOps: MiddleLayerDebugOptions;\n\n /** Contain temporal options controlling how often should pl trees be\n * synchronized with the pl server. */\n readonly defaultTreeOptions: TemporalSynchronizedTreeOps;\n\n /** Defines interval in milliseconds for running periodic project maintenance job.\n * Project maintenance includes gradual staging rendering and cached outputs cleanup. */\n readonly projectRefreshInterval: number;\n\n /** This controls average number of block staging states that are rendered per\n * second during project maintenance job execution. */\n readonly stagingRenderingRate: number;\n\n /** How often to check for dev block updates */\n readonly devBlockUpdateRecheckInterval: number;\n\n /** Prioritize this channel if update is available in this block */\n readonly preferredUpdateChannel?: string;\n};\n\nexport type MiddleLayerOps = MiddleLayerOpsSettings & MiddleLayerOpsPaths;\n\n/** Some defaults fot MiddleLayerOps. */\nexport const DefaultMiddleLayerOpsSettings: Pick<\n MiddleLayerOps,\n | keyof typeof DefaultDriverKitOpsSettings\n | 'defaultTreeOptions'\n | 'projectRefreshInterval'\n | 'stagingRenderingRate'\n | 'devBlockUpdateRecheckInterval'\n | 'debugOps'\n> = {\n ...DefaultDriverKitOpsSettings,\n defaultTreeOptions: {\n pollingInterval: 350,\n stopPollingDelay: 2500,\n initialTreeLoadingTimeout: 100 * 60 * 60 * 1000, // disable timeout for loading project tree (100 hours)\n },\n debugOps: {\n dumpInitialTreeState: false,\n },\n devBlockUpdateRecheckInterval: 1000,\n projectRefreshInterval: 700,\n stagingRenderingRate: 5,\n};\n\nexport function DefaultMiddleLayerOpsPaths(\n workDir: string,\n): Pick<\n MiddleLayerOpsPaths,\n keyof ReturnType<typeof DefaultDriverKitOpsPaths> | 'frontendDownloadPath'\n > {\n return {\n ...DefaultDriverKitOpsPaths(workDir),\n frontendDownloadPath: path.join(workDir, 'frontend'),\n };\n}\n\nexport type MiddleLayerOpsConstructor = Omit<\n MiddleLayerOpsSettings,\n keyof typeof DefaultMiddleLayerOpsSettings\n> &\nPartial<typeof DefaultMiddleLayerOpsSettings> &\nOmit<MiddleLayerOpsPaths, keyof Awaited<ReturnType<typeof DefaultMiddleLayerOpsPaths>>> &\nPartial<Awaited<ReturnType<typeof DefaultMiddleLayerOpsPaths>>>;\n"],"names":[],"mappings":";;;AAqIA;AACO,MAAM,2BAA2B,GASpC;IACF,MAAM,EAAE,IAAI,oBAAoB,EAAE;AAClC,IAAA,aAAa,EAAE;QACb,kBAAkB,EAAE,CAAC,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI;QAC1C,uBAAuB,EAAE,CAAC,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI;AAC/C,QAAA,oBAAoB,EAAE,EAAE;AACzB,KAAA;AACD,IAAA,yBAAyB,EAAE;QACzB,kBAAkB,EAAE,CAAC,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI;AAC1C,QAAA,UAAU,EAAE,IAAI;AAChB,QAAA,oBAAoB,EAAE,EAAE;AACzB,KAAA;AACD,IAAA,0BAA0B,EAAE;QAC1B,kBAAkB,EAAE,CAAC,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI;AAC1C,QAAA,oBAAoB,EAAE,EAAE;AACzB,KAAA;AACD,IAAA,eAAe,EAAE;AACf,QAAA,sBAAsB,EAAE,EAAE;AAC1B,QAAA,wBAAwB,EAAE,EAAE;AAC5B,QAAA,eAAe,EAAE,IAAI;AACrB,QAAA,gBAAgB,EAAE,IAAI;AACvB,KAAA;AACD,IAAA,kBAAkB,EAAE;AAClB,QAAA,kBAAkB,EAAE,EAAE;AACtB,QAAA,eAAe,EAAE,IAAI;AACrB,QAAA,gBAAgB,EAAE,IAAI;AACvB,KAAA;AACD,IAAA,eAAe,EAAE;QACf,iBAAiB,EAAE,CAAC;QACpB,iBAAiB,EAAE,CAAC;QACpB,iBAAiB,EAAE,CAAC;QACpB,mBAAmB,EAAE,EAAE;QACvB,mBAAmB,EAAE,CAAC,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI;QAC3C,mBAAmB,EAAE,EAAE,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI;AAC7C,KAAA;;AAGG,SAAU,wBAAwB,CACtC,OAAe,EAAA;IAMf,OAAO;QACL,gBAAgB,EAAE,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,UAAU,CAAC;QAChD,2BAA2B,EAAE,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,qBAAqB,CAAC;QACtE,qBAAqB,EAAE,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,eAAe,CAAC;QAC1D,gBAAgB,EAAE,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,SAAS,CAAC;KAChD;AACH;AA+CA;AACO,MAAM,6BAA6B,GAQtC;AACF,IAAA,GAAG,2BAA2B;AAC9B,IAAA,kBAAkB,EAAE;AAClB,QAAA,eAAe,EAAE,GAAG;AACpB,QAAA,gBAAgB,EAAE,IAAI;QACtB,yBAAyB,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI;AAChD,KAAA;AACD,IAAA,QAAQ,EAAE;AACR,QAAA,oBAAoB,EAAE,KAAK;AAC5B,KAAA;AACD,IAAA,6BAA6B,EAAE,IAAI;AACnC,IAAA,sBAAsB,EAAE,GAAG;AAC3B,IAAA,oBAAoB,EAAE,CAAC;;AAGnB,SAAU,0BAA0B,CACxC,OAAe,EAAA;IAKf,OAAO;QACL,GAAG,wBAAwB,CAAC,OAAO,CAAC;QACpC,oBAAoB,EAAE,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,UAAU,CAAC;KACrD;AACH;;;;"}
|
|
1
|
+
{"version":3,"file":"ops.js","sources":["../../src/middle_layer/ops.ts"],"sourcesContent":["import type { TemporalSynchronizedTreeOps } from './types';\nimport type {\n DownloadBlobToURLDriverOps,\n DownloadDriverOps,\n DownloadUrlDriverOps,\n OpenFileDialogCallback,\n VirtualLocalStorageSpec,\n} from '@milaboratories/pl-drivers';\nimport type { UploadDriverOps } from '@milaboratories/pl-drivers';\nimport type { LogsStreamDriverOps } from '@milaboratories/pl-drivers';\nimport type { MiLogger } from '@milaboratories/ts-helpers';\nimport { ConsoleLoggerAdapter } from '@milaboratories/ts-helpers';\nimport type { LocalStorageProjection } from '@milaboratories/pl-drivers';\nimport path from 'node:path';\nimport { PFrameDriverOpsDefaults, type PFrameDriverOps } from '../pool';\n\n/** Paths part of {@link DriverKitOps}. */\nexport type DriverKitOpsPaths = {\n /** Common root where to put downloaded blobs / downloaded blob cache */\n readonly blobDownloadPath: string;\n\n /** Common root for a cache for range queries. */\n readonly blobDownloadRangesCachePath: string;\n\n /** Common root where to put downloaded blobs with */\n readonly downloadBlobToURLPath: string;\n\n /**\n * List of pl storages that have projections in local file system.\n *\n * This option affect two drivers:\n *\n * (1) LS driver generates \"index\" handles instead of \"upload\" for paths inside those locations\n *\n * (2) Download driver directly serves content retrieval requests for blobs from listed storages,\n * and don't apply any caching for such blobs (i.e. preventing duplication of files for Downloaded\n * type handles, making OnDemand and Downloaded handles equivalent)\n *\n * */\n readonly localProjections: LocalStorageProjection[];\n\n /**\n * List of virtual storages that will allow homogeneous access to local FSs through LS API.\n * If undefined, default list will be created.\n * */\n readonly virtualLocalStoragesOverride?: VirtualLocalStorageSpec[];\n\n /** Path to the directory where pframes will spill temporary files and store materialized views */\n readonly pframesSpillPath: string;\n};\n\n/** Options required to initialize full set of middle layer driver kit */\nexport type DriverKitOpsSettings = {\n //\n // Common\n //\n\n readonly logger: MiLogger;\n\n //\n // Signer\n //\n\n /**\n * Local secret, that is used to sign and verify different pieces of information\n * that can be used to access local data, like local paths for ongoing uploads.\n *\n * Use {@link MiddleLayer.generateLocalSecret} to generate sufficiently random string.\n * */\n readonly localSecret: string;\n\n //\n // Blob Driver\n //\n\n /**\n * Settings related to the download driver making operations with blobs. This driver is also used\n * to download logs when source process terminates and log terns into a blob\n */\n readonly blobDriverOps: DownloadDriverOps;\n\n //\n // Frontend Driver\n //\n\n /** Settings related to the frontend driver that downloads frontends. */\n readonly frontendDownloadDriverOps: DownloadUrlDriverOps;\n\n //\n // Blob To URL Driver\n //\n\n readonly downloadBlobToURLDriverOps: DownloadBlobToURLDriverOps;\n\n //\n // Upload Driver\n //\n\n /**\n * Settings related to the upload driver that actually performs upload and helps render upload\n * and indexing progresses from related pl resources.\n * */\n readonly uploadDriverOps: UploadDriverOps;\n\n //\n // Log streaming ops\n // (static logs are served via the blob driver)\n //\n\n /** Settings related to the streaming log driver */\n readonly logStreamDriverOps: LogsStreamDriverOps;\n\n //\n // LS Driver\n //\n\n /**\n * Callback to access system file open dialog, must be provided by the environment,\n * to allow for {@link showOpenSingleFileDialog} / {@link showOpenMultipleFilesDialog}\n * calls from the UI.\n */\n readonly openFileDialogCallback: OpenFileDialogCallback;\n\n //\n // PFrame Driver\n //\n\n /** Settings related to the PFrame driver */\n readonly pFrameDriverOps: PFrameDriverOps;\n};\n\nexport type DriverKitOps = DriverKitOpsPaths & DriverKitOpsSettings;\n\n/** Some defaults fot MiddleLayerOps. */\nexport const DefaultDriverKitOpsSettings: Pick<\n DriverKitOpsSettings,\n | 'logger'\n | 'blobDriverOps'\n | 'frontendDownloadDriverOps'\n | 'downloadBlobToURLDriverOps'\n | 'uploadDriverOps'\n | 'logStreamDriverOps'\n | 'pFrameDriverOps'\n> = {\n logger: new ConsoleLoggerAdapter(),\n blobDriverOps: {\n cacheSoftSizeBytes: 8 * 1024 * 1024 * 1024, // 8 GB\n rangesCacheMaxSizeBytes: 8 * 1024 * 1024 * 1024, // 8 GB\n nConcurrentDownloads: 10,\n },\n frontendDownloadDriverOps: {\n cacheSoftSizeBytes: 1 * 1024 * 1024 * 1024, // 1 GB\n withGunzip: true,\n nConcurrentDownloads: 50,\n },\n downloadBlobToURLDriverOps: {\n cacheSoftSizeBytes: 1 * 1024 * 1024 * 1024, // 1 GB\n nConcurrentDownloads: 10,\n },\n uploadDriverOps: {\n nConcurrentPartUploads: 10,\n nConcurrentGetProgresses: 10,\n pollingInterval: 1000,\n stopPollingDelay: 1000,\n },\n logStreamDriverOps: {\n nConcurrentGetLogs: 10,\n pollingInterval: 1000,\n stopPollingDelay: 1000,\n },\n pFrameDriverOps: PFrameDriverOpsDefaults,\n};\n\nexport function DefaultDriverKitOpsPaths(\n workDir: string,\n): Pick<DriverKitOpsPaths,\n| 'blobDownloadPath'\n| 'blobDownloadRangesCachePath'\n| 'downloadBlobToURLPath'\n| 'pframesSpillPath'> {\n return {\n blobDownloadPath: path.join(workDir, 'download'),\n blobDownloadRangesCachePath: path.join(workDir, 'downloadRangesCache'),\n downloadBlobToURLPath: path.join(workDir, 'downloadToURL'),\n pframesSpillPath: path.join(workDir, 'pframes'),\n };\n}\n\n/** Fields with default values are marked as optional here. */\n// prettier-ignore\nexport type DriverKitOpsConstructor =\n Omit<DriverKitOpsSettings, keyof typeof DefaultDriverKitOpsSettings>\n & Partial<typeof DefaultDriverKitOpsSettings>\n & Omit<DriverKitOpsPaths, keyof ReturnType<typeof DefaultDriverKitOpsPaths>>\n & Partial<ReturnType<typeof DefaultDriverKitOpsPaths>>;\n\nexport type MiddleLayerOpsPaths = DriverKitOpsPaths & {\n /** Common root where to put frontend code. */\n readonly frontendDownloadPath: string;\n};\n\n/** Debug options for middle layer. */\nexport type MiddleLayerDebugOptions = {\n /** If true, will dump initial tree state to the file with root resource id as name. */\n dumpInitialTreeState: boolean;\n};\n\n/** Configuration controlling different aspects of middle layer behaviour. */\nexport type MiddleLayerOpsSettings = DriverKitOpsSettings & {\n /** Debug options. */\n readonly debugOps: MiddleLayerDebugOptions;\n\n /** Contain temporal options controlling how often should pl trees be\n * synchronized with the pl server. */\n readonly defaultTreeOptions: TemporalSynchronizedTreeOps;\n\n /** Defines interval in milliseconds for running periodic project maintenance job.\n * Project maintenance includes gradual staging rendering and cached outputs cleanup. */\n readonly projectRefreshInterval: number;\n\n /** This controls average number of block staging states that are rendered per\n * second during project maintenance job execution. */\n readonly stagingRenderingRate: number;\n\n /** How often to check for dev block updates */\n readonly devBlockUpdateRecheckInterval: number;\n\n /** Prioritize this channel if update is available in this block */\n readonly preferredUpdateChannel?: string;\n};\n\nexport type MiddleLayerOps = MiddleLayerOpsSettings & MiddleLayerOpsPaths;\n\n/** Some defaults fot MiddleLayerOps. */\nexport const DefaultMiddleLayerOpsSettings: Pick<\n MiddleLayerOps,\n | keyof typeof DefaultDriverKitOpsSettings\n | 'defaultTreeOptions'\n | 'projectRefreshInterval'\n | 'stagingRenderingRate'\n | 'devBlockUpdateRecheckInterval'\n | 'debugOps'\n> = {\n ...DefaultDriverKitOpsSettings,\n defaultTreeOptions: {\n pollingInterval: 350,\n stopPollingDelay: 2500,\n initialTreeLoadingTimeout: 100 * 60 * 60 * 1000, // disable timeout for loading project tree (100 hours)\n },\n debugOps: {\n dumpInitialTreeState: false,\n },\n devBlockUpdateRecheckInterval: 1000,\n projectRefreshInterval: 700,\n stagingRenderingRate: 5,\n};\n\nexport function DefaultMiddleLayerOpsPaths(\n workDir: string,\n): Pick<\n MiddleLayerOpsPaths,\n keyof ReturnType<typeof DefaultDriverKitOpsPaths> | 'frontendDownloadPath'\n > {\n return {\n ...DefaultDriverKitOpsPaths(workDir),\n frontendDownloadPath: path.join(workDir, 'frontend'),\n };\n}\n\nexport type MiddleLayerOpsConstructor = Omit<\n MiddleLayerOpsSettings,\n keyof typeof DefaultMiddleLayerOpsSettings\n> &\nPartial<typeof DefaultMiddleLayerOpsSettings> &\nOmit<MiddleLayerOpsPaths, keyof Awaited<ReturnType<typeof DefaultMiddleLayerOpsPaths>>> &\nPartial<Awaited<ReturnType<typeof DefaultMiddleLayerOpsPaths>>>;\n"],"names":[],"mappings":";;;;;;AAqIA;AACO,MAAM,2BAA2B,GASpC;IACF,MAAM,EAAE,IAAI,oBAAoB,EAAE;AAClC,IAAA,aAAa,EAAE;QACb,kBAAkB,EAAE,CAAC,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI;QAC1C,uBAAuB,EAAE,CAAC,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI;AAC/C,QAAA,oBAAoB,EAAE,EAAE;AACzB,KAAA;AACD,IAAA,yBAAyB,EAAE;QACzB,kBAAkB,EAAE,CAAC,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI;AAC1C,QAAA,UAAU,EAAE,IAAI;AAChB,QAAA,oBAAoB,EAAE,EAAE;AACzB,KAAA;AACD,IAAA,0BAA0B,EAAE;QAC1B,kBAAkB,EAAE,CAAC,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI;AAC1C,QAAA,oBAAoB,EAAE,EAAE;AACzB,KAAA;AACD,IAAA,eAAe,EAAE;AACf,QAAA,sBAAsB,EAAE,EAAE;AAC1B,QAAA,wBAAwB,EAAE,EAAE;AAC5B,QAAA,eAAe,EAAE,IAAI;AACrB,QAAA,gBAAgB,EAAE,IAAI;AACvB,KAAA;AACD,IAAA,kBAAkB,EAAE;AAClB,QAAA,kBAAkB,EAAE,EAAE;AACtB,QAAA,eAAe,EAAE,IAAI;AACrB,QAAA,gBAAgB,EAAE,IAAI;AACvB,KAAA;AACD,IAAA,eAAe,EAAE,uBAAuB;;AAGpC,SAAU,wBAAwB,CACtC,OAAe,EAAA;IAMf,OAAO;QACL,gBAAgB,EAAE,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,UAAU,CAAC;QAChD,2BAA2B,EAAE,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,qBAAqB,CAAC;QACtE,qBAAqB,EAAE,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,eAAe,CAAC;QAC1D,gBAAgB,EAAE,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,SAAS,CAAC;KAChD;AACH;AA+CA;AACO,MAAM,6BAA6B,GAQtC;AACF,IAAA,GAAG,2BAA2B;AAC9B,IAAA,kBAAkB,EAAE;AAClB,QAAA,eAAe,EAAE,GAAG;AACpB,QAAA,gBAAgB,EAAE,IAAI;QACtB,yBAAyB,EAAE,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI;AAChD,KAAA;AACD,IAAA,QAAQ,EAAE;AACR,QAAA,oBAAoB,EAAE,KAAK;AAC5B,KAAA;AACD,IAAA,6BAA6B,EAAE,IAAI;AACnC,IAAA,sBAAsB,EAAE,GAAG;AAC3B,IAAA,oBAAoB,EAAE,CAAC;;AAGnB,SAAU,0BAA0B,CACxC,OAAe,EAAA;IAKf,OAAO;QACL,GAAG,wBAAwB,CAAC,OAAO,CAAC;QACpC,oBAAoB,EAAE,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,UAAU,CAAC;KACrD;AACH;;;;"}
|
package/dist/pool/data.cjs
CHANGED
|
@@ -204,20 +204,6 @@ function traverseParquetChunkResource(resource) {
|
|
|
204
204
|
...mapping,
|
|
205
205
|
};
|
|
206
206
|
}
|
|
207
|
-
function makeDataInfoFromPColumnValues(spec, data) {
|
|
208
|
-
const keyLength = spec.axesSpec.length;
|
|
209
|
-
const jsonData = {};
|
|
210
|
-
for (const { key, val } of data) {
|
|
211
|
-
if (key.length !== keyLength)
|
|
212
|
-
throw new model.PFrameDriverError(`inline column key length ${key.length} differs from axes count ${keyLength}`);
|
|
213
|
-
jsonData[JSON.stringify(key)] = val;
|
|
214
|
-
}
|
|
215
|
-
return {
|
|
216
|
-
type: 'Json',
|
|
217
|
-
keyLength,
|
|
218
|
-
data: jsonData,
|
|
219
|
-
};
|
|
220
|
-
}
|
|
221
207
|
function deriveLegacyPObjectId(spec, data) {
|
|
222
208
|
const hash = node_crypto.createHash('sha256');
|
|
223
209
|
hash.update(canonicalize(spec));
|
|
@@ -242,7 +228,6 @@ exports.ParquetChunkResourceType = ParquetChunkResourceType;
|
|
|
242
228
|
exports.deriveGlobalPObjectId = deriveGlobalPObjectId;
|
|
243
229
|
exports.deriveLegacyPObjectId = deriveLegacyPObjectId;
|
|
244
230
|
exports.deriveLocalPObjectId = deriveLocalPObjectId;
|
|
245
|
-
exports.makeDataInfoFromPColumnValues = makeDataInfoFromPColumnValues;
|
|
246
231
|
exports.parseDataInfoResource = parseDataInfoResource;
|
|
247
232
|
exports.traverseParquetChunkResource = traverseParquetChunkResource;
|
|
248
233
|
//# sourceMappingURL=data.cjs.map
|