@milaboratories/pl-middle-layer 1.43.60 → 1.43.63

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.
@@ -1 +1 @@
1
- {"version":3,"file":"project.js","sources":["../../src/mutator/project.ts"],"sourcesContent":["import type {\n AnyRef,\n AnyResourceRef,\n BasicResourceData,\n PlTransaction,\n ResourceData,\n ResourceId,\n TxOps } from '@milaboratories/pl-client';\nimport {\n ensureResourceIdNotNull,\n field,\n isNotNullResourceId,\n isNullResourceId,\n isResource,\n isResourceId,\n isResourceRef,\n Pl,\n PlClient,\n} from '@milaboratories/pl-client';\nimport { createRenderHeavyBlock, createBContextFromUpstreams } from './template/render_block';\nimport type {\n Block,\n ProjectStructure,\n ProjectField,\n ProjectRenderingState } from '../model/project_model';\nimport {\n BlockRenderingStateKey,\n ProjectStructureKey,\n parseProjectField,\n projectFieldName,\n SchemaVersionCurrent,\n SchemaVersionKey,\n ProjectResourceType,\n InitialBlockStructure,\n InitialProjectRenderingState,\n ProjectMetaKey,\n InitialBlockMeta,\n blockArgsAuthorKey,\n ProjectLastModifiedTimestamp,\n ProjectCreatedTimestamp,\n ProjectStructureAuthorKey,\n getServiceTemplateField,\n FieldsToDuplicate,\n} from '../model/project_model';\nimport { BlockPackTemplateField, createBlockPack } from './block-pack/block_pack';\nimport type {\n BlockGraph,\n ProductionGraphBlockInfo } from '../model/project_model_util';\nimport {\n allBlocks,\n graphDiff,\n productionGraph,\n stagingGraph,\n} from '../model/project_model_util';\nimport type { BlockPackSpecPrepared } from '../model';\nimport type {\n AuthorMarker,\n BlockPackSpec,\n BlockSettings,\n ProjectMeta,\n} from '@milaboratories/pl-model-middle-layer';\nimport {\n InitialBlockSettings,\n} from '@milaboratories/pl-model-middle-layer';\nimport Denque from 'denque';\nimport { exportContext, getPreparedExportTemplateEnvelope } from './context_export';\nimport { loadTemplate } from './template/template_loading';\nimport { cachedDeserialize, notEmpty, canonicalJsonGzBytes, canonicalJsonBytes } from '@milaboratories/ts-helpers';\nimport type { ProjectHelper } from '../model/project_helper';\nimport { extractConfig, UiError, type BlockConfig } from '@platforma-sdk/model';\nimport { getDebugFlags } from '../debug';\nimport type { BlockPackInfo } from '../model/block_pack';\n\ntype FieldStatus = 'NotReady' | 'Ready' | 'Error';\n\ninterface BlockFieldState {\n modCount: number;\n ref?: AnyRef;\n status?: FieldStatus;\n value?: Uint8Array;\n}\n\ntype BlockFieldStates = Partial<Record<ProjectField['fieldName'], BlockFieldState>>;\ntype BlockFieldStateValue = Omit<BlockFieldState, 'modCount'>;\n\ninterface BlockInfoState {\n readonly id: string;\n readonly fields: BlockFieldStates;\n blockConfig?: BlockConfig;\n blockPack?: BlockPackSpec;\n}\n\nfunction cached<ModId, T>(modIdCb: () => ModId, valueCb: () => T): () => T {\n let initialized = false;\n let lastModId: ModId | undefined = undefined;\n let value: T | undefined = undefined;\n return () => {\n if (!initialized) {\n initialized = true;\n lastModId = modIdCb();\n value = valueCb();\n return value;\n }\n const currentModId = modIdCb();\n if (lastModId !== currentModId) {\n lastModId = currentModId;\n value = valueCb();\n }\n return valueCb();\n };\n}\n\nclass BlockInfo {\n constructor(\n public readonly id: string,\n public readonly fields: BlockFieldStates,\n public readonly config: BlockConfig,\n public readonly source: BlockPackSpec,\n ) {}\n\n public check() {\n // state assertions\n\n if ((this.fields.prodOutput === undefined) !== (this.fields.prodCtx === undefined))\n throw new Error('inconsistent prod fields');\n\n if ((this.fields.stagingOutput === undefined) !== (this.fields.stagingCtx === undefined))\n throw new Error('inconsistent stage fields');\n\n if (\n (this.fields.prodOutputPrevious === undefined)\n !== (this.fields.prodCtxPrevious === undefined)\n )\n throw new Error('inconsistent prod cache fields');\n\n if (\n (this.fields.stagingOutputPrevious === undefined)\n !== (this.fields.stagingCtxPrevious === undefined)\n )\n throw new Error('inconsistent stage cache fields');\n\n if (this.fields.blockPack === undefined) throw new Error('no block pack field');\n\n if (this.fields.currentArgs === undefined) throw new Error('no current args field');\n }\n\n private readonly currentArgsC = cached(\n () => this.fields.currentArgs!.modCount,\n () => cachedDeserialize(this.fields.currentArgs!.value!),\n );\n\n private readonly prodArgsC = cached(\n () => this.fields.prodArgs?.modCount,\n () => {\n const bin = this.fields.prodArgs?.value;\n if (bin === undefined) return undefined;\n return cachedDeserialize(bin);\n },\n );\n\n get currentArgs(): unknown {\n return this.currentArgsC();\n }\n\n get stagingRendered(): boolean {\n return this.fields.stagingCtx !== undefined;\n }\n\n get productionRendered(): boolean {\n return this.fields.prodCtx !== undefined;\n }\n\n get productionHasErrors(): boolean {\n return this.fields.prodUiCtx?.status === 'Error';\n }\n\n private readonly productionStaleC: () => boolean = cached(\n () => `${this.fields.currentArgs!.modCount}_${this.fields.prodArgs?.modCount}`,\n () =>\n this.fields.prodArgs === undefined\n || Buffer.compare(this.fields.currentArgs!.value!, this.fields.prodArgs.value!) !== 0,\n );\n\n // get productionStale(): boolean {\n // return this.productionRendered && this.productionStaleC() && ;\n // }\n\n get requireProductionRendering(): boolean {\n return !this.productionRendered || this.productionStaleC() || this.productionHasErrors;\n }\n\n get prodArgs(): unknown {\n return this.prodArgsC();\n }\n\n public getTemplate(tx: PlTransaction): AnyRef {\n return tx.getFutureFieldValue(\n Pl.unwrapHolder(tx, this.fields.blockPack!.ref!),\n BlockPackTemplateField,\n 'Input',\n );\n }\n}\n\nexport interface NewBlockSpec {\n blockPack: BlockPackSpecPrepared;\n args: string;\n uiState: string;\n}\n\nconst NoNewBlocks = (blockId: string) => {\n throw new Error(`No new block info for ${blockId}`);\n};\n\nexport interface SetStatesRequest {\n blockId: string;\n args?: unknown;\n uiState?: unknown;\n}\n\ntype _GraphInfoFields =\n | 'stagingUpstream'\n | 'stagingDownstream'\n | 'futureProductionUpstream'\n | 'futureProductionDownstream'\n | 'actualProductionUpstream'\n | 'actualProductionDownstream';\n\nexport type ArgsAndUiState = {\n args: unknown;\n uiState: unknown;\n};\n\nexport class ProjectMutator {\n private globalModCount = 0;\n private fieldsChanged: boolean = false;\n\n //\n // Change trackers\n //\n\n private lastModifiedChanged = false;\n private structureChanged = false;\n private metaChanged = false;\n private renderingStateChanged = false;\n\n /** Set blocks will be assigned current mutator author marker on save */\n private readonly blocksWithChangedInputs = new Set<string>();\n\n constructor(\n public readonly rid: ResourceId,\n private readonly tx: PlTransaction,\n private readonly author: AuthorMarker | undefined,\n private readonly schema: string,\n private lastModified: number,\n private meta: ProjectMeta,\n private struct: ProjectStructure,\n private readonly renderingState: Omit<ProjectRenderingState, 'blocksInLimbo'>,\n private readonly blocksInLimbo: Set<string>,\n private readonly blockInfos: Map<string, BlockInfo>,\n private readonly ctxExportTplHolder: AnyResourceRef,\n private readonly projectHelper: ProjectHelper,\n ) {}\n\n private fixProblemsAndMigrate() {\n // Fixing problems introduced by old code\n this.blockInfos.forEach((blockInfo) => {\n if (\n blockInfo.fields.prodArgs === undefined\n || blockInfo.fields.prodOutput === undefined\n || blockInfo.fields.prodCtx === undefined\n )\n this.deleteBlockFields(blockInfo.id, 'prodArgs', 'prodOutput', 'prodCtx');\n });\n\n // Migration for addition of block settings field\n let initialBlockSettings: Omit<BlockFieldState, 'modCount'> | undefined;\n this.blockInfos.forEach((blockInfo) => {\n if (blockInfo.fields.blockSettings === undefined) {\n if (initialBlockSettings === undefined)\n initialBlockSettings = this.createJsonFieldValue(InitialBlockSettings);\n this.setBlockFieldObj(blockInfo.id, 'blockSettings', initialBlockSettings);\n }\n });\n }\n\n get wasModified(): boolean {\n return (\n this.lastModifiedChanged\n || this.structureChanged\n || this.fieldsChanged\n || this.metaChanged\n || this.renderingStateChanged\n );\n }\n\n get structure(): ProjectStructure {\n // clone\n return JSON.parse(JSON.stringify(this.struct)) as ProjectStructure;\n }\n\n //\n // Graph calculation\n //\n\n private stagingGraph: BlockGraph | undefined = undefined;\n private pendingProductionGraph: BlockGraph | undefined = undefined;\n private actualProductionGraph: BlockGraph | undefined = undefined;\n\n private getStagingGraph(): BlockGraph {\n if (this.stagingGraph === undefined) this.stagingGraph = stagingGraph(this.struct);\n return this.stagingGraph;\n }\n\n private getProductionGraphBlockInfo(blockId: string, prod: boolean): ProductionGraphBlockInfo | undefined {\n const bInfo = this.getBlockInfo(blockId);\n\n let argsField: BlockFieldState;\n let args: unknown;\n\n if (prod) {\n if (bInfo.fields.prodArgs === undefined) return undefined;\n argsField = bInfo.fields.prodArgs;\n args = bInfo.prodArgs;\n } else {\n argsField = notEmpty(bInfo.fields.currentArgs);\n args = bInfo.currentArgs;\n }\n\n const blockPackField = notEmpty(bInfo.fields.blockPack);\n\n if (isResourceId(argsField.ref!) && isResourceId(blockPackField.ref!))\n return {\n args,\n enrichmentTargets: this.projectHelper.getEnrichmentTargets(() => bInfo.config, () => args,\n { argsRid: argsField.ref, blockPackRid: blockPackField.ref }),\n };\n else\n return {\n args,\n enrichmentTargets: this.projectHelper.getEnrichmentTargets(() => bInfo.config, () => args),\n };\n }\n\n private getPendingProductionGraph(): BlockGraph {\n if (this.pendingProductionGraph === undefined)\n this.pendingProductionGraph = productionGraph(\n this.struct,\n (blockId) => this.getProductionGraphBlockInfo(blockId, false),\n );\n return this.pendingProductionGraph;\n }\n\n private getActualProductionGraph(): BlockGraph {\n if (this.actualProductionGraph === undefined)\n this.actualProductionGraph = productionGraph(\n this.struct,\n (blockId) => this.getProductionGraphBlockInfo(blockId, true),\n );\n return this.actualProductionGraph;\n }\n\n //\n // Generic helpers to interact with project state\n //\n\n private getBlockInfo(blockId: string): BlockInfo {\n const info = this.blockInfos.get(blockId);\n if (info === undefined) throw new Error(`No such block: ${blockId}`);\n return info;\n }\n\n private createJsonFieldValueByContent(content: string): BlockFieldStateValue {\n const value = Buffer.from(content);\n const ref = this.tx.createValue(Pl.JsonObject, value);\n return { ref, value, status: 'Ready' };\n }\n\n private createJsonFieldValue(obj: unknown): BlockFieldStateValue {\n return this.createJsonFieldValueByContent(JSON.stringify(obj));\n }\n\n private getBlock(blockId: string): Block {\n for (const block of allBlocks(this.struct)) if (block.id === blockId) return block;\n throw new Error('block not found');\n }\n\n private setBlockFieldObj(\n blockId: string,\n fieldName: keyof BlockFieldStates,\n state: BlockFieldStateValue,\n ) {\n const fid = field(this.rid, projectFieldName(blockId, fieldName));\n\n if (state.ref === undefined) throw new Error('Can\\'t set value with empty ref');\n\n if (this.getBlockInfo(blockId).fields[fieldName] === undefined)\n this.tx.createField(fid, 'Dynamic', state.ref);\n else this.tx.setField(fid, state.ref);\n\n this.getBlockInfo(blockId).fields[fieldName] = {\n modCount: this.globalModCount++,\n ...state,\n };\n\n this.fieldsChanged = true;\n }\n\n private setBlockField(\n blockId: string,\n fieldName: keyof BlockFieldStates,\n ref: AnyRef,\n status: FieldStatus,\n value?: Uint8Array,\n ) {\n this.setBlockFieldObj(blockId, fieldName, { ref, status, value });\n }\n\n private deleteBlockFields(blockId: string, ...fieldNames: (keyof BlockFieldStates)[]): boolean {\n let deleted = false;\n const info = this.getBlockInfo(blockId);\n for (const fieldName of fieldNames) {\n const fields = info.fields;\n if (!(fieldName in fields)) continue;\n this.tx.removeField(field(this.rid, projectFieldName(blockId, fieldName)));\n delete fields[fieldName];\n this.fieldsChanged = true;\n deleted = true;\n }\n return deleted;\n }\n\n private updateLastModified() {\n this.lastModified = Date.now();\n this.lastModifiedChanged = true;\n }\n\n //\n // Main project actions\n //\n\n private resetStagingRefreshTimestamp() {\n this.renderingState.stagingRefreshTimestamp = Date.now();\n this.renderingStateChanged = true;\n }\n\n private resetStaging(blockId: string): void {\n const fields = this.getBlockInfo(blockId).fields;\n if (\n fields.stagingOutput?.status === 'Ready'\n && fields.stagingCtx?.status === 'Ready'\n && fields.stagingUiCtx?.status === 'Ready'\n ) {\n this.setBlockFieldObj(blockId, 'stagingOutputPrevious', fields.stagingOutput);\n this.setBlockFieldObj(blockId, 'stagingCtxPrevious', fields.stagingCtx);\n this.setBlockFieldObj(blockId, 'stagingUiCtxPrevious', fields.stagingUiCtx);\n }\n if (this.deleteBlockFields(blockId, 'stagingOutput', 'stagingCtx', 'stagingUiCtx'))\n this.resetStagingRefreshTimestamp();\n }\n\n private resetProduction(blockId: string): void {\n const fields = this.getBlockInfo(blockId).fields;\n if (\n fields.prodOutput?.status === 'Ready'\n && fields.prodCtx?.status === 'Ready'\n && fields.prodUiCtx?.status === 'Ready'\n ) {\n this.setBlockFieldObj(blockId, 'prodOutputPrevious', fields.prodOutput);\n this.setBlockFieldObj(blockId, 'prodCtxPrevious', fields.prodCtx);\n this.setBlockFieldObj(blockId, 'prodUiCtxPrevious', fields.prodUiCtx);\n }\n this.deleteBlockFields(blockId, 'prodOutput', 'prodCtx', 'prodUiCtx', 'prodArgs');\n }\n\n /** Running blocks are reset, already computed moved to limbo. Returns if\n * either of the actions were actually performed.\n * This method ensures the block is left in a consistent state that passes check() constraints. */\n private resetOrLimboProduction(blockId: string): boolean {\n const fields = this.getBlockInfo(blockId).fields;\n\n // Check if we can safely move to limbo (both core production fields are ready)\n if (fields.prodOutput?.status === 'Ready' && fields.prodCtx?.status === 'Ready') {\n if (this.blocksInLimbo.has(blockId))\n // we are already in limbo\n return false;\n\n // limbo - keep the ready production results but clean up cache\n this.blocksInLimbo.add(blockId);\n this.renderingStateChanged = true;\n\n // doing some gc - clean up previous cache fields\n this.deleteBlockFields(blockId, 'prodOutputPrevious', 'prodCtxPrevious', 'prodUiCtxPrevious');\n\n return true;\n } else {\n // reset - clean up any partial/inconsistent production stat\n return this.deleteBlockFields(\n blockId,\n 'prodOutput',\n 'prodCtx',\n 'prodUiCtx',\n 'prodArgs',\n 'prodOutputPrevious',\n 'prodCtxPrevious',\n 'prodUiCtxPrevious',\n );\n }\n }\n\n /** Optimally sets inputs for multiple blocks in one go */\n public setStates(requests: SetStatesRequest[]) {\n const changedArgs: string[] = [];\n let somethingChanged = false;\n for (const req of requests) {\n const info = this.getBlockInfo(req.blockId);\n let blockChanged = false;\n for (const stateKey of ['args', 'uiState'] as const) {\n if (!(stateKey in req)) continue;\n const statePart = req[stateKey];\n if (statePart === undefined || statePart === null)\n throw new Error(\n `Can't set ${stateKey} to null or undefined, please omit the key if you don't want to change it`,\n );\n\n const fieldName = stateKey === 'args' ? 'currentArgs' : 'uiState';\n\n let data: Uint8Array;\n let gzipped: boolean = false;\n if (stateKey === 'args') {\n // don't gzip args, workflow code can't uncompress gzip yet\n data = canonicalJsonBytes(statePart);\n } else {\n const { data: binary, isGzipped } = canonicalJsonGzBytes(statePart);\n data = binary;\n gzipped = isGzipped;\n }\n if (Buffer.compare(info.fields[fieldName]!.value!, data) === 0) continue;\n console.log('setting', fieldName, gzipped, data.length);\n const statePartRef = this.tx.createValue(gzipped ? Pl.JsonGzObject : Pl.JsonObject, data);\n this.setBlockField(req.blockId, fieldName, statePartRef, 'Ready', data);\n\n blockChanged = true;\n if (stateKey === 'args') changedArgs.push(req.blockId);\n }\n if (blockChanged) {\n // will be assigned our author marker\n this.blocksWithChangedInputs.add(req.blockId);\n somethingChanged = true;\n }\n }\n\n // resetting staging outputs for all downstream blocks\n this.getStagingGraph().traverse('downstream', changedArgs, ({ id }) => this.resetStaging(id));\n\n if (somethingChanged) this.updateLastModified();\n }\n\n public setBlockSettings(blockId: string, newValue: BlockSettings): void {\n this.setBlockFieldObj(blockId, 'blockSettings', this.createJsonFieldValue(newValue));\n this.updateLastModified();\n }\n\n private createProdCtx(upstream: Set<string>): AnyRef {\n const upstreamContexts: AnyRef[] = [];\n upstream.forEach((id) => {\n const info = this.getBlockInfo(id);\n if (info.fields['prodCtx']?.ref === undefined)\n throw new Error('One of the upstreams staging is not rendered.');\n upstreamContexts.push(Pl.unwrapHolder(this.tx, info.fields['prodCtx'].ref));\n });\n return createBContextFromUpstreams(this.tx, upstreamContexts);\n }\n\n private createStagingCtx(upstream: Set<string>): AnyRef {\n const upstreamContexts: AnyRef[] = [];\n upstream.forEach((id) => {\n const info = this.getBlockInfo(id);\n if (info.fields['stagingCtx']?.ref === undefined)\n throw new Error('One of the upstreams staging is not rendered.');\n upstreamContexts.push(Pl.unwrapHolder(this.tx, info.fields['stagingCtx'].ref));\n if (info.fields['prodCtx']?.ref !== undefined)\n upstreamContexts.push(Pl.unwrapHolder(this.tx, info.fields['prodCtx'].ref));\n });\n return createBContextFromUpstreams(this.tx, upstreamContexts);\n }\n\n private exportCtx(ctx: AnyRef): AnyRef {\n return exportContext(this.tx, Pl.unwrapHolder(this.tx, this.ctxExportTplHolder), ctx);\n }\n\n private renderStagingFor(blockId: string) {\n this.resetStaging(blockId);\n\n const info = this.getBlockInfo(blockId);\n\n const ctx = this.createStagingCtx(this.getStagingGraph().nodes.get(blockId)!.upstream);\n\n if (this.getBlock(blockId).renderingMode !== 'Heavy') throw new Error('not supported yet');\n\n const tpl = info.getTemplate(this.tx);\n\n const results = createRenderHeavyBlock(this.tx, tpl, {\n args: info.fields.currentArgs!.ref!,\n blockId: this.tx.createValue(Pl.JsonString, JSON.stringify(blockId)),\n isProduction: this.tx.createValue(Pl.JsonBool, JSON.stringify(false)),\n context: ctx,\n });\n\n this.setBlockField(\n blockId,\n 'stagingCtx',\n Pl.wrapInEphHolder(this.tx, results.context),\n 'NotReady',\n );\n\n this.setBlockField(blockId, 'stagingUiCtx', this.exportCtx(results.context), 'NotReady');\n\n this.setBlockField(blockId, 'stagingOutput', results.result, 'NotReady');\n }\n\n private renderProductionFor(blockId: string) {\n this.resetProduction(blockId);\n\n const info = this.getBlockInfo(blockId);\n\n const ctx = this.createProdCtx(this.getPendingProductionGraph().nodes.get(blockId)!.upstream);\n\n if (this.getBlock(blockId).renderingMode === 'Light')\n throw new Error('Can\\'t render production for light block.');\n\n const tpl = info.getTemplate(this.tx);\n\n const results = createRenderHeavyBlock(this.tx, tpl, {\n args: info.fields.currentArgs!.ref!,\n blockId: this.tx.createValue(Pl.JsonString, JSON.stringify(blockId)),\n isProduction: this.tx.createValue(Pl.JsonBool, JSON.stringify(true)),\n context: ctx,\n });\n this.setBlockField(\n blockId,\n 'prodCtx',\n Pl.wrapInEphHolder(this.tx, results.context),\n 'NotReady',\n );\n this.setBlockField(blockId, 'prodUiCtx', this.exportCtx(results.context), 'NotReady');\n this.setBlockField(blockId, 'prodOutput', results.result, 'NotReady');\n\n // saving inputs for which we rendered the production\n this.setBlockFieldObj(blockId, 'prodArgs', info.fields.currentArgs!);\n\n // removing block from limbo as we juts rendered fresh production for it\n if (this.blocksInLimbo.delete(blockId)) this.renderingStateChanged = true;\n }\n\n //\n // Structure changes\n //\n\n private initializeNewBlock(blockId: string, spec: NewBlockSpec): void {\n const info = new BlockInfo(blockId, {}, extractConfig(spec.blockPack.config), spec.blockPack.source);\n this.blockInfos.set(blockId, info);\n\n // block pack\n const bp = createBlockPack(this.tx, spec.blockPack);\n this.setBlockField(blockId, 'blockPack', Pl.wrapInHolder(this.tx, bp), 'NotReady');\n\n // settings\n this.setBlockFieldObj(\n blockId,\n 'blockSettings',\n this.createJsonFieldValue(InitialBlockSettings),\n );\n\n // args\n this.setBlockFieldObj(blockId, 'currentArgs', this.createJsonFieldValueByContent(spec.args));\n\n // uiState\n this.setBlockFieldObj(blockId, 'uiState', this.createJsonFieldValueByContent(spec.uiState ?? '{}'));\n\n // checking structure\n info.check();\n }\n\n private getFieldNamesToDuplicate(blockId: string): Set<ProjectField['fieldName']> {\n const fields = this.getBlockInfo(blockId).fields;\n\n const diff = <T>(setA: Set<T>, setB: Set<T>): Set<T> => new Set([...setA].filter((x) => !setB.has(x)));\n\n // Check if we can safely move to limbo (both core production fields are ready)\n if (fields.prodOutput?.status === 'Ready' && fields.prodCtx?.status === 'Ready') {\n if (this.blocksInLimbo.has(blockId))\n // we are already in limbo\n return FieldsToDuplicate;\n\n return diff(FieldsToDuplicate, new Set([\n 'prodOutputPrevious',\n 'prodCtxPrevious',\n 'prodUiCtxPrevious',\n ]));\n } else {\n return diff(FieldsToDuplicate, new Set([\n 'prodOutput',\n 'prodCtx',\n 'prodUiCtx',\n 'prodArgs',\n 'prodOutputPrevious',\n 'prodCtxPrevious',\n 'prodUiCtxPrevious',\n ]));\n }\n }\n\n private initializeBlockDuplicate(blockId: string, originalBlockInfo: BlockInfo) {\n const info = new BlockInfo(\n blockId,\n {},\n originalBlockInfo.config,\n originalBlockInfo.source,\n );\n\n this.blockInfos.set(blockId, info);\n\n const fieldNamesToDuplicate = this.getFieldNamesToDuplicate(blockId);\n\n // Copy all fields from original block to new block by sharing references\n for (const [fieldName, fieldState] of Object.entries(originalBlockInfo.fields)) {\n if (fieldNamesToDuplicate.has(fieldName as ProjectField['fieldName']) && fieldState && fieldState.ref) {\n this.setBlockFieldObj(blockId, fieldName as keyof BlockFieldStates, {\n ref: fieldState.ref,\n status: fieldState.status,\n value: fieldState.value,\n });\n }\n }\n\n this.resetOrLimboProduction(blockId);\n\n info.check();\n }\n\n /** Very generic method, better check for more specialized case-specific methods first. */\n public updateStructure(\n newStructure: ProjectStructure,\n newBlockInitializer: (blockId: string) => void = NoNewBlocks,\n ): void {\n const currentStagingGraph = this.getStagingGraph();\n const currentActualProductionGraph = this.getActualProductionGraph();\n\n const newStagingGraph = stagingGraph(newStructure);\n\n const stagingDiff = graphDiff(currentStagingGraph, newStagingGraph);\n\n // removing blocks\n for (const blockId of stagingDiff.onlyInA) {\n const { fields } = this.getBlockInfo(blockId);\n this.deleteBlockFields(blockId, ...(Object.keys(fields) as ProjectField['fieldName'][]));\n this.blockInfos.delete(blockId);\n if (this.blocksInLimbo.delete(blockId)) this.renderingStateChanged = true;\n }\n\n // creating new blocks\n for (const blockId of stagingDiff.onlyInB) {\n newBlockInitializer(blockId);\n }\n\n // resetting stagings affected by topology change\n for (const blockId of stagingDiff.different) this.resetStaging(blockId);\n\n // new actual production graph without new blocks\n const newActualProductionGraph = productionGraph(\n newStructure,\n (blockId) => this.getProductionGraphBlockInfo(blockId, true),\n );\n\n const prodDiff = graphDiff(currentActualProductionGraph, newActualProductionGraph);\n\n // applying changes due to topology change in production to affected nodes and\n // all their downstreams\n currentActualProductionGraph.traverse('downstream', [...prodDiff.different], (node) => {\n this.resetOrLimboProduction(node.id);\n });\n\n if (\n stagingDiff.onlyInB.size > 0\n || stagingDiff.onlyInA.size > 0\n || stagingDiff.different.size > 0\n )\n this.resetStagingRefreshTimestamp();\n\n this.struct = newStructure;\n this.structureChanged = true;\n this.stagingGraph = undefined;\n this.pendingProductionGraph = undefined;\n this.actualProductionGraph = undefined;\n\n this.updateLastModified();\n }\n\n //\n // Structure change helpers\n //\n\n public addBlock(block: Block, spec: NewBlockSpec, before?: string): void {\n const newStruct = this.structure; // copy current structure\n if (before === undefined) {\n // adding as a very last block\n newStruct.groups[newStruct.groups.length - 1].blocks.push(block);\n } else {\n let done = false;\n for (const group of newStruct.groups) {\n const idx = group.blocks.findIndex((b) => b.id === before);\n if (idx < 0) continue;\n group.blocks.splice(idx, 0, block);\n done = true;\n break;\n }\n if (!done) throw new Error(`Can't find element with id: ${before}`);\n }\n this.updateStructure(newStruct, (blockId) => {\n if (blockId !== block.id) throw new Error('Unexpected');\n this.initializeNewBlock(blockId, spec);\n });\n }\n\n /**\n * Duplicates an existing block by copying all its fields and structure.\n * This method creates a deep copy of the block at the mutator level.\n *\n * @param originalBlockId id of the block to duplicate\n * @param newBlockId id for the new duplicated block\n * @param after id of the block to insert new block after\n */\n public duplicateBlock(originalBlockId: string, newBlockId: string, after?: string): void {\n // Get the original block from structure\n const originalBlock = this.getBlock(originalBlockId);\n const originalBlockInfo = this.getBlockInfo(originalBlockId);\n\n // Create new block in structure\n const newBlock: Block = {\n id: newBlockId,\n label: originalBlock.label,\n renderingMode: originalBlock.renderingMode,\n };\n\n // Add the new block to structure\n const newStruct = this.structure; // copy current structure\n if (after === undefined) {\n // adding as a very last block\n newStruct.groups[newStruct.groups.length - 1].blocks.push(newBlock);\n } else {\n let done = false;\n for (const group of newStruct.groups) {\n const idx = group.blocks.findIndex((b) => b.id === after);\n if (idx < 0) continue;\n group.blocks.splice(idx + 1, 0, newBlock);\n done = true;\n break;\n }\n if (!done) throw new Error(`Can't find element with id: ${after}`);\n }\n\n this.updateStructure(newStruct, (blockId) => {\n if (blockId !== newBlockId) throw new Error('Unexpected');\n this.initializeBlockDuplicate(blockId, originalBlockInfo);\n });\n }\n\n public deleteBlock(blockId: string): void {\n const newStruct = this.structure; // copy current structure\n let done = false;\n for (const group of newStruct.groups) {\n const idx = group.blocks.findIndex((b) => b.id === blockId);\n if (idx < 0) continue;\n group.blocks.splice(idx, 1);\n done = true;\n break;\n }\n if (!done) throw new Error(`Can't find element with id: ${blockId}`);\n this.updateStructure(newStruct);\n }\n\n //\n // Block-pack migration\n //\n\n public migrateBlockPack(blockId: string, spec: BlockPackSpecPrepared, newArgsAndUiState?: ArgsAndUiState): void {\n const info = this.getBlockInfo(blockId);\n\n this.setBlockField(\n blockId,\n 'blockPack',\n Pl.wrapInHolder(this.tx, createBlockPack(this.tx, spec)),\n 'NotReady',\n );\n\n if (newArgsAndUiState !== undefined) {\n // this will also reset all downstream stagings\n this.setStates([{ blockId, args: newArgsAndUiState.args, uiState: newArgsAndUiState.uiState }]);\n } else {\n // resetting staging outputs for all downstream blocks\n this.getStagingGraph().traverse('downstream', [blockId], ({ id }) => this.resetStaging(id));\n }\n\n // also reset or limbo all downstream productions\n if (info.productionRendered)\n this.getActualProductionGraph().traverse('downstream', [blockId], ({ id }) =>\n this.resetOrLimboProduction(id),\n );\n\n this.updateLastModified();\n }\n\n //\n // Render\n //\n\n public renderProduction(blockIds: string[], addUpstreams: boolean = false): Set<string> {\n const blockIdsSet = new Set(blockIds);\n\n const prodGraph = this.getPendingProductionGraph();\n if (addUpstreams)\n // adding all upstreams automatically\n prodGraph.traverse('upstream', blockIds, (node) => {\n blockIdsSet.add(node.id);\n });\n else // checking that targets contain all upstreams\n for (const blockId of blockIdsSet) {\n const node = prodGraph.nodes.get(blockId);\n if (node === undefined) throw new Error(`Can't find block with id: ${blockId}`);\n for (const upstream of node.upstream)\n if (!blockIdsSet.has(upstream))\n throw new Error('Can\\'t render blocks not including all upstreams.');\n }\n\n // traversing in topological order and rendering target blocks\n const rendered = new Set<string>();\n for (const block of allBlocks(this.structure)) {\n if (!blockIdsSet.has(block.id)) continue;\n\n let render\n = this.getBlockInfo(block.id).requireProductionRendering || this.blocksInLimbo.has(block.id);\n\n if (!render)\n for (const upstream of prodGraph.nodes.get(block.id)!.upstream)\n if (rendered.has(upstream)) {\n render = true;\n break;\n }\n\n if (render) {\n this.renderProductionFor(block.id);\n rendered.add(block.id);\n }\n }\n\n const renderedArray = [...rendered];\n\n // sending to limbo all downstream blocks\n prodGraph.traverse('downstream', renderedArray, (node) => {\n if (rendered.has(node.id))\n // don't send to limbo blocks that were just rendered\n return;\n this.resetOrLimboProduction(node.id);\n });\n\n // resetting staging outputs for all downstream blocks\n this.getStagingGraph().traverse('downstream', renderedArray, ({ id }) => {\n // don't reset staging of the first rendered block\n if (renderedArray[0] !== id) this.resetStaging(id);\n });\n\n if (rendered.size > 0) this.updateLastModified();\n\n return rendered;\n }\n\n /** Stops running blocks from the list and modify states of other blocks\n * accordingly */\n public stopProduction(...blockIds: string[]) {\n const activeProdGraph = this.getActualProductionGraph();\n\n // we will stop all blocks listed in request and all their downstreams\n const queue = new Denque(blockIds);\n const queued = new Set(blockIds);\n const stopped: string[] = [];\n\n while (!queue.isEmpty()) {\n const blockId = queue.shift()!;\n const fields = this.getBlockInfo(blockId).fields;\n\n if (fields.prodOutput?.status === 'Ready' && fields.prodCtx?.status === 'Ready')\n // skipping finished blocks\n continue;\n\n if (this.deleteBlockFields(blockId, 'prodOutput', 'prodCtx', 'prodUiCtx', 'prodArgs')) {\n // was actually stopped\n stopped.push(blockId);\n\n // will try to stop all its downstreams\n for (const downstream of activeProdGraph.traverseIdsExcludingRoots('downstream', blockId)) {\n if (queued.has(downstream)) continue;\n queue.push(downstream);\n queued.add(downstream);\n }\n }\n }\n\n // blocks under stopped blocks, but still having results, goes to limbo\n for (const blockId of activeProdGraph.traverseIdsExcludingRoots('downstream', ...stopped))\n this.resetOrLimboProduction(blockId);\n }\n\n private traverseWithStagingLag(cb: (blockId: string, lag: number) => void) {\n const lags = new Map<string, number>();\n const stagingGraph = this.getStagingGraph();\n stagingGraph.nodes.forEach((node) => {\n const info = this.getBlockInfo(node.id);\n let lag = info.stagingRendered ? 0 : 1;\n node.upstream.forEach((upstream) => {\n const upstreamLag = lags.get(upstream)!;\n if (upstreamLag === 0) return;\n lag = Math.max(upstreamLag + 1, lag);\n });\n cb(node.id, lag);\n lags.set(node.id, lag);\n });\n }\n\n /** @param stagingRenderingRate rate in blocks per second */\n private refreshStagings(stagingRenderingRate?: number) {\n const elapsed = Date.now() - this.renderingState.stagingRefreshTimestamp;\n const lagThreshold\n = stagingRenderingRate === undefined\n ? undefined\n : 1 + Math.max(0, (elapsed * stagingRenderingRate) / 1000);\n let rendered = 0;\n this.traverseWithStagingLag((blockId, lag) => {\n if (lag === 0)\n // meaning staging already rendered\n return;\n if (lagThreshold === undefined || lag <= lagThreshold) {\n this.renderStagingFor(blockId);\n rendered++;\n }\n });\n if (rendered > 0) this.resetStagingRefreshTimestamp();\n }\n\n //\n // Meta\n //\n\n /** Updates project metadata */\n public setMeta(meta: ProjectMeta): void {\n this.meta = meta;\n this.metaChanged = true;\n this.updateLastModified();\n }\n\n //\n // Maintenance\n //\n\n /** @param stagingRenderingRate rate in blocks per second */\n public doRefresh(stagingRenderingRate?: number) {\n this.refreshStagings(stagingRenderingRate);\n this.blockInfos.forEach((blockInfo) => {\n if (\n blockInfo.fields.prodCtx?.status === 'Ready'\n && blockInfo.fields.prodOutput?.status === 'Ready'\n )\n this.deleteBlockFields(\n blockInfo.id,\n 'prodOutputPrevious',\n 'prodCtxPrevious',\n 'prodUiCtxPrevious',\n );\n if (\n blockInfo.fields.stagingCtx?.status === 'Ready'\n && blockInfo.fields.stagingOutput?.status === 'Ready'\n )\n this.deleteBlockFields(\n blockInfo.id,\n 'stagingOutputPrevious',\n 'stagingCtxPrevious',\n 'stagingUiCtxPrevious',\n );\n });\n }\n\n private assignAuthorMarkers() {\n const markerStr = this.author ? JSON.stringify(this.author) : undefined;\n\n for (const blockId of this.blocksWithChangedInputs)\n if (markerStr === undefined) this.tx.deleteKValue(this.rid, blockArgsAuthorKey(blockId));\n else this.tx.setKValue(this.rid, blockArgsAuthorKey(blockId), markerStr);\n\n if (this.metaChanged || this.structureChanged) {\n if (markerStr === undefined) this.tx.deleteKValue(this.rid, ProjectStructureAuthorKey);\n else this.tx.setKValue(this.rid, ProjectStructureAuthorKey, markerStr);\n }\n }\n\n public save() {\n if (!this.wasModified) return;\n\n if (this.lastModifiedChanged)\n this.tx.setKValue(this.rid, ProjectLastModifiedTimestamp, JSON.stringify(this.lastModified));\n\n if (this.structureChanged)\n this.tx.setKValue(this.rid, ProjectStructureKey, JSON.stringify(this.struct));\n\n if (this.renderingStateChanged)\n this.tx.setKValue(\n this.rid,\n BlockRenderingStateKey,\n JSON.stringify({\n ...this.renderingState,\n blocksInLimbo: [...this.blocksInLimbo],\n } as ProjectRenderingState),\n );\n\n if (this.metaChanged) this.tx.setKValue(this.rid, ProjectMetaKey, JSON.stringify(this.meta));\n\n this.assignAuthorMarkers();\n }\n\n public static async load(\n projectHelper: ProjectHelper,\n tx: PlTransaction,\n rid: ResourceId,\n author?: AuthorMarker,\n ): Promise<ProjectMutator> {\n //\n // Sending initial requests to read project state (start of round-trip #1)\n //\n\n const fullResourceStateP = tx.getResourceData(rid, true);\n const schemaP = tx.getKValueJson<string>(rid, SchemaVersionKey);\n const lastModifiedP = tx.getKValueJson<number>(rid, ProjectLastModifiedTimestamp);\n const metaP = tx.getKValueJson<ProjectMeta>(rid, ProjectMetaKey);\n const structureP = tx.getKValueJson<ProjectStructure>(rid, ProjectStructureKey);\n const renderingStateP = tx.getKValueJson<ProjectRenderingState>(rid, BlockRenderingStateKey);\n\n const fullResourceState = await fullResourceStateP;\n\n // loading field information\n const blockInfoStates = new Map<string, BlockInfoState>();\n for (const f of fullResourceState.fields) {\n const projectField = parseProjectField(f.name);\n\n // processing only fields with known structure\n if (projectField === undefined) continue;\n\n let info = blockInfoStates.get(projectField.blockId);\n if (info === undefined) {\n info = {\n id: projectField.blockId,\n fields: {},\n };\n blockInfoStates.set(projectField.blockId, info);\n }\n\n info.fields[projectField.fieldName] = isNullResourceId(f.value)\n ? { modCount: 0 }\n : { modCount: 0, ref: f.value };\n }\n\n //\n // Roundtrip #1 not yet finished, but as soon as field list is received,\n // we can start sending requests to read states of referenced resources\n // (start of round-trip #2)\n //\n\n const blockFieldRequests: [BlockInfoState, ProjectField['fieldName'], BlockFieldState, Promise<BasicResourceData | ResourceData>][] = [];\n blockInfoStates.forEach((info) => {\n const fields = info.fields;\n for (const [fName, state] of Object.entries(fields)) {\n if (state.ref === undefined) continue;\n if (!isResource(state.ref) || isResourceRef(state.ref))\n throw new Error('unexpected behaviour');\n const fieldName = fName as ProjectField['fieldName'];\n blockFieldRequests.push([\n info, fieldName,\n state, tx.getResourceData(state.ref, fieldName == 'blockPack')]);\n }\n });\n\n // loading jsons\n const [\n schema,\n lastModified,\n meta,\n structure,\n { stagingRefreshTimestamp, blocksInLimbo },\n ] = await Promise.all([\n schemaP,\n lastModifiedP,\n metaP,\n structureP,\n renderingStateP,\n ]);\n\n // Checking schema version of the project\n if (schema !== SchemaVersionCurrent) {\n if (Number(schema) < Number(SchemaVersionCurrent))\n throw new UiError(`Can't perform this action on this project because it has older schema. Try (re)loading the project to update it.`);\n else\n throw new UiError(`Can't perform this action on this project because it has newer schema. Upgrade your desktop app to the latest version.`);\n }\n\n //\n // <- at this point we have all the responses from round-trip #1\n //\n\n //\n // Receiving responses from round-trip #2 and sending requests to read block pack descriptions\n // (start of round-trip #3)\n //\n\n const blockPackRequests: [BlockInfoState, Promise<BasicResourceData>][] = [];\n for (const [info, fieldName, state, response] of blockFieldRequests) {\n const result = await response;\n state.value = result.data;\n if (isNotNullResourceId(result.error)) state.status = 'Error';\n else if (result.resourceReady || isNotNullResourceId(result.originalResourceId))\n state.status = 'Ready';\n else state.status = 'NotReady';\n\n // For block pack we need to traverse the ref field from the resource data\n if (fieldName === 'blockPack') {\n const refField = (result as ResourceData).fields.find((f) => f.name === Pl.HolderRefField);\n if (refField === undefined)\n throw new Error('Block pack ref field is missing');\n blockPackRequests.push([info, tx.getResourceData(ensureResourceIdNotNull(refField.value), false)]);\n }\n }\n\n //\n // <- at this point we have all the responses from round-trip #2\n //\n\n for (const [info, response] of blockPackRequests) {\n const result = await response;\n const bpInfo = cachedDeserialize<BlockPackInfo>(notEmpty(result.data));\n info.blockConfig = extractConfig(bpInfo.config);\n info.blockPack = bpInfo.source;\n }\n\n //\n // <- at this point we have all the responses from round-trip #3\n //\n\n // loading ctx export template to check if we already have cached materialized template in our project\n const ctxExportTplEnvelope = await getPreparedExportTemplateEnvelope();\n\n // expected field name\n const ctxExportTplCacheFieldName = getServiceTemplateField(ctxExportTplEnvelope.hash);\n const ctxExportTplField = fullResourceState.fields.find(\n (f) => f.name === ctxExportTplCacheFieldName,\n );\n let ctxExportTplHolder: AnyResourceRef;\n if (ctxExportTplField !== undefined)\n ctxExportTplHolder = ensureResourceIdNotNull(ctxExportTplField.value);\n else {\n ctxExportTplHolder = Pl.wrapInHolder(tx, loadTemplate(tx, ctxExportTplEnvelope.spec));\n tx.createField(\n field(rid, getServiceTemplateField(ctxExportTplEnvelope.hash)),\n 'Dynamic',\n ctxExportTplHolder,\n );\n }\n\n const renderingState = { stagingRefreshTimestamp };\n const blocksInLimboSet = new Set(blocksInLimbo);\n\n const blockInfos = new Map<string, BlockInfo>();\n blockInfoStates.forEach(({ id, fields, blockConfig, blockPack }) => blockInfos.set(id,\n new BlockInfo(id, fields, notEmpty(blockConfig), notEmpty(blockPack))));\n\n // check consistency of project state\n const blockInStruct = new Set<string>();\n for (const b of allBlocks(structure)) {\n if (!blockInfos.has(b.id))\n throw new Error(`Inconsistent project structure: no inputs for ${b.id}`);\n blockInStruct.add(b.id);\n }\n blockInfos.forEach((info) => {\n if (!blockInStruct.has(info.id))\n throw new Error(`Inconsistent project structure: no structure entry for ${info.id}`);\n // checking structure\n info.check();\n });\n\n const prj = new ProjectMutator(\n rid,\n tx,\n author,\n schema,\n lastModified,\n meta,\n structure,\n renderingState,\n blocksInLimboSet,\n blockInfos,\n ctxExportTplHolder,\n projectHelper,\n );\n\n prj.fixProblemsAndMigrate();\n\n return prj;\n }\n}\n\nexport interface ProjectState {\n schema: string;\n structure: ProjectStructure;\n renderingState: Omit<ProjectRenderingState, 'blocksInLimbo'>;\n blocksInLimbo: Set<string>;\n blockInfos: Map<string, BlockInfo>;\n}\n\nexport async function createProject(\n tx: PlTransaction,\n meta: ProjectMeta = InitialBlockMeta,\n): Promise<AnyResourceRef> {\n const prj = tx.createEphemeral(ProjectResourceType);\n tx.lock(prj);\n const ts = String(Date.now());\n tx.setKValue(prj, SchemaVersionKey, JSON.stringify(SchemaVersionCurrent));\n tx.setKValue(prj, ProjectCreatedTimestamp, ts);\n tx.setKValue(prj, ProjectLastModifiedTimestamp, ts);\n tx.setKValue(prj, ProjectMetaKey, JSON.stringify(meta));\n tx.setKValue(prj, ProjectStructureKey, JSON.stringify(InitialBlockStructure));\n tx.setKValue(prj, BlockRenderingStateKey, JSON.stringify(InitialProjectRenderingState));\n const ctxExportTplEnvelope = await getPreparedExportTemplateEnvelope();\n tx.createField(\n field(prj, getServiceTemplateField(ctxExportTplEnvelope.hash)),\n 'Dynamic',\n Pl.wrapInHolder(tx, loadTemplate(tx, ctxExportTplEnvelope.spec)),\n );\n return prj;\n}\n\nexport async function withProject<T>(\n projectHelper: ProjectHelper,\n txOrPl: PlTransaction | PlClient,\n rid: ResourceId,\n cb: (p: ProjectMutator) => T | Promise<T>,\n ops?: Partial<TxOps>,\n): Promise<T> {\n return withProjectAuthored(projectHelper, txOrPl, rid, undefined, cb, ops);\n}\n\nexport async function withProjectAuthored<T>(\n projectHelper: ProjectHelper,\n txOrPl: PlTransaction | PlClient,\n rid: ResourceId,\n author: AuthorMarker | undefined,\n cb: (p: ProjectMutator) => T | Promise<T>,\n ops: Partial<TxOps> = {},\n): Promise<T> {\n if (txOrPl instanceof PlClient) {\n return await txOrPl.withWriteTx('ProjectAction' + (ops.name ? `: ${ops.name}` : ''), async (tx) => {\n const mut = await ProjectMutator.load(projectHelper, tx, rid, author);\n const result = await cb(mut);\n if (!mut.wasModified)\n // skipping save and commit altogether if no modifications were actually made\n return result;\n mut.save();\n await tx.commit();\n if (getDebugFlags().logProjectMutationStat) console.log(JSON.stringify(tx.stat));\n return result;\n }, ops);\n } else {\n const mut = await ProjectMutator.load(projectHelper, txOrPl, rid, author);\n const result = await cb(mut);\n mut.save();\n return result;\n }\n}\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"project.js","sources":["../../src/mutator/project.ts"],"sourcesContent":["import type {\n AnyRef,\n AnyResourceRef,\n BasicResourceData,\n PlTransaction,\n ResourceData,\n ResourceId,\n TxOps } from '@milaboratories/pl-client';\nimport {\n ensureResourceIdNotNull,\n field,\n isNotNullResourceId,\n isNullResourceId,\n isResource,\n isResourceId,\n isResourceRef,\n Pl,\n PlClient,\n} from '@milaboratories/pl-client';\nimport { createRenderHeavyBlock, createBContextFromUpstreams } from './template/render_block';\nimport type {\n Block,\n ProjectStructure,\n ProjectField,\n ProjectRenderingState } from '../model/project_model';\nimport {\n BlockRenderingStateKey,\n ProjectStructureKey,\n parseProjectField,\n projectFieldName,\n SchemaVersionCurrent,\n SchemaVersionKey,\n ProjectResourceType,\n InitialBlockStructure,\n InitialProjectRenderingState,\n ProjectMetaKey,\n InitialBlockMeta,\n blockArgsAuthorKey,\n ProjectLastModifiedTimestamp,\n ProjectCreatedTimestamp,\n ProjectStructureAuthorKey,\n getServiceTemplateField,\n FieldsToDuplicate,\n} from '../model/project_model';\nimport { BlockPackTemplateField, createBlockPack } from './block-pack/block_pack';\nimport type {\n BlockGraph,\n ProductionGraphBlockInfo } from '../model/project_model_util';\nimport {\n allBlocks,\n graphDiff,\n productionGraph,\n stagingGraph,\n} from '../model/project_model_util';\nimport type { BlockPackSpecPrepared } from '../model';\nimport type {\n AuthorMarker,\n BlockPackSpec,\n BlockSettings,\n ProjectMeta,\n} from '@milaboratories/pl-model-middle-layer';\nimport {\n InitialBlockSettings,\n} from '@milaboratories/pl-model-middle-layer';\nimport Denque from 'denque';\nimport { exportContext, getPreparedExportTemplateEnvelope } from './context_export';\nimport { loadTemplate } from './template/template_loading';\nimport { cachedDeserialize, notEmpty, canonicalJsonGzBytes, canonicalJsonBytes } from '@milaboratories/ts-helpers';\nimport type { ProjectHelper } from '../model/project_helper';\nimport { extractConfig, UiError, type BlockConfig } from '@platforma-sdk/model';\nimport { getDebugFlags } from '../debug';\nimport type { BlockPackInfo } from '../model/block_pack';\n\ntype FieldStatus = 'NotReady' | 'Ready' | 'Error';\n\ninterface BlockFieldState {\n modCount: number;\n ref?: AnyRef;\n status?: FieldStatus;\n value?: Uint8Array;\n}\n\ntype BlockFieldStates = Partial<Record<ProjectField['fieldName'], BlockFieldState>>;\ntype BlockFieldStateValue = Omit<BlockFieldState, 'modCount'>;\n\ninterface BlockInfoState {\n readonly id: string;\n readonly fields: BlockFieldStates;\n blockConfig?: BlockConfig;\n blockPack?: BlockPackSpec;\n}\n\nfunction cached<ModId, T>(modIdCb: () => ModId, valueCb: () => T): () => T {\n let initialized = false;\n let lastModId: ModId | undefined = undefined;\n let value: T | undefined = undefined;\n return () => {\n if (!initialized) {\n initialized = true;\n lastModId = modIdCb();\n value = valueCb();\n return value;\n }\n const currentModId = modIdCb();\n if (lastModId !== currentModId) {\n lastModId = currentModId;\n value = valueCb();\n }\n return valueCb();\n };\n}\n\nclass BlockInfo {\n constructor(\n public readonly id: string,\n public readonly fields: BlockFieldStates,\n public readonly config: BlockConfig,\n public readonly source: BlockPackSpec,\n ) {}\n\n public check() {\n // state assertions\n\n if ((this.fields.prodOutput === undefined) !== (this.fields.prodCtx === undefined))\n throw new Error('inconsistent prod fields');\n\n if ((this.fields.stagingOutput === undefined) !== (this.fields.stagingCtx === undefined))\n throw new Error('inconsistent stage fields');\n\n if (\n (this.fields.prodOutputPrevious === undefined)\n !== (this.fields.prodCtxPrevious === undefined)\n )\n throw new Error('inconsistent prod cache fields');\n\n if (\n (this.fields.stagingOutputPrevious === undefined)\n !== (this.fields.stagingCtxPrevious === undefined)\n )\n throw new Error('inconsistent stage cache fields');\n\n if (this.fields.blockPack === undefined) throw new Error('no block pack field');\n\n if (this.fields.currentArgs === undefined) throw new Error('no current args field');\n }\n\n private readonly currentArgsC = cached(\n () => this.fields.currentArgs!.modCount,\n () => cachedDeserialize(this.fields.currentArgs!.value!),\n );\n\n private readonly prodArgsC = cached(\n () => this.fields.prodArgs?.modCount,\n () => {\n const bin = this.fields.prodArgs?.value;\n if (bin === undefined) return undefined;\n return cachedDeserialize(bin);\n },\n );\n\n get currentArgs(): unknown {\n return this.currentArgsC();\n }\n\n get stagingRendered(): boolean {\n return this.fields.stagingCtx !== undefined;\n }\n\n get productionRendered(): boolean {\n return this.fields.prodCtx !== undefined;\n }\n\n get productionHasErrors(): boolean {\n return this.fields.prodUiCtx?.status === 'Error';\n }\n\n private readonly productionStaleC: () => boolean = cached(\n () => `${this.fields.currentArgs!.modCount}_${this.fields.prodArgs?.modCount}`,\n () =>\n this.fields.prodArgs === undefined\n || Buffer.compare(this.fields.currentArgs!.value!, this.fields.prodArgs.value!) !== 0,\n );\n\n // get productionStale(): boolean {\n // return this.productionRendered && this.productionStaleC() && ;\n // }\n\n get requireProductionRendering(): boolean {\n return !this.productionRendered || this.productionStaleC() || this.productionHasErrors;\n }\n\n get prodArgs(): unknown {\n return this.prodArgsC();\n }\n\n public getTemplate(tx: PlTransaction): AnyRef {\n return tx.getFutureFieldValue(\n Pl.unwrapHolder(tx, this.fields.blockPack!.ref!),\n BlockPackTemplateField,\n 'Input',\n );\n }\n}\n\nexport interface NewBlockSpec {\n blockPack: BlockPackSpecPrepared;\n args: string;\n uiState: string;\n}\n\nconst NoNewBlocks = (blockId: string) => {\n throw new Error(`No new block info for ${blockId}`);\n};\n\nexport interface SetStatesRequest {\n blockId: string;\n args?: unknown;\n uiState?: unknown;\n}\n\ntype _GraphInfoFields =\n | 'stagingUpstream'\n | 'stagingDownstream'\n | 'futureProductionUpstream'\n | 'futureProductionDownstream'\n | 'actualProductionUpstream'\n | 'actualProductionDownstream';\n\nexport type ArgsAndUiState = {\n args: unknown;\n uiState: unknown;\n};\n\nexport class ProjectMutator {\n private globalModCount = 0;\n private fieldsChanged: boolean = false;\n\n //\n // Change trackers\n //\n\n private lastModifiedChanged = false;\n private structureChanged = false;\n private metaChanged = false;\n private renderingStateChanged = false;\n\n /** Set blocks will be assigned current mutator author marker on save */\n private readonly blocksWithChangedInputs = new Set<string>();\n\n constructor(\n public readonly rid: ResourceId,\n private readonly tx: PlTransaction,\n private readonly author: AuthorMarker | undefined,\n private readonly schema: string,\n private lastModified: number,\n private meta: ProjectMeta,\n private struct: ProjectStructure,\n private readonly renderingState: Omit<ProjectRenderingState, 'blocksInLimbo'>,\n private readonly blocksInLimbo: Set<string>,\n private readonly blockInfos: Map<string, BlockInfo>,\n private readonly ctxExportTplHolder: AnyResourceRef,\n private readonly projectHelper: ProjectHelper,\n ) {}\n\n private fixProblemsAndMigrate() {\n // Fixing problems introduced by old code\n this.blockInfos.forEach((blockInfo) => {\n if (\n blockInfo.fields.prodArgs === undefined\n || blockInfo.fields.prodOutput === undefined\n || blockInfo.fields.prodCtx === undefined\n )\n this.deleteBlockFields(blockInfo.id, 'prodArgs', 'prodOutput', 'prodCtx');\n });\n\n // Migration for addition of block settings field\n let initialBlockSettings: Omit<BlockFieldState, 'modCount'> | undefined;\n this.blockInfos.forEach((blockInfo) => {\n if (blockInfo.fields.blockSettings === undefined) {\n if (initialBlockSettings === undefined)\n initialBlockSettings = this.createJsonFieldValue(InitialBlockSettings);\n this.setBlockFieldObj(blockInfo.id, 'blockSettings', initialBlockSettings);\n }\n });\n }\n\n get wasModified(): boolean {\n return (\n this.lastModifiedChanged\n || this.structureChanged\n || this.fieldsChanged\n || this.metaChanged\n || this.renderingStateChanged\n );\n }\n\n get structure(): ProjectStructure {\n // clone\n return JSON.parse(JSON.stringify(this.struct)) as ProjectStructure;\n }\n\n //\n // Graph calculation\n //\n\n private stagingGraph: BlockGraph | undefined = undefined;\n private pendingProductionGraph: BlockGraph | undefined = undefined;\n private actualProductionGraph: BlockGraph | undefined = undefined;\n\n private getStagingGraph(): BlockGraph {\n if (this.stagingGraph === undefined) this.stagingGraph = stagingGraph(this.struct);\n return this.stagingGraph;\n }\n\n private getProductionGraphBlockInfo(blockId: string, prod: boolean): ProductionGraphBlockInfo | undefined {\n const bInfo = this.getBlockInfo(blockId);\n\n let argsField: BlockFieldState;\n let args: unknown;\n\n if (prod) {\n if (bInfo.fields.prodArgs === undefined) return undefined;\n argsField = bInfo.fields.prodArgs;\n args = bInfo.prodArgs;\n } else {\n argsField = notEmpty(bInfo.fields.currentArgs);\n args = bInfo.currentArgs;\n }\n\n const blockPackField = notEmpty(bInfo.fields.blockPack);\n\n if (isResourceId(argsField.ref!) && isResourceId(blockPackField.ref!))\n return {\n args,\n enrichmentTargets: this.projectHelper.getEnrichmentTargets(() => bInfo.config, () => args,\n { argsRid: argsField.ref, blockPackRid: blockPackField.ref }),\n };\n else\n return {\n args,\n enrichmentTargets: this.projectHelper.getEnrichmentTargets(() => bInfo.config, () => args),\n };\n }\n\n private getPendingProductionGraph(): BlockGraph {\n if (this.pendingProductionGraph === undefined)\n this.pendingProductionGraph = productionGraph(\n this.struct,\n (blockId) => this.getProductionGraphBlockInfo(blockId, false),\n );\n return this.pendingProductionGraph;\n }\n\n private getActualProductionGraph(): BlockGraph {\n if (this.actualProductionGraph === undefined)\n this.actualProductionGraph = productionGraph(\n this.struct,\n (blockId) => this.getProductionGraphBlockInfo(blockId, true),\n );\n return this.actualProductionGraph;\n }\n\n //\n // Generic helpers to interact with project state\n //\n\n private getBlockInfo(blockId: string): BlockInfo {\n const info = this.blockInfos.get(blockId);\n if (info === undefined) throw new Error(`No such block: ${blockId}`);\n return info;\n }\n\n private createJsonFieldValueByContent(content: string): BlockFieldStateValue {\n const value = Buffer.from(content);\n const ref = this.tx.createValue(Pl.JsonObject, value);\n return { ref, value, status: 'Ready' };\n }\n\n private createJsonFieldValue(obj: unknown): BlockFieldStateValue {\n return this.createJsonFieldValueByContent(JSON.stringify(obj));\n }\n\n private getBlock(blockId: string): Block {\n for (const block of allBlocks(this.struct)) if (block.id === blockId) return block;\n throw new Error('block not found');\n }\n\n private setBlockFieldObj(\n blockId: string,\n fieldName: keyof BlockFieldStates,\n state: BlockFieldStateValue,\n ) {\n const fid = field(this.rid, projectFieldName(blockId, fieldName));\n\n if (state.ref === undefined) throw new Error('Can\\'t set value with empty ref');\n\n if (this.getBlockInfo(blockId).fields[fieldName] === undefined)\n this.tx.createField(fid, 'Dynamic', state.ref);\n else this.tx.setField(fid, state.ref);\n\n this.getBlockInfo(blockId).fields[fieldName] = {\n modCount: this.globalModCount++,\n ...state,\n };\n\n this.fieldsChanged = true;\n }\n\n private setBlockField(\n blockId: string,\n fieldName: keyof BlockFieldStates,\n ref: AnyRef,\n status: FieldStatus,\n value?: Uint8Array,\n ) {\n this.setBlockFieldObj(blockId, fieldName, { ref, status, value });\n }\n\n private deleteBlockFields(blockId: string, ...fieldNames: (keyof BlockFieldStates)[]): boolean {\n let deleted = false;\n const info = this.getBlockInfo(blockId);\n for (const fieldName of fieldNames) {\n const fields = info.fields;\n if (!(fieldName in fields)) continue;\n this.tx.removeField(field(this.rid, projectFieldName(blockId, fieldName)));\n delete fields[fieldName];\n this.fieldsChanged = true;\n deleted = true;\n }\n return deleted;\n }\n\n private updateLastModified() {\n this.lastModified = Date.now();\n this.lastModifiedChanged = true;\n }\n\n //\n // Main project actions\n //\n\n private resetStagingRefreshTimestamp() {\n this.renderingState.stagingRefreshTimestamp = Date.now();\n this.renderingStateChanged = true;\n }\n\n private resetStaging(blockId: string): void {\n const fields = this.getBlockInfo(blockId).fields;\n if (\n fields.stagingOutput?.status === 'Ready'\n && fields.stagingCtx?.status === 'Ready'\n && fields.stagingUiCtx?.status === 'Ready'\n ) {\n this.setBlockFieldObj(blockId, 'stagingOutputPrevious', fields.stagingOutput);\n this.setBlockFieldObj(blockId, 'stagingCtxPrevious', fields.stagingCtx);\n this.setBlockFieldObj(blockId, 'stagingUiCtxPrevious', fields.stagingUiCtx);\n }\n if (this.deleteBlockFields(blockId, 'stagingOutput', 'stagingCtx', 'stagingUiCtx'))\n this.resetStagingRefreshTimestamp();\n }\n\n private resetProduction(blockId: string): void {\n const fields = this.getBlockInfo(blockId).fields;\n if (\n fields.prodOutput?.status === 'Ready'\n && fields.prodCtx?.status === 'Ready'\n && fields.prodUiCtx?.status === 'Ready'\n ) {\n this.setBlockFieldObj(blockId, 'prodOutputPrevious', fields.prodOutput);\n this.setBlockFieldObj(blockId, 'prodCtxPrevious', fields.prodCtx);\n this.setBlockFieldObj(blockId, 'prodUiCtxPrevious', fields.prodUiCtx);\n }\n this.deleteBlockFields(blockId, 'prodOutput', 'prodCtx', 'prodUiCtx', 'prodArgs');\n }\n\n /** Running blocks are reset, already computed moved to limbo. Returns if\n * either of the actions were actually performed.\n * This method ensures the block is left in a consistent state that passes check() constraints. */\n private resetOrLimboProduction(blockId: string): boolean {\n const fields = this.getBlockInfo(blockId).fields;\n\n // Check if we can safely move to limbo (both core production fields are ready)\n if (fields.prodOutput?.status === 'Ready' && fields.prodCtx?.status === 'Ready') {\n if (this.blocksInLimbo.has(blockId))\n // we are already in limbo\n return false;\n\n // limbo - keep the ready production results but clean up cache\n this.blocksInLimbo.add(blockId);\n this.renderingStateChanged = true;\n\n // doing some gc - clean up previous cache fields\n this.deleteBlockFields(blockId, 'prodOutputPrevious', 'prodCtxPrevious', 'prodUiCtxPrevious');\n\n return true;\n } else {\n // reset - clean up any partial/inconsistent production stat\n return this.deleteBlockFields(\n blockId,\n 'prodOutput',\n 'prodCtx',\n 'prodUiCtx',\n 'prodArgs',\n 'prodOutputPrevious',\n 'prodCtxPrevious',\n 'prodUiCtxPrevious',\n );\n }\n }\n\n /** Optimally sets inputs for multiple blocks in one go */\n public setStates(requests: SetStatesRequest[]) {\n const changedArgs: string[] = [];\n let somethingChanged = false;\n for (const req of requests) {\n const info = this.getBlockInfo(req.blockId);\n let blockChanged = false;\n for (const stateKey of ['args', 'uiState'] as const) {\n if (!(stateKey in req)) continue;\n const statePart = req[stateKey];\n if (statePart === undefined || statePart === null)\n throw new Error(\n `Can't set ${stateKey} to null or undefined, please omit the key if you don't want to change it`,\n );\n\n const fieldName = stateKey === 'args' ? 'currentArgs' : 'uiState';\n\n let data: Uint8Array;\n let gzipped: boolean = false;\n if (stateKey === 'args') {\n // don't gzip args, workflow code can't uncompress gzip yet\n data = canonicalJsonBytes(statePart);\n } else {\n const { data: binary, isGzipped } = canonicalJsonGzBytes(statePart);\n data = binary;\n gzipped = isGzipped;\n }\n if (Buffer.compare(info.fields[fieldName]!.value!, data) === 0) continue;\n // console.log('setting', fieldName, gzipped, data.length);\n const statePartRef = this.tx.createValue(gzipped ? Pl.JsonGzObject : Pl.JsonObject, data);\n this.setBlockField(req.blockId, fieldName, statePartRef, 'Ready', data);\n\n blockChanged = true;\n if (stateKey === 'args') changedArgs.push(req.blockId);\n }\n if (blockChanged) {\n // will be assigned our author marker\n this.blocksWithChangedInputs.add(req.blockId);\n somethingChanged = true;\n }\n }\n\n // resetting staging outputs for all downstream blocks\n this.getStagingGraph().traverse('downstream', changedArgs, ({ id }) => this.resetStaging(id));\n\n if (somethingChanged) this.updateLastModified();\n }\n\n public setBlockSettings(blockId: string, newValue: BlockSettings): void {\n this.setBlockFieldObj(blockId, 'blockSettings', this.createJsonFieldValue(newValue));\n this.updateLastModified();\n }\n\n private createProdCtx(upstream: Set<string>): AnyRef {\n const upstreamContexts: AnyRef[] = [];\n upstream.forEach((id) => {\n const info = this.getBlockInfo(id);\n if (info.fields['prodCtx']?.ref === undefined)\n throw new Error('One of the upstreams staging is not rendered.');\n upstreamContexts.push(Pl.unwrapHolder(this.tx, info.fields['prodCtx'].ref));\n });\n return createBContextFromUpstreams(this.tx, upstreamContexts);\n }\n\n private createStagingCtx(upstream: Set<string>): AnyRef {\n const upstreamContexts: AnyRef[] = [];\n upstream.forEach((id) => {\n const info = this.getBlockInfo(id);\n if (info.fields['stagingCtx']?.ref === undefined)\n throw new Error('One of the upstreams staging is not rendered.');\n upstreamContexts.push(Pl.unwrapHolder(this.tx, info.fields['stagingCtx'].ref));\n if (info.fields['prodCtx']?.ref !== undefined)\n upstreamContexts.push(Pl.unwrapHolder(this.tx, info.fields['prodCtx'].ref));\n });\n return createBContextFromUpstreams(this.tx, upstreamContexts);\n }\n\n private exportCtx(ctx: AnyRef): AnyRef {\n return exportContext(this.tx, Pl.unwrapHolder(this.tx, this.ctxExportTplHolder), ctx);\n }\n\n private renderStagingFor(blockId: string) {\n this.resetStaging(blockId);\n\n const info = this.getBlockInfo(blockId);\n\n const ctx = this.createStagingCtx(this.getStagingGraph().nodes.get(blockId)!.upstream);\n\n if (this.getBlock(blockId).renderingMode !== 'Heavy') throw new Error('not supported yet');\n\n const tpl = info.getTemplate(this.tx);\n\n const results = createRenderHeavyBlock(this.tx, tpl, {\n args: info.fields.currentArgs!.ref!,\n blockId: this.tx.createValue(Pl.JsonString, JSON.stringify(blockId)),\n isProduction: this.tx.createValue(Pl.JsonBool, JSON.stringify(false)),\n context: ctx,\n });\n\n this.setBlockField(\n blockId,\n 'stagingCtx',\n Pl.wrapInEphHolder(this.tx, results.context),\n 'NotReady',\n );\n\n this.setBlockField(blockId, 'stagingUiCtx', this.exportCtx(results.context), 'NotReady');\n\n this.setBlockField(blockId, 'stagingOutput', results.result, 'NotReady');\n }\n\n private renderProductionFor(blockId: string) {\n this.resetProduction(blockId);\n\n const info = this.getBlockInfo(blockId);\n\n const ctx = this.createProdCtx(this.getPendingProductionGraph().nodes.get(blockId)!.upstream);\n\n if (this.getBlock(blockId).renderingMode === 'Light')\n throw new Error('Can\\'t render production for light block.');\n\n const tpl = info.getTemplate(this.tx);\n\n const results = createRenderHeavyBlock(this.tx, tpl, {\n args: info.fields.currentArgs!.ref!,\n blockId: this.tx.createValue(Pl.JsonString, JSON.stringify(blockId)),\n isProduction: this.tx.createValue(Pl.JsonBool, JSON.stringify(true)),\n context: ctx,\n });\n this.setBlockField(\n blockId,\n 'prodCtx',\n Pl.wrapInEphHolder(this.tx, results.context),\n 'NotReady',\n );\n this.setBlockField(blockId, 'prodUiCtx', this.exportCtx(results.context), 'NotReady');\n this.setBlockField(blockId, 'prodOutput', results.result, 'NotReady');\n\n // saving inputs for which we rendered the production\n this.setBlockFieldObj(blockId, 'prodArgs', info.fields.currentArgs!);\n\n // removing block from limbo as we juts rendered fresh production for it\n if (this.blocksInLimbo.delete(blockId)) this.renderingStateChanged = true;\n }\n\n //\n // Structure changes\n //\n\n private initializeNewBlock(blockId: string, spec: NewBlockSpec): void {\n const info = new BlockInfo(blockId, {}, extractConfig(spec.blockPack.config), spec.blockPack.source);\n this.blockInfos.set(blockId, info);\n\n // block pack\n const bp = createBlockPack(this.tx, spec.blockPack);\n this.setBlockField(blockId, 'blockPack', Pl.wrapInHolder(this.tx, bp), 'NotReady');\n\n // settings\n this.setBlockFieldObj(\n blockId,\n 'blockSettings',\n this.createJsonFieldValue(InitialBlockSettings),\n );\n\n // args\n this.setBlockFieldObj(blockId, 'currentArgs', this.createJsonFieldValueByContent(spec.args));\n\n // uiState\n this.setBlockFieldObj(blockId, 'uiState', this.createJsonFieldValueByContent(spec.uiState ?? '{}'));\n\n // checking structure\n info.check();\n }\n\n private getFieldNamesToDuplicate(blockId: string): Set<ProjectField['fieldName']> {\n const fields = this.getBlockInfo(blockId).fields;\n\n const diff = <T>(setA: Set<T>, setB: Set<T>): Set<T> => new Set([...setA].filter((x) => !setB.has(x)));\n\n // Check if we can safely move to limbo (both core production fields are ready)\n if (fields.prodOutput?.status === 'Ready' && fields.prodCtx?.status === 'Ready') {\n if (this.blocksInLimbo.has(blockId))\n // we are already in limbo\n return FieldsToDuplicate;\n\n return diff(FieldsToDuplicate, new Set([\n 'prodOutputPrevious',\n 'prodCtxPrevious',\n 'prodUiCtxPrevious',\n ]));\n } else {\n return diff(FieldsToDuplicate, new Set([\n 'prodOutput',\n 'prodCtx',\n 'prodUiCtx',\n 'prodArgs',\n 'prodOutputPrevious',\n 'prodCtxPrevious',\n 'prodUiCtxPrevious',\n ]));\n }\n }\n\n private initializeBlockDuplicate(blockId: string, originalBlockInfo: BlockInfo) {\n const info = new BlockInfo(\n blockId,\n {},\n originalBlockInfo.config,\n originalBlockInfo.source,\n );\n\n this.blockInfos.set(blockId, info);\n\n const fieldNamesToDuplicate = this.getFieldNamesToDuplicate(blockId);\n\n // Copy all fields from original block to new block by sharing references\n for (const [fieldName, fieldState] of Object.entries(originalBlockInfo.fields)) {\n if (fieldNamesToDuplicate.has(fieldName as ProjectField['fieldName']) && fieldState && fieldState.ref) {\n this.setBlockFieldObj(blockId, fieldName as keyof BlockFieldStates, {\n ref: fieldState.ref,\n status: fieldState.status,\n value: fieldState.value,\n });\n }\n }\n\n this.resetOrLimboProduction(blockId);\n\n info.check();\n }\n\n /** Very generic method, better check for more specialized case-specific methods first. */\n public updateStructure(\n newStructure: ProjectStructure,\n newBlockInitializer: (blockId: string) => void = NoNewBlocks,\n ): void {\n const currentStagingGraph = this.getStagingGraph();\n const currentActualProductionGraph = this.getActualProductionGraph();\n\n const newStagingGraph = stagingGraph(newStructure);\n\n const stagingDiff = graphDiff(currentStagingGraph, newStagingGraph);\n\n // removing blocks\n for (const blockId of stagingDiff.onlyInA) {\n const { fields } = this.getBlockInfo(blockId);\n this.deleteBlockFields(blockId, ...(Object.keys(fields) as ProjectField['fieldName'][]));\n this.blockInfos.delete(blockId);\n if (this.blocksInLimbo.delete(blockId)) this.renderingStateChanged = true;\n }\n\n // creating new blocks\n for (const blockId of stagingDiff.onlyInB) {\n newBlockInitializer(blockId);\n }\n\n // resetting stagings affected by topology change\n for (const blockId of stagingDiff.different) this.resetStaging(blockId);\n\n // new actual production graph without new blocks\n const newActualProductionGraph = productionGraph(\n newStructure,\n (blockId) => this.getProductionGraphBlockInfo(blockId, true),\n );\n\n const prodDiff = graphDiff(currentActualProductionGraph, newActualProductionGraph);\n\n // applying changes due to topology change in production to affected nodes and\n // all their downstreams\n currentActualProductionGraph.traverse('downstream', [...prodDiff.different], (node) => {\n this.resetOrLimboProduction(node.id);\n });\n\n if (\n stagingDiff.onlyInB.size > 0\n || stagingDiff.onlyInA.size > 0\n || stagingDiff.different.size > 0\n )\n this.resetStagingRefreshTimestamp();\n\n this.struct = newStructure;\n this.structureChanged = true;\n this.stagingGraph = undefined;\n this.pendingProductionGraph = undefined;\n this.actualProductionGraph = undefined;\n\n this.updateLastModified();\n }\n\n //\n // Structure change helpers\n //\n\n public addBlock(block: Block, spec: NewBlockSpec, before?: string): void {\n const newStruct = this.structure; // copy current structure\n if (before === undefined) {\n // adding as a very last block\n newStruct.groups[newStruct.groups.length - 1].blocks.push(block);\n } else {\n let done = false;\n for (const group of newStruct.groups) {\n const idx = group.blocks.findIndex((b) => b.id === before);\n if (idx < 0) continue;\n group.blocks.splice(idx, 0, block);\n done = true;\n break;\n }\n if (!done) throw new Error(`Can't find element with id: ${before}`);\n }\n this.updateStructure(newStruct, (blockId) => {\n if (blockId !== block.id) throw new Error('Unexpected');\n this.initializeNewBlock(blockId, spec);\n });\n }\n\n /**\n * Duplicates an existing block by copying all its fields and structure.\n * This method creates a deep copy of the block at the mutator level.\n *\n * @param originalBlockId id of the block to duplicate\n * @param newBlockId id for the new duplicated block\n * @param after id of the block to insert new block after\n */\n public duplicateBlock(originalBlockId: string, newBlockId: string, after?: string): void {\n // Get the original block from structure\n const originalBlock = this.getBlock(originalBlockId);\n const originalBlockInfo = this.getBlockInfo(originalBlockId);\n\n // Create new block in structure\n const newBlock: Block = {\n id: newBlockId,\n label: originalBlock.label,\n renderingMode: originalBlock.renderingMode,\n };\n\n // Add the new block to structure\n const newStruct = this.structure; // copy current structure\n if (after === undefined) {\n // adding as a very last block\n newStruct.groups[newStruct.groups.length - 1].blocks.push(newBlock);\n } else {\n let done = false;\n for (const group of newStruct.groups) {\n const idx = group.blocks.findIndex((b) => b.id === after);\n if (idx < 0) continue;\n group.blocks.splice(idx + 1, 0, newBlock);\n done = true;\n break;\n }\n if (!done) throw new Error(`Can't find element with id: ${after}`);\n }\n\n this.updateStructure(newStruct, (blockId) => {\n if (blockId !== newBlockId) throw new Error('Unexpected');\n this.initializeBlockDuplicate(blockId, originalBlockInfo);\n });\n }\n\n public deleteBlock(blockId: string): void {\n const newStruct = this.structure; // copy current structure\n let done = false;\n for (const group of newStruct.groups) {\n const idx = group.blocks.findIndex((b) => b.id === blockId);\n if (idx < 0) continue;\n group.blocks.splice(idx, 1);\n done = true;\n break;\n }\n if (!done) throw new Error(`Can't find element with id: ${blockId}`);\n this.updateStructure(newStruct);\n }\n\n //\n // Block-pack migration\n //\n\n public migrateBlockPack(blockId: string, spec: BlockPackSpecPrepared, newArgsAndUiState?: ArgsAndUiState): void {\n const info = this.getBlockInfo(blockId);\n\n this.setBlockField(\n blockId,\n 'blockPack',\n Pl.wrapInHolder(this.tx, createBlockPack(this.tx, spec)),\n 'NotReady',\n );\n\n if (newArgsAndUiState !== undefined) {\n // this will also reset all downstream stagings\n this.setStates([{ blockId, args: newArgsAndUiState.args, uiState: newArgsAndUiState.uiState }]);\n } else {\n // resetting staging outputs for all downstream blocks\n this.getStagingGraph().traverse('downstream', [blockId], ({ id }) => this.resetStaging(id));\n }\n\n // also reset or limbo all downstream productions\n if (info.productionRendered)\n this.getActualProductionGraph().traverse('downstream', [blockId], ({ id }) =>\n this.resetOrLimboProduction(id),\n );\n\n this.updateLastModified();\n }\n\n //\n // Render\n //\n\n public renderProduction(blockIds: string[], addUpstreams: boolean = false): Set<string> {\n const blockIdsSet = new Set(blockIds);\n\n const prodGraph = this.getPendingProductionGraph();\n if (addUpstreams)\n // adding all upstreams automatically\n prodGraph.traverse('upstream', blockIds, (node) => {\n blockIdsSet.add(node.id);\n });\n else // checking that targets contain all upstreams\n for (const blockId of blockIdsSet) {\n const node = prodGraph.nodes.get(blockId);\n if (node === undefined) throw new Error(`Can't find block with id: ${blockId}`);\n for (const upstream of node.upstream)\n if (!blockIdsSet.has(upstream))\n throw new Error('Can\\'t render blocks not including all upstreams.');\n }\n\n // traversing in topological order and rendering target blocks\n const rendered = new Set<string>();\n for (const block of allBlocks(this.structure)) {\n if (!blockIdsSet.has(block.id)) continue;\n\n let render\n = this.getBlockInfo(block.id).requireProductionRendering || this.blocksInLimbo.has(block.id);\n\n if (!render)\n for (const upstream of prodGraph.nodes.get(block.id)!.upstream)\n if (rendered.has(upstream)) {\n render = true;\n break;\n }\n\n if (render) {\n this.renderProductionFor(block.id);\n rendered.add(block.id);\n }\n }\n\n const renderedArray = [...rendered];\n\n // sending to limbo all downstream blocks\n prodGraph.traverse('downstream', renderedArray, (node) => {\n if (rendered.has(node.id))\n // don't send to limbo blocks that were just rendered\n return;\n this.resetOrLimboProduction(node.id);\n });\n\n // resetting staging outputs for all downstream blocks\n this.getStagingGraph().traverse('downstream', renderedArray, ({ id }) => {\n // don't reset staging of the first rendered block\n if (renderedArray[0] !== id) this.resetStaging(id);\n });\n\n if (rendered.size > 0) this.updateLastModified();\n\n return rendered;\n }\n\n /** Stops running blocks from the list and modify states of other blocks\n * accordingly */\n public stopProduction(...blockIds: string[]) {\n const activeProdGraph = this.getActualProductionGraph();\n\n // we will stop all blocks listed in request and all their downstreams\n const queue = new Denque(blockIds);\n const queued = new Set(blockIds);\n const stopped: string[] = [];\n\n while (!queue.isEmpty()) {\n const blockId = queue.shift()!;\n const fields = this.getBlockInfo(blockId).fields;\n\n if (fields.prodOutput?.status === 'Ready' && fields.prodCtx?.status === 'Ready')\n // skipping finished blocks\n continue;\n\n if (this.deleteBlockFields(blockId, 'prodOutput', 'prodCtx', 'prodUiCtx', 'prodArgs')) {\n // was actually stopped\n stopped.push(blockId);\n\n // will try to stop all its downstreams\n for (const downstream of activeProdGraph.traverseIdsExcludingRoots('downstream', blockId)) {\n if (queued.has(downstream)) continue;\n queue.push(downstream);\n queued.add(downstream);\n }\n }\n }\n\n // blocks under stopped blocks, but still having results, goes to limbo\n for (const blockId of activeProdGraph.traverseIdsExcludingRoots('downstream', ...stopped))\n this.resetOrLimboProduction(blockId);\n }\n\n private traverseWithStagingLag(cb: (blockId: string, lag: number) => void) {\n const lags = new Map<string, number>();\n const stagingGraph = this.getStagingGraph();\n stagingGraph.nodes.forEach((node) => {\n const info = this.getBlockInfo(node.id);\n let lag = info.stagingRendered ? 0 : 1;\n node.upstream.forEach((upstream) => {\n const upstreamLag = lags.get(upstream)!;\n if (upstreamLag === 0) return;\n lag = Math.max(upstreamLag + 1, lag);\n });\n cb(node.id, lag);\n lags.set(node.id, lag);\n });\n }\n\n /** @param stagingRenderingRate rate in blocks per second */\n private refreshStagings(stagingRenderingRate?: number) {\n const elapsed = Date.now() - this.renderingState.stagingRefreshTimestamp;\n const lagThreshold\n = stagingRenderingRate === undefined\n ? undefined\n : 1 + Math.max(0, (elapsed * stagingRenderingRate) / 1000);\n let rendered = 0;\n this.traverseWithStagingLag((blockId, lag) => {\n if (lag === 0)\n // meaning staging already rendered\n return;\n if (lagThreshold === undefined || lag <= lagThreshold) {\n this.renderStagingFor(blockId);\n rendered++;\n }\n });\n if (rendered > 0) this.resetStagingRefreshTimestamp();\n }\n\n //\n // Meta\n //\n\n /** Updates project metadata */\n public setMeta(meta: ProjectMeta): void {\n this.meta = meta;\n this.metaChanged = true;\n this.updateLastModified();\n }\n\n //\n // Maintenance\n //\n\n /** @param stagingRenderingRate rate in blocks per second */\n public doRefresh(stagingRenderingRate?: number) {\n this.refreshStagings(stagingRenderingRate);\n this.blockInfos.forEach((blockInfo) => {\n if (\n blockInfo.fields.prodCtx?.status === 'Ready'\n && blockInfo.fields.prodOutput?.status === 'Ready'\n )\n this.deleteBlockFields(\n blockInfo.id,\n 'prodOutputPrevious',\n 'prodCtxPrevious',\n 'prodUiCtxPrevious',\n );\n if (\n blockInfo.fields.stagingCtx?.status === 'Ready'\n && blockInfo.fields.stagingOutput?.status === 'Ready'\n )\n this.deleteBlockFields(\n blockInfo.id,\n 'stagingOutputPrevious',\n 'stagingCtxPrevious',\n 'stagingUiCtxPrevious',\n );\n });\n }\n\n private assignAuthorMarkers() {\n const markerStr = this.author ? JSON.stringify(this.author) : undefined;\n\n for (const blockId of this.blocksWithChangedInputs)\n if (markerStr === undefined) this.tx.deleteKValue(this.rid, blockArgsAuthorKey(blockId));\n else this.tx.setKValue(this.rid, blockArgsAuthorKey(blockId), markerStr);\n\n if (this.metaChanged || this.structureChanged) {\n if (markerStr === undefined) this.tx.deleteKValue(this.rid, ProjectStructureAuthorKey);\n else this.tx.setKValue(this.rid, ProjectStructureAuthorKey, markerStr);\n }\n }\n\n public save() {\n if (!this.wasModified) return;\n\n if (this.lastModifiedChanged)\n this.tx.setKValue(this.rid, ProjectLastModifiedTimestamp, JSON.stringify(this.lastModified));\n\n if (this.structureChanged)\n this.tx.setKValue(this.rid, ProjectStructureKey, JSON.stringify(this.struct));\n\n if (this.renderingStateChanged)\n this.tx.setKValue(\n this.rid,\n BlockRenderingStateKey,\n JSON.stringify({\n ...this.renderingState,\n blocksInLimbo: [...this.blocksInLimbo],\n } as ProjectRenderingState),\n );\n\n if (this.metaChanged) this.tx.setKValue(this.rid, ProjectMetaKey, JSON.stringify(this.meta));\n\n this.assignAuthorMarkers();\n }\n\n public static async load(\n projectHelper: ProjectHelper,\n tx: PlTransaction,\n rid: ResourceId,\n author?: AuthorMarker,\n ): Promise<ProjectMutator> {\n //\n // Sending initial requests to read project state (start of round-trip #1)\n //\n\n const fullResourceStateP = tx.getResourceData(rid, true);\n const schemaP = tx.getKValueJson<string>(rid, SchemaVersionKey);\n const lastModifiedP = tx.getKValueJson<number>(rid, ProjectLastModifiedTimestamp);\n const metaP = tx.getKValueJson<ProjectMeta>(rid, ProjectMetaKey);\n const structureP = tx.getKValueJson<ProjectStructure>(rid, ProjectStructureKey);\n const renderingStateP = tx.getKValueJson<ProjectRenderingState>(rid, BlockRenderingStateKey);\n\n const fullResourceState = await fullResourceStateP;\n\n // loading field information\n const blockInfoStates = new Map<string, BlockInfoState>();\n for (const f of fullResourceState.fields) {\n const projectField = parseProjectField(f.name);\n\n // processing only fields with known structure\n if (projectField === undefined) continue;\n\n let info = blockInfoStates.get(projectField.blockId);\n if (info === undefined) {\n info = {\n id: projectField.blockId,\n fields: {},\n };\n blockInfoStates.set(projectField.blockId, info);\n }\n\n info.fields[projectField.fieldName] = isNullResourceId(f.value)\n ? { modCount: 0 }\n : { modCount: 0, ref: f.value };\n }\n\n //\n // Roundtrip #1 not yet finished, but as soon as field list is received,\n // we can start sending requests to read states of referenced resources\n // (start of round-trip #2)\n //\n\n const blockFieldRequests: [BlockInfoState, ProjectField['fieldName'], BlockFieldState, Promise<BasicResourceData | ResourceData>][] = [];\n blockInfoStates.forEach((info) => {\n const fields = info.fields;\n for (const [fName, state] of Object.entries(fields)) {\n if (state.ref === undefined) continue;\n if (!isResource(state.ref) || isResourceRef(state.ref))\n throw new Error('unexpected behaviour');\n const fieldName = fName as ProjectField['fieldName'];\n blockFieldRequests.push([\n info, fieldName,\n state, tx.getResourceData(state.ref, fieldName == 'blockPack')]);\n }\n });\n\n // loading jsons\n const [\n schema,\n lastModified,\n meta,\n structure,\n { stagingRefreshTimestamp, blocksInLimbo },\n ] = await Promise.all([\n schemaP,\n lastModifiedP,\n metaP,\n structureP,\n renderingStateP,\n ]);\n\n // Checking schema version of the project\n if (schema !== SchemaVersionCurrent) {\n if (Number(schema) < Number(SchemaVersionCurrent))\n throw new UiError(`Can't perform this action on this project because it has older schema. Try (re)loading the project to update it.`);\n else\n throw new UiError(`Can't perform this action on this project because it has newer schema. Upgrade your desktop app to the latest version.`);\n }\n\n //\n // <- at this point we have all the responses from round-trip #1\n //\n\n //\n // Receiving responses from round-trip #2 and sending requests to read block pack descriptions\n // (start of round-trip #3)\n //\n\n const blockPackRequests: [BlockInfoState, Promise<BasicResourceData>][] = [];\n for (const [info, fieldName, state, response] of blockFieldRequests) {\n const result = await response;\n state.value = result.data;\n if (isNotNullResourceId(result.error)) state.status = 'Error';\n else if (result.resourceReady || isNotNullResourceId(result.originalResourceId))\n state.status = 'Ready';\n else state.status = 'NotReady';\n\n // For block pack we need to traverse the ref field from the resource data\n if (fieldName === 'blockPack') {\n const refField = (result as ResourceData).fields.find((f) => f.name === Pl.HolderRefField);\n if (refField === undefined)\n throw new Error('Block pack ref field is missing');\n blockPackRequests.push([info, tx.getResourceData(ensureResourceIdNotNull(refField.value), false)]);\n }\n }\n\n //\n // <- at this point we have all the responses from round-trip #2\n //\n\n for (const [info, response] of blockPackRequests) {\n const result = await response;\n const bpInfo = cachedDeserialize<BlockPackInfo>(notEmpty(result.data));\n info.blockConfig = extractConfig(bpInfo.config);\n info.blockPack = bpInfo.source;\n }\n\n //\n // <- at this point we have all the responses from round-trip #3\n //\n\n // loading ctx export template to check if we already have cached materialized template in our project\n const ctxExportTplEnvelope = await getPreparedExportTemplateEnvelope();\n\n // expected field name\n const ctxExportTplCacheFieldName = getServiceTemplateField(ctxExportTplEnvelope.hash);\n const ctxExportTplField = fullResourceState.fields.find(\n (f) => f.name === ctxExportTplCacheFieldName,\n );\n let ctxExportTplHolder: AnyResourceRef;\n if (ctxExportTplField !== undefined)\n ctxExportTplHolder = ensureResourceIdNotNull(ctxExportTplField.value);\n else {\n ctxExportTplHolder = Pl.wrapInHolder(tx, loadTemplate(tx, ctxExportTplEnvelope.spec));\n tx.createField(\n field(rid, getServiceTemplateField(ctxExportTplEnvelope.hash)),\n 'Dynamic',\n ctxExportTplHolder,\n );\n }\n\n const renderingState = { stagingRefreshTimestamp };\n const blocksInLimboSet = new Set(blocksInLimbo);\n\n const blockInfos = new Map<string, BlockInfo>();\n blockInfoStates.forEach(({ id, fields, blockConfig, blockPack }) => blockInfos.set(id,\n new BlockInfo(id, fields, notEmpty(blockConfig), notEmpty(blockPack))));\n\n // check consistency of project state\n const blockInStruct = new Set<string>();\n for (const b of allBlocks(structure)) {\n if (!blockInfos.has(b.id))\n throw new Error(`Inconsistent project structure: no inputs for ${b.id}`);\n blockInStruct.add(b.id);\n }\n blockInfos.forEach((info) => {\n if (!blockInStruct.has(info.id))\n throw new Error(`Inconsistent project structure: no structure entry for ${info.id}`);\n // checking structure\n info.check();\n });\n\n const prj = new ProjectMutator(\n rid,\n tx,\n author,\n schema,\n lastModified,\n meta,\n structure,\n renderingState,\n blocksInLimboSet,\n blockInfos,\n ctxExportTplHolder,\n projectHelper,\n );\n\n prj.fixProblemsAndMigrate();\n\n return prj;\n }\n}\n\nexport interface ProjectState {\n schema: string;\n structure: ProjectStructure;\n renderingState: Omit<ProjectRenderingState, 'blocksInLimbo'>;\n blocksInLimbo: Set<string>;\n blockInfos: Map<string, BlockInfo>;\n}\n\nexport async function createProject(\n tx: PlTransaction,\n meta: ProjectMeta = InitialBlockMeta,\n): Promise<AnyResourceRef> {\n const prj = tx.createEphemeral(ProjectResourceType);\n tx.lock(prj);\n const ts = String(Date.now());\n tx.setKValue(prj, SchemaVersionKey, JSON.stringify(SchemaVersionCurrent));\n tx.setKValue(prj, ProjectCreatedTimestamp, ts);\n tx.setKValue(prj, ProjectLastModifiedTimestamp, ts);\n tx.setKValue(prj, ProjectMetaKey, JSON.stringify(meta));\n tx.setKValue(prj, ProjectStructureKey, JSON.stringify(InitialBlockStructure));\n tx.setKValue(prj, BlockRenderingStateKey, JSON.stringify(InitialProjectRenderingState));\n const ctxExportTplEnvelope = await getPreparedExportTemplateEnvelope();\n tx.createField(\n field(prj, getServiceTemplateField(ctxExportTplEnvelope.hash)),\n 'Dynamic',\n Pl.wrapInHolder(tx, loadTemplate(tx, ctxExportTplEnvelope.spec)),\n );\n return prj;\n}\n\nexport async function withProject<T>(\n projectHelper: ProjectHelper,\n txOrPl: PlTransaction | PlClient,\n rid: ResourceId,\n cb: (p: ProjectMutator) => T | Promise<T>,\n ops?: Partial<TxOps>,\n): Promise<T> {\n return withProjectAuthored(projectHelper, txOrPl, rid, undefined, cb, ops);\n}\n\nexport async function withProjectAuthored<T>(\n projectHelper: ProjectHelper,\n txOrPl: PlTransaction | PlClient,\n rid: ResourceId,\n author: AuthorMarker | undefined,\n cb: (p: ProjectMutator) => T | Promise<T>,\n ops: Partial<TxOps> = {},\n): Promise<T> {\n if (txOrPl instanceof PlClient) {\n return await txOrPl.withWriteTx('ProjectAction' + (ops.name ? `: ${ops.name}` : ''), async (tx) => {\n const mut = await ProjectMutator.load(projectHelper, tx, rid, author);\n const result = await cb(mut);\n if (!mut.wasModified)\n // skipping save and commit altogether if no modifications were actually made\n return result;\n mut.save();\n await tx.commit();\n if (getDebugFlags().logProjectMutationStat) console.log(JSON.stringify(tx.stat));\n return result;\n }, ops);\n } else {\n const mut = await ProjectMutator.load(projectHelper, txOrPl, rid, author);\n const result = await cb(mut);\n mut.save();\n return result;\n }\n}\n"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"driver.cjs","sources":["../../src/pool/driver.ts"],"sourcesContent":["import {\n mapDataInfo,\n isDataInfo,\n ensureError,\n PFrameDriverError,\n isAbortError,\n type LocalBlobHandleAndSize,\n type RemoteBlobHandleAndSize,\n type RemoteBlobHandle,\n type ContentHandler,\n type PColumnSpec,\n type PColumnDataUniversal,\n} from '@platforma-sdk/model';\nimport { PFrameInternal } from '@milaboratories/pl-model-middle-layer';\nimport {\n emptyDir,\n RefCountPoolBase,\n type PoolEntry,\n type MiLogger,\n} from '@milaboratories/ts-helpers';\nimport type { DownloadDriver } from '@milaboratories/pl-drivers';\nimport {\n isPlTreeNodeAccessor,\n type PlTreeEntry,\n type PlTreeNodeAccessor,\n} from '@milaboratories/pl-tree';\nimport type {\n Computable,\n ComputableStableDefined,\n} from '@milaboratories/computable';\nimport {\n makeJsonDataInfo,\n AbstractPFrameDriver,\n AbstractPFrameDriverOpsDefaults,\n type AbstractInternalPFrameDriver,\n type AbstractPFrameDriverOps,\n type LocalBlobProvider,\n type RemoteBlobProvider,\n} from '@milaboratories/pf-driver';\nimport { HttpHelpers } from '@milaboratories/pframes-rs-node';\nimport path from 'node:path';\nimport { Readable } from 'node:stream';\nimport {\n parseDataInfoResource,\n traverseParquetChunkResource,\n} from './data';\n\nfunction makeBlobId(res: PlTreeEntry): PFrameInternal.PFrameBlobId {\n return String(res.rid);\n}\n\ntype LocalBlob = ComputableStableDefined<LocalBlobHandleAndSize>;\nclass LocalBlobProviderImpl\n extends RefCountPoolBase<PlTreeEntry, PFrameInternal.PFrameBlobId, LocalBlob>\n implements LocalBlobProvider<PlTreeEntry> {\n constructor(\n private readonly blobDriver: DownloadDriver,\n private readonly logger: PFrameInternal.Logger,\n ) {\n super();\n }\n\n protected calculateParamsKey(params: PlTreeEntry): PFrameInternal.PFrameBlobId {\n return makeBlobId(params);\n }\n\n protected createNewResource(params: PlTreeEntry, _key: PFrameInternal.PFrameBlobId): LocalBlob {\n return this.blobDriver.getDownloadedBlob(params);\n }\n\n public getByKey(blobId: PFrameInternal.PFrameBlobId): LocalBlob {\n const resource = super.tryGetByKey(blobId);\n if (!resource) throw new PFrameDriverError(`Local blob with id ${blobId} not found.`);\n return resource;\n }\n\n public makeDataSource(signal: AbortSignal): Omit<PFrameInternal.PFrameDataSourceV2, 'parquetServer'> {\n return {\n preloadBlob: async (blobIds: PFrameInternal.PFrameBlobId[]) => {\n try {\n await Promise.all(blobIds.map((blobId) => this.getByKey(blobId).awaitStableFullValue(signal)));\n } catch (err: unknown) {\n if (!isAbortError(err)) throw err;\n }\n },\n resolveBlobContent: async (blobId: PFrameInternal.PFrameBlobId) => {\n const computable = this.getByKey(blobId);\n const blob = await computable.awaitStableValue(signal);\n return await this.blobDriver.getContent(blob.handle, { signal });\n },\n };\n }\n}\n\ntype RemoteBlob = Computable<RemoteBlobHandleAndSize>;\nclass RemoteBlobPool\n extends RefCountPoolBase<PlTreeEntry, PFrameInternal.PFrameBlobId, RemoteBlob> {\n constructor(\n private readonly blobDriver: DownloadDriver,\n private readonly logger: PFrameInternal.Logger,\n ) {\n super();\n }\n\n protected calculateParamsKey(params: PlTreeEntry): PFrameInternal.PFrameBlobId {\n return makeBlobId(params);\n }\n\n protected createNewResource(params: PlTreeEntry, _key: PFrameInternal.PFrameBlobId): RemoteBlob {\n return this.blobDriver.getOnDemandBlob(params);\n }\n\n public getByKey(blobId: PFrameInternal.PFrameBlobId): RemoteBlob {\n const resource = super.tryGetByKey(blobId);\n if (!resource) throw new PFrameDriverError(`Remote blob with id ${blobId} not found.`);\n return resource;\n }\n\n public async withContent<T>(\n handle: RemoteBlobHandle,\n options: {\n range: PFrameInternal.FileRange;\n signal: AbortSignal;\n handler: ContentHandler<T>;\n },\n ): Promise<T> {\n return await this.blobDriver.withContent(handle, {\n range: {\n from: options.range.start,\n to: options.range.end + 1,\n },\n signal: options.signal,\n handler: options.handler,\n });\n }\n}\n\ninterface BlobStoreOptions extends PFrameInternal.ObjectStoreOptions {\n remoteBlobProvider: RemoteBlobPool;\n};\n\nclass BlobStore extends PFrameInternal.BaseObjectStore {\n private readonly remoteBlobProvider: RemoteBlobPool;\n\n constructor(options: BlobStoreOptions) {\n super(options);\n this.remoteBlobProvider = options.remoteBlobProvider;\n }\n\n public override async request(\n filename: PFrameInternal.ParquetFileName,\n params: {\n method: PFrameInternal.HttpMethod;\n range?: PFrameInternal.HttpRange;\n signal: AbortSignal;\n callback: (response: PFrameInternal.ObjectStoreResponse) => Promise<void>;\n },\n ): Promise<void> {\n const blobId = filename.slice(0, -PFrameInternal.ParquetExtension.length);\n const respond = async (response: PFrameInternal.ObjectStoreResponse): Promise<void> => {\n try {\n await params.callback(response);\n } catch (error: unknown) {\n this.logger('warn',\n `PFrames blob store received unhandled rejection from HTTP handler: ${ensureError(error)}`,\n );\n }\n };\n\n try {\n const computable = this.remoteBlobProvider.tryGetByKey(blobId);\n if (!computable) return await respond({ type: 'NotFound' });\n\n let blob: RemoteBlobHandleAndSize;\n try {\n blob = await computable.getValue();\n } catch (error: unknown) {\n this.logger('error',\n `PFrames blob store failed to get blob from computable: ${ensureError(error)}`,\n );\n return await respond({ type: 'InternalError' });\n }\n params.signal.throwIfAborted();\n\n const translatedRange = this.translate(blob.size, params.range);\n if (!translatedRange) {\n return await respond({\n type: 'RangeNotSatisfiable',\n size: blob.size,\n });\n }\n\n if (params.method === 'HEAD') {\n return await respond({\n type: 'Ok',\n size: blob.size,\n range: translatedRange,\n });\n }\n\n this.logger('info',\n `PFrames blob store requesting content for ${blobId}, `\n + `range [${translatedRange.start}..=${translatedRange.end}]`,\n );\n return await this.remoteBlobProvider.withContent(blob.handle, {\n range: translatedRange,\n signal: params.signal,\n handler: async (data) => {\n return await respond({\n type: 'Ok',\n size: blob.size,\n range: translatedRange,\n // eslint-disable-next-line n/no-unsupported-features/node-builtins\n data: Readable.fromWeb(data),\n });\n },\n });\n } catch (error: unknown) {\n if (!isAbortError(error)) {\n this.logger('warn',\n `PFrames blob store unhandled error: ${ensureError(error)}`,\n );\n }\n return await respond({ type: 'InternalError' });\n }\n }\n}\n\nclass RemoteBlobProviderImpl implements RemoteBlobProvider<PlTreeEntry> {\n constructor(\n private readonly pool: RemoteBlobPool,\n private readonly server: PFrameInternal.HttpServer,\n ) {}\n\n public static async init(\n blobDriver: DownloadDriver,\n logger: PFrameInternal.Logger,\n serverOptions: Omit<PFrameInternal.HttpServerOptions, 'handler'>,\n ): Promise<RemoteBlobProviderImpl> {\n const pool = new RemoteBlobPool(blobDriver, logger);\n const store = new BlobStore({ remoteBlobProvider: pool, logger });\n\n const handler = HttpHelpers.createRequestHandler({ store });\n const server = await HttpHelpers.createHttpServer({ ...serverOptions, handler });\n logger('info', `PFrames HTTP server started on ${server.info.url}`);\n\n return new RemoteBlobProviderImpl(pool, server);\n }\n\n public acquire(params: PlTreeEntry): PoolEntry {\n return this.pool.acquire(params);\n }\n\n public httpServerInfo(): PFrameInternal.HttpServerInfo {\n return this.server.info;\n }\n\n async [Symbol.asyncDispose](): Promise<void> {\n await this.server.stop();\n }\n}\n\nexport interface InternalPFrameDriver\n extends AbstractInternalPFrameDriver<PColumnDataUniversal<PlTreeNodeAccessor>> {};\n\nexport type PFrameDriverOps = AbstractPFrameDriverOps & {\n /** Port to run parquet HTTP server on. */\n parquetServerPort: number;\n};\n\nexport const PFrameDriverOpsDefaults: PFrameDriverOps = {\n ...AbstractPFrameDriverOpsDefaults,\n parquetServerPort: 0, // 0 means that some unused port will be assigned by the OS\n};\n\nexport async function createPFrameDriver(params: {\n blobDriver: DownloadDriver;\n logger: MiLogger;\n spillPath: string;\n options: PFrameDriverOps;\n}): Promise<InternalPFrameDriver> {\n const resolvedSpillPath = path.resolve(params.spillPath);\n await emptyDir(resolvedSpillPath);\n\n const logger: PFrameInternal.Logger = (level, message) => params.logger[level](message);\n const localBlobProvider = new LocalBlobProviderImpl(params.blobDriver, logger);\n const remoteBlobProvider = await RemoteBlobProviderImpl.init(\n params.blobDriver,\n logger,\n { port: params.options.parquetServerPort },\n );\n\n const resolveDataInfo = (spec: PColumnSpec, data: PColumnDataUniversal<PlTreeNodeAccessor>) => {\n return isPlTreeNodeAccessor(data)\n ? parseDataInfoResource(data)\n : isDataInfo(data)\n ? data.type === 'ParquetPartitioned'\n ? mapDataInfo(data, (a) => traverseParquetChunkResource(a))\n : mapDataInfo(data, (a) => a.persist())\n : makeJsonDataInfo(spec, data);\n };\n\n return new AbstractPFrameDriver({\n logger,\n localBlobProvider,\n remoteBlobProvider,\n spillPath: resolvedSpillPath,\n options: params.options,\n resolveDataInfo,\n });\n}\n"],"names":["RefCountPoolBase","PFrameDriverError","isAbortError","PFrameInternal","ensureError","Readable","HttpHelpers","AbstractPFrameDriverOpsDefaults","emptyDir","data","isPlTreeNodeAccessor","parseDataInfoResource","isDataInfo","mapDataInfo","traverseParquetChunkResource","makeJsonDataInfo","AbstractPFrameDriver"],"mappings":";;;;;;;;;;;;AA+CA,SAAS,UAAU,CAAC,GAAgB,EAAA;AAClC,IAAA,OAAO,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC;AACxB;AAGA,MAAM,qBACJ,SAAQA,0BAAqE,CAAA;AAG1D,IAAA,UAAA;AACA,IAAA,MAAA;IAFnB,WAAA,CACmB,UAA0B,EAC1B,MAA6B,EAAA;AAE9C,QAAA,KAAK,EAAE;QAHU,IAAA,CAAA,UAAU,GAAV,UAAU;QACV,IAAA,CAAA,MAAM,GAAN,MAAM;IAGzB;AAEU,IAAA,kBAAkB,CAAC,MAAmB,EAAA;AAC9C,QAAA,OAAO,UAAU,CAAC,MAAM,CAAC;IAC3B;IAEU,iBAAiB,CAAC,MAAmB,EAAE,IAAiC,EAAA;QAChF,OAAO,IAAI,CAAC,UAAU,CAAC,iBAAiB,CAAC,MAAM,CAAC;IAClD;AAEO,IAAA,QAAQ,CAAC,MAAmC,EAAA;QACjD,MAAM,QAAQ,GAAG,KAAK,CAAC,WAAW,CAAC,MAAM,CAAC;AAC1C,QAAA,IAAI,CAAC,QAAQ;AAAE,YAAA,MAAM,IAAIC,uBAAiB,CAAC,sBAAsB,MAAM,CAAA,WAAA,CAAa,CAAC;AACrF,QAAA,OAAO,QAAQ;IACjB;AAEO,IAAA,cAAc,CAAC,MAAmB,EAAA;QACvC,OAAO;AACL,YAAA,WAAW,EAAE,OAAO,OAAsC,KAAI;AAC5D,gBAAA,IAAI;oBACF,MAAM,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,KAAK,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,oBAAoB,CAAC,MAAM,CAAC,CAAC,CAAC;gBAChG;gBAAE,OAAO,GAAY,EAAE;AACrB,oBAAA,IAAI,CAACC,kBAAY,CAAC,GAAG,CAAC;AAAE,wBAAA,MAAM,GAAG;gBACnC;YACF,CAAC;AACD,YAAA,kBAAkB,EAAE,OAAO,MAAmC,KAAI;gBAChE,MAAM,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC;gBACxC,MAAM,IAAI,GAAG,MAAM,UAAU,CAAC,gBAAgB,CAAC,MAAM,CAAC;AACtD,gBAAA,OAAO,MAAM,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,MAAM,EAAE,CAAC;YAClE,CAAC;SACF;IACH;AACD;AAGD,MAAM,cACJ,SAAQF,0BAAsE,CAAA;AAE3D,IAAA,UAAA;AACA,IAAA,MAAA;IAFnB,WAAA,CACmB,UAA0B,EAC1B,MAA6B,EAAA;AAE9C,QAAA,KAAK,EAAE;QAHU,IAAA,CAAA,UAAU,GAAV,UAAU;QACV,IAAA,CAAA,MAAM,GAAN,MAAM;IAGzB;AAEU,IAAA,kBAAkB,CAAC,MAAmB,EAAA;AAC9C,QAAA,OAAO,UAAU,CAAC,MAAM,CAAC;IAC3B;IAEU,iBAAiB,CAAC,MAAmB,EAAE,IAAiC,EAAA;QAChF,OAAO,IAAI,CAAC,UAAU,CAAC,eAAe,CAAC,MAAM,CAAC;IAChD;AAEO,IAAA,QAAQ,CAAC,MAAmC,EAAA;QACjD,MAAM,QAAQ,GAAG,KAAK,CAAC,WAAW,CAAC,MAAM,CAAC;AAC1C,QAAA,IAAI,CAAC,QAAQ;AAAE,YAAA,MAAM,IAAIC,uBAAiB,CAAC,uBAAuB,MAAM,CAAA,WAAA,CAAa,CAAC;AACtF,QAAA,OAAO,QAAQ;IACjB;AAEO,IAAA,MAAM,WAAW,CACtB,MAAwB,EACxB,OAIC,EAAA;QAED,OAAO,MAAM,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,MAAM,EAAE;AAC/C,YAAA,KAAK,EAAE;AACL,gBAAA,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,KAAK;AACzB,gBAAA,EAAE,EAAE,OAAO,CAAC,KAAK,CAAC,GAAG,GAAG,CAAC;AAC1B,aAAA;YACD,MAAM,EAAE,OAAO,CAAC,MAAM;YACtB,OAAO,EAAE,OAAO,CAAC,OAAO;AACzB,SAAA,CAAC;IACJ;AACD;AAMD,MAAM,SAAU,SAAQE,iCAAc,CAAC,eAAe,CAAA;AACnC,IAAA,kBAAkB;AAEnC,IAAA,WAAA,CAAY,OAAyB,EAAA;QACnC,KAAK,CAAC,OAAO,CAAC;AACd,QAAA,IAAI,CAAC,kBAAkB,GAAG,OAAO,CAAC,kBAAkB;IACtD;AAEgB,IAAA,MAAM,OAAO,CAC3B,QAAwC,EACxC,MAKC,EAAA;AAED,QAAA,MAAM,MAAM,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,CAACA,iCAAc,CAAC,gBAAgB,CAAC,MAAM,CAAC;AACzE,QAAA,MAAM,OAAO,GAAG,OAAO,QAA4C,KAAmB;AACpF,YAAA,IAAI;AACF,gBAAA,MAAM,MAAM,CAAC,QAAQ,CAAC,QAAQ,CAAC;YACjC;YAAE,OAAO,KAAc,EAAE;AACvB,gBAAA,IAAI,CAAC,MAAM,CAAC,MAAM,EAChB,CAAA,mEAAA,EAAsEC,iBAAW,CAAC,KAAK,CAAC,CAAA,CAAE,CAC3F;YACH;AACF,QAAA,CAAC;AAED,QAAA,IAAI;YACF,MAAM,UAAU,GAAG,IAAI,CAAC,kBAAkB,CAAC,WAAW,CAAC,MAAM,CAAC;AAC9D,YAAA,IAAI,CAAC,UAAU;gBAAE,OAAO,MAAM,OAAO,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC;AAE3D,YAAA,IAAI,IAA6B;AACjC,YAAA,IAAI;AACF,gBAAA,IAAI,GAAG,MAAM,UAAU,CAAC,QAAQ,EAAE;YACpC;YAAE,OAAO,KAAc,EAAE;AACvB,gBAAA,IAAI,CAAC,MAAM,CAAC,OAAO,EACjB,CAAA,uDAAA,EAA0DA,iBAAW,CAAC,KAAK,CAAC,CAAA,CAAE,CAC/E;gBACD,OAAO,MAAM,OAAO,CAAC,EAAE,IAAI,EAAE,eAAe,EAAE,CAAC;YACjD;AACA,YAAA,MAAM,CAAC,MAAM,CAAC,cAAc,EAAE;AAE9B,YAAA,MAAM,eAAe,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,EAAE,MAAM,CAAC,KAAK,CAAC;YAC/D,IAAI,CAAC,eAAe,EAAE;gBACpB,OAAO,MAAM,OAAO,CAAC;AACnB,oBAAA,IAAI,EAAE,qBAAqB;oBAC3B,IAAI,EAAE,IAAI,CAAC,IAAI;AAChB,iBAAA,CAAC;YACJ;AAEA,YAAA,IAAI,MAAM,CAAC,MAAM,KAAK,MAAM,EAAE;gBAC5B,OAAO,MAAM,OAAO,CAAC;AACnB,oBAAA,IAAI,EAAE,IAAI;oBACV,IAAI,EAAE,IAAI,CAAC,IAAI;AACf,oBAAA,KAAK,EAAE,eAAe;AACvB,iBAAA,CAAC;YACJ;AAEA,YAAA,IAAI,CAAC,MAAM,CAAC,MAAM,EAChB,CAAA,0CAAA,EAA6C,MAAM,CAAA,EAAA;kBACjD,CAAA,OAAA,EAAU,eAAe,CAAC,KAAK,CAAA,GAAA,EAAM,eAAe,CAAC,GAAG,CAAA,CAAA,CAAG,CAC9D;YACD,OAAO,MAAM,IAAI,CAAC,kBAAkB,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,EAAE;AAC5D,gBAAA,KAAK,EAAE,eAAe;gBACtB,MAAM,EAAE,MAAM,CAAC,MAAM;AACrB,gBAAA,OAAO,EAAE,OAAO,IAAI,KAAI;oBACtB,OAAO,MAAM,OAAO,CAAC;AACnB,wBAAA,IAAI,EAAE,IAAI;wBACV,IAAI,EAAE,IAAI,CAAC,IAAI;AACf,wBAAA,KAAK,EAAE,eAAe;;AAEtB,wBAAA,IAAI,EAAEC,oBAAQ,CAAC,OAAO,CAAC,IAAI,CAAC;AAC7B,qBAAA,CAAC;gBACJ,CAAC;AACF,aAAA,CAAC;QACJ;QAAE,OAAO,KAAc,EAAE;AACvB,YAAA,IAAI,CAACH,kBAAY,CAAC,KAAK,CAAC,EAAE;AACxB,gBAAA,IAAI,CAAC,MAAM,CAAC,MAAM,EAChB,CAAA,oCAAA,EAAuCE,iBAAW,CAAC,KAAK,CAAC,CAAA,CAAE,CAC5D;YACH;YACA,OAAO,MAAM,OAAO,CAAC,EAAE,IAAI,EAAE,eAAe,EAAE,CAAC;QACjD;IACF;AACD;AAED,MAAM,sBAAsB,CAAA;AAEP,IAAA,IAAA;AACA,IAAA,MAAA;IAFnB,WAAA,CACmB,IAAoB,EACpB,MAAiC,EAAA;QADjC,IAAA,CAAA,IAAI,GAAJ,IAAI;QACJ,IAAA,CAAA,MAAM,GAAN,MAAM;IACtB;IAEI,aAAa,IAAI,CACtB,UAA0B,EAC1B,MAA6B,EAC7B,aAAgE,EAAA;QAEhE,MAAM,IAAI,GAAG,IAAI,cAAc,CAAC,UAAU,EAAE,MAAM,CAAC;AACnD,QAAA,MAAM,KAAK,GAAG,IAAI,SAAS,CAAC,EAAE,kBAAkB,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;QAEjE,MAAM,OAAO,GAAGE,yBAAW,CAAC,oBAAoB,CAAC,EAAE,KAAK,EAAE,CAAC;AAC3D,QAAA,MAAM,MAAM,GAAG,MAAMA,yBAAW,CAAC,gBAAgB,CAAC,EAAE,GAAG,aAAa,EAAE,OAAO,EAAE,CAAC;QAChF,MAAM,CAAC,MAAM,EAAE,CAAA,+BAAA,EAAkC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAA,CAAE,CAAC;AAEnE,QAAA,OAAO,IAAI,sBAAsB,CAAC,IAAI,EAAE,MAAM,CAAC;IACjD;AAEO,IAAA,OAAO,CAAC,MAAmB,EAAA;QAChC,OAAO,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC;IAClC;IAEO,cAAc,GAAA;AACnB,QAAA,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI;IACzB;AAEA,IAAA,OAAO,MAAM,CAAC,YAAY,CAAC,GAAA;AACzB,QAAA,MAAM,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE;IAC1B;AACD;AAUM,MAAM,uBAAuB,GAAoB;AACtD,IAAA,GAAGC,wCAA+B;IAClC,iBAAiB,EAAE,CAAC;;AAGf,eAAe,kBAAkB,CAAC,MAKxC,EAAA;IACC,MAAM,iBAAiB,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,SAAS,CAAC;AACxD,IAAA,MAAMC,kBAAQ,CAAC,iBAAiB,CAAC;AAEjC,IAAA,MAAM,MAAM,GAA0B,CAAC,KAAK,EAAE,OAAO,KAAK,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC;IACvF,MAAM,iBAAiB,GAAG,IAAI,qBAAqB,CAAC,MAAM,CAAC,UAAU,EAAE,MAAM,CAAC;IAC9E,MAAM,kBAAkB,GAAG,MAAM,sBAAsB,CAAC,IAAI,CAC1D,MAAM,CAAC,UAAU,EACjB,MAAM,EACN,EAAE,IAAI,EAAE,MAAM,CAAC,OAAO,CAAC,iBAAiB,EAAE,CAC3C;AAED,IAAA,MAAM,eAAe,GAAG,CAAC,IAAiB,EAAEC,MAA8C,KAAI;QAC5F,OAAOC,2BAAoB,CAACD,MAAI;AAC9B,cAAEE,0BAAqB,CAACF,MAAI;AAC5B,cAAEG,gBAAU,CAACH,MAAI;AACf,kBAAEA,MAAI,CAAC,IAAI,KAAK;AACd,sBAAEI,iBAAW,CAACJ,MAAI,EAAE,CAAC,CAAC,KAAKK,iCAA4B,CAAC,CAAC,CAAC;AAC1D,sBAAED,iBAAW,CAACJ,MAAI,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,EAAE;AACxC,kBAAEM,yBAAgB,CAAC,IAAI,EAAEN,MAAI,CAAC;AACpC,IAAA,CAAC;IAED,OAAO,IAAIO,6BAAoB,CAAC;QAC9B,MAAM;QACN,iBAAiB;QACjB,kBAAkB;AAClB,QAAA,SAAS,EAAE,iBAAiB;QAC5B,OAAO,EAAE,MAAM,CAAC,OAAO;QACvB,eAAe;AAChB,KAAA,CAAC;AACJ;;;;;"}
1
+ {"version":3,"file":"driver.cjs","sources":["../../src/pool/driver.ts"],"sourcesContent":["import {\n mapDataInfo,\n isDataInfo,\n ensureError,\n PFrameDriverError,\n isAbortError,\n type LocalBlobHandleAndSize,\n type RemoteBlobHandleAndSize,\n type RemoteBlobHandle,\n type ContentHandler,\n type PColumnSpec,\n type PColumnDataUniversal,\n} from '@platforma-sdk/model';\nimport { PFrameInternal } from '@milaboratories/pl-model-middle-layer';\nimport {\n emptyDir,\n RefCountPoolBase,\n type PoolEntry,\n type MiLogger,\n} from '@milaboratories/ts-helpers';\nimport type { DownloadDriver } from '@milaboratories/pl-drivers';\nimport {\n isPlTreeNodeAccessor,\n type PlTreeEntry,\n type PlTreeNodeAccessor,\n} from '@milaboratories/pl-tree';\nimport type {\n Computable,\n ComputableStableDefined,\n} from '@milaboratories/computable';\nimport {\n makeJsonDataInfo,\n AbstractPFrameDriver,\n AbstractPFrameDriverOpsDefaults,\n type AbstractInternalPFrameDriver,\n type AbstractPFrameDriverOps,\n type LocalBlobProvider,\n type RemoteBlobProvider,\n} from '@milaboratories/pf-driver';\nimport { HttpHelpers } from '@milaboratories/pframes-rs-node';\nimport path from 'node:path';\nimport { Readable } from 'node:stream';\nimport {\n parseDataInfoResource,\n traverseParquetChunkResource,\n} from './data';\n\nfunction makeBlobId(res: PlTreeEntry): PFrameInternal.PFrameBlobId {\n return String(res.rid) as PFrameInternal.PFrameBlobId;\n}\n\ntype LocalBlob = ComputableStableDefined<LocalBlobHandleAndSize>;\nclass LocalBlobProviderImpl\n extends RefCountPoolBase<PlTreeEntry, PFrameInternal.PFrameBlobId, LocalBlob>\n implements LocalBlobProvider<PlTreeEntry> {\n constructor(\n private readonly blobDriver: DownloadDriver,\n private readonly logger: PFrameInternal.Logger,\n ) {\n super();\n }\n\n protected calculateParamsKey(params: PlTreeEntry): PFrameInternal.PFrameBlobId {\n return makeBlobId(params);\n }\n\n protected createNewResource(params: PlTreeEntry, _key: PFrameInternal.PFrameBlobId): LocalBlob {\n return this.blobDriver.getDownloadedBlob(params);\n }\n\n public getByKey(blobId: PFrameInternal.PFrameBlobId): LocalBlob {\n const resource = super.tryGetByKey(blobId);\n if (!resource) throw new PFrameDriverError(`Local blob with id ${blobId} not found.`);\n return resource;\n }\n\n public makeDataSource(signal: AbortSignal): Omit<PFrameInternal.PFrameDataSourceV2, 'parquetServer'> {\n return {\n preloadBlob: async (blobIds: PFrameInternal.PFrameBlobId[]) => {\n try {\n await Promise.all(blobIds.map((blobId) => this.getByKey(blobId).awaitStableFullValue(signal)));\n } catch (err: unknown) {\n if (!isAbortError(err)) throw err;\n }\n },\n resolveBlobContent: async (blobId: PFrameInternal.PFrameBlobId) => {\n const computable = this.getByKey(blobId);\n const blob = await computable.awaitStableValue(signal);\n return await this.blobDriver.getContent(blob.handle, { signal });\n },\n };\n }\n}\n\ntype RemoteBlob = Computable<RemoteBlobHandleAndSize>;\nclass RemoteBlobPool\n extends RefCountPoolBase<PlTreeEntry, PFrameInternal.PFrameBlobId, RemoteBlob> {\n constructor(\n private readonly blobDriver: DownloadDriver,\n private readonly logger: PFrameInternal.Logger,\n ) {\n super();\n }\n\n protected calculateParamsKey(params: PlTreeEntry): PFrameInternal.PFrameBlobId {\n return makeBlobId(params);\n }\n\n protected createNewResource(params: PlTreeEntry, _key: PFrameInternal.PFrameBlobId): RemoteBlob {\n return this.blobDriver.getOnDemandBlob(params);\n }\n\n public getByKey(blobId: PFrameInternal.PFrameBlobId): RemoteBlob {\n const resource = super.tryGetByKey(blobId);\n if (!resource) throw new PFrameDriverError(`Remote blob with id ${blobId} not found.`);\n return resource;\n }\n\n public async withContent<T>(\n handle: RemoteBlobHandle,\n options: {\n range: PFrameInternal.FileRange;\n signal: AbortSignal;\n handler: ContentHandler<T>;\n },\n ): Promise<T> {\n return await this.blobDriver.withContent(handle, {\n range: {\n from: options.range.start,\n to: options.range.end + 1,\n },\n signal: options.signal,\n handler: options.handler,\n });\n }\n}\n\ninterface BlobStoreOptions extends PFrameInternal.ObjectStoreOptions {\n remoteBlobProvider: RemoteBlobPool;\n};\n\nclass BlobStore extends PFrameInternal.BaseObjectStore {\n private readonly remoteBlobProvider: RemoteBlobPool;\n\n constructor(options: BlobStoreOptions) {\n super(options);\n this.remoteBlobProvider = options.remoteBlobProvider;\n }\n\n public override async request(\n filename: PFrameInternal.ParquetFileName,\n params: {\n method: PFrameInternal.HttpMethod;\n range?: PFrameInternal.HttpRange;\n signal: AbortSignal;\n callback: (response: PFrameInternal.ObjectStoreResponse) => Promise<void>;\n },\n ): Promise<void> {\n const blobId = filename.slice(0, -PFrameInternal.ParquetExtension.length) as PFrameInternal.PFrameBlobId;\n const respond = async (response: PFrameInternal.ObjectStoreResponse): Promise<void> => {\n try {\n await params.callback(response);\n } catch (error: unknown) {\n this.logger('warn',\n `PFrames blob store received unhandled rejection from HTTP handler: ${ensureError(error)}`,\n );\n }\n };\n\n try {\n const computable = this.remoteBlobProvider.tryGetByKey(blobId);\n if (!computable) return await respond({ type: 'NotFound' });\n\n let blob: RemoteBlobHandleAndSize;\n try {\n blob = await computable.getValue();\n } catch (error: unknown) {\n this.logger('error',\n `PFrames blob store failed to get blob from computable: ${ensureError(error)}`,\n );\n return await respond({ type: 'InternalError' });\n }\n params.signal.throwIfAborted();\n\n const translatedRange = this.translate(blob.size, params.range);\n if (!translatedRange) {\n return await respond({\n type: 'RangeNotSatisfiable',\n size: blob.size,\n });\n }\n\n if (params.method === 'HEAD') {\n return await respond({\n type: 'Ok',\n size: blob.size,\n range: translatedRange,\n });\n }\n\n this.logger('info',\n `PFrames blob store requesting content for ${blobId}, `\n + `range [${translatedRange.start}..=${translatedRange.end}]`,\n );\n return await this.remoteBlobProvider.withContent(blob.handle, {\n range: translatedRange,\n signal: params.signal,\n handler: async (data) => {\n return await respond({\n type: 'Ok',\n size: blob.size,\n range: translatedRange,\n // eslint-disable-next-line n/no-unsupported-features/node-builtins\n data: Readable.fromWeb(data),\n });\n },\n });\n } catch (error: unknown) {\n if (!isAbortError(error)) {\n this.logger('warn',\n `PFrames blob store unhandled error: ${ensureError(error)}`,\n );\n }\n return await respond({ type: 'InternalError' });\n }\n }\n}\n\nclass RemoteBlobProviderImpl implements RemoteBlobProvider<PlTreeEntry> {\n constructor(\n private readonly pool: RemoteBlobPool,\n private readonly server: PFrameInternal.HttpServer,\n ) {}\n\n public static async init(\n blobDriver: DownloadDriver,\n logger: PFrameInternal.Logger,\n serverOptions: Omit<PFrameInternal.HttpServerOptions, 'handler'>,\n ): Promise<RemoteBlobProviderImpl> {\n const pool = new RemoteBlobPool(blobDriver, logger);\n const store = new BlobStore({ remoteBlobProvider: pool, logger });\n\n const handler = HttpHelpers.createRequestHandler({ store });\n const server = await HttpHelpers.createHttpServer({ ...serverOptions, handler });\n logger('info', `PFrames HTTP server started on ${server.info.url}`);\n\n return new RemoteBlobProviderImpl(pool, server);\n }\n\n public acquire(params: PlTreeEntry): PoolEntry<PFrameInternal.PFrameBlobId> {\n return this.pool.acquire(params);\n }\n\n public httpServerInfo(): PFrameInternal.HttpServerInfo {\n return this.server.info;\n }\n\n async [Symbol.asyncDispose](): Promise<void> {\n await this.server.stop();\n }\n}\n\nexport interface InternalPFrameDriver\n extends AbstractInternalPFrameDriver<PColumnDataUniversal<PlTreeNodeAccessor>> {};\n\nexport type PFrameDriverOps = AbstractPFrameDriverOps & {\n /** Port to run parquet HTTP server on. */\n parquetServerPort: number;\n};\n\nexport const PFrameDriverOpsDefaults: PFrameDriverOps = {\n ...AbstractPFrameDriverOpsDefaults,\n parquetServerPort: 0, // 0 means that some unused port will be assigned by the OS\n};\n\nexport async function createPFrameDriver(params: {\n blobDriver: DownloadDriver;\n logger: MiLogger;\n spillPath: string;\n options: PFrameDriverOps;\n}): Promise<InternalPFrameDriver> {\n const resolvedSpillPath = path.resolve(params.spillPath);\n await emptyDir(resolvedSpillPath);\n\n const logger: PFrameInternal.Logger = (level, message) => params.logger[level](message);\n const localBlobProvider = new LocalBlobProviderImpl(params.blobDriver, logger);\n const remoteBlobProvider = await RemoteBlobProviderImpl.init(\n params.blobDriver,\n logger,\n { port: params.options.parquetServerPort },\n );\n\n const resolveDataInfo = (spec: PColumnSpec, data: PColumnDataUniversal<PlTreeNodeAccessor>) => {\n return isPlTreeNodeAccessor(data)\n ? parseDataInfoResource(data)\n : isDataInfo(data)\n ? data.type === 'ParquetPartitioned'\n ? mapDataInfo(data, (a) => traverseParquetChunkResource(a))\n : mapDataInfo(data, (a) => a.persist())\n : makeJsonDataInfo(spec, data);\n };\n\n return new AbstractPFrameDriver({\n logger,\n localBlobProvider,\n remoteBlobProvider,\n spillPath: resolvedSpillPath,\n options: params.options,\n resolveDataInfo,\n });\n}\n"],"names":["RefCountPoolBase","PFrameDriverError","isAbortError","PFrameInternal","ensureError","Readable","HttpHelpers","AbstractPFrameDriverOpsDefaults","emptyDir","data","isPlTreeNodeAccessor","parseDataInfoResource","isDataInfo","mapDataInfo","traverseParquetChunkResource","makeJsonDataInfo","AbstractPFrameDriver"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"driver.js","sources":["../../src/pool/driver.ts"],"sourcesContent":["import {\n mapDataInfo,\n isDataInfo,\n ensureError,\n PFrameDriverError,\n isAbortError,\n type LocalBlobHandleAndSize,\n type RemoteBlobHandleAndSize,\n type RemoteBlobHandle,\n type ContentHandler,\n type PColumnSpec,\n type PColumnDataUniversal,\n} from '@platforma-sdk/model';\nimport { PFrameInternal } from '@milaboratories/pl-model-middle-layer';\nimport {\n emptyDir,\n RefCountPoolBase,\n type PoolEntry,\n type MiLogger,\n} from '@milaboratories/ts-helpers';\nimport type { DownloadDriver } from '@milaboratories/pl-drivers';\nimport {\n isPlTreeNodeAccessor,\n type PlTreeEntry,\n type PlTreeNodeAccessor,\n} from '@milaboratories/pl-tree';\nimport type {\n Computable,\n ComputableStableDefined,\n} from '@milaboratories/computable';\nimport {\n makeJsonDataInfo,\n AbstractPFrameDriver,\n AbstractPFrameDriverOpsDefaults,\n type AbstractInternalPFrameDriver,\n type AbstractPFrameDriverOps,\n type LocalBlobProvider,\n type RemoteBlobProvider,\n} from '@milaboratories/pf-driver';\nimport { HttpHelpers } from '@milaboratories/pframes-rs-node';\nimport path from 'node:path';\nimport { Readable } from 'node:stream';\nimport {\n parseDataInfoResource,\n traverseParquetChunkResource,\n} from './data';\n\nfunction makeBlobId(res: PlTreeEntry): PFrameInternal.PFrameBlobId {\n return String(res.rid);\n}\n\ntype LocalBlob = ComputableStableDefined<LocalBlobHandleAndSize>;\nclass LocalBlobProviderImpl\n extends RefCountPoolBase<PlTreeEntry, PFrameInternal.PFrameBlobId, LocalBlob>\n implements LocalBlobProvider<PlTreeEntry> {\n constructor(\n private readonly blobDriver: DownloadDriver,\n private readonly logger: PFrameInternal.Logger,\n ) {\n super();\n }\n\n protected calculateParamsKey(params: PlTreeEntry): PFrameInternal.PFrameBlobId {\n return makeBlobId(params);\n }\n\n protected createNewResource(params: PlTreeEntry, _key: PFrameInternal.PFrameBlobId): LocalBlob {\n return this.blobDriver.getDownloadedBlob(params);\n }\n\n public getByKey(blobId: PFrameInternal.PFrameBlobId): LocalBlob {\n const resource = super.tryGetByKey(blobId);\n if (!resource) throw new PFrameDriverError(`Local blob with id ${blobId} not found.`);\n return resource;\n }\n\n public makeDataSource(signal: AbortSignal): Omit<PFrameInternal.PFrameDataSourceV2, 'parquetServer'> {\n return {\n preloadBlob: async (blobIds: PFrameInternal.PFrameBlobId[]) => {\n try {\n await Promise.all(blobIds.map((blobId) => this.getByKey(blobId).awaitStableFullValue(signal)));\n } catch (err: unknown) {\n if (!isAbortError(err)) throw err;\n }\n },\n resolveBlobContent: async (blobId: PFrameInternal.PFrameBlobId) => {\n const computable = this.getByKey(blobId);\n const blob = await computable.awaitStableValue(signal);\n return await this.blobDriver.getContent(blob.handle, { signal });\n },\n };\n }\n}\n\ntype RemoteBlob = Computable<RemoteBlobHandleAndSize>;\nclass RemoteBlobPool\n extends RefCountPoolBase<PlTreeEntry, PFrameInternal.PFrameBlobId, RemoteBlob> {\n constructor(\n private readonly blobDriver: DownloadDriver,\n private readonly logger: PFrameInternal.Logger,\n ) {\n super();\n }\n\n protected calculateParamsKey(params: PlTreeEntry): PFrameInternal.PFrameBlobId {\n return makeBlobId(params);\n }\n\n protected createNewResource(params: PlTreeEntry, _key: PFrameInternal.PFrameBlobId): RemoteBlob {\n return this.blobDriver.getOnDemandBlob(params);\n }\n\n public getByKey(blobId: PFrameInternal.PFrameBlobId): RemoteBlob {\n const resource = super.tryGetByKey(blobId);\n if (!resource) throw new PFrameDriverError(`Remote blob with id ${blobId} not found.`);\n return resource;\n }\n\n public async withContent<T>(\n handle: RemoteBlobHandle,\n options: {\n range: PFrameInternal.FileRange;\n signal: AbortSignal;\n handler: ContentHandler<T>;\n },\n ): Promise<T> {\n return await this.blobDriver.withContent(handle, {\n range: {\n from: options.range.start,\n to: options.range.end + 1,\n },\n signal: options.signal,\n handler: options.handler,\n });\n }\n}\n\ninterface BlobStoreOptions extends PFrameInternal.ObjectStoreOptions {\n remoteBlobProvider: RemoteBlobPool;\n};\n\nclass BlobStore extends PFrameInternal.BaseObjectStore {\n private readonly remoteBlobProvider: RemoteBlobPool;\n\n constructor(options: BlobStoreOptions) {\n super(options);\n this.remoteBlobProvider = options.remoteBlobProvider;\n }\n\n public override async request(\n filename: PFrameInternal.ParquetFileName,\n params: {\n method: PFrameInternal.HttpMethod;\n range?: PFrameInternal.HttpRange;\n signal: AbortSignal;\n callback: (response: PFrameInternal.ObjectStoreResponse) => Promise<void>;\n },\n ): Promise<void> {\n const blobId = filename.slice(0, -PFrameInternal.ParquetExtension.length);\n const respond = async (response: PFrameInternal.ObjectStoreResponse): Promise<void> => {\n try {\n await params.callback(response);\n } catch (error: unknown) {\n this.logger('warn',\n `PFrames blob store received unhandled rejection from HTTP handler: ${ensureError(error)}`,\n );\n }\n };\n\n try {\n const computable = this.remoteBlobProvider.tryGetByKey(blobId);\n if (!computable) return await respond({ type: 'NotFound' });\n\n let blob: RemoteBlobHandleAndSize;\n try {\n blob = await computable.getValue();\n } catch (error: unknown) {\n this.logger('error',\n `PFrames blob store failed to get blob from computable: ${ensureError(error)}`,\n );\n return await respond({ type: 'InternalError' });\n }\n params.signal.throwIfAborted();\n\n const translatedRange = this.translate(blob.size, params.range);\n if (!translatedRange) {\n return await respond({\n type: 'RangeNotSatisfiable',\n size: blob.size,\n });\n }\n\n if (params.method === 'HEAD') {\n return await respond({\n type: 'Ok',\n size: blob.size,\n range: translatedRange,\n });\n }\n\n this.logger('info',\n `PFrames blob store requesting content for ${blobId}, `\n + `range [${translatedRange.start}..=${translatedRange.end}]`,\n );\n return await this.remoteBlobProvider.withContent(blob.handle, {\n range: translatedRange,\n signal: params.signal,\n handler: async (data) => {\n return await respond({\n type: 'Ok',\n size: blob.size,\n range: translatedRange,\n // eslint-disable-next-line n/no-unsupported-features/node-builtins\n data: Readable.fromWeb(data),\n });\n },\n });\n } catch (error: unknown) {\n if (!isAbortError(error)) {\n this.logger('warn',\n `PFrames blob store unhandled error: ${ensureError(error)}`,\n );\n }\n return await respond({ type: 'InternalError' });\n }\n }\n}\n\nclass RemoteBlobProviderImpl implements RemoteBlobProvider<PlTreeEntry> {\n constructor(\n private readonly pool: RemoteBlobPool,\n private readonly server: PFrameInternal.HttpServer,\n ) {}\n\n public static async init(\n blobDriver: DownloadDriver,\n logger: PFrameInternal.Logger,\n serverOptions: Omit<PFrameInternal.HttpServerOptions, 'handler'>,\n ): Promise<RemoteBlobProviderImpl> {\n const pool = new RemoteBlobPool(blobDriver, logger);\n const store = new BlobStore({ remoteBlobProvider: pool, logger });\n\n const handler = HttpHelpers.createRequestHandler({ store });\n const server = await HttpHelpers.createHttpServer({ ...serverOptions, handler });\n logger('info', `PFrames HTTP server started on ${server.info.url}`);\n\n return new RemoteBlobProviderImpl(pool, server);\n }\n\n public acquire(params: PlTreeEntry): PoolEntry {\n return this.pool.acquire(params);\n }\n\n public httpServerInfo(): PFrameInternal.HttpServerInfo {\n return this.server.info;\n }\n\n async [Symbol.asyncDispose](): Promise<void> {\n await this.server.stop();\n }\n}\n\nexport interface InternalPFrameDriver\n extends AbstractInternalPFrameDriver<PColumnDataUniversal<PlTreeNodeAccessor>> {};\n\nexport type PFrameDriverOps = AbstractPFrameDriverOps & {\n /** Port to run parquet HTTP server on. */\n parquetServerPort: number;\n};\n\nexport const PFrameDriverOpsDefaults: PFrameDriverOps = {\n ...AbstractPFrameDriverOpsDefaults,\n parquetServerPort: 0, // 0 means that some unused port will be assigned by the OS\n};\n\nexport async function createPFrameDriver(params: {\n blobDriver: DownloadDriver;\n logger: MiLogger;\n spillPath: string;\n options: PFrameDriverOps;\n}): Promise<InternalPFrameDriver> {\n const resolvedSpillPath = path.resolve(params.spillPath);\n await emptyDir(resolvedSpillPath);\n\n const logger: PFrameInternal.Logger = (level, message) => params.logger[level](message);\n const localBlobProvider = new LocalBlobProviderImpl(params.blobDriver, logger);\n const remoteBlobProvider = await RemoteBlobProviderImpl.init(\n params.blobDriver,\n logger,\n { port: params.options.parquetServerPort },\n );\n\n const resolveDataInfo = (spec: PColumnSpec, data: PColumnDataUniversal<PlTreeNodeAccessor>) => {\n return isPlTreeNodeAccessor(data)\n ? parseDataInfoResource(data)\n : isDataInfo(data)\n ? data.type === 'ParquetPartitioned'\n ? mapDataInfo(data, (a) => traverseParquetChunkResource(a))\n : mapDataInfo(data, (a) => a.persist())\n : makeJsonDataInfo(spec, data);\n };\n\n return new AbstractPFrameDriver({\n logger,\n localBlobProvider,\n remoteBlobProvider,\n spillPath: resolvedSpillPath,\n options: params.options,\n resolveDataInfo,\n });\n}\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"driver.js","sources":["../../src/pool/driver.ts"],"sourcesContent":["import {\n mapDataInfo,\n isDataInfo,\n ensureError,\n PFrameDriverError,\n isAbortError,\n type LocalBlobHandleAndSize,\n type RemoteBlobHandleAndSize,\n type RemoteBlobHandle,\n type ContentHandler,\n type PColumnSpec,\n type PColumnDataUniversal,\n} from '@platforma-sdk/model';\nimport { PFrameInternal } from '@milaboratories/pl-model-middle-layer';\nimport {\n emptyDir,\n RefCountPoolBase,\n type PoolEntry,\n type MiLogger,\n} from '@milaboratories/ts-helpers';\nimport type { DownloadDriver } from '@milaboratories/pl-drivers';\nimport {\n isPlTreeNodeAccessor,\n type PlTreeEntry,\n type PlTreeNodeAccessor,\n} from '@milaboratories/pl-tree';\nimport type {\n Computable,\n ComputableStableDefined,\n} from '@milaboratories/computable';\nimport {\n makeJsonDataInfo,\n AbstractPFrameDriver,\n AbstractPFrameDriverOpsDefaults,\n type AbstractInternalPFrameDriver,\n type AbstractPFrameDriverOps,\n type LocalBlobProvider,\n type RemoteBlobProvider,\n} from '@milaboratories/pf-driver';\nimport { HttpHelpers } from '@milaboratories/pframes-rs-node';\nimport path from 'node:path';\nimport { Readable } from 'node:stream';\nimport {\n parseDataInfoResource,\n traverseParquetChunkResource,\n} from './data';\n\nfunction makeBlobId(res: PlTreeEntry): PFrameInternal.PFrameBlobId {\n return String(res.rid) as PFrameInternal.PFrameBlobId;\n}\n\ntype LocalBlob = ComputableStableDefined<LocalBlobHandleAndSize>;\nclass LocalBlobProviderImpl\n extends RefCountPoolBase<PlTreeEntry, PFrameInternal.PFrameBlobId, LocalBlob>\n implements LocalBlobProvider<PlTreeEntry> {\n constructor(\n private readonly blobDriver: DownloadDriver,\n private readonly logger: PFrameInternal.Logger,\n ) {\n super();\n }\n\n protected calculateParamsKey(params: PlTreeEntry): PFrameInternal.PFrameBlobId {\n return makeBlobId(params);\n }\n\n protected createNewResource(params: PlTreeEntry, _key: PFrameInternal.PFrameBlobId): LocalBlob {\n return this.blobDriver.getDownloadedBlob(params);\n }\n\n public getByKey(blobId: PFrameInternal.PFrameBlobId): LocalBlob {\n const resource = super.tryGetByKey(blobId);\n if (!resource) throw new PFrameDriverError(`Local blob with id ${blobId} not found.`);\n return resource;\n }\n\n public makeDataSource(signal: AbortSignal): Omit<PFrameInternal.PFrameDataSourceV2, 'parquetServer'> {\n return {\n preloadBlob: async (blobIds: PFrameInternal.PFrameBlobId[]) => {\n try {\n await Promise.all(blobIds.map((blobId) => this.getByKey(blobId).awaitStableFullValue(signal)));\n } catch (err: unknown) {\n if (!isAbortError(err)) throw err;\n }\n },\n resolveBlobContent: async (blobId: PFrameInternal.PFrameBlobId) => {\n const computable = this.getByKey(blobId);\n const blob = await computable.awaitStableValue(signal);\n return await this.blobDriver.getContent(blob.handle, { signal });\n },\n };\n }\n}\n\ntype RemoteBlob = Computable<RemoteBlobHandleAndSize>;\nclass RemoteBlobPool\n extends RefCountPoolBase<PlTreeEntry, PFrameInternal.PFrameBlobId, RemoteBlob> {\n constructor(\n private readonly blobDriver: DownloadDriver,\n private readonly logger: PFrameInternal.Logger,\n ) {\n super();\n }\n\n protected calculateParamsKey(params: PlTreeEntry): PFrameInternal.PFrameBlobId {\n return makeBlobId(params);\n }\n\n protected createNewResource(params: PlTreeEntry, _key: PFrameInternal.PFrameBlobId): RemoteBlob {\n return this.blobDriver.getOnDemandBlob(params);\n }\n\n public getByKey(blobId: PFrameInternal.PFrameBlobId): RemoteBlob {\n const resource = super.tryGetByKey(blobId);\n if (!resource) throw new PFrameDriverError(`Remote blob with id ${blobId} not found.`);\n return resource;\n }\n\n public async withContent<T>(\n handle: RemoteBlobHandle,\n options: {\n range: PFrameInternal.FileRange;\n signal: AbortSignal;\n handler: ContentHandler<T>;\n },\n ): Promise<T> {\n return await this.blobDriver.withContent(handle, {\n range: {\n from: options.range.start,\n to: options.range.end + 1,\n },\n signal: options.signal,\n handler: options.handler,\n });\n }\n}\n\ninterface BlobStoreOptions extends PFrameInternal.ObjectStoreOptions {\n remoteBlobProvider: RemoteBlobPool;\n};\n\nclass BlobStore extends PFrameInternal.BaseObjectStore {\n private readonly remoteBlobProvider: RemoteBlobPool;\n\n constructor(options: BlobStoreOptions) {\n super(options);\n this.remoteBlobProvider = options.remoteBlobProvider;\n }\n\n public override async request(\n filename: PFrameInternal.ParquetFileName,\n params: {\n method: PFrameInternal.HttpMethod;\n range?: PFrameInternal.HttpRange;\n signal: AbortSignal;\n callback: (response: PFrameInternal.ObjectStoreResponse) => Promise<void>;\n },\n ): Promise<void> {\n const blobId = filename.slice(0, -PFrameInternal.ParquetExtension.length) as PFrameInternal.PFrameBlobId;\n const respond = async (response: PFrameInternal.ObjectStoreResponse): Promise<void> => {\n try {\n await params.callback(response);\n } catch (error: unknown) {\n this.logger('warn',\n `PFrames blob store received unhandled rejection from HTTP handler: ${ensureError(error)}`,\n );\n }\n };\n\n try {\n const computable = this.remoteBlobProvider.tryGetByKey(blobId);\n if (!computable) return await respond({ type: 'NotFound' });\n\n let blob: RemoteBlobHandleAndSize;\n try {\n blob = await computable.getValue();\n } catch (error: unknown) {\n this.logger('error',\n `PFrames blob store failed to get blob from computable: ${ensureError(error)}`,\n );\n return await respond({ type: 'InternalError' });\n }\n params.signal.throwIfAborted();\n\n const translatedRange = this.translate(blob.size, params.range);\n if (!translatedRange) {\n return await respond({\n type: 'RangeNotSatisfiable',\n size: blob.size,\n });\n }\n\n if (params.method === 'HEAD') {\n return await respond({\n type: 'Ok',\n size: blob.size,\n range: translatedRange,\n });\n }\n\n this.logger('info',\n `PFrames blob store requesting content for ${blobId}, `\n + `range [${translatedRange.start}..=${translatedRange.end}]`,\n );\n return await this.remoteBlobProvider.withContent(blob.handle, {\n range: translatedRange,\n signal: params.signal,\n handler: async (data) => {\n return await respond({\n type: 'Ok',\n size: blob.size,\n range: translatedRange,\n // eslint-disable-next-line n/no-unsupported-features/node-builtins\n data: Readable.fromWeb(data),\n });\n },\n });\n } catch (error: unknown) {\n if (!isAbortError(error)) {\n this.logger('warn',\n `PFrames blob store unhandled error: ${ensureError(error)}`,\n );\n }\n return await respond({ type: 'InternalError' });\n }\n }\n}\n\nclass RemoteBlobProviderImpl implements RemoteBlobProvider<PlTreeEntry> {\n constructor(\n private readonly pool: RemoteBlobPool,\n private readonly server: PFrameInternal.HttpServer,\n ) {}\n\n public static async init(\n blobDriver: DownloadDriver,\n logger: PFrameInternal.Logger,\n serverOptions: Omit<PFrameInternal.HttpServerOptions, 'handler'>,\n ): Promise<RemoteBlobProviderImpl> {\n const pool = new RemoteBlobPool(blobDriver, logger);\n const store = new BlobStore({ remoteBlobProvider: pool, logger });\n\n const handler = HttpHelpers.createRequestHandler({ store });\n const server = await HttpHelpers.createHttpServer({ ...serverOptions, handler });\n logger('info', `PFrames HTTP server started on ${server.info.url}`);\n\n return new RemoteBlobProviderImpl(pool, server);\n }\n\n public acquire(params: PlTreeEntry): PoolEntry<PFrameInternal.PFrameBlobId> {\n return this.pool.acquire(params);\n }\n\n public httpServerInfo(): PFrameInternal.HttpServerInfo {\n return this.server.info;\n }\n\n async [Symbol.asyncDispose](): Promise<void> {\n await this.server.stop();\n }\n}\n\nexport interface InternalPFrameDriver\n extends AbstractInternalPFrameDriver<PColumnDataUniversal<PlTreeNodeAccessor>> {};\n\nexport type PFrameDriverOps = AbstractPFrameDriverOps & {\n /** Port to run parquet HTTP server on. */\n parquetServerPort: number;\n};\n\nexport const PFrameDriverOpsDefaults: PFrameDriverOps = {\n ...AbstractPFrameDriverOpsDefaults,\n parquetServerPort: 0, // 0 means that some unused port will be assigned by the OS\n};\n\nexport async function createPFrameDriver(params: {\n blobDriver: DownloadDriver;\n logger: MiLogger;\n spillPath: string;\n options: PFrameDriverOps;\n}): Promise<InternalPFrameDriver> {\n const resolvedSpillPath = path.resolve(params.spillPath);\n await emptyDir(resolvedSpillPath);\n\n const logger: PFrameInternal.Logger = (level, message) => params.logger[level](message);\n const localBlobProvider = new LocalBlobProviderImpl(params.blobDriver, logger);\n const remoteBlobProvider = await RemoteBlobProviderImpl.init(\n params.blobDriver,\n logger,\n { port: params.options.parquetServerPort },\n );\n\n const resolveDataInfo = (spec: PColumnSpec, data: PColumnDataUniversal<PlTreeNodeAccessor>) => {\n return isPlTreeNodeAccessor(data)\n ? parseDataInfoResource(data)\n : isDataInfo(data)\n ? data.type === 'ParquetPartitioned'\n ? mapDataInfo(data, (a) => traverseParquetChunkResource(a))\n : mapDataInfo(data, (a) => a.persist())\n : makeJsonDataInfo(spec, data);\n };\n\n return new AbstractPFrameDriver({\n logger,\n localBlobProvider,\n remoteBlobProvider,\n spillPath: resolvedSpillPath,\n options: params.options,\n resolveDataInfo,\n });\n}\n"],"names":[],"mappings":"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"}
@@ -11,7 +11,9 @@ const workerApi = {
11
11
  const t1 = performance.now();
12
12
  const result = plModelBackend.parseTemplate(payload);
13
13
  const t2 = performance.now();
14
- console.info(`>>>> parseTemplate in worker took ${t2 - t1}ms`);
14
+ const dt = t2 - t1;
15
+ if (dt > 100)
16
+ console.warn(`parseTemplate in worker took ${dt}ms`);
15
17
  return result;
16
18
  },
17
19
  };
@@ -1 +1 @@
1
- {"version":3,"file":"workerApi.cjs","sources":["../../src/worker/workerApi.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/require-await */\nimport { parseTemplate } from '@milaboratories/pl-model-backend';\n\n/**\n * Add there all heavy synchronous operations that can be moved to the worker thread.\n */\nexport const workerApi = {\n parseTemplate: async (payload: Uint8Array) => {\n const t1 = performance.now();\n const result = parseTemplate(payload);\n const t2 = performance.now();\n console.info(`>>>> parseTemplate in worker took ${t2 - t1}ms`);\n return result;\n },\n} satisfies Record<string, (...args: any[]) => Promise<unknown>>;\n\ntype ToScheme<T extends Record<string, (...args: any[]) => any>> = {\n [K in keyof T]: {\n args: Parameters<T[K]>;\n response: Awaited<ReturnType<T[K]>>;\n };\n};\n\nexport type Scheme = ToScheme<typeof workerApi>;\n"],"names":["parseTemplate"],"mappings":";;;;AAAA;AAGA;;AAEG;AACI,MAAM,SAAS,GAAG;AACvB,IAAA,aAAa,EAAE,OAAO,OAAmB,KAAI;AAC3C,QAAA,MAAM,EAAE,GAAG,WAAW,CAAC,GAAG,EAAE;AAC5B,QAAA,MAAM,MAAM,GAAGA,4BAAa,CAAC,OAAO,CAAC;AACrC,QAAA,MAAM,EAAE,GAAG,WAAW,CAAC,GAAG,EAAE;QAC5B,OAAO,CAAC,IAAI,CAAC,CAAA,kCAAA,EAAqC,EAAE,GAAG,EAAE,CAAA,EAAA,CAAI,CAAC;AAC9D,QAAA,OAAO,MAAM;IACf,CAAC;;;;;"}
1
+ {"version":3,"file":"workerApi.cjs","sources":["../../src/worker/workerApi.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/require-await */\nimport { parseTemplate } from '@milaboratories/pl-model-backend';\n\n/**\n * Add there all heavy synchronous operations that can be moved to the worker thread.\n */\nexport const workerApi = {\n parseTemplate: async (payload: Uint8Array) => {\n const t1 = performance.now();\n const result = parseTemplate(payload);\n const t2 = performance.now();\n const dt = t2 - t1;\n if (dt > 100) console.warn(`parseTemplate in worker took ${dt}ms`);\n return result;\n },\n} satisfies Record<string, (...args: any[]) => Promise<unknown>>;\n\ntype ToScheme<T extends Record<string, (...args: any[]) => any>> = {\n [K in keyof T]: {\n args: Parameters<T[K]>;\n response: Awaited<ReturnType<T[K]>>;\n };\n};\n\nexport type Scheme = ToScheme<typeof workerApi>;\n"],"names":["parseTemplate"],"mappings":";;;;AAAA;AAGA;;AAEG;AACI,MAAM,SAAS,GAAG;AACvB,IAAA,aAAa,EAAE,OAAO,OAAmB,KAAI;AAC3C,QAAA,MAAM,EAAE,GAAG,WAAW,CAAC,GAAG,EAAE;AAC5B,QAAA,MAAM,MAAM,GAAGA,4BAAa,CAAC,OAAO,CAAC;AACrC,QAAA,MAAM,EAAE,GAAG,WAAW,CAAC,GAAG,EAAE;AAC5B,QAAA,MAAM,EAAE,GAAG,EAAE,GAAG,EAAE;QAClB,IAAI,EAAE,GAAG,GAAG;AAAE,YAAA,OAAO,CAAC,IAAI,CAAC,gCAAgC,EAAE,CAAA,EAAA,CAAI,CAAC;AAClE,QAAA,OAAO,MAAM;IACf,CAAC;;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"workerApi.d.ts","sourceRoot":"","sources":["../../src/worker/workerApi.ts"],"names":[],"mappings":"AAGA;;GAEG;AACH,eAAO,MAAM,SAAS;6BACW,UAAU;CAOqB,CAAC;AAEjE,KAAK,QAAQ,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,GAAG,CAAC,IAAI;KAChE,CAAC,IAAI,MAAM,CAAC,GAAG;QACd,IAAI,EAAE,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACvB,QAAQ,EAAE,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;KACrC;CACF,CAAC;AAEF,MAAM,MAAM,MAAM,GAAG,QAAQ,CAAC,OAAO,SAAS,CAAC,CAAC"}
1
+ {"version":3,"file":"workerApi.d.ts","sourceRoot":"","sources":["../../src/worker/workerApi.ts"],"names":[],"mappings":"AAGA;;GAEG;AACH,eAAO,MAAM,SAAS;6BACW,UAAU;CAQqB,CAAC;AAEjE,KAAK,QAAQ,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,GAAG,CAAC,IAAI;KAChE,CAAC,IAAI,MAAM,CAAC,GAAG;QACd,IAAI,EAAE,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACvB,QAAQ,EAAE,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;KACrC;CACF,CAAC;AAEF,MAAM,MAAM,MAAM,GAAG,QAAQ,CAAC,OAAO,SAAS,CAAC,CAAC"}