@dxos/echo 0.8.4-staging.ac66bdf99f → 0.9.0

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 (437) hide show
  1. package/LICENSE +102 -5
  2. package/README.md +7 -7
  3. package/dist/lib/neutral/Annotation.mjs +37 -6
  4. package/dist/lib/neutral/Database.mjs +6 -17
  5. package/dist/lib/neutral/Entity.mjs +31 -20
  6. package/dist/lib/neutral/Err.mjs +3 -3
  7. package/dist/lib/neutral/Feed.mjs +23 -19
  8. package/dist/lib/neutral/Filter.mjs +13 -15
  9. package/dist/lib/neutral/Format.mjs +23 -3
  10. package/dist/lib/neutral/JsonSchema.mjs +7 -8
  11. package/dist/lib/neutral/Key.mjs +9 -5
  12. package/dist/lib/neutral/Migration.mjs +11 -10
  13. package/dist/lib/neutral/Obj.mjs +29 -20
  14. package/dist/lib/neutral/Order.mjs +7 -3
  15. package/dist/lib/neutral/Query.mjs +17 -17
  16. package/dist/lib/neutral/QueryResult.mjs +1 -1
  17. package/dist/lib/neutral/Ref.mjs +10 -9
  18. package/dist/lib/neutral/Registry.mjs +14 -0
  19. package/dist/lib/neutral/Relation.mjs +28 -25
  20. package/dist/lib/neutral/Scope.mjs +12 -0
  21. package/dist/lib/neutral/Tag.mjs +17 -14
  22. package/dist/lib/neutral/Type.mjs +54 -26
  23. package/dist/lib/neutral/{chunk-OMUPQMLR.mjs → chunk-35INCYOE.mjs} +1 -1
  24. package/dist/lib/neutral/chunk-35INCYOE.mjs.map +7 -0
  25. package/dist/lib/neutral/chunk-3PBP4V4O.mjs +101 -0
  26. package/dist/lib/neutral/chunk-3PBP4V4O.mjs.map +7 -0
  27. package/dist/lib/neutral/chunk-4ZUHOTCG.mjs +184 -0
  28. package/dist/lib/neutral/chunk-4ZUHOTCG.mjs.map +7 -0
  29. package/dist/lib/neutral/chunk-5SMDBFVB.mjs +108 -0
  30. package/dist/lib/neutral/chunk-5SMDBFVB.mjs.map +7 -0
  31. package/dist/lib/neutral/{chunk-OS35K56T.mjs → chunk-5SUJPHAE.mjs} +3 -3
  32. package/dist/lib/neutral/{chunk-OS35K56T.mjs.map → chunk-5SUJPHAE.mjs.map} +2 -2
  33. package/dist/lib/neutral/{chunk-GZQTCRJB.mjs → chunk-6M2Z6WBH.mjs} +22 -2
  34. package/dist/lib/neutral/chunk-6M2Z6WBH.mjs.map +7 -0
  35. package/dist/lib/neutral/{chunk-V36VO5SS.mjs → chunk-6YDI3J37.mjs} +32 -40
  36. package/dist/lib/neutral/chunk-6YDI3J37.mjs.map +7 -0
  37. package/dist/lib/neutral/{chunk-MOR5ERFM.mjs → chunk-7FPIAJIV.mjs} +701 -1256
  38. package/dist/lib/neutral/chunk-7FPIAJIV.mjs.map +7 -0
  39. package/dist/lib/neutral/{chunk-ANHVGJI4.mjs → chunk-7LOUAPYZ.mjs} +9 -5
  40. package/dist/lib/neutral/chunk-7LOUAPYZ.mjs.map +7 -0
  41. package/dist/lib/neutral/{chunk-JUXPFOEI.mjs → chunk-7PI7C4EF.mjs} +48 -88
  42. package/dist/lib/neutral/chunk-7PI7C4EF.mjs.map +7 -0
  43. package/dist/lib/neutral/{chunk-UBEZSGXY.mjs → chunk-BBFJWWAV.mjs} +6 -6
  44. package/dist/lib/neutral/chunk-BBFJWWAV.mjs.map +7 -0
  45. package/dist/lib/neutral/{chunk-UI6MWK5W.mjs → chunk-EVK6XBXO.mjs} +16 -2
  46. package/dist/lib/neutral/chunk-EVK6XBXO.mjs.map +7 -0
  47. package/dist/lib/neutral/{chunk-7RO7CPBZ.mjs → chunk-IGK6FN65.mjs} +2 -2
  48. package/dist/lib/neutral/{chunk-HBUZJNZO.mjs → chunk-LWXVKPPW.mjs} +94 -99
  49. package/dist/lib/neutral/chunk-LWXVKPPW.mjs.map +7 -0
  50. package/dist/lib/neutral/{chunk-BVOFLCVF.mjs → chunk-MZ7K3MLL.mjs} +9 -6
  51. package/dist/lib/neutral/chunk-MZ7K3MLL.mjs.map +7 -0
  52. package/dist/lib/neutral/{chunk-TBKX6JQO.mjs → chunk-O6BH7EPN.mjs} +30 -3
  53. package/dist/lib/neutral/chunk-O6BH7EPN.mjs.map +7 -0
  54. package/dist/lib/neutral/{chunk-EAMSSLZC.mjs → chunk-QQIYS74I.mjs} +83 -46
  55. package/dist/lib/neutral/chunk-QQIYS74I.mjs.map +7 -0
  56. package/dist/lib/neutral/chunk-R5W6DXR4.mjs +678 -0
  57. package/dist/lib/neutral/chunk-R5W6DXR4.mjs.map +7 -0
  58. package/dist/lib/neutral/{chunk-WAK4DMFV.mjs → chunk-RIVWNMSF.mjs} +12 -7
  59. package/dist/lib/neutral/chunk-RIVWNMSF.mjs.map +7 -0
  60. package/dist/lib/neutral/{chunk-T6W2LEZU.mjs → chunk-SBVFRTST.mjs} +73 -38
  61. package/dist/lib/neutral/chunk-SBVFRTST.mjs.map +7 -0
  62. package/dist/lib/neutral/chunk-T6E37YIP.mjs +251 -0
  63. package/dist/lib/neutral/chunk-T6E37YIP.mjs.map +7 -0
  64. package/dist/lib/neutral/{chunk-DQYLD2RB.mjs → chunk-TFEWTY5A.mjs} +155 -129
  65. package/dist/lib/neutral/chunk-TFEWTY5A.mjs.map +7 -0
  66. package/dist/lib/neutral/{chunk-B4BASU6W.mjs → chunk-TYGKCRMK.mjs} +85 -76
  67. package/dist/lib/neutral/chunk-TYGKCRMK.mjs.map +7 -0
  68. package/dist/lib/neutral/{chunk-4OIBYSXE.mjs → chunk-UUP46KUQ.mjs} +78 -32
  69. package/dist/lib/neutral/chunk-UUP46KUQ.mjs.map +7 -0
  70. package/dist/lib/neutral/chunk-WISOH2XH.mjs +36 -0
  71. package/dist/lib/neutral/chunk-WISOH2XH.mjs.map +7 -0
  72. package/dist/lib/neutral/{chunk-G3IQMKF7.mjs → chunk-WTQJHC75.mjs} +111 -112
  73. package/dist/lib/neutral/chunk-WTQJHC75.mjs.map +7 -0
  74. package/dist/lib/neutral/chunk-WU3GIANS.mjs +31 -0
  75. package/dist/lib/neutral/chunk-WU3GIANS.mjs.map +7 -0
  76. package/dist/lib/neutral/{chunk-TU3GW67D.mjs → chunk-ZGNNFYHS.mjs} +40 -40
  77. package/dist/lib/neutral/chunk-ZGNNFYHS.mjs.map +7 -0
  78. package/dist/lib/neutral/index.mjs +47 -41
  79. package/dist/lib/neutral/internal/index.mjs +137 -72
  80. package/dist/lib/neutral/meta.json +1 -1
  81. package/dist/lib/neutral/testing/index.mjs +261 -178
  82. package/dist/lib/neutral/testing/index.mjs.map +4 -4
  83. package/dist/types/src/Annotation.d.ts +108 -4
  84. package/dist/types/src/Annotation.d.ts.map +1 -1
  85. package/dist/types/src/Annotation.test.d.ts +2 -0
  86. package/dist/types/src/Annotation.test.d.ts.map +1 -0
  87. package/dist/types/src/Collection.d.ts +2 -3
  88. package/dist/types/src/Collection.d.ts.map +1 -1
  89. package/dist/types/src/Database.d.ts +56 -49
  90. package/dist/types/src/Database.d.ts.map +1 -1
  91. package/dist/types/src/Dataset.d.ts +16 -6
  92. package/dist/types/src/Dataset.d.ts.map +1 -1
  93. package/dist/types/src/Entity.d.ts +101 -28
  94. package/dist/types/src/Entity.d.ts.map +1 -1
  95. package/dist/types/src/Err.d.ts +27 -27
  96. package/dist/types/src/Err.d.ts.map +1 -1
  97. package/dist/types/src/Feed.d.ts +66 -19
  98. package/dist/types/src/Feed.d.ts.map +1 -1
  99. package/dist/types/src/Filter.d.ts +38 -12
  100. package/dist/types/src/Filter.d.ts.map +1 -1
  101. package/dist/types/src/Format.d.ts +0 -2
  102. package/dist/types/src/Format.d.ts.map +1 -1
  103. package/dist/types/src/Hypergraph.d.ts +14 -9
  104. package/dist/types/src/Hypergraph.d.ts.map +1 -1
  105. package/dist/types/src/Json.d.ts +33 -0
  106. package/dist/types/src/Json.d.ts.map +1 -0
  107. package/dist/types/src/Json.test.d.ts +2 -0
  108. package/dist/types/src/Json.test.d.ts.map +1 -0
  109. package/dist/types/src/JsonSchema.d.ts +2 -2
  110. package/dist/types/src/JsonSchema.d.ts.map +1 -1
  111. package/dist/types/src/Key.d.ts +1 -1
  112. package/dist/types/src/Key.d.ts.map +1 -1
  113. package/dist/types/src/Migration.d.ts +26 -11
  114. package/dist/types/src/Migration.d.ts.map +1 -1
  115. package/dist/types/src/Obj.d.ts +104 -61
  116. package/dist/types/src/Obj.d.ts.map +1 -1
  117. package/dist/types/src/Order.d.ts +10 -0
  118. package/dist/types/src/Order.d.ts.map +1 -1
  119. package/dist/types/src/Query.d.ts +34 -12
  120. package/dist/types/src/Query.d.ts.map +1 -1
  121. package/dist/types/src/QueryResult.d.ts +21 -0
  122. package/dist/types/src/QueryResult.d.ts.map +1 -1
  123. package/dist/types/src/Ref.d.ts +15 -7
  124. package/dist/types/src/Ref.d.ts.map +1 -1
  125. package/dist/types/src/Registry.d.ts +131 -0
  126. package/dist/types/src/Registry.d.ts.map +1 -0
  127. package/dist/types/src/Relation.d.ts +73 -41
  128. package/dist/types/src/Relation.d.ts.map +1 -1
  129. package/dist/types/src/Scope.d.ts +35 -0
  130. package/dist/types/src/Scope.d.ts.map +1 -0
  131. package/dist/types/src/Tag.d.ts +21 -5
  132. package/dist/types/src/Tag.d.ts.map +1 -1
  133. package/dist/types/src/Type.d.ts +362 -95
  134. package/dist/types/src/Type.d.ts.map +1 -1
  135. package/dist/types/src/View.d.ts +9 -12
  136. package/dist/types/src/View.d.ts.map +1 -1
  137. package/dist/types/src/exemplars.test.d.ts +2 -0
  138. package/dist/types/src/exemplars.test.d.ts.map +1 -0
  139. package/dist/types/src/index.d.ts +4 -3
  140. package/dist/types/src/index.d.ts.map +1 -1
  141. package/dist/types/src/internal/Annotation/annotations.d.ts +79 -38
  142. package/dist/types/src/internal/Annotation/annotations.d.ts.map +1 -1
  143. package/dist/types/src/internal/Annotation/dictionary.d.ts +24 -0
  144. package/dist/types/src/internal/Annotation/dictionary.d.ts.map +1 -0
  145. package/dist/types/src/internal/Annotation/entity-dictionary.d.ts +14 -0
  146. package/dist/types/src/internal/Annotation/entity-dictionary.d.ts.map +1 -0
  147. package/dist/types/src/internal/Annotation/index.d.ts +4 -2
  148. package/dist/types/src/internal/Annotation/index.d.ts.map +1 -1
  149. package/dist/types/src/internal/Annotation/sorting.d.ts.map +1 -1
  150. package/dist/types/src/internal/Annotation/util.d.ts +14 -5
  151. package/dist/types/src/internal/Annotation/util.d.ts.map +1 -1
  152. package/dist/types/src/internal/Entity/api.d.ts +17 -3
  153. package/dist/types/src/internal/Entity/api.d.ts.map +1 -1
  154. package/dist/types/src/internal/Entity/entity.d.ts +72 -8
  155. package/dist/types/src/internal/Entity/entity.d.ts.map +1 -1
  156. package/dist/types/src/internal/Entity/guard.d.ts +10 -0
  157. package/dist/types/src/internal/Entity/guard.d.ts.map +1 -0
  158. package/dist/types/src/internal/Entity/index.d.ts +2 -0
  159. package/dist/types/src/internal/Entity/index.d.ts.map +1 -1
  160. package/dist/types/src/internal/Entity/model.d.ts +21 -17
  161. package/dist/types/src/internal/Entity/model.d.ts.map +1 -1
  162. package/dist/types/src/internal/Entity/object.d.ts +3 -3
  163. package/dist/types/src/internal/Entity/object.d.ts.map +1 -1
  164. package/dist/types/src/internal/Entity/relation.d.ts +30 -7
  165. package/dist/types/src/internal/Entity/relation.d.ts.map +1 -1
  166. package/dist/types/src/internal/Entity/type-kind.d.ts +24 -0
  167. package/dist/types/src/internal/Entity/type-kind.d.ts.map +1 -0
  168. package/dist/types/src/internal/Entity/type-uri.d.ts +24 -0
  169. package/dist/types/src/internal/Entity/type-uri.d.ts.map +1 -0
  170. package/dist/types/src/internal/Entity/version.d.ts.map +1 -1
  171. package/dist/types/src/internal/Format/date.d.ts.map +1 -1
  172. package/dist/types/src/internal/Format/format.d.ts +3 -2
  173. package/dist/types/src/internal/Format/format.d.ts.map +1 -1
  174. package/dist/types/src/internal/Format/index.d.ts +2 -2
  175. package/dist/types/src/internal/Format/index.d.ts.map +1 -1
  176. package/dist/types/src/internal/Format/number.d.ts.map +1 -1
  177. package/dist/types/src/internal/Format/object.d.ts +3 -1
  178. package/dist/types/src/internal/Format/object.d.ts.map +1 -1
  179. package/dist/types/src/internal/Format/types.d.ts.map +1 -1
  180. package/dist/types/src/internal/JsonSchema/json-schema-normalize.d.ts.map +1 -1
  181. package/dist/types/src/internal/JsonSchema/json-schema-type.d.ts +34 -34
  182. package/dist/types/src/internal/JsonSchema/json-schema-type.d.ts.map +1 -1
  183. package/dist/types/src/internal/JsonSchema/json-schema.d.ts +3 -2
  184. package/dist/types/src/internal/JsonSchema/json-schema.d.ts.map +1 -1
  185. package/dist/types/src/internal/Obj/atoms.d.ts +38 -0
  186. package/dist/types/src/internal/Obj/atoms.d.ts.map +1 -0
  187. package/dist/types/src/internal/Obj/clone.d.ts.map +1 -1
  188. package/dist/types/src/internal/Obj/common.d.ts.map +1 -1
  189. package/dist/types/src/internal/Obj/create-object.d.ts +12 -12
  190. package/dist/types/src/internal/Obj/create-object.d.ts.map +1 -1
  191. package/dist/types/src/internal/Obj/deleted.d.ts.map +1 -1
  192. package/dist/types/src/internal/Obj/index.d.ts +1 -1
  193. package/dist/types/src/internal/Obj/index.d.ts.map +1 -1
  194. package/dist/types/src/internal/Obj/json-serializer.d.ts +8 -8
  195. package/dist/types/src/internal/Obj/json-serializer.d.ts.map +1 -1
  196. package/dist/types/src/internal/Obj/set-value.d.ts +1 -1
  197. package/dist/types/src/internal/Obj/set-value.d.ts.map +1 -1
  198. package/dist/types/src/internal/Obj/snapshot.d.ts.map +1 -1
  199. package/dist/types/src/internal/Obj/typed-object.d.ts +1 -1
  200. package/dist/types/src/internal/Query/index.d.ts +2 -0
  201. package/dist/types/src/internal/Query/index.d.ts.map +1 -0
  202. package/dist/types/src/internal/{Query.d.ts → Query/pretty.d.ts} +1 -1
  203. package/dist/types/src/internal/Query/pretty.d.ts.map +1 -0
  204. package/dist/types/src/internal/Ref/atoms.d.ts +10 -0
  205. package/dist/types/src/internal/Ref/atoms.d.ts.map +1 -0
  206. package/dist/types/src/internal/Ref/ref-array.d.ts +2 -2
  207. package/dist/types/src/internal/Ref/ref.d.ts +50 -19
  208. package/dist/types/src/internal/Ref/ref.d.ts.map +1 -1
  209. package/dist/types/src/internal/Ref/utils.d.ts +8 -0
  210. package/dist/types/src/internal/Ref/utils.d.ts.map +1 -0
  211. package/dist/types/src/internal/Type/compose.d.ts.map +1 -1
  212. package/dist/types/src/internal/Type/index.d.ts +1 -2
  213. package/dist/types/src/internal/Type/index.d.ts.map +1 -1
  214. package/dist/types/src/internal/Type/manipulation.d.ts +0 -1
  215. package/dist/types/src/internal/Type/manipulation.d.ts.map +1 -1
  216. package/dist/types/src/internal/Type/type-schema.d.ts +52 -0
  217. package/dist/types/src/internal/Type/type-schema.d.ts.map +1 -0
  218. package/dist/types/src/internal/common/api/meta.d.ts +14 -11
  219. package/dist/types/src/internal/common/api/meta.d.ts.map +1 -1
  220. package/dist/types/src/internal/common/proxy/change-context.d.ts +1 -1
  221. package/dist/types/src/internal/common/proxy/change-context.d.ts.map +1 -1
  222. package/dist/types/src/internal/common/proxy/define-hidden-property.d.ts.map +1 -1
  223. package/dist/types/src/internal/common/proxy/errors.d.ts +1 -1
  224. package/dist/types/src/internal/common/proxy/errors.d.ts.map +1 -1
  225. package/dist/types/src/internal/common/proxy/event-batch.d.ts.map +1 -1
  226. package/dist/types/src/internal/common/proxy/json-serializer.d.ts.map +1 -1
  227. package/dist/types/src/internal/common/proxy/make-object.d.ts +11 -5
  228. package/dist/types/src/internal/common/proxy/make-object.d.ts.map +1 -1
  229. package/dist/types/src/internal/common/proxy/ownership.d.ts.map +1 -1
  230. package/dist/types/src/internal/common/proxy/proxy-utils.d.ts.map +1 -1
  231. package/dist/types/src/internal/common/proxy/reactive-array.d.ts +1 -1
  232. package/dist/types/src/internal/common/proxy/reactive.d.ts +1 -1
  233. package/dist/types/src/internal/common/proxy/reactive.d.ts.map +1 -1
  234. package/dist/types/src/internal/common/proxy/reactive.test.d.ts +2 -0
  235. package/dist/types/src/internal/common/proxy/reactive.test.d.ts.map +1 -0
  236. package/dist/types/src/internal/common/proxy/schema-validator.d.ts.map +1 -1
  237. package/dist/types/src/internal/common/proxy/typed-handler.d.ts +18 -2
  238. package/dist/types/src/internal/common/proxy/typed-handler.d.ts.map +1 -1
  239. package/dist/types/src/internal/common/types/base.d.ts +4 -4
  240. package/dist/types/src/internal/common/types/base.d.ts.map +1 -1
  241. package/dist/types/src/internal/common/types/entity.d.ts +62 -5
  242. package/dist/types/src/internal/common/types/entity.d.ts.map +1 -1
  243. package/dist/types/src/internal/common/types/index.d.ts +1 -1
  244. package/dist/types/src/internal/common/types/index.d.ts.map +1 -1
  245. package/dist/types/src/internal/common/types/meta.d.ts +33 -12
  246. package/dist/types/src/internal/common/types/meta.d.ts.map +1 -1
  247. package/dist/types/src/internal/common/types/model-symbols.d.ts +15 -4
  248. package/dist/types/src/internal/common/types/model-symbols.d.ts.map +1 -1
  249. package/dist/types/src/internal/common/types/typename.d.ts +7 -0
  250. package/dist/types/src/internal/common/types/typename.d.ts.map +1 -1
  251. package/dist/types/src/internal/common/types/version.d.ts +1 -1
  252. package/dist/types/src/internal/common/types/well-known-types.d.ts +11 -0
  253. package/dist/types/src/internal/common/types/well-known-types.d.ts.map +1 -0
  254. package/dist/types/src/internal/index.d.ts +2 -2
  255. package/dist/types/src/internal/index.d.ts.map +1 -1
  256. package/dist/types/src/testing/index.d.ts +1 -0
  257. package/dist/types/src/testing/index.d.ts.map +1 -1
  258. package/dist/types/src/testing/registry.d.ts +9 -0
  259. package/dist/types/src/testing/registry.d.ts.map +1 -0
  260. package/dist/types/src/testing/test-data.d.ts +8 -8
  261. package/dist/types/src/testing/test-data.d.ts.map +1 -1
  262. package/dist/types/src/testing/test-schema.d.ts +83 -89
  263. package/dist/types/src/testing/test-schema.d.ts.map +1 -1
  264. package/dist/types/src/testing/util.d.ts +5 -3
  265. package/dist/types/src/testing/util.d.ts.map +1 -1
  266. package/dist/types/tsconfig.tsbuildinfo +1 -1
  267. package/package.json +26 -24
  268. package/src/Annotation.test.ts +439 -0
  269. package/src/Annotation.ts +158 -4
  270. package/src/Collection.ts +5 -9
  271. package/src/Database.ts +93 -100
  272. package/src/Dataset.ts +10 -2
  273. package/src/Entity.test.ts +116 -6
  274. package/src/Entity.ts +134 -32
  275. package/src/Err.ts +4 -4
  276. package/src/Feed.ts +92 -44
  277. package/src/Filter.ts +70 -40
  278. package/src/Format.ts +0 -4
  279. package/src/Hypergraph.ts +14 -9
  280. package/src/Json.test.ts +175 -0
  281. package/src/Json.ts +103 -0
  282. package/src/Key.ts +1 -1
  283. package/src/Migration.ts +39 -19
  284. package/src/Obj.test.ts +122 -20
  285. package/src/Obj.ts +168 -91
  286. package/src/Order.ts +22 -0
  287. package/src/Query.test.ts +183 -154
  288. package/src/Query.ts +172 -85
  289. package/src/QueryResult.ts +26 -0
  290. package/src/Ref.ts +22 -4
  291. package/src/Registry.ts +155 -0
  292. package/src/Relation.test.ts +10 -10
  293. package/src/Relation.ts +116 -69
  294. package/src/Scope.ts +50 -0
  295. package/src/Tag.md +88 -0
  296. package/src/Tag.ts +49 -6
  297. package/src/Type.test.ts +223 -18
  298. package/src/Type.ts +609 -131
  299. package/src/View.ts +14 -23
  300. package/src/exemplars.test.ts +21 -0
  301. package/src/index.ts +4 -4
  302. package/src/internal/Annotation/annotations.test.ts +31 -11
  303. package/src/internal/Annotation/annotations.ts +143 -111
  304. package/src/internal/Annotation/dictionary.ts +47 -0
  305. package/src/internal/Annotation/entity-dictionary.ts +74 -0
  306. package/src/internal/Annotation/index.ts +4 -2
  307. package/src/internal/Annotation/util.ts +17 -8
  308. package/src/internal/Entity/api.ts +54 -7
  309. package/src/internal/Entity/entity.ts +196 -47
  310. package/src/internal/Entity/guard.ts +26 -0
  311. package/src/internal/Entity/index.ts +2 -0
  312. package/src/internal/Entity/model.ts +38 -28
  313. package/src/internal/Entity/object.ts +21 -5
  314. package/src/internal/Entity/relation.ts +68 -34
  315. package/src/internal/Entity/type-kind.ts +75 -0
  316. package/src/internal/Entity/type-uri.ts +92 -0
  317. package/src/internal/Entity/util.ts +9 -9
  318. package/src/internal/Format/date.ts +0 -4
  319. package/src/internal/Format/format.test.ts +21 -0
  320. package/src/internal/Format/index.ts +2 -3
  321. package/src/internal/Format/object.ts +21 -4
  322. package/src/internal/Format/types.ts +1 -1
  323. package/src/internal/JsonSchema/annotations.ts +1 -1
  324. package/src/internal/JsonSchema/json-schema-type.ts +4 -4
  325. package/src/internal/JsonSchema/json-schema.test.ts +71 -145
  326. package/src/internal/JsonSchema/json-schema.ts +49 -35
  327. package/src/internal/Obj/atoms.ts +244 -0
  328. package/src/internal/Obj/clone.ts +9 -4
  329. package/src/internal/Obj/create-object.test.ts +12 -10
  330. package/src/internal/Obj/create-object.ts +68 -22
  331. package/src/internal/Obj/index.ts +1 -1
  332. package/src/internal/Obj/inspect.ts +5 -3
  333. package/src/internal/Obj/json-serializer.test.ts +101 -22
  334. package/src/internal/Obj/json-serializer.ts +89 -33
  335. package/src/internal/Obj/set-value.test.ts +22 -45
  336. package/src/internal/Obj/set-value.ts +12 -19
  337. package/src/internal/Obj/snapshot.ts +13 -4
  338. package/src/internal/Obj/typed-object.test.ts +9 -11
  339. package/src/internal/Obj/typed-object.ts +1 -1
  340. package/src/internal/Query/index.ts +5 -0
  341. package/src/internal/{Query.ts → Query/pretty.ts} +40 -12
  342. package/src/internal/Ref/atoms.ts +20 -0
  343. package/src/internal/Ref/ref-array.ts +3 -3
  344. package/src/internal/Ref/ref.test.ts +18 -27
  345. package/src/internal/Ref/ref.ts +137 -59
  346. package/src/internal/Ref/utils.ts +45 -0
  347. package/src/internal/Type/compose.test.ts +3 -1
  348. package/src/internal/Type/index.ts +1 -2
  349. package/src/internal/Type/manipulation.ts +0 -25
  350. package/src/internal/Type/type-schema.ts +60 -0
  351. package/src/internal/common/README.md +2 -2
  352. package/src/internal/common/api/meta.ts +19 -17
  353. package/src/internal/common/proxy/change-context.ts +1 -1
  354. package/src/internal/common/proxy/change.test.ts +91 -83
  355. package/src/internal/common/proxy/errors.ts +2 -2
  356. package/src/internal/common/proxy/handler.test.ts +1 -1
  357. package/src/internal/common/proxy/json-serializer.ts +27 -16
  358. package/src/internal/common/proxy/make-object.ts +44 -20
  359. package/src/internal/common/proxy/ownership.ts +2 -2
  360. package/src/internal/common/proxy/reactive-array.ts +1 -1
  361. package/src/internal/common/proxy/reactive.test.ts +54 -0
  362. package/src/internal/common/proxy/reactive.ts +11 -2
  363. package/src/internal/common/proxy/schema.test.ts +48 -86
  364. package/src/internal/common/proxy/typed-handler.test.ts +12 -11
  365. package/src/internal/common/proxy/typed-handler.ts +78 -16
  366. package/src/internal/common/proxy/typed-object.test.ts +16 -28
  367. package/src/internal/common/types/base.ts +4 -4
  368. package/src/internal/common/types/entity.ts +80 -1
  369. package/src/internal/common/types/index.ts +6 -1
  370. package/src/internal/common/types/meta.ts +62 -20
  371. package/src/internal/common/types/model-symbols.ts +24 -4
  372. package/src/internal/common/types/typename.ts +39 -3
  373. package/src/internal/common/types/well-known-types.ts +15 -0
  374. package/src/internal/index.ts +6 -4
  375. package/src/testing/api.test.ts +15 -9
  376. package/src/testing/index.ts +1 -0
  377. package/src/testing/registry.ts +44 -0
  378. package/src/testing/test-data.ts +159 -99
  379. package/src/testing/test-schema.ts +22 -58
  380. package/src/testing/util.ts +14 -11
  381. package/dist/lib/neutral/Extension.mjs +0 -18
  382. package/dist/lib/neutral/SchemaRegistry.mjs +0 -2
  383. package/dist/lib/neutral/chunk-2KHZ36F5.mjs +0 -361
  384. package/dist/lib/neutral/chunk-2KHZ36F5.mjs.map +0 -7
  385. package/dist/lib/neutral/chunk-4OIBYSXE.mjs.map +0 -7
  386. package/dist/lib/neutral/chunk-4P3IXBLT.mjs +0 -45
  387. package/dist/lib/neutral/chunk-4P3IXBLT.mjs.map +0 -7
  388. package/dist/lib/neutral/chunk-ANHVGJI4.mjs.map +0 -7
  389. package/dist/lib/neutral/chunk-B4BASU6W.mjs.map +0 -7
  390. package/dist/lib/neutral/chunk-BNCCGLJN.mjs +0 -7
  391. package/dist/lib/neutral/chunk-BNCCGLJN.mjs.map +0 -7
  392. package/dist/lib/neutral/chunk-BVOFLCVF.mjs.map +0 -7
  393. package/dist/lib/neutral/chunk-DQYLD2RB.mjs.map +0 -7
  394. package/dist/lib/neutral/chunk-EAMSSLZC.mjs.map +0 -7
  395. package/dist/lib/neutral/chunk-G3IQMKF7.mjs.map +0 -7
  396. package/dist/lib/neutral/chunk-GZQTCRJB.mjs.map +0 -7
  397. package/dist/lib/neutral/chunk-HBUZJNZO.mjs.map +0 -7
  398. package/dist/lib/neutral/chunk-JUXPFOEI.mjs.map +0 -7
  399. package/dist/lib/neutral/chunk-MOR5ERFM.mjs.map +0 -7
  400. package/dist/lib/neutral/chunk-OMUPQMLR.mjs.map +0 -7
  401. package/dist/lib/neutral/chunk-PHU22NLC.mjs +0 -136
  402. package/dist/lib/neutral/chunk-PHU22NLC.mjs.map +0 -7
  403. package/dist/lib/neutral/chunk-ROG4RXXL.mjs +0 -97
  404. package/dist/lib/neutral/chunk-ROG4RXXL.mjs.map +0 -7
  405. package/dist/lib/neutral/chunk-T6W2LEZU.mjs.map +0 -7
  406. package/dist/lib/neutral/chunk-TBKX6JQO.mjs.map +0 -7
  407. package/dist/lib/neutral/chunk-TU3GW67D.mjs.map +0 -7
  408. package/dist/lib/neutral/chunk-UBEZSGXY.mjs.map +0 -7
  409. package/dist/lib/neutral/chunk-UI6MWK5W.mjs.map +0 -7
  410. package/dist/lib/neutral/chunk-V36VO5SS.mjs.map +0 -7
  411. package/dist/lib/neutral/chunk-WAK4DMFV.mjs.map +0 -7
  412. package/dist/lib/neutral/chunk-YAHXAYOW.mjs +0 -56
  413. package/dist/lib/neutral/chunk-YAHXAYOW.mjs.map +0 -7
  414. package/dist/lib/neutral/chunk-YS6Q3XAD.mjs +0 -50
  415. package/dist/lib/neutral/chunk-YS6Q3XAD.mjs.map +0 -7
  416. package/dist/types/src/Extension.d.ts +0 -80
  417. package/dist/types/src/Extension.d.ts.map +0 -1
  418. package/dist/types/src/Extension.test.d.ts +0 -2
  419. package/dist/types/src/Extension.test.d.ts.map +0 -1
  420. package/dist/types/src/SchemaRegistry.d.ts +0 -84
  421. package/dist/types/src/SchemaRegistry.d.ts.map +0 -1
  422. package/dist/types/src/internal/Obj/ids.d.ts +0 -6
  423. package/dist/types/src/internal/Obj/ids.d.ts.map +0 -1
  424. package/dist/types/src/internal/Query.d.ts.map +0 -1
  425. package/dist/types/src/internal/Type/echo-schema.d.ts +0 -181
  426. package/dist/types/src/internal/Type/echo-schema.d.ts.map +0 -1
  427. package/dist/types/src/internal/Type/persistent-schema.d.ts +0 -20
  428. package/dist/types/src/internal/Type/persistent-schema.d.ts.map +0 -1
  429. package/src/Extension.test.ts +0 -235
  430. package/src/Extension.ts +0 -122
  431. package/src/SchemaRegistry.ts +0 -106
  432. package/src/internal/Obj/ids.ts +0 -12
  433. package/src/internal/Type/echo-schema.ts +0 -423
  434. package/src/internal/Type/persistent-schema.ts +0 -33
  435. /package/dist/lib/neutral/{Extension.mjs.map → Registry.mjs.map} +0 -0
  436. /package/dist/lib/neutral/{SchemaRegistry.mjs.map → Scope.mjs.map} +0 -0
  437. /package/dist/lib/neutral/{chunk-7RO7CPBZ.mjs.map → chunk-IGK6FN65.mjs.map} +0 -0
@@ -1,43 +1,64 @@
1
- import type * as Schema from 'effect/Schema';
1
+ import * as Schema from 'effect/Schema';
2
+ import type * as Types from 'effect/Types';
2
3
  import { type EncodedReference } from '@dxos/echo-protocol';
3
- import { type DXN } from '@dxos/keys';
4
- import { type ToMutable } from '@dxos/util';
5
- import type * as Entity from './Entity';
4
+ import { DXN, type EntityId, type URI } from '@dxos/keys';
5
+ import type * as Database from './Database';
6
+ import type * as EntityModule from './Entity';
6
7
  import * as internal from './internal';
7
8
  import * as typeInternal from './internal/Type';
8
- import type * as ObjModule from './Obj';
9
9
  import type * as RelationModule from './Relation';
10
10
  /**
11
- * Dynamic type that can be constructed, mutated, and persisted in the ECHO database.
11
+ * Structural base shared by the three sibling type-entity interfaces
12
+ * ({@link Obj}, {@link Relation}, {@link Type}). NOT exported — callers
13
+ * should constrain on {@link AnyEntity} when they want "any of the three"
14
+ * and on the specific kind interface otherwise.
12
15
  */
13
- export declare const RuntimeType: typeof internal.EchoSchema;
14
- /**
15
- * Dynamic type that can be constructed, mutated, and persisted in the ECHO database.
16
- */
17
- export type RuntimeType = typeInternal.EchoSchema;
18
- /**
19
- * Type that marks a schema as an ECHO schema.
20
- * The value indicates the entity kind (Object or Relation).
21
- */
22
- type EchoSchemaKind<K extends internal.EntityKind = internal.EntityKind> = {
23
- readonly [internal.SchemaKindId]: K;
24
- };
16
+ interface BaseTypeEntity<A> {
17
+ /**
18
+ * Entity-kind brand of the type-entity value itself always `EntityKind.Type`.
19
+ * The kind of instance the type *describes* lives on `[SchemaKindId]`
20
+ * (Object / Relation / Type). Lets `Obj.isObject` / `Relation.isRelation`
21
+ * reject type entities by a single `[KindId]` check.
22
+ */
23
+ readonly [internal.KindId]: internal.EntityKind.Type;
24
+ /**
25
+ * Object id. Like all ECHO entities, type entities always carry an id
26
+ * stamped at construction for in-memory (static) declarations and assigned by
27
+ * the database once persisted. The id does NOT determine the entity's URI:
28
+ * static types resolve to their typename DXN, persisted types to `echo:/<id>`
29
+ * (see `getTypeURIFromSpecifier`).
30
+ */
31
+ readonly id: EntityId;
32
+ readonly name?: string;
33
+ readonly jsonSchema: internal.JsonSchemaType;
34
+ readonly [InstancePhantomId]?: A;
35
+ }
25
36
  /**
26
- * TypeScript type for an ECHO object schema.
27
- * `T` is the instance type produced by the schema.
28
- * `Fields` is the optional struct fields type for introspection.
37
+ * TypeScript type for an ECHO object type — a `Type.Type<A>` entity.
38
+ *
39
+ * `T` is the instance type produced by `Obj.make(Foo, props)`. `Fields` is
40
+ * retained as a structural hint (the runtime value still carries `.fields`),
41
+ * but consumers should derive instance/encoded types via `Type.InstanceType`.
42
+ *
43
+ * **Not a `Schema.Schema`.** `Foo.ast` / `Schema.Schema.Type<typeof Foo>` /
44
+ * `Schema.extend(Foo)` no longer typecheck — extract the Effect Schema via
45
+ * `Type.getSchema(Foo)` first, or derive instance types via
46
+ * `Type.InstanceType<typeof Foo>`.
29
47
  *
30
48
  * @example
31
49
  * ```ts
32
- * const PersonSchema: Type.Obj<Person> = Schema.Struct({
50
+ * const Person = Schema.Struct({
33
51
  * name: Schema.String,
34
- * }).pipe(Type.object({ typename: 'Person', version: '0.1.0' }));
52
+ * }).pipe(Type.makeObject(DXN.make('com.example.type.person', '0.1.0')));
35
53
  *
36
- * // Access fields for introspection:
37
- * Object.keys(PersonSchema.fields); // ['name']
54
+ * type Person = Type.InstanceType<typeof Person>;
38
55
  * ```
39
56
  */
40
- export interface Obj<T, Fields extends Schema.Struct.Fields = Schema.Struct.Fields> extends internal.TypeMeta, EchoSchemaKind<internal.EntityKind.Object>, Schema.AnnotableClass<Obj<T, Fields>, Entity.OfKind<typeof Entity.Kind.Object> & T, Schema.Simplify<ObjModule.BaseObjJson & ToMutable<T>>, never> {
57
+ export interface Obj<T, Fields extends Schema.Struct.Fields = Schema.Struct.Fields> extends BaseTypeEntity<T & EntityModule.OfKind<typeof EntityModule.Kind.Object>> {
58
+ /** Schema-kind brand (object). */
59
+ readonly [internal.SchemaKindId]: internal.EntityKind.Object;
60
+ /** Source Effect Schema — used internally by `Type.getSchema(self)`. */
61
+ readonly [internal.StaticTypeSchemaSlot]: Schema.Schema.AnyNoContext;
41
62
  /**
42
63
  * The fields defined in the original struct schema.
43
64
  * Allows accessing field definitions for introspection.
@@ -45,44 +66,86 @@ export interface Obj<T, Fields extends Schema.Struct.Fields = Schema.Struct.Fiel
45
66
  readonly fields: Fields;
46
67
  }
47
68
  /**
48
- * Structural base type for any ECHO object schema.
49
- * Accepts both static schemas (created with Type.object()) and EchoSchema.
50
- * NOTE: Does not include the brand symbol to avoid TS4053 declaration portability issues.
51
- * Use Type.isObjectSchema() for runtime type guards.
52
- */
53
- type ObjectSchemaBase = Schema.Schema.AnyNoContext & {
54
- readonly typename: string;
55
- readonly version: string;
56
- };
57
- /**
58
- * Type that represents any ECHO object schema.
59
- * Accepts both static schemas (Type.object()) and mutable schemas (EchoSchema).
69
+ * Type that represents any ECHO object type — a `Type.Type` entity branded
70
+ * with the object entity kind, i.e. what `Type.makeObject(dxn)` produces.
60
71
  */
61
- export type AnyObj = ObjectSchemaBase;
72
+ export type AnyObj = Obj<unknown>;
62
73
  /**
63
- * Factory function to create an ECHO object schema.
64
- * Adds object metadata annotations to an Effect schema.
74
+ * Factory function to create an ECHO object type.
75
+ *
76
+ * Returns a `Type.Type` entity — a live, in-memory `TypeSchema` instance,
77
+ * NOT a `Schema.Schema`. Use `Type.InstanceType<typeof Foo>` for the instance
78
+ * type and `Type.getSchema(Foo)` to obtain the underlying Effect Schema.
79
+ *
80
+ * The entity's id defaults to `EntityId.deterministic(typename, version)` so
81
+ * constructing a type never reaches `crypto.getRandomValues()` — required for
82
+ * Cloudflare workerd, which forbids RNG calls in global (module-evaluation)
83
+ * scope. Pass `{ id }` to override (e.g. with `EntityId.random()` from a
84
+ * request handler).
65
85
  *
66
86
  * @example
67
87
  * ```ts
68
88
  * const Person = Schema.Struct({
69
89
  * name: Schema.String,
70
- * }).pipe(Type.object({ typename: 'com.example.type.person', version: '0.1.0' }));
90
+ * }).pipe(Type.makeObject(DXN.make('com.example.type.person', '0.1.0')));
71
91
  * ```
72
92
  */
73
- export declare const object: {
74
- (opts: internal.TypeMeta): <Self extends Schema.Schema.Any>(self: Self) => Obj<Schema.Schema.Type<Self>>;
93
+ export declare const makeObject: {
94
+ (dxn: DXN.DXN, options?: {
95
+ id?: EntityId;
96
+ }): <Self extends Schema.Schema.Any>(self: Self) => Obj<Schema.Schema.Type<Self>>;
75
97
  };
76
- export declare const PersistentType: Obj<typeInternal.PersistentSchema>;
77
- export interface PersistentType extends Schema.Schema.Type<typeof PersistentType> {
78
- }
79
98
  /**
80
- * TypeScript type for an ECHO relation schema.
81
- * `T` is the instance type produced by the schema (excluding source/target).
82
- * `Source` and `Target` are the endpoint types.
83
- * `Fields` is the optional struct fields type for introspection.
99
+ * ECHO meta-schema entity stores `{ name?, typename, version, jsonSchema }`.
100
+ * Type-kind sibling of `Type.makeObject(...)` / `Type.makeRelation(...)` outputs.
101
+ * Stored types live under this entity; filter via `Filter.type(Type.Type)`.
102
+ */
103
+ export declare const Type: Type<typeInternal.TypeSchema>;
104
+ /**
105
+ * Common props shared by the type-kind factories. Typename and version are
106
+ * optional — drafts omit typename and default version to {@link DRAFT_VERSION}.
84
107
  */
85
- export interface Relation<T, Source, Target, Fields extends Schema.Struct.Fields = Schema.Struct.Fields> extends internal.TypeMeta, EchoSchemaKind<internal.EntityKind.Relation>, Schema.AnnotableClass<Relation<T, Source, Target, Fields>, Entity.OfKind<typeof Entity.Kind.Relation> & RelationModule.Endpoints<Source, Target> & T, Schema.Simplify<RelationModule.BaseRelationJson & ToMutable<T>>, never> {
108
+ type MakeTypeProps = {
109
+ jsonSchema: internal.JsonSchemaType;
110
+ typename?: string;
111
+ version?: string;
112
+ name?: string;
113
+ id?: EntityId;
114
+ };
115
+ /**
116
+ * Construct a new object-kind type entity from raw metadata — for cases where
117
+ * an Effect Schema isn't available (e.g. JSON-Schema arriving over the network
118
+ * or from a UI editor). Parallel to {@link makeObject} but takes pre-built
119
+ * `jsonSchema` instead of piping through an Effect schema.
120
+ *
121
+ * The returned entity is in-memory; persist it with `db.addType(entity)`.
122
+ */
123
+ export declare const makeObjectFromJsonSchema: (props: MakeTypeProps) => Type<typeInternal.TypeSchema>;
124
+ /**
125
+ * Construct a new relation-kind type entity from raw metadata. Parallel to
126
+ * {@link makeRelation} but takes pre-built `jsonSchema` instead of piping
127
+ * through an Effect schema. `source` / `target` accept either a static
128
+ * `Type.Obj` entity or the well-known `Obj.Unknown` schema.
129
+ *
130
+ * The returned entity is in-memory; persist it with `db.addType(entity)`.
131
+ */
132
+ export declare const makeRelationFromJsonSchema: (props: MakeTypeProps & {
133
+ source: AnyObj | internal.UnknownTypeSchema<any, typeof EntityModule.Kind.Object>;
134
+ target: AnyObj | internal.UnknownTypeSchema<any, typeof EntityModule.Kind.Object>;
135
+ }) => Type<typeInternal.TypeSchema>;
136
+ /**
137
+ * TypeScript type for an ECHO relation type — a `Type.Type<A>` entity.
138
+ *
139
+ * `T` is the instance-property type produced by `Relation.make(...)` (excluding
140
+ * source/target endpoints). `Source` and `Target` are the endpoint types.
141
+ *
142
+ * **Not a `Schema.Schema`.** See {@link Obj}'s note.
143
+ */
144
+ export interface Relation<T, Source, Target, Fields extends Schema.Struct.Fields = Schema.Struct.Fields> extends BaseTypeEntity<RelationModule.Endpoints<Source, Target> & T & EntityModule.OfKind<typeof EntityModule.Kind.Relation>> {
145
+ /** Schema-kind brand (relation). */
146
+ readonly [internal.SchemaKindId]: internal.EntityKind.Relation;
147
+ /** Source Effect Schema — used internally by `Type.getSchema(self)`. */
148
+ readonly [internal.StaticTypeSchemaSlot]: Schema.Schema.AnyNoContext;
86
149
  /**
87
150
  * The fields defined in the original struct schema.
88
151
  * Allows accessing field definitions for introspection.
@@ -90,20 +153,10 @@ export interface Relation<T, Source, Target, Fields extends Schema.Struct.Fields
90
153
  readonly fields: Fields;
91
154
  }
92
155
  /**
93
- * Structural base type for any ECHO relation schema.
94
- * Accepts static schemas (created with Type.relation()).
95
- * NOTE: Does not include the brand symbol to avoid TS4053 declaration portability issues.
96
- * Use Type.isRelationSchema() for runtime type guards.
97
- */
98
- type RelationSchemaBase = Schema.Schema.AnyNoContext & {
99
- readonly typename: string;
100
- readonly version: string;
101
- };
102
- /**
103
- * Type that represents any ECHO relation schema.
104
- * Accepts static schemas (Type.relation()).
156
+ * Type that represents any ECHO relation type — a `Type.Type` entity branded
157
+ * with the relation entity kind, i.e. what `Type.makeRelation(...)` produces.
105
158
  */
106
- export type AnyRelation = RelationSchemaBase;
159
+ export type AnyRelation = Relation<unknown, unknown, unknown>;
107
160
  /**
108
161
  * Factory function to create an ECHO relation schema.
109
162
  * Adds relation metadata annotations to an Effect schema.
@@ -112,65 +165,279 @@ export type AnyRelation = RelationSchemaBase;
112
165
  * ```ts
113
166
  * const WorksFor = Schema.Struct({
114
167
  * role: Schema.String,
115
- * }).pipe(Type.relation({
116
- * typename: 'com.example.type.works-for',
117
- * version: '0.1.0',
168
+ * }).pipe(Type.makeRelation({
169
+ * dxn: DXN.make('com.example.type.worksFor', '0.1.0'),
118
170
  * source: Person,
119
171
  * target: Company,
120
172
  * }));
121
173
  * ```
122
174
  */
123
- export declare const relation: {
124
- <SourceSchema extends Schema.Schema.AnyNoContext, TargetSchema extends Schema.Schema.AnyNoContext>(opts: internal.EchoRelationSchemaOptions<SourceSchema, TargetSchema>): <Self extends Schema.Schema.Any>(self: Self) => Relation<Schema.Schema.Type<Self>, Schema.Schema.Type<SourceSchema>, Schema.Schema.Type<TargetSchema>>;
175
+ export declare const makeRelation: {
176
+ <SourceInstance, TargetInstance>(opts: {
177
+ dxn: DXN.DXN;
178
+ source: Obj<SourceInstance, any> | internal.UnknownTypeSchema<SourceInstance, typeof EntityModule.Kind.Object>;
179
+ target: Obj<TargetInstance, any> | internal.UnknownTypeSchema<TargetInstance, typeof EntityModule.Kind.Object>;
180
+ /**
181
+ * Override the entity id. Defaults to `EntityId.deterministic(typename, version)`;
182
+ * see `Type.makeObject` for the workerd motivation.
183
+ */
184
+ id?: EntityId;
185
+ }): <Self extends Schema.Schema.Any>(self: Self) => Relation<Schema.Schema.Type<Self>, SourceInstance & EntityModule.OfKind<typeof EntityModule.Kind.Object>, TargetInstance & EntityModule.OfKind<typeof EntityModule.Kind.Object>>;
125
186
  };
126
187
  /**
127
- * Type alias for any ECHO entity schema (object or relation).
128
- * Use this in type annotations for schema parameters.
188
+ * Type that represents any ECHO type-kind entity a `Type.Type` meta-schema
189
+ * value (static `Type.Type` or a persisted draft from `db.addType(...)`).
190
+ * Mirrors {@link AnyObj} / {@link AnyRelation} for the third sibling kind.
191
+ */
192
+ export type AnyType = Type<unknown>;
193
+ /**
194
+ * Any ECHO type-entity — one of the three sibling kinds: object-kind, relation-kind,
195
+ * or type-kind (the meta-schema). APIs that want "any ECHO type" use this union;
196
+ * the underlying Effect Schema is retrieved via `Type.getSchema`.
129
197
  */
130
- export type AnyEntity = AnyObj | AnyRelation;
198
+ export type AnyEntity = AnyObj | AnyRelation | AnyType;
131
199
  /**
132
- * Type guard to check if a schema is an object schema.
133
- * NOTE: This checks SCHEMAS, not instances. Use Obj.isObject for instances.
200
+ * Type guard: narrows a `Type.AnyEntity` to an object-kind entity. Checks
201
+ * ENTITIES, not instances use `Obj.isObject` for instances. Raw
202
+ * `Schema.Schema` values (including the branded `Obj.Unknown` companion)
203
+ * are intentionally not accepted; inspect their `TypeAnnotation` directly.
134
204
  */
135
- export declare const isObjectSchema: (schema: AnyEntity) => schema is AnyObj;
205
+ export declare const isObject: (entity: AnyEntity) => entity is AnyObj;
136
206
  /**
137
- * Type guard to check if a schema is a relation schema.
138
- * NOTE: This checks SCHEMAS, not instances. Use Relation.isRelation for instances.
207
+ * Type guard: narrows a `Type.AnyEntity` to a relation-kind entity. Checks
208
+ * ENTITIES, not instances use `Relation.isRelation` for instances.
139
209
  */
140
- export declare const isRelationSchema: (schema: AnyEntity) => schema is AnyRelation;
210
+ export declare const isRelation: (entity: AnyEntity) => entity is AnyRelation;
211
+ /**
212
+ * Type guard: narrows a `Type.AnyEntity` to the type-kind meta-schema
213
+ * (e.g. `Type.Type`). Mirrors {@link isObject} / {@link isRelation}.
214
+ */
215
+ export declare const isTypeKind: (entity: AnyEntity) => entity is Type;
216
+ /**
217
+ * Narrow a `Type.AnyEntity` (e.g. one returned from `schemaRegistry.query(...)`)
218
+ * to `AnyObj`, throwing if it describes a relation or the type-kind
219
+ * meta-schema. Use at call sites that need to pass the value to `Obj.make`,
220
+ * `Filter.type`, or other object-only APIs.
221
+ */
222
+ export declare const assertObject: (entity: AnyEntity) => AnyObj;
223
+ /** Narrow a `Type.AnyEntity` to `AnyRelation`, throwing otherwise. */
224
+ export declare const expectRelation: (entity: AnyEntity) => AnyRelation;
225
+ /** Narrow a `Type.AnyEntity` to the `Type.Type` meta-schema, throwing otherwise. */
226
+ export declare const expectTypeKind: (entity: AnyEntity) => Type;
141
227
  /**
142
228
  * Type that represents any Ref schema (with unknown target type).
143
229
  * This is a schema type, not an instance type.
144
230
  */
145
231
  export type AnyRef = Schema.Schema<internal.Ref<any>, EncodedReference>;
146
232
  /**
147
- * Gets the full DXN of the schema.
148
- * Will include the version if it's a `type` DXN.
149
- * @example "dxn:com.example.type.person:0.1.0"
150
- * @example "dxn:echo:SSSSSSSSSS:XXXXXXXXXXXXX"
233
+ * Returns the URI identifying a type entity. Always defined.
234
+ *
235
+ * - Static `Type.Obj` / `Type.Relation` → typename DXN (e.g. `dxn:com.example.type.person:0.1.0`).
236
+ * - Persisted `Type.Type` instance (has `id`) → local `EID` (`echo:/<objectId>`).
237
+ * - In-memory `Type.Type` draft (has `id`, no typename) → local `EID`.
238
+ *
239
+ * Only accepts `Type.AnyEntity` entities. Raw `Schema.Schema` values and the
240
+ * branded `Obj.Unknown` / `Relation.Unknown` schemas are intentionally not
241
+ * supported — use `internal.getSchemaURI` or the schema's typename annotation
242
+ * directly when working at the schema level.
151
243
  */
152
- export declare const getDXN: (schema: AnyEntity) => DXN | undefined;
244
+ export declare const getURI: (input: AnyEntity) => URI.URI;
153
245
  /**
154
- * @param schema - Schema to get the typename from.
155
- * @returns The typename of the schema. Example: `com.example.type.person`.
246
+ * @returns The typename. Example: `com.example.type.person`.
247
+ *
248
+ * Persisted `Type.Type` entities carry typename in `EntityMeta.key` (the
249
+ * canonical registry-provenance field); unnamed drafts fall back to the
250
+ * entity's object id so the helper always returns a string. Any `dxn:` or
251
+ * `echo:/` prefix is stripped — typename is a bare identifier, not a URI.
156
252
  */
157
- export declare const getTypename: (schema: AnyEntity) => string;
253
+ export declare const getTypename: (input: AnyEntity) => string;
158
254
  /**
159
- * Gets the version of the schema.
255
+ * Gets the version.
160
256
  * @example 0.1.0
257
+ * @example 0.1.0-<heads> (in-database, versioned by automerge heads)
258
+ *
259
+ * The registry-provenance semver lives in `EntityMeta.version`; unversioned
260
+ * drafts default to {@link DRAFT_VERSION} (`'0.0.0'`). In-database entities are
261
+ * additionally versioned by their automerge heads, which are exposed as the
262
+ * semver pre-release tag (`<semver>-<heads>`). In-memory declarations have no
263
+ * heads and surface the bare semver. Read the registry semver alone via
264
+ * `Type.getMeta(input).version`.
265
+ */
266
+ export declare const getVersion: (input: AnyEntity) => string;
267
+ /**
268
+ * Type predicate: true iff the value is any type-kind ECHO entity — a static
269
+ * `Type.Obj` / `Type.Relation` produced by `Type.makeObject` / `Type.makeRelation`, a
270
+ * static meta `Type.Type`, or a persisted `Type.Type` returned by the database.
271
+ *
272
+ * All three branches stamp `[KindId] = Type`, so this is a single brand check.
273
+ * Use {@link isObject} / {@link isRelation} / {@link isTypeKind}
274
+ * when you need to discriminate further; use {@link getDatabase} when you mean
275
+ * "is this a db-attached type" (vs. an in-memory declaration).
276
+ */
277
+ export declare const isType: (value: unknown) => value is AnyEntity;
278
+ /**
279
+ * Get the database the type entity belongs to, or `undefined` if it is an
280
+ * in-memory declaration (`Type.makeObject` / `Type.makeRelation` result) not
281
+ * yet attached to a database. Mirrors `Obj.getDatabase` / `Relation.getDatabase`.
282
+ *
283
+ * Database attachment is the canonical discriminator between in-memory and
284
+ * in-database type entities — both are live reactive `TypeSchema` instances and
285
+ * are otherwise indistinguishable.
286
+ */
287
+ export declare const getDatabase: (input: AnyEntity) => Database.Database | undefined;
288
+ /**
289
+ * Mutable meta type returned by `Type.getMeta` inside a `Type.update` callback.
290
+ * Mirrors `Obj.Meta` / `Relation.Meta` — `Type.Type` is an Entity like its
291
+ * siblings, so its meta is the same `EntityMeta` record:
292
+ * `{ keys, tags?, key?, version? }`.
293
+ *
294
+ * `key` / `version` here are the canonical registry-provenance pair
295
+ * (typename + semver) on persisted Type.Type entities; they are absent on
296
+ * unnamed drafts. Use {@link getTypename} / {@link getVersion} when you want
297
+ * a non-`undefined` value with id / {@link DRAFT_VERSION} fallbacks.
298
+ */
299
+ export type Meta = internal.Meta;
300
+ /**
301
+ * Deeply read-only version of {@link Meta}.
302
+ * Prevents mutation at all nesting levels (e.g., `meta.keys.push()` is a TS error).
303
+ */
304
+ export type ReadonlyMeta = internal.ReadonlyMeta;
305
+ /**
306
+ * Returns the entity's `EntityMeta`. Same semantics as `Obj.getMeta` /
307
+ * `Relation.getMeta` — `Type.Type` is an Entity and carries the canonical
308
+ * `EntityMeta` directly. Returns mutable meta when passed a mutable type
309
+ * (inside a `Type.update` callback), read-only meta otherwise.
310
+ *
311
+ * For persisted Type entities, `meta.key` holds the typename and
312
+ * `meta.version` holds the semver. Use {@link getTypename} / {@link getVersion}
313
+ * if you want the helpers' id / {@link DRAFT_VERSION} fallbacks for drafts.
314
+ *
315
+ * Both persisted and in-memory type entities (`Type.makeObject` /
316
+ * `Type.makeRelation` results) carry their `EntityMeta` via `[MetaId]`, so the
317
+ * lookup is uniform.
318
+ */
319
+ export declare function getMeta(entity: internal.Mutable<AnyEntity>): Meta;
320
+ export declare function getMeta(entity: Mutable): Meta;
321
+ export declare function getMeta(entity: AnyEntity): ReadonlyMeta;
322
+ /**
323
+ * Get the display label of a type entity.
324
+ * Reads the field(s) nominated by the type's {@link LabelAnnotation} (e.g. `name` on persisted schemas).
325
+ * Returns `undefined` if no label field is populated.
326
+ */
327
+ export declare const getLabel: (entity: AnyEntity, options?: internal.GetLabelOptions) => string | undefined;
328
+ /**
329
+ * String key used to phantom-carry the instance type produced by a `Type.Type`.
330
+ * Used by `Type.InstanceType<typeof Foo>` to recover the schema instance type
331
+ * since `Type.makeObject(dxn)` does not return a `Schema.Schema`.
332
+ *
333
+ * Re-exported from the internal types layer so both `Type.ts` and internal
334
+ * helpers (`makeObject`, `createObject`) reference the same phantom key.
335
+ */
336
+ export declare const InstancePhantomId: "~@dxos/echo/Type.Instance";
337
+ export type InstancePhantomId = internal.InstancePhantomId;
338
+ /**
339
+ * Sibling of {@link Obj} / {@link Relation} for the third ECHO entity kind:
340
+ * **type-kind** entities (meta-schemas). The singleton {@link Type} const is
341
+ * the canonical example — it describes stored type definitions themselves.
342
+ *
343
+ * Not a `Schema.Schema`. Use `Type.getSchema(value)` to obtain the underlying
344
+ * Effect Schema and `Type.update(value, draft => ...)` to mutate.
345
+ *
346
+ * `A` is the instance-type phantom — what `Obj.make(value, ...)` would produce.
347
+ * Merged with the `Type` const value via TypeScript declaration merging.
348
+ */
349
+ export interface Type<A = unknown> extends BaseTypeEntity<A & EntityModule.OfKind<typeof EntityModule.Kind.Type>> {
350
+ /** Schema-kind brand (type — the meta-schema kind). */
351
+ readonly [internal.SchemaKindId]: internal.EntityKind.Type;
352
+ /** Source Effect Schema — used internally by `Type.getSchema(self)`. */
353
+ readonly [internal.StaticTypeSchemaSlot]: Schema.Schema.AnyNoContext;
354
+ }
355
+ /**
356
+ * Instance type produced by a Type entity.
357
+ *
358
+ * Accepts ONLY {@link AnyEntity} inputs — `Type.Obj`, `Type.Relation`, or
359
+ * `Type.Type`. Raw Effect `Schema.Schema` values are rejected: for those, use
360
+ * `Schema.Schema.Type<typeof Foo>` directly. This separation keeps the type
361
+ * system honest about which values represent ECHO entities versus plain
362
+ * Effect schemas.
363
+ *
364
+ * Dispatches on the entity kind:
365
+ * - `Relation<Props, S, T>` → `Endpoints<S,T> & Props & OfKind<Relation>`
366
+ * - `Obj<A>` → `A & OfKind<Object>`
367
+ * - `Type<A>` → `A & OfKind<Type>`
368
+ */
369
+ export type InstanceType<T extends AnyEntity> = T extends Relation<infer Props, infer Source, infer Target, any> ? RelationModule.Endpoints<Source, Target> & Props & EntityModule.OfKind<typeof EntityModule.Kind.Relation> : T extends Obj<infer A, any> ? A & EntityModule.OfKind<typeof EntityModule.Kind.Object> : T extends Type<infer A> ? A & EntityModule.OfKind<typeof EntityModule.Kind.Type> : never;
370
+ /**
371
+ * Returns the Effect Schema for a type entity.
372
+ *
373
+ * - For static `Type.Obj` / `Type.Relation` entities the source Effect Schema is
374
+ * read from a hidden slot — these overloads preserve the instance type.
375
+ * - For `Type.Type` entities (the meta-schema kind) the schema is rebuilt from
376
+ * `type.jsonSchema`; the instance type isn't statically knowable so the wide
377
+ * `AnyEntity` overload widens to `Schema.Schema.AnyNoContext`.
378
+ *
379
+ * Always call this when you need to interact with the Effect Schema API
380
+ * (e.g. before passing to Effect.Schema functions). For ECHO-side APIs
381
+ * (`Obj.make`, `Filter.type`, `Ref`) pass the type entity directly.
382
+ *
383
+ * Only accepts `Type.AnyEntity` — raw `Schema.Schema` values can be used
384
+ * directly without unwrapping.
385
+ */
386
+ export declare function getSchema<T extends AnyObj>(type: T): Schema.Schema<InstanceType<T>>;
387
+ export declare function getSchema<T extends AnyRelation>(type: T): Schema.Schema<InstanceType<T>>;
388
+ export declare function getSchema(type: AnyEntity): Schema.Schema.AnyNoContext;
389
+ /**
390
+ * Mutable view of a `Type.Type` — the shape passed to the `Type.update` callback.
391
+ * Outside `Type.update`, `Type.Type` fields are read-only (both at the type level
392
+ * and at runtime — direct assignment throws). Use this to constrain mutation to
393
+ * the change context, analogous to `Obj.update(obj, (draft) => ...)`.
394
+ *
395
+ * NOTE: `typename` and `version` are intentionally absent — they live in
396
+ * `EntityMeta` (`key` / `version` — the canonical registry-provenance pair).
397
+ * Read them via {@link getTypename} / {@link getVersion} / {@link getMeta};
398
+ * `typename` is treated as immutable on persisted entities.
399
+ *
400
+ * Unlike `Obj.update` — whose mutable view is inferred as `Mutable<A>` over the
401
+ * whole instance type because every data field is editable — a `Type.Type`
402
+ * exposes only `name` and `jsonSchema` for mutation. The rest of its shape
403
+ * (`id`, the `[KindId]` / `[SchemaKindId]` brands, and `typename` / `version`
404
+ * in meta) is immutable, so this view is declared explicitly rather than
405
+ * derived from `InstanceType<Type.Type>`.
406
+ */
407
+ export interface Mutable {
408
+ name?: string;
409
+ jsonSchema: Types.DeepMutable<internal.JsonSchemaType>;
410
+ }
411
+ /**
412
+ * Perform mutations on a `Type.Type` within a change context.
413
+ *
414
+ * The callback receives a {@link Mutable} view of the type — direct mutation of
415
+ * a `Type.Type` outside `Type.update` throws at runtime, mirroring `Obj.update`.
416
+ * Delegates to the same automerge-transaction primitive `Obj.update(obj, cb)` uses.
417
+ */
418
+ export declare const update: (type: AnyEntity, callback: (mutable: Mutable) => void) => void;
419
+ /**
420
+ * Add fields to a persisted type's schema.
421
+ * @throws if the type is not persisted.
161
422
  */
162
- export declare const getVersion: (schema: AnyEntity) => string;
423
+ export declare const addFields: (type: AnyEntity, fields: Schema.Struct.Fields) => void;
163
424
  /**
164
- * @returns True if the schema is mutable.
425
+ * Replace existing fields on a persisted type's schema.
426
+ * @throws if the type is not persisted.
165
427
  */
166
- export declare const isMutable: (schema: Schema.Schema.AnyNoContext) => schema is internal.EchoSchema;
428
+ export declare const updateFields: (type: AnyEntity, fields: Schema.Struct.Fields) => void;
167
429
  /**
168
- * ECHO type metadata.
430
+ * Rename a field on a persisted type's schema.
431
+ * @throws if the type is not persisted.
169
432
  */
170
- export type Meta = internal.TypeAnnotation;
433
+ export declare const updateFieldPropertyName: (type: Type, { before, after }: {
434
+ before: PropertyKey;
435
+ after: PropertyKey;
436
+ }) => void;
171
437
  /**
172
- * Gets the meta data of the schema.
438
+ * Remove fields from a persisted type's schema.
439
+ * @throws if the type is not persisted.
173
440
  */
174
- export declare const getMeta: (schema: AnyEntity) => Meta | undefined;
441
+ export declare const removeFields: (type: AnyEntity, fieldNames: string[]) => void;
175
442
  export {};
176
443
  //# sourceMappingURL=Type.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"Type.d.ts","sourceRoot":"","sources":["../../../src/Type.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"Type.d.ts","sourceRoot":"","sources":["../../../src/Type.ts"],"names":[],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  import * as Schema from 'effect/Schema';
2
2
  import { QueryAST } from '@dxos/echo-protocol';
3
- import { JsonPath } from '@dxos/effect';
3
+ import { SchemaEx } from '@dxos/effect';
4
4
  import * as internal from './internal';
5
5
  import * as Obj from './Obj';
6
6
  import * as Type from './Type';
@@ -9,9 +9,9 @@ import * as Type from './Type';
9
9
  */
10
10
  export declare const FieldSchema: Schema.Struct<{
11
11
  id: typeof Schema.String;
12
- path: Schema.Schema<JsonPath, JsonPath, never>;
12
+ path: Schema.Schema<SchemaEx.JsonPath, SchemaEx.JsonPath, never>;
13
13
  visible: Schema.optional<typeof Schema.Boolean>;
14
- referencePath: Schema.optional<Schema.Schema<JsonPath, JsonPath, never>>;
14
+ referencePath: Schema.optional<Schema.Schema<SchemaEx.JsonPath, SchemaEx.JsonPath, never>>;
15
15
  }>;
16
16
  export type FieldType = Schema.Schema.Type<typeof FieldSchema>;
17
17
  export declare const KeyValueProps: Schema.Record$<typeof Schema.String, typeof Schema.Any>;
@@ -26,9 +26,9 @@ export declare const Projection: Schema.Struct<{
26
26
  */
27
27
  fields: Schema.Array$<Schema.Struct<{
28
28
  id: typeof Schema.String;
29
- path: Schema.Schema<JsonPath, JsonPath, never>;
29
+ path: Schema.Schema<SchemaEx.JsonPath, SchemaEx.JsonPath, never>;
30
30
  visible: Schema.optional<typeof Schema.Boolean>;
31
- referencePath: Schema.optional<Schema.Schema<JsonPath, JsonPath, never>>;
31
+ referencePath: Schema.optional<Schema.Schema<SchemaEx.JsonPath, SchemaEx.JsonPath, never>>;
32
32
  }>>;
33
33
  /**
34
34
  * The id for the field used to pivot the view.
@@ -43,25 +43,22 @@ export type Projection = Schema.Schema.Type<typeof Projection>;
43
43
  */
44
44
  declare const ViewSchema: Type.Obj<{
45
45
  readonly query: {
46
- readonly ast: QueryAST.QuerySelectClause | QueryAST.QueryFilterClause | QueryAST.QueryReferenceTraversalClause | QueryAST.QueryIncomingReferencesClause | QueryAST.QueryRelationClause | QueryAST.QueryRelationTraversalClause | QueryAST.QueryHierarchyTraversalClause | QueryAST.QueryUnionClause | QueryAST.QuerySetDifferenceClause | QueryAST.QueryOrderClause | QueryAST.QueryOptionsClause | QueryAST.QueryLimitClause | QueryAST.QueryFromClause;
47
46
  readonly raw?: string | undefined;
47
+ readonly ast: QueryAST.QueryFilterClause | QueryAST.QueryFromClause | QueryAST.QueryHierarchyTraversalClause | QueryAST.QueryIncomingReferencesClause | QueryAST.QueryLimitClause | QueryAST.QueryOptionsClause | QueryAST.QueryOrderClause | QueryAST.QueryReferenceTraversalClause | QueryAST.QueryRelationClause | QueryAST.QueryRelationTraversalClause | QueryAST.QuerySelectClause | QueryAST.QuerySetDifferenceClause | QueryAST.QueryUnionClause;
48
48
  };
49
49
  readonly projection: {
50
50
  readonly schema?: internal.JsonSchemaType | undefined;
51
51
  readonly fields: readonly {
52
52
  readonly id: string;
53
- readonly path: JsonPath;
53
+ readonly path: SchemaEx.JsonPath;
54
54
  readonly visible?: boolean | undefined;
55
- readonly referencePath?: JsonPath | undefined;
55
+ readonly referencePath?: SchemaEx.JsonPath | undefined;
56
56
  }[];
57
57
  readonly pivotFieldId?: string | undefined;
58
58
  };
59
59
  }, Schema.Struct.Fields>;
60
- export interface View extends Schema.Schema.Type<typeof ViewSchema> {
60
+ export interface View extends Type.InstanceType<typeof ViewSchema> {
61
61
  }
62
- /**
63
- * View instance type.
64
- */
65
62
  export declare const View: Type.Obj<View>;
66
63
  export declare const make: (props: Partial<Obj.MakeProps<typeof View>>) => View;
67
64
  export {};