@dxos/echo 0.8.4-main.fffef41 → 0.8.4-staging.ac66bdf99f
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 +3 -4
- package/dist/lib/neutral/Annotation.mjs +37 -0
- package/dist/lib/neutral/Database.mjs +49 -0
- package/dist/lib/neutral/Entity.mjs +61 -0
- package/dist/lib/neutral/Err.mjs +12 -0
- package/dist/lib/neutral/Extension.mjs +18 -0
- package/dist/lib/neutral/Feed.mjs +50 -0
- package/dist/lib/neutral/Filter.mjs +72 -0
- package/dist/lib/neutral/Filter.mjs.map +7 -0
- package/dist/lib/neutral/Format.mjs +66 -0
- package/dist/lib/neutral/Format.mjs.map +7 -0
- package/dist/lib/neutral/JsonSchema.mjs +19 -0
- package/dist/lib/neutral/JsonSchema.mjs.map +7 -0
- package/dist/lib/neutral/Key.mjs +12 -0
- package/dist/lib/neutral/Key.mjs.map +7 -0
- package/dist/lib/neutral/Migration.mjs +17 -0
- package/dist/lib/neutral/Migration.mjs.map +7 -0
- package/dist/lib/neutral/Obj.mjs +113 -0
- package/dist/lib/neutral/Obj.mjs.map +7 -0
- package/dist/lib/neutral/Order.mjs +12 -0
- package/dist/lib/neutral/Order.mjs.map +7 -0
- package/dist/lib/neutral/Query.mjs +38 -0
- package/dist/lib/neutral/Query.mjs.map +7 -0
- package/dist/lib/neutral/QueryResult.mjs +2 -0
- package/dist/lib/neutral/QueryResult.mjs.map +7 -0
- package/dist/lib/neutral/Ref.mjs +24 -0
- package/dist/lib/neutral/Ref.mjs.map +7 -0
- package/dist/lib/neutral/Relation.mjs +94 -0
- package/dist/lib/neutral/Relation.mjs.map +7 -0
- package/dist/lib/neutral/SchemaRegistry.mjs +2 -0
- package/dist/lib/neutral/SchemaRegistry.mjs.map +7 -0
- package/dist/lib/neutral/Tag.mjs +29 -0
- package/dist/lib/neutral/Tag.mjs.map +7 -0
- package/dist/lib/neutral/Type.mjs +37 -0
- package/dist/lib/neutral/Type.mjs.map +7 -0
- package/dist/lib/neutral/chunk-2KHZ36F5.mjs +361 -0
- package/dist/lib/neutral/chunk-2KHZ36F5.mjs.map +7 -0
- package/dist/lib/neutral/chunk-4OIBYSXE.mjs +159 -0
- package/dist/lib/neutral/chunk-4OIBYSXE.mjs.map +7 -0
- package/dist/lib/neutral/chunk-4P3IXBLT.mjs +45 -0
- package/dist/lib/neutral/chunk-4P3IXBLT.mjs.map +7 -0
- package/dist/lib/neutral/chunk-7RO7CPBZ.mjs +27 -0
- package/dist/lib/neutral/chunk-7RO7CPBZ.mjs.map +7 -0
- package/dist/lib/neutral/chunk-ANHVGJI4.mjs +21 -0
- package/dist/lib/neutral/chunk-ANHVGJI4.mjs.map +7 -0
- package/dist/lib/neutral/chunk-B4BASU6W.mjs +428 -0
- package/dist/lib/neutral/chunk-B4BASU6W.mjs.map +7 -0
- package/dist/lib/neutral/chunk-BNCCGLJN.mjs +7 -0
- package/dist/lib/neutral/chunk-BNCCGLJN.mjs.map +7 -0
- package/dist/lib/neutral/chunk-BVOFLCVF.mjs +45 -0
- package/dist/lib/neutral/chunk-BVOFLCVF.mjs.map +7 -0
- package/dist/lib/neutral/chunk-DQYLD2RB.mjs +402 -0
- package/dist/lib/neutral/chunk-DQYLD2RB.mjs.map +7 -0
- package/dist/lib/neutral/chunk-EAMSSLZC.mjs +299 -0
- package/dist/lib/neutral/chunk-EAMSSLZC.mjs.map +7 -0
- package/dist/lib/neutral/chunk-G3IQMKF7.mjs +396 -0
- package/dist/lib/neutral/chunk-G3IQMKF7.mjs.map +7 -0
- package/dist/lib/neutral/chunk-GZQTCRJB.mjs +73 -0
- package/dist/lib/neutral/chunk-GZQTCRJB.mjs.map +7 -0
- package/dist/lib/neutral/chunk-HBUZJNZO.mjs +286 -0
- package/dist/lib/neutral/chunk-HBUZJNZO.mjs.map +7 -0
- package/dist/lib/neutral/chunk-J5LGTIGS.mjs +10 -0
- package/dist/lib/neutral/chunk-J5LGTIGS.mjs.map +7 -0
- package/dist/lib/neutral/chunk-JUXPFOEI.mjs +787 -0
- package/dist/lib/neutral/chunk-JUXPFOEI.mjs.map +7 -0
- package/dist/lib/neutral/chunk-MOR5ERFM.mjs +2834 -0
- package/dist/lib/neutral/chunk-MOR5ERFM.mjs.map +7 -0
- package/dist/lib/neutral/chunk-OMUPQMLR.mjs +7 -0
- package/dist/lib/neutral/chunk-OMUPQMLR.mjs.map +7 -0
- package/dist/lib/neutral/chunk-OS35K56T.mjs +34 -0
- package/dist/lib/neutral/chunk-OS35K56T.mjs.map +7 -0
- package/dist/lib/neutral/chunk-PHU22NLC.mjs +136 -0
- package/dist/lib/neutral/chunk-PHU22NLC.mjs.map +7 -0
- package/dist/lib/neutral/chunk-ROG4RXXL.mjs +97 -0
- package/dist/lib/neutral/chunk-ROG4RXXL.mjs.map +7 -0
- package/dist/lib/neutral/chunk-T6W2LEZU.mjs +125 -0
- package/dist/lib/neutral/chunk-T6W2LEZU.mjs.map +7 -0
- package/dist/lib/neutral/chunk-TBKX6JQO.mjs +67 -0
- package/dist/lib/neutral/chunk-TBKX6JQO.mjs.map +7 -0
- package/dist/lib/neutral/chunk-TU3GW67D.mjs +132 -0
- package/dist/lib/neutral/chunk-TU3GW67D.mjs.map +7 -0
- package/dist/lib/neutral/chunk-UBEZSGXY.mjs +51 -0
- package/dist/lib/neutral/chunk-UBEZSGXY.mjs.map +7 -0
- package/dist/lib/neutral/chunk-UI6MWK5W.mjs +42 -0
- package/dist/lib/neutral/chunk-UI6MWK5W.mjs.map +7 -0
- package/dist/lib/neutral/chunk-V36VO5SS.mjs +354 -0
- package/dist/lib/neutral/chunk-V36VO5SS.mjs.map +7 -0
- package/dist/lib/neutral/chunk-WAK4DMFV.mjs +36 -0
- package/dist/lib/neutral/chunk-WAK4DMFV.mjs.map +7 -0
- package/dist/lib/neutral/chunk-YAHXAYOW.mjs +56 -0
- package/dist/lib/neutral/chunk-YAHXAYOW.mjs.map +7 -0
- package/dist/lib/neutral/chunk-YS6Q3XAD.mjs +50 -0
- package/dist/lib/neutral/chunk-YS6Q3XAD.mjs.map +7 -0
- package/dist/lib/neutral/index.mjs +105 -0
- package/dist/lib/neutral/index.mjs.map +7 -0
- package/dist/lib/{node-esm → neutral}/internal/index.mjs +290 -152
- package/dist/lib/neutral/internal/index.mjs.map +7 -0
- package/dist/lib/neutral/meta.json +1 -0
- package/dist/lib/neutral/testing/index.mjs +375 -0
- package/dist/lib/neutral/testing/index.mjs.map +7 -0
- package/dist/types/src/Annotation.d.ts +24 -0
- package/dist/types/src/Annotation.d.ts.map +1 -0
- package/dist/types/src/Collection.d.ts +16 -0
- package/dist/types/src/Collection.d.ts.map +1 -0
- package/dist/types/src/Database.d.ts +201 -0
- package/dist/types/src/Database.d.ts.map +1 -0
- package/dist/types/src/Dataset.d.ts +19 -0
- package/dist/types/src/Dataset.d.ts.map +1 -0
- package/dist/types/src/Entity.d.ts +174 -0
- package/dist/types/src/Entity.d.ts.map +1 -0
- package/dist/types/src/Entity.test.d.ts +2 -0
- package/dist/types/src/Entity.test.d.ts.map +1 -0
- package/dist/types/src/Err.d.ts +107 -0
- package/dist/types/src/Err.d.ts.map +1 -0
- package/dist/types/src/Extension.d.ts +80 -0
- package/dist/types/src/Extension.d.ts.map +1 -0
- package/dist/types/src/Extension.test.d.ts +2 -0
- package/dist/types/src/Extension.test.d.ts.map +1 -0
- package/dist/types/src/Feed.d.ts +182 -0
- package/dist/types/src/Feed.d.ts.map +1 -0
- package/dist/types/src/Filter.d.ts +149 -0
- package/dist/types/src/Filter.d.ts.map +1 -0
- package/dist/types/src/Filter.test.d.ts +2 -0
- package/dist/types/src/Filter.test.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/Hypergraph.d.ts +65 -0
- package/dist/types/src/Hypergraph.d.ts.map +1 -0
- package/dist/types/src/JsonSchema.d.ts +16 -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/Migration.d.ts +57 -0
- package/dist/types/src/Migration.d.ts.map +1 -0
- package/dist/types/src/Obj.d.ts +434 -104
- package/dist/types/src/Obj.d.ts.map +1 -1
- package/dist/types/src/Obj.test.d.ts +2 -0
- package/dist/types/src/Obj.test.d.ts.map +1 -0
- package/dist/types/src/Order.d.ts +16 -0
- package/dist/types/src/Order.d.ts.map +1 -0
- package/dist/types/src/Query.d.ts +209 -0
- package/dist/types/src/Query.d.ts.map +1 -0
- package/dist/types/src/Query.test.d.ts +2 -0
- package/dist/types/src/Query.test.d.ts.map +1 -0
- package/dist/types/src/QueryResult.d.ts +80 -0
- package/dist/types/src/QueryResult.d.ts.map +1 -0
- package/dist/types/src/Ref.d.ts +61 -11
- package/dist/types/src/Ref.d.ts.map +1 -1
- package/dist/types/src/Relation.d.ts +287 -21
- package/dist/types/src/Relation.d.ts.map +1 -1
- package/dist/types/src/Relation.test.d.ts +2 -0
- package/dist/types/src/Relation.test.d.ts.map +1 -0
- package/dist/types/src/SchemaRegistry.d.ts +84 -0
- package/dist/types/src/SchemaRegistry.d.ts.map +1 -0
- package/dist/types/src/Tag.d.ts +8 -7
- package/dist/types/src/Tag.d.ts.map +1 -1
- package/dist/types/src/Type.d.ts +123 -99
- package/dist/types/src/Type.d.ts.map +1 -1
- package/dist/types/src/Type.test.d.ts +2 -0
- package/dist/types/src/Type.test.d.ts.map +1 -0
- package/dist/types/src/View.d.ts +68 -0
- package/dist/types/src/View.d.ts.map +1 -0
- package/dist/types/src/hierarchy.test.d.ts +2 -0
- package/dist/types/src/hierarchy.test.d.ts.map +1 -0
- package/dist/types/src/index.d.ts +20 -5
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/internal/Annotation/annotations.d.ts +231 -0
- package/dist/types/src/internal/Annotation/annotations.d.ts.map +1 -0
- package/dist/types/src/internal/Annotation/annotations.test.d.ts.map +1 -0
- package/dist/types/src/internal/Annotation/index.d.ts +4 -0
- package/dist/types/src/internal/Annotation/index.d.ts.map +1 -0
- package/dist/types/src/internal/Annotation/sorting.d.ts +24 -0
- package/dist/types/src/internal/Annotation/sorting.d.ts.map +1 -0
- package/dist/types/src/internal/Annotation/util.d.ts +39 -0
- package/dist/types/src/internal/Annotation/util.d.ts.map +1 -0
- package/dist/types/src/internal/Entity/api.d.ts +13 -0
- package/dist/types/src/internal/Entity/api.d.ts.map +1 -0
- package/dist/types/src/internal/Entity/entity.d.ts +20 -0
- package/dist/types/src/internal/Entity/entity.d.ts.map +1 -0
- package/dist/types/src/internal/Entity/index.d.ts +8 -0
- package/dist/types/src/internal/Entity/index.d.ts.map +1 -0
- package/dist/types/src/internal/Entity/model.d.ts +55 -0
- package/dist/types/src/internal/Entity/model.d.ts.map +1 -0
- package/dist/types/src/internal/Entity/object.d.ts +18 -0
- package/dist/types/src/internal/Entity/object.d.ts.map +1 -0
- package/dist/types/src/internal/Entity/relation.d.ts +35 -0
- package/dist/types/src/internal/Entity/relation.d.ts.map +1 -0
- package/dist/types/src/internal/Entity/util.d.ts +2 -0
- package/dist/types/src/internal/Entity/util.d.ts.map +1 -0
- package/dist/types/src/internal/Entity/version.d.ts +42 -0
- package/dist/types/src/internal/Entity/version.d.ts.map +1 -0
- package/dist/types/src/internal/Format/date.d.ts.map +1 -0
- package/dist/types/src/internal/Format/date.test.d.ts.map +1 -0
- package/dist/types/src/internal/{formats → Format}/format.d.ts +4 -2
- package/dist/types/src/internal/Format/format.d.ts.map +1 -0
- package/dist/types/src/internal/Format/format.test.d.ts.map +1 -0
- package/dist/types/src/internal/Format/index.d.ts.map +1 -0
- package/dist/types/src/internal/Format/number.d.ts.map +1 -0
- package/dist/types/src/internal/Format/object.d.ts.map +1 -0
- package/dist/types/src/internal/{formats → Format}/select.d.ts +6 -4
- package/dist/types/src/internal/Format/select.d.ts.map +1 -0
- package/dist/types/src/internal/{formats → Format}/string.d.ts +4 -0
- package/dist/types/src/internal/Format/string.d.ts.map +1 -0
- package/dist/types/src/internal/{formats → Format}/types.d.ts +14 -10
- package/dist/types/src/internal/Format/types.d.ts.map +1 -0
- package/dist/types/src/internal/{json → JsonSchema}/annotations.d.ts +1 -1
- package/dist/types/src/internal/JsonSchema/annotations.d.ts.map +1 -0
- package/dist/types/src/internal/JsonSchema/effect-schema.test.d.ts.map +1 -0
- package/dist/types/src/internal/JsonSchema/index.d.ts +5 -0
- package/dist/types/src/internal/JsonSchema/index.d.ts.map +1 -0
- package/dist/types/src/internal/JsonSchema/json-schema-normalize.d.ts.map +1 -0
- package/dist/types/src/internal/{json-schema → JsonSchema}/json-schema-type.d.ts +131 -30
- package/dist/types/src/internal/JsonSchema/json-schema-type.d.ts.map +1 -0
- package/dist/types/src/internal/{json → JsonSchema}/json-schema.d.ts +4 -2
- package/dist/types/src/internal/JsonSchema/json-schema.d.ts.map +1 -0
- package/dist/types/src/internal/JsonSchema/json-schema.test.d.ts.map +1 -0
- package/dist/types/src/internal/Obj/clone.d.ts +8 -0
- package/dist/types/src/internal/Obj/clone.d.ts.map +1 -0
- package/dist/types/src/internal/Obj/common.d.ts.map +1 -0
- package/dist/types/src/internal/{object/create.d.ts → Obj/create-object.d.ts} +10 -11
- package/dist/types/src/internal/Obj/create-object.d.ts.map +1 -0
- package/dist/types/src/internal/Obj/create-object.test.d.ts +2 -0
- package/dist/types/src/internal/Obj/create-object.test.d.ts.map +1 -0
- package/dist/types/src/internal/Obj/deleted.d.ts +6 -0
- package/dist/types/src/internal/Obj/deleted.d.ts.map +1 -0
- package/dist/types/src/internal/Obj/ids.d.ts.map +1 -0
- package/dist/types/src/internal/Obj/index.d.ts +11 -0
- package/dist/types/src/internal/Obj/index.d.ts.map +1 -0
- package/dist/types/src/internal/Obj/inspect.d.ts.map +1 -0
- package/dist/types/src/internal/Obj/json-serializer.d.ts +45 -0
- package/dist/types/src/internal/Obj/json-serializer.d.ts.map +1 -0
- package/dist/types/src/internal/Obj/json-serializer.test.d.ts.map +1 -0
- package/dist/types/src/internal/Obj/schema-validator.d.ts +2 -0
- package/dist/types/src/internal/Obj/schema-validator.d.ts.map +1 -0
- package/dist/types/src/internal/Obj/schema-validator.test.d.ts.map +1 -0
- package/dist/types/src/internal/Obj/set-value.d.ts +7 -0
- package/dist/types/src/internal/Obj/set-value.d.ts.map +1 -0
- package/dist/types/src/internal/Obj/set-value.test.d.ts +2 -0
- package/dist/types/src/internal/Obj/set-value.test.d.ts.map +1 -0
- package/dist/types/src/internal/Obj/snapshot.d.ts +6 -0
- package/dist/types/src/internal/Obj/snapshot.d.ts.map +1 -0
- package/dist/types/src/internal/Obj/typed-object.d.ts +25 -0
- package/dist/types/src/internal/Obj/typed-object.d.ts.map +1 -0
- package/dist/types/src/internal/Obj/typed-object.test.d.ts.map +1 -0
- package/dist/types/src/internal/Query.d.ts +10 -0
- package/dist/types/src/internal/Query.d.ts.map +1 -0
- package/dist/types/src/internal/Ref/index.d.ts.map +1 -0
- package/dist/types/src/internal/{ref → Ref}/ref-array.d.ts +4 -4
- package/dist/types/src/internal/Ref/ref-array.d.ts.map +1 -0
- package/dist/types/src/internal/{ref → Ref}/ref.d.ts +44 -19
- package/dist/types/src/internal/Ref/ref.d.ts.map +1 -0
- package/dist/types/src/internal/Ref/ref.test.d.ts.map +1 -0
- package/dist/types/src/internal/Type/compose.d.ts +7 -0
- package/dist/types/src/internal/Type/compose.d.ts.map +1 -0
- package/dist/types/src/internal/Type/compose.test.d.ts.map +1 -0
- package/dist/types/src/internal/{schema → Type}/echo-schema.d.ts +27 -14
- package/dist/types/src/internal/Type/echo-schema.d.ts.map +1 -0
- package/dist/types/src/internal/Type/index.d.ts +4 -0
- package/dist/types/src/internal/Type/index.d.ts.map +1 -0
- package/dist/types/src/internal/Type/manipulation.d.ts.map +1 -0
- package/dist/types/src/internal/Type/persistent-schema.d.ts +20 -0
- package/dist/types/src/internal/Type/persistent-schema.d.ts.map +1 -0
- package/dist/types/src/internal/common/api/index.d.ts +11 -0
- package/dist/types/src/internal/common/api/index.d.ts.map +1 -0
- package/dist/types/src/internal/common/api/meta.d.ts +42 -0
- package/dist/types/src/internal/common/api/meta.d.ts.map +1 -0
- package/dist/types/src/internal/common/index.d.ts +4 -0
- package/dist/types/src/internal/common/index.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/change-context.d.ts +55 -0
- package/dist/types/src/internal/common/proxy/change-context.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/change.test.d.ts +2 -0
- package/dist/types/src/internal/common/proxy/change.test.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/define-hidden-property.d.ts +5 -0
- package/dist/types/src/internal/common/proxy/define-hidden-property.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/errors.d.ts +19 -0
- package/dist/types/src/internal/common/proxy/errors.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/event-batch.d.ts +10 -0
- package/dist/types/src/internal/common/proxy/event-batch.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/handler.test.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/index.d.ts +14 -0
- package/dist/types/src/internal/common/proxy/index.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/json-serializer.d.ts +6 -0
- package/dist/types/src/internal/common/proxy/json-serializer.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/make-object.d.ts +14 -0
- package/dist/types/src/internal/common/proxy/make-object.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/ownership.d.ts +57 -0
- package/dist/types/src/internal/common/proxy/ownership.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/proxy-types.d.ts +18 -0
- package/dist/types/src/internal/common/proxy/proxy-types.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/proxy-utils.d.ts +47 -0
- package/dist/types/src/internal/common/proxy/proxy-utils.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/reactive-array.d.ts +8 -0
- package/dist/types/src/internal/common/proxy/reactive-array.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/reactive.d.ts +39 -0
- package/dist/types/src/internal/common/proxy/reactive.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/schema-validator.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/schema.test.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/symbols.d.ts +3 -0
- package/dist/types/src/internal/common/proxy/symbols.d.ts.map +1 -0
- package/dist/types/src/internal/{proxy → common/proxy}/typed-handler.d.ts +16 -12
- package/dist/types/src/internal/common/proxy/typed-handler.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/typed-handler.test.d.ts.map +1 -0
- package/dist/types/src/internal/common/proxy/typed-object.test.d.ts.map +1 -0
- package/dist/types/src/internal/common/types/base.d.ts +27 -0
- package/dist/types/src/internal/common/types/base.d.ts.map +1 -0
- package/dist/types/src/internal/common/types/entity.d.ts +37 -0
- package/dist/types/src/internal/common/types/entity.d.ts.map +1 -0
- package/dist/types/src/internal/common/types/index.d.ts +7 -0
- package/dist/types/src/internal/common/types/index.d.ts.map +1 -0
- package/dist/types/src/internal/{object → common/types}/meta.d.ts +18 -16
- package/dist/types/src/internal/common/types/meta.d.ts.map +1 -0
- package/dist/types/src/internal/common/types/model-symbols.d.ts +54 -0
- package/dist/types/src/internal/common/types/model-symbols.d.ts.map +1 -0
- package/dist/types/src/internal/common/types/typename.d.ts +21 -0
- package/dist/types/src/internal/common/types/typename.d.ts.map +1 -0
- package/dist/types/src/internal/common/types/version.d.ts +15 -0
- package/dist/types/src/internal/common/types/version.d.ts.map +1 -0
- package/dist/types/src/internal/index.d.ts +10 -14
- package/dist/types/src/internal/index.d.ts.map +1 -1
- 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 +304 -0
- package/dist/types/src/testing/test-schema.d.ts.map +1 -0
- package/dist/types/src/testing/util.d.ts +21 -0
- package/dist/types/src/testing/util.d.ts.map +1 -0
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +116 -65
- package/src/Annotation.ts +48 -0
- package/src/Collection.ts +37 -0
- package/src/Database.ts +352 -0
- package/src/Dataset.ts +26 -0
- package/src/Entity.test.ts +22 -0
- package/src/Entity.ts +243 -0
- package/src/Err.ts +40 -0
- package/src/Extension.test.ts +235 -0
- package/src/Extension.ts +122 -0
- package/src/Feed.ts +304 -0
- package/src/Filter.test.ts +90 -0
- package/src/Filter.ts +454 -0
- package/src/Format.ts +9 -0
- package/src/Hypergraph.ts +79 -0
- package/src/JsonSchema.ts +26 -0
- package/src/Key.ts +3 -0
- package/src/Migration.ts +94 -0
- package/src/Obj.test.ts +539 -0
- package/src/Obj.ts +697 -277
- package/src/Order.ts +46 -0
- package/src/Query.test.ts +806 -0
- package/src/Query.ts +547 -0
- package/src/QueryResult.ts +106 -0
- package/src/Ref.ts +79 -9
- package/src/Relation.test.ts +88 -0
- package/src/Relation.ts +449 -60
- package/src/SchemaRegistry.ts +106 -0
- package/src/Tag.ts +7 -5
- package/src/Type.test.ts +52 -0
- package/src/Type.ts +167 -153
- package/src/View.ts +107 -0
- package/src/hierarchy.test.ts +33 -0
- package/src/index.ts +22 -6
- package/src/internal/Annotation/annotations.test.ts +145 -0
- package/src/internal/Annotation/annotations.ts +577 -0
- package/src/internal/Annotation/index.ts +7 -0
- package/src/internal/Annotation/sorting.ts +51 -0
- package/src/internal/Annotation/util.ts +85 -0
- package/src/internal/Entity/api.ts +30 -0
- package/src/internal/Entity/entity.ts +128 -0
- package/src/internal/Entity/index.ts +11 -0
- package/src/internal/Entity/model.ts +109 -0
- package/src/internal/Entity/object.ts +57 -0
- package/src/internal/Entity/relation.ts +154 -0
- package/src/internal/Entity/util.ts +33 -0
- package/src/internal/Entity/version.ts +96 -0
- package/src/internal/{formats → Format}/date.test.ts +1 -2
- package/src/internal/{formats → Format}/date.ts +5 -5
- package/src/internal/{formats → Format}/format.test.ts +6 -7
- package/src/internal/{formats → Format}/format.ts +8 -6
- package/src/internal/{formats → Format}/number.ts +5 -5
- package/src/internal/{formats → Format}/object.ts +4 -4
- package/src/internal/{formats → Format}/select.ts +6 -4
- package/src/internal/{formats → Format}/string.ts +14 -9
- package/src/internal/{formats → Format}/types.ts +54 -43
- package/src/internal/{json → JsonSchema}/annotations.ts +3 -3
- package/src/internal/{json-schema → JsonSchema}/index.ts +2 -0
- package/src/internal/{json-schema → JsonSchema}/json-schema-normalize.ts +4 -2
- package/src/internal/{json-schema → JsonSchema}/json-schema-type.ts +36 -36
- package/src/internal/{json → JsonSchema}/json-schema.test.ts +106 -95
- package/src/internal/{json → JsonSchema}/json-schema.ts +29 -15
- package/src/internal/Obj/clone.ts +48 -0
- package/src/internal/{object → Obj}/common.ts +3 -4
- package/src/internal/{object/create.test.ts → Obj/create-object.test.ts} +32 -36
- package/src/internal/{object/create.ts → Obj/create-object.ts} +35 -37
- package/src/internal/Obj/deleted.ts +19 -0
- package/src/internal/{object → Obj}/ids.ts +1 -1
- package/src/internal/Obj/index.ts +14 -0
- package/src/internal/{object → Obj}/inspect.ts +5 -7
- package/src/internal/Obj/json-serializer.test.ts +120 -0
- package/src/internal/{object → Obj}/json-serializer.ts +106 -109
- package/src/internal/{object → Obj}/schema-validator.test.ts +3 -7
- package/src/internal/Obj/schema-validator.ts +6 -0
- package/src/internal/Obj/set-value.test.ts +281 -0
- package/src/internal/Obj/set-value.ts +165 -0
- package/src/internal/Obj/snapshot.ts +105 -0
- package/src/internal/{object → Obj}/typed-object.test.ts +12 -12
- package/src/internal/Obj/typed-object.ts +30 -0
- package/src/internal/Query.ts +134 -0
- package/src/internal/{ref → Ref}/ref-array.ts +4 -5
- package/src/internal/{ref → Ref}/ref.test.ts +11 -11
- package/src/internal/{ref → Ref}/ref.ts +108 -57
- package/src/internal/{projection → Type}/compose.test.ts +8 -10
- package/src/internal/{projection → Type}/compose.ts +14 -9
- package/src/internal/{schema → Type}/echo-schema.ts +74 -34
- package/src/internal/Type/index.ts +7 -0
- package/src/internal/{schema → Type}/manipulation.ts +1 -1
- package/src/internal/Type/persistent-schema.ts +33 -0
- package/src/internal/common/README.md +102 -0
- package/src/internal/common/api/index.ts +15 -0
- package/src/internal/common/api/meta.ts +88 -0
- package/src/internal/{testing → common}/index.ts +2 -1
- package/src/internal/common/proxy/change-context.ts +138 -0
- package/src/internal/common/proxy/change.test.ts +519 -0
- package/src/internal/common/proxy/define-hidden-property.ts +14 -0
- package/src/internal/common/proxy/errors.ts +42 -0
- package/src/internal/common/proxy/event-batch.ts +44 -0
- package/src/internal/common/proxy/handler.test.ts +121 -0
- package/src/internal/common/proxy/index.ts +17 -0
- package/src/internal/common/proxy/json-serializer.ts +90 -0
- package/src/internal/common/proxy/make-object.ts +105 -0
- package/src/internal/common/proxy/ownership.ts +252 -0
- package/src/internal/common/proxy/proxy-types.ts +23 -0
- package/src/internal/common/proxy/proxy-utils.ts +150 -0
- package/src/internal/common/proxy/reactive-array.ts +71 -0
- package/src/internal/common/proxy/reactive.ts +68 -0
- package/src/internal/{object → common/proxy}/schema-validator.ts +6 -3
- package/src/internal/{proxy → common/proxy}/schema.test.ts +31 -22
- package/src/internal/common/proxy/symbols.ts +7 -0
- package/src/internal/common/proxy/typed-handler.test.ts +313 -0
- package/src/internal/common/proxy/typed-handler.ts +447 -0
- package/src/internal/common/proxy/typed-object.test.ts +115 -0
- package/src/internal/common/types/base.ts +43 -0
- package/src/internal/common/types/entity.ts +54 -0
- package/src/internal/common/types/index.ts +10 -0
- package/src/internal/common/types/meta.ts +67 -0
- package/src/internal/common/types/model-symbols.ts +69 -0
- package/src/internal/common/types/typename.ts +55 -0
- package/src/internal/common/types/version.ts +19 -0
- package/src/internal/index.ts +12 -17
- package/src/testing/api.test.ts +125 -0
- package/src/testing/index.ts +3 -3
- package/src/testing/test-data.ts +129 -0
- package/src/testing/test-schema.ts +240 -0
- package/src/testing/util.ts +85 -0
- package/dist/lib/browser/chunk-BIDAASFK.mjs +0 -3727
- package/dist/lib/browser/chunk-BIDAASFK.mjs.map +0 -7
- package/dist/lib/browser/chunk-ZDLCWGEW.mjs +0 -410
- package/dist/lib/browser/chunk-ZDLCWGEW.mjs.map +0 -7
- package/dist/lib/browser/chunk-ZFRJKT4A.mjs +0 -585
- package/dist/lib/browser/chunk-ZFRJKT4A.mjs.map +0 -7
- package/dist/lib/browser/index.mjs +0 -35
- package/dist/lib/browser/internal/index.mjs +0 -336
- package/dist/lib/browser/meta.json +0 -1
- package/dist/lib/browser/query/index.mjs +0 -13
- package/dist/lib/browser/testing/index.mjs +0 -267
- package/dist/lib/browser/testing/index.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-3SVRRCUU.mjs +0 -3727
- package/dist/lib/node-esm/chunk-3SVRRCUU.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-CGDHRZWH.mjs +0 -585
- package/dist/lib/node-esm/chunk-CGDHRZWH.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-HWS6VBQC.mjs +0 -410
- package/dist/lib/node-esm/chunk-HWS6VBQC.mjs.map +0 -7
- package/dist/lib/node-esm/index.mjs +0 -35
- package/dist/lib/node-esm/meta.json +0 -1
- package/dist/lib/node-esm/query/index.mjs +0 -13
- package/dist/lib/node-esm/testing/index.mjs +0 -267
- package/dist/lib/node-esm/testing/index.mjs.map +0 -7
- package/dist/types/src/errors.d.ts +0 -68
- package/dist/types/src/errors.d.ts.map +0 -1
- 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 -131
- 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 +0 -10
- 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/formats/date.d.ts.map +0 -1
- package/dist/types/src/internal/formats/date.test.d.ts.map +0 -1
- package/dist/types/src/internal/formats/format.d.ts.map +0 -1
- package/dist/types/src/internal/formats/format.test.d.ts.map +0 -1
- package/dist/types/src/internal/formats/index.d.ts.map +0 -1
- package/dist/types/src/internal/formats/number.d.ts.map +0 -1
- package/dist/types/src/internal/formats/object.d.ts.map +0 -1
- package/dist/types/src/internal/formats/select.d.ts.map +0 -1
- package/dist/types/src/internal/formats/string.d.ts.map +0 -1
- package/dist/types/src/internal/formats/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/json-schema/index.d.ts +0 -3
- package/dist/types/src/internal/json-schema/index.d.ts.map +0 -1
- package/dist/types/src/internal/json-schema/json-schema-normalize.d.ts.map +0 -1
- package/dist/types/src/internal/json-schema/json-schema-type.d.ts.map +0 -1
- package/dist/types/src/internal/object/accessors.d.ts +0 -37
- package/dist/types/src/internal/object/accessors.d.ts.map +0 -1
- package/dist/types/src/internal/object/common.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/deleted.d.ts +0 -6
- package/dist/types/src/internal/object/deleted.d.ts.map +0 -1
- package/dist/types/src/internal/object/entity.d.ts +0 -33
- package/dist/types/src/internal/object/entity.d.ts.map +0 -1
- package/dist/types/src/internal/object/expando.d.ts +0 -14
- package/dist/types/src/internal/object/expando.d.ts.map +0 -1
- package/dist/types/src/internal/object/ids.d.ts.map +0 -1
- package/dist/types/src/internal/object/index.d.ts +0 -16
- package/dist/types/src/internal/object/index.d.ts.map +0 -1
- package/dist/types/src/internal/object/inspect.d.ts.map +0 -1
- package/dist/types/src/internal/object/json-serializer.d.ts +0 -32
- package/dist/types/src/internal/object/json-serializer.d.ts.map +0 -1
- package/dist/types/src/internal/object/json-serializer.test.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/schema-validator.d.ts.map +0 -1
- package/dist/types/src/internal/object/schema-validator.test.d.ts.map +0 -1
- package/dist/types/src/internal/object/typed-object.d.ts +0 -31
- package/dist/types/src/internal/object/typed-object.d.ts.map +0 -1
- package/dist/types/src/internal/object/typed-object.test.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 +0 -14
- package/dist/types/src/internal/object/version.d.ts.map +0 -1
- package/dist/types/src/internal/projection/compose.d.ts +0 -6
- 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/handler.test.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/proxy/schema.test.d.ts.map +0 -1
- package/dist/types/src/internal/proxy/typed-handler.d.ts.map +0 -1
- package/dist/types/src/internal/proxy/typed-handler.test.d.ts.map +0 -1
- package/dist/types/src/internal/proxy/typed-object.test.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 +0 -17
- package/dist/types/src/internal/query/query.d.ts.map +0 -1
- package/dist/types/src/internal/ref/index.d.ts.map +0 -1
- package/dist/types/src/internal/ref/ref-array.d.ts.map +0 -1
- package/dist/types/src/internal/ref/ref.d.ts.map +0 -1
- package/dist/types/src/internal/ref/ref.test.d.ts.map +0 -1
- package/dist/types/src/internal/schema/echo-schema.d.ts.map +0 -1
- package/dist/types/src/internal/schema/index.d.ts +0 -7
- package/dist/types/src/internal/schema/index.d.ts.map +0 -1
- package/dist/types/src/internal/schema/manipulation.d.ts.map +0 -1
- package/dist/types/src/internal/schema/runtime-schema-registry.d.ts +0 -18
- package/dist/types/src/internal/schema/runtime-schema-registry.d.ts.map +0 -1
- package/dist/types/src/internal/schema/snapshot.d.ts +0 -6
- package/dist/types/src/internal/schema/snapshot.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 -381
- package/dist/types/src/internal/testing/types.d.ts.map +0 -1
- package/dist/types/src/internal/testing/utils.d.ts +0 -10
- package/dist/types/src/internal/testing/utils.d.ts.map +0 -1
- package/dist/types/src/internal/types/index.d.ts +0 -3
- package/dist/types/src/internal/types/index.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/index.d.ts +0 -2
- package/dist/types/src/query/index.d.ts.map +0 -1
- package/dist/types/src/query/query.d.ts +0 -248
- package/dist/types/src/query/query.d.ts.map +0 -1
- package/dist/types/src/query/query.test.d.ts +0 -2
- package/dist/types/src/query/query.test.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 -228
- package/dist/types/src/testing/types.d.ts.map +0 -1
- package/src/errors.ts +0 -18
- package/src/internal/ast/annotation-helper.ts +0 -22
- package/src/internal/ast/annotations.test.ts +0 -98
- package/src/internal/ast/annotations.ts +0 -226
- package/src/internal/ast/entity-kind.ts +0 -15
- 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 -153
- package/src/internal/object/deleted.ts +0 -19
- package/src/internal/object/entity.ts +0 -248
- package/src/internal/object/expando.ts +0 -21
- package/src/internal/object/index.ts +0 -19
- package/src/internal/object/json-serializer.test.ts +0 -99
- package/src/internal/object/meta.ts +0 -61
- package/src/internal/object/model.ts +0 -170
- package/src/internal/object/relation.ts +0 -24
- package/src/internal/object/typed-object.ts +0 -88
- 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/proxy/handler.test.ts +0 -163
- package/src/internal/proxy/reactive-object.ts +0 -108
- package/src/internal/proxy/typed-handler.test.ts +0 -102
- package/src/internal/proxy/typed-handler.ts +0 -228
- package/src/internal/proxy/typed-object.test.ts +0 -100
- package/src/internal/query/index.ts +0 -5
- package/src/internal/query/query.ts +0 -23
- package/src/internal/schema/index.ts +0 -10
- package/src/internal/schema/runtime-schema-registry.ts +0 -78
- package/src/internal/schema/snapshot.ts +0 -25
- package/src/internal/schema/stored-schema.ts +0 -26
- package/src/internal/testing/types.ts +0 -144
- package/src/internal/testing/utils.ts +0 -54
- package/src/internal/types/index.ts +0 -6
- 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/index.ts +0 -6
- package/src/query/query.test.ts +0 -401
- package/src/query/query.ts +0 -789
- package/src/test/api.test.ts +0 -180
- package/src/testing/echo-schema.ts +0 -39
- package/src/testing/types.ts +0 -108
- /package/dist/lib/{browser/index.mjs.map → neutral/Annotation.mjs.map} +0 -0
- /package/dist/lib/{browser/internal/index.mjs.map → neutral/Database.mjs.map} +0 -0
- /package/dist/lib/{browser/query/index.mjs.map → neutral/Entity.mjs.map} +0 -0
- /package/dist/lib/{node-esm/index.mjs.map → neutral/Err.mjs.map} +0 -0
- /package/dist/lib/{node-esm/internal/index.mjs.map → neutral/Extension.mjs.map} +0 -0
- /package/dist/lib/{node-esm/query/index.mjs.map → neutral/Feed.mjs.map} +0 -0
- /package/dist/types/src/internal/{ast → Annotation}/annotations.test.d.ts +0 -0
- /package/dist/types/src/internal/{formats → Format}/date.d.ts +0 -0
- /package/dist/types/src/internal/{formats → Format}/date.test.d.ts +0 -0
- /package/dist/types/src/internal/{formats → Format}/format.test.d.ts +0 -0
- /package/dist/types/src/internal/{formats → Format}/index.d.ts +0 -0
- /package/dist/types/src/internal/{formats → Format}/number.d.ts +0 -0
- /package/dist/types/src/internal/{formats → Format}/object.d.ts +0 -0
- /package/dist/types/src/internal/{json → JsonSchema}/effect-schema.test.d.ts +0 -0
- /package/dist/types/src/internal/{json-schema → JsonSchema}/json-schema-normalize.d.ts +0 -0
- /package/dist/types/src/internal/{json → JsonSchema}/json-schema.test.d.ts +0 -0
- /package/dist/types/src/internal/{object → Obj}/common.d.ts +0 -0
- /package/dist/types/src/internal/{object → Obj}/ids.d.ts +0 -0
- /package/dist/types/src/internal/{object → Obj}/inspect.d.ts +0 -0
- /package/dist/types/src/internal/{object → Obj}/json-serializer.test.d.ts +0 -0
- /package/dist/types/src/internal/{object → Obj}/schema-validator.test.d.ts +0 -0
- /package/dist/types/src/internal/{object → Obj}/typed-object.test.d.ts +0 -0
- /package/dist/types/src/internal/{ref → Ref}/index.d.ts +0 -0
- /package/dist/types/src/internal/{ref → Ref}/ref.test.d.ts +0 -0
- /package/dist/types/src/internal/{projection → Type}/compose.test.d.ts +0 -0
- /package/dist/types/src/internal/{schema → Type}/manipulation.d.ts +0 -0
- /package/dist/types/src/internal/{proxy → common/proxy}/handler.test.d.ts +0 -0
- /package/dist/types/src/internal/{object → common/proxy}/schema-validator.d.ts +0 -0
- /package/dist/types/src/internal/{proxy → common/proxy}/schema.test.d.ts +0 -0
- /package/dist/types/src/internal/{proxy → common/proxy}/typed-handler.test.d.ts +0 -0
- /package/dist/types/src/internal/{proxy → common/proxy}/typed-object.test.d.ts +0 -0
- /package/dist/types/src/{test → testing}/api.test.d.ts +0 -0
- /package/src/internal/{formats → Format}/index.ts +0 -0
- /package/src/internal/{json → JsonSchema}/effect-schema.test.ts +0 -0
- /package/src/internal/{ref → Ref}/index.ts +0 -0
|
@@ -0,0 +1,2834 @@
|
|
|
1
|
+
import {
|
|
2
|
+
JsonSchemaFields,
|
|
3
|
+
JsonSchemaType,
|
|
4
|
+
toEffectSchema,
|
|
5
|
+
toJsonSchema
|
|
6
|
+
} from "./chunk-JUXPFOEI.mjs";
|
|
7
|
+
import {
|
|
8
|
+
Ref,
|
|
9
|
+
refFromEncodedReference,
|
|
10
|
+
setRefResolver
|
|
11
|
+
} from "./chunk-G3IQMKF7.mjs";
|
|
12
|
+
import {
|
|
13
|
+
ATTR_PARENT,
|
|
14
|
+
ATTR_TYPE,
|
|
15
|
+
IconAnnotation,
|
|
16
|
+
LabelAnnotation,
|
|
17
|
+
ParentId,
|
|
18
|
+
SchemaId,
|
|
19
|
+
SchemaMetaSymbol,
|
|
20
|
+
TypeAnnotationId,
|
|
21
|
+
TypeId,
|
|
22
|
+
TypeIdentifierAnnotationId,
|
|
23
|
+
TypenameSchema,
|
|
24
|
+
VersionSchema,
|
|
25
|
+
getEntityKind,
|
|
26
|
+
getLabel,
|
|
27
|
+
getSchema,
|
|
28
|
+
getSchemaDXN,
|
|
29
|
+
getSchemaTypename,
|
|
30
|
+
getTypeAnnotation,
|
|
31
|
+
getTypeDXN,
|
|
32
|
+
getTypeIdentifierAnnotation,
|
|
33
|
+
getTypename,
|
|
34
|
+
setSchema,
|
|
35
|
+
setTypename
|
|
36
|
+
} from "./chunk-2KHZ36F5.mjs";
|
|
37
|
+
import {
|
|
38
|
+
EntityKind,
|
|
39
|
+
KindId,
|
|
40
|
+
SchemaKindId,
|
|
41
|
+
SnapshotKindId,
|
|
42
|
+
makeTypeJsonSchemaAnnotation
|
|
43
|
+
} from "./chunk-TBKX6JQO.mjs";
|
|
44
|
+
|
|
45
|
+
// src/internal/index.ts
|
|
46
|
+
import { JsonPath, JsonProp, getValue, splitJsonPath } from "@dxos/effect";
|
|
47
|
+
|
|
48
|
+
// src/internal/common/types/base.ts
|
|
49
|
+
import * as Schema from "effect/Schema";
|
|
50
|
+
import * as SchemaAST from "effect/SchemaAST";
|
|
51
|
+
var RawObject = (schema) => {
|
|
52
|
+
return Schema.make(SchemaAST.omit(schema.ast, [
|
|
53
|
+
"id"
|
|
54
|
+
]));
|
|
55
|
+
};
|
|
56
|
+
|
|
57
|
+
// src/internal/common/types/meta.ts
|
|
58
|
+
import * as Schema2 from "effect/Schema";
|
|
59
|
+
import { ForeignKey } from "@dxos/echo-protocol";
|
|
60
|
+
import { invariant } from "@dxos/invariant";
|
|
61
|
+
import { intersection } from "@dxos/util";
|
|
62
|
+
var __dxlog_file = "/__w/dxos/dxos/packages/core/echo/echo/src/internal/common/types/meta.ts";
|
|
63
|
+
var ATTR_META = "@meta";
|
|
64
|
+
var MetaId = /* @__PURE__ */ Symbol.for("@dxos/echo/Meta");
|
|
65
|
+
var ObjectMetaSchema = Schema2.Struct({
|
|
66
|
+
keys: Schema2.Array(ForeignKey),
|
|
67
|
+
/**
|
|
68
|
+
* A set of tags.
|
|
69
|
+
* Tags are arbitrary application-defined strings.
|
|
70
|
+
* ECHO makes no assumptions about the tag structure.
|
|
71
|
+
*/
|
|
72
|
+
// TODO(dmaretskyi): Has to be optional for compatibility with old data.
|
|
73
|
+
// Defaulting to an empty array is possible but requires a bit more work.
|
|
74
|
+
// TODO(dmaretskyi): In automerge this should be a map of { [tag]: boolean } for uniqueness and conflict resolution.
|
|
75
|
+
tags: Schema2.optional(Schema2.Array(Schema2.String))
|
|
76
|
+
});
|
|
77
|
+
var getMeta = (obj) => {
|
|
78
|
+
const metadata = obj[MetaId];
|
|
79
|
+
invariant(metadata, "ObjectMeta not found.", {
|
|
80
|
+
F: __dxlog_file,
|
|
81
|
+
L: 54,
|
|
82
|
+
S: void 0,
|
|
83
|
+
A: [
|
|
84
|
+
"metadata",
|
|
85
|
+
"'ObjectMeta not found.'"
|
|
86
|
+
]
|
|
87
|
+
});
|
|
88
|
+
return metadata;
|
|
89
|
+
};
|
|
90
|
+
var foreignKey = (source, id) => ({
|
|
91
|
+
source,
|
|
92
|
+
id
|
|
93
|
+
});
|
|
94
|
+
var foreignKeyEquals = (a, b) => a.source === b.source && a.id === b.id;
|
|
95
|
+
var compareForeignKeys = (a, b) => intersection(getMeta(a).keys, getMeta(b).keys, foreignKeyEquals).length > 0;
|
|
96
|
+
|
|
97
|
+
// src/internal/common/types/model-symbols.ts
|
|
98
|
+
var ATTR_SELF_DXN = "@dxn";
|
|
99
|
+
var SelfDXNId = /* @__PURE__ */ Symbol.for("@dxos/echo/DXN");
|
|
100
|
+
var ATTR_DELETED = "@deleted";
|
|
101
|
+
var ObjectDeletedId = /* @__PURE__ */ Symbol.for("@dxos/echo/Deleted");
|
|
102
|
+
var ObjectVersionId = /* @__PURE__ */ Symbol.for("@dxos/echo/Version");
|
|
103
|
+
var ObjectDatabaseId = /* @__PURE__ */ Symbol.for("@dxos/echo/Database");
|
|
104
|
+
var ATTR_RELATION_SOURCE = "@relationSource";
|
|
105
|
+
var RelationSourceId = /* @__PURE__ */ Symbol.for("@dxos/echo/RelationSource");
|
|
106
|
+
var RelationSourceDXNId = /* @__PURE__ */ Symbol.for("@dxos/echo/RelationSourceDXN");
|
|
107
|
+
var ATTR_RELATION_TARGET = "@relationTarget";
|
|
108
|
+
var RelationTargetId = /* @__PURE__ */ Symbol.for("@dxos/echo/RelationTarget");
|
|
109
|
+
var RelationTargetDXNId = /* @__PURE__ */ Symbol.for("@dxos/echo/RelationTargetDXN");
|
|
110
|
+
|
|
111
|
+
// src/internal/common/types/version.ts
|
|
112
|
+
var VersionTypeId = "~@dxos/echo/VersionTypeId";
|
|
113
|
+
|
|
114
|
+
// src/internal/Annotation/sorting.ts
|
|
115
|
+
var compare = (a, b) => {
|
|
116
|
+
if (a == null) {
|
|
117
|
+
return b == null ? 0 : 1;
|
|
118
|
+
}
|
|
119
|
+
if (b == null) {
|
|
120
|
+
return -1;
|
|
121
|
+
}
|
|
122
|
+
return a.localeCompare(b);
|
|
123
|
+
};
|
|
124
|
+
var sortByLabel = (a, b) => compare(getLabel(a), getLabel(b));
|
|
125
|
+
var sortByTypename = (a, b) => compare(getTypename(a), getTypename(b));
|
|
126
|
+
var sort = (...comparators) => {
|
|
127
|
+
return (a, b) => {
|
|
128
|
+
for (const comparator of comparators) {
|
|
129
|
+
const result = comparator(a, b);
|
|
130
|
+
if (result !== 0) {
|
|
131
|
+
return result;
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
return 0;
|
|
135
|
+
};
|
|
136
|
+
};
|
|
137
|
+
|
|
138
|
+
// src/internal/common/api/meta.ts
|
|
139
|
+
import { assertArgument, invariant as invariant2 } from "@dxos/invariant";
|
|
140
|
+
var __dxlog_file2 = "/__w/dxos/dxos/packages/core/echo/echo/src/internal/common/api/meta.ts";
|
|
141
|
+
function getMetaChecked(entity) {
|
|
142
|
+
assertArgument(entity, "entity", "Should be an entity.");
|
|
143
|
+
const meta = getMeta(entity);
|
|
144
|
+
invariant2(meta != null, "Invalid entity.", {
|
|
145
|
+
F: __dxlog_file2,
|
|
146
|
+
L: 34,
|
|
147
|
+
S: this,
|
|
148
|
+
A: [
|
|
149
|
+
"meta != null",
|
|
150
|
+
"'Invalid entity.'"
|
|
151
|
+
]
|
|
152
|
+
});
|
|
153
|
+
return meta;
|
|
154
|
+
}
|
|
155
|
+
var getKeys = (entity, source) => {
|
|
156
|
+
assertArgument(entity, "entity", "Should be an entity.");
|
|
157
|
+
const meta = getMetaChecked(entity);
|
|
158
|
+
invariant2(meta != null, "Invalid entity.", {
|
|
159
|
+
F: __dxlog_file2,
|
|
160
|
+
L: 45,
|
|
161
|
+
S: void 0,
|
|
162
|
+
A: [
|
|
163
|
+
"meta != null",
|
|
164
|
+
"'Invalid entity.'"
|
|
165
|
+
]
|
|
166
|
+
});
|
|
167
|
+
return meta.keys.filter((key) => key.source === source);
|
|
168
|
+
};
|
|
169
|
+
var deleteKeys = (entity, source) => {
|
|
170
|
+
const meta = getMetaChecked(entity);
|
|
171
|
+
for (let i = 0; i < meta.keys.length; i++) {
|
|
172
|
+
if (meta.keys[i].source === source) {
|
|
173
|
+
meta.keys.splice(i, 1);
|
|
174
|
+
i--;
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
};
|
|
178
|
+
var addTag = (entity, tag) => {
|
|
179
|
+
const meta = getMetaChecked(entity);
|
|
180
|
+
meta.tags ??= [];
|
|
181
|
+
meta.tags.push(tag);
|
|
182
|
+
};
|
|
183
|
+
var removeTag = (entity, tag) => {
|
|
184
|
+
const meta = getMetaChecked(entity);
|
|
185
|
+
if (!meta.tags) {
|
|
186
|
+
return;
|
|
187
|
+
}
|
|
188
|
+
for (let i = 0; i < meta.tags.length; i++) {
|
|
189
|
+
if (meta.tags[i] === tag) {
|
|
190
|
+
meta.tags.splice(i, 1);
|
|
191
|
+
i--;
|
|
192
|
+
}
|
|
193
|
+
}
|
|
194
|
+
};
|
|
195
|
+
|
|
196
|
+
// src/internal/common/proxy/symbols.ts
|
|
197
|
+
var EventId = /* @__PURE__ */ Symbol.for("@dxos/live-object/EventId");
|
|
198
|
+
var ChangeId = /* @__PURE__ */ Symbol.for("@dxos/live-object/ChangeId");
|
|
199
|
+
|
|
200
|
+
// src/internal/common/proxy/event-batch.ts
|
|
201
|
+
var eventBatchDepth = 0;
|
|
202
|
+
var pendingEventTargets = /* @__PURE__ */ new Set();
|
|
203
|
+
var batchEvents = (callback) => {
|
|
204
|
+
eventBatchDepth++;
|
|
205
|
+
try {
|
|
206
|
+
callback();
|
|
207
|
+
} finally {
|
|
208
|
+
eventBatchDepth--;
|
|
209
|
+
if (eventBatchDepth === 0) {
|
|
210
|
+
for (const target of pendingEventTargets) {
|
|
211
|
+
target[EventId]?.emit();
|
|
212
|
+
}
|
|
213
|
+
pendingEventTargets.clear();
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
};
|
|
217
|
+
var emitEvent = (target) => {
|
|
218
|
+
if (eventBatchDepth > 0) {
|
|
219
|
+
pendingEventTargets.add(target);
|
|
220
|
+
} else {
|
|
221
|
+
target[EventId]?.emit();
|
|
222
|
+
}
|
|
223
|
+
};
|
|
224
|
+
|
|
225
|
+
// src/internal/common/proxy/change-context.ts
|
|
226
|
+
var currentChangeContext = null;
|
|
227
|
+
var pendingNotificationKey = null;
|
|
228
|
+
var pendingOwnerNotifications = /* @__PURE__ */ new Set();
|
|
229
|
+
var enterChangeContext = (key) => {
|
|
230
|
+
currentChangeContext = key;
|
|
231
|
+
return () => {
|
|
232
|
+
currentChangeContext = null;
|
|
233
|
+
};
|
|
234
|
+
};
|
|
235
|
+
var isInChangeContext = (key) => {
|
|
236
|
+
return currentChangeContext === key;
|
|
237
|
+
};
|
|
238
|
+
var queueNotification = (key) => {
|
|
239
|
+
if (currentChangeContext === key) {
|
|
240
|
+
pendingNotificationKey = key;
|
|
241
|
+
}
|
|
242
|
+
};
|
|
243
|
+
var queueOwnerNotification = (target) => {
|
|
244
|
+
if (currentChangeContext !== null && target !== currentChangeContext) {
|
|
245
|
+
pendingOwnerNotifications.add(target);
|
|
246
|
+
}
|
|
247
|
+
};
|
|
248
|
+
var hasPendingNotifications = (key) => {
|
|
249
|
+
return pendingNotificationKey === key;
|
|
250
|
+
};
|
|
251
|
+
var clearPendingNotifications = (key) => {
|
|
252
|
+
if (pendingNotificationKey === key) {
|
|
253
|
+
pendingNotificationKey = null;
|
|
254
|
+
}
|
|
255
|
+
};
|
|
256
|
+
var executeChange = (contextKey, eventTarget, proxy, callback) => {
|
|
257
|
+
const exitContext = enterChangeContext(contextKey);
|
|
258
|
+
try {
|
|
259
|
+
batchEvents(() => callback(proxy));
|
|
260
|
+
} finally {
|
|
261
|
+
exitContext();
|
|
262
|
+
if (hasPendingNotifications(contextKey)) {
|
|
263
|
+
clearPendingNotifications(contextKey);
|
|
264
|
+
eventTarget[EventId]?.emit();
|
|
265
|
+
}
|
|
266
|
+
for (const ownerTarget of pendingOwnerNotifications) {
|
|
267
|
+
ownerTarget[EventId]?.emit();
|
|
268
|
+
}
|
|
269
|
+
pendingOwnerNotifications.clear();
|
|
270
|
+
}
|
|
271
|
+
};
|
|
272
|
+
|
|
273
|
+
// src/internal/common/proxy/define-hidden-property.ts
|
|
274
|
+
var defineHiddenProperty = (object, key, value2) => {
|
|
275
|
+
Object.defineProperty(object, key, {
|
|
276
|
+
enumerable: false,
|
|
277
|
+
configurable: true,
|
|
278
|
+
value: value2
|
|
279
|
+
});
|
|
280
|
+
};
|
|
281
|
+
|
|
282
|
+
// src/internal/common/proxy/errors.ts
|
|
283
|
+
var MutationOutsideChangeContextError = class extends Error {
|
|
284
|
+
constructor(operation, suggestion) {
|
|
285
|
+
super(`Cannot ${operation} outside of Obj.change(). Use Obj.change(obj, (mutableObj) => { ${suggestion} }) instead.`);
|
|
286
|
+
this.name = "MutationOutsideChangeContextError";
|
|
287
|
+
}
|
|
288
|
+
};
|
|
289
|
+
var createPropertySetError = (prop) => {
|
|
290
|
+
return new MutationOutsideChangeContextError(`modify object property "${String(prop)}"`, `mutableObj.${String(prop)} = value;`);
|
|
291
|
+
};
|
|
292
|
+
var createPropertyDeleteError = (prop) => {
|
|
293
|
+
return new MutationOutsideChangeContextError(`delete object property "${String(prop)}"`, `delete mutableObj.${String(prop)};`);
|
|
294
|
+
};
|
|
295
|
+
var createArrayMethodError = (method) => {
|
|
296
|
+
return new MutationOutsideChangeContextError(`call array.${method}()`, `mutableObj.array.${method}(...);`);
|
|
297
|
+
};
|
|
298
|
+
|
|
299
|
+
// src/internal/common/proxy/json-serializer.ts
|
|
300
|
+
import { invariant as invariant3 } from "@dxos/invariant";
|
|
301
|
+
import { DXN } from "@dxos/keys";
|
|
302
|
+
import { deepMapValues } from "@dxos/util";
|
|
303
|
+
var __dxlog_file3 = "/__w/dxos/dxos/packages/core/echo/echo/src/internal/common/proxy/json-serializer.ts";
|
|
304
|
+
var attachTypedJsonSerializer = (obj) => {
|
|
305
|
+
const descriptor = Object.getOwnPropertyDescriptor(obj, "toJSON");
|
|
306
|
+
if (descriptor) {
|
|
307
|
+
return;
|
|
308
|
+
}
|
|
309
|
+
Object.defineProperty(obj, "toJSON", {
|
|
310
|
+
value: typedJsonSerializer,
|
|
311
|
+
writable: false,
|
|
312
|
+
enumerable: false,
|
|
313
|
+
// Setting `configurable` to false breaks proxy invariants, should be fixable.
|
|
314
|
+
configurable: true
|
|
315
|
+
});
|
|
316
|
+
};
|
|
317
|
+
var typedJsonSerializer = function() {
|
|
318
|
+
const { id, ...rest } = this;
|
|
319
|
+
const result = {
|
|
320
|
+
id
|
|
321
|
+
};
|
|
322
|
+
if (this[TypeId]) {
|
|
323
|
+
result[ATTR_TYPE] = this[TypeId].toString();
|
|
324
|
+
}
|
|
325
|
+
if (this[MetaId]) {
|
|
326
|
+
result[ATTR_META] = serializeMeta(this[MetaId]);
|
|
327
|
+
}
|
|
328
|
+
if (this[SelfDXNId]) {
|
|
329
|
+
result[ATTR_SELF_DXN] = this[SelfDXNId].toString();
|
|
330
|
+
}
|
|
331
|
+
if (this[RelationSourceDXNId]) {
|
|
332
|
+
const sourceDXN = this[RelationSourceDXNId];
|
|
333
|
+
invariant3(sourceDXN instanceof DXN, void 0, {
|
|
334
|
+
F: __dxlog_file3,
|
|
335
|
+
L: 64,
|
|
336
|
+
S: this,
|
|
337
|
+
A: [
|
|
338
|
+
"sourceDXN instanceof DXN",
|
|
339
|
+
""
|
|
340
|
+
]
|
|
341
|
+
});
|
|
342
|
+
result[ATTR_RELATION_SOURCE] = sourceDXN.toString();
|
|
343
|
+
}
|
|
344
|
+
if (this[RelationTargetDXNId]) {
|
|
345
|
+
const targetDXN = this[RelationTargetDXNId];
|
|
346
|
+
invariant3(targetDXN instanceof DXN, void 0, {
|
|
347
|
+
F: __dxlog_file3,
|
|
348
|
+
L: 69,
|
|
349
|
+
S: this,
|
|
350
|
+
A: [
|
|
351
|
+
"targetDXN instanceof DXN",
|
|
352
|
+
""
|
|
353
|
+
]
|
|
354
|
+
});
|
|
355
|
+
result[ATTR_RELATION_TARGET] = targetDXN.toString();
|
|
356
|
+
}
|
|
357
|
+
Object.assign(result, serializeData(rest));
|
|
358
|
+
return result;
|
|
359
|
+
};
|
|
360
|
+
var serializeData = (data) => {
|
|
361
|
+
return deepMapValues(data, (value2, recurse) => {
|
|
362
|
+
if (Ref.isRef(value2)) {
|
|
363
|
+
return value2.noInline().encode();
|
|
364
|
+
}
|
|
365
|
+
return recurse(value2);
|
|
366
|
+
});
|
|
367
|
+
};
|
|
368
|
+
var serializeMeta = (meta) => {
|
|
369
|
+
return deepMapValues(meta, (value2, recurse) => recurse(value2));
|
|
370
|
+
};
|
|
371
|
+
|
|
372
|
+
// src/internal/common/proxy/make-object.ts
|
|
373
|
+
import { ObjectId } from "@dxos/keys";
|
|
374
|
+
|
|
375
|
+
// src/internal/common/proxy/proxy-utils.ts
|
|
376
|
+
import { invariant as invariant4 } from "@dxos/invariant";
|
|
377
|
+
var __dxlog_file4 = "/__w/dxos/dxos/packages/core/echo/echo/src/internal/common/proxy/proxy-utils.ts";
|
|
378
|
+
var symbolIsProxy = /* @__PURE__ */ Symbol.for("@dxos/schema/Proxy");
|
|
379
|
+
var isProxy = (value2) => !!value2?.[symbolIsProxy];
|
|
380
|
+
var isValidProxyTarget = (value2) => {
|
|
381
|
+
if (value2 == null || value2[symbolIsProxy]) {
|
|
382
|
+
return false;
|
|
383
|
+
}
|
|
384
|
+
if (Array.isArray(value2)) {
|
|
385
|
+
return true;
|
|
386
|
+
}
|
|
387
|
+
return typeof value2 === "object" && Object.getPrototypeOf(value2) === Object.prototype;
|
|
388
|
+
};
|
|
389
|
+
var getProxySlot = (proxy) => {
|
|
390
|
+
const value2 = proxy[symbolIsProxy];
|
|
391
|
+
invariant4(value2 instanceof ProxyHandlerSlot, void 0, {
|
|
392
|
+
F: __dxlog_file4,
|
|
393
|
+
L: 32,
|
|
394
|
+
S: void 0,
|
|
395
|
+
A: [
|
|
396
|
+
"value instanceof ProxyHandlerSlot",
|
|
397
|
+
""
|
|
398
|
+
]
|
|
399
|
+
});
|
|
400
|
+
return value2;
|
|
401
|
+
};
|
|
402
|
+
var getProxyTarget = (proxy) => {
|
|
403
|
+
return getProxySlot(proxy).target;
|
|
404
|
+
};
|
|
405
|
+
var getProxyHandler = (proxy) => {
|
|
406
|
+
return getProxySlot(proxy).handler;
|
|
407
|
+
};
|
|
408
|
+
var dangerouslySetProxyId = (obj, id) => {
|
|
409
|
+
getProxySlot(obj).target.id = id;
|
|
410
|
+
};
|
|
411
|
+
var createProxy = (target, handler) => {
|
|
412
|
+
const existingProxy = handler._proxyMap.get(target);
|
|
413
|
+
if (existingProxy) {
|
|
414
|
+
return existingProxy;
|
|
415
|
+
}
|
|
416
|
+
const proxy = new Proxy(target, new ProxyHandlerSlot(target, handler));
|
|
417
|
+
handler.init(target);
|
|
418
|
+
handler._proxyMap.set(target, proxy);
|
|
419
|
+
return proxy;
|
|
420
|
+
};
|
|
421
|
+
var ProxyHandlerSlot = class {
|
|
422
|
+
target;
|
|
423
|
+
_handler;
|
|
424
|
+
/**
|
|
425
|
+
* @param target Original object.
|
|
426
|
+
* @param _handler Handles intercepted operations.
|
|
427
|
+
*/
|
|
428
|
+
constructor(target, _handler) {
|
|
429
|
+
this.target = target;
|
|
430
|
+
this._handler = _handler;
|
|
431
|
+
}
|
|
432
|
+
get handler() {
|
|
433
|
+
invariant4(this._handler, void 0, {
|
|
434
|
+
F: __dxlog_file4,
|
|
435
|
+
L: 91,
|
|
436
|
+
S: this,
|
|
437
|
+
A: [
|
|
438
|
+
"this._handler",
|
|
439
|
+
""
|
|
440
|
+
]
|
|
441
|
+
});
|
|
442
|
+
return this._handler;
|
|
443
|
+
}
|
|
444
|
+
// TODO(burdon): Requires comment.
|
|
445
|
+
setHandler(handler) {
|
|
446
|
+
this._handler = handler;
|
|
447
|
+
}
|
|
448
|
+
/**
|
|
449
|
+
* Get value.
|
|
450
|
+
*/
|
|
451
|
+
get(target, prop, receiver) {
|
|
452
|
+
if (prop === symbolIsProxy) {
|
|
453
|
+
return this;
|
|
454
|
+
}
|
|
455
|
+
if (!this._handler || !this._handler.get) {
|
|
456
|
+
return Reflect.get(target, prop, receiver);
|
|
457
|
+
}
|
|
458
|
+
return this._handler.get(target, prop, receiver);
|
|
459
|
+
}
|
|
460
|
+
static {
|
|
461
|
+
const TRAPS = [
|
|
462
|
+
"apply",
|
|
463
|
+
"construct",
|
|
464
|
+
"defineProperty",
|
|
465
|
+
"deleteProperty",
|
|
466
|
+
"get",
|
|
467
|
+
"getOwnPropertyDescriptor",
|
|
468
|
+
"getPrototypeOf",
|
|
469
|
+
"has",
|
|
470
|
+
"isExtensible",
|
|
471
|
+
"ownKeys",
|
|
472
|
+
"preventExtensions",
|
|
473
|
+
"set",
|
|
474
|
+
"setPrototypeOf"
|
|
475
|
+
];
|
|
476
|
+
for (const trap of TRAPS) {
|
|
477
|
+
if (trap === "get") {
|
|
478
|
+
continue;
|
|
479
|
+
}
|
|
480
|
+
Object.defineProperty(this.prototype, trap, {
|
|
481
|
+
enumerable: false,
|
|
482
|
+
value: function(...args) {
|
|
483
|
+
if (!this._handler || !this._handler[trap]) {
|
|
484
|
+
return Reflect[trap](...args);
|
|
485
|
+
}
|
|
486
|
+
return this._handler[trap].apply(this._handler, args);
|
|
487
|
+
}
|
|
488
|
+
});
|
|
489
|
+
}
|
|
490
|
+
}
|
|
491
|
+
};
|
|
492
|
+
|
|
493
|
+
// src/internal/common/proxy/typed-handler.ts
|
|
494
|
+
import * as Schema4 from "effect/Schema";
|
|
495
|
+
import * as SchemaAST3 from "effect/SchemaAST";
|
|
496
|
+
import { Event } from "@dxos/async";
|
|
497
|
+
import { inspectCustom } from "@dxos/debug";
|
|
498
|
+
import { invariant as invariant7 } from "@dxos/invariant";
|
|
499
|
+
|
|
500
|
+
// src/internal/common/proxy/ownership.ts
|
|
501
|
+
import { invariant as invariant5 } from "@dxos/invariant";
|
|
502
|
+
var __dxlog_file5 = "/__w/dxos/dxos/packages/core/echo/echo/src/internal/common/proxy/ownership.ts";
|
|
503
|
+
var EchoOwner = /* @__PURE__ */ Symbol.for("@dxos/echo/Owner");
|
|
504
|
+
var getRawTarget = (value2) => {
|
|
505
|
+
return isProxy(value2) ? getProxyTarget(value2) : value2;
|
|
506
|
+
};
|
|
507
|
+
var getOwner = (value2) => {
|
|
508
|
+
return value2?.[EchoOwner];
|
|
509
|
+
};
|
|
510
|
+
var setMetaOwner = (metaTarget, parent) => {
|
|
511
|
+
defineHiddenProperty(metaTarget, EchoOwner, parent);
|
|
512
|
+
};
|
|
513
|
+
var setOwnerRecursive = (value2, owner, options = {}) => {
|
|
514
|
+
const { visited = /* @__PURE__ */ new Set(), depth = 0, allowedPreviousOwner } = options;
|
|
515
|
+
if (value2 == null || typeof value2 !== "object") {
|
|
516
|
+
return;
|
|
517
|
+
}
|
|
518
|
+
const actualValue = getRawTarget(value2);
|
|
519
|
+
if (visited.has(actualValue)) {
|
|
520
|
+
return;
|
|
521
|
+
}
|
|
522
|
+
visited.add(actualValue);
|
|
523
|
+
const existingOwner = getOwner(actualValue);
|
|
524
|
+
const isRootEchoObject = EventId in actualValue;
|
|
525
|
+
let newAllowedPreviousOwner = allowedPreviousOwner;
|
|
526
|
+
if (isRootEchoObject && depth === 0) {
|
|
527
|
+
newAllowedPreviousOwner = actualValue;
|
|
528
|
+
}
|
|
529
|
+
if (!isRootEchoObject) {
|
|
530
|
+
const ownershipAllowed = existingOwner == null || existingOwner === owner || existingOwner === newAllowedPreviousOwner;
|
|
531
|
+
invariant5(ownershipAllowed, "Cannot reassign ownership of a nested record to a different ECHO object. Use deep copy first.", {
|
|
532
|
+
F: __dxlog_file5,
|
|
533
|
+
L: 101,
|
|
534
|
+
S: void 0,
|
|
535
|
+
A: [
|
|
536
|
+
"ownershipAllowed",
|
|
537
|
+
"'Cannot reassign ownership of a nested record to a different ECHO object. Use deep copy first.'"
|
|
538
|
+
]
|
|
539
|
+
});
|
|
540
|
+
}
|
|
541
|
+
defineHiddenProperty(actualValue, EchoOwner, owner);
|
|
542
|
+
const recursiveOptions = {
|
|
543
|
+
visited,
|
|
544
|
+
depth: depth + 1,
|
|
545
|
+
allowedPreviousOwner: newAllowedPreviousOwner
|
|
546
|
+
};
|
|
547
|
+
if (Array.isArray(actualValue)) {
|
|
548
|
+
for (const item of actualValue) {
|
|
549
|
+
if (isValidProxyTarget(item) || isProxy(item)) {
|
|
550
|
+
setOwnerRecursive(item, owner, recursiveOptions);
|
|
551
|
+
}
|
|
552
|
+
}
|
|
553
|
+
} else {
|
|
554
|
+
for (const key in actualValue) {
|
|
555
|
+
if (Object.prototype.hasOwnProperty.call(actualValue, key)) {
|
|
556
|
+
const nested = actualValue[key];
|
|
557
|
+
if (isValidProxyTarget(nested) || isProxy(nested)) {
|
|
558
|
+
setOwnerRecursive(nested, owner, recursiveOptions);
|
|
559
|
+
}
|
|
560
|
+
}
|
|
561
|
+
}
|
|
562
|
+
}
|
|
563
|
+
};
|
|
564
|
+
var traverseObjectGraph = (value2, visitor, visited = /* @__PURE__ */ new Set()) => {
|
|
565
|
+
if (value2 == null || typeof value2 !== "object") {
|
|
566
|
+
return false;
|
|
567
|
+
}
|
|
568
|
+
const actualValue = getRawTarget(value2);
|
|
569
|
+
if (visited.has(actualValue)) {
|
|
570
|
+
return false;
|
|
571
|
+
}
|
|
572
|
+
visited.add(actualValue);
|
|
573
|
+
if (visitor(actualValue)) {
|
|
574
|
+
return true;
|
|
575
|
+
}
|
|
576
|
+
if (Array.isArray(actualValue)) {
|
|
577
|
+
for (const item of actualValue) {
|
|
578
|
+
if (traverseObjectGraph(item, visitor, visited)) {
|
|
579
|
+
return true;
|
|
580
|
+
}
|
|
581
|
+
}
|
|
582
|
+
} else {
|
|
583
|
+
for (const key in actualValue) {
|
|
584
|
+
if (Object.prototype.hasOwnProperty.call(actualValue, key)) {
|
|
585
|
+
if (traverseObjectGraph(actualValue[key], visitor, visited)) {
|
|
586
|
+
return true;
|
|
587
|
+
}
|
|
588
|
+
}
|
|
589
|
+
}
|
|
590
|
+
}
|
|
591
|
+
return false;
|
|
592
|
+
};
|
|
593
|
+
var wouldCreateCycle = (targetRoot, value2) => traverseObjectGraph(value2, (v) => v === targetRoot);
|
|
594
|
+
var hasForeignOwner = (value2, target) => traverseObjectGraph(value2, (v) => {
|
|
595
|
+
const owner = getOwner(v);
|
|
596
|
+
if (owner != null && owner !== target) {
|
|
597
|
+
return true;
|
|
598
|
+
}
|
|
599
|
+
if (EventId in v && v !== target) {
|
|
600
|
+
return true;
|
|
601
|
+
}
|
|
602
|
+
return false;
|
|
603
|
+
});
|
|
604
|
+
var MAX_OWNER_DEPTH = 100;
|
|
605
|
+
var getEchoRoot = (target, depth = 0) => {
|
|
606
|
+
invariant5(depth < MAX_OWNER_DEPTH, "Owner chain too deep - possible circular ownership", {
|
|
607
|
+
F: __dxlog_file5,
|
|
608
|
+
L: 220,
|
|
609
|
+
S: void 0,
|
|
610
|
+
A: [
|
|
611
|
+
"depth < MAX_OWNER_DEPTH",
|
|
612
|
+
"'Owner chain too deep - possible circular ownership'"
|
|
613
|
+
]
|
|
614
|
+
});
|
|
615
|
+
if (KindId in target) {
|
|
616
|
+
return target;
|
|
617
|
+
}
|
|
618
|
+
const owner = getOwner(target);
|
|
619
|
+
if (owner) {
|
|
620
|
+
return getEchoRoot(owner, depth + 1);
|
|
621
|
+
}
|
|
622
|
+
return target;
|
|
623
|
+
};
|
|
624
|
+
var notifyOwnerChain = (target) => {
|
|
625
|
+
const owner = getOwner(target);
|
|
626
|
+
if (owner) {
|
|
627
|
+
queueOwnerNotification(getEchoRoot(owner));
|
|
628
|
+
notifyOwnerChain(owner);
|
|
629
|
+
}
|
|
630
|
+
};
|
|
631
|
+
|
|
632
|
+
// src/internal/common/proxy/proxy-types.ts
|
|
633
|
+
var objectData = /* @__PURE__ */ Symbol.for("@dxos/live-object/objectData");
|
|
634
|
+
|
|
635
|
+
// src/internal/common/proxy/reactive-array.ts
|
|
636
|
+
var checkArrayMutationAllowed = (arr, method) => {
|
|
637
|
+
const target = isProxy(arr) ? getProxyTarget(arr) : arr;
|
|
638
|
+
const echoRoot = getEchoRoot(target);
|
|
639
|
+
const isInitialized = echoRoot[ChangeId] === true || EventId in echoRoot;
|
|
640
|
+
if (!isInitialized) {
|
|
641
|
+
return;
|
|
642
|
+
}
|
|
643
|
+
if (!isInChangeContext(echoRoot)) {
|
|
644
|
+
throw createArrayMethodError(method);
|
|
645
|
+
}
|
|
646
|
+
};
|
|
647
|
+
var ReactiveArray = class extends Array {
|
|
648
|
+
static get [Symbol.species]() {
|
|
649
|
+
return Array;
|
|
650
|
+
}
|
|
651
|
+
static {
|
|
652
|
+
const BATCHED_METHODS = [
|
|
653
|
+
"push",
|
|
654
|
+
"pop",
|
|
655
|
+
"shift",
|
|
656
|
+
"unshift",
|
|
657
|
+
"splice",
|
|
658
|
+
"sort",
|
|
659
|
+
"reverse"
|
|
660
|
+
];
|
|
661
|
+
for (const method of BATCHED_METHODS) {
|
|
662
|
+
Object.defineProperty(this.prototype, method, {
|
|
663
|
+
enumerable: false,
|
|
664
|
+
value: function(...args) {
|
|
665
|
+
checkArrayMutationAllowed(this, method);
|
|
666
|
+
let result;
|
|
667
|
+
batchEvents(() => {
|
|
668
|
+
result = Array.prototype[method].apply(this, args);
|
|
669
|
+
});
|
|
670
|
+
return result;
|
|
671
|
+
}
|
|
672
|
+
});
|
|
673
|
+
}
|
|
674
|
+
}
|
|
675
|
+
};
|
|
676
|
+
|
|
677
|
+
// src/internal/common/proxy/schema-validator.ts
|
|
678
|
+
import * as Schema3 from "effect/Schema";
|
|
679
|
+
import * as SchemaAST2 from "effect/SchemaAST";
|
|
680
|
+
import { invariant as invariant6 } from "@dxos/invariant";
|
|
681
|
+
import { log } from "@dxos/log";
|
|
682
|
+
var __dxlog_file6 = "/__w/dxos/dxos/packages/core/echo/echo/src/internal/common/proxy/schema-validator.ts";
|
|
683
|
+
var SchemaValidator = class {
|
|
684
|
+
/**
|
|
685
|
+
* Recursively check that schema specifies constructions we can handle.
|
|
686
|
+
* Validates there are no ambiguous discriminated union types.
|
|
687
|
+
*/
|
|
688
|
+
static validateSchema(schema) {
|
|
689
|
+
const visitAll = (nodes) => nodes.forEach((node) => this.validateSchema(Schema3.make(node)));
|
|
690
|
+
if (SchemaAST2.isUnion(schema.ast)) {
|
|
691
|
+
const typeAstList = schema.ast.types.filter((type) => SchemaAST2.isTypeLiteral(type));
|
|
692
|
+
if (typeAstList.length > 1) {
|
|
693
|
+
getTypeDiscriminators(typeAstList);
|
|
694
|
+
}
|
|
695
|
+
visitAll(typeAstList);
|
|
696
|
+
} else if (SchemaAST2.isTupleType(schema.ast)) {
|
|
697
|
+
const positionalTypes = schema.ast.elements.map((t) => t.type);
|
|
698
|
+
const allTypes = positionalTypes.concat(schema.ast.rest.map((t) => t.type));
|
|
699
|
+
visitAll(allTypes);
|
|
700
|
+
} else if (SchemaAST2.isTypeLiteral(schema.ast)) {
|
|
701
|
+
visitAll(SchemaAST2.getPropertySignatures(schema.ast).map((p) => p.type));
|
|
702
|
+
}
|
|
703
|
+
}
|
|
704
|
+
static hasTypeAnnotation(rootObjectSchema, property, annotation) {
|
|
705
|
+
try {
|
|
706
|
+
let type = this.getPropertySchema(rootObjectSchema, [
|
|
707
|
+
property
|
|
708
|
+
]);
|
|
709
|
+
if (SchemaAST2.isTupleType(type.ast)) {
|
|
710
|
+
type = this.getPropertySchema(rootObjectSchema, [
|
|
711
|
+
property,
|
|
712
|
+
"0"
|
|
713
|
+
]);
|
|
714
|
+
}
|
|
715
|
+
return type.ast.annotations[annotation] != null;
|
|
716
|
+
} catch {
|
|
717
|
+
return false;
|
|
718
|
+
}
|
|
719
|
+
}
|
|
720
|
+
static getPropertySchema(rootObjectSchema, propertyPath, getProperty = () => null) {
|
|
721
|
+
let schema = rootObjectSchema;
|
|
722
|
+
for (let i = 0; i < propertyPath.length; i++) {
|
|
723
|
+
const propertyName = propertyPath[i];
|
|
724
|
+
const tupleAst = unwrapArray(schema.ast);
|
|
725
|
+
if (tupleAst != null) {
|
|
726
|
+
schema = getArrayElementSchema(tupleAst, propertyName);
|
|
727
|
+
} else {
|
|
728
|
+
const propertyType = getPropertyType(schema.ast, propertyName.toString(), (propertyName2) => getProperty([
|
|
729
|
+
...propertyPath.slice(0, i),
|
|
730
|
+
propertyName2
|
|
731
|
+
]));
|
|
732
|
+
if (propertyType == null) {
|
|
733
|
+
log.warn("unknown property", {
|
|
734
|
+
path: propertyPath,
|
|
735
|
+
property: propertyName
|
|
736
|
+
}, {
|
|
737
|
+
F: __dxlog_file6,
|
|
738
|
+
L: 71,
|
|
739
|
+
S: this,
|
|
740
|
+
C: (f, a) => f(...a)
|
|
741
|
+
});
|
|
742
|
+
continue;
|
|
743
|
+
}
|
|
744
|
+
schema = Schema3.make(propertyType).annotations(propertyType.annotations);
|
|
745
|
+
}
|
|
746
|
+
}
|
|
747
|
+
return schema;
|
|
748
|
+
}
|
|
749
|
+
static getTargetPropertySchema(target, prop) {
|
|
750
|
+
const schema = target[SchemaId];
|
|
751
|
+
invariant6(schema, "target has no schema", {
|
|
752
|
+
F: __dxlog_file6,
|
|
753
|
+
L: 84,
|
|
754
|
+
S: this,
|
|
755
|
+
A: [
|
|
756
|
+
"schema",
|
|
757
|
+
"'target has no schema'"
|
|
758
|
+
]
|
|
759
|
+
});
|
|
760
|
+
const arrayAst = unwrapArray(schema.ast);
|
|
761
|
+
if (arrayAst != null) {
|
|
762
|
+
return getArrayElementSchema(arrayAst, prop);
|
|
763
|
+
}
|
|
764
|
+
const propertyType = getPropertyType(schema.ast, prop.toString(), (prop2) => target[prop2]);
|
|
765
|
+
if (propertyType == null) {
|
|
766
|
+
return Schema3.Any;
|
|
767
|
+
}
|
|
768
|
+
invariant6(propertyType, `invalid property: ${prop.toString()}`, {
|
|
769
|
+
F: __dxlog_file6,
|
|
770
|
+
L: 95,
|
|
771
|
+
S: this,
|
|
772
|
+
A: [
|
|
773
|
+
"propertyType",
|
|
774
|
+
"`invalid property: ${prop.toString()}`"
|
|
775
|
+
]
|
|
776
|
+
});
|
|
777
|
+
return Schema3.make(propertyType);
|
|
778
|
+
}
|
|
779
|
+
};
|
|
780
|
+
var getArrayElementSchema = (tupleAst, property) => {
|
|
781
|
+
const elementIndex = typeof property === "string" ? parseInt(property, 10) : Number.NaN;
|
|
782
|
+
if (Number.isNaN(elementIndex)) {
|
|
783
|
+
invariant6(property === "length", `invalid array property: ${String(property)}`, {
|
|
784
|
+
F: __dxlog_file6,
|
|
785
|
+
L: 111,
|
|
786
|
+
S: void 0,
|
|
787
|
+
A: [
|
|
788
|
+
"property === 'length'",
|
|
789
|
+
"`invalid array property: ${String(property)}`"
|
|
790
|
+
]
|
|
791
|
+
});
|
|
792
|
+
return Schema3.Number;
|
|
793
|
+
}
|
|
794
|
+
if (elementIndex < tupleAst.elements.length) {
|
|
795
|
+
const elementType = tupleAst.elements[elementIndex].type;
|
|
796
|
+
return Schema3.make(elementType).annotations(elementType.annotations);
|
|
797
|
+
}
|
|
798
|
+
const restType = tupleAst.rest;
|
|
799
|
+
return Schema3.make(restType[0].type).annotations(restType[0].annotations);
|
|
800
|
+
};
|
|
801
|
+
var flattenUnion = (typeAst) => SchemaAST2.isUnion(typeAst) ? typeAst.types.flatMap(flattenUnion) : [
|
|
802
|
+
typeAst
|
|
803
|
+
];
|
|
804
|
+
var getProperties = (typeAst, getTargetPropertyFn) => {
|
|
805
|
+
const astCandidates = flattenUnion(typeAst);
|
|
806
|
+
const typeAstList = astCandidates.filter((type) => SchemaAST2.isTypeLiteral(type));
|
|
807
|
+
if (typeAstList.length === 0) {
|
|
808
|
+
return [];
|
|
809
|
+
}
|
|
810
|
+
if (typeAstList.length === 1) {
|
|
811
|
+
return SchemaAST2.getPropertySignatures(typeAstList[0]);
|
|
812
|
+
}
|
|
813
|
+
const typeDiscriminators = getTypeDiscriminators(typeAstList);
|
|
814
|
+
const targetPropertyValue = getTargetPropertyFn(String(typeDiscriminators[0].name));
|
|
815
|
+
const typeIndex = typeDiscriminators.findIndex((p) => targetPropertyValue === p.type.literal);
|
|
816
|
+
invariant6(typeIndex !== -1, "discriminator field not set on target", {
|
|
817
|
+
F: __dxlog_file6,
|
|
818
|
+
L: 142,
|
|
819
|
+
S: void 0,
|
|
820
|
+
A: [
|
|
821
|
+
"typeIndex !== -1",
|
|
822
|
+
"'discriminator field not set on target'"
|
|
823
|
+
]
|
|
824
|
+
});
|
|
825
|
+
return SchemaAST2.getPropertySignatures(typeAstList[typeIndex]);
|
|
826
|
+
};
|
|
827
|
+
var getPropertyType = (ast, propertyName, getTargetPropertyFn) => {
|
|
828
|
+
const anyOrObject = unwrapAst(ast, (candidate) => SchemaAST2.isAnyKeyword(candidate) || SchemaAST2.isObjectKeyword(candidate));
|
|
829
|
+
if (anyOrObject != null) {
|
|
830
|
+
return ast;
|
|
831
|
+
}
|
|
832
|
+
const typeOrDiscriminatedUnion = unwrapAst(ast, (t) => {
|
|
833
|
+
return SchemaAST2.isTypeLiteral(t) || SchemaAST2.isUnion(t) && t.types.some((t2) => SchemaAST2.isTypeLiteral(t2));
|
|
834
|
+
});
|
|
835
|
+
if (typeOrDiscriminatedUnion == null) {
|
|
836
|
+
return null;
|
|
837
|
+
}
|
|
838
|
+
const targetProperty = getProperties(typeOrDiscriminatedUnion, getTargetPropertyFn).find((p) => p.name === propertyName);
|
|
839
|
+
if (targetProperty != null) {
|
|
840
|
+
return unwrapAst(targetProperty.type);
|
|
841
|
+
}
|
|
842
|
+
const indexSignatureType = unwrapAst(ast, SchemaAST2.isTypeLiteral);
|
|
843
|
+
if (indexSignatureType && SchemaAST2.isTypeLiteral(indexSignatureType) && indexSignatureType.indexSignatures.length > 0) {
|
|
844
|
+
return unwrapAst(indexSignatureType.indexSignatures[0].type);
|
|
845
|
+
}
|
|
846
|
+
return null;
|
|
847
|
+
};
|
|
848
|
+
var getTypeDiscriminators = (typeAstList) => {
|
|
849
|
+
const discriminatorPropCandidates = typeAstList.flatMap(SchemaAST2.getPropertySignatures).filter((p) => SchemaAST2.isLiteral(p.type));
|
|
850
|
+
const propertyName = discriminatorPropCandidates[0].name;
|
|
851
|
+
const isValidDiscriminator = discriminatorPropCandidates.every((p) => p.name === propertyName && !p.isOptional);
|
|
852
|
+
const everyTypeHasDiscriminator = discriminatorPropCandidates.length === typeAstList.length;
|
|
853
|
+
const isDiscriminatedUnion = isValidDiscriminator && everyTypeHasDiscriminator;
|
|
854
|
+
invariant6(isDiscriminatedUnion, "type ambiguity: every type in a union must have a single unique-literal field", {
|
|
855
|
+
F: __dxlog_file6,
|
|
856
|
+
L: 193,
|
|
857
|
+
S: void 0,
|
|
858
|
+
A: [
|
|
859
|
+
"isDiscriminatedUnion",
|
|
860
|
+
"'type ambiguity: every type in a union must have a single unique-literal field'"
|
|
861
|
+
]
|
|
862
|
+
});
|
|
863
|
+
return discriminatorPropCandidates;
|
|
864
|
+
};
|
|
865
|
+
var unwrapAst = (rootAst, predicate) => {
|
|
866
|
+
let ast = rootAst;
|
|
867
|
+
while (ast != null) {
|
|
868
|
+
if (predicate?.(ast)) {
|
|
869
|
+
return ast;
|
|
870
|
+
}
|
|
871
|
+
if (SchemaAST2.isUnion(ast)) {
|
|
872
|
+
const next = ast.types.find((t) => predicate != null && predicate(t) || SchemaAST2.isSuspend(t));
|
|
873
|
+
if (next != null) {
|
|
874
|
+
ast = next;
|
|
875
|
+
continue;
|
|
876
|
+
}
|
|
877
|
+
}
|
|
878
|
+
if (SchemaAST2.isSuspend(ast)) {
|
|
879
|
+
ast = ast.f();
|
|
880
|
+
} else {
|
|
881
|
+
return predicate == null ? ast : null;
|
|
882
|
+
}
|
|
883
|
+
}
|
|
884
|
+
return null;
|
|
885
|
+
};
|
|
886
|
+
var unwrapArray = (ast) => unwrapAst(ast, SchemaAST2.isTupleType);
|
|
887
|
+
var checkIdNotPresentOnSchema = (schema) => {
|
|
888
|
+
invariant6(SchemaAST2.isTypeLiteral(schema.ast), void 0, {
|
|
889
|
+
F: __dxlog_file6,
|
|
890
|
+
L: 236,
|
|
891
|
+
S: void 0,
|
|
892
|
+
A: [
|
|
893
|
+
"SchemaAST.isTypeLiteral(schema.ast)",
|
|
894
|
+
""
|
|
895
|
+
]
|
|
896
|
+
});
|
|
897
|
+
const idProperty = SchemaAST2.getPropertySignatures(schema.ast).find((prop) => prop.name === "id");
|
|
898
|
+
if (idProperty != null) {
|
|
899
|
+
throw new Error('"id" property name is reserved');
|
|
900
|
+
}
|
|
901
|
+
};
|
|
902
|
+
|
|
903
|
+
// src/internal/common/proxy/typed-handler.ts
|
|
904
|
+
var __dxlog_file7 = "/__w/dxos/dxos/packages/core/echo/echo/src/internal/common/proxy/typed-handler.ts";
|
|
905
|
+
var deepCopy = (value2, visited = /* @__PURE__ */ new Map()) => {
|
|
906
|
+
if (value2 == null || typeof value2 !== "object") {
|
|
907
|
+
return value2;
|
|
908
|
+
}
|
|
909
|
+
const actualValue = getRawTarget(value2);
|
|
910
|
+
if (visited.has(actualValue)) {
|
|
911
|
+
return visited.get(actualValue);
|
|
912
|
+
}
|
|
913
|
+
if (actualValue instanceof ReactiveArray) {
|
|
914
|
+
const copy2 = new ReactiveArray();
|
|
915
|
+
visited.set(actualValue, copy2);
|
|
916
|
+
for (const item of actualValue) {
|
|
917
|
+
copy2.push(deepCopy(item, visited));
|
|
918
|
+
}
|
|
919
|
+
copyHiddenProperties(actualValue, copy2);
|
|
920
|
+
return copy2;
|
|
921
|
+
}
|
|
922
|
+
const proto = Object.getPrototypeOf(actualValue);
|
|
923
|
+
if (proto !== Object.prototype && proto !== Array.prototype && proto !== null) {
|
|
924
|
+
return value2;
|
|
925
|
+
}
|
|
926
|
+
if (Array.isArray(actualValue)) {
|
|
927
|
+
const copy2 = new ReactiveArray();
|
|
928
|
+
visited.set(actualValue, copy2);
|
|
929
|
+
for (const item of actualValue) {
|
|
930
|
+
copy2.push(deepCopy(item, visited));
|
|
931
|
+
}
|
|
932
|
+
return copy2;
|
|
933
|
+
}
|
|
934
|
+
const copy = {};
|
|
935
|
+
visited.set(actualValue, copy);
|
|
936
|
+
for (const key of Object.keys(actualValue)) {
|
|
937
|
+
copy[key] = deepCopy(actualValue[key], visited);
|
|
938
|
+
}
|
|
939
|
+
copyHiddenProperties(actualValue, copy);
|
|
940
|
+
return copy;
|
|
941
|
+
};
|
|
942
|
+
var copyHiddenProperties = (source, target) => {
|
|
943
|
+
if (SchemaId in source) {
|
|
944
|
+
defineHiddenProperty(target, SchemaId, source[SchemaId]);
|
|
945
|
+
}
|
|
946
|
+
if (TypeId in source) {
|
|
947
|
+
defineHiddenProperty(target, TypeId, source[TypeId]);
|
|
948
|
+
}
|
|
949
|
+
};
|
|
950
|
+
var TypedReactiveHandler = class _TypedReactiveHandler {
|
|
951
|
+
static instance = new _TypedReactiveHandler();
|
|
952
|
+
_proxyMap = /* @__PURE__ */ new WeakMap();
|
|
953
|
+
_inSet = false;
|
|
954
|
+
constructor() {
|
|
955
|
+
}
|
|
956
|
+
init(target) {
|
|
957
|
+
invariant7(typeof target === "object" && target !== null, void 0, {
|
|
958
|
+
F: __dxlog_file7,
|
|
959
|
+
L: 145,
|
|
960
|
+
S: this,
|
|
961
|
+
A: [
|
|
962
|
+
"typeof target === 'object' && target !== null",
|
|
963
|
+
""
|
|
964
|
+
]
|
|
965
|
+
});
|
|
966
|
+
invariant7(SchemaId in target, "Schema is not defined for the target", {
|
|
967
|
+
F: __dxlog_file7,
|
|
968
|
+
L: 146,
|
|
969
|
+
S: this,
|
|
970
|
+
A: [
|
|
971
|
+
"SchemaId in target",
|
|
972
|
+
"'Schema is not defined for the target'"
|
|
973
|
+
]
|
|
974
|
+
});
|
|
975
|
+
const hasOwner = !!getOwner(target);
|
|
976
|
+
if (!(EventId in target) && !hasOwner) {
|
|
977
|
+
defineHiddenProperty(target, EventId, new Event());
|
|
978
|
+
}
|
|
979
|
+
defineHiddenProperty(target, ObjectDeletedId, false);
|
|
980
|
+
if (!hasOwner && !(ChangeId in target)) {
|
|
981
|
+
defineHiddenProperty(target, ChangeId, true);
|
|
982
|
+
}
|
|
983
|
+
if (!hasOwner) {
|
|
984
|
+
for (const key in target) {
|
|
985
|
+
if (target[symbolIsProxy]) {
|
|
986
|
+
continue;
|
|
987
|
+
}
|
|
988
|
+
let value2 = target[key];
|
|
989
|
+
if (isValidProxyTarget(value2) || isProxy(value2)) {
|
|
990
|
+
if (hasForeignOwner(value2, target)) {
|
|
991
|
+
value2 = deepCopy(value2);
|
|
992
|
+
target[key] = value2;
|
|
993
|
+
}
|
|
994
|
+
setOwnerRecursive(value2, target);
|
|
995
|
+
}
|
|
996
|
+
}
|
|
997
|
+
}
|
|
998
|
+
Object.defineProperty(target, inspectCustom, {
|
|
999
|
+
enumerable: false,
|
|
1000
|
+
configurable: true,
|
|
1001
|
+
value: this._inspect.bind(target)
|
|
1002
|
+
});
|
|
1003
|
+
}
|
|
1004
|
+
get(target, prop, receiver) {
|
|
1005
|
+
switch (prop) {
|
|
1006
|
+
// TODO(burdon): Remove?
|
|
1007
|
+
case objectData: {
|
|
1008
|
+
return toJSON(target);
|
|
1009
|
+
}
|
|
1010
|
+
case ChangeId: {
|
|
1011
|
+
if (target[ChangeId] !== true) {
|
|
1012
|
+
return void 0;
|
|
1013
|
+
}
|
|
1014
|
+
return (callback) => executeChange(target, target, receiver, callback);
|
|
1015
|
+
}
|
|
1016
|
+
}
|
|
1017
|
+
if (Object.getOwnPropertyDescriptor(target, prop)?.get) {
|
|
1018
|
+
return Reflect.get(target, prop, receiver);
|
|
1019
|
+
}
|
|
1020
|
+
const value2 = Reflect.get(target, prop, receiver);
|
|
1021
|
+
if (isValidProxyTarget(value2)) {
|
|
1022
|
+
return createProxy(value2, this);
|
|
1023
|
+
}
|
|
1024
|
+
return value2;
|
|
1025
|
+
}
|
|
1026
|
+
set(target, prop, value2, receiver) {
|
|
1027
|
+
const echoRoot = getEchoRoot(target);
|
|
1028
|
+
const isInitialized = ChangeId in echoRoot || EventId in echoRoot;
|
|
1029
|
+
const isSymbolProp = typeof prop === "symbol";
|
|
1030
|
+
if (isInitialized && !isSymbolProp && !isInChangeContext(echoRoot)) {
|
|
1031
|
+
throw new Error(`Cannot modify object property "${String(prop)}" outside of Obj.change(). Use Obj.change(obj, (mutableObj) => { mutableObj.property = value; }) instead.`);
|
|
1032
|
+
}
|
|
1033
|
+
let result = false;
|
|
1034
|
+
this._inSet = true;
|
|
1035
|
+
try {
|
|
1036
|
+
batchEvents(() => {
|
|
1037
|
+
const { echoRoot: _, preparedValue } = this._prepareValueForAssignment(target, prop, value2);
|
|
1038
|
+
result = Reflect.set(target, prop, preparedValue, receiver);
|
|
1039
|
+
if (isInitialized) {
|
|
1040
|
+
queueNotification(echoRoot);
|
|
1041
|
+
notifyOwnerChain(target);
|
|
1042
|
+
}
|
|
1043
|
+
});
|
|
1044
|
+
} finally {
|
|
1045
|
+
this._inSet = false;
|
|
1046
|
+
}
|
|
1047
|
+
return result;
|
|
1048
|
+
}
|
|
1049
|
+
ownKeys(target) {
|
|
1050
|
+
return Reflect.ownKeys(target);
|
|
1051
|
+
}
|
|
1052
|
+
deleteProperty(target, property) {
|
|
1053
|
+
const echoRoot = getEchoRoot(target);
|
|
1054
|
+
const isInitialized = echoRoot[ChangeId] === true || EventId in echoRoot;
|
|
1055
|
+
const isSymbolProp = typeof property === "symbol";
|
|
1056
|
+
if (isInitialized && !isSymbolProp && !isInChangeContext(echoRoot)) {
|
|
1057
|
+
throw createPropertyDeleteError(property);
|
|
1058
|
+
}
|
|
1059
|
+
const result = Reflect.deleteProperty(target, property);
|
|
1060
|
+
if (isInitialized) {
|
|
1061
|
+
queueNotification(echoRoot);
|
|
1062
|
+
}
|
|
1063
|
+
return result;
|
|
1064
|
+
}
|
|
1065
|
+
defineProperty(target, property, attributes) {
|
|
1066
|
+
const echoRoot = getEchoRoot(target);
|
|
1067
|
+
const isInitialized = ChangeId in echoRoot || EventId in echoRoot;
|
|
1068
|
+
const isSymbolProp = typeof property === "symbol";
|
|
1069
|
+
if (isInitialized && !isSymbolProp && !isInChangeContext(echoRoot)) {
|
|
1070
|
+
throw new Error(`Cannot modify object property "${String(property)}" outside of Obj.change(). Use Obj.change(obj, (mutableObj) => { mutableObj.property = value; }) instead.`);
|
|
1071
|
+
}
|
|
1072
|
+
const { echoRoot: _, preparedValue } = this._prepareValueForAssignment(target, property, attributes.value);
|
|
1073
|
+
const result = Reflect.defineProperty(target, property, {
|
|
1074
|
+
...attributes,
|
|
1075
|
+
value: preparedValue
|
|
1076
|
+
});
|
|
1077
|
+
if (!this._inSet && isInitialized) {
|
|
1078
|
+
queueNotification(echoRoot);
|
|
1079
|
+
}
|
|
1080
|
+
return result;
|
|
1081
|
+
}
|
|
1082
|
+
/**
|
|
1083
|
+
* Prepare a value for assignment to a typed object property.
|
|
1084
|
+
* Handles cycle detection, copy-on-assign, array conversion, validation, and ownership.
|
|
1085
|
+
*/
|
|
1086
|
+
_prepareValueForAssignment(target, prop, value2) {
|
|
1087
|
+
const echoRoot = getEchoRoot(target);
|
|
1088
|
+
if (prop === ParentId) {
|
|
1089
|
+
return {
|
|
1090
|
+
echoRoot,
|
|
1091
|
+
preparedValue: value2
|
|
1092
|
+
};
|
|
1093
|
+
}
|
|
1094
|
+
if (isValidProxyTarget(value2) || isProxy(value2)) {
|
|
1095
|
+
if (wouldCreateCycle(echoRoot, value2)) {
|
|
1096
|
+
throw new Error("Cannot create cycles in typed object graph. Consider using Ref for circular references.");
|
|
1097
|
+
}
|
|
1098
|
+
}
|
|
1099
|
+
if (isValidProxyTarget(value2) || isProxy(value2)) {
|
|
1100
|
+
const actualValue = getRawTarget(value2);
|
|
1101
|
+
const isRootEchoObject = EventId in actualValue;
|
|
1102
|
+
if (isRootEchoObject) {
|
|
1103
|
+
throw new Error("Object references must be wrapped with `Ref.make`");
|
|
1104
|
+
}
|
|
1105
|
+
}
|
|
1106
|
+
if (isValidProxyTarget(value2) || isProxy(value2)) {
|
|
1107
|
+
const actualValue = getRawTarget(value2);
|
|
1108
|
+
const existingOwner = getOwner(actualValue);
|
|
1109
|
+
if (existingOwner != null && existingOwner !== echoRoot) {
|
|
1110
|
+
value2 = deepCopy(value2);
|
|
1111
|
+
}
|
|
1112
|
+
}
|
|
1113
|
+
if (Array.isArray(value2) && !(value2 instanceof ReactiveArray)) {
|
|
1114
|
+
value2 = ReactiveArray.from(value2);
|
|
1115
|
+
}
|
|
1116
|
+
const validatedValue = this._validateValue(target, prop, value2);
|
|
1117
|
+
if (isValidProxyTarget(validatedValue) || isProxy(validatedValue)) {
|
|
1118
|
+
setOwnerRecursive(validatedValue, echoRoot);
|
|
1119
|
+
}
|
|
1120
|
+
return {
|
|
1121
|
+
echoRoot,
|
|
1122
|
+
preparedValue: validatedValue
|
|
1123
|
+
};
|
|
1124
|
+
}
|
|
1125
|
+
_validateValue(target, prop, value2) {
|
|
1126
|
+
if (prop === ParentId) {
|
|
1127
|
+
return value2;
|
|
1128
|
+
}
|
|
1129
|
+
const schema = SchemaValidator.getTargetPropertySchema(target, prop);
|
|
1130
|
+
const _ = Schema4.asserts(schema)(value2);
|
|
1131
|
+
if (isValidProxyTarget(value2)) {
|
|
1132
|
+
setSchemaProperties(value2, schema);
|
|
1133
|
+
}
|
|
1134
|
+
return value2;
|
|
1135
|
+
}
|
|
1136
|
+
_inspect(_, options, inspectFn) {
|
|
1137
|
+
const inspected = inspectFn(this, {
|
|
1138
|
+
...options,
|
|
1139
|
+
showHidden: false,
|
|
1140
|
+
customInspect: false
|
|
1141
|
+
});
|
|
1142
|
+
return `Typed ${inspected}`;
|
|
1143
|
+
}
|
|
1144
|
+
};
|
|
1145
|
+
var toJSON = (target) => {
|
|
1146
|
+
return {
|
|
1147
|
+
"@type": "TypedReactiveObject",
|
|
1148
|
+
...target
|
|
1149
|
+
};
|
|
1150
|
+
};
|
|
1151
|
+
var setSchemaProperties = (obj, schema) => {
|
|
1152
|
+
const schemaType = getSchemaDXN(schema);
|
|
1153
|
+
if (schemaType != null) {
|
|
1154
|
+
defineHiddenProperty(obj, TypeId, schemaType);
|
|
1155
|
+
}
|
|
1156
|
+
defineHiddenProperty(obj, SchemaId, schema);
|
|
1157
|
+
for (const key in obj) {
|
|
1158
|
+
if (isValidProxyTarget(obj[key])) {
|
|
1159
|
+
const elementSchema = SchemaValidator.getTargetPropertySchema(obj, key);
|
|
1160
|
+
if (elementSchema != null) {
|
|
1161
|
+
setSchemaProperties(obj[key], elementSchema);
|
|
1162
|
+
}
|
|
1163
|
+
}
|
|
1164
|
+
}
|
|
1165
|
+
};
|
|
1166
|
+
var prepareTypedTarget = (target, schema) => {
|
|
1167
|
+
if (!SchemaAST3.isTypeLiteral(schema.ast)) {
|
|
1168
|
+
throw new Error("schema has to describe an object type");
|
|
1169
|
+
}
|
|
1170
|
+
SchemaValidator.validateSchema(schema);
|
|
1171
|
+
const _ = Schema4.asserts(schema)(target);
|
|
1172
|
+
makeArraysReactive(target);
|
|
1173
|
+
setSchemaProperties(target, schema);
|
|
1174
|
+
};
|
|
1175
|
+
var makeArraysReactive = (target) => {
|
|
1176
|
+
for (const key in target) {
|
|
1177
|
+
if (target[symbolIsProxy]) {
|
|
1178
|
+
continue;
|
|
1179
|
+
}
|
|
1180
|
+
if (Array.isArray(target[key])) {
|
|
1181
|
+
target[key] = ReactiveArray.from(target[key]);
|
|
1182
|
+
}
|
|
1183
|
+
if (typeof target[key] === "object") {
|
|
1184
|
+
makeArraysReactive(target[key]);
|
|
1185
|
+
}
|
|
1186
|
+
}
|
|
1187
|
+
};
|
|
1188
|
+
|
|
1189
|
+
// src/internal/common/proxy/make-object.ts
|
|
1190
|
+
var makeObject = (schema, obj, meta) => {
|
|
1191
|
+
return createReactiveObject(Object.assign({}, obj), meta, schema);
|
|
1192
|
+
};
|
|
1193
|
+
var createReactiveObject = (obj, meta, schema) => {
|
|
1194
|
+
if (!isValidProxyTarget(obj)) {
|
|
1195
|
+
throw new Error("Value cannot be made into a reactive object.");
|
|
1196
|
+
}
|
|
1197
|
+
if (!schema) {
|
|
1198
|
+
throw new Error("Schema is required for reactive objects. Use Atom for untyped reactive state.");
|
|
1199
|
+
}
|
|
1200
|
+
const parent = obj[ParentId];
|
|
1201
|
+
if (parent !== void 0) {
|
|
1202
|
+
delete obj[ParentId];
|
|
1203
|
+
}
|
|
1204
|
+
const annotation = getTypeAnnotation(schema);
|
|
1205
|
+
if (annotation) {
|
|
1206
|
+
setIdOnTarget(obj);
|
|
1207
|
+
defineHiddenProperty(obj, KindId, annotation.kind);
|
|
1208
|
+
}
|
|
1209
|
+
initMeta(obj, meta);
|
|
1210
|
+
if (parent !== void 0) {
|
|
1211
|
+
defineHiddenProperty(obj, ParentId, parent);
|
|
1212
|
+
}
|
|
1213
|
+
prepareTypedTarget(obj, schema);
|
|
1214
|
+
attachTypedJsonSerializer(obj);
|
|
1215
|
+
const proxy = createProxy(obj, TypedReactiveHandler.instance);
|
|
1216
|
+
const metaProxy = obj[MetaId];
|
|
1217
|
+
if (metaProxy) {
|
|
1218
|
+
const metaTarget = getProxyTarget(metaProxy);
|
|
1219
|
+
if (metaTarget) {
|
|
1220
|
+
setMetaOwner(metaTarget, obj);
|
|
1221
|
+
}
|
|
1222
|
+
}
|
|
1223
|
+
return proxy;
|
|
1224
|
+
};
|
|
1225
|
+
var setIdOnTarget = (target) => {
|
|
1226
|
+
if ("id" in target && target.id !== void 0 && target.id !== null) {
|
|
1227
|
+
if (!ObjectId.isValid(target.id)) {
|
|
1228
|
+
throw new Error("Invalid object id format.");
|
|
1229
|
+
}
|
|
1230
|
+
} else {
|
|
1231
|
+
target.id = ObjectId.random();
|
|
1232
|
+
}
|
|
1233
|
+
};
|
|
1234
|
+
var initMeta = (obj, meta = {
|
|
1235
|
+
keys: []
|
|
1236
|
+
}) => {
|
|
1237
|
+
prepareTypedTarget(meta, ObjectMetaSchema);
|
|
1238
|
+
defineHiddenProperty(obj, MetaId, createProxy(meta, TypedReactiveHandler.instance));
|
|
1239
|
+
};
|
|
1240
|
+
|
|
1241
|
+
// src/internal/common/proxy/reactive.ts
|
|
1242
|
+
var subscribe = (obj, callback) => {
|
|
1243
|
+
const target = getProxyTarget(obj);
|
|
1244
|
+
if (target && EventId in target) {
|
|
1245
|
+
return target[EventId].on(callback);
|
|
1246
|
+
}
|
|
1247
|
+
return () => {
|
|
1248
|
+
};
|
|
1249
|
+
};
|
|
1250
|
+
var change = (obj, callback) => {
|
|
1251
|
+
const changeFn = obj[ChangeId];
|
|
1252
|
+
if (changeFn) {
|
|
1253
|
+
changeFn(callback);
|
|
1254
|
+
} else {
|
|
1255
|
+
callback(obj);
|
|
1256
|
+
}
|
|
1257
|
+
};
|
|
1258
|
+
|
|
1259
|
+
// src/internal/Entity/api.ts
|
|
1260
|
+
import { invariant as invariant10 } from "@dxos/invariant";
|
|
1261
|
+
import { assumeType as assumeType3 } from "@dxos/util";
|
|
1262
|
+
|
|
1263
|
+
// src/internal/Entity/model.ts
|
|
1264
|
+
import { invariant as invariant8 } from "@dxos/invariant";
|
|
1265
|
+
import { DXN as DXN2, ObjectId as ObjectId2 } from "@dxos/keys";
|
|
1266
|
+
import { assumeType } from "@dxos/util";
|
|
1267
|
+
var __dxlog_file8 = "/__w/dxos/dxos/packages/core/echo/echo/src/internal/Entity/model.ts";
|
|
1268
|
+
function assertObjectModel(obj) {
|
|
1269
|
+
invariant8(typeof obj === "object" && obj !== null, "Invalid object model: not an object", {
|
|
1270
|
+
F: __dxlog_file8,
|
|
1271
|
+
L: 94,
|
|
1272
|
+
S: this,
|
|
1273
|
+
A: [
|
|
1274
|
+
"typeof obj === 'object' && obj !== null",
|
|
1275
|
+
"'Invalid object model: not an object'"
|
|
1276
|
+
]
|
|
1277
|
+
});
|
|
1278
|
+
assumeType(obj);
|
|
1279
|
+
invariant8(ObjectId2.isValid(obj.id), "Invalid object model: invalid id", {
|
|
1280
|
+
F: __dxlog_file8,
|
|
1281
|
+
L: 96,
|
|
1282
|
+
S: this,
|
|
1283
|
+
A: [
|
|
1284
|
+
"ObjectId.isValid(obj.id)",
|
|
1285
|
+
"'Invalid object model: invalid id'"
|
|
1286
|
+
]
|
|
1287
|
+
});
|
|
1288
|
+
invariant8(obj[TypeId] === void 0 || obj[TypeId] instanceof DXN2, "Invalid object model: invalid type", {
|
|
1289
|
+
F: __dxlog_file8,
|
|
1290
|
+
L: 97,
|
|
1291
|
+
S: this,
|
|
1292
|
+
A: [
|
|
1293
|
+
"obj[TypeId] === undefined || obj[TypeId] instanceof DXN",
|
|
1294
|
+
"'Invalid object model: invalid type'"
|
|
1295
|
+
]
|
|
1296
|
+
});
|
|
1297
|
+
invariant8(obj[KindId] === EntityKind.Object || obj[KindId] === EntityKind.Relation, "Invalid object model: invalid entity kind", {
|
|
1298
|
+
F: __dxlog_file8,
|
|
1299
|
+
L: 98,
|
|
1300
|
+
S: this,
|
|
1301
|
+
A: [
|
|
1302
|
+
"obj[KindId] === EntityKind.Object || obj[KindId] === EntityKind.Relation",
|
|
1303
|
+
"'Invalid object model: invalid entity kind'"
|
|
1304
|
+
]
|
|
1305
|
+
});
|
|
1306
|
+
if (obj[KindId] === EntityKind.Relation) {
|
|
1307
|
+
invariant8(obj[RelationSourceDXNId] instanceof DXN2, "Invalid object model: invalid relation source", {
|
|
1308
|
+
F: __dxlog_file8,
|
|
1309
|
+
L: 104,
|
|
1310
|
+
S: this,
|
|
1311
|
+
A: [
|
|
1312
|
+
"obj[RelationSourceDXNId] instanceof DXN",
|
|
1313
|
+
"'Invalid object model: invalid relation source'"
|
|
1314
|
+
]
|
|
1315
|
+
});
|
|
1316
|
+
invariant8(obj[RelationTargetDXNId] instanceof DXN2, "Invalid object model: invalid relation target", {
|
|
1317
|
+
F: __dxlog_file8,
|
|
1318
|
+
L: 105,
|
|
1319
|
+
S: this,
|
|
1320
|
+
A: [
|
|
1321
|
+
"obj[RelationTargetDXNId] instanceof DXN",
|
|
1322
|
+
"'Invalid object model: invalid relation target'"
|
|
1323
|
+
]
|
|
1324
|
+
});
|
|
1325
|
+
invariant8(!(obj[RelationSourceId] instanceof DXN2), "Invalid object model: source pointer is a DXN", {
|
|
1326
|
+
F: __dxlog_file8,
|
|
1327
|
+
L: 106,
|
|
1328
|
+
S: this,
|
|
1329
|
+
A: [
|
|
1330
|
+
"!(obj[RelationSourceId] instanceof DXN)",
|
|
1331
|
+
"'Invalid object model: source pointer is a DXN'"
|
|
1332
|
+
]
|
|
1333
|
+
});
|
|
1334
|
+
invariant8(!(obj[RelationTargetId] instanceof DXN2), "Invalid object model: target pointer is a DXN", {
|
|
1335
|
+
F: __dxlog_file8,
|
|
1336
|
+
L: 107,
|
|
1337
|
+
S: this,
|
|
1338
|
+
A: [
|
|
1339
|
+
"!(obj[RelationTargetId] instanceof DXN)",
|
|
1340
|
+
"'Invalid object model: target pointer is a DXN'"
|
|
1341
|
+
]
|
|
1342
|
+
});
|
|
1343
|
+
}
|
|
1344
|
+
}
|
|
1345
|
+
|
|
1346
|
+
// src/internal/Entity/util.ts
|
|
1347
|
+
import * as Schema5 from "effect/Schema";
|
|
1348
|
+
import { assertArgument as assertArgument2, invariant as invariant9 } from "@dxos/invariant";
|
|
1349
|
+
import { DXN as DXN3, ObjectId as ObjectId3 } from "@dxos/keys";
|
|
1350
|
+
import { assumeType as assumeType2 } from "@dxos/util";
|
|
1351
|
+
var __dxlog_file9 = "/__w/dxos/dxos/packages/core/echo/echo/src/internal/Entity/util.ts";
|
|
1352
|
+
var getObjectDXN = (object) => {
|
|
1353
|
+
invariant9(!Schema5.isSchema(object), "schema not allowed in this function", {
|
|
1354
|
+
F: __dxlog_file9,
|
|
1355
|
+
L: 19,
|
|
1356
|
+
S: void 0,
|
|
1357
|
+
A: [
|
|
1358
|
+
"!Schema.isSchema(object)",
|
|
1359
|
+
"'schema not allowed in this function'"
|
|
1360
|
+
]
|
|
1361
|
+
});
|
|
1362
|
+
assertArgument2(typeof object === "object" && object != null, "object", "expected object");
|
|
1363
|
+
assumeType2(object);
|
|
1364
|
+
if (object[SelfDXNId]) {
|
|
1365
|
+
invariant9(object[SelfDXNId] instanceof DXN3, "Invalid object model: invalid self dxn", {
|
|
1366
|
+
F: __dxlog_file9,
|
|
1367
|
+
L: 24,
|
|
1368
|
+
S: void 0,
|
|
1369
|
+
A: [
|
|
1370
|
+
"object[SelfDXNId] instanceof DXN",
|
|
1371
|
+
"'Invalid object model: invalid self dxn'"
|
|
1372
|
+
]
|
|
1373
|
+
});
|
|
1374
|
+
return object[SelfDXNId];
|
|
1375
|
+
}
|
|
1376
|
+
if (!ObjectId3.isValid(object.id)) {
|
|
1377
|
+
throw new TypeError("Object id is not valid.");
|
|
1378
|
+
}
|
|
1379
|
+
return DXN3.fromLocalObjectId(object.id);
|
|
1380
|
+
};
|
|
1381
|
+
|
|
1382
|
+
// src/internal/Entity/api.ts
|
|
1383
|
+
var __dxlog_file10 = "/__w/dxos/dxos/packages/core/echo/echo/src/internal/Entity/api.ts";
|
|
1384
|
+
var getDXN = (entity) => {
|
|
1385
|
+
const dxn = getObjectDXN(entity);
|
|
1386
|
+
invariant10(dxn != null, "Invalid entity.", {
|
|
1387
|
+
F: __dxlog_file10,
|
|
1388
|
+
L: 19,
|
|
1389
|
+
S: void 0,
|
|
1390
|
+
A: [
|
|
1391
|
+
"dxn != null",
|
|
1392
|
+
"'Invalid entity.'"
|
|
1393
|
+
]
|
|
1394
|
+
});
|
|
1395
|
+
return dxn;
|
|
1396
|
+
};
|
|
1397
|
+
var getDatabase = (entity) => {
|
|
1398
|
+
assumeType3(entity);
|
|
1399
|
+
return entity[ObjectDatabaseId];
|
|
1400
|
+
};
|
|
1401
|
+
|
|
1402
|
+
// src/internal/Entity/entity.ts
|
|
1403
|
+
import * as Schema6 from "effect/Schema";
|
|
1404
|
+
var makeEchoTypeSchema = (fields, ast, typename, version2, kind) => {
|
|
1405
|
+
return class EchoObjectSchemaClass extends Schema6.make(ast) {
|
|
1406
|
+
static typename = typename;
|
|
1407
|
+
static version = version2;
|
|
1408
|
+
static [SchemaKindId] = kind;
|
|
1409
|
+
static fields = fields;
|
|
1410
|
+
static annotations(annotations3) {
|
|
1411
|
+
const schema = Schema6.make(ast).annotations(annotations3);
|
|
1412
|
+
return makeEchoTypeSchema(fields, schema.ast, typename, version2, kind);
|
|
1413
|
+
}
|
|
1414
|
+
// static make(
|
|
1415
|
+
// props: RequiredKeys<Schema.TypeLiteral.Constructor<Fields, []>> extends never
|
|
1416
|
+
// ? void | Simplify<Schema.TypeLiteral.Constructor<Fields, []>>
|
|
1417
|
+
// : Simplify<Schema.TypeLiteral.Constructor<Fields, []>>,
|
|
1418
|
+
// options?: MakeProps,
|
|
1419
|
+
// ): Simplify<Schema.TypeLiteral.Type<Fields, []>> {
|
|
1420
|
+
// const propsWithDefaults: any = _lazilyMergeDefaults(fields, { ...(props as any) });
|
|
1421
|
+
// return _getDisableValidationMakeOption(options)
|
|
1422
|
+
// ? propsWithDefaults
|
|
1423
|
+
// : ParseResult.validateSync(this)(propsWithDefaults);
|
|
1424
|
+
// }
|
|
1425
|
+
static instanceOf(value2) {
|
|
1426
|
+
return Schema6.is(this)(value2);
|
|
1427
|
+
}
|
|
1428
|
+
};
|
|
1429
|
+
};
|
|
1430
|
+
|
|
1431
|
+
// src/internal/Entity/object.ts
|
|
1432
|
+
import * as Schema7 from "effect/Schema";
|
|
1433
|
+
import * as SchemaAST4 from "effect/SchemaAST";
|
|
1434
|
+
import { invariant as invariant11 } from "@dxos/invariant";
|
|
1435
|
+
var __dxlog_file11 = "/__w/dxos/dxos/packages/core/echo/echo/src/internal/Entity/object.ts";
|
|
1436
|
+
var EchoObjectSchema = ({ typename, version: version2 }) => {
|
|
1437
|
+
return (self) => {
|
|
1438
|
+
invariant11(typeof TypeAnnotationId === "symbol", "Sanity.", {
|
|
1439
|
+
F: __dxlog_file11,
|
|
1440
|
+
L: 36,
|
|
1441
|
+
S: void 0,
|
|
1442
|
+
A: [
|
|
1443
|
+
"typeof TypeAnnotationId === 'symbol'",
|
|
1444
|
+
"'Sanity.'"
|
|
1445
|
+
]
|
|
1446
|
+
});
|
|
1447
|
+
invariant11(SchemaAST4.isTypeLiteral(self.ast), "Schema must be a TypeLiteral.", {
|
|
1448
|
+
F: __dxlog_file11,
|
|
1449
|
+
L: 37,
|
|
1450
|
+
S: void 0,
|
|
1451
|
+
A: [
|
|
1452
|
+
"SchemaAST.isTypeLiteral(self.ast)",
|
|
1453
|
+
"'Schema must be a TypeLiteral.'"
|
|
1454
|
+
]
|
|
1455
|
+
});
|
|
1456
|
+
const fields = self.fields ?? {};
|
|
1457
|
+
const schemaWithId = Schema7.extend(self, Schema7.Struct({
|
|
1458
|
+
id: Schema7.String
|
|
1459
|
+
}));
|
|
1460
|
+
const ast = SchemaAST4.annotations(schemaWithId.ast, {
|
|
1461
|
+
// TODO(dmaretskyi): `extend` kills the annotations.
|
|
1462
|
+
...self.ast.annotations,
|
|
1463
|
+
[TypeAnnotationId]: {
|
|
1464
|
+
kind: EntityKind.Object,
|
|
1465
|
+
typename,
|
|
1466
|
+
version: version2
|
|
1467
|
+
},
|
|
1468
|
+
// TODO(dmaretskyi): TypeIdentifierAnnotationId?
|
|
1469
|
+
[SchemaAST4.JSONSchemaAnnotationId]: makeTypeJsonSchemaAnnotation({
|
|
1470
|
+
kind: EntityKind.Object,
|
|
1471
|
+
typename,
|
|
1472
|
+
version: version2
|
|
1473
|
+
})
|
|
1474
|
+
});
|
|
1475
|
+
return makeEchoTypeSchema(fields, ast, typename, version2, EntityKind.Object);
|
|
1476
|
+
};
|
|
1477
|
+
};
|
|
1478
|
+
|
|
1479
|
+
// src/internal/Entity/relation.ts
|
|
1480
|
+
import * as Schema8 from "effect/Schema";
|
|
1481
|
+
import * as SchemaAST5 from "effect/SchemaAST";
|
|
1482
|
+
import { raise } from "@dxos/debug";
|
|
1483
|
+
import { assertArgument as assertArgument3, invariant as invariant12 } from "@dxos/invariant";
|
|
1484
|
+
import { DXN as DXN4 } from "@dxos/keys";
|
|
1485
|
+
var __dxlog_file12 = "/__w/dxos/dxos/packages/core/echo/echo/src/internal/Entity/relation.ts";
|
|
1486
|
+
var EchoRelationSchema = ({ source, target, typename, version: version2 }) => {
|
|
1487
|
+
assertArgument3(Schema8.isSchema(source), "source");
|
|
1488
|
+
assertArgument3(Schema8.isSchema(target), "target");
|
|
1489
|
+
const sourceDXN = getDXNForRelationSchemaRef(source);
|
|
1490
|
+
const targetDXN = getDXNForRelationSchemaRef(target);
|
|
1491
|
+
if (getEntityKind(source) !== EntityKind.Object) {
|
|
1492
|
+
raise(new Error("Source schema must be an echo object schema."));
|
|
1493
|
+
}
|
|
1494
|
+
if (getEntityKind(target) !== EntityKind.Object) {
|
|
1495
|
+
raise(new Error("Target schema must be an echo object schema."));
|
|
1496
|
+
}
|
|
1497
|
+
return (self) => {
|
|
1498
|
+
invariant12(SchemaAST5.isTypeLiteral(self.ast), "Schema must be a TypeLiteral.", {
|
|
1499
|
+
F: __dxlog_file12,
|
|
1500
|
+
L: 110,
|
|
1501
|
+
S: void 0,
|
|
1502
|
+
A: [
|
|
1503
|
+
"SchemaAST.isTypeLiteral(self.ast)",
|
|
1504
|
+
"'Schema must be a TypeLiteral.'"
|
|
1505
|
+
]
|
|
1506
|
+
});
|
|
1507
|
+
const fields = self.fields ?? {};
|
|
1508
|
+
const schemaWithId = Schema8.extend(self, Schema8.Struct({
|
|
1509
|
+
id: Schema8.String
|
|
1510
|
+
}));
|
|
1511
|
+
const ast = SchemaAST5.annotations(schemaWithId.ast, {
|
|
1512
|
+
// TODO(dmaretskyi): `extend` kills the annotations.
|
|
1513
|
+
...self.ast.annotations,
|
|
1514
|
+
[TypeAnnotationId]: {
|
|
1515
|
+
kind: EntityKind.Relation,
|
|
1516
|
+
typename,
|
|
1517
|
+
version: version2,
|
|
1518
|
+
sourceSchema: sourceDXN,
|
|
1519
|
+
targetSchema: targetDXN
|
|
1520
|
+
},
|
|
1521
|
+
// TODO(dmaretskyi): TypeIdentifierAnnotationId?
|
|
1522
|
+
[SchemaAST5.JSONSchemaAnnotationId]: makeTypeJsonSchemaAnnotation({
|
|
1523
|
+
kind: EntityKind.Relation,
|
|
1524
|
+
typename,
|
|
1525
|
+
version: version2,
|
|
1526
|
+
relationSource: sourceDXN,
|
|
1527
|
+
relationTarget: targetDXN
|
|
1528
|
+
})
|
|
1529
|
+
});
|
|
1530
|
+
return makeEchoTypeSchema(fields, ast, typename, version2, EntityKind.Relation);
|
|
1531
|
+
};
|
|
1532
|
+
};
|
|
1533
|
+
var getDXNForRelationSchemaRef = (schema) => {
|
|
1534
|
+
assertArgument3(Schema8.isSchema(schema), "schema");
|
|
1535
|
+
const identifier = getTypeIdentifierAnnotation(schema);
|
|
1536
|
+
if (identifier) {
|
|
1537
|
+
return identifier;
|
|
1538
|
+
}
|
|
1539
|
+
const typename = getSchemaTypename(schema);
|
|
1540
|
+
if (!typename) {
|
|
1541
|
+
throw new Error("Schema must have a typename");
|
|
1542
|
+
}
|
|
1543
|
+
return DXN4.fromTypename(typename).toString();
|
|
1544
|
+
};
|
|
1545
|
+
|
|
1546
|
+
// src/internal/Entity/version.ts
|
|
1547
|
+
import { assertArgument as assertArgument4 } from "@dxos/invariant";
|
|
1548
|
+
var unversioned = {
|
|
1549
|
+
[VersionTypeId]: {},
|
|
1550
|
+
versioned: false
|
|
1551
|
+
};
|
|
1552
|
+
var isVersion = (entity) => {
|
|
1553
|
+
return entity != null && typeof entity === "object" && VersionTypeId in entity;
|
|
1554
|
+
};
|
|
1555
|
+
var version = (entity) => {
|
|
1556
|
+
const ver = entity[ObjectVersionId];
|
|
1557
|
+
if (ver === void 0) {
|
|
1558
|
+
return unversioned;
|
|
1559
|
+
}
|
|
1560
|
+
return ver;
|
|
1561
|
+
};
|
|
1562
|
+
var versionValid = (ver) => {
|
|
1563
|
+
assertArgument4(isVersion(ver), "version", "Invalid version object");
|
|
1564
|
+
return !!ver.versioned;
|
|
1565
|
+
};
|
|
1566
|
+
var compareVersions = (version1, version2) => {
|
|
1567
|
+
assertArgument4(isVersion(version1), "version1", "Invalid version object");
|
|
1568
|
+
assertArgument4(isVersion(version2), "version2", "Invalid version object");
|
|
1569
|
+
if (!versionValid(version1) || !versionValid(version2)) {
|
|
1570
|
+
return "unversioned";
|
|
1571
|
+
}
|
|
1572
|
+
if (version1.automergeHeads?.length !== version2.automergeHeads?.length) {
|
|
1573
|
+
return "different";
|
|
1574
|
+
}
|
|
1575
|
+
if (version1.automergeHeads?.some((head) => !version2.automergeHeads?.includes(head))) {
|
|
1576
|
+
return "different";
|
|
1577
|
+
}
|
|
1578
|
+
return "equal";
|
|
1579
|
+
};
|
|
1580
|
+
var encodeVersion = (ver) => {
|
|
1581
|
+
return JSON.stringify(ver);
|
|
1582
|
+
};
|
|
1583
|
+
var decodeVersion = (ver) => {
|
|
1584
|
+
const parsed = JSON.parse(ver);
|
|
1585
|
+
parsed[VersionTypeId] = {};
|
|
1586
|
+
return parsed;
|
|
1587
|
+
};
|
|
1588
|
+
|
|
1589
|
+
// src/internal/JsonSchema/json-schema-normalize.ts
|
|
1590
|
+
var normalizeSchema = (schema) => {
|
|
1591
|
+
const copy = structuredClone(schema);
|
|
1592
|
+
go(copy);
|
|
1593
|
+
return copy;
|
|
1594
|
+
};
|
|
1595
|
+
var go = (schema) => {
|
|
1596
|
+
if (typeof schema !== "object" || schema === null) {
|
|
1597
|
+
return;
|
|
1598
|
+
}
|
|
1599
|
+
if (schema.exclusiveMaximum === true) {
|
|
1600
|
+
schema.exclusiveMaximum = schema.maximum;
|
|
1601
|
+
delete schema.exclusiveMaximum;
|
|
1602
|
+
} else if (schema.exclusiveMaximum === false) {
|
|
1603
|
+
delete schema.exclusiveMaximum;
|
|
1604
|
+
}
|
|
1605
|
+
if (schema.exclusiveMinimum === true) {
|
|
1606
|
+
schema.exclusiveMinimum = schema.minimum;
|
|
1607
|
+
delete schema.exclusiveMinimum;
|
|
1608
|
+
} else if (schema.exclusiveMinimum === false) {
|
|
1609
|
+
delete schema.exclusiveMinimum;
|
|
1610
|
+
}
|
|
1611
|
+
for (const key of Object.keys(schema)) {
|
|
1612
|
+
if (!JsonSchemaFields.includes(key)) {
|
|
1613
|
+
delete schema[key];
|
|
1614
|
+
}
|
|
1615
|
+
}
|
|
1616
|
+
if (schema.properties) {
|
|
1617
|
+
goOnRecord(schema.properties);
|
|
1618
|
+
}
|
|
1619
|
+
if (schema.patternProperties) {
|
|
1620
|
+
goOnRecord(schema.patternProperties);
|
|
1621
|
+
}
|
|
1622
|
+
if (schema.propertyNames) {
|
|
1623
|
+
go(schema.propertyNames);
|
|
1624
|
+
}
|
|
1625
|
+
if (schema.definitions) {
|
|
1626
|
+
goOnRecord(schema.definitions);
|
|
1627
|
+
}
|
|
1628
|
+
if (schema.items) {
|
|
1629
|
+
maybeGoOnArray(schema.items);
|
|
1630
|
+
}
|
|
1631
|
+
if (schema.additionalItems) {
|
|
1632
|
+
maybeGoOnArray(schema.additionalItems);
|
|
1633
|
+
}
|
|
1634
|
+
if (schema.contains) {
|
|
1635
|
+
go(schema.contains);
|
|
1636
|
+
}
|
|
1637
|
+
if (schema.if) {
|
|
1638
|
+
go(schema.if);
|
|
1639
|
+
}
|
|
1640
|
+
if (schema.then) {
|
|
1641
|
+
go(schema.then);
|
|
1642
|
+
}
|
|
1643
|
+
if (schema.else) {
|
|
1644
|
+
go(schema.else);
|
|
1645
|
+
}
|
|
1646
|
+
if (schema.allOf) {
|
|
1647
|
+
maybeGoOnArray(schema.allOf);
|
|
1648
|
+
}
|
|
1649
|
+
if (schema.anyOf) {
|
|
1650
|
+
maybeGoOnArray(schema.anyOf);
|
|
1651
|
+
}
|
|
1652
|
+
if (schema.oneOf) {
|
|
1653
|
+
maybeGoOnArray(schema.oneOf);
|
|
1654
|
+
}
|
|
1655
|
+
if (schema.not) {
|
|
1656
|
+
go(schema.not);
|
|
1657
|
+
}
|
|
1658
|
+
if (schema.$defs) {
|
|
1659
|
+
goOnRecord(schema.$defs);
|
|
1660
|
+
}
|
|
1661
|
+
if (schema.reference) {
|
|
1662
|
+
go(schema.reference.schema);
|
|
1663
|
+
}
|
|
1664
|
+
};
|
|
1665
|
+
var maybeGoOnArray = (value2) => {
|
|
1666
|
+
if (Array.isArray(value2)) {
|
|
1667
|
+
for (const item of value2) {
|
|
1668
|
+
go(item);
|
|
1669
|
+
}
|
|
1670
|
+
} else if (typeof value2 === "object" && value2 !== null) {
|
|
1671
|
+
go(value2);
|
|
1672
|
+
}
|
|
1673
|
+
};
|
|
1674
|
+
var goOnRecord = (record) => {
|
|
1675
|
+
for (const key of Object.keys(record)) {
|
|
1676
|
+
go(record[key]);
|
|
1677
|
+
}
|
|
1678
|
+
};
|
|
1679
|
+
|
|
1680
|
+
// src/internal/Obj/common.ts
|
|
1681
|
+
import * as Schema9 from "effect/Schema";
|
|
1682
|
+
var makeTypedEntityClass = (typename, version2, baseSchema) => {
|
|
1683
|
+
return class {
|
|
1684
|
+
// Implement TypedObject properties.
|
|
1685
|
+
static typename = typename;
|
|
1686
|
+
static version = version2;
|
|
1687
|
+
// Implement Schema.Schema properties.
|
|
1688
|
+
// TODO(burdon): Comment required.
|
|
1689
|
+
static [Schema9.TypeId] = schemaVariance;
|
|
1690
|
+
static ast = baseSchema.ast;
|
|
1691
|
+
static annotations = baseSchema.annotations.bind(baseSchema);
|
|
1692
|
+
static pipe = baseSchema.pipe.bind(baseSchema);
|
|
1693
|
+
// TODO(burdon): Comment required.
|
|
1694
|
+
static [Symbol.hasInstance](obj) {
|
|
1695
|
+
return obj != null && getTypename(obj) === typename;
|
|
1696
|
+
}
|
|
1697
|
+
// TODO(burdon): Throw APIError.
|
|
1698
|
+
constructor() {
|
|
1699
|
+
throw new Error("Use live(Typename, { ...fields }) to instantiate an object.");
|
|
1700
|
+
}
|
|
1701
|
+
};
|
|
1702
|
+
};
|
|
1703
|
+
var schemaVariance = {
|
|
1704
|
+
_A: (_) => _,
|
|
1705
|
+
_I: (_) => _,
|
|
1706
|
+
_R: (_) => _
|
|
1707
|
+
};
|
|
1708
|
+
|
|
1709
|
+
// src/internal/Obj/create-object.ts
|
|
1710
|
+
import { raise as raise3 } from "@dxos/debug";
|
|
1711
|
+
import { assertArgument as assertArgument6, failedInvariant } from "@dxos/invariant";
|
|
1712
|
+
import { ObjectId as ObjectId5 } from "@dxos/keys";
|
|
1713
|
+
|
|
1714
|
+
// src/internal/Obj/inspect.ts
|
|
1715
|
+
import { inspectCustom as inspectCustom2 } from "@dxos/debug";
|
|
1716
|
+
var attachedTypedObjectInspector = (obj) => {
|
|
1717
|
+
const descriptor = Object.getOwnPropertyDescriptor(obj, inspectCustom2);
|
|
1718
|
+
if (descriptor) {
|
|
1719
|
+
return;
|
|
1720
|
+
}
|
|
1721
|
+
Object.defineProperty(obj, inspectCustom2, {
|
|
1722
|
+
value: typedObjectInspectFunction,
|
|
1723
|
+
writable: false,
|
|
1724
|
+
enumerable: false,
|
|
1725
|
+
configurable: true
|
|
1726
|
+
});
|
|
1727
|
+
};
|
|
1728
|
+
var typedObjectInspectFunction = function(depth, options, inspect) {
|
|
1729
|
+
const { id, ...props } = this;
|
|
1730
|
+
return inspect({
|
|
1731
|
+
id,
|
|
1732
|
+
[ATTR_TYPE]: getTypeDXN(this),
|
|
1733
|
+
...props,
|
|
1734
|
+
[ATTR_META]: this[MetaId]
|
|
1735
|
+
}, options);
|
|
1736
|
+
};
|
|
1737
|
+
|
|
1738
|
+
// src/internal/Obj/json-serializer.ts
|
|
1739
|
+
import * as Schema10 from "effect/Schema";
|
|
1740
|
+
import { raise as raise2 } from "@dxos/debug";
|
|
1741
|
+
import { ObjectStructure, isEncodedReference } from "@dxos/echo-protocol";
|
|
1742
|
+
import { assertArgument as assertArgument5, invariant as invariant13 } from "@dxos/invariant";
|
|
1743
|
+
import { DXN as DXN5, ObjectId as ObjectId4 } from "@dxos/keys";
|
|
1744
|
+
import { assumeType as assumeType4, deepMapValues as deepMapValues2, visitValues } from "@dxos/util";
|
|
1745
|
+
var __dxlog_file13 = "/__w/dxos/dxos/packages/core/echo/echo/src/internal/Obj/json-serializer.ts";
|
|
1746
|
+
var objectToJSON = (obj) => {
|
|
1747
|
+
const typename = getTypeDXN(obj)?.toString();
|
|
1748
|
+
invariant13(typename && typeof typename === "string", void 0, {
|
|
1749
|
+
F: __dxlog_file13,
|
|
1750
|
+
L: 66,
|
|
1751
|
+
S: void 0,
|
|
1752
|
+
A: [
|
|
1753
|
+
"typename && typeof typename === 'string'",
|
|
1754
|
+
""
|
|
1755
|
+
]
|
|
1756
|
+
});
|
|
1757
|
+
return typedJsonSerializer.call(obj);
|
|
1758
|
+
};
|
|
1759
|
+
var objectFromJSON = async (jsonData, { refResolver, dxn, database, parent } = {}) => {
|
|
1760
|
+
assumeType4(jsonData);
|
|
1761
|
+
assertArgument5(typeof jsonData === "object" && jsonData !== null, "jsonData", "expect object");
|
|
1762
|
+
assertArgument5(typeof jsonData[ATTR_TYPE] === "string", "jsonData[ATTR_TYPE]", "expected object to have a type");
|
|
1763
|
+
assertArgument5(typeof jsonData.id === "string", "jsonData.id", "expected object to have an id");
|
|
1764
|
+
const type = DXN5.parse(jsonData[ATTR_TYPE]);
|
|
1765
|
+
const schema = await refResolver?.resolveSchema(type);
|
|
1766
|
+
invariant13(schema === void 0 || Schema10.isSchema(schema), void 0, {
|
|
1767
|
+
F: __dxlog_file13,
|
|
1768
|
+
L: 97,
|
|
1769
|
+
S: void 0,
|
|
1770
|
+
A: [
|
|
1771
|
+
"schema === undefined || Schema.isSchema(schema)",
|
|
1772
|
+
""
|
|
1773
|
+
]
|
|
1774
|
+
});
|
|
1775
|
+
const decodedInput = stripInternalJsonKeys(jsonData);
|
|
1776
|
+
let obj;
|
|
1777
|
+
if (schema != null) {
|
|
1778
|
+
obj = await schema.pipe(Schema10.decodeUnknownPromise)(decodedInput);
|
|
1779
|
+
if (refResolver) {
|
|
1780
|
+
setRefResolverOnData(obj, refResolver);
|
|
1781
|
+
}
|
|
1782
|
+
} else {
|
|
1783
|
+
obj = decodeGeneric(decodedInput, {
|
|
1784
|
+
refResolver
|
|
1785
|
+
});
|
|
1786
|
+
}
|
|
1787
|
+
invariant13(ObjectId4.isValid(obj.id), "Invalid object id", {
|
|
1788
|
+
F: __dxlog_file13,
|
|
1789
|
+
L: 110,
|
|
1790
|
+
S: void 0,
|
|
1791
|
+
A: [
|
|
1792
|
+
"ObjectId.isValid(obj.id)",
|
|
1793
|
+
"'Invalid object id'"
|
|
1794
|
+
]
|
|
1795
|
+
});
|
|
1796
|
+
setTypename(obj, type);
|
|
1797
|
+
if (schema) {
|
|
1798
|
+
setSchema(obj, schema);
|
|
1799
|
+
}
|
|
1800
|
+
const isRelation = typeof jsonData[ATTR_RELATION_SOURCE] === "string" || typeof jsonData[ATTR_RELATION_TARGET] === "string";
|
|
1801
|
+
if (isRelation) {
|
|
1802
|
+
const sourceDxn = DXN5.parse(jsonData[ATTR_RELATION_SOURCE] ?? raise2(new TypeError("Missing relation source")));
|
|
1803
|
+
const targetDxn = DXN5.parse(jsonData[ATTR_RELATION_TARGET] ?? raise2(new TypeError("Missing relation target")));
|
|
1804
|
+
const source = await refResolver?.resolve(sourceDxn);
|
|
1805
|
+
const target = await refResolver?.resolve(targetDxn);
|
|
1806
|
+
defineHiddenProperty(obj, KindId, EntityKind.Relation);
|
|
1807
|
+
defineHiddenProperty(obj, RelationSourceDXNId, sourceDxn);
|
|
1808
|
+
defineHiddenProperty(obj, RelationTargetDXNId, targetDxn);
|
|
1809
|
+
defineHiddenProperty(obj, RelationSourceId, source);
|
|
1810
|
+
defineHiddenProperty(obj, RelationTargetId, target);
|
|
1811
|
+
} else {
|
|
1812
|
+
defineHiddenProperty(obj, KindId, EntityKind.Object);
|
|
1813
|
+
}
|
|
1814
|
+
if (typeof jsonData[ATTR_META] === "object") {
|
|
1815
|
+
const meta = await ObjectMetaSchema.pipe(Schema10.decodeUnknownPromise)(jsonData[ATTR_META]);
|
|
1816
|
+
invariant13(Array.isArray(meta.keys), void 0, {
|
|
1817
|
+
F: __dxlog_file13,
|
|
1818
|
+
L: 136,
|
|
1819
|
+
S: void 0,
|
|
1820
|
+
A: [
|
|
1821
|
+
"Array.isArray(meta.keys)",
|
|
1822
|
+
""
|
|
1823
|
+
]
|
|
1824
|
+
});
|
|
1825
|
+
defineHiddenProperty(obj, MetaId, meta);
|
|
1826
|
+
} else {
|
|
1827
|
+
defineHiddenProperty(obj, MetaId, {
|
|
1828
|
+
keys: []
|
|
1829
|
+
});
|
|
1830
|
+
}
|
|
1831
|
+
if (jsonData[ATTR_PARENT]) {
|
|
1832
|
+
const parentDxn = DXN5.parse(jsonData[ATTR_PARENT]);
|
|
1833
|
+
const resolvedParent = await refResolver?.resolve(parentDxn);
|
|
1834
|
+
defineHiddenProperty(obj, ParentId, resolvedParent);
|
|
1835
|
+
} else if (parent) {
|
|
1836
|
+
defineHiddenProperty(obj, ParentId, parent);
|
|
1837
|
+
}
|
|
1838
|
+
if (dxn) {
|
|
1839
|
+
defineHiddenProperty(obj, SelfDXNId, dxn);
|
|
1840
|
+
}
|
|
1841
|
+
if (database) {
|
|
1842
|
+
defineHiddenProperty(obj, ObjectDatabaseId, database);
|
|
1843
|
+
}
|
|
1844
|
+
assertObjectModel(obj);
|
|
1845
|
+
invariant13(obj[ATTR_TYPE] === void 0, "Invalid object model", {
|
|
1846
|
+
F: __dxlog_file13,
|
|
1847
|
+
L: 161,
|
|
1848
|
+
S: void 0,
|
|
1849
|
+
A: [
|
|
1850
|
+
"(obj as any)[ATTR_TYPE] === undefined",
|
|
1851
|
+
"'Invalid object model'"
|
|
1852
|
+
]
|
|
1853
|
+
});
|
|
1854
|
+
invariant13(obj[ATTR_META] === void 0, "Invalid object model", {
|
|
1855
|
+
F: __dxlog_file13,
|
|
1856
|
+
L: 162,
|
|
1857
|
+
S: void 0,
|
|
1858
|
+
A: [
|
|
1859
|
+
"(obj as any)[ATTR_META] === undefined",
|
|
1860
|
+
"'Invalid object model'"
|
|
1861
|
+
]
|
|
1862
|
+
});
|
|
1863
|
+
invariant13(obj[ATTR_DELETED] === void 0, "Invalid object model", {
|
|
1864
|
+
F: __dxlog_file13,
|
|
1865
|
+
L: 163,
|
|
1866
|
+
S: void 0,
|
|
1867
|
+
A: [
|
|
1868
|
+
"(obj as any)[ATTR_DELETED] === undefined",
|
|
1869
|
+
"'Invalid object model'"
|
|
1870
|
+
]
|
|
1871
|
+
});
|
|
1872
|
+
invariant13(obj[ATTR_SELF_DXN] === void 0, "Invalid object model", {
|
|
1873
|
+
F: __dxlog_file13,
|
|
1874
|
+
L: 164,
|
|
1875
|
+
S: void 0,
|
|
1876
|
+
A: [
|
|
1877
|
+
"(obj as any)[ATTR_SELF_DXN] === undefined",
|
|
1878
|
+
"'Invalid object model'"
|
|
1879
|
+
]
|
|
1880
|
+
});
|
|
1881
|
+
invariant13(obj[ATTR_RELATION_SOURCE] === void 0, "Invalid object model", {
|
|
1882
|
+
F: __dxlog_file13,
|
|
1883
|
+
L: 165,
|
|
1884
|
+
S: void 0,
|
|
1885
|
+
A: [
|
|
1886
|
+
"(obj as any)[ATTR_RELATION_SOURCE] === undefined",
|
|
1887
|
+
"'Invalid object model'"
|
|
1888
|
+
]
|
|
1889
|
+
});
|
|
1890
|
+
invariant13(obj[ATTR_RELATION_TARGET] === void 0, "Invalid object model", {
|
|
1891
|
+
F: __dxlog_file13,
|
|
1892
|
+
L: 166,
|
|
1893
|
+
S: void 0,
|
|
1894
|
+
A: [
|
|
1895
|
+
"(obj as any)[ATTR_RELATION_TARGET] === undefined",
|
|
1896
|
+
"'Invalid object model'"
|
|
1897
|
+
]
|
|
1898
|
+
});
|
|
1899
|
+
return obj;
|
|
1900
|
+
};
|
|
1901
|
+
var decodeGeneric = (jsonData, options) => {
|
|
1902
|
+
const props = stripInternalJsonKeys(jsonData);
|
|
1903
|
+
return deepMapValues2(props, (value2, visitor) => {
|
|
1904
|
+
if (isEncodedReference(value2)) {
|
|
1905
|
+
return refFromEncodedReference(value2, options.refResolver);
|
|
1906
|
+
}
|
|
1907
|
+
return visitor(value2);
|
|
1908
|
+
});
|
|
1909
|
+
};
|
|
1910
|
+
var stripInternalJsonKeys = (jsonData) => {
|
|
1911
|
+
const { [ATTR_TYPE]: _type, [ATTR_META]: _meta, [ATTR_DELETED]: _deleted, [ATTR_SELF_DXN]: _selfDxn, [ATTR_RELATION_SOURCE]: _relationSource, [ATTR_RELATION_TARGET]: _relationTarget, ...props } = jsonData;
|
|
1912
|
+
return props;
|
|
1913
|
+
};
|
|
1914
|
+
var setRefResolverOnData = (obj, refResolver) => {
|
|
1915
|
+
const visitor = (value2) => {
|
|
1916
|
+
if (Ref.isRef(value2)) {
|
|
1917
|
+
setRefResolver(value2, refResolver);
|
|
1918
|
+
} else {
|
|
1919
|
+
visitValues(value2, visitor);
|
|
1920
|
+
}
|
|
1921
|
+
};
|
|
1922
|
+
visitor(obj);
|
|
1923
|
+
};
|
|
1924
|
+
var objectStructureToJson = (objectId, structure) => {
|
|
1925
|
+
return {
|
|
1926
|
+
...structure.data,
|
|
1927
|
+
id: objectId,
|
|
1928
|
+
[ATTR_TYPE]: ObjectStructure.getTypeReference(structure)?.["/"] ?? "",
|
|
1929
|
+
[ATTR_DELETED]: ObjectStructure.isDeleted(structure),
|
|
1930
|
+
[ATTR_PARENT]: ObjectStructure.getParent(structure)?.["/"],
|
|
1931
|
+
[ATTR_RELATION_SOURCE]: ObjectStructure.getRelationSource(structure)?.["/"],
|
|
1932
|
+
[ATTR_RELATION_TARGET]: ObjectStructure.getRelationTarget(structure)?.["/"]
|
|
1933
|
+
};
|
|
1934
|
+
};
|
|
1935
|
+
|
|
1936
|
+
// src/internal/Obj/create-object.ts
|
|
1937
|
+
var createObject = (schema, props) => {
|
|
1938
|
+
const annotation = getTypeAnnotation(schema);
|
|
1939
|
+
if (!annotation) {
|
|
1940
|
+
throw new Error("Schema is not an ECHO schema");
|
|
1941
|
+
}
|
|
1942
|
+
assertArgument6(!("@type" in props), "data", "@type is not allowed");
|
|
1943
|
+
assertArgument6(!(RelationSourceDXNId in props), "data", "Relation source DXN is not allowed in the constructor");
|
|
1944
|
+
assertArgument6(!(RelationTargetDXNId in props), "data", "Relation target DXN is not allowed in the constructor");
|
|
1945
|
+
assertArgument6(RelationSourceId in props === RelationTargetId in props, "data", "Relation source and target must be provided together");
|
|
1946
|
+
const obj = {
|
|
1947
|
+
...props,
|
|
1948
|
+
id: props.id ?? ObjectId5.random()
|
|
1949
|
+
};
|
|
1950
|
+
const kind = RelationSourceId in props ? EntityKind.Relation : EntityKind.Object;
|
|
1951
|
+
defineHiddenProperty(obj, KindId, kind);
|
|
1952
|
+
defineHiddenProperty(obj, MetaId, {
|
|
1953
|
+
keys: []
|
|
1954
|
+
});
|
|
1955
|
+
setSchema(obj, schema);
|
|
1956
|
+
setTypename(obj, getSchemaDXN(schema) ?? failedInvariant("Missing schema DXN"));
|
|
1957
|
+
attachTypedJsonSerializer(obj);
|
|
1958
|
+
attachedTypedObjectInspector(obj);
|
|
1959
|
+
if (kind === EntityKind.Relation) {
|
|
1960
|
+
const sourceDXN = getObjectDXN(props[RelationSourceId]) ?? raise3(new Error("Unresolved relation source"));
|
|
1961
|
+
const targetDXN = getObjectDXN(props[RelationTargetId]) ?? raise3(new Error("Unresolved relation target"));
|
|
1962
|
+
defineHiddenProperty(obj, RelationSourceDXNId, sourceDXN);
|
|
1963
|
+
defineHiddenProperty(obj, RelationTargetDXNId, targetDXN);
|
|
1964
|
+
}
|
|
1965
|
+
assertObjectModel(obj);
|
|
1966
|
+
return obj;
|
|
1967
|
+
};
|
|
1968
|
+
|
|
1969
|
+
// src/internal/Obj/deleted.ts
|
|
1970
|
+
var isDeleted = (obj) => {
|
|
1971
|
+
if (obj[ObjectDeletedId] === void 0) {
|
|
1972
|
+
return false;
|
|
1973
|
+
}
|
|
1974
|
+
return obj[ObjectDeletedId] ?? false;
|
|
1975
|
+
};
|
|
1976
|
+
|
|
1977
|
+
// src/internal/Obj/ids.ts
|
|
1978
|
+
import { DXN as DXN6, ObjectId as ObjectId6, QueueSubspaceTags, SpaceId } from "@dxos/keys";
|
|
1979
|
+
var createQueueDXN = (spaceId = SpaceId.random(), queueId = ObjectId6.random()) => new DXN6(DXN6.kind.QUEUE, [
|
|
1980
|
+
QueueSubspaceTags.DATA,
|
|
1981
|
+
spaceId,
|
|
1982
|
+
queueId
|
|
1983
|
+
]);
|
|
1984
|
+
|
|
1985
|
+
// src/internal/Obj/set-value.ts
|
|
1986
|
+
import * as Match from "effect/Match";
|
|
1987
|
+
import * as Option from "effect/Option";
|
|
1988
|
+
import * as SchemaAST6 from "effect/SchemaAST";
|
|
1989
|
+
import { getArrayElementType, getBaseType, getProperties as getProperties2, isArrayType, isNestedType } from "@dxos/effect";
|
|
1990
|
+
import { invariant as invariant14 } from "@dxos/invariant";
|
|
1991
|
+
var __dxlog_file14 = "/__w/dxos/dxos/packages/core/echo/echo/src/internal/Obj/set-value.ts";
|
|
1992
|
+
var setValue = (obj, path, value2) => {
|
|
1993
|
+
invariant14(path.length > 0, "Path must not be empty", {
|
|
1994
|
+
F: __dxlog_file14,
|
|
1995
|
+
L: 27,
|
|
1996
|
+
S: void 0,
|
|
1997
|
+
A: [
|
|
1998
|
+
"path.length > 0",
|
|
1999
|
+
"'Path must not be empty'"
|
|
2000
|
+
]
|
|
2001
|
+
});
|
|
2002
|
+
const schema = getSchema(obj);
|
|
2003
|
+
invariant14(schema != null, "Object must have a schema", {
|
|
2004
|
+
F: __dxlog_file14,
|
|
2005
|
+
L: 30,
|
|
2006
|
+
S: void 0,
|
|
2007
|
+
A: [
|
|
2008
|
+
"schema != null",
|
|
2009
|
+
"'Object must have a schema'"
|
|
2010
|
+
]
|
|
2011
|
+
});
|
|
2012
|
+
let parent = obj;
|
|
2013
|
+
let currentAST = schema.ast;
|
|
2014
|
+
for (let i = 0; i < path.length - 1; i++) {
|
|
2015
|
+
const part = path[i];
|
|
2016
|
+
const key = typeof part === "number" ? part : String(part);
|
|
2017
|
+
if (parent[key] === void 0) {
|
|
2018
|
+
const propertyAST = getPropertyAST(currentAST, String(part));
|
|
2019
|
+
const shouldBeArray = propertyAST ? isArrayType(propertyAST) : false;
|
|
2020
|
+
if (shouldBeArray) {
|
|
2021
|
+
parent[key] = [];
|
|
2022
|
+
} else {
|
|
2023
|
+
const objWithDefaults = createObjectWithDefaults(propertyAST);
|
|
2024
|
+
parent[key] = objWithDefaults;
|
|
2025
|
+
}
|
|
2026
|
+
}
|
|
2027
|
+
parent = parent[key];
|
|
2028
|
+
currentAST = getPropertyAST(currentAST, String(part));
|
|
2029
|
+
}
|
|
2030
|
+
const finalKey = path[path.length - 1];
|
|
2031
|
+
parent[finalKey] = value2;
|
|
2032
|
+
return value2;
|
|
2033
|
+
};
|
|
2034
|
+
var getPropertyAST = (ast, propertyName) => {
|
|
2035
|
+
if (!ast) {
|
|
2036
|
+
return void 0;
|
|
2037
|
+
}
|
|
2038
|
+
if (isNestedType(ast)) {
|
|
2039
|
+
const properties = getProperties2(ast);
|
|
2040
|
+
const property = properties.find((p) => p.name.toString() === propertyName);
|
|
2041
|
+
if (property) {
|
|
2042
|
+
return getBaseType(property).type;
|
|
2043
|
+
}
|
|
2044
|
+
}
|
|
2045
|
+
if (isArrayType(ast)) {
|
|
2046
|
+
const elementType = getArrayElementType(ast);
|
|
2047
|
+
return elementType;
|
|
2048
|
+
}
|
|
2049
|
+
return void 0;
|
|
2050
|
+
};
|
|
2051
|
+
var getRequiredProperties = (ast) => {
|
|
2052
|
+
if (!ast) {
|
|
2053
|
+
return [];
|
|
2054
|
+
}
|
|
2055
|
+
if (!isNestedType(ast)) {
|
|
2056
|
+
return [];
|
|
2057
|
+
}
|
|
2058
|
+
const properties = getProperties2(ast);
|
|
2059
|
+
return properties.filter((p) => !p.isOptional);
|
|
2060
|
+
};
|
|
2061
|
+
var getDefaultValueForType = (ast) => {
|
|
2062
|
+
if (!ast) {
|
|
2063
|
+
return void 0;
|
|
2064
|
+
}
|
|
2065
|
+
const defaultValue = SchemaAST6.getDefaultAnnotation(ast);
|
|
2066
|
+
if (Option.isSome(defaultValue)) {
|
|
2067
|
+
return defaultValue.value;
|
|
2068
|
+
}
|
|
2069
|
+
return Match.value(ast).pipe(Match.when({
|
|
2070
|
+
_tag: "StringKeyword"
|
|
2071
|
+
}, () => ""), Match.when({
|
|
2072
|
+
_tag: "NumberKeyword"
|
|
2073
|
+
}, () => 0), Match.when({
|
|
2074
|
+
_tag: "BooleanKeyword"
|
|
2075
|
+
}, () => false), Match.orElse(() => void 0));
|
|
2076
|
+
};
|
|
2077
|
+
var createObjectWithDefaults = (ast) => {
|
|
2078
|
+
if (!ast) {
|
|
2079
|
+
return {};
|
|
2080
|
+
}
|
|
2081
|
+
const requiredProps = getRequiredProperties(ast);
|
|
2082
|
+
const obj = {};
|
|
2083
|
+
for (const prop of requiredProps) {
|
|
2084
|
+
const defaultValue = getDefaultValueForType(prop.type);
|
|
2085
|
+
if (defaultValue !== void 0) {
|
|
2086
|
+
obj[prop.name] = defaultValue;
|
|
2087
|
+
} else if (isNestedType(prop.type)) {
|
|
2088
|
+
obj[prop.name] = createObjectWithDefaults(prop.type);
|
|
2089
|
+
}
|
|
2090
|
+
}
|
|
2091
|
+
return obj;
|
|
2092
|
+
};
|
|
2093
|
+
|
|
2094
|
+
// src/internal/Obj/snapshot.ts
|
|
2095
|
+
import { assertArgument as assertArgument7 } from "@dxos/invariant";
|
|
2096
|
+
import { deepMapValues as deepMapValues3 } from "@dxos/util";
|
|
2097
|
+
var copySymbolProperty = (source, target, symbol, transform) => {
|
|
2098
|
+
let value2;
|
|
2099
|
+
try {
|
|
2100
|
+
value2 = source[symbol];
|
|
2101
|
+
} catch {
|
|
2102
|
+
return;
|
|
2103
|
+
}
|
|
2104
|
+
if (value2 !== void 0) {
|
|
2105
|
+
const finalValue = transform ? transform(value2) : value2;
|
|
2106
|
+
Object.defineProperty(target, symbol, {
|
|
2107
|
+
value: finalValue,
|
|
2108
|
+
writable: false,
|
|
2109
|
+
enumerable: false,
|
|
2110
|
+
configurable: false
|
|
2111
|
+
});
|
|
2112
|
+
}
|
|
2113
|
+
};
|
|
2114
|
+
var getSnapshot = (obj) => {
|
|
2115
|
+
assertArgument7(typeof obj === "object" && obj !== null && KindId in obj, "obj", "must be an entity");
|
|
2116
|
+
const snapshot = deepMapValues3(obj, (value2, recurse) => {
|
|
2117
|
+
if (typeof value2 === "object" && value2 !== null && Object.getPrototypeOf(value2) !== Object.prototype && !Array.isArray(value2)) {
|
|
2118
|
+
return value2;
|
|
2119
|
+
}
|
|
2120
|
+
return recurse(value2);
|
|
2121
|
+
});
|
|
2122
|
+
if (obj != null && typeof obj === "object" && KindId in obj) {
|
|
2123
|
+
snapshot[SnapshotKindId] = obj[KindId];
|
|
2124
|
+
}
|
|
2125
|
+
const source = obj;
|
|
2126
|
+
copySymbolProperty(source, snapshot, TypeId);
|
|
2127
|
+
copySymbolProperty(source, snapshot, SchemaId);
|
|
2128
|
+
copySymbolProperty(source, snapshot, SelfDXNId);
|
|
2129
|
+
copySymbolProperty(source, snapshot, ObjectDatabaseId);
|
|
2130
|
+
copySymbolProperty(source, snapshot, ObjectDeletedId);
|
|
2131
|
+
copySymbolProperty(source, snapshot, MetaId, (meta) => ({
|
|
2132
|
+
keys: [
|
|
2133
|
+
...meta?.keys ?? []
|
|
2134
|
+
],
|
|
2135
|
+
tags: [
|
|
2136
|
+
...meta?.tags ?? []
|
|
2137
|
+
]
|
|
2138
|
+
}));
|
|
2139
|
+
copySymbolProperty(source, snapshot, RelationSourceDXNId);
|
|
2140
|
+
copySymbolProperty(source, snapshot, RelationTargetDXNId);
|
|
2141
|
+
copySymbolProperty(source, snapshot, RelationSourceId);
|
|
2142
|
+
copySymbolProperty(source, snapshot, RelationTargetId);
|
|
2143
|
+
return Object.freeze(snapshot);
|
|
2144
|
+
};
|
|
2145
|
+
|
|
2146
|
+
// src/internal/Obj/clone.ts
|
|
2147
|
+
import { invariant as invariant15 } from "@dxos/invariant";
|
|
2148
|
+
import { deepMapValues as deepMapValues4 } from "@dxos/util";
|
|
2149
|
+
var __dxlog_file15 = "/__w/dxos/dxos/packages/core/echo/echo/src/internal/Obj/clone.ts";
|
|
2150
|
+
var clone = (obj, opts) => {
|
|
2151
|
+
const { id, ...data } = obj;
|
|
2152
|
+
const schema = getSchema(obj);
|
|
2153
|
+
invariant15(schema != null, "Object should have a schema", {
|
|
2154
|
+
F: __dxlog_file15,
|
|
2155
|
+
L: 21,
|
|
2156
|
+
S: void 0,
|
|
2157
|
+
A: [
|
|
2158
|
+
"schema != null",
|
|
2159
|
+
"'Object should have a schema'"
|
|
2160
|
+
]
|
|
2161
|
+
});
|
|
2162
|
+
const props = deepMapValues4(data, (value2, recurse) => {
|
|
2163
|
+
if (Ref.isRef(value2)) {
|
|
2164
|
+
if (opts?.deep) {
|
|
2165
|
+
return Ref.make(clone(value2.target, opts));
|
|
2166
|
+
}
|
|
2167
|
+
return value2;
|
|
2168
|
+
}
|
|
2169
|
+
return recurse(value2);
|
|
2170
|
+
});
|
|
2171
|
+
if (opts?.retainId) {
|
|
2172
|
+
props.id = id;
|
|
2173
|
+
}
|
|
2174
|
+
const meta = deepMapValues4(getMeta(obj), (value2, recurse) => {
|
|
2175
|
+
if (Ref.isRef(value2)) {
|
|
2176
|
+
if (opts?.deep) {
|
|
2177
|
+
return Ref.make(clone(value2.target, opts));
|
|
2178
|
+
}
|
|
2179
|
+
return value2;
|
|
2180
|
+
}
|
|
2181
|
+
return recurse(value2);
|
|
2182
|
+
});
|
|
2183
|
+
return makeObject(schema, props, meta);
|
|
2184
|
+
};
|
|
2185
|
+
|
|
2186
|
+
// src/internal/Query.ts
|
|
2187
|
+
var prettyFilter = (filter) => {
|
|
2188
|
+
switch (filter.type) {
|
|
2189
|
+
case "object": {
|
|
2190
|
+
const parts = [];
|
|
2191
|
+
if (filter.typename !== null) {
|
|
2192
|
+
parts.push(String(filter.typename));
|
|
2193
|
+
}
|
|
2194
|
+
if (filter.id !== void 0 && filter.id.length > 0) {
|
|
2195
|
+
parts.push(`id: [${filter.id.join(", ")}]`);
|
|
2196
|
+
}
|
|
2197
|
+
const propEntries = Object.entries(filter.props);
|
|
2198
|
+
if (propEntries.length > 0) {
|
|
2199
|
+
const propsStr = propEntries.map(([k, v]) => `${k}: ${prettyFilter(v)}`).join(", ");
|
|
2200
|
+
parts.push(`{ ${propsStr} }`);
|
|
2201
|
+
}
|
|
2202
|
+
if (filter.foreignKeys !== void 0 && filter.foreignKeys.length > 0) {
|
|
2203
|
+
parts.push(`foreignKeys: [${filter.foreignKeys.map((fk) => JSON.stringify(fk)).join(", ")}]`);
|
|
2204
|
+
}
|
|
2205
|
+
return parts.length > 0 ? `Filter.type(${parts.join(", ")})` : "Filter.everything()";
|
|
2206
|
+
}
|
|
2207
|
+
case "compare":
|
|
2208
|
+
return `Filter.${filter.operator}(${JSON.stringify(filter.value)})`;
|
|
2209
|
+
case "in":
|
|
2210
|
+
return `Filter.in([${filter.values.map((v) => JSON.stringify(v)).join(", ")}])`;
|
|
2211
|
+
case "contains":
|
|
2212
|
+
return `Filter.contains(${JSON.stringify(filter.value)})`;
|
|
2213
|
+
case "tag":
|
|
2214
|
+
return `Filter.tag(${JSON.stringify(filter.tag)})`;
|
|
2215
|
+
case "range":
|
|
2216
|
+
return `Filter.range(${JSON.stringify(filter.from)}, ${JSON.stringify(filter.to)})`;
|
|
2217
|
+
case "text-search":
|
|
2218
|
+
return filter.searchKind ? `Filter.textSearch(${JSON.stringify(filter.text)}, ${JSON.stringify(filter.searchKind)})` : `Filter.textSearch(${JSON.stringify(filter.text)})`;
|
|
2219
|
+
case "timestamp":
|
|
2220
|
+
return `Filter.${filter.field}.${filter.operator}(${filter.value})`;
|
|
2221
|
+
case "child-of":
|
|
2222
|
+
return `Filter.childOf([${filter.parents.map((p) => JSON.stringify(p)).join(", ")}], { transitive: ${filter.transitive} })`;
|
|
2223
|
+
case "not":
|
|
2224
|
+
return `Filter.not(${prettyFilter(filter.filter)})`;
|
|
2225
|
+
case "and":
|
|
2226
|
+
return `Filter.and(${filter.filters.map(prettyFilter).join(", ")})`;
|
|
2227
|
+
case "or":
|
|
2228
|
+
return `Filter.or(${filter.filters.map(prettyFilter).join(", ")})`;
|
|
2229
|
+
}
|
|
2230
|
+
};
|
|
2231
|
+
var prettyQuery = (query) => {
|
|
2232
|
+
switch (query.type) {
|
|
2233
|
+
case "select":
|
|
2234
|
+
return `Query.select(${prettyFilter(query.filter)})`;
|
|
2235
|
+
case "filter":
|
|
2236
|
+
return `${prettyQuery(query.selection)}.select(${prettyFilter(query.filter)})`;
|
|
2237
|
+
case "reference-traversal":
|
|
2238
|
+
return `${prettyQuery(query.anchor)}.reference(${JSON.stringify(query.property)})`;
|
|
2239
|
+
case "incoming-references": {
|
|
2240
|
+
const args = [];
|
|
2241
|
+
if (query.typename !== null) {
|
|
2242
|
+
args.push(String(query.typename));
|
|
2243
|
+
}
|
|
2244
|
+
if (query.property !== null) {
|
|
2245
|
+
args.push(JSON.stringify(query.property));
|
|
2246
|
+
}
|
|
2247
|
+
return `${prettyQuery(query.anchor)}.referencedBy(${args.join(", ")})`;
|
|
2248
|
+
}
|
|
2249
|
+
case "relation": {
|
|
2250
|
+
const method = query.direction === "outgoing" ? "sourceOf" : query.direction === "incoming" ? "targetOf" : "relationOf";
|
|
2251
|
+
const filterStr = query.filter !== void 0 ? prettyFilter(query.filter) : "";
|
|
2252
|
+
return `${prettyQuery(query.anchor)}.${method}(${filterStr})`;
|
|
2253
|
+
}
|
|
2254
|
+
case "relation-traversal":
|
|
2255
|
+
return `${prettyQuery(query.anchor)}.${query.direction}()`;
|
|
2256
|
+
case "hierarchy-traversal":
|
|
2257
|
+
return query.direction === "to-parent" ? `${prettyQuery(query.anchor)}.parent()` : `${prettyQuery(query.anchor)}.children()`;
|
|
2258
|
+
case "union":
|
|
2259
|
+
return `Query.all(${query.queries.map(prettyQuery).join(", ")})`;
|
|
2260
|
+
case "set-difference":
|
|
2261
|
+
return `Query.without(${prettyQuery(query.source)}, ${prettyQuery(query.exclude)})`;
|
|
2262
|
+
case "order": {
|
|
2263
|
+
const orders = query.order.map((o) => {
|
|
2264
|
+
if (o.kind === "natural") {
|
|
2265
|
+
return "Order.natural()";
|
|
2266
|
+
} else if (o.kind === "rank") {
|
|
2267
|
+
return `Order.rank(${JSON.stringify(o.direction)})`;
|
|
2268
|
+
} else {
|
|
2269
|
+
return `Order.property(${JSON.stringify(o.property)}, ${JSON.stringify(o.direction)})`;
|
|
2270
|
+
}
|
|
2271
|
+
});
|
|
2272
|
+
return `${prettyQuery(query.query)}.orderBy(${orders.join(", ")})`;
|
|
2273
|
+
}
|
|
2274
|
+
case "options": {
|
|
2275
|
+
const opts = query.options;
|
|
2276
|
+
const parts = [];
|
|
2277
|
+
if (opts.deleted !== void 0) {
|
|
2278
|
+
parts.push(`deleted: ${JSON.stringify(opts.deleted)}`);
|
|
2279
|
+
}
|
|
2280
|
+
return `${prettyQuery(query.query)}.options({ ${parts.join(", ")} })`;
|
|
2281
|
+
}
|
|
2282
|
+
case "from": {
|
|
2283
|
+
if (query.from._tag === "scope") {
|
|
2284
|
+
const scope = query.from.scope;
|
|
2285
|
+
const parts = [];
|
|
2286
|
+
if (scope.spaceIds !== void 0) {
|
|
2287
|
+
parts.push(`spaceIds: [${scope.spaceIds.map((s) => JSON.stringify(s)).join(", ")}]`);
|
|
2288
|
+
}
|
|
2289
|
+
if (scope.queues !== void 0) {
|
|
2290
|
+
parts.push(`queues: [${scope.queues.map(String).join(", ")}]`);
|
|
2291
|
+
}
|
|
2292
|
+
if (scope.allQueuesFromSpaces !== void 0) {
|
|
2293
|
+
parts.push(`allQueuesFromSpaces: ${scope.allQueuesFromSpaces}`);
|
|
2294
|
+
}
|
|
2295
|
+
return `${prettyQuery(query.query)}.from({ ${parts.join(", ")} })`;
|
|
2296
|
+
}
|
|
2297
|
+
return `${prettyQuery(query.query)}.from(${prettyQuery(query.from.query)})`;
|
|
2298
|
+
}
|
|
2299
|
+
case "limit":
|
|
2300
|
+
return `${prettyQuery(query.query)}.limit(${query.limit})`;
|
|
2301
|
+
}
|
|
2302
|
+
};
|
|
2303
|
+
|
|
2304
|
+
// src/internal/Type/echo-schema.ts
|
|
2305
|
+
import * as Schema13 from "effect/Schema";
|
|
2306
|
+
import * as SchemaAST8 from "effect/SchemaAST";
|
|
2307
|
+
import { invariant as invariant17 } from "@dxos/invariant";
|
|
2308
|
+
|
|
2309
|
+
// src/internal/Type/manipulation.ts
|
|
2310
|
+
import * as Schema11 from "effect/Schema";
|
|
2311
|
+
import * as SchemaAST7 from "effect/SchemaAST";
|
|
2312
|
+
import { invariant as invariant16 } from "@dxos/invariant";
|
|
2313
|
+
import { DXN as DXN7 } from "@dxos/keys";
|
|
2314
|
+
var __dxlog_file16 = "/__w/dxos/dxos/packages/core/echo/echo/src/internal/Type/manipulation.ts";
|
|
2315
|
+
var addFieldsToSchema = (schema, fields) => {
|
|
2316
|
+
const schemaExtension = Schema11.partial(Schema11.Struct(fields));
|
|
2317
|
+
return Schema11.extend(schema, schemaExtension).annotations(schema.ast.annotations);
|
|
2318
|
+
};
|
|
2319
|
+
var updateFieldsInSchema = (schema, fields) => {
|
|
2320
|
+
const ast = schema.ast;
|
|
2321
|
+
invariant16(SchemaAST7.isTypeLiteral(ast), void 0, {
|
|
2322
|
+
F: __dxlog_file16,
|
|
2323
|
+
L: 29,
|
|
2324
|
+
S: void 0,
|
|
2325
|
+
A: [
|
|
2326
|
+
"SchemaAST.isTypeLiteral(ast)",
|
|
2327
|
+
""
|
|
2328
|
+
]
|
|
2329
|
+
});
|
|
2330
|
+
const updatedProperties = [
|
|
2331
|
+
...ast.propertySignatures
|
|
2332
|
+
];
|
|
2333
|
+
const propertiesToUpdate = Schema11.partial(Schema11.Struct(fields)).ast.propertySignatures;
|
|
2334
|
+
for (const property of propertiesToUpdate) {
|
|
2335
|
+
const index = updatedProperties.findIndex((p) => p.name === property.name);
|
|
2336
|
+
if (index !== -1) {
|
|
2337
|
+
updatedProperties[index] = property;
|
|
2338
|
+
} else {
|
|
2339
|
+
updatedProperties.push(property);
|
|
2340
|
+
}
|
|
2341
|
+
}
|
|
2342
|
+
return Schema11.make(new SchemaAST7.TypeLiteral(updatedProperties, ast.indexSignatures, ast.annotations));
|
|
2343
|
+
};
|
|
2344
|
+
var removeFieldsFromSchema = (schema, fieldNames) => {
|
|
2345
|
+
return Schema11.make(SchemaAST7.omit(schema.ast, fieldNames)).annotations(schema.ast.annotations);
|
|
2346
|
+
};
|
|
2347
|
+
var updateFieldNameInSchema = (schema, { before, after }) => {
|
|
2348
|
+
const ast = schema.ast;
|
|
2349
|
+
invariant16(SchemaAST7.isTypeLiteral(ast), void 0, {
|
|
2350
|
+
F: __dxlog_file16,
|
|
2351
|
+
L: 57,
|
|
2352
|
+
S: void 0,
|
|
2353
|
+
A: [
|
|
2354
|
+
"SchemaAST.isTypeLiteral(ast)",
|
|
2355
|
+
""
|
|
2356
|
+
]
|
|
2357
|
+
});
|
|
2358
|
+
return Schema11.make(new SchemaAST7.TypeLiteral(ast.propertySignatures.map((p) => p.name === before ? new SchemaAST7.PropertySignature(after, p.type, p.isOptional, p.isReadonly, p.annotations) : p), ast.indexSignatures, ast.annotations));
|
|
2359
|
+
};
|
|
2360
|
+
var setTypenameInSchema = (schema, typename) => {
|
|
2361
|
+
const existingAnnotation = schema.ast.annotations[TypeAnnotationId];
|
|
2362
|
+
invariant16(existingAnnotation, `Missing ${String(TypeAnnotationId)}`, {
|
|
2363
|
+
F: __dxlog_file16,
|
|
2364
|
+
L: 77,
|
|
2365
|
+
S: void 0,
|
|
2366
|
+
A: [
|
|
2367
|
+
"existingAnnotation",
|
|
2368
|
+
"`Missing ${String(TypeAnnotationId)}`"
|
|
2369
|
+
]
|
|
2370
|
+
});
|
|
2371
|
+
return schema.annotations({
|
|
2372
|
+
...schema.ast.annotations,
|
|
2373
|
+
[TypeAnnotationId]: {
|
|
2374
|
+
kind: existingAnnotation.kind,
|
|
2375
|
+
typename,
|
|
2376
|
+
version: existingAnnotation.version
|
|
2377
|
+
},
|
|
2378
|
+
[SchemaAST7.JSONSchemaAnnotationId]: {
|
|
2379
|
+
...schema.ast.annotations[SchemaAST7.JSONSchemaAnnotationId] ?? {},
|
|
2380
|
+
$id: schema.ast.annotations[TypeIdentifierAnnotationId] ?? DXN7.fromTypename(typename).toString(),
|
|
2381
|
+
typename
|
|
2382
|
+
}
|
|
2383
|
+
});
|
|
2384
|
+
};
|
|
2385
|
+
|
|
2386
|
+
// src/internal/Type/persistent-schema.ts
|
|
2387
|
+
import * as Schema12 from "effect/Schema";
|
|
2388
|
+
var PersistentSchema = Schema12.Struct({
|
|
2389
|
+
name: Schema12.optional(Schema12.String),
|
|
2390
|
+
typename: TypenameSchema,
|
|
2391
|
+
version: VersionSchema,
|
|
2392
|
+
jsonSchema: JsonSchemaType
|
|
2393
|
+
}).pipe(EchoObjectSchema({
|
|
2394
|
+
typename: "org.dxos.type.schema",
|
|
2395
|
+
version: "0.1.0"
|
|
2396
|
+
}), LabelAnnotation.set([
|
|
2397
|
+
"name"
|
|
2398
|
+
]), IconAnnotation.set({
|
|
2399
|
+
icon: "ph--database--regular",
|
|
2400
|
+
hue: "green"
|
|
2401
|
+
}));
|
|
2402
|
+
|
|
2403
|
+
// src/internal/Type/echo-schema.ts
|
|
2404
|
+
var __dxlog_file17 = "/__w/dxos/dxos/packages/core/echo/echo/src/internal/Type/echo-schema.ts";
|
|
2405
|
+
var ImmutableSchema = class {
|
|
2406
|
+
_schema;
|
|
2407
|
+
_objectAnnotation;
|
|
2408
|
+
constructor(_schema) {
|
|
2409
|
+
this._schema = _schema;
|
|
2410
|
+
this._objectAnnotation = getTypeAnnotation(this._schema);
|
|
2411
|
+
invariant17(this._objectAnnotation, void 0, {
|
|
2412
|
+
F: __dxlog_file17,
|
|
2413
|
+
L: 48,
|
|
2414
|
+
S: this,
|
|
2415
|
+
A: [
|
|
2416
|
+
"this._objectAnnotation",
|
|
2417
|
+
""
|
|
2418
|
+
]
|
|
2419
|
+
});
|
|
2420
|
+
}
|
|
2421
|
+
//
|
|
2422
|
+
// Effect Schema (push to abstract base class).
|
|
2423
|
+
//
|
|
2424
|
+
get [Schema13.TypeId]() {
|
|
2425
|
+
return schemaVariance2;
|
|
2426
|
+
}
|
|
2427
|
+
get Type() {
|
|
2428
|
+
return this._schema.Type;
|
|
2429
|
+
}
|
|
2430
|
+
get Encoded() {
|
|
2431
|
+
return this._schema.Encoded;
|
|
2432
|
+
}
|
|
2433
|
+
get Context() {
|
|
2434
|
+
return this._schema.Context;
|
|
2435
|
+
}
|
|
2436
|
+
get ast() {
|
|
2437
|
+
return this._schema.ast;
|
|
2438
|
+
}
|
|
2439
|
+
get annotations() {
|
|
2440
|
+
return this._schema.annotations;
|
|
2441
|
+
}
|
|
2442
|
+
get pipe() {
|
|
2443
|
+
return this._schema.pipe;
|
|
2444
|
+
}
|
|
2445
|
+
//
|
|
2446
|
+
// TypedObject
|
|
2447
|
+
//
|
|
2448
|
+
get kind() {
|
|
2449
|
+
return this._objectAnnotation.kind;
|
|
2450
|
+
}
|
|
2451
|
+
get typename() {
|
|
2452
|
+
return this._objectAnnotation.typename;
|
|
2453
|
+
}
|
|
2454
|
+
get version() {
|
|
2455
|
+
return this._objectAnnotation.version;
|
|
2456
|
+
}
|
|
2457
|
+
//
|
|
2458
|
+
// BaseSchema
|
|
2459
|
+
//
|
|
2460
|
+
get readonly() {
|
|
2461
|
+
return true;
|
|
2462
|
+
}
|
|
2463
|
+
get snapshot() {
|
|
2464
|
+
return this._schema;
|
|
2465
|
+
}
|
|
2466
|
+
// TODO(burdon): Change from getter since this is expensive.
|
|
2467
|
+
get jsonSchema() {
|
|
2468
|
+
return toJsonSchema(this._schema);
|
|
2469
|
+
}
|
|
2470
|
+
get mutable() {
|
|
2471
|
+
throw new Error("Schema is readonly.");
|
|
2472
|
+
}
|
|
2473
|
+
};
|
|
2474
|
+
var EchoSchemaConstructor = () => {
|
|
2475
|
+
return class {
|
|
2476
|
+
static get _schema() {
|
|
2477
|
+
return Schema13.Union(PersistentSchema, Schema13.instanceOf(EchoSchema)).annotations(PersistentSchema.ast.annotations);
|
|
2478
|
+
}
|
|
2479
|
+
static [Schema13.TypeId] = schemaVariance2;
|
|
2480
|
+
static get ast() {
|
|
2481
|
+
const schema = this._schema;
|
|
2482
|
+
return schema.ast;
|
|
2483
|
+
}
|
|
2484
|
+
static get annotations() {
|
|
2485
|
+
const schema = this._schema;
|
|
2486
|
+
return schema.annotations.bind(schema);
|
|
2487
|
+
}
|
|
2488
|
+
static get pipe() {
|
|
2489
|
+
const schema = this._schema;
|
|
2490
|
+
return schema.pipe.bind(schema);
|
|
2491
|
+
}
|
|
2492
|
+
};
|
|
2493
|
+
};
|
|
2494
|
+
var isMutable = (schema) => {
|
|
2495
|
+
return schema instanceof EchoSchema;
|
|
2496
|
+
};
|
|
2497
|
+
var schemaVariance2 = {
|
|
2498
|
+
_A: (_) => _,
|
|
2499
|
+
_I: (_) => _,
|
|
2500
|
+
_R: (_) => _
|
|
2501
|
+
};
|
|
2502
|
+
var EchoSchema = class extends EchoSchemaConstructor() {
|
|
2503
|
+
_persistentSchema;
|
|
2504
|
+
_schema;
|
|
2505
|
+
_isDirty = true;
|
|
2506
|
+
/**
|
|
2507
|
+
* Schema kind key that marks this as an ECHO schema.
|
|
2508
|
+
* Makes EchoSchema satisfy the Type.AnyObj type.
|
|
2509
|
+
*/
|
|
2510
|
+
[SchemaKindId] = EntityKind.Object;
|
|
2511
|
+
constructor(_persistentSchema) {
|
|
2512
|
+
super(), this._persistentSchema = _persistentSchema;
|
|
2513
|
+
}
|
|
2514
|
+
//
|
|
2515
|
+
// Effect Schema (push to abstract base class).
|
|
2516
|
+
//
|
|
2517
|
+
get [Schema13.TypeId]() {
|
|
2518
|
+
return schemaVariance2;
|
|
2519
|
+
}
|
|
2520
|
+
get Type() {
|
|
2521
|
+
return this._persistentSchema;
|
|
2522
|
+
}
|
|
2523
|
+
get Encoded() {
|
|
2524
|
+
return this._persistentSchema;
|
|
2525
|
+
}
|
|
2526
|
+
get Context() {
|
|
2527
|
+
const schema = this._getSchema();
|
|
2528
|
+
return schema.Context;
|
|
2529
|
+
}
|
|
2530
|
+
get ast() {
|
|
2531
|
+
const schema = this._getSchema();
|
|
2532
|
+
return schema.ast;
|
|
2533
|
+
}
|
|
2534
|
+
get annotations() {
|
|
2535
|
+
const schema = this._getSchema();
|
|
2536
|
+
return schema.annotations.bind(schema);
|
|
2537
|
+
}
|
|
2538
|
+
get pipe() {
|
|
2539
|
+
const schema = this._getSchema();
|
|
2540
|
+
return schema.pipe.bind(schema);
|
|
2541
|
+
}
|
|
2542
|
+
//
|
|
2543
|
+
// BaseSchema
|
|
2544
|
+
//
|
|
2545
|
+
get kind() {
|
|
2546
|
+
return EntityKind.Object;
|
|
2547
|
+
}
|
|
2548
|
+
get typename() {
|
|
2549
|
+
return this._persistentSchema.typename;
|
|
2550
|
+
}
|
|
2551
|
+
get version() {
|
|
2552
|
+
return this._persistentSchema.version;
|
|
2553
|
+
}
|
|
2554
|
+
get readonly() {
|
|
2555
|
+
return false;
|
|
2556
|
+
}
|
|
2557
|
+
/**
|
|
2558
|
+
* Returns an immutable schema snapshot of the current state of the schema.
|
|
2559
|
+
*/
|
|
2560
|
+
get snapshot() {
|
|
2561
|
+
return this._getSchema();
|
|
2562
|
+
}
|
|
2563
|
+
/**
|
|
2564
|
+
* Returns the JSON schema for the schema.
|
|
2565
|
+
*/
|
|
2566
|
+
get jsonSchema() {
|
|
2567
|
+
return this._persistentSchema.jsonSchema;
|
|
2568
|
+
}
|
|
2569
|
+
/**
|
|
2570
|
+
* Returns a mutable schema.
|
|
2571
|
+
*/
|
|
2572
|
+
get mutable() {
|
|
2573
|
+
invariant17(!this.readonly, "Schema is not mutable", {
|
|
2574
|
+
F: __dxlog_file17,
|
|
2575
|
+
L: 278,
|
|
2576
|
+
S: this,
|
|
2577
|
+
A: [
|
|
2578
|
+
"!this.readonly",
|
|
2579
|
+
"'Schema is not mutable'"
|
|
2580
|
+
]
|
|
2581
|
+
});
|
|
2582
|
+
return this;
|
|
2583
|
+
}
|
|
2584
|
+
//
|
|
2585
|
+
// Mutable Schema
|
|
2586
|
+
//
|
|
2587
|
+
/**
|
|
2588
|
+
* Id of the ECHO object containing the schema.
|
|
2589
|
+
*/
|
|
2590
|
+
get id() {
|
|
2591
|
+
return this._persistentSchema.id;
|
|
2592
|
+
}
|
|
2593
|
+
/**
|
|
2594
|
+
* Short name of the schema.
|
|
2595
|
+
*/
|
|
2596
|
+
get name() {
|
|
2597
|
+
return this._persistentSchema.name;
|
|
2598
|
+
}
|
|
2599
|
+
get [SchemaMetaSymbol]() {
|
|
2600
|
+
return {
|
|
2601
|
+
id: this.id,
|
|
2602
|
+
typename: this.typename,
|
|
2603
|
+
version: this._persistentSchema.version
|
|
2604
|
+
};
|
|
2605
|
+
}
|
|
2606
|
+
/**
|
|
2607
|
+
* Reference to the underlying persistent schema object.
|
|
2608
|
+
*/
|
|
2609
|
+
get persistentSchema() {
|
|
2610
|
+
return this._persistentSchema;
|
|
2611
|
+
}
|
|
2612
|
+
getProperties() {
|
|
2613
|
+
const ast = this._getSchema().ast;
|
|
2614
|
+
invariant17(SchemaAST8.isTypeLiteral(ast), void 0, {
|
|
2615
|
+
F: __dxlog_file17,
|
|
2616
|
+
L: 313,
|
|
2617
|
+
S: this,
|
|
2618
|
+
A: [
|
|
2619
|
+
"SchemaAST.isTypeLiteral(ast)",
|
|
2620
|
+
""
|
|
2621
|
+
]
|
|
2622
|
+
});
|
|
2623
|
+
return [
|
|
2624
|
+
...ast.propertySignatures
|
|
2625
|
+
].filter((p) => p.name !== "id").map(unwrapOptionality);
|
|
2626
|
+
}
|
|
2627
|
+
//
|
|
2628
|
+
// Mutation methods.
|
|
2629
|
+
// TODO(burdon): Create separate interface for dynamic schema.
|
|
2630
|
+
// TODO(burdon): Deprecate direct manipulation? Use JSONSchema directly.
|
|
2631
|
+
//
|
|
2632
|
+
/**
|
|
2633
|
+
* @throws Error if the schema is readonly.
|
|
2634
|
+
*/
|
|
2635
|
+
updateTypename(typename) {
|
|
2636
|
+
const updated = setTypenameInSchema(this._getSchema(), typename);
|
|
2637
|
+
this._change((schema) => {
|
|
2638
|
+
schema.typename = typename;
|
|
2639
|
+
schema.jsonSchema = toJsonSchema(updated);
|
|
2640
|
+
});
|
|
2641
|
+
}
|
|
2642
|
+
/**
|
|
2643
|
+
* @throws Error if the schema is readonly.
|
|
2644
|
+
*/
|
|
2645
|
+
addFields(fields) {
|
|
2646
|
+
const extended = addFieldsToSchema(this._getSchema(), fields);
|
|
2647
|
+
this._change((schema) => {
|
|
2648
|
+
schema.jsonSchema = toJsonSchema(extended);
|
|
2649
|
+
});
|
|
2650
|
+
}
|
|
2651
|
+
/**
|
|
2652
|
+
* @throws Error if the schema is readonly.
|
|
2653
|
+
*/
|
|
2654
|
+
updateFields(fields) {
|
|
2655
|
+
const updated = updateFieldsInSchema(this._getSchema(), fields);
|
|
2656
|
+
this._change((schema) => {
|
|
2657
|
+
schema.jsonSchema = toJsonSchema(updated);
|
|
2658
|
+
});
|
|
2659
|
+
}
|
|
2660
|
+
/**
|
|
2661
|
+
* @throws Error if the schema is readonly.
|
|
2662
|
+
*/
|
|
2663
|
+
updateFieldPropertyName({ before, after }) {
|
|
2664
|
+
const renamed = updateFieldNameInSchema(this._getSchema(), {
|
|
2665
|
+
before,
|
|
2666
|
+
after
|
|
2667
|
+
});
|
|
2668
|
+
this._change((schema) => {
|
|
2669
|
+
schema.jsonSchema = toJsonSchema(renamed);
|
|
2670
|
+
});
|
|
2671
|
+
}
|
|
2672
|
+
/**
|
|
2673
|
+
* @throws Error if the schema is readonly.
|
|
2674
|
+
*/
|
|
2675
|
+
removeFields(fieldNames) {
|
|
2676
|
+
const removed = removeFieldsFromSchema(this._getSchema(), fieldNames);
|
|
2677
|
+
this._change((schema) => {
|
|
2678
|
+
schema.jsonSchema = toJsonSchema(removed);
|
|
2679
|
+
});
|
|
2680
|
+
}
|
|
2681
|
+
/**
|
|
2682
|
+
* Wrapper for Obj.change that handles the change context for the persistent schema.
|
|
2683
|
+
*/
|
|
2684
|
+
_change(callback) {
|
|
2685
|
+
const changeFn = this._persistentSchema[ChangeId];
|
|
2686
|
+
if (changeFn) {
|
|
2687
|
+
changeFn(callback);
|
|
2688
|
+
} else {
|
|
2689
|
+
callback(this._persistentSchema);
|
|
2690
|
+
}
|
|
2691
|
+
}
|
|
2692
|
+
//
|
|
2693
|
+
// Internals
|
|
2694
|
+
//
|
|
2695
|
+
/**
|
|
2696
|
+
* Called by DatabaseSchemaRegistry on update.
|
|
2697
|
+
*/
|
|
2698
|
+
_invalidate() {
|
|
2699
|
+
this._isDirty = true;
|
|
2700
|
+
}
|
|
2701
|
+
/**
|
|
2702
|
+
* Rebuilds this schema if it is dirty.
|
|
2703
|
+
*/
|
|
2704
|
+
_rebuild() {
|
|
2705
|
+
if (this._isDirty || this._schema == null) {
|
|
2706
|
+
this._schema = toEffectSchema(getSnapshot(this._persistentSchema).jsonSchema);
|
|
2707
|
+
this._isDirty = false;
|
|
2708
|
+
}
|
|
2709
|
+
}
|
|
2710
|
+
_getSchema() {
|
|
2711
|
+
this._rebuild();
|
|
2712
|
+
return this._schema;
|
|
2713
|
+
}
|
|
2714
|
+
};
|
|
2715
|
+
var unwrapOptionality = (property) => {
|
|
2716
|
+
if (!SchemaAST8.isUnion(property.type)) {
|
|
2717
|
+
return property;
|
|
2718
|
+
}
|
|
2719
|
+
return {
|
|
2720
|
+
...property,
|
|
2721
|
+
type: property.type.types.find((type) => !SchemaAST8.isUndefinedKeyword(type))
|
|
2722
|
+
};
|
|
2723
|
+
};
|
|
2724
|
+
|
|
2725
|
+
export {
|
|
2726
|
+
RawObject,
|
|
2727
|
+
ATTR_META,
|
|
2728
|
+
MetaId,
|
|
2729
|
+
ObjectMetaSchema,
|
|
2730
|
+
getMeta,
|
|
2731
|
+
foreignKey,
|
|
2732
|
+
foreignKeyEquals,
|
|
2733
|
+
compareForeignKeys,
|
|
2734
|
+
ATTR_SELF_DXN,
|
|
2735
|
+
SelfDXNId,
|
|
2736
|
+
ATTR_DELETED,
|
|
2737
|
+
ObjectDeletedId,
|
|
2738
|
+
ObjectVersionId,
|
|
2739
|
+
ObjectDatabaseId,
|
|
2740
|
+
ATTR_RELATION_SOURCE,
|
|
2741
|
+
RelationSourceId,
|
|
2742
|
+
RelationSourceDXNId,
|
|
2743
|
+
ATTR_RELATION_TARGET,
|
|
2744
|
+
RelationTargetId,
|
|
2745
|
+
RelationTargetDXNId,
|
|
2746
|
+
VersionTypeId,
|
|
2747
|
+
compare,
|
|
2748
|
+
sortByLabel,
|
|
2749
|
+
sortByTypename,
|
|
2750
|
+
sort,
|
|
2751
|
+
getMetaChecked,
|
|
2752
|
+
getKeys,
|
|
2753
|
+
deleteKeys,
|
|
2754
|
+
addTag,
|
|
2755
|
+
removeTag,
|
|
2756
|
+
EventId,
|
|
2757
|
+
ChangeId,
|
|
2758
|
+
batchEvents,
|
|
2759
|
+
emitEvent,
|
|
2760
|
+
enterChangeContext,
|
|
2761
|
+
isInChangeContext,
|
|
2762
|
+
queueNotification,
|
|
2763
|
+
queueOwnerNotification,
|
|
2764
|
+
hasPendingNotifications,
|
|
2765
|
+
clearPendingNotifications,
|
|
2766
|
+
executeChange,
|
|
2767
|
+
defineHiddenProperty,
|
|
2768
|
+
MutationOutsideChangeContextError,
|
|
2769
|
+
createPropertySetError,
|
|
2770
|
+
createPropertyDeleteError,
|
|
2771
|
+
createArrayMethodError,
|
|
2772
|
+
attachTypedJsonSerializer,
|
|
2773
|
+
typedJsonSerializer,
|
|
2774
|
+
symbolIsProxy,
|
|
2775
|
+
isProxy,
|
|
2776
|
+
isValidProxyTarget,
|
|
2777
|
+
getProxySlot,
|
|
2778
|
+
getProxyTarget,
|
|
2779
|
+
getProxyHandler,
|
|
2780
|
+
dangerouslySetProxyId,
|
|
2781
|
+
createProxy,
|
|
2782
|
+
setMetaOwner,
|
|
2783
|
+
getEchoRoot,
|
|
2784
|
+
objectData,
|
|
2785
|
+
ReactiveArray,
|
|
2786
|
+
SchemaValidator,
|
|
2787
|
+
checkIdNotPresentOnSchema,
|
|
2788
|
+
TypedReactiveHandler,
|
|
2789
|
+
prepareTypedTarget,
|
|
2790
|
+
makeObject,
|
|
2791
|
+
subscribe,
|
|
2792
|
+
change,
|
|
2793
|
+
assertObjectModel,
|
|
2794
|
+
getObjectDXN,
|
|
2795
|
+
getDXN,
|
|
2796
|
+
getDatabase,
|
|
2797
|
+
makeEchoTypeSchema,
|
|
2798
|
+
EchoObjectSchema,
|
|
2799
|
+
EchoRelationSchema,
|
|
2800
|
+
isVersion,
|
|
2801
|
+
version,
|
|
2802
|
+
versionValid,
|
|
2803
|
+
compareVersions,
|
|
2804
|
+
encodeVersion,
|
|
2805
|
+
decodeVersion,
|
|
2806
|
+
normalizeSchema,
|
|
2807
|
+
makeTypedEntityClass,
|
|
2808
|
+
objectToJSON,
|
|
2809
|
+
objectFromJSON,
|
|
2810
|
+
setRefResolverOnData,
|
|
2811
|
+
objectStructureToJson,
|
|
2812
|
+
createObject,
|
|
2813
|
+
isDeleted,
|
|
2814
|
+
createQueueDXN,
|
|
2815
|
+
setValue,
|
|
2816
|
+
getSnapshot,
|
|
2817
|
+
clone,
|
|
2818
|
+
prettyFilter,
|
|
2819
|
+
prettyQuery,
|
|
2820
|
+
addFieldsToSchema,
|
|
2821
|
+
updateFieldsInSchema,
|
|
2822
|
+
removeFieldsFromSchema,
|
|
2823
|
+
updateFieldNameInSchema,
|
|
2824
|
+
setTypenameInSchema,
|
|
2825
|
+
PersistentSchema,
|
|
2826
|
+
ImmutableSchema,
|
|
2827
|
+
isMutable,
|
|
2828
|
+
EchoSchema,
|
|
2829
|
+
JsonPath,
|
|
2830
|
+
JsonProp,
|
|
2831
|
+
getValue,
|
|
2832
|
+
splitJsonPath
|
|
2833
|
+
};
|
|
2834
|
+
//# sourceMappingURL=chunk-MOR5ERFM.mjs.map
|