@dxos/echo 0.8.4-main.c4373fc → 0.8.4-main.c85a9c8dae

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (559) hide show
  1. package/README.md +3 -4
  2. package/dist/lib/neutral/Annotation.mjs +37 -0
  3. package/dist/lib/neutral/Database.mjs +45 -0
  4. package/dist/lib/neutral/Entity.mjs +56 -0
  5. package/dist/lib/neutral/Err.mjs +12 -0
  6. package/dist/lib/neutral/Feed.mjs +43 -0
  7. package/dist/lib/neutral/Filter.mjs +61 -0
  8. package/dist/lib/neutral/Format.mjs +66 -0
  9. package/dist/lib/neutral/Format.mjs.map +7 -0
  10. package/dist/lib/neutral/JsonSchema.mjs +18 -0
  11. package/dist/lib/neutral/JsonSchema.mjs.map +7 -0
  12. package/dist/lib/neutral/Key.mjs +12 -0
  13. package/dist/lib/neutral/Key.mjs.map +7 -0
  14. package/dist/lib/neutral/Obj.mjs +107 -0
  15. package/dist/lib/neutral/Obj.mjs.map +7 -0
  16. package/dist/lib/neutral/Order.mjs +12 -0
  17. package/dist/lib/neutral/Order.mjs.map +7 -0
  18. package/dist/lib/neutral/Query.mjs +32 -0
  19. package/dist/lib/neutral/Query.mjs.map +7 -0
  20. package/dist/lib/neutral/QueryResult.mjs +2 -0
  21. package/dist/lib/neutral/QueryResult.mjs.map +7 -0
  22. package/dist/lib/neutral/Ref.mjs +24 -0
  23. package/dist/lib/neutral/Ref.mjs.map +7 -0
  24. package/dist/lib/neutral/Relation.mjs +90 -0
  25. package/dist/lib/neutral/Relation.mjs.map +7 -0
  26. package/dist/lib/neutral/SchemaRegistry.mjs +2 -0
  27. package/dist/lib/neutral/SchemaRegistry.mjs.map +7 -0
  28. package/dist/lib/neutral/Tag.mjs +25 -0
  29. package/dist/lib/neutral/Tag.mjs.map +7 -0
  30. package/dist/lib/neutral/Type.mjs +34 -0
  31. package/dist/lib/neutral/Type.mjs.map +7 -0
  32. package/dist/lib/neutral/chunk-4KG6IGL4.mjs +67 -0
  33. package/dist/lib/neutral/chunk-4KG6IGL4.mjs.map +7 -0
  34. package/dist/lib/neutral/chunk-5ELDDYWE.mjs +130 -0
  35. package/dist/lib/neutral/chunk-5ELDDYWE.mjs.map +7 -0
  36. package/dist/lib/neutral/chunk-ALOGSVBP.mjs +299 -0
  37. package/dist/lib/neutral/chunk-ALOGSVBP.mjs.map +7 -0
  38. package/dist/lib/neutral/chunk-ANHVGJI4.mjs +21 -0
  39. package/dist/lib/neutral/chunk-ANHVGJI4.mjs.map +7 -0
  40. package/dist/lib/neutral/chunk-AQP4QKYP.mjs +283 -0
  41. package/dist/lib/neutral/chunk-AQP4QKYP.mjs.map +7 -0
  42. package/dist/lib/neutral/chunk-BRJSLACP.mjs +152 -0
  43. package/dist/lib/neutral/chunk-BRJSLACP.mjs.map +7 -0
  44. package/dist/lib/neutral/chunk-DZQSL6RW.mjs +73 -0
  45. package/dist/lib/neutral/chunk-DZQSL6RW.mjs.map +7 -0
  46. package/dist/lib/neutral/chunk-F7KMHDPJ.mjs +327 -0
  47. package/dist/lib/neutral/chunk-F7KMHDPJ.mjs.map +7 -0
  48. package/dist/lib/neutral/chunk-GAWKQ5DZ.mjs +56 -0
  49. package/dist/lib/neutral/chunk-GAWKQ5DZ.mjs.map +7 -0
  50. package/dist/lib/neutral/chunk-GFNCSK7F.mjs +101 -0
  51. package/dist/lib/neutral/chunk-GFNCSK7F.mjs.map +7 -0
  52. package/dist/lib/neutral/chunk-J5LGTIGS.mjs +10 -0
  53. package/dist/lib/neutral/chunk-J5LGTIGS.mjs.map +7 -0
  54. package/dist/lib/neutral/chunk-KGV3QIRX.mjs +313 -0
  55. package/dist/lib/neutral/chunk-KGV3QIRX.mjs.map +7 -0
  56. package/dist/lib/neutral/chunk-M2KVTHZM.mjs +402 -0
  57. package/dist/lib/neutral/chunk-M2KVTHZM.mjs.map +7 -0
  58. package/dist/lib/neutral/chunk-MXQJZCPY.mjs +51 -0
  59. package/dist/lib/neutral/chunk-MXQJZCPY.mjs.map +7 -0
  60. package/dist/lib/neutral/chunk-O3TZFQCT.mjs +27 -0
  61. package/dist/lib/neutral/chunk-O3TZFQCT.mjs.map +7 -0
  62. package/dist/lib/neutral/chunk-OMUPQMLR.mjs +7 -0
  63. package/dist/lib/neutral/chunk-OMUPQMLR.mjs.map +7 -0
  64. package/dist/lib/neutral/chunk-OVUBTQLT.mjs +45 -0
  65. package/dist/lib/neutral/chunk-OVUBTQLT.mjs.map +7 -0
  66. package/dist/lib/neutral/chunk-PP4DNUZU.mjs +3919 -0
  67. package/dist/lib/neutral/chunk-PP4DNUZU.mjs.map +7 -0
  68. package/dist/lib/neutral/chunk-QXF3LGN2.mjs +43 -0
  69. package/dist/lib/neutral/chunk-QXF3LGN2.mjs.map +7 -0
  70. package/dist/lib/neutral/chunk-T4MPQJ7X.mjs +97 -0
  71. package/dist/lib/neutral/chunk-T4MPQJ7X.mjs.map +7 -0
  72. package/dist/lib/neutral/chunk-T6JEFNP6.mjs +7 -0
  73. package/dist/lib/neutral/chunk-T6JEFNP6.mjs.map +7 -0
  74. package/dist/lib/neutral/chunk-W7OP5HGZ.mjs +121 -0
  75. package/dist/lib/neutral/chunk-W7OP5HGZ.mjs.map +7 -0
  76. package/dist/lib/neutral/chunk-ZTUBYOGB.mjs +42 -0
  77. package/dist/lib/neutral/chunk-ZTUBYOGB.mjs.map +7 -0
  78. package/dist/lib/neutral/chunk-ZWKJ4LZJ.mjs +298 -0
  79. package/dist/lib/neutral/chunk-ZWKJ4LZJ.mjs.map +7 -0
  80. package/dist/lib/neutral/index.mjs +94 -0
  81. package/dist/lib/neutral/index.mjs.map +7 -0
  82. package/dist/lib/{node-esm → neutral}/internal/index.mjs +260 -122
  83. package/dist/lib/neutral/internal/index.mjs.map +7 -0
  84. package/dist/lib/neutral/meta.json +1 -0
  85. package/dist/lib/neutral/testing/index.mjs +369 -0
  86. package/dist/lib/neutral/testing/index.mjs.map +7 -0
  87. package/dist/types/src/Annotation.d.ts +24 -0
  88. package/dist/types/src/Annotation.d.ts.map +1 -0
  89. package/dist/types/src/Collection.d.ts +16 -0
  90. package/dist/types/src/Collection.d.ts.map +1 -0
  91. package/dist/types/src/Database.d.ts +189 -0
  92. package/dist/types/src/Database.d.ts.map +1 -0
  93. package/dist/types/src/Dataset.d.ts +18 -0
  94. package/dist/types/src/Dataset.d.ts.map +1 -0
  95. package/dist/types/src/Entity.d.ts +168 -0
  96. package/dist/types/src/Entity.d.ts.map +1 -0
  97. package/dist/types/src/Entity.test.d.ts +2 -0
  98. package/dist/types/src/Entity.test.d.ts.map +1 -0
  99. package/dist/types/src/Err.d.ts +107 -0
  100. package/dist/types/src/Err.d.ts.map +1 -0
  101. package/dist/types/src/Feed.d.ts +165 -0
  102. package/dist/types/src/Feed.d.ts.map +1 -0
  103. package/dist/types/src/Filter.d.ts +120 -0
  104. package/dist/types/src/Filter.d.ts.map +1 -0
  105. package/dist/types/src/Format.d.ts +4 -0
  106. package/dist/types/src/Format.d.ts.map +1 -0
  107. package/dist/types/src/Hypergraph.d.ts +60 -0
  108. package/dist/types/src/Hypergraph.d.ts.map +1 -0
  109. package/dist/types/src/JsonSchema.d.ts +16 -0
  110. package/dist/types/src/JsonSchema.d.ts.map +1 -0
  111. package/dist/types/src/Key.d.ts +1 -0
  112. package/dist/types/src/Key.d.ts.map +1 -1
  113. package/dist/types/src/Obj.d.ts +423 -95
  114. package/dist/types/src/Obj.d.ts.map +1 -1
  115. package/dist/types/src/Obj.test.d.ts +2 -0
  116. package/dist/types/src/Obj.test.d.ts.map +1 -0
  117. package/dist/types/src/Order.d.ts +16 -0
  118. package/dist/types/src/Order.d.ts.map +1 -0
  119. package/dist/types/src/Query.d.ts +202 -0
  120. package/dist/types/src/Query.d.ts.map +1 -0
  121. package/dist/types/src/Query.test.d.ts +2 -0
  122. package/dist/types/src/Query.test.d.ts.map +1 -0
  123. package/dist/types/src/QueryResult.d.ts +80 -0
  124. package/dist/types/src/QueryResult.d.ts.map +1 -0
  125. package/dist/types/src/Ref.d.ts +61 -11
  126. package/dist/types/src/Ref.d.ts.map +1 -1
  127. package/dist/types/src/Relation.d.ts +287 -21
  128. package/dist/types/src/Relation.d.ts.map +1 -1
  129. package/dist/types/src/Relation.test.d.ts +2 -0
  130. package/dist/types/src/Relation.test.d.ts.map +1 -0
  131. package/dist/types/src/SchemaRegistry.d.ts +84 -0
  132. package/dist/types/src/SchemaRegistry.d.ts.map +1 -0
  133. package/dist/types/src/Tag.d.ts +18 -0
  134. package/dist/types/src/Tag.d.ts.map +1 -0
  135. package/dist/types/src/Type.d.ts +120 -97
  136. package/dist/types/src/Type.d.ts.map +1 -1
  137. package/dist/types/src/Type.test.d.ts +2 -0
  138. package/dist/types/src/Type.test.d.ts.map +1 -0
  139. package/dist/types/src/View.d.ts +68 -0
  140. package/dist/types/src/View.d.ts.map +1 -0
  141. package/dist/types/src/hierarchy.test.d.ts +2 -0
  142. package/dist/types/src/hierarchy.test.d.ts.map +1 -0
  143. package/dist/types/src/index.d.ts +19 -5
  144. package/dist/types/src/index.d.ts.map +1 -1
  145. package/dist/types/src/internal/annotations/annotations.d.ts +209 -0
  146. package/dist/types/src/internal/annotations/annotations.d.ts.map +1 -0
  147. package/dist/types/src/internal/annotations/annotations.test.d.ts.map +1 -0
  148. package/dist/types/src/internal/annotations/index.d.ts +3 -0
  149. package/dist/types/src/internal/annotations/index.d.ts.map +1 -0
  150. package/dist/types/src/internal/annotations/util.d.ts +39 -0
  151. package/dist/types/src/internal/annotations/util.d.ts.map +1 -0
  152. package/dist/types/src/internal/api/annotations.d.ts +23 -0
  153. package/dist/types/src/internal/api/annotations.d.ts.map +1 -0
  154. package/dist/types/src/internal/api/entity.d.ts +13 -0
  155. package/dist/types/src/internal/api/entity.d.ts.map +1 -0
  156. package/dist/types/src/internal/api/index.d.ts +15 -0
  157. package/dist/types/src/internal/api/index.d.ts.map +1 -0
  158. package/dist/types/src/internal/api/meta.d.ts +42 -0
  159. package/dist/types/src/internal/api/meta.d.ts.map +1 -0
  160. package/dist/types/src/internal/api/sorting.d.ts +24 -0
  161. package/dist/types/src/internal/api/sorting.d.ts.map +1 -0
  162. package/dist/types/src/internal/api/version.d.ts +42 -0
  163. package/dist/types/src/internal/api/version.d.ts.map +1 -0
  164. package/dist/types/src/internal/entities/entity.d.ts +20 -0
  165. package/dist/types/src/internal/entities/entity.d.ts.map +1 -0
  166. package/dist/types/src/internal/entities/index.d.ts +6 -0
  167. package/dist/types/src/internal/entities/index.d.ts.map +1 -0
  168. package/dist/types/src/internal/entities/model.d.ts +79 -0
  169. package/dist/types/src/internal/entities/model.d.ts.map +1 -0
  170. package/dist/types/src/internal/entities/object.d.ts +18 -0
  171. package/dist/types/src/internal/entities/object.d.ts.map +1 -0
  172. package/dist/types/src/internal/entities/relation.d.ts +62 -0
  173. package/dist/types/src/internal/entities/relation.d.ts.map +1 -0
  174. package/dist/types/src/internal/entities/util.d.ts +2 -0
  175. package/dist/types/src/internal/entities/util.d.ts.map +1 -0
  176. package/dist/types/src/internal/formats/format.d.ts +4 -2
  177. package/dist/types/src/internal/formats/format.d.ts.map +1 -1
  178. package/dist/types/src/internal/formats/select.d.ts +6 -4
  179. package/dist/types/src/internal/formats/select.d.ts.map +1 -1
  180. package/dist/types/src/internal/formats/string.d.ts +4 -0
  181. package/dist/types/src/internal/formats/string.d.ts.map +1 -1
  182. package/dist/types/src/internal/formats/types.d.ts +13 -9
  183. package/dist/types/src/internal/formats/types.d.ts.map +1 -1
  184. package/dist/types/src/internal/index.d.ts +7 -10
  185. package/dist/types/src/internal/index.d.ts.map +1 -1
  186. package/dist/types/src/internal/json-schema/annotations.d.ts.map +1 -0
  187. package/dist/types/src/internal/json-schema/effect-schema.test.d.ts.map +1 -0
  188. package/dist/types/src/internal/json-schema/index.d.ts +2 -0
  189. package/dist/types/src/internal/json-schema/index.d.ts.map +1 -1
  190. package/dist/types/src/internal/json-schema/json-schema-normalize.d.ts.map +1 -1
  191. package/dist/types/src/internal/json-schema/json-schema-type.d.ts +130 -29
  192. package/dist/types/src/internal/json-schema/json-schema-type.d.ts.map +1 -1
  193. package/dist/types/src/internal/{json → json-schema}/json-schema.d.ts +4 -6
  194. package/dist/types/src/internal/json-schema/json-schema.d.ts.map +1 -0
  195. package/dist/types/src/internal/json-schema/json-schema.test.d.ts.map +1 -0
  196. package/dist/types/src/internal/object/clone.d.ts +8 -0
  197. package/dist/types/src/internal/object/clone.d.ts.map +1 -0
  198. package/dist/types/src/internal/object/common.d.ts.map +1 -1
  199. package/dist/types/src/internal/object/{create.d.ts → create-object.d.ts} +10 -11
  200. package/dist/types/src/internal/object/create-object.d.ts.map +1 -0
  201. package/dist/types/src/internal/object/create-object.test.d.ts +2 -0
  202. package/dist/types/src/internal/object/create-object.test.d.ts.map +1 -0
  203. package/dist/types/src/internal/object/deleted.d.ts +2 -2
  204. package/dist/types/src/internal/object/deleted.d.ts.map +1 -1
  205. package/dist/types/src/internal/object/ids.d.ts.map +1 -1
  206. package/dist/types/src/internal/object/index.d.ts +6 -12
  207. package/dist/types/src/internal/object/index.d.ts.map +1 -1
  208. package/dist/types/src/internal/object/json-serializer.d.ts +14 -9
  209. package/dist/types/src/internal/object/json-serializer.d.ts.map +1 -1
  210. package/dist/types/src/internal/object/schema-validator.d.ts +1 -14
  211. package/dist/types/src/internal/object/schema-validator.d.ts.map +1 -1
  212. package/dist/types/src/internal/object/set-value.d.ts +7 -0
  213. package/dist/types/src/internal/object/set-value.d.ts.map +1 -0
  214. package/dist/types/src/internal/object/set-value.test.d.ts +2 -0
  215. package/dist/types/src/internal/object/set-value.test.d.ts.map +1 -0
  216. package/dist/types/src/internal/object/snapshot.d.ts +6 -0
  217. package/dist/types/src/internal/object/snapshot.d.ts.map +1 -0
  218. package/dist/types/src/internal/object/typed-object.d.ts +8 -14
  219. package/dist/types/src/internal/object/typed-object.d.ts.map +1 -1
  220. package/dist/types/src/internal/proxy/change-context.d.ts +55 -0
  221. package/dist/types/src/internal/proxy/change-context.d.ts.map +1 -0
  222. package/dist/types/src/internal/proxy/change.test.d.ts +2 -0
  223. package/dist/types/src/internal/proxy/change.test.d.ts.map +1 -0
  224. package/dist/types/src/internal/proxy/define-hidden-property.d.ts +5 -0
  225. package/dist/types/src/internal/proxy/define-hidden-property.d.ts.map +1 -0
  226. package/dist/types/src/internal/proxy/errors.d.ts +19 -0
  227. package/dist/types/src/internal/proxy/errors.d.ts.map +1 -0
  228. package/dist/types/src/internal/proxy/event-batch.d.ts +10 -0
  229. package/dist/types/src/internal/proxy/event-batch.d.ts.map +1 -0
  230. package/dist/types/src/internal/proxy/index.d.ts +14 -0
  231. package/dist/types/src/internal/proxy/index.d.ts.map +1 -0
  232. package/dist/types/src/internal/proxy/json-serializer.d.ts +6 -0
  233. package/dist/types/src/internal/proxy/json-serializer.d.ts.map +1 -0
  234. package/dist/types/src/internal/proxy/make-object.d.ts +14 -0
  235. package/dist/types/src/internal/proxy/make-object.d.ts.map +1 -0
  236. package/dist/types/src/internal/proxy/ownership.d.ts +57 -0
  237. package/dist/types/src/internal/proxy/ownership.d.ts.map +1 -0
  238. package/dist/types/src/internal/proxy/proxy-types.d.ts +18 -0
  239. package/dist/types/src/internal/proxy/proxy-types.d.ts.map +1 -0
  240. package/dist/types/src/internal/proxy/proxy-utils.d.ts +47 -0
  241. package/dist/types/src/internal/proxy/proxy-utils.d.ts.map +1 -0
  242. package/dist/types/src/internal/proxy/reactive-array.d.ts +8 -0
  243. package/dist/types/src/internal/proxy/reactive-array.d.ts.map +1 -0
  244. package/dist/types/src/internal/proxy/reactive.d.ts +39 -0
  245. package/dist/types/src/internal/proxy/reactive.d.ts.map +1 -0
  246. package/dist/types/src/internal/proxy/schema-validator.d.ts +15 -0
  247. package/dist/types/src/internal/proxy/schema-validator.d.ts.map +1 -0
  248. package/dist/types/src/internal/proxy/symbols.d.ts +3 -0
  249. package/dist/types/src/internal/proxy/symbols.d.ts.map +1 -0
  250. package/dist/types/src/internal/proxy/typed-handler.d.ts +16 -12
  251. package/dist/types/src/internal/proxy/typed-handler.d.ts.map +1 -1
  252. package/dist/types/src/internal/ref/ref-array.d.ts +4 -4
  253. package/dist/types/src/internal/ref/ref-array.d.ts.map +1 -1
  254. package/dist/types/src/internal/ref/ref.d.ts +43 -18
  255. package/dist/types/src/internal/ref/ref.d.ts.map +1 -1
  256. package/dist/types/src/internal/schema/compose.d.ts +7 -0
  257. package/dist/types/src/internal/schema/compose.d.ts.map +1 -0
  258. package/dist/types/src/internal/schema/compose.test.d.ts.map +1 -0
  259. package/dist/types/src/internal/schema/echo-schema.d.ts +25 -12
  260. package/dist/types/src/internal/schema/echo-schema.d.ts.map +1 -1
  261. package/dist/types/src/internal/schema/index.d.ts +1 -4
  262. package/dist/types/src/internal/schema/index.d.ts.map +1 -1
  263. package/dist/types/src/internal/schema/manipulation.d.ts.map +1 -1
  264. package/dist/types/src/internal/schema/persistent-schema.d.ts +20 -0
  265. package/dist/types/src/internal/schema/persistent-schema.d.ts.map +1 -0
  266. package/dist/types/src/internal/types/base.d.ts +27 -0
  267. package/dist/types/src/internal/types/base.d.ts.map +1 -0
  268. package/dist/types/src/internal/types/entity.d.ts +37 -0
  269. package/dist/types/src/internal/types/entity.d.ts.map +1 -0
  270. package/dist/types/src/internal/types/index.d.ts +5 -2
  271. package/dist/types/src/internal/types/index.d.ts.map +1 -1
  272. package/dist/types/src/internal/{object → types}/meta.d.ts +16 -14
  273. package/dist/types/src/internal/types/meta.d.ts.map +1 -0
  274. package/dist/types/src/internal/types/typename.d.ts +21 -0
  275. package/dist/types/src/internal/types/typename.d.ts.map +1 -0
  276. package/dist/types/src/internal/types/version.d.ts +15 -0
  277. package/dist/types/src/internal/types/version.d.ts.map +1 -0
  278. package/dist/types/src/{test → testing}/api.test.d.ts.map +1 -1
  279. package/dist/types/src/testing/index.d.ts +3 -3
  280. package/dist/types/src/testing/index.d.ts.map +1 -1
  281. package/dist/types/src/testing/test-data.d.ts +18 -0
  282. package/dist/types/src/testing/test-data.d.ts.map +1 -0
  283. package/dist/types/src/testing/test-schema.d.ts +304 -0
  284. package/dist/types/src/testing/test-schema.d.ts.map +1 -0
  285. package/dist/types/src/testing/util.d.ts +21 -0
  286. package/dist/types/src/testing/util.d.ts.map +1 -0
  287. package/dist/types/tsconfig.tsbuildinfo +1 -1
  288. package/package.json +106 -65
  289. package/src/Annotation.ts +46 -0
  290. package/src/Collection.ts +30 -0
  291. package/src/Database.ts +315 -0
  292. package/src/Dataset.ts +24 -0
  293. package/src/Entity.test.ts +22 -0
  294. package/src/Entity.ts +234 -0
  295. package/src/Err.ts +38 -0
  296. package/src/Feed.ts +254 -0
  297. package/src/Filter.ts +389 -0
  298. package/src/Format.ts +9 -0
  299. package/src/Hypergraph.ts +74 -0
  300. package/src/JsonSchema.ts +24 -0
  301. package/src/Key.ts +3 -0
  302. package/src/Obj.test.ts +447 -0
  303. package/src/Obj.ts +588 -248
  304. package/src/Order.ts +44 -0
  305. package/src/Query.test.ts +632 -0
  306. package/src/Query.ts +520 -0
  307. package/src/QueryResult.ts +106 -0
  308. package/src/Ref.ts +77 -9
  309. package/src/Relation.test.ts +88 -0
  310. package/src/Relation.ts +440 -58
  311. package/src/SchemaRegistry.ts +106 -0
  312. package/src/Tag.ts +39 -0
  313. package/src/Type.test.ts +52 -0
  314. package/src/Type.ts +162 -151
  315. package/src/View.ts +100 -0
  316. package/src/hierarchy.test.ts +33 -0
  317. package/src/index.ts +20 -6
  318. package/src/internal/README.md +102 -0
  319. package/src/internal/{ast → annotations}/annotations.test.ts +18 -20
  320. package/src/internal/annotations/annotations.ts +526 -0
  321. package/src/internal/annotations/index.ts +6 -0
  322. package/src/internal/annotations/util.ts +85 -0
  323. package/src/internal/api/annotations.ts +60 -0
  324. package/src/internal/api/entity.ts +29 -0
  325. package/src/internal/api/index.ts +19 -0
  326. package/src/internal/api/meta.ts +88 -0
  327. package/src/internal/api/sorting.ts +53 -0
  328. package/src/internal/api/version.ts +96 -0
  329. package/src/internal/entities/entity.ts +128 -0
  330. package/src/internal/entities/index.ts +9 -0
  331. package/src/internal/entities/model.ts +138 -0
  332. package/src/internal/entities/object.ts +58 -0
  333. package/src/internal/entities/relation.ts +171 -0
  334. package/src/internal/entities/util.ts +33 -0
  335. package/src/internal/formats/date.test.ts +1 -1
  336. package/src/internal/formats/date.ts +5 -5
  337. package/src/internal/formats/format.test.ts +6 -6
  338. package/src/internal/formats/format.ts +8 -6
  339. package/src/internal/formats/number.ts +5 -5
  340. package/src/internal/formats/object.ts +4 -4
  341. package/src/internal/formats/select.ts +6 -4
  342. package/src/internal/formats/string.ts +14 -9
  343. package/src/internal/formats/types.ts +53 -42
  344. package/src/internal/index.ts +30 -13
  345. package/src/internal/{json → json-schema}/annotations.ts +1 -1
  346. package/src/internal/json-schema/index.ts +2 -0
  347. package/src/internal/json-schema/json-schema-normalize.ts +4 -2
  348. package/src/internal/json-schema/json-schema-type.ts +35 -35
  349. package/src/internal/{json → json-schema}/json-schema.test.ts +232 -97
  350. package/src/internal/{json → json-schema}/json-schema.ts +79 -93
  351. package/src/internal/object/clone.ts +48 -0
  352. package/src/internal/object/common.ts +3 -4
  353. package/src/internal/object/{create.test.ts → create-object.test.ts} +31 -33
  354. package/src/internal/object/{create.ts → create-object.ts} +36 -37
  355. package/src/internal/object/deleted.ts +6 -6
  356. package/src/internal/object/ids.ts +1 -1
  357. package/src/internal/object/index.ts +6 -12
  358. package/src/internal/object/inspect.ts +5 -7
  359. package/src/internal/object/json-serializer.test.ts +59 -37
  360. package/src/internal/object/json-serializer.ts +87 -108
  361. package/src/internal/object/schema-validator.test.ts +3 -7
  362. package/src/internal/object/schema-validator.ts +2 -237
  363. package/src/internal/object/set-value.test.ts +281 -0
  364. package/src/internal/object/set-value.ts +165 -0
  365. package/src/internal/object/snapshot.ts +96 -0
  366. package/src/internal/object/typed-object.test.ts +11 -11
  367. package/src/internal/object/typed-object.ts +8 -59
  368. package/src/internal/proxy/change-context.ts +138 -0
  369. package/src/internal/proxy/change.test.ts +519 -0
  370. package/src/internal/proxy/define-hidden-property.ts +14 -0
  371. package/src/internal/proxy/errors.ts +42 -0
  372. package/src/internal/proxy/event-batch.ts +44 -0
  373. package/src/internal/proxy/handler.test.ts +51 -91
  374. package/src/internal/proxy/index.ts +17 -0
  375. package/src/internal/proxy/json-serializer.ts +87 -0
  376. package/src/internal/proxy/make-object.ts +106 -0
  377. package/src/internal/proxy/ownership.ts +253 -0
  378. package/src/internal/proxy/proxy-types.ts +23 -0
  379. package/src/internal/proxy/proxy-utils.ts +150 -0
  380. package/src/internal/proxy/reactive-array.ts +71 -0
  381. package/src/internal/proxy/reactive.ts +69 -0
  382. package/src/internal/proxy/schema-validator.ts +244 -0
  383. package/src/internal/proxy/schema.test.ts +27 -18
  384. package/src/internal/proxy/symbols.ts +7 -0
  385. package/src/internal/proxy/typed-handler.test.ts +260 -48
  386. package/src/internal/proxy/typed-handler.ts +283 -61
  387. package/src/internal/proxy/typed-object.test.ts +54 -38
  388. package/src/internal/ref/ref-array.ts +4 -4
  389. package/src/internal/ref/ref.test.ts +10 -9
  390. package/src/internal/ref/ref.ts +107 -56
  391. package/src/internal/{projection → schema}/compose.test.ts +8 -9
  392. package/src/internal/{projection → schema}/compose.ts +13 -8
  393. package/src/internal/schema/echo-schema.ts +74 -33
  394. package/src/internal/schema/index.ts +1 -4
  395. package/src/internal/schema/manipulation.ts +7 -1
  396. package/src/internal/schema/persistent-schema.ts +33 -0
  397. package/src/internal/types/base.ts +43 -0
  398. package/src/internal/types/entity.ts +54 -0
  399. package/src/internal/types/index.ts +5 -2
  400. package/src/internal/types/meta.ts +68 -0
  401. package/src/internal/types/typename.ts +55 -0
  402. package/src/internal/types/version.ts +19 -0
  403. package/src/testing/api.test.ts +126 -0
  404. package/src/testing/index.ts +3 -3
  405. package/src/testing/test-data.ts +130 -0
  406. package/src/testing/test-schema.ts +240 -0
  407. package/src/testing/util.ts +85 -0
  408. package/dist/lib/browser/chunk-MWLA34S5.mjs +0 -3843
  409. package/dist/lib/browser/chunk-MWLA34S5.mjs.map +0 -7
  410. package/dist/lib/browser/chunk-OAZJQHVO.mjs +0 -453
  411. package/dist/lib/browser/chunk-OAZJQHVO.mjs.map +0 -7
  412. package/dist/lib/browser/chunk-ORIE2FMS.mjs +0 -514
  413. package/dist/lib/browser/chunk-ORIE2FMS.mjs.map +0 -7
  414. package/dist/lib/browser/index.mjs +0 -43
  415. package/dist/lib/browser/internal/index.mjs +0 -326
  416. package/dist/lib/browser/meta.json +0 -1
  417. package/dist/lib/browser/query/index.mjs +0 -23
  418. package/dist/lib/browser/testing/index.mjs +0 -298
  419. package/dist/lib/browser/testing/index.mjs.map +0 -7
  420. package/dist/lib/node-esm/chunk-AXWVDOP7.mjs +0 -453
  421. package/dist/lib/node-esm/chunk-AXWVDOP7.mjs.map +0 -7
  422. package/dist/lib/node-esm/chunk-L4PBAJDP.mjs +0 -514
  423. package/dist/lib/node-esm/chunk-L4PBAJDP.mjs.map +0 -7
  424. package/dist/lib/node-esm/chunk-YTNLFBIK.mjs +0 -3843
  425. package/dist/lib/node-esm/chunk-YTNLFBIK.mjs.map +0 -7
  426. package/dist/lib/node-esm/index.mjs +0 -43
  427. package/dist/lib/node-esm/meta.json +0 -1
  428. package/dist/lib/node-esm/query/index.mjs +0 -23
  429. package/dist/lib/node-esm/testing/index.mjs +0 -298
  430. package/dist/lib/node-esm/testing/index.mjs.map +0 -7
  431. package/dist/types/src/errors.d.ts +0 -72
  432. package/dist/types/src/errors.d.ts.map +0 -1
  433. package/dist/types/src/internal/ast/annotation-helper.d.ts +0 -8
  434. package/dist/types/src/internal/ast/annotation-helper.d.ts.map +0 -1
  435. package/dist/types/src/internal/ast/annotations.d.ts +0 -119
  436. package/dist/types/src/internal/ast/annotations.d.ts.map +0 -1
  437. package/dist/types/src/internal/ast/annotations.test.d.ts.map +0 -1
  438. package/dist/types/src/internal/ast/entity-kind.d.ts +0 -10
  439. package/dist/types/src/internal/ast/entity-kind.d.ts.map +0 -1
  440. package/dist/types/src/internal/ast/index.d.ts +0 -5
  441. package/dist/types/src/internal/ast/index.d.ts.map +0 -1
  442. package/dist/types/src/internal/ast/types.d.ts +0 -6
  443. package/dist/types/src/internal/ast/types.d.ts.map +0 -1
  444. package/dist/types/src/internal/json/annotations.d.ts.map +0 -1
  445. package/dist/types/src/internal/json/effect-schema.test.d.ts.map +0 -1
  446. package/dist/types/src/internal/json/index.d.ts +0 -2
  447. package/dist/types/src/internal/json/index.d.ts.map +0 -1
  448. package/dist/types/src/internal/json/json-schema.d.ts.map +0 -1
  449. package/dist/types/src/internal/json/json-schema.test.d.ts.map +0 -1
  450. package/dist/types/src/internal/object/accessors.d.ts +0 -29
  451. package/dist/types/src/internal/object/accessors.d.ts.map +0 -1
  452. package/dist/types/src/internal/object/create.d.ts.map +0 -1
  453. package/dist/types/src/internal/object/create.test.d.ts +0 -2
  454. package/dist/types/src/internal/object/create.test.d.ts.map +0 -1
  455. package/dist/types/src/internal/object/entity.d.ts +0 -22
  456. package/dist/types/src/internal/object/entity.d.ts.map +0 -1
  457. package/dist/types/src/internal/object/expando.d.ts +0 -14
  458. package/dist/types/src/internal/object/expando.d.ts.map +0 -1
  459. package/dist/types/src/internal/object/meta.d.ts.map +0 -1
  460. package/dist/types/src/internal/object/model.d.ts +0 -117
  461. package/dist/types/src/internal/object/model.d.ts.map +0 -1
  462. package/dist/types/src/internal/object/relation.d.ts +0 -17
  463. package/dist/types/src/internal/object/relation.d.ts.map +0 -1
  464. package/dist/types/src/internal/object/typed-relation.d.ts +0 -32
  465. package/dist/types/src/internal/object/typed-relation.d.ts.map +0 -1
  466. package/dist/types/src/internal/object/typename.d.ts +0 -15
  467. package/dist/types/src/internal/object/typename.d.ts.map +0 -1
  468. package/dist/types/src/internal/object/version.d.ts +0 -14
  469. package/dist/types/src/internal/object/version.d.ts.map +0 -1
  470. package/dist/types/src/internal/projection/compose.d.ts +0 -6
  471. package/dist/types/src/internal/projection/compose.d.ts.map +0 -1
  472. package/dist/types/src/internal/projection/compose.test.d.ts.map +0 -1
  473. package/dist/types/src/internal/projection/index.d.ts +0 -2
  474. package/dist/types/src/internal/projection/index.d.ts.map +0 -1
  475. package/dist/types/src/internal/proxy/reactive-object.d.ts +0 -15
  476. package/dist/types/src/internal/proxy/reactive-object.d.ts.map +0 -1
  477. package/dist/types/src/internal/query/index.d.ts +0 -2
  478. package/dist/types/src/internal/query/index.d.ts.map +0 -1
  479. package/dist/types/src/internal/query/query.d.ts +0 -17
  480. package/dist/types/src/internal/query/query.d.ts.map +0 -1
  481. package/dist/types/src/internal/schema/runtime-schema-registry.d.ts +0 -18
  482. package/dist/types/src/internal/schema/runtime-schema-registry.d.ts.map +0 -1
  483. package/dist/types/src/internal/schema/snapshot.d.ts +0 -6
  484. package/dist/types/src/internal/schema/snapshot.d.ts.map +0 -1
  485. package/dist/types/src/internal/schema/stored-schema.d.ts +0 -13
  486. package/dist/types/src/internal/schema/stored-schema.d.ts.map +0 -1
  487. package/dist/types/src/internal/testing/index.d.ts +0 -3
  488. package/dist/types/src/internal/testing/index.d.ts.map +0 -1
  489. package/dist/types/src/internal/testing/types.d.ts +0 -455
  490. package/dist/types/src/internal/testing/types.d.ts.map +0 -1
  491. package/dist/types/src/internal/testing/utils.d.ts +0 -10
  492. package/dist/types/src/internal/testing/utils.d.ts.map +0 -1
  493. package/dist/types/src/internal/types/types.d.ts +0 -79
  494. package/dist/types/src/internal/types/types.d.ts.map +0 -1
  495. package/dist/types/src/internal/types/types.test.d.ts +0 -2
  496. package/dist/types/src/internal/types/types.test.d.ts.map +0 -1
  497. package/dist/types/src/internal/types/util.d.ts +0 -5
  498. package/dist/types/src/internal/types/util.d.ts.map +0 -1
  499. package/dist/types/src/query/index.d.ts +0 -3
  500. package/dist/types/src/query/index.d.ts.map +0 -1
  501. package/dist/types/src/query/query.d.ts +0 -247
  502. package/dist/types/src/query/query.d.ts.map +0 -1
  503. package/dist/types/src/query/query.test.d.ts +0 -2
  504. package/dist/types/src/query/query.test.d.ts.map +0 -1
  505. package/dist/types/src/query/tag.d.ts +0 -18
  506. package/dist/types/src/query/tag.d.ts.map +0 -1
  507. package/dist/types/src/testing/echo-schema.d.ts +0 -7
  508. package/dist/types/src/testing/echo-schema.d.ts.map +0 -1
  509. package/dist/types/src/testing/types.d.ts +0 -113
  510. package/dist/types/src/testing/types.d.ts.map +0 -1
  511. package/src/errors.ts +0 -18
  512. package/src/internal/ast/annotation-helper.ts +0 -22
  513. package/src/internal/ast/annotations.ts +0 -212
  514. package/src/internal/ast/entity-kind.ts +0 -15
  515. package/src/internal/ast/index.ts +0 -8
  516. package/src/internal/ast/types.ts +0 -17
  517. package/src/internal/json/index.ts +0 -5
  518. package/src/internal/object/accessors.ts +0 -115
  519. package/src/internal/object/entity.ts +0 -204
  520. package/src/internal/object/expando.ts +0 -21
  521. package/src/internal/object/meta.ts +0 -62
  522. package/src/internal/object/model.ts +0 -170
  523. package/src/internal/object/relation.ts +0 -24
  524. package/src/internal/object/typed-relation.ts +0 -85
  525. package/src/internal/object/typename.ts +0 -61
  526. package/src/internal/object/version.ts +0 -22
  527. package/src/internal/projection/index.ts +0 -5
  528. package/src/internal/proxy/reactive-object.ts +0 -108
  529. package/src/internal/query/index.ts +0 -5
  530. package/src/internal/query/query.ts +0 -23
  531. package/src/internal/schema/runtime-schema-registry.ts +0 -78
  532. package/src/internal/schema/snapshot.ts +0 -25
  533. package/src/internal/schema/stored-schema.ts +0 -26
  534. package/src/internal/testing/index.ts +0 -6
  535. package/src/internal/testing/types.ts +0 -211
  536. package/src/internal/testing/utils.ts +0 -54
  537. package/src/internal/types/types.test.ts +0 -48
  538. package/src/internal/types/types.ts +0 -176
  539. package/src/internal/types/util.ts +0 -9
  540. package/src/query/index.ts +0 -6
  541. package/src/query/query.test.ts +0 -362
  542. package/src/query/query.ts +0 -784
  543. package/src/query/tag.ts +0 -35
  544. package/src/test/api.test.ts +0 -180
  545. package/src/testing/echo-schema.ts +0 -39
  546. package/src/testing/types.ts +0 -91
  547. /package/dist/lib/{browser/index.mjs.map → neutral/Annotation.mjs.map} +0 -0
  548. /package/dist/lib/{browser/internal/index.mjs.map → neutral/Database.mjs.map} +0 -0
  549. /package/dist/lib/{browser/query/index.mjs.map → neutral/Entity.mjs.map} +0 -0
  550. /package/dist/lib/{node-esm/index.mjs.map → neutral/Err.mjs.map} +0 -0
  551. /package/dist/lib/{node-esm/internal/index.mjs.map → neutral/Feed.mjs.map} +0 -0
  552. /package/dist/lib/{node-esm/query/index.mjs.map → neutral/Filter.mjs.map} +0 -0
  553. /package/dist/types/src/internal/{ast → annotations}/annotations.test.d.ts +0 -0
  554. /package/dist/types/src/internal/{json → json-schema}/annotations.d.ts +0 -0
  555. /package/dist/types/src/internal/{json → json-schema}/effect-schema.test.d.ts +0 -0
  556. /package/dist/types/src/internal/{json → json-schema}/json-schema.test.d.ts +0 -0
  557. /package/dist/types/src/internal/{projection → schema}/compose.test.d.ts +0 -0
  558. /package/dist/types/src/{test → testing}/api.test.d.ts +0 -0
  559. /package/src/internal/{json → json-schema}/effect-schema.test.ts +0 -0
package/src/Relation.ts CHANGED
@@ -5,144 +5,526 @@
5
5
  import * as Schema from 'effect/Schema';
6
6
 
7
7
  import { raise } from '@dxos/debug';
8
+ import type { ForeignKey } from '@dxos/echo-protocol';
9
+ import { createJsonPath } from '@dxos/effect';
8
10
  import { assertArgument, invariant } from '@dxos/invariant';
9
- import { DXN } from '@dxos/keys';
10
- import { type Live } from '@dxos/live-object';
11
+ import { DXN, type ObjectId } from '@dxos/keys';
11
12
  import { assumeType } from '@dxos/util';
12
13
 
13
- import { live } from './internal';
14
- import * as EchoSchema from './internal';
14
+ import type * as Database from './Database';
15
+ import * as Entity from './Entity';
16
+ import * as internal from './internal';
15
17
  import * as Obj from './Obj';
16
- import * as Type from './Type';
18
+ import type * as Type from './Type';
19
+
20
+ export type Endpoints<Source, Target> = {
21
+ [Source]: Source;
22
+ [Target]: Target;
23
+ };
17
24
 
18
25
  /**
19
- * NOTE: Don't export: Relation.Relation and Relation.Any form the public API.
26
+ * Base type for all ECHO relations.
27
+ * @private
20
28
  */
21
29
  interface BaseRelation<Source, Target>
22
- extends EchoSchema.HasId,
23
- Type.Relation.Endpoints<Source, Target>,
24
- Type.OfKind<EchoSchema.EntityKind.Relation> {}
30
+ extends internal.AnyEntity, Endpoints<Source, Target>, Entity.OfKind<internal.EntityKind.Relation> {}
25
31
 
26
32
  /**
27
- * Relation type with specific properties.
33
+ * Relation with no known properties beyond id, kind, source, and target.
34
+ * Use this when the relation's schema/properties are not known.
35
+ *
36
+ * NOTE: This is a TypeScript type only, not a schema.
37
+ * To validate that a value is an ECHO relation, use `Relation.isRelation`.
28
38
  */
29
- export type Relation<Source extends Obj.Any, Target extends Obj.Any, Props> = BaseRelation<Source, Target> & Props;
39
+ export interface Unknown extends BaseRelation<Obj.Unknown, Obj.Unknown> {}
30
40
 
31
41
  /**
32
- * Base type for all ECHO relations.
42
+ * Runtime Effect schema for any ECHO relation.
43
+ * Use for validation, parsing, or as a reference target for collections.
44
+ * A relation has `id`, source, and target fields plus any additional properties.
45
+ *
46
+ * NOTE: `Schema.is(Type.Relation)` does STRUCTURAL validation only (checks for `id` field).
47
+ * Use `Relation.isRelation()` for proper ECHO instance type guards that check the KindId brand.
48
+ *
49
+ * @example
50
+ * ```ts
51
+ * // Structural type guard (accepts any object with id field)
52
+ * if (Schema.is(Type.Relation)(unknownValue)) { ... }
53
+ *
54
+ * // ECHO instance type guard (checks KindId brand)
55
+ * if (Relation.isRelation(unknownValue)) { ... }
56
+ * ```
33
57
  */
34
- export interface Any extends BaseRelation<Obj.Any, Obj.Any> {}
35
-
36
- export const Any = Schema.Struct({}).pipe(
37
- Type.Relation({
38
- typename: 'dxos.org/types/Any',
39
- version: '0.1.0',
40
- source: Obj.Any,
41
- target: Obj.Any,
58
+ // TODO(dmaretskyi): Change ObjModule.Any to ObjModule.Unknown to have stricter types.
59
+ export const Unknown: Type.Relation<Unknown, Obj.Any, Obj.Any> = Schema.Struct({
60
+ id: Schema.String,
61
+ }).pipe(
62
+ Schema.extend(Schema.Record({ key: Schema.String, value: Schema.Unknown })),
63
+ // TODO(dmaretskyi): Clean this up.
64
+ // NOTE: The EchoRelationSchema annotation is required for Ref.Ref(Relation.Unknown) to work.
65
+ // The typename/version/source/target only satisfy ECHO schema machinery for reference targets.
66
+ internal.EchoRelationSchema({
67
+ typename: 'dxos.org/schema/AnyRelation',
68
+ version: '0.0.0',
69
+ source: Obj.Unknown,
70
+ target: Obj.Unknown,
42
71
  }),
72
+ (schema) =>
73
+ Object.assign(schema, {
74
+ [internal.SchemaKindId]: (schema as any)[internal.SchemaKindId],
75
+ }) as unknown as Type.Relation<Unknown, Obj.Any, Obj.Any>,
43
76
  );
44
77
 
45
- // TODO(dmaretskyi): Has to be `unique symbol`.
46
- export const Source: unique symbol = EchoSchema.RelationSourceId as any;
78
+ /**
79
+ * Relation type with specific source and target types.
80
+ */
81
+ export type OfShape<Source extends Obj.Unknown, Target extends Obj.Unknown, Props> = BaseRelation<Source, Target> &
82
+ Props;
83
+
84
+ /**
85
+ * Base type for snapshot relations (has SnapshotKindId instead of KindId).
86
+ */
87
+ interface BaseRelationSnapshot<Source, Target> extends internal.AnyEntity, Endpoints<Source, Target> {
88
+ readonly [Entity.SnapshotKindId]: internal.EntityKind.Relation;
89
+ readonly id: ObjectId;
90
+ }
91
+
92
+ /**
93
+ * JSON-encoded properties for relations.
94
+ */
95
+ export interface BaseRelationJson {
96
+ id: string;
97
+ [internal.ATTR_RELATION_SOURCE]: string;
98
+ [internal.ATTR_RELATION_TARGET]: string;
99
+ }
100
+
101
+ /**
102
+ * Immutable snapshot of an ECHO relation.
103
+ * Branded with SnapshotKindId (not KindId).
104
+ * Property values are frozen at the time the snapshot was created.
105
+ * Returned by getSnapshot() and hooks.
106
+ */
107
+ export type Snapshot<T extends Unknown = Unknown> = Omit<T, Entity.KindId> &
108
+ BaseRelationSnapshot<Obj.Unknown, Obj.Unknown>;
109
+
110
+ export const Source: unique symbol = internal.RelationSourceId as any;
47
111
  export type Source = typeof Source;
48
- export const Target: unique symbol = EchoSchema.RelationTargetId as any;
112
+
113
+ export const Target: unique symbol = internal.RelationTargetId as any;
49
114
  export type Target = typeof Target;
50
115
 
51
- type MakeProps<T extends Any> = {
52
- id?: EchoSchema.ObjectId;
116
+ /**
117
+ * Get relation source type.
118
+ */
119
+ export type SourceOf<A> = A extends Endpoints<infer S, infer _T> ? S : never;
120
+
121
+ /**
122
+ * Get relation target type.
123
+ */
124
+ export type TargetOf<A> = A extends Endpoints<infer _S, infer T> ? T : never;
125
+
126
+ /**
127
+ * Internal props type for relation instance creation.
128
+ */
129
+ type MakePropsInternal<T extends Unknown> = {
130
+ id?: ObjectId;
131
+ [Meta]?: internal.ObjectMeta;
53
132
  [Source]: T[Source];
54
133
  [Target]: T[Target];
55
- } & Type.Properties<T>;
134
+ } & Entity.Properties<T>;
135
+
136
+ /**
137
+ * Props type for relation creation with a given schema.
138
+ * Takes a schema type (created with Type.Relation) and extracts the props type.
139
+ */
140
+ export type MakeProps<S extends Type.AnyRelation> = MakePropsInternal<Schema.Schema.Type<S>>;
56
141
 
57
142
  /**
58
143
  * Creates new relation.
59
144
  * @param schema - Relation schema.
60
145
  * @param props - Relation properties. Endpoints are passed as [Relation.Source] and [Relation.Target] keys.
61
- * @param meta - Relation metadata.
146
+ * @param meta - Relation metadata. (deprecated; use [Obj.Meta] instead)
62
147
  * @returns
63
148
  */
64
149
  // NOTE: Writing the definition this way (with generic over schema) makes typescript perfer to infer the type from the first param (this schema) rather than the second param (the props).
65
150
  // TODO(dmaretskyi): Move meta into props.
66
- export const make = <S extends Type.Relation.Any>(
151
+ export const make = <S extends Type.AnyRelation>(
67
152
  schema: S,
68
- props: NoInfer<MakeProps<Schema.Schema.Type<S>>>,
69
- meta?: EchoSchema.ObjectMeta,
70
- ): Live<Schema.Schema.Type<S> & Type.OfKind<EchoSchema.EntityKind.Relation>> => {
153
+ props: NoInfer<MakeProps<S>>,
154
+ ): Schema.Schema.Type<S> & Entity.OfKind<typeof Entity.Kind.Relation> => {
71
155
  assertArgument(
72
- EchoSchema.getTypeAnnotation(schema)?.kind === EchoSchema.EntityKind.Relation,
156
+ internal.getTypeAnnotation(schema)?.kind === internal.EntityKind.Relation,
73
157
  'schema',
74
158
  'Expected a relation schema',
75
159
  );
160
+ assertArgument(props[internal.ParentId] === undefined, 'props', 'Parent is not allowed for relations');
76
161
 
77
- if (props[EchoSchema.MetaId] != null) {
78
- meta = props[EchoSchema.MetaId] as any;
79
- delete props[EchoSchema.MetaId];
162
+ let meta: internal.ObjectMeta | undefined = undefined;
163
+
164
+ if (props[internal.MetaId] != null) {
165
+ meta = props[internal.MetaId] as any;
166
+ delete props[internal.MetaId];
80
167
  }
81
168
 
82
- const sourceDXN = EchoSchema.getObjectDXN(props[Source]) ?? raise(new Error('Unresolved relation source'));
83
- const targetDXN = EchoSchema.getObjectDXN(props[Target]) ?? raise(new Error('Unresolved relation target'));
84
- (props as any)[EchoSchema.RelationSourceDXNId] = sourceDXN;
85
- (props as any)[EchoSchema.RelationTargetDXNId] = targetDXN;
169
+ const sourceDXN = internal.getObjectDXN(props[Source]) ?? raise(new Error('Unresolved relation source'));
170
+ const targetDXN = internal.getObjectDXN(props[Target]) ?? raise(new Error('Unresolved relation target'));
171
+
172
+ (props as any)[internal.RelationSourceDXNId] = sourceDXN;
173
+ (props as any)[internal.RelationTargetDXNId] = targetDXN;
86
174
 
87
- return live<Schema.Schema.Type<S>>(schema, props as any, meta);
175
+ return internal.makeObject<Schema.Schema.Type<S>>(schema, props as any, meta);
88
176
  };
89
177
 
90
- export const isRelation = (value: unknown): value is Any => {
178
+ /**
179
+ * Type guard for relations.
180
+ * Returns true for both reactive relations and relation snapshots.
181
+ */
182
+ export const isRelation = (value: unknown): value is Unknown => {
91
183
  if (typeof value !== 'object' || value === null) {
92
184
  return false;
93
185
  }
94
- if (EchoSchema.ATTR_RELATION_SOURCE in value || EchoSchema.ATTR_RELATION_TARGET in value) {
186
+ if (internal.ATTR_RELATION_SOURCE in value || internal.ATTR_RELATION_TARGET in value) {
95
187
  return true;
96
188
  }
97
189
 
98
- const kind = (value as any)[EchoSchema.EntityKindId];
99
- return kind === EchoSchema.EntityKind.Relation;
190
+ // Check for reactive relation (KindId) or snapshot (SnapshotKindId).
191
+ const kind = (value as any)[Entity.KindId] ?? (value as any)[Entity.SnapshotKindId];
192
+ return kind === internal.EntityKind.Relation;
193
+ };
194
+
195
+ export const isSnapshot = (value: unknown): value is Snapshot => {
196
+ if (typeof value !== 'object' || value === null) {
197
+ return false;
198
+ }
199
+ return (value as any)[Entity.SnapshotKindId] === internal.EntityKind.Relation;
100
200
  };
101
201
 
102
202
  /**
103
203
  * @returns Relation source DXN.
204
+ * Accepts both reactive relations and snapshots.
104
205
  * @throws If the object is not a relation.
105
206
  */
106
- export const getSourceDXN = (value: Any): DXN => {
207
+ export const getSourceDXN = (value: Unknown | Snapshot): DXN => {
107
208
  assertArgument(isRelation(value), 'Expected a relation');
108
- assumeType<EchoSchema.InternalObjectProps>(value);
109
- const dxn = (value as EchoSchema.InternalObjectProps)[EchoSchema.RelationSourceDXNId];
209
+ assumeType<internal.InternalObjectProps>(value);
210
+ const dxn = (value as internal.InternalObjectProps)[internal.RelationSourceDXNId];
110
211
  invariant(dxn instanceof DXN);
111
212
  return dxn;
112
213
  };
113
214
 
114
215
  /**
115
216
  * @returns Relation target DXN.
217
+ * Accepts both reactive relations and snapshots.
116
218
  * @throws If the object is not a relation.
117
219
  */
118
- export const getTargetDXN = (value: Any): DXN => {
220
+ export const getTargetDXN = (value: Unknown | Snapshot): DXN => {
119
221
  assertArgument(isRelation(value), 'Expected a relation');
120
- assumeType<EchoSchema.InternalObjectProps>(value);
121
- const dxn = (value as EchoSchema.InternalObjectProps)[EchoSchema.RelationTargetDXNId];
222
+ assumeType<internal.InternalObjectProps>(value);
223
+ const dxn = (value as internal.InternalObjectProps)[internal.RelationTargetDXNId];
122
224
  invariant(dxn instanceof DXN);
123
225
  return dxn;
124
226
  };
125
227
 
126
228
  /**
127
229
  * @returns Relation source.
230
+ * Accepts both reactive relations and snapshots.
128
231
  * @throws If the object is not a relation.
129
232
  */
130
- export const getSource = <T extends Any>(relation: T): Type.Relation.Source<T> => {
233
+ export const getSource = <T extends Unknown | Snapshot>(relation: T): SourceOf<T> => {
131
234
  assertArgument(isRelation(relation), 'Expected a relation');
132
- assumeType<EchoSchema.InternalObjectProps>(relation);
133
- const obj = (relation as EchoSchema.InternalObjectProps)[EchoSchema.RelationSourceId];
235
+ assumeType<internal.InternalObjectProps>(relation);
236
+ const obj = (relation as internal.InternalObjectProps)[internal.RelationSourceId];
134
237
  invariant(obj !== undefined, `Invalid source: ${relation.id}`);
135
- return obj as Type.Relation.Source<T>;
238
+ return obj as SourceOf<T>;
136
239
  };
137
240
 
138
241
  /**
139
242
  * @returns Relation target.
243
+ * Accepts both reactive relations and snapshots.
140
244
  * @throws If the object is not a relation.
141
245
  */
142
- export const getTarget = <T extends Any>(relation: T): Type.Relation.Target<T> => {
246
+ export const getTarget = <T extends Unknown | Snapshot>(relation: T): TargetOf<T> => {
143
247
  assertArgument(isRelation(relation), 'Expected a relation');
144
- assumeType<EchoSchema.InternalObjectProps>(relation);
145
- const obj = (relation as EchoSchema.InternalObjectProps)[EchoSchema.RelationTargetId];
248
+ assumeType<internal.InternalObjectProps>(relation);
249
+ const obj = (relation as internal.InternalObjectProps)[internal.RelationTargetId];
146
250
  invariant(obj !== undefined, `Invalid target: ${relation.id}`);
147
- return obj as Type.Relation.Target<T>;
251
+ return obj as TargetOf<T>;
252
+ };
253
+
254
+ //
255
+ // Change
256
+ //
257
+
258
+ /**
259
+ * Makes all properties mutable recursively.
260
+ * Used to provide a mutable view of a relation within `Relation.change`.
261
+ */
262
+ export type Mutable<T> = internal.Mutable<T>;
263
+
264
+ /**
265
+ * Perform mutations on an echo relation within a controlled context.
266
+ *
267
+ * All mutations within the callback are batched and trigger a single notification
268
+ * when the callback completes. Direct mutations outside of `Relation.change` will throw
269
+ * an error for echo relations.
270
+ *
271
+ * @param relation - The echo relation to mutate. Use `Obj.change` for objects.
272
+ * @param callback - The callback that performs mutations on the relation.
273
+ *
274
+ * @example
275
+ * ```ts
276
+ * const worksFor = Relation.make(EmployedBy, {
277
+ * [Relation.Source]: person,
278
+ * [Relation.Target]: company,
279
+ * role: 'Engineer',
280
+ * });
281
+ *
282
+ * // Mutate within Relation.change
283
+ * Relation.change(worksFor, (r) => {
284
+ * r.role = 'Senior Engineer';
285
+ * });
286
+ * ```
287
+ *
288
+ * Note: Only accepts relations. Use `Obj.change` for objects.
289
+ */
290
+ export const change = <T extends Unknown>(relation: T, callback: internal.ChangeCallback<T>): void => {
291
+ internal.change(relation, callback);
148
292
  };
293
+
294
+ //
295
+ // Snapshot
296
+ //
297
+
298
+ /**
299
+ * Returns an immutable snapshot of a relation.
300
+ * The snapshot is branded with SnapshotKindId instead of KindId,
301
+ * making it distinguishable from the reactive relation at the type level.
302
+ */
303
+ export const getSnapshot: <T extends Unknown>(rel: T) => Snapshot<T> = internal.getSnapshot as any;
304
+
305
+ //
306
+ // Subscribe
307
+ //
308
+
309
+ /**
310
+ * Subscribe to relation updates.
311
+ * The callback is called synchronously when the relation is modified.
312
+ * Only accepts reactive relations (not snapshots).
313
+ * @returns Unsubscribe function.
314
+ */
315
+ export const subscribe = (rel: Unknown, callback: () => void): (() => void) => {
316
+ return internal.subscribe(rel, callback);
317
+ };
318
+
319
+ //
320
+ // Property Access
321
+ //
322
+
323
+ /**
324
+ * Get a deeply nested property from a relation.
325
+ * Accepts both reactive relations and snapshots.
326
+ */
327
+ export const getValue = (rel: Unknown | Snapshot, path: readonly (string | number)[]): any => {
328
+ return internal.getValue(rel, createJsonPath(path));
329
+ };
330
+
331
+ /**
332
+ * Set a deeply nested property on a relation.
333
+ * Must be called within a `Relation.change` callback.
334
+ *
335
+ * NOTE: TypeScript's structural typing allows readonly objects to be passed to `Mutable<T>`
336
+ * parameters, so there is no compile-time error. Enforcement is runtime-only.
337
+ */
338
+ export const setValue: (rel: Mutable<Unknown>, path: readonly (string | number)[], value: any) => void =
339
+ internal.setValue as any;
340
+
341
+ //
342
+ // Type
343
+ //
344
+
345
+ /**
346
+ * Get the DXN of the relation.
347
+ * Accepts both reactive relations and snapshots.
348
+ */
349
+ export const getDXN = (entity: Unknown | Snapshot): DXN => internal.getDXN(entity);
350
+
351
+ /**
352
+ * @returns The DXN of the relation's type.
353
+ */
354
+ export const getTypeDXN = internal.getTypeDXN;
355
+
356
+ /**
357
+ * Get the schema of the relation.
358
+ * Returns the branded ECHO schema used to create the relation.
359
+ */
360
+ export const getSchema: (rel: unknown | undefined) => Type.AnyEntity | undefined = internal.getSchema as any;
361
+
362
+ /**
363
+ * @returns The typename of the relation's type.
364
+ * Accepts both reactive relations and snapshots.
365
+ */
366
+ export const getTypename = (entity: Unknown | Snapshot): string | undefined => internal.getTypename(entity);
367
+
368
+ //
369
+ // Database
370
+ //
371
+
372
+ /**
373
+ * Get the database the relation belongs to.
374
+ * Accepts both reactive relations and snapshots.
375
+ */
376
+ export const getDatabase = (entity: Unknown | Snapshot): Database.Database | undefined => internal.getDatabase(entity);
377
+
378
+ //
379
+ // Meta
380
+ //
381
+
382
+ /**
383
+ * Property that accesses metadata for an entity.
384
+ *
385
+ * Alias for `Entity.Meta`.
386
+ */
387
+ export const Meta = internal.MetaId;
388
+
389
+ /**
390
+ * Deeply read-only version of ObjectMeta.
391
+ */
392
+ export type ReadonlyMeta = internal.ReadonlyMeta;
393
+
394
+ /**
395
+ * Mutable meta type returned by `Relation.getMeta` inside a `Relation.change` callback.
396
+ */
397
+ export type Meta = internal.Meta;
398
+
399
+ /**
400
+ * Get the metadata for a relation.
401
+ * Returns mutable meta when passed a mutable relation (inside `Relation.change` callback).
402
+ * Returns read-only meta when passed a regular relation or snapshot.
403
+ */
404
+ // TODO(wittjosiah): When passed a Snapshot, should return a snapshot of meta, not the live meta proxy.
405
+ export function getMeta(entity: Mutable<Unknown>): Meta;
406
+ export function getMeta(entity: Unknown | Snapshot): ReadonlyMeta;
407
+ export function getMeta(entity: Unknown | Snapshot | Mutable<Unknown>): Meta | ReadonlyMeta {
408
+ return internal.getMetaChecked(entity);
409
+ }
410
+
411
+ /**
412
+ * @returns Foreign keys for the relation from the specified source.
413
+ * Accepts both reactive relations and snapshots.
414
+ */
415
+ export const getKeys = (entity: Unknown | Snapshot, source: string): ForeignKey[] => internal.getKeys(entity, source);
416
+
417
+ /**
418
+ * Delete all keys from the relation for the specified source.
419
+ * Must be called within a `Relation.change` callback.
420
+ *
421
+ * NOTE: TypeScript's structural typing allows readonly objects to be passed to `Mutable<T>`
422
+ * parameters, so there is no compile-time error. Enforcement is runtime-only.
423
+ */
424
+ export const deleteKeys = (entity: Mutable<Unknown>, source: string): void => internal.deleteKeys(entity, source);
425
+
426
+ /**
427
+ * Add a tag to the relation.
428
+ * Must be called within a `Relation.change` callback.
429
+ *
430
+ * NOTE: TypeScript's structural typing allows readonly objects to be passed to `Mutable<T>`
431
+ * parameters, so there is no compile-time error. Enforcement is runtime-only.
432
+ */
433
+ export const addTag = (entity: Mutable<Unknown>, tag: string): void => internal.addTag(entity, tag);
434
+
435
+ /**
436
+ * Remove a tag from the relation.
437
+ * Must be called within a `Relation.change` callback.
438
+ *
439
+ * NOTE: TypeScript's structural typing allows readonly objects to be passed to `Mutable<T>`
440
+ * parameters, so there is no compile-time error. Enforcement is runtime-only.
441
+ */
442
+ export const removeTag = (entity: Mutable<Unknown>, tag: string): void => internal.removeTag(entity, tag);
443
+
444
+ /**
445
+ * Check if the relation is deleted.
446
+ * Accepts both reactive relations and snapshots.
447
+ */
448
+ export const isDeleted = (entity: Unknown | Snapshot): boolean => internal.isDeleted(entity);
449
+
450
+ //
451
+ // Annotations
452
+ //
453
+
454
+ /**
455
+ * Get the label of the relation.
456
+ * Accepts both reactive relations and snapshots.
457
+ */
458
+ export const getLabel = (entity: Unknown | Snapshot): string | undefined => internal.getLabel(entity);
459
+
460
+ /**
461
+ * Set the label of the relation.
462
+ * Must be called within a `Relation.change` callback.
463
+ *
464
+ * NOTE: TypeScript's structural typing allows readonly objects to be passed to `Mutable<T>`
465
+ * parameters, so there is no compile-time error. Enforcement is runtime-only.
466
+ */
467
+ export const setLabel = (entity: Mutable<Unknown>, label: string): void => internal.setLabel(entity, label);
468
+
469
+ /**
470
+ * Get the description of the relation.
471
+ * Accepts both reactive relations and snapshots.
472
+ */
473
+ export const getDescription = (entity: Unknown | Snapshot): string | undefined => internal.getDescription(entity);
474
+
475
+ /**
476
+ * Set the description of the relation.
477
+ * Must be called within a `Relation.change` callback.
478
+ *
479
+ * NOTE: TypeScript's structural typing allows readonly objects to be passed to `Mutable<T>`
480
+ * parameters, so there is no compile-time error. Enforcement is runtime-only.
481
+ */
482
+ export const setDescription = (entity: Mutable<Unknown>, description: string): void =>
483
+ internal.setDescription(entity, description);
484
+
485
+ //
486
+ // JSON
487
+ //
488
+
489
+ /**
490
+ * JSON representation of a relation.
491
+ */
492
+ export type JSON = internal.ObjectJSON;
493
+
494
+ /**
495
+ * Converts relation to its JSON representation.
496
+ * Accepts both reactive relations and snapshots.
497
+ */
498
+ export const toJSON = (entity: Unknown | Snapshot): JSON => internal.objectToJSON(entity);
499
+
500
+ //
501
+ // Sorting
502
+ //
503
+
504
+ /**
505
+ * Comparator function type for sorting relations.
506
+ * Accepts both reactive relations and snapshots.
507
+ */
508
+ export type Comparator = internal.Comparator<Unknown | Snapshot>;
509
+
510
+ export const sortByLabel: Comparator = internal.sortByLabel as Comparator;
511
+ export const sortByTypename: Comparator = internal.sortByTypename as Comparator;
512
+ export const sort = (...comparators: Comparator[]): Comparator => internal.sort(...comparators) as Comparator;
513
+
514
+ //
515
+ // Version
516
+ //
517
+
518
+ export const VersionTypeId = internal.VersionTypeId;
519
+ export const isVersion = internal.isVersion;
520
+
521
+ /**
522
+ * Represent relation version.
523
+ */
524
+ export type Version = internal.EntityVersion;
525
+
526
+ /**
527
+ * Returns the version of the relation.
528
+ * Accepts both reactive relations and snapshots.
529
+ */
530
+ export const version = (entity: Unknown | Snapshot): Version => internal.version(entity);
@@ -0,0 +1,106 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import type * as Types from 'effect/Types';
6
+
7
+ import type * as JsonSchema from './JsonSchema';
8
+ import type * as Key from './Key';
9
+ import type * as QueryResult from './QueryResult';
10
+ import type * as Type from './Type';
11
+
12
+ // TODO(wittjosiah): Replace w/ Query.Query.
13
+ export type Query = {
14
+ /**
15
+ * Filter by schema ID.
16
+ * Schema id is a DXN with `echo` or `type` kind.
17
+ */
18
+ id?: string | string[];
19
+
20
+ /**
21
+ * Id of the backing ECHO object.
22
+ */
23
+ backingObjectId?: Key.ObjectId | Key.ObjectId[];
24
+
25
+ /**
26
+ * One or more typenames to filter by.
27
+ */
28
+ typename?: string | string[];
29
+
30
+ /**
31
+ * [Semver Range](https://docs.npmjs.com/cli/v6/using-npm/semver#ranges) for the schema version.
32
+ */
33
+ version?: string;
34
+
35
+ /**
36
+ * Where to look for the schema.
37
+ *
38
+ * Database schema are stored in the database of the current space.
39
+ * Runtime schema are registered in the runtime.
40
+ *
41
+ * @default ['database']
42
+ */
43
+ location?: ('database' | 'runtime')[];
44
+
45
+ /**
46
+ * Include system schemas.
47
+ * @default false
48
+ *
49
+ * The system schema include but are not limited to:
50
+ * - dxos.org/type/Schema
51
+ */
52
+ includeSystem?: boolean;
53
+ };
54
+
55
+ /**
56
+ * Input for schema registration.
57
+ * The typename, version and schema mutability metadata is read from the schema annotations.
58
+ *
59
+ * Accepts:
60
+ * - Branded ECHO schemas created with Type.Obj() or Type.Relation()
61
+ * - JSON schema with typename and version
62
+ */
63
+ export type RegisterSchemaInput =
64
+ | Type.AnyEntity
65
+ | {
66
+ typename: string;
67
+ version: string;
68
+ jsonSchema: JsonSchema.JsonSchema;
69
+ /**
70
+ * Display name of the schema.
71
+ */
72
+ name?: string;
73
+ };
74
+
75
+ export type ExtractQueryResult<Query> = Query extends { location: ('database' | 'runtime')[] }
76
+ ? Type.AnyEntity
77
+ : Type.RuntimeType;
78
+
79
+ // TODO(dmaretskyi): Rename TypeRegistry
80
+ export interface SchemaRegistry {
81
+ /**
82
+ * Checks if the provided schema is registered.
83
+ */
84
+ // TODO(burdon): Type?
85
+ hasSchema(schema: Type.AnyEntity): boolean;
86
+
87
+ /**
88
+ * Registers the provided schema.
89
+ *
90
+ * @returns Mutable runtime instances of schemas that were registered.
91
+ *
92
+ * The behavior of this method depends on the state of the database.
93
+ * The general principle is that the schema will be upserted into the space.
94
+ * If an equivalent schema with the same name and version already exists, the method does nothing.
95
+ * If a different schema with the same name and version exists, the method throws an error.
96
+ * If no schema with the same name and version exists, a new schema will be inserted based on semantic versioning rules.
97
+ */
98
+ register(input: RegisterSchemaInput[]): Promise<Type.RuntimeType[]>;
99
+
100
+ /**
101
+ *
102
+ */
103
+ query<Q extends Types.NoExcessProperties<Query, Q>>(
104
+ query?: Q & Query,
105
+ ): QueryResult.QueryResult<ExtractQueryResult<Q>>;
106
+ }