@itwin/imodel-transformer 2.0.0-dev.5 → 2.0.0-dev.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/cjs/BranchProvenanceInitializer.d.ts.map +1 -1
- package/lib/cjs/BranchProvenanceInitializer.js +9 -11
- package/lib/cjs/BranchProvenanceInitializer.js.map +1 -1
- package/lib/cjs/DetachedExportElementAspectsStrategy.d.ts.map +1 -1
- package/lib/cjs/DetachedExportElementAspectsStrategy.js +3 -3
- package/lib/cjs/DetachedExportElementAspectsStrategy.js.map +1 -1
- package/lib/cjs/ECReferenceTypesCache.d.ts.map +1 -1
- package/lib/cjs/ECReferenceTypesCache.js +4 -3
- package/lib/cjs/ECReferenceTypesCache.js.map +1 -1
- package/lib/cjs/EntityUnifier.d.ts +1 -1
- package/lib/cjs/EntityUnifier.d.ts.map +1 -1
- package/lib/cjs/EntityUnifier.js +5 -12
- package/lib/cjs/EntityUnifier.js.map +1 -1
- package/lib/cjs/ExportElementAspectsStrategy.d.ts +2 -2
- package/lib/cjs/ExportElementAspectsStrategy.d.ts.map +1 -1
- package/lib/cjs/ExportElementAspectsStrategy.js.map +1 -1
- package/lib/cjs/ExportElementAspectsWithElementsStrategy.js +2 -2
- package/lib/cjs/ExportElementAspectsWithElementsStrategy.js.map +1 -1
- package/lib/cjs/IModelCloneContext.d.ts +2 -2
- package/lib/cjs/IModelCloneContext.d.ts.map +1 -1
- package/lib/cjs/IModelCloneContext.js +52 -50
- package/lib/cjs/IModelCloneContext.js.map +1 -1
- package/lib/cjs/IModelExporter.d.ts +16 -7
- package/lib/cjs/IModelExporter.d.ts.map +1 -1
- package/lib/cjs/IModelExporter.js +78 -83
- package/lib/cjs/IModelExporter.js.map +1 -1
- package/lib/cjs/IModelImporter.d.ts +2 -2
- package/lib/cjs/IModelImporter.d.ts.map +1 -1
- package/lib/cjs/IModelImporter.js +10 -13
- package/lib/cjs/IModelImporter.js.map +1 -1
- package/lib/cjs/IModelTransformer.d.ts +26 -28
- package/lib/cjs/IModelTransformer.d.ts.map +1 -1
- package/lib/cjs/IModelTransformer.js +387 -397
- package/lib/cjs/IModelTransformer.js.map +1 -1
- package/package.json +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"IModelExporter.js","sourceRoot":"","sources":["../../src/IModelExporter.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\n * Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n * See LICENSE.md in the project root for license terms and full copyright notice.\n *--------------------------------------------------------------------------------------------*/\n/** @packageDocumentation\n * @module iModels\n */\n\nimport {\n BriefcaseDb,\n BriefcaseManager,\n ChangedECInstance,\n ChangesetECAdaptor,\n DefinitionModel,\n ECSqlStatement,\n // eslint-disable-next-line @typescript-eslint/no-redeclare\n Element,\n ElementAspect,\n ElementMultiAspect,\n ElementRefersToElements,\n ElementUniqueAspect,\n GeometricElement,\n IModelDb,\n IModelJsNative,\n Model,\n PartialECChangeUnifier,\n RecipeDefinitionElement,\n Relationship,\n SqliteChangeOp,\n SqliteChangesetReader,\n} from \"@itwin/core-backend\";\nimport {\n assert,\n DbResult,\n Id64,\n Id64Arg,\n Id64Set,\n Id64String,\n IModelStatus,\n Logger,\n YieldManager,\n} from \"@itwin/core-bentley\";\nimport {\n ChangesetFileProps,\n CodeSpec,\n FontProps,\n IModel,\n IModelError,\n QueryBinder,\n} from \"@itwin/core-common\";\nimport {\n ECVersion,\n Schema,\n SchemaKey,\n SchemaLoader,\n} from \"@itwin/ecschema-metadata\";\nimport { TransformerLoggerCategory } from \"./TransformerLoggerCategory\";\nimport * as nodeAssert from \"assert\";\nimport {\n ElementAspectsHandler,\n ExportElementAspectsStrategy,\n} from \"./ExportElementAspectsStrategy\";\nimport { ExportElementAspectsWithElementsStrategy } from \"./ExportElementAspectsWithElementsStrategy\";\n\nconst loggerCategory = TransformerLoggerCategory.IModelExporter;\n\n/**\n * @beta\n * The (optional) result of [[IModelExportHandler.onExportSchema]]\n */\nexport interface ExportSchemaResult {\n /** set this property to notify subclasses where you wrote a schema for later import */\n schemaPath?: string;\n}\n\n/**\n * Arguments for [[IModelExporter.initialize]], usually in case you want to query changedata early\n * such as in the case of the IModelTransformer\n * @beta\n */\nexport type ExporterInitOptions = ExportChangesOptions;\n\n/**\n * Arguments for [[IModelExporter.exportChanges]]\n * @public\n */\nexport type ExportChangesOptions = {\n skipPropagateChangesToRootElements?: boolean;\n} /**\n * an array of ChangesetFileProps which are used to read the changesets and populate the ChangedInstanceIds using [[ChangedInstanceIds.initialize]] in [[IModelExporter.exportChanges]]\n * @note mutually exclusive with @see changesetRanges, @see startChangeset and @see changedInstanceIds, so define one of the four, never more\n */ & (\n | { csFileProps: ChangesetFileProps[] }\n /**\n * Class instance that contains modified elements between 2 versions of an iModel.\n * If this parameter is not provided, then [[ChangedInstanceIds.initialize]] in [[IModelExporter.exportChanges]]\n * will be called to discover changed elements.\n * @note mutually exclusive with @see changesetRanges, @see csFileProps and @see startChangeset, so define one of the four, never more\n */\n | { changedInstanceIds: ChangedInstanceIds }\n /**\n * An ordered array of changeset index ranges, e.g. [[2,2], [4,5]] is [2,4,5]\n * @note mutually exclusive with @see changedInstanceIds, @see csFileProps and @see startChangeset, so define one of the four, never more\n */\n | { changesetRanges: [number, number][] }\n /**\n * Include changes from this changeset up through and including the current changeset.\n * @note To form a range of versions to process, set `startChangeset` for the start (inclusive)\n * of the desired range and open the source iModel as of the end (inclusive) of the desired range.\n * @default the current changeset of the sourceDb, if undefined\n */\n | { startChangeset: { id?: string; index?: number } }\n // eslint-disable-next-line @typescript-eslint/no-empty-object-type\n | {}\n);\n\n/** Handles the events generated by IModelExporter.\n * @note Change information is available when `IModelExportHandler` methods are invoked via [IModelExporter.exportChanges]($transformer), but not available when invoked via [IModelExporter.exportAll]($transformer).\n * @note The handler is intended to be owned by (registered with) and called from the IModelExporter exclusively\n * @see [iModel Transformation and Data Exchange]($docs/learning/transformer/index.md), [IModelExporter]($transformer)\n * @beta\n */\nexport abstract class IModelExportHandler {\n /** If `true` is returned, then the CodeSpec will be exported.\n * @note This method can optionally be overridden to exclude an individual CodeSpec from the export. The base implementation always returns `true`.\n */\n public shouldExportCodeSpec(_codeSpec: CodeSpec): boolean {\n return true;\n }\n\n /** Called when a CodeSpec should be exported.\n * @param codeSpec The CodeSpec to export\n * @param isUpdate If defined, then `true` indicates an UPDATE operation while `false` indicates an INSERT operation. If not defined, then INSERT vs. UPDATE is not known.\n * @note This should be overridden to actually do the export.\n */\n public onExportCodeSpec(\n _codeSpec: CodeSpec,\n _isUpdate: boolean | undefined\n ): void {}\n\n /** Called when a font should be exported.\n * @param font The font to export\n * @param isUpdate If defined, then `true` indicates an UPDATE operation while `false` indicates an INSERT operation. If not defined, then INSERT vs. UPDATE is not known.\n * @note This should be overridden to actually do the export.\n */\n public onExportFont(_font: FontProps, _isUpdate: boolean | undefined): void {}\n\n /** Called when a model should be exported.\n * @param model The model to export\n * @param isUpdate If defined, then `true` indicates an UPDATE operation while `false` indicates an INSERT operation. If not defined, then INSERT vs. UPDATE is not known.\n * @note This should be overridden to actually do the export.\n */\n public onExportModel(_model: Model, _isUpdate: boolean | undefined): void {}\n\n /** Called when a model should be deleted. */\n public onDeleteModel(_modelId: Id64String): void {}\n\n /** If `true` is returned, then the element will be exported.\n * @note This method can optionally be overridden to exclude an individual Element (and its children and ElementAspects) from the export. The base implementation always returns `true`.\n */\n public shouldExportElement(_element: Element): boolean {\n return true;\n }\n\n /** Called when element is skipped instead of exported.\n * @note When an element is skipped, exporter will not export any of its child elements. Because of this, [[onSkipElement]] will not be invoked for any children of a \"skipped\" element.\n */\n public onSkipElement(_elementId: Id64String): void {}\n\n /** Called when an element should be exported.\n * @param element The element to export\n * @param isUpdate If defined, then `true` indicates an UPDATE operation while `false` indicates an INSERT operation. If not defined, then INSERT vs. UPDATE is not known.\n * @note This should be overridden to actually do the export.\n */\n public onExportElement(\n _element: Element,\n _isUpdate: boolean | undefined\n ): void {}\n\n /**\n * Do any asynchronous actions before exporting an element\n * @note Do not implement this handler manually, it is internal, it will be removed.\n * This will become a part of onExportElement once that becomes async\n * @internal\n */\n public async preExportElement(_element: Element): Promise<void> {}\n\n /** Called when an element should be deleted. */\n public onDeleteElement(_elementId: Id64String): void {}\n\n /** If `true` is returned, then the ElementAspect will be exported.\n * @note This method can optionally be overridden to exclude an individual ElementAspect from the export. The base implementation always returns `true`.\n */\n public shouldExportElementAspect(_aspect: ElementAspect): boolean {\n return true;\n }\n\n /** Called when an ElementUniqueAspect should be exported.\n * @param aspect The ElementUniqueAspect to export\n * @param isUpdate If defined, then `true` indicates an UPDATE operation while `false` indicates an INSERT operation. If not defined, then INSERT vs. UPDATE is not known.\n * @note This should be overridden to actually do the export.\n */\n public onExportElementUniqueAspect(\n _aspect: ElementUniqueAspect,\n _isUpdate: boolean | undefined\n ): void {}\n\n /** Called when ElementMultiAspects should be exported.\n * @note This should be overridden to actually do the export.\n */\n public onExportElementMultiAspects(_aspects: ElementMultiAspect[]): void {}\n\n /** If `true` is returned, then the relationship will be exported.\n * @note This method can optionally be overridden to exclude an individual CodeSpec from the export. The base implementation always returns `true`.\n */\n public shouldExportRelationship(_relationship: Relationship): boolean {\n return true;\n }\n\n /** Called when a Relationship should be exported.\n * @param relationship The Relationship to export\n * @param isUpdate If defined, then `true` indicates an UPDATE operation while `false` indicates an INSERT operation. If not defined, then INSERT vs. UPDATE is not known.\n * @note This should be overridden to actually do the export.\n */\n public onExportRelationship(\n _relationship: Relationship,\n _isUpdate: boolean | undefined\n ): void {}\n\n /** Called when a relationship should be deleted. */\n public onDeleteRelationship(_relInstanceId: Id64String): void {}\n\n /** If `true` is returned, then the schema will be exported.\n * @note This method can optionally be overridden to exclude an individual schema from the export. The base implementation always returns `true`.\n */\n public shouldExportSchema(_schemaKey: SchemaKey): boolean {\n return true;\n }\n\n /** Called when a schema should be exported.\n * @param schema The schema to export\n * @note This should be overridden to actually do the export.\n * @note return an [[ExportSchemaResult]] with a `schemaPath` property to notify overrides that call `super`\n * where a schema was written for import.\n */\n public async onExportSchema(\n _schema: Schema\n ): Promise<void | ExportSchemaResult> {}\n\n /** This method is called when IModelExporter has made incremental progress based on the [[IModelExporter.progressInterval]] setting.\n * This method is `async` to make it easier to integrate with asynchronous status and health reporting services.\n * @note A subclass may override this method to report custom progress. The base implementation does nothing.\n */\n public async onProgress(): Promise<void> {}\n}\n\n/** Base class for exporting data from an iModel.\n * @note Most uses cases will not require a custom subclass of `IModelExporter`. Instead, it is more typical to subclass/customize [IModelExportHandler]($transformer).\n * @see [iModel Transformation and Data Exchange]($docs/learning/transformer/index.md), [[registerHandler]], [IModelTransformer]($transformer), [IModelImporter]($transformer)\n * @beta\n */\nexport class IModelExporter {\n /** The read-only source iModel. */\n public readonly sourceDb: IModelDb;\n /** A flag that indicates whether element GeometryStreams are loaded or not.\n * @note As an optimization, exporters that don't need geometry can set this flag to `false`. The default is `true`.\n * @note The transformer by default sets this to `false` as an optimization.\n * @note This implies the `wantBRepData` option when loading elements.\n * @see [ElementLoadProps.wantGeometry]($common)\n */\n public wantGeometry: boolean = true;\n /** A flag that indicates whether template models should be exported or not. The default is `true`.\n * @note If only exporting *instances* then template models can be skipped since they are just definitions that are cloned to create new instances.\n * @see [Model.isTemplate]($backend)\n */\n public wantTemplateModels: boolean = true;\n /** A flag that indicates whether *system* schemas should be exported or not. The default is `true` (previously false).\n * This can be set to false for the legacy default behavior, but it may cause errors during schema processing in some cases.\n * @see [[exportSchemas]]\n */\n public wantSystemSchemas: boolean = true;\n /** A flag that determines whether this IModelExporter should visit Elements or not. The default is `true`.\n * @note This flag is available as an optimization when the exporter doesn't need to visit elements, so can skip loading them.\n */\n public visitElements: boolean = true;\n /** A flag that determines whether this IModelExporter should visit Relationships or not. The default is `true`.\n * @note This flag is available as an optimization when the exporter doesn't need to visit relationships, so can skip loading them.\n */\n public visitRelationships: boolean = true;\n /** The number of entities exported before incremental progress should be reported via the [[onProgress]] callback. */\n public progressInterval: number = 1000;\n /** Tracks the current total number of entities exported. */\n private _progressCounter: number = 0;\n /** Optionally cached entity change information */\n private _sourceDbChanges?: ChangedInstanceIds;\n\n /**\n * Retrieve the cached entity change information.\n * @note This will only be initialized after [IModelExporter.exportChanges] is invoked or [IModelExporter.initialize] is called.\n */\n public get sourceDbChanges(): ChangedInstanceIds | undefined {\n return this._sourceDbChanges;\n }\n /** The handler called by this IModelExporter. */\n private _handler: IModelExportHandler | undefined;\n /** The handler called by this IModelExporter. */\n protected get handler(): IModelExportHandler {\n if (undefined === this._handler) {\n throw new Error(\"IModelExportHandler not registered\");\n }\n\n return this._handler;\n }\n\n /** The set of CodeSpecs to exclude from the export. */\n private _excludedCodeSpecNames = new Set<string>();\n /** The set of specific Elements to exclude from the export. */\n private _excludedElementIds = new Set<Id64String>();\n /** The set of Categories where Elements in that Category will be excluded from transformation to the target iModel. */\n private _excludedElementCategoryIds = new Set<Id64String>();\n /** The set of classes of Elements that will be excluded (polymorphically) from transformation to the target iModel. */\n private _excludedElementClasses = new Set<typeof Element>();\n /** The set of classes of Relationships that will be excluded (polymorphically) from transformation to the target iModel. */\n private _excludedRelationshipClasses = new Set<typeof Relationship>();\n\n /** Strategy for how ElementAspects are exported */\n private _exportElementAspectsStrategy: ExportElementAspectsStrategy;\n\n /** Construct a new IModelExporter\n * @param sourceDb The source IModelDb\n * @see registerHandler\n */\n public constructor(\n sourceDb: IModelDb,\n elementAspectsStrategy: new (\n source: IModelDb,\n handler: ElementAspectsHandler\n ) => ExportElementAspectsStrategy = ExportElementAspectsWithElementsStrategy\n ) {\n this.sourceDb = sourceDb;\n this._exportElementAspectsStrategy = new elementAspectsStrategy(\n this.sourceDb,\n {\n onExportElementMultiAspects: (aspects) =>\n this.handler.onExportElementMultiAspects(aspects),\n onExportElementUniqueAspect: (aspect, isUpdate) =>\n this.handler.onExportElementUniqueAspect(aspect, isUpdate),\n shouldExportElementAspect: (aspect) =>\n this.handler.shouldExportElementAspect(aspect),\n trackProgress: async () => this.trackProgress(),\n }\n );\n }\n\n /**\n * Initialize prerequisites of exporting. This is implicitly done by any `export*` calls that need initialization\n * which is currently just `exportChanges`.\n * Prefer to not call this explicitly (e.g. just call [[IModelExporter.exportChanges]])\n * @note that if you do call this explicitly, you must do so with the same options that\n * you pass to [[IModelExporter.exportChanges]]\n */\n public async initialize(options: ExporterInitOptions): Promise<void> {\n if (!this.sourceDb.isBriefcaseDb() || this._sourceDbChanges) return;\n\n this._sourceDbChanges = await ChangedInstanceIds.initialize({\n iModel: this.sourceDb,\n ...options,\n });\n if (this._sourceDbChanges === undefined) return;\n\n this._exportElementAspectsStrategy.setAspectChanges(\n this._sourceDbChanges.aspect\n );\n }\n\n /** Register the handler that will be called by IModelExporter. */\n public registerHandler(handler: IModelExportHandler): void {\n this._handler = handler;\n }\n\n /** Add a rule to exclude a CodeSpec */\n public excludeCodeSpec(codeSpecName: string): void {\n this._excludedCodeSpecNames.add(codeSpecName);\n }\n\n /** Add a rule to exclude a specific Element. */\n public excludeElement(elementId: Id64String): void {\n this._excludedElementIds.add(elementId);\n }\n\n /** Add a rule to exclude all Elements in a specified Category. */\n public excludeElementsInCategory(categoryId: Id64String): void {\n this._excludedElementCategoryIds.add(categoryId);\n }\n\n /** Add a rule to exclude all Elements of a specified class. */\n public excludeElementClass(classFullName: string): void {\n this._excludedElementClasses.add(\n this.sourceDb.getJsClass<typeof Element>(classFullName)\n );\n }\n\n /** Add a rule to exclude all ElementAspects of a specified class. */\n public excludeElementAspectClass(classFullName: string): void {\n this._exportElementAspectsStrategy.excludeElementAspectClass(classFullName);\n }\n\n /** Add a rule to exclude all Relationships of a specified class. */\n public excludeRelationshipClass(classFullName: string): void {\n this._excludedRelationshipClasses.add(\n this.sourceDb.getJsClass<typeof Relationship>(classFullName)\n );\n }\n\n /** Export all entity instance types from the source iModel.\n * @note [[exportSchemas]] must be called separately.\n */\n public async exportAll(): Promise<void> {\n await this.initialize({});\n\n await this.exportCodeSpecs();\n await this.exportFonts();\n await this.exportModel(IModel.repositoryModelId);\n await this.exportRelationships(ElementRefersToElements.classFullName);\n }\n\n /** Export changes from the source iModel.\n * Inserts, updates, and deletes are determined by inspecting the changeset(s).\n * @note To form a range of versions to process, set `startChangesetId` for the start (inclusive) of the desired\n * range and open the source iModel as of the end (inclusive) of the desired range.\n * @note the changedInstanceIds are just for this call to exportChanges, so you must continue to pass it in\n * for consecutive calls\n */\n public async exportChanges(args?: ExportChangesOptions): Promise<void> {\n if (!this.sourceDb.isBriefcaseDb())\n throw new IModelError(\n IModelStatus.BadRequest,\n \"Must be a briefcase to export changes\"\n );\n\n if (\n \"\" === this.sourceDb.changeset.id &&\n !this.sourceDbChanges?.hasChanges\n ) {\n await this.exportAll(); // no changesets or custom changes, so revert to exportAll\n return;\n }\n\n const startChangeset =\n args && \"startChangeset\" in args ? args.startChangeset : undefined;\n\n const initOpts: ExporterInitOptions = {\n startChangeset: { id: startChangeset?.id },\n };\n await this.initialize(initOpts);\n // _sourceDbChanges are initialized in this.initialize\n nodeAssert(\n this._sourceDbChanges !== undefined,\n \"sourceDbChanges must be initialized.\"\n );\n\n await this.exportCodeSpecs();\n await this.exportFonts();\n if (initOpts.skipPropagateChangesToRootElements) {\n await this.exportModelContents(IModel.repositoryModelId);\n await this.exportSubModels(IModel.repositoryModelId);\n } else {\n await this.exportModel(IModel.repositoryModelId);\n }\n await this.exportAllAspects();\n await this.exportRelationships(ElementRefersToElements.classFullName);\n\n // handle deletes\n if (this.visitElements) {\n // must delete models first since they have a constraint on the submodeling element which may also be deleted\n for (const modelId of this._sourceDbChanges.model.deleteIds) {\n this.handler.onDeleteModel(modelId);\n }\n for (const elementId of this._sourceDbChanges.element.deleteIds) {\n // We don't know how the handler wants to handle deletions, and we don't have enough information\n // to know if deleted entities were related, so when processing changes, ignore errors from deletion.\n // Technically, to keep the ignored error scope small, we ignore only the error of looking up a missing element,\n // that approach works at least for the IModelTransformer.\n // In the future, the handler may be responsible for doing the work of finding out which elements were cascade deleted,\n // and returning them for the exporter to use to avoid double-deleting with error ignoring\n try {\n this.handler.onDeleteElement(elementId);\n } catch (err: unknown) {\n const isMissingErr =\n err instanceof IModelError &&\n err.errorNumber === IModelStatus.NotFound;\n if (!isMissingErr) throw err;\n }\n }\n }\n\n if (this.visitRelationships) {\n for (const relInstanceId of this._sourceDbChanges.relationship\n .deleteIds) {\n this.handler.onDeleteRelationship(relInstanceId);\n }\n }\n\n // Enable consecutive exportChanges runs without the need to re-instantiate the exporter.\n // You can counteract the obvious impact of losing this expensive data by always calling\n // exportChanges with the [[ExportChangesOptions.changedInstanceIds]] option set to\n // whatever you want\n if (this._resetChangeDataOnExport) this._sourceDbChanges = undefined;\n }\n\n private _resetChangeDataOnExport = true;\n\n /** Export schemas from the source iModel.\n * @note This must be called separately from [[exportAll]] or [[exportChanges]].\n */\n public async exportSchemas(): Promise<void> {\n const sql = `\n SELECT s.Name, s.VersionMajor, s.VersionWrite, s.VersionMinor\n FROM ECDbMeta.ECSchemaDef s\n ${\n this.wantSystemSchemas\n ? \"\"\n : `\n WHERE ECInstanceId >= (SELECT ECInstanceId FROM ECDbMeta.ECSchemaDef WHERE Name='BisCore')\n `\n }\n ORDER BY ECInstanceId\n `;\n const schemaNamesToExport: string[] = [];\n // eslint-disable-next-line @itwin/no-internal, @typescript-eslint/no-deprecated\n this.sourceDb.withPreparedStatement(sql, (statement: ECSqlStatement) => {\n while (DbResult.BE_SQLITE_ROW === statement.step()) {\n const schemaName = statement.getValue(0).getString();\n const versionMajor = statement.getValue(1).getInteger();\n const versionWrite = statement.getValue(2).getInteger();\n const versionMinor = statement.getValue(3).getInteger();\n const schemaKey = new SchemaKey(\n schemaName,\n new ECVersion(versionMajor, versionWrite, versionMinor)\n );\n if (this.handler.shouldExportSchema(schemaKey)) {\n schemaNamesToExport.push(schemaName);\n }\n }\n });\n\n if (schemaNamesToExport.length === 0) return;\n\n const schemaLoader = new SchemaLoader((name: string) =>\n this.sourceDb.getSchemaProps(name)\n );\n await Promise.all(\n schemaNamesToExport.map(async (schemaName) => {\n const schema = schemaLoader.getSchema(schemaName);\n Logger.logTrace(loggerCategory, `exportSchema(${schemaName})`);\n return this.handler.onExportSchema(schema);\n })\n );\n }\n\n /** For logging, indicate the change type if known. */\n private getChangeOpSuffix(isUpdate: boolean | undefined): string {\n return isUpdate ? \" UPDATE\" : undefined === isUpdate ? \"\" : \" INSERT\";\n }\n\n /** Export all CodeSpecs from the source iModel.\n * @note This method is called from [[exportChanges]] and [[exportAll]], so it only needs to be called directly when exporting a subset of an iModel.\n */\n public async exportCodeSpecs(): Promise<void> {\n Logger.logTrace(loggerCategory, \"exportCodeSpecs()\");\n const sql = \"SELECT Name FROM BisCore:CodeSpec ORDER BY ECInstanceId\";\n // eslint-disable-next-line @itwin/no-internal, @typescript-eslint/no-deprecated\n await this.sourceDb.withPreparedStatement(\n sql,\n // eslint-disable-next-line @itwin/no-internal, @typescript-eslint/no-deprecated\n async (statement: ECSqlStatement): Promise<void> => {\n while (DbResult.BE_SQLITE_ROW === statement.step()) {\n const codeSpecName: string = statement.getValue(0).getString();\n await this.exportCodeSpecByName(codeSpecName);\n }\n }\n );\n }\n\n /** Export a single CodeSpec from the source iModel.\n * @note This method is called from [[exportChanges]] and [[exportAll]], so it only needs to be called directly when exporting a subset of an iModel.\n */\n public async exportCodeSpecByName(codeSpecName: string): Promise<void> {\n const codeSpec: CodeSpec = this.sourceDb.codeSpecs.getByName(codeSpecName);\n let isUpdate: boolean | undefined;\n if (undefined !== this._sourceDbChanges) {\n // is changeset information available?\n if (this._sourceDbChanges.codeSpec.insertIds.has(codeSpec.id)) {\n isUpdate = false;\n } else if (this._sourceDbChanges.codeSpec.updateIds.has(codeSpec.id)) {\n isUpdate = true;\n } else {\n return; // not in changeset, don't export\n }\n }\n // passed changeset test, now apply standard exclusion rules\n if (this._excludedCodeSpecNames.has(codeSpec.name)) {\n Logger.logInfo(loggerCategory, `Excluding CodeSpec: ${codeSpec.name}`);\n return;\n }\n // CodeSpec has passed standard exclusion rules, now give handler a chance to accept/reject export\n if (this.handler.shouldExportCodeSpec(codeSpec)) {\n Logger.logTrace(\n loggerCategory,\n `exportCodeSpec(${codeSpecName})${this.getChangeOpSuffix(isUpdate)}`\n );\n this.handler.onExportCodeSpec(codeSpec, isUpdate);\n return this.trackProgress();\n }\n }\n\n /** Export a single CodeSpec from the source iModel.\n * @note This method is called from [[exportChanges]] and [[exportAll]], so it only needs to be called directly when exporting a subset of an iModel.\n */\n public async exportCodeSpecById(codeSpecId: Id64String): Promise<void> {\n const codeSpec: CodeSpec = this.sourceDb.codeSpecs.getById(codeSpecId);\n return this.exportCodeSpecByName(codeSpec.name);\n }\n\n /** Export all fonts from the source iModel.\n * @note This method is called from [[exportChanges]] and [[exportAll]], so it only needs to be called directly when exporting a subset of an iModel.\n */\n public async exportFonts(): Promise<void> {\n Logger.logTrace(loggerCategory, \"exportFonts()\");\n for (const font of this.sourceDb.fontMap.fonts.values()) {\n await this.exportFontByNumber(font.id);\n }\n }\n\n /** Export a single font from the source iModel.\n * @note This method is called from [[exportChanges]] and [[exportAll]], so it only needs to be called directly when exporting a subset of an iModel.\n */\n public async exportFontByName(fontName: string): Promise<void> {\n Logger.logTrace(loggerCategory, `exportFontByName(${fontName})`);\n const font: FontProps | undefined = this.sourceDb.fontMap.getFont(fontName);\n if (undefined !== font) {\n await this.exportFontByNumber(font.id);\n }\n }\n\n /** Export a single font from the source iModel.\n * @note This method is called from [[exportChanges]] and [[exportAll]], so it only needs to be called directly when exporting a subset of an iModel.\n */\n public async exportFontByNumber(fontNumber: number): Promise<void> {\n /** sourceDbChanges now works by using TS ChangesetECAdaptor which doesn't pick up changes to fonts since fonts is not an ec table.\n * So lets always export fonts for the time being by always setting isUpdate = true.\n * It is very rare and even problematic for the font table to reach a large size, so it is not a bottleneck in transforming changes.\n * See https://github.com/iTwin/imodel-transformer/pull/135 for removed code.\n */\n const isUpdate = true;\n Logger.logTrace(loggerCategory, `exportFontById(${fontNumber})`);\n const font: FontProps | undefined =\n this.sourceDb.fontMap.getFont(fontNumber);\n if (undefined !== font) {\n this.handler.onExportFont(font, isUpdate);\n return this.trackProgress();\n }\n }\n\n /** Export the model container, contents, and sub-models from the source iModel.\n * @note This method is called from [[exportChanges]] and [[exportAll]], so it only needs to be called directly when exporting a subset of an iModel.\n */\n public async exportModel(modeledElementId: Id64String): Promise<void> {\n const model: Model = this.sourceDb.models.getModel(modeledElementId);\n if (model.isTemplate && !this.wantTemplateModels) {\n return;\n }\n const modeledElement: Element = this.sourceDb.elements.getElement({\n id: modeledElementId,\n wantGeometry: this.wantGeometry,\n wantBRepData: this.wantGeometry,\n });\n Logger.logTrace(loggerCategory, `exportModel(${modeledElementId})`);\n if (this.shouldExportElement(modeledElement)) {\n await this.exportModelContainer(model);\n if (this.visitElements) {\n await this.exportModelContents(modeledElementId);\n }\n await this.exportSubModels(modeledElementId);\n }\n }\n\n /** Export the model (the container only) from the source iModel. */\n private async exportModelContainer(model: Model): Promise<void> {\n let isUpdate: boolean | undefined;\n if (undefined !== this._sourceDbChanges) {\n // is changeset information available?\n if (this._sourceDbChanges.model.insertIds.has(model.id)) {\n isUpdate = false;\n } else if (this._sourceDbChanges.model.updateIds.has(model.id)) {\n isUpdate = true;\n } else {\n return; // not in changeset, don't export\n }\n }\n this.handler.onExportModel(model, isUpdate);\n return this.trackProgress();\n }\n\n private _yieldManager = new YieldManager();\n\n /** Export the model contents.\n * @param modelId The only required parameter\n * @param elementClassFullName Can be optionally specified if the goal is to export a subset of the model contents\n * @param skipRootSubject Decides whether or not to export the root Subject. It is normally left undefined except for internal implementation purposes.\n * @note This method is called from [[exportChanges]] and [[exportAll]], so it only needs to be called directly when exporting a subset of an iModel.\n */\n public async exportModelContents(\n modelId: Id64String,\n elementClassFullName: string = Element.classFullName,\n skipRootSubject?: boolean\n ): Promise<void> {\n if (skipRootSubject) {\n // NOTE: IModelTransformer.processAll should skip the root Subject since it is specific to the individual iModel and is not part of the changes that need to be synchronized\n // NOTE: IModelExporter.exportAll should not skip the root Subject since the goal is to export everything\n assert(modelId === IModel.repositoryModelId); // flag is only relevant when processing the RepositoryModel\n }\n if (!this.visitElements) {\n Logger.logTrace(\n loggerCategory,\n `visitElements=false, skipping exportModelContents(${modelId})`\n );\n return;\n }\n if (undefined !== this._sourceDbChanges) {\n // is changeset information available?\n if (\n !this._sourceDbChanges.model.insertIds.has(modelId) &&\n !this._sourceDbChanges.model.updateIds.has(modelId)\n ) {\n return; // this optimization assumes that the Model changes (LastMod) any time an Element in the Model changes\n }\n }\n Logger.logTrace(loggerCategory, `exportModelContents(${modelId})`);\n let sql: string;\n if (skipRootSubject) {\n sql = `SELECT ECInstanceId FROM ${elementClassFullName} WHERE Parent.Id IS NULL AND Model.Id=:modelId AND ECInstanceId!=:rootSubjectId ORDER BY ECInstanceId`;\n } else {\n sql = `SELECT ECInstanceId FROM ${elementClassFullName} WHERE Parent.Id IS NULL AND Model.Id=:modelId ORDER BY ECInstanceId`;\n }\n // eslint-disable-next-line @itwin/no-internal, @typescript-eslint/no-deprecated\n await this.sourceDb.withPreparedStatement(\n sql,\n // eslint-disable-next-line @itwin/no-internal, @typescript-eslint/no-deprecated\n async (statement: ECSqlStatement): Promise<void> => {\n statement.bindId(\"modelId\", modelId);\n if (skipRootSubject) {\n statement.bindId(\"rootSubjectId\", IModel.rootSubjectId);\n }\n while (DbResult.BE_SQLITE_ROW === statement.step()) {\n await this.exportElement(statement.getValue(0).getId());\n await this._yieldManager.allowYield();\n }\n }\n );\n }\n\n /** Export the sub-models directly below the specified model.\n * @note This method is called from [[exportChanges]] and [[exportAll]], so it only needs to be called directly when exporting a subset of an iModel.\n */\n public async exportSubModels(parentModelId: Id64String): Promise<void> {\n Logger.logTrace(loggerCategory, `exportSubModels(${parentModelId})`);\n const definitionModelIds: Id64String[] = [];\n const otherModelIds: Id64String[] = [];\n const sql = `SELECT ECInstanceId FROM ${Model.classFullName} WHERE ParentModel.Id=:parentModelId ORDER BY ECInstanceId`;\n // eslint-disable-next-line @itwin/no-internal, @typescript-eslint/no-deprecated\n this.sourceDb.withPreparedStatement(\n sql,\n // eslint-disable-next-line @itwin/no-internal, @typescript-eslint/no-deprecated\n (statement: ECSqlStatement): void => {\n statement.bindId(\"parentModelId\", parentModelId);\n while (DbResult.BE_SQLITE_ROW === statement.step()) {\n const modelId: Id64String = statement.getValue(0).getId();\n const model: Model = this.sourceDb.models.getModel(modelId);\n if (model instanceof DefinitionModel) {\n definitionModelIds.push(modelId);\n } else {\n otherModelIds.push(modelId);\n }\n }\n }\n );\n // export DefinitionModels before other types of Models\n for (const definitionModelId of definitionModelIds) {\n await this.exportModel(definitionModelId);\n }\n for (const otherModelId of otherModelIds) {\n await this.exportModel(otherModelId);\n }\n }\n\n /** Returns true if the specified element should be exported.\n * This considers the standard IModelExporter exclusion rules plus calls [IModelExportHandler.shouldExportElement]($transformer) for any custom exclusion rules.\n * @note This method is called from within [[exportChanges]] and [[exportAll]], so usually does not need to be called directly.\n */\n public shouldExportElement(element: Element): boolean {\n if (this._excludedElementIds.has(element.id)) {\n Logger.logInfo(loggerCategory, `Excluded element ${element.id} by Id`);\n return false;\n }\n if (element instanceof GeometricElement) {\n if (this._excludedElementCategoryIds.has(element.category)) {\n Logger.logInfo(\n loggerCategory,\n `Excluded element ${element.id} by Category`\n );\n return false;\n }\n }\n if (\n !this.wantTemplateModels &&\n element instanceof RecipeDefinitionElement\n ) {\n Logger.logInfo(\n loggerCategory,\n `Excluded RecipeDefinitionElement ${element.id} because wantTemplate=false`\n );\n return false;\n }\n for (const excludedElementClass of this._excludedElementClasses) {\n if (element instanceof excludedElementClass) {\n Logger.logInfo(\n loggerCategory,\n `Excluded element ${element.id} by class: ${excludedElementClass.classFullName}`\n );\n return false;\n }\n }\n // element has passed standard exclusion rules, now give handler a chance to accept/reject\n return this.handler.shouldExportElement(element);\n }\n\n /** Export the specified element, its child elements (if applicable), and any owned ElementAspects.\n * @note This method is called from [[exportChanges]] and [[exportAll]], so it only needs to be called directly when exporting a subset of an iModel.\n */\n public async exportElement(elementId: Id64String): Promise<void> {\n if (!this.visitElements) {\n Logger.logTrace(\n loggerCategory,\n `visitElements=false, skipping exportElement(${elementId})`\n );\n return;\n }\n\n // Return early if the elementId is already in the excludedElementIds, that way we don't need to load the element from the db.\n if (this._excludedElementIds.has(elementId)) {\n Logger.logInfo(loggerCategory, `Excluded element ${elementId} by Id`);\n this.handler.onSkipElement(elementId);\n return;\n }\n\n // are we processing changes?\n const isUpdate = this._sourceDbChanges?.element.insertIds.has(elementId)\n ? false\n : this._sourceDbChanges?.element.updateIds.has(elementId)\n ? true\n : undefined;\n\n const element = this.sourceDb.elements.getElement({\n id: elementId,\n wantGeometry: this.wantGeometry,\n wantBRepData: this.wantGeometry,\n });\n Logger.logTrace(\n loggerCategory,\n `exportElement(${\n element.id\n }, \"${element.getDisplayLabel()}\")${this.getChangeOpSuffix(isUpdate)}`\n );\n // the order and `await`ing of calls beyond here is depended upon by the IModelTransformer for a current bug workaround\n if (this.shouldExportElement(element)) {\n await this.handler.preExportElement(element);\n this.handler.onExportElement(element, isUpdate);\n await this.trackProgress();\n await this._exportElementAspectsStrategy.exportElementAspectsForElement(\n elementId\n );\n return this.exportChildElements(elementId);\n } else {\n this.handler.onSkipElement(element.id);\n }\n }\n\n /** Export the child elements of the specified element from the source iModel.\n * @note This method is called from [[exportChanges]] and [[exportAll]], so it only needs to be called directly when exporting a subset of an iModel.\n */\n public async exportChildElements(elementId: Id64String): Promise<void> {\n if (!this.visitElements) {\n Logger.logTrace(\n loggerCategory,\n `visitElements=false, skipping exportChildElements(${elementId})`\n );\n return;\n }\n const childElementIds: Id64String[] =\n this.sourceDb.elements.queryChildren(elementId);\n if (childElementIds.length > 0) {\n Logger.logTrace(loggerCategory, `exportChildElements(${elementId})`);\n for (const childElementId of childElementIds) {\n await this.exportElement(childElementId);\n }\n }\n }\n\n /** Exports all aspects present in the iModel.\n */\n private async exportAllAspects(): Promise<void> {\n return this._exportElementAspectsStrategy.exportAllElementAspects();\n }\n\n /** Exports all relationships that subclass from the specified base class.\n * @note This method is called from [[exportChanges]] and [[exportAll]], so it only needs to be called directly when exporting a subset of an iModel.\n */\n public async exportRelationships(\n baseRelClassFullName: string\n ): Promise<void> {\n if (!this.visitRelationships) {\n Logger.logTrace(\n loggerCategory,\n \"visitRelationships=false, skipping exportRelationships()\"\n );\n return;\n }\n Logger.logTrace(\n loggerCategory,\n `exportRelationships(${baseRelClassFullName})`\n );\n const sql = `SELECT r.ECInstanceId, r.ECClassId FROM ${baseRelClassFullName} r\n JOIN bis.Element s ON s.ECInstanceId = r.SourceECInstanceId\n JOIN bis.Element t ON t.ECInstanceId = r.TargetECInstanceId\n WHERE s.ECInstanceId IS NOT NULL AND t.ECInstanceId IS NOT NULL`;\n // eslint-disable-next-line @itwin/no-internal, @typescript-eslint/no-deprecated\n await this.sourceDb.withPreparedStatement(\n sql,\n // eslint-disable-next-line @itwin/no-internal, @typescript-eslint/no-deprecated\n async (statement: ECSqlStatement): Promise<void> => {\n while (DbResult.BE_SQLITE_ROW === statement.step()) {\n const relationshipId = statement.getValue(0).getId();\n const relationshipClass = statement\n .getValue(1)\n .getClassNameForClassId();\n await this.exportRelationship(relationshipClass, relationshipId); // must call exportRelationship using the actual classFullName, not baseRelClassFullName\n await this._yieldManager.allowYield();\n }\n }\n );\n }\n\n /** Export a relationship from the source iModel. */\n public async exportRelationship(\n relClassFullName: string,\n relInstanceId: Id64String\n ): Promise<void> {\n if (!this.visitRelationships) {\n Logger.logTrace(\n loggerCategory,\n `visitRelationships=false, skipping exportRelationship(${relClassFullName}, ${relInstanceId})`\n );\n return;\n }\n let isUpdate: boolean | undefined;\n if (undefined !== this._sourceDbChanges) {\n // is changeset information available?\n if (this._sourceDbChanges.relationship.insertIds.has(relInstanceId)) {\n isUpdate = false;\n } else if (\n this._sourceDbChanges.relationship.updateIds.has(relInstanceId)\n ) {\n isUpdate = true;\n } else {\n return; // not in changeset, don't export\n }\n }\n // passed changeset test, now apply standard exclusion rules\n Logger.logTrace(\n loggerCategory,\n `exportRelationship(${relClassFullName}, ${relInstanceId})`\n );\n const relationship: Relationship = this.sourceDb.relationships.getInstance(\n relClassFullName,\n relInstanceId\n );\n for (const excludedRelationshipClass of this._excludedRelationshipClasses) {\n if (relationship instanceof excludedRelationshipClass) {\n Logger.logInfo(\n loggerCategory,\n `Excluded relationship by class: ${excludedRelationshipClass.classFullName}`\n );\n return;\n }\n }\n // relationship has passed standard exclusion rules, now give handler a chance to accept/reject export\n if (this.handler.shouldExportRelationship(relationship)) {\n this.handler.onExportRelationship(relationship, isUpdate);\n await this.trackProgress();\n }\n }\n\n /** Tracks incremental progress */\n private async trackProgress(): Promise<void> {\n this._progressCounter++;\n if (0 === this._progressCounter % this.progressInterval) {\n return this.handler.onProgress();\n }\n }\n}\n\n/**\n * Arguments for [[ChangedInstanceIds.initialize]]\n * @public\n */\nexport type ChangedInstanceIdsInitOptions = ExportChangesOptions & {\n iModel: BriefcaseDb;\n};\n\n/** Class for holding change information.\n * @public\n */\nexport class ChangedInstanceOps {\n public insertIds = new Set<Id64String>();\n public updateIds = new Set<Id64String>();\n public deleteIds = new Set<Id64String>();\n\n /** Initializes the object from IModelJsNative.ChangedInstanceOpsProps. */\n public addFromJson(\n val: IModelJsNative.ChangedInstanceOpsProps | undefined\n ): void {\n if (undefined !== val) {\n if (undefined !== val.insert && Array.isArray(val.insert))\n val.insert.forEach((id: Id64String) => this.insertIds.add(id));\n\n if (undefined !== val.update && Array.isArray(val.update))\n val.update.forEach((id: Id64String) => this.updateIds.add(id));\n\n if (undefined !== val.delete && Array.isArray(val.delete))\n val.delete.forEach((id: Id64String) => this.deleteIds.add(id));\n }\n }\n\n /**\n * Checks if empty.\n * @returns true if there no ids in the ChangedInstanceOps object.\n */\n public get isEmpty(): boolean {\n return (\n 0 === this.insertIds.size &&\n 0 === this.updateIds.size &&\n 0 === this.deleteIds.size\n );\n }\n}\n\n/**\n * Class for discovering modified elements between 2 versions of an iModel.\n * @public\n */\nexport class ChangedInstanceIds {\n public codeSpec = new ChangedInstanceOps();\n public model = new ChangedInstanceOps();\n public element = new ChangedInstanceOps();\n public aspect = new ChangedInstanceOps();\n public relationship = new ChangedInstanceOps();\n public font = new ChangedInstanceOps();\n private _codeSpecSubclassIds?: Set<string>;\n private _modelSubclassIds?: Set<string>;\n private _elementSubclassIds?: Set<string>;\n private _aspectSubclassIds?: Set<string>;\n private _relationshipSubclassIds?: Set<string>;\n private _relationshipSubclassIdsToSkip?: Set<string>;\n\n private _db: IModelDb;\n public constructor(db: IModelDb) {\n this._db = db;\n }\n\n private async setupECClassIds(): Promise<void> {\n this._codeSpecSubclassIds = new Set<string>();\n this._modelSubclassIds = new Set<string>();\n this._elementSubclassIds = new Set<string>();\n this._aspectSubclassIds = new Set<string>();\n this._relationshipSubclassIds = new Set<string>();\n this._relationshipSubclassIdsToSkip = new Set<string>();\n\n const addECClassIdsToSet = async (\n setToModify: Set<string>,\n baseClass: string\n ) => {\n for await (const row of this._db.createQueryReader(\n `SELECT ECInstanceId FROM ECDbMeta.ECClassDef where ECInstanceId IS (${baseClass})`\n )) {\n setToModify.add(row.ECInstanceId);\n }\n };\n const promises = [\n addECClassIdsToSet(this._codeSpecSubclassIds, \"BisCore.CodeSpec\"),\n addECClassIdsToSet(this._modelSubclassIds, \"BisCore.Model\"),\n addECClassIdsToSet(this._elementSubclassIds, \"BisCore.Element\"),\n addECClassIdsToSet(\n this._aspectSubclassIds,\n \"BisCore.ElementUniqueAspect\"\n ),\n addECClassIdsToSet(this._aspectSubclassIds, \"BisCore.ElementMultiAspect\"),\n addECClassIdsToSet(\n this._relationshipSubclassIds,\n \"BisCore.ElementRefersToElements\"\n ),\n addECClassIdsToSet(\n this._relationshipSubclassIdsToSkip,\n \"BisCore.ElementDrivesElement\"\n ),\n ];\n await Promise.all(promises);\n }\n\n private get _ecClassIdsInitialized() {\n return (\n this._codeSpecSubclassIds &&\n this._modelSubclassIds &&\n this._elementSubclassIds &&\n this._aspectSubclassIds &&\n this._relationshipSubclassIds &&\n this._relationshipSubclassIdsToSkip\n );\n }\n\n private isRelationship(ecClassId: string) {\n return this._relationshipSubclassIds?.has(ecClassId);\n }\n\n private isCodeSpec(ecClassId: string) {\n return this._codeSpecSubclassIds?.has(ecClassId);\n }\n\n private isAspect(ecClassId: string) {\n return this._aspectSubclassIds?.has(ecClassId);\n }\n\n private isModel(ecClassId: string) {\n return this._modelSubclassIds?.has(ecClassId);\n }\n\n private isElement(ecClassId: string) {\n return this._elementSubclassIds?.has(ecClassId);\n }\n\n /** Checks if there are any changes.\n * @returns true if there are any changes in the ChangedInstanceIds object.\n */\n public get hasChanges(): boolean {\n return (\n !this.codeSpec.isEmpty ||\n !this.model.isEmpty ||\n !this.element.isEmpty ||\n !this.aspect.isEmpty ||\n !this.relationship.isEmpty ||\n !this.font.isEmpty\n );\n }\n\n /**\n * Adds the provided [[ChangedECInstance]] to the appropriate set of changes by class type (codeSpec, model, element, aspect, or relationship) maintained by this instance of ChangedInstanceIds.\n * If the same ECInstanceId is seen multiple times, the changedInstanceIds will be modified accordingly, i.e. if an id 'x' was updated but now we see 'x' was deleted, we will remove 'x'\n * from the set of updatedIds and add it to the set of deletedIds for the appropriate class type.\n * @param change ChangedECInstance which has the ECInstanceId, changeType (insert, update, delete) and ECClassId of the changed entity\n */\n public async addChange(change: ChangedECInstance): Promise<void> {\n if (!this._ecClassIdsInitialized) await this.setupECClassIds();\n const ecClassId = change.ECClassId ?? change.$meta?.fallbackClassId;\n if (ecClassId === undefined)\n throw new Error(\n `ECClassId was not found for id: ${change.ECInstanceId}! Table is : ${change?.$meta?.tables}`\n );\n const changeType: SqliteChangeOp | undefined = change.$meta?.op;\n if (changeType === undefined)\n throw new Error(\n `ChangeType was undefined for id: ${change.ECInstanceId}.`\n );\n if (this._relationshipSubclassIdsToSkip?.has(ecClassId)) return;\n\n if (this.isRelationship(ecClassId))\n this.handleChange(this.relationship, changeType, change.ECInstanceId);\n else if (this.isCodeSpec(ecClassId))\n this.handleChange(this.codeSpec, changeType, change.ECInstanceId);\n else if (this.isAspect(ecClassId))\n this.handleChange(this.aspect, changeType, change.ECInstanceId);\n else if (this.isModel(ecClassId))\n this.handleChange(this.model, changeType, change.ECInstanceId);\n else if (this.isElement(ecClassId))\n this.handleChange(this.element, changeType, change.ECInstanceId);\n }\n\n /**\n * This method should only be called inside [[IModelTransformer.addCustomChanges]].\n * It adds the provided change to the element changes maintained by this instance of ChangedInstanceIds.\n * If the same ECInstanceId is seen multiple times, the changedInstanceIds will be modified accordingly, i.e. if an id 'x' was updated but now we see 'x' was deleted, we will remove 'x'\n * from the set of updatedIds and add it to the set of deletedIds for the appropriate class type.\n * @note Custom element 'Insert' and 'Update' will mark element's parent model hierarchy and their modeled elements as 'Updated' in [[ChangedInstanceIds.model]] and [[ChangedInstanceIds.element]]. Parent models have to be marked as 'Updated' to make sure that added change is not skipped by transformer. Transformer starts processing elements from RepositoryModel and then visits all child models. Modeled elements hierarchy is marked as updated to trigger their inserts in case a new model (or its parent) needs to be inserted.\n * @note Custom element 'Insert' will also mark element aspects and all element relationships as inserted.\n * @note It is the responsibility of the caller to ensure that the provided id is, in fact an element.\n * @note In most cases, this method does not need to be called. Its only for consumers to mimic changes as if they were found in a changeset, which should only be useful in certain cases such as the changing of filter criteria for a preexisting master branch relationship.\n * @note In data processing with filter criteria scenarios it is important to consistently filter out models and their modeled elements that were previously removed from target via [[addCustomModelChange]] or [[shouldExportElement]] apis.\n * @beta\n */\n public async addCustomElementChange(\n changeType: SqliteChangeOp,\n ids: Id64Arg\n ): Promise<void> {\n if (Id64.sizeOf(ids) === 0) {\n return;\n }\n\n for (const id of Id64.iterable(ids)) {\n this.handleChange(this.element, changeType, id);\n }\n\n if (changeType === \"Deleted\") {\n return;\n }\n\n const idsSet = Id64.toIdSet(ids, true);\n // Parent models have to be marked as 'Updated' to make sure that added change is not skipped by transformer. Transformer starts processing elements from RepositoryModel and then visits all child models.\n // Transformer handles update as insert if element is not found in target, for this reason modeled elements will be also marked as updated to trigger their inserts in case a new model (or its parent) needs to be inserted. Otherwise error would be thrown about missing modeled element while inserting new model.\n const parentModelIds = await this.markParentModelsAsUpdated(idsSet);\n\n // Aspects and relationships of inserted data needs to be marked as inserted otherwise those would not be exported\n if (changeType === \"Inserted\") {\n // Adding parents as well as we are not sure if those were inserted or updated\n parentModelIds.forEach((parentId) => {\n idsSet.add(parentId);\n });\n\n await this.markElementAspectsAsInserted(idsSet);\n // Marking only ElementRefersToElements.classFullName as only those are exported in exportRelationships()\n await this.markElementRelationshipsAsInserted(\n ElementRefersToElements.classFullName,\n idsSet\n );\n }\n }\n\n /**\n * This method should only be called inside [IModelTransformer.addCustomChanges].\n * Adds the provided change to the model changes maintained by this instance of ChangedInstanceIds.\n * If the same ECInstanceId is seen multiple times, the changedInstanceIds will be modified accordingly, i.e. if an id 'x' was updated but now we see 'x' was deleted, we will remove 'x'\n * from the set of updatedIds and add it to the set of deletedIds for the appropriate class type.\n * Will add same change to the model's modeledElement by calling [[ChangedInstanceIds.addCustomElementChange]] which will register more needed changes. This is to ensure the changes from the model and its modeledElement get exported together.\n * @note It is the responsibility of the caller to ensure that the provided id is, in fact a model.\n * @note In most cases, this method does not need to be called. Its only for consumers to mimic changes as if they were found in a changeset, which should only be useful in certain cases such as the changing of filter criteria for a preexisting master branch relationship.\n * @note In data processing with filter criteria scenarios it is important to consistently filter out models and their modeled elements that were previously removed from target via [[addCustomModelChange]] or [[shouldExportElement]] apis.\n * @beta\n */\n public async addCustomModelChange(\n changeType: SqliteChangeOp,\n ids: Id64Arg\n ): Promise<void> {\n // Also add the model's modeledElement to the element changes. The modeledElement and model go hand in hand and have the same id.\n await this.addCustomElementChange(changeType, ids);\n for (const id of Id64.iterable(ids)) {\n this.handleChange(this.model, changeType, id);\n }\n }\n\n /**\n * This method should only be called inside [IModelTransformer.addCustomChanges].\n * Adds the provided change to the aspect changes maintained by this instance of ChangedInstanceIds\n * If the same ECInstanceId is seen multiple times, the changedInstanceIds will be modified accordingly, i.e. if an id 'x' was updated but now we see 'x' was deleted, we will remove 'x'\n * from the set of updatedIds and add it to the set of deletedIds for the appropriate class type.\n * @note It is the responsibility of the caller to ensure that the provided id is, in fact an aspect.\n * @note In most cases, this method does not need to be called. Its only for consumers to mimic changes as if they were found in a changeset, which should only be useful in certain cases such as the changing of filter criteria for a preexisting master branch relationship.\n * @beta\n */\n public addCustomAspectChange(changeType: SqliteChangeOp, ids: Id64Arg): void {\n for (const id of Id64.iterable(ids)) {\n this.handleChange(this.aspect, changeType, id);\n }\n }\n\n /**\n * There is an optimization in [IModelExporter.exportModelContents] which doesn't try to export elements within a model unless the model itself is marked as `Updated` or 'Inserted' in sourceDbChanges. This method is used in [[addCustomElementChange]] and [[addCustomModelChange]] to add the parent model hierarchy to the 'updatedIds' so that the custom element changes are exported.\n * Transformer will insert 'Updated' model to target if it does not exist there already. To handle such case, modeled elements of parent models are also marked as updated. This is done, because model can not be inserted without it's modeled element.\n */\n private async markParentModelsAsUpdated(elementIds: Id64Set) {\n const params = new QueryBinder().bindIdSet(\"elementIds\", elementIds);\n\n const ecQuery = `\n WITH RECURSIVE hierarchy (parentId) AS (\n SELECT Model.Id FROM bis.Element WHERE InVirtualSet(:elementIds, ECInstanceId)\n UNION\n SELECT ParentModel.id\n FROM bis.Model e\n INNER JOIN hierarchy h ON h.parentId = e.ECInstanceId\n )\n SELECT parentId FROM hierarchy where parentId is not null\n `;\n const parentModelIds = new Set<Id64String>();\n for await (const row of this._db.createQueryReader(ecQuery, params)) {\n // Transformer handles update as insert when element does not exist in target.\n // Which means that in scenario where child and parent model are filtered out from target,\n // and child element is inserted trough custom change, its parent model will be marked as updated.\n // Transformer then will:\n // 1. Handle parent update as insert (since it does not exist in target).\n // 2. Will insert child element (otherwise this insert would be ignored due to missing parent).\n this.handleChange(this.model, \"Updated\", row.parentId);\n this.handleChange(this.element, \"Updated\", row.parentId);\n parentModelIds.add(row.parentId);\n }\n return parentModelIds;\n }\n\n private async markElementRelationshipsAsInserted(\n relationshipClassName: string,\n elementIds: Id64Set\n ) {\n const ecQuery = `SELECT ECInstanceId FROM ${relationshipClassName}\n WHERE InVirtualSet(:elementIds, TargetECInstanceId)\n OR InVirtualSet(:elementIds, SourceECInstanceId)`;\n\n const queryBinder = new QueryBinder().bindIdSet(\"elementIds\", elementIds);\n const queryReader = this._db.createQueryReader(ecQuery, queryBinder);\n\n for await (const row of queryReader) {\n this.handleChange(this.relationship, \"Inserted\", row.ECInstanceId);\n }\n }\n\n private async markElementAspectsAsInserted(elementIds: Id64Set) {\n for (const aspectClassName of [\n ElementUniqueAspect.classFullName,\n ElementMultiAspect.classFullName,\n ]) {\n const ecQuery = `Select ECInstanceId from ${aspectClassName} where InVirtualSet(:elementIds, Element.Id)`;\n const queryBinder = new QueryBinder().bindIdSet(\"elementIds\", elementIds);\n const queryReader = this._db.createQueryReader(ecQuery, queryBinder);\n for await (const row of queryReader) {\n this.addCustomAspectChange(\"Inserted\", row.toArray()[0]);\n }\n }\n }\n\n private handleChange(\n changedInstanceOps: ChangedInstanceOps,\n changeType: SqliteChangeOp,\n id: Id64String\n ) {\n // if changeType is a delete and we already have the id in the inserts then we can remove the id from the inserts.\n // if changeType is a delete and we already have the id in the updates then we can remove the id from the updates AND add it to the deletes.\n // if changeType is an insert and we already have the id in the deletes then we can remove the id from the deletes AND add it to the inserts.\n if (changeType === \"Inserted\") {\n changedInstanceOps.insertIds.add(id);\n changedInstanceOps.deleteIds.delete(id);\n } else if (changeType === \"Updated\") {\n if (!changedInstanceOps.insertIds.has(id))\n changedInstanceOps.updateIds.add(id);\n } else if (changeType === \"Deleted\") {\n // If we've inserted the entity at some point already and now we're seeing a delete. We can simply remove the entity from our inserted ids without adding it to deletedIds.\n if (changedInstanceOps.insertIds.has(id))\n changedInstanceOps.insertIds.delete(id);\n else {\n changedInstanceOps.updateIds.delete(id);\n changedInstanceOps.deleteIds.add(id);\n }\n }\n }\n\n /**\n * Initializes a new ChangedInstanceIds object with information taken from a range of changesets.\n * @public\n */\n public static async initialize(\n opts: ChangedInstanceIdsInitOptions\n ): Promise<ChangedInstanceIds | undefined> {\n if (\"changedInstanceIds\" in opts) return opts.changedInstanceIds;\n\n const iModelId = opts.iModel.iModelId;\n\n const startChangeset =\n \"startChangeset\" in opts ? opts.startChangeset : undefined;\n const changesetRanges =\n startChangeset !== undefined\n ? [\n [\n startChangeset.index ??\n (\n await BriefcaseManager.queryChangeset({\n iModelId,\n changeset: {\n id: startChangeset.id ?? opts.iModel.changeset.id,\n },\n })\n ).index,\n opts.iModel.changeset.index ??\n (\n await BriefcaseManager.queryChangeset({\n iModelId,\n changeset: { id: opts.iModel.changeset.id },\n })\n ).index,\n ],\n ]\n : \"changesetRanges\" in opts\n ? opts.changesetRanges\n : undefined;\n const csFileProps =\n changesetRanges !== undefined\n ? (\n await Promise.all(\n changesetRanges.map(async ([first, end]) =>\n BriefcaseManager.downloadChangesets({\n iModelId,\n range: { first, end },\n targetDir: BriefcaseManager.getChangeSetsPath(iModelId),\n })\n )\n )\n ).flat()\n : \"csFileProps\" in opts\n ? opts.csFileProps\n : undefined;\n\n if (csFileProps === undefined) return undefined;\n\n const changedInstanceIds = new ChangedInstanceIds(opts.iModel);\n\n for (const csFile of csFileProps) {\n const csReader = SqliteChangesetReader.openFile({\n fileName: csFile.pathname,\n db: opts.iModel,\n disableSchemaCheck: true,\n });\n const csAdaptor = new ChangesetECAdaptor(csReader);\n const ecChangeUnifier = new PartialECChangeUnifier(opts.iModel);\n while (csAdaptor.step()) {\n ecChangeUnifier.appendFrom(csAdaptor);\n }\n const changes: ChangedECInstance[] = [...ecChangeUnifier.instances];\n\n for (const change of changes) {\n await changedInstanceIds.addChange(change);\n }\n csReader.close();\n }\n return changedInstanceIds;\n }\n}\n"]}
|
|
1
|
+
{"version":3,"file":"IModelExporter.js","sourceRoot":"","sources":["../../src/IModelExporter.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\n * Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n * See LICENSE.md in the project root for license terms and full copyright notice.\n *--------------------------------------------------------------------------------------------*/\n/** @packageDocumentation\n * @module iModels\n */\n\nimport {\n BriefcaseDb,\n BriefcaseManager,\n ChangedECInstance,\n ChangesetECAdaptor,\n DefinitionModel,\n // eslint-disable-next-line @typescript-eslint/no-redeclare\n Element,\n ElementAspect,\n ElementMultiAspect,\n ElementRefersToElements,\n ElementUniqueAspect,\n GeometricElement,\n IModelDb,\n IModelJsNative,\n Model,\n PartialECChangeUnifier,\n RecipeDefinitionElement,\n Relationship,\n SqliteChangeOp,\n SqliteChangesetReader,\n} from \"@itwin/core-backend\";\nimport {\n assert,\n Id64,\n Id64Arg,\n Id64Set,\n Id64String,\n IModelStatus,\n Logger,\n YieldManager,\n} from \"@itwin/core-bentley\";\nimport {\n ChangesetFileProps,\n CodeSpec,\n FontFamilyDescriptor,\n FontId,\n FontProps,\n IModel,\n IModelError,\n QueryBinder,\n} from \"@itwin/core-common\";\nimport {\n ECVersion,\n Schema,\n SchemaKey,\n SchemaLoader,\n} from \"@itwin/ecschema-metadata\";\nimport { TransformerLoggerCategory } from \"./TransformerLoggerCategory\";\nimport * as nodeAssert from \"assert\";\nimport {\n ElementAspectsHandler,\n ExportElementAspectsStrategy,\n} from \"./ExportElementAspectsStrategy\";\nimport { ExportElementAspectsWithElementsStrategy } from \"./ExportElementAspectsWithElementsStrategy\";\n\nconst loggerCategory = TransformerLoggerCategory.IModelExporter;\n\n/**\n * @beta\n * The (optional) result of [[IModelExportHandler.onExportSchema]]\n */\nexport interface ExportSchemaResult {\n /** set this property to notify subclasses where you wrote a schema for later import */\n schemaPath?: string;\n}\n\n/**\n * Arguments for [[IModelExporter.initialize]], usually in case you want to query changedata early\n * such as in the case of the IModelTransformer\n * @beta\n */\nexport type ExporterInitOptions = ExportChangesOptions;\n\n/**\n * Arguments for [[IModelExporter.exportChanges]]\n * @public\n */\nexport type ExportChangesOptions = {\n skipPropagateChangesToRootElements?: boolean;\n} /**\n * an array of ChangesetFileProps which are used to read the changesets and populate the ChangedInstanceIds using [[ChangedInstanceIds.initialize]] in [[IModelExporter.exportChanges]]\n * @note mutually exclusive with @see changesetRanges, @see startChangeset and @see changedInstanceIds, so define one of the four, never more\n */ & (\n | { csFileProps: ChangesetFileProps[] }\n /**\n * Class instance that contains modified elements between 2 versions of an iModel.\n * If this parameter is not provided, then [[ChangedInstanceIds.initialize]] in [[IModelExporter.exportChanges]]\n * will be called to discover changed elements.\n * @note mutually exclusive with @see changesetRanges, @see csFileProps and @see startChangeset, so define one of the four, never more\n */\n | { changedInstanceIds: ChangedInstanceIds }\n /**\n * An ordered array of changeset index ranges, e.g. [[2,2], [4,5]] is [2,4,5]\n * @note mutually exclusive with @see changedInstanceIds, @see csFileProps and @see startChangeset, so define one of the four, never more\n */\n | { changesetRanges: [number, number][] }\n /**\n * Include changes from this changeset up through and including the current changeset.\n * @note To form a range of versions to process, set `startChangeset` for the start (inclusive)\n * of the desired range and open the source iModel as of the end (inclusive) of the desired range.\n * @default the current changeset of the sourceDb, if undefined\n */\n | { startChangeset: { id?: string; index?: number } }\n // eslint-disable-next-line @typescript-eslint/no-empty-object-type\n | {}\n);\n\n/** Handles the events generated by IModelExporter.\n * @note Change information is available when `IModelExportHandler` methods are invoked via [IModelExporter.exportChanges]($transformer), but not available when invoked via [IModelExporter.exportAll]($transformer).\n * @note The handler is intended to be owned by (registered with) and called from the IModelExporter exclusively\n * @see [iModel Transformation and Data Exchange]($docs/learning/transformer/index.md), [IModelExporter]($transformer)\n * @beta\n */\nexport abstract class IModelExportHandler {\n /** If `true` is returned, then the CodeSpec will be exported.\n * @note This method can optionally be overridden to exclude an individual CodeSpec from the export. The base implementation always returns `true`.\n */\n public shouldExportCodeSpec(_codeSpec: CodeSpec): boolean {\n return true;\n }\n\n /** Called when a CodeSpec should be exported.\n * @param codeSpec The CodeSpec to export\n * @param isUpdate If defined, then `true` indicates an UPDATE operation while `false` indicates an INSERT operation. If not defined, then INSERT vs. UPDATE is not known.\n * @note This should be overridden to actually do the export.\n */\n public onExportCodeSpec(\n _codeSpec: CodeSpec,\n _isUpdate: boolean | undefined\n ): void {}\n\n /** Called when a font should be exported.\n * @param font The font to export\n * @param isUpdate If defined, then `true` indicates an UPDATE operation while `false` indicates an INSERT operation. If not defined, then INSERT vs. UPDATE is not known.\n * @note This should be overridden to actually do the export.\n */\n public onExportFont(_font: FontProps, _isUpdate: boolean | undefined): void {}\n\n /** Called when a model should be exported.\n * @param model The model to export\n * @param isUpdate If defined, then `true` indicates an UPDATE operation while `false` indicates an INSERT operation. If not defined, then INSERT vs. UPDATE is not known.\n * @note This should be overridden to actually do the export.\n */\n public onExportModel(_model: Model, _isUpdate: boolean | undefined): void {}\n\n /** Called when a model should be deleted. */\n public async onDeleteModel(_modelId: Id64String): Promise<void> {}\n\n /** If `true` is returned, then the element will be exported.\n * @note This method can optionally be overridden to exclude an individual Element (and its children and ElementAspects) from the export. The base implementation always returns `true`.\n */\n public shouldExportElement(_element: Element): boolean {\n return true;\n }\n\n /** Called when element is skipped instead of exported.\n * @note When an element is skipped, exporter will not export any of its child elements. Because of this, [[onSkipElement]] will not be invoked for any children of a \"skipped\" element.\n */\n public onSkipElement(_elementId: Id64String): void {}\n\n /** Called when an element should be exported.\n * @param element The element to export\n * @param isUpdate If defined, then `true` indicates an UPDATE operation while `false` indicates an INSERT operation. If not defined, then INSERT vs. UPDATE is not known.\n * @note This should be overridden to actually do the export.\n */\n public async onExportElement(\n _element: Element,\n _isUpdate: boolean | undefined\n ): Promise<void> {}\n\n /**\n * Do any asynchronous actions before exporting an element\n * @note Do not implement this handler manually, it is internal, it will be removed.\n * This will become a part of onExportElement once that becomes async\n * @internal\n */\n public async preExportElement(_element: Element): Promise<void> {}\n\n /** Called when an element should be deleted. */\n public onDeleteElement(_elementId: Id64String): void {}\n\n /** If `true` is returned, then the ElementAspect will be exported.\n * @note This method can optionally be overridden to exclude an individual ElementAspect from the export. The base implementation always returns `true`.\n */\n public shouldExportElementAspect(_aspect: ElementAspect): boolean {\n return true;\n }\n\n /** Called when an ElementUniqueAspect should be exported.\n * @param aspect The ElementUniqueAspect to export\n * @param isUpdate If defined, then `true` indicates an UPDATE operation while `false` indicates an INSERT operation. If not defined, then INSERT vs. UPDATE is not known.\n * @note This should be overridden to actually do the export.\n */\n public async onExportElementUniqueAspect(\n _aspect: ElementUniqueAspect,\n _isUpdate: boolean | undefined\n ): Promise<void> {}\n\n /** Called when ElementMultiAspects should be exported.\n * @note This should be overridden to actually do the export.\n */\n public async onExportElementMultiAspects(\n _aspects: ElementMultiAspect[]\n ): Promise<void> {}\n\n /** If `true` is returned, then the relationship will be exported.\n * @note This method can optionally be overridden to exclude an individual CodeSpec from the export. The base implementation always returns `true`.\n */\n public shouldExportRelationship(_relationship: Relationship): boolean {\n return true;\n }\n\n /** Called when a Relationship should be exported.\n * @param relationship The Relationship to export\n * @param isUpdate If defined, then `true` indicates an UPDATE operation while `false` indicates an INSERT operation. If not defined, then INSERT vs. UPDATE is not known.\n * @note This should be overridden to actually do the export.\n */\n public async onExportRelationship(\n _relationship: Relationship,\n _isUpdate: boolean | undefined\n ): Promise<void> {}\n\n /** Called when a relationship should be deleted. */\n public onDeleteRelationship(_relInstanceId: Id64String): void {}\n\n /** If `true` is returned, then the schema will be exported.\n * @note This method can optionally be overridden to exclude an individual schema from the export. The base implementation always returns `true`.\n */\n public shouldExportSchema(_schemaKey: SchemaKey): boolean {\n return true;\n }\n\n /** Called when a schema should be exported.\n * @param schema The schema to export\n * @note This should be overridden to actually do the export.\n * @note return an [[ExportSchemaResult]] with a `schemaPath` property to notify overrides that call `super`\n * where a schema was written for import.\n */\n public async onExportSchema(\n _schema: Schema\n ): Promise<void | ExportSchemaResult> {}\n\n /** This method is called when IModelExporter has made incremental progress based on the [[IModelExporter.progressInterval]] setting.\n * This method is `async` to make it easier to integrate with asynchronous status and health reporting services.\n * @note A subclass may override this method to report custom progress. The base implementation does nothing.\n */\n public async onProgress(): Promise<void> {}\n}\n\n/** Base class for exporting data from an iModel.\n * @note Most uses cases will not require a custom subclass of `IModelExporter`. Instead, it is more typical to subclass/customize [IModelExportHandler]($transformer).\n * @see [iModel Transformation and Data Exchange]($docs/learning/transformer/index.md), [[registerHandler]], [IModelTransformer]($transformer), [IModelImporter]($transformer)\n * @beta\n */\nexport class IModelExporter {\n /** The read-only source iModel. */\n public readonly sourceDb: IModelDb;\n /** A flag that indicates whether element GeometryStreams are loaded or not.\n * @note As an optimization, exporters that don't need geometry can set this flag to `false`. The default is `true`.\n * @note The transformer by default sets this to `false` as an optimization.\n * @note This implies the `wantBRepData` option when loading elements.\n * @see [ElementLoadProps.wantGeometry]($common)\n */\n public wantGeometry: boolean = true;\n /** A flag that indicates whether template models should be exported or not. The default is `true`.\n * @note If only exporting *instances* then template models can be skipped since they are just definitions that are cloned to create new instances.\n * @see [Model.isTemplate]($backend)\n */\n public wantTemplateModels: boolean = true;\n /** A flag that indicates whether *system* schemas should be exported or not. The default is `true` (previously false).\n * This can be set to false for the legacy default behavior, but it may cause errors during schema processing in some cases.\n * @see [[exportSchemas]]\n */\n public wantSystemSchemas: boolean = true;\n /** A flag that determines whether this IModelExporter should visit Elements or not. The default is `true`.\n * @note This flag is available as an optimization when the exporter doesn't need to visit elements, so can skip loading them.\n */\n public visitElements: boolean = true;\n /** A flag that determines whether this IModelExporter should visit Relationships or not. The default is `true`.\n * @note This flag is available as an optimization when the exporter doesn't need to visit relationships, so can skip loading them.\n */\n public visitRelationships: boolean = true;\n /** The number of entities exported before incremental progress should be reported via the [[onProgress]] callback. */\n public progressInterval: number = 1000;\n /** Tracks the current total number of entities exported. */\n private _progressCounter: number = 0;\n /** Optionally cached entity change information */\n private _sourceDbChanges?: ChangedInstanceIds;\n\n /**\n * Retrieve the cached entity change information.\n * @note This will only be initialized after [IModelExporter.exportChanges] is invoked or [IModelExporter.initialize] is called.\n */\n public get sourceDbChanges(): ChangedInstanceIds | undefined {\n return this._sourceDbChanges;\n }\n /** The handler called by this IModelExporter. */\n private _handler: IModelExportHandler | undefined;\n /** The handler called by this IModelExporter. */\n protected get handler(): IModelExportHandler {\n if (undefined === this._handler) {\n throw new Error(\"IModelExportHandler not registered\");\n }\n\n return this._handler;\n }\n\n /** The set of CodeSpecs to exclude from the export. */\n private _excludedCodeSpecNames = new Set<string>();\n /** The set of specific Elements to exclude from the export. */\n private _excludedElementIds = new Set<Id64String>();\n /** The set of Categories where Elements in that Category will be excluded from transformation to the target iModel. */\n private _excludedElementCategoryIds = new Set<Id64String>();\n /** The set of classes of Elements that will be excluded (polymorphically) from transformation to the target iModel. */\n private _excludedElementClasses = new Set<typeof Element>();\n /** The set of classes of Relationships that will be excluded (polymorphically) from transformation to the target iModel. */\n private _excludedRelationshipClasses = new Set<typeof Relationship>();\n\n /** Strategy for how ElementAspects are exported */\n private _exportElementAspectsStrategy: ExportElementAspectsStrategy;\n\n /** Construct a new IModelExporter\n * @param sourceDb The source IModelDb\n * @see registerHandler\n */\n public constructor(\n sourceDb: IModelDb,\n elementAspectsStrategy: new (\n source: IModelDb,\n handler: ElementAspectsHandler\n ) => ExportElementAspectsStrategy = ExportElementAspectsWithElementsStrategy\n ) {\n this.sourceDb = sourceDb;\n this._exportElementAspectsStrategy = new elementAspectsStrategy(\n this.sourceDb,\n {\n onExportElementMultiAspects: async (aspects) =>\n this.handler.onExportElementMultiAspects(aspects),\n onExportElementUniqueAspect: async (aspect, isUpdate) =>\n this.handler.onExportElementUniqueAspect(aspect, isUpdate),\n shouldExportElementAspect: (aspect) =>\n this.handler.shouldExportElementAspect(aspect),\n trackProgress: async () => this.trackProgress(),\n }\n );\n }\n\n /**\n * Initialize prerequisites of exporting. This is implicitly done by any `export*` calls that need initialization\n * which is currently just `exportChanges`.\n * Prefer to not call this explicitly (e.g. just call [[IModelExporter.exportChanges]])\n * @note that if you do call this explicitly, you must do so with the same options that\n * you pass to [[IModelExporter.exportChanges]]\n */\n public async initialize(options: ExporterInitOptions): Promise<void> {\n if (!this.sourceDb.isBriefcaseDb() || this._sourceDbChanges) return;\n\n this._sourceDbChanges = await ChangedInstanceIds.initialize({\n iModel: this.sourceDb,\n ...options,\n });\n if (this._sourceDbChanges === undefined) return;\n\n this._exportElementAspectsStrategy.setAspectChanges(\n this._sourceDbChanges.aspect\n );\n }\n\n /** Register the handler that will be called by IModelExporter. */\n public registerHandler(handler: IModelExportHandler): void {\n this._handler = handler;\n }\n\n /** Add a rule to exclude a CodeSpec */\n public excludeCodeSpec(codeSpecName: string): void {\n this._excludedCodeSpecNames.add(codeSpecName);\n }\n\n /** Add a rule to exclude a specific Element. */\n public excludeElement(elementId: Id64String): void {\n this._excludedElementIds.add(elementId);\n }\n\n /** Add a rule to exclude all Elements in a specified Category. */\n public excludeElementsInCategory(categoryId: Id64String): void {\n this._excludedElementCategoryIds.add(categoryId);\n }\n\n /** Add a rule to exclude all Elements of a specified class. */\n public excludeElementClass(classFullName: string): void {\n this._excludedElementClasses.add(\n this.sourceDb.getJsClass<typeof Element>(classFullName)\n );\n }\n\n /** Add a rule to exclude all ElementAspects of a specified class. */\n public excludeElementAspectClass(classFullName: string): void {\n this._exportElementAspectsStrategy.excludeElementAspectClass(classFullName);\n }\n\n /** Add a rule to exclude all Relationships of a specified class. */\n public excludeRelationshipClass(classFullName: string): void {\n this._excludedRelationshipClasses.add(\n this.sourceDb.getJsClass<typeof Relationship>(classFullName)\n );\n }\n\n /** Export all entity instance types from the source iModel.\n * @note [[exportSchemas]] must be called separately.\n */\n public async exportAll(): Promise<void> {\n await this.initialize({});\n\n await this.exportCodeSpecs();\n await this.exportFonts();\n await this.exportModel(IModel.repositoryModelId);\n await this.exportRelationships(ElementRefersToElements.classFullName);\n }\n\n /** Export changes from the source iModel.\n * Inserts, updates, and deletes are determined by inspecting the changeset(s).\n * @note To form a range of versions to process, set `startChangesetId` for the start (inclusive) of the desired\n * range and open the source iModel as of the end (inclusive) of the desired range.\n * @note the changedInstanceIds are just for this call to exportChanges, so you must continue to pass it in\n * for consecutive calls\n */\n public async exportChanges(args?: ExportChangesOptions): Promise<void> {\n if (!this.sourceDb.isBriefcaseDb())\n throw new IModelError(\n IModelStatus.BadRequest,\n \"Must be a briefcase to export changes\"\n );\n\n if (\n \"\" === this.sourceDb.changeset.id &&\n !this.sourceDbChanges?.hasChanges\n ) {\n await this.exportAll(); // no changesets or custom changes, so revert to exportAll\n return;\n }\n\n const startChangeset =\n args && \"startChangeset\" in args ? args.startChangeset : undefined;\n\n const initOpts: ExporterInitOptions = {\n startChangeset: { id: startChangeset?.id },\n };\n await this.initialize(initOpts);\n // _sourceDbChanges are initialized in this.initialize\n nodeAssert(\n this._sourceDbChanges !== undefined,\n \"sourceDbChanges must be initialized.\"\n );\n\n await this.exportCodeSpecs();\n await this.exportFonts();\n if (initOpts.skipPropagateChangesToRootElements) {\n await this.exportModelContents(IModel.repositoryModelId);\n await this.exportSubModels(IModel.repositoryModelId);\n } else {\n await this.exportModel(IModel.repositoryModelId);\n }\n await this.exportAllAspects();\n await this.exportRelationships(ElementRefersToElements.classFullName);\n\n // handle deletes\n if (this.visitElements) {\n // must delete models first since they have a constraint on the submodeling element which may also be deleted\n for (const modelId of this._sourceDbChanges.model.deleteIds) {\n await this.handler.onDeleteModel(modelId);\n }\n for (const elementId of this._sourceDbChanges.element.deleteIds) {\n // We don't know how the handler wants to handle deletions, and we don't have enough information\n // to know if deleted entities were related, so when processing changes, ignore errors from deletion.\n // Technically, to keep the ignored error scope small, we ignore only the error of looking up a missing element,\n // that approach works at least for the IModelTransformer.\n // In the future, the handler may be responsible for doing the work of finding out which elements were cascade deleted,\n // and returning them for the exporter to use to avoid double-deleting with error ignoring\n try {\n this.handler.onDeleteElement(elementId);\n } catch (err: unknown) {\n const isMissingErr =\n err instanceof IModelError &&\n err.errorNumber === IModelStatus.NotFound;\n if (!isMissingErr) throw err;\n }\n }\n }\n\n if (this.visitRelationships) {\n for (const relInstanceId of this._sourceDbChanges.relationship\n .deleteIds) {\n this.handler.onDeleteRelationship(relInstanceId);\n }\n }\n\n // Enable consecutive exportChanges runs without the need to re-instantiate the exporter.\n // You can counteract the obvious impact of losing this expensive data by always calling\n // exportChanges with the [[ExportChangesOptions.changedInstanceIds]] option set to\n // whatever you want\n if (this._resetChangeDataOnExport) this._sourceDbChanges = undefined;\n }\n\n private _resetChangeDataOnExport = true;\n\n /** Export schemas from the source iModel.\n * @note This must be called separately from [[exportAll]] or [[exportChanges]].\n */\n public async exportSchemas(): Promise<void> {\n const sql = `\n SELECT s.Name, s.VersionMajor, s.VersionWrite, s.VersionMinor\n FROM ECDbMeta.ECSchemaDef s\n ${\n this.wantSystemSchemas\n ? \"\"\n : `\n WHERE ECInstanceId >= (SELECT ECInstanceId FROM ECDbMeta.ECSchemaDef WHERE Name='BisCore')\n `\n }\n ORDER BY ECInstanceId\n `;\n const schemaNamesToExport: string[] = [];\n for await (const row of this.sourceDb.createQueryReader(sql)) {\n const schemaName = row[0];\n const versionMajor = row[1];\n const versionWrite = row[2];\n const versionMinor = row[3];\n const schemaKey = new SchemaKey(\n schemaName,\n new ECVersion(versionMajor, versionWrite, versionMinor)\n );\n if (this.handler.shouldExportSchema(schemaKey)) {\n schemaNamesToExport.push(schemaName);\n }\n }\n if (schemaNamesToExport.length === 0) return;\n\n const schemaLoader = new SchemaLoader((name: string) =>\n this.sourceDb.getSchemaProps(name)\n );\n await Promise.all(\n schemaNamesToExport.map(async (schemaName) => {\n const schema = schemaLoader.getSchema(schemaName);\n Logger.logTrace(loggerCategory, `exportSchema(${schemaName})`);\n return this.handler.onExportSchema(schema);\n })\n );\n }\n\n /** For logging, indicate the change type if known. */\n private getChangeOpSuffix(isUpdate: boolean | undefined): string {\n return isUpdate ? \" UPDATE\" : undefined === isUpdate ? \"\" : \" INSERT\";\n }\n\n /** Export all CodeSpecs from the source iModel.\n * @note This method is called from [[exportChanges]] and [[exportAll]], so it only needs to be called directly when exporting a subset of an iModel.\n */\n public async exportCodeSpecs(): Promise<void> {\n Logger.logTrace(loggerCategory, \"exportCodeSpecs()\");\n const sql = \"SELECT Name FROM BisCore:CodeSpec ORDER BY ECInstanceId\";\n for await (const row of this.sourceDb.createQueryReader(sql)) {\n await this.exportCodeSpecByName(row.name);\n }\n }\n\n /** Export a single CodeSpec from the source iModel.\n * @note This method is called from [[exportChanges]] and [[exportAll]], so it only needs to be called directly when exporting a subset of an iModel.\n */\n public async exportCodeSpecByName(codeSpecName: string): Promise<void> {\n const codeSpec: CodeSpec = this.sourceDb.codeSpecs.getByName(codeSpecName);\n let isUpdate: boolean | undefined;\n if (undefined !== this._sourceDbChanges) {\n // is changeset information available?\n if (this._sourceDbChanges.codeSpec.insertIds.has(codeSpec.id)) {\n isUpdate = false;\n } else if (this._sourceDbChanges.codeSpec.updateIds.has(codeSpec.id)) {\n isUpdate = true;\n } else {\n return; // not in changeset, don't export\n }\n }\n // passed changeset test, now apply standard exclusion rules\n if (this._excludedCodeSpecNames.has(codeSpec.name)) {\n Logger.logInfo(loggerCategory, `Excluding CodeSpec: ${codeSpec.name}`);\n return;\n }\n // CodeSpec has passed standard exclusion rules, now give handler a chance to accept/reject export\n if (this.handler.shouldExportCodeSpec(codeSpec)) {\n Logger.logTrace(\n loggerCategory,\n `exportCodeSpec(${codeSpecName})${this.getChangeOpSuffix(isUpdate)}`\n );\n this.handler.onExportCodeSpec(codeSpec, isUpdate);\n return this.trackProgress();\n }\n }\n\n /** Export a single CodeSpec from the source iModel.\n * @note This method is called from [[exportChanges]] and [[exportAll]], so it only needs to be called directly when exporting a subset of an iModel.\n */\n public async exportCodeSpecById(codeSpecId: Id64String): Promise<void> {\n const codeSpec: CodeSpec = this.sourceDb.codeSpecs.getById(codeSpecId);\n return this.exportCodeSpecByName(codeSpec.name);\n }\n\n /** Export all fonts from the source iModel.\n * @note This method is called from [[exportChanges]] and [[exportAll]], so it only needs to be called directly when exporting a subset of an iModel.\n */\n public async exportFonts(): Promise<void> {\n Logger.logTrace(loggerCategory, \"exportFonts()\");\n for (const font of this.sourceDb.fonts.queryMappedFamilies()) {\n await this.exportFontByFontProps(font);\n }\n }\n\n /** Export a single font from the source iModel.\n * @note multiple fonts can have the same font name, if a font with a specific type is needed use exportFontByFontFamilyDescriptor.\n * If not this will only export the first font with this type in the db.\n */\n public async exportFontByName(fontName: string): Promise<void> {\n Logger.logTrace(loggerCategory, `exportFontByName(${fontName})`);\n const fontId: FontId | undefined = this.sourceDb.fonts.findId({\n name: fontName,\n });\n if (undefined !== fontId) {\n await this.exportFontByNumber(fontId);\n }\n }\n\n /** Export a single font from the source iModel.\n * @note This method is called from [[exportChanges]] and [[exportAll]], so it only needs to be called directly when exporting a subset of an iModel.\n */\n public async exportFontByFontProps(fontProps: FontProps): Promise<void> {\n Logger.logTrace(\n loggerCategory,\n `exportFontByFamily(${fontProps.name}, ${fontProps.type})`\n );\n this.handler.onExportFont(fontProps, true);\n return this.trackProgress();\n }\n\n /** Export a single font from the source iModel.\n * @note This method is called from [[exportChanges]] and [[exportAll]], so it only needs to be called directly when exporting a subset of an iModel.\n */\n public async exportFontByFontFamilyDescriptor(\n fontFamily: FontFamilyDescriptor\n ): Promise<void> {\n Logger.logTrace(\n loggerCategory,\n `exportFontByFamilyDescriptor(${fontFamily.name}, ${fontFamily.type})`\n );\n const fontId: FontId | undefined =\n await this.sourceDb.fonts.acquireId(fontFamily);\n if (undefined !== fontId) {\n await this.exportFontByFontProps({ ...fontFamily, id: fontId });\n }\n }\n\n /** Export a single font from the source iModel.\n * @note This method is called from [[exportChanges]] and [[exportAll]], so it only needs to be called directly when exporting a subset of an iModel.\n */\n public async exportFontByNumber(fontNumber: number): Promise<void> {\n /** sourceDbChanges now works by using TS ChangesetECAdaptor which doesn't pick up changes to fonts since fonts is not an ec table.\n * So lets always export fonts for the time being by always setting isUpdate = true.\n * It is very rare and even problematic for the font table to reach a large size, so it is not a bottleneck in transforming changes.\n * See https://github.com/iTwin/imodel-transformer/pull/135 for removed code.\n */\n Logger.logTrace(loggerCategory, `exportFontById(${fontNumber})`);\n const font: FontFamilyDescriptor | undefined =\n this.sourceDb.fonts.findDescriptor(fontNumber);\n if (undefined !== font) {\n await this.exportFontByFontFamilyDescriptor(font);\n }\n }\n\n /** Export the model container, contents, and sub-models from the source iModel.\n * @note This method is called from [[exportChanges]] and [[exportAll]], so it only needs to be called directly when exporting a subset of an iModel.\n */\n public async exportModel(modeledElementId: Id64String): Promise<void> {\n const model: Model = this.sourceDb.models.getModel(modeledElementId);\n if (model.isTemplate && !this.wantTemplateModels) {\n return;\n }\n const modeledElement: Element = this.sourceDb.elements.getElement({\n id: modeledElementId,\n wantGeometry: this.wantGeometry,\n wantBRepData: this.wantGeometry,\n });\n Logger.logTrace(loggerCategory, `exportModel(${modeledElementId})`);\n if (this.shouldExportElement(modeledElement)) {\n await this.exportModelContainer(model);\n if (this.visitElements) {\n await this.exportModelContents(modeledElementId);\n }\n await this.exportSubModels(modeledElementId);\n }\n }\n\n /** Export the model (the container only) from the source iModel. */\n private async exportModelContainer(model: Model): Promise<void> {\n let isUpdate: boolean | undefined;\n if (undefined !== this._sourceDbChanges) {\n // is changeset information available?\n if (this._sourceDbChanges.model.insertIds.has(model.id)) {\n isUpdate = false;\n } else if (this._sourceDbChanges.model.updateIds.has(model.id)) {\n isUpdate = true;\n } else {\n return; // not in changeset, don't export\n }\n }\n this.handler.onExportModel(model, isUpdate);\n return this.trackProgress();\n }\n\n private _yieldManager = new YieldManager();\n\n /** Export the model contents.\n * @param modelId The only required parameter\n * @param elementClassFullName Can be optionally specified if the goal is to export a subset of the model contents\n * @param skipRootSubject Decides whether or not to export the root Subject. It is normally left undefined except for internal implementation purposes.\n * @note This method is called from [[exportChanges]] and [[exportAll]], so it only needs to be called directly when exporting a subset of an iModel.\n */\n public async exportModelContents(\n modelId: Id64String,\n elementClassFullName: string = Element.classFullName,\n skipRootSubject?: boolean\n ): Promise<void> {\n if (skipRootSubject) {\n // NOTE: IModelTransformer.processAll should skip the root Subject since it is specific to the individual iModel and is not part of the changes that need to be synchronized\n // NOTE: IModelExporter.exportAll should not skip the root Subject since the goal is to export everything\n assert(modelId === IModel.repositoryModelId); // flag is only relevant when processing the RepositoryModel\n }\n if (!this.visitElements) {\n Logger.logTrace(\n loggerCategory,\n `visitElements=false, skipping exportModelContents(${modelId})`\n );\n return;\n }\n if (undefined !== this._sourceDbChanges) {\n // is changeset information available?\n if (\n !this._sourceDbChanges.model.insertIds.has(modelId) &&\n !this._sourceDbChanges.model.updateIds.has(modelId)\n ) {\n return; // this optimization assumes that the Model changes (LastMod) any time an Element in the Model changes\n }\n }\n Logger.logTrace(loggerCategory, `exportModelContents(${modelId})`);\n let sql: string;\n if (skipRootSubject) {\n sql = `SELECT ECInstanceId FROM ${elementClassFullName} WHERE Parent.Id IS NULL AND Model.Id=:modelId AND ECInstanceId!=:rootSubjectId ORDER BY ECInstanceId`;\n } else {\n sql = `SELECT ECInstanceId FROM ${elementClassFullName} WHERE Parent.Id IS NULL AND Model.Id=:modelId ORDER BY ECInstanceId`;\n }\n const params = new QueryBinder().bindId(\"modelId\", modelId);\n if (skipRootSubject) {\n params.bindId(\"rootSubjectId\", IModel.rootSubjectId);\n }\n for await (const row of this.sourceDb.createQueryReader(sql, params, {\n usePrimaryConn: true,\n })) {\n await this.exportElement(row.id);\n await this._yieldManager.allowYield();\n }\n }\n\n /** Export the sub-models directly below the specified model.\n * @note This method is called from [[exportChanges]] and [[exportAll]], so it only needs to be called directly when exporting a subset of an iModel.\n */\n public async exportSubModels(parentModelId: Id64String): Promise<void> {\n Logger.logTrace(loggerCategory, `exportSubModels(${parentModelId})`);\n const definitionModelIds: Id64String[] = [];\n const otherModelIds: Id64String[] = [];\n const sql = `SELECT ECInstanceId FROM ${Model.classFullName} WHERE ParentModel.Id=:parentModelId ORDER BY ECInstanceId`;\n const params = new QueryBinder().bindId(\"parentModelId\", parentModelId);\n for await (const row of this.sourceDb.createQueryReader(sql, params)) {\n const modelId: Id64String = row.ecinstanceid;\n const model: Model = this.sourceDb.models.getModel(modelId);\n if (model instanceof DefinitionModel) {\n definitionModelIds.push(modelId);\n } else {\n otherModelIds.push(modelId);\n }\n }\n // export DefinitionModels before other types of Models\n for (const definitionModelId of definitionModelIds) {\n await this.exportModel(definitionModelId);\n }\n for (const otherModelId of otherModelIds) {\n await this.exportModel(otherModelId);\n }\n }\n\n /** Returns true if the specified element should be exported.\n * This considers the standard IModelExporter exclusion rules plus calls [IModelExportHandler.shouldExportElement]($transformer) for any custom exclusion rules.\n * @note This method is called from within [[exportChanges]] and [[exportAll]], so usually does not need to be called directly.\n */\n public shouldExportElement(element: Element): boolean {\n if (this._excludedElementIds.has(element.id)) {\n Logger.logInfo(loggerCategory, `Excluded element ${element.id} by Id`);\n return false;\n }\n if (element instanceof GeometricElement) {\n if (this._excludedElementCategoryIds.has(element.category)) {\n Logger.logInfo(\n loggerCategory,\n `Excluded element ${element.id} by Category`\n );\n return false;\n }\n }\n if (\n !this.wantTemplateModels &&\n element instanceof RecipeDefinitionElement\n ) {\n Logger.logInfo(\n loggerCategory,\n `Excluded RecipeDefinitionElement ${element.id} because wantTemplate=false`\n );\n return false;\n }\n for (const excludedElementClass of this._excludedElementClasses) {\n if (element instanceof excludedElementClass) {\n Logger.logInfo(\n loggerCategory,\n `Excluded element ${element.id} by class: ${excludedElementClass.classFullName}`\n );\n return false;\n }\n }\n // element has passed standard exclusion rules, now give handler a chance to accept/reject\n return this.handler.shouldExportElement(element);\n }\n\n /** Export the specified element, its child elements (if applicable), and any owned ElementAspects.\n * @note This method is called from [[exportChanges]] and [[exportAll]], so it only needs to be called directly when exporting a subset of an iModel.\n */\n public async exportElement(elementId: Id64String): Promise<void> {\n if (!this.visitElements) {\n Logger.logTrace(\n loggerCategory,\n `visitElements=false, skipping exportElement(${elementId})`\n );\n return;\n }\n\n // Return early if the elementId is already in the excludedElementIds, that way we don't need to load the element from the db.\n if (this._excludedElementIds.has(elementId)) {\n Logger.logInfo(loggerCategory, `Excluded element ${elementId} by Id`);\n this.handler.onSkipElement(elementId);\n return;\n }\n\n // are we processing changes?\n const isUpdate = this._sourceDbChanges?.element.insertIds.has(elementId)\n ? false\n : this._sourceDbChanges?.element.updateIds.has(elementId)\n ? true\n : undefined;\n\n const element = this.sourceDb.elements.getElement({\n id: elementId,\n wantGeometry: this.wantGeometry,\n wantBRepData: this.wantGeometry,\n });\n Logger.logTrace(\n loggerCategory,\n `exportElement(${\n element.id\n }, \"${element.getDisplayLabel()}\")${this.getChangeOpSuffix(isUpdate)}`\n );\n // the order and `await`ing of calls beyond here is depended upon by the IModelTransformer for a current bug workaround\n if (this.shouldExportElement(element)) {\n await this.handler.preExportElement(element);\n await this.handler.onExportElement(element, isUpdate);\n await this.trackProgress();\n await this._exportElementAspectsStrategy.exportElementAspectsForElement(\n elementId\n );\n return this.exportChildElements(elementId);\n } else {\n this.handler.onSkipElement(element.id);\n }\n }\n\n /** Export the child elements of the specified element from the source iModel.\n * @note This method is called from [[exportChanges]] and [[exportAll]], so it only needs to be called directly when exporting a subset of an iModel.\n */\n public async exportChildElements(elementId: Id64String): Promise<void> {\n if (!this.visitElements) {\n Logger.logTrace(\n loggerCategory,\n `visitElements=false, skipping exportChildElements(${elementId})`\n );\n return;\n }\n const childElementIds: Id64String[] =\n this.sourceDb.elements.queryChildren(elementId);\n if (childElementIds.length > 0) {\n Logger.logTrace(loggerCategory, `exportChildElements(${elementId})`);\n for (const childElementId of childElementIds) {\n await this.exportElement(childElementId);\n }\n }\n }\n\n /** Exports all aspects present in the iModel.\n */\n private async exportAllAspects(): Promise<void> {\n return this._exportElementAspectsStrategy.exportAllElementAspects();\n }\n\n /** Exports all relationships that subclass from the specified base class.\n * @note This method is called from [[exportChanges]] and [[exportAll]], so it only needs to be called directly when exporting a subset of an iModel.\n */\n public async exportRelationships(\n baseRelClassFullName: string\n ): Promise<void> {\n if (!this.visitRelationships) {\n Logger.logTrace(\n loggerCategory,\n \"visitRelationships=false, skipping exportRelationships()\"\n );\n return;\n }\n Logger.logTrace(\n loggerCategory,\n `exportRelationships(${baseRelClassFullName})`\n );\n const sql = `SELECT r.ECInstanceId, ec_className(r.ECClassId, 's.c') as ClassName FROM ${baseRelClassFullName} r\n JOIN bis.Element s ON s.ECInstanceId = r.SourceECInstanceId\n JOIN bis.Element t ON t.ECInstanceId = r.TargetECInstanceId\n WHERE s.ECInstanceId IS NOT NULL AND t.ECInstanceId IS NOT NULL`;\n for await (const row of this.sourceDb.createQueryReader(sql)) {\n const relationshipId = row.ecinstanceid;\n const relationshipClass = row.classname;\n await this.exportRelationship(relationshipClass, relationshipId); // must call exportRelationship using the actual classFullName, not baseRelClassFullName\n await this._yieldManager.allowYield();\n }\n }\n\n /** Export a relationship from the source iModel. */\n public async exportRelationship(\n relClassFullName: string,\n relInstanceId: Id64String\n ): Promise<void> {\n if (!this.visitRelationships) {\n Logger.logTrace(\n loggerCategory,\n `visitRelationships=false, skipping exportRelationship(${relClassFullName}, ${relInstanceId})`\n );\n return;\n }\n let isUpdate: boolean | undefined;\n if (undefined !== this._sourceDbChanges) {\n // is changeset information available?\n if (this._sourceDbChanges.relationship.insertIds.has(relInstanceId)) {\n isUpdate = false;\n } else if (\n this._sourceDbChanges.relationship.updateIds.has(relInstanceId)\n ) {\n isUpdate = true;\n } else {\n return; // not in changeset, don't export\n }\n }\n // passed changeset test, now apply standard exclusion rules\n Logger.logTrace(\n loggerCategory,\n `exportRelationship(${relClassFullName}, ${relInstanceId})`\n );\n const relationship: Relationship = this.sourceDb.relationships.getInstance(\n relClassFullName,\n relInstanceId\n );\n for (const excludedRelationshipClass of this._excludedRelationshipClasses) {\n if (relationship instanceof excludedRelationshipClass) {\n Logger.logInfo(\n loggerCategory,\n `Excluded relationship by class: ${excludedRelationshipClass.classFullName}`\n );\n return;\n }\n }\n // relationship has passed standard exclusion rules, now give handler a chance to accept/reject export\n if (this.handler.shouldExportRelationship(relationship)) {\n await this.handler.onExportRelationship(relationship, isUpdate);\n await this.trackProgress();\n }\n }\n\n /** Tracks incremental progress */\n private async trackProgress(): Promise<void> {\n this._progressCounter++;\n if (0 === this._progressCounter % this.progressInterval) {\n return this.handler.onProgress();\n }\n }\n}\n\n/**\n * Arguments for [[ChangedInstanceIds.initialize]]\n * @public\n */\nexport type ChangedInstanceIdsInitOptions = ExportChangesOptions & {\n iModel: BriefcaseDb;\n};\n\n/** Class for holding change information.\n * @public\n */\nexport class ChangedInstanceOps {\n public insertIds = new Set<Id64String>();\n public updateIds = new Set<Id64String>();\n public deleteIds = new Set<Id64String>();\n\n /** Initializes the object from IModelJsNative.ChangedInstanceOpsProps. */\n public addFromJson(\n val: IModelJsNative.ChangedInstanceOpsProps | undefined\n ): void {\n if (undefined !== val) {\n if (undefined !== val.insert && Array.isArray(val.insert))\n val.insert.forEach((id: Id64String) => this.insertIds.add(id));\n\n if (undefined !== val.update && Array.isArray(val.update))\n val.update.forEach((id: Id64String) => this.updateIds.add(id));\n\n if (undefined !== val.delete && Array.isArray(val.delete))\n val.delete.forEach((id: Id64String) => this.deleteIds.add(id));\n }\n }\n\n /**\n * Checks if empty.\n * @returns true if there no ids in the ChangedInstanceOps object.\n */\n public get isEmpty(): boolean {\n return (\n 0 === this.insertIds.size &&\n 0 === this.updateIds.size &&\n 0 === this.deleteIds.size\n );\n }\n}\n\n/**\n * Class for discovering modified elements between 2 versions of an iModel.\n * @public\n */\nexport class ChangedInstanceIds {\n public codeSpec = new ChangedInstanceOps();\n public model = new ChangedInstanceOps();\n public element = new ChangedInstanceOps();\n public aspect = new ChangedInstanceOps();\n public relationship = new ChangedInstanceOps();\n public font = new ChangedInstanceOps();\n private _codeSpecSubclassIds?: Set<string>;\n private _modelSubclassIds?: Set<string>;\n private _elementSubclassIds?: Set<string>;\n private _aspectSubclassIds?: Set<string>;\n private _relationshipSubclassIds?: Set<string>;\n private _relationshipSubclassIdsToSkip?: Set<string>;\n\n private _db: IModelDb;\n public constructor(db: IModelDb) {\n this._db = db;\n }\n\n private async setupECClassIds(): Promise<void> {\n this._codeSpecSubclassIds = new Set<string>();\n this._modelSubclassIds = new Set<string>();\n this._elementSubclassIds = new Set<string>();\n this._aspectSubclassIds = new Set<string>();\n this._relationshipSubclassIds = new Set<string>();\n this._relationshipSubclassIdsToSkip = new Set<string>();\n\n const addECClassIdsToSet = async (\n setToModify: Set<string>,\n baseClass: string\n ) => {\n for await (const row of this._db.createQueryReader(\n `SELECT ECInstanceId FROM ECDbMeta.ECClassDef where ECInstanceId IS (${baseClass})`\n )) {\n setToModify.add(row.ECInstanceId);\n }\n };\n const promises = [\n addECClassIdsToSet(this._codeSpecSubclassIds, \"BisCore.CodeSpec\"),\n addECClassIdsToSet(this._modelSubclassIds, \"BisCore.Model\"),\n addECClassIdsToSet(this._elementSubclassIds, \"BisCore.Element\"),\n addECClassIdsToSet(\n this._aspectSubclassIds,\n \"BisCore.ElementUniqueAspect\"\n ),\n addECClassIdsToSet(this._aspectSubclassIds, \"BisCore.ElementMultiAspect\"),\n addECClassIdsToSet(\n this._relationshipSubclassIds,\n \"BisCore.ElementRefersToElements\"\n ),\n addECClassIdsToSet(\n this._relationshipSubclassIdsToSkip,\n \"BisCore.ElementDrivesElement\"\n ),\n ];\n await Promise.all(promises);\n }\n\n private get _ecClassIdsInitialized() {\n return (\n this._codeSpecSubclassIds &&\n this._modelSubclassIds &&\n this._elementSubclassIds &&\n this._aspectSubclassIds &&\n this._relationshipSubclassIds &&\n this._relationshipSubclassIdsToSkip\n );\n }\n\n private isRelationship(ecClassId: string) {\n return this._relationshipSubclassIds?.has(ecClassId);\n }\n\n private isCodeSpec(ecClassId: string) {\n return this._codeSpecSubclassIds?.has(ecClassId);\n }\n\n private isAspect(ecClassId: string) {\n return this._aspectSubclassIds?.has(ecClassId);\n }\n\n private isModel(ecClassId: string) {\n return this._modelSubclassIds?.has(ecClassId);\n }\n\n private isElement(ecClassId: string) {\n return this._elementSubclassIds?.has(ecClassId);\n }\n\n /** Checks if there are any changes.\n * @returns true if there are any changes in the ChangedInstanceIds object.\n */\n public get hasChanges(): boolean {\n return (\n !this.codeSpec.isEmpty ||\n !this.model.isEmpty ||\n !this.element.isEmpty ||\n !this.aspect.isEmpty ||\n !this.relationship.isEmpty ||\n !this.font.isEmpty\n );\n }\n\n /**\n * Adds the provided [[ChangedECInstance]] to the appropriate set of changes by class type (codeSpec, model, element, aspect, or relationship) maintained by this instance of ChangedInstanceIds.\n * If the same ECInstanceId is seen multiple times, the changedInstanceIds will be modified accordingly, i.e. if an id 'x' was updated but now we see 'x' was deleted, we will remove 'x'\n * from the set of updatedIds and add it to the set of deletedIds for the appropriate class type.\n * @param change ChangedECInstance which has the ECInstanceId, changeType (insert, update, delete) and ECClassId of the changed entity\n */\n public async addChange(change: ChangedECInstance): Promise<void> {\n if (!this._ecClassIdsInitialized) await this.setupECClassIds();\n const ecClassId = change.ECClassId ?? change.$meta?.fallbackClassId;\n if (ecClassId === undefined)\n throw new Error(\n `ECClassId was not found for id: ${change.ECInstanceId}! Table is : ${change?.$meta?.tables}`\n );\n const changeType: SqliteChangeOp | undefined = change.$meta?.op;\n if (changeType === undefined)\n throw new Error(\n `ChangeType was undefined for id: ${change.ECInstanceId}.`\n );\n if (this._relationshipSubclassIdsToSkip?.has(ecClassId)) return;\n\n if (this.isRelationship(ecClassId))\n this.handleChange(this.relationship, changeType, change.ECInstanceId);\n else if (this.isCodeSpec(ecClassId))\n this.handleChange(this.codeSpec, changeType, change.ECInstanceId);\n else if (this.isAspect(ecClassId))\n this.handleChange(this.aspect, changeType, change.ECInstanceId);\n else if (this.isModel(ecClassId))\n this.handleChange(this.model, changeType, change.ECInstanceId);\n else if (this.isElement(ecClassId))\n this.handleChange(this.element, changeType, change.ECInstanceId);\n }\n\n /**\n * This method should only be called inside [[IModelTransformer.addCustomChanges]].\n * It adds the provided change to the element changes maintained by this instance of ChangedInstanceIds.\n * If the same ECInstanceId is seen multiple times, the changedInstanceIds will be modified accordingly, i.e. if an id 'x' was updated but now we see 'x' was deleted, we will remove 'x'\n * from the set of updatedIds and add it to the set of deletedIds for the appropriate class type.\n * @note Custom element 'Insert' and 'Update' will mark element's parent model hierarchy and their modeled elements as 'Updated' in [[ChangedInstanceIds.model]] and [[ChangedInstanceIds.element]]. Parent models have to be marked as 'Updated' to make sure that added change is not skipped by transformer. Transformer starts processing elements from RepositoryModel and then visits all child models. Modeled elements hierarchy is marked as updated to trigger their inserts in case a new model (or its parent) needs to be inserted.\n * @note Custom element 'Insert' will also mark element aspects and all element relationships as inserted.\n * @note It is the responsibility of the caller to ensure that the provided id is, in fact an element.\n * @note In most cases, this method does not need to be called. Its only for consumers to mimic changes as if they were found in a changeset, which should only be useful in certain cases such as the changing of filter criteria for a preexisting master branch relationship.\n * @note In data processing with filter criteria scenarios it is important to consistently filter out models and their modeled elements that were previously removed from target via [[addCustomModelChange]] or [[shouldExportElement]] apis.\n * @beta\n */\n public async addCustomElementChange(\n changeType: SqliteChangeOp,\n ids: Id64Arg\n ): Promise<void> {\n if (Id64.sizeOf(ids) === 0) {\n return;\n }\n\n for (const id of Id64.iterable(ids)) {\n this.handleChange(this.element, changeType, id);\n }\n\n if (changeType === \"Deleted\") {\n return;\n }\n\n const idsSet = Id64.toIdSet(ids, true);\n // Parent models have to be marked as 'Updated' to make sure that added change is not skipped by transformer. Transformer starts processing elements from RepositoryModel and then visits all child models.\n // Transformer handles update as insert if element is not found in target, for this reason modeled elements will be also marked as updated to trigger their inserts in case a new model (or its parent) needs to be inserted. Otherwise error would be thrown about missing modeled element while inserting new model.\n const parentModelIds = await this.markParentModelsAsUpdated(idsSet);\n\n // Aspects and relationships of inserted data needs to be marked as inserted otherwise those would not be exported\n if (changeType === \"Inserted\") {\n // Adding parents as well as we are not sure if those were inserted or updated\n parentModelIds.forEach((parentId) => {\n idsSet.add(parentId);\n });\n\n await this.markElementAspectsAsInserted(idsSet);\n // Marking only ElementRefersToElements.classFullName as only those are exported in exportRelationships()\n await this.markElementRelationshipsAsInserted(\n ElementRefersToElements.classFullName,\n idsSet\n );\n }\n }\n\n /**\n * This method should only be called inside [IModelTransformer.addCustomChanges].\n * Adds the provided change to the model changes maintained by this instance of ChangedInstanceIds.\n * If the same ECInstanceId is seen multiple times, the changedInstanceIds will be modified accordingly, i.e. if an id 'x' was updated but now we see 'x' was deleted, we will remove 'x'\n * from the set of updatedIds and add it to the set of deletedIds for the appropriate class type.\n * Will add same change to the model's modeledElement by calling [[ChangedInstanceIds.addCustomElementChange]] which will register more needed changes. This is to ensure the changes from the model and its modeledElement get exported together.\n * @note It is the responsibility of the caller to ensure that the provided id is, in fact a model.\n * @note In most cases, this method does not need to be called. Its only for consumers to mimic changes as if they were found in a changeset, which should only be useful in certain cases such as the changing of filter criteria for a preexisting master branch relationship.\n * @note In data processing with filter criteria scenarios it is important to consistently filter out models and their modeled elements that were previously removed from target via [[addCustomModelChange]] or [[shouldExportElement]] apis.\n * @beta\n */\n public async addCustomModelChange(\n changeType: SqliteChangeOp,\n ids: Id64Arg\n ): Promise<void> {\n // Also add the model's modeledElement to the element changes. The modeledElement and model go hand in hand and have the same id.\n await this.addCustomElementChange(changeType, ids);\n for (const id of Id64.iterable(ids)) {\n this.handleChange(this.model, changeType, id);\n }\n }\n\n /**\n * This method should only be called inside [IModelTransformer.addCustomChanges].\n * Adds the provided change to the aspect changes maintained by this instance of ChangedInstanceIds\n * If the same ECInstanceId is seen multiple times, the changedInstanceIds will be modified accordingly, i.e. if an id 'x' was updated but now we see 'x' was deleted, we will remove 'x'\n * from the set of updatedIds and add it to the set of deletedIds for the appropriate class type.\n * @note It is the responsibility of the caller to ensure that the provided id is, in fact an aspect.\n * @note In most cases, this method does not need to be called. Its only for consumers to mimic changes as if they were found in a changeset, which should only be useful in certain cases such as the changing of filter criteria for a preexisting master branch relationship.\n * @beta\n */\n public addCustomAspectChange(changeType: SqliteChangeOp, ids: Id64Arg): void {\n for (const id of Id64.iterable(ids)) {\n this.handleChange(this.aspect, changeType, id);\n }\n }\n\n /**\n * There is an optimization in [IModelExporter.exportModelContents] which doesn't try to export elements within a model unless the model itself is marked as `Updated` or 'Inserted' in sourceDbChanges. This method is used in [[addCustomElementChange]] and [[addCustomModelChange]] to add the parent model hierarchy to the 'updatedIds' so that the custom element changes are exported.\n * Transformer will insert 'Updated' model to target if it does not exist there already. To handle such case, modeled elements of parent models are also marked as updated. This is done, because model can not be inserted without it's modeled element.\n */\n private async markParentModelsAsUpdated(elementIds: Id64Set) {\n const params = new QueryBinder().bindIdSet(\"elementIds\", elementIds);\n\n const ecQuery = `\n WITH RECURSIVE hierarchy (parentId) AS (\n SELECT Model.Id FROM bis.Element WHERE InVirtualSet(:elementIds, ECInstanceId)\n UNION\n SELECT ParentModel.id\n FROM bis.Model e\n INNER JOIN hierarchy h ON h.parentId = e.ECInstanceId\n )\n SELECT parentId FROM hierarchy where parentId is not null\n `;\n const parentModelIds = new Set<Id64String>();\n for await (const row of this._db.createQueryReader(ecQuery, params)) {\n // Transformer handles update as insert when element does not exist in target.\n // Which means that in scenario where child and parent model are filtered out from target,\n // and child element is inserted trough custom change, its parent model will be marked as updated.\n // Transformer then will:\n // 1. Handle parent update as insert (since it does not exist in target).\n // 2. Will insert child element (otherwise this insert would be ignored due to missing parent).\n this.handleChange(this.model, \"Updated\", row.parentId);\n this.handleChange(this.element, \"Updated\", row.parentId);\n parentModelIds.add(row.parentId);\n }\n return parentModelIds;\n }\n\n private async markElementRelationshipsAsInserted(\n relationshipClassName: string,\n elementIds: Id64Set\n ) {\n const ecQuery = `SELECT ECInstanceId FROM ${relationshipClassName}\n WHERE InVirtualSet(:elementIds, TargetECInstanceId)\n OR InVirtualSet(:elementIds, SourceECInstanceId)`;\n\n const queryBinder = new QueryBinder().bindIdSet(\"elementIds\", elementIds);\n const queryReader = this._db.createQueryReader(ecQuery, queryBinder);\n\n for await (const row of queryReader) {\n this.handleChange(this.relationship, \"Inserted\", row.ECInstanceId);\n }\n }\n\n private async markElementAspectsAsInserted(elementIds: Id64Set) {\n for (const aspectClassName of [\n ElementUniqueAspect.classFullName,\n ElementMultiAspect.classFullName,\n ]) {\n const ecQuery = `Select ECInstanceId from ${aspectClassName} where InVirtualSet(:elementIds, Element.Id)`;\n const queryBinder = new QueryBinder().bindIdSet(\"elementIds\", elementIds);\n const queryReader = this._db.createQueryReader(ecQuery, queryBinder);\n for await (const row of queryReader) {\n this.addCustomAspectChange(\"Inserted\", row.toArray()[0]);\n }\n }\n }\n\n private handleChange(\n changedInstanceOps: ChangedInstanceOps,\n changeType: SqliteChangeOp,\n id: Id64String\n ) {\n // if changeType is a delete and we already have the id in the inserts then we can remove the id from the inserts.\n // if changeType is a delete and we already have the id in the updates then we can remove the id from the updates AND add it to the deletes.\n // if changeType is an insert and we already have the id in the deletes then we can remove the id from the deletes AND add it to the inserts.\n if (changeType === \"Inserted\") {\n changedInstanceOps.insertIds.add(id);\n changedInstanceOps.deleteIds.delete(id);\n } else if (changeType === \"Updated\") {\n if (!changedInstanceOps.insertIds.has(id))\n changedInstanceOps.updateIds.add(id);\n } else if (changeType === \"Deleted\") {\n // If we've inserted the entity at some point already and now we're seeing a delete. We can simply remove the entity from our inserted ids without adding it to deletedIds.\n if (changedInstanceOps.insertIds.has(id))\n changedInstanceOps.insertIds.delete(id);\n else {\n changedInstanceOps.updateIds.delete(id);\n changedInstanceOps.deleteIds.add(id);\n }\n }\n }\n\n /**\n * Initializes a new ChangedInstanceIds object with information taken from a range of changesets.\n * @public\n */\n public static async initialize(\n opts: ChangedInstanceIdsInitOptions\n ): Promise<ChangedInstanceIds | undefined> {\n if (\"changedInstanceIds\" in opts) return opts.changedInstanceIds;\n\n const iModelId = opts.iModel.iModelId;\n\n const startChangeset =\n \"startChangeset\" in opts ? opts.startChangeset : undefined;\n const changesetRanges =\n startChangeset !== undefined\n ? [\n [\n startChangeset.index ??\n (\n await BriefcaseManager.queryChangeset({\n iModelId,\n changeset: {\n id: startChangeset.id ?? opts.iModel.changeset.id,\n },\n })\n ).index,\n opts.iModel.changeset.index ??\n (\n await BriefcaseManager.queryChangeset({\n iModelId,\n changeset: { id: opts.iModel.changeset.id },\n })\n ).index,\n ],\n ]\n : \"changesetRanges\" in opts\n ? opts.changesetRanges\n : undefined;\n const csFileProps =\n changesetRanges !== undefined\n ? (\n await Promise.all(\n changesetRanges.map(async ([first, end]) =>\n BriefcaseManager.downloadChangesets({\n iModelId,\n range: { first, end },\n targetDir: BriefcaseManager.getChangeSetsPath(iModelId),\n })\n )\n )\n ).flat()\n : \"csFileProps\" in opts\n ? opts.csFileProps\n : undefined;\n\n if (csFileProps === undefined) return undefined;\n\n const changedInstanceIds = new ChangedInstanceIds(opts.iModel);\n\n for (const csFile of csFileProps) {\n const csReader = SqliteChangesetReader.openFile({\n fileName: csFile.pathname,\n db: opts.iModel,\n disableSchemaCheck: true,\n });\n const csAdaptor = new ChangesetECAdaptor(csReader);\n const ecChangeUnifier = new PartialECChangeUnifier(opts.iModel);\n while (csAdaptor.step()) {\n ecChangeUnifier.appendFrom(csAdaptor);\n }\n const changes: ChangedECInstance[] = [...ecChangeUnifier.instances];\n\n for (const change of changes) {\n await changedInstanceIds.addChange(change);\n }\n csReader.close();\n }\n return changedInstanceIds;\n }\n}\n"]}
|
|
@@ -138,9 +138,9 @@ export declare class IModelImporter {
|
|
|
138
138
|
/** Delete the specified Model from the target iModel.
|
|
139
139
|
* @note A subclass may override this method to customize delete behavior but should call `super.onDeleteModel`.
|
|
140
140
|
*/
|
|
141
|
-
protected onDeleteModel(modelId: Id64String): void
|
|
141
|
+
protected onDeleteModel(modelId: Id64String): Promise<void>;
|
|
142
142
|
/** Delete the specified Model from the target iModel. */
|
|
143
|
-
deleteModel(modelId: Id64String): void
|
|
143
|
+
deleteModel(modelId: Id64String): Promise<void>;
|
|
144
144
|
/** Format an Element for the Logger. */
|
|
145
145
|
private formatElementForLogger;
|
|
146
146
|
/** Import an ElementUniqueAspect into the target iModel. */
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"IModelImporter.d.ts","sourceRoot":"","sources":["../../src/IModelImporter.ts"],"names":[],"mappings":"AAIA;;GAEG;AACH,OAAO,EAGL,UAAU,EAGX,MAAM,qBAAqB,CAAC;AAC7B,OAAO,
|
|
1
|
+
{"version":3,"file":"IModelImporter.d.ts","sourceRoot":"","sources":["../../src/IModelImporter.ts"],"names":[],"mappings":"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"}
|
|
@@ -15,6 +15,7 @@ const TransformerLoggerCategory_1 = require("./TransformerLoggerCategory");
|
|
|
15
15
|
const core_backend_1 = require("@itwin/core-backend");
|
|
16
16
|
const assert = require("assert");
|
|
17
17
|
const ElementCascadingDeleter_1 = require("./ElementCascadingDeleter");
|
|
18
|
+
const ecschema_metadata_1 = require("@itwin/ecschema-metadata");
|
|
18
19
|
const loggerCategory = TransformerLoggerCategory_1.TransformerLoggerCategory.IModelImporter;
|
|
19
20
|
/** Base class for importing data into an iModel.
|
|
20
21
|
* @see [iModel Transformation and Data Exchange]($docs/learning/transformer/index.md)
|
|
@@ -226,7 +227,6 @@ class IModelImporter {
|
|
|
226
227
|
* @note A subclass may override this method to customize insert behavior but should call `super.onInsertElement`.
|
|
227
228
|
*/
|
|
228
229
|
onInsertElement(elementProps) {
|
|
229
|
-
/* eslint-disable @typescript-eslint/no-deprecated */
|
|
230
230
|
try {
|
|
231
231
|
const elementId = this.targetDb.elements.insertElement(elementProps, {
|
|
232
232
|
forceUseId: this.options.preserveElementIdsForFiltering,
|
|
@@ -252,7 +252,6 @@ class IModelImporter {
|
|
|
252
252
|
}
|
|
253
253
|
throw error; // throw original error
|
|
254
254
|
}
|
|
255
|
-
/* eslint-enable @typescript-eslint/no-deprecated */
|
|
256
255
|
}
|
|
257
256
|
/** Update an existing Element in the target iModel from the specified ElementProps.
|
|
258
257
|
* @note A subclass may override this method to customize update behavior but should call `super.onUpdateElement`.
|
|
@@ -265,7 +264,6 @@ class IModelImporter {
|
|
|
265
264
|
core_bentley_1.Logger.logInfo(loggerCategory, `Updated ${this.formatElementForLogger(elementProps)}`);
|
|
266
265
|
this.trackProgress();
|
|
267
266
|
if (this.options.simplifyElementGeometry) {
|
|
268
|
-
/* eslint-disable-next-line @typescript-eslint/no-deprecated */
|
|
269
267
|
this.targetDb.simplifyElementGeometry({
|
|
270
268
|
id: elementProps.id,
|
|
271
269
|
convertBReps: true,
|
|
@@ -293,14 +291,14 @@ class IModelImporter {
|
|
|
293
291
|
/** Delete the specified Model from the target iModel.
|
|
294
292
|
* @note A subclass may override this method to customize delete behavior but should call `super.onDeleteModel`.
|
|
295
293
|
*/
|
|
296
|
-
onDeleteModel(modelId) {
|
|
294
|
+
async onDeleteModel(modelId) {
|
|
297
295
|
this.targetDb.models.deleteModel(modelId);
|
|
298
296
|
core_bentley_1.Logger.logInfo(loggerCategory, `Deleted model ${modelId}`);
|
|
299
297
|
this.trackProgress();
|
|
300
298
|
}
|
|
301
299
|
/** Delete the specified Model from the target iModel. */
|
|
302
|
-
deleteModel(modelId) {
|
|
303
|
-
this.onDeleteModel(modelId);
|
|
300
|
+
async deleteModel(modelId) {
|
|
301
|
+
await this.onDeleteModel(modelId);
|
|
304
302
|
}
|
|
305
303
|
/** Format an Element for the Logger. */
|
|
306
304
|
formatElementForLogger(elementProps) {
|
|
@@ -566,7 +564,6 @@ class IModelImporter {
|
|
|
566
564
|
*/
|
|
567
565
|
optimizeGeometry(options) {
|
|
568
566
|
if (options.inlineUniqueGeometryParts) {
|
|
569
|
-
/* eslint-disable-next-line @typescript-eslint/no-deprecated */
|
|
570
567
|
const result = this.targetDb.inlineGeometryParts();
|
|
571
568
|
core_bentley_1.Logger.logInfo(loggerCategory, `Inlined ${result.numRefsInlined} references to ${result.numCandidateParts} geometry parts and deleted ${result.numPartsDeleted} parts.`);
|
|
572
569
|
}
|
|
@@ -598,19 +595,19 @@ exports.IModelImporter = IModelImporter;
|
|
|
598
595
|
*/
|
|
599
596
|
function hasEntityChanged(entity, entityProps, namesToIgnore) {
|
|
600
597
|
let changed = false;
|
|
601
|
-
entity.
|
|
598
|
+
entity.forEach((propertyName, property) => {
|
|
602
599
|
if (!changed) {
|
|
603
600
|
if (namesToIgnore && namesToIgnore.has(propertyName)) {
|
|
604
601
|
// skip
|
|
605
602
|
}
|
|
606
|
-
else if (
|
|
607
|
-
changed = hasBinaryValueChanged(entity.asAny[propertyName], entityProps[propertyName]);
|
|
603
|
+
else if (ecschema_metadata_1.PropertyType.Binary === property.propertyType) {
|
|
604
|
+
changed = hasBinaryValueChanged(entity.asAny[core_common_1.ECJsNames.toJsName(propertyName)], entityProps[core_common_1.ECJsNames.toJsName(propertyName)]);
|
|
608
605
|
}
|
|
609
|
-
else if (
|
|
610
|
-
changed = hasNavigationValueChanged(entity.asAny[propertyName], entityProps[propertyName]);
|
|
606
|
+
else if (property.isNavigation()) {
|
|
607
|
+
changed = hasNavigationValueChanged(entity.asAny[core_common_1.ECJsNames.toJsName(propertyName)], entityProps[core_common_1.ECJsNames.toJsName(propertyName)]);
|
|
611
608
|
}
|
|
612
609
|
else {
|
|
613
|
-
changed = hasValueChanged(entity.asAny[propertyName], entityProps[propertyName]);
|
|
610
|
+
changed = hasValueChanged(entity.asAny[core_common_1.ECJsNames.toJsName(propertyName)], entityProps[core_common_1.ECJsNames.toJsName(propertyName)]);
|
|
614
611
|
}
|
|
615
612
|
}
|
|
616
613
|
});
|