@itwin/imodel-transformer 0.4.1 → 0.4.18-fedguidopt.2

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.
@@ -13,6 +13,7 @@ const core_bentley_1 = require("@itwin/core-bentley");
13
13
  const core_common_1 = require("@itwin/core-common");
14
14
  const ecschema_metadata_1 = require("@itwin/ecschema-metadata");
15
15
  const TransformerLoggerCategory_1 = require("./TransformerLoggerCategory");
16
+ const nodeAssert = require("assert");
16
17
  const ExportElementAspectsWithElementsStrategy_1 = require("./ExportElementAspectsWithElementsStrategy");
17
18
  const loggerCategory = TransformerLoggerCategory_1.TransformerLoggerCategory.IModelExporter;
18
19
  /** Handles the events generated by IModelExporter.
@@ -175,6 +176,7 @@ class IModelExporter {
175
176
  this._excludedElementClasses = new Set();
176
177
  /** The set of classes of Relationships that will be excluded (polymorphically) from transformation to the target iModel. */
177
178
  this._excludedRelationshipClasses = new Set();
179
+ this._resetChangeDataOnExport = true;
178
180
  this._yieldManager = new core_bentley_1.YieldManager();
179
181
  this.sourceDb = sourceDb;
180
182
  this._exportElementAspectsStrategy = new elementAspectsStrategy(this.sourceDb, {
@@ -184,6 +186,21 @@ class IModelExporter {
184
186
  trackProgress: async () => this.trackProgress(),
185
187
  });
186
188
  }
189
+ /**
190
+ * Initialize prerequisites of exporting. This is implicitly done by any `export*` calls that need initialization
191
+ * which is currently just `exportChanges`.
192
+ * Prefer to not call this explicitly (e.g. just call [[IModelExporter.exportChanges]])
193
+ * @note that if you do call this explicitly, you must do so with the same options that
194
+ * you pass to [[IModelExporter.exportChanges]]
195
+ */
196
+ async initialize(options) {
197
+ const hasChangeData = options.startChangeset || options.changesetRanges || options.changedInstanceIds;
198
+ if (this._sourceDbChanges || !this.sourceDb.isBriefcaseDb() || !hasChangeData)
199
+ return;
200
+ this._sourceDbChanges = options.changedInstanceIds
201
+ ?? await ChangedInstanceIds.initialize({ iModel: this.sourceDb, ...options });
202
+ this._exportElementAspectsStrategy.setAspectChanges(this._sourceDbChanges.aspect);
203
+ }
187
204
  /** Register the handler that will be called by IModelExporter. */
188
205
  registerHandler(handler) {
189
206
  this._handler = handler;
@@ -216,36 +233,28 @@ class IModelExporter {
216
233
  * @note [[exportSchemas]] must be called separately.
217
234
  */
218
235
  async exportAll() {
236
+ await this.initialize({});
219
237
  await this.exportCodeSpecs();
220
238
  await this.exportFonts();
221
239
  await this.exportModel(core_common_1.IModel.repositoryModelId);
222
240
  await this.exportRelationships(core_backend_1.ElementRefersToElements.classFullName);
223
241
  }
224
- async exportChanges(accessTokenOrArgs, startChangesetId) {
242
+ async exportChanges(accessTokenOrOpts, startChangesetId) {
225
243
  if (!this.sourceDb.isBriefcaseDb())
226
244
  throw new core_common_1.IModelError(core_bentley_1.IModelStatus.BadRequest, "Must be a briefcase to export changes");
227
245
  if ("" === this.sourceDb.changeset.id) {
228
246
  await this.exportAll(); // no changesets, so revert to exportAll
229
247
  return;
230
248
  }
231
- const { accessToken, startChangeset } = typeof accessTokenOrArgs === "object"
232
- ? accessTokenOrArgs
249
+ const initOpts = typeof accessTokenOrOpts === "object"
250
+ ? accessTokenOrOpts
233
251
  : {
234
- accessToken: accessTokenOrArgs,
252
+ accessToken: accessTokenOrOpts,
235
253
  startChangeset: { id: startChangesetId },
236
254
  };
237
- this._sourceDbChanges =
238
- (typeof accessTokenOrArgs === "object"
239
- ? accessTokenOrArgs.changedInstanceIds
240
- : undefined)
241
- ?? await ChangedInstanceIds.initialize({
242
- accessToken,
243
- startChangeset: startChangeset?.id !== undefined || startChangeset?.index !== undefined
244
- ? startChangeset
245
- : this.sourceDb.changeset,
246
- iModel: this.sourceDb,
247
- });
248
- this._exportElementAspectsStrategy.setAspectChanges(this._sourceDbChanges?.aspect);
255
+ await this.initialize(initOpts);
256
+ // _sourceDbChanges are initialized in this.initialize
257
+ nodeAssert(this._sourceDbChanges !== undefined, "sourceDbChanges must be initialized.");
249
258
  await this.exportCodeSpecs();
250
259
  await this.exportFonts();
251
260
  await this.exportModelContents(core_common_1.IModel.repositoryModelId);
@@ -279,6 +288,12 @@ class IModelExporter {
279
288
  this.handler.onDeleteRelationship(relInstanceId);
280
289
  }
281
290
  }
291
+ // Enable consecutive exportChanges runs without the need to re-instantiate the exporter.
292
+ // You can counteract the obvious impact of losing this expensive data by always calling
293
+ // exportChanges with the [[ExportChangesOptions.changedInstanceIds]] option set to
294
+ // whatever you want
295
+ if (this._resetChangeDataOnExport)
296
+ this._sourceDbChanges = undefined;
282
297
  }
283
298
  /** Export schemas from the source iModel.
284
299
  * @note This must be called separately from [[exportAll]] or [[exportChanges]].
@@ -552,20 +567,10 @@ class IModelExporter {
552
567
  core_bentley_1.Logger.logTrace(loggerCategory, `visitElements=false, skipping exportElement(${elementId})`);
553
568
  return;
554
569
  }
555
- let isUpdate;
556
- if (undefined !== this._sourceDbChanges) { // is changeset information available?
557
- if (this._sourceDbChanges.element.insertIds.has(elementId)) {
558
- isUpdate = false;
559
- }
560
- else if (this._sourceDbChanges.element.updateIds.has(elementId)) {
561
- isUpdate = true;
562
- }
563
- else {
564
- // NOTE: This optimization assumes that the Element will change (LastMod) if an owned ElementAspect changes
565
- // NOTE: However, child elements may have changed without the parent changing
566
- return this.exportChildElements(elementId);
567
- }
568
- }
570
+ // are we processing changes?
571
+ const isUpdate = this._sourceDbChanges?.element.insertIds.has(elementId) ? false
572
+ : this._sourceDbChanges?.element.updateIds.has(elementId) ? true
573
+ : undefined;
569
574
  const element = this.sourceDb.elements.getElement({ id: elementId, wantGeometry: this.wantGeometry, wantBRepData: this.wantGeometry });
570
575
  core_bentley_1.Logger.logTrace(loggerCategory, `exportElement(${element.id}, "${element.getDisplayLabel()}")${this.getChangeOpSuffix(isUpdate)}`);
571
576
  // the order and `await`ing of calls beyond here is depended upon by the IModelTransformer for a current bug workaround
@@ -722,6 +727,29 @@ class IModelExporter {
722
727
  }
723
728
  }
724
729
  exports.IModelExporter = IModelExporter;
730
+ /**
731
+ * Asserts that the passed in options have exactly one of:
732
+ * startChangeset xor changesetRanges xor changedInstanceIds
733
+ * defined
734
+ */
735
+ function assertHasChangeDataOptions(opts) {
736
+ const xor = (...args) => {
737
+ let result = false;
738
+ for (const a of args) {
739
+ if (!result && a)
740
+ result = true;
741
+ else if (result && a)
742
+ return false;
743
+ }
744
+ return result;
745
+ };
746
+ nodeAssert(xor(opts.startChangeset, opts.changesetRanges, opts.changedInstanceIds), "exactly one of startChangeset, XOR changesetRanges XOR opts.changedInstanceIds may be defined but "
747
+ + `received ${JSON.stringify({
748
+ startChangeset: !!opts.startChangeset,
749
+ changesetRanges: !!opts.changesetRanges,
750
+ ChangedInstanceIds: !!opts.changedInstanceIds,
751
+ })}`);
752
+ }
725
753
  /** Class for holding change information.
726
754
  * @beta
727
755
  */
@@ -773,13 +801,31 @@ class ChangedInstanceIds {
773
801
  iModel: iModel,
774
802
  startChangeset: { id: startChangesetId },
775
803
  };
776
- const accessToken = opts.accessToken;
804
+ assertHasChangeDataOptions(opts);
777
805
  const iModelId = opts.iModel.iModelId;
778
- const first = opts.startChangeset?.index
779
- ?? (await core_backend_1.IModelHost.hubAccess.queryChangeset({ iModelId, changeset: { id: opts.startChangeset.id }, accessToken })).index;
780
- const end = opts.iModel.changeset.index
781
- ?? (await core_backend_1.IModelHost.hubAccess.queryChangeset({ iModelId, changeset: { id: opts.iModel.changeset.id }, accessToken })).index;
782
- const changesets = await core_backend_1.IModelHost.hubAccess.downloadChangesets({ accessToken, iModelId, range: { first, end }, targetDir: core_backend_1.BriefcaseManager.getChangeSetsPath(iModelId) });
806
+ const accessToken = opts.accessToken;
807
+ const changesetRanges = opts.changesetRanges
808
+ ?? [[
809
+ // we know startChangeset is defined because of the assert above
810
+ opts.startChangeset.index
811
+ ?? (await core_backend_1.IModelHost.hubAccess.queryChangeset({
812
+ iModelId,
813
+ changeset: { id: opts.startChangeset.id ?? opts.iModel.changeset.id },
814
+ accessToken,
815
+ })).index,
816
+ opts.iModel.changeset.index
817
+ ?? (await core_backend_1.IModelHost.hubAccess.queryChangeset({
818
+ iModelId,
819
+ changeset: { id: opts.iModel.changeset.id },
820
+ accessToken,
821
+ })).index,
822
+ ]];
823
+ core_bentley_1.Logger.logTrace(loggerCategory, `ChangedInstanceIds.initialize ranges: ${changesetRanges.join("|")}`);
824
+ const changesets = (await Promise.all(changesetRanges.map(async ([first, end]) => core_backend_1.IModelHost.hubAccess.downloadChangesets({
825
+ accessToken,
826
+ iModelId, range: { first, end },
827
+ targetDir: core_backend_1.BriefcaseManager.getChangeSetsPath(iModelId),
828
+ })))).flat();
783
829
  const changedInstanceIds = new ChangedInstanceIds();
784
830
  const changesetFiles = changesets.map((c) => c.pathname);
785
831
  const statusOrResult = opts.iModel.nativeDb.extractChangedInstanceIdsFromChangeSets(changesetFiles);
@@ -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, BriefcaseManager, DefinitionModel, ECSqlStatement, Element, ElementAspect,\n ElementMultiAspect, ElementRefersToElements, ElementUniqueAspect, GeometricElement, IModelDb,\n IModelHost, IModelJsNative, Model, RecipeDefinitionElement, Relationship,\n} from \"@itwin/core-backend\";\nimport { AccessToken, assert, CompressedId64Set, DbResult, Id64, Id64String, IModelStatus, Logger, YieldManager } from \"@itwin/core-bentley\";\nimport { ChangesetIndexOrId, CodeSpec, FontProps, IModel, IModelError } from \"@itwin/core-common\";\nimport { ECVersion, Schema, SchemaKey, SchemaLoader } from \"@itwin/ecschema-metadata\";\nimport { TransformerLoggerCategory } from \"./TransformerLoggerCategory\";\nimport type { InitFromExternalSourceAspectsArgs } from \"./IModelTransformer\";\nimport { ElementAspectsHandler, ExportElementAspectsStrategy } 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.exportChanges]]\n * @public\n */\nexport interface ExportChangesOptions extends InitFromExternalSourceAspectsArgs {\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 */\n changedInstanceIds?: ChangedInstanceIds;\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 { return true; }\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(_codeSpec: CodeSpec, _isUpdate: boolean | undefined): 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 { return true; }\n\n /** Called when element is skipped instead of exported. */\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(_element: Element, _isUpdate: boolean | undefined): 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 { return true; }\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(_aspect: ElementUniqueAspect, _isUpdate: boolean | undefined): 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 { return true; }\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(_relationship: Relationship, _isUpdate: boolean | undefined): 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 { return true; }\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(_schema: Schema): 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 * Retrieve the cached entity change information.\n * @note This will only be initialized after [IModelExporter.exportChanges] is invoked.\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(sourceDb: IModelDb, elementAspectsStrategy: new (source: IModelDb, handler: ElementAspectsHandler) => ExportElementAspectsStrategy = ExportElementAspectsWithElementsStrategy) {\n this.sourceDb = sourceDb;\n this._exportElementAspectsStrategy = new elementAspectsStrategy(this.sourceDb, {\n onExportElementMultiAspects: (aspects) => this.handler.onExportElementMultiAspects(aspects),\n onExportElementUniqueAspect: (aspect, isUpdate) => this.handler.onExportElementUniqueAspect(aspect, isUpdate),\n shouldExportElementAspect: (aspect) => this.handler.shouldExportElementAspect(aspect),\n trackProgress: async () => this.trackProgress(),\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(this.sourceDb.getJsClass<typeof Element>(classFullName));\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(this.sourceDb.getJsClass<typeof Relationship>(classFullName));\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.exportCodeSpecs();\n await this.exportFonts();\n await this.exportModel(IModel.repositoryModelId);\n await this.exportRelationships(ElementRefersToElements.classFullName);\n }\n\n /**\n * Export changes from the source iModel.\n */\n public async exportChanges(args?: ExportChangesOptions): Promise<void>;\n /** @deprecated in 0.1.x, use a single ExportChangesArgs object instead */\n public async exportChanges(accessToken?: AccessToken, startChangesetId?: string, args?: ExportChangesOptions): Promise<void>;\n public async exportChanges(accessTokenOrArgs?: AccessToken | ExportChangesOptions, startChangesetId?: string): Promise<void> {\n if (!this.sourceDb.isBriefcaseDb())\n throw new IModelError(IModelStatus.BadRequest, \"Must be a briefcase to export changes\");\n\n if (\"\" === this.sourceDb.changeset.id) {\n await this.exportAll(); // no changesets, so revert to exportAll\n return;\n }\n\n const { accessToken, startChangeset }\n = typeof accessTokenOrArgs === \"object\"\n ? accessTokenOrArgs\n : {\n accessToken: accessTokenOrArgs,\n startChangeset: { id: startChangesetId },\n };\n\n this._sourceDbChanges =\n (typeof accessTokenOrArgs === \"object\"\n ? accessTokenOrArgs.changedInstanceIds\n : undefined)\n ?? await ChangedInstanceIds.initialize({\n accessToken,\n startChangeset: startChangeset?.id !== undefined || startChangeset?.index !== undefined\n ? startChangeset as ChangesetIndexOrId\n : this.sourceDb.changeset,\n iModel: this.sourceDb,\n });\n this._exportElementAspectsStrategy.setAspectChanges(this._sourceDbChanges?.aspect);\n\n await this.exportCodeSpecs();\n await this.exportFonts();\n await this.exportModelContents(IModel.repositoryModelId);\n await this.exportSubModels(IModel.repositoryModelId);\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 = err instanceof IModelError && err.errorNumber === IModelStatus.NotFound;\n if (!isMissingErr)\n throw err;\n }\n }\n }\n if (this.visitRelationships) {\n for (const relInstanceId of this._sourceDbChanges.relationship.deleteIds) {\n this.handler.onDeleteRelationship(relInstanceId);\n }\n }\n }\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 /* eslint-disable @typescript-eslint/indent */\n const sql = `\n SELECT s.Name, s.VersionMajor, s.VersionWrite, s.VersionMinor\n FROM ECDbMeta.ECSchemaDef s\n ${this.wantSystemSchemas ? \"\" : `\n WHERE ECInstanceId >= (SELECT ECInstanceId FROM ECDbMeta.ECSchemaDef WHERE Name='BisCore')\n `}\n ORDER BY ECInstanceId\n `;\n /* eslint-enable @typescript-eslint/indent */\n const schemaNamesToExport: string[] = [];\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(schemaName, new ECVersion(versionMajor, versionWrite, versionMinor));\n if (this.handler.shouldExportSchema(schemaKey)) {\n schemaNamesToExport.push(schemaName);\n }\n }\n });\n\n if (schemaNamesToExport.length === 0)\n return;\n\n const schemaLoader = new SchemaLoader((name: string) => this.sourceDb.getSchemaProps(name));\n await Promise.all(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 /** 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 await this.sourceDb.withPreparedStatement(sql, 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 /** 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) { // 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(loggerCategory, `exportCodeSpec(${codeSpecName})${this.getChangeOpSuffix(isUpdate)}`);\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 let isUpdate: boolean | undefined;\n if (undefined !== this._sourceDbChanges) { // is changeset information available?\n const fontId: Id64String = Id64.fromUint32Pair(fontNumber, 0); // changeset information uses Id64String, not number\n if (this._sourceDbChanges.font.insertIds.has(fontId)) {\n isUpdate = false;\n } else if (this._sourceDbChanges.font.updateIds.has(fontId)) {\n isUpdate = true;\n } else {\n return; // not in changeset, don't export\n }\n }\n Logger.logTrace(loggerCategory, `exportFontById(${fontNumber})`);\n const font: FontProps | undefined = 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({ id: modeledElementId, wantGeometry: this.wantGeometry, wantBRepData: this.wantGeometry });\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) { // 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(modelId: Id64String, elementClassFullName: string = Element.classFullName, skipRootSubject?: boolean): 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(loggerCategory, `visitElements=false, skipping exportModelContents(${modelId})`);\n return;\n }\n if (undefined !== this._sourceDbChanges) { // is changeset information available?\n if (!this._sourceDbChanges.model.insertIds.has(modelId) && !this._sourceDbChanges.model.updateIds.has(modelId)) {\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 await this.sourceDb.withPreparedStatement(sql, 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 /** 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 this.sourceDb.withPreparedStatement(sql, (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 // 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(loggerCategory, `Excluded element ${element.id} by Category`);\n return false;\n }\n }\n if (!this.wantTemplateModels && (element instanceof RecipeDefinitionElement)) {\n Logger.logInfo(loggerCategory, `Excluded RecipeDefinitionElement ${element.id} because wantTemplate=false`);\n return false;\n }\n for (const excludedElementClass of this._excludedElementClasses) {\n if (element instanceof excludedElementClass) {\n Logger.logInfo(loggerCategory, `Excluded element ${element.id} by class: ${excludedElementClass.classFullName}`);\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(loggerCategory, `visitElements=false, skipping exportElement(${elementId})`);\n return;\n }\n let isUpdate: boolean | undefined;\n if (undefined !== this._sourceDbChanges) { // is changeset information available?\n if (this._sourceDbChanges.element.insertIds.has(elementId)) {\n isUpdate = false;\n } else if (this._sourceDbChanges.element.updateIds.has(elementId)) {\n isUpdate = true;\n } else {\n // NOTE: This optimization assumes that the Element will change (LastMod) if an owned ElementAspect changes\n // NOTE: However, child elements may have changed without the parent changing\n return this.exportChildElements(elementId);\n }\n }\n const element: Element = this.sourceDb.elements.getElement({ id: elementId, wantGeometry: this.wantGeometry, wantBRepData: this.wantGeometry });\n Logger.logTrace(loggerCategory, `exportElement(${element.id}, \"${element.getDisplayLabel()}\")${this.getChangeOpSuffix(isUpdate)}`);\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(elementId);\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(loggerCategory, `visitElements=false, skipping exportChildElements(${elementId})`);\n return;\n }\n const childElementIds: Id64String[] = 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(baseRelClassFullName: string): Promise<void> {\n if (!this.visitRelationships) {\n Logger.logTrace(loggerCategory, `visitRelationships=false, skipping exportRelationships()`);\n return;\n }\n Logger.logTrace(loggerCategory, `exportRelationships(${baseRelClassFullName})`);\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 await this.sourceDb.withPreparedStatement(sql, async (statement: ECSqlStatement): Promise<void> => {\n while (DbResult.BE_SQLITE_ROW === statement.step()) {\n const relationshipId = statement.getValue(0).getId();\n const relationshipClass = statement.getValue(1).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 /** Export a relationship from the source iModel. */\n public async exportRelationship(relClassFullName: string, relInstanceId: Id64String): Promise<void> {\n if (!this.visitRelationships) {\n Logger.logTrace(loggerCategory, `visitRelationships=false, skipping exportRelationship(${relClassFullName}, ${relInstanceId})`);\n return;\n }\n let isUpdate: boolean | undefined;\n if (undefined !== this._sourceDbChanges) { // is changeset information available?\n if (this._sourceDbChanges.relationship.insertIds.has(relInstanceId)) {\n isUpdate = false;\n } else if (this._sourceDbChanges.relationship.updateIds.has(relInstanceId)) {\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(loggerCategory, `exportRelationship(${relClassFullName}, ${relInstanceId})`);\n const relationship: Relationship = this.sourceDb.relationships.getInstance(relClassFullName, relInstanceId);\n for (const excludedRelationshipClass of this._excludedRelationshipClasses) {\n if (relationship instanceof excludedRelationshipClass) {\n Logger.logInfo(loggerCategory, `Excluded relationship by class: ${excludedRelationshipClass.classFullName}`);\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 * You may override this to store arbitrary json state in a exporter state dump, useful for some resumptions\n * @see [[IModelTransformer.saveStateToFile]]\n */\n protected getAdditionalStateJson(): any {\n return {};\n }\n\n /**\n * You may override this to load arbitrary json state in a transformer state dump, useful for some resumptions\n * @see [[IModelTransformer.loadStateFromFile]]\n */\n protected loadAdditionalStateJson(_additionalState: any): void {}\n\n /**\n * Reload our state from a JSON object\n * Intended for [[IModelTransformer.resumeTransformation]]\n * @internal\n * You can load custom json from the exporter save state for custom exporters by overriding [[IModelExporter.loadAdditionalStateJson]]\n */\n public loadStateFromJson(state: IModelExporterState): void {\n if (state.exporterClass !== this.constructor.name)\n throw Error(\"resuming from a differently named exporter class, it is not necessarily valid to resume with a different exporter class\");\n this.wantGeometry = state.wantGeometry;\n this.wantTemplateModels = state.wantTemplateModels;\n this.wantSystemSchemas = state.wantSystemSchemas;\n this.visitElements = state.visitElements;\n this.visitRelationships = state.visitRelationships;\n this._excludedCodeSpecNames = new Set(state.excludedCodeSpecNames);\n this._excludedElementIds = CompressedId64Set.decompressSet(state.excludedElementIds),\n this._excludedElementCategoryIds = CompressedId64Set.decompressSet(state.excludedElementCategoryIds),\n this._excludedElementClasses = new Set(state.excludedElementClassNames.map((c) => this.sourceDb.getJsClass(c)));\n this._exportElementAspectsStrategy.loadExcludedElementAspectClasses(state.excludedElementAspectClassFullNames);\n this._excludedRelationshipClasses = new Set(state.excludedRelationshipClassNames.map((c) => this.sourceDb.getJsClass(c)));\n this.loadAdditionalStateJson(state.additionalState);\n }\n\n /**\n * Serialize state to a JSON object\n * Intended for [[IModelTransformer.resumeTransformation]]\n * @internal\n * You can add custom json to the exporter save state for custom exporters by overriding [[IModelExporter.getAdditionalStateJson]]\n */\n public saveStateToJson(): IModelExporterState {\n return {\n exporterClass: this.constructor.name,\n wantGeometry: this.wantGeometry,\n wantTemplateModels: this.wantTemplateModels,\n wantSystemSchemas: this.wantSystemSchemas,\n visitElements: this.visitElements,\n visitRelationships: this.visitRelationships,\n excludedCodeSpecNames: [...this._excludedCodeSpecNames],\n excludedElementIds: CompressedId64Set.compressSet(this._excludedElementIds),\n excludedElementCategoryIds: CompressedId64Set.compressSet(this._excludedElementCategoryIds),\n excludedElementClassNames: Array.from(this._excludedElementClasses, (cls) => cls.classFullName),\n excludedElementAspectClassFullNames: [...this._exportElementAspectsStrategy.excludedElementAspectClassFullNames],\n excludedRelationshipClassNames: Array.from(this._excludedRelationshipClasses, (cls) => cls.classFullName),\n additionalState: this.getAdditionalStateJson(),\n };\n }\n}\n\n/**\n * The JSON format of a serialized IModelExporter instance\n * Used for starting an exporter in the middle of an export operation,\n * such as resuming a crashed transformation\n *\n * @note Must be kept synchronized with IModelExporter\n * @internal\n */\nexport interface IModelExporterState {\n exporterClass: string;\n wantGeometry: boolean;\n wantTemplateModels: boolean;\n wantSystemSchemas: boolean;\n visitElements: boolean;\n visitRelationships: boolean;\n excludedCodeSpecNames: string[];\n excludedElementIds: CompressedId64Set;\n excludedElementCategoryIds: CompressedId64Set;\n excludedElementClassNames: string[];\n excludedElementAspectClassFullNames: string[];\n excludedRelationshipClassNames: string[];\n additionalState?: any;\n}\n\n/**\n * Arguments for [[ChangedInstanceIds.initialize]]\n * @beta\n */\nexport interface ChangedInstanceIdsInitOptions extends ExportChangesOptions {\n /** @inheritdoc */\n startChangeset: ChangesetIndexOrId;\n iModel: BriefcaseDb;\n}\n\n/** Class for holding change information.\n * @beta\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(val: IModelJsNative.ChangedInstanceOpsProps | undefined): 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/**\n * Class for discovering modified elements between 2 versions of an iModel.\n * @beta\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 constructor() { }\n\n /**\n * Initializes a new ChangedInstanceIds object with information taken from a range of changesets.\n */\n public static async initialize(opts: ChangedInstanceIdsInitOptions): Promise<ChangedInstanceIds>;\n /**\n * Initializes a new ChangedInstanceIds object with information taken from a range of changesets.\n * @deprecated in 0.1.x. Pass a [[ChangedInstanceIdsInitOptions]] object instead of a changeset id\n * @param accessToken Access token.\n * @param iModel IModel briefcase whose changesets will be queried.\n * @param firstChangesetId Changeset id.\n * @note Modified element information will be taken from a range of changesets. First changeset in a range will be the 'firstChangesetId', the last will be whichever changeset the 'iModel' briefcase is currently opened on.\n */\n public static async initialize(\n accessTokenOrOpts: AccessToken | ChangedInstanceIdsInitOptions | undefined,\n iModel?: BriefcaseDb,\n startChangesetId?: string,\n ): Promise<ChangedInstanceIds> {\n const opts: ChangedInstanceIdsInitOptions\n = typeof accessTokenOrOpts === \"object\"\n ? accessTokenOrOpts\n : {\n accessToken: accessTokenOrOpts,\n iModel: iModel!,\n startChangeset: { id: startChangesetId! },\n };\n\n const accessToken = opts.accessToken;\n const iModelId = opts.iModel.iModelId;\n\n const first = opts.startChangeset?.index\n ?? (await IModelHost.hubAccess.queryChangeset({ iModelId, changeset: { id: opts.startChangeset.id }, accessToken })).index;\n const end = opts.iModel.changeset.index\n ?? (await IModelHost.hubAccess.queryChangeset({ iModelId, changeset: { id: opts.iModel.changeset.id }, accessToken })).index;\n const changesets = await IModelHost.hubAccess.downloadChangesets({ accessToken, iModelId, range: { first, end }, targetDir: BriefcaseManager.getChangeSetsPath(iModelId) });\n\n const changedInstanceIds = new ChangedInstanceIds();\n const changesetFiles = changesets.map((c) => c.pathname);\n const statusOrResult = opts.iModel.nativeDb.extractChangedInstanceIdsFromChangeSets(changesetFiles);\n if (statusOrResult.error) {\n throw new IModelError(statusOrResult.error.status, \"Error processing changeset\");\n }\n const result = statusOrResult.result;\n assert(result !== undefined);\n changedInstanceIds.codeSpec.addFromJson(result.codeSpec);\n changedInstanceIds.model.addFromJson(result.model);\n changedInstanceIds.element.addFromJson(result.element);\n changedInstanceIds.aspect.addFromJson(result.aspect);\n changedInstanceIds.relationship.addFromJson(result.relationship);\n changedInstanceIds.font.addFromJson(result.font);\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, BriefcaseManager, DefinitionModel, ECSqlStatement, Element, ElementAspect,\n ElementMultiAspect, ElementRefersToElements, ElementUniqueAspect, GeometricElement, IModelDb,\n IModelHost, IModelJsNative, Model, RecipeDefinitionElement, Relationship,\n} from \"@itwin/core-backend\";\nimport { AccessToken, assert, CompressedId64Set, DbResult, Id64, Id64String, IModelStatus, Logger, YieldManager } from \"@itwin/core-bentley\";\nimport { CodeSpec, FontProps, IModel, IModelError } from \"@itwin/core-common\";\nimport { ECVersion, Schema, SchemaKey, SchemaLoader } from \"@itwin/ecschema-metadata\";\nimport { TransformerLoggerCategory } from \"./TransformerLoggerCategory\";\nimport * as nodeAssert from \"assert\";\nimport type { InitOptions } from \"./IModelTransformer\";\nimport { ElementAspectsHandler, ExportElementAspectsStrategy } 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.exportChanges]]\n * @public\n */\nexport interface ExportChangesOptions extends InitOptions {\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 and @see startChangeset, so define one of the three, 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 and @see startChangeset, so define one of the three, never more\n */\n changesetRanges?: [number, number][];\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/** 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 { return true; }\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(_codeSpec: CodeSpec, _isUpdate: boolean | undefined): 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 { return true; }\n\n /** Called when element is skipped instead of exported. */\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(_element: Element, _isUpdate: boolean | undefined): 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 { return true; }\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(_aspect: ElementUniqueAspect, _isUpdate: boolean | undefined): 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 { return true; }\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(_relationship: Relationship, _isUpdate: boolean | undefined): 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 { return true; }\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(_schema: Schema): 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 * Retrieve the cached entity change information.\n * @note This will only be initialized after [IModelExporter.exportChanges] is invoked.\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(sourceDb: IModelDb, elementAspectsStrategy: new (source: IModelDb, handler: ElementAspectsHandler) => ExportElementAspectsStrategy = ExportElementAspectsWithElementsStrategy) {\n this.sourceDb = sourceDb;\n this._exportElementAspectsStrategy = new elementAspectsStrategy(this.sourceDb, {\n onExportElementMultiAspects: (aspects) => this.handler.onExportElementMultiAspects(aspects),\n onExportElementUniqueAspect: (aspect, isUpdate) => this.handler.onExportElementUniqueAspect(aspect, isUpdate),\n shouldExportElementAspect: (aspect) => this.handler.shouldExportElementAspect(aspect),\n trackProgress: async () => this.trackProgress(),\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 const hasChangeData = options.startChangeset || options.changesetRanges || options.changedInstanceIds;\n if (this._sourceDbChanges || !this.sourceDb.isBriefcaseDb() || !hasChangeData)\n return;\n\n this._sourceDbChanges = options.changedInstanceIds\n ?? await ChangedInstanceIds.initialize({ iModel: this.sourceDb, ...options });\n\n this._exportElementAspectsStrategy.setAspectChanges(this._sourceDbChanges.aspect);\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(this.sourceDb.getJsClass<typeof Element>(classFullName));\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(this.sourceDb.getJsClass<typeof Relationship>(classFullName));\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 /** @deprecated in 0.1.x, use a single [[ExportChangesOptions]] object instead */\n public async exportChanges(accessToken?: AccessToken, startChangesetId?: string, args?: ExportChangesOptions): Promise<void>;\n public async exportChanges(accessTokenOrOpts?: AccessToken | ExportChangesOptions, startChangesetId?: string): Promise<void> {\n if (!this.sourceDb.isBriefcaseDb())\n throw new IModelError(IModelStatus.BadRequest, \"Must be a briefcase to export changes\");\n\n if (\"\" === this.sourceDb.changeset.id) {\n await this.exportAll(); // no changesets, so revert to exportAll\n return;\n }\n\n const initOpts: ExporterInitOptions\n = typeof accessTokenOrOpts === \"object\"\n ? accessTokenOrOpts\n : {\n accessToken: accessTokenOrOpts,\n startChangeset: { id: startChangesetId },\n };\n\n await this.initialize(initOpts);\n // _sourceDbChanges are initialized in this.initialize\n nodeAssert(this._sourceDbChanges !== undefined, \"sourceDbChanges must be initialized.\");\n\n await this.exportCodeSpecs();\n await this.exportFonts();\n await this.exportModelContents(IModel.repositoryModelId);\n await this.exportSubModels(IModel.repositoryModelId);\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 = err instanceof IModelError && err.errorNumber === IModelStatus.NotFound;\n if (!isMissingErr)\n throw err;\n }\n }\n }\n\n if (this.visitRelationships) {\n for (const relInstanceId of this._sourceDbChanges.relationship.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)\n 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 /* eslint-disable @typescript-eslint/indent */\n const sql = `\n SELECT s.Name, s.VersionMajor, s.VersionWrite, s.VersionMinor\n FROM ECDbMeta.ECSchemaDef s\n ${this.wantSystemSchemas ? \"\" : `\n WHERE ECInstanceId >= (SELECT ECInstanceId FROM ECDbMeta.ECSchemaDef WHERE Name='BisCore')\n `}\n ORDER BY ECInstanceId\n `;\n /* eslint-enable @typescript-eslint/indent */\n const schemaNamesToExport: string[] = [];\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(schemaName, new ECVersion(versionMajor, versionWrite, versionMinor));\n if (this.handler.shouldExportSchema(schemaKey)) {\n schemaNamesToExport.push(schemaName);\n }\n }\n });\n\n if (schemaNamesToExport.length === 0)\n return;\n\n const schemaLoader = new SchemaLoader((name: string) => this.sourceDb.getSchemaProps(name));\n await Promise.all(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 /** 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 await this.sourceDb.withPreparedStatement(sql, 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 /** 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) { // 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(loggerCategory, `exportCodeSpec(${codeSpecName})${this.getChangeOpSuffix(isUpdate)}`);\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 let isUpdate: boolean | undefined;\n if (undefined !== this._sourceDbChanges) { // is changeset information available?\n const fontId: Id64String = Id64.fromUint32Pair(fontNumber, 0); // changeset information uses Id64String, not number\n if (this._sourceDbChanges.font.insertIds.has(fontId)) {\n isUpdate = false;\n } else if (this._sourceDbChanges.font.updateIds.has(fontId)) {\n isUpdate = true;\n } else {\n return; // not in changeset, don't export\n }\n }\n Logger.logTrace(loggerCategory, `exportFontById(${fontNumber})`);\n const font: FontProps | undefined = 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({ id: modeledElementId, wantGeometry: this.wantGeometry, wantBRepData: this.wantGeometry });\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) { // 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(modelId: Id64String, elementClassFullName: string = Element.classFullName, skipRootSubject?: boolean): 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(loggerCategory, `visitElements=false, skipping exportModelContents(${modelId})`);\n return;\n }\n if (undefined !== this._sourceDbChanges) { // is changeset information available?\n if (!this._sourceDbChanges.model.insertIds.has(modelId) && !this._sourceDbChanges.model.updateIds.has(modelId)) {\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 await this.sourceDb.withPreparedStatement(sql, 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 /** 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 this.sourceDb.withPreparedStatement(sql, (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 // 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(loggerCategory, `Excluded element ${element.id} by Category`);\n return false;\n }\n }\n if (!this.wantTemplateModels && (element instanceof RecipeDefinitionElement)) {\n Logger.logInfo(loggerCategory, `Excluded RecipeDefinitionElement ${element.id} because wantTemplate=false`);\n return false;\n }\n for (const excludedElementClass of this._excludedElementClasses) {\n if (element instanceof excludedElementClass) {\n Logger.logInfo(loggerCategory, `Excluded element ${element.id} by class: ${excludedElementClass.classFullName}`);\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(loggerCategory, `visitElements=false, skipping exportElement(${elementId})`);\n return;\n }\n\n // are we processing changes?\n const isUpdate\n = this._sourceDbChanges?.element.insertIds.has(elementId) ? false\n : this._sourceDbChanges?.element.updateIds.has(elementId) ? true\n : undefined;\n\n const element = this.sourceDb.elements.getElement({ id: elementId, wantGeometry: this.wantGeometry, wantBRepData: this.wantGeometry });\n Logger.logTrace(loggerCategory, `exportElement(${element.id}, \"${element.getDisplayLabel()}\")${this.getChangeOpSuffix(isUpdate)}`);\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(elementId);\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(loggerCategory, `visitElements=false, skipping exportChildElements(${elementId})`);\n return;\n }\n const childElementIds: Id64String[] = 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(baseRelClassFullName: string): Promise<void> {\n if (!this.visitRelationships) {\n Logger.logTrace(loggerCategory, `visitRelationships=false, skipping exportRelationships()`);\n return;\n }\n Logger.logTrace(loggerCategory, `exportRelationships(${baseRelClassFullName})`);\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 await this.sourceDb.withPreparedStatement(sql, async (statement: ECSqlStatement): Promise<void> => {\n while (DbResult.BE_SQLITE_ROW === statement.step()) {\n const relationshipId = statement.getValue(0).getId();\n const relationshipClass = statement.getValue(1).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 /** Export a relationship from the source iModel. */\n public async exportRelationship(relClassFullName: string, relInstanceId: Id64String): Promise<void> {\n if (!this.visitRelationships) {\n Logger.logTrace(loggerCategory, `visitRelationships=false, skipping exportRelationship(${relClassFullName}, ${relInstanceId})`);\n return;\n }\n let isUpdate: boolean | undefined;\n if (undefined !== this._sourceDbChanges) { // is changeset information available?\n if (this._sourceDbChanges.relationship.insertIds.has(relInstanceId)) {\n isUpdate = false;\n } else if (this._sourceDbChanges.relationship.updateIds.has(relInstanceId)) {\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(loggerCategory, `exportRelationship(${relClassFullName}, ${relInstanceId})`);\n const relationship: Relationship = this.sourceDb.relationships.getInstance(relClassFullName, relInstanceId);\n for (const excludedRelationshipClass of this._excludedRelationshipClasses) {\n if (relationship instanceof excludedRelationshipClass) {\n Logger.logInfo(loggerCategory, `Excluded relationship by class: ${excludedRelationshipClass.classFullName}`);\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 * You may override this to store arbitrary json state in a exporter state dump, useful for some resumptions\n * @see [[IModelTransformer.saveStateToFile]]\n */\n protected getAdditionalStateJson(): any {\n return {};\n }\n\n /**\n * You may override this to load arbitrary json state in a transformer state dump, useful for some resumptions\n * @see [[IModelTransformer.loadStateFromFile]]\n */\n protected loadAdditionalStateJson(_additionalState: any): void {}\n\n /**\n * Reload our state from a JSON object\n * Intended for [[IModelTransformer.resumeTransformation]]\n * @internal\n * You can load custom json from the exporter save state for custom exporters by overriding [[IModelExporter.loadAdditionalStateJson]]\n */\n public loadStateFromJson(state: IModelExporterState): void {\n if (state.exporterClass !== this.constructor.name)\n throw Error(\"resuming from a differently named exporter class, it is not necessarily valid to resume with a different exporter class\");\n this.wantGeometry = state.wantGeometry;\n this.wantTemplateModels = state.wantTemplateModels;\n this.wantSystemSchemas = state.wantSystemSchemas;\n this.visitElements = state.visitElements;\n this.visitRelationships = state.visitRelationships;\n this._excludedCodeSpecNames = new Set(state.excludedCodeSpecNames);\n this._excludedElementIds = CompressedId64Set.decompressSet(state.excludedElementIds),\n this._excludedElementCategoryIds = CompressedId64Set.decompressSet(state.excludedElementCategoryIds),\n this._excludedElementClasses = new Set(state.excludedElementClassNames.map((c) => this.sourceDb.getJsClass(c)));\n this._exportElementAspectsStrategy.loadExcludedElementAspectClasses(state.excludedElementAspectClassFullNames);\n this._excludedRelationshipClasses = new Set(state.excludedRelationshipClassNames.map((c) => this.sourceDb.getJsClass(c)));\n this.loadAdditionalStateJson(state.additionalState);\n }\n\n /**\n * Serialize state to a JSON object\n * Intended for [[IModelTransformer.resumeTransformation]]\n * @internal\n * You can add custom json to the exporter save state for custom exporters by overriding [[IModelExporter.getAdditionalStateJson]]\n */\n public saveStateToJson(): IModelExporterState {\n return {\n exporterClass: this.constructor.name,\n wantGeometry: this.wantGeometry,\n wantTemplateModels: this.wantTemplateModels,\n wantSystemSchemas: this.wantSystemSchemas,\n visitElements: this.visitElements,\n visitRelationships: this.visitRelationships,\n excludedCodeSpecNames: [...this._excludedCodeSpecNames],\n excludedElementIds: CompressedId64Set.compressSet(this._excludedElementIds),\n excludedElementCategoryIds: CompressedId64Set.compressSet(this._excludedElementCategoryIds),\n excludedElementClassNames: Array.from(this._excludedElementClasses, (cls) => cls.classFullName),\n excludedElementAspectClassFullNames: [...this._exportElementAspectsStrategy.excludedElementAspectClassFullNames],\n excludedRelationshipClassNames: Array.from(this._excludedRelationshipClasses, (cls) => cls.classFullName),\n additionalState: this.getAdditionalStateJson(),\n };\n }\n}\n\n/**\n * The JSON format of a serialized IModelExporter instance\n * Used for starting an exporter in the middle of an export operation,\n * such as resuming a crashed transformation\n *\n * @note Must be kept synchronized with IModelExporter\n * @internal\n */\nexport interface IModelExporterState {\n exporterClass: string;\n wantGeometry: boolean;\n wantTemplateModels: boolean;\n wantSystemSchemas: boolean;\n visitElements: boolean;\n visitRelationships: boolean;\n excludedCodeSpecNames: string[];\n excludedElementIds: CompressedId64Set;\n excludedElementCategoryIds: CompressedId64Set;\n excludedElementClassNames: string[];\n excludedElementAspectClassFullNames: string[];\n excludedRelationshipClassNames: string[];\n additionalState?: any;\n}\n\n/**\n * Asserts that the passed in options have exactly one of:\n * startChangeset xor changesetRanges xor changedInstanceIds\n * defined\n */\nfunction assertHasChangeDataOptions(opts: ExportChangesOptions): void {\n const xor = (...args: any): boolean => {\n let result = false;\n for (const a of args) {\n if (!result && a)\n result = true;\n else if (result && a)\n return false;\n }\n return result;\n };\n\n nodeAssert(\n xor(opts.startChangeset, opts.changesetRanges, opts.changedInstanceIds),\n \"exactly one of startChangeset, XOR changesetRanges XOR opts.changedInstanceIds may be defined but \"\n + `received ${JSON.stringify({\n startChangeset: !!opts.startChangeset,\n changesetRanges: !!opts.changesetRanges,\n ChangedInstanceIds: !!opts.changedInstanceIds,\n })}`,\n );\n}\n\n/**\n * Arguments for [[ChangedInstanceIds.initialize]]\n * @beta\n */\nexport interface ChangedInstanceIdsInitOptions extends ExportChangesOptions {\n iModel: BriefcaseDb;\n}\n\n/** Class for holding change information.\n * @beta\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(val: IModelJsNative.ChangedInstanceOpsProps | undefined): 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/**\n * Class for discovering modified elements between 2 versions of an iModel.\n * @beta\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 constructor() { }\n\n /**\n * Initializes a new ChangedInstanceIds object with information taken from a range of changesets.\n */\n public static async initialize(opts: ChangedInstanceIdsInitOptions): Promise<ChangedInstanceIds>;\n /**\n * Initializes a new ChangedInstanceIds object with information taken from a range of changesets.\n * @deprecated in 0.1.x. Pass a [[ChangedInstanceIdsInitOptions]] object instead of a changeset id\n * @param accessToken Access token.\n * @param iModel IModel briefcase whose changesets will be queried.\n * @param firstChangesetId Changeset id.\n * @note Modified element information will be taken from a range of changesets. First changeset in a range will be the 'firstChangesetId', the last will be whichever changeset the 'iModel' briefcase is currently opened on.\n */\n public static async initialize(\n accessTokenOrOpts: AccessToken | ChangedInstanceIdsInitOptions | undefined,\n iModel?: BriefcaseDb,\n startChangesetId?: string,\n ): Promise<ChangedInstanceIds> {\n const opts: ChangedInstanceIdsInitOptions\n = typeof accessTokenOrOpts === \"object\"\n ? accessTokenOrOpts\n : {\n accessToken: accessTokenOrOpts,\n iModel: iModel!,\n startChangeset: { id: startChangesetId! },\n };\n\n assertHasChangeDataOptions(opts);\n\n const iModelId = opts.iModel.iModelId;\n const accessToken = opts.accessToken;\n\n const changesetRanges = opts.changesetRanges\n ?? [[\n // we know startChangeset is defined because of the assert above\n opts.startChangeset!.index\n ?? (await IModelHost.hubAccess.queryChangeset({\n iModelId,\n changeset: { id: opts.startChangeset!.id ?? opts.iModel.changeset.id },\n accessToken,\n })).index,\n opts.iModel.changeset.index\n ?? (await IModelHost.hubAccess.queryChangeset({\n iModelId,\n changeset: { id: opts.iModel.changeset.id },\n accessToken,\n })).index,\n ]];\n\n Logger.logTrace(loggerCategory, `ChangedInstanceIds.initialize ranges: ${changesetRanges.join(\"|\")}`);\n\n const changesets = (await Promise.all(\n changesetRanges.map(async ([first, end]) =>\n IModelHost.hubAccess.downloadChangesets({\n accessToken,\n iModelId, range: { first, end },\n targetDir: BriefcaseManager.getChangeSetsPath(iModelId),\n })\n )\n )).flat();\n\n const changedInstanceIds = new ChangedInstanceIds();\n const changesetFiles = changesets.map((c) => c.pathname);\n const statusOrResult = opts.iModel.nativeDb.extractChangedInstanceIdsFromChangeSets(changesetFiles);\n if (statusOrResult.error) {\n throw new IModelError(statusOrResult.error.status, \"Error processing changeset\");\n }\n const result = statusOrResult.result;\n assert(result !== undefined);\n changedInstanceIds.codeSpec.addFromJson(result.codeSpec);\n changedInstanceIds.model.addFromJson(result.model);\n changedInstanceIds.element.addFromJson(result.element);\n changedInstanceIds.aspect.addFromJson(result.aspect);\n changedInstanceIds.relationship.addFromJson(result.relationship);\n changedInstanceIds.font.addFromJson(result.font);\n return changedInstanceIds;\n }\n}\n"]}