@dxos/echo 0.8.4-main.a4bbb77 → 0.8.4-main.abd8ff62ef

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 (539) hide show
  1. package/README.md +3 -4
  2. package/dist/lib/neutral/Annotation.mjs +37 -0
  3. package/dist/lib/neutral/Database.mjs +49 -0
  4. package/dist/lib/neutral/Entity.mjs +61 -0
  5. package/dist/lib/neutral/Entity.mjs.map +7 -0
  6. package/dist/lib/neutral/Err.mjs +12 -0
  7. package/dist/lib/neutral/Err.mjs.map +7 -0
  8. package/dist/lib/neutral/Extension.mjs +18 -0
  9. package/dist/lib/neutral/Extension.mjs.map +7 -0
  10. package/dist/lib/neutral/Feed.mjs +50 -0
  11. package/dist/lib/neutral/Feed.mjs.map +7 -0
  12. package/dist/lib/neutral/Filter.mjs +72 -0
  13. package/dist/lib/neutral/Filter.mjs.map +7 -0
  14. package/dist/lib/neutral/Format.mjs +66 -0
  15. package/dist/lib/neutral/Format.mjs.map +7 -0
  16. package/dist/lib/neutral/JsonSchema.mjs +19 -0
  17. package/dist/lib/neutral/JsonSchema.mjs.map +7 -0
  18. package/dist/lib/neutral/Key.mjs +12 -0
  19. package/dist/lib/neutral/Key.mjs.map +7 -0
  20. package/dist/lib/neutral/Migration.mjs +17 -0
  21. package/dist/lib/neutral/Migration.mjs.map +7 -0
  22. package/dist/lib/neutral/Obj.mjs +113 -0
  23. package/dist/lib/neutral/Obj.mjs.map +7 -0
  24. package/dist/lib/neutral/Order.mjs +12 -0
  25. package/dist/lib/neutral/Order.mjs.map +7 -0
  26. package/dist/lib/neutral/Query.mjs +38 -0
  27. package/dist/lib/neutral/Query.mjs.map +7 -0
  28. package/dist/lib/neutral/QueryResult.mjs +2 -0
  29. package/dist/lib/neutral/QueryResult.mjs.map +7 -0
  30. package/dist/lib/neutral/Ref.mjs +24 -0
  31. package/dist/lib/neutral/Ref.mjs.map +7 -0
  32. package/dist/lib/neutral/Relation.mjs +94 -0
  33. package/dist/lib/neutral/Relation.mjs.map +7 -0
  34. package/dist/lib/neutral/SchemaRegistry.mjs +2 -0
  35. package/dist/lib/neutral/SchemaRegistry.mjs.map +7 -0
  36. package/dist/lib/neutral/Tag.mjs +29 -0
  37. package/dist/lib/neutral/Tag.mjs.map +7 -0
  38. package/dist/lib/neutral/Type.mjs +37 -0
  39. package/dist/lib/neutral/Type.mjs.map +7 -0
  40. package/dist/lib/neutral/chunk-2T22UGGN.mjs +206 -0
  41. package/dist/lib/neutral/chunk-2T22UGGN.mjs.map +7 -0
  42. package/dist/lib/neutral/chunk-44HT3MEC.mjs +73 -0
  43. package/dist/lib/neutral/chunk-44HT3MEC.mjs.map +7 -0
  44. package/dist/lib/neutral/chunk-6VC3FI5E.mjs +125 -0
  45. package/dist/lib/neutral/chunk-6VC3FI5E.mjs.map +7 -0
  46. package/dist/lib/neutral/chunk-7JFW72MX.mjs +132 -0
  47. package/dist/lib/neutral/chunk-7JFW72MX.mjs.map +7 -0
  48. package/dist/lib/neutral/chunk-7RVZT53K.mjs +21 -0
  49. package/dist/lib/neutral/chunk-7RVZT53K.mjs.map +7 -0
  50. package/dist/lib/neutral/chunk-BICZKPQG.mjs +7 -0
  51. package/dist/lib/neutral/chunk-BICZKPQG.mjs.map +7 -0
  52. package/dist/lib/neutral/chunk-CIWZ5MHQ.mjs +36 -0
  53. package/dist/lib/neutral/chunk-CIWZ5MHQ.mjs.map +7 -0
  54. package/dist/lib/neutral/chunk-DUNXPKAC.mjs +56 -0
  55. package/dist/lib/neutral/chunk-DUNXPKAC.mjs.map +7 -0
  56. package/dist/lib/neutral/chunk-FAW7PJRO.mjs +34 -0
  57. package/dist/lib/neutral/chunk-FAW7PJRO.mjs.map +7 -0
  58. package/dist/lib/neutral/chunk-FAYW32CW.mjs +27 -0
  59. package/dist/lib/neutral/chunk-FAYW32CW.mjs.map +7 -0
  60. package/dist/lib/neutral/chunk-GWFFC34K.mjs +50 -0
  61. package/dist/lib/neutral/chunk-GWFFC34K.mjs.map +7 -0
  62. package/dist/lib/neutral/chunk-I2MFJ76N.mjs +354 -0
  63. package/dist/lib/neutral/chunk-I2MFJ76N.mjs.map +7 -0
  64. package/dist/lib/neutral/chunk-J5LGTIGS.mjs +10 -0
  65. package/dist/lib/neutral/chunk-J5LGTIGS.mjs.map +7 -0
  66. package/dist/lib/neutral/chunk-JALF2CVV.mjs +345 -0
  67. package/dist/lib/neutral/chunk-JALF2CVV.mjs.map +7 -0
  68. package/dist/lib/neutral/chunk-KQUQZ3CB.mjs +128 -0
  69. package/dist/lib/neutral/chunk-KQUQZ3CB.mjs.map +7 -0
  70. package/dist/lib/neutral/chunk-LOTZLYHB.mjs +420 -0
  71. package/dist/lib/neutral/chunk-LOTZLYHB.mjs.map +7 -0
  72. package/dist/lib/neutral/chunk-N4B7FHQT.mjs +67 -0
  73. package/dist/lib/neutral/chunk-N4B7FHQT.mjs.map +7 -0
  74. package/dist/lib/neutral/chunk-NKXEKBP5.mjs +81 -0
  75. package/dist/lib/neutral/chunk-NKXEKBP5.mjs.map +7 -0
  76. package/dist/lib/neutral/chunk-NSMLBSFS.mjs +270 -0
  77. package/dist/lib/neutral/chunk-NSMLBSFS.mjs.map +7 -0
  78. package/dist/lib/neutral/chunk-QBIGOSRF.mjs +45 -0
  79. package/dist/lib/neutral/chunk-QBIGOSRF.mjs.map +7 -0
  80. package/dist/lib/neutral/chunk-QBLYZ4IV.mjs +734 -0
  81. package/dist/lib/neutral/chunk-QBLYZ4IV.mjs.map +7 -0
  82. package/dist/lib/neutral/chunk-QEVM3JUP.mjs +318 -0
  83. package/dist/lib/neutral/chunk-QEVM3JUP.mjs.map +7 -0
  84. package/dist/lib/neutral/chunk-REP7WWAQ.mjs +346 -0
  85. package/dist/lib/neutral/chunk-REP7WWAQ.mjs.map +7 -0
  86. package/dist/lib/neutral/chunk-TRPZU2HV.mjs +402 -0
  87. package/dist/lib/neutral/chunk-TRPZU2HV.mjs.map +7 -0
  88. package/dist/lib/neutral/chunk-TTCSATUD.mjs +42 -0
  89. package/dist/lib/neutral/chunk-TTCSATUD.mjs.map +7 -0
  90. package/dist/lib/neutral/chunk-TW76K7H5.mjs +45 -0
  91. package/dist/lib/neutral/chunk-TW76K7H5.mjs.map +7 -0
  92. package/dist/lib/neutral/chunk-UYJYDSD7.mjs +2436 -0
  93. package/dist/lib/neutral/chunk-UYJYDSD7.mjs.map +7 -0
  94. package/dist/lib/neutral/chunk-V72DY6LU.mjs +7 -0
  95. package/dist/lib/neutral/chunk-V72DY6LU.mjs.map +7 -0
  96. package/dist/lib/neutral/chunk-ZISMEVKD.mjs +51 -0
  97. package/dist/lib/neutral/chunk-ZISMEVKD.mjs.map +7 -0
  98. package/dist/lib/neutral/index.mjs +107 -0
  99. package/dist/lib/neutral/index.mjs.map +7 -0
  100. package/dist/lib/neutral/internal/index.mjs +474 -0
  101. package/dist/lib/neutral/internal/index.mjs.map +7 -0
  102. package/dist/lib/neutral/meta.json +1 -0
  103. package/dist/lib/neutral/testing/index.mjs +375 -0
  104. package/dist/lib/neutral/testing/index.mjs.map +7 -0
  105. package/dist/types/src/Annotation.d.ts +24 -0
  106. package/dist/types/src/Annotation.d.ts.map +1 -0
  107. package/dist/types/src/Collection.d.ts +16 -0
  108. package/dist/types/src/Collection.d.ts.map +1 -0
  109. package/dist/types/src/Database.d.ts +201 -0
  110. package/dist/types/src/Database.d.ts.map +1 -0
  111. package/dist/types/src/Dataset.d.ts +19 -0
  112. package/dist/types/src/Dataset.d.ts.map +1 -0
  113. package/dist/types/src/Entity.d.ts +174 -0
  114. package/dist/types/src/Entity.d.ts.map +1 -0
  115. package/dist/types/src/Entity.test.d.ts +2 -0
  116. package/dist/types/src/Entity.test.d.ts.map +1 -0
  117. package/dist/types/src/Err.d.ts +107 -0
  118. package/dist/types/src/Err.d.ts.map +1 -0
  119. package/dist/types/src/Extension.d.ts +80 -0
  120. package/dist/types/src/Extension.d.ts.map +1 -0
  121. package/dist/types/src/Extension.test.d.ts +2 -0
  122. package/dist/types/src/Extension.test.d.ts.map +1 -0
  123. package/dist/types/src/Feed.d.ts +182 -0
  124. package/dist/types/src/Feed.d.ts.map +1 -0
  125. package/dist/types/src/Filter.d.ts +149 -0
  126. package/dist/types/src/Filter.d.ts.map +1 -0
  127. package/dist/types/src/Filter.test.d.ts +2 -0
  128. package/dist/types/src/Filter.test.d.ts.map +1 -0
  129. package/dist/types/src/Format.d.ts +4 -0
  130. package/dist/types/src/Format.d.ts.map +1 -0
  131. package/dist/types/src/Hypergraph.d.ts +65 -0
  132. package/dist/types/src/Hypergraph.d.ts.map +1 -0
  133. package/dist/types/src/Json.d.ts +33 -0
  134. package/dist/types/src/Json.d.ts.map +1 -0
  135. package/dist/types/src/Json.test.d.ts +2 -0
  136. package/dist/types/src/Json.test.d.ts.map +1 -0
  137. package/dist/types/src/JsonSchema.d.ts +16 -0
  138. package/dist/types/src/JsonSchema.d.ts.map +1 -0
  139. package/dist/types/src/Key.d.ts +1 -0
  140. package/dist/types/src/Key.d.ts.map +1 -1
  141. package/dist/types/src/Migration.d.ts +57 -0
  142. package/dist/types/src/Migration.d.ts.map +1 -0
  143. package/dist/types/src/Obj.d.ts +442 -98
  144. package/dist/types/src/Obj.d.ts.map +1 -1
  145. package/dist/types/src/Obj.test.d.ts +2 -0
  146. package/dist/types/src/Obj.test.d.ts.map +1 -0
  147. package/dist/types/src/Order.d.ts +16 -0
  148. package/dist/types/src/Order.d.ts.map +1 -0
  149. package/dist/types/src/Query.d.ts +213 -0
  150. package/dist/types/src/Query.d.ts.map +1 -0
  151. package/dist/types/src/Query.test.d.ts +2 -0
  152. package/dist/types/src/Query.test.d.ts.map +1 -0
  153. package/dist/types/src/QueryResult.d.ts +80 -0
  154. package/dist/types/src/QueryResult.d.ts.map +1 -0
  155. package/dist/types/src/Ref.d.ts +61 -11
  156. package/dist/types/src/Ref.d.ts.map +1 -1
  157. package/dist/types/src/Relation.d.ts +288 -22
  158. package/dist/types/src/Relation.d.ts.map +1 -1
  159. package/dist/types/src/Relation.test.d.ts +2 -0
  160. package/dist/types/src/Relation.test.d.ts.map +1 -0
  161. package/dist/types/src/SchemaRegistry.d.ts +84 -0
  162. package/dist/types/src/SchemaRegistry.d.ts.map +1 -0
  163. package/dist/types/src/Tag.d.ts +18 -0
  164. package/dist/types/src/Tag.d.ts.map +1 -0
  165. package/dist/types/src/Type.d.ts +123 -100
  166. package/dist/types/src/Type.d.ts.map +1 -1
  167. package/dist/types/src/Type.test.d.ts +2 -0
  168. package/dist/types/src/Type.test.d.ts.map +1 -0
  169. package/dist/types/src/View.d.ts +68 -0
  170. package/dist/types/src/View.d.ts.map +1 -0
  171. package/dist/types/src/hierarchy.test.d.ts +2 -0
  172. package/dist/types/src/hierarchy.test.d.ts.map +1 -0
  173. package/dist/types/src/index.d.ts +22 -5
  174. package/dist/types/src/index.d.ts.map +1 -1
  175. package/dist/types/src/internal/Annotation/annotations.d.ts +231 -0
  176. package/dist/types/src/internal/Annotation/annotations.d.ts.map +1 -0
  177. package/dist/types/src/internal/Annotation/annotations.test.d.ts +2 -0
  178. package/dist/types/src/internal/Annotation/annotations.test.d.ts.map +1 -0
  179. package/dist/types/src/internal/Annotation/index.d.ts +4 -0
  180. package/dist/types/src/internal/Annotation/index.d.ts.map +1 -0
  181. package/dist/types/src/internal/Annotation/sorting.d.ts +24 -0
  182. package/dist/types/src/internal/Annotation/sorting.d.ts.map +1 -0
  183. package/dist/types/src/internal/Annotation/util.d.ts +39 -0
  184. package/dist/types/src/internal/Annotation/util.d.ts.map +1 -0
  185. package/dist/types/src/internal/Entity/api.d.ts +13 -0
  186. package/dist/types/src/internal/Entity/api.d.ts.map +1 -0
  187. package/dist/types/src/internal/Entity/entity.d.ts +20 -0
  188. package/dist/types/src/internal/Entity/entity.d.ts.map +1 -0
  189. package/dist/types/src/internal/Entity/index.d.ts +8 -0
  190. package/dist/types/src/internal/Entity/index.d.ts.map +1 -0
  191. package/dist/types/src/internal/Entity/model.d.ts +55 -0
  192. package/dist/types/src/internal/Entity/model.d.ts.map +1 -0
  193. package/dist/types/src/internal/Entity/object.d.ts +18 -0
  194. package/dist/types/src/internal/Entity/object.d.ts.map +1 -0
  195. package/dist/types/src/internal/Entity/relation.d.ts +35 -0
  196. package/dist/types/src/internal/Entity/relation.d.ts.map +1 -0
  197. package/dist/types/src/internal/Entity/util.d.ts +2 -0
  198. package/dist/types/src/internal/Entity/util.d.ts.map +1 -0
  199. package/dist/types/src/internal/Entity/version.d.ts +42 -0
  200. package/dist/types/src/internal/Entity/version.d.ts.map +1 -0
  201. package/dist/types/src/internal/Format/date.d.ts +63 -0
  202. package/dist/types/src/internal/Format/date.d.ts.map +1 -0
  203. package/dist/types/src/internal/Format/date.test.d.ts +2 -0
  204. package/dist/types/src/internal/Format/date.test.d.ts.map +1 -0
  205. package/dist/types/src/internal/Format/format.d.ts +32 -0
  206. package/dist/types/src/internal/Format/format.d.ts.map +1 -0
  207. package/dist/types/src/internal/Format/format.test.d.ts +2 -0
  208. package/dist/types/src/internal/Format/format.test.d.ts.map +1 -0
  209. package/dist/types/src/internal/Format/index.d.ts +8 -0
  210. package/dist/types/src/internal/Format/index.d.ts.map +1 -0
  211. package/dist/types/src/internal/Format/number.d.ts +31 -0
  212. package/dist/types/src/internal/Format/number.d.ts.map +1 -0
  213. package/dist/types/src/internal/Format/object.d.ts +35 -0
  214. package/dist/types/src/internal/Format/object.d.ts.map +1 -0
  215. package/dist/types/src/internal/Format/select.d.ts +13 -0
  216. package/dist/types/src/internal/Format/select.d.ts.map +1 -0
  217. package/dist/types/src/internal/Format/string.d.ts +42 -0
  218. package/dist/types/src/internal/Format/string.d.ts.map +1 -0
  219. package/dist/types/src/internal/Format/types.d.ts +72 -0
  220. package/dist/types/src/internal/Format/types.d.ts.map +1 -0
  221. package/dist/types/src/internal/JsonSchema/annotations.d.ts +19 -0
  222. package/dist/types/src/internal/JsonSchema/annotations.d.ts.map +1 -0
  223. package/dist/types/src/internal/JsonSchema/effect-schema.test.d.ts +2 -0
  224. package/dist/types/src/internal/JsonSchema/effect-schema.test.d.ts.map +1 -0
  225. package/dist/types/src/internal/JsonSchema/index.d.ts +5 -0
  226. package/dist/types/src/internal/JsonSchema/index.d.ts.map +1 -0
  227. package/dist/types/src/internal/JsonSchema/json-schema-normalize.d.ts +7 -0
  228. package/dist/types/src/internal/JsonSchema/json-schema-normalize.d.ts.map +1 -0
  229. package/dist/types/src/internal/JsonSchema/json-schema-type.d.ts +351 -0
  230. package/dist/types/src/internal/JsonSchema/json-schema-type.d.ts.map +1 -0
  231. package/dist/types/src/internal/JsonSchema/json-schema.d.ts +30 -0
  232. package/dist/types/src/internal/JsonSchema/json-schema.d.ts.map +1 -0
  233. package/dist/types/src/internal/JsonSchema/json-schema.test.d.ts +2 -0
  234. package/dist/types/src/internal/JsonSchema/json-schema.test.d.ts.map +1 -0
  235. package/dist/types/src/internal/Obj/clone.d.ts +8 -0
  236. package/dist/types/src/internal/Obj/clone.d.ts.map +1 -0
  237. package/dist/types/src/internal/Obj/common.d.ts +18 -0
  238. package/dist/types/src/internal/Obj/common.d.ts.map +1 -0
  239. package/dist/types/src/internal/Obj/create-object.d.ts +39 -0
  240. package/dist/types/src/internal/Obj/create-object.d.ts.map +1 -0
  241. package/dist/types/src/internal/Obj/create-object.test.d.ts +2 -0
  242. package/dist/types/src/internal/Obj/create-object.test.d.ts.map +1 -0
  243. package/dist/types/src/internal/Obj/deleted.d.ts +6 -0
  244. package/dist/types/src/internal/Obj/deleted.d.ts.map +1 -0
  245. package/dist/types/src/internal/Obj/ids.d.ts +6 -0
  246. package/dist/types/src/internal/Obj/ids.d.ts.map +1 -0
  247. package/dist/types/src/internal/Obj/index.d.ts +11 -0
  248. package/dist/types/src/internal/Obj/index.d.ts.map +1 -0
  249. package/dist/types/src/internal/Obj/inspect.d.ts +2 -0
  250. package/dist/types/src/internal/Obj/inspect.d.ts.map +1 -0
  251. package/dist/types/src/internal/Obj/json-serializer.d.ts +45 -0
  252. package/dist/types/src/internal/Obj/json-serializer.d.ts.map +1 -0
  253. package/dist/types/src/internal/Obj/json-serializer.test.d.ts +2 -0
  254. package/dist/types/src/internal/Obj/json-serializer.test.d.ts.map +1 -0
  255. package/dist/types/src/internal/Obj/schema-validator.d.ts +2 -0
  256. package/dist/types/src/internal/Obj/schema-validator.d.ts.map +1 -0
  257. package/dist/types/src/internal/Obj/schema-validator.test.d.ts +2 -0
  258. package/dist/types/src/internal/Obj/schema-validator.test.d.ts.map +1 -0
  259. package/dist/types/src/internal/Obj/set-value.d.ts +7 -0
  260. package/dist/types/src/internal/Obj/set-value.d.ts.map +1 -0
  261. package/dist/types/src/internal/Obj/set-value.test.d.ts +2 -0
  262. package/dist/types/src/internal/Obj/set-value.test.d.ts.map +1 -0
  263. package/dist/types/src/internal/Obj/snapshot.d.ts +6 -0
  264. package/dist/types/src/internal/Obj/snapshot.d.ts.map +1 -0
  265. package/dist/types/src/internal/Obj/typed-object.d.ts +25 -0
  266. package/dist/types/src/internal/Obj/typed-object.d.ts.map +1 -0
  267. package/dist/types/src/internal/Obj/typed-object.test.d.ts +2 -0
  268. package/dist/types/src/internal/Obj/typed-object.test.d.ts.map +1 -0
  269. package/dist/types/src/internal/Query.d.ts +10 -0
  270. package/dist/types/src/internal/Query.d.ts.map +1 -0
  271. package/dist/types/src/internal/Ref/index.d.ts +3 -0
  272. package/dist/types/src/internal/Ref/index.d.ts.map +1 -0
  273. package/dist/types/src/internal/Ref/ref-array.d.ts +21 -0
  274. package/dist/types/src/internal/Ref/ref-array.d.ts.map +1 -0
  275. package/dist/types/src/internal/Ref/ref.d.ts +244 -0
  276. package/dist/types/src/internal/Ref/ref.d.ts.map +1 -0
  277. package/dist/types/src/internal/Ref/ref.test.d.ts +2 -0
  278. package/dist/types/src/internal/Ref/ref.test.d.ts.map +1 -0
  279. package/dist/types/src/internal/Type/compose.d.ts +7 -0
  280. package/dist/types/src/internal/Type/compose.d.ts.map +1 -0
  281. package/dist/types/src/internal/Type/compose.test.d.ts +2 -0
  282. package/dist/types/src/internal/Type/compose.test.d.ts.map +1 -0
  283. package/dist/types/src/internal/Type/echo-schema.d.ts +181 -0
  284. package/dist/types/src/internal/Type/echo-schema.d.ts.map +1 -0
  285. package/dist/types/src/internal/Type/index.d.ts +4 -0
  286. package/dist/types/src/internal/Type/index.d.ts.map +1 -0
  287. package/dist/types/src/internal/Type/manipulation.d.ts +10 -0
  288. package/dist/types/src/internal/Type/manipulation.d.ts.map +1 -0
  289. package/dist/types/src/internal/Type/persistent-schema.d.ts +20 -0
  290. package/dist/types/src/internal/Type/persistent-schema.d.ts.map +1 -0
  291. package/dist/types/src/internal/common/api/index.d.ts +11 -0
  292. package/dist/types/src/internal/common/api/index.d.ts.map +1 -0
  293. package/dist/types/src/internal/common/api/meta.d.ts +42 -0
  294. package/dist/types/src/internal/common/api/meta.d.ts.map +1 -0
  295. package/dist/types/src/internal/common/index.d.ts +4 -0
  296. package/dist/types/src/internal/common/index.d.ts.map +1 -0
  297. package/dist/types/src/internal/common/proxy/change-context.d.ts +55 -0
  298. package/dist/types/src/internal/common/proxy/change-context.d.ts.map +1 -0
  299. package/dist/types/src/internal/common/proxy/change.test.d.ts +2 -0
  300. package/dist/types/src/internal/common/proxy/change.test.d.ts.map +1 -0
  301. package/dist/types/src/internal/common/proxy/define-hidden-property.d.ts +5 -0
  302. package/dist/types/src/internal/common/proxy/define-hidden-property.d.ts.map +1 -0
  303. package/dist/types/src/internal/common/proxy/errors.d.ts +19 -0
  304. package/dist/types/src/internal/common/proxy/errors.d.ts.map +1 -0
  305. package/dist/types/src/internal/common/proxy/event-batch.d.ts +10 -0
  306. package/dist/types/src/internal/common/proxy/event-batch.d.ts.map +1 -0
  307. package/dist/types/src/internal/common/proxy/handler.test.d.ts +2 -0
  308. package/dist/types/src/internal/common/proxy/handler.test.d.ts.map +1 -0
  309. package/dist/types/src/internal/common/proxy/index.d.ts +14 -0
  310. package/dist/types/src/internal/common/proxy/index.d.ts.map +1 -0
  311. package/dist/types/src/internal/common/proxy/json-serializer.d.ts +6 -0
  312. package/dist/types/src/internal/common/proxy/json-serializer.d.ts.map +1 -0
  313. package/dist/types/src/internal/common/proxy/make-object.d.ts +14 -0
  314. package/dist/types/src/internal/common/proxy/make-object.d.ts.map +1 -0
  315. package/dist/types/src/internal/common/proxy/ownership.d.ts +57 -0
  316. package/dist/types/src/internal/common/proxy/ownership.d.ts.map +1 -0
  317. package/dist/types/src/internal/common/proxy/proxy-types.d.ts +18 -0
  318. package/dist/types/src/internal/common/proxy/proxy-types.d.ts.map +1 -0
  319. package/dist/types/src/internal/common/proxy/proxy-utils.d.ts +47 -0
  320. package/dist/types/src/internal/common/proxy/proxy-utils.d.ts.map +1 -0
  321. package/dist/types/src/internal/common/proxy/reactive-array.d.ts +8 -0
  322. package/dist/types/src/internal/common/proxy/reactive-array.d.ts.map +1 -0
  323. package/dist/types/src/internal/common/proxy/reactive.d.ts +39 -0
  324. package/dist/types/src/internal/common/proxy/reactive.d.ts.map +1 -0
  325. package/dist/types/src/internal/common/proxy/reactive.test.d.ts +2 -0
  326. package/dist/types/src/internal/common/proxy/reactive.test.d.ts.map +1 -0
  327. package/dist/types/src/internal/common/proxy/schema-validator.d.ts +15 -0
  328. package/dist/types/src/internal/common/proxy/schema-validator.d.ts.map +1 -0
  329. package/dist/types/src/internal/common/proxy/schema.test.d.ts +2 -0
  330. package/dist/types/src/internal/common/proxy/schema.test.d.ts.map +1 -0
  331. package/dist/types/src/internal/common/proxy/symbols.d.ts +3 -0
  332. package/dist/types/src/internal/common/proxy/symbols.d.ts.map +1 -0
  333. package/dist/types/src/internal/common/proxy/typed-handler.d.ts +48 -0
  334. package/dist/types/src/internal/common/proxy/typed-handler.d.ts.map +1 -0
  335. package/dist/types/src/internal/common/proxy/typed-handler.test.d.ts +2 -0
  336. package/dist/types/src/internal/common/proxy/typed-handler.test.d.ts.map +1 -0
  337. package/dist/types/src/internal/common/proxy/typed-object.test.d.ts +2 -0
  338. package/dist/types/src/internal/common/proxy/typed-object.test.d.ts.map +1 -0
  339. package/dist/types/src/internal/common/types/base.d.ts +27 -0
  340. package/dist/types/src/internal/common/types/base.d.ts.map +1 -0
  341. package/dist/types/src/internal/common/types/entity.d.ts +37 -0
  342. package/dist/types/src/internal/common/types/entity.d.ts.map +1 -0
  343. package/dist/types/src/internal/common/types/index.d.ts +7 -0
  344. package/dist/types/src/internal/common/types/index.d.ts.map +1 -0
  345. package/dist/types/src/internal/common/types/meta.d.ts +33 -0
  346. package/dist/types/src/internal/common/types/meta.d.ts.map +1 -0
  347. package/dist/types/src/internal/common/types/model-symbols.d.ts +54 -0
  348. package/dist/types/src/internal/common/types/model-symbols.d.ts.map +1 -0
  349. package/dist/types/src/internal/common/types/typename.d.ts +21 -0
  350. package/dist/types/src/internal/common/types/typename.d.ts.map +1 -0
  351. package/dist/types/src/internal/common/types/version.d.ts +15 -0
  352. package/dist/types/src/internal/common/types/version.d.ts.map +1 -0
  353. package/dist/types/src/internal/index.d.ts +11 -0
  354. package/dist/types/src/internal/index.d.ts.map +1 -0
  355. package/dist/types/src/{test → testing}/api.test.d.ts.map +1 -1
  356. package/dist/types/src/testing/index.d.ts +3 -1
  357. package/dist/types/src/testing/index.d.ts.map +1 -1
  358. package/dist/types/src/testing/test-data.d.ts +18 -0
  359. package/dist/types/src/testing/test-data.d.ts.map +1 -0
  360. package/dist/types/src/testing/test-schema.d.ts +304 -0
  361. package/dist/types/src/testing/test-schema.d.ts.map +1 -0
  362. package/dist/types/src/testing/util.d.ts +21 -0
  363. package/dist/types/src/testing/util.d.ts.map +1 -0
  364. package/dist/types/tsconfig.tsbuildinfo +1 -1
  365. package/package.json +119 -57
  366. package/src/Annotation.ts +48 -0
  367. package/src/Collection.ts +37 -0
  368. package/src/Database.ts +352 -0
  369. package/src/Dataset.ts +26 -0
  370. package/src/Entity.test.ts +22 -0
  371. package/src/Entity.ts +243 -0
  372. package/src/Err.ts +40 -0
  373. package/src/Extension.test.ts +235 -0
  374. package/src/Extension.ts +122 -0
  375. package/src/Feed.ts +304 -0
  376. package/src/Filter.test.ts +90 -0
  377. package/src/Filter.ts +454 -0
  378. package/src/Format.ts +9 -0
  379. package/src/Hypergraph.ts +79 -0
  380. package/src/Json.test.ts +175 -0
  381. package/src/Json.ts +102 -0
  382. package/src/JsonSchema.ts +26 -0
  383. package/src/Key.ts +3 -0
  384. package/src/Migration.ts +94 -0
  385. package/src/Obj.test.ts +539 -0
  386. package/src/Obj.ts +713 -244
  387. package/src/Order.ts +46 -0
  388. package/src/Query.test.ts +822 -0
  389. package/src/Query.ts +567 -0
  390. package/src/QueryResult.ts +106 -0
  391. package/src/Ref.ts +78 -9
  392. package/src/Relation.test.ts +88 -0
  393. package/src/Relation.ts +450 -60
  394. package/src/SchemaRegistry.ts +106 -0
  395. package/src/Tag.ts +41 -0
  396. package/src/Type.test.ts +52 -0
  397. package/src/Type.ts +168 -155
  398. package/src/View.ts +107 -0
  399. package/src/hierarchy.test.ts +33 -0
  400. package/src/index.ts +24 -6
  401. package/src/internal/Annotation/annotations.test.ts +145 -0
  402. package/src/internal/Annotation/annotations.ts +577 -0
  403. package/src/internal/Annotation/index.ts +7 -0
  404. package/src/internal/Annotation/sorting.ts +51 -0
  405. package/src/internal/Annotation/util.ts +85 -0
  406. package/src/internal/Entity/api.ts +30 -0
  407. package/src/internal/Entity/entity.ts +128 -0
  408. package/src/internal/Entity/index.ts +11 -0
  409. package/src/internal/Entity/model.ts +109 -0
  410. package/src/internal/Entity/object.ts +57 -0
  411. package/src/internal/Entity/relation.ts +154 -0
  412. package/src/internal/Entity/util.ts +33 -0
  413. package/src/internal/Entity/version.ts +96 -0
  414. package/src/internal/Format/date.test.ts +55 -0
  415. package/src/internal/Format/date.ts +217 -0
  416. package/src/internal/Format/format.test.ts +76 -0
  417. package/src/internal/Format/format.ts +54 -0
  418. package/src/internal/Format/index.ts +12 -0
  419. package/src/internal/Format/number.ts +89 -0
  420. package/src/internal/Format/object.ts +80 -0
  421. package/src/internal/Format/select.ts +18 -0
  422. package/src/internal/Format/string.ts +81 -0
  423. package/src/internal/Format/types.ts +186 -0
  424. package/src/internal/JsonSchema/annotations.ts +50 -0
  425. package/src/internal/JsonSchema/effect-schema.test.ts +143 -0
  426. package/src/internal/JsonSchema/index.ts +8 -0
  427. package/src/internal/JsonSchema/json-schema-normalize.ts +111 -0
  428. package/src/internal/JsonSchema/json-schema-type.ts +403 -0
  429. package/src/internal/JsonSchema/json-schema.test.ts +860 -0
  430. package/src/internal/JsonSchema/json-schema.ts +533 -0
  431. package/src/internal/Obj/clone.ts +48 -0
  432. package/src/internal/Obj/common.ts +75 -0
  433. package/src/internal/Obj/create-object.test.ts +114 -0
  434. package/src/internal/Obj/create-object.ts +94 -0
  435. package/src/internal/Obj/deleted.ts +19 -0
  436. package/src/internal/Obj/ids.ts +12 -0
  437. package/src/internal/Obj/index.ts +14 -0
  438. package/src/internal/Obj/inspect.ts +46 -0
  439. package/src/internal/Obj/json-serializer.test.ts +120 -0
  440. package/src/internal/Obj/json-serializer.ts +222 -0
  441. package/src/internal/Obj/schema-validator.test.ts +182 -0
  442. package/src/internal/Obj/schema-validator.ts +6 -0
  443. package/src/internal/Obj/set-value.test.ts +281 -0
  444. package/src/internal/Obj/set-value.ts +165 -0
  445. package/src/internal/Obj/snapshot.ts +105 -0
  446. package/src/internal/Obj/typed-object.test.ts +34 -0
  447. package/src/internal/Obj/typed-object.ts +30 -0
  448. package/src/internal/Query.ts +137 -0
  449. package/src/internal/Ref/index.ts +6 -0
  450. package/src/internal/Ref/ref-array.ts +38 -0
  451. package/src/internal/Ref/ref.test.ts +100 -0
  452. package/src/internal/Ref/ref.ts +589 -0
  453. package/src/internal/Type/compose.test.ts +41 -0
  454. package/src/internal/Type/compose.ts +41 -0
  455. package/src/internal/Type/echo-schema.ts +423 -0
  456. package/src/internal/Type/index.ts +7 -0
  457. package/src/internal/Type/manipulation.ts +92 -0
  458. package/src/internal/Type/persistent-schema.ts +33 -0
  459. package/src/internal/common/README.md +102 -0
  460. package/src/internal/common/api/index.ts +15 -0
  461. package/src/internal/common/api/meta.ts +88 -0
  462. package/src/internal/common/index.ts +7 -0
  463. package/src/internal/common/proxy/change-context.ts +138 -0
  464. package/src/internal/common/proxy/change.test.ts +519 -0
  465. package/src/internal/common/proxy/define-hidden-property.ts +14 -0
  466. package/src/internal/common/proxy/errors.ts +42 -0
  467. package/src/internal/common/proxy/event-batch.ts +44 -0
  468. package/src/internal/common/proxy/handler.test.ts +121 -0
  469. package/src/internal/common/proxy/index.ts +17 -0
  470. package/src/internal/common/proxy/json-serializer.ts +90 -0
  471. package/src/internal/common/proxy/make-object.ts +105 -0
  472. package/src/internal/common/proxy/ownership.ts +252 -0
  473. package/src/internal/common/proxy/proxy-types.ts +23 -0
  474. package/src/internal/common/proxy/proxy-utils.ts +150 -0
  475. package/src/internal/common/proxy/reactive-array.ts +71 -0
  476. package/src/internal/common/proxy/reactive.test.ts +54 -0
  477. package/src/internal/common/proxy/reactive.ts +77 -0
  478. package/src/internal/common/proxy/schema-validator.ts +244 -0
  479. package/src/internal/common/proxy/schema.test.ts +145 -0
  480. package/src/internal/common/proxy/symbols.ts +7 -0
  481. package/src/internal/common/proxy/typed-handler.test.ts +313 -0
  482. package/src/internal/common/proxy/typed-handler.ts +447 -0
  483. package/src/internal/common/proxy/typed-object.test.ts +115 -0
  484. package/src/internal/common/types/base.ts +43 -0
  485. package/src/internal/common/types/entity.ts +54 -0
  486. package/src/internal/common/types/index.ts +10 -0
  487. package/src/internal/common/types/meta.ts +67 -0
  488. package/src/internal/common/types/model-symbols.ts +69 -0
  489. package/src/internal/common/types/typename.ts +55 -0
  490. package/src/internal/common/types/version.ts +19 -0
  491. package/src/internal/index.ts +17 -0
  492. package/src/testing/api.test.ts +125 -0
  493. package/src/testing/index.ts +3 -1
  494. package/src/testing/test-data.ts +129 -0
  495. package/src/testing/test-schema.ts +240 -0
  496. package/src/testing/util.ts +85 -0
  497. package/dist/lib/browser/chunk-I4YEWYJA.mjs +0 -882
  498. package/dist/lib/browser/chunk-I4YEWYJA.mjs.map +0 -7
  499. package/dist/lib/browser/index.mjs +0 -30
  500. package/dist/lib/browser/meta.json +0 -1
  501. package/dist/lib/browser/testing/index.mjs +0 -70
  502. package/dist/lib/browser/testing/index.mjs.map +0 -7
  503. package/dist/lib/node-esm/chunk-AWWFAF75.mjs +0 -882
  504. package/dist/lib/node-esm/chunk-AWWFAF75.mjs.map +0 -7
  505. package/dist/lib/node-esm/index.mjs +0 -30
  506. package/dist/lib/node-esm/meta.json +0 -1
  507. package/dist/lib/node-esm/testing/index.mjs +0 -70
  508. package/dist/lib/node-esm/testing/index.mjs.map +0 -7
  509. package/dist/types/src/errors.d.ts +0 -72
  510. package/dist/types/src/errors.d.ts.map +0 -1
  511. package/dist/types/src/experimental/database.d.ts +0 -8
  512. package/dist/types/src/experimental/database.d.ts.map +0 -1
  513. package/dist/types/src/experimental/index.d.ts +0 -1
  514. package/dist/types/src/experimental/index.d.ts.map +0 -1
  515. package/dist/types/src/experimental/queue.d.ts +0 -8
  516. package/dist/types/src/experimental/queue.d.ts.map +0 -1
  517. package/dist/types/src/experimental/space.d.ts +0 -8
  518. package/dist/types/src/experimental/space.d.ts.map +0 -1
  519. package/dist/types/src/query/dsl.d.ts +0 -245
  520. package/dist/types/src/query/dsl.d.ts.map +0 -1
  521. package/dist/types/src/query/dsl.test.d.ts +0 -2
  522. package/dist/types/src/query/dsl.test.d.ts.map +0 -1
  523. package/dist/types/src/query/index.d.ts +0 -2
  524. package/dist/types/src/query/index.d.ts.map +0 -1
  525. package/dist/types/src/testing/types.d.ts +0 -113
  526. package/dist/types/src/testing/types.d.ts.map +0 -1
  527. package/src/errors.ts +0 -18
  528. package/src/experimental/database.ts +0 -11
  529. package/src/experimental/index.ts +0 -7
  530. package/src/experimental/queue.ts +0 -11
  531. package/src/experimental/space.ts +0 -11
  532. package/src/query/dsl.test.ts +0 -362
  533. package/src/query/dsl.ts +0 -759
  534. package/src/query/index.ts +0 -5
  535. package/src/test/api.test.ts +0 -180
  536. package/src/testing/types.ts +0 -91
  537. /package/dist/lib/{browser/index.mjs.map → neutral/Annotation.mjs.map} +0 -0
  538. /package/dist/lib/{node-esm/index.mjs.map → neutral/Database.mjs.map} +0 -0
  539. /package/dist/types/src/{test → testing}/api.test.d.ts +0 -0
@@ -0,0 +1,589 @@
1
+ //
2
+ // Copyright 2024 DXOS.org
3
+ //
4
+
5
+ import * as Effect from 'effect/Effect';
6
+ import * as Equal from 'effect/Equal';
7
+ import * as Hash from 'effect/Hash';
8
+ import * as Option from 'effect/Option';
9
+ import * as ParseResult from 'effect/ParseResult';
10
+ import * as Pipeable from 'effect/Pipeable';
11
+ import * as Schema from 'effect/Schema';
12
+ import * as SchemaAST from 'effect/SchemaAST';
13
+ import type * as Types from 'effect/Types';
14
+
15
+ import { Event } from '@dxos/async';
16
+ import { type CustomInspectFunction, inspectCustom } from '@dxos/debug';
17
+ import { EncodedReference } from '@dxos/echo-protocol';
18
+ import { assertArgument, invariant } from '@dxos/invariant';
19
+ import { DXN, ObjectId } from '@dxos/keys';
20
+
21
+ import * as Database from '../../Database';
22
+ import { ReferenceAnnotationId, getSchemaDXN, getTypeAnnotation, getTypeIdentifierAnnotation } from '../Annotation';
23
+ import type { AnyEntity, AnyProperties } from '../common/types';
24
+ import { type JsonSchemaType } from '../JsonSchema';
25
+
26
+ /**
27
+ * The `$id` and `$ref` fields for an ECHO reference schema.
28
+ */
29
+ export const JSON_SCHEMA_ECHO_REF_ID = '/schemas/echo/ref';
30
+
31
+ export const getSchemaReference = (property: JsonSchemaType): { typename: string } | undefined => {
32
+ const { $id, reference: { schema: { $ref } = {} } = {} } = property;
33
+ if ($id === JSON_SCHEMA_ECHO_REF_ID && $ref) {
34
+ return { typename: DXN.parse($ref).typename };
35
+ }
36
+ };
37
+
38
+ export const createSchemaReference = (typename: string): Types.DeepMutable<JsonSchemaType> => {
39
+ return {
40
+ $id: JSON_SCHEMA_ECHO_REF_ID,
41
+ reference: {
42
+ schema: {
43
+ $ref: DXN.fromTypename(typename).toString(),
44
+ },
45
+ },
46
+ };
47
+ };
48
+
49
+ /**
50
+ * Runtime type-info for a reference extracted from effect AST.
51
+ */
52
+ export type RefereneAST = {
53
+ /**
54
+ * Typename of linked schema.
55
+ */
56
+ typename: string;
57
+
58
+ /**
59
+ * Version of linked schema.
60
+ */
61
+ version: string;
62
+ };
63
+
64
+ export const getReferenceAst = (ast: SchemaAST.AST): RefereneAST | undefined => {
65
+ if (ast._tag !== 'Declaration' || !ast.annotations[ReferenceAnnotationId]) {
66
+ return undefined;
67
+ }
68
+ return {
69
+ typename: (ast.annotations[ReferenceAnnotationId] as any).typename,
70
+ version: (ast.annotations[ReferenceAnnotationId] as any).version,
71
+ };
72
+ };
73
+
74
+ export const RefTypeId: unique symbol = Symbol('@dxos/echo/internal/Ref');
75
+
76
+ /**
77
+ * Reference Schema.
78
+ */
79
+ export interface RefSchema<T extends AnyEntity> extends Schema.SchemaClass<Ref<T>, EncodedReference> {}
80
+
81
+ /**
82
+ * Type of the `Ref` function and extra methods attached to it.
83
+ */
84
+ export interface RefFn {
85
+ <S extends Schema.Schema.Any>(schema: S): RefSchema<Schema.Schema.Type<S>>;
86
+
87
+ /**
88
+ * @returns True if the object is a reference.
89
+ */
90
+ isRef: (obj: unknown) => obj is Ref<any>;
91
+
92
+ /**
93
+ * @returns True if the reference points to the given object id.
94
+ */
95
+ hasObjectId: (id: ObjectId) => (ref: Ref<any>) => boolean;
96
+
97
+ /**
98
+ * @returns True if the schema is a reference schema.
99
+ */
100
+ isRefSchema: (schema: Schema.Schema<any, any>) => schema is RefSchema<any>;
101
+
102
+ /**
103
+ * @returns True if the schema AST is a reference schema.
104
+ */
105
+ isRefSchemaAST: (ast: SchemaAST.AST) => boolean;
106
+
107
+ /**
108
+ * Constructs a reference that points to the given object.
109
+ */
110
+ // TODO(burdon): Narrow to Obj.Unknown?
111
+ make: <T extends AnyEntity>(object: T) => Ref<T>;
112
+
113
+ /**
114
+ * Constructs a reference that points to the object specified by the provided DXN.
115
+ */
116
+ fromDXN: (dxn: DXN) => Ref<any>;
117
+ }
118
+
119
+ /**
120
+ * Schema builder for references.
121
+ */
122
+ export const Ref: RefFn = <S extends Schema.Schema.Any>(schema: S): RefSchema<Schema.Schema.Type<S>> => {
123
+ assertArgument(Schema.isSchema(schema), 'schema', 'Must call with an instance of effect-schema');
124
+ const annotation = getTypeAnnotation(schema);
125
+ if (annotation == null) {
126
+ throw new Error('Reference target must be an ECHO schema.');
127
+ }
128
+
129
+ return createEchoReferenceSchema(getTypeIdentifierAnnotation(schema), annotation.typename, annotation.version);
130
+ };
131
+
132
+ /**
133
+ * Represents materialized reference to a target.
134
+ * This is the data type for the fields marked as ref.
135
+ */
136
+ export interface Ref<T> extends Pipeable.Pipeable {
137
+ /**
138
+ * Target object DXN.
139
+ */
140
+ get dxn(): DXN;
141
+
142
+ /**
143
+ * Returns true if the reference has a target available (inlined or resolver set).
144
+ */
145
+ get isAvailable(): boolean;
146
+
147
+ /**
148
+ * @returns The reference target.
149
+ * May return `undefined` if the object is not loaded in the working set.
150
+ * Accessing this property, even if it returns `undefined` will trigger the object to be loaded to the working set.
151
+ */
152
+ get target(): T | undefined;
153
+
154
+ /**
155
+ * @returns Promise that will resolves with the target object.
156
+ * Will load the object from disk if it is not present in the working set.
157
+ * @throws If the object is not available locally.
158
+ */
159
+ load(): Promise<T>;
160
+
161
+ /**
162
+ * @returns Promise that will resolves with the target object or undefined if the object is not loaded locally.
163
+ */
164
+
165
+ tryLoad(): Promise<T | undefined>;
166
+
167
+ /**
168
+ * Subscribe to the ref's resolution event.
169
+ * The callback fires when the target object becomes available in the working set
170
+ * (e.g. when its document is loaded after sibling-client mutation).
171
+ * Note: the resolver only schedules a notification when the target is requested
172
+ * via {@link target} while it is not yet loaded.
173
+ * @returns Function that unsubscribes the callback.
174
+ */
175
+ onResolved(callback: () => void): () => void;
176
+
177
+ /**
178
+ * Do not inline the target object in the reference.
179
+ * Makes .target unavailable unless the reference is connected to a database context.
180
+ *
181
+ * When serialized with toJSON, the difference is between:
182
+ * `{ "/": "dxn:..." }`
183
+ * and
184
+ * `{ "/": "dxn:...", "target": { ... } }`
185
+ *
186
+ * Clones the reference object.
187
+ */
188
+ noInline(): Ref<T>;
189
+
190
+ /**
191
+ * Serializes the reference to a JSON object.
192
+ * The serialization format is compatible with the IPLD-style encoded references.
193
+ * When a reference has a saved target (i.e. the target or object holding the reference is not in the database),
194
+ * the target is included in the serialized object.
195
+ *
196
+ * Examples:
197
+ * `{ "/": "dxn:..." }`
198
+ * `{ "/": "dxn:...", "target": { ... } }`
199
+ */
200
+ encode(): EncodedReference;
201
+
202
+ [RefTypeId]: {
203
+ _T: T;
204
+ };
205
+ }
206
+
207
+ export declare namespace Ref {
208
+ /**
209
+ * Target of the reference.
210
+ */
211
+ export type Target<R> = R extends Ref<infer U> ? U : never;
212
+ }
213
+
214
+ Ref.isRef = (obj: any): obj is Ref<any> => {
215
+ return obj && typeof obj === 'object' && RefTypeId in obj;
216
+ };
217
+
218
+ Ref.hasObjectId = (id: ObjectId) => (ref: Ref<any>) => ref.dxn.isLocalObjectId() && ref.dxn.parts[1] === id;
219
+
220
+ Ref.isRefSchema = (schema: Schema.Schema<any, any>): schema is RefSchema<any> => {
221
+ return Ref.isRefSchemaAST(schema.ast);
222
+ };
223
+
224
+ Ref.isRefSchemaAST = (ast: SchemaAST.AST): boolean => {
225
+ return SchemaAST.getAnnotation(ast, ReferenceAnnotationId).pipe(Option.isSome);
226
+ };
227
+
228
+ Ref.make = <T extends AnyProperties>(obj: T): Ref<T> => {
229
+ if (typeof obj !== 'object' || obj === null) {
230
+ throw new TypeError('Expected: ECHO object.');
231
+ }
232
+
233
+ // TODO(dmaretskyi): Extract to `getObjectDXN` function.
234
+ const id = obj.id;
235
+ invariant(ObjectId.isValid(id), 'Invalid object ID');
236
+ const dxn = DXN.fromLocalObjectId(id);
237
+ return new RefImpl(dxn, obj);
238
+ };
239
+
240
+ Ref.fromDXN = (dxn: DXN): Ref<any> => {
241
+ assertArgument(dxn instanceof DXN, 'dxn', 'Expected DXN');
242
+ return new RefImpl(dxn);
243
+ };
244
+
245
+ /**
246
+ * `reference` field on the schema object.
247
+ */
248
+ export type JsonSchemaReferenceInfo = {
249
+ schema: { $ref: string };
250
+ schemaVersion?: string;
251
+ };
252
+
253
+ /**
254
+ * @internal
255
+ */
256
+ // TODO(burdon): Move to json schema and make private?
257
+ export const createEchoReferenceSchema = (
258
+ echoId: string | undefined,
259
+ typename: string | undefined,
260
+ version: string | undefined,
261
+ ): Schema.SchemaClass<Ref<any>, EncodedReference> => {
262
+ if (!echoId && !typename) {
263
+ throw new TypeError('Either echoId or typename must be provided.');
264
+ }
265
+
266
+ const referenceInfo: JsonSchemaReferenceInfo = {
267
+ schema: {
268
+ // TODO(dmaretskyi): Include version?
269
+ $ref: echoId ?? DXN.fromTypename(typename!).toString(),
270
+ },
271
+ schemaVersion: version,
272
+ };
273
+
274
+ // TODO(dmaretskyi): Add name and description.
275
+ const refSchema = Schema.declare<Ref<any>, EncodedReference, []>(
276
+ [],
277
+ {
278
+ encode: () => {
279
+ return (value) =>
280
+ Effect.gen(function* () {
281
+ if (Ref.isRef(value)) {
282
+ return EncodedReference.fromDXN((value as Ref<any>).dxn);
283
+ } else if (EncodedReference.isEncodedReference(value)) {
284
+ return value;
285
+ }
286
+ throw new Error('Invalid reference');
287
+ });
288
+ },
289
+ decode: () => {
290
+ return (value) =>
291
+ Effect.gen(function* () {
292
+ const dbService = yield* Effect.serviceOption(Database.Service);
293
+
294
+ // TODO(dmaretskyi): This branch seems to be taken by Schema.is
295
+ if (Ref.isRef(value)) {
296
+ if (Option.isSome(dbService)) {
297
+ return dbService.value.db.makeRef(value.dxn);
298
+ } else {
299
+ return value;
300
+ }
301
+ }
302
+
303
+ if (!EncodedReference.isEncodedReference(value)) {
304
+ return yield* Effect.fail(new ParseResult.Unexpected(value, 'reference'));
305
+ }
306
+ if (Option.isSome(dbService)) {
307
+ return dbService.value.db.makeRef(EncodedReference.toDXN(value));
308
+ } else {
309
+ return Ref.fromDXN(EncodedReference.toDXN(value));
310
+ }
311
+ });
312
+ },
313
+ },
314
+ {
315
+ jsonSchema: {
316
+ // TODO(dmaretskyi): We should remove `$id` and keep `$ref` with a fully qualified name.
317
+ $id: JSON_SCHEMA_ECHO_REF_ID,
318
+ $ref: JSON_SCHEMA_ECHO_REF_ID,
319
+ reference: referenceInfo,
320
+ },
321
+ [ReferenceAnnotationId]: {
322
+ typename: typename ?? '',
323
+ version,
324
+ },
325
+ },
326
+ );
327
+
328
+ return refSchema;
329
+ };
330
+
331
+ const getSchemaExpectedName = (ast: SchemaAST.Annotated): string | undefined => {
332
+ return SchemaAST.getIdentifierAnnotation(ast).pipe(
333
+ Option.orElse(() => SchemaAST.getTitleAnnotation(ast)),
334
+ Option.orElse(() => SchemaAST.getDescriptionAnnotation(ast)),
335
+ Option.getOrElse(() => undefined),
336
+ );
337
+ };
338
+
339
+ export interface RefResolver {
340
+ /**
341
+ * Resolve ref synchronously from the objects in the working set.
342
+ *
343
+ * @param dxn
344
+ * @param load If true the resolver should attempt to load the object from disk.
345
+ * @param onLoad Callback to call when the object is loaded.
346
+ */
347
+ resolveSync(dxn: DXN, load: boolean, onLoad?: () => void): AnyProperties | undefined;
348
+
349
+ /**
350
+ * Resolver ref asynchronously.
351
+ */
352
+ resolve(dxn: DXN): Promise<AnyProperties | undefined>;
353
+
354
+ // TODO(dmaretskyi): Combine with `resolve`.
355
+ resolveSchema(dxn: DXN): Promise<Schema.Schema.AnyNoContext | undefined>;
356
+ }
357
+
358
+ export class RefImpl<T> implements Ref<T> {
359
+ #dxn: DXN;
360
+ #resolver?: RefResolver = undefined;
361
+ #resolved = new Event<void>();
362
+
363
+ /**
364
+ * Target is set when the reference is created from a specific object.
365
+ * In this case, the target might not be in the database.
366
+ */
367
+ #target: T | undefined = undefined;
368
+
369
+ /**
370
+ * Callback to issue a reactive notification when object is resolved.
371
+ */
372
+ #resolverCallback = () => {
373
+ this.#resolved.emit();
374
+ };
375
+
376
+ constructor(dxn: DXN, target?: T) {
377
+ this.#dxn = dxn;
378
+ this.#target = target;
379
+ }
380
+
381
+ /**
382
+ * @inheritdoc
383
+ */
384
+ get dxn(): DXN {
385
+ return this.#dxn;
386
+ }
387
+
388
+ /**
389
+ * @inheritdoc
390
+ */
391
+ get isAvailable(): boolean {
392
+ return this.#target !== undefined || this.#resolver !== undefined;
393
+ }
394
+
395
+ /**
396
+ * @inheritdoc
397
+ */
398
+ get target(): T | undefined {
399
+ if (this.#target) {
400
+ return this.#target;
401
+ }
402
+
403
+ invariant(this.#resolver, 'Resolver is not set');
404
+ return this.#resolver.resolveSync(this.#dxn, true, this.#resolverCallback) as T | undefined;
405
+ }
406
+
407
+ /**
408
+ * @inheritdoc
409
+ */
410
+ async load(): Promise<T> {
411
+ if (this.#target) {
412
+ return this.#target;
413
+ }
414
+ invariant(this.#resolver, 'Resolver is not set');
415
+ const obj = await this.#resolver.resolve(this.#dxn);
416
+ if (obj == null) {
417
+ throw new Error('Object not found');
418
+ }
419
+ return obj as T;
420
+ }
421
+
422
+ /**
423
+ * @inheritdoc
424
+ */
425
+ async tryLoad(): Promise<T | undefined> {
426
+ if (this.#target) {
427
+ return this.#target;
428
+ }
429
+ invariant(this.#resolver, 'Resolver is not set');
430
+ return (await this.#resolver.resolve(this.#dxn)) as T | undefined;
431
+ }
432
+
433
+ /**
434
+ * @inheritdoc
435
+ */
436
+ onResolved(callback: () => void): () => void {
437
+ return this.#resolved.on(callback);
438
+ }
439
+
440
+ /**
441
+ * Do not inline the target object in the reference.
442
+ * Makes .target unavailable unless the reference is connected to a database context.
443
+ * Clones the reference object.
444
+ */
445
+ noInline(): RefImpl<T> {
446
+ const ref = new RefImpl<T>(this.#dxn, undefined);
447
+ ref.#resolver = this.#resolver;
448
+ return ref;
449
+ }
450
+
451
+ encode(): EncodedReference {
452
+ return {
453
+ '/': this.#dxn.toString(),
454
+ ...(this.#target ? { target: this.#target } : {}),
455
+ };
456
+ }
457
+
458
+ /**
459
+ * Serializes the reference to a JSON object.
460
+ * The serialization format is compatible with the IPLD-style encoded references.
461
+ * When a reference has a saved target (i.e. the target or object holding the reference is not in the database),
462
+ * the target is included in the serialized object.
463
+ */
464
+ toJSON(): EncodedReference {
465
+ return this.encode();
466
+ }
467
+
468
+ toString(): string {
469
+ if (this.#target) {
470
+ return `Ref(${this.#target.toString()})`;
471
+ }
472
+
473
+ return `Ref(${this.#dxn.toString()})`;
474
+ }
475
+
476
+ [inspectCustom]: CustomInspectFunction = (depth, options, inspect) => {
477
+ return this.toString();
478
+ };
479
+
480
+ [RefTypeId] = refVariance;
481
+
482
+ /**
483
+ * Effect Hash trait. Required for MutableHashMap-based caches (e.g., Atom.family)
484
+ * to deduplicate Ref instances that point to the same object.
485
+ * ECHO proxies return new RefImpl instances on every property access,
486
+ * so without this, each access would create a separate cache entry.
487
+ */
488
+ [Hash.symbol](): number {
489
+ return Hash.hash(this.#dxn.toString());
490
+ }
491
+
492
+ /** Effect Equal trait. See {@link Hash.symbol} for rationale. */
493
+ [Equal.symbol](that: Equal.Equal): boolean {
494
+ return that instanceof RefImpl && this.#dxn.toString() === that.dxn.toString();
495
+ }
496
+
497
+ /**
498
+ * Internal method to set the resolver.
499
+ *
500
+ * @internal
501
+ */
502
+ _setResolver(resolver: RefResolver): void {
503
+ this.#resolver = resolver;
504
+ }
505
+
506
+ /**
507
+ * @internal
508
+ */
509
+ _getSavedTarget(): T | undefined {
510
+ return this.#target;
511
+ }
512
+
513
+ pipe() {
514
+ // eslint-disable-next-line prefer-rest-params
515
+ return Pipeable.pipeArguments(this, arguments);
516
+ }
517
+ }
518
+
519
+ /**
520
+ * Internal API for setting the reference resolver.
521
+ */
522
+ export const setRefResolver = (ref: Ref<any>, resolver: RefResolver) => {
523
+ invariant(ref instanceof RefImpl, 'Ref is not an instance of RefImpl');
524
+ ref._setResolver(resolver);
525
+ };
526
+
527
+ /**
528
+ * Internal API for getting the saved target on a reference.
529
+ */
530
+ export const getRefSavedTarget = (ref: Ref<any>): AnyProperties | undefined => {
531
+ invariant(ref instanceof RefImpl, 'Ref is not an instance of RefImpl');
532
+ return ref._getSavedTarget();
533
+ };
534
+
535
+ // Used to validate reference target type.
536
+ const refVariance: Ref<any>[typeof RefTypeId] = {
537
+ _T: null as any,
538
+ };
539
+
540
+ export const refFromEncodedReference = (encodedReference: EncodedReference, resolver?: RefResolver): Ref<any> => {
541
+ const dxn = DXN.parse(encodedReference['/']);
542
+ const ref = new RefImpl(dxn);
543
+
544
+ // TODO(dmaretskyi): Handle inline target in the encoded reference.
545
+
546
+ if (resolver) {
547
+ setRefResolver(ref, resolver);
548
+ }
549
+ return ref;
550
+ };
551
+
552
+ export class StaticRefResolver implements RefResolver {
553
+ public objects = new Map<ObjectId, AnyProperties>();
554
+ public schemas = new Map<DXN.String, Schema.Schema.AnyNoContext>();
555
+
556
+ addObject(obj: AnyProperties): this {
557
+ this.objects.set(obj.id, obj);
558
+ return this;
559
+ }
560
+
561
+ addSchema(schema: Schema.Schema.AnyNoContext): this {
562
+ const dxn = getSchemaDXN(schema);
563
+ invariant(dxn, 'Schema has no DXN');
564
+ this.schemas.set(dxn.toString(), schema);
565
+ return this;
566
+ }
567
+
568
+ resolveSync(dxn: DXN, _load: boolean, _onLoad?: () => void): AnyProperties | undefined {
569
+ const id = dxn?.asEchoDXN()?.echoId;
570
+ if (id == null) {
571
+ return undefined;
572
+ }
573
+
574
+ return this.objects.get(id);
575
+ }
576
+
577
+ async resolve(dxn: DXN): Promise<AnyProperties | undefined> {
578
+ const id = dxn?.asEchoDXN()?.echoId;
579
+ if (id == null) {
580
+ return undefined;
581
+ }
582
+
583
+ return this.objects.get(id);
584
+ }
585
+
586
+ async resolveSchema(dxn: DXN): Promise<Schema.Schema.AnyNoContext | undefined> {
587
+ return this.schemas.get(dxn.toString());
588
+ }
589
+ }
@@ -0,0 +1,41 @@
1
+ //
2
+ // Copyright 2024 DXOS.org
3
+ //
4
+
5
+ import * as Schema from 'effect/Schema';
6
+ import { describe, test } from 'vitest';
7
+
8
+ import { FieldPath } from '../Annotation';
9
+ import { EchoObjectSchema } from '../Entity';
10
+ import { FormatAnnotation, TypeFormat } from '../Format';
11
+ import { ECHO_ANNOTATIONS_NS_KEY, toJsonSchema } from '../JsonSchema';
12
+ import { composeSchema } from './compose';
13
+
14
+ describe('schema composition', () => {
15
+ test('schema composition', ({ expect }) => {
16
+ const BaseType = Schema.Struct({
17
+ name: Schema.String,
18
+ email: Schema.String,
19
+ }).pipe(EchoObjectSchema({ typename: 'com.example.person', version: '0.1.0' }));
20
+
21
+ const OverlaySchema = Schema.Struct({
22
+ email: Schema.String.pipe(FieldPath('$.email'), FormatAnnotation.set(TypeFormat.Email)),
23
+ });
24
+
25
+ const baseSchema = toJsonSchema(BaseType);
26
+ const overlaySchema = toJsonSchema(OverlaySchema);
27
+ const composedSchema = composeSchema(baseSchema, overlaySchema);
28
+ expect(composedSchema.properties).to.deep.eq({
29
+ email: {
30
+ type: 'string',
31
+ format: TypeFormat.Email,
32
+ // TODO(dmaretskyi): Should use the new field.
33
+ [ECHO_ANNOTATIONS_NS_KEY]: {
34
+ meta: {
35
+ path: '$.email',
36
+ },
37
+ },
38
+ },
39
+ });
40
+ });
41
+ });
@@ -0,0 +1,41 @@
1
+ //
2
+ // Copyright 2024 DXOS.org
3
+ //
4
+
5
+ import type * as Types from 'effect/Types';
6
+
7
+ import { invariant } from '@dxos/invariant';
8
+
9
+ import { type JsonSchemaType } from '../JsonSchema';
10
+
11
+ /**
12
+ * Creates a composite schema from the source and projection schemas.
13
+ */
14
+ // TODO(burdon): Use effect schema projections.
15
+ // TODO(burdon): Can avoid having to call this every time we modify any property on the view?
16
+ export const composeSchema = (
17
+ source: Types.Mutable<JsonSchemaType>,
18
+ target: Types.Mutable<JsonSchemaType>,
19
+ ): Types.Mutable<JsonSchemaType> => {
20
+ const result = structuredClone(target);
21
+ invariant('type' in result && result.type === 'object', 'source schema must be an object');
22
+ invariant('type' in source && source.type === 'object', 'target schema must be an object');
23
+
24
+ for (const prop in result.properties) {
25
+ const propSchema = source.properties![prop]; // TODO(dmaretskyi): Find by json-path instead.
26
+ const annotations = (propSchema as JsonSchemaType)?.annotations?.meta;
27
+ if (annotations) {
28
+ const resultProp = result.properties[prop] as Record<string, any>;
29
+ resultProp.annotations ??= {};
30
+ resultProp.annotations.meta ??= {};
31
+ for (const key in annotations) {
32
+ resultProp.annotations.meta[key] ??= {};
33
+ Object.assign(resultProp.annotations.meta[key], annotations[key], {
34
+ ...resultProp.annotations.meta[key],
35
+ });
36
+ }
37
+ }
38
+ }
39
+
40
+ return result;
41
+ };