@dxos/echo 0.8.4-main.5ad4a44 → 0.8.4-main.66e292d
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/{chunk-MWLA34S5.mjs → chunk-7GH6RXJ3.mjs} +2513 -2673
- package/dist/lib/browser/chunk-7GH6RXJ3.mjs.map +7 -0
- package/dist/lib/browser/chunk-E4UTVJNF.mjs +1111 -0
- package/dist/lib/browser/chunk-E4UTVJNF.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +21 -19
- package/dist/lib/browser/internal/index.mjs +55 -45
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/testing/index.mjs +247 -217
- package/dist/lib/browser/testing/index.mjs.map +4 -4
- package/dist/lib/node-esm/chunk-JE5RXM2I.mjs +1111 -0
- package/dist/lib/node-esm/chunk-JE5RXM2I.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-YTNLFBIK.mjs → chunk-M4B6BMD2.mjs} +2513 -2673
- package/dist/lib/node-esm/chunk-M4B6BMD2.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +21 -19
- package/dist/lib/node-esm/internal/index.mjs +55 -45
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/testing/index.mjs +247 -217
- package/dist/lib/node-esm/testing/index.mjs.map +4 -4
- package/dist/types/src/Annotation.d.ts +2 -0
- package/dist/types/src/Annotation.d.ts.map +1 -0
- package/dist/types/src/Database.d.ts +137 -0
- package/dist/types/src/Database.d.ts.map +1 -0
- package/dist/types/src/Entity.d.ts +36 -0
- package/dist/types/src/Entity.d.ts.map +1 -0
- package/dist/types/src/Format.d.ts +4 -0
- package/dist/types/src/Format.d.ts.map +1 -0
- package/dist/types/src/JsonSchema.d.ts +9 -0
- package/dist/types/src/JsonSchema.d.ts.map +1 -0
- package/dist/types/src/Key.d.ts +1 -0
- package/dist/types/src/Key.d.ts.map +1 -1
- package/dist/types/src/Obj.d.ts +85 -62
- package/dist/types/src/Obj.d.ts.map +1 -1
- package/dist/types/src/Ref.d.ts +10 -10
- package/dist/types/src/Ref.d.ts.map +1 -1
- package/dist/types/src/Relation.d.ts +14 -11
- package/dist/types/src/Relation.d.ts.map +1 -1
- package/dist/types/src/Tag.d.ts +17 -0
- package/dist/types/src/Tag.d.ts.map +1 -0
- package/dist/types/src/Type.d.ts +39 -49
- package/dist/types/src/Type.d.ts.map +1 -1
- package/dist/types/src/errors.d.ts +14 -18
- package/dist/types/src/errors.d.ts.map +1 -1
- package/dist/types/src/index.d.ts +7 -3
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/internal/annotations/annotations.d.ts +174 -0
- package/dist/types/src/internal/annotations/annotations.d.ts.map +1 -0
- package/dist/types/src/internal/annotations/annotations.test.d.ts.map +1 -0
- package/dist/types/src/internal/annotations/index.d.ts +3 -0
- package/dist/types/src/internal/annotations/index.d.ts.map +1 -0
- package/dist/types/src/internal/annotations/util.d.ts +26 -0
- package/dist/types/src/internal/annotations/util.d.ts.map +1 -0
- package/dist/types/src/internal/entities/entity.d.ts +10 -0
- package/dist/types/src/internal/entities/entity.d.ts.map +1 -0
- package/dist/types/src/internal/{object → entities}/expando.d.ts +3 -1
- package/dist/types/src/internal/entities/expando.d.ts.map +1 -0
- package/dist/types/src/internal/entities/index.d.ts +6 -0
- package/dist/types/src/internal/entities/index.d.ts.map +1 -0
- package/dist/types/src/internal/entities/model.d.ts +70 -0
- package/dist/types/src/internal/entities/model.d.ts.map +1 -0
- package/dist/types/src/internal/entities/object.d.ts +11 -0
- package/dist/types/src/internal/entities/object.d.ts.map +1 -0
- package/dist/types/src/internal/entities/relation.d.ts +55 -0
- package/dist/types/src/internal/entities/relation.d.ts.map +1 -0
- package/dist/types/src/internal/entities/util.d.ts +2 -0
- package/dist/types/src/internal/entities/util.d.ts.map +1 -0
- package/dist/types/src/internal/formats/format.d.ts +2 -0
- package/dist/types/src/internal/formats/format.d.ts.map +1 -1
- package/dist/types/src/internal/formats/types.d.ts +7 -7
- package/dist/types/src/internal/formats/types.d.ts.map +1 -1
- package/dist/types/src/internal/index.d.ts +6 -10
- package/dist/types/src/internal/index.d.ts.map +1 -1
- package/dist/types/src/internal/json-schema/annotations.d.ts.map +1 -0
- package/dist/types/src/internal/json-schema/effect-schema.test.d.ts.map +1 -0
- package/dist/types/src/internal/json-schema/index.d.ts +2 -0
- package/dist/types/src/internal/json-schema/index.d.ts.map +1 -1
- package/dist/types/src/internal/json-schema/json-schema-type.d.ts.map +1 -1
- package/dist/types/src/internal/{json → json-schema}/json-schema.d.ts +2 -5
- package/dist/types/src/internal/json-schema/json-schema.d.ts.map +1 -0
- package/dist/types/src/internal/json-schema/json-schema.test.d.ts.map +1 -0
- package/dist/types/src/internal/object/common.d.ts.map +1 -1
- package/dist/types/src/internal/object/{create.d.ts → create-object.d.ts} +9 -10
- package/dist/types/src/internal/object/create-object.d.ts.map +1 -0
- package/dist/types/src/internal/object/create-object.test.d.ts +2 -0
- package/dist/types/src/internal/object/create-object.test.d.ts.map +1 -0
- package/dist/types/src/internal/object/deleted.d.ts +2 -2
- package/dist/types/src/internal/object/deleted.d.ts.map +1 -1
- package/dist/types/src/internal/object/ids.d.ts.map +1 -1
- package/dist/types/src/internal/object/index.d.ts +3 -12
- package/dist/types/src/internal/object/index.d.ts.map +1 -1
- package/dist/types/src/internal/object/json-serializer.d.ts +1 -2
- package/dist/types/src/internal/object/json-serializer.d.ts.map +1 -1
- package/dist/types/src/internal/object/schema-validator.d.ts.map +1 -1
- package/dist/types/src/internal/object/typed-object.d.ts +1 -1
- package/dist/types/src/internal/object/typed-object.d.ts.map +1 -1
- package/dist/types/src/internal/proxy/index.d.ts +3 -0
- package/dist/types/src/internal/proxy/index.d.ts.map +1 -0
- package/dist/types/src/internal/proxy/make-object.d.ts +16 -0
- package/dist/types/src/internal/proxy/make-object.d.ts.map +1 -0
- package/dist/types/src/internal/proxy/typed-handler.d.ts +1 -1
- package/dist/types/src/internal/proxy/typed-handler.d.ts.map +1 -1
- package/dist/types/src/internal/ref/ref.d.ts +15 -12
- package/dist/types/src/internal/ref/ref.d.ts.map +1 -1
- package/dist/types/src/internal/schema/compose.d.ts.map +1 -0
- package/dist/types/src/internal/schema/compose.test.d.ts.map +1 -0
- package/dist/types/src/internal/schema/echo-schema.d.ts +9 -9
- package/dist/types/src/internal/schema/echo-schema.d.ts.map +1 -1
- package/dist/types/src/internal/schema/index.d.ts +3 -4
- package/dist/types/src/internal/schema/index.d.ts.map +1 -1
- package/dist/types/src/internal/schema/manipulation.d.ts.map +1 -1
- package/dist/types/src/internal/schema/persistent-schema.d.ts +18 -0
- package/dist/types/src/internal/schema/persistent-schema.d.ts.map +1 -0
- package/dist/types/src/internal/schema/runtime-schema-registry.d.ts +1 -1
- package/dist/types/src/internal/schema/runtime-schema-registry.d.ts.map +1 -1
- package/dist/types/src/internal/types/base.d.ts +37 -0
- package/dist/types/src/internal/types/base.d.ts.map +1 -0
- package/dist/types/src/internal/{ast/entity-kind.d.ts → types/entity.d.ts} +3 -1
- package/dist/types/src/internal/types/entity.d.ts.map +1 -0
- package/dist/types/src/internal/types/index.d.ts +5 -2
- package/dist/types/src/internal/types/index.d.ts.map +1 -1
- package/dist/types/src/internal/{object → types}/meta.d.ts +20 -11
- package/dist/types/src/internal/types/meta.d.ts.map +1 -0
- package/dist/types/src/internal/types/typename.d.ts +13 -0
- package/dist/types/src/internal/types/typename.d.ts.map +1 -0
- package/dist/types/src/internal/{object → types}/version.d.ts +3 -2
- package/dist/types/src/internal/types/version.d.ts.map +1 -0
- package/dist/types/src/query/filter.d.ts +167 -0
- package/dist/types/src/query/filter.d.ts.map +1 -0
- package/dist/types/src/query/index.d.ts +3 -1
- package/dist/types/src/query/index.d.ts.map +1 -1
- package/dist/types/src/query/order.d.ts +12 -0
- package/dist/types/src/query/order.d.ts.map +1 -0
- package/dist/types/src/query/query.d.ts +9 -144
- package/dist/types/src/query/query.d.ts.map +1 -1
- package/dist/types/src/query/testing.d.ts +51 -0
- package/dist/types/src/query/testing.d.ts.map +1 -0
- package/dist/types/src/{internal/query/query.d.ts → query/types.d.ts} +1 -1
- package/dist/types/src/query/types.d.ts.map +1 -0
- package/dist/types/src/query/util.d.ts +8 -0
- package/dist/types/src/query/util.d.ts.map +1 -0
- package/dist/types/src/{test → testing}/api.test.d.ts.map +1 -1
- package/dist/types/src/testing/index.d.ts +3 -3
- package/dist/types/src/testing/index.d.ts.map +1 -1
- package/dist/types/src/testing/test-data.d.ts +18 -0
- package/dist/types/src/testing/test-data.d.ts.map +1 -0
- package/dist/types/src/testing/test-schema.d.ts +337 -0
- package/dist/types/src/testing/test-schema.d.ts.map +1 -0
- package/dist/types/src/{internal/testing/utils.d.ts → testing/util.d.ts} +11 -5
- package/dist/types/src/testing/util.d.ts.map +1 -0
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +46 -38
- package/src/Annotation.ts +17 -0
- package/src/Database.ts +189 -0
- package/src/Entity.ts +51 -0
- package/src/Format.ts +11 -0
- package/src/JsonSchema.ts +16 -0
- package/src/Key.ts +3 -0
- package/src/Obj.ts +260 -147
- package/src/Ref.ts +9 -9
- package/src/Relation.ts +58 -44
- package/src/Tag.ts +40 -0
- package/src/Type.ts +96 -83
- package/src/index.ts +10 -4
- package/src/internal/README.md +83 -0
- package/src/internal/{ast → annotations}/annotations.test.ts +13 -15
- package/src/internal/annotations/annotations.ts +463 -0
- package/src/internal/annotations/index.ts +6 -0
- package/src/internal/annotations/util.ts +70 -0
- package/src/internal/entities/entity.ts +109 -0
- package/src/internal/{object → entities}/expando.ts +7 -5
- package/src/internal/entities/index.ts +9 -0
- package/src/internal/entities/model.ts +129 -0
- package/src/internal/entities/object.ts +45 -0
- package/src/internal/entities/relation.ts +155 -0
- package/src/internal/entities/util.ts +33 -0
- package/src/internal/formats/date.test.ts +1 -1
- package/src/internal/formats/date.ts +5 -5
- package/src/internal/formats/format.test.ts +5 -5
- package/src/internal/formats/format.ts +3 -0
- package/src/internal/formats/number.ts +5 -5
- package/src/internal/formats/object.ts +2 -2
- package/src/internal/formats/string.ts +9 -9
- package/src/internal/formats/types.ts +44 -39
- package/src/internal/index.ts +29 -13
- package/src/internal/{json → json-schema}/annotations.ts +1 -1
- package/src/internal/json-schema/index.ts +2 -0
- package/src/internal/json-schema/json-schema-type.ts +4 -3
- package/src/internal/{json → json-schema}/json-schema.test.ts +230 -97
- package/src/internal/{json → json-schema}/json-schema.ts +67 -87
- package/src/internal/object/common.ts +3 -4
- package/src/internal/object/{create.test.ts → create-object.test.ts} +31 -33
- package/src/internal/object/{create.ts → create-object.ts} +34 -35
- package/src/internal/object/deleted.ts +6 -6
- package/src/internal/object/ids.ts +1 -1
- package/src/internal/object/index.ts +3 -12
- package/src/internal/object/inspect.ts +3 -5
- package/src/internal/object/json-serializer.test.ts +33 -38
- package/src/internal/object/json-serializer.ts +43 -38
- package/src/internal/object/schema-validator.ts +3 -2
- package/src/internal/object/typed-object.test.ts +1 -1
- package/src/internal/object/typed-object.ts +17 -4
- package/src/internal/proxy/handler.test.ts +30 -20
- package/src/internal/proxy/index.ts +6 -0
- package/src/internal/proxy/{reactive-object.ts → make-object.ts} +19 -14
- package/src/internal/proxy/schema.test.ts +5 -4
- package/src/internal/proxy/typed-handler.test.ts +28 -28
- package/src/internal/proxy/typed-handler.ts +11 -6
- package/src/internal/proxy/typed-object.test.ts +17 -12
- package/src/internal/ref/ref.test.ts +9 -8
- package/src/internal/ref/ref.ts +24 -20
- package/src/internal/{projection → schema}/compose.test.ts +5 -6
- package/src/internal/{projection → schema}/compose.ts +2 -1
- package/src/internal/schema/echo-schema.ts +30 -28
- package/src/internal/schema/index.ts +3 -4
- package/src/internal/schema/manipulation.ts +7 -1
- package/src/internal/schema/persistent-schema.ts +28 -0
- package/src/internal/schema/runtime-schema-registry.ts +4 -4
- package/src/internal/types/base.ts +58 -0
- package/src/internal/{ast/entity-kind.ts → types/entity.ts} +8 -0
- package/src/internal/types/index.ts +5 -2
- package/src/internal/{object → types}/meta.ts +32 -18
- package/src/internal/types/typename.ts +45 -0
- package/src/internal/types/version.ts +20 -0
- package/src/query/filter.ts +455 -0
- package/src/query/index.ts +4 -1
- package/src/query/order.ts +34 -0
- package/src/query/query.test.ts +188 -216
- package/src/query/query.ts +24 -505
- package/src/query/testing.ts +64 -0
- package/src/query/util.ts +25 -0
- package/src/testing/api.test.ts +100 -0
- package/src/testing/index.ts +3 -3
- package/src/testing/test-data.ts +130 -0
- package/src/testing/test-schema.ts +213 -0
- package/src/{internal/testing/utils.ts → testing/util.ts} +38 -14
- package/dist/lib/browser/chunk-MWLA34S5.mjs.map +0 -7
- package/dist/lib/browser/chunk-OAZJQHVO.mjs +0 -453
- package/dist/lib/browser/chunk-OAZJQHVO.mjs.map +0 -7
- package/dist/lib/browser/chunk-ORIE2FMS.mjs +0 -514
- package/dist/lib/browser/chunk-ORIE2FMS.mjs.map +0 -7
- package/dist/lib/browser/query/index.mjs +0 -23
- package/dist/lib/browser/query/index.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-AXWVDOP7.mjs +0 -453
- package/dist/lib/node-esm/chunk-AXWVDOP7.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-L4PBAJDP.mjs +0 -514
- package/dist/lib/node-esm/chunk-L4PBAJDP.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-YTNLFBIK.mjs.map +0 -7
- package/dist/lib/node-esm/query/index.mjs +0 -23
- package/dist/lib/node-esm/query/index.mjs.map +0 -7
- package/dist/types/src/internal/ast/annotation-helper.d.ts +0 -8
- package/dist/types/src/internal/ast/annotation-helper.d.ts.map +0 -1
- package/dist/types/src/internal/ast/annotations.d.ts +0 -119
- package/dist/types/src/internal/ast/annotations.d.ts.map +0 -1
- package/dist/types/src/internal/ast/annotations.test.d.ts.map +0 -1
- package/dist/types/src/internal/ast/entity-kind.d.ts.map +0 -1
- package/dist/types/src/internal/ast/index.d.ts +0 -5
- package/dist/types/src/internal/ast/index.d.ts.map +0 -1
- package/dist/types/src/internal/ast/types.d.ts +0 -6
- package/dist/types/src/internal/ast/types.d.ts.map +0 -1
- package/dist/types/src/internal/json/annotations.d.ts.map +0 -1
- package/dist/types/src/internal/json/effect-schema.test.d.ts.map +0 -1
- package/dist/types/src/internal/json/index.d.ts +0 -2
- package/dist/types/src/internal/json/index.d.ts.map +0 -1
- package/dist/types/src/internal/json/json-schema.d.ts.map +0 -1
- package/dist/types/src/internal/json/json-schema.test.d.ts.map +0 -1
- package/dist/types/src/internal/object/accessors.d.ts +0 -29
- package/dist/types/src/internal/object/accessors.d.ts.map +0 -1
- package/dist/types/src/internal/object/create.d.ts.map +0 -1
- package/dist/types/src/internal/object/create.test.d.ts +0 -2
- package/dist/types/src/internal/object/create.test.d.ts.map +0 -1
- package/dist/types/src/internal/object/entity.d.ts +0 -22
- package/dist/types/src/internal/object/entity.d.ts.map +0 -1
- package/dist/types/src/internal/object/expando.d.ts.map +0 -1
- package/dist/types/src/internal/object/meta.d.ts.map +0 -1
- package/dist/types/src/internal/object/model.d.ts +0 -117
- package/dist/types/src/internal/object/model.d.ts.map +0 -1
- package/dist/types/src/internal/object/relation.d.ts +0 -17
- package/dist/types/src/internal/object/relation.d.ts.map +0 -1
- package/dist/types/src/internal/object/typed-relation.d.ts +0 -32
- package/dist/types/src/internal/object/typed-relation.d.ts.map +0 -1
- package/dist/types/src/internal/object/typename.d.ts +0 -15
- package/dist/types/src/internal/object/typename.d.ts.map +0 -1
- package/dist/types/src/internal/object/version.d.ts.map +0 -1
- package/dist/types/src/internal/projection/compose.d.ts.map +0 -1
- package/dist/types/src/internal/projection/compose.test.d.ts.map +0 -1
- package/dist/types/src/internal/projection/index.d.ts +0 -2
- package/dist/types/src/internal/projection/index.d.ts.map +0 -1
- package/dist/types/src/internal/proxy/reactive-object.d.ts +0 -15
- package/dist/types/src/internal/proxy/reactive-object.d.ts.map +0 -1
- package/dist/types/src/internal/query/index.d.ts +0 -2
- package/dist/types/src/internal/query/index.d.ts.map +0 -1
- package/dist/types/src/internal/query/query.d.ts.map +0 -1
- package/dist/types/src/internal/schema/stored-schema.d.ts +0 -13
- package/dist/types/src/internal/schema/stored-schema.d.ts.map +0 -1
- package/dist/types/src/internal/testing/index.d.ts +0 -3
- package/dist/types/src/internal/testing/index.d.ts.map +0 -1
- package/dist/types/src/internal/testing/types.d.ts +0 -455
- package/dist/types/src/internal/testing/types.d.ts.map +0 -1
- package/dist/types/src/internal/testing/utils.d.ts.map +0 -1
- package/dist/types/src/internal/types/types.d.ts +0 -79
- package/dist/types/src/internal/types/types.d.ts.map +0 -1
- package/dist/types/src/internal/types/types.test.d.ts +0 -2
- package/dist/types/src/internal/types/types.test.d.ts.map +0 -1
- package/dist/types/src/internal/types/util.d.ts +0 -5
- package/dist/types/src/internal/types/util.d.ts.map +0 -1
- package/dist/types/src/query/tag.d.ts +0 -18
- package/dist/types/src/query/tag.d.ts.map +0 -1
- package/dist/types/src/testing/echo-schema.d.ts +0 -7
- package/dist/types/src/testing/echo-schema.d.ts.map +0 -1
- package/dist/types/src/testing/types.d.ts +0 -113
- package/dist/types/src/testing/types.d.ts.map +0 -1
- package/src/internal/ast/annotation-helper.ts +0 -22
- package/src/internal/ast/annotations.ts +0 -212
- package/src/internal/ast/index.ts +0 -8
- package/src/internal/ast/types.ts +0 -17
- package/src/internal/json/index.ts +0 -5
- package/src/internal/object/accessors.ts +0 -115
- package/src/internal/object/entity.ts +0 -204
- package/src/internal/object/model.ts +0 -170
- package/src/internal/object/relation.ts +0 -24
- package/src/internal/object/typed-relation.ts +0 -85
- package/src/internal/object/typename.ts +0 -61
- package/src/internal/object/version.ts +0 -22
- package/src/internal/projection/index.ts +0 -5
- package/src/internal/query/index.ts +0 -5
- package/src/internal/schema/stored-schema.ts +0 -26
- package/src/internal/testing/index.ts +0 -6
- package/src/internal/testing/types.ts +0 -211
- package/src/internal/types/types.test.ts +0 -48
- package/src/internal/types/types.ts +0 -176
- package/src/internal/types/util.ts +0 -9
- package/src/query/tag.ts +0 -35
- package/src/test/api.test.ts +0 -180
- package/src/testing/echo-schema.ts +0 -39
- package/src/testing/types.ts +0 -91
- /package/dist/types/src/internal/{ast → annotations}/annotations.test.d.ts +0 -0
- /package/dist/types/src/internal/{json → json-schema}/annotations.d.ts +0 -0
- /package/dist/types/src/internal/{json → json-schema}/effect-schema.test.d.ts +0 -0
- /package/dist/types/src/internal/{json → json-schema}/json-schema.test.d.ts +0 -0
- /package/dist/types/src/internal/{projection → schema}/compose.d.ts +0 -0
- /package/dist/types/src/internal/{projection → schema}/compose.test.d.ts +0 -0
- /package/dist/types/src/{test → testing}/api.test.d.ts +0 -0
- /package/src/internal/{json → json-schema}/effect-schema.test.ts +0 -0
- /package/src/{internal/query/query.ts → query/types.ts} +0 -0
|
@@ -12,7 +12,7 @@ import type * as Types from 'effect/Types';
|
|
|
12
12
|
|
|
13
13
|
import { raise } from '@dxos/debug';
|
|
14
14
|
import { mapAst } from '@dxos/effect';
|
|
15
|
-
import { invariant } from '@dxos/invariant';
|
|
15
|
+
import { assertArgument, invariant } from '@dxos/invariant';
|
|
16
16
|
import { DXN, ObjectId } from '@dxos/keys';
|
|
17
17
|
import { log } from '@dxos/log';
|
|
18
18
|
import { clearUndefined, orderKeys, removeProperties } from '@dxos/util';
|
|
@@ -21,33 +21,20 @@ import {
|
|
|
21
21
|
type TypeAnnotation,
|
|
22
22
|
TypeAnnotationId,
|
|
23
23
|
TypeIdentifierAnnotationId,
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
} from '../
|
|
27
|
-
import {
|
|
24
|
+
makeTypeJsonSchemaAnnotation,
|
|
25
|
+
} from '../annotations';
|
|
26
|
+
import { Expando } from '../entities';
|
|
27
|
+
import { type JsonSchemaReferenceInfo, Ref, createEchoReferenceSchema } from '../ref';
|
|
28
|
+
import { EntityKind, EntityKindSchema } from '../types';
|
|
29
|
+
|
|
30
|
+
import { CustomAnnotations, DecodedAnnotations, EchoAnnotations } from './annotations';
|
|
28
31
|
import {
|
|
29
32
|
ECHO_ANNOTATIONS_NS_DEPRECATED_KEY,
|
|
30
33
|
ECHO_ANNOTATIONS_NS_KEY,
|
|
31
34
|
type JsonSchemaEchoAnnotations,
|
|
32
35
|
type JsonSchemaType,
|
|
33
36
|
getNormalizedEchoAnnotations,
|
|
34
|
-
} from '
|
|
35
|
-
import { Expando } from '../object';
|
|
36
|
-
import { type JsonSchemaReferenceInfo, Ref, createEchoReferenceSchema } from '../ref';
|
|
37
|
-
|
|
38
|
-
import { CustomAnnotations, DecodedAnnotations, EchoAnnotations } from './annotations';
|
|
39
|
-
|
|
40
|
-
/**
|
|
41
|
-
* Create object jsonSchema.
|
|
42
|
-
*/
|
|
43
|
-
export const createJsonSchema = (schema: Schema.Struct<any> = Schema.Struct({})): JsonSchemaType => {
|
|
44
|
-
const jsonSchema = _toJsonSchema(schema);
|
|
45
|
-
|
|
46
|
-
// TODO(dmaretskyi): Fix those in the serializer.
|
|
47
|
-
jsonSchema.type = 'object';
|
|
48
|
-
delete jsonSchema.anyOf;
|
|
49
|
-
return jsonSchema;
|
|
50
|
-
};
|
|
37
|
+
} from './json-schema-type';
|
|
51
38
|
|
|
52
39
|
// TODO(burdon): Are these values stored (can they be changed?)
|
|
53
40
|
export enum PropType {
|
|
@@ -89,10 +76,14 @@ export type JsonSchemaOptions = {
|
|
|
89
76
|
|
|
90
77
|
/**
|
|
91
78
|
* Convert effect schema to JSON Schema.
|
|
79
|
+
* NOTE: This handles custom annotations.
|
|
92
80
|
* @param schema
|
|
93
81
|
*/
|
|
82
|
+
// TODO(burdon): Reconcile with possibly extending @effect/Schema/JSONSchema
|
|
83
|
+
// We add additional propertyOrder (but the object properties ARE ordered); and type "string" for literals.
|
|
94
84
|
export const toJsonSchema = (schema: Schema.Schema.All, options: JsonSchemaOptions = {}): JsonSchemaType => {
|
|
95
|
-
|
|
85
|
+
assertArgument(Schema.isSchema(schema), 'schema');
|
|
86
|
+
let jsonSchema = _toJsonSchemaAST(schema.ast);
|
|
96
87
|
if (options.strict) {
|
|
97
88
|
// TOOD(burdon): Workaround to ensure JSON schema is valid (for agv parsing).
|
|
98
89
|
jsonSchema = removeProperties(jsonSchema, (key, value) => {
|
|
@@ -113,71 +104,13 @@ export const toJsonSchema = (schema: Schema.Schema.All, options: JsonSchemaOptio
|
|
|
113
104
|
return jsonSchema;
|
|
114
105
|
};
|
|
115
106
|
|
|
116
|
-
const
|
|
117
|
-
|
|
118
|
-
const
|
|
119
|
-
let jsonSchema = JSONSchema.fromAST(withRefinements, {
|
|
107
|
+
const _toJsonSchemaAST = (ast: SchemaAST.AST): JsonSchemaType => {
|
|
108
|
+
const withRefinements = withEchoRefinements(ast, '#');
|
|
109
|
+
const jsonSchema = JSONSchema.fromAST(withRefinements, {
|
|
120
110
|
definitions: {},
|
|
121
111
|
}) as JsonSchemaType;
|
|
122
112
|
|
|
123
|
-
jsonSchema
|
|
124
|
-
|
|
125
|
-
if (jsonSchema.properties && 'id' in jsonSchema.properties) {
|
|
126
|
-
jsonSchema.properties = orderKeys(jsonSchema.properties, ['id']); // Put id first.
|
|
127
|
-
}
|
|
128
|
-
|
|
129
|
-
const echoIdentifier = getTypeIdentifierAnnotation(schema);
|
|
130
|
-
if (echoIdentifier) {
|
|
131
|
-
jsonSchema.$id = echoIdentifier;
|
|
132
|
-
}
|
|
133
|
-
|
|
134
|
-
const objectAnnotation = getTypeAnnotation(schema);
|
|
135
|
-
if (objectAnnotation) {
|
|
136
|
-
// EchoIdentifier annotation takes precedence but the id can also be defined by the typename.
|
|
137
|
-
if (!jsonSchema.$id) {
|
|
138
|
-
// TODO(dmaretskyi): Should this include the version?
|
|
139
|
-
jsonSchema.$id = DXN.fromTypename(objectAnnotation.typename).toString();
|
|
140
|
-
}
|
|
141
|
-
jsonSchema.entityKind = objectAnnotation.kind;
|
|
142
|
-
jsonSchema.version = objectAnnotation.version;
|
|
143
|
-
jsonSchema.typename = objectAnnotation.typename;
|
|
144
|
-
if (jsonSchema.entityKind === EntityKind.Relation) {
|
|
145
|
-
jsonSchema.relationTarget = {
|
|
146
|
-
$ref: objectAnnotation.sourceSchema,
|
|
147
|
-
};
|
|
148
|
-
jsonSchema.relationSource = {
|
|
149
|
-
$ref: objectAnnotation.targetSchema,
|
|
150
|
-
};
|
|
151
|
-
}
|
|
152
|
-
}
|
|
153
|
-
|
|
154
|
-
// Fix field order.
|
|
155
|
-
// TODO(dmaretskyi): Makes sure undefined is not left on optional fields for the resulting object.
|
|
156
|
-
// TODO(dmaretskyi): `orderFields` util.
|
|
157
|
-
jsonSchema = orderKeys(jsonSchema, [
|
|
158
|
-
'$schema',
|
|
159
|
-
'$id',
|
|
160
|
-
|
|
161
|
-
'entityKind',
|
|
162
|
-
'typename',
|
|
163
|
-
'version',
|
|
164
|
-
'relationTarget',
|
|
165
|
-
'relationSource',
|
|
166
|
-
|
|
167
|
-
'type',
|
|
168
|
-
'enum',
|
|
169
|
-
|
|
170
|
-
'properties',
|
|
171
|
-
'required',
|
|
172
|
-
'propertyOrder', // Custom.
|
|
173
|
-
'items',
|
|
174
|
-
'additionalProperties',
|
|
175
|
-
|
|
176
|
-
'anyOf',
|
|
177
|
-
'oneOf',
|
|
178
|
-
]);
|
|
179
|
-
|
|
180
|
-
return jsonSchema;
|
|
113
|
+
return normalizeJsonSchema(jsonSchema);
|
|
181
114
|
};
|
|
182
115
|
|
|
183
116
|
const withEchoRefinements = (
|
|
@@ -201,7 +134,7 @@ const withEchoRefinements = (
|
|
|
201
134
|
},
|
|
202
135
|
});
|
|
203
136
|
} else {
|
|
204
|
-
const jsonSchema =
|
|
137
|
+
const jsonSchema = _toJsonSchemaAST(suspendedAst);
|
|
205
138
|
recursiveResult = new SchemaAST.Suspend(() => withEchoRefinements(suspendedAst, path, suspendCache), {
|
|
206
139
|
[SchemaAST.JSONSchemaAnnotationId]: jsonSchema,
|
|
207
140
|
});
|
|
@@ -421,6 +354,7 @@ const refToEffectSchema = (root: any): Schema.Schema.AnyNoContext => {
|
|
|
421
354
|
if (!('reference' in root)) {
|
|
422
355
|
return Ref(Expando);
|
|
423
356
|
}
|
|
357
|
+
|
|
424
358
|
const reference: JsonSchemaReferenceInfo = root.reference;
|
|
425
359
|
if (typeof reference !== 'object') {
|
|
426
360
|
throw new Error('Invalid reference field in ref schema');
|
|
@@ -528,7 +462,17 @@ const jsonSchemaFieldsToAnnotations = (schema: JsonSchemaType): SchemaAST.Annota
|
|
|
528
462
|
}
|
|
529
463
|
|
|
530
464
|
annotations[TypeIdentifierAnnotationId] = decodeTypeIdentifierAnnotation(schema);
|
|
531
|
-
|
|
465
|
+
const typeAnnotation = decodeTypeAnnotation(schema);
|
|
466
|
+
if (typeAnnotation) {
|
|
467
|
+
annotations[TypeAnnotationId] = typeAnnotation;
|
|
468
|
+
annotations[SchemaAST.JSONSchemaAnnotationId] = makeTypeJsonSchemaAnnotation({
|
|
469
|
+
kind: typeAnnotation.kind,
|
|
470
|
+
typename: typeAnnotation.typename,
|
|
471
|
+
version: typeAnnotation.version,
|
|
472
|
+
relationSource: typeAnnotation.sourceSchema,
|
|
473
|
+
relationTarget: typeAnnotation.targetSchema,
|
|
474
|
+
});
|
|
475
|
+
}
|
|
532
476
|
|
|
533
477
|
// Custom (at end).
|
|
534
478
|
for (const [key, annotationId] of Object.entries({ ...CustomAnnotations, ...DecodedAnnotations })) {
|
|
@@ -546,3 +490,39 @@ const makeAnnotatedRefinement = (ast: SchemaAST.AST, annotations: SchemaAST.Anno
|
|
|
546
490
|
|
|
547
491
|
const addJsonSchemaFields = (ast: SchemaAST.AST, schema: JsonSchemaType): SchemaAST.AST =>
|
|
548
492
|
makeAnnotatedRefinement(ast, { [SchemaAST.JSONSchemaAnnotationId]: schema });
|
|
493
|
+
|
|
494
|
+
/**
|
|
495
|
+
* Fixes field order.
|
|
496
|
+
* Sets `$schema` prop.
|
|
497
|
+
*/
|
|
498
|
+
const normalizeJsonSchema = (jsonSchema: JsonSchemaType): JsonSchemaType => {
|
|
499
|
+
if (jsonSchema.properties && 'id' in jsonSchema.properties) {
|
|
500
|
+
jsonSchema.properties = orderKeys(jsonSchema.properties, ['id']); // Put id first.
|
|
501
|
+
}
|
|
502
|
+
|
|
503
|
+
// TODO(dmaretskyi): Makes sure undefined is not left on optional fields for the resulting object.
|
|
504
|
+
jsonSchema.$schema = JSON_SCHEMA_URL;
|
|
505
|
+
jsonSchema = orderKeys(jsonSchema, [
|
|
506
|
+
'$schema',
|
|
507
|
+
'$id',
|
|
508
|
+
|
|
509
|
+
'entityKind',
|
|
510
|
+
'typename',
|
|
511
|
+
'version',
|
|
512
|
+
'relationTarget',
|
|
513
|
+
'relationSource',
|
|
514
|
+
|
|
515
|
+
'type',
|
|
516
|
+
'enum',
|
|
517
|
+
|
|
518
|
+
'properties',
|
|
519
|
+
'required',
|
|
520
|
+
'propertyOrder', // Custom.
|
|
521
|
+
'items',
|
|
522
|
+
'additionalProperties',
|
|
523
|
+
|
|
524
|
+
'anyOf',
|
|
525
|
+
'oneOf',
|
|
526
|
+
]);
|
|
527
|
+
return jsonSchema;
|
|
528
|
+
};
|
|
@@ -4,9 +4,8 @@
|
|
|
4
4
|
|
|
5
5
|
import * as Schema from 'effect/Schema';
|
|
6
6
|
|
|
7
|
-
import {
|
|
8
|
-
|
|
9
|
-
import { getTypename } from './typename';
|
|
7
|
+
import { getTypename } from '../annotations';
|
|
8
|
+
import { type AnyProperties } from '../types';
|
|
10
9
|
|
|
11
10
|
// TODO(dmaretskyi): Rename to represent commonality between objects and relations (e.g. `entity`).
|
|
12
11
|
export type TypedObjectOptions = {
|
|
@@ -58,7 +57,7 @@ export const makeTypedEntityClass = (
|
|
|
58
57
|
static readonly pipe = baseSchema.pipe.bind(baseSchema);
|
|
59
58
|
|
|
60
59
|
// TODO(burdon): Comment required.
|
|
61
|
-
static [Symbol.hasInstance](obj:
|
|
60
|
+
static [Symbol.hasInstance](obj: AnyProperties) {
|
|
62
61
|
return obj != null && getTypename(obj) === typename;
|
|
63
62
|
}
|
|
64
63
|
|
|
@@ -9,15 +9,14 @@ import { describe, expect, test } from 'vitest';
|
|
|
9
9
|
|
|
10
10
|
import { DXN } from '@dxos/keys';
|
|
11
11
|
|
|
12
|
-
import {
|
|
13
|
-
import {
|
|
14
|
-
import { isInstanceOf } from '../
|
|
12
|
+
import { Relation } from '../../index';
|
|
13
|
+
import { TestSchema } from '../../testing';
|
|
14
|
+
import { getSchemaDXN, getTypeDXN, isInstanceOf } from '../annotations';
|
|
15
|
+
import { ATTR_RELATION_SOURCE, ATTR_RELATION_TARGET } from '../entities';
|
|
16
|
+
import { ATTR_META, ATTR_TYPE, getSchema } from '../types';
|
|
15
17
|
|
|
16
|
-
import {
|
|
17
|
-
import { create } from './create';
|
|
18
|
+
import { createObject } from './create-object';
|
|
18
19
|
import { objectToJSON } from './json-serializer';
|
|
19
|
-
import { RelationSourceId, RelationTargetId } from './model';
|
|
20
|
-
import { getType } from './typename';
|
|
21
20
|
|
|
22
21
|
describe('create (static version)', () => {
|
|
23
22
|
test('defaults', ({ expect }) => {
|
|
@@ -34,7 +33,7 @@ describe('create (static version)', () => {
|
|
|
34
33
|
});
|
|
35
34
|
|
|
36
35
|
test('create static object', () => {
|
|
37
|
-
const contact =
|
|
36
|
+
const contact = createObject(TestSchema.Person, {
|
|
38
37
|
name: 'Bot',
|
|
39
38
|
email: 'bot@example.com',
|
|
40
39
|
});
|
|
@@ -43,12 +42,12 @@ describe('create (static version)', () => {
|
|
|
43
42
|
expect(contact.name).toBe('Bot');
|
|
44
43
|
expect(contact.email).toBe('bot@example.com');
|
|
45
44
|
expect((contact as any)['@type']).toBeUndefined();
|
|
46
|
-
expect(
|
|
47
|
-
expect(isInstanceOf(
|
|
45
|
+
expect(getTypeDXN(contact)?.toString()).toBe(getSchemaDXN(TestSchema.Person)!.toString());
|
|
46
|
+
expect(isInstanceOf(TestSchema.Person, contact)).toBe(true);
|
|
48
47
|
});
|
|
49
48
|
|
|
50
49
|
test('JSON encoding', () => {
|
|
51
|
-
const contact =
|
|
50
|
+
const contact = createObject(TestSchema.Person, {
|
|
52
51
|
name: 'Bot',
|
|
53
52
|
email: 'bot@example.com',
|
|
54
53
|
});
|
|
@@ -56,7 +55,7 @@ describe('create (static version)', () => {
|
|
|
56
55
|
const json = JSON.parse(JSON.stringify(contact));
|
|
57
56
|
expect(json).toEqual({
|
|
58
57
|
id: contact.id,
|
|
59
|
-
'@type': DXN.fromTypenameAndVersion(
|
|
58
|
+
'@type': DXN.fromTypenameAndVersion(TestSchema.Person.typename, TestSchema.Person.version).toString(),
|
|
60
59
|
'@meta': {
|
|
61
60
|
keys: [],
|
|
62
61
|
},
|
|
@@ -67,52 +66,51 @@ describe('create (static version)', () => {
|
|
|
67
66
|
});
|
|
68
67
|
|
|
69
68
|
test('JSON encoding with relation', () => {
|
|
70
|
-
const
|
|
71
|
-
name: '
|
|
72
|
-
email: '
|
|
69
|
+
const person1 = createObject(TestSchema.Person, {
|
|
70
|
+
name: 'Alice',
|
|
71
|
+
email: 'alice@example.com',
|
|
73
72
|
});
|
|
74
|
-
const
|
|
75
|
-
name: '
|
|
76
|
-
email: '
|
|
73
|
+
const person2 = createObject(TestSchema.Person, {
|
|
74
|
+
name: 'Bob',
|
|
75
|
+
email: 'bob@example.com',
|
|
77
76
|
});
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
[
|
|
77
|
+
|
|
78
|
+
const manager = createObject(TestSchema.HasManager, {
|
|
79
|
+
[Relation.Source]: person1 as any,
|
|
80
|
+
[Relation.Target]: person2 as any,
|
|
81
81
|
});
|
|
82
82
|
|
|
83
|
-
const json = JSON.parse(JSON.stringify(
|
|
83
|
+
const json = JSON.parse(JSON.stringify(manager));
|
|
84
84
|
expect(json).toEqual({
|
|
85
|
-
id:
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
85
|
+
id: manager.id,
|
|
86
|
+
[ATTR_TYPE]: DXN.fromTypenameAndVersion(TestSchema.HasManager.typename, TestSchema.HasManager.version).toString(),
|
|
87
|
+
[ATTR_RELATION_SOURCE]: DXN.fromLocalObjectId(person1.id).toString(),
|
|
88
|
+
[ATTR_RELATION_TARGET]: DXN.fromLocalObjectId(person2.id).toString(),
|
|
89
|
+
[ATTR_META]: {
|
|
90
90
|
keys: [],
|
|
91
91
|
},
|
|
92
92
|
});
|
|
93
93
|
});
|
|
94
94
|
|
|
95
95
|
test('getSchema', () => {
|
|
96
|
-
const contact =
|
|
96
|
+
const contact = createObject(TestSchema.Person, {
|
|
97
97
|
name: 'Bot',
|
|
98
98
|
email: 'bot@example.com',
|
|
99
99
|
});
|
|
100
100
|
|
|
101
|
-
expect(getSchema(contact)).toBe(
|
|
101
|
+
expect(getSchema(contact)).toBe(TestSchema.Person);
|
|
102
102
|
});
|
|
103
103
|
|
|
104
104
|
test('inspect', () => {
|
|
105
|
-
const contact =
|
|
105
|
+
const contact = createObject(TestSchema.Person, {
|
|
106
106
|
name: 'Bot',
|
|
107
107
|
email: 'bot@example.com',
|
|
108
108
|
});
|
|
109
109
|
|
|
110
|
-
// console.log(contact);
|
|
111
|
-
|
|
112
110
|
const text = inspect(contact);
|
|
113
111
|
expect(text).toContain('Bot');
|
|
114
112
|
expect(text).toContain('bot@example.com');
|
|
115
|
-
expect(text).toContain('example.com/type/
|
|
113
|
+
expect(text).toContain('example.com/type/Person');
|
|
116
114
|
expect(text).toContain('0.1.0');
|
|
117
115
|
});
|
|
118
116
|
});
|
|
@@ -9,31 +9,28 @@ import { assertArgument, failedInvariant } from '@dxos/invariant';
|
|
|
9
9
|
import { ObjectId } from '@dxos/keys';
|
|
10
10
|
import { defineHiddenProperty } from '@dxos/live-object';
|
|
11
11
|
|
|
12
|
-
import {
|
|
13
|
-
|
|
14
|
-
import { getObjectDXN, setSchema } from './accessors';
|
|
15
|
-
import { attachedTypedObjectInspector } from './inspect';
|
|
16
|
-
import { attachTypedJsonSerializer } from './json-serializer';
|
|
12
|
+
import { getSchemaDXN, getTypeAnnotation, setTypename } from '../annotations';
|
|
17
13
|
import {
|
|
18
|
-
EntityKindId,
|
|
19
|
-
MetaId,
|
|
20
14
|
RelationSourceDXNId,
|
|
21
15
|
RelationSourceId,
|
|
22
16
|
RelationTargetDXNId,
|
|
23
17
|
RelationTargetId,
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
18
|
+
assertObjectModel,
|
|
19
|
+
getObjectDXN,
|
|
20
|
+
} from '../entities';
|
|
21
|
+
import { EntityKind, KindId, MetaId, setSchema } from '../types';
|
|
22
|
+
|
|
23
|
+
import { attachedTypedObjectInspector } from './inspect';
|
|
24
|
+
import { attachTypedJsonSerializer } from './json-serializer';
|
|
27
25
|
|
|
28
|
-
|
|
29
|
-
type CreateData<T> = T extends { id: string } ? Omit<T, 'id' | typeof EntityKindId> & { id?: string } : T;
|
|
26
|
+
export type CreateObjectProps<T> = T extends { id: string } ? Omit<T, 'id' | KindId> & { id?: string } : T;
|
|
30
27
|
|
|
31
28
|
/**
|
|
32
29
|
* Creates a new object instance from a schema and data, without signal reactivity.
|
|
33
30
|
* This static version creates plain JavaScript objects that are not reactive/observable.
|
|
34
31
|
* For reactive objects that automatically update UI when changed, use the regular live() function.
|
|
35
32
|
*
|
|
36
|
-
* @param schema - The Effect schema that defines the object's structure and type, piped into
|
|
33
|
+
* @param schema - The Effect schema that defines the object's structure and type, piped into EchoObjectSchema
|
|
37
34
|
* @param data - The data to initialize the object with. The id and @type fields are handled automatically.
|
|
38
35
|
* @returns A new non-reactive object instance conforming to the schema
|
|
39
36
|
* @throws {Error} If the schema is not an object schema
|
|
@@ -45,52 +42,54 @@ type CreateData<T> = T extends { id: string } ? Omit<T, 'id' | typeof EntityKind
|
|
|
45
42
|
* name: Schema.String,
|
|
46
43
|
* email: Schema.String,
|
|
47
44
|
* }).pipe(Type.Obj({
|
|
48
|
-
* typename: 'example.com/type/
|
|
45
|
+
* typename: 'example.com/type/Person',
|
|
49
46
|
* version: '0.1.0',
|
|
50
47
|
* }))
|
|
51
48
|
*
|
|
52
|
-
*
|
|
53
|
-
* const contact = create(Contact, {
|
|
49
|
+
* const contact = createObject(Contact, {
|
|
54
50
|
* name: "John",
|
|
55
51
|
* email: "john@example.com",
|
|
56
52
|
* })
|
|
57
53
|
* ```
|
|
58
54
|
*/
|
|
59
|
-
// TODO(burdon):
|
|
60
|
-
|
|
61
|
-
// TODO(dmaretskyi): Use `Obj.make` and `Relation.make` from '@dxos/echo' instead.
|
|
62
|
-
export const create = <S extends Schema.Schema.AnyNoContext>(
|
|
55
|
+
// TODO(burdon): Make internal.
|
|
56
|
+
export const createObject = <S extends Schema.Schema.AnyNoContext>(
|
|
63
57
|
schema: S,
|
|
64
|
-
|
|
65
|
-
):
|
|
58
|
+
props: CreateObjectProps<Schema.Schema.Type<S>>,
|
|
59
|
+
): CreateObjectProps<Schema.Schema.Type<S>> & { id: string; [KindId]: EntityKind } => {
|
|
66
60
|
const annotation = getTypeAnnotation(schema);
|
|
67
61
|
if (!annotation) {
|
|
68
|
-
throw new Error('Schema is not an
|
|
62
|
+
throw new Error('Schema is not an ECHO schema');
|
|
69
63
|
}
|
|
70
|
-
assertArgument(!('@type' in
|
|
71
|
-
assertArgument(!(RelationSourceDXNId in
|
|
72
|
-
assertArgument(!(RelationTargetDXNId in
|
|
64
|
+
assertArgument(!('@type' in props), 'data', '@type is not allowed');
|
|
65
|
+
assertArgument(!(RelationSourceDXNId in props), 'data', 'Relation source DXN is not allowed in the constructor');
|
|
66
|
+
assertArgument(!(RelationTargetDXNId in props), 'data', 'Relation target DXN is not allowed in the constructor');
|
|
73
67
|
assertArgument(
|
|
74
|
-
RelationSourceId in
|
|
68
|
+
RelationSourceId in props === RelationTargetId in props,
|
|
75
69
|
'data',
|
|
76
70
|
'Relation source and target must be provided together',
|
|
77
71
|
);
|
|
78
72
|
|
|
79
|
-
|
|
80
|
-
const
|
|
81
|
-
|
|
82
|
-
|
|
73
|
+
// Raw object.
|
|
74
|
+
const obj = { ...props, id: props.id ?? ObjectId.random() };
|
|
75
|
+
|
|
76
|
+
// Metadata.
|
|
77
|
+
const kind = RelationSourceId in props ? EntityKind.Relation : EntityKind.Object;
|
|
78
|
+
defineHiddenProperty(obj, KindId, kind);
|
|
79
|
+
defineHiddenProperty(obj, MetaId, { keys: [] });
|
|
83
80
|
setSchema(obj, schema);
|
|
81
|
+
setTypename(obj, getSchemaDXN(schema) ?? failedInvariant('Missing schema DXN'));
|
|
84
82
|
attachTypedJsonSerializer(obj);
|
|
85
83
|
attachedTypedObjectInspector(obj);
|
|
86
|
-
|
|
84
|
+
|
|
85
|
+
// Relation.
|
|
87
86
|
if (kind === EntityKind.Relation) {
|
|
88
|
-
const sourceDXN = getObjectDXN(
|
|
89
|
-
const targetDXN = getObjectDXN(
|
|
87
|
+
const sourceDXN = getObjectDXN(props[RelationSourceId]) ?? raise(new Error('Unresolved relation source'));
|
|
88
|
+
const targetDXN = getObjectDXN(props[RelationTargetId]) ?? raise(new Error('Unresolved relation target'));
|
|
90
89
|
defineHiddenProperty(obj, RelationSourceDXNId, sourceDXN);
|
|
91
90
|
defineHiddenProperty(obj, RelationTargetDXNId, targetDXN);
|
|
92
91
|
}
|
|
93
92
|
|
|
94
|
-
|
|
93
|
+
assertObjectModel(obj);
|
|
95
94
|
return obj;
|
|
96
95
|
};
|
|
@@ -2,18 +2,18 @@
|
|
|
2
2
|
// Copyright 2025 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import
|
|
6
|
-
|
|
7
|
-
import { DeletedId } from './model';
|
|
5
|
+
import { ObjectDeletedId } from '../entities';
|
|
6
|
+
import { type AnyProperties } from '../types';
|
|
8
7
|
|
|
9
8
|
/**
|
|
10
9
|
* @returns `true` if the object has been marked as deleted.
|
|
11
10
|
*/
|
|
12
|
-
export const isDeleted = (obj:
|
|
13
|
-
if ((obj as any)[
|
|
11
|
+
export const isDeleted = (obj: AnyProperties): boolean => {
|
|
12
|
+
if ((obj as any)[ObjectDeletedId] === undefined) {
|
|
14
13
|
// TODO(dmaretskyi): Return to prior behavior of throwing.
|
|
15
14
|
// throw new Error('Object does not support deletion marker');
|
|
16
15
|
return false;
|
|
17
16
|
}
|
|
18
|
-
|
|
17
|
+
|
|
18
|
+
return (obj as any)[ObjectDeletedId] ?? false;
|
|
19
19
|
};
|
|
@@ -4,9 +4,9 @@
|
|
|
4
4
|
|
|
5
5
|
import { DXN, ObjectId, QueueSubspaceTags, SpaceId } from '@dxos/keys';
|
|
6
6
|
|
|
7
|
-
// TODO(burdon): Move to @dxos/keys once ObjectId is moved there.
|
|
8
7
|
/**
|
|
9
8
|
* @deprecated Use `db.queues.create()`
|
|
10
9
|
*/
|
|
10
|
+
// TODO(burdon): Move to @dxos/keys.
|
|
11
11
|
export const createQueueDXN = (spaceId = SpaceId.random(), queueId = ObjectId.random()) =>
|
|
12
12
|
new DXN(DXN.kind.QUEUE, [QueueSubspaceTags.DATA, spaceId, queueId]);
|
|
@@ -3,18 +3,9 @@
|
|
|
3
3
|
//
|
|
4
4
|
|
|
5
5
|
export * from './common';
|
|
6
|
-
export * from './create';
|
|
7
|
-
export * from './
|
|
8
|
-
export * from './expando';
|
|
6
|
+
export * from './create-object';
|
|
7
|
+
export * from './deleted';
|
|
9
8
|
export * from './ids';
|
|
10
9
|
export * from './json-serializer';
|
|
11
|
-
export * from './meta';
|
|
12
|
-
export type * from './relation';
|
|
13
|
-
export * from './typed-object';
|
|
14
|
-
export * from './typed-relation';
|
|
15
|
-
export * from './typename';
|
|
16
|
-
export * from './deleted';
|
|
17
|
-
export * from './model';
|
|
18
|
-
export * from './accessors';
|
|
19
10
|
export * from './schema-validator';
|
|
20
|
-
export * from './
|
|
11
|
+
export * from './typed-object';
|
|
@@ -6,10 +6,8 @@ import type { InspectOptionsStylized, inspect as inspectFn } from 'node:util';
|
|
|
6
6
|
|
|
7
7
|
import { type CustomInspectFunction, inspectCustom } from '@dxos/debug';
|
|
8
8
|
|
|
9
|
-
import {
|
|
10
|
-
|
|
11
|
-
import { ATTR_META, ATTR_TYPE, MetaId } from './model';
|
|
12
|
-
import { getType } from './typename';
|
|
9
|
+
import { getTypeDXN } from '../annotations';
|
|
10
|
+
import { ATTR_META, ATTR_TYPE, type AnyEchoObject, MetaId } from '../types';
|
|
13
11
|
|
|
14
12
|
/*
|
|
15
13
|
* @internal
|
|
@@ -39,7 +37,7 @@ const typedObjectInspectFunction: CustomInspectFunction<AnyEchoObject> = functio
|
|
|
39
37
|
return inspect(
|
|
40
38
|
{
|
|
41
39
|
id,
|
|
42
|
-
[ATTR_TYPE]:
|
|
40
|
+
[ATTR_TYPE]: getTypeDXN(this),
|
|
43
41
|
...props,
|
|
44
42
|
[ATTR_META]: (this as any)[MetaId], // TODO(dmaretskyi): Couldn't use getMeta since that throw's if the object has no meta.
|
|
45
43
|
},
|