@itwin/core-backend 5.0.0-dev.98 → 5.0.0-dev.99
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/cjs/ChangeSummaryManager.d.ts.map +1 -1
- package/lib/cjs/ChangeSummaryManager.js +12 -5
- package/lib/cjs/ChangeSummaryManager.js.map +1 -1
- package/lib/cjs/ChangesetECAdaptor.d.ts.map +1 -1
- package/lib/cjs/ChangesetECAdaptor.js +1 -0
- package/lib/cjs/ChangesetECAdaptor.js.map +1 -1
- package/lib/cjs/ECDb.d.ts +37 -1
- package/lib/cjs/ECDb.d.ts.map +1 -1
- package/lib/cjs/ECDb.js +81 -0
- package/lib/cjs/ECDb.js.map +1 -1
- package/lib/cjs/ECSqlStatement.d.ts +181 -2
- package/lib/cjs/ECSqlStatement.d.ts.map +1 -1
- package/lib/cjs/ECSqlStatement.js +224 -5
- package/lib/cjs/ECSqlStatement.js.map +1 -1
- package/lib/cjs/ElementAspect.d.ts.map +1 -1
- package/lib/cjs/ElementAspect.js +1 -0
- package/lib/cjs/ElementAspect.js.map +1 -1
- package/lib/cjs/ElementTreeWalker.d.ts.map +1 -1
- package/lib/cjs/ElementTreeWalker.js +4 -0
- package/lib/cjs/ElementTreeWalker.js.map +1 -1
- package/lib/cjs/IModelDb.d.ts +4 -0
- package/lib/cjs/IModelDb.d.ts.map +1 -1
- package/lib/cjs/IModelDb.js +29 -1
- package/lib/cjs/IModelDb.js.map +1 -1
- package/lib/cjs/Relationship.d.ts.map +1 -1
- package/lib/cjs/Relationship.js +2 -0
- package/lib/cjs/Relationship.js.map +1 -1
- package/lib/cjs/ViewStore.d.ts.map +1 -1
- package/lib/cjs/ViewStore.js +2 -1
- package/lib/cjs/ViewStore.js.map +1 -1
- package/lib/cjs/internal/ChannelAdmin.d.ts.map +1 -1
- package/lib/cjs/internal/ChannelAdmin.js +2 -0
- package/lib/cjs/internal/ChannelAdmin.js.map +1 -1
- package/lib/cjs/rpc-impl/IModelReadRpcImpl.d.ts.map +1 -1
- package/lib/cjs/rpc-impl/IModelReadRpcImpl.js +1 -0
- package/lib/cjs/rpc-impl/IModelReadRpcImpl.js.map +1 -1
- package/lib/esm/ChangeSummaryManager.d.ts.map +1 -1
- package/lib/esm/ChangeSummaryManager.js +12 -5
- package/lib/esm/ChangeSummaryManager.js.map +1 -1
- package/lib/esm/ChangesetECAdaptor.d.ts.map +1 -1
- package/lib/esm/ChangesetECAdaptor.js +1 -0
- package/lib/esm/ChangesetECAdaptor.js.map +1 -1
- package/lib/esm/ECDb.d.ts +37 -1
- package/lib/esm/ECDb.d.ts.map +1 -1
- package/lib/esm/ECDb.js +82 -1
- package/lib/esm/ECDb.js.map +1 -1
- package/lib/esm/ECSqlStatement.d.ts +181 -2
- package/lib/esm/ECSqlStatement.d.ts.map +1 -1
- package/lib/esm/ECSqlStatement.js +222 -4
- package/lib/esm/ECSqlStatement.js.map +1 -1
- package/lib/esm/ElementAspect.d.ts.map +1 -1
- package/lib/esm/ElementAspect.js +1 -0
- package/lib/esm/ElementAspect.js.map +1 -1
- package/lib/esm/ElementTreeWalker.d.ts.map +1 -1
- package/lib/esm/ElementTreeWalker.js +4 -0
- package/lib/esm/ElementTreeWalker.js.map +1 -1
- package/lib/esm/IModelDb.d.ts +4 -0
- package/lib/esm/IModelDb.d.ts.map +1 -1
- package/lib/esm/IModelDb.js +29 -1
- package/lib/esm/IModelDb.js.map +1 -1
- package/lib/esm/Relationship.d.ts.map +1 -1
- package/lib/esm/Relationship.js +2 -0
- package/lib/esm/Relationship.js.map +1 -1
- package/lib/esm/ViewStore.d.ts.map +1 -1
- package/lib/esm/ViewStore.js +2 -1
- package/lib/esm/ViewStore.js.map +1 -1
- package/lib/esm/internal/ChannelAdmin.d.ts.map +1 -1
- package/lib/esm/internal/ChannelAdmin.js +2 -0
- package/lib/esm/internal/ChannelAdmin.js.map +1 -1
- package/lib/esm/rpc-impl/IModelReadRpcImpl.d.ts.map +1 -1
- package/lib/esm/rpc-impl/IModelReadRpcImpl.js +1 -0
- package/lib/esm/rpc-impl/IModelReadRpcImpl.js.map +1 -1
- package/lib/esm/test/IModelTestUtils.d.ts.map +1 -1
- package/lib/esm/test/IModelTestUtils.js +10 -0
- package/lib/esm/test/IModelTestUtils.js.map +1 -1
- package/lib/esm/test/PrintElementTree.js +1 -0
- package/lib/esm/test/PrintElementTree.js.map +1 -1
- package/lib/esm/test/SchemaUtils.test.js +2 -0
- package/lib/esm/test/SchemaUtils.test.js.map +1 -1
- package/lib/esm/test/ecdb/ECDb.test.js +12 -1
- package/lib/esm/test/ecdb/ECDb.test.js.map +1 -1
- package/lib/esm/test/ecdb/ECSqlAst.test.js +1 -0
- package/lib/esm/test/ecdb/ECSqlAst.test.js.map +1 -1
- package/lib/esm/test/ecdb/ECSqlQuery.test.js +6 -0
- package/lib/esm/test/ecdb/ECSqlQuery.test.js.map +1 -1
- package/lib/esm/test/ecdb/ECSqlReader.test.js +1 -1
- package/lib/esm/test/ecdb/ECSqlReader.test.js.map +1 -1
- package/lib/esm/test/ecdb/ECSqlStatement.test.js +253 -163
- package/lib/esm/test/ecdb/ECSqlStatement.test.js.map +1 -1
- package/lib/esm/test/ecdb/SqliteStatement.test.js +2 -0
- package/lib/esm/test/ecdb/SqliteStatement.test.js.map +1 -1
- package/lib/esm/test/ecsql/src/ECSqlTestGenerator.js +1 -0
- package/lib/esm/test/ecsql/src/ECSqlTestGenerator.js.map +1 -1
- package/lib/esm/test/ecsql/src/ECSqlTestRunner.test.js +5 -1
- package/lib/esm/test/ecsql/src/ECSqlTestRunner.test.js.map +1 -1
- package/lib/esm/test/element/ElementRoundTrip.test.js +10 -0
- package/lib/esm/test/element/ElementRoundTrip.test.js.map +1 -1
- package/lib/esm/test/imodel/ElementTreeWalker.test.js +1 -0
- package/lib/esm/test/imodel/ElementTreeWalker.test.js.map +1 -1
- package/lib/esm/test/imodel/IModel.test.js +14 -0
- package/lib/esm/test/imodel/IModel.test.js.map +1 -1
- package/lib/esm/test/schema/GenericDomain.test.js +1 -0
- package/lib/esm/test/schema/GenericDomain.test.js.map +1 -1
- package/lib/esm/test/standalone/ChangesetReader.test.js +1 -0
- package/lib/esm/test/standalone/ChangesetReader.test.js.map +1 -1
- package/lib/esm/test/standalone/IModelWrite.test.js +7 -0
- package/lib/esm/test/standalone/IModelWrite.test.js.map +1 -1
- package/lib/esm/test/standalone/RenderMaterialElement.test.js +1 -0
- package/lib/esm/test/standalone/RenderMaterialElement.test.js.map +1 -1
- package/package.json +12 -12
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ChangeSummaryManager.d.ts","sourceRoot":"","sources":["../../src/ChangeSummaryManager.ts"],"names":[],"mappings":"AAIA;;GAEG;AAEH,OAAO,EAAE,WAAW,EAAoB,UAAU,EAAE,UAAU,EAAwB,MAAM,qBAAqB,CAAC;AAClH,OAAO,EAAE,iBAAiB,EAAE,YAAY,EAAE,cAAc,EAA8B,MAAM,oBAAoB,CAAC;AAMjH,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAO7D;;;;;;;;GAQG;AACH,MAAM,WAAW,aAAa;IAC5B,EAAE,EAAE,UAAU,CAAC;IACf,SAAS,EAAE;QAAE,KAAK,EAAE,UAAU,CAAC;QAAC,WAAW,EAAE,UAAU,CAAC;QAAC,WAAW,EAAE,MAAM,CAAC;QAAC,QAAQ,EAAE,MAAM,CAAC;QAAC,WAAW,EAAE,UAAU,CAAA;KAAE,CAAC;CAC3H;AAED;;;;;;GAMG;AACH,MAAM,WAAW,cAAc;IAC7B,EAAE,EAAE,UAAU,CAAC;IACf,SAAS,EAAE,UAAU,CAAC;IACtB,eAAe,EAAE;QAAE,EAAE,EAAE,UAAU,CAAC;QAAC,SAAS,EAAE,MAAM,CAAA;KAAE,CAAC;IACvD,MAAM,EAAE,YAAY,CAAC;IACrB,UAAU,EAAE,OAAO,CAAC;CACrB;AAED;;GAEG;AACH,MAAM,WAAW,uBAAwB,SAAQ,QAAQ;IACvD,+CAA+C;IAC/C,OAAO,EAAE,UAAU,CAAC;IAEpB,uBAAuB;IACvB,QAAQ,EAAE,UAAU,CAAC;IAErB;;;;OAIG;IACH,KAAK,EAAE,cAAc,CAAC;CACvB;AAED;;;;;GAKG;AACH,qBAAa,oBAAoB;IAC/B,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,iCAAiC,CAAmC;IAE5F;;;OAGG;WACW,qBAAqB,CAAC,MAAM,EAAE,QAAQ,GAAG,OAAO;IAO9D;;;;OAIG;WACW,iBAAiB,CAAC,MAAM,EAAE,QAAQ,GAAG,IAAI;IAmBvD;;;;OAIG;WACW,iBAAiB,CAAC,MAAM,EAAE,QAAQ,GAAG,IAAI;IAUvD,OAAO,CAAC,MAAM,CAAC,uBAAuB;IAuBtC,OAAO,CAAC,MAAM,CAAC,qBAAqB;IAYpC,OAAO,CAAC,MAAM,CAAC,mBAAmB;IAmBlC,OAAO,CAAC,MAAM,CAAC,qBAAqB;IAEpC,OAAO,CAAC,MAAM,CAAC,yBAAyB;IAWxC,OAAO,CAAC,MAAM,CAAC,gBAAgB;IAuB/B;;;;;;;;;;OAUG;WACW,kBAAkB,CAAC,MAAM,EAAE,WAAW,EAAE,eAAe,EAAE,UAAU,GAAG,aAAa;IAejG;;;;;;;;;;OAUG;WACW,mBAAmB,CAAC,MAAM,EAAE,WAAW,EAAE,gBAAgB,EAAE,UAAU,GAAG,cAAc;
|
|
1
|
+
{"version":3,"file":"ChangeSummaryManager.d.ts","sourceRoot":"","sources":["../../src/ChangeSummaryManager.ts"],"names":[],"mappings":"AAIA;;GAEG;AAEH,OAAO,EAAE,WAAW,EAAoB,UAAU,EAAE,UAAU,EAAwB,MAAM,qBAAqB,CAAC;AAClH,OAAO,EAAE,iBAAiB,EAAE,YAAY,EAAE,cAAc,EAA8B,MAAM,oBAAoB,CAAC;AAMjH,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAO7D;;;;;;;;GAQG;AACH,MAAM,WAAW,aAAa;IAC5B,EAAE,EAAE,UAAU,CAAC;IACf,SAAS,EAAE;QAAE,KAAK,EAAE,UAAU,CAAC;QAAC,WAAW,EAAE,UAAU,CAAC;QAAC,WAAW,EAAE,MAAM,CAAC;QAAC,QAAQ,EAAE,MAAM,CAAC;QAAC,WAAW,EAAE,UAAU,CAAA;KAAE,CAAC;CAC3H;AAED;;;;;;GAMG;AACH,MAAM,WAAW,cAAc;IAC7B,EAAE,EAAE,UAAU,CAAC;IACf,SAAS,EAAE,UAAU,CAAC;IACtB,eAAe,EAAE;QAAE,EAAE,EAAE,UAAU,CAAC;QAAC,SAAS,EAAE,MAAM,CAAA;KAAE,CAAC;IACvD,MAAM,EAAE,YAAY,CAAC;IACrB,UAAU,EAAE,OAAO,CAAC;CACrB;AAED;;GAEG;AACH,MAAM,WAAW,uBAAwB,SAAQ,QAAQ;IACvD,+CAA+C;IAC/C,OAAO,EAAE,UAAU,CAAC;IAEpB,uBAAuB;IACvB,QAAQ,EAAE,UAAU,CAAC;IAErB;;;;OAIG;IACH,KAAK,EAAE,cAAc,CAAC;CACvB;AAED;;;;;GAKG;AACH,qBAAa,oBAAoB;IAC/B,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,iCAAiC,CAAmC;IAE5F;;;OAGG;WACW,qBAAqB,CAAC,MAAM,EAAE,QAAQ,GAAG,OAAO;IAO9D;;;;OAIG;WACW,iBAAiB,CAAC,MAAM,EAAE,QAAQ,GAAG,IAAI;IAmBvD;;;;OAIG;WACW,iBAAiB,CAAC,MAAM,EAAE,QAAQ,GAAG,IAAI;IAUvD,OAAO,CAAC,MAAM,CAAC,uBAAuB;IAuBtC,OAAO,CAAC,MAAM,CAAC,qBAAqB;IAYpC,OAAO,CAAC,MAAM,CAAC,mBAAmB;IAmBlC,OAAO,CAAC,MAAM,CAAC,qBAAqB;IAEpC,OAAO,CAAC,MAAM,CAAC,yBAAyB;IAWxC,OAAO,CAAC,MAAM,CAAC,gBAAgB;IAuB/B;;;;;;;;;;OAUG;WACW,kBAAkB,CAAC,MAAM,EAAE,WAAW,EAAE,eAAe,EAAE,UAAU,GAAG,aAAa;IAejG;;;;;;;;;;OAUG;WACW,mBAAmB,CAAC,MAAM,EAAE,WAAW,EAAE,gBAAgB,EAAE,UAAU,GAAG,cAAc;IA6BpG;;;;;;;OAOG;WACW,4BAA4B,CAAC,MAAM,EAAE,QAAQ,EAAE,gBAAgB,EAAE,UAAU,GAAG,MAAM,EAAE;IA4BpG;;;;;;;;;;;;;;;OAeG;WACW,8BAA8B,CAAC,MAAM,EAAE,QAAQ,EAAE,kBAAkB,EAAE;QAAE,EAAE,EAAE,UAAU,CAAC;QAAC,SAAS,EAAE,UAAU,CAAC;QAAC,eAAe,EAAE;YAAE,EAAE,EAAE,UAAU,CAAC;YAAC,SAAS,EAAE,MAAM,CAAA;SAAE,CAAA;KAAE,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,oBAAoB,CAAC,EAAE,MAAM,EAAE,GAAG,MAAM;IAyBpQ;;;;;;OAMG;WACiB,mBAAmB,CAAC,WAAW,EAAE,WAAW,EAAE,MAAM,EAAE,WAAW,GAAG,OAAO,CAAC,UAAU,CAAC;IAyC3G;;;;OAIG;WACiB,qBAAqB,CAAC,IAAI,EAAE,uBAAuB,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC;CAyChG"}
|
|
@@ -162,6 +162,7 @@ class ChangeSummaryManager {
|
|
|
162
162
|
}
|
|
163
163
|
static openChangeCacheFile(changesFile, changeCacheFilePath) {
|
|
164
164
|
changesFile.openDb(changeCacheFilePath, ECDb_1.ECDbOpenMode.FileUpgrade);
|
|
165
|
+
// eslint-disable-next-line @typescript-eslint/no-deprecated
|
|
165
166
|
const actualSchemaVersion = changesFile.withPreparedStatement("SELECT VersionMajor read,VersionWrite write,VersionMinor minor FROM meta.ECSchemaDef WHERE Name='IModelChange'", (stmt) => {
|
|
166
167
|
if (stmt.step() !== core_bentley_1.DbResult.BE_SQLITE_ROW)
|
|
167
168
|
throw new core_common_1.IModelError(core_bentley_1.DbResult.BE_SQLITE_ERROR, "File is not a valid Change Cache file.");
|
|
@@ -175,6 +176,7 @@ class ChangeSummaryManager {
|
|
|
175
176
|
}
|
|
176
177
|
static getExtendedSchemaPath() { return path.join(IModelHost_1.KnownLocations.packageAssetsDir, "IModelChange.02.00.00.ecschema.xml"); }
|
|
177
178
|
static isSummaryAlreadyExtracted(changesFile, changeSetId) {
|
|
179
|
+
// eslint-disable-next-line @typescript-eslint/no-deprecated
|
|
178
180
|
return changesFile.withPreparedStatement("SELECT Summary.Id summaryid FROM imodelchange.ChangeSet WHERE WsgId=?", (stmt) => {
|
|
179
181
|
stmt.bindString(1, changeSetId);
|
|
180
182
|
if (core_bentley_1.DbResult.BE_SQLITE_ROW === stmt.step())
|
|
@@ -183,7 +185,7 @@ class ChangeSummaryManager {
|
|
|
183
185
|
});
|
|
184
186
|
}
|
|
185
187
|
static addExtendedInfos(changesFile, changeSummaryId, changesetWsgId, changesetParentWsgId, description, changesetPushDate, changeSetUserCreated) {
|
|
186
|
-
changesFile.
|
|
188
|
+
changesFile.withCachedWriteStatement("INSERT INTO imodelchange.ChangeSet(Summary.Id,WsgId,ParentWsgId,Description,PushDate,UserCreated) VALUES(?,?,?,?,?,?)", (stmt) => {
|
|
187
189
|
stmt.bindId(1, changeSummaryId);
|
|
188
190
|
stmt.bindString(2, changesetWsgId);
|
|
189
191
|
if (changesetParentWsgId)
|
|
@@ -194,9 +196,9 @@ class ChangeSummaryManager {
|
|
|
194
196
|
stmt.bindDateTime(5, changesetPushDate);
|
|
195
197
|
if (changeSetUserCreated)
|
|
196
198
|
stmt.bindString(6, changeSetUserCreated);
|
|
197
|
-
const r = stmt.
|
|
198
|
-
if (r !== core_bentley_1.DbResult.BE_SQLITE_DONE)
|
|
199
|
-
throw new core_common_1.IModelError(r, `Failed to add changeset information to extracted change summary ${changeSummaryId}`);
|
|
199
|
+
const r = stmt.stepForInsert();
|
|
200
|
+
if (r.status !== core_bentley_1.DbResult.BE_SQLITE_DONE)
|
|
201
|
+
throw new core_common_1.IModelError(r.status, `Failed to add changeset information to extracted change summary ${changeSummaryId}`);
|
|
200
202
|
});
|
|
201
203
|
}
|
|
202
204
|
/** Queries the ChangeSummary for the specified change summary id
|
|
@@ -213,6 +215,7 @@ class ChangeSummaryManager {
|
|
|
213
215
|
static queryChangeSummary(iModel, changeSummaryId) {
|
|
214
216
|
if (!ChangeSummaryManager.isChangeCacheAttached(iModel))
|
|
215
217
|
throw new core_common_1.IModelError(core_bentley_1.IModelStatus.BadArg, "Change Cache file must be attached to iModel.");
|
|
218
|
+
// eslint-disable-next-line @typescript-eslint/no-deprecated
|
|
216
219
|
return iModel.withPreparedStatement("SELECT WsgId,ParentWsgId,Description,PushDate,UserCreated FROM ecchange.imodelchange.ChangeSet WHERE Summary.Id=?", (stmt) => {
|
|
217
220
|
stmt.bindId(1, changeSummaryId);
|
|
218
221
|
if (stmt.step() !== core_bentley_1.DbResult.BE_SQLITE_ROW)
|
|
@@ -236,9 +239,12 @@ class ChangeSummaryManager {
|
|
|
236
239
|
if (!ChangeSummaryManager.isChangeCacheAttached(iModel))
|
|
237
240
|
throw new core_common_1.IModelError(core_bentley_1.IModelStatus.BadArg, "Change Cache file must be attached to iModel.");
|
|
238
241
|
// query instance changes
|
|
242
|
+
// eslint-disable-next-line @typescript-eslint/no-deprecated
|
|
239
243
|
const instanceChange = iModel.withPreparedStatement(`SELECT ic.Summary.Id summaryId, s.Name changedInstanceSchemaName, c.Name changedInstanceClassName, ic.ChangedInstance.Id changedInstanceId,
|
|
240
244
|
ic.OpCode, ic.IsIndirect FROM ecchange.change.InstanceChange ic JOIN main.meta.ECClassDef c ON c.ECInstanceId = ic.ChangedInstance.ClassId
|
|
241
|
-
JOIN main.meta.ECSchemaDef s ON c.Schema.Id = s.ECInstanceId WHERE ic.ECInstanceId =? `,
|
|
245
|
+
JOIN main.meta.ECSchemaDef s ON c.Schema.Id = s.ECInstanceId WHERE ic.ECInstanceId =? `,
|
|
246
|
+
// eslint-disable-next-line @typescript-eslint/no-deprecated
|
|
247
|
+
(stmt) => {
|
|
242
248
|
stmt.bindId(1, instanceChangeId);
|
|
243
249
|
if (stmt.step() !== core_bentley_1.DbResult.BE_SQLITE_ROW)
|
|
244
250
|
throw new core_common_1.IModelError(core_bentley_1.IModelStatus.BadArg, `No InstanceChange found for id ${instanceChangeId}.`);
|
|
@@ -262,6 +268,7 @@ class ChangeSummaryManager {
|
|
|
262
268
|
* @throws [IModelError]($common) if the change cache file hasn't been attached, or in case of other errors.
|
|
263
269
|
*/
|
|
264
270
|
static getChangedPropertyValueNames(iModel, instanceChangeId) {
|
|
271
|
+
// eslint-disable-next-line @typescript-eslint/no-deprecated
|
|
265
272
|
return iModel.withPreparedStatement("SELECT AccessString FROM ecchange.change.PropertyValueChange WHERE InstanceChange.Id=?", (stmt) => {
|
|
266
273
|
stmt.bindId(1, instanceChangeId);
|
|
267
274
|
const selectClauseItems = [];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ChangeSummaryManager.js","sourceRoot":"","sources":["../../src/ChangeSummaryManager.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 { AccessToken, assert, DbResult, GuidString, Id64String, IModelStatus, Logger } from \"@itwin/core-bentley\";\nimport { ChangedValueState, ChangeOpCode, ChangesetRange, IModelError, IModelVersion } from \"@itwin/core-common\";\nimport * as path from \"path\";\nimport { BackendLoggerCategory } from \"./BackendLoggerCategory\";\nimport { BriefcaseManager } from \"./BriefcaseManager\";\nimport { ECDb, ECDbOpenMode } from \"./ECDb\";\nimport { ECSqlStatement } from \"./ECSqlStatement\";\nimport { BriefcaseDb, IModelDb, TokenArg } from \"./IModelDb\";\nimport { IModelHost, KnownLocations } from \"./IModelHost\";\nimport { IModelJsFs } from \"./IModelJsFs\";\nimport { _hubAccess, _nativeDb } from \"./internal/Symbols\";\n\nconst loggerCategory: string = BackendLoggerCategory.ECDb;\n\n/** Represents an instance of the `ChangeSummary` ECClass from the `ECDbChange` ECSchema\n * combined with the information from the related `Changeset` instance (from the `IModelChange` ECSchema) from\n * which the Change Summary was extracted.\n *\n * See also\n * - [ChangeSummaryManager.queryChangeSummary]($backend)\n * - [ChangeSummary Overview]($docs/learning/ChangeSummaries)\n * @beta\n */\nexport interface ChangeSummary {\n id: Id64String;\n changeSet: { wsgId: GuidString, parentWsgId: GuidString, description: string, pushDate: string, userCreated: GuidString };\n}\n\n/** Represents an instance of the `InstanceChange` ECClass from the `ECDbChange` ECSchema\n *\n * See also\n * - [ChangeSummaryManager.queryInstanceChange]($backend)\n * - [ChangeSummary Overview]($docs/learning/ChangeSummaries)\n * @beta\n */\nexport interface InstanceChange {\n id: Id64String;\n summaryId: Id64String;\n changedInstance: { id: Id64String, className: string };\n opCode: ChangeOpCode;\n isIndirect: boolean;\n}\n\n/** Options for [ChangeSummaryManager.createChangeSummaries]($backend).\n * @beta\n */\nexport interface CreateChangeSummaryArgs extends TokenArg {\n /** Id of the iTwin that contains the iModel */\n iTwinId: GuidString;\n\n /** Id of the iModel */\n iModelId: GuidString;\n\n /**\n * Range of change sets\n * - the Change Summary for the first and last versions are also included\n * - if unspecified, all change sets until the latest version are processed\n */\n range: ChangesetRange;\n}\n\n/** Class to extract Change Summaries for a briefcase.\n *\n * See also:\n * - [ChangeSummary Overview]($docs/learning/ChangeSummaries)\n * @beta\n */\nexport class ChangeSummaryManager {\n private static readonly _currentIModelChangeSchemaVersion = { read: 2, write: 0, minor: 0 };\n\n /** Determines whether the *Change Cache file* is attached to the specified iModel or not\n * @param iModel iModel to check whether a *Change Cache file* is attached\n * @returns Returns true if the *Change Cache file* is attached to the iModel. false otherwise\n */\n public static isChangeCacheAttached(iModel: IModelDb): boolean {\n if (!iModel || !iModel.isOpen)\n throw new IModelError(IModelStatus.BadRequest, \"Briefcase must be open\");\n\n return iModel[_nativeDb].isChangeCacheAttached();\n }\n\n /** Attaches the *Change Cache file* to the specified iModel if it hasn't been attached yet.\n * A new *Change Cache file* will be created for the iModel if it hasn't existed before.\n * @param iModel iModel to attach the *Change Cache file* file to\n * @throws [IModelError]($common)\n */\n public static attachChangeCache(iModel: IModelDb): void {\n if (!iModel || !iModel.isOpen)\n throw new IModelError(IModelStatus.BadRequest, \"Briefcase must be open\");\n\n if (ChangeSummaryManager.isChangeCacheAttached(iModel))\n return;\n\n const changesCacheFilePath: string = BriefcaseManager.getChangeCachePathName(iModel.iModelId);\n if (!IModelJsFs.existsSync(changesCacheFilePath)) {\n using changeCacheFile = new ECDb();\n ChangeSummaryManager.createChangeCacheFile(iModel, changeCacheFile, changesCacheFilePath);\n }\n\n assert(IModelJsFs.existsSync(changesCacheFilePath));\n const res: DbResult = iModel[_nativeDb].attachChangeCache(changesCacheFilePath);\n if (res !== DbResult.BE_SQLITE_OK)\n throw new IModelError(res, `Failed to attach Change Cache file to ${iModel.pathName}.`);\n }\n\n /** Detaches the *Change Cache file* from the specified iModel.\n * - note that this method will cause any pending (currently running or queued) queries to fail\n * @param iModel iModel to detach the *Change Cache file* to\n * @throws [IModelError]($common) in case of errors, e.g. if no *Change Cache file* was attached before.\n */\n public static detachChangeCache(iModel: IModelDb): void {\n if (!iModel || !iModel.isOpen)\n throw new IModelError(IModelStatus.BadRequest, \"Briefcase must be open\");\n\n iModel.clearCaches();\n const res: DbResult = iModel[_nativeDb].detachChangeCache();\n if (res !== DbResult.BE_SQLITE_OK)\n throw new IModelError(res, `Failed to detach Change Cache file from ${iModel.pathName}.`);\n }\n\n private static openOrCreateChangesFile(iModel: BriefcaseDb): ECDb {\n if (!iModel?.isOpen)\n throw new IModelError(IModelStatus.BadArg, \"Invalid iModel handle. iModel must be open.\");\n\n const changesFile = new ECDb();\n const changeCacheFilePath = BriefcaseManager.getChangeCachePathName(iModel.iModelId);\n if (IModelJsFs.existsSync(changeCacheFilePath)) {\n ChangeSummaryManager.openChangeCacheFile(changesFile, changeCacheFilePath);\n return changesFile;\n }\n\n try {\n ChangeSummaryManager.createChangeCacheFile(iModel, changesFile, changeCacheFilePath);\n return changesFile;\n } catch (e) {\n // delete cache file again in case it was created but schema import failed\n if (IModelJsFs.existsSync(changeCacheFilePath))\n IModelJsFs.removeSync(changeCacheFilePath);\n\n throw e;\n }\n }\n\n private static createChangeCacheFile(iModel: IModelDb, changesFile: ECDb, changeCacheFilePath: string): void {\n if (!iModel?.isOpen)\n throw new IModelError(IModelStatus.BadArg, \"Invalid iModel object. iModel must be open.\");\n\n const stat: DbResult = iModel[_nativeDb].createChangeCache(changesFile[_nativeDb], changeCacheFilePath);\n if (stat !== DbResult.BE_SQLITE_OK)\n throw new IModelError(stat, `Failed to create Change Cache file at \"${changeCacheFilePath}\".`);\n\n // Extended information like changeset ids, push dates are persisted in the IModelChange ECSchema\n changesFile.importSchema(ChangeSummaryManager.getExtendedSchemaPath());\n }\n\n private static openChangeCacheFile(changesFile: ECDb, changeCacheFilePath: string): void {\n changesFile.openDb(changeCacheFilePath, ECDbOpenMode.FileUpgrade);\n\n const actualSchemaVersion: { read: number, write: number, minor: number } = changesFile.withPreparedStatement(\"SELECT VersionMajor read,VersionWrite write,VersionMinor minor FROM meta.ECSchemaDef WHERE Name='IModelChange'\",\n (stmt: ECSqlStatement) => {\n if (stmt.step() !== DbResult.BE_SQLITE_ROW)\n throw new IModelError(DbResult.BE_SQLITE_ERROR, \"File is not a valid Change Cache file.\");\n\n return stmt.getRow();\n });\n\n if (actualSchemaVersion.read === ChangeSummaryManager._currentIModelChangeSchemaVersion.read &&\n actualSchemaVersion.write === ChangeSummaryManager._currentIModelChangeSchemaVersion.write &&\n actualSchemaVersion.minor === ChangeSummaryManager._currentIModelChangeSchemaVersion.minor)\n return;\n\n changesFile.importSchema(ChangeSummaryManager.getExtendedSchemaPath());\n }\n\n private static getExtendedSchemaPath(): string { return path.join(KnownLocations.packageAssetsDir, \"IModelChange.02.00.00.ecschema.xml\"); }\n\n private static isSummaryAlreadyExtracted(changesFile: ECDb, changeSetId: GuidString): Id64String | undefined {\n return changesFile.withPreparedStatement(\"SELECT Summary.Id summaryid FROM imodelchange.ChangeSet WHERE WsgId=?\",\n (stmt: ECSqlStatement) => {\n stmt.bindString(1, changeSetId);\n if (DbResult.BE_SQLITE_ROW === stmt.step())\n return stmt.getValue(0).getId();\n\n return undefined;\n });\n }\n\n private static addExtendedInfos(changesFile: ECDb, changeSummaryId: Id64String, changesetWsgId: GuidString, changesetParentWsgId?: GuidString, description?: string, changesetPushDate?: string, changeSetUserCreated?: GuidString): void {\n changesFile.withPreparedStatement(\"INSERT INTO imodelchange.ChangeSet(Summary.Id,WsgId,ParentWsgId,Description,PushDate,UserCreated) VALUES(?,?,?,?,?,?)\",\n (stmt: ECSqlStatement) => {\n stmt.bindId(1, changeSummaryId);\n stmt.bindString(2, changesetWsgId);\n if (changesetParentWsgId)\n stmt.bindString(3, changesetParentWsgId);\n\n if (description)\n stmt.bindString(4, description);\n\n if (changesetPushDate)\n stmt.bindDateTime(5, changesetPushDate);\n\n if (changeSetUserCreated)\n stmt.bindString(6, changeSetUserCreated);\n\n const r: DbResult = stmt.step();\n if (r !== DbResult.BE_SQLITE_DONE)\n throw new IModelError(r, `Failed to add changeset information to extracted change summary ${changeSummaryId}`);\n });\n }\n\n /** Queries the ChangeSummary for the specified change summary id\n *\n * See also\n * - `ECDbChange.ChangeSummary` ECClass in the *ECDbChange* ECSchema\n * - [Change Summary Overview]($docs/learning/ChangeSummaries)\n * @param iModel iModel\n * @param changeSummaryId ECInstanceId of the ChangeSummary\n * @returns Returns the requested ChangeSummary object\n * @throws [IModelError]($common) If change summary does not exist for the specified id, or if the\n * change cache file hasn't been attached, or in case of other errors.\n */\n public static queryChangeSummary(iModel: BriefcaseDb, changeSummaryId: Id64String): ChangeSummary {\n if (!ChangeSummaryManager.isChangeCacheAttached(iModel))\n throw new IModelError(IModelStatus.BadArg, \"Change Cache file must be attached to iModel.\");\n\n return iModel.withPreparedStatement(\"SELECT WsgId,ParentWsgId,Description,PushDate,UserCreated FROM ecchange.imodelchange.ChangeSet WHERE Summary.Id=?\",\n (stmt: ECSqlStatement) => {\n stmt.bindId(1, changeSummaryId);\n if (stmt.step() !== DbResult.BE_SQLITE_ROW)\n throw new IModelError(IModelStatus.BadArg, `No ChangeSet information found for ChangeSummary ${changeSummaryId}.`);\n\n const row = stmt.getRow();\n return { id: changeSummaryId, changeSet: { wsgId: row.wsgId, parentWsgId: row.parentWsgId, description: row.description, pushDate: row.pushDate, userCreated: row.userCreated } };\n });\n }\n\n /** Queries the InstanceChange for the specified instance change id.\n *\n * See also\n * - `ECDbChange.InstanceChange` ECClass in the *ECDbChange* ECSchema\n * - [Change Summary Overview]($docs/learning/ChangeSummaries)\n * @param iModel iModel\n * @param instanceChangeId ECInstanceId of the InstanceChange (see `ECDbChange.InstanceChange` ECClass in the *ECDbChange* ECSchema)\n * @returns Returns the requested InstanceChange object (see `ECDbChange.InstanceChange` ECClass in the *ECDbChange* ECSchema)\n * @throws [IModelError]($common) if instance change does not exist for the specified id, or if the\n * change cache file hasn't been attached, or in case of other errors.\n */\n public static queryInstanceChange(iModel: BriefcaseDb, instanceChangeId: Id64String): InstanceChange {\n if (!ChangeSummaryManager.isChangeCacheAttached(iModel))\n throw new IModelError(IModelStatus.BadArg, \"Change Cache file must be attached to iModel.\");\n\n // query instance changes\n const instanceChange: InstanceChange = iModel.withPreparedStatement(`SELECT ic.Summary.Id summaryId, s.Name changedInstanceSchemaName, c.Name changedInstanceClassName, ic.ChangedInstance.Id changedInstanceId,\n ic.OpCode, ic.IsIndirect FROM ecchange.change.InstanceChange ic JOIN main.meta.ECClassDef c ON c.ECInstanceId = ic.ChangedInstance.ClassId\n JOIN main.meta.ECSchemaDef s ON c.Schema.Id = s.ECInstanceId WHERE ic.ECInstanceId =? `, (stmt: ECSqlStatement) => {\n stmt.bindId(1, instanceChangeId);\n if (stmt.step() !== DbResult.BE_SQLITE_ROW)\n throw new IModelError(IModelStatus.BadArg, `No InstanceChange found for id ${instanceChangeId}.`);\n\n const row = stmt.getRow();\n const changedInstanceId: Id64String = row.changedInstanceId;\n const changedInstanceClassName: string = `[${row.changedInstanceSchemaName}].[${row.changedInstanceClassName}]`;\n const op: ChangeOpCode = row.opCode as ChangeOpCode;\n\n return {\n id: instanceChangeId, summaryId: row.summaryId, changedInstance: { id: changedInstanceId, className: changedInstanceClassName },\n opCode: op, isIndirect: row.isIndirect,\n };\n });\n\n return instanceChange;\n }\n\n /** Retrieves the names of the properties whose values have changed for the given instance change\n *\n * See also [Change Summary Overview]($docs/learning/ChangeSummaries)\n * @param iModel iModel\n * @param instanceChangeId Id of the InstanceChange to query the properties whose values have changed\n * @returns Returns names of the properties whose values have changed for the given instance change\n * @throws [IModelError]($common) if the change cache file hasn't been attached, or in case of other errors.\n */\n public static getChangedPropertyValueNames(iModel: IModelDb, instanceChangeId: Id64String): string[] {\n return iModel.withPreparedStatement(\"SELECT AccessString FROM ecchange.change.PropertyValueChange WHERE InstanceChange.Id=?\",\n (stmt: ECSqlStatement) => {\n stmt.bindId(1, instanceChangeId);\n\n const selectClauseItems: string[] = [];\n while (stmt.step() === DbResult.BE_SQLITE_ROW) {\n // access string tokens need to be escaped as they might collide with reserved words in ECSQL or SQLite\n const accessString: string = stmt.getValue(0).getString();\n const accessStringTokens: string[] = accessString.split(\".\");\n assert(accessStringTokens.length > 0);\n\n let isFirstToken: boolean = true;\n let item: string = \"\";\n for (const token of accessStringTokens) {\n if (!isFirstToken)\n item += \".\";\n\n item += `[${token}]`;\n isFirstToken = false;\n }\n selectClauseItems.push(item);\n }\n\n return selectClauseItems;\n });\n }\n\n /** Builds the ECSQL to query the property value changes for the specified instance change and the specified ChangedValueState.\n *\n * See also [Change Summary Overview]($docs/learning/ChangeSummaries)\n * @param iModel iModel\n * @param instanceChangeInfo InstanceChange to query the property value changes for\n * changedInstance.className must be fully qualified and schema and class name must be escaped with square brackets if they collide with reserved ECSQL words: `[schema name].[class name]`\n * @param changedValueState The Changed State to query the values for. This must correspond to the [InstanceChange.OpCode]($backend) of the InstanceChange.\n * @param changedPropertyNames List of the property names for which values have changed for the specified instance change.\n * The list can be obtained by calling [ChangeSummaryManager.getChangedPropertyValueNames]($core-backend).\n * If omitted, the method will call the above method by itself. The parameter allows for checking first whether\n * an instance change has any property value changes at all. If there are no property value changes, this method\n * should not be called, as it will throw an error.\n * @returns Returns the ECSQL that will retrieve the property value changes\n * @throws [IModelError]($common) if instance change does not exist, if there are not property value changes for the instance change,\n * if the change cache file hasn't been attached, or in case of other errors.\n */\n public static buildPropertyValueChangesECSql(iModel: IModelDb, instanceChangeInfo: { id: Id64String, summaryId: Id64String, changedInstance: { id: Id64String, className: string } }, changedValueState: ChangedValueState, changedPropertyNames?: string[]): string {\n let selectClauseItems: string[];\n if (!changedPropertyNames) {\n // query property value changes just to build a SELECT statement against the class of the changed instance\n selectClauseItems = ChangeSummaryManager.getChangedPropertyValueNames(iModel, instanceChangeInfo.id);\n } else\n selectClauseItems = changedPropertyNames;\n\n if (selectClauseItems.length === 0)\n throw new IModelError(IModelStatus.BadArg, `No property value changes found for InstanceChange ${instanceChangeInfo.id}.`);\n\n let ecsql: string = \"SELECT \";\n selectClauseItems.map((item: string, index: number) => {\n if (index !== 0)\n ecsql += \",\";\n\n ecsql += item;\n });\n\n // Avoiding parameters in the Changes function speeds up performance because ECDb can do optimizations\n // if it knows the function args at prepare time\n ecsql += ` FROM main.${instanceChangeInfo.changedInstance.className}.Changes(${instanceChangeInfo.summaryId},${changedValueState}) WHERE ECInstanceId=${instanceChangeInfo.changedInstance.id}`;\n return ecsql;\n }\n\n /**\n * Creates a change summary for the last applied change set to the iModel\n * @param accessToken A valid access token string\n * @param iModel iModel to extract change summaries for. The iModel must not be a standalone iModel, and must have at least one change set applied to it.\n * @returns The id of the extracted change summary.\n * @beta\n */\n public static async createChangeSummary(accessToken: AccessToken, iModel: BriefcaseDb): Promise<Id64String> {\n if (!iModel?.isOpen)\n throw new IModelError(IModelStatus.BadRequest, \"Briefcase must be open\");\n const changesetId = iModel.changeset.id;\n if (!changesetId)\n throw new IModelError(IModelStatus.BadRequest, \"No change set was applied to the iModel\");\n if (this.isChangeCacheAttached(iModel))\n throw new IModelError(IModelStatus.BadRequest, \"Change cache must be detached before extraction\");\n\n const iModelId = iModel.iModelId;\n const changesetsFolder: string = BriefcaseManager.getChangeSetsPath(iModelId);\n const changeset = await IModelHost[_hubAccess].downloadChangeset({ accessToken: IModelHost.authorizationClient ? undefined : accessToken, iModelId, changeset: { id: iModel.changeset.id }, targetDir: changesetsFolder });\n\n if (!IModelJsFs.existsSync(changeset.pathname))\n throw new IModelError(IModelStatus.FileNotFound, `Failed to download change set: ${changeset.pathname}`);\n\n try {\n using changesFile = ChangeSummaryManager.openOrCreateChangesFile(iModel);\n assert(changesFile[_nativeDb] !== undefined, \"Invalid changesFile - should've caused an exception\");\n\n let changeSummaryId = ChangeSummaryManager.isSummaryAlreadyExtracted(changesFile, changesetId);\n if (changeSummaryId !== undefined) {\n Logger.logInfo(loggerCategory, `Change Summary for changeset already exists. It is not extracted again.`, () => ({ iModelId, changeSetId: changesetId }));\n return changeSummaryId;\n }\n\n const stat = iModel[_nativeDb].extractChangeSummary(changesFile[_nativeDb], changeset.pathname);\n if (stat.error && stat.error.status !== DbResult.BE_SQLITE_OK)\n throw new IModelError(stat.error.status, stat.error.message);\n\n assert(undefined !== stat.result);\n changeSummaryId = stat.result;\n ChangeSummaryManager.addExtendedInfos(changesFile, changeSummaryId, changesetId, changeset.parentId, changeset.description, changeset.pushDate, changeset.userCreated);\n\n changesFile.saveChanges();\n return changeSummaryId;\n } finally {\n IModelJsFs.unlinkSync(changeset.pathname);\n }\n }\n\n /**\n * Creates change summaries for the specified iModel and a specified range of versions\n * @note This may be an expensive operation - downloads the first version and starts applying the change sets, extracting summaries one by one\n * @param args Arguments including the range of versions for which Change Summaries are to be created, and other necessary input for creation\n */\n public static async createChangeSummaries(args: CreateChangeSummaryArgs): Promise<Id64String[]> {\n // if we pass undefined to hubAccess methods they will use our authorizationClient to refresh the token as needed.\n const accessToken = IModelHost.authorizationClient ? undefined : args.accessToken ?? \"\";\n const { iModelId, iTwinId, range } = args;\n range.end = range.end ?? (await IModelHost[_hubAccess].getChangesetFromVersion({ accessToken, iModelId, version: IModelVersion.latest() })).index;\n if (range.first > range.end)\n throw new IModelError(IModelStatus.BadArg, \"Invalid range of changesets\");\n if (range.first === 0 && range.end === 0)\n return []; // no changesets exist, so the inclusive range is empty\n\n const changesets = await IModelHost[_hubAccess].queryChangesets({ accessToken, iModelId, range });\n\n // Setup a temporary briefcase to help with extracting change summaries\n const briefcasePath = BriefcaseManager.getBriefcaseBasePath(iModelId);\n const fileName: string = path.join(briefcasePath, `ChangeSummaryBriefcase.bim`);\n if (IModelJsFs.existsSync(fileName))\n IModelJsFs.removeSync(fileName);\n\n let iModel: BriefcaseDb | undefined;\n try {\n // Download a version that has the first change set applied\n const props = await BriefcaseManager.downloadBriefcase({ accessToken, iTwinId, iModelId, asOf: { afterChangeSetId: changesets[0].id }, briefcaseId: 0, fileName });\n iModel = await BriefcaseDb.open({ fileName: props.fileName });\n\n const summaryIds = new Array<Id64String>();\n for (let index = 0; index < changesets.length; index++) {\n // Apply a change set if necessary\n if (index > 0)\n await iModel.pullChanges({ accessToken, toIndex: changesets[index].index });\n\n // Create a change summary for the last change set that was applied\n const summaryId = await this.createChangeSummary(accessToken ?? await IModelHost.authorizationClient?.getAccessToken() ?? \"\", iModel);\n summaryIds.push(summaryId);\n }\n return summaryIds;\n } finally {\n if (iModel !== undefined)\n iModel.close();\n IModelJsFs.removeSync(fileName);\n }\n }\n}\n"]}
|
|
1
|
+
{"version":3,"file":"ChangeSummaryManager.js","sourceRoot":"","sources":["../../src/ChangeSummaryManager.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 { AccessToken, assert, DbResult, GuidString, Id64String, IModelStatus, Logger } from \"@itwin/core-bentley\";\nimport { ChangedValueState, ChangeOpCode, ChangesetRange, IModelError, IModelVersion } from \"@itwin/core-common\";\nimport * as path from \"path\";\nimport { BackendLoggerCategory } from \"./BackendLoggerCategory\";\nimport { BriefcaseManager } from \"./BriefcaseManager\";\nimport { ECDb, ECDbOpenMode } from \"./ECDb\";\nimport { ECSqlInsertResult, ECSqlStatement, ECSqlWriteStatement } from \"./ECSqlStatement\";\nimport { BriefcaseDb, IModelDb, TokenArg } from \"./IModelDb\";\nimport { IModelHost, KnownLocations } from \"./IModelHost\";\nimport { IModelJsFs } from \"./IModelJsFs\";\nimport { _hubAccess, _nativeDb } from \"./internal/Symbols\";\n\nconst loggerCategory: string = BackendLoggerCategory.ECDb;\n\n/** Represents an instance of the `ChangeSummary` ECClass from the `ECDbChange` ECSchema\n * combined with the information from the related `Changeset` instance (from the `IModelChange` ECSchema) from\n * which the Change Summary was extracted.\n *\n * See also\n * - [ChangeSummaryManager.queryChangeSummary]($backend)\n * - [ChangeSummary Overview]($docs/learning/ChangeSummaries)\n * @beta\n */\nexport interface ChangeSummary {\n id: Id64String;\n changeSet: { wsgId: GuidString, parentWsgId: GuidString, description: string, pushDate: string, userCreated: GuidString };\n}\n\n/** Represents an instance of the `InstanceChange` ECClass from the `ECDbChange` ECSchema\n *\n * See also\n * - [ChangeSummaryManager.queryInstanceChange]($backend)\n * - [ChangeSummary Overview]($docs/learning/ChangeSummaries)\n * @beta\n */\nexport interface InstanceChange {\n id: Id64String;\n summaryId: Id64String;\n changedInstance: { id: Id64String, className: string };\n opCode: ChangeOpCode;\n isIndirect: boolean;\n}\n\n/** Options for [ChangeSummaryManager.createChangeSummaries]($backend).\n * @beta\n */\nexport interface CreateChangeSummaryArgs extends TokenArg {\n /** Id of the iTwin that contains the iModel */\n iTwinId: GuidString;\n\n /** Id of the iModel */\n iModelId: GuidString;\n\n /**\n * Range of change sets\n * - the Change Summary for the first and last versions are also included\n * - if unspecified, all change sets until the latest version are processed\n */\n range: ChangesetRange;\n}\n\n/** Class to extract Change Summaries for a briefcase.\n *\n * See also:\n * - [ChangeSummary Overview]($docs/learning/ChangeSummaries)\n * @beta\n */\nexport class ChangeSummaryManager {\n private static readonly _currentIModelChangeSchemaVersion = { read: 2, write: 0, minor: 0 };\n\n /** Determines whether the *Change Cache file* is attached to the specified iModel or not\n * @param iModel iModel to check whether a *Change Cache file* is attached\n * @returns Returns true if the *Change Cache file* is attached to the iModel. false otherwise\n */\n public static isChangeCacheAttached(iModel: IModelDb): boolean {\n if (!iModel || !iModel.isOpen)\n throw new IModelError(IModelStatus.BadRequest, \"Briefcase must be open\");\n\n return iModel[_nativeDb].isChangeCacheAttached();\n }\n\n /** Attaches the *Change Cache file* to the specified iModel if it hasn't been attached yet.\n * A new *Change Cache file* will be created for the iModel if it hasn't existed before.\n * @param iModel iModel to attach the *Change Cache file* file to\n * @throws [IModelError]($common)\n */\n public static attachChangeCache(iModel: IModelDb): void {\n if (!iModel || !iModel.isOpen)\n throw new IModelError(IModelStatus.BadRequest, \"Briefcase must be open\");\n\n if (ChangeSummaryManager.isChangeCacheAttached(iModel))\n return;\n\n const changesCacheFilePath: string = BriefcaseManager.getChangeCachePathName(iModel.iModelId);\n if (!IModelJsFs.existsSync(changesCacheFilePath)) {\n using changeCacheFile = new ECDb();\n ChangeSummaryManager.createChangeCacheFile(iModel, changeCacheFile, changesCacheFilePath);\n }\n\n assert(IModelJsFs.existsSync(changesCacheFilePath));\n const res: DbResult = iModel[_nativeDb].attachChangeCache(changesCacheFilePath);\n if (res !== DbResult.BE_SQLITE_OK)\n throw new IModelError(res, `Failed to attach Change Cache file to ${iModel.pathName}.`);\n }\n\n /** Detaches the *Change Cache file* from the specified iModel.\n * - note that this method will cause any pending (currently running or queued) queries to fail\n * @param iModel iModel to detach the *Change Cache file* to\n * @throws [IModelError]($common) in case of errors, e.g. if no *Change Cache file* was attached before.\n */\n public static detachChangeCache(iModel: IModelDb): void {\n if (!iModel || !iModel.isOpen)\n throw new IModelError(IModelStatus.BadRequest, \"Briefcase must be open\");\n\n iModel.clearCaches();\n const res: DbResult = iModel[_nativeDb].detachChangeCache();\n if (res !== DbResult.BE_SQLITE_OK)\n throw new IModelError(res, `Failed to detach Change Cache file from ${iModel.pathName}.`);\n }\n\n private static openOrCreateChangesFile(iModel: BriefcaseDb): ECDb {\n if (!iModel?.isOpen)\n throw new IModelError(IModelStatus.BadArg, \"Invalid iModel handle. iModel must be open.\");\n\n const changesFile = new ECDb();\n const changeCacheFilePath = BriefcaseManager.getChangeCachePathName(iModel.iModelId);\n if (IModelJsFs.existsSync(changeCacheFilePath)) {\n ChangeSummaryManager.openChangeCacheFile(changesFile, changeCacheFilePath);\n return changesFile;\n }\n\n try {\n ChangeSummaryManager.createChangeCacheFile(iModel, changesFile, changeCacheFilePath);\n return changesFile;\n } catch (e) {\n // delete cache file again in case it was created but schema import failed\n if (IModelJsFs.existsSync(changeCacheFilePath))\n IModelJsFs.removeSync(changeCacheFilePath);\n\n throw e;\n }\n }\n\n private static createChangeCacheFile(iModel: IModelDb, changesFile: ECDb, changeCacheFilePath: string): void {\n if (!iModel?.isOpen)\n throw new IModelError(IModelStatus.BadArg, \"Invalid iModel object. iModel must be open.\");\n\n const stat: DbResult = iModel[_nativeDb].createChangeCache(changesFile[_nativeDb], changeCacheFilePath);\n if (stat !== DbResult.BE_SQLITE_OK)\n throw new IModelError(stat, `Failed to create Change Cache file at \"${changeCacheFilePath}\".`);\n\n // Extended information like changeset ids, push dates are persisted in the IModelChange ECSchema\n changesFile.importSchema(ChangeSummaryManager.getExtendedSchemaPath());\n }\n\n private static openChangeCacheFile(changesFile: ECDb, changeCacheFilePath: string): void {\n changesFile.openDb(changeCacheFilePath, ECDbOpenMode.FileUpgrade);\n\n // eslint-disable-next-line @typescript-eslint/no-deprecated\n const actualSchemaVersion: { read: number, write: number, minor: number } = changesFile.withPreparedStatement(\"SELECT VersionMajor read,VersionWrite write,VersionMinor minor FROM meta.ECSchemaDef WHERE Name='IModelChange'\", (stmt: ECSqlStatement) => {\n if (stmt.step() !== DbResult.BE_SQLITE_ROW)\n throw new IModelError(DbResult.BE_SQLITE_ERROR, \"File is not a valid Change Cache file.\");\n\n return stmt.getRow();\n });\n\n if (actualSchemaVersion.read === ChangeSummaryManager._currentIModelChangeSchemaVersion.read &&\n actualSchemaVersion.write === ChangeSummaryManager._currentIModelChangeSchemaVersion.write &&\n actualSchemaVersion.minor === ChangeSummaryManager._currentIModelChangeSchemaVersion.minor)\n return;\n\n changesFile.importSchema(ChangeSummaryManager.getExtendedSchemaPath());\n }\n\n private static getExtendedSchemaPath(): string { return path.join(KnownLocations.packageAssetsDir, \"IModelChange.02.00.00.ecschema.xml\"); }\n\n private static isSummaryAlreadyExtracted(changesFile: ECDb, changeSetId: GuidString): Id64String | undefined {\n // eslint-disable-next-line @typescript-eslint/no-deprecated\n return changesFile.withPreparedStatement(\"SELECT Summary.Id summaryid FROM imodelchange.ChangeSet WHERE WsgId=?\", (stmt: ECSqlStatement) => {\n stmt.bindString(1, changeSetId);\n if (DbResult.BE_SQLITE_ROW === stmt.step())\n return stmt.getValue(0).getId();\n\n return undefined;\n });\n }\n\n private static addExtendedInfos(changesFile: ECDb, changeSummaryId: Id64String, changesetWsgId: GuidString, changesetParentWsgId?: GuidString, description?: string, changesetPushDate?: string, changeSetUserCreated?: GuidString): void {\n changesFile.withCachedWriteStatement(\"INSERT INTO imodelchange.ChangeSet(Summary.Id,WsgId,ParentWsgId,Description,PushDate,UserCreated) VALUES(?,?,?,?,?,?)\",\n (stmt: ECSqlWriteStatement) => {\n stmt.bindId(1, changeSummaryId);\n stmt.bindString(2, changesetWsgId);\n if (changesetParentWsgId)\n stmt.bindString(3, changesetParentWsgId);\n\n if (description)\n stmt.bindString(4, description);\n\n if (changesetPushDate)\n stmt.bindDateTime(5, changesetPushDate);\n\n if (changeSetUserCreated)\n stmt.bindString(6, changeSetUserCreated);\n\n const r: ECSqlInsertResult = stmt.stepForInsert();\n if (r.status !== DbResult.BE_SQLITE_DONE)\n throw new IModelError(r.status, `Failed to add changeset information to extracted change summary ${changeSummaryId}`);\n });\n }\n\n /** Queries the ChangeSummary for the specified change summary id\n *\n * See also\n * - `ECDbChange.ChangeSummary` ECClass in the *ECDbChange* ECSchema\n * - [Change Summary Overview]($docs/learning/ChangeSummaries)\n * @param iModel iModel\n * @param changeSummaryId ECInstanceId of the ChangeSummary\n * @returns Returns the requested ChangeSummary object\n * @throws [IModelError]($common) If change summary does not exist for the specified id, or if the\n * change cache file hasn't been attached, or in case of other errors.\n */\n public static queryChangeSummary(iModel: BriefcaseDb, changeSummaryId: Id64String): ChangeSummary {\n if (!ChangeSummaryManager.isChangeCacheAttached(iModel))\n throw new IModelError(IModelStatus.BadArg, \"Change Cache file must be attached to iModel.\");\n\n // eslint-disable-next-line @typescript-eslint/no-deprecated\n return iModel.withPreparedStatement(\"SELECT WsgId,ParentWsgId,Description,PushDate,UserCreated FROM ecchange.imodelchange.ChangeSet WHERE Summary.Id=?\", (stmt: ECSqlStatement) => {\n stmt.bindId(1, changeSummaryId);\n if (stmt.step() !== DbResult.BE_SQLITE_ROW)\n throw new IModelError(IModelStatus.BadArg, `No ChangeSet information found for ChangeSummary ${changeSummaryId}.`);\n\n const row = stmt.getRow();\n return { id: changeSummaryId, changeSet: { wsgId: row.wsgId, parentWsgId: row.parentWsgId, description: row.description, pushDate: row.pushDate, userCreated: row.userCreated } };\n });\n }\n\n /** Queries the InstanceChange for the specified instance change id.\n *\n * See also\n * - `ECDbChange.InstanceChange` ECClass in the *ECDbChange* ECSchema\n * - [Change Summary Overview]($docs/learning/ChangeSummaries)\n * @param iModel iModel\n * @param instanceChangeId ECInstanceId of the InstanceChange (see `ECDbChange.InstanceChange` ECClass in the *ECDbChange* ECSchema)\n * @returns Returns the requested InstanceChange object (see `ECDbChange.InstanceChange` ECClass in the *ECDbChange* ECSchema)\n * @throws [IModelError]($common) if instance change does not exist for the specified id, or if the\n * change cache file hasn't been attached, or in case of other errors.\n */\n public static queryInstanceChange(iModel: BriefcaseDb, instanceChangeId: Id64String): InstanceChange {\n if (!ChangeSummaryManager.isChangeCacheAttached(iModel))\n throw new IModelError(IModelStatus.BadArg, \"Change Cache file must be attached to iModel.\");\n\n // query instance changes\n // eslint-disable-next-line @typescript-eslint/no-deprecated\n const instanceChange: InstanceChange = iModel.withPreparedStatement(`SELECT ic.Summary.Id summaryId, s.Name changedInstanceSchemaName, c.Name changedInstanceClassName, ic.ChangedInstance.Id changedInstanceId,\n ic.OpCode, ic.IsIndirect FROM ecchange.change.InstanceChange ic JOIN main.meta.ECClassDef c ON c.ECInstanceId = ic.ChangedInstance.ClassId\n JOIN main.meta.ECSchemaDef s ON c.Schema.Id = s.ECInstanceId WHERE ic.ECInstanceId =? `,\n // eslint-disable-next-line @typescript-eslint/no-deprecated\n (stmt: ECSqlStatement) => {\n stmt.bindId(1, instanceChangeId);\n if (stmt.step() !== DbResult.BE_SQLITE_ROW)\n throw new IModelError(IModelStatus.BadArg, `No InstanceChange found for id ${instanceChangeId}.`);\n\n const row = stmt.getRow();\n const changedInstanceId: Id64String = row.changedInstanceId;\n const changedInstanceClassName: string = `[${row.changedInstanceSchemaName}].[${row.changedInstanceClassName}]`;\n const op: ChangeOpCode = row.opCode as ChangeOpCode;\n\n return {\n id: instanceChangeId, summaryId: row.summaryId, changedInstance: { id: changedInstanceId, className: changedInstanceClassName },\n opCode: op, isIndirect: row.isIndirect,\n };\n });\n\n return instanceChange;\n }\n\n /** Retrieves the names of the properties whose values have changed for the given instance change\n *\n * See also [Change Summary Overview]($docs/learning/ChangeSummaries)\n * @param iModel iModel\n * @param instanceChangeId Id of the InstanceChange to query the properties whose values have changed\n * @returns Returns names of the properties whose values have changed for the given instance change\n * @throws [IModelError]($common) if the change cache file hasn't been attached, or in case of other errors.\n */\n public static getChangedPropertyValueNames(iModel: IModelDb, instanceChangeId: Id64String): string[] {\n // eslint-disable-next-line @typescript-eslint/no-deprecated\n return iModel.withPreparedStatement(\"SELECT AccessString FROM ecchange.change.PropertyValueChange WHERE InstanceChange.Id=?\", (stmt: ECSqlStatement) => {\n stmt.bindId(1, instanceChangeId);\n\n const selectClauseItems: string[] = [];\n while (stmt.step() === DbResult.BE_SQLITE_ROW) {\n // access string tokens need to be escaped as they might collide with reserved words in ECSQL or SQLite\n const accessString: string = stmt.getValue(0).getString();\n const accessStringTokens: string[] = accessString.split(\".\");\n assert(accessStringTokens.length > 0);\n\n let isFirstToken: boolean = true;\n let item: string = \"\";\n for (const token of accessStringTokens) {\n if (!isFirstToken)\n item += \".\";\n\n item += `[${token}]`;\n isFirstToken = false;\n }\n selectClauseItems.push(item);\n }\n\n return selectClauseItems;\n });\n }\n\n /** Builds the ECSQL to query the property value changes for the specified instance change and the specified ChangedValueState.\n *\n * See also [Change Summary Overview]($docs/learning/ChangeSummaries)\n * @param iModel iModel\n * @param instanceChangeInfo InstanceChange to query the property value changes for\n * changedInstance.className must be fully qualified and schema and class name must be escaped with square brackets if they collide with reserved ECSQL words: `[schema name].[class name]`\n * @param changedValueState The Changed State to query the values for. This must correspond to the [InstanceChange.OpCode]($backend) of the InstanceChange.\n * @param changedPropertyNames List of the property names for which values have changed for the specified instance change.\n * The list can be obtained by calling [ChangeSummaryManager.getChangedPropertyValueNames]($core-backend).\n * If omitted, the method will call the above method by itself. The parameter allows for checking first whether\n * an instance change has any property value changes at all. If there are no property value changes, this method\n * should not be called, as it will throw an error.\n * @returns Returns the ECSQL that will retrieve the property value changes\n * @throws [IModelError]($common) if instance change does not exist, if there are not property value changes for the instance change,\n * if the change cache file hasn't been attached, or in case of other errors.\n */\n public static buildPropertyValueChangesECSql(iModel: IModelDb, instanceChangeInfo: { id: Id64String, summaryId: Id64String, changedInstance: { id: Id64String, className: string } }, changedValueState: ChangedValueState, changedPropertyNames?: string[]): string {\n let selectClauseItems: string[];\n if (!changedPropertyNames) {\n // query property value changes just to build a SELECT statement against the class of the changed instance\n selectClauseItems = ChangeSummaryManager.getChangedPropertyValueNames(iModel, instanceChangeInfo.id);\n } else\n selectClauseItems = changedPropertyNames;\n\n if (selectClauseItems.length === 0)\n throw new IModelError(IModelStatus.BadArg, `No property value changes found for InstanceChange ${instanceChangeInfo.id}.`);\n\n let ecsql: string = \"SELECT \";\n selectClauseItems.map((item: string, index: number) => {\n if (index !== 0)\n ecsql += \",\";\n\n ecsql += item;\n });\n\n // Avoiding parameters in the Changes function speeds up performance because ECDb can do optimizations\n // if it knows the function args at prepare time\n ecsql += ` FROM main.${instanceChangeInfo.changedInstance.className}.Changes(${instanceChangeInfo.summaryId},${changedValueState}) WHERE ECInstanceId=${instanceChangeInfo.changedInstance.id}`;\n return ecsql;\n }\n\n /**\n * Creates a change summary for the last applied change set to the iModel\n * @param accessToken A valid access token string\n * @param iModel iModel to extract change summaries for. The iModel must not be a standalone iModel, and must have at least one change set applied to it.\n * @returns The id of the extracted change summary.\n * @beta\n */\n public static async createChangeSummary(accessToken: AccessToken, iModel: BriefcaseDb): Promise<Id64String> {\n if (!iModel?.isOpen)\n throw new IModelError(IModelStatus.BadRequest, \"Briefcase must be open\");\n const changesetId = iModel.changeset.id;\n if (!changesetId)\n throw new IModelError(IModelStatus.BadRequest, \"No change set was applied to the iModel\");\n if (this.isChangeCacheAttached(iModel))\n throw new IModelError(IModelStatus.BadRequest, \"Change cache must be detached before extraction\");\n\n const iModelId = iModel.iModelId;\n const changesetsFolder: string = BriefcaseManager.getChangeSetsPath(iModelId);\n const changeset = await IModelHost[_hubAccess].downloadChangeset({ accessToken: IModelHost.authorizationClient ? undefined : accessToken, iModelId, changeset: { id: iModel.changeset.id }, targetDir: changesetsFolder });\n\n if (!IModelJsFs.existsSync(changeset.pathname))\n throw new IModelError(IModelStatus.FileNotFound, `Failed to download change set: ${changeset.pathname}`);\n\n try {\n using changesFile = ChangeSummaryManager.openOrCreateChangesFile(iModel);\n assert(changesFile[_nativeDb] !== undefined, \"Invalid changesFile - should've caused an exception\");\n\n let changeSummaryId = ChangeSummaryManager.isSummaryAlreadyExtracted(changesFile, changesetId);\n if (changeSummaryId !== undefined) {\n Logger.logInfo(loggerCategory, `Change Summary for changeset already exists. It is not extracted again.`, () => ({ iModelId, changeSetId: changesetId }));\n return changeSummaryId;\n }\n\n const stat = iModel[_nativeDb].extractChangeSummary(changesFile[_nativeDb], changeset.pathname);\n if (stat.error && stat.error.status !== DbResult.BE_SQLITE_OK)\n throw new IModelError(stat.error.status, stat.error.message);\n\n assert(undefined !== stat.result);\n changeSummaryId = stat.result;\n ChangeSummaryManager.addExtendedInfos(changesFile, changeSummaryId, changesetId, changeset.parentId, changeset.description, changeset.pushDate, changeset.userCreated);\n\n changesFile.saveChanges();\n return changeSummaryId;\n } finally {\n IModelJsFs.unlinkSync(changeset.pathname);\n }\n }\n\n /**\n * Creates change summaries for the specified iModel and a specified range of versions\n * @note This may be an expensive operation - downloads the first version and starts applying the change sets, extracting summaries one by one\n * @param args Arguments including the range of versions for which Change Summaries are to be created, and other necessary input for creation\n */\n public static async createChangeSummaries(args: CreateChangeSummaryArgs): Promise<Id64String[]> {\n // if we pass undefined to hubAccess methods they will use our authorizationClient to refresh the token as needed.\n const accessToken = IModelHost.authorizationClient ? undefined : args.accessToken ?? \"\";\n const { iModelId, iTwinId, range } = args;\n range.end = range.end ?? (await IModelHost[_hubAccess].getChangesetFromVersion({ accessToken, iModelId, version: IModelVersion.latest() })).index;\n if (range.first > range.end)\n throw new IModelError(IModelStatus.BadArg, \"Invalid range of changesets\");\n if (range.first === 0 && range.end === 0)\n return []; // no changesets exist, so the inclusive range is empty\n\n const changesets = await IModelHost[_hubAccess].queryChangesets({ accessToken, iModelId, range });\n\n // Setup a temporary briefcase to help with extracting change summaries\n const briefcasePath = BriefcaseManager.getBriefcaseBasePath(iModelId);\n const fileName: string = path.join(briefcasePath, `ChangeSummaryBriefcase.bim`);\n if (IModelJsFs.existsSync(fileName))\n IModelJsFs.removeSync(fileName);\n\n let iModel: BriefcaseDb | undefined;\n try {\n // Download a version that has the first change set applied\n const props = await BriefcaseManager.downloadBriefcase({ accessToken, iTwinId, iModelId, asOf: { afterChangeSetId: changesets[0].id }, briefcaseId: 0, fileName });\n iModel = await BriefcaseDb.open({ fileName: props.fileName });\n\n const summaryIds = new Array<Id64String>();\n for (let index = 0; index < changesets.length; index++) {\n // Apply a change set if necessary\n if (index > 0)\n await iModel.pullChanges({ accessToken, toIndex: changesets[index].index });\n\n // Create a change summary for the last change set that was applied\n const summaryId = await this.createChangeSummary(accessToken ?? await IModelHost.authorizationClient?.getAccessToken() ?? \"\", iModel);\n summaryIds.push(summaryId);\n }\n return summaryIds;\n } finally {\n if (iModel !== undefined)\n iModel.close();\n IModelJsFs.removeSync(fileName);\n }\n }\n}\n"]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ChangesetECAdaptor.d.ts","sourceRoot":"","sources":["../../src/ChangesetECAdaptor.ts"],"names":[],"mappings":"AAIA;;GAEG;AACH,OAAO,EAAwB,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACvE,OAAO,EAAuB,cAAc,EAAE,qBAAqB,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAoVvH;;;KAGK;AACL,MAAM,WAAW,cAAc;IAC7B,8CAA8C;IAC9C,MAAM,EAAE,MAAM,EAAE,CAAC;IACjB,+CAA+C;IAC/C,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,8CAA8C;IAC9C,EAAE,EAAE,cAAc,CAAC;IACnB,mDAAmD;IACnD,KAAK,EAAE,gBAAgB,CAAC;IACxB,sFAAsF;IACtF,eAAe,CAAC,EAAE,UAAU,CAAC;IAC7B,iEAAiE;IACjE,aAAa,EAAE,MAAM,EAAE,CAAC;CACzB;AAED;;;GAGG;AACH,MAAM,WAAW,iBAAiB;IAEhC,YAAY,EAAE,UAAU,CAAC;IAEzB,SAAS,CAAC,EAAE,UAAU,CAAC;IACvB,KAAK,CAAC,EAAE,cAAc,CAAC;IACvB,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAC;CACpB;AA4BD;;;;;GAKG;AACH,qBAAa,sBAAsB;IACjC,OAAO,CAAC,MAAM,CAAwC;IACtD,OAAO,CAAC,SAAS,CAAS;IAC1B;;;;;OAKG;IACH,OAAO,CAAC,MAAM,CAAC,cAAc;IAgC7B;;;OAGG;IACH,OAAO,CAAC,OAAO;
|
|
1
|
+
{"version":3,"file":"ChangesetECAdaptor.d.ts","sourceRoot":"","sources":["../../src/ChangesetECAdaptor.ts"],"names":[],"mappings":"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"}
|
|
@@ -387,6 +387,7 @@ class PartialECChangeUnifier {
|
|
|
387
387
|
if (rhs.$meta.fallbackClassId && lhs.$meta.fallbackClassId && db && rhs.$meta.fallbackClassId !== lhs.$meta.fallbackClassId) {
|
|
388
388
|
const lhsClassId = lhs.$meta.fallbackClassId;
|
|
389
389
|
const rhsClassId = rhs.$meta.fallbackClassId;
|
|
390
|
+
// eslint-disable-next-line @typescript-eslint/no-deprecated
|
|
390
391
|
const isRhsIsSubClassOfLhs = db.withPreparedStatement("SELECT ec_instanceof(?,?)", (stmt) => {
|
|
391
392
|
stmt.bindId(1, rhsClassId);
|
|
392
393
|
stmt.bindId(2, lhsClassId);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ChangesetECAdaptor.js","sourceRoot":"","sources":["../../src/ChangesetECAdaptor.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 ECDb\n */\nimport { DbResult, GuidString, Id64String } from \"@itwin/core-bentley\";\nimport { AnyDb, SqliteChange, SqliteChangeOp, SqliteChangesetReader, SqliteValueStage } from \"./SqliteChangesetReader\";\n\ninterface IClassRef {\n classId: Id64String;\n classFullName: string;\n}\n\ninterface IClassMap {\n readonly id: Id64String;\n readonly name: string;\n readonly mapStrategy: \"NotMapped\" | \"OwnTable\" | \"TablePerHierarchy\" | \"ExistingTable\" | \"ForeignKeyInTargetTable\" | \"ForeignKeyInSourceTable\";\n readonly type: \"Entity\" | \"Relationship\" | \"Struct\" | \"CustomAttribute\";\n readonly modifier: \"None\" | \"Abstract\" | \"Sealed\";\n readonly properties: IProperty[];\n}\n\ninterface IDateTimeInfo {\n readonly dateTimeKind?: \"Utc\" | \"Local\" | \"Unspecified\";\n readonly dateTimeComponent?: \"DateTime\" | \"Date\" | \"TimeOfDay\";\n}\n\ninterface IProperty {\n readonly id: Id64String;\n readonly name: string;\n readonly kind: \"Primitive\" | \"Struct\" | \"PrimitiveArray\" | \"StructArray\" | \"Navigation\";\n readonly primitiveType?: \"Binary\" | \"Boolean\" | \"DateTime\" | \"Double\" | \"Integer\" | \"Long\" | \"Point2d\" | \"Point3d\" | \"String\" | \"IGeometry\";\n readonly extendedTypeName?: string;\n readonly navigationRelationship?: IClassRef;\n readonly structClass?: IClassRef;\n readonly dateTimeInfo?: IDateTimeInfo;\n readonly columns: IColumn[];\n\n}\n\ninterface IColumn {\n readonly table: string;\n readonly column: string;\n readonly type: \"Any\" | \"Boolean\" | \"Blob\" | \"Timestamp\" | \"Real\" | \"Integer\" | \"Text\";\n readonly columnKind: \"Default\" | \"Id\" | \"ClassId\" | \"Shared\";\n readonly accessString: string;\n readonly isVirtual: boolean;\n}\n\ninterface ITable {\n readonly id: Id64String;\n readonly name: string;\n readonly type: \"Primary\" | \"Joined\" | \"Existing\" | \"Overflow\" | \"Virtual\";\n readonly exclusiveRootClassId: Id64String;\n readonly isClassIdVirtual: boolean;\n}\n\nclass ECDbMap {\n private _cachedClassMaps = new Map<Id64String, IClassMap>();\n private _cacheTables = new Map<string, ITable>();\n public constructor(public readonly db: AnyDb) { }\n public getAllDerivedClasses(classFullName: string) {\n const sql = `\n SELECT format('0x%x', ch.ClassId)\n FROM [ec_cache_ClassHierarchy] [ch]\n JOIN [ec_Class] [cs] ON [cs].[Id] = [ch].[BaseClassId]\n JOIN [ec_Schema] [sc] ON [sc].[Id] = [cs].[SchemaId]\n WHERE (([sc].[Alias] = :schemaNameOrAlias\n OR [sc].[Name] = :schemaNameOrAlias)\n AND ([cs].[Name] = :className))\n `;\n return this.db.withPreparedSqliteStatement(sql, (stmt) => {\n const parts = classFullName.indexOf(\".\") !== -1 ? classFullName.split(\".\") : classFullName.split(\":\");\n stmt.bindString(\":schemaNameOrAlias\", parts[0]);\n stmt.bindString(\":className\", parts[1]);\n const classIds = [];\n while (stmt.step() === DbResult.BE_SQLITE_ROW)\n classIds.push(stmt.getValueString(0));\n return classIds;\n });\n }\n public getTable(tableName: string): ITable | undefined {\n if (this._cacheTables.has(tableName))\n return this._cacheTables.get(tableName);\n\n const sql = `\n SELECT\n JSON_OBJECT (\n 'id', FORMAT ('0x%x', [t].[id]),\n 'name', [t].[Name],\n 'type', (\n CASE\n [t].[type]\n WHEN 0 THEN 'Primary'\n WHEN 1 THEN 'Joined'\n WHEN 2 THEN 'Existing'\n WHEN 3 THEN 'Overflow'\n WHEN 4 THEN 'Virtual'\n END\n ),\n 'exclusiveRootClassId', FORMAT ('0x%x',\n COALESCE (\n [t].[ExclusiveRootClassId], (\n SELECT [parent].[ExclusiveRootClassId]\n FROM [ec_Table] [parent]\n WHERE [parent].[Id] = [t].[ParentTableId] AND [parent].[Type] = 1))),\n 'isClassIdVirtual', (\n SELECT\n [c].[IsVirtual]\n FROM\n [ec_Column] [c]\n WHERE\n [c].[Name] = 'ECClassId' AND [c].[TableId] = [t].[Id]\n )\n )\n FROM [ec_Table] [t]\n WHERE\n [t].[Name] = ?;\n `;\n\n return this.db.withPreparedSqliteStatement(sql, (stmt) => {\n stmt.bindString(1, tableName);\n if (stmt.step() === DbResult.BE_SQLITE_ROW) {\n const table = JSON.parse(stmt.getValueString(0), (key, value) => {\n if (value === null)\n return undefined;\n\n if (key === \"isClassIdVirtual\")\n return value === 0 ? false : true;\n\n return value;\n }) as ITable;\n\n this._cacheTables.set(tableName, table);\n return table;\n }\n return undefined;\n });\n }\n public getClassMap(classId: Id64String): IClassMap | undefined {\n if (this._cachedClassMaps.has(classId))\n return this._cachedClassMaps.get(classId);\n\n const sql = `\n SELECT\n JSON_OBJECT(\n 'id', format('0x%x', cs.id),\n 'name', format('%s:%s', ss.Name, cs.Name),\n 'mapStrategy',\n (\n CASE cm.MapStrategy\n WHEN 0 THEN 'NotMapped'\n WHEN 1 THEN 'OwnTable'\n WHEN 2 THEN 'TablePerHierarchy'\n WHEN 3 THEN 'ExistingTable'\n WHEN 10 THEN 'ForeignKeyInTargetTable'\n WHEN 11 THEN 'ForeignKeyInSourceTable'\n END\n ),\n 'type',\n (\n CASE cs.Type\n WHEN 0 THEN 'Entity'\n WHEN 1 THEN 'Relationship'\n WHEN 2 THEN 'Struct'\n WHEN 3 THEN 'CustomAttribute'\n END\n ),\n 'modifier',\n (\n CASE cs.Modifier\n WHEN 0 THEN 'None'\n WHEN 1 THEN 'Abstract'\n WHEN 2 THEN 'Sealed'\n END\n ),\n 'properties',\n (\n SELECT\n JSON_GROUP_ARRAY(JSON(propJson))\n FROM\n (\n SELECT\n JSON_OBJECT(\n 'id', format('0x%x', pt.id),\n 'name', pt.Name,\n 'kind',\n (\n CASE pt.Kind\n WHEN 0 THEN 'Primitive'\n WHEN 1 THEN 'Struct'\n WHEN 2 THEN 'PrimitiveArray'\n WHEN 3 THEN 'StructArray'\n WHEN 4 THEN 'Navigation'\n END\n ),\n 'primitiveType',\n (\n CASE pt.PrimitiveType\n WHEN 0x101 THEN 'Binary'\n WHEN 0x201 THEN 'Boolean'\n WHEN 0x301 THEN 'DateTime'\n WHEN 0x401 THEN 'Double'\n WHEN 0x501 THEN 'Integer'\n WHEN 0x601 THEN 'Long'\n WHEN 0x701 THEN 'Point2d'\n WHEN 0x801 THEN 'Point3d'\n WHEN 0x901 THEN 'String'\n WHEN 0xa01 THEN 'IGeometry'\n END\n ),\n 'extendedTypeName', ExtendedTypeName,\n 'navigationRelationship',\n (\n SELECT\n JSON_OBJECT(\n 'classId', format('0x%x', nc.Id),\n 'classFullName', format('%s:%s', ns.Name, nc.Name)\n )\n FROM ec_Class nc\n JOIN ec_Schema ns ON ns.Id = nc.SchemaId\n WHERE\n nc.Id = pt.NavigationRelationshipClassId\n ),\n 'structClass',\n (\n SELECT\n JSON_OBJECT(\n 'classId', format('0x%x', nc.Id),\n 'classFullName', format('%s:%s', ns.Name, nc.Name)\n )\n FROM ec_Class nc\n JOIN ec_Schema ns ON ns.Id = nc.SchemaId\n WHERE\n nc.Id = pt.StructClassId\n ),\n 'dateTimeInfo', (\n SELECT\n JSON_OBJECT (\n 'dateTimeKind', (\n CASE\n WHEN [ca].[Instance] LIKE '%<DateTimeKind>Utc</DateTimeKind>%' COLLATE [NoCase] THEN 'Utc'\n WHEN [ca].[Instance] LIKE '%<DateTimeKind>Local</DateTimeKind>%' COLLATE [NoCase] THEN 'Local'\n ELSE 'Unspecified'\n END\n ),\n 'dateTimeComponent', (\n CASE\n WHEN [ca].[Instance] LIKE '%<DateTimeComponent>DateTime</DateTimeComponent>%' COLLATE [NoCase] THEN 'DateTime'\n WHEN [ca].[Instance] LIKE '%<DateTimeComponent>Date</DateTimeComponent>%' COLLATE [NoCase] THEN 'Date'\n WHEN [ca].[Instance] LIKE '%<DateTimeComponent>TimeOfDay</DateTimeComponent>%' COLLATE [NoCase] THEN 'TimeOfDay'\n ELSE 'DateTime'\n END\n )\n )\n FROM\n [ec_CustomAttribute] [ca]\n JOIN [ec_Class] [cl] ON [cl].[Id] = [ca].[ClassId]\n JOIN [ec_Schema] [sc] ON [sc].[Id] = [cl].[SchemaId]\n WHERE\n [ca].[ContainerType] = 992\n AND [cl].[Name] = 'DateTimeInfo'\n AND [sc].[Name] = 'CoreCustomAttributes'\n AND [ca].[ContainerId] = [pt].[Id]\n ),\n 'columns',\n (\n SELECT\n JSON_GROUP_ARRAY(JSON(columnJson))\n FROM\n (\n SELECT\n JSON_OBJECT(\n 'table', tb.Name,\n 'column', cc.Name,\n 'type',\n (\n CASE cc.Type\n WHEN 0 THEN 'Any'\n WHEN 1 THEN 'Boolean'\n WHEN 2 THEN 'Blob'\n WHEN 3 THEN 'Timestamp'\n WHEN 4 THEN 'Real'\n WHEN 5 THEN 'Integer'\n WHEN 6 THEN 'Text'\n END\n ),\n 'columnKind',\n (\n CASE cc.ColumnKind\n WHEN 0 THEN 'Default'\n WHEN 1 THEN 'Id'\n WHEN 2 THEN 'ClassId'\n WHEN 4 THEN 'SharedData'\n END\n ),\n 'accessString', pp0.AccessString,\n 'isVirtual', cc.IsVirtual OR tb.Type = 4\n ) columnJson\n FROM [ec_PropertyMap] [pm0]\n JOIN [ec_Column] [cc] ON [cc].[Id] = [pm0].[ColumnId]\n JOIN [ec_Table] [tb] ON [tb].[Id] = [cc].[TableId]\n JOIN [ec_PropertyPath] [pp0] ON [pp0].[Id] = [pm0].[PropertyPathId]\n WHERE\n [pp0].[RootPropertyId] = pt.Id AND pm0.ClassId = cs.Id\n )\n )\n ) propJson\n FROM [ec_PropertyMap] [pm]\n JOIN [ec_PropertyPath] [pp] ON [pp].[Id] = [pm].[PropertyPathId]\n JOIN [ec_Property] [pt] ON [pt].[Id] = [pp].[RootPropertyId]\n WHERE\n pm.ClassId = cs.Id\n GROUP BY\n pt.Id\n )\n )\n ) classDef\n FROM [ec_Class] [cs]\n JOIN [ec_ClassMap] [cm] ON [cm].[ClassId] = [cs].[Id]\n JOIN [ec_Schema] [ss] ON [ss].[Id] = [cs].[SchemaId]\n WHERE\n [cs].[Id] = ?\n `;\n\n return this.db.withPreparedSqliteStatement(sql, (stmt) => {\n stmt.bindId(1, classId);\n if (stmt.step() === DbResult.BE_SQLITE_ROW) {\n const classMap = JSON.parse(stmt.getValueString(0), (key, value) => {\n if (value === null) {\n return undefined;\n }\n if (key === \"isVirtual\") {\n return value === 0 ? false : true;\n }\n return value;\n }) as IClassMap;\n\n this._cachedClassMaps.set(classId, classMap);\n return classMap;\n }\n return undefined;\n });\n }\n}\n\n/**\n * Record meta data for the change.\n * @beta\n * */\nexport interface ChangeMetaData {\n /** list of tables making up this EC change */\n tables: string[];\n /** full name of the class of this EC change */\n classFullName?: string;\n /** sqlite operation that caused the change */\n op: SqliteChangeOp;\n /** version of the value read from sqlite change */\n stage: SqliteValueStage;\n /** if classId for the change was not found in db then fallback class for the table */\n fallbackClassId?: Id64String;\n /** list of change index making up this change (one per table) */\n changeIndexes: number[];\n}\n\n/**\n * Represent EC change derived from low level sqlite change\n * @beta\n */\nexport interface ChangedECInstance {\n // eslint-disable-next-line @typescript-eslint/naming-convention\n ECInstanceId: Id64String;\n // eslint-disable-next-line @typescript-eslint/naming-convention\n ECClassId?: Id64String;\n $meta?: ChangeMetaData;\n [key: string]: any;\n}\n\n/**\n * Helper function to convert between JS DateTime & SQLite JulianDay values.\n * @beta\n * */\nnamespace DateTime {\n /**\n * Convert JS date to JulianDay value.\n * @param dt JS Date object.\n * @param convertToUtc convert the input value to UTC.\n * @returns julian day value\n */\n export function toJulianDay(dt: Date, convertToUtc = true): number {\n const utcOffset = convertToUtc ? dt.getTimezoneOffset() / 1440 : 0;\n return (dt.valueOf() / 86400000) - utcOffset + 2440587.5;\n }\n /**\n * Convert Julian day to JS Date object\n * @param jd JulianDay value for date/time\n * @param isLocalTime if julian day is local time or UTC\n * @returns JS Date object.\n */\n export function fromJulianDay(jd: number, isLocalTime: boolean): Date {\n const utcOffset = isLocalTime ? 0 : new Date().getTimezoneOffset() / 1440;\n return new Date((jd - 2440587.5 + utcOffset) * 86400000);\n }\n}\n/**\n * Combine partial changed instance into single instance.\n * Partial changes is per table and a single instance can\n * span multiple tables.\n * @beta\n */\nexport class PartialECChangeUnifier {\n private _cache = new Map<string, ChangedECInstance>();\n private _readonly = false;\n /**\n * Get root class id for a given class\n * @param classId given class id\n * @param db use to find root class\n * @returns return root class id\n */\n private static getRootClassId(classId: Id64String, db: AnyDb): Id64String | undefined {\n const sql = `\n WITH\n [base_class]([classId], [baseClassId], [Level]) AS(\n SELECT [ch].[ClassId], [ch].[BaseClassId], 0\n FROM [ec_ClassHasBaseClasses] [ch] WHERE [ch].[ClassId] = ?\n UNION ALL\n SELECT [ch].[ClassId], [ch].[BaseClassId], [Level] + 1\n FROM [ec_ClassHasBaseClasses] [ch], [base_class] [bc] WHERE [bc].[BaseClassId] = [ch].[ClassId]\n\n )\n SELECT FORMAT('0x%x', [bc].[BaseClassId]) rootClass\n FROM [base_class] [bc]\n WHERE [bc].[ClassId] <> [bc].[BaseClassId]\n AND [bc].[BaseClassId] NOT IN (SELECT [ca].[ContainerId]\n FROM [ec_CustomAttribute] [ca]\n WHERE [ca].[ContainerType] = 30\n AND [ca].[ClassId] IN (SELECT [cc].[Id]\n FROM [ec_Class] [cc]\n JOIN [ec_Schema] [ss] ON [ss].[Id] = [cc].[SchemaId]\n WHERE [cc].[Name] = 'IsMixIn'\n AND [ss].[Name] = 'CoreCustomAttributes'))\n ORDER BY [Level] DESC`;\n\n return db.withSqliteStatement(sql, (stmt) => {\n stmt.bindId(1, classId);\n if (stmt.step() === DbResult.BE_SQLITE_ROW && !stmt.isValueNull(0)) {\n return stmt.getValueString(0);\n }\n return classId;\n });\n }\n /**\n * Combine partial instance with instance with same key if already exists.\n * @param rhs partial instance\n */\n private combine(rhs: ChangedECInstance, db?: AnyDb): void {\n if (!rhs.$meta) {\n throw new Error(\"PartialECChange being combine must have '$meta' property\");\n }\n const key = PartialECChangeUnifier.buildKey(rhs, db);\n const lhs = this._cache.get(key);\n if (lhs) {\n const { $meta: _, ...restOfRhs } = rhs;\n Object.assign(lhs, restOfRhs);\n if (lhs.$meta && rhs.$meta) {\n lhs.$meta.tables = [...rhs.$meta?.tables, ...lhs.$meta?.tables];\n lhs.$meta.changeIndexes = [...rhs.$meta?.changeIndexes, ...lhs.$meta?.changeIndexes];\n\n // we preserve child class name & id when merging instance.\n if (rhs.$meta.fallbackClassId && lhs.$meta.fallbackClassId && db && rhs.$meta.fallbackClassId !== lhs.$meta.fallbackClassId) {\n const lhsClassId = lhs.$meta.fallbackClassId;\n const rhsClassId = rhs.$meta.fallbackClassId;\n const isRhsIsSubClassOfLhs = db.withPreparedStatement(\"SELECT ec_instanceof(?,?)\", (stmt) => {\n stmt.bindId(1, rhsClassId);\n stmt.bindId(2, lhsClassId);\n stmt.step();\n return stmt.getValue(0).getInteger() === 1;\n });\n if (isRhsIsSubClassOfLhs) {\n lhs.$meta.fallbackClassId = rhs.$meta.fallbackClassId;\n lhs.$meta.classFullName = rhs.$meta.classFullName;\n }\n }\n }\n } else {\n this._cache.set(key, rhs);\n }\n }\n /**\n * Build key from EC change.\n * @param change EC change\n * @returns key created from EC change.\n */\n private static buildKey(change: ChangedECInstance, db?: AnyDb): string {\n let classId = change.ECClassId;\n if (typeof classId === \"undefined\") {\n if (db && change.$meta?.fallbackClassId) {\n classId = this.getRootClassId(change.$meta.fallbackClassId, db);\n }\n if (typeof classId === \"undefined\") {\n throw new Error(`unable to resolve ECClassId to root class id.`);\n }\n }\n return `${change.ECInstanceId}-${classId}-${change.$meta?.stage}`.toLowerCase();\n }\n /**\n * Append partial changes which will be combine using there instance key.\n * @note $meta property must be present on partial change as information\n * in it is used to combine partial instances.\n * @param adaptor changeset adaptor is use to read the partial EC change.\n * @beta\n */\n public appendFrom(adaptor: ChangesetECAdaptor): void {\n if (adaptor.disableMetaData) {\n throw new Error(\"change adaptor property 'disableMetaData' must be set to 'false'\");\n }\n if (this._readonly) {\n throw new Error(\"this instance is marked as readonly.\");\n }\n\n if (adaptor.op === \"Updated\" && adaptor.inserted && adaptor.deleted) {\n this.combine(adaptor.inserted, adaptor.reader.db);\n this.combine(adaptor.deleted, adaptor.reader.db);\n } else if (adaptor.op === \"Inserted\" && adaptor.inserted) {\n this.combine(adaptor.inserted, adaptor.reader.db);\n } else if (adaptor.op === \"Deleted\" && adaptor.deleted) {\n this.combine(adaptor.deleted, adaptor.reader.db);\n }\n }\n /**\n * Delete $meta from all the instances.\n */\n public stripMetaData(): void {\n for (const inst of this._cache.values()) {\n if (\"$meta\" in inst) {\n delete inst.$meta;\n }\n }\n this._readonly = true;\n }\n /**\n * Returns complete EC change instances.\n * @beta\n */\n public get instances(): IterableIterator<ChangedECInstance> { return this._cache.values(); }\n}\n\n/**\n * Transform sqlite change to ec change. EC change is partial change as\n * it is per table while a single instance can span multiple table.\n * @note PrimitiveArray and StructArray are not supported types.\n * @beta\n *\n*/\nexport class ChangesetECAdaptor implements Disposable {\n private readonly _mapCache: ECDbMap;\n private readonly _tableFilter = new Set<string>();\n private readonly _opFilter = new Set<SqliteChangeOp>();\n private readonly _classFilter = new Set<string>();\n private _allowedClasses = new Set<string>();\n /**\n * set debug flags\n */\n public readonly debugFlags = {\n replaceBlobWithEllipsis: false, // replace bolb with ... for debugging\n replaceGeomWithEllipsis: false, // replace geom with ... for debugging\n replaceGuidWithEllipsis: false, // replace geom with ... for debugging\n };\n /**\n * Return partial inserted instance\n * For updates inserted represent new version of instance after update.\n */\n public inserted?: ChangedECInstance;\n /**\n * Return partial deleted instance.\n * For updates deleted represent old version of instance before update.\n */\n public deleted?: ChangedECInstance;\n\n /**\n * Setup filter that will result in change enumeration restricted to\n * list of tables added by acceptTable().\n * @param table Name of the table\n * @returns Fluent reference to ChangesetAdaptor.\n */\n public acceptTable(table: string): ChangesetECAdaptor {\n if (!this._tableFilter.has(table))\n this._tableFilter.add(table);\n return this;\n }\n /**\n * Setup filter that will result in change enumeration restricted to\n * list of op added by acceptOp().\n * @param op\n * @returns Fluent reference to ChangesetAdaptor.\n */\n public acceptOp(op: SqliteChangeOp): ChangesetECAdaptor {\n if (!this._opFilter.has(op))\n this._opFilter.add(op);\n return this;\n }\n /**\n * Setup filter that will result in change enumeration restricted to\n * list of class and its derived classes added by acceptClass().\n * @param classFullName\n * @returns\n */\n public acceptClass(classFullName: string): ChangesetECAdaptor {\n if (!this._classFilter.has(classFullName))\n this._classFilter.add(classFullName);\n\n this._allowedClasses.clear();\n return this;\n }\n private buildClassFilter() {\n if (this._allowedClasses.size !== 0 || this._classFilter.size === 0)\n return;\n\n this._classFilter.forEach((className) => {\n this._mapCache.getAllDerivedClasses(className).forEach((classId) => {\n this._allowedClasses.add(classId);\n });\n });\n }\n /**\n * Construct adaptor with a initialized reader.\n * @note the changeset reader must have disableSchemaCheck\n * set to false and db must also be set.\n * @param reader wrap changeset reader.\n */\n public constructor(public readonly reader: SqliteChangesetReader, public readonly disableMetaData = false) {\n if (!reader.disableSchemaCheck)\n throw new Error(\"SqliteChangesetReader, 'disableSchemaCheck' param must be set to false.\");\n\n this._mapCache = new ECDbMap(reader.db);\n }\n /**\n * dispose current instance and it will also dispose the changeset reader.\n */\n public [Symbol.dispose](): void {\n this.close();\n }\n /**\n * close current instance and it will also close the changeset reader.\n */\n public close(): void {\n this.reader.close();\n }\n /**\n * Convert binary GUID into string GUID.\n * @param binaryGUID binary version of guid.\n * @returns GUID string.\n */\n private static convertBinaryToGuid(binaryGUID: Uint8Array): GuidString {\n // Check if the array has 16 elements\n if (binaryGUID.length !== 16) {\n throw new Error(\"Invalid array length for Guid\");\n }\n // Convert each element to a two-digit hexadecimal string\n const hex = Array.from(binaryGUID, (byte) => byte.toString(16).padStart(2, \"0\"));\n // Join the hexadecimal strings and insert hyphens\n return `${hex.slice(0, 4).join(\"\")}-${hex.slice(4, 6).join(\"\")}-${hex.slice(6, 8).join(\"\")}-${hex.slice(8, 10).join(\"\")}-${hex.slice(10, 16).join(\"\")}`;\n\n }\n /**\n * Set value use access string in a JS object.\n * @param targetObj object that will be updated.\n * @param accessString access string token separated by '.'.\n */\n private static setValue(targetObj: any, accessString: string, value: any): void {\n let cursor = targetObj;\n const propPath = accessString.split(\".\");\n propPath.forEach((propertyName) => {\n if (propertyName === \"__proto__\")\n throw new Error(\"access string cannot container __proto__\");\n });\n\n const leafProp = propPath.splice(-1).shift();\n if (!leafProp)\n throw new Error(\"not access string was specified.\");\n\n for (const elem of propPath) {\n if (typeof cursor[elem] === \"undefined\")\n cursor[elem] = {};\n cursor = cursor[elem];\n }\n cursor[leafProp] = value;\n }\n\n /**\n * Check if sqlite change table is a EC data table\n * @param tableName name of the table.\n * @returns true if table has EC data.\n */\n public isECTable(tableName: string) {\n return typeof this._mapCache.getTable(tableName) !== \"undefined\";\n }\n /**\n * Attempt find ECClassId from ECInstanceId for a change of type 'updated'.\n * @param tableName name of the table to find ECClassId from given ECInstanceId\n * @param instanceId instance id for which we need ECClassId for.\n * @returns if successful returns ECClassId else return undefined.\n */\n private getClassIdFromDb(tableName: string, instanceId: Id64String): Id64String | undefined {\n try {\n return this.reader.db?.withPreparedSqliteStatement(`SELECT [ECClassId] FROM [${tableName}] WHERE [rowId]=?`, (stmt) => {\n stmt.bindId(1, instanceId);\n return stmt.step() === DbResult.BE_SQLITE_ROW ? stmt.getValueId(0) : undefined;\n });\n } catch {\n return undefined;\n }\n }\n /** helper method around reader.op */\n public get op() { return this.reader.op; }\n /** Return true if current change is of type \"Inserted\" */\n public get isInserted() { return this.op === \"Inserted\"; }\n /** Return true if current change is of type \"Deleted\" */\n public get isDeleted() { return this.op === \"Deleted\"; }\n /** Return true if current change is of type \"Updated\" */\n public get isUpdated() { return this.op === \"Updated\"; }\n\n /**\n * Advance reader to next change or a change that meets the filter set in the current adaptor\n * @returns return false if no more changes to read.\n */\n public step(): boolean {\n this.inserted = undefined;\n this.deleted = undefined;\n this.buildClassFilter();\n while (this.reader.step()) {\n if (!this.isECTable(this.reader.tableName))\n continue;\n\n if (this._tableFilter.size > 0) {\n if (!this._tableFilter.has(this.reader.tableName))\n continue;\n }\n\n if (this._opFilter.size > 0) {\n if (!this._opFilter.has(this.reader.op))\n continue;\n }\n\n if (this.reader.hasRow) {\n const table = this._mapCache.getTable(this.reader.tableName);\n if (!table || table.type === \"Virtual\") {\n throw new Error(`table in changeset not found or is virtual ${this.reader.tableName}`);\n }\n\n const change = {\n inserted: this.reader.getChangeValuesObject(\"New\", { includePrimaryKeyInUpdateNew: true }),\n deleted: this.reader.getChangeValuesObject(\"Old\", { includePrimaryKeyInUpdateNew: true }),\n };\n\n if (!change.inserted && !change.deleted) {\n throw new Error(`unable to get change from changeset reader`);\n }\n\n let ecClassId: Id64String | undefined = this.reader.op === \"Inserted\" ? change.inserted?.ECClassId : change.deleted?.ECClassId;\n const classIdPresentInChange = typeof ecClassId !== \"undefined\";\n let classMap: IClassMap | undefined;\n let fallbackClassId: Id64String | undefined;\n if (table.isClassIdVirtual) {\n classMap = this._mapCache.getClassMap(table.exclusiveRootClassId);\n } else {\n if (!ecClassId) {\n // attempt to find ECClassId against row from the db.\n const primaryKeys = this.reader.primaryKeyValues;\n if (primaryKeys.length === 1) {\n ecClassId = this.getClassIdFromDb(this.reader.tableName, this.reader.primaryKeyValues[0] as Id64String);\n }\n }\n if (ecClassId)\n classMap = this._mapCache.getClassMap(ecClassId);\n if (!classMap) {\n // fallback to root map for table.\n classMap = this._mapCache.getClassMap(table.exclusiveRootClassId);\n if (classMap)\n fallbackClassId = table.exclusiveRootClassId;\n }\n }\n\n if (!classMap)\n throw new Error(`unable to load class map`);\n\n if (!classIdPresentInChange && !ecClassId && !fallbackClassId)\n ecClassId = classMap.id;\n\n if (this._allowedClasses.size !== 0) {\n if (!this._allowedClasses.has(classMap.id))\n continue;\n }\n\n const $meta = {\n tables: [this.reader.tableName],\n op: this.reader.op,\n classFullName: classMap.name,\n fallbackClassId,\n changeIndexes: [this.reader.changeIndex],\n };\n\n if (this.reader.op === \"Inserted\" && change.inserted) {\n // eslint-disable-next-line @typescript-eslint/naming-convention\n this.inserted = { ECClassId: ecClassId, ECInstanceId: \"\" };\n if (!this.disableMetaData)\n this.inserted.$meta = { ...$meta, stage: \"New\" };\n this.transform(classMap, change.inserted, table, this.inserted);\n } else if (this.reader.op === \"Deleted\" && change.deleted) {\n // eslint-disable-next-line @typescript-eslint/naming-convention\n this.deleted = { ECClassId: ecClassId, ECInstanceId: \"\" };\n if (!this.disableMetaData)\n this.deleted.$meta = { ...$meta, stage: \"Old\" };\n this.transform(classMap, change.deleted, table, this.deleted);\n } else if (change.inserted && change.deleted) {\n // eslint-disable-next-line @typescript-eslint/naming-convention\n this.inserted = { ECClassId: ecClassId, ECInstanceId: \"\" };\n if (!this.disableMetaData)\n this.inserted.$meta = { ...$meta, stage: \"New\" };\n this.transform(classMap, change.inserted, table, this.inserted);\n // eslint-disable-next-line @typescript-eslint/naming-convention\n this.deleted = { ECClassId: ecClassId, ECInstanceId: \"\" };\n if (!this.disableMetaData)\n this.deleted.$meta = { ...$meta, stage: \"Old\" };\n this.transform(classMap, change.deleted, table, this.deleted);\n } else {\n throw new Error(\"unable to read EC changes\");\n }\n break;\n }\n }\n return this.reader.hasRow;\n }\n /**\n * Transform nav change column into navigation EC property\n * @param prop navigation property definition.\n * @param change sqlite change.\n * @param out ec instance that will be updated with navigation property.\n */\n private transformNavigationProperty(prop: IProperty, change: SqliteChange, out: ChangedECInstance): void {\n const idCol = prop.columns.filter(($) => $.accessString.endsWith(\".Id\")).at(0);\n if (!idCol) {\n throw new Error(\"invalid map for nav property\");\n }\n\n const idValue = change[idCol.column];\n if (typeof idValue === \"undefined\")\n return;\n\n ChangesetECAdaptor.setValue(out, idCol.accessString, idValue);\n\n const relClassIdCol = prop.columns.filter(($) => $.accessString.endsWith(\".RelECClassId\")).at(0);\n if (!relClassIdCol) {\n throw new Error(\"invalid map for nav property\");\n }\n\n const relClassIdValue = relClassIdCol.isVirtual ? prop.navigationRelationship?.classId : change[relClassIdCol.column];\n if (typeof relClassIdValue === \"undefined\")\n return;\n\n ChangesetECAdaptor.setValue(out, relClassIdCol.accessString, relClassIdValue);\n }\n /**\n * Transform sqlite change into EC change.\n * @param classMap classMap use to deserialize sqlite change into EC change.\n * @param change sqlite change from changeset.\n * @param table table definition of sqlite change provided.\n * @param out EC changeset that will be updated with properties.\n */\n private transform(classMap: IClassMap, change: SqliteChange, table: ITable, out: ChangedECInstance): void {\n // transform change row to instance\n for (const prop of classMap.properties) {\n if (prop.kind === \"PrimitiveArray\" || prop.kind === \"StructArray\") {\n // Arrays not supported\n continue;\n }\n if (prop.columns.filter((_) => _.isVirtual).length === prop.columns.length) {\n continue;\n }\n if (prop.kind === \"Navigation\") {\n this.transformNavigationProperty(prop, change, out);\n } else {\n for (const col of prop.columns) {\n if (col.table !== table.name)\n continue;\n\n const columnValue = change[col.column];\n if (typeof columnValue === \"undefined\")\n continue;\n\n if (columnValue !== null) {\n if (prop.primitiveType === \"DateTime\") {\n const dt = DateTime.fromJulianDay(columnValue, prop.dateTimeInfo?.dateTimeKind === \"Local\");\n ChangesetECAdaptor.setValue(out, col.accessString, dt.toISOString());\n continue;\n }\n if (prop.extendedTypeName === \"BeGuid\") {\n ChangesetECAdaptor.setValue(out, col.accessString, this.debugFlags.replaceGuidWithEllipsis ? \"...\" : ChangesetECAdaptor.convertBinaryToGuid(columnValue));\n continue;\n }\n if (prop.extendedTypeName === \"GeometryStream\") {\n ChangesetECAdaptor.setValue(out, col.accessString, this.debugFlags.replaceGeomWithEllipsis ? \"...\" : columnValue);\n continue;\n }\n if (prop.primitiveType === \"Binary\") {\n ChangesetECAdaptor.setValue(out, col.accessString, this.debugFlags.replaceBlobWithEllipsis ? \"...\" : columnValue);\n continue;\n }\n }\n ChangesetECAdaptor.setValue(out, col.accessString, columnValue);\n }\n }\n }\n }\n}\n"]}
|
|
1
|
+
{"version":3,"file":"ChangesetECAdaptor.js","sourceRoot":"","sources":["../../src/ChangesetECAdaptor.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 ECDb\n */\nimport { DbResult, GuidString, Id64String } from \"@itwin/core-bentley\";\nimport { AnyDb, SqliteChange, SqliteChangeOp, SqliteChangesetReader, SqliteValueStage } from \"./SqliteChangesetReader\";\n\ninterface IClassRef {\n classId: Id64String;\n classFullName: string;\n}\n\ninterface IClassMap {\n readonly id: Id64String;\n readonly name: string;\n readonly mapStrategy: \"NotMapped\" | \"OwnTable\" | \"TablePerHierarchy\" | \"ExistingTable\" | \"ForeignKeyInTargetTable\" | \"ForeignKeyInSourceTable\";\n readonly type: \"Entity\" | \"Relationship\" | \"Struct\" | \"CustomAttribute\";\n readonly modifier: \"None\" | \"Abstract\" | \"Sealed\";\n readonly properties: IProperty[];\n}\n\ninterface IDateTimeInfo {\n readonly dateTimeKind?: \"Utc\" | \"Local\" | \"Unspecified\";\n readonly dateTimeComponent?: \"DateTime\" | \"Date\" | \"TimeOfDay\";\n}\n\ninterface IProperty {\n readonly id: Id64String;\n readonly name: string;\n readonly kind: \"Primitive\" | \"Struct\" | \"PrimitiveArray\" | \"StructArray\" | \"Navigation\";\n readonly primitiveType?: \"Binary\" | \"Boolean\" | \"DateTime\" | \"Double\" | \"Integer\" | \"Long\" | \"Point2d\" | \"Point3d\" | \"String\" | \"IGeometry\";\n readonly extendedTypeName?: string;\n readonly navigationRelationship?: IClassRef;\n readonly structClass?: IClassRef;\n readonly dateTimeInfo?: IDateTimeInfo;\n readonly columns: IColumn[];\n\n}\n\ninterface IColumn {\n readonly table: string;\n readonly column: string;\n readonly type: \"Any\" | \"Boolean\" | \"Blob\" | \"Timestamp\" | \"Real\" | \"Integer\" | \"Text\";\n readonly columnKind: \"Default\" | \"Id\" | \"ClassId\" | \"Shared\";\n readonly accessString: string;\n readonly isVirtual: boolean;\n}\n\ninterface ITable {\n readonly id: Id64String;\n readonly name: string;\n readonly type: \"Primary\" | \"Joined\" | \"Existing\" | \"Overflow\" | \"Virtual\";\n readonly exclusiveRootClassId: Id64String;\n readonly isClassIdVirtual: boolean;\n}\n\nclass ECDbMap {\n private _cachedClassMaps = new Map<Id64String, IClassMap>();\n private _cacheTables = new Map<string, ITable>();\n public constructor(public readonly db: AnyDb) { }\n public getAllDerivedClasses(classFullName: string) {\n const sql = `\n SELECT format('0x%x', ch.ClassId)\n FROM [ec_cache_ClassHierarchy] [ch]\n JOIN [ec_Class] [cs] ON [cs].[Id] = [ch].[BaseClassId]\n JOIN [ec_Schema] [sc] ON [sc].[Id] = [cs].[SchemaId]\n WHERE (([sc].[Alias] = :schemaNameOrAlias\n OR [sc].[Name] = :schemaNameOrAlias)\n AND ([cs].[Name] = :className))\n `;\n return this.db.withPreparedSqliteStatement(sql, (stmt) => {\n const parts = classFullName.indexOf(\".\") !== -1 ? classFullName.split(\".\") : classFullName.split(\":\");\n stmt.bindString(\":schemaNameOrAlias\", parts[0]);\n stmt.bindString(\":className\", parts[1]);\n const classIds = [];\n while (stmt.step() === DbResult.BE_SQLITE_ROW)\n classIds.push(stmt.getValueString(0));\n return classIds;\n });\n }\n public getTable(tableName: string): ITable | undefined {\n if (this._cacheTables.has(tableName))\n return this._cacheTables.get(tableName);\n\n const sql = `\n SELECT\n JSON_OBJECT (\n 'id', FORMAT ('0x%x', [t].[id]),\n 'name', [t].[Name],\n 'type', (\n CASE\n [t].[type]\n WHEN 0 THEN 'Primary'\n WHEN 1 THEN 'Joined'\n WHEN 2 THEN 'Existing'\n WHEN 3 THEN 'Overflow'\n WHEN 4 THEN 'Virtual'\n END\n ),\n 'exclusiveRootClassId', FORMAT ('0x%x',\n COALESCE (\n [t].[ExclusiveRootClassId], (\n SELECT [parent].[ExclusiveRootClassId]\n FROM [ec_Table] [parent]\n WHERE [parent].[Id] = [t].[ParentTableId] AND [parent].[Type] = 1))),\n 'isClassIdVirtual', (\n SELECT\n [c].[IsVirtual]\n FROM\n [ec_Column] [c]\n WHERE\n [c].[Name] = 'ECClassId' AND [c].[TableId] = [t].[Id]\n )\n )\n FROM [ec_Table] [t]\n WHERE\n [t].[Name] = ?;\n `;\n\n return this.db.withPreparedSqliteStatement(sql, (stmt) => {\n stmt.bindString(1, tableName);\n if (stmt.step() === DbResult.BE_SQLITE_ROW) {\n const table = JSON.parse(stmt.getValueString(0), (key, value) => {\n if (value === null)\n return undefined;\n\n if (key === \"isClassIdVirtual\")\n return value === 0 ? false : true;\n\n return value;\n }) as ITable;\n\n this._cacheTables.set(tableName, table);\n return table;\n }\n return undefined;\n });\n }\n public getClassMap(classId: Id64String): IClassMap | undefined {\n if (this._cachedClassMaps.has(classId))\n return this._cachedClassMaps.get(classId);\n\n const sql = `\n SELECT\n JSON_OBJECT(\n 'id', format('0x%x', cs.id),\n 'name', format('%s:%s', ss.Name, cs.Name),\n 'mapStrategy',\n (\n CASE cm.MapStrategy\n WHEN 0 THEN 'NotMapped'\n WHEN 1 THEN 'OwnTable'\n WHEN 2 THEN 'TablePerHierarchy'\n WHEN 3 THEN 'ExistingTable'\n WHEN 10 THEN 'ForeignKeyInTargetTable'\n WHEN 11 THEN 'ForeignKeyInSourceTable'\n END\n ),\n 'type',\n (\n CASE cs.Type\n WHEN 0 THEN 'Entity'\n WHEN 1 THEN 'Relationship'\n WHEN 2 THEN 'Struct'\n WHEN 3 THEN 'CustomAttribute'\n END\n ),\n 'modifier',\n (\n CASE cs.Modifier\n WHEN 0 THEN 'None'\n WHEN 1 THEN 'Abstract'\n WHEN 2 THEN 'Sealed'\n END\n ),\n 'properties',\n (\n SELECT\n JSON_GROUP_ARRAY(JSON(propJson))\n FROM\n (\n SELECT\n JSON_OBJECT(\n 'id', format('0x%x', pt.id),\n 'name', pt.Name,\n 'kind',\n (\n CASE pt.Kind\n WHEN 0 THEN 'Primitive'\n WHEN 1 THEN 'Struct'\n WHEN 2 THEN 'PrimitiveArray'\n WHEN 3 THEN 'StructArray'\n WHEN 4 THEN 'Navigation'\n END\n ),\n 'primitiveType',\n (\n CASE pt.PrimitiveType\n WHEN 0x101 THEN 'Binary'\n WHEN 0x201 THEN 'Boolean'\n WHEN 0x301 THEN 'DateTime'\n WHEN 0x401 THEN 'Double'\n WHEN 0x501 THEN 'Integer'\n WHEN 0x601 THEN 'Long'\n WHEN 0x701 THEN 'Point2d'\n WHEN 0x801 THEN 'Point3d'\n WHEN 0x901 THEN 'String'\n WHEN 0xa01 THEN 'IGeometry'\n END\n ),\n 'extendedTypeName', ExtendedTypeName,\n 'navigationRelationship',\n (\n SELECT\n JSON_OBJECT(\n 'classId', format('0x%x', nc.Id),\n 'classFullName', format('%s:%s', ns.Name, nc.Name)\n )\n FROM ec_Class nc\n JOIN ec_Schema ns ON ns.Id = nc.SchemaId\n WHERE\n nc.Id = pt.NavigationRelationshipClassId\n ),\n 'structClass',\n (\n SELECT\n JSON_OBJECT(\n 'classId', format('0x%x', nc.Id),\n 'classFullName', format('%s:%s', ns.Name, nc.Name)\n )\n FROM ec_Class nc\n JOIN ec_Schema ns ON ns.Id = nc.SchemaId\n WHERE\n nc.Id = pt.StructClassId\n ),\n 'dateTimeInfo', (\n SELECT\n JSON_OBJECT (\n 'dateTimeKind', (\n CASE\n WHEN [ca].[Instance] LIKE '%<DateTimeKind>Utc</DateTimeKind>%' COLLATE [NoCase] THEN 'Utc'\n WHEN [ca].[Instance] LIKE '%<DateTimeKind>Local</DateTimeKind>%' COLLATE [NoCase] THEN 'Local'\n ELSE 'Unspecified'\n END\n ),\n 'dateTimeComponent', (\n CASE\n WHEN [ca].[Instance] LIKE '%<DateTimeComponent>DateTime</DateTimeComponent>%' COLLATE [NoCase] THEN 'DateTime'\n WHEN [ca].[Instance] LIKE '%<DateTimeComponent>Date</DateTimeComponent>%' COLLATE [NoCase] THEN 'Date'\n WHEN [ca].[Instance] LIKE '%<DateTimeComponent>TimeOfDay</DateTimeComponent>%' COLLATE [NoCase] THEN 'TimeOfDay'\n ELSE 'DateTime'\n END\n )\n )\n FROM\n [ec_CustomAttribute] [ca]\n JOIN [ec_Class] [cl] ON [cl].[Id] = [ca].[ClassId]\n JOIN [ec_Schema] [sc] ON [sc].[Id] = [cl].[SchemaId]\n WHERE\n [ca].[ContainerType] = 992\n AND [cl].[Name] = 'DateTimeInfo'\n AND [sc].[Name] = 'CoreCustomAttributes'\n AND [ca].[ContainerId] = [pt].[Id]\n ),\n 'columns',\n (\n SELECT\n JSON_GROUP_ARRAY(JSON(columnJson))\n FROM\n (\n SELECT\n JSON_OBJECT(\n 'table', tb.Name,\n 'column', cc.Name,\n 'type',\n (\n CASE cc.Type\n WHEN 0 THEN 'Any'\n WHEN 1 THEN 'Boolean'\n WHEN 2 THEN 'Blob'\n WHEN 3 THEN 'Timestamp'\n WHEN 4 THEN 'Real'\n WHEN 5 THEN 'Integer'\n WHEN 6 THEN 'Text'\n END\n ),\n 'columnKind',\n (\n CASE cc.ColumnKind\n WHEN 0 THEN 'Default'\n WHEN 1 THEN 'Id'\n WHEN 2 THEN 'ClassId'\n WHEN 4 THEN 'SharedData'\n END\n ),\n 'accessString', pp0.AccessString,\n 'isVirtual', cc.IsVirtual OR tb.Type = 4\n ) columnJson\n FROM [ec_PropertyMap] [pm0]\n JOIN [ec_Column] [cc] ON [cc].[Id] = [pm0].[ColumnId]\n JOIN [ec_Table] [tb] ON [tb].[Id] = [cc].[TableId]\n JOIN [ec_PropertyPath] [pp0] ON [pp0].[Id] = [pm0].[PropertyPathId]\n WHERE\n [pp0].[RootPropertyId] = pt.Id AND pm0.ClassId = cs.Id\n )\n )\n ) propJson\n FROM [ec_PropertyMap] [pm]\n JOIN [ec_PropertyPath] [pp] ON [pp].[Id] = [pm].[PropertyPathId]\n JOIN [ec_Property] [pt] ON [pt].[Id] = [pp].[RootPropertyId]\n WHERE\n pm.ClassId = cs.Id\n GROUP BY\n pt.Id\n )\n )\n ) classDef\n FROM [ec_Class] [cs]\n JOIN [ec_ClassMap] [cm] ON [cm].[ClassId] = [cs].[Id]\n JOIN [ec_Schema] [ss] ON [ss].[Id] = [cs].[SchemaId]\n WHERE\n [cs].[Id] = ?\n `;\n\n return this.db.withPreparedSqliteStatement(sql, (stmt) => {\n stmt.bindId(1, classId);\n if (stmt.step() === DbResult.BE_SQLITE_ROW) {\n const classMap = JSON.parse(stmt.getValueString(0), (key, value) => {\n if (value === null) {\n return undefined;\n }\n if (key === \"isVirtual\") {\n return value === 0 ? false : true;\n }\n return value;\n }) as IClassMap;\n\n this._cachedClassMaps.set(classId, classMap);\n return classMap;\n }\n return undefined;\n });\n }\n}\n\n/**\n * Record meta data for the change.\n * @beta\n * */\nexport interface ChangeMetaData {\n /** list of tables making up this EC change */\n tables: string[];\n /** full name of the class of this EC change */\n classFullName?: string;\n /** sqlite operation that caused the change */\n op: SqliteChangeOp;\n /** version of the value read from sqlite change */\n stage: SqliteValueStage;\n /** if classId for the change was not found in db then fallback class for the table */\n fallbackClassId?: Id64String;\n /** list of change index making up this change (one per table) */\n changeIndexes: number[];\n}\n\n/**\n * Represent EC change derived from low level sqlite change\n * @beta\n */\nexport interface ChangedECInstance {\n // eslint-disable-next-line @typescript-eslint/naming-convention\n ECInstanceId: Id64String;\n // eslint-disable-next-line @typescript-eslint/naming-convention\n ECClassId?: Id64String;\n $meta?: ChangeMetaData;\n [key: string]: any;\n}\n\n/**\n * Helper function to convert between JS DateTime & SQLite JulianDay values.\n * @beta\n * */\nnamespace DateTime {\n /**\n * Convert JS date to JulianDay value.\n * @param dt JS Date object.\n * @param convertToUtc convert the input value to UTC.\n * @returns julian day value\n */\n export function toJulianDay(dt: Date, convertToUtc = true): number {\n const utcOffset = convertToUtc ? dt.getTimezoneOffset() / 1440 : 0;\n return (dt.valueOf() / 86400000) - utcOffset + 2440587.5;\n }\n /**\n * Convert Julian day to JS Date object\n * @param jd JulianDay value for date/time\n * @param isLocalTime if julian day is local time or UTC\n * @returns JS Date object.\n */\n export function fromJulianDay(jd: number, isLocalTime: boolean): Date {\n const utcOffset = isLocalTime ? 0 : new Date().getTimezoneOffset() / 1440;\n return new Date((jd - 2440587.5 + utcOffset) * 86400000);\n }\n}\n/**\n * Combine partial changed instance into single instance.\n * Partial changes is per table and a single instance can\n * span multiple tables.\n * @beta\n */\nexport class PartialECChangeUnifier {\n private _cache = new Map<string, ChangedECInstance>();\n private _readonly = false;\n /**\n * Get root class id for a given class\n * @param classId given class id\n * @param db use to find root class\n * @returns return root class id\n */\n private static getRootClassId(classId: Id64String, db: AnyDb): Id64String | undefined {\n const sql = `\n WITH\n [base_class]([classId], [baseClassId], [Level]) AS(\n SELECT [ch].[ClassId], [ch].[BaseClassId], 0\n FROM [ec_ClassHasBaseClasses] [ch] WHERE [ch].[ClassId] = ?\n UNION ALL\n SELECT [ch].[ClassId], [ch].[BaseClassId], [Level] + 1\n FROM [ec_ClassHasBaseClasses] [ch], [base_class] [bc] WHERE [bc].[BaseClassId] = [ch].[ClassId]\n\n )\n SELECT FORMAT('0x%x', [bc].[BaseClassId]) rootClass\n FROM [base_class] [bc]\n WHERE [bc].[ClassId] <> [bc].[BaseClassId]\n AND [bc].[BaseClassId] NOT IN (SELECT [ca].[ContainerId]\n FROM [ec_CustomAttribute] [ca]\n WHERE [ca].[ContainerType] = 30\n AND [ca].[ClassId] IN (SELECT [cc].[Id]\n FROM [ec_Class] [cc]\n JOIN [ec_Schema] [ss] ON [ss].[Id] = [cc].[SchemaId]\n WHERE [cc].[Name] = 'IsMixIn'\n AND [ss].[Name] = 'CoreCustomAttributes'))\n ORDER BY [Level] DESC`;\n\n return db.withSqliteStatement(sql, (stmt) => {\n stmt.bindId(1, classId);\n if (stmt.step() === DbResult.BE_SQLITE_ROW && !stmt.isValueNull(0)) {\n return stmt.getValueString(0);\n }\n return classId;\n });\n }\n /**\n * Combine partial instance with instance with same key if already exists.\n * @param rhs partial instance\n */\n private combine(rhs: ChangedECInstance, db?: AnyDb): void {\n if (!rhs.$meta) {\n throw new Error(\"PartialECChange being combine must have '$meta' property\");\n }\n const key = PartialECChangeUnifier.buildKey(rhs, db);\n const lhs = this._cache.get(key);\n if (lhs) {\n const { $meta: _, ...restOfRhs } = rhs;\n Object.assign(lhs, restOfRhs);\n if (lhs.$meta && rhs.$meta) {\n lhs.$meta.tables = [...rhs.$meta?.tables, ...lhs.$meta?.tables];\n lhs.$meta.changeIndexes = [...rhs.$meta?.changeIndexes, ...lhs.$meta?.changeIndexes];\n\n // we preserve child class name & id when merging instance.\n if (rhs.$meta.fallbackClassId && lhs.$meta.fallbackClassId && db && rhs.$meta.fallbackClassId !== lhs.$meta.fallbackClassId) {\n const lhsClassId = lhs.$meta.fallbackClassId;\n const rhsClassId = rhs.$meta.fallbackClassId;\n // eslint-disable-next-line @typescript-eslint/no-deprecated\n const isRhsIsSubClassOfLhs = db.withPreparedStatement(\"SELECT ec_instanceof(?,?)\", (stmt) => {\n stmt.bindId(1, rhsClassId);\n stmt.bindId(2, lhsClassId);\n stmt.step();\n return stmt.getValue(0).getInteger() === 1;\n });\n if (isRhsIsSubClassOfLhs) {\n lhs.$meta.fallbackClassId = rhs.$meta.fallbackClassId;\n lhs.$meta.classFullName = rhs.$meta.classFullName;\n }\n }\n }\n } else {\n this._cache.set(key, rhs);\n }\n }\n /**\n * Build key from EC change.\n * @param change EC change\n * @returns key created from EC change.\n */\n private static buildKey(change: ChangedECInstance, db?: AnyDb): string {\n let classId = change.ECClassId;\n if (typeof classId === \"undefined\") {\n if (db && change.$meta?.fallbackClassId) {\n classId = this.getRootClassId(change.$meta.fallbackClassId, db);\n }\n if (typeof classId === \"undefined\") {\n throw new Error(`unable to resolve ECClassId to root class id.`);\n }\n }\n return `${change.ECInstanceId}-${classId}-${change.$meta?.stage}`.toLowerCase();\n }\n /**\n * Append partial changes which will be combine using there instance key.\n * @note $meta property must be present on partial change as information\n * in it is used to combine partial instances.\n * @param adaptor changeset adaptor is use to read the partial EC change.\n * @beta\n */\n public appendFrom(adaptor: ChangesetECAdaptor): void {\n if (adaptor.disableMetaData) {\n throw new Error(\"change adaptor property 'disableMetaData' must be set to 'false'\");\n }\n if (this._readonly) {\n throw new Error(\"this instance is marked as readonly.\");\n }\n\n if (adaptor.op === \"Updated\" && adaptor.inserted && adaptor.deleted) {\n this.combine(adaptor.inserted, adaptor.reader.db);\n this.combine(adaptor.deleted, adaptor.reader.db);\n } else if (adaptor.op === \"Inserted\" && adaptor.inserted) {\n this.combine(adaptor.inserted, adaptor.reader.db);\n } else if (adaptor.op === \"Deleted\" && adaptor.deleted) {\n this.combine(adaptor.deleted, adaptor.reader.db);\n }\n }\n /**\n * Delete $meta from all the instances.\n */\n public stripMetaData(): void {\n for (const inst of this._cache.values()) {\n if (\"$meta\" in inst) {\n delete inst.$meta;\n }\n }\n this._readonly = true;\n }\n /**\n * Returns complete EC change instances.\n * @beta\n */\n public get instances(): IterableIterator<ChangedECInstance> { return this._cache.values(); }\n}\n\n/**\n * Transform sqlite change to ec change. EC change is partial change as\n * it is per table while a single instance can span multiple table.\n * @note PrimitiveArray and StructArray are not supported types.\n * @beta\n *\n*/\nexport class ChangesetECAdaptor implements Disposable {\n private readonly _mapCache: ECDbMap;\n private readonly _tableFilter = new Set<string>();\n private readonly _opFilter = new Set<SqliteChangeOp>();\n private readonly _classFilter = new Set<string>();\n private _allowedClasses = new Set<string>();\n /**\n * set debug flags\n */\n public readonly debugFlags = {\n replaceBlobWithEllipsis: false, // replace bolb with ... for debugging\n replaceGeomWithEllipsis: false, // replace geom with ... for debugging\n replaceGuidWithEllipsis: false, // replace geom with ... for debugging\n };\n /**\n * Return partial inserted instance\n * For updates inserted represent new version of instance after update.\n */\n public inserted?: ChangedECInstance;\n /**\n * Return partial deleted instance.\n * For updates deleted represent old version of instance before update.\n */\n public deleted?: ChangedECInstance;\n\n /**\n * Setup filter that will result in change enumeration restricted to\n * list of tables added by acceptTable().\n * @param table Name of the table\n * @returns Fluent reference to ChangesetAdaptor.\n */\n public acceptTable(table: string): ChangesetECAdaptor {\n if (!this._tableFilter.has(table))\n this._tableFilter.add(table);\n return this;\n }\n /**\n * Setup filter that will result in change enumeration restricted to\n * list of op added by acceptOp().\n * @param op\n * @returns Fluent reference to ChangesetAdaptor.\n */\n public acceptOp(op: SqliteChangeOp): ChangesetECAdaptor {\n if (!this._opFilter.has(op))\n this._opFilter.add(op);\n return this;\n }\n /**\n * Setup filter that will result in change enumeration restricted to\n * list of class and its derived classes added by acceptClass().\n * @param classFullName\n * @returns\n */\n public acceptClass(classFullName: string): ChangesetECAdaptor {\n if (!this._classFilter.has(classFullName))\n this._classFilter.add(classFullName);\n\n this._allowedClasses.clear();\n return this;\n }\n private buildClassFilter() {\n if (this._allowedClasses.size !== 0 || this._classFilter.size === 0)\n return;\n\n this._classFilter.forEach((className) => {\n this._mapCache.getAllDerivedClasses(className).forEach((classId) => {\n this._allowedClasses.add(classId);\n });\n });\n }\n /**\n * Construct adaptor with a initialized reader.\n * @note the changeset reader must have disableSchemaCheck\n * set to false and db must also be set.\n * @param reader wrap changeset reader.\n */\n public constructor(public readonly reader: SqliteChangesetReader, public readonly disableMetaData = false) {\n if (!reader.disableSchemaCheck)\n throw new Error(\"SqliteChangesetReader, 'disableSchemaCheck' param must be set to false.\");\n\n this._mapCache = new ECDbMap(reader.db);\n }\n /**\n * dispose current instance and it will also dispose the changeset reader.\n */\n public [Symbol.dispose](): void {\n this.close();\n }\n /**\n * close current instance and it will also close the changeset reader.\n */\n public close(): void {\n this.reader.close();\n }\n /**\n * Convert binary GUID into string GUID.\n * @param binaryGUID binary version of guid.\n * @returns GUID string.\n */\n private static convertBinaryToGuid(binaryGUID: Uint8Array): GuidString {\n // Check if the array has 16 elements\n if (binaryGUID.length !== 16) {\n throw new Error(\"Invalid array length for Guid\");\n }\n // Convert each element to a two-digit hexadecimal string\n const hex = Array.from(binaryGUID, (byte) => byte.toString(16).padStart(2, \"0\"));\n // Join the hexadecimal strings and insert hyphens\n return `${hex.slice(0, 4).join(\"\")}-${hex.slice(4, 6).join(\"\")}-${hex.slice(6, 8).join(\"\")}-${hex.slice(8, 10).join(\"\")}-${hex.slice(10, 16).join(\"\")}`;\n\n }\n /**\n * Set value use access string in a JS object.\n * @param targetObj object that will be updated.\n * @param accessString access string token separated by '.'.\n */\n private static setValue(targetObj: any, accessString: string, value: any): void {\n let cursor = targetObj;\n const propPath = accessString.split(\".\");\n propPath.forEach((propertyName) => {\n if (propertyName === \"__proto__\")\n throw new Error(\"access string cannot container __proto__\");\n });\n\n const leafProp = propPath.splice(-1).shift();\n if (!leafProp)\n throw new Error(\"not access string was specified.\");\n\n for (const elem of propPath) {\n if (typeof cursor[elem] === \"undefined\")\n cursor[elem] = {};\n cursor = cursor[elem];\n }\n cursor[leafProp] = value;\n }\n\n /**\n * Check if sqlite change table is a EC data table\n * @param tableName name of the table.\n * @returns true if table has EC data.\n */\n public isECTable(tableName: string) {\n return typeof this._mapCache.getTable(tableName) !== \"undefined\";\n }\n /**\n * Attempt find ECClassId from ECInstanceId for a change of type 'updated'.\n * @param tableName name of the table to find ECClassId from given ECInstanceId\n * @param instanceId instance id for which we need ECClassId for.\n * @returns if successful returns ECClassId else return undefined.\n */\n private getClassIdFromDb(tableName: string, instanceId: Id64String): Id64String | undefined {\n try {\n return this.reader.db?.withPreparedSqliteStatement(`SELECT [ECClassId] FROM [${tableName}] WHERE [rowId]=?`, (stmt) => {\n stmt.bindId(1, instanceId);\n return stmt.step() === DbResult.BE_SQLITE_ROW ? stmt.getValueId(0) : undefined;\n });\n } catch {\n return undefined;\n }\n }\n /** helper method around reader.op */\n public get op() { return this.reader.op; }\n /** Return true if current change is of type \"Inserted\" */\n public get isInserted() { return this.op === \"Inserted\"; }\n /** Return true if current change is of type \"Deleted\" */\n public get isDeleted() { return this.op === \"Deleted\"; }\n /** Return true if current change is of type \"Updated\" */\n public get isUpdated() { return this.op === \"Updated\"; }\n\n /**\n * Advance reader to next change or a change that meets the filter set in the current adaptor\n * @returns return false if no more changes to read.\n */\n public step(): boolean {\n this.inserted = undefined;\n this.deleted = undefined;\n this.buildClassFilter();\n while (this.reader.step()) {\n if (!this.isECTable(this.reader.tableName))\n continue;\n\n if (this._tableFilter.size > 0) {\n if (!this._tableFilter.has(this.reader.tableName))\n continue;\n }\n\n if (this._opFilter.size > 0) {\n if (!this._opFilter.has(this.reader.op))\n continue;\n }\n\n if (this.reader.hasRow) {\n const table = this._mapCache.getTable(this.reader.tableName);\n if (!table || table.type === \"Virtual\") {\n throw new Error(`table in changeset not found or is virtual ${this.reader.tableName}`);\n }\n\n const change = {\n inserted: this.reader.getChangeValuesObject(\"New\", { includePrimaryKeyInUpdateNew: true }),\n deleted: this.reader.getChangeValuesObject(\"Old\", { includePrimaryKeyInUpdateNew: true }),\n };\n\n if (!change.inserted && !change.deleted) {\n throw new Error(`unable to get change from changeset reader`);\n }\n\n let ecClassId: Id64String | undefined = this.reader.op === \"Inserted\" ? change.inserted?.ECClassId : change.deleted?.ECClassId;\n const classIdPresentInChange = typeof ecClassId !== \"undefined\";\n let classMap: IClassMap | undefined;\n let fallbackClassId: Id64String | undefined;\n if (table.isClassIdVirtual) {\n classMap = this._mapCache.getClassMap(table.exclusiveRootClassId);\n } else {\n if (!ecClassId) {\n // attempt to find ECClassId against row from the db.\n const primaryKeys = this.reader.primaryKeyValues;\n if (primaryKeys.length === 1) {\n ecClassId = this.getClassIdFromDb(this.reader.tableName, this.reader.primaryKeyValues[0] as Id64String);\n }\n }\n if (ecClassId)\n classMap = this._mapCache.getClassMap(ecClassId);\n if (!classMap) {\n // fallback to root map for table.\n classMap = this._mapCache.getClassMap(table.exclusiveRootClassId);\n if (classMap)\n fallbackClassId = table.exclusiveRootClassId;\n }\n }\n\n if (!classMap)\n throw new Error(`unable to load class map`);\n\n if (!classIdPresentInChange && !ecClassId && !fallbackClassId)\n ecClassId = classMap.id;\n\n if (this._allowedClasses.size !== 0) {\n if (!this._allowedClasses.has(classMap.id))\n continue;\n }\n\n const $meta = {\n tables: [this.reader.tableName],\n op: this.reader.op,\n classFullName: classMap.name,\n fallbackClassId,\n changeIndexes: [this.reader.changeIndex],\n };\n\n if (this.reader.op === \"Inserted\" && change.inserted) {\n // eslint-disable-next-line @typescript-eslint/naming-convention\n this.inserted = { ECClassId: ecClassId, ECInstanceId: \"\" };\n if (!this.disableMetaData)\n this.inserted.$meta = { ...$meta, stage: \"New\" };\n this.transform(classMap, change.inserted, table, this.inserted);\n } else if (this.reader.op === \"Deleted\" && change.deleted) {\n // eslint-disable-next-line @typescript-eslint/naming-convention\n this.deleted = { ECClassId: ecClassId, ECInstanceId: \"\" };\n if (!this.disableMetaData)\n this.deleted.$meta = { ...$meta, stage: \"Old\" };\n this.transform(classMap, change.deleted, table, this.deleted);\n } else if (change.inserted && change.deleted) {\n // eslint-disable-next-line @typescript-eslint/naming-convention\n this.inserted = { ECClassId: ecClassId, ECInstanceId: \"\" };\n if (!this.disableMetaData)\n this.inserted.$meta = { ...$meta, stage: \"New\" };\n this.transform(classMap, change.inserted, table, this.inserted);\n // eslint-disable-next-line @typescript-eslint/naming-convention\n this.deleted = { ECClassId: ecClassId, ECInstanceId: \"\" };\n if (!this.disableMetaData)\n this.deleted.$meta = { ...$meta, stage: \"Old\" };\n this.transform(classMap, change.deleted, table, this.deleted);\n } else {\n throw new Error(\"unable to read EC changes\");\n }\n break;\n }\n }\n return this.reader.hasRow;\n }\n /**\n * Transform nav change column into navigation EC property\n * @param prop navigation property definition.\n * @param change sqlite change.\n * @param out ec instance that will be updated with navigation property.\n */\n private transformNavigationProperty(prop: IProperty, change: SqliteChange, out: ChangedECInstance): void {\n const idCol = prop.columns.filter(($) => $.accessString.endsWith(\".Id\")).at(0);\n if (!idCol) {\n throw new Error(\"invalid map for nav property\");\n }\n\n const idValue = change[idCol.column];\n if (typeof idValue === \"undefined\")\n return;\n\n ChangesetECAdaptor.setValue(out, idCol.accessString, idValue);\n\n const relClassIdCol = prop.columns.filter(($) => $.accessString.endsWith(\".RelECClassId\")).at(0);\n if (!relClassIdCol) {\n throw new Error(\"invalid map for nav property\");\n }\n\n const relClassIdValue = relClassIdCol.isVirtual ? prop.navigationRelationship?.classId : change[relClassIdCol.column];\n if (typeof relClassIdValue === \"undefined\")\n return;\n\n ChangesetECAdaptor.setValue(out, relClassIdCol.accessString, relClassIdValue);\n }\n /**\n * Transform sqlite change into EC change.\n * @param classMap classMap use to deserialize sqlite change into EC change.\n * @param change sqlite change from changeset.\n * @param table table definition of sqlite change provided.\n * @param out EC changeset that will be updated with properties.\n */\n private transform(classMap: IClassMap, change: SqliteChange, table: ITable, out: ChangedECInstance): void {\n // transform change row to instance\n for (const prop of classMap.properties) {\n if (prop.kind === \"PrimitiveArray\" || prop.kind === \"StructArray\") {\n // Arrays not supported\n continue;\n }\n if (prop.columns.filter((_) => _.isVirtual).length === prop.columns.length) {\n continue;\n }\n if (prop.kind === \"Navigation\") {\n this.transformNavigationProperty(prop, change, out);\n } else {\n for (const col of prop.columns) {\n if (col.table !== table.name)\n continue;\n\n const columnValue = change[col.column];\n if (typeof columnValue === \"undefined\")\n continue;\n\n if (columnValue !== null) {\n if (prop.primitiveType === \"DateTime\") {\n const dt = DateTime.fromJulianDay(columnValue, prop.dateTimeInfo?.dateTimeKind === \"Local\");\n ChangesetECAdaptor.setValue(out, col.accessString, dt.toISOString());\n continue;\n }\n if (prop.extendedTypeName === \"BeGuid\") {\n ChangesetECAdaptor.setValue(out, col.accessString, this.debugFlags.replaceGuidWithEllipsis ? \"...\" : ChangesetECAdaptor.convertBinaryToGuid(columnValue));\n continue;\n }\n if (prop.extendedTypeName === \"GeometryStream\") {\n ChangesetECAdaptor.setValue(out, col.accessString, this.debugFlags.replaceGeomWithEllipsis ? \"...\" : columnValue);\n continue;\n }\n if (prop.primitiveType === \"Binary\") {\n ChangesetECAdaptor.setValue(out, col.accessString, this.debugFlags.replaceBlobWithEllipsis ? \"...\" : columnValue);\n continue;\n }\n }\n ChangesetECAdaptor.setValue(out, col.accessString, columnValue);\n }\n }\n }\n }\n}\n"]}
|