@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
package/CHANGELOG.md CHANGED
@@ -1,6 +1,11 @@
1
1
  # Change Log - @itwin/core-backend
2
2
 
3
- This log was last generated on Wed, 02 Apr 2025 19:38:36 GMT and should not be manually modified.
3
+ This log was last generated on Thu, 10 Apr 2025 17:50:15 GMT and should not be manually modified.
4
+
5
+ ## 4.10.13
6
+ Thu, 10 Apr 2025 17:47:21 GMT
7
+
8
+ _Version update only_
4
9
 
5
10
  ## 4.10.12
6
11
  Wed, 02 Apr 2025 19:35:47 GMT
@@ -0,0 +1,103 @@
1
+ /** @packageDocumentation
2
+ * @module iModels
3
+ */
4
+ import { type CatalogIModel, IModelConnectionProps } from "@itwin/core-common";
5
+ import { IpcHandler } from "./IpcHost";
6
+ import { StandaloneDb } from "./IModelDb";
7
+ /** A [[StandaloneDb]] that provides read-only access to the contents of a [CatalogIModel]($common).
8
+ * @see [[CatalogDb.openReadonly]] to instantiate this type.
9
+ * @beta
10
+ */
11
+ export interface CatalogDb extends StandaloneDb {
12
+ /** Get the catalog's manifest. */
13
+ getManifest(): CatalogIModel.Manifest | undefined;
14
+ /** Get the catalog's version information. */
15
+ getVersion(): string;
16
+ /** Get the catalog's manifest and version. */
17
+ getInfo(): {
18
+ manifest?: CatalogIModel.Manifest;
19
+ version: string;
20
+ };
21
+ /** Returns true if the catalog was opened in read-write mode. */
22
+ isEditable(): this is EditableCatalogDb;
23
+ }
24
+ /** A writable [[CatalogDb]].
25
+ * @see [[CatalogDb.openEditable]] to instantiate this type.
26
+ * @beta
27
+ */
28
+ export interface EditableCatalogDb extends CatalogDb {
29
+ /** Update the contents of the catalog manifest. */
30
+ updateCatalogManifest(manifest: CatalogIModel.Manifest): void;
31
+ }
32
+ /** @beta */
33
+ export declare namespace CatalogDb {
34
+ /** Create a new [[BlobContainer]] to hold versions of a [[CatalogDb]].
35
+ * @returns The properties of the newly created container.
36
+ * @note creating new containers requires "admin" authorization.
37
+ */
38
+ function createNewContainer(args: CatalogIModel.CreateNewContainerArgs): Promise<CatalogIModel.NewContainerProps>;
39
+ /** Acquire the write lock for a [CatalogIModel]($common) container. Only one person may obtain the write lock at a time.
40
+ * You must obtain the lock before attempting to write to the container via functions like [[CatalogDb.openEditable]] and [[CatalogDb.createNewVersion]].
41
+ * @note This requires "write" authorization to the container
42
+ */
43
+ function acquireWriteLock(args: {
44
+ /** The id of the container */
45
+ containerId: string;
46
+ /**
47
+ * The name of the individual acquiring the lock. This will be shown to others who attempt to acquire the lock while it is held.
48
+ * It is also stored in the "lastEditedBy" field of the manifest of any new version edited while the lock is held.
49
+ */
50
+ username: string;
51
+ }): Promise<void>;
52
+ /** 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. */
53
+ function releaseWriteLock(args: {
54
+ /** The id of the container */
55
+ containerId: string;
56
+ /** If true, abandon all local changes before releasing the lock */
57
+ abandon?: true;
58
+ }): Promise<void>;
59
+ /** Open an [[EditableCatalogDb]] for write access.
60
+ * @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.
61
+ * @note The write lock must be held for this operation to succeed
62
+ */
63
+ function openEditable(args: CatalogIModel.OpenArgs): Promise<EditableCatalogDb>;
64
+ /** Open a [[CatalogDb]] for read-only access. */
65
+ function openReadonly(args: CatalogIModel.OpenArgs): Promise<CatalogDb>;
66
+ /**
67
+ * 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
68
+ * of the source CatalogIModel. Then, use [[CatalogDb.openEditable]] to modify the new version with new content.
69
+ * @note The write lock must be held for this operation to succeed
70
+ */
71
+ function createNewVersion(args: CatalogIModel.CreateNewVersionArgs): Promise<{
72
+ oldDb: CatalogIModel.NameAndVersion;
73
+ newDb: CatalogIModel.NameAndVersion;
74
+ }>;
75
+ }
76
+ /**
77
+ * Handler for Ipc access to CatalogIModels. Registered by NativeHost.
78
+ * @internal
79
+ */
80
+ export declare class CatalogIModelHandler extends IpcHandler implements CatalogIModel.IpcMethods {
81
+ get channelName(): CatalogIModel.IpcChannel;
82
+ createNewContainer(args: CatalogIModel.CreateNewContainerArgs): Promise<CatalogIModel.NewContainerProps>;
83
+ acquireWriteLock(args: {
84
+ containerId: string;
85
+ username: string;
86
+ }): Promise<void>;
87
+ releaseWriteLock(args: {
88
+ containerId: string;
89
+ abandon?: true;
90
+ }): Promise<void>;
91
+ openReadonly(args: CatalogIModel.OpenArgs): Promise<IModelConnectionProps>;
92
+ openEditable(args: CatalogIModel.OpenArgs): Promise<IModelConnectionProps>;
93
+ createNewVersion(args: CatalogIModel.CreateNewVersionArgs): Promise<{
94
+ oldDb: CatalogIModel.NameAndVersion;
95
+ newDb: CatalogIModel.NameAndVersion;
96
+ }>;
97
+ getInfo(key: string): Promise<{
98
+ manifest?: CatalogIModel.Manifest;
99
+ version: string;
100
+ }>;
101
+ updateCatalogManifest(key: string, manifest: CatalogIModel.Manifest): Promise<void>;
102
+ }
103
+ //# sourceMappingURL=CatalogDb.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CatalogDb.d.ts","sourceRoot":"","sources":["../../src/CatalogDb.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,271 @@
1
+ "use strict";
2
+ /*---------------------------------------------------------------------------------------------
3
+ * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
4
+ * See LICENSE.md in the project root for license terms and full copyright notice.
5
+ *--------------------------------------------------------------------------------------------*/
6
+ /** @packageDocumentation
7
+ * @module iModels
8
+ */
9
+ Object.defineProperty(exports, "__esModule", { value: true });
10
+ exports.CatalogIModelHandler = exports.CatalogDb = void 0;
11
+ const fs = require("fs");
12
+ const path_1 = require("path");
13
+ const CloudSqlite_1 = require("./CloudSqlite");
14
+ const IModelHost_1 = require("./IModelHost");
15
+ const core_common_1 = require("@itwin/core-common");
16
+ const IpcHost_1 = require("./IpcHost");
17
+ const IModelDb_1 = require("./IModelDb");
18
+ const core_bentley_1 = require("@itwin/core-bentley");
19
+ const Symbols_1 = require("./internal/Symbols");
20
+ const NativePlatform_1 = require("./internal/NativePlatform");
21
+ let readonlyCloudCache;
22
+ let writeableCloudCache;
23
+ const catalogManifestName = "CatalogManifest";
24
+ // we make a readonly CloudCache and a writeable CloudCache. That way the access token authorizations are distinct.
25
+ function makeCloudCache(arg, writeable) {
26
+ const cache = CloudSqlite_1.CloudSqlite.CloudCaches.getCache(arg);
27
+ // if the cache was just created, add the "catalog" members as hidden
28
+ if (undefined === cache.catalogContainers) {
29
+ CloudSqlite_1.CloudSqlite.addHiddenProperty(cache, "catalogContainers", new Map());
30
+ CloudSqlite_1.CloudSqlite.addHiddenProperty(cache, "writeable", writeable);
31
+ }
32
+ return cache;
33
+ }
34
+ // find an existing CloudContainer for accessing a CatalogIModel, or make a new one and connect it
35
+ async function getCatalogContainerObj(cache, containerId) {
36
+ const cloudContainer = cache.catalogContainers.get(containerId);
37
+ if (undefined !== cloudContainer)
38
+ return cloudContainer;
39
+ const accessLevel = cache.writeable ? "write" : "read";
40
+ const tokenProps = await CloudSqlite_1.CloudSqlite.getBlobService().requestToken({ containerId, accessLevel, userToken: await IModelHost_1.IModelHost.getAccessToken() });
41
+ const container = CloudSqlite_1.CloudSqlite.createCloudContainer({
42
+ accessLevel,
43
+ baseUri: tokenProps.baseUri,
44
+ containerId,
45
+ storageType: tokenProps.provider,
46
+ writeable: cache.writeable,
47
+ accessToken: tokenProps.token
48
+ });
49
+ cache.catalogContainers.set(containerId, container); // save the container in the map of ContainerIds so we can reuse them
50
+ container.connect(cache);
51
+ return container;
52
+ }
53
+ function getReadonlyCloudCache() { return readonlyCloudCache ??= makeCloudCache({ cacheName: "catalogs", cacheSize: "10G" }, false); }
54
+ ;
55
+ function getWritableCloudCache() { return writeableCloudCache ??= makeCloudCache({ cacheName: "writeableCatalogs", cacheSize: "10G" }, true); }
56
+ ;
57
+ async function getReadonlyContainer(containerId) { return getCatalogContainerObj(getReadonlyCloudCache(), containerId); }
58
+ ;
59
+ async function getWriteableContainer(containerId) { return getCatalogContainerObj(getWritableCloudCache(), containerId); }
60
+ ;
61
+ /** Throw an error if the write lock is not held for the supplied container */
62
+ function ensureLocked(container, reason) {
63
+ if (!container.hasWriteLock)
64
+ core_common_1.CloudSqliteError.throwError("write-lock-not-held", { message: `Write lock must be held to ${reason}` });
65
+ }
66
+ /** update the manifest in a CatalogIModel (calls `saveChanges`) */
67
+ function updateManifest(nativeDb, manifest) {
68
+ nativeDb.saveLocalValue(catalogManifestName, JSON.stringify(manifest));
69
+ nativeDb.saveChanges("update manifest");
70
+ }
71
+ function catalogDbNameWithDefault(dbName) {
72
+ return dbName ?? "catalog-db";
73
+ }
74
+ /** A StandaloneDb that holds a CatalogIModel */
75
+ class CatalogDbImpl extends IModelDb_1.StandaloneDb {
76
+ isEditable() {
77
+ return false;
78
+ }
79
+ getManifest() {
80
+ const manifestString = this[Symbols_1._nativeDb].queryLocalValue(catalogManifestName);
81
+ if (undefined === manifestString)
82
+ return undefined;
83
+ return JSON.parse(manifestString);
84
+ }
85
+ getVersion() {
86
+ return CloudSqlite_1.CloudSqlite.parseDbFileName(this[Symbols_1._nativeDb].getFilePath()).version;
87
+ }
88
+ getInfo() {
89
+ return { manifest: this.getManifest(), version: this.getVersion() };
90
+ }
91
+ }
92
+ /**
93
+ * A CatalogDb that permits editing.
94
+ * This class ensures that CatalogIModels never have a Txn table when they are published.
95
+ * It also automatically updates the `lastEditedBy` field in the CatalogManifest.
96
+ */
97
+ class EditableCatalogDbImpl extends CatalogDbImpl {
98
+ isEditable() {
99
+ return true;
100
+ }
101
+ updateCatalogManifest(manifest) {
102
+ updateManifest(this[Symbols_1._nativeDb], manifest);
103
+ }
104
+ // Make sure the txn table is deleted and update the manifest every time we close.
105
+ beforeClose() {
106
+ try {
107
+ const manifest = this.getManifest();
108
+ const container = this.cloudContainer;
109
+ if (container && manifest) {
110
+ manifest.lastEditedBy = CloudSqlite_1.CloudSqlite.getWriteLockHeldBy(container);
111
+ this.updateCatalogManifest(manifest);
112
+ }
113
+ // when saved, CatalogIModels should never have any Txns. If we wanted to create a changeset, we'd have to do it here.
114
+ this[Symbols_1._nativeDb].deleteAllTxns();
115
+ }
116
+ catch { } // ignore errors attempting to update
117
+ // might also want to vacuum here?
118
+ super.beforeClose();
119
+ }
120
+ }
121
+ function findCatalogByKey(key) {
122
+ return CatalogDbImpl.findByKey(key);
123
+ }
124
+ /** @beta */
125
+ var CatalogDb;
126
+ (function (CatalogDb) {
127
+ /** Create a new [[BlobContainer]] to hold versions of a [[CatalogDb]].
128
+ * @returns The properties of the newly created container.
129
+ * @note creating new containers requires "admin" authorization.
130
+ */
131
+ async function createNewContainer(args) {
132
+ const dbName = catalogDbNameWithDefault(args.dbName);
133
+ CloudSqlite_1.CloudSqlite.validateDbName(dbName);
134
+ CloudSqlite_1.CloudSqlite.validateDbVersion(args.version);
135
+ const tmpName = (0, path_1.join)(IModelHost_1.KnownLocations.tmpdir, `temp-${dbName}`);
136
+ try {
137
+ // make a copy of the file they supplied so we can modify its contents safely
138
+ fs.copyFileSync(args.localCatalogFile, tmpName);
139
+ const nativeDb = new NativePlatform_1.IModelNative.platform.DgnDb();
140
+ nativeDb.openIModel(tmpName, core_bentley_1.OpenMode.ReadWrite);
141
+ nativeDb.setITwinId(core_bentley_1.Guid.empty); // catalogs must be a StandaloneDb
142
+ nativeDb.setIModelId(core_bentley_1.Guid.createValue()); // make sure its iModelId is unique
143
+ updateManifest(nativeDb, args.manifest); // store the manifest inside the Catalog
144
+ nativeDb.deleteAllTxns(); // Catalogs should never have Txns (and, this must be empty before resetting BriefcaseId)
145
+ nativeDb.resetBriefcaseId(core_common_1.BriefcaseIdValue.Unassigned); // catalogs should always be unassigned
146
+ nativeDb.saveChanges(); // save change to briefcaseId
147
+ nativeDb.vacuum();
148
+ nativeDb.closeFile();
149
+ }
150
+ catch (e) {
151
+ core_common_1.CatalogError.throwError("invalid-seed-catalog", { message: "Illegal seed catalog", ...args, cause: e });
152
+ }
153
+ const userToken = await IModelHost_1.IModelHost.getAccessToken();
154
+ // create tne new container from the blob service, requires "admin" authorization
155
+ const cloudContainerProps = await CloudSqlite_1.CloudSqlite.getBlobService().create({ scope: { iTwinId: args.iTwinId }, metadata: { ...args.metadata, containerType: "CatalogIModel" }, userToken });
156
+ // now create a CloudSqlite container object to access it
157
+ const container = CloudSqlite_1.CloudSqlite.createCloudContainer({
158
+ accessToken: await CloudSqlite_1.CloudSqlite.requestToken(cloudContainerProps),
159
+ accessLevel: "admin",
160
+ writeable: true,
161
+ baseUri: cloudContainerProps.baseUri,
162
+ containerId: cloudContainerProps.containerId,
163
+ storageType: cloudContainerProps.provider,
164
+ });
165
+ // initialize the container for use by CloudSqlite
166
+ container.initializeContainer({ blockSize: 4 * 1024 * 1024 });
167
+ container.connect(getWritableCloudCache());
168
+ // upload the initial version of the Catalog
169
+ await CloudSqlite_1.CloudSqlite.withWriteLock({ user: "initialize", container }, async () => {
170
+ await CloudSqlite_1.CloudSqlite.uploadDb(container, { dbName: CloudSqlite_1.CloudSqlite.makeSemverName(dbName, args.version), localFileName: tmpName });
171
+ fs.unlinkSync(tmpName); // delete temporary copy of catalog
172
+ });
173
+ container.disconnect();
174
+ return cloudContainerProps;
175
+ }
176
+ CatalogDb.createNewContainer = createNewContainer;
177
+ /** Acquire the write lock for a [CatalogIModel]($common) container. Only one person may obtain the write lock at a time.
178
+ * You must obtain the lock before attempting to write to the container via functions like [[CatalogDb.openEditable]] and [[CatalogDb.createNewVersion]].
179
+ * @note This requires "write" authorization to the container
180
+ */
181
+ async function acquireWriteLock(args) {
182
+ const container = await getWriteableContainer(args.containerId);
183
+ return CloudSqlite_1.CloudSqlite.acquireWriteLock({ container, user: args.username });
184
+ }
185
+ CatalogDb.acquireWriteLock = acquireWriteLock;
186
+ /** 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. */
187
+ async function releaseWriteLock(args) {
188
+ const container = await getWriteableContainer(args.containerId);
189
+ if (args.abandon)
190
+ container.abandonChanges();
191
+ CloudSqlite_1.CloudSqlite.releaseWriteLock(container);
192
+ }
193
+ CatalogDb.releaseWriteLock = releaseWriteLock;
194
+ /** Open an [[EditableCatalogDb]] for write access.
195
+ * @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.
196
+ * @note The write lock must be held for this operation to succeed
197
+ */
198
+ async function openEditable(args) {
199
+ const dbName = catalogDbNameWithDefault(args.dbName);
200
+ if (undefined === args.containerId) // local file?
201
+ return EditableCatalogDbImpl.openFile(dbName, core_bentley_1.OpenMode.ReadWrite, args);
202
+ const container = await getWriteableContainer(args.containerId);
203
+ ensureLocked(container, "open a Catalog for editing"); // editing Catalogs requires the write lock
204
+ // look up the full name with version
205
+ const dbFullName = CloudSqlite_1.CloudSqlite.querySemverMatch({ container, dbName, version: args.version ?? "*" });
206
+ if (!CloudSqlite_1.CloudSqlite.isSemverEditable(dbFullName, container))
207
+ core_common_1.CloudSqliteError.throwError("already-published", { message: "Catalog has already been published and is not editable. Make a new version first.", ...args });
208
+ if (args.prefetch)
209
+ CloudSqlite_1.CloudSqlite.startCloudPrefetch(container, dbFullName);
210
+ return EditableCatalogDbImpl.openFile(dbFullName, core_bentley_1.OpenMode.ReadWrite, { container, ...args });
211
+ }
212
+ CatalogDb.openEditable = openEditable;
213
+ /** Open a [[CatalogDb]] for read-only access. */
214
+ async function openReadonly(args) {
215
+ const dbName = catalogDbNameWithDefault(args.dbName);
216
+ if (undefined === args.containerId) // local file?
217
+ return CatalogDbImpl.openFile(dbName, core_bentley_1.OpenMode.Readonly, args);
218
+ const container = await getReadonlyContainer(args.containerId);
219
+ if (args.syncWithCloud)
220
+ container.checkForChanges();
221
+ const dbFullName = CloudSqlite_1.CloudSqlite.querySemverMatch({ container, ...args, dbName });
222
+ if (args.prefetch)
223
+ CloudSqlite_1.CloudSqlite.startCloudPrefetch(container, dbFullName);
224
+ return CatalogDbImpl.openFile(dbFullName, core_bentley_1.OpenMode.Readonly, { container, ...args });
225
+ }
226
+ CatalogDb.openReadonly = openReadonly;
227
+ /**
228
+ * 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
229
+ * of the source CatalogIModel. Then, use [[CatalogDb.openEditable]] to modify the new version with new content.
230
+ * @note The write lock must be held for this operation to succeed
231
+ */
232
+ async function createNewVersion(args) {
233
+ const container = await getWriteableContainer(args.containerId);
234
+ ensureLocked(container, "create a new version");
235
+ return CloudSqlite_1.CloudSqlite.createNewDbVersion(container, { ...args, fromDb: { ...args.fromDb, dbName: catalogDbNameWithDefault(args.fromDb.dbName) } });
236
+ }
237
+ CatalogDb.createNewVersion = createNewVersion;
238
+ })(CatalogDb || (exports.CatalogDb = CatalogDb = {}));
239
+ /**
240
+ * Handler for Ipc access to CatalogIModels. Registered by NativeHost.
241
+ * @internal
242
+ */
243
+ class CatalogIModelHandler extends IpcHost_1.IpcHandler {
244
+ get channelName() { return "catalogIModel/ipc"; }
245
+ async createNewContainer(args) {
246
+ return CatalogDb.createNewContainer(args);
247
+ }
248
+ async acquireWriteLock(args) {
249
+ return CatalogDb.acquireWriteLock(args);
250
+ }
251
+ async releaseWriteLock(args) {
252
+ return CatalogDb.releaseWriteLock(args);
253
+ }
254
+ async openReadonly(args) {
255
+ return ((await CatalogDb.openReadonly(args)).getConnectionProps());
256
+ }
257
+ async openEditable(args) {
258
+ return (await CatalogDb.openEditable(args)).getConnectionProps();
259
+ }
260
+ async createNewVersion(args) {
261
+ return CatalogDb.createNewVersion(args);
262
+ }
263
+ async getInfo(key) {
264
+ return findCatalogByKey(key).getInfo();
265
+ }
266
+ async updateCatalogManifest(key, manifest) {
267
+ findCatalogByKey(key).updateCatalogManifest(manifest);
268
+ }
269
+ }
270
+ exports.CatalogIModelHandler = CatalogIModelHandler;
271
+ //# 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":"AAIA;;GAEG;AAMH,OAAO,EAAe,OAAO,EAAyB,UAAU,EAAgE,MAAM,qBAAqB,CAAC;AAC5J,OAAO,EACa,WAAW,EAAE,oBAAoB,EAAmD,YAAY,EAAE,aAAa,EAAE,kBAAkB,EACtJ,MAAM,oBAAoB,CAAC;AAI5B,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAG5C,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAElD,OAAO,EAAc,eAAe,EAAa,MAAM,oBAAoB,CAAC;AAI5E,gBAAgB;AAChB,MAAM,WAAW,cAAc;IAC7B,UAAU,CAAC,UAAU,EAAE,eAAe,GAAG,MAAM,CAAC;IAChD,YAAY,CAAC,QAAQ,EAAE,eAAe,GAAG,IAAI,CAAC;CAC/C;AAED;;;GAGG;AACH,MAAM,WAAW,eAAgB,SAAQ,QAAQ;IAC/C,QAAQ,CAAC,QAAQ,CAAC,EAAE,OAAO,CAAC;IAE5B,uCAAuC;IACvC,QAAQ,CAAC,OAAO,EAAE,UAAU,CAAC;IAE7B,uBAAuB;IACvB,QAAQ,CAAC,QAAQ,EAAE,UAAU,CAAC;IAE9B,mCAAmC;IACnC,QAAQ,CAAC,SAAS,EAAE,oBAAoB,CAAC;IAEzC,8IAA8I;IAC9I,QAAQ,CAAC,cAAc,CAAC,EAAE,OAAO,CAAC;IAElC,qHAAqH;IACrH,QAAQ,CAAC,qBAAqB,CAAC,EAAE,MAAM,CAAC;CACzC;AAED;;GAEG;AACH,oBAAY,cAAc;IACxB,yBAAyB;IACzB,QAAQ,IAAI;IACZ,sBAAsB;IACtB,KAAK,IAAI;CACV;AAED;;GAEG;AACH,MAAM,MAAM,gBAAgB,GAAG,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,KAAK,cAAc,CAAC;AAEjF;;GAEG;AACH,MAAM,WAAW,eAAe;IAC9B,sDAAsD;IACtD,SAAS,EAAE,aAAa,CAAC;IAEzB;;;OAGG;IACH,QAAQ,CAAC,UAAU,CAAC,EAAE,aAAa,CAAC,MAAM,CAAC,CAAC;IAE5C,oDAAoD;IACpD,QAAQ,CAAC,UAAU,EAAE,eAAe,CAAC;IAErC;;OAEG;IACH,QAAQ,CAAC,UAAU,CAAC,EAAE,gBAAgB,CAAC;CACxC;AAED,gBAAgB;AAChB,MAAM,WAAW,WAAW;IAC1B,OAAO,EAAE,eAAe,CAAC;IACzB,OAAO,CAAC,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;CACxB;AAED,gBAAgB;AAChB,qBAAa,SAAS;IACpB,OAAO,CAAC,MAAM,CAAC,OAAO,CAAkC;mBAEnC,OAAO;WAUd,YAAY,CAAC,QAAQ,EAAE,aAAa,GAAG,WAAW,GAAG,SAAS;WAIxD,QAAQ,CAAC,CAAC,EAAE,OAAO,EAAE,eAAe,EAAE,UAAU,EAAE,CAAC,GAAG,EAAE,WAAW,KAAK,OAAO,CAAC,CAAC,CAAC;CAUvG;AAED;;;EAGE;AACF,qBAAa,mBAAmB;IAC9B,gBAAuB,cAAc,iBAAiB;IACtD,OAAO,CAAC,MAAM,CAAC,WAAW,CAAC,CAAyB;IACpD,OAAO,CAAC,MAAM,CAAC,UAAU,CAAiD;IAE1E;;OAEG;IACH,OAAc,CAAC,eAAe,CAAC,CAAC,EAAE,cAAc,CAAC;WAGnC,SAAS,IAAI,YAAY;WASzB,OAAO,IAAI,IAAI;IAW7B,OAAO,CAAC,MAAM,KAAK,UAAU,GAU5B;IAED,qKAAqK;IACrK,OAAO,CAAC,MAAM,CAAC,qBAAqB;IAIpC,OAAO,CAAC,MAAM,CAAC,YAAY;WAkBP,MAAM,CAAC,UAAU,EAAE,eAAe,GAAG,OAAO,CAAC;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,WAAW,CAAC,cAAc,GAAG,SAAS,CAAA;KAAE,CAAC;IAmDvI,gBAAgB;mBACK,eAAe;IAgBpC;;;OAGG;WACiB,kBAAkB,CAAC,OAAO,EAAE,eAAe,GAAG,OAAO,CAAC,WAAW,CAAC;CAGvF;AAED,iBAAiB;AACjB,qBAAa,iBAAiB;IAC5B,gBAAuB,YAAY,gBAAqB,WAAW,KAAK,IAAI,EAAI;WAClE,MAAM,CAAC,UAAU,EAAE,eAAe;mBAE3B,UAAU;WAaX,wBAAwB,CAAC,OAAO,EAAE,eAAe;IAmDrE,uGAAuG;WACnF,kBAAkB,CAAC,OAAO,EAAE,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC;IAiB/E,6FAA6F;WAC/E,uBAAuB,CAAC,UAAU,EAAE,eAAe,EAAE,UAAU,EAAE,UAAU;IAyBzF,4DAA4D;WAC9C,gBAAgB,CAAC,UAAU,EAAE,eAAe,EAAE,QAAQ,EAAE,aAAa,GAAG,OAAO;WAmBzE,iBAAiB,CAAC,IAAI,EAAE,kBAAkB,GAAG,OAAO,CAAC,eAAe,CAAC;CAY1F"}
@@ -67,6 +67,10 @@ class V2CheckpointManager {
67
67
  static cloudCacheName = "Checkpoints";
68
68
  static _cloudCache;
69
69
  static containers = new Map();
70
+ /** used by HubMock
71
+ * @internal
72
+ */
73
+ static [Symbols_1._mockCheckpoint];
70
74
  static getFolder() {
71
75
  const cloudCachePath = path.join(BriefcaseManager_1.BriefcaseManager.cacheDir, V2CheckpointManager.cloudCacheName);
72
76
  if (!(IModelJsFs_1.IModelJsFs.existsSync(cloudCachePath))) {
@@ -116,6 +120,8 @@ class V2CheckpointManager {
116
120
  return container;
117
121
  }
118
122
  static async attach(checkpoint) {
123
+ if (this[Symbols_1._mockCheckpoint]) // used by HubMock
124
+ return { dbName: this[Symbols_1._mockCheckpoint].mockAttach(checkpoint), container: undefined };
119
125
  let v2props;
120
126
  try {
121
127
  v2props = await IModelHost_1.IModelHost[Symbols_1._hubAccess].queryV2Checkpoint(checkpoint);
@@ -163,14 +169,19 @@ class V2CheckpointManager {
163
169
  throw new core_common_1.IModelError(e.errorNumber, error);
164
170
  }
165
171
  }
172
+ /** @internal */
166
173
  static async performDownload(job) {
167
174
  const request = job.request;
168
- const v2props = await IModelHost_1.IModelHost[Symbols_1._hubAccess].queryV2Checkpoint({ ...request.checkpoint, allowPreceding: true });
169
- if (!v2props)
170
- throw new core_common_1.IModelError(core_bentley_1.IModelStatus.NotFound, "V2 checkpoint not found");
171
- CheckpointManager.onDownloadV2.raiseEvent(job);
172
- const container = CloudSqlite_1.CloudSqlite.createCloudContainer(this.toCloudContainerProps(v2props));
173
- await CloudSqlite_1.CloudSqlite.transferDb("download", container, { dbName: v2props.dbName, localFileName: request.localFile, onProgress: request.onProgress });
175
+ if (this[Symbols_1._mockCheckpoint])
176
+ this[Symbols_1._mockCheckpoint].mockDownload(request);
177
+ else {
178
+ const v2props = await IModelHost_1.IModelHost[Symbols_1._hubAccess].queryV2Checkpoint({ ...request.checkpoint, allowPreceding: true });
179
+ if (!v2props)
180
+ throw new core_common_1.IModelError(core_bentley_1.IModelStatus.NotFound, "V2 checkpoint not found");
181
+ CheckpointManager.onDownloadV2.raiseEvent(job);
182
+ const container = CloudSqlite_1.CloudSqlite.createCloudContainer(this.toCloudContainerProps(v2props));
183
+ await CloudSqlite_1.CloudSqlite.transferDb("download", container, { dbName: v2props.dbName, localFileName: request.localFile, onProgress: request.onProgress });
184
+ }
174
185
  return request.checkpoint.changeset.id;
175
186
  }
176
187
  /** Fully download a V2 checkpoint to a local file that can be used to create a briefcase or to work offline.
@@ -180,19 +191,6 @@ class V2CheckpointManager {
180
191
  static async downloadCheckpoint(request) {
181
192
  return Downloads.download(request, async (job) => this.performDownload(job));
182
193
  }
183
- /** @internal */
184
- static async [Symbols_1._getCheckpointDb](request) {
185
- const db = IModelDb_1.SnapshotDb.tryFindByKey(CheckpointManager.getKey(request.checkpoint));
186
- return (undefined !== db) ? db : Downloads.download(request, async (job) => this.downloadAndOpen(job));
187
- }
188
- static async downloadAndOpen(job) {
189
- const db = CheckpointManager.tryOpenLocalFile(job.request);
190
- if (db)
191
- return db;
192
- await this.performDownload(job);
193
- await CheckpointManager.updateToRequestedVersion(job.request);
194
- return CheckpointManager[Symbols_1._openCheckpoint](job.request.localFile, job.request.checkpoint);
195
- }
196
194
  }
197
195
  exports.V2CheckpointManager = V2CheckpointManager;
198
196
  /** @internal */
@@ -313,28 +311,6 @@ class CheckpointManager {
313
311
  IModelJsFs_1.IModelJsFs.removeSync(fileName);
314
312
  return isValid;
315
313
  }
316
- /** @internal */
317
- static [Symbols_1._openCheckpoint](fileName, checkpoint) {
318
- const snapshot = IModelDb_1.SnapshotDb.openFile(fileName, { key: this.getKey(checkpoint) });
319
- snapshot._iTwinId = checkpoint.iTwinId;
320
- return snapshot;
321
- }
322
- /** try to open an existing local file to satisfy a download request */
323
- static tryOpenLocalFile(request) {
324
- const checkpoint = request.checkpoint;
325
- if (this.verifyCheckpoint(checkpoint, request.localFile))
326
- return this[Symbols_1._openCheckpoint](request.localFile, checkpoint);
327
- // check a list of aliases for finding checkpoints downloaded to non-default locations (e.g. from older versions)
328
- if (request.aliasFiles) {
329
- for (const alias of request.aliasFiles) {
330
- if (this.verifyCheckpoint(checkpoint, alias)) {
331
- request.localFile = alias;
332
- return this[Symbols_1._openCheckpoint](alias, checkpoint);
333
- }
334
- }
335
- }
336
- return undefined;
337
- }
338
314
  static async toCheckpointProps(args) {
339
315
  const changeset = args.changeset ?? await IModelHost_1.IModelHost[Symbols_1._hubAccess].getLatestChangeset({ ...args, accessToken: await IModelHost_1.IModelHost.getAccessToken() });
340
316
  return {