@dxos/migrations 0.8.4-main.dedc0f3 → 0.8.4-main.dfabb4ec29
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +2 -2
- package/dist/lib/browser/index.mjs +71 -135
- package/dist/lib/browser/index.mjs.map +3 -3
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/node-esm/index.mjs +71 -135
- package/dist/lib/node-esm/index.mjs.map +3 -3
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/types/src/migration-builder.d.ts +4 -4
- package/dist/types/src/migration-builder.d.ts.map +1 -1
- package/dist/types/src/migrations.d.ts +2 -1
- package/dist/types/src/migrations.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +18 -16
- package/src/migration-builder.ts +32 -31
- package/src/migrations.test.ts +25 -17
- package/src/migrations.ts +14 -6
|
@@ -1,27 +1,28 @@
|
|
|
1
1
|
import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
|
|
2
2
|
|
|
3
3
|
// src/migration-builder.ts
|
|
4
|
-
import { next as
|
|
4
|
+
import { next as A } from "@automerge/automerge";
|
|
5
5
|
import { CreateEpochRequest } from "@dxos/client/halo";
|
|
6
6
|
import { ObjectCore, migrateDocument } from "@dxos/echo-db";
|
|
7
|
-
import {
|
|
8
|
-
import {
|
|
7
|
+
import { EncodedReference, SpaceDocVersion } from "@dxos/echo-protocol";
|
|
8
|
+
import { getSchemaDXN } from "@dxos/echo/internal";
|
|
9
9
|
import { invariant } from "@dxos/invariant";
|
|
10
|
-
|
|
11
|
-
if (key in obj) {
|
|
12
|
-
Object.defineProperty(obj, key, {
|
|
13
|
-
value,
|
|
14
|
-
enumerable: true,
|
|
15
|
-
configurable: true,
|
|
16
|
-
writable: true
|
|
17
|
-
});
|
|
18
|
-
} else {
|
|
19
|
-
obj[key] = value;
|
|
20
|
-
}
|
|
21
|
-
return obj;
|
|
22
|
-
}
|
|
10
|
+
import { DXN } from "@dxos/keys";
|
|
23
11
|
var __dxlog_file = "/__w/dxos/dxos/packages/sdk/migrations/src/migration-builder.ts";
|
|
24
12
|
var MigrationBuilder = class {
|
|
13
|
+
_space;
|
|
14
|
+
_repo;
|
|
15
|
+
_rootDoc;
|
|
16
|
+
// echoId -> automergeUrl
|
|
17
|
+
_newLinks = {};
|
|
18
|
+
_flushIds = [];
|
|
19
|
+
_deleteObjects = [];
|
|
20
|
+
_newRoot = void 0;
|
|
21
|
+
constructor(_space) {
|
|
22
|
+
this._space = _space;
|
|
23
|
+
this._repo = this._space.internal.db.coreDatabase._repo;
|
|
24
|
+
this._rootDoc = this._space.internal.db.coreDatabase._automergeDocLoader.getSpaceRootDocHandle().doc();
|
|
25
|
+
}
|
|
25
26
|
async findObject(id) {
|
|
26
27
|
const documentId = (this._rootDoc.links?.[id] || this._newLinks[id])?.toString();
|
|
27
28
|
const docHandle = documentId && this._repo.find(documentId);
|
|
@@ -39,15 +40,7 @@ var MigrationBuilder = class {
|
|
|
39
40
|
}
|
|
40
41
|
const { schema, props } = await migrate(objectStructure);
|
|
41
42
|
const oldHandle = await this._findObjectContainingHandle(id);
|
|
42
|
-
invariant(oldHandle, void 0, {
|
|
43
|
-
F: __dxlog_file,
|
|
44
|
-
L: 84,
|
|
45
|
-
S: this,
|
|
46
|
-
A: [
|
|
47
|
-
"oldHandle",
|
|
48
|
-
""
|
|
49
|
-
]
|
|
50
|
-
});
|
|
43
|
+
invariant(oldHandle, void 0, { "~LogMeta": "~LogMeta", F: __dxlog_file, L: 59, S: this, A: ["oldHandle", ""] });
|
|
51
44
|
const newState = {
|
|
52
45
|
version: SpaceDocVersion.CURRENT,
|
|
53
46
|
access: {
|
|
@@ -56,7 +49,7 @@ var MigrationBuilder = class {
|
|
|
56
49
|
objects: {
|
|
57
50
|
[id]: {
|
|
58
51
|
system: {
|
|
59
|
-
type:
|
|
52
|
+
type: EncodedReference.fromDXN(getSchemaDXN(schema))
|
|
60
53
|
},
|
|
61
54
|
data: props,
|
|
62
55
|
meta: {
|
|
@@ -66,59 +59,47 @@ var MigrationBuilder = class {
|
|
|
66
59
|
}
|
|
67
60
|
};
|
|
68
61
|
const migratedDoc = migrateDocument(oldHandle.doc(), newState);
|
|
69
|
-
const newHandle = this._repo.import(
|
|
62
|
+
const newHandle = this._repo.import(A.save(migratedDoc));
|
|
63
|
+
await newHandle.whenReady();
|
|
64
|
+
invariant(newHandle.url, "Migrated document URL not available after whenReady", { "~LogMeta": "~LogMeta", F: __dxlog_file, L: 80, S: this, A: ["newHandle.url", "'Migrated document URL not available after whenReady'"] });
|
|
70
65
|
this._newLinks[id] = newHandle.url;
|
|
71
|
-
this._addHandleToFlushList(newHandle);
|
|
66
|
+
this._addHandleToFlushList(newHandle.documentId);
|
|
72
67
|
}
|
|
73
68
|
async addObject(schema, props) {
|
|
74
|
-
const core = this._createObject({
|
|
69
|
+
const core = await this._createObject({
|
|
75
70
|
schema,
|
|
76
71
|
props
|
|
77
72
|
});
|
|
78
73
|
return core.id;
|
|
79
74
|
}
|
|
80
75
|
createReference(id) {
|
|
81
|
-
return
|
|
76
|
+
return EncodedReference.fromDXN(DXN.fromLocalObjectId(id));
|
|
82
77
|
}
|
|
83
78
|
deleteObject(id) {
|
|
84
79
|
this._deleteObjects.push(id);
|
|
85
80
|
}
|
|
86
|
-
changeProperties(changeFn) {
|
|
81
|
+
async changeProperties(changeFn) {
|
|
87
82
|
if (!this._newRoot) {
|
|
88
|
-
this._buildNewRoot();
|
|
83
|
+
await this._buildNewRoot();
|
|
89
84
|
}
|
|
90
|
-
invariant(this._newRoot, "New root not created", {
|
|
91
|
-
F: __dxlog_file,
|
|
92
|
-
L: 126,
|
|
93
|
-
S: this,
|
|
94
|
-
A: [
|
|
95
|
-
"this._newRoot",
|
|
96
|
-
"'New root not created'"
|
|
97
|
-
]
|
|
98
|
-
});
|
|
85
|
+
invariant(this._newRoot, "New root not created", { "~LogMeta": "~LogMeta", F: __dxlog_file, L: 101, S: this, A: ["this._newRoot", "'New root not created'"] });
|
|
99
86
|
this._newRoot.change((doc) => {
|
|
100
87
|
const propertiesStructure = doc.objects?.[this._space.properties.id];
|
|
101
88
|
propertiesStructure && changeFn(propertiesStructure);
|
|
102
89
|
});
|
|
103
|
-
this.
|
|
90
|
+
await this._newRoot.whenReady();
|
|
91
|
+
this._addHandleToFlushList(this._newRoot.documentId);
|
|
104
92
|
}
|
|
105
93
|
/**
|
|
106
94
|
* @internal
|
|
107
95
|
*/
|
|
108
96
|
async _commit() {
|
|
109
97
|
if (!this._newRoot) {
|
|
110
|
-
this._buildNewRoot();
|
|
98
|
+
await this._buildNewRoot();
|
|
111
99
|
}
|
|
112
|
-
invariant(this._newRoot, "New root not created", {
|
|
113
|
-
F: __dxlog_file,
|
|
114
|
-
L: 142,
|
|
115
|
-
S: this,
|
|
116
|
-
A: [
|
|
117
|
-
"this._newRoot",
|
|
118
|
-
"'New root not created'"
|
|
119
|
-
]
|
|
120
|
-
});
|
|
100
|
+
invariant(this._newRoot, "New root not created", { "~LogMeta": "~LogMeta", F: __dxlog_file, L: 115, S: this, A: ["this._newRoot", "'New root not created'"] });
|
|
121
101
|
await this._space.db.flush();
|
|
102
|
+
invariant(this._newRoot.url, "New root URL not available", { "~LogMeta": "~LogMeta", F: __dxlog_file, L: 118, S: this, A: ["this._newRoot.url", "'New root URL not available'"] });
|
|
122
103
|
await this._space.internal.createEpoch({
|
|
123
104
|
migration: CreateEpochRequest.Migration.REPLACE_AUTOMERGE_ROOT,
|
|
124
105
|
automergeRootUrl: this._newRoot.url
|
|
@@ -133,7 +114,7 @@ var MigrationBuilder = class {
|
|
|
133
114
|
await docHandle.whenReady();
|
|
134
115
|
return docHandle;
|
|
135
116
|
}
|
|
136
|
-
_buildNewRoot() {
|
|
117
|
+
async _buildNewRoot() {
|
|
137
118
|
const links = {
|
|
138
119
|
...this._rootDoc.links ?? {}
|
|
139
120
|
};
|
|
@@ -141,7 +122,7 @@ var MigrationBuilder = class {
|
|
|
141
122
|
delete links[id];
|
|
142
123
|
}
|
|
143
124
|
for (const [id, url] of Object.entries(this._newLinks)) {
|
|
144
|
-
links[id] = new
|
|
125
|
+
links[id] = new A.RawString(url);
|
|
145
126
|
}
|
|
146
127
|
this._newRoot = this._repo.create({
|
|
147
128
|
version: SpaceDocVersion.CURRENT,
|
|
@@ -151,15 +132,16 @@ var MigrationBuilder = class {
|
|
|
151
132
|
objects: this._rootDoc.objects,
|
|
152
133
|
links
|
|
153
134
|
});
|
|
154
|
-
this.
|
|
135
|
+
await this._newRoot.whenReady();
|
|
136
|
+
this._addHandleToFlushList(this._newRoot.documentId);
|
|
155
137
|
}
|
|
156
|
-
_createObject({ id, schema, props }) {
|
|
138
|
+
async _createObject({ id, schema, props }) {
|
|
157
139
|
const core = new ObjectCore();
|
|
158
140
|
if (id) {
|
|
159
141
|
core.id = id;
|
|
160
142
|
}
|
|
161
143
|
core.initNewObject(props);
|
|
162
|
-
core.setType(
|
|
144
|
+
core.setType(EncodedReference.fromDXN(getSchemaDXN(schema)));
|
|
163
145
|
const newHandle = this._repo.create({
|
|
164
146
|
version: SpaceDocVersion.CURRENT,
|
|
165
147
|
access: {
|
|
@@ -169,49 +151,29 @@ var MigrationBuilder = class {
|
|
|
169
151
|
[core.id]: core.getDoc()
|
|
170
152
|
}
|
|
171
153
|
});
|
|
154
|
+
await newHandle.whenReady();
|
|
172
155
|
this._newLinks[core.id] = newHandle.url;
|
|
173
|
-
this._addHandleToFlushList(newHandle);
|
|
156
|
+
this._addHandleToFlushList(newHandle.documentId);
|
|
174
157
|
return core;
|
|
175
158
|
}
|
|
176
|
-
_addHandleToFlushList(
|
|
177
|
-
this._flushIds.push(
|
|
178
|
-
}
|
|
179
|
-
constructor(_space) {
|
|
180
|
-
_define_property(this, "_space", void 0);
|
|
181
|
-
_define_property(this, "_repo", void 0);
|
|
182
|
-
_define_property(this, "_rootDoc", void 0);
|
|
183
|
-
_define_property(this, "_newLinks", void 0);
|
|
184
|
-
_define_property(this, "_flushIds", void 0);
|
|
185
|
-
_define_property(this, "_deleteObjects", void 0);
|
|
186
|
-
_define_property(this, "_newRoot", void 0);
|
|
187
|
-
this._space = _space;
|
|
188
|
-
this._newLinks = {};
|
|
189
|
-
this._flushIds = [];
|
|
190
|
-
this._deleteObjects = [];
|
|
191
|
-
this._newRoot = void 0;
|
|
192
|
-
this._repo = this._space.db.coreDatabase._repo;
|
|
193
|
-
this._rootDoc = this._space.db.coreDatabase._automergeDocLoader.getSpaceRootDocHandle().doc();
|
|
159
|
+
_addHandleToFlushList(id) {
|
|
160
|
+
this._flushIds.push(id);
|
|
194
161
|
}
|
|
195
162
|
};
|
|
196
163
|
|
|
197
164
|
// src/migrations.ts
|
|
198
|
-
import {
|
|
165
|
+
import { Atom } from "@effect-atom/atom";
|
|
166
|
+
import * as Registry from "@effect-atom/atom/Registry";
|
|
167
|
+
import { SpaceState } from "@dxos/client/echo";
|
|
199
168
|
import { invariant as invariant2 } from "@dxos/invariant";
|
|
200
|
-
function _define_property2(obj, key, value) {
|
|
201
|
-
if (key in obj) {
|
|
202
|
-
Object.defineProperty(obj, key, {
|
|
203
|
-
value,
|
|
204
|
-
enumerable: true,
|
|
205
|
-
configurable: true,
|
|
206
|
-
writable: true
|
|
207
|
-
});
|
|
208
|
-
} else {
|
|
209
|
-
obj[key] = value;
|
|
210
|
-
}
|
|
211
|
-
return obj;
|
|
212
|
-
}
|
|
213
169
|
var __dxlog_file2 = "/__w/dxos/dxos/packages/sdk/migrations/src/migrations.ts";
|
|
214
170
|
var Migrations = class {
|
|
171
|
+
static namespace;
|
|
172
|
+
static migrations = [];
|
|
173
|
+
static _registry = Registry.make();
|
|
174
|
+
static _stateAtom = Atom.make({
|
|
175
|
+
running: []
|
|
176
|
+
}).pipe(Atom.keepAlive);
|
|
215
177
|
static get versionProperty() {
|
|
216
178
|
return this.namespace && `${this.namespace}.version`;
|
|
217
179
|
}
|
|
@@ -219,40 +181,17 @@ var Migrations = class {
|
|
|
219
181
|
return this.migrations[this.migrations.length - 1]?.version;
|
|
220
182
|
}
|
|
221
183
|
static running(space) {
|
|
222
|
-
|
|
184
|
+
const state = this._registry.get(this._stateAtom);
|
|
185
|
+
return state.running.includes(space.key.toHex());
|
|
223
186
|
}
|
|
224
187
|
static define(namespace, migrations) {
|
|
225
188
|
this.namespace = namespace;
|
|
226
189
|
this.migrations = migrations;
|
|
227
190
|
}
|
|
228
191
|
static async migrate(space, targetVersion) {
|
|
229
|
-
invariant2(!this.running(space), "Migration already running", {
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
S: this,
|
|
233
|
-
A: [
|
|
234
|
-
"!this.running(space)",
|
|
235
|
-
"'Migration already running'"
|
|
236
|
-
]
|
|
237
|
-
});
|
|
238
|
-
invariant2(this.versionProperty, "Migrations namespace not set", {
|
|
239
|
-
F: __dxlog_file2,
|
|
240
|
-
L: 45,
|
|
241
|
-
S: this,
|
|
242
|
-
A: [
|
|
243
|
-
"this.versionProperty",
|
|
244
|
-
"'Migrations namespace not set'"
|
|
245
|
-
]
|
|
246
|
-
});
|
|
247
|
-
invariant2(space.state.get() === SpaceState.SPACE_READY, "Space not ready", {
|
|
248
|
-
F: __dxlog_file2,
|
|
249
|
-
L: 46,
|
|
250
|
-
S: this,
|
|
251
|
-
A: [
|
|
252
|
-
"space.state.get() === SpaceState.SPACE_READY",
|
|
253
|
-
"'Space not ready'"
|
|
254
|
-
]
|
|
255
|
-
});
|
|
192
|
+
invariant2(!this.running(space), "Migration already running", { "~LogMeta": "~LogMeta", F: __dxlog_file2, L: 31, S: this, A: ["!this.running(space)", "'Migration already running'"] });
|
|
193
|
+
invariant2(this.versionProperty, "Migrations namespace not set", { "~LogMeta": "~LogMeta", F: __dxlog_file2, L: 32, S: this, A: ["this.versionProperty", "'Migrations namespace not set'"] });
|
|
194
|
+
invariant2(space.state.get() === SpaceState.SPACE_READY, "Space not ready", { "~LogMeta": "~LogMeta", F: __dxlog_file2, L: 33, S: this, A: ["space.state.get() === SpaceState.SPACE_READY", "'Space not ready'"] });
|
|
256
195
|
const currentVersion = space.properties[this.versionProperty];
|
|
257
196
|
const currentIndex = this.migrations.findIndex((m) => m.version === currentVersion) + 1;
|
|
258
197
|
const i = this.migrations.findIndex((m) => m.version === targetVersion);
|
|
@@ -260,7 +199,14 @@ var Migrations = class {
|
|
|
260
199
|
if (currentIndex === targetIndex) {
|
|
261
200
|
return false;
|
|
262
201
|
}
|
|
263
|
-
|
|
202
|
+
const spaceKey = space.key.toHex();
|
|
203
|
+
const currentState = this._registry.get(this._stateAtom);
|
|
204
|
+
this._registry.set(this._stateAtom, {
|
|
205
|
+
running: [
|
|
206
|
+
...currentState.running,
|
|
207
|
+
spaceKey
|
|
208
|
+
]
|
|
209
|
+
});
|
|
264
210
|
if (targetIndex > currentIndex) {
|
|
265
211
|
const migrations = this.migrations.slice(currentIndex, targetIndex);
|
|
266
212
|
for (const migration of migrations) {
|
|
@@ -269,30 +215,20 @@ var Migrations = class {
|
|
|
269
215
|
space,
|
|
270
216
|
builder
|
|
271
217
|
});
|
|
272
|
-
builder.changeProperties((propertiesStructure) => {
|
|
273
|
-
invariant2(this.versionProperty, "Migrations namespace not set", {
|
|
274
|
-
F: __dxlog_file2,
|
|
275
|
-
L: 62,
|
|
276
|
-
S: this,
|
|
277
|
-
A: [
|
|
278
|
-
"this.versionProperty",
|
|
279
|
-
"'Migrations namespace not set'"
|
|
280
|
-
]
|
|
281
|
-
});
|
|
218
|
+
await builder.changeProperties((propertiesStructure) => {
|
|
219
|
+
invariant2(this.versionProperty, "Migrations namespace not set", { "~LogMeta": "~LogMeta", F: __dxlog_file2, L: 58, S: this, A: ["this.versionProperty", "'Migrations namespace not set'"] });
|
|
282
220
|
propertiesStructure.data[this.versionProperty] = migration.version;
|
|
283
221
|
});
|
|
284
222
|
await builder._commit();
|
|
285
223
|
}
|
|
286
224
|
}
|
|
287
|
-
this.
|
|
225
|
+
const finalState = this._registry.get(this._stateAtom);
|
|
226
|
+
this._registry.set(this._stateAtom, {
|
|
227
|
+
running: finalState.running.filter((key) => key !== spaceKey)
|
|
228
|
+
});
|
|
288
229
|
return true;
|
|
289
230
|
}
|
|
290
231
|
};
|
|
291
|
-
_define_property2(Migrations, "namespace", void 0);
|
|
292
|
-
_define_property2(Migrations, "migrations", []);
|
|
293
|
-
_define_property2(Migrations, "_state", live({
|
|
294
|
-
running: []
|
|
295
|
-
}));
|
|
296
232
|
export {
|
|
297
233
|
MigrationBuilder,
|
|
298
234
|
Migrations
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../src/migration-builder.ts", "../../../src/migrations.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport {
|
|
5
|
-
"mappings": ";;;AAIA,
|
|
6
|
-
"names": ["next", "
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport { next as A, type Doc } from '@automerge/automerge';\nimport { type AnyDocumentId, type DocumentId } from '@automerge/automerge-repo';\nimport type * as Schema from 'effect/Schema';\n\nimport { type Space } from '@dxos/client/echo';\nimport { CreateEpochRequest } from '@dxos/client/halo';\nimport { type DocHandleProxy, ObjectCore, type RepoProxy, migrateDocument } from '@dxos/echo-db';\nimport { type DatabaseDirectory, EncodedReference, type ObjectStructure, SpaceDocVersion } from '@dxos/echo-protocol';\nimport { getSchemaDXN } from '@dxos/echo/internal';\nimport { invariant } from '@dxos/invariant';\nimport { DXN } from '@dxos/keys';\nimport { type MaybePromise } from '@dxos/util';\n\n/*\n\nConsidering a better API for this:\n\n```ts\nconst migration = space.db.beginMigration(); // all actions are not visible to queries and are only applied once you call `apply`\n\nmigration.applyObjectMigration(defineMigration(From, To, { ... }));\n\nmigration.delete(id);\nmigration.add(obj);\n\nawait migration.apply(); // Will create new epoch.\n```\n\n*/\n\n// TODO(dmaretskyi): We no longer need to hook into ECHO internals, with the changes to echo APIs.\nexport class MigrationBuilder {\n private readonly _repo: RepoProxy;\n private readonly _rootDoc: Doc<DatabaseDirectory>;\n\n // echoId -> automergeUrl\n private readonly _newLinks: Record<string, string> = {};\n private readonly _flushIds: DocumentId[] = [];\n private readonly _deleteObjects: string[] = [];\n\n private _newRoot?: DocHandleProxy<DatabaseDirectory> = undefined;\n\n constructor(private readonly _space: Space) {\n this._repo = this._space.internal.db.coreDatabase._repo;\n // TODO(wittjosiah): Accessing private API.\n this._rootDoc = (this._space.internal.db.coreDatabase as any)._automergeDocLoader\n .getSpaceRootDocHandle()\n .doc() as Doc<DatabaseDirectory>;\n }\n\n async findObject(id: string): Promise<ObjectStructure | undefined> {\n const documentId = (this._rootDoc.links?.[id] || this._newLinks[id])?.toString() as AnyDocumentId | undefined;\n const docHandle = documentId && this._repo.find(documentId);\n if (!docHandle) {\n return undefined;\n }\n\n await docHandle.whenReady();\n const doc = docHandle.doc() as Doc<DatabaseDirectory>;\n return doc.objects?.[id];\n }\n\n async migrateObject(\n id: string,\n migrate: (objectStructure: ObjectStructure) => MaybePromise<{ schema: Schema.Schema.AnyNoContext; props: any }>,\n ): Promise<void> {\n const objectStructure = await this.findObject(id);\n if (!objectStructure) {\n return;\n }\n\n const { schema, props } = await migrate(objectStructure);\n\n const oldHandle = await this._findObjectContainingHandle(id);\n invariant(oldHandle);\n\n const newState: DatabaseDirectory = {\n version: SpaceDocVersion.CURRENT,\n access: {\n spaceKey: this._space.key.toHex(),\n },\n objects: {\n [id]: {\n system: {\n type: EncodedReference.fromDXN(getSchemaDXN(schema)!),\n },\n data: props,\n meta: {\n keys: [],\n },\n },\n },\n };\n const migratedDoc = migrateDocument(oldHandle.doc() as Doc<DatabaseDirectory>, newState);\n const newHandle = this._repo.import<DatabaseDirectory>(A.save(migratedDoc));\n await newHandle.whenReady();\n invariant(newHandle.url, 'Migrated document URL not available after whenReady');\n this._newLinks[id] = newHandle.url;\n this._addHandleToFlushList(newHandle.documentId!);\n }\n\n async addObject(schema: Schema.Schema.AnyNoContext, props: any): Promise<string> {\n const core = await this._createObject({ schema, props });\n return core.id;\n }\n\n createReference(id: string) {\n return EncodedReference.fromDXN(DXN.fromLocalObjectId(id));\n }\n\n deleteObject(id: string): void {\n this._deleteObjects.push(id);\n }\n\n async changeProperties(changeFn: (properties: ObjectStructure) => void): Promise<void> {\n if (!this._newRoot) {\n await this._buildNewRoot();\n }\n invariant(this._newRoot, 'New root not created');\n\n this._newRoot.change((doc: DatabaseDirectory) => {\n const propertiesStructure = doc.objects?.[this._space.properties.id];\n propertiesStructure && changeFn(propertiesStructure);\n });\n await this._newRoot.whenReady();\n this._addHandleToFlushList(this._newRoot.documentId!);\n }\n\n /**\n * @internal\n */\n async _commit(): Promise<void> {\n if (!this._newRoot) {\n await this._buildNewRoot();\n }\n invariant(this._newRoot, 'New root not created');\n\n await this._space.db.flush();\n\n // Create new epoch.\n invariant(this._newRoot.url, 'New root URL not available');\n await this._space.internal.createEpoch({\n migration: CreateEpochRequest.Migration.REPLACE_AUTOMERGE_ROOT,\n automergeRootUrl: this._newRoot.url,\n });\n }\n\n private async _findObjectContainingHandle(id: string): Promise<DocHandleProxy<DatabaseDirectory> | undefined> {\n const documentId = (this._rootDoc.links?.[id] || this._newLinks[id])?.toString() as AnyDocumentId | undefined;\n const docHandle = documentId && this._repo.find(documentId);\n if (!docHandle) {\n return undefined;\n }\n\n await docHandle.whenReady();\n return docHandle;\n }\n\n private async _buildNewRoot(): Promise<void> {\n const links = { ...(this._rootDoc.links ?? {}) };\n for (const id of this._deleteObjects) {\n delete links[id];\n }\n\n for (const [id, url] of Object.entries(this._newLinks)) {\n links[id] = new A.RawString(url);\n }\n\n this._newRoot = this._repo.create<DatabaseDirectory>({\n version: SpaceDocVersion.CURRENT,\n access: {\n spaceKey: this._space.key.toHex(),\n },\n objects: this._rootDoc.objects,\n links,\n });\n await this._newRoot.whenReady();\n this._addHandleToFlushList(this._newRoot.documentId!);\n }\n\n private async _createObject({\n id,\n schema,\n props,\n }: {\n id?: string;\n schema: Schema.Schema.AnyNoContext;\n props: any;\n }): Promise<ObjectCore> {\n const core = new ObjectCore();\n if (id) {\n core.id = id;\n }\n\n core.initNewObject(props);\n core.setType(EncodedReference.fromDXN(getSchemaDXN(schema)!));\n const newHandle = this._repo.create<DatabaseDirectory>({\n version: SpaceDocVersion.CURRENT,\n access: {\n spaceKey: this._space.key.toHex(),\n },\n objects: {\n [core.id]: core.getDoc() as ObjectStructure,\n },\n });\n await newHandle.whenReady();\n this._newLinks[core.id] = newHandle.url!;\n this._addHandleToFlushList(newHandle.documentId!);\n\n return core;\n }\n\n private _addHandleToFlushList(id: DocumentId): void {\n this._flushIds.push(id);\n }\n}\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { Atom } from '@effect-atom/atom';\nimport * as Registry from '@effect-atom/atom/Registry';\n\nimport { type Space, SpaceState } from '@dxos/client/echo';\nimport { invariant } from '@dxos/invariant';\nimport { type MaybePromise } from '@dxos/util';\n\nimport { MigrationBuilder } from './migration-builder';\n\nexport type MigrationContext = {\n space: Space;\n builder: MigrationBuilder;\n};\n\nexport type Migration = {\n version: string;\n next: (context: MigrationContext) => MaybePromise<void>;\n};\n\nexport class Migrations {\n static namespace?: string;\n static migrations: Migration[] = [];\n private static _registry = Registry.make();\n private static _stateAtom = Atom.make<{ running: string[] }>({ running: [] }).pipe(Atom.keepAlive);\n\n static get versionProperty() {\n return this.namespace && `${this.namespace}.version`;\n }\n\n static get targetVersion() {\n return this.migrations[this.migrations.length - 1]?.version;\n }\n\n static running(space: Space): boolean {\n const state = this._registry.get(this._stateAtom);\n return state.running.includes(space.key.toHex());\n }\n\n static define(namespace: string, migrations: Migration[]): void {\n this.namespace = namespace;\n this.migrations = migrations;\n }\n\n static async migrate(space: Space, targetVersion?: string | number): Promise<boolean> {\n invariant(!this.running(space), 'Migration already running');\n invariant(this.versionProperty, 'Migrations namespace not set');\n invariant(space.state.get() === SpaceState.SPACE_READY, 'Space not ready');\n const currentVersion = space.properties[this.versionProperty];\n const currentIndex = this.migrations.findIndex((m) => m.version === currentVersion) + 1;\n const i = this.migrations.findIndex((m) => m.version === targetVersion);\n const targetIndex = i === -1 ? this.migrations.length : i + 1;\n if (currentIndex === targetIndex) {\n return false;\n }\n\n const spaceKey = space.key.toHex();\n const currentState = this._registry.get(this._stateAtom);\n this._registry.set(this._stateAtom, { running: [...currentState.running, spaceKey] });\n if (targetIndex > currentIndex) {\n const migrations = this.migrations.slice(currentIndex, targetIndex);\n for (const migration of migrations) {\n const builder = new MigrationBuilder(space);\n await migration.next({ space, builder });\n await builder.changeProperties((propertiesStructure) => {\n invariant(this.versionProperty, 'Migrations namespace not set');\n propertiesStructure.data[this.versionProperty] = migration.version;\n });\n await builder._commit();\n }\n }\n const finalState = this._registry.get(this._stateAtom);\n this._registry.set(this._stateAtom, { running: finalState.running.filter((key) => key !== spaceKey) });\n\n return true;\n }\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["next", "A", "CreateEpochRequest", "ObjectCore", "migrateDocument", "EncodedReference", "SpaceDocVersion", "getSchemaDXN", "invariant", "DXN", "_repo", "_rootDoc", "_newLinks", "_deleteObjects", "_newRoot", "undefined", "_space", "internal", "db", "coreDatabase", "findObject", "docHandle", "objects", "migrateObject", "migrate", "objectStructure", "oldHandle", "newState", "version", "access", "spaceKey", "system", "data", "props", "meta", "keys", "newHandle", "whenReady", "id", "_addHandleToFlushList", "addObject", "schema", "createReference", "deleteObject", "changeProperties", "changeFn", "_buildNewRoot", "propertiesStructure", "properties", "migration", "REPLACE_AUTOMERGE_ROOT", "automergeRootUrl", "documentId", "url", "create", "links", "_createObject", "core", "initNewObject", "CURRENT", "Atom", "Registry", "SpaceState", "invariant", "__dxlog_file", "Migrations", "migrations", "_registry", "_stateAtom", "Atom", "running", "keepAlive", "versionProperty", "namespace", "targetVersion", "space", "state", "define", "invariant", "get", "SpaceState", "currentVersion", "properties", "currentIndex", "findIndex", "version", "i", "m", "targetIndex", "length", "spaceKey", "set", "currentState", "migration", "builder", "MigrationBuilder", "propertiesStructure", "finalState", "filter", "key"]
|
|
7
7
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"inputs":{"src/migration-builder.ts":{"bytes":
|
|
1
|
+
{"inputs":{"src/migration-builder.ts":{"bytes":23409,"imports":[{"path":"@automerge/automerge","kind":"import-statement","external":true},{"path":"@dxos/client/halo","kind":"import-statement","external":true},{"path":"@dxos/echo-db","kind":"import-statement","external":true},{"path":"@dxos/echo-protocol","kind":"import-statement","external":true},{"path":"@dxos/echo/internal","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true}],"format":"esm"},"src/migrations.ts":{"bytes":10982,"imports":[{"path":"@effect-atom/atom","kind":"import-statement","external":true},{"path":"@effect-atom/atom/Registry","kind":"import-statement","external":true},{"path":"@dxos/client/echo","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"src/migration-builder.ts","kind":"import-statement","original":"./migration-builder"}],"format":"esm"},"src/index.ts":{"bytes":575,"imports":[{"path":"src/migration-builder.ts","kind":"import-statement","original":"./migration-builder"},{"path":"src/migrations.ts","kind":"import-statement","original":"./migrations"}],"format":"esm"}},"outputs":{"dist/lib/node-esm/index.mjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":16637},"dist/lib/node-esm/index.mjs":{"imports":[{"path":"@automerge/automerge","kind":"import-statement","external":true},{"path":"@dxos/client/halo","kind":"import-statement","external":true},{"path":"@dxos/echo-db","kind":"import-statement","external":true},{"path":"@dxos/echo-protocol","kind":"import-statement","external":true},{"path":"@dxos/echo/internal","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@effect-atom/atom","kind":"import-statement","external":true},{"path":"@effect-atom/atom/Registry","kind":"import-statement","external":true},{"path":"@dxos/client/echo","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true}],"exports":["MigrationBuilder","Migrations"],"entryPoint":"src/index.ts","inputs":{"src/migration-builder.ts":{"bytesInOutput":5430},"src/index.ts":{"bytesInOutput":0},"src/migrations.ts":{"bytesInOutput":3055}},"bytes":8708}}}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import
|
|
1
|
+
import type * as Schema from 'effect/Schema';
|
|
2
2
|
import { type Space } from '@dxos/client/echo';
|
|
3
|
-
import { type ObjectStructure } from '@dxos/echo-protocol';
|
|
3
|
+
import { EncodedReference, type ObjectStructure } from '@dxos/echo-protocol';
|
|
4
4
|
import { type MaybePromise } from '@dxos/util';
|
|
5
5
|
export declare class MigrationBuilder {
|
|
6
6
|
private readonly _space;
|
|
@@ -17,9 +17,9 @@ export declare class MigrationBuilder {
|
|
|
17
17
|
props: any;
|
|
18
18
|
}>): Promise<void>;
|
|
19
19
|
addObject(schema: Schema.Schema.AnyNoContext, props: any): Promise<string>;
|
|
20
|
-
createReference(id: string):
|
|
20
|
+
createReference(id: string): EncodedReference;
|
|
21
21
|
deleteObject(id: string): void;
|
|
22
|
-
changeProperties(changeFn: (properties: ObjectStructure) => void): void
|
|
22
|
+
changeProperties(changeFn: (properties: ObjectStructure) => void): Promise<void>;
|
|
23
23
|
private _findObjectContainingHandle;
|
|
24
24
|
private _buildNewRoot;
|
|
25
25
|
private _createObject;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"migration-builder.d.ts","sourceRoot":"","sources":["../../../src/migration-builder.ts"],"names":[],"mappings":"AAMA,OAAO,
|
|
1
|
+
{"version":3,"file":"migration-builder.d.ts","sourceRoot":"","sources":["../../../src/migration-builder.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,KAAK,MAAM,MAAM,eAAe,CAAC;AAE7C,OAAO,EAAE,KAAK,KAAK,EAAE,MAAM,mBAAmB,CAAC;AAG/C,OAAO,EAA0B,gBAAgB,EAAE,KAAK,eAAe,EAAmB,MAAM,qBAAqB,CAAC;AAItH,OAAO,EAAE,KAAK,YAAY,EAAE,MAAM,YAAY,CAAC;AAoB/C,qBAAa,gBAAgB;IAWf,OAAO,CAAC,QAAQ,CAAC,MAAM;IAVnC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAY;IAClC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAyB;IAGlD,OAAO,CAAC,QAAQ,CAAC,SAAS,CAA8B;IACxD,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAoB;IAC9C,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAgB;IAE/C,OAAO,CAAC,QAAQ,CAAC,CAAgD;IAEjE,YAA6B,MAAM,EAAE,KAAK,EAMzC;IAEK,UAAU,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,eAAe,GAAG,SAAS,CAAC,CAUjE;IAEK,aAAa,CACjB,EAAE,EAAE,MAAM,EACV,OAAO,EAAE,CAAC,eAAe,EAAE,eAAe,KAAK,YAAY,CAAC;QAAE,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,YAAY,CAAC;QAAC,KAAK,EAAE,GAAG,CAAA;KAAE,CAAC,GAC9G,OAAO,CAAC,IAAI,CAAC,CAkCf;IAEK,SAAS,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,YAAY,EAAE,KAAK,EAAE,GAAG,GAAG,OAAO,CAAC,MAAM,CAAC,CAG/E;IAED,eAAe,CAAC,EAAE,EAAE,MAAM,oBAEzB;IAED,YAAY,CAAC,EAAE,EAAE,MAAM,GAAG,IAAI,CAE7B;IAEK,gBAAgB,CAAC,QAAQ,EAAE,CAAC,UAAU,EAAE,eAAe,KAAK,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAYrF;YAqBa,2BAA2B;YAW3B,aAAa;YAsBb,aAAa;IAgC3B,OAAO,CAAC,qBAAqB;CAG9B"}
|
|
@@ -12,7 +12,8 @@ export type Migration = {
|
|
|
12
12
|
export declare class Migrations {
|
|
13
13
|
static namespace?: string;
|
|
14
14
|
static migrations: Migration[];
|
|
15
|
-
private static
|
|
15
|
+
private static _registry;
|
|
16
|
+
private static _stateAtom;
|
|
16
17
|
static get versionProperty(): string | undefined;
|
|
17
18
|
static get targetVersion(): string;
|
|
18
19
|
static running(space: Space): boolean;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"migrations.d.ts","sourceRoot":"","sources":["../../../src/migrations.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"migrations.d.ts","sourceRoot":"","sources":["../../../src/migrations.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,KAAK,KAAK,EAAc,MAAM,mBAAmB,CAAC;AAE3D,OAAO,EAAE,KAAK,YAAY,EAAE,MAAM,YAAY,CAAC;AAE/C,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AAEvD,MAAM,MAAM,gBAAgB,GAAG;IAC7B,KAAK,EAAE,KAAK,CAAC;IACb,OAAO,EAAE,gBAAgB,CAAC;CAC3B,CAAC;AAEF,MAAM,MAAM,SAAS,GAAG;IACtB,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,CAAC,OAAO,EAAE,gBAAgB,KAAK,YAAY,CAAC,IAAI,CAAC,CAAC;CACzD,CAAC;AAEF,qBAAa,UAAU;IACrB,MAAM,CAAC,SAAS,CAAC,EAAE,MAAM,CAAC;IAC1B,MAAM,CAAC,UAAU,EAAE,SAAS,EAAE,CAAM;IACpC,OAAO,CAAC,MAAM,CAAC,SAAS,CAAmB;IAC3C,OAAO,CAAC,MAAM,CAAC,UAAU,CAA0E;IAEnG,MAAM,KAAK,eAAe,uBAEzB;IAED,MAAM,KAAK,aAAa,WAEvB;IAED,MAAM,CAAC,OAAO,CAAC,KAAK,EAAE,KAAK,GAAG,OAAO,CAGpC;IAED,MAAM,CAAC,MAAM,CAAC,SAAS,EAAE,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,GAAG,IAAI,CAG9D;IAED,OAAa,OAAO,CAAC,KAAK,EAAE,KAAK,EAAE,aAAa,CAAC,EAAE,MAAM,GAAG,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,CA+BpF;CACF"}
|