@dxos/echo-protocol 0.8.4-main.b97322e → 0.8.4-main.dedc0f3
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/dist/lib/browser/index.mjs +85 -16
- package/dist/lib/browser/index.mjs.map +3 -3
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/node-esm/index.mjs +85 -16
- package/dist/lib/node-esm/index.mjs.map +3 -3
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/types/src/document-structure.d.ts.map +1 -1
- package/dist/types/src/query/ast.d.ts +62 -10
- package/dist/types/src/query/ast.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +8 -7
- package/src/document-structure.ts +1 -1
- package/src/query/ast.ts +71 -0
- package/src/reference.ts +1 -1
- package/src/space-id.ts +1 -1
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@dxos/echo-protocol",
|
|
3
|
-
"version": "0.8.4-main.
|
|
3
|
+
"version": "0.8.4-main.dedc0f3",
|
|
4
4
|
"description": "Core ECHO APIs.",
|
|
5
5
|
"homepage": "https://dxos.org",
|
|
6
6
|
"bugs": "https://github.com/dxos/dxos/issues",
|
|
@@ -11,6 +11,7 @@
|
|
|
11
11
|
"type": "module",
|
|
12
12
|
"exports": {
|
|
13
13
|
".": {
|
|
14
|
+
"source": "./src/index.ts",
|
|
14
15
|
"types": "./dist/types/src/index.d.ts",
|
|
15
16
|
"browser": "./dist/lib/browser/index.mjs",
|
|
16
17
|
"node": "./dist/lib/node-esm/index.mjs"
|
|
@@ -25,12 +26,12 @@
|
|
|
25
26
|
"src"
|
|
26
27
|
],
|
|
27
28
|
"dependencies": {
|
|
28
|
-
"effect": "3.17.
|
|
29
|
-
"@dxos/crypto": "0.8.4-main.
|
|
30
|
-
"@dxos/
|
|
31
|
-
"@dxos/
|
|
32
|
-
"@dxos/protocols": "0.8.4-main.
|
|
33
|
-
"@dxos/util": "0.8.4-main.
|
|
29
|
+
"effect": "3.17.7",
|
|
30
|
+
"@dxos/crypto": "0.8.4-main.dedc0f3",
|
|
31
|
+
"@dxos/keys": "0.8.4-main.dedc0f3",
|
|
32
|
+
"@dxos/invariant": "0.8.4-main.dedc0f3",
|
|
33
|
+
"@dxos/protocols": "0.8.4-main.dedc0f3",
|
|
34
|
+
"@dxos/util": "0.8.4-main.dedc0f3"
|
|
34
35
|
},
|
|
35
36
|
"publishConfig": {
|
|
36
37
|
"access": "public"
|
|
@@ -8,7 +8,7 @@ import { visitValues } from '@dxos/util';
|
|
|
8
8
|
|
|
9
9
|
import { type RawString } from './automerge';
|
|
10
10
|
import type { ForeignKey } from './foreign-key';
|
|
11
|
-
import {
|
|
11
|
+
import { type EncodedReference, isEncodedReference } from './reference';
|
|
12
12
|
import { type SpaceDocVersion } from './space-doc-version';
|
|
13
13
|
|
|
14
14
|
export type SpaceState = {
|
package/src/query/ast.ts
CHANGED
|
@@ -205,6 +205,35 @@ const QuerySetDifferenceClause_ = Schema.Struct({
|
|
|
205
205
|
export interface QuerySetDifferenceClause extends Schema.Schema.Type<typeof QuerySetDifferenceClause_> {}
|
|
206
206
|
export const QuerySetDifferenceClause: Schema.Schema<QuerySetDifferenceClause> = QuerySetDifferenceClause_;
|
|
207
207
|
|
|
208
|
+
export const OrderDirection = Schema.Literal('asc', 'desc');
|
|
209
|
+
export type OrderDirection = Schema.Schema.Type<typeof OrderDirection>;
|
|
210
|
+
|
|
211
|
+
const Order_ = Schema.Union(
|
|
212
|
+
Schema.Struct({
|
|
213
|
+
// How database wants to order them (in practice - by id).
|
|
214
|
+
kind: Schema.Literal('natural'),
|
|
215
|
+
}),
|
|
216
|
+
Schema.Struct({
|
|
217
|
+
kind: Schema.Literal('property'),
|
|
218
|
+
property: Schema.String,
|
|
219
|
+
direction: OrderDirection,
|
|
220
|
+
}),
|
|
221
|
+
);
|
|
222
|
+
export type Order = Schema.Schema.Type<typeof Order_>;
|
|
223
|
+
export const Order: Schema.Schema<Order> = Order_;
|
|
224
|
+
|
|
225
|
+
/**
|
|
226
|
+
* Order the query results.
|
|
227
|
+
* Left-to-right the orders dominate.
|
|
228
|
+
*/
|
|
229
|
+
const QueryOrderClause_ = Schema.Struct({
|
|
230
|
+
type: Schema.Literal('order'),
|
|
231
|
+
query: Schema.suspend(() => Query),
|
|
232
|
+
order: Schema.Array(Order),
|
|
233
|
+
});
|
|
234
|
+
export interface QueryOrderClause extends Schema.Schema.Type<typeof QueryOrderClause_> {}
|
|
235
|
+
export const QueryOrderClause: Schema.Schema<QueryOrderClause> = QueryOrderClause_;
|
|
236
|
+
|
|
208
237
|
/**
|
|
209
238
|
* Add options to a query.
|
|
210
239
|
*/
|
|
@@ -225,6 +254,7 @@ const Query_ = Schema.Union(
|
|
|
225
254
|
QueryRelationTraversalClause,
|
|
226
255
|
QueryUnionClause,
|
|
227
256
|
QuerySetDifferenceClause,
|
|
257
|
+
QueryOrderClause,
|
|
228
258
|
QueryOptionsClause,
|
|
229
259
|
);
|
|
230
260
|
|
|
@@ -232,7 +262,23 @@ export type Query = Schema.Schema.Type<typeof Query_>;
|
|
|
232
262
|
export const Query: Schema.Schema<Query> = Query_;
|
|
233
263
|
|
|
234
264
|
export const QueryOptions = Schema.Struct({
|
|
265
|
+
/**
|
|
266
|
+
* The nested select statemets will select from the given spaces.
|
|
267
|
+
*
|
|
268
|
+
* NOTE: Spaces and queues are unioned together if both are specified.
|
|
269
|
+
*/
|
|
235
270
|
spaceIds: Schema.optional(Schema.Array(Schema.String)),
|
|
271
|
+
|
|
272
|
+
/**
|
|
273
|
+
* The nested select statemets will select from the given queues.
|
|
274
|
+
*
|
|
275
|
+
* NOTE: Spaces and queues are unioned together if both are specified.
|
|
276
|
+
*/
|
|
277
|
+
queues: Schema.optional(Schema.Array(DXN.Schema)),
|
|
278
|
+
|
|
279
|
+
/**
|
|
280
|
+
* Nested select statements will use this option to filter deleted objects.
|
|
281
|
+
*/
|
|
236
282
|
deleted: Schema.optional(Schema.Literal('include', 'exclude', 'only')),
|
|
237
283
|
});
|
|
238
284
|
export interface QueryOptions extends Schema.Schema.Type<typeof QueryOptions> {}
|
|
@@ -266,3 +312,28 @@ export const visit = (query: Query, visitor: (node: Query) => void) => {
|
|
|
266
312
|
break;
|
|
267
313
|
}
|
|
268
314
|
};
|
|
315
|
+
|
|
316
|
+
export const fold = <T>(query: Query, reducer: (node: Query) => T): T[] => {
|
|
317
|
+
switch (query.type) {
|
|
318
|
+
case 'filter':
|
|
319
|
+
return fold(query.selection, reducer);
|
|
320
|
+
case 'reference-traversal':
|
|
321
|
+
return fold(query.anchor, reducer);
|
|
322
|
+
case 'incoming-references':
|
|
323
|
+
return fold(query.anchor, reducer);
|
|
324
|
+
case 'relation':
|
|
325
|
+
return fold(query.anchor, reducer);
|
|
326
|
+
case 'options':
|
|
327
|
+
return fold(query.query, reducer);
|
|
328
|
+
case 'relation-traversal':
|
|
329
|
+
return fold(query.anchor, reducer);
|
|
330
|
+
case 'union':
|
|
331
|
+
return query.queries.flatMap((q: Query) => fold(q, reducer));
|
|
332
|
+
case 'set-difference':
|
|
333
|
+
return fold(query.source, reducer);
|
|
334
|
+
case 'order':
|
|
335
|
+
return fold(query.query, reducer);
|
|
336
|
+
case 'select':
|
|
337
|
+
return [];
|
|
338
|
+
}
|
|
339
|
+
};
|
package/src/reference.ts
CHANGED
|
@@ -170,7 +170,7 @@ export const isEncodedReference = (value: any): value is EncodedReference =>
|
|
|
170
170
|
export const EncodedReference = Object.freeze({
|
|
171
171
|
isEncodedReference,
|
|
172
172
|
getReferenceString: (value: EncodedReference): string => {
|
|
173
|
-
assertArgument(isEncodedReference(value), 'invalid reference');
|
|
173
|
+
assertArgument(isEncodedReference(value), 'value', 'invalid reference');
|
|
174
174
|
return value['/'];
|
|
175
175
|
},
|
|
176
176
|
toDXN: (value: EncodedReference): DXN => {
|
package/src/space-id.ts
CHANGED
|
@@ -18,7 +18,7 @@ export const createIdFromSpaceKey = async (spaceKey: PublicKey): Promise<SpaceId
|
|
|
18
18
|
return cachedValue;
|
|
19
19
|
}
|
|
20
20
|
|
|
21
|
-
const digest = await subtleCrypto.digest('SHA-256', spaceKey.asUint8Array());
|
|
21
|
+
const digest = await subtleCrypto.digest('SHA-256', spaceKey.asUint8Array() as Uint8Array<ArrayBuffer>);
|
|
22
22
|
|
|
23
23
|
const bytes = new Uint8Array(digest).slice(0, SpaceId.byteLength);
|
|
24
24
|
const spaceId = SpaceId.encode(bytes);
|