@itwin/core-backend 5.0.0-dev.99 → 5.1.0-dev.1

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.
Files changed (162) hide show
  1. package/CHANGELOG.md +6 -1
  2. package/lib/cjs/CatalogDb.d.ts +103 -0
  3. package/lib/cjs/CatalogDb.d.ts.map +1 -0
  4. package/lib/cjs/CatalogDb.js +271 -0
  5. package/lib/cjs/CatalogDb.js.map +1 -0
  6. package/lib/cjs/CheckpointManager.d.ts +12 -10
  7. package/lib/cjs/CheckpointManager.d.ts.map +1 -1
  8. package/lib/cjs/CheckpointManager.js +17 -41
  9. package/lib/cjs/CheckpointManager.js.map +1 -1
  10. package/lib/cjs/CloudSqlite.d.ts +104 -20
  11. package/lib/cjs/CloudSqlite.d.ts.map +1 -1
  12. package/lib/cjs/CloudSqlite.js +157 -46
  13. package/lib/cjs/CloudSqlite.js.map +1 -1
  14. package/lib/cjs/ECSchemaXmlContext.d.ts +1 -1
  15. package/lib/cjs/ECSchemaXmlContext.js +1 -1
  16. package/lib/cjs/ECSchemaXmlContext.js.map +1 -1
  17. package/lib/cjs/Entity.d.ts +8 -4
  18. package/lib/cjs/Entity.d.ts.map +1 -1
  19. package/lib/cjs/Entity.js +3 -3
  20. package/lib/cjs/Entity.js.map +1 -1
  21. package/lib/cjs/IModelDb.d.ts +6 -1
  22. package/lib/cjs/IModelDb.d.ts.map +1 -1
  23. package/lib/cjs/IModelDb.js +14 -7
  24. package/lib/cjs/IModelDb.js.map +1 -1
  25. package/lib/cjs/IModelHost.d.ts +1 -1
  26. package/lib/cjs/IModelHost.js +1 -1
  27. package/lib/cjs/IModelHost.js.map +1 -1
  28. package/lib/cjs/NativeHost.d.ts.map +1 -1
  29. package/lib/cjs/NativeHost.js +4 -1
  30. package/lib/cjs/NativeHost.js.map +1 -1
  31. package/lib/cjs/SQLiteDb.d.ts.map +1 -1
  32. package/lib/cjs/SQLiteDb.js +5 -4
  33. package/lib/cjs/SQLiteDb.js.map +1 -1
  34. package/lib/cjs/ViewStore.d.ts.map +1 -1
  35. package/lib/cjs/ViewStore.js +27 -27
  36. package/lib/cjs/ViewStore.js.map +1 -1
  37. package/lib/cjs/core-backend.d.ts +1 -1
  38. package/lib/cjs/core-backend.d.ts.map +1 -1
  39. package/lib/cjs/core-backend.js +1 -1
  40. package/lib/cjs/core-backend.js.map +1 -1
  41. package/lib/cjs/internal/ChannelAdmin.js +4 -4
  42. package/lib/cjs/internal/ChannelAdmin.js.map +1 -1
  43. package/lib/cjs/{HubMock.d.ts → internal/HubMock.d.ts} +4 -5
  44. package/lib/cjs/internal/HubMock.d.ts.map +1 -0
  45. package/lib/cjs/{HubMock.js → internal/HubMock.js} +22 -11
  46. package/lib/cjs/internal/HubMock.js.map +1 -0
  47. package/lib/cjs/internal/Symbols.d.ts +1 -2
  48. package/lib/cjs/internal/Symbols.d.ts.map +1 -1
  49. package/lib/cjs/internal/Symbols.js +2 -3
  50. package/lib/cjs/internal/Symbols.js.map +1 -1
  51. package/lib/cjs/internal/workspace/WorkspaceImpl.d.ts +2 -16
  52. package/lib/cjs/internal/workspace/WorkspaceImpl.d.ts.map +1 -1
  53. package/lib/cjs/internal/workspace/WorkspaceImpl.js +35 -104
  54. package/lib/cjs/internal/workspace/WorkspaceImpl.js.map +1 -1
  55. package/lib/cjs/workspace/Workspace.d.ts +6 -13
  56. package/lib/cjs/workspace/Workspace.d.ts.map +1 -1
  57. package/lib/cjs/workspace/Workspace.js.map +1 -1
  58. package/lib/cjs/workspace/WorkspaceEditor.d.ts +2 -7
  59. package/lib/cjs/workspace/WorkspaceEditor.d.ts.map +1 -1
  60. package/lib/cjs/workspace/WorkspaceEditor.js.map +1 -1
  61. package/lib/esm/CatalogDb.d.ts +103 -0
  62. package/lib/esm/CatalogDb.d.ts.map +1 -0
  63. package/lib/esm/CatalogDb.js +267 -0
  64. package/lib/esm/CatalogDb.js.map +1 -0
  65. package/lib/esm/CheckpointManager.d.ts +12 -10
  66. package/lib/esm/CheckpointManager.d.ts.map +1 -1
  67. package/lib/esm/CheckpointManager.js +18 -42
  68. package/lib/esm/CheckpointManager.js.map +1 -1
  69. package/lib/esm/CloudSqlite.d.ts +104 -20
  70. package/lib/esm/CloudSqlite.d.ts.map +1 -1
  71. package/lib/esm/CloudSqlite.js +157 -46
  72. package/lib/esm/CloudSqlite.js.map +1 -1
  73. package/lib/esm/ECSchemaXmlContext.d.ts +1 -1
  74. package/lib/esm/ECSchemaXmlContext.js +1 -1
  75. package/lib/esm/ECSchemaXmlContext.js.map +1 -1
  76. package/lib/esm/Entity.d.ts +8 -4
  77. package/lib/esm/Entity.d.ts.map +1 -1
  78. package/lib/esm/Entity.js +3 -3
  79. package/lib/esm/Entity.js.map +1 -1
  80. package/lib/esm/IModelDb.d.ts +6 -1
  81. package/lib/esm/IModelDb.d.ts.map +1 -1
  82. package/lib/esm/IModelDb.js +14 -7
  83. package/lib/esm/IModelDb.js.map +1 -1
  84. package/lib/esm/IModelHost.d.ts +1 -1
  85. package/lib/esm/IModelHost.js +1 -1
  86. package/lib/esm/IModelHost.js.map +1 -1
  87. package/lib/esm/NativeHost.d.ts.map +1 -1
  88. package/lib/esm/NativeHost.js +4 -1
  89. package/lib/esm/NativeHost.js.map +1 -1
  90. package/lib/esm/SQLiteDb.d.ts.map +1 -1
  91. package/lib/esm/SQLiteDb.js +5 -4
  92. package/lib/esm/SQLiteDb.js.map +1 -1
  93. package/lib/esm/ViewStore.d.ts.map +1 -1
  94. package/lib/esm/ViewStore.js +28 -28
  95. package/lib/esm/ViewStore.js.map +1 -1
  96. package/lib/esm/core-backend.d.ts +1 -1
  97. package/lib/esm/core-backend.d.ts.map +1 -1
  98. package/lib/esm/core-backend.js +1 -1
  99. package/lib/esm/core-backend.js.map +1 -1
  100. package/lib/esm/internal/ChannelAdmin.js +5 -5
  101. package/lib/esm/internal/ChannelAdmin.js.map +1 -1
  102. package/lib/esm/{HubMock.d.ts → internal/HubMock.d.ts} +4 -5
  103. package/lib/esm/internal/HubMock.d.ts.map +1 -0
  104. package/lib/esm/{HubMock.js → internal/HubMock.js} +22 -11
  105. package/lib/esm/internal/HubMock.js.map +1 -0
  106. package/lib/esm/internal/Symbols.d.ts +1 -2
  107. package/lib/esm/internal/Symbols.d.ts.map +1 -1
  108. package/lib/esm/internal/Symbols.js +1 -2
  109. package/lib/esm/internal/Symbols.js.map +1 -1
  110. package/lib/esm/internal/workspace/WorkspaceImpl.d.ts +2 -16
  111. package/lib/esm/internal/workspace/WorkspaceImpl.d.ts.map +1 -1
  112. package/lib/esm/internal/workspace/WorkspaceImpl.js +36 -100
  113. package/lib/esm/internal/workspace/WorkspaceImpl.js.map +1 -1
  114. package/lib/esm/test/IModelTestUtils.d.ts +6 -2
  115. package/lib/esm/test/IModelTestUtils.d.ts.map +1 -1
  116. package/lib/esm/test/IModelTestUtils.js +27 -6
  117. package/lib/esm/test/IModelTestUtils.js.map +1 -1
  118. package/lib/esm/test/TestChangeSetUtility.js +1 -1
  119. package/lib/esm/test/TestChangeSetUtility.js.map +1 -1
  120. package/lib/esm/test/ecdb/ECSchemaXmlContext.test.js +4 -4
  121. package/lib/esm/test/ecdb/ECSchemaXmlContext.test.js.map +1 -1
  122. package/lib/esm/test/font/IModelDbFonts.test.js +1 -1
  123. package/lib/esm/test/font/IModelDbFonts.test.js.map +1 -1
  124. package/lib/esm/test/hubaccess/BriefcaseManager.test.js +1 -1
  125. package/lib/esm/test/hubaccess/BriefcaseManager.test.js.map +1 -1
  126. package/lib/esm/test/hubaccess/CheckpointManager.test.js +4 -3
  127. package/lib/esm/test/hubaccess/CheckpointManager.test.js.map +1 -1
  128. package/lib/esm/test/imodel/IModel.test.js +1 -1
  129. package/lib/esm/test/imodel/IModel.test.js.map +1 -1
  130. package/lib/esm/test/standalone/ChangeMerge.test.js +1 -1
  131. package/lib/esm/test/standalone/ChangeMerge.test.js.map +1 -1
  132. package/lib/esm/test/standalone/ChangesetReader.test.js +1 -1
  133. package/lib/esm/test/standalone/ChangesetReader.test.js.map +1 -1
  134. package/lib/esm/test/standalone/ExportGraphics.test.js +5 -40
  135. package/lib/esm/test/standalone/ExportGraphics.test.js.map +1 -1
  136. package/lib/esm/test/standalone/HubMock.test.js +1 -1
  137. package/lib/esm/test/standalone/HubMock.test.js.map +1 -1
  138. package/lib/esm/test/standalone/IModelWrite.test.js +1 -1
  139. package/lib/esm/test/standalone/IModelWrite.test.js.map +1 -1
  140. package/lib/esm/test/standalone/MergeConflict.test.js +1 -1
  141. package/lib/esm/test/standalone/MergeConflict.test.js.map +1 -1
  142. package/lib/esm/test/standalone/ServerBasedLocks.test.js +1 -1
  143. package/lib/esm/test/standalone/ServerBasedLocks.test.js.map +1 -1
  144. package/lib/esm/test/standalone/SnapshotDb.test.js +5 -4
  145. package/lib/esm/test/standalone/SnapshotDb.test.js.map +1 -1
  146. package/lib/esm/test/standalone/Workspace.test.js +4 -3
  147. package/lib/esm/test/standalone/Workspace.test.js.map +1 -1
  148. package/lib/esm/workspace/Workspace.d.ts +6 -13
  149. package/lib/esm/workspace/Workspace.d.ts.map +1 -1
  150. package/lib/esm/workspace/Workspace.js.map +1 -1
  151. package/lib/esm/workspace/WorkspaceEditor.d.ts +2 -7
  152. package/lib/esm/workspace/WorkspaceEditor.d.ts.map +1 -1
  153. package/lib/esm/workspace/WorkspaceEditor.js.map +1 -1
  154. package/package.json +12 -12
  155. package/lib/cjs/HubMock.d.ts.map +0 -1
  156. package/lib/cjs/HubMock.js.map +0 -1
  157. package/lib/esm/HubMock.d.ts.map +0 -1
  158. package/lib/esm/HubMock.js.map +0 -1
  159. package/lib/esm/test/CloudSqliteMock.d.ts +0 -37
  160. package/lib/esm/test/CloudSqliteMock.d.ts.map +0 -1
  161. package/lib/esm/test/CloudSqliteMock.js +0 -117
  162. package/lib/esm/test/CloudSqliteMock.js.map +0 -1
@@ -0,0 +1,267 @@
1
+ /*---------------------------------------------------------------------------------------------
2
+ * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
3
+ * See LICENSE.md in the project root for license terms and full copyright notice.
4
+ *--------------------------------------------------------------------------------------------*/
5
+ /** @packageDocumentation
6
+ * @module iModels
7
+ */
8
+ import * as fs from "fs";
9
+ import { join } from "path";
10
+ import { CloudSqlite } from "./CloudSqlite";
11
+ import { IModelHost, KnownLocations } from "./IModelHost";
12
+ import { BriefcaseIdValue, CatalogError, CloudSqliteError } from "@itwin/core-common";
13
+ import { IpcHandler } from "./IpcHost";
14
+ import { StandaloneDb } from "./IModelDb";
15
+ import { Guid, OpenMode } from "@itwin/core-bentley";
16
+ import { _nativeDb } from "./internal/Symbols";
17
+ import { IModelNative } from "./internal/NativePlatform";
18
+ let readonlyCloudCache;
19
+ let writeableCloudCache;
20
+ const catalogManifestName = "CatalogManifest";
21
+ // we make a readonly CloudCache and a writeable CloudCache. That way the access token authorizations are distinct.
22
+ function makeCloudCache(arg, writeable) {
23
+ const cache = CloudSqlite.CloudCaches.getCache(arg);
24
+ // if the cache was just created, add the "catalog" members as hidden
25
+ if (undefined === cache.catalogContainers) {
26
+ CloudSqlite.addHiddenProperty(cache, "catalogContainers", new Map());
27
+ CloudSqlite.addHiddenProperty(cache, "writeable", writeable);
28
+ }
29
+ return cache;
30
+ }
31
+ // find an existing CloudContainer for accessing a CatalogIModel, or make a new one and connect it
32
+ async function getCatalogContainerObj(cache, containerId) {
33
+ const cloudContainer = cache.catalogContainers.get(containerId);
34
+ if (undefined !== cloudContainer)
35
+ return cloudContainer;
36
+ const accessLevel = cache.writeable ? "write" : "read";
37
+ const tokenProps = await CloudSqlite.getBlobService().requestToken({ containerId, accessLevel, userToken: await IModelHost.getAccessToken() });
38
+ const container = CloudSqlite.createCloudContainer({
39
+ accessLevel,
40
+ baseUri: tokenProps.baseUri,
41
+ containerId,
42
+ storageType: tokenProps.provider,
43
+ writeable: cache.writeable,
44
+ accessToken: tokenProps.token
45
+ });
46
+ cache.catalogContainers.set(containerId, container); // save the container in the map of ContainerIds so we can reuse them
47
+ container.connect(cache);
48
+ return container;
49
+ }
50
+ function getReadonlyCloudCache() { return readonlyCloudCache ??= makeCloudCache({ cacheName: "catalogs", cacheSize: "10G" }, false); }
51
+ ;
52
+ function getWritableCloudCache() { return writeableCloudCache ??= makeCloudCache({ cacheName: "writeableCatalogs", cacheSize: "10G" }, true); }
53
+ ;
54
+ async function getReadonlyContainer(containerId) { return getCatalogContainerObj(getReadonlyCloudCache(), containerId); }
55
+ ;
56
+ async function getWriteableContainer(containerId) { return getCatalogContainerObj(getWritableCloudCache(), containerId); }
57
+ ;
58
+ /** Throw an error if the write lock is not held for the supplied container */
59
+ function ensureLocked(container, reason) {
60
+ if (!container.hasWriteLock)
61
+ CloudSqliteError.throwError("write-lock-not-held", { message: `Write lock must be held to ${reason}` });
62
+ }
63
+ /** update the manifest in a CatalogIModel (calls `saveChanges`) */
64
+ function updateManifest(nativeDb, manifest) {
65
+ nativeDb.saveLocalValue(catalogManifestName, JSON.stringify(manifest));
66
+ nativeDb.saveChanges("update manifest");
67
+ }
68
+ function catalogDbNameWithDefault(dbName) {
69
+ return dbName ?? "catalog-db";
70
+ }
71
+ /** A StandaloneDb that holds a CatalogIModel */
72
+ class CatalogDbImpl extends StandaloneDb {
73
+ isEditable() {
74
+ return false;
75
+ }
76
+ getManifest() {
77
+ const manifestString = this[_nativeDb].queryLocalValue(catalogManifestName);
78
+ if (undefined === manifestString)
79
+ return undefined;
80
+ return JSON.parse(manifestString);
81
+ }
82
+ getVersion() {
83
+ return CloudSqlite.parseDbFileName(this[_nativeDb].getFilePath()).version;
84
+ }
85
+ getInfo() {
86
+ return { manifest: this.getManifest(), version: this.getVersion() };
87
+ }
88
+ }
89
+ /**
90
+ * A CatalogDb that permits editing.
91
+ * This class ensures that CatalogIModels never have a Txn table when they are published.
92
+ * It also automatically updates the `lastEditedBy` field in the CatalogManifest.
93
+ */
94
+ class EditableCatalogDbImpl extends CatalogDbImpl {
95
+ isEditable() {
96
+ return true;
97
+ }
98
+ updateCatalogManifest(manifest) {
99
+ updateManifest(this[_nativeDb], manifest);
100
+ }
101
+ // Make sure the txn table is deleted and update the manifest every time we close.
102
+ beforeClose() {
103
+ try {
104
+ const manifest = this.getManifest();
105
+ const container = this.cloudContainer;
106
+ if (container && manifest) {
107
+ manifest.lastEditedBy = CloudSqlite.getWriteLockHeldBy(container);
108
+ this.updateCatalogManifest(manifest);
109
+ }
110
+ // when saved, CatalogIModels should never have any Txns. If we wanted to create a changeset, we'd have to do it here.
111
+ this[_nativeDb].deleteAllTxns();
112
+ }
113
+ catch { } // ignore errors attempting to update
114
+ // might also want to vacuum here?
115
+ super.beforeClose();
116
+ }
117
+ }
118
+ function findCatalogByKey(key) {
119
+ return CatalogDbImpl.findByKey(key);
120
+ }
121
+ /** @beta */
122
+ export var CatalogDb;
123
+ (function (CatalogDb) {
124
+ /** Create a new [[BlobContainer]] to hold versions of a [[CatalogDb]].
125
+ * @returns The properties of the newly created container.
126
+ * @note creating new containers requires "admin" authorization.
127
+ */
128
+ async function createNewContainer(args) {
129
+ const dbName = catalogDbNameWithDefault(args.dbName);
130
+ CloudSqlite.validateDbName(dbName);
131
+ CloudSqlite.validateDbVersion(args.version);
132
+ const tmpName = join(KnownLocations.tmpdir, `temp-${dbName}`);
133
+ try {
134
+ // make a copy of the file they supplied so we can modify its contents safely
135
+ fs.copyFileSync(args.localCatalogFile, tmpName);
136
+ const nativeDb = new IModelNative.platform.DgnDb();
137
+ nativeDb.openIModel(tmpName, OpenMode.ReadWrite);
138
+ nativeDb.setITwinId(Guid.empty); // catalogs must be a StandaloneDb
139
+ nativeDb.setIModelId(Guid.createValue()); // make sure its iModelId is unique
140
+ updateManifest(nativeDb, args.manifest); // store the manifest inside the Catalog
141
+ nativeDb.deleteAllTxns(); // Catalogs should never have Txns (and, this must be empty before resetting BriefcaseId)
142
+ nativeDb.resetBriefcaseId(BriefcaseIdValue.Unassigned); // catalogs should always be unassigned
143
+ nativeDb.saveChanges(); // save change to briefcaseId
144
+ nativeDb.vacuum();
145
+ nativeDb.closeFile();
146
+ }
147
+ catch (e) {
148
+ CatalogError.throwError("invalid-seed-catalog", { message: "Illegal seed catalog", ...args, cause: e });
149
+ }
150
+ const userToken = await IModelHost.getAccessToken();
151
+ // create tne new container from the blob service, requires "admin" authorization
152
+ const cloudContainerProps = await CloudSqlite.getBlobService().create({ scope: { iTwinId: args.iTwinId }, metadata: { ...args.metadata, containerType: "CatalogIModel" }, userToken });
153
+ // now create a CloudSqlite container object to access it
154
+ const container = CloudSqlite.createCloudContainer({
155
+ accessToken: await CloudSqlite.requestToken(cloudContainerProps),
156
+ accessLevel: "admin",
157
+ writeable: true,
158
+ baseUri: cloudContainerProps.baseUri,
159
+ containerId: cloudContainerProps.containerId,
160
+ storageType: cloudContainerProps.provider,
161
+ });
162
+ // initialize the container for use by CloudSqlite
163
+ container.initializeContainer({ blockSize: 4 * 1024 * 1024 });
164
+ container.connect(getWritableCloudCache());
165
+ // upload the initial version of the Catalog
166
+ await CloudSqlite.withWriteLock({ user: "initialize", container }, async () => {
167
+ await CloudSqlite.uploadDb(container, { dbName: CloudSqlite.makeSemverName(dbName, args.version), localFileName: tmpName });
168
+ fs.unlinkSync(tmpName); // delete temporary copy of catalog
169
+ });
170
+ container.disconnect();
171
+ return cloudContainerProps;
172
+ }
173
+ CatalogDb.createNewContainer = createNewContainer;
174
+ /** Acquire the write lock for a [CatalogIModel]($common) container. Only one person may obtain the write lock at a time.
175
+ * You must obtain the lock before attempting to write to the container via functions like [[CatalogDb.openEditable]] and [[CatalogDb.createNewVersion]].
176
+ * @note This requires "write" authorization to the container
177
+ */
178
+ async function acquireWriteLock(args) {
179
+ const container = await getWriteableContainer(args.containerId);
180
+ return CloudSqlite.acquireWriteLock({ container, user: args.username });
181
+ }
182
+ CatalogDb.acquireWriteLock = acquireWriteLock;
183
+ /** Release the write lock on a [CatalogIModel]($common) container. This uploads all changes made while the lock is held, so they become visible to other users. */
184
+ async function releaseWriteLock(args) {
185
+ const container = await getWriteableContainer(args.containerId);
186
+ if (args.abandon)
187
+ container.abandonChanges();
188
+ CloudSqlite.releaseWriteLock(container);
189
+ }
190
+ CatalogDb.releaseWriteLock = releaseWriteLock;
191
+ /** Open an [[EditableCatalogDb]] for write access.
192
+ * @note Once a version of a catalog iModel has been published (i.e. the write lock has been released), it is no longer editable, *unless* it is a prerelease version.
193
+ * @note The write lock must be held for this operation to succeed
194
+ */
195
+ async function openEditable(args) {
196
+ const dbName = catalogDbNameWithDefault(args.dbName);
197
+ if (undefined === args.containerId) // local file?
198
+ return EditableCatalogDbImpl.openFile(dbName, OpenMode.ReadWrite, args);
199
+ const container = await getWriteableContainer(args.containerId);
200
+ ensureLocked(container, "open a Catalog for editing"); // editing Catalogs requires the write lock
201
+ // look up the full name with version
202
+ const dbFullName = CloudSqlite.querySemverMatch({ container, dbName, version: args.version ?? "*" });
203
+ if (!CloudSqlite.isSemverEditable(dbFullName, container))
204
+ CloudSqliteError.throwError("already-published", { message: "Catalog has already been published and is not editable. Make a new version first.", ...args });
205
+ if (args.prefetch)
206
+ CloudSqlite.startCloudPrefetch(container, dbFullName);
207
+ return EditableCatalogDbImpl.openFile(dbFullName, OpenMode.ReadWrite, { container, ...args });
208
+ }
209
+ CatalogDb.openEditable = openEditable;
210
+ /** Open a [[CatalogDb]] for read-only access. */
211
+ async function openReadonly(args) {
212
+ const dbName = catalogDbNameWithDefault(args.dbName);
213
+ if (undefined === args.containerId) // local file?
214
+ return CatalogDbImpl.openFile(dbName, OpenMode.Readonly, args);
215
+ const container = await getReadonlyContainer(args.containerId);
216
+ if (args.syncWithCloud)
217
+ container.checkForChanges();
218
+ const dbFullName = CloudSqlite.querySemverMatch({ container, ...args, dbName });
219
+ if (args.prefetch)
220
+ CloudSqlite.startCloudPrefetch(container, dbFullName);
221
+ return CatalogDbImpl.openFile(dbFullName, OpenMode.Readonly, { container, ...args });
222
+ }
223
+ CatalogDb.openReadonly = openReadonly;
224
+ /**
225
+ * Create a new version of a [CatalogIModel]($common) as a copy of an existing version. Immediately after this operation, the new version will be an exact copy
226
+ * of the source CatalogIModel. Then, use [[CatalogDb.openEditable]] to modify the new version with new content.
227
+ * @note The write lock must be held for this operation to succeed
228
+ */
229
+ async function createNewVersion(args) {
230
+ const container = await getWriteableContainer(args.containerId);
231
+ ensureLocked(container, "create a new version");
232
+ return CloudSqlite.createNewDbVersion(container, { ...args, fromDb: { ...args.fromDb, dbName: catalogDbNameWithDefault(args.fromDb.dbName) } });
233
+ }
234
+ CatalogDb.createNewVersion = createNewVersion;
235
+ })(CatalogDb || (CatalogDb = {}));
236
+ /**
237
+ * Handler for Ipc access to CatalogIModels. Registered by NativeHost.
238
+ * @internal
239
+ */
240
+ export class CatalogIModelHandler extends IpcHandler {
241
+ get channelName() { return "catalogIModel/ipc"; }
242
+ async createNewContainer(args) {
243
+ return CatalogDb.createNewContainer(args);
244
+ }
245
+ async acquireWriteLock(args) {
246
+ return CatalogDb.acquireWriteLock(args);
247
+ }
248
+ async releaseWriteLock(args) {
249
+ return CatalogDb.releaseWriteLock(args);
250
+ }
251
+ async openReadonly(args) {
252
+ return ((await CatalogDb.openReadonly(args)).getConnectionProps());
253
+ }
254
+ async openEditable(args) {
255
+ return (await CatalogDb.openEditable(args)).getConnectionProps();
256
+ }
257
+ async createNewVersion(args) {
258
+ return CatalogDb.createNewVersion(args);
259
+ }
260
+ async getInfo(key) {
261
+ return findCatalogByKey(key).getInfo();
262
+ }
263
+ async updateCatalogManifest(key, manifest) {
264
+ findCatalogByKey(key).updateCatalogManifest(manifest);
265
+ }
266
+ }
267
+ //# sourceMappingURL=CatalogDb.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CatalogDb.js","sourceRoot":"","sources":["../../src/CatalogDb.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 * as fs from \"fs\";\nimport { join } from \"path\";\nimport { CloudSqlite } from \"./CloudSqlite\";\nimport { IModelHost, KnownLocations } from \"./IModelHost\";\nimport { BriefcaseIdValue, CatalogError, type CatalogIModel, CloudSqliteError, IModelConnectionProps } from \"@itwin/core-common\";\nimport { IpcHandler } from \"./IpcHost\";\nimport { StandaloneDb } from \"./IModelDb\";\nimport { Guid, OpenMode } from \"@itwin/core-bentley\";\nimport { _nativeDb } from \"./internal/Symbols\";\nimport { IModelNative } from \"./internal/NativePlatform\";\nimport { IModelJsNative } from \"@bentley/imodeljs-native\";\n\ninterface CatalogCloudCache extends CloudSqlite.CloudCache {\n writeable: boolean;\n catalogContainers: Map<string, CloudSqlite.CloudContainer>;\n}\n\nlet readonlyCloudCache: CatalogCloudCache | undefined;\nlet writeableCloudCache: CatalogCloudCache | undefined;\nconst catalogManifestName = \"CatalogManifest\";\n\n// we make a readonly CloudCache and a writeable CloudCache. That way the access token authorizations are distinct.\nfunction makeCloudCache(arg: CloudSqlite.CreateCloudCacheArg, writeable: boolean) {\n const cache = CloudSqlite.CloudCaches.getCache(arg) as CatalogCloudCache;\n // if the cache was just created, add the \"catalog\" members as hidden\n if (undefined === cache.catalogContainers) {\n CloudSqlite.addHiddenProperty(cache, \"catalogContainers\", new Map<string, CloudSqlite.CloudContainer>());\n CloudSqlite.addHiddenProperty(cache, \"writeable\", writeable);\n }\n return cache;\n}\n\n// find an existing CloudContainer for accessing a CatalogIModel, or make a new one and connect it\nasync function getCatalogContainerObj(cache: CatalogCloudCache, containerId: string): Promise<CloudSqlite.CloudContainer> {\n const cloudContainer = cache.catalogContainers.get(containerId);\n if (undefined !== cloudContainer)\n return cloudContainer;\n\n const accessLevel = cache.writeable ? \"write\" : \"read\";\n const tokenProps = await CloudSqlite.getBlobService().requestToken({ containerId, accessLevel, userToken: await IModelHost.getAccessToken() });\n const container = CloudSqlite.createCloudContainer({\n accessLevel,\n baseUri: tokenProps.baseUri,\n containerId,\n storageType: tokenProps.provider,\n writeable: cache.writeable,\n accessToken: tokenProps.token\n });\n cache.catalogContainers.set(containerId, container); // save the container in the map of ContainerIds so we can reuse them\n container.connect(cache);\n return container;\n}\n\nfunction getReadonlyCloudCache() { return readonlyCloudCache ??= makeCloudCache({ cacheName: \"catalogs\", cacheSize: \"10G\" }, false) };\nfunction getWritableCloudCache() { return writeableCloudCache ??= makeCloudCache({ cacheName: \"writeableCatalogs\", cacheSize: \"10G\" }, true) };\nasync function getReadonlyContainer(containerId: string) { return getCatalogContainerObj(getReadonlyCloudCache(), containerId) };\nasync function getWriteableContainer(containerId: string) { return getCatalogContainerObj(getWritableCloudCache(), containerId) };\n\n/** Throw an error if the write lock is not held for the supplied container */\nfunction ensureLocked(container: CloudSqlite.CloudContainer, reason: string) {\n if (!container.hasWriteLock)\n CloudSqliteError.throwError(\"write-lock-not-held\", { message: `Write lock must be held to ${reason}` });\n}\n/** update the manifest in a CatalogIModel (calls `saveChanges`) */\nfunction updateManifest(nativeDb: IModelJsNative.DgnDb, manifest: CatalogIModel.Manifest) {\n nativeDb.saveLocalValue(catalogManifestName, JSON.stringify(manifest));\n nativeDb.saveChanges(\"update manifest\");\n}\nfunction catalogDbNameWithDefault(dbName?: string): string {\n return dbName ?? \"catalog-db\";\n}\n\n/** A [[StandaloneDb]] that provides read-only access to the contents of a [CatalogIModel]($common).\n * @see [[CatalogDb.openReadonly]] to instantiate this type.\n * @beta\n */\nexport interface CatalogDb extends StandaloneDb {\n /** Get the catalog's manifest. */\n getManifest(): CatalogIModel.Manifest | undefined;\n /** Get the catalog's version information. */\n getVersion(): string;\n /** Get the catalog's manifest and version. */\n getInfo(): { manifest?: CatalogIModel.Manifest, version: string };\n /** Returns true if the catalog was opened in read-write mode. */\n isEditable(): this is EditableCatalogDb;\n}\n\n/** A writable [[CatalogDb]].\n * @see [[CatalogDb.openEditable]] to instantiate this type.\n * @beta\n */\nexport interface EditableCatalogDb extends CatalogDb {\n /** Update the contents of the catalog manifest. */\n updateCatalogManifest(manifest: CatalogIModel.Manifest): void;\n}\n\n/** A StandaloneDb that holds a CatalogIModel */\nclass CatalogDbImpl extends StandaloneDb implements CatalogDb {\n public isEditable(): this is EditableCatalogDb {\n return false;\n }\n\n public getManifest(): CatalogIModel.Manifest | undefined {\n const manifestString = this[_nativeDb].queryLocalValue(catalogManifestName);\n if (undefined === manifestString)\n return undefined;\n return JSON.parse(manifestString) as CatalogIModel.Manifest;\n }\n\n public getVersion(): string {\n return CloudSqlite.parseDbFileName(this[_nativeDb].getFilePath()).version;\n }\n\n public getInfo() {\n return { manifest: this.getManifest(), version: this.getVersion() };\n }\n}\n\n/**\n * A CatalogDb that permits editing.\n * This class ensures that CatalogIModels never have a Txn table when they are published.\n * It also automatically updates the `lastEditedBy` field in the CatalogManifest.\n */\nclass EditableCatalogDbImpl extends CatalogDbImpl implements EditableCatalogDb {\n public override isEditable(): this is EditableCatalogDb {\n return true;\n }\n\n public updateCatalogManifest(manifest: CatalogIModel.Manifest): void {\n updateManifest(this[_nativeDb], manifest);\n }\n\n // Make sure the txn table is deleted and update the manifest every time we close.\n public override beforeClose(): void {\n try {\n const manifest = this.getManifest();\n const container = this.cloudContainer;\n if (container && manifest) {\n manifest.lastEditedBy = CloudSqlite.getWriteLockHeldBy(container);\n this.updateCatalogManifest(manifest);\n }\n\n // when saved, CatalogIModels should never have any Txns. If we wanted to create a changeset, we'd have to do it here.\n this[_nativeDb].deleteAllTxns();\n } catch { } // ignore errors attempting to update\n\n // might also want to vacuum here?\n super.beforeClose();\n }\n}\n\nfunction findCatalogByKey(key: string): CatalogDbImpl & EditableCatalogDb {\n return CatalogDbImpl.findByKey(key) as CatalogDbImpl & EditableCatalogDb;\n}\n\n/** @beta */\nexport namespace CatalogDb {\n /** Create a new [[BlobContainer]] to hold versions of a [[CatalogDb]].\n * @returns The properties of the newly created container.\n * @note creating new containers requires \"admin\" authorization.\n */\n export async function createNewContainer(args: CatalogIModel.CreateNewContainerArgs): Promise<CatalogIModel.NewContainerProps> {\n const dbName = catalogDbNameWithDefault(args.dbName);\n CloudSqlite.validateDbName(dbName);\n CloudSqlite.validateDbVersion(args.version);\n\n const tmpName = join(KnownLocations.tmpdir, `temp-${dbName}`);\n try {\n // make a copy of the file they supplied so we can modify its contents safely\n fs.copyFileSync(args.localCatalogFile, tmpName);\n const nativeDb = new IModelNative.platform.DgnDb();\n nativeDb.openIModel(tmpName, OpenMode.ReadWrite);\n nativeDb.setITwinId(Guid.empty); // catalogs must be a StandaloneDb\n nativeDb.setIModelId(Guid.createValue()); // make sure its iModelId is unique\n updateManifest(nativeDb, args.manifest); // store the manifest inside the Catalog\n nativeDb.deleteAllTxns(); // Catalogs should never have Txns (and, this must be empty before resetting BriefcaseId)\n nativeDb.resetBriefcaseId(BriefcaseIdValue.Unassigned); // catalogs should always be unassigned\n nativeDb.saveChanges(); // save change to briefcaseId\n nativeDb.vacuum();\n nativeDb.closeFile();\n } catch (e: unknown) {\n CatalogError.throwError(\"invalid-seed-catalog\", { message: \"Illegal seed catalog\", ...args, cause: e });\n }\n\n const userToken = await IModelHost.getAccessToken();\n // create tne new container from the blob service, requires \"admin\" authorization\n const cloudContainerProps = await CloudSqlite.getBlobService().create({ scope: { iTwinId: args.iTwinId }, metadata: { ...args.metadata, containerType: \"CatalogIModel\" }, userToken });\n\n // now create a CloudSqlite container object to access it\n const container = CloudSqlite.createCloudContainer({\n accessToken: await CloudSqlite.requestToken(cloudContainerProps),\n accessLevel: \"admin\",\n writeable: true,\n baseUri: cloudContainerProps.baseUri,\n containerId: cloudContainerProps.containerId,\n storageType: cloudContainerProps.provider,\n });\n\n // initialize the container for use by CloudSqlite\n container.initializeContainer({ blockSize: 4 * 1024 * 1024 });\n container.connect(getWritableCloudCache());\n\n // upload the initial version of the Catalog\n await CloudSqlite.withWriteLock({ user: \"initialize\", container }, async () => {\n await CloudSqlite.uploadDb(container, { dbName: CloudSqlite.makeSemverName(dbName, args.version), localFileName: tmpName });\n fs.unlinkSync(tmpName); // delete temporary copy of catalog\n });\n container.disconnect();\n return cloudContainerProps;\n }\n\n /** Acquire the write lock for a [CatalogIModel]($common) container. Only one person may obtain the write lock at a time.\n * You must obtain the lock before attempting to write to the container via functions like [[CatalogDb.openEditable]] and [[CatalogDb.createNewVersion]].\n * @note This requires \"write\" authorization to the container\n */\n export async function acquireWriteLock(args: {\n /** The id of the container */\n containerId: string,\n /**\n * The name of the individual acquiring the lock. This will be shown to others who attempt to acquire the lock while it is held.\n * It is also stored in the \"lastEditedBy\" field of the manifest of any new version edited while the lock is held.\n */\n username: string;\n }): Promise<void> {\n const container = await getWriteableContainer(args.containerId);\n return CloudSqlite.acquireWriteLock({ container, user: args.username });\n }\n\n /** Release the write lock on a [CatalogIModel]($common) container. This uploads all changes made while the lock is held, so they become visible to other users. */\n export async function releaseWriteLock(args: {\n /** The id of the container */\n containerId: string,\n /** If true, abandon all local changes before releasing the lock */\n abandon?: true\n }): Promise<void> {\n const container = await getWriteableContainer(args.containerId);\n if (args.abandon)\n container.abandonChanges();\n CloudSqlite.releaseWriteLock(container);\n }\n\n /** Open an [[EditableCatalogDb]] for write access.\n * @note Once a version of a catalog iModel has been published (i.e. the write lock has been released), it is no longer editable, *unless* it is a prerelease version.\n * @note The write lock must be held for this operation to succeed\n */\n export async function openEditable(args: CatalogIModel.OpenArgs): Promise<EditableCatalogDb> {\n const dbName = catalogDbNameWithDefault(args.dbName);\n if (undefined === args.containerId) // local file?\n return EditableCatalogDbImpl.openFile(dbName, OpenMode.ReadWrite, args) as EditableCatalogDbImpl;\n\n const container = await getWriteableContainer(args.containerId);\n ensureLocked(container, \"open a Catalog for editing\"); // editing Catalogs requires the write lock\n\n // look up the full name with version\n const dbFullName = CloudSqlite.querySemverMatch({ container, dbName, version: args.version ?? \"*\" });\n if (!CloudSqlite.isSemverEditable(dbFullName, container))\n CloudSqliteError.throwError(\"already-published\", { message: \"Catalog has already been published and is not editable. Make a new version first.\", ...args })\n\n if (args.prefetch)\n CloudSqlite.startCloudPrefetch(container, dbFullName);\n\n return EditableCatalogDbImpl.openFile(dbFullName, OpenMode.ReadWrite, { container, ...args }) as EditableCatalogDbImpl;\n }\n\n /** Open a [[CatalogDb]] for read-only access. */\n export async function openReadonly(args: CatalogIModel.OpenArgs): Promise<CatalogDb> {\n const dbName = catalogDbNameWithDefault(args.dbName);\n if (undefined === args.containerId) // local file?\n return CatalogDbImpl.openFile(dbName, OpenMode.Readonly, args) as CatalogDbImpl;\n\n const container = await getReadonlyContainer(args.containerId);\n if (args.syncWithCloud)\n container.checkForChanges();\n\n const dbFullName = CloudSqlite.querySemverMatch({ container, ...args, dbName });\n if (args.prefetch)\n CloudSqlite.startCloudPrefetch(container, dbFullName);\n\n return CatalogDbImpl.openFile(dbFullName, OpenMode.Readonly, { container, ...args }) as CatalogDbImpl;\n }\n\n /**\n * Create a new version of a [CatalogIModel]($common) as a copy of an existing version. Immediately after this operation, the new version will be an exact copy\n * of the source CatalogIModel. Then, use [[CatalogDb.openEditable]] to modify the new version with new content.\n * @note The write lock must be held for this operation to succeed\n */\n export async function createNewVersion(args: CatalogIModel.CreateNewVersionArgs): Promise<{ oldDb: CatalogIModel.NameAndVersion; newDb: CatalogIModel.NameAndVersion; }> {\n const container = await getWriteableContainer(args.containerId);\n ensureLocked(container, \"create a new version\");\n return CloudSqlite.createNewDbVersion(container, { ...args, fromDb: { ...args.fromDb, dbName: catalogDbNameWithDefault(args.fromDb.dbName) } });\n }\n}\n\n/**\n * Handler for Ipc access to CatalogIModels. Registered by NativeHost.\n * @internal\n */\nexport class CatalogIModelHandler extends IpcHandler implements CatalogIModel.IpcMethods {\n public get channelName(): CatalogIModel.IpcChannel { return \"catalogIModel/ipc\"; }\n\n public async createNewContainer(args: CatalogIModel.CreateNewContainerArgs): Promise<CatalogIModel.NewContainerProps> {\n return CatalogDb.createNewContainer(args);\n }\n public async acquireWriteLock(args: { containerId: string, username: string; }): Promise<void> {\n return CatalogDb.acquireWriteLock(args);\n }\n public async releaseWriteLock(args: { containerId: string, abandon?: true; }): Promise<void> {\n return CatalogDb.releaseWriteLock(args);\n }\n public async openReadonly(args: CatalogIModel.OpenArgs): Promise<IModelConnectionProps> {\n return ((await CatalogDb.openReadonly(args)).getConnectionProps());\n }\n public async openEditable(args: CatalogIModel.OpenArgs): Promise<IModelConnectionProps> {\n return (await CatalogDb.openEditable(args)).getConnectionProps();\n }\n public async createNewVersion(args: CatalogIModel.CreateNewVersionArgs): Promise<{ oldDb: CatalogIModel.NameAndVersion; newDb: CatalogIModel.NameAndVersion; }> {\n return CatalogDb.createNewVersion(args);\n }\n public async getInfo(key: string): Promise<{ manifest?: CatalogIModel.Manifest, version: string }> {\n return findCatalogByKey(key).getInfo();\n }\n public async updateCatalogManifest(key: string, manifest: CatalogIModel.Manifest): Promise<void> {\n findCatalogByKey(key).updateCatalogManifest(manifest);\n }\n}\n"]}
@@ -3,10 +3,14 @@
3
3
  */
4
4
  import { BeEvent, GuidString } from "@itwin/core-bentley";
5
5
  import { ChangesetId, ChangesetIdWithIndex, LocalDirName, LocalFileName, OpenCheckpointArgs } from "@itwin/core-common";
6
- import { V2CheckpointAccessProps } from "./BackendHubAccess";
7
6
  import { CloudSqlite } from "./CloudSqlite";
8
7
  import { SnapshotDb, TokenArg } from "./IModelDb";
9
- import { _getCheckpointDb, _openCheckpoint } from "./internal/Symbols";
8
+ import { _mockCheckpoint } from "./internal/Symbols";
9
+ /** @internal */
10
+ export interface MockCheckpoint {
11
+ mockAttach(checkpoint: CheckpointProps): string;
12
+ mockDownload(_request: DownloadRequest): void;
13
+ }
10
14
  /**
11
15
  * Properties of a checkpoint
12
16
  * @public
@@ -75,25 +79,27 @@ export declare class V2CheckpointManager {
75
79
  static readonly cloudCacheName = "Checkpoints";
76
80
  private static _cloudCache?;
77
81
  private static containers;
82
+ /** used by HubMock
83
+ * @internal
84
+ */
85
+ static [_mockCheckpoint]?: MockCheckpoint;
78
86
  static getFolder(): LocalDirName;
79
87
  static cleanup(): void;
80
88
  private static get cloudCache();
81
89
  /** Member names differ slightly between the V2Checkpoint api and the CloudSqlite api. Add aliases `accessName` for `accountName` and `accessToken` for `sasToken` */
82
90
  private static toCloudContainerProps;
83
- static getContainer(v2Props: V2CheckpointAccessProps, checkpoint: CheckpointProps): CloudSqlite.CloudContainer;
91
+ private static getContainer;
84
92
  static attach(checkpoint: CheckpointProps): Promise<{
85
93
  dbName: string;
86
94
  container: CloudSqlite.CloudContainer | undefined;
87
95
  }>;
96
+ /** @internal */
88
97
  private static performDownload;
89
98
  /** Fully download a V2 checkpoint to a local file that can be used to create a briefcase or to work offline.
90
99
  * @returns a Promise that is resolved when the download completes with the changesetId of the downloaded checkpoint (which will
91
100
  * be the same as the requested changesetId or the most recent checkpoint before it.)
92
101
  */
93
102
  static downloadCheckpoint(request: DownloadRequest): Promise<ChangesetId>;
94
- /** @internal */
95
- static [_getCheckpointDb](request: DownloadRequest): Promise<SnapshotDb>;
96
- private static downloadAndOpen;
97
103
  }
98
104
  /** @internal */
99
105
  export declare class CheckpointManager {
@@ -107,10 +113,6 @@ export declare class CheckpointManager {
107
113
  static validateCheckpointGuids(checkpoint: CheckpointProps, snapshotDb: SnapshotDb): void;
108
114
  /** @returns true if the file is the checkpoint requested */
109
115
  static verifyCheckpoint(checkpoint: CheckpointProps, fileName: LocalFileName): boolean;
110
- /** @internal */
111
- static [_openCheckpoint](fileName: LocalFileName, checkpoint: CheckpointProps): SnapshotDb;
112
- /** try to open an existing local file to satisfy a download request */
113
- static tryOpenLocalFile(request: DownloadRequest): SnapshotDb | undefined;
114
116
  static toCheckpointProps(args: OpenCheckpointArgs): Promise<CheckpointProps>;
115
117
  }
116
118
  //# sourceMappingURL=CheckpointManager.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"CheckpointManager.d.ts","sourceRoot":"","sources":["../../src/CheckpointManager.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"CheckpointManager.d.ts","sourceRoot":"","sources":["../../src/CheckpointManager.ts"],"names":[],"mappings":"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"}
@@ -17,7 +17,7 @@ import { IModelHost } from "./IModelHost";
17
17
  import { IModelJsFs } from "./IModelJsFs";
18
18
  import { SnapshotDb } from "./IModelDb";
19
19
  import { IModelNative } from "./internal/NativePlatform";
20
- import { _getCheckpointDb, _hubAccess, _nativeDb, _openCheckpoint } from "./internal/Symbols";
20
+ import { _hubAccess, _mockCheckpoint, _nativeDb } from "./internal/Symbols";
21
21
  const loggerCategory = BackendLoggerCategory.IModelDb;
22
22
  /** Return value from [[ProgressFunction]].
23
23
  * @public
@@ -63,6 +63,10 @@ export class V2CheckpointManager {
63
63
  static cloudCacheName = "Checkpoints";
64
64
  static _cloudCache;
65
65
  static containers = new Map();
66
+ /** used by HubMock
67
+ * @internal
68
+ */
69
+ static [_mockCheckpoint];
66
70
  static getFolder() {
67
71
  const cloudCachePath = path.join(BriefcaseManager.cacheDir, V2CheckpointManager.cloudCacheName);
68
72
  if (!(IModelJsFs.existsSync(cloudCachePath))) {
@@ -112,6 +116,8 @@ export class V2CheckpointManager {
112
116
  return container;
113
117
  }
114
118
  static async attach(checkpoint) {
119
+ if (this[_mockCheckpoint]) // used by HubMock
120
+ return { dbName: this[_mockCheckpoint].mockAttach(checkpoint), container: undefined };
115
121
  let v2props;
116
122
  try {
117
123
  v2props = await IModelHost[_hubAccess].queryV2Checkpoint(checkpoint);
@@ -159,14 +165,19 @@ export class V2CheckpointManager {
159
165
  throw new IModelError(e.errorNumber, error);
160
166
  }
161
167
  }
168
+ /** @internal */
162
169
  static async performDownload(job) {
163
170
  const request = job.request;
164
- const v2props = await IModelHost[_hubAccess].queryV2Checkpoint({ ...request.checkpoint, allowPreceding: true });
165
- if (!v2props)
166
- throw new IModelError(IModelStatus.NotFound, "V2 checkpoint not found");
167
- CheckpointManager.onDownloadV2.raiseEvent(job);
168
- const container = CloudSqlite.createCloudContainer(this.toCloudContainerProps(v2props));
169
- await CloudSqlite.transferDb("download", container, { dbName: v2props.dbName, localFileName: request.localFile, onProgress: request.onProgress });
171
+ if (this[_mockCheckpoint])
172
+ this[_mockCheckpoint].mockDownload(request);
173
+ else {
174
+ const v2props = await IModelHost[_hubAccess].queryV2Checkpoint({ ...request.checkpoint, allowPreceding: true });
175
+ if (!v2props)
176
+ throw new IModelError(IModelStatus.NotFound, "V2 checkpoint not found");
177
+ CheckpointManager.onDownloadV2.raiseEvent(job);
178
+ const container = CloudSqlite.createCloudContainer(this.toCloudContainerProps(v2props));
179
+ await CloudSqlite.transferDb("download", container, { dbName: v2props.dbName, localFileName: request.localFile, onProgress: request.onProgress });
180
+ }
170
181
  return request.checkpoint.changeset.id;
171
182
  }
172
183
  /** Fully download a V2 checkpoint to a local file that can be used to create a briefcase or to work offline.
@@ -176,19 +187,6 @@ export class V2CheckpointManager {
176
187
  static async downloadCheckpoint(request) {
177
188
  return Downloads.download(request, async (job) => this.performDownload(job));
178
189
  }
179
- /** @internal */
180
- static async [_getCheckpointDb](request) {
181
- const db = SnapshotDb.tryFindByKey(CheckpointManager.getKey(request.checkpoint));
182
- return (undefined !== db) ? db : Downloads.download(request, async (job) => this.downloadAndOpen(job));
183
- }
184
- static async downloadAndOpen(job) {
185
- const db = CheckpointManager.tryOpenLocalFile(job.request);
186
- if (db)
187
- return db;
188
- await this.performDownload(job);
189
- await CheckpointManager.updateToRequestedVersion(job.request);
190
- return CheckpointManager[_openCheckpoint](job.request.localFile, job.request.checkpoint);
191
- }
192
190
  }
193
191
  /** @internal */
194
192
  export class CheckpointManager {
@@ -308,28 +306,6 @@ export class CheckpointManager {
308
306
  IModelJsFs.removeSync(fileName);
309
307
  return isValid;
310
308
  }
311
- /** @internal */
312
- static [_openCheckpoint](fileName, checkpoint) {
313
- const snapshot = SnapshotDb.openFile(fileName, { key: this.getKey(checkpoint) });
314
- snapshot._iTwinId = checkpoint.iTwinId;
315
- return snapshot;
316
- }
317
- /** try to open an existing local file to satisfy a download request */
318
- static tryOpenLocalFile(request) {
319
- const checkpoint = request.checkpoint;
320
- if (this.verifyCheckpoint(checkpoint, request.localFile))
321
- return this[_openCheckpoint](request.localFile, checkpoint);
322
- // check a list of aliases for finding checkpoints downloaded to non-default locations (e.g. from older versions)
323
- if (request.aliasFiles) {
324
- for (const alias of request.aliasFiles) {
325
- if (this.verifyCheckpoint(checkpoint, alias)) {
326
- request.localFile = alias;
327
- return this[_openCheckpoint](alias, checkpoint);
328
- }
329
- }
330
- }
331
- return undefined;
332
- }
333
309
  static async toCheckpointProps(args) {
334
310
  const changeset = args.changeset ?? await IModelHost[_hubAccess].getLatestChangeset({ ...args, accessToken: await IModelHost.getAccessToken() });
335
311
  return {