@xyo-network/sdk-js 3.12.5 → 3.13.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 (235) hide show
  1. package/eslint.config.mjs +1 -1
  2. package/package.json +19 -17
  3. package/scripts/run-cycle.mjs +71 -0
  4. package/packages/modules-mongo/dist/browser/index.mjs +0 -195
  5. package/packages/modules-mongo/dist/browser/index.mjs.map +0 -1
  6. package/packages/modules-mongo/dist/neutral/index.mjs +0 -195
  7. package/packages/modules-mongo/dist/neutral/index.mjs.map +0 -1
  8. package/packages/modules-mongo/dist/node/index.mjs +0 -195
  9. package/packages/modules-mongo/dist/node/index.mjs.map +0 -1
  10. package/packages/modules-mongo/dist/types/Archivist/addArchivistModuleFactories.d.ts +0 -3
  11. package/packages/modules-mongo/dist/types/Archivist/addArchivistModuleFactories.d.ts.map +0 -1
  12. package/packages/modules-mongo/dist/types/Archivist/index.d.ts +0 -2
  13. package/packages/modules-mongo/dist/types/Archivist/index.d.ts.map +0 -1
  14. package/packages/modules-mongo/dist/types/Diviner/addDivinerModuleFactories.d.ts +0 -3
  15. package/packages/modules-mongo/dist/types/Diviner/addDivinerModuleFactories.d.ts.map +0 -1
  16. package/packages/modules-mongo/dist/types/Diviner/index.d.ts +0 -2
  17. package/packages/modules-mongo/dist/types/Diviner/index.d.ts.map +0 -1
  18. package/packages/modules-mongo/dist/types/Job/getJobs.d.ts +0 -4
  19. package/packages/modules-mongo/dist/types/Job/getJobs.d.ts.map +0 -1
  20. package/packages/modules-mongo/dist/types/Job/index.d.ts +0 -2
  21. package/packages/modules-mongo/dist/types/Job/index.d.ts.map +0 -1
  22. package/packages/modules-mongo/dist/types/JobQueue/JobQueueContainerModule.d.ts +0 -3
  23. package/packages/modules-mongo/dist/types/JobQueue/JobQueueContainerModule.d.ts.map +0 -1
  24. package/packages/modules-mongo/dist/types/JobQueue/getJobQueue.d.ts +0 -3
  25. package/packages/modules-mongo/dist/types/JobQueue/getJobQueue.d.ts.map +0 -1
  26. package/packages/modules-mongo/dist/types/JobQueue/getName.d.ts +0 -2
  27. package/packages/modules-mongo/dist/types/JobQueue/getName.d.ts.map +0 -1
  28. package/packages/modules-mongo/dist/types/JobQueue/index.d.ts +0 -2
  29. package/packages/modules-mongo/dist/types/JobQueue/index.d.ts.map +0 -1
  30. package/packages/modules-mongo/dist/types/Mongo/AddressInfo.d.ts +0 -6
  31. package/packages/modules-mongo/dist/types/Mongo/AddressInfo.d.ts.map +0 -1
  32. package/packages/modules-mongo/dist/types/Mongo/Indexes/IndexCreationInfo.d.ts +0 -3
  33. package/packages/modules-mongo/dist/types/Mongo/Indexes/IndexCreationInfo.d.ts.map +0 -1
  34. package/packages/modules-mongo/dist/types/Mongo/Indexes/Specifications/AddressInfo/UX_address.d.ts +0 -3
  35. package/packages/modules-mongo/dist/types/Mongo/Indexes/Specifications/AddressInfo/UX_address.d.ts.map +0 -1
  36. package/packages/modules-mongo/dist/types/Mongo/Indexes/Specifications/AddressInfo/index.d.ts +0 -3
  37. package/packages/modules-mongo/dist/types/Mongo/Indexes/Specifications/AddressInfo/index.d.ts.map +0 -1
  38. package/packages/modules-mongo/dist/types/Mongo/Indexes/Specifications/index.d.ts +0 -2
  39. package/packages/modules-mongo/dist/types/Mongo/Indexes/Specifications/index.d.ts.map +0 -1
  40. package/packages/modules-mongo/dist/types/Mongo/Indexes/addIndexes.d.ts +0 -2
  41. package/packages/modules-mongo/dist/types/Mongo/Indexes/addIndexes.d.ts.map +0 -1
  42. package/packages/modules-mongo/dist/types/Mongo/Indexes/index.d.ts +0 -2
  43. package/packages/modules-mongo/dist/types/Mongo/Indexes/index.d.ts.map +0 -1
  44. package/packages/modules-mongo/dist/types/Mongo/index.d.ts +0 -3
  45. package/packages/modules-mongo/dist/types/Mongo/index.d.ts.map +0 -1
  46. package/packages/modules-mongo/dist/types/Mongo/initializeDatabase.d.ts +0 -2
  47. package/packages/modules-mongo/dist/types/Mongo/initializeDatabase.d.ts.map +0 -1
  48. package/packages/modules-mongo/dist/types/PreviousHashStore/MongoDBPreviousHashStore.d.ts +0 -12
  49. package/packages/modules-mongo/dist/types/PreviousHashStore/MongoDBPreviousHashStore.d.ts.map +0 -1
  50. package/packages/modules-mongo/dist/types/PreviousHashStore/addPreviousHashStore.d.ts +0 -2
  51. package/packages/modules-mongo/dist/types/PreviousHashStore/addPreviousHashStore.d.ts.map +0 -1
  52. package/packages/modules-mongo/dist/types/PreviousHashStore/index.d.ts +0 -2
  53. package/packages/modules-mongo/dist/types/PreviousHashStore/index.d.ts.map +0 -1
  54. package/packages/modules-mongo/dist/types/addMongoModules.d.ts +0 -3
  55. package/packages/modules-mongo/dist/types/addMongoModules.d.ts.map +0 -1
  56. package/packages/modules-mongo/dist/types/canAddMongoModules.d.ts +0 -2
  57. package/packages/modules-mongo/dist/types/canAddMongoModules.d.ts.map +0 -1
  58. package/packages/modules-mongo/dist/types/index.d.ts +0 -4
  59. package/packages/modules-mongo/dist/types/index.d.ts.map +0 -1
  60. package/packages/modules-mongo/dist/types/mongoTypes.d.ts +0 -5
  61. package/packages/modules-mongo/dist/types/mongoTypes.d.ts.map +0 -1
  62. package/packages/modules-mongo/packages/archivist/dist/browser/index.mjs +0 -274
  63. package/packages/modules-mongo/packages/archivist/dist/browser/index.mjs.map +0 -1
  64. package/packages/modules-mongo/packages/archivist/dist/neutral/index.mjs +0 -274
  65. package/packages/modules-mongo/packages/archivist/dist/neutral/index.mjs.map +0 -1
  66. package/packages/modules-mongo/packages/archivist/dist/node/index.mjs +0 -274
  67. package/packages/modules-mongo/packages/archivist/dist/node/index.mjs.map +0 -1
  68. package/packages/modules-mongo/packages/archivist/dist/types/Archivist.d.ts +0 -69
  69. package/packages/modules-mongo/packages/archivist/dist/types/Archivist.d.ts.map +0 -1
  70. package/packages/modules-mongo/packages/archivist/dist/types/ArchivistV2.d.ts +0 -65
  71. package/packages/modules-mongo/packages/archivist/dist/types/ArchivistV2.d.ts.map +0 -1
  72. package/packages/modules-mongo/packages/archivist/dist/types/index.d.ts +0 -4
  73. package/packages/modules-mongo/packages/archivist/dist/types/index.d.ts.map +0 -1
  74. package/packages/modules-mongo/packages/archivist/dist/types/lib/index.d.ts +0 -2
  75. package/packages/modules-mongo/packages/archivist/dist/types/lib/index.d.ts.map +0 -1
  76. package/packages/modules-mongo/packages/archivist/dist/types/lib/validByType.d.ts +0 -4
  77. package/packages/modules-mongo/packages/archivist/dist/types/lib/validByType.d.ts.map +0 -1
  78. package/packages/modules-mongo/packages/archivist/packages/model/dist/browser/index.mjs +0 -6
  79. package/packages/modules-mongo/packages/archivist/packages/model/dist/browser/index.mjs.map +0 -1
  80. package/packages/modules-mongo/packages/archivist/packages/model/dist/neutral/index.mjs +0 -6
  81. package/packages/modules-mongo/packages/archivist/packages/model/dist/neutral/index.mjs.map +0 -1
  82. package/packages/modules-mongo/packages/archivist/packages/model/dist/node/index.mjs +0 -6
  83. package/packages/modules-mongo/packages/archivist/packages/model/dist/node/index.mjs.map +0 -1
  84. package/packages/modules-mongo/packages/archivist/packages/model/dist/types/Config.d.ts +0 -9
  85. package/packages/modules-mongo/packages/archivist/packages/model/dist/types/Config.d.ts.map +0 -1
  86. package/packages/modules-mongo/packages/archivist/packages/model/dist/types/ConfigV2.d.ts +0 -8
  87. package/packages/modules-mongo/packages/archivist/packages/model/dist/types/ConfigV2.d.ts.map +0 -1
  88. package/packages/modules-mongo/packages/archivist/packages/model/dist/types/Labels.d.ts +0 -5
  89. package/packages/modules-mongo/packages/archivist/packages/model/dist/types/Labels.d.ts.map +0 -1
  90. package/packages/modules-mongo/packages/archivist/packages/model/dist/types/Params.d.ts +0 -9
  91. package/packages/modules-mongo/packages/archivist/packages/model/dist/types/Params.d.ts.map +0 -1
  92. package/packages/modules-mongo/packages/archivist/packages/model/dist/types/Schema.d.ts +0 -3
  93. package/packages/modules-mongo/packages/archivist/packages/model/dist/types/Schema.d.ts.map +0 -1
  94. package/packages/modules-mongo/packages/archivist/packages/model/dist/types/index.d.ts +0 -5
  95. package/packages/modules-mongo/packages/archivist/packages/model/dist/types/index.d.ts.map +0 -1
  96. package/packages/modules-mongo/packages/diviner/dist/browser/index.mjs +0 -1100
  97. package/packages/modules-mongo/packages/diviner/dist/browser/index.mjs.map +0 -1
  98. package/packages/modules-mongo/packages/diviner/dist/neutral/index.mjs +0 -1100
  99. package/packages/modules-mongo/packages/diviner/dist/neutral/index.mjs.map +0 -1
  100. package/packages/modules-mongo/packages/diviner/dist/node/index.mjs +0 -1100
  101. package/packages/modules-mongo/packages/diviner/dist/node/index.mjs.map +0 -1
  102. package/packages/modules-mongo/packages/diviner/dist/types/JobQueue/defineJobs.d.ts +0 -3
  103. package/packages/modules-mongo/packages/diviner/dist/types/JobQueue/defineJobs.d.ts.map +0 -1
  104. package/packages/modules-mongo/packages/diviner/dist/types/JobQueue/getName.d.ts +0 -2
  105. package/packages/modules-mongo/packages/diviner/dist/types/JobQueue/getName.d.ts.map +0 -1
  106. package/packages/modules-mongo/packages/diviner/dist/types/JobQueue/index.d.ts +0 -3
  107. package/packages/modules-mongo/packages/diviner/dist/types/JobQueue/index.d.ts.map +0 -1
  108. package/packages/modules-mongo/packages/diviner/dist/types/JobQueue/scheduleJobs.d.ts +0 -3
  109. package/packages/modules-mongo/packages/diviner/dist/types/JobQueue/scheduleJobs.d.ts.map +0 -1
  110. package/packages/modules-mongo/packages/diviner/dist/types/MongoDBAddressHistoryDiviner.d.ts +0 -61
  111. package/packages/modules-mongo/packages/diviner/dist/types/MongoDBAddressHistoryDiviner.d.ts.map +0 -1
  112. package/packages/modules-mongo/packages/diviner/dist/types/MongoDBAddressSpaceBatchDiviner.d.ts +0 -67
  113. package/packages/modules-mongo/packages/diviner/dist/types/MongoDBAddressSpaceBatchDiviner.d.ts.map +0 -1
  114. package/packages/modules-mongo/packages/diviner/dist/types/MongoDBAddressSpaceDiviner.d.ts +0 -57
  115. package/packages/modules-mongo/packages/diviner/dist/types/MongoDBAddressSpaceDiviner.d.ts.map +0 -1
  116. package/packages/modules-mongo/packages/diviner/dist/types/MongoDBBoundWitnessDiviner.d.ts +0 -59
  117. package/packages/modules-mongo/packages/diviner/dist/types/MongoDBBoundWitnessDiviner.d.ts.map +0 -1
  118. package/packages/modules-mongo/packages/diviner/dist/types/MongoDBBoundWitnessStatsDiviner.d.ts +0 -91
  119. package/packages/modules-mongo/packages/diviner/dist/types/MongoDBBoundWitnessStatsDiviner.d.ts.map +0 -1
  120. package/packages/modules-mongo/packages/diviner/dist/types/MongoDBPayloadDiviner.d.ts +0 -57
  121. package/packages/modules-mongo/packages/diviner/dist/types/MongoDBPayloadDiviner.d.ts.map +0 -1
  122. package/packages/modules-mongo/packages/diviner/dist/types/MongoDBPayloadStatsDiviner.d.ts +0 -104
  123. package/packages/modules-mongo/packages/diviner/dist/types/MongoDBPayloadStatsDiviner.d.ts.map +0 -1
  124. package/packages/modules-mongo/packages/diviner/dist/types/MongoDBSchemaListDiviner.d.ts +0 -61
  125. package/packages/modules-mongo/packages/diviner/dist/types/MongoDBSchemaListDiviner.d.ts.map +0 -1
  126. package/packages/modules-mongo/packages/diviner/dist/types/MongoDBSchemaStatsDiviner.d.ts +0 -113
  127. package/packages/modules-mongo/packages/diviner/dist/types/MongoDBSchemaStatsDiviner.d.ts.map +0 -1
  128. package/packages/modules-mongo/packages/diviner/dist/types/SetIterator/BatchSetIterator.d.ts +0 -10
  129. package/packages/modules-mongo/packages/diviner/dist/types/SetIterator/BatchSetIterator.d.ts.map +0 -1
  130. package/packages/modules-mongo/packages/diviner/dist/types/SetIterator/SetIterator.d.ts +0 -9
  131. package/packages/modules-mongo/packages/diviner/dist/types/SetIterator/SetIterator.d.ts.map +0 -1
  132. package/packages/modules-mongo/packages/diviner/dist/types/SetIterator/index.d.ts +0 -3
  133. package/packages/modules-mongo/packages/diviner/dist/types/SetIterator/index.d.ts.map +0 -1
  134. package/packages/modules-mongo/packages/diviner/dist/types/UserLocationsDiviner.d.ts +0 -41
  135. package/packages/modules-mongo/packages/diviner/dist/types/UserLocationsDiviner.d.ts.map +0 -1
  136. package/packages/modules-mongo/packages/diviner/dist/types/index.d.ts +0 -12
  137. package/packages/modules-mongo/packages/diviner/dist/types/index.d.ts.map +0 -1
  138. package/packages/modules-mongo/packages/module/dist/browser/index.mjs +0 -4
  139. package/packages/modules-mongo/packages/module/dist/browser/index.mjs.map +0 -1
  140. package/packages/modules-mongo/packages/module/dist/neutral/index.mjs +0 -4
  141. package/packages/modules-mongo/packages/module/dist/neutral/index.mjs.map +0 -1
  142. package/packages/modules-mongo/packages/module/dist/node/index.mjs +0 -4
  143. package/packages/modules-mongo/packages/module/dist/node/index.mjs.map +0 -1
  144. package/packages/modules-mongo/packages/module/dist/types/index.d.ts +0 -3
  145. package/packages/modules-mongo/packages/module/dist/types/index.d.ts.map +0 -1
  146. package/packages/modules-mongo/packages/module/packages/abstract/dist/browser/index.mjs +0 -277
  147. package/packages/modules-mongo/packages/module/packages/abstract/dist/browser/index.mjs.map +0 -1
  148. package/packages/modules-mongo/packages/module/packages/abstract/dist/neutral/index.mjs +0 -277
  149. package/packages/modules-mongo/packages/module/packages/abstract/dist/neutral/index.mjs.map +0 -1
  150. package/packages/modules-mongo/packages/module/packages/abstract/dist/node/index.mjs +0 -277
  151. package/packages/modules-mongo/packages/module/packages/abstract/dist/node/index.mjs.map +0 -1
  152. package/packages/modules-mongo/packages/module/packages/abstract/dist/types/AnyAbstractModule.d.ts +0 -4
  153. package/packages/modules-mongo/packages/module/packages/abstract/dist/types/AnyAbstractModule.d.ts.map +0 -1
  154. package/packages/modules-mongo/packages/module/packages/abstract/dist/types/Collections.d.ts +0 -9
  155. package/packages/modules-mongo/packages/module/packages/abstract/dist/types/Collections.d.ts.map +0 -1
  156. package/packages/modules-mongo/packages/module/packages/abstract/dist/types/Databases.d.ts +0 -4
  157. package/packages/modules-mongo/packages/module/packages/abstract/dist/types/Databases.d.ts.map +0 -1
  158. package/packages/modules-mongo/packages/module/packages/abstract/dist/types/Defaults.d.ts +0 -5
  159. package/packages/modules-mongo/packages/module/packages/abstract/dist/types/Defaults.d.ts.map +0 -1
  160. package/packages/modules-mongo/packages/module/packages/abstract/dist/types/IndexDescription.d.ts +0 -24
  161. package/packages/modules-mongo/packages/module/packages/abstract/dist/types/IndexDescription.d.ts.map +0 -1
  162. package/packages/modules-mongo/packages/module/packages/abstract/dist/types/Indexes/CollectionIndexFunction.d.ts +0 -3
  163. package/packages/modules-mongo/packages/module/packages/abstract/dist/types/Indexes/CollectionIndexFunction.d.ts.map +0 -1
  164. package/packages/modules-mongo/packages/module/packages/abstract/dist/types/Indexes/index.d.ts +0 -2
  165. package/packages/modules-mongo/packages/module/packages/abstract/dist/types/Indexes/index.d.ts.map +0 -1
  166. package/packages/modules-mongo/packages/module/packages/abstract/dist/types/Module.d.ts +0 -42
  167. package/packages/modules-mongo/packages/module/packages/abstract/dist/types/Module.d.ts.map +0 -1
  168. package/packages/modules-mongo/packages/module/packages/abstract/dist/types/ModuleV2.d.ts +0 -39
  169. package/packages/modules-mongo/packages/module/packages/abstract/dist/types/ModuleV2.d.ts.map +0 -1
  170. package/packages/modules-mongo/packages/module/packages/abstract/dist/types/config/getBaseMongoSdk.d.ts +0 -6
  171. package/packages/modules-mongo/packages/module/packages/abstract/dist/types/config/getBaseMongoSdk.d.ts.map +0 -1
  172. package/packages/modules-mongo/packages/module/packages/abstract/dist/types/config/getMongoDBConfig.d.ts +0 -5
  173. package/packages/modules-mongo/packages/module/packages/abstract/dist/types/config/getMongoDBConfig.d.ts.map +0 -1
  174. package/packages/modules-mongo/packages/module/packages/abstract/dist/types/config/hasMongoDBConfig.d.ts +0 -2
  175. package/packages/modules-mongo/packages/module/packages/abstract/dist/types/config/hasMongoDBConfig.d.ts.map +0 -1
  176. package/packages/modules-mongo/packages/module/packages/abstract/dist/types/config/index.d.ts +0 -4
  177. package/packages/modules-mongo/packages/module/packages/abstract/dist/types/config/index.d.ts.map +0 -1
  178. package/packages/modules-mongo/packages/module/packages/abstract/dist/types/index.d.ts +0 -10
  179. package/packages/modules-mongo/packages/module/packages/abstract/dist/types/index.d.ts.map +0 -1
  180. package/packages/modules-mongo/packages/module/packages/abstract/dist/types/util/dbProperty.d.ts +0 -4
  181. package/packages/modules-mongo/packages/module/packages/abstract/dist/types/util/dbProperty.d.ts.map +0 -1
  182. package/packages/modules-mongo/packages/module/packages/abstract/dist/types/util/index.d.ts +0 -2
  183. package/packages/modules-mongo/packages/module/packages/abstract/dist/types/util/index.d.ts.map +0 -1
  184. package/packages/modules-mongo/packages/module/packages/model/dist/browser/index.mjs +0 -10
  185. package/packages/modules-mongo/packages/module/packages/model/dist/browser/index.mjs.map +0 -1
  186. package/packages/modules-mongo/packages/module/packages/model/dist/neutral/index.mjs +0 -10
  187. package/packages/modules-mongo/packages/module/packages/model/dist/neutral/index.mjs.map +0 -1
  188. package/packages/modules-mongo/packages/module/packages/model/dist/node/index.mjs +0 -10
  189. package/packages/modules-mongo/packages/module/packages/model/dist/node/index.mjs.map +0 -1
  190. package/packages/modules-mongo/packages/module/packages/model/dist/types/Config.d.ts +0 -9
  191. package/packages/modules-mongo/packages/module/packages/model/dist/types/Config.d.ts.map +0 -1
  192. package/packages/modules-mongo/packages/module/packages/model/dist/types/ConfigV2.d.ts +0 -8
  193. package/packages/modules-mongo/packages/module/packages/model/dist/types/ConfigV2.d.ts.map +0 -1
  194. package/packages/modules-mongo/packages/module/packages/model/dist/types/Labels.d.ts +0 -6
  195. package/packages/modules-mongo/packages/module/packages/model/dist/types/Labels.d.ts.map +0 -1
  196. package/packages/modules-mongo/packages/module/packages/model/dist/types/Module.d.ts +0 -9
  197. package/packages/modules-mongo/packages/module/packages/model/dist/types/Module.d.ts.map +0 -1
  198. package/packages/modules-mongo/packages/module/packages/model/dist/types/ModuleV2.d.ts +0 -7
  199. package/packages/modules-mongo/packages/module/packages/model/dist/types/ModuleV2.d.ts.map +0 -1
  200. package/packages/modules-mongo/packages/module/packages/model/dist/types/MongoDBModuleStatic.d.ts +0 -5
  201. package/packages/modules-mongo/packages/module/packages/model/dist/types/MongoDBModuleStatic.d.ts.map +0 -1
  202. package/packages/modules-mongo/packages/module/packages/model/dist/types/Params.d.ts +0 -10
  203. package/packages/modules-mongo/packages/module/packages/model/dist/types/Params.d.ts.map +0 -1
  204. package/packages/modules-mongo/packages/module/packages/model/dist/types/ParamsV2.d.ts +0 -9
  205. package/packages/modules-mongo/packages/module/packages/model/dist/types/ParamsV2.d.ts.map +0 -1
  206. package/packages/modules-mongo/packages/module/packages/model/dist/types/Schema.d.ts +0 -3
  207. package/packages/modules-mongo/packages/module/packages/model/dist/types/Schema.d.ts.map +0 -1
  208. package/packages/modules-mongo/packages/module/packages/model/dist/types/index.d.ts +0 -10
  209. package/packages/modules-mongo/packages/module/packages/model/dist/types/index.d.ts.map +0 -1
  210. package/packages/modules-mongo/packages/payload/dist/browser/index.mjs +0 -51
  211. package/packages/modules-mongo/packages/payload/dist/browser/index.mjs.map +0 -1
  212. package/packages/modules-mongo/packages/payload/dist/neutral/index.mjs +0 -51
  213. package/packages/modules-mongo/packages/payload/dist/neutral/index.mjs.map +0 -1
  214. package/packages/modules-mongo/packages/payload/dist/node/index.mjs +0 -51
  215. package/packages/modules-mongo/packages/payload/dist/node/index.mjs.map +0 -1
  216. package/packages/modules-mongo/packages/payload/dist/types/BoundWitness/BoundWitnessMongoMeta.d.ts +0 -7
  217. package/packages/modules-mongo/packages/payload/dist/types/BoundWitness/BoundWitnessMongoMeta.d.ts.map +0 -1
  218. package/packages/modules-mongo/packages/payload/dist/types/BoundWitness/BoundWitnessWithMongoMeta.d.ts +0 -6
  219. package/packages/modules-mongo/packages/payload/dist/types/BoundWitness/BoundWitnessWithMongoMeta.d.ts.map +0 -1
  220. package/packages/modules-mongo/packages/payload/dist/types/BoundWitness/index.d.ts +0 -3
  221. package/packages/modules-mongo/packages/payload/dist/types/BoundWitness/index.d.ts.map +0 -1
  222. package/packages/modules-mongo/packages/payload/dist/types/Mappings/fromDbRepresentation.d.ts +0 -8
  223. package/packages/modules-mongo/packages/payload/dist/types/Mappings/fromDbRepresentation.d.ts.map +0 -1
  224. package/packages/modules-mongo/packages/payload/dist/types/Mappings/index.d.ts +0 -3
  225. package/packages/modules-mongo/packages/payload/dist/types/Mappings/index.d.ts.map +0 -1
  226. package/packages/modules-mongo/packages/payload/dist/types/Mappings/toDbRepresentation.d.ts +0 -8
  227. package/packages/modules-mongo/packages/payload/dist/types/Mappings/toDbRepresentation.d.ts.map +0 -1
  228. package/packages/modules-mongo/packages/payload/dist/types/Payload/PayloadMongoMeta.d.ts +0 -11
  229. package/packages/modules-mongo/packages/payload/dist/types/Payload/PayloadMongoMeta.d.ts.map +0 -1
  230. package/packages/modules-mongo/packages/payload/dist/types/Payload/PayloadWithMongoMeta.d.ts +0 -5
  231. package/packages/modules-mongo/packages/payload/dist/types/Payload/PayloadWithMongoMeta.d.ts.map +0 -1
  232. package/packages/modules-mongo/packages/payload/dist/types/Payload/index.d.ts +0 -3
  233. package/packages/modules-mongo/packages/payload/dist/types/Payload/index.d.ts.map +0 -1
  234. package/packages/modules-mongo/packages/payload/dist/types/index.d.ts +0 -4
  235. package/packages/modules-mongo/packages/payload/dist/types/index.d.ts.map +0 -1
@@ -1,274 +0,0 @@
1
- // src/Archivist.ts
2
- import { exists } from "@xylabs/exists";
3
- import { AbstractArchivist } from "@xyo-network/archivist-abstract";
4
- import { ArchivistInsertQuerySchema, ArchivistNextQuerySchema } from "@xyo-network/archivist-model";
5
- import { MongoDBArchivistConfigSchema } from "@xyo-network/archivist-model-mongodb";
6
- import { MongoDBModuleMixin } from "@xyo-network/module-abstract-mongodb";
7
- import { fromDbRepresentation, toDbRepresentation } from "@xyo-network/payload-mongodb";
8
- import { ObjectId } from "mongodb";
9
-
10
- // src/lib/validByType.ts
11
- import { isBoundWitness, isQueryBoundWitness } from "@xyo-network/boundwitness-model";
12
- import { BoundWitnessWrapper, QueryBoundWitnessWrapper } from "@xyo-network/boundwitness-wrapper";
13
- import { PayloadWrapper } from "@xyo-network/payload-wrapper";
14
- var validByType = async (payloads = []) => {
15
- const results = [[], []];
16
- await Promise.all(
17
- payloads.map(async (payload) => {
18
- if (isBoundWitness(payload)) {
19
- const wrapper = isQueryBoundWitness(payload) ? QueryBoundWitnessWrapper : BoundWitnessWrapper;
20
- const bw = wrapper.parse(payload);
21
- if (await bw.getValid()) {
22
- results[0].push(payload);
23
- } else {
24
- const errors = await bw.getErrors();
25
- console.log(`validByType.Error: ${JSON.stringify(errors, null, 2)}`);
26
- }
27
- } else {
28
- const payloadWrapper = PayloadWrapper.wrap(payload);
29
- if (await payloadWrapper.getValid()) {
30
- results[1].push(payload);
31
- }
32
- }
33
- })
34
- );
35
- return results;
36
- };
37
-
38
- // src/Archivist.ts
39
- var MongoDBArchivistBase = MongoDBModuleMixin(AbstractArchivist);
40
- var MongoDBArchivist = class extends MongoDBArchivistBase {
41
- static configSchemas = [...super.configSchemas, MongoDBArchivistConfigSchema];
42
- static defaultConfigSchema = MongoDBArchivistConfigSchema;
43
- queries = [ArchivistInsertQuerySchema, ArchivistNextQuerySchema, ...super.queries];
44
- /**
45
- * The amount of time to allow the aggregate query to execute
46
- */
47
- aggregateTimeoutMs = 1e4;
48
- async findOneByHash(hash) {
49
- const dataPayload = await this.payloads.findOne({ _$hash: hash });
50
- if (dataPayload) {
51
- return dataPayload;
52
- } else {
53
- const dataBw = await this.boundWitnesses.findOne({ _$hash: hash });
54
- if (dataBw) {
55
- return dataBw;
56
- } else {
57
- const payload = await this.payloads.findOne({ _hash: hash });
58
- if (payload) {
59
- return payload;
60
- } else {
61
- const bw = await this.boundWitnesses.findOne({ _hash: hash });
62
- return bw ?? void 0;
63
- }
64
- }
65
- }
66
- }
67
- async findOneBySequence(sequence) {
68
- const dataPayload = await this.payloads.findOne({ _sequence: sequence });
69
- if (dataPayload) {
70
- return dataPayload;
71
- } else {
72
- const dataBw = await this.boundWitnesses.findOne({ _sequence: sequence });
73
- return dataBw;
74
- }
75
- }
76
- async getHandler(hashes) {
77
- let remainingHashes = [...hashes];
78
- const dataPayloads = (await Promise.all(remainingHashes.map((_dataHash) => this.payloads.findOne({ _dataHash })))).filter(exists);
79
- const dataPayloadsHashes = new Set(dataPayloads.map((payload) => payload._dataHash));
80
- remainingHashes = remainingHashes.filter((hash) => !dataPayloadsHashes.has(hash));
81
- const dataBws = (await Promise.all(remainingHashes.map((_dataHash) => this.boundWitnesses.findOne({ _dataHash })))).filter(exists);
82
- const dataBwsHashes = new Set(dataBws.map((payload) => payload._dataHash));
83
- remainingHashes = remainingHashes.filter((hash) => !dataBwsHashes.has(hash));
84
- const payloads = (await Promise.all(remainingHashes.map((_hash) => this.payloads.findOne({ _hash })))).filter(exists);
85
- const payloadsHashes = new Set(payloads.map((payload) => payload._hash));
86
- remainingHashes = remainingHashes.filter((hash) => !payloadsHashes.has(hash));
87
- const bws = (await Promise.all(remainingHashes.map((_hash) => this.boundWitnesses.findOne({ _hash })))).filter(exists);
88
- const bwsHashes = new Set(bws.map((payload) => payload._hash));
89
- remainingHashes = remainingHashes.filter((hash) => !bwsHashes.has(hash));
90
- const foundPayloads = [...dataPayloads, ...dataBws, ...payloads, ...bws];
91
- const result = foundPayloads.map(fromDbRepresentation);
92
- return result;
93
- }
94
- async insertHandler(payloads) {
95
- const [bw, p] = await validByType(payloads);
96
- const payloadsWithExternalMeta = p.map((value) => toDbRepresentation(value));
97
- if (payloadsWithExternalMeta.length > 0) {
98
- const payloadsResult = await this.payloads.insertMany(payloadsWithExternalMeta);
99
- if (!payloadsResult.acknowledged || payloadsResult.insertedCount !== payloadsWithExternalMeta.length)
100
- throw new Error("MongoDBArchivist: Error inserting Payloads");
101
- }
102
- const boundWitnessesWithExternalMeta = bw.map((value) => toDbRepresentation(value));
103
- if (boundWitnessesWithExternalMeta.length > 0) {
104
- const boundWitnessesResult = await this.boundWitnesses.insertMany(boundWitnessesWithExternalMeta);
105
- if (!boundWitnessesResult.acknowledged || boundWitnessesResult.insertedCount !== boundWitnessesWithExternalMeta.length)
106
- throw new Error("MongoDBArchivist: Error inserting BoundWitnesses");
107
- }
108
- return [...boundWitnessesWithExternalMeta, ...payloadsWithExternalMeta].map(fromDbRepresentation);
109
- }
110
- async nextHandler(options) {
111
- let {
112
- limit,
113
- cursor,
114
- order,
115
- open
116
- } = options ?? { limit: 10, order: "desc" };
117
- if (!limit) limit = 10;
118
- if (limit > 100) limit = 100;
119
- if (order != "asc") order = "desc";
120
- let id;
121
- if (cursor) {
122
- const payload = await this.findOneBySequence(cursor);
123
- if (payload) id = payload._id;
124
- } else {
125
- id = order === "asc" ? ObjectId.createFromTime(0) : ObjectId.createFromTime((Date.now() + 1e4) / 1e3);
126
- }
127
- if (!id) return [];
128
- const sort = order === "asc" ? 1 : -1;
129
- const match = order === "asc" ? open ? { _id: { $gte: id } } : { _id: { $gt: id } } : open ? { _id: { $lte: id } } : { _id: { $lt: id } };
130
- const foundPayloads = await this.payloads.useCollection((collection) => {
131
- return collection.aggregate([
132
- // Pre-filter payloads collection
133
- { $match: match },
134
- // Sort payloads by _id
135
- { $sort: { _id: sort } },
136
- // Limit payloads to the first N payloads
137
- { $limit: limit },
138
- // Combine with filtered boundWitnesses collection
139
- {
140
- $unionWith: {
141
- coll: this.boundWitnessSdkConfig.collection,
142
- pipeline: [
143
- { $match: match },
144
- // Pre-filter boundWitnesses
145
- { $sort: { _id: sort } },
146
- // Sort boundWitnesses by _id
147
- { $limit: limit }
148
- // Limit boundWitnesses to the first N boundWitnesses
149
- ]
150
- }
151
- },
152
- // Sort the combined result by _id
153
- { $sort: { _id: sort } },
154
- // Limit the final result to N documents
155
- { $limit: limit }
156
- ]).maxTimeMS(this.aggregateTimeoutMs).toArray();
157
- });
158
- return foundPayloads.map(fromDbRepresentation);
159
- }
160
- async startHandler() {
161
- await super.startHandler();
162
- await this.ensureIndexes();
163
- return true;
164
- }
165
- };
166
-
167
- // src/ArchivistV2.ts
168
- import { exists as exists2 } from "@xylabs/exists";
169
- import { AbstractArchivist as AbstractArchivist2 } from "@xyo-network/archivist-abstract";
170
- import { ArchivistInsertQuerySchema as ArchivistInsertQuerySchema2, ArchivistNextQuerySchema as ArchivistNextQuerySchema2 } from "@xyo-network/archivist-model";
171
- import { MongoDBArchivistConfigSchema as MongoDBArchivistConfigSchema2 } from "@xyo-network/archivist-model-mongodb";
172
- import { MongoDBModuleMixinV2 } from "@xyo-network/module-abstract-mongodb";
173
- import {
174
- SequenceConstants
175
- } from "@xyo-network/payload-model";
176
- import { fromDbRepresentation as fromDbRepresentation2, toDbRepresentation as toDbRepresentation2 } from "@xyo-network/payload-mongodb";
177
- var MongoDBArchivistBaseV2 = MongoDBModuleMixinV2(AbstractArchivist2);
178
- var MONGODB_DUPLICATE_KEY_ERROR = 11e3;
179
- var MongoDBArchivistV2 = class extends MongoDBArchivistBaseV2 {
180
- static configSchemas = [...super.configSchemas, MongoDBArchivistConfigSchema2];
181
- static defaultConfigSchema = MongoDBArchivistConfigSchema2;
182
- queries = [ArchivistInsertQuerySchema2, ArchivistNextQuerySchema2, ...super.queries];
183
- /**
184
- * The amount of time to allow the aggregate query to execute
185
- */
186
- aggregateTimeoutMs = 1e4;
187
- async findOneByHash(hash) {
188
- const dataPayload = await this.payloads.findOne({ _$hash: hash });
189
- if (dataPayload) {
190
- return dataPayload;
191
- } else {
192
- const payload = await this.payloads.findOne({ _hash: hash });
193
- if (payload) {
194
- return payload;
195
- }
196
- }
197
- }
198
- async findOneBySequence(sequence) {
199
- const dataPayload = await this.payloads.findOne({ _sequence: sequence });
200
- if (dataPayload) {
201
- return dataPayload;
202
- }
203
- }
204
- async getHandler(hashes) {
205
- let remainingHashes = [...hashes];
206
- const dataPayloads = (await Promise.all(remainingHashes.map((_dataHash) => this.payloads.findOne({ _dataHash })))).filter(exists2);
207
- const dataPayloadsHashes = new Set(dataPayloads.map((payload) => payload._dataHash));
208
- remainingHashes = remainingHashes.filter((hash) => !dataPayloadsHashes.has(hash));
209
- const payloads = (await Promise.all(remainingHashes.map((_hash) => this.payloads.findOne({ _hash })))).filter(exists2);
210
- const payloadsHashes = new Set(payloads.map((payload) => payload._hash));
211
- remainingHashes = remainingHashes.filter((hash) => !payloadsHashes.has(hash));
212
- const foundPayloads = [...dataPayloads, ...payloads];
213
- const result = foundPayloads.map(fromDbRepresentation2);
214
- return result;
215
- }
216
- async insertHandler(payloads) {
217
- const payloadsWithExternalMeta = payloads.map((value) => toDbRepresentation2(value));
218
- if (payloadsWithExternalMeta.length > 0) {
219
- try {
220
- const payloadsResult = await this.payloads.insertMany(payloadsWithExternalMeta, { ordered: false });
221
- if (!payloadsResult.acknowledged) throw new Error("MongoDBArchivist: Error inserting Payloads");
222
- } catch (error) {
223
- const mongoError = error;
224
- if (mongoError?.code != MONGODB_DUPLICATE_KEY_ERROR) throw error;
225
- }
226
- }
227
- return [...payloadsWithExternalMeta].map(fromDbRepresentation2);
228
- }
229
- async nextHandler(options) {
230
- let {
231
- limit,
232
- cursor,
233
- order,
234
- open = true
235
- } = options ?? { limit: 10, order: "desc" };
236
- if (!limit) limit = 10;
237
- if (limit > 100) limit = 100;
238
- if (order != "asc") order = "desc";
239
- let sequence;
240
- if (cursor) {
241
- const payload = await this.findOneBySequence(cursor);
242
- if (payload) sequence = payload._sequence;
243
- } else {
244
- sequence = order === "asc" ? SequenceConstants.minLocalSequence : SequenceConstants.maxLocalSequence;
245
- }
246
- if (!sequence) return [];
247
- const sort = order === "asc" ? 1 : -1;
248
- const match = order === "asc" ? open ? { _sequence: { $gt: sequence } } : { _sequence: { $gte: sequence } } : open ? { _sequence: { $lt: sequence } } : { _sequence: { $lte: sequence } };
249
- const foundPayloads = await this.payloads.useCollection((collection) => {
250
- return collection.aggregate([
251
- // Pre-filter payloads collection
252
- { $match: match },
253
- // Sort payloads by _sequence
254
- { $sort: { _sequence: sort } },
255
- // Limit payloads to the first N payloads
256
- { $limit: limit }
257
- ]).maxTimeMS(this.aggregateTimeoutMs).toArray();
258
- });
259
- return foundPayloads.map(fromDbRepresentation2);
260
- }
261
- async startHandler() {
262
- await super.startHandler();
263
- await this.ensureIndexes();
264
- return true;
265
- }
266
- };
267
-
268
- // src/index.ts
269
- export * from "@xyo-network/archivist-model-mongodb";
270
- export {
271
- MongoDBArchivist,
272
- MongoDBArchivistV2
273
- };
274
- //# sourceMappingURL=index.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/Archivist.ts","../../src/lib/validByType.ts","../../src/ArchivistV2.ts","../../src/index.ts"],"sourcesContent":["import { exists } from '@xylabs/exists'\nimport type { Hash } from '@xylabs/hex'\nimport { AbstractArchivist } from '@xyo-network/archivist-abstract'\nimport type { ArchivistNextOptions } from '@xyo-network/archivist-model'\nimport { ArchivistInsertQuerySchema, ArchivistNextQuerySchema } from '@xyo-network/archivist-model'\nimport { MongoDBArchivistConfigSchema } from '@xyo-network/archivist-model-mongodb'\nimport { MongoDBModuleMixin } from '@xyo-network/module-abstract-mongodb'\nimport type {\n Payload, Schema, Sequence, WithStorageMeta,\n} from '@xyo-network/payload-model'\nimport type { PayloadWithMongoMeta } from '@xyo-network/payload-mongodb'\nimport { fromDbRepresentation, toDbRepresentation } from '@xyo-network/payload-mongodb'\nimport { ObjectId } from 'mongodb'\n\nimport { validByType } from './lib/index.js'\n\nconst MongoDBArchivistBase = MongoDBModuleMixin(AbstractArchivist)\n\nexport class MongoDBArchivist extends MongoDBArchivistBase {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, MongoDBArchivistConfigSchema]\n static override readonly defaultConfigSchema: Schema = MongoDBArchivistConfigSchema\n\n override readonly queries: string[] = [ArchivistInsertQuerySchema, ArchivistNextQuerySchema, ...super.queries]\n\n /**\n * The amount of time to allow the aggregate query to execute\n */\n protected readonly aggregateTimeoutMs = 10_000\n\n protected async findOneByHash(hash: Hash) {\n const dataPayload = (await this.payloads.findOne({ _$hash: hash }))\n if (dataPayload) {\n return dataPayload\n } else {\n const dataBw = (await this.boundWitnesses.findOne({ _$hash: hash }))\n if (dataBw) {\n return dataBw\n } else {\n const payload = (await this.payloads.findOne({ _hash: hash }))\n if (payload) {\n return payload\n } else {\n const bw = (await this.boundWitnesses.findOne({ _hash: hash }))\n return bw ?? undefined\n }\n }\n }\n }\n\n protected async findOneBySequence(sequence: Sequence) {\n const dataPayload = (await this.payloads.findOne({ _sequence: sequence }))\n if (dataPayload) {\n return dataPayload\n } else {\n const dataBw = (await this.boundWitnesses.findOne({ _sequence: sequence }))\n return dataBw\n }\n }\n\n protected override async getHandler(hashes: Hash[]): Promise<WithStorageMeta<Payload>[]> {\n let remainingHashes = [...hashes]\n\n const dataPayloads = (await Promise.all(remainingHashes.map(_dataHash => this.payloads.findOne({ _dataHash })))).filter(exists)\n const dataPayloadsHashes = new Set(dataPayloads.map(payload => payload._dataHash))\n remainingHashes = remainingHashes.filter(hash => !dataPayloadsHashes.has(hash))\n\n const dataBws = (await Promise.all(remainingHashes.map(_dataHash => this.boundWitnesses.findOne({ _dataHash })))).filter(exists)\n const dataBwsHashes = new Set(dataBws.map(payload => payload._dataHash))\n remainingHashes = remainingHashes.filter(hash => !dataBwsHashes.has(hash))\n\n const payloads = (await Promise.all(remainingHashes.map(_hash => this.payloads.findOne({ _hash })))).filter(exists)\n const payloadsHashes = new Set(payloads.map(payload => payload._hash))\n remainingHashes = remainingHashes.filter(hash => !payloadsHashes.has(hash))\n\n const bws = (await Promise.all(remainingHashes.map(_hash => this.boundWitnesses.findOne({ _hash })))).filter(exists)\n const bwsHashes = new Set(bws.map(payload => payload._hash))\n // eslint-disable-next-line sonarjs/no-dead-store\n remainingHashes = remainingHashes.filter(hash => !bwsHashes.has(hash))\n\n const foundPayloads = [...dataPayloads, ...dataBws, ...payloads, ...bws] as PayloadWithMongoMeta<Payload>[]\n const result = foundPayloads.map(fromDbRepresentation)\n // console.log(`getHandler: ${JSON.stringify(hashes, null, 2)}:${JSON.stringify(result, null, 2)}`)\n return result\n }\n\n protected override async insertHandler(payloads: WithStorageMeta<Payload>[]): Promise<WithStorageMeta<Payload>[]> {\n const [bw, p] = await validByType(payloads)\n const payloadsWithExternalMeta = p.map(value => toDbRepresentation(value))\n if (payloadsWithExternalMeta.length > 0) {\n const payloadsResult = await this.payloads.insertMany(payloadsWithExternalMeta)\n if (!payloadsResult.acknowledged || payloadsResult.insertedCount !== payloadsWithExternalMeta.length)\n throw new Error('MongoDBArchivist: Error inserting Payloads')\n }\n\n const boundWitnessesWithExternalMeta = bw.map(value => toDbRepresentation(value))\n if (boundWitnessesWithExternalMeta.length > 0) {\n const boundWitnessesResult = await this.boundWitnesses.insertMany(boundWitnessesWithExternalMeta)\n if (!boundWitnessesResult.acknowledged || boundWitnessesResult.insertedCount !== boundWitnessesWithExternalMeta.length)\n throw new Error('MongoDBArchivist: Error inserting BoundWitnesses')\n }\n\n return [...boundWitnessesWithExternalMeta, ...payloadsWithExternalMeta].map(fromDbRepresentation)\n }\n\n protected override async nextHandler(options?: ArchivistNextOptions): Promise<WithStorageMeta<Payload>[]> {\n // Sanitize inputs and set defaults\n let {\n limit, cursor, order, open,\n } = options ?? { limit: 10, order: 'desc' }\n\n if (!limit) limit = 10\n if (limit > 100) limit = 100\n\n if (order != 'asc') order = 'desc'\n\n let id: ObjectId | undefined\n if (cursor) {\n const payload = await this.findOneBySequence(cursor)\n // TODO: Should we throw an error if the requested payload is not found?\n if (payload) id = payload._id\n } else {\n id = order === 'asc'\n // If ascending, start from the beginning of time\n ? ObjectId.createFromTime(0)\n // If descending, start from now (plus a bit more in the future to ensure\n // them most recent ObjectIds are included)\n : ObjectId.createFromTime((Date.now() + 10_000) / 1000)\n }\n if (!id) return []\n\n // Create aggregate criteria\n const sort = order === 'asc' ? 1 : -1\n // TODO: How to handle random component of ID across multiple collections\n // to ensure we don't skip some payloads\n const match = order === 'asc' ? (open ? { _id: { $gte: id } } : { _id: { $gt: id } }) : (open ? { _id: { $lte: id } } : { _id: { $lt: id } })\n\n // Run the aggregate query\n const foundPayloads = await this.payloads.useCollection((collection) => {\n return collection\n .aggregate<PayloadWithMongoMeta>([\n // Pre-filter payloads collection\n { $match: match },\n // Sort payloads by _id\n { $sort: { _id: sort } },\n // Limit payloads to the first N payloads\n { $limit: limit },\n // Combine with filtered boundWitnesses collection\n {\n $unionWith: {\n coll: this.boundWitnessSdkConfig.collection,\n pipeline: [\n { $match: match }, // Pre-filter boundWitnesses\n { $sort: { _id: sort } }, // Sort boundWitnesses by _id\n { $limit: limit }, // Limit boundWitnesses to the first N boundWitnesses\n ],\n },\n },\n // Sort the combined result by _id\n { $sort: { _id: sort } },\n // Limit the final result to N documents\n { $limit: limit },\n ])\n .maxTimeMS(this.aggregateTimeoutMs)\n .toArray()\n })\n\n // Convert from DB representation to Payloads\n return foundPayloads.map(fromDbRepresentation)\n }\n\n protected override async startHandler() {\n await super.startHandler()\n await this.ensureIndexes()\n return true\n }\n}\n","import type { BoundWitness } from '@xyo-network/boundwitness-model'\nimport { isBoundWitness, isQueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { BoundWitnessWrapper, QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport type { Payload, WithStorageMeta } from '@xyo-network/payload-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\n\nexport const validByType = async (payloads: WithStorageMeta<Payload>[] = []) => {\n const results: [WithStorageMeta<BoundWitness>[], WithStorageMeta<Payload>[]] = [[], []]\n await Promise.all(\n payloads.map(async (payload) => {\n if (isBoundWitness(payload)) {\n const wrapper = isQueryBoundWitness(payload) ? QueryBoundWitnessWrapper : BoundWitnessWrapper\n const bw = wrapper.parse(payload)\n if (await bw.getValid()) {\n results[0].push(payload)\n } else {\n const errors = await bw.getErrors()\n console.log(`validByType.Error: ${JSON.stringify(errors, null, 2)}`)\n }\n } else {\n const payloadWrapper = PayloadWrapper.wrap(payload)\n if (await payloadWrapper.getValid()) {\n results[1].push(payload)\n }\n }\n }),\n )\n return results\n}\n","import { exists } from '@xylabs/exists'\nimport type { Hash } from '@xylabs/hex'\nimport { AbstractArchivist } from '@xyo-network/archivist-abstract'\nimport type { ArchivistNextOptions } from '@xyo-network/archivist-model'\nimport { ArchivistInsertQuerySchema, ArchivistNextQuerySchema } from '@xyo-network/archivist-model'\nimport { MongoDBArchivistConfigSchema } from '@xyo-network/archivist-model-mongodb'\nimport { MongoDBModuleMixinV2 } from '@xyo-network/module-abstract-mongodb'\nimport {\n type Payload, type Schema, type Sequence, SequenceConstants,\n type WithStorageMeta,\n} from '@xyo-network/payload-model'\nimport type { PayloadWithMongoMeta } from '@xyo-network/payload-mongodb'\nimport { fromDbRepresentation, toDbRepresentation } from '@xyo-network/payload-mongodb'\nimport type { MongoError } from 'mongodb'\n\nconst MongoDBArchivistBaseV2 = MongoDBModuleMixinV2(AbstractArchivist)\n\nconst MONGODB_DUPLICATE_KEY_ERROR = 11_000\n\nexport class MongoDBArchivistV2 extends MongoDBArchivistBaseV2 {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, MongoDBArchivistConfigSchema]\n static override readonly defaultConfigSchema: Schema = MongoDBArchivistConfigSchema\n\n override readonly queries: string[] = [ArchivistInsertQuerySchema, ArchivistNextQuerySchema, ...super.queries]\n\n /**\n * The amount of time to allow the aggregate query to execute\n */\n protected readonly aggregateTimeoutMs = 10_000\n\n protected async findOneByHash(hash: Hash) {\n const dataPayload = (await this.payloads.findOne({ _$hash: hash }))\n if (dataPayload) {\n return dataPayload\n } else {\n const payload = (await this.payloads.findOne({ _hash: hash }))\n if (payload) {\n return payload\n }\n }\n }\n\n protected async findOneBySequence(sequence: Sequence) {\n const dataPayload = (await this.payloads.findOne({ _sequence: sequence }))\n if (dataPayload) {\n return dataPayload\n }\n }\n\n protected override async getHandler(hashes: Hash[]): Promise<WithStorageMeta<Payload>[]> {\n let remainingHashes = [...hashes]\n\n const dataPayloads = (await Promise.all(remainingHashes.map(_dataHash => this.payloads.findOne({ _dataHash })))).filter(exists)\n const dataPayloadsHashes = new Set(dataPayloads.map(payload => payload._dataHash))\n remainingHashes = remainingHashes.filter(hash => !dataPayloadsHashes.has(hash))\n\n const payloads = (await Promise.all(remainingHashes.map(_hash => this.payloads.findOne({ _hash })))).filter(exists)\n const payloadsHashes = new Set(payloads.map(payload => payload._hash))\n // eslint-disable-next-line sonarjs/no-dead-store\n remainingHashes = remainingHashes.filter(hash => !payloadsHashes.has(hash))\n\n const foundPayloads = [...dataPayloads, ...payloads] as PayloadWithMongoMeta<Payload>[]\n const result = foundPayloads.map(fromDbRepresentation)\n return result\n }\n\n protected override async insertHandler(payloads: WithStorageMeta<Payload>[]): Promise<WithStorageMeta<Payload>[]> {\n const payloadsWithExternalMeta = payloads.map(value => toDbRepresentation(value))\n if (payloadsWithExternalMeta.length > 0) {\n try {\n const payloadsResult = await this.payloads.insertMany(payloadsWithExternalMeta, { ordered: false })\n if (!payloadsResult.acknowledged) throw new Error('MongoDBArchivist: Error inserting Payloads')\n } catch (error) {\n const mongoError = error as MongoError\n // NOTE: Intentional coercive equality since Mongo error codes are\n // of type string | number\n if (mongoError?.code != MONGODB_DUPLICATE_KEY_ERROR) throw error\n }\n }\n return [...payloadsWithExternalMeta].map(fromDbRepresentation)\n }\n\n protected override async nextHandler(options?: ArchivistNextOptions): Promise<WithStorageMeta<Payload>[]> {\n // Sanitize inputs and set defaults\n let {\n limit, cursor, order, open = true,\n } = options ?? { limit: 10, order: 'desc' }\n\n if (!limit) limit = 10\n if (limit > 100) limit = 100\n\n if (order != 'asc') order = 'desc'\n\n let sequence: Sequence | undefined\n if (cursor) {\n const payload = await this.findOneBySequence(cursor)\n // TODO: Should we throw an error if the requested payload is not found?\n if (payload) sequence = payload._sequence\n } else {\n sequence = order === 'asc'\n // If ascending, start from the beginning of time\n ? SequenceConstants.minLocalSequence\n // If descending, start from now (plus a bit more in the future to ensure\n // them most recent ObjectIds are included)\n : SequenceConstants.maxLocalSequence\n }\n if (!sequence) return []\n\n // Create find criteria\n const sort = order === 'asc' ? 1 : -1\n\n const match = order === 'asc'\n ? (open\n ? { _sequence: { $gt: sequence } }\n : { _sequence: { $gte: sequence } })\n : (open\n ? { _sequence: { $lt: sequence } }\n : { _sequence: { $lte: sequence } })\n\n // Run the aggregate query\n const foundPayloads = await this.payloads.useCollection((collection) => {\n return collection\n .aggregate<PayloadWithMongoMeta>([\n // Pre-filter payloads collection\n { $match: match },\n // Sort payloads by _sequence\n { $sort: { _sequence: sort } },\n // Limit payloads to the first N payloads\n { $limit: limit },\n ])\n .maxTimeMS(this.aggregateTimeoutMs)\n .toArray()\n })\n\n // Convert from DB representation to Payloads\n return foundPayloads.map(fromDbRepresentation)\n }\n\n protected override async startHandler() {\n await super.startHandler()\n await this.ensureIndexes()\n return true\n }\n}\n","export * from './Archivist.js'\nexport * from './ArchivistV2.ts'\nexport * from '@xyo-network/archivist-model-mongodb'\n"],"mappings":"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","names":["exists","AbstractArchivist","ArchivistInsertQuerySchema","ArchivistNextQuerySchema","MongoDBArchivistConfigSchema","fromDbRepresentation","toDbRepresentation"]}
@@ -1,274 +0,0 @@
1
- // src/Archivist.ts
2
- import { exists } from "@xylabs/exists";
3
- import { AbstractArchivist } from "@xyo-network/archivist-abstract";
4
- import { ArchivistInsertQuerySchema, ArchivistNextQuerySchema } from "@xyo-network/archivist-model";
5
- import { MongoDBArchivistConfigSchema } from "@xyo-network/archivist-model-mongodb";
6
- import { MongoDBModuleMixin } from "@xyo-network/module-abstract-mongodb";
7
- import { fromDbRepresentation, toDbRepresentation } from "@xyo-network/payload-mongodb";
8
- import { ObjectId } from "mongodb";
9
-
10
- // src/lib/validByType.ts
11
- import { isBoundWitness, isQueryBoundWitness } from "@xyo-network/boundwitness-model";
12
- import { BoundWitnessWrapper, QueryBoundWitnessWrapper } from "@xyo-network/boundwitness-wrapper";
13
- import { PayloadWrapper } from "@xyo-network/payload-wrapper";
14
- var validByType = async (payloads = []) => {
15
- const results = [[], []];
16
- await Promise.all(
17
- payloads.map(async (payload) => {
18
- if (isBoundWitness(payload)) {
19
- const wrapper = isQueryBoundWitness(payload) ? QueryBoundWitnessWrapper : BoundWitnessWrapper;
20
- const bw = wrapper.parse(payload);
21
- if (await bw.getValid()) {
22
- results[0].push(payload);
23
- } else {
24
- const errors = await bw.getErrors();
25
- console.log(`validByType.Error: ${JSON.stringify(errors, null, 2)}`);
26
- }
27
- } else {
28
- const payloadWrapper = PayloadWrapper.wrap(payload);
29
- if (await payloadWrapper.getValid()) {
30
- results[1].push(payload);
31
- }
32
- }
33
- })
34
- );
35
- return results;
36
- };
37
-
38
- // src/Archivist.ts
39
- var MongoDBArchivistBase = MongoDBModuleMixin(AbstractArchivist);
40
- var MongoDBArchivist = class extends MongoDBArchivistBase {
41
- static configSchemas = [...super.configSchemas, MongoDBArchivistConfigSchema];
42
- static defaultConfigSchema = MongoDBArchivistConfigSchema;
43
- queries = [ArchivistInsertQuerySchema, ArchivistNextQuerySchema, ...super.queries];
44
- /**
45
- * The amount of time to allow the aggregate query to execute
46
- */
47
- aggregateTimeoutMs = 1e4;
48
- async findOneByHash(hash) {
49
- const dataPayload = await this.payloads.findOne({ _$hash: hash });
50
- if (dataPayload) {
51
- return dataPayload;
52
- } else {
53
- const dataBw = await this.boundWitnesses.findOne({ _$hash: hash });
54
- if (dataBw) {
55
- return dataBw;
56
- } else {
57
- const payload = await this.payloads.findOne({ _hash: hash });
58
- if (payload) {
59
- return payload;
60
- } else {
61
- const bw = await this.boundWitnesses.findOne({ _hash: hash });
62
- return bw ?? void 0;
63
- }
64
- }
65
- }
66
- }
67
- async findOneBySequence(sequence) {
68
- const dataPayload = await this.payloads.findOne({ _sequence: sequence });
69
- if (dataPayload) {
70
- return dataPayload;
71
- } else {
72
- const dataBw = await this.boundWitnesses.findOne({ _sequence: sequence });
73
- return dataBw;
74
- }
75
- }
76
- async getHandler(hashes) {
77
- let remainingHashes = [...hashes];
78
- const dataPayloads = (await Promise.all(remainingHashes.map((_dataHash) => this.payloads.findOne({ _dataHash })))).filter(exists);
79
- const dataPayloadsHashes = new Set(dataPayloads.map((payload) => payload._dataHash));
80
- remainingHashes = remainingHashes.filter((hash) => !dataPayloadsHashes.has(hash));
81
- const dataBws = (await Promise.all(remainingHashes.map((_dataHash) => this.boundWitnesses.findOne({ _dataHash })))).filter(exists);
82
- const dataBwsHashes = new Set(dataBws.map((payload) => payload._dataHash));
83
- remainingHashes = remainingHashes.filter((hash) => !dataBwsHashes.has(hash));
84
- const payloads = (await Promise.all(remainingHashes.map((_hash) => this.payloads.findOne({ _hash })))).filter(exists);
85
- const payloadsHashes = new Set(payloads.map((payload) => payload._hash));
86
- remainingHashes = remainingHashes.filter((hash) => !payloadsHashes.has(hash));
87
- const bws = (await Promise.all(remainingHashes.map((_hash) => this.boundWitnesses.findOne({ _hash })))).filter(exists);
88
- const bwsHashes = new Set(bws.map((payload) => payload._hash));
89
- remainingHashes = remainingHashes.filter((hash) => !bwsHashes.has(hash));
90
- const foundPayloads = [...dataPayloads, ...dataBws, ...payloads, ...bws];
91
- const result = foundPayloads.map(fromDbRepresentation);
92
- return result;
93
- }
94
- async insertHandler(payloads) {
95
- const [bw, p] = await validByType(payloads);
96
- const payloadsWithExternalMeta = p.map((value) => toDbRepresentation(value));
97
- if (payloadsWithExternalMeta.length > 0) {
98
- const payloadsResult = await this.payloads.insertMany(payloadsWithExternalMeta);
99
- if (!payloadsResult.acknowledged || payloadsResult.insertedCount !== payloadsWithExternalMeta.length)
100
- throw new Error("MongoDBArchivist: Error inserting Payloads");
101
- }
102
- const boundWitnessesWithExternalMeta = bw.map((value) => toDbRepresentation(value));
103
- if (boundWitnessesWithExternalMeta.length > 0) {
104
- const boundWitnessesResult = await this.boundWitnesses.insertMany(boundWitnessesWithExternalMeta);
105
- if (!boundWitnessesResult.acknowledged || boundWitnessesResult.insertedCount !== boundWitnessesWithExternalMeta.length)
106
- throw new Error("MongoDBArchivist: Error inserting BoundWitnesses");
107
- }
108
- return [...boundWitnessesWithExternalMeta, ...payloadsWithExternalMeta].map(fromDbRepresentation);
109
- }
110
- async nextHandler(options) {
111
- let {
112
- limit,
113
- cursor,
114
- order,
115
- open
116
- } = options ?? { limit: 10, order: "desc" };
117
- if (!limit) limit = 10;
118
- if (limit > 100) limit = 100;
119
- if (order != "asc") order = "desc";
120
- let id;
121
- if (cursor) {
122
- const payload = await this.findOneBySequence(cursor);
123
- if (payload) id = payload._id;
124
- } else {
125
- id = order === "asc" ? ObjectId.createFromTime(0) : ObjectId.createFromTime((Date.now() + 1e4) / 1e3);
126
- }
127
- if (!id) return [];
128
- const sort = order === "asc" ? 1 : -1;
129
- const match = order === "asc" ? open ? { _id: { $gte: id } } : { _id: { $gt: id } } : open ? { _id: { $lte: id } } : { _id: { $lt: id } };
130
- const foundPayloads = await this.payloads.useCollection((collection) => {
131
- return collection.aggregate([
132
- // Pre-filter payloads collection
133
- { $match: match },
134
- // Sort payloads by _id
135
- { $sort: { _id: sort } },
136
- // Limit payloads to the first N payloads
137
- { $limit: limit },
138
- // Combine with filtered boundWitnesses collection
139
- {
140
- $unionWith: {
141
- coll: this.boundWitnessSdkConfig.collection,
142
- pipeline: [
143
- { $match: match },
144
- // Pre-filter boundWitnesses
145
- { $sort: { _id: sort } },
146
- // Sort boundWitnesses by _id
147
- { $limit: limit }
148
- // Limit boundWitnesses to the first N boundWitnesses
149
- ]
150
- }
151
- },
152
- // Sort the combined result by _id
153
- { $sort: { _id: sort } },
154
- // Limit the final result to N documents
155
- { $limit: limit }
156
- ]).maxTimeMS(this.aggregateTimeoutMs).toArray();
157
- });
158
- return foundPayloads.map(fromDbRepresentation);
159
- }
160
- async startHandler() {
161
- await super.startHandler();
162
- await this.ensureIndexes();
163
- return true;
164
- }
165
- };
166
-
167
- // src/ArchivistV2.ts
168
- import { exists as exists2 } from "@xylabs/exists";
169
- import { AbstractArchivist as AbstractArchivist2 } from "@xyo-network/archivist-abstract";
170
- import { ArchivistInsertQuerySchema as ArchivistInsertQuerySchema2, ArchivistNextQuerySchema as ArchivistNextQuerySchema2 } from "@xyo-network/archivist-model";
171
- import { MongoDBArchivistConfigSchema as MongoDBArchivistConfigSchema2 } from "@xyo-network/archivist-model-mongodb";
172
- import { MongoDBModuleMixinV2 } from "@xyo-network/module-abstract-mongodb";
173
- import {
174
- SequenceConstants
175
- } from "@xyo-network/payload-model";
176
- import { fromDbRepresentation as fromDbRepresentation2, toDbRepresentation as toDbRepresentation2 } from "@xyo-network/payload-mongodb";
177
- var MongoDBArchivistBaseV2 = MongoDBModuleMixinV2(AbstractArchivist2);
178
- var MONGODB_DUPLICATE_KEY_ERROR = 11e3;
179
- var MongoDBArchivistV2 = class extends MongoDBArchivistBaseV2 {
180
- static configSchemas = [...super.configSchemas, MongoDBArchivistConfigSchema2];
181
- static defaultConfigSchema = MongoDBArchivistConfigSchema2;
182
- queries = [ArchivistInsertQuerySchema2, ArchivistNextQuerySchema2, ...super.queries];
183
- /**
184
- * The amount of time to allow the aggregate query to execute
185
- */
186
- aggregateTimeoutMs = 1e4;
187
- async findOneByHash(hash) {
188
- const dataPayload = await this.payloads.findOne({ _$hash: hash });
189
- if (dataPayload) {
190
- return dataPayload;
191
- } else {
192
- const payload = await this.payloads.findOne({ _hash: hash });
193
- if (payload) {
194
- return payload;
195
- }
196
- }
197
- }
198
- async findOneBySequence(sequence) {
199
- const dataPayload = await this.payloads.findOne({ _sequence: sequence });
200
- if (dataPayload) {
201
- return dataPayload;
202
- }
203
- }
204
- async getHandler(hashes) {
205
- let remainingHashes = [...hashes];
206
- const dataPayloads = (await Promise.all(remainingHashes.map((_dataHash) => this.payloads.findOne({ _dataHash })))).filter(exists2);
207
- const dataPayloadsHashes = new Set(dataPayloads.map((payload) => payload._dataHash));
208
- remainingHashes = remainingHashes.filter((hash) => !dataPayloadsHashes.has(hash));
209
- const payloads = (await Promise.all(remainingHashes.map((_hash) => this.payloads.findOne({ _hash })))).filter(exists2);
210
- const payloadsHashes = new Set(payloads.map((payload) => payload._hash));
211
- remainingHashes = remainingHashes.filter((hash) => !payloadsHashes.has(hash));
212
- const foundPayloads = [...dataPayloads, ...payloads];
213
- const result = foundPayloads.map(fromDbRepresentation2);
214
- return result;
215
- }
216
- async insertHandler(payloads) {
217
- const payloadsWithExternalMeta = payloads.map((value) => toDbRepresentation2(value));
218
- if (payloadsWithExternalMeta.length > 0) {
219
- try {
220
- const payloadsResult = await this.payloads.insertMany(payloadsWithExternalMeta, { ordered: false });
221
- if (!payloadsResult.acknowledged) throw new Error("MongoDBArchivist: Error inserting Payloads");
222
- } catch (error) {
223
- const mongoError = error;
224
- if (mongoError?.code != MONGODB_DUPLICATE_KEY_ERROR) throw error;
225
- }
226
- }
227
- return [...payloadsWithExternalMeta].map(fromDbRepresentation2);
228
- }
229
- async nextHandler(options) {
230
- let {
231
- limit,
232
- cursor,
233
- order,
234
- open = true
235
- } = options ?? { limit: 10, order: "desc" };
236
- if (!limit) limit = 10;
237
- if (limit > 100) limit = 100;
238
- if (order != "asc") order = "desc";
239
- let sequence;
240
- if (cursor) {
241
- const payload = await this.findOneBySequence(cursor);
242
- if (payload) sequence = payload._sequence;
243
- } else {
244
- sequence = order === "asc" ? SequenceConstants.minLocalSequence : SequenceConstants.maxLocalSequence;
245
- }
246
- if (!sequence) return [];
247
- const sort = order === "asc" ? 1 : -1;
248
- const match = order === "asc" ? open ? { _sequence: { $gt: sequence } } : { _sequence: { $gte: sequence } } : open ? { _sequence: { $lt: sequence } } : { _sequence: { $lte: sequence } };
249
- const foundPayloads = await this.payloads.useCollection((collection) => {
250
- return collection.aggregate([
251
- // Pre-filter payloads collection
252
- { $match: match },
253
- // Sort payloads by _sequence
254
- { $sort: { _sequence: sort } },
255
- // Limit payloads to the first N payloads
256
- { $limit: limit }
257
- ]).maxTimeMS(this.aggregateTimeoutMs).toArray();
258
- });
259
- return foundPayloads.map(fromDbRepresentation2);
260
- }
261
- async startHandler() {
262
- await super.startHandler();
263
- await this.ensureIndexes();
264
- return true;
265
- }
266
- };
267
-
268
- // src/index.ts
269
- export * from "@xyo-network/archivist-model-mongodb";
270
- export {
271
- MongoDBArchivist,
272
- MongoDBArchivistV2
273
- };
274
- //# sourceMappingURL=index.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/Archivist.ts","../../src/lib/validByType.ts","../../src/ArchivistV2.ts","../../src/index.ts"],"sourcesContent":["import { exists } from '@xylabs/exists'\nimport type { Hash } from '@xylabs/hex'\nimport { AbstractArchivist } from '@xyo-network/archivist-abstract'\nimport type { ArchivistNextOptions } from '@xyo-network/archivist-model'\nimport { ArchivistInsertQuerySchema, ArchivistNextQuerySchema } from '@xyo-network/archivist-model'\nimport { MongoDBArchivistConfigSchema } from '@xyo-network/archivist-model-mongodb'\nimport { MongoDBModuleMixin } from '@xyo-network/module-abstract-mongodb'\nimport type {\n Payload, Schema, Sequence, WithStorageMeta,\n} from '@xyo-network/payload-model'\nimport type { PayloadWithMongoMeta } from '@xyo-network/payload-mongodb'\nimport { fromDbRepresentation, toDbRepresentation } from '@xyo-network/payload-mongodb'\nimport { ObjectId } from 'mongodb'\n\nimport { validByType } from './lib/index.js'\n\nconst MongoDBArchivistBase = MongoDBModuleMixin(AbstractArchivist)\n\nexport class MongoDBArchivist extends MongoDBArchivistBase {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, MongoDBArchivistConfigSchema]\n static override readonly defaultConfigSchema: Schema = MongoDBArchivistConfigSchema\n\n override readonly queries: string[] = [ArchivistInsertQuerySchema, ArchivistNextQuerySchema, ...super.queries]\n\n /**\n * The amount of time to allow the aggregate query to execute\n */\n protected readonly aggregateTimeoutMs = 10_000\n\n protected async findOneByHash(hash: Hash) {\n const dataPayload = (await this.payloads.findOne({ _$hash: hash }))\n if (dataPayload) {\n return dataPayload\n } else {\n const dataBw = (await this.boundWitnesses.findOne({ _$hash: hash }))\n if (dataBw) {\n return dataBw\n } else {\n const payload = (await this.payloads.findOne({ _hash: hash }))\n if (payload) {\n return payload\n } else {\n const bw = (await this.boundWitnesses.findOne({ _hash: hash }))\n return bw ?? undefined\n }\n }\n }\n }\n\n protected async findOneBySequence(sequence: Sequence) {\n const dataPayload = (await this.payloads.findOne({ _sequence: sequence }))\n if (dataPayload) {\n return dataPayload\n } else {\n const dataBw = (await this.boundWitnesses.findOne({ _sequence: sequence }))\n return dataBw\n }\n }\n\n protected override async getHandler(hashes: Hash[]): Promise<WithStorageMeta<Payload>[]> {\n let remainingHashes = [...hashes]\n\n const dataPayloads = (await Promise.all(remainingHashes.map(_dataHash => this.payloads.findOne({ _dataHash })))).filter(exists)\n const dataPayloadsHashes = new Set(dataPayloads.map(payload => payload._dataHash))\n remainingHashes = remainingHashes.filter(hash => !dataPayloadsHashes.has(hash))\n\n const dataBws = (await Promise.all(remainingHashes.map(_dataHash => this.boundWitnesses.findOne({ _dataHash })))).filter(exists)\n const dataBwsHashes = new Set(dataBws.map(payload => payload._dataHash))\n remainingHashes = remainingHashes.filter(hash => !dataBwsHashes.has(hash))\n\n const payloads = (await Promise.all(remainingHashes.map(_hash => this.payloads.findOne({ _hash })))).filter(exists)\n const payloadsHashes = new Set(payloads.map(payload => payload._hash))\n remainingHashes = remainingHashes.filter(hash => !payloadsHashes.has(hash))\n\n const bws = (await Promise.all(remainingHashes.map(_hash => this.boundWitnesses.findOne({ _hash })))).filter(exists)\n const bwsHashes = new Set(bws.map(payload => payload._hash))\n // eslint-disable-next-line sonarjs/no-dead-store\n remainingHashes = remainingHashes.filter(hash => !bwsHashes.has(hash))\n\n const foundPayloads = [...dataPayloads, ...dataBws, ...payloads, ...bws] as PayloadWithMongoMeta<Payload>[]\n const result = foundPayloads.map(fromDbRepresentation)\n // console.log(`getHandler: ${JSON.stringify(hashes, null, 2)}:${JSON.stringify(result, null, 2)}`)\n return result\n }\n\n protected override async insertHandler(payloads: WithStorageMeta<Payload>[]): Promise<WithStorageMeta<Payload>[]> {\n const [bw, p] = await validByType(payloads)\n const payloadsWithExternalMeta = p.map(value => toDbRepresentation(value))\n if (payloadsWithExternalMeta.length > 0) {\n const payloadsResult = await this.payloads.insertMany(payloadsWithExternalMeta)\n if (!payloadsResult.acknowledged || payloadsResult.insertedCount !== payloadsWithExternalMeta.length)\n throw new Error('MongoDBArchivist: Error inserting Payloads')\n }\n\n const boundWitnessesWithExternalMeta = bw.map(value => toDbRepresentation(value))\n if (boundWitnessesWithExternalMeta.length > 0) {\n const boundWitnessesResult = await this.boundWitnesses.insertMany(boundWitnessesWithExternalMeta)\n if (!boundWitnessesResult.acknowledged || boundWitnessesResult.insertedCount !== boundWitnessesWithExternalMeta.length)\n throw new Error('MongoDBArchivist: Error inserting BoundWitnesses')\n }\n\n return [...boundWitnessesWithExternalMeta, ...payloadsWithExternalMeta].map(fromDbRepresentation)\n }\n\n protected override async nextHandler(options?: ArchivistNextOptions): Promise<WithStorageMeta<Payload>[]> {\n // Sanitize inputs and set defaults\n let {\n limit, cursor, order, open,\n } = options ?? { limit: 10, order: 'desc' }\n\n if (!limit) limit = 10\n if (limit > 100) limit = 100\n\n if (order != 'asc') order = 'desc'\n\n let id: ObjectId | undefined\n if (cursor) {\n const payload = await this.findOneBySequence(cursor)\n // TODO: Should we throw an error if the requested payload is not found?\n if (payload) id = payload._id\n } else {\n id = order === 'asc'\n // If ascending, start from the beginning of time\n ? ObjectId.createFromTime(0)\n // If descending, start from now (plus a bit more in the future to ensure\n // them most recent ObjectIds are included)\n : ObjectId.createFromTime((Date.now() + 10_000) / 1000)\n }\n if (!id) return []\n\n // Create aggregate criteria\n const sort = order === 'asc' ? 1 : -1\n // TODO: How to handle random component of ID across multiple collections\n // to ensure we don't skip some payloads\n const match = order === 'asc' ? (open ? { _id: { $gte: id } } : { _id: { $gt: id } }) : (open ? { _id: { $lte: id } } : { _id: { $lt: id } })\n\n // Run the aggregate query\n const foundPayloads = await this.payloads.useCollection((collection) => {\n return collection\n .aggregate<PayloadWithMongoMeta>([\n // Pre-filter payloads collection\n { $match: match },\n // Sort payloads by _id\n { $sort: { _id: sort } },\n // Limit payloads to the first N payloads\n { $limit: limit },\n // Combine with filtered boundWitnesses collection\n {\n $unionWith: {\n coll: this.boundWitnessSdkConfig.collection,\n pipeline: [\n { $match: match }, // Pre-filter boundWitnesses\n { $sort: { _id: sort } }, // Sort boundWitnesses by _id\n { $limit: limit }, // Limit boundWitnesses to the first N boundWitnesses\n ],\n },\n },\n // Sort the combined result by _id\n { $sort: { _id: sort } },\n // Limit the final result to N documents\n { $limit: limit },\n ])\n .maxTimeMS(this.aggregateTimeoutMs)\n .toArray()\n })\n\n // Convert from DB representation to Payloads\n return foundPayloads.map(fromDbRepresentation)\n }\n\n protected override async startHandler() {\n await super.startHandler()\n await this.ensureIndexes()\n return true\n }\n}\n","import type { BoundWitness } from '@xyo-network/boundwitness-model'\nimport { isBoundWitness, isQueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { BoundWitnessWrapper, QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport type { Payload, WithStorageMeta } from '@xyo-network/payload-model'\nimport { PayloadWrapper } from '@xyo-network/payload-wrapper'\n\nexport const validByType = async (payloads: WithStorageMeta<Payload>[] = []) => {\n const results: [WithStorageMeta<BoundWitness>[], WithStorageMeta<Payload>[]] = [[], []]\n await Promise.all(\n payloads.map(async (payload) => {\n if (isBoundWitness(payload)) {\n const wrapper = isQueryBoundWitness(payload) ? QueryBoundWitnessWrapper : BoundWitnessWrapper\n const bw = wrapper.parse(payload)\n if (await bw.getValid()) {\n results[0].push(payload)\n } else {\n const errors = await bw.getErrors()\n console.log(`validByType.Error: ${JSON.stringify(errors, null, 2)}`)\n }\n } else {\n const payloadWrapper = PayloadWrapper.wrap(payload)\n if (await payloadWrapper.getValid()) {\n results[1].push(payload)\n }\n }\n }),\n )\n return results\n}\n","import { exists } from '@xylabs/exists'\nimport type { Hash } from '@xylabs/hex'\nimport { AbstractArchivist } from '@xyo-network/archivist-abstract'\nimport type { ArchivistNextOptions } from '@xyo-network/archivist-model'\nimport { ArchivistInsertQuerySchema, ArchivistNextQuerySchema } from '@xyo-network/archivist-model'\nimport { MongoDBArchivistConfigSchema } from '@xyo-network/archivist-model-mongodb'\nimport { MongoDBModuleMixinV2 } from '@xyo-network/module-abstract-mongodb'\nimport {\n type Payload, type Schema, type Sequence, SequenceConstants,\n type WithStorageMeta,\n} from '@xyo-network/payload-model'\nimport type { PayloadWithMongoMeta } from '@xyo-network/payload-mongodb'\nimport { fromDbRepresentation, toDbRepresentation } from '@xyo-network/payload-mongodb'\nimport type { MongoError } from 'mongodb'\n\nconst MongoDBArchivistBaseV2 = MongoDBModuleMixinV2(AbstractArchivist)\n\nconst MONGODB_DUPLICATE_KEY_ERROR = 11_000\n\nexport class MongoDBArchivistV2 extends MongoDBArchivistBaseV2 {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, MongoDBArchivistConfigSchema]\n static override readonly defaultConfigSchema: Schema = MongoDBArchivistConfigSchema\n\n override readonly queries: string[] = [ArchivistInsertQuerySchema, ArchivistNextQuerySchema, ...super.queries]\n\n /**\n * The amount of time to allow the aggregate query to execute\n */\n protected readonly aggregateTimeoutMs = 10_000\n\n protected async findOneByHash(hash: Hash) {\n const dataPayload = (await this.payloads.findOne({ _$hash: hash }))\n if (dataPayload) {\n return dataPayload\n } else {\n const payload = (await this.payloads.findOne({ _hash: hash }))\n if (payload) {\n return payload\n }\n }\n }\n\n protected async findOneBySequence(sequence: Sequence) {\n const dataPayload = (await this.payloads.findOne({ _sequence: sequence }))\n if (dataPayload) {\n return dataPayload\n }\n }\n\n protected override async getHandler(hashes: Hash[]): Promise<WithStorageMeta<Payload>[]> {\n let remainingHashes = [...hashes]\n\n const dataPayloads = (await Promise.all(remainingHashes.map(_dataHash => this.payloads.findOne({ _dataHash })))).filter(exists)\n const dataPayloadsHashes = new Set(dataPayloads.map(payload => payload._dataHash))\n remainingHashes = remainingHashes.filter(hash => !dataPayloadsHashes.has(hash))\n\n const payloads = (await Promise.all(remainingHashes.map(_hash => this.payloads.findOne({ _hash })))).filter(exists)\n const payloadsHashes = new Set(payloads.map(payload => payload._hash))\n // eslint-disable-next-line sonarjs/no-dead-store\n remainingHashes = remainingHashes.filter(hash => !payloadsHashes.has(hash))\n\n const foundPayloads = [...dataPayloads, ...payloads] as PayloadWithMongoMeta<Payload>[]\n const result = foundPayloads.map(fromDbRepresentation)\n return result\n }\n\n protected override async insertHandler(payloads: WithStorageMeta<Payload>[]): Promise<WithStorageMeta<Payload>[]> {\n const payloadsWithExternalMeta = payloads.map(value => toDbRepresentation(value))\n if (payloadsWithExternalMeta.length > 0) {\n try {\n const payloadsResult = await this.payloads.insertMany(payloadsWithExternalMeta, { ordered: false })\n if (!payloadsResult.acknowledged) throw new Error('MongoDBArchivist: Error inserting Payloads')\n } catch (error) {\n const mongoError = error as MongoError\n // NOTE: Intentional coercive equality since Mongo error codes are\n // of type string | number\n if (mongoError?.code != MONGODB_DUPLICATE_KEY_ERROR) throw error\n }\n }\n return [...payloadsWithExternalMeta].map(fromDbRepresentation)\n }\n\n protected override async nextHandler(options?: ArchivistNextOptions): Promise<WithStorageMeta<Payload>[]> {\n // Sanitize inputs and set defaults\n let {\n limit, cursor, order, open = true,\n } = options ?? { limit: 10, order: 'desc' }\n\n if (!limit) limit = 10\n if (limit > 100) limit = 100\n\n if (order != 'asc') order = 'desc'\n\n let sequence: Sequence | undefined\n if (cursor) {\n const payload = await this.findOneBySequence(cursor)\n // TODO: Should we throw an error if the requested payload is not found?\n if (payload) sequence = payload._sequence\n } else {\n sequence = order === 'asc'\n // If ascending, start from the beginning of time\n ? SequenceConstants.minLocalSequence\n // If descending, start from now (plus a bit more in the future to ensure\n // them most recent ObjectIds are included)\n : SequenceConstants.maxLocalSequence\n }\n if (!sequence) return []\n\n // Create find criteria\n const sort = order === 'asc' ? 1 : -1\n\n const match = order === 'asc'\n ? (open\n ? { _sequence: { $gt: sequence } }\n : { _sequence: { $gte: sequence } })\n : (open\n ? { _sequence: { $lt: sequence } }\n : { _sequence: { $lte: sequence } })\n\n // Run the aggregate query\n const foundPayloads = await this.payloads.useCollection((collection) => {\n return collection\n .aggregate<PayloadWithMongoMeta>([\n // Pre-filter payloads collection\n { $match: match },\n // Sort payloads by _sequence\n { $sort: { _sequence: sort } },\n // Limit payloads to the first N payloads\n { $limit: limit },\n ])\n .maxTimeMS(this.aggregateTimeoutMs)\n .toArray()\n })\n\n // Convert from DB representation to Payloads\n return foundPayloads.map(fromDbRepresentation)\n }\n\n protected override async startHandler() {\n await super.startHandler()\n await this.ensureIndexes()\n return true\n }\n}\n","export * from './Archivist.js'\nexport * from './ArchivistV2.ts'\nexport * from '@xyo-network/archivist-model-mongodb'\n"],"mappings":"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","names":["exists","AbstractArchivist","ArchivistInsertQuerySchema","ArchivistNextQuerySchema","MongoDBArchivistConfigSchema","fromDbRepresentation","toDbRepresentation"]}